/* =====================================================================
   Magau - website design system  (v2, editorial premium)
   Brand: Pagoda-M · sindoor crimson + marigold doorstep-dot on cream.
   Rules: FLAT - no gradients, no drop shadows. Premium via editorial
   type, generous space, hairline structure, disciplined colour, and the
   recurring marigold dot motif. Type: Inter (Latin) × Mukta (Devanagari).
   ===================================================================== */

/* ----------------------------- tokens ----------------------------- */
:root{
  --crimson:#C8102E;   --crimson-700:#9E0B23;   --crimson-050:#FBEAEC;
  --marigold:#F2A900;  --marigold-700:#C98700;  --gold-light:#FFD23F;
  --teal:#15897F;

  --cream:#FBF5EA;     --surface:#FFFFFF;   --surface-2:#F4ECDC;
  --ink:#1A1A1A;       --ink-soft:#4A453C;  --muted:#8C8579;  --line:#E7DECB;
  --hairline:#EBE3D3;
  --on-primary:#FBF5EA; --on-accent:#3A2A00;

  --success:#1E8E4E;   --warn:#E08A00;   --danger:#C0341D;   --star:#F2A900;

  --radius-sm:10px; --radius:14px; --radius-lg:20px; --radius-xl:26px; --radius-pill:999px;
  --container:1160px; --measure:66ch;
  --line-w:1px;

  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --font-ne:'Mukta','Inter',system-ui,sans-serif;

  --step--1:clamp(.8rem,.77rem + .12vw,.88rem);
  --step-0:clamp(.97rem,.93rem + .18vw,1.06rem);
  --step-1:clamp(1.12rem,1.04rem + .36vw,1.34rem);
  --step-2:clamp(1.4rem,1.22rem + .8vw,2rem);
  --step-3:clamp(1.85rem,1.5rem + 1.6vw,2.9rem);
  --step-4:clamp(2.3rem,1.75rem + 2.7vw,3.9rem);
  --step-5:clamp(2.9rem,1.95rem + 4.4vw,5.4rem);

  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.22,.68,.28,1);
}

/* ----------------------------- reset ------------------------------ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:96px}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--font);font-size:var(--step-0);line-height:1.62;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-feature-settings:"cv11","ss01";overflow-x:hidden;
}
img,svg,video{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul,ol{padding-left:1.2rem}
:focus-visible{outline:2.5px solid var(--crimson);outline-offset:3px;border-radius:4px}
::selection{background:var(--marigold);color:var(--on-accent)}
.lang-ne{font-family:var(--font-ne)}

/* ----------------------------- layout ----------------------------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,4.5vw,40px)}
.container-narrow{max-width:840px}
.section{padding-block:clamp(64px,10vw,132px)}
.section--tight{padding-block:clamp(44px,7vw,80px)}
.section--cream{background:var(--cream)}
.section--surface{background:var(--surface)}
.section--well{background:var(--surface-2)}
.section--crimson{background:var(--crimson);color:var(--on-primary)}
.section--ink{background:var(--ink);color:var(--cream)}
.divider{border:0;border-top:var(--line-w) solid var(--line);margin:0}

.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--ink);color:var(--cream);
  padding:10px 16px;border-radius:0 0 var(--radius) 0;font-weight:700}
.skip-link:focus{left:0}

/* --------------------------- typography --------------------------- */
h1,h2,h3,h4{margin:0 0 .5em;font-weight:800;letter-spacing:-.022em;line-height:1.08;color:inherit}
h1{font-size:var(--step-5);font-weight:800;letter-spacing:-.04em;line-height:1.02}
h2{font-size:var(--step-4);font-weight:800;letter-spacing:-.035em;line-height:1.05}
h3{font-size:var(--step-2);letter-spacing:-.028em}
h4{font-size:var(--step-1);letter-spacing:-.02em}
p{margin:0 0 1rem}

/* eyebrow - muted label with the marigold doorstep dot */
.eyebrow{display:inline-flex;align-items:center;gap:.62em;margin:0 0 20px;
  font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--marigold);flex:0 0 auto}
