
:root {
  --paper: #faf6ef; --paper-deep: #f3ecdf; --card: #fffdf8;
  --ink: #1c2434; --ink-soft: #4c5568; --ink-faint: #8b93a5; --line: #e4dccb;
  --accent: #d64524; --accent-deep: #b53617; --accent-wash: #fbe9e2;
  --leaf: #2e7d5b; --leaf-wash: #e2f0e8; --gold: #c9972b; --gold-wash: #f9efd8;
  --shadow: 0 1px 2px rgb(28 36 52 / .05), 0 6px 24px -8px rgb(28 36 52 / .12);
  --lift: 0 2px 4px rgb(28 36 52 / .06), 0 16px 40px -12px rgb(28 36 52 / .18);
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0; background: var(--paper); color: var(--ink);
  font: 16px/1.6 'Karla', 'Helvetica Neue', sans-serif;
  -webkit-font-smoothing: antialiased;
  background-image: radial-gradient(rgb(28 36 52 / .025) 1px, transparent 1px);
  background-size: 22px 22px;
}
h1, h2, h3, .display { font-family: 'Fraunces', Georgia, serif; font-weight: 600; letter-spacing: -.01em; line-height: 1.15; }
a { color: var(--accent-deep); }
img { max-width: 100%; }
::selection { background: var(--accent-wash); color: var(--accent-deep); }
.wrap { max-width: 960px; margin: 0 auto; padding: 0 20px; }
.narrow { max-width: 720px; }

/* header */
.site-header { position: sticky; top: 0; z-index: 50; background: rgb(250 246 239 / .88); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.site-header .bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 0; }
.brand { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--ink); font-family: 'Fraunces', serif; font-size: 21px; font-weight: 600; }
.brand svg { width: 32px; height: 32px; }
.site-nav { display: flex; align-items: center; gap: 4px; }
.site-nav a { text-decoration: none; color: var(--ink-soft); font-weight: 600; font-size: 14.5px; padding: 7px 12px; border-radius: 999px; }
.site-nav a:hover { background: var(--paper-deep); color: var(--ink); }
.site-nav a.active { background: var(--ink); color: var(--paper); }
.btn { display: inline-block; background: var(--accent); color: #fff !important; text-decoration: none; font-weight: 700; font-size: 14.5px; padding: 9px 20px; border-radius: 999px; border: 0; cursor: pointer; transition: background .15s, transform .15s; }
.btn:hover { background: var(--accent-deep); transform: translateY(-1px); }
.btn.big { font-size: 16px; padding: 13px 30px; }
.btn.ghost { background: transparent; color: var(--ink) !important; border: 1.5px solid var(--line); }
.btn.ghost:hover { background: var(--paper-deep); }
.nav-toggle { display: none; }
@media (max-width: 640px) {
  .site-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; align-items: stretch; background: var(--card); border-bottom: 1px solid var(--line); padding: 10px 16px 16px; box-shadow: var(--lift); }
  .site-nav a { padding: 12px 14px; font-size: 16px; }
  .nav-open .site-nav { display: flex; }
  .nav-toggle { display: grid; place-items: center; width: 40px; height: 40px; background: none; border: 1.5px solid var(--line); border-radius: 12px; color: var(--ink); cursor: pointer; }
}

/* hero */
.hero { padding: 72px 0 56px; }
.eyebrow { font-size: 12px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--accent); margin: 0 0 14px; }
.hero h1 { font-size: clamp(38px, 7vw, 62px); margin: 0 0 18px; }
.hero h1 .dot { color: var(--accent); }
.hero p.lead { font-size: 19px; color: var(--ink-soft); max-width: 34em; margin: 0 0 28px; }
.hero-stats { display: flex; flex-wrap: wrap; gap: 26px; margin-top: 40px; }
.hero-stats div strong { display: block; font-family: 'Fraunces', serif; font-size: 30px; font-weight: 600; }
.hero-stats div span { font-size: 13px; color: var(--ink-faint); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }

