/* =====================================================================
   LightHouse — Coastal Dawn / Beacon
   Aesthetic: soft sunrise gradients over calm-sea teal, warm amber-coral
   "beam" accent. Display: Fraunces · Body: Hanken Grotesk · Mono: Spline Sans
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  /* sea / primary */
  --teal-900:#06343f;
  --teal-800:#0a4b54;
  --teal-700:#0d6e6e;
  --teal-600:#0f8f86;
  --teal-500:#16b3a3;
  --teal-400:#3fd0bf;

  /* beam / sunrise accents */
  --amber-400:#fbbf3b;
  --gold-300:#ffd66b;
  --coral-500:#ff7a59;
  --coral-400:#ff9472;
  --rose-400:#ff8fa3;

  /* sky */
  --sky-300:#7fd2f5;

  /* warm neutrals */
  --cream:#fff8ef;
  --sand:#fef2e3;
  --paper:#ffffff;
  --ink:#0e2a33;
  --ink-2:#3a5860;
  --ink-3:#6a868d;
  --line:rgba(14,42,51,.10);
  --line-2:rgba(14,42,51,.06);

  /* signature gradients */
  --grad-beam:linear-gradient(135deg,var(--gold-300) 0%,var(--coral-500) 100%);
  --grad-beam-soft:linear-gradient(135deg,#ffe6a8 0%,#ffb59c 100%);
  --grad-sea:linear-gradient(160deg,var(--teal-700) 0%,var(--teal-500) 100%);
  --grad-sea-deep:linear-gradient(155deg,var(--teal-900) 0%,var(--teal-700) 70%,var(--teal-600) 100%);

  /* shadows (layered, tinted) */
  --sh-sm:0 1px 2px rgba(14,42,51,.05), 0 4px 12px -6px rgba(14,42,51,.12);
  --sh-md:0 1px 2px rgba(14,42,51,.04), 0 10px 28px -12px rgba(14,42,51,.18), 0 24px 48px -28px rgba(16,143,134,.20);
  --sh-lg:0 2px 4px rgba(14,42,51,.05), 0 18px 40px -16px rgba(14,42,51,.22), 0 40px 80px -32px rgba(16,143,134,.22);
  --sh-beam:0 14px 36px -10px rgba(255,122,89,.45);

  /* radii (soft/friendly) */
  --r-xs:10px;
  --r-sm:14px;
  --r:18px;
  --r-lg:26px;
  --r-xl:34px;
  --pill:999px;

  --maxw:1380px;
  --pad:clamp(1.1rem,4vw,2rem);
  --ease:cubic-bezier(.2,.8,.2,1);
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{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;
  font-family:"Hanken Grotesk",ui-sans-serif,system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:clamp(1rem,.97rem + .2vw,1.1rem);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{margin:0;font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.08;letter-spacing:-.01em;color:var(--ink)}
p{margin:0}
button{font-family:inherit}
:focus-visible{outline:3px solid var(--teal-500);outline-offset:3px;border-radius:6px}

.skip-link{
  position:absolute;left:-999px;top:10px;z-index:200;
  background:var(--ink);color:#fff;padding:.7rem 1.1rem;border-radius:var(--r-sm);
}
.skip-link:focus{left:16px}

/* ---------- Atmosphere (decorative dawn) ---------- */
.atmosphere{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5}
.orb--peach{width:46vw;height:46vw;top:-12vw;right:-8vw;
  background:radial-gradient(circle at 30% 30%,#ffd9b0,#ffb59c 60%,transparent 72%)}
.orb--mint{width:42vw;height:42vw;top:38vh;left:-14vw;
  background:radial-gradient(circle at 40% 40%,#bff1e6,#8fe3d2 55%,transparent 72%);opacity:.42}
.orb--sky{width:38vw;height:38vw;bottom:-10vw;right:6vw;
  background:radial-gradient(circle at 50% 50%,#cdeafd,#a9ddf6 55%,transparent 72%);opacity:.38}
.grain{
  position:absolute;inset:0;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.container--narrow{max-width:780px}
.section{padding-block:clamp(3.5rem,8vw,6.5rem)}

/* ---------- Eyebrow ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:"Spline Sans Mono",monospace;font-size:.74rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--teal-700);
  margin:0 0 1rem;
}
.eyebrow--light{color:var(--gold-300)}
.eyebrow__dot{
  width:.55rem;height:.55rem;border-radius:50%;background:var(--grad-beam);
  box-shadow:0 0 0 4px rgba(255,122,89,.15);
}
@media (prefers-reduced-motion:no-preference){
  .eyebrow__dot{animation:pulse 2.6s var(--ease) infinite}
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(255,122,89,.14)}50%{box-shadow:0 0 0 7px rgba(255,122,89,.05)}}

.ink-beam{
  background:var(--grad-beam);-webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink);--fg:#fff;
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.8rem 1.25rem;border-radius:var(--pill);border:1px solid transparent;
  font-weight:700;font-size:.98rem;letter-spacing:.005em;cursor:pointer;
  background:var(--bg);color:var(--fg);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  overflow:hidden;white-space:nowrap;
}
.btn .ico{width:1.15em;height:1.15em;fill:currentColor;flex:none}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn::after{ /* light sweep */
  content:"";position:absolute;inset:0;transform:translateX(-120%);
  background:linear-gradient(100deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transition:transform .6s var(--ease);
}
.btn:hover::after{transform:translateX(120%)}
.btn--sm{padding:.55rem .95rem;font-size:.9rem}
.btn--lg{padding:.95rem 1.6rem;font-size:1.04rem}

.btn--beam{--bg:none;color:#5a2010;background:var(--grad-beam);box-shadow:var(--sh-beam)}
.btn--beam:hover{box-shadow:0 18px 44px -10px rgba(255,122,89,.55)}
.btn--solid{--bg:var(--teal-700);--fg:#fff;box-shadow:var(--sh-sm)}
.btn--solid:hover{background:var(--teal-800)}
.btn--light{--bg:#fff;--fg:var(--teal-800);box-shadow:var(--sh-sm)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line);}
.btn--ghost:hover{background:rgba(14,42,51,.04)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100}
.header__inner{
  display:flex;align-items:center;gap:1rem;
  margin-top:.85rem;padding:.55rem .7rem .55rem 1rem;
  background:rgba(255,248,239,.72);backdrop-filter:blur(14px) saturate(140%);
  border:1px solid var(--line);border-radius:var(--pill);
  box-shadow:var(--sh-sm);
}
.site-header.is-scrolled .header__inner{
  background:rgba(255,248,239,.88);box-shadow:var(--sh-md);border-color:rgba(14,42,51,.12);
}
.brand{display:inline-flex;align-items:center;gap:.6rem}
.brand__mark{display:grid;place-items:center;width:42px;height:42px;border-radius:13px;
  background:var(--grad-sea);box-shadow:inset 0 1px 0 rgba(255,255,255,.25),var(--sh-sm)}
.brand__word{font-family:"Fraunces",serif;font-weight:600;font-size:1.32rem;letter-spacing:-.02em;color:var(--ink)}
.brand__word span{color:var(--teal-600)}
.brand__word--light{color:var(--cream)}
.brand__word--light span{color:var(--gold-300)}

.nav{display:flex;gap:.35rem;margin-left:.6rem}
.nav a{
  padding:.5rem .8rem;border-radius:var(--pill);font-weight:600;font-size:.95rem;color:var(--ink-2);
  transition:color .2s,background .2s;
}
.nav a:hover{color:var(--ink);background:rgba(14,42,51,.05)}
.header__cta{display:flex;align-items:center;gap:.5rem;margin-left:auto}

.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:13px;
  background:#fff;cursor:pointer;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.nav-toggle span{width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.mobile-nav{
  margin-top:.5rem;padding:1rem;border-radius:var(--r-lg);
  background:rgba(255,248,239,.96);backdrop-filter:blur(14px);
  border:1px solid var(--line);box-shadow:var(--sh-md);
  animation:drop .3s var(--ease);
}
.mobile-nav[hidden]{display:none}
@keyframes drop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.mobile-nav nav{display:flex;flex-direction:column}
.mobile-nav nav a{padding:.85rem .6rem;font-weight:600;border-bottom:1px solid var(--line-2);font-size:1.05rem}
.mobile-nav__cta{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem}
.mobile-nav__cta .btn{width:100%}

/* ---------- Hero ---------- */
.hero{position:relative;padding-top:clamp(2.5rem,6vw,4.5rem);padding-bottom:clamp(2rem,5vw,3rem)}
.hero__grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;
}
.hero__copy{max-width:36rem}
h1{font-size:clamp(2.5rem,2rem + 4vw,4.6rem);font-weight:600}
h1 em{font-style:italic;font-weight:500;color:var(--teal-700)}
.hero__lede{margin:1.4rem 0 2rem;font-size:clamp(1.08rem,1.04rem + .3vw,1.3rem);color:var(--ink-2);max-width:34rem}
.hero__lede strong{color:var(--ink);font-weight:700}
.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem}
.hero__meta{margin-top:1.3rem;font-size:.95rem;color:var(--ink-3)}
.hero__meta strong{color:var(--teal-700)}

/* product visual */
.hero__visual{position:relative;min-height:430px;display:grid;place-items:center}
.beacon-glow{position:absolute;inset:-6% -10%;border-radius:50%;z-index:0;
  background:conic-gradient(from 0deg,rgba(255,214,107,.0),rgba(255,214,107,.35),rgba(255,122,89,.18),rgba(255,214,107,.0));
  filter:blur(34px);opacity:.85}
@media (prefers-reduced-motion:no-preference){.beacon-glow{animation:spin 16s linear infinite}}
@keyframes spin{to{transform:rotate(360deg)}}

.ui-card{position:relative;z-index:1;background:rgba(255,255,255,.86);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.7);border-radius:var(--r-lg);box-shadow:var(--sh-lg)}
.ui-tag{font-family:"Spline Sans Mono",monospace;font-size:.72rem;font-weight:600;letter-spacing:.04em;
  color:var(--teal-700);background:rgba(16,143,134,.12);padding:.2rem .5rem;border-radius:var(--pill)}
.ui-pill{font-size:.72rem;font-weight:700;padding:.28rem .6rem;border-radius:var(--pill)}
.ui-pill--warn{color:#9a4a16;background:#ffe6cf}
.ui-pill--ok{color:#0a6a52;background:#cdf3e4}
.cur{font-family:"Spline Sans Mono",monospace;font-size:.7em;color:var(--ink-3);font-weight:600;margin-right:.15em}

.ui-card--khata{width:min(330px,92%);padding:1.3rem 1.35rem}
.ui-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}
.ui-card__head h3{font-size:1.2rem;margin-top:.45rem}
.ui-amount{display:flex;flex-direction:column;gap:.1rem;margin-bottom:.7rem}
.ui-amount__label{font-size:.78rem;color:var(--ink-3);font-weight:600}
.ui-amount__value{font-family:"Fraunces",serif;font-size:1.95rem;font-weight:600;color:var(--ink)}
.ui-progress{height:8px;border-radius:var(--pill);background:rgba(14,42,51,.08);overflow:hidden;margin-bottom:1rem}
.ui-progress span{display:block;height:100%;border-radius:var(--pill);background:var(--grad-beam)}
.ui-progress--lg{height:11px}
.ui-rows{display:flex;flex-direction:column;gap:.55rem}
.ui-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--ink-2)}
.ui-row b{color:var(--ink)}

.ui-card--stat{position:absolute;top:-6%;right:-4%;width:200px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.2rem}
.ui-stat__label{font-size:.76rem;font-weight:600;color:var(--ink-3)}
.ui-stat__value{font-family:"Fraunces",serif;font-size:1.5rem;font-weight:600}
.ui-trend{font-size:.78rem;font-weight:700;color:var(--teal-600)}
.spark{margin-top:.4rem;height:34px}
.spark svg{width:100%;height:100%}

.ui-card--receipt{position:absolute;bottom:-7%;left:-6%;width:190px;padding:.95rem 1rem;font-size:.82rem;color:var(--ink-2)}
.rcpt__head{font-family:"Spline Sans Mono",monospace;font-size:.72rem;font-weight:600;color:var(--teal-700);
  text-align:center;padding-bottom:.5rem;margin-bottom:.55rem;border-bottom:1px dashed var(--line)}
.rcpt__line{display:flex;justify-content:space-between;padding:.12rem 0;font-family:"Spline Sans Mono",monospace;font-size:.78rem}
.rcpt__total{display:flex;justify-content:space-between;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed var(--line);
  font-weight:700;color:var(--ink);font-family:"Spline Sans Mono",monospace}
.rcpt__cut{margin:.6rem -1rem -.95rem;height:12px;
  background:repeating-linear-gradient(135deg,transparent 0 6px,rgba(14,42,51,.06) 6px 12px)}

/* float motion */
@media (prefers-reduced-motion:no-preference){
  .float-a{animation:floaty 7s ease-in-out infinite}
  .float-b{animation:floaty 6s ease-in-out infinite .6s}
  .float-c{animation:floaty 8s ease-in-out infinite 1.1s}
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* trust strip */
.trust{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem 1.6rem;
  margin-top:clamp(2rem,5vw,3.5rem);padding-top:1.6rem;border-top:1px solid var(--line);
  font-size:.92rem;font-weight:600;color:var(--ink-2)}
.trust li{display:inline-flex;align-items:center;gap:.5rem}
.trust__ic{display:grid;place-items:center;width:1.7rem;height:1.7rem;border-radius:9px;
  background:#fff;box-shadow:var(--sh-sm);font-size:.95rem}

/* ---------- Section heads ---------- */
.section__head{max-width:42rem;margin-bottom:clamp(2rem,4vw,3rem)}
.section__head h2{font-size:clamp(1.9rem,1.6rem + 1.8vw,3rem)}
.section__sub{margin-top:.9rem;font-size:1.1rem;color:var(--ink-2)}

/* ---------- Bento features ---------- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(.9rem,1.6vw,1.3rem)}
.bento__card{
  grid-column:span 2;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:1.6rem;box-shadow:var(--sh-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
}
.bento__card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:rgba(16,143,134,.35)}
.bento__card h3{font-size:1.28rem;margin-bottom:.5rem}
.bento__card p{color:var(--ink-2);font-size:.98rem}
.bento__card--feature{grid-column:span 2;grid-row:span 2;
  background:linear-gradient(165deg,#fff 0%,#fff6ef 100%);border-color:rgba(255,122,89,.22);
  display:flex;flex-direction:column}
.bento__card--feature h3{font-size:1.7rem;margin-top:.3rem}
.bento__card--feature p{font-size:1.05rem}
.bento__card--wide{grid-column:span 4}
.bento__wide-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;height:100%}

.feat-ic{display:grid;place-items:center;width:54px;height:54px;border-radius:16px;margin-bottom:1rem}
.feat-ic svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.feat-ic--teal{background:var(--grad-sea)}
.feat-ic--coral{background:var(--grad-beam)}
.feat-ic--amber{background:linear-gradient(135deg,#ffcf6b,#ff9f43)}

.feat-list{margin-top:auto;padding-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.feat-list li{position:relative;padding-left:1.5rem;font-size:.95rem;font-weight:600;color:var(--ink-2)}
.feat-list li::before{content:"";position:absolute;left:0;top:.45em;width:.7rem;height:.7rem;border-radius:50%;
  background:var(--grad-beam);box-shadow:0 0 0 3px rgba(255,122,89,.14)}

.mini-bars{display:flex;align-items:flex-end;gap:.5rem;height:96px}
.mini-bars span{width:18px;height:var(--h);border-radius:6px 6px 3px 3px;
  background:linear-gradient(180deg,var(--teal-400),var(--teal-600))}
.mini-bars span:nth-child(even){background:linear-gradient(180deg,var(--gold-300),var(--coral-500))}

/* ---------- Khata deep dive ---------- */
.khata{position:relative}
.khata__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.khata__points{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}
.kpoint{display:flex;gap:1.1rem;align-items:flex-start}
.kpoint__num{flex:none;font-family:"Spline Sans Mono",monospace;font-size:.85rem;font-weight:700;color:#fff;
  display:grid;place-items:center;width:2.4rem;height:2.4rem;border-radius:12px;background:var(--grad-sea);box-shadow:var(--sh-sm)}
.kpoint h3{font-size:1.18rem;margin-bottom:.25rem}
.kpoint p{color:var(--ink-2);font-size:.98rem}

/* ledger visual */
.khata__visual{display:grid;place-items:center}
.ledger{position:relative;width:min(420px,100%);padding:1.7rem 1.7rem 1.5rem;border-radius:var(--r-xl);
  background:linear-gradient(165deg,#ffffff 0%,#f4fbfa 100%);
  border:1px solid var(--line);box-shadow:var(--sh-lg)}
.ledger::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(160deg,rgba(255,214,107,.6),rgba(16,143,134,.25),transparent);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.ledger__top{display:flex;justify-content:space-between;align-items:center}
.ledger__name{font-size:1.45rem;margin:.7rem 0 .15rem}
.ledger__sub{font-family:"Spline Sans Mono",monospace;font-size:.78rem;color:var(--ink-3)}
.ledger__balance{display:flex;justify-content:space-between;align-items:flex-end;margin:1.3rem 0 .6rem}
.ledger__balance span{font-size:.85rem;color:var(--ink-3);font-weight:600}
.ledger__balance strong{font-family:"Fraunces",serif;font-size:2.2rem;font-weight:600}
.ledger__pct{font-size:.85rem;color:var(--ink-2);font-weight:600;margin-top:.5rem}
.ledger__history{margin-top:1.3rem;display:flex;flex-direction:column;gap:.7rem;
  padding-top:1.1rem;border-top:1px dashed var(--line)}
.ledger__history li{display:flex;align-items:center;gap:.6rem;font-size:.92rem;color:var(--ink-2)}
.ledger__history b{margin-left:auto;color:var(--ink);font-weight:700}
.ledger__history time{font-family:"Spline Sans Mono",monospace;font-size:.76rem;color:var(--ink-3);min-width:3.4rem;text-align:right}
.dot{width:.6rem;height:.6rem;border-radius:50%;flex:none}
.dot--ok{background:var(--teal-500)}
.dot--due{background:var(--coral-500);box-shadow:0 0 0 4px rgba(255,122,89,.16)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.5vw,2rem);counter-reset:s;position:relative}
.step{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:2rem 1.6rem 1.7rem;box-shadow:var(--sh-sm)}
.step__no{display:grid;place-items:center;width:2.8rem;height:2.8rem;border-radius:50%;margin-bottom:1.1rem;
  font-family:"Fraunces",serif;font-weight:600;font-size:1.3rem;color:#5a2010;background:var(--grad-beam);box-shadow:var(--sh-beam)}
.step h3{font-size:1.25rem;margin-bottom:.45rem}
.step p{color:var(--ink-2);font-size:.98rem}

/* ---------- Audience ---------- */
.aud-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(.9rem,1.6vw,1.3rem)}
.aud-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:1.7rem 1.4rem;box-shadow:var(--sh-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.aud-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.aud-ic{font-size:2rem;width:60px;height:60px;display:grid;place-items:center;border-radius:18px;
  background:linear-gradient(165deg,#fff,#fff2e6);box-shadow:inset 0 0 0 1px var(--line-2);margin-bottom:1rem}
.aud-card h3{font-size:1.25rem;margin-bottom:.4rem}
.aud-card p{color:var(--ink-2);font-size:.95rem}

/* ---------- Why ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(.9rem,1.6vw,1.3rem)}
.why-card{padding:1.6rem 1.4rem;border-radius:var(--r-lg);
  background:linear-gradient(165deg,rgba(255,255,255,.7),rgba(255,246,239,.6));
  border:1px solid var(--line);box-shadow:var(--sh-sm)}
.why-card__big{display:block;font-family:"Fraunces",serif;font-size:1.5rem;font-weight:600;
  background:var(--grad-sea);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:.5rem}
.why-card p{color:var(--ink-2);font-size:.96rem}

/* ---------- FAQ ---------- */
.accordion{display:flex;flex-direction:column;gap:.8rem}
.ac{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden}
.ac summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;
  padding:1.15rem 1.3rem;font-family:"Fraunces",serif;font-weight:600;font-size:1.12rem;list-style:none}
.ac summary::-webkit-details-marker{display:none}
.ac summary:hover{color:var(--teal-700)}
.ac__chev{position:relative;flex:none;width:1.2rem;height:1.2rem}
.ac__chev::before,.ac__chev::after{content:"";position:absolute;top:50%;left:50%;width:.7rem;height:2px;border-radius:2px;
  background:var(--teal-700);transition:transform .3s var(--ease)}
.ac__chev::before{transform:translate(-50%,-50%)}
.ac__chev::after{transform:translate(-50%,-50%) rotate(90deg)}
.ac[open] .ac__chev::after{transform:translate(-50%,-50%) rotate(0)}
.ac__body{padding:0 1.3rem 1.2rem;color:var(--ink-2)}
.ac__body p{font-size:1rem}
@media (prefers-reduced-motion:no-preference){
  .ac[open] .ac__body{animation:fade .35s var(--ease)}
}
@keyframes fade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* ---------- CTA ---------- */
.cta{padding-block:clamp(2rem,5vw,4rem) clamp(3.5rem,8vw,6rem)}
.cta__panel{position:relative;border-radius:var(--r-xl);overflow:hidden;
  background:var(--grad-sea-deep);box-shadow:var(--sh-lg);isolation:isolate}
.cta__beam{position:absolute;inset:0;z-index:0;opacity:.9;
  background:
    radial-gradient(120% 90% at 85% -10%,rgba(255,214,107,.45),transparent 55%),
    radial-gradient(90% 70% at 10% 120%,rgba(255,122,89,.4),transparent 55%);
}
.cta__inner{position:relative;z-index:1;padding:clamp(2.2rem,5vw,4rem);text-align:center;color:#fff}
.cta__inner h2{color:#fff;font-size:clamp(2rem,1.6rem + 2.2vw,3.2rem)}
.cta__sub{margin:1rem auto 2rem;max-width:34rem;color:rgba(255,255,255,.85);font-size:1.12rem}
.cta__actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}
.cta__person{margin-top:1.4rem;font-size:.95rem;color:rgba(255,255,255,.8)}
.cta__person strong{color:var(--gold-300)}

/* ---------- Footer ---------- */
.site-footer{background:var(--teal-900);color:rgba(255,255,255,.78);margin-top:2rem}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem;padding-block:clamp(2.8rem,5vw,4rem) 2rem}
.footer__brand .brand{margin-bottom:1rem}
.footer__brand .brand__mark{background:rgba(255,255,255,.08)}
.footer__tag{max-width:24rem;font-size:.96rem;line-height:1.6;color:rgba(255,255,255,.6)}
.footer__col h4{font-family:"Hanken Grotesk",sans-serif;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold-300);margin-bottom:1rem;font-weight:700}
.footer__col a{display:block;padding:.32rem 0;color:rgba(255,255,255,.74);font-weight:500;transition:color .2s}
.footer__col a:hover{color:#fff}
.footer__contact{display:inline-flex;align-items:center;gap:.55rem}
.footer__contact .ico{width:1.05em;height:1.05em;fill:var(--teal-400)}
.footer__person{margin-top:.5rem;color:rgba(255,255,255,.55);font-size:.92rem}
.footer__bottom{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;
  padding-block:1.4rem 2rem;border-top:1px solid rgba(255,255,255,.1);font-size:.88rem;color:rgba(255,255,255,.55)}

/* ---------- Mobile sticky bar ---------- */
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;gap:.6rem;padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));
  background:rgba(255,248,239,.9);backdrop-filter:blur(12px);border-top:1px solid var(--line)}
.mobile-bar__btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem;border-radius:var(--pill);font-weight:700;font-size:.98rem}
.mobile-bar__btn .ico{width:1.15em;height:1.15em;fill:currentColor}
.mobile-bar__btn--call{background:var(--teal-700);color:#fff}
.mobile-bar__btn--wa{background:var(--grad-beam);color:#5a2010}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px)}
.reveal.in{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .7s var(--ease)}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .float-a,.float-b,.float-c,.beacon-glow,.eyebrow__dot{animation:none!important}
}
/* hero staggered load delays */
.hero .reveal[data-d="0"]{transition-delay:.02s}
.hero .reveal[data-d="1"]{transition-delay:.1s}
.hero .reveal[data-d="2"]{transition-delay:.2s}
.hero .reveal[data-d="3"]{transition-delay:.3s}
.hero .reveal[data-d="4"]{transition-delay:.4s}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1020px){
  .hero__grid{grid-template-columns:1fr;gap:3rem}
  .hero__visual{min-height:380px;margin-top:.5rem}
  .khata__grid{grid-template-columns:1fr;gap:2.5rem}
  .bento{grid-template-columns:repeat(4,1fr)}
  .bento__card--feature{grid-column:span 4;grid-row:span 1}
  .bento__card--wide{grid-column:span 4}
  .aud-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:860px){
  .nav{display:none}
  .header__cta .btn--sm{display:none}
  .nav-toggle{display:flex}
  .footer__grid{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
}

@media (max-width:680px){
  body{padding-bottom:72px} /* room for sticky bar */
  .header__inner{margin-top:.6rem}
  .steps{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr}
  .bento__card,.bento__card--feature,.bento__card--wide{grid-column:span 1}
  .aud-grid,.why-grid{grid-template-columns:1fr}
  .bento__wide-inner{flex-direction:column;align-items:flex-start;gap:1.4rem}
  .mini-bars{align-self:stretch;justify-content:space-between}
  .mini-bars span{flex:1}
  .mobile-bar{display:flex}

  /* hero visual: settle floating cards into a tidy stack */
  .hero__visual{min-height:0;display:block;padding:.5rem 0}
  .beacon-glow{display:none}
  .ui-card--khata{width:100%;max-width:380px;margin:0 auto}
  .ui-card--stat{position:relative;top:auto;right:auto;width:100%;max-width:380px;margin:.9rem auto 0}
  .ui-card--receipt{position:relative;bottom:auto;left:auto;width:100%;max-width:380px;margin:.9rem auto 0}
  .float-a,.float-b,.float-c{animation:none}

  .ledger__balance strong{font-size:1.9rem}
  .cta__actions .btn{width:100%}
}

@media (max-width:380px){
  .brand__word{font-size:1.15rem}
  .header__cta{gap:.35rem}
}