.section--crimson .eyebrow,.section--ink .eyebrow{color:rgba(251,245,234,.72)}

.lead{font-size:var(--step-1);line-height:1.6;color:var(--ink-soft);max-width:var(--measure);font-weight:400}
.section--crimson .lead,.section--ink .lead{color:rgba(251,245,234,.9)}
.muted{color:var(--muted)}
.center{text-align:center}
.center .lead,.center .eyebrow,.center .accent-rule{margin-inline:auto}
.balance{text-wrap:balance}
.accent-rule{width:52px;height:3px;background:var(--marigold);border-radius:2px;border:0;margin:22px 0}

.section-head{max-width:44ch}
.section-head .lead{margin-top:2px}
.section-head.center{max-width:56ch;margin-inline:auto}
.section-head--wide{max-width:60ch}

/* ---------------------------- buttons ----------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:.86em 1.5em;border-radius:var(--radius);border:1.5px solid transparent;
  font-size:var(--step-0);font-weight:600;letter-spacing:-.01em;line-height:1;
  transition:transform .12s var(--ease),background .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease);
  text-align:center;white-space:nowrap;
}
.btn:active{transform:scale(.975)}
.btn-primary{background:var(--crimson);color:var(--on-primary)}
.btn-primary:hover{background:var(--crimson-700)}
.btn-accent{background:var(--marigold);color:var(--on-accent)}
.btn-accent:hover{background:var(--marigold-700)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-on-crimson{background:var(--cream);color:var(--crimson)}
.btn-on-crimson:hover{background:#fff}
.btn-outline-cream{background:transparent;color:var(--cream);border-color:rgba(251,245,234,.45)}
.btn-outline-cream:hover{border-color:var(--cream);background:rgba(251,245,234,.08)}
.btn-lg{padding:1.02em 1.8em;font-size:var(--step-1)}
.btn-block{display:flex;width:100%}
.btn-link{display:inline-flex;align-items:center;gap:.45em;font-weight:600;color:var(--crimson);
  border-bottom:1.5px solid transparent;padding-bottom:2px;transition:border-color .18s var(--ease),gap .18s var(--ease)}
.btn-link::after{content:"→";transition:transform .18s var(--ease)}
.btn-link:hover{border-color:var(--crimson)}
.btn-link:hover::after{transform:translateX(3px)}
.section--crimson .btn-link,.section--ink .btn-link{color:var(--marigold)}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.center .btn-row{justify-content:center}

/* app-store badges */
.play-badge{display:inline-flex;transition:transform .12s var(--ease),opacity .18s var(--ease)}
.play-badge:hover{opacity:.92}
.play-badge:active{transform:scale(.97)}
.play-badge img{height:56px;width:auto;display:block}
.soon-badge{display:inline-flex;align-items:center;height:56px;padding:0 22px;border-radius:var(--radius);
  background:transparent;border:1.5px solid var(--line);cursor:default}
.section--crimson .soon-badge{border-color:rgba(251,245,234,.28)}
.soon-badge small{display:block;font-size:.62rem;letter-spacing:.09em;text-transform:uppercase;font-weight:600;color:var(--muted)}
.soon-badge b{display:block;font-size:1.02rem;font-weight:700;letter-spacing:-.01em;line-height:1.15;color:var(--ink-soft)}
.section--crimson .soon-badge small{color:rgba(251,245,234,.62)}
.section--crimson .soon-badge b{color:var(--cream)}

/* --------------------------- top nav ------------------------------ */
.nav{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--cream) 82%,transparent);
  -webkit-backdrop-filter:saturate(1.5) blur(12px);backdrop-filter:saturate(1.5) blur(12px);
  border-bottom:var(--line-w) solid var(--line)}