/* cards & sections */
.section { padding: 56px 0; }
.section h2 { font-size: clamp(26px, 4.4vw, 36px); margin: 0 0 10px; }
.section p.sub { color: var(--ink-soft); margin: 0 0 32px; max-width: 40em; }
.grid { display: grid; gap: 16px; }
@media (min-width: 640px) { .grid.cols-2 { grid-template-columns: 1fr 1fr; } .grid.cols-3 { grid-template-columns: repeat(3, 1fr); } }
.card { background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 24px; box-shadow: var(--shadow); }
.card h3 { font-size: 19px; margin: 0 0 8px; }
.card p { margin: 0; font-size: 15px; color: var(--ink-soft); }
.card .glyph { font-family: 'Fraunces', serif; font-size: 26px; color: var(--accent); display: block; margin-bottom: 12px; }
.dark-cta { background: var(--ink); color: var(--paper); border-radius: 22px; padding: 44px 32px; text-align: center; box-shadow: var(--lift); position: relative; overflow: hidden; }
.dark-cta::before { content: ''; position: absolute; top: -60px; right: -60px; width: 220px; height: 220px; border-radius: 50%; background: radial-gradient(circle, var(--accent), transparent 70%); opacity: .25; pointer-events: none; }
.dark-cta h2 { color: var(--paper); }
.dark-cta p { color: rgb(250 246 239 / .75); }

/* tables */
table.spec { width: 100%; border-collapse: collapse; background: var(--card); border-radius: 16px; overflow: hidden; box-shadow: var(--shadow); font-size: 15px; }
table.spec th, table.spec td { text-align: left; padding: 12px 16px; border-bottom: 1px solid var(--line); }
table.spec th { background: var(--paper-deep); font-size: 12.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-soft); }
table.spec tr:last-child td { border-bottom: 0; }
.table-scroll { overflow-x: auto; border-radius: 16px; }

/* faq */
details.faq { background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 4px 20px; margin-bottom: 10px; box-shadow: var(--shadow); }
details.faq summary { cursor: pointer; font-weight: 700; padding: 14px 0; list-style: none; }
details.faq summary::-webkit-details-marker { display: none; }
details.faq summary::after { content: '+'; float: right; font-family: 'Fraunces', serif; font-size: 20px; color: var(--accent); }
details.faq[open] summary::after { content: '–'; }
details.faq p { margin: 0 0 16px; color: var(--ink-soft); font-size: 15px; }

/* blog */
.post-card { display: block; text-decoration: none; color: var(--ink); background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 26px; box-shadow: var(--shadow); transition: transform .15s; }
.post-card:hover { transform: translateY(-3px); }
.post-card .meta { font-size: 12.5px; color: var(--ink-faint); font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.post-card h3 { margin: 8px 0; font-size: 21px; }
.post-card p { margin: 0; color: var(--ink-soft); font-size: 15px; }
.post-card .more { display: inline-block; margin-top: 14px; color: var(--accent-deep); font-weight: 700; font-size: 14px; }

/* article */
article.post { padding: 56px 0 24px; }
article.post h1 { font-size: clamp(30px, 5.5vw, 44px); margin: 8px 0 14px; }
article.post .byline { color: var(--ink-faint); font-size: 14px; margin-bottom: 36px; }
article.post h2 { font-size: 26px; margin: 40px 0 12px; }
article.post h3 { font-size: 20px; margin: 28px 0 10px; }
article.post p, article.post li { color: var(--ink-soft); font-size: 16.5px; line-height: 1.75; }
article.post strong { color: var(--ink); }
article.post blockquote { margin: 24px 0; padding: 16px 22px; background: var(--gold-wash); border-left: 3px solid var(--gold); border-radius: 0 14px 14px 0; }
article.post blockquote p { margin: 0; }

/* forms */
.field { display: block; margin-bottom: 16px; }
.field span { display: block; font-size: 13px; font-weight: 700; margin-bottom: 6px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .05em; }
.field input, .field textarea { width: 100%; border: 1.5px solid var(--line); background: var(--card); border-radius: 14px; padding: 12px 14px; font: inherit; color: var(--ink); }
.field input:focus, .field textarea:focus { outline: 2px solid var(--accent); outline-offset: 1px; border-color: transparent; }

/* footer */
.site-footer { margin-top: 72px; border-top: 1px solid var(--line); background: var(--paper-deep); }
.site-footer .cols { display: grid; gap: 32px; padding: 44px 0 28px; }
@media (min-width: 640px) { .site-footer .cols { grid-template-columns: 2fr 1fr 1fr 1fr; } }
.site-footer h4 { font-size: 12.5px; text-transform: uppercase; letter-spacing: .1em; color: var(--ink-faint); margin: 0 0 12px; }
.site-footer ul { list-style: none; margin: 0; padding: 0; }
.site-footer li { margin-bottom: 8px; }
.site-footer a { color: var(--ink-soft); text-decoration: none; font-size: 14.5px; }
.site-footer a:hover { color: var(--ink); }
.site-footer .blurb { color: var(--ink-soft); font-size: 14.5px; max-width: 26em; margin: 10px 0 0; }
.site-footer .legal { border-top: 1px solid var(--line); padding: 18px 0 26px; font-size: 13px; color: var(--ink-faint); }
