/* LW Bookkeeping/TaxPrep Inc. — premium mockup by Synvanta AI
   Scene: warm linen ledger desk at dawn. Display: Fraunces. Body: Inter. */

:root{
  --linen:#F4EFE4;
  --paper:#FBF8F1;
  --paper-2:#EFE8D9;
  --ink:#1C2A38;
  --ink-soft:#56657A;
  --green:#2F5D50;
  --green-deep:#21443A;
  --green-tint:#E7EEEA;
  --brass:#C2913C;
  --brass-soft:#D8B872;
  --line:#E4DCCC;
  --shadow: 0 18px 50px -24px rgba(28,42,56,.35);
  --shadow-sm: 0 6px 20px -12px rgba(28,42,56,.30);

  --u:8px;
  --maxw:1120px;
  --r:16px;
  --ease:cubic-bezier(.16,1,.3,1);

  --synvanta:#2850F0;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--linen);
  color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--green-deep); }
h1,h2,h3{ font-family:"Fraunces",Georgia,"Times New Roman",serif; font-weight:600; line-height:1.08; letter-spacing:-.01em; margin:0; color:var(--ink); }
h1{ font-size:clamp(40px,7vw,76px); }
h2{ font-size:clamp(30px,4.6vw,50px); }
h3{ font-size:clamp(20px,2.4vw,26px); letter-spacing:0; }
p{ margin:0; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.eyebrow{
  font-family:"Inter",sans-serif; font-weight:600; font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--green); margin:0 0 14px;
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--brass); display:inline-block; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:"Inter",sans-serif; font-weight:600; font-size:16px;
  border-radius:999px; padding:15px 28px; text-decoration:none; cursor:pointer;
  border:1px solid transparent; transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.btn-primary{ background:var(--green); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:var(--green-deep); transform:translateY(-2px); box-shadow:var(--shadow); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--green); transform:translateY(-2px); }
.btn svg{ width:18px; height:18px; }

/* Nav */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px; transition:background .3s var(--ease), box-shadow .3s var(--ease), padding .3s var(--ease);
}
.nav.scrolled{ background:rgba(244,239,228,.86); backdrop-filter:blur(10px); box-shadow:0 1px 0 var(--line); padding:12px 24px; }
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--ink); }
.brand .mark{ width:38px; height:38px; }
.brand b{ font-family:"Fraunces",serif; font-weight:600; font-size:19px; letter-spacing:-.01em; }
.brand span{ display:block; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); font-weight:600; }
.nav-links{ display:flex; align-items:center; gap:28px; }
.nav-links a{ text-decoration:none; color:var(--ink); font-weight:500; font-size:15px; }
.nav-links a.text:hover{ color:var(--green); }
.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; transition:.25s var(--ease); }