.nav__row{display:flex;align-items:center;gap:20px;height:72px}
.nav__brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:1.3rem;letter-spacing:-.03em}
.nav__brand img{width:30px;height:30px}
.nav__brand .ne{font-family:var(--font-ne);font-weight:600;font-size:.86rem;color:var(--muted);letter-spacing:0}
.nav__spacer{flex:1}
.nav__links{display:flex;align-items:center;gap:2px}
.nav__links a:not(.btn){padding:9px 14px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;color:var(--ink-soft);
  transition:color .16s var(--ease)}
.nav__links a:not(.btn):hover,.nav__links a:not(.btn)[aria-current="page"]{color:var(--crimson)}
.nav__cta{margin-left:8px;color:var(--on-primary);padding-block:.68em}
.nav__toggle{display:none;width:46px;height:46px;border:var(--line-w) solid var(--line);border-radius:var(--radius-sm);
  background:var(--surface);align-items:center;justify-content:center}
.nav__toggle span,.nav__toggle span::before,.nav__toggle span::after{
  content:"";display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s var(--ease),opacity .2s var(--ease)}
.nav__toggle span::before{transform:translateY(-6px)}
.nav__toggle span::after{transform:translateY(4px)}
.nav.is-open .nav__toggle span{background:transparent}
.nav.is-open .nav__toggle span::before{transform:rotate(45deg)}
.nav.is-open .nav__toggle span::after{transform:rotate(-45deg) translateY(-2px)}
@media(max-width:900px){
  .nav__toggle{display:inline-flex}
  .nav__links{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;gap:2px;
    background:var(--cream);border-bottom:var(--line-w) solid var(--line);padding:16px clamp(20px,4.5vw,40px) 24px;
    transform:translateY(-8px);opacity:0;visibility:hidden;transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s}
  .nav.is-open .nav__links{transform:none;opacity:1;visibility:visible}
  .nav__links a:not(.btn){padding:14px 12px;font-size:1.06rem}
  .nav__cta{margin:10px 0 0}
}

/* ----------------------------- hero ------------------------------- */
.hero{position:relative;background:var(--crimson);color:var(--on-primary);overflow:hidden}
.hero__roofs{position:absolute;top:0;right:0;left:0;height:280px;opacity:.06;pointer-events:none;
  background:
    linear-gradient(var(--on-primary) 0 0) no-repeat; /* placeholder to satisfy no rule - overridden below */
  background:none}
.hero__roofs{display:flex;flex-direction:column;align-items:center;gap:13px;padding-top:30px}
.hero__roofs i{display:block;height:7px;border-radius:4px;background:var(--on-primary)}
.hero .container{position:relative;padding-block:clamp(60px,10vw,116px)}
.hero__grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(32px,6vw,80px);align-items:center}
.hero__badge{display:inline-flex;align-items:center;gap:9px;padding:8px 15px;border-radius:var(--radius-pill);
  background:rgba(251,245,234,.1);border:var(--line-w) solid rgba(251,245,234,.24);font-size:.82rem;font-weight:500;margin-bottom:26px}
.hero__badge .dot{width:7px;height:7px;border-radius:50%;background:var(--marigold)}
.hero h1{margin:0}
.hero__ne{font-family:var(--font-ne);font-weight:700;font-size:var(--step-3);color:var(--marigold);margin-top:12px;line-height:1.1}
.hero__tag{font-size:var(--step-1);font-weight:400;margin-top:24px;max-width:34ch;color:rgba(251,245,234,.92)}
.hero__actions{margin-top:34px}
.hero__trust{display:flex;flex-wrap:wrap;align-items:center;gap:10px 20px;margin-top:34px;
  padding-top:26px;border-top:var(--line-w) solid rgba(251,245,234,.18);
  font-size:.86rem;font-weight:500;color:rgba(251,245,234,.82)}
.hero__trust span{display:inline-flex;align-items:center;gap:9px}
.hero__trust span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--marigold)}
.hero__art{display:flex;align-items:center;justify-content:center;position:relative}
@media(max-width:860px){
  .hero__grid{grid-template-columns:1fr;text-align:center}
  .hero__badge,.hero__tag{margin-inline:auto}
  .hero__actions .btn-row,.hero__trust{justify-content:center}
  .hero__art{order:-1;margin-bottom:10px}
  .hero__trust{border-top:0;padding-top:8px}
}

/* generic inner-page hero */
.page-hero{background:var(--cream);border-bottom:var(--line-w) solid var(--line);position:relative;overflow:hidden}
.page-hero .container{padding-block:clamp(52px,8vw,96px);position:relative}
.page-hero h1{font-size:var(--step-4)}
.page-hero .lead{margin-top:6px}

/* ------------------- hero device / in-app mock -------------------- */
.device{width:min(300px,76vw);border-radius:42px;padding:12px;background:#141210;
  border:1px solid rgba(0,0,0,.5);position:relative}
.device::before{content:"";position:absolute;top:20px;left:50%;transform:translateX(-50%);
  width:96px;height:22px;border-radius:14px;background:#141210;z-index:3}
.device__screen{border-radius:32px;overflow:hidden;background:var(--cream);aspect-ratio:300/620;display:flex;flex-direction:column}
.appui{display:flex;flex-direction:column;height:100%;font-size:12px}
.appui__status{display:flex;align-items:center;justify-content:space-between;padding:12px 20px 6px;font-size:11px;font-weight:700;color:var(--ink)}
.appui__status i{width:15px;height:9px;border:1.5px solid var(--ink);border-radius:2px;display:inline-block;margin-left:3px;opacity:.75}
.appui__bar{display:flex;align-items:center;gap:8px;padding:6px 16px 12px}
.appui__back{width:26px;height:26px;border-radius:50%;background:var(--surface);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--ink);line-height:1}
.appui__title{font-size:14px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.appui__title .lang-ne{color:var(--muted);font-weight:500;font-size:11px;margin-left:5px}
.appui__map{position:relative;flex:1;background:var(--surface-2);overflow:hidden}
.appui__streets{position:absolute;inset:0}
.appui__streets i{position:absolute;background:var(--surface)}
.appui__park{position:absolute;border-radius:12px;background:color-mix(in srgb,var(--success) 20%,var(--surface-2))}
.appui__route{position:absolute;inset:0}
.appui__route path{fill:none;stroke:var(--crimson);stroke-width:4;stroke-linecap:round;stroke-dasharray:2 11}
.appui__stop{position:absolute;width:16px;height:16px;border-radius:50%;background:var(--surface);
  border:2px solid var(--ink);transform:translate(-50%,-50%)}
.appui__stop.is-store{border-color:var(--crimson)}
.appui__stop.is-store::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--crimson)}
.appui__pin{position:absolute;transform:translate(-50%,-100%)}
.appui__pin i{display:block;width:24px;height:24px;border-radius:50% 50% 50% 0;background:var(--crimson);transform:rotate(-45deg)}
.appui__pin i::after{content:"";position:absolute;top:6px;left:6px;width:12px;height:12px;border-radius:50%;background:var(--marigold);
  animation:pinpulse 2.6s var(--ease-out) infinite}
@keyframes pinpulse{0%,100%{transform:scale(1)}50%{transform:scale(.68)}}
.appui__rider-dot{position:absolute;width:26px;height:26px;border-radius:50%;background:var(--marigold);
  border:3px solid var(--cream);transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:var(--on-accent)}
.appui__sheet{background:var(--surface);border-top:1px solid var(--line);border-radius:18px 18px 0 0;
  margin-top:-16px;position:relative;padding:14px 16px 18px}