/* Hero */
.hero{ position:relative; padding:150px 0 90px; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.hero h1 .accent{ color:var(--green); font-style:italic; }
.hero .lede{ font-size:clamp(18px,2.2vw,21px); color:var(--ink-soft); margin:24px 0 32px; max-width:34ch; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-fine{ margin-top:18px; font-size:14px; color:var(--ink-soft); display:flex; align-items:center; gap:8px; }
.hero-fine svg{ width:16px; height:16px; color:var(--green); }

/* Hero visual: crafted desk scene. Optional Higgsfield image drops into --hero-img. */
.hero-visual{
  position:relative; aspect-ratio:4/3.4; border-radius:24px; overflow:hidden;
  background:
    radial-gradient(120% 90% at 78% 12%, rgba(216,184,114,.30), transparent 55%),
    linear-gradient(160deg, #36584c 0%, #213f37 60%, #1a332c 100%);
  box-shadow:var(--shadow); border:1px solid rgba(255,255,255,.06);
}
.hero-visual .photo{
  position:absolute; inset:0; background-size:cover; background-position:center;
  background-image:var(--hero-img,none); opacity:var(--hero-img-opacity,0);
}
.hero-visual .glow{ position:absolute; inset:0; background:radial-gradient(80% 60% at 30% 90%, rgba(0,0,0,.30), transparent 60%); }
.ledger-card{
  position:absolute; left:7%; right:7%; bottom:8%;
  background:rgba(251,248,241,.96); border-radius:14px; padding:18px 20px; box-shadow:var(--shadow);
}
.ledger-card .row{ display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px dashed var(--line); font-size:15px; color:var(--ink-soft); }
.ledger-card .row span:last-child{ font-variant-numeric:tabular-nums; color:var(--ink); font-weight:600; }
.ledger-card .row.total{ border-bottom:0; padding-top:14px; }
.ledger-card .row.total span:first-child{ color:var(--ink); font-weight:700; }
.ledger-card .row.total span:last-child{ color:var(--green); font-weight:700; font-size:18px; }
.ledger-tag{ position:absolute; top:18px; left:18px; display:inline-flex; align-items:center; gap:8px; background:rgba(251,248,241,.92); color:var(--green-deep); font-weight:600; font-size:12px; letter-spacing:.12em; text-transform:uppercase; padding:8px 14px; border-radius:999px; }
.ledger-tag i{ width:8px; height:8px; border-radius:50%; background:var(--green); display:inline-block; }
.float-receipt{ position:absolute; width:74px; height:92px; background:var(--paper); border-radius:8px; box-shadow:var(--shadow-sm); opacity:.95; }
.float-receipt::before{ content:""; position:absolute; left:12px; right:12px; top:14px; height:6px; background:var(--line); border-radius:3px; box-shadow:0 12px 0 var(--line), 0 24px 0 var(--line); }
.fr1{ top:12%; left:10%; transform:rotate(-9deg); }
.fr2{ top:20%; right:12%; transform:rotate(8deg); }

/* Proof strip */
.proof{ background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.proof .wrap{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:24px; padding:26px 24px; }
.proof .item{ display:flex; align-items:center; gap:12px; }
.proof .num{ font-family:"Fraunces",serif; font-weight:600; font-size:30px; color:var(--ink); line-height:1; }
.proof .lbl{ font-size:13px; color:var(--ink-soft); max-width:16ch; }
.stars{ color:var(--brass); letter-spacing:2px; font-size:18px; }
.proof .divide{ width:1px; height:38px; background:var(--line); }

/* Generic section */
.section{ padding:96px 0; }
.section.tint{ background:var(--paper); }
.section.deep{ background:var(--green-deep); color:#fff; }
.section.deep h2,.section.deep h3{ color:#fff; }
.section-head{ max-width:60ch; margin-bottom:48px; }
.section-head p{ color:var(--ink-soft); font-size:19px; margin-top:14px; }
.section.deep .section-head p{ color:rgba(255,255,255,.78); }

/* Tension */
.tension-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.tension-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:28px; }
.section.tint .tension-card{ background:var(--linen); }
.tension-card .ic{ width:44px; height:44px; color:var(--green); margin-bottom:16px; }
.tension-card h3{ margin-bottom:8px; }
.tension-card p{ color:var(--ink-soft); font-size:16px; }

/* Services */
.svc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.svc{ display:flex; gap:18px; padding:26px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r); transition:transform .25s var(--ease), box-shadow .25s var(--ease); }
.svc:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.svc .ic{ flex:0 0 auto; width:48px; height:48px; border-radius:12px; background:var(--green-tint); color:var(--green-deep); display:grid; place-items:center; }
.svc .ic svg{ width:26px; height:26px; }
.svc h3{ font-size:20px; margin-bottom:6px; }
.svc p{ color:var(--ink-soft); font-size:16px; }

/* Signature: pinned shoebox -> balanced */
.pin{ position:relative; }
.pin-sticky{ position:sticky; top:0; min-height:100vh; display:grid; place-items:center; overflow:hidden; }
.pin-track{ height:280vh; }
.scene{ width:100%; max-width:var(--maxw); padding:0 24px; }
.scene-inner{ position:relative; display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.scene-copy .step{ opacity:.28; transition:opacity .4s var(--ease); padding:14px 0; border-left:2px solid var(--line); padding-left:22px; margin:6px 0; }
.scene-copy .step.on{ opacity:1; border-color:var(--green); }
.scene-copy .step .k{ font-family:"Inter",sans-serif; font-weight:700; color:var(--brass); font-size:13px; letter-spacing:.16em; text-transform:uppercase; }
.scene-copy .step h3{ margin:6px 0 6px; }
.scene-copy .step p{ color:var(--ink-soft); font-size:16px; }

.stage{ position:relative; aspect-ratio:1/1; background:var(--paper); border:1px solid var(--line); border-radius:24px; box-shadow:var(--shadow); overflow:hidden; }
.stage .box{ position:absolute; left:50%; top:54%; width:46%; height:30%; transform:translate(-50%,-50%); border-radius:10px; background:linear-gradient(180deg,#caa86f,#b5894b); box-shadow:var(--shadow-sm); opacity:var(--box-op,1); }
.stage .box::before{ content:"Receipts"; position:absolute; inset:0; display:grid; place-items:center; color:#5a3f1a; font-weight:700; letter-spacing:.08em; font-size:13px; text-transform:uppercase; }
.rcpt{ position:absolute; width:14%; height:18%; background:var(--linen); border:1px solid var(--line); border-radius:6px; box-shadow:var(--shadow-sm); transition:transform .1s linear, opacity .3s var(--ease); }
.rcpt::before{ content:""; position:absolute; left:14%; right:14%; top:20%; height:3px; background:var(--line); border-radius:2px; box-shadow:0 7px 0 var(--line),0 14px 0 var(--line),0 21px 0 var(--line); }
.ledger-final{ position:absolute; left:8%; right:8%; top:50%; transform:translateY(-50%); background:var(--paper); border-radius:14px; padding:8px 22px; opacity:var(--ledger-op,0); box-shadow:var(--shadow); }
.ledger-final .lf-row{ display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px dashed var(--line); font-size:15px; color:var(--ink-soft); }
.ledger-final .lf-row b{ color:var(--ink); font-variant-numeric:tabular-nums; }
.ledger-final .lf-row.bal{ border-bottom:0; }
.ledger-final .lf-row.bal span{ color:var(--green); font-weight:700; }
.ledger-final .lf-row.bal b{ color:var(--green); font-weight:700; }
.balance-line{ position:absolute; left:8%; right:8%; bottom:16%; height:3px; background:var(--green); transform:scaleX(var(--bal-scale,0)); transform-origin:left; border-radius:2px; }

/* Owner */
.owner-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:center; }
.owner-photo{ position:relative; aspect-ratio:4/5; border-radius:20px; overflow:hidden; box-shadow:var(--shadow);
  background:linear-gradient(160deg,#2f5d50,#21443a); display:grid; place-items:center; }
.owner-photo .ph-label{ position:absolute; bottom:16px; left:16px; right:16px; color:rgba(255,255,255,.82); font-size:13px; letter-spacing:.04em; background:rgba(0,0,0,.18); padding:8px 12px; border-radius:8px; backdrop-filter:blur(4px); }
.owner-photo .ph-mark{ width:120px; height:120px; opacity:.92; }
.owner-grid h2{ margin-bottom:6px; }
.owner-grid .role{ color:var(--brass); font-weight:600; letter-spacing:.06em; margin-bottom:18px; }
.owner-grid p{ color:var(--ink-soft); margin-bottom:14px; }
.owner-sign{ font-family:"Fraunces",serif; font-style:italic; font-size:24px; color:var(--ink); margin-top:8px; }

/* Testimonials */
.tcards{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.tcard{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:26px; position:relative; }
.section.tint .tcard{ background:var(--linen); }
.tcard .qm{ font-family:"Fraunces",serif; font-size:54px; line-height:.6; color:var(--brass-soft); }
.tcard .qt{ color:var(--ink); font-size:17px; margin:10px 0 18px; }
.tcard .who{ display:flex; align-items:center; gap:10px; font-size:14px; color:var(--ink-soft); }
.tcard .who b{ color:var(--ink); }
.tcard .ph-note{ font-size:12px; color:var(--brass); font-weight:600; letter-spacing:.04em; }
.t-aggregate{ display:flex; align-items:center; gap:18px; margin-bottom:36px; flex-wrap:wrap; }
.t-aggregate .big{ font-family:"Fraunces",serif; font-size:54px; color:var(--ink); line-height:1; }
.t-aggregate a{ color:var(--green-deep); font-weight:600; }

/* CTA band */
.ctaband{ text-align:center; }
.ctaband h2{ max-width:18ch; margin:0 auto 14px; }
.ctaband p{ color:rgba(255,255,255,.8); max-width:48ch; margin:0 auto 28px; }
.section.deep .btn-primary{ background:#fff; color:var(--green-deep); }
.section.deep .btn-primary:hover{ background:var(--paper); }

/* Contact */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; }
.contact-info .line{ display:flex; gap:14px; align-items:flex-start; margin-bottom:20px; }
.contact-info .line svg{ width:22px; height:22px; color:var(--green); flex:0 0 auto; margin-top:3px; }
.contact-info .line a{ color:var(--ink); text-decoration:none; font-weight:500; }
.contact-info .line a:hover{ color:var(--green); }
.contact-info .line small{ display:block; color:var(--ink-soft); font-weight:400; }
.form{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:28px; box-shadow:var(--shadow-sm); }
.section.tint .form{ background:var(--linen); }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:14px; font-weight:600; margin-bottom:7px; }
.field input,.field textarea{ width:100%; font:inherit; font-size:16px; padding:13px 15px; border:1px solid var(--line); border-radius:10px; background:var(--linen); color:var(--ink); }
.section.tint .field input,.section.tint .field textarea{ background:var(--paper); }
.field input:focus,.field textarea:focus{ outline:2px solid var(--green); border-color:var(--green); }
.field.err input,.field.err textarea{ border-color:#b5462f; }
.field .msg{ color:#b5462f; font-size:13px; margin-top:6px; display:none; }
.field.err .msg{ display:block; }
.form .btn-primary{ width:100%; justify-content:center; }
.form-success{ text-align:center; padding:22px 10px; }
.form-success .check{ width:60px; height:60px; margin:0 auto 14px; }
.form-success h3{ margin-bottom:8px; }
.form-success p{ color:var(--ink-soft); font-size:15px; }
.form-note{ font-size:13px; color:var(--ink-soft); margin-top:12px; text-align:center; }

/* Footer */
.footer{ background:var(--ink); color:rgba(255,255,255,.78); padding:56px 0 30px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; margin-bottom:36px; }
.footer .brand b{ color:#fff; } .footer .brand span{ color:rgba(255,255,255,.6); }
.footer h4{ font-family:"Inter",sans-serif; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.6); margin:0 0 14px; }
.footer a{ color:rgba(255,255,255,.8); text-decoration:none; display:block; margin-bottom:9px; font-size:15px; }
.footer a:hover{ color:#fff; }
.footer .legal{ border-top:1px solid rgba(255,255,255,.12); padding-top:20px; font-size:13px; color:rgba(255,255,255,.55); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }

/* Sticky buy CTA + preview ribbon */
.buy-cta{
  position:fixed; right:20px; bottom:20px; z-index:80;
  display:inline-flex; align-items:center; gap:10px; text-decoration:none;
  background:var(--synvanta); color:#fff; font-weight:600; font-size:15px;
  padding:13px 20px; border-radius:999px; box-shadow:0 14px 40px -12px rgba(40,80,240,.6);
  transform:translateY(140%); transition:transform .4s var(--ease);
}
.buy-cta.show{ transform:translateY(0); }
.buy-cta svg{ width:17px; height:17px; }
.ribbon{
  position:fixed; left:20px; bottom:20px; z-index:80;
  background:var(--synvanta); color:#fff; font-size:12px; font-weight:600; letter-spacing:.03em;
  padding:8px 14px; border-radius:999px; text-decoration:none; box-shadow:var(--shadow-sm);
}

/* Reveal */
.js .reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.js .reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }

/* Exit modal */
.exit-overlay{ position:fixed; inset:0; z-index:100; background:rgba(20,28,38,.55); backdrop-filter:blur(4px); display:grid; place-items:center; padding:20px; }
.exit-modal{ background:var(--paper); border-radius:18px; max-width:440px; width:100%; padding:32px; box-shadow:var(--shadow); border-top:4px solid var(--synvanta); position:relative; }
.exit-modal h3{ font-size:24px; margin-bottom:10px; }
.exit-modal p{ color:var(--ink-soft); font-size:16px; margin-bottom:14px; }
.exit-modal .x{ position:absolute; top:14px; right:16px; background:none; border:0; font-size:22px; color:var(--ink-soft); cursor:pointer; line-height:1; }
.exit-actions{ display:flex; flex-direction:column; gap:12px; margin-top:8px; }
.exit-email{ display:flex; align-items:center; gap:10px; background:var(--linen); border:1px solid var(--line); border-radius:10px; padding:10px 12px; }
.exit-email code{ font-family:"Inter",sans-serif; font-size:15px; color:var(--ink); user-select:all; }
.exit-email button{ margin-left:auto; background:var(--green); color:#fff; border:0; border-radius:8px; padding:7px 12px; font-weight:600; cursor:pointer; font-size:13px; }
.exit-foot{ font-size:13px; color:var(--ink-soft); margin-top:14px; margin-bottom:0; }

[hidden]{ display:none !important; }

/* Responsive */
@media (max-width: 920px){
  .hero-grid{ grid-template-columns:1fr; gap:36px; }
  .scene-inner{ grid-template-columns:1fr; }
  .owner-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .tension-grid{ grid-template-columns:1fr; }
  .svc-grid{ grid-template-columns:1fr; }
  .tcards{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 760px){
  body{ font-size:17px; }
  .nav-links{ position:fixed; inset:64px 16px auto 16px; flex-direction:column; align-items:stretch; gap:6px;
    background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:14px; box-shadow:var(--shadow);
    transform:translateY(-12px); opacity:0; visibility:hidden; pointer-events:none; transition:.25s var(--ease); }
  .nav-links.open{ transform:none; opacity:1; visibility:visible; pointer-events:auto; }
  .nav-links a.text{ padding:10px 8px; border-bottom:1px solid var(--line); }
  .nav-links .btn{ justify-content:center; }
  .nav-toggle{ display:block; }
  .pin-sticky{ min-height:auto; padding:60px 0; position:static; }
  .pin-track{ height:auto; }
  .footer-grid{ grid-template-columns:1fr; }
  .proof .divide{ display:none; }
  .hero{ padding:120px 0 60px; }
}
@media (prefers-reduced-motion: reduce){
  .js .reveal{ opacity:1; transform:none; transition:none; }
  .rcpt{ transition:none; }
  .buy-cta{ transition:none; }
}

/* ===== Award-pass additions ===== */

/* Skip link */
.skip-link{ position:absolute; left:16px; top:-60px; z-index:200; background:var(--green); color:#fff;
  padding:10px 16px; border-radius:0 0 10px 10px; font-weight:600; text-decoration:none; transition:top .2s var(--ease); }
.skip-link:focus{ top:0; }

/* Visible focus everywhere */
a:focus-visible, button:focus-visible, summary:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:3px solid var(--green); outline-offset:2px; border-radius:6px;
}
.btn-primary:focus-visible{ outline-color:var(--brass); }

/* Semantic address should not italicize */
.addr{ font-style:normal; }

/* Contrast fixes: brass fails as small text on light. Use green for small labels. */
.scene-copy .step .k{ color:var(--green-deep); }
.owner-grid .role{ color:var(--green-deep); }

/* Truthful proof panel */
.proof-panel{ background:var(--paper); border:1px solid var(--line); border-radius:20px; padding:34px; box-shadow:var(--shadow-sm); max-width:760px; }
.pp-top{ display:flex; align-items:center; gap:28px; flex-wrap:wrap; padding-bottom:22px; border-bottom:1px solid var(--line); }
.pp-score{ display:flex; align-items:center; gap:14px; }
.pp-score .stars{ font-size:26px; }
.pp-num{ display:flex; flex-direction:column; line-height:1; }
.pp-num .big{ font-family:"Fraunces",serif; font-size:46px; color:var(--ink); }
.pp-num .pp-sub{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--green-deep); font-weight:600; margin-top:4px; }
.pp-meta{ display:flex; flex-direction:column; gap:4px; }
.pp-meta strong{ font-size:18px; color:var(--ink); }
.pp-meta span{ color:var(--ink-soft); font-size:15px; max-width:34ch; }
.pp-people{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin:22px 0 24px; }
.ava{ width:38px; height:38px; border-radius:50%; background:var(--a,#2F5D50); color:#fff; display:grid; place-items:center;
  font-weight:700; font-size:15px; margin-left:-8px; box-shadow:0 0 0 3px var(--paper); }
.ava:first-child{ margin-left:0; }
.pp-names{ color:var(--ink-soft); font-size:15px; margin-left:8px; }
.proof-panel .btn-primary{ width:auto; }

/* FAQ */
.faq{ max-width:780px; }
.faq-item{ background:var(--linen); border:1px solid var(--line); border-radius:14px; padding:4px 22px; margin-bottom:12px; }
.faq-item summary{ list-style:none; cursor:pointer; padding:18px 0; font-family:"Fraunces",serif; font-size:20px; color:var(--ink);
  display:flex; align-items:center; justify-content:space-between; gap:16px; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; font-family:"Inter",sans-serif; font-size:26px; color:var(--green); line-height:1; transition:transform .25s var(--ease); }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ color:var(--ink-soft); font-size:16px; padding:0 0 20px; margin:0; max-width:64ch; }

/* ===== Design pass v2: editorial craft layer ===== */

/* Tactile paper grain over the whole canvas (very subtle) */
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1; opacity:.045; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* More confident, editorial typography */
.hero h1{ font-size:clamp(46px,8.4vw,92px); letter-spacing:-.025em; line-height:1.0; }
h2{ letter-spacing:-.02em; }
.section{ padding:clamp(80px,11vw,140px) 0; }
.section-head{ margin-bottom:clamp(40px,5vw,64px); }

/* Warm dawn wash behind the hero */
.hero{ position:relative; }
.hero::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(58% 50% at 86% 2%, rgba(216,184,114,.12), transparent 60%); }
.hero .wrap{ position:relative; z-index:1; }

/* Editorial ledger index on eyebrows */
.idx{ font-style:normal; font-family:"Inter",sans-serif; font-weight:700; font-size:12px;
  letter-spacing:.08em; color:var(--brass); font-variant-numeric:tabular-nums; }

/* Tabular figures so count-ups never shift layout */
.num, .pp-num .big{ font-variant-numeric:tabular-nums; }

/* Kinetic heading reveal: type wipes up under a mask, driven by the section reveal */
.js .section-head h2{ clip-path:inset(0 0 110% 0); transform:translateY(14px);
  transition:clip-path .85s var(--ease), transform .85s var(--ease); }
.js .section-head.in h2{ clip-path:inset(0 0 -12% 0); transform:none; }
.js .hero h1.reveal{ clip-path:inset(0 0 112% 0); }
.js .hero h1.reveal.in{ clip-path:inset(0 0 -12% 0); }

/* Micro-interactions */
.nav-links a.text{ position:relative; }
.nav-links a.text::after{ content:""; position:absolute; left:0; right:0; bottom:-5px; height:2px;
  background:var(--green); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease); }
.nav-links a.text:hover::after{ transform:scaleX(1); }
.btn svg{ transition:transform .25s var(--ease); }
.btn:hover svg{ transform:translateX(4px); }
.svc{ position:relative; overflow:hidden; }
.svc::before{ content:""; position:absolute; left:0; right:0; top:0; height:3px; background:var(--brass);
  transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.svc:hover::before{ transform:scaleX(1); }
.svc .ic{ transition:transform .4s var(--ease), background .3s var(--ease); }
.svc:hover .ic{ transform:translateY(-2px) rotate(-3deg); }

/* Hero visual gets a touch more depth */
.hero-visual{ will-change:transform; }
.ledger-card .row.total span:last-child{ position:relative; }

@media (max-width:760px){
  .nav-links a.text::after{ display:none; }
}
@media (prefers-reduced-motion: reduce){
  body::after{ display:none; }
  .js .section-head h2, .js .hero h1.reveal{ clip-path:none; transform:none; transition:none; }
  .btn:hover svg, .svc:hover .ic{ transform:none; }
}

/* Anchored jumps clear the fixed nav */
section[id], main[id]{ scroll-margin-top: 92px; }

/* Real review cards sit below the proof panel */
.proof-panel + .tcards{ margin-top: 22px; }