.appui__grab{width:34px;height:4px;border-radius:2px;background:var(--line);margin:0 auto 12px}
.appui__eta-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.appui__eta{font-size:15px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.appui__chip{font-size:10px;font-weight:700;color:var(--success);background:color-mix(in srgb,var(--success) 14%,var(--surface));
  padding:3px 9px;border-radius:999px}
.appui__prog{height:5px;border-radius:3px;background:var(--surface-2);overflow:hidden;margin-bottom:14px}
.appui__prog i{display:block;height:100%;width:68%;background:var(--crimson);border-radius:3px}
.appui__rider{display:flex;align-items:center;gap:11px}
.appui__avatar{width:40px;height:40px;border-radius:50%;background:var(--crimson);color:var(--cream);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;flex:0 0 auto}
.appui__rinfo{flex:1;min-width:0}
.appui__rinfo b{display:block;font-size:13px;font-weight:700;color:var(--ink);line-height:1.2}
.appui__rinfo span{font-size:11px;color:var(--muted)}
.appui__call{width:36px;height:36px;border-radius:50%;background:var(--crimson);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center}
.appui__call svg{width:17px;height:17px;color:var(--cream)}
.hero__float{position:absolute;z-index:5;background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:11px 14px;display:flex;align-items:center;gap:10px;font-size:12px;font-weight:600;color:var(--ink)}
.hero__float .tick{width:24px;height:24px;border-radius:50%;background:color-mix(in srgb,var(--success) 16%,#fff);
  display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.hero__float .tick svg{width:14px;height:14px;color:var(--success)}
.hero__float--tl{top:6%;left:-6%}
.hero__float--br{bottom:9%;right:-7%}
@media(max-width:1040px){.hero__float{display:none}}

/* ------------------------- grids & cards -------------------------- */
.grid{display:grid;gap:clamp(18px,2.4vw,26px)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:var(--surface);border:var(--line-w) solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px,2.8vw,32px);transition:transform .25s var(--ease-out),border-color .25s var(--ease)}
.card--pad-lg{padding:clamp(28px,3.4vw,44px)}
.card-hover:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--crimson) 34%,var(--line))}
.card h3,.card h4{margin-bottom:.4em}
.card p:last-child{margin-bottom:0}
.center .card{text-align:left}

/* icon - monoline, no coloured container (single accent) */
.icon-badge{display:inline-flex;align-items:center;justify-content:center;color:var(--crimson);margin-bottom:22px}
.icon-badge svg{width:30px;height:30px;stroke-width:1.7}
.icon-badge--marigold,.icon-badge--teal,.icon-badge--success{color:var(--crimson)}

/* verticals - numbered editorial cards (no left rule, no colour square) */
.vcard{position:relative;background:var(--surface);border:var(--line-w) solid var(--line);border-radius:var(--radius-xl);
  padding:clamp(26px,3vw,34px);transition:transform .25s var(--ease-out),border-color .25s var(--ease)}
.vcard.card-hover:hover,.vcard:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--crimson) 30%,var(--line))}
.vcard__top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:26px}
.vcard__index{font-size:.82rem;font-weight:700;letter-spacing:.14em;color:var(--muted)}
.vcard__icon{color:var(--crimson)}
.vcard__icon svg{width:34px;height:34px;stroke-width:1.6}
.vcard--services .vcard__icon{color:var(--muted)}
.vcard__title{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;font-size:var(--step-2);font-weight:800;letter-spacing:-.03em;margin:0 0 10px}
.vcard__ne{font-family:var(--font-ne);font-weight:600;font-size:.62em;color:var(--marigold-700)}
.vcard p{margin:0;color:var(--ink-soft)}
.vcard__soon{display:inline-block;margin-bottom:12px;font-size:.6rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--marigold-700);border:1px solid color-mix(in srgb,var(--marigold) 45%,var(--line));
  padding:4px 10px;border-radius:999px}
/* legacy vertical bits kept harmless */
.vcard__head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.tag-soon{margin-left:auto;font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--marigold-700)}

/* feature list - editorial, hairline separated (no colour squares) */
.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(32px,5vw,72px)}
@media(max-width:720px){.feature-list{grid-template-columns:1fr}}
.feature-item{display:flex;gap:18px;padding:26px 0;border-top:var(--line-w) solid var(--line)}
.feature-item .icon-badge{margin:0;flex:0 0 auto}
.feature-item .icon-badge svg{width:26px;height:26px}
.feature-item h4{margin:0 0 .3em}
.feature-item p{margin:0;color:var(--ink-soft);font-size:var(--step--1)}
/* feature row (used on partner pages) */
.feature{display:flex;gap:15px;align-items:flex-start}
.feature__ic{flex:0 0 auto;color:var(--crimson)}
.feature__ic svg{width:26px;height:26px;stroke-width:1.7}
.feature h4{margin-bottom:.25em}
.feature p{margin:0;color:var(--ink-soft);font-size:var(--step--1)}

/* steps - big editorial numerals */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,40px)}
@media(max-width:820px){.steps{grid-template-columns:repeat(2,1fr);gap:36px 28px}}
@media(max-width:460px){.steps{grid-template-columns:1fr}}
.step{counter-increment:step;position:relative}
.step::before{content:counter(step,decimal-leading-zero);display:block;
  font-size:2.7rem;font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--crimson-050);margin-bottom:14px;
  -webkit-text-stroke:1px color-mix(in srgb,var(--crimson) 32%,transparent)}
.section--crimson .step::before{color:rgba(158,11,35,.55);-webkit-text-stroke:1px rgba(251,245,234,.4)}
.step h4{margin-bottom:.3em}
.step p{margin:0;color:var(--ink-soft)}
.section--crimson .step p{color:rgba(251,245,234,.85)}
.step::after{content:"";position:absolute;top:18px;left:calc(100% - 8px);width:calc(100% - 40px);height:1px;background:var(--line)}
.steps .step:last-child::after,.step:nth-child(4n)::after{display:none}
@media(max-width:820px){.step::after{display:none}}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,3vw,40px)}
@media(max-width:640px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat__num{font-size:var(--step-3);font-weight:800;letter-spacing:-.03em;color:var(--crimson)}
.section--crimson .stat__num,.section--ink .stat__num{color:var(--marigold)}
.stat__label{font-size:var(--step--1);color:var(--muted);font-weight:500;margin-top:4px}
.section--crimson .stat__label,.section--ink .stat__label{color:rgba(251,245,234,.78)}

/* split - asymmetric two-column editorial block */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.split--wide{grid-template-columns:1.1fr .9fr}
@media(max-width:860px){.split,.split--wide{grid-template-columns:1fr;gap:32px}}

/* CTA band */
.cta-band{background:var(--crimson);color:var(--on-primary);border-radius:var(--radius-xl);
  padding:clamp(36px,5.5vw,72px);text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:var(--on-primary)}
.cta-band .eyebrow{color:rgba(251,245,234,.72);justify-content:center}
.cta-band .lead{color:rgba(251,245,234,.92);margin-inline:auto}
.cta-band .soon-badge{border-color:rgba(251,245,234,.28)}
.cta-band .soon-badge small{color:rgba(251,245,234,.62)}
.cta-band .soon-badge b{color:var(--cream)}
.cta-band__roofs{position:absolute;top:0;left:0;right:0;height:70px;display:flex;flex-direction:column;
  align-items:center;gap:9px;padding-top:16px;opacity:.08;pointer-events:none}
.cta-band__roofs i{height:6px;border-radius:3px;background:var(--on-primary)}

/* partner band split (dark) */
.partner{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,32px)}
@media(max-width:760px){.partner{grid-template-columns:1fr}}
.partner__card{border:var(--line-w) solid rgba(251,245,234,.16);border-radius:var(--radius-xl);
  padding:clamp(26px,3vw,40px);transition:border-color .25s var(--ease),transform .25s var(--ease-out)}
.partner__card:hover{border-color:rgba(251,245,234,.4);transform:translateY(-4px)}
.partner__card .icon-badge{color:var(--marigold);margin-bottom:20px}
.partner__card h3{color:var(--cream)}
.partner__card p{color:rgba(251,245,234,.8)}

/* --------------------------- legal doc ---------------------------- */
.doc{display:grid;grid-template-columns:230px 1fr;gap:clamp(30px,5vw,72px);align-items:start}
.doc__toc{position:sticky;top:96px;font-size:.9rem}
.doc__toc-title{font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.doc__toc ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px}
.doc__toc a{display:block;padding:7px 12px;border-radius:var(--radius-sm);color:var(--ink-soft);font-weight:500;
  border-left:2px solid transparent;transition:color .16s var(--ease),border-color .16s var(--ease)}
.doc__toc a:hover,.doc__toc a.is-active{color:var(--crimson);border-left-color:var(--crimson)}
.doc__body{max-width:var(--measure)}
.doc__body h2{font-size:var(--step-2);margin-top:2.4em;padding-top:1.3em;border-top:var(--line-w) solid var(--line);scroll-margin-top:96px;letter-spacing:-.025em}
.doc__body h2:first-of-type{margin-top:0;padding-top:0;border-top:0}
.doc__body h3{font-size:var(--step-1);margin-top:1.7em}
.doc__body p,.doc__body li{color:var(--ink-soft);line-height:1.75}
.doc__body ul,.doc__body ol{margin:0 0 1.1rem;padding-left:1.3rem}
.doc__body li{margin-bottom:.5rem}
.doc__body li::marker{color:var(--marigold-700)}
.doc__body a{color:var(--crimson);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.doc__body a:hover{color:var(--crimson-700)}
.doc__body strong{color:var(--ink);font-weight:700}
.doc-meta{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:var(--step--1);color:var(--muted);margin-top:14px}
.doc-meta b{color:var(--ink-soft);font-weight:700}
.callout{background:var(--surface-2);border:var(--line-w) solid var(--line);border-radius:var(--radius);padding:18px 22px;margin:1.5rem 0}
.callout::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--marigold);margin-right:10px;vertical-align:middle}
.callout p:last-child{margin-bottom:0}
.table-wrap{overflow-x:auto;margin:1.3rem 0;border:var(--line-w) solid var(--line);border-radius:var(--radius)}
table.data{width:100%;border-collapse:collapse;font-size:var(--step--1)}
table.data th,table.data td{text-align:left;padding:13px 16px;border-bottom:var(--line-w) solid var(--line);vertical-align:top}
table.data th{background:var(--surface-2);font-weight:700;color:var(--ink);white-space:nowrap}
table.data tr:last-child td{border-bottom:0}
table.data td{color:var(--ink-soft)}
@media(max-width:820px){
  .doc{grid-template-columns:1fr}
  .doc__toc{position:static;border:var(--line-w) solid var(--line);border-radius:var(--radius);padding:16px 18px;background:var(--surface)}
}

/* ------------------------------ FAQ ------------------------------- */
.faq{display:flex;flex-direction:column;gap:0;max-width:840px;margin-inline:auto;border-top:var(--line-w) solid var(--line)}
.faq details{border-bottom:var(--line-w) solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:22px 8px;font-weight:600;font-size:var(--step-1);
  display:flex;align-items:center;gap:16px;letter-spacing:-.01em;transition:color .16s var(--ease)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";margin-left:auto;flex:0 0 auto;width:11px;height:11px;border-right:2px solid var(--crimson);
  border-bottom:2px solid var(--crimson);transform:rotate(45deg);transition:transform .22s var(--ease)}
.faq details[open] summary::after{transform:rotate(-135deg)}
.faq summary:hover{color:var(--crimson)}
.faq__a{padding:0 8px 24px;color:var(--ink-soft);line-height:1.72;max-width:64ch}
.faq__a p:last-child{margin-bottom:0}

/* ----------------------------- forms ------------------------------ */
.form{display:grid;gap:18px;max-width:660px}
.form-row{display:grid;gap:18px;grid-template-columns:1fr 1fr}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:.86rem;font-weight:600;color:var(--ink-soft)}
.field .req{color:var(--crimson)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:var(--step-0);color:var(--ink);background:var(--surface);
  border:var(--line-w) solid var(--line);border-radius:var(--radius);padding:13px 15px;transition:border-color .16s var(--ease)}
.field textarea{resize:vertical;min-height:140px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--crimson)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.form-note{font-size:var(--step--1);color:var(--muted)}

/* contact tiles */
.contact-card{display:flex;flex-direction:column;background:var(--surface);
  border:var(--line-w) solid var(--line);border-radius:var(--radius-lg);padding:26px;transition:border-color .25s var(--ease),transform .25s var(--ease-out)}
.contact-card:hover{border-color:color-mix(in srgb,var(--crimson) 30%,var(--line));transform:translateY(-3px)}
.contact-card .icon-badge{margin-bottom:18px}
.contact-card h4{margin-bottom:.3em}
.contact-card a{color:var(--crimson);font-weight:600}
.contact-card p{margin:0;color:var(--ink-soft);font-size:var(--step--1)}

/* pills / chips */
.pills{display:flex;flex-wrap:wrap;gap:10px}
.pill{background:var(--surface);border:var(--line-w) solid var(--line);border-radius:var(--radius-pill);
  padding:8px 16px;font-size:.86rem;font-weight:500;color:var(--ink-soft)}
.pill--crimson{background:var(--crimson-050);border-color:color-mix(in srgb,var(--crimson) 22%,var(--line));color:var(--crimson)}

/* checklist with marigold ticks */
.checklist{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.checklist li{position:relative;padding-left:36px;color:var(--ink-soft)}
.checklist li::before{content:"";position:absolute;left:0;top:1px;width:22px;height:22px;border-radius:50%;
  border:1.5px solid color-mix(in srgb,var(--crimson) 40%,var(--line))}
.checklist li::after{content:"";position:absolute;left:7px;top:7px;width:8px;height:5px;
  border-left:2px solid var(--crimson);border-bottom:2px solid var(--crimson);transform:rotate(-45deg)}

/* marigold-dot bullet list */
.dot-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.dot-list li{position:relative;padding-left:24px;color:var(--ink-soft)}
.dot-list li::before{content:"";position:absolute;left:2px;top:.62em;width:7px;height:7px;border-radius:50%;background:var(--marigold)}

/* ---------------------------- footer ------------------------------ */
.footer{background:var(--ink);color:rgba(251,245,234,.72);padding-block:clamp(52px,6vw,80px) 34px}
.footer__grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
@media(max-width:820px){.footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer__grid{grid-template-columns:1fr}}
.footer__brand{display:inline-flex;align-items:center;gap:10px}
.footer__brand img{height:32px;width:auto}
.footer__blurb{margin-top:18px;max-width:34ch;font-size:var(--step--1);line-height:1.7}
.footer__ne{font-family:var(--font-ne);color:var(--marigold);font-weight:500;margin-top:10px}
.footer__col h5{color:var(--cream);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin:0 0 18px}
.footer__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
.footer__col a{color:rgba(251,245,234,.7);font-size:.92rem;transition:color .16s var(--ease)}
.footer__col a:hover{color:var(--marigold)}
.footer__bottom{margin-top:clamp(36px,5vw,56px);padding-top:26px;border-top:var(--line-w) solid rgba(251,245,234,.14);
  display:flex;flex-wrap:wrap;gap:12px 24px;align-items:center;justify-content:space-between;font-size:.84rem}
.footer__made{display:inline-flex;align-items:center;gap:8px;color:rgba(251,245,234,.7)}
.footer__made::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--marigold)}

/* ---------------------------- motion ------------------------------ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.09s}
.reveal[data-delay="2"]{transition-delay:.18s}
.reveal[data-delay="3"]{transition-delay:.27s}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}

/* --------------------------- utilities ---------------------------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.mt-1{margin-top:14px}.mt-2{margin-top:26px}.mt-3{margin-top:44px}
.hide-mobile{display:initial}
@media(max-width:640px){.hide-mobile{display:none}}
.text-crimson{color:var(--crimson)}
.text-marigold{color:var(--marigold-700)}
