*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --forest:#0D1F13;--ink:#1C2B22;--ink2:#4A5E52;--ink3:#8A9E90;
  --blanc:#FAFAFA;--white:#FFFFFF;--copper:#B85C2A;
  --border:rgba(28,43,34,0.1);
  --fd:'Raleway',sans-serif;--fb:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth;overflow-x:clip}
body{background:var(--blanc);color:var(--ink);font-family:var(--fb);font-weight:300;overflow-x:clip}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;z-index:9000}

@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes hedReveal{to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* blob removed */

/* ══ NAV ══ */
nav.topnav{position:fixed;top:0;left:0;right:0;z-index:900;padding:24px 52px;display:flex;align-items:center;justify-content:space-between;pointer-events:none;transition:opacity .3s ease}
nav.topnav.hidden{opacity:0;pointer-events:none;visibility:hidden}
.nav-logo{pointer-events:all;display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer}
.nav-name{font-family:var(--fd);font-size:11px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);opacity:.75;transition:opacity .2s}
.nav-logo:hover .nav-name{opacity:1}
.nav-cta{pointer-events:all;font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;background:var(--forest);color:var(--blanc);border:none;padding:10px 22px;border-radius:6px;cursor:pointer;transition:opacity .2s}
.nav-cta:hover{opacity:.75}

/* ══ STICKY NAV ══ */
.snav{position:sticky;top:0;z-index:910;background:rgba(250,250,250,.72);border-bottom:0.5px solid rgba(28,43,34,.06);padding:0 52px;display:flex;align-items:center;justify-content:space-between;height:54px;transform:translateY(-100%);transition:transform .35s ease;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.snav.vis{transform:none}
.snav-progress{position:absolute;bottom:0;left:0;height:2px;background:var(--copper);width:0%;transition:width .1s linear;opacity:.6}
.snav-logo{display:flex;align-items:center;gap:9px;text-decoration:none;cursor:pointer}
.snav-name{font-family:var(--fd);font-size:10px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--ink2)}
.snav-links{display:flex;gap:0}
.snav-link{font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:rgba(28,43,34,.5);text-decoration:none;cursor:pointer;padding:0 16px;height:54px;display:flex;align-items:center;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.snav-link:hover{color:var(--ink)}
.snav-link.active{color:var(--forest);border-bottom-color:var(--copper)}
.snav-cta{font-family:var(--fb);font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;background:var(--copper);color:var(--blanc);border:none;padding:9px 20px;border-radius:6px;cursor:pointer;transition:opacity .18s ease}
.snav-cta:hover{opacity:.75}

/* hamburger — hidden on desktop */
.snav-burger{display:none;width:36px;height:36px;border:none;background:none;cursor:pointer;padding:8px 6px;flex-direction:column;justify-content:center;gap:5px}
.snav-burger span{display:block;height:1.5px;background:var(--ink);border-radius:1px;transition:transform .3s ease,opacity .3s ease}
.snav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.snav-burger.open span:nth-child(2){opacity:0}
.snav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile dropdown */
.snav-mobile{display:none;position:absolute;top:54px;left:0;right:0;background:rgba(250,250,250,.98);backdrop-filter:blur(12px);border-bottom:0.5px solid var(--border);padding:12px 0;flex-direction:column}
.snav-mobile.open{display:flex}
.snav-mobile-link{font-family:var(--fb);font-size:12px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:var(--ink2);text-decoration:none;padding:14px 24px;transition:color .2s,background .2s}
.snav-mobile-link:hover{color:var(--copper);background:rgba(184,92,42,.04)}

/* ══ HERO ══ */
.hero{min-height:100vh;background:var(--blanc);position:relative;overflow:hidden;display:flex;align-items:center}
/* morphing blob */
.hero-blob{position:absolute;top:12%;right:8%;width:52vw;height:52vw;max-width:680px;max-height:680px;background:radial-gradient(ellipse at 38% 32%,rgba(184,92,42,.55) 0%,rgba(184,92,42,.35) 30%,rgba(184,92,42,.15) 60%,transparent 100%);border-radius:60% 40% 30% 70% / 60% 30% 70% 40%;animation:blobMorph 12s ease-in-out infinite,blobFloat 8s ease-in-out infinite;z-index:1;will-change:border-radius,transform}
@keyframes blobMorph{0%,100%{border-radius:60% 40% 30% 70% / 60% 30% 70% 40%}25%{border-radius:30% 60% 70% 40% / 50% 60% 30% 60%}50%{border-radius:50% 35% 55% 45% / 35% 55% 40% 65%}75%{border-radius:40% 55% 35% 65% / 65% 40% 60% 35%}}
@keyframes blobFloat{0%,100%{transform:translate(0,0) rotate(0deg)}50%{transform:translate(-14px,10px) rotate(2deg)}}
.hero-inner{position:relative;z-index:10;max-width:1160px;margin:0 auto;padding:0 56px;width:100%}
.hero-eyebrow{font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--copper);margin-bottom:28px;opacity:0;animation:fadeUp .8s ease .1s both;display:flex;align-items:center;gap:10px}
.hero-eyebrow::before{content:'';display:block;width:20px;height:1px;background:var(--copper)}
.hero-hed{font-family:var(--fd);font-weight:200;font-size:clamp(56px,7.5vw,112px);line-height:.93;letter-spacing:-.048em;color:var(--forest);margin-bottom:14px}
.hero-hed em{font-style:italic;color:var(--copper)}
.hed-line{display:block;overflow:hidden;padding-bottom:.1em;margin-bottom:-.1em}
.hed-line-inner{display:block;opacity:0;transform:translateY(105%);animation:hedReveal .85s cubic-bezier(.22,.68,0,1) forwards}
.hed-line:nth-child(1) .hed-line-inner{animation-delay:.18s}
.hed-line:nth-child(2) .hed-line-inner{animation-delay:.34s}
.hero-sub{font-family:var(--fd);font-weight:200;font-size:clamp(20px,2.6vw,34px);line-height:1.15;letter-spacing:-.025em;color:var(--ink2);margin-bottom:44px;opacity:0;animation:fadeUp .9s ease .58s both}
.hero-sub em{font-style:italic;color:var(--copper)}
.hero-form-row{display:flex;gap:6px;flex-wrap:wrap;opacity:0;animation:fadeUp .9s ease .72s both}
.hero-inp{background:var(--white);border:0.5px solid var(--border);border-radius:6px;padding:0 16px;font-family:var(--fb);font-size:13px;font-weight:300;color:var(--ink);outline:none;transition:border-color .2s;height:46px;width:240px}
.hero-inp::placeholder{color:var(--ink3)}
.hero-inp:focus{border-color:rgba(184,92,42,.45)}
.hero-btn{font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:var(--copper);color:var(--blanc);border:none;height:46px;padding:0 28px;border-radius:6px;cursor:pointer;transition:opacity .18s}
.hero-btn:hover{opacity:.75}
.hero-ok{display:none;font-size:12px;color:var(--ink2);padding:8px 0;letter-spacing:.02em}
.hero-ok.on{display:block;animation:fadeUp .4s ease forwards}
.hero-launch{font-size:11px;color:var(--ink3);letter-spacing:.03em;margin-top:12px;opacity:0;animation:fadeUp .9s ease .88s both}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadeUp 1s ease 1.3s both;z-index:3}
.hero-scroll-line{width:0.5px;height:40px;background:var(--ink3);transform-origin:top;animation:drawLine 1.2s ease 1.5s both}
@keyframes drawLine{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.hero-scroll{animation:fadeUp 1s ease 1.3s both,scrollBounce 2s ease-in-out 2.5s infinite;transition:opacity .5s ease}
.hero-scroll.faded{opacity:0!important;pointer-events:none}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
.hero-scroll-label{font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3)}

/* ══ ENGINE STATES ══ */
.states-track{position:relative;background:var(--blanc);padding:80px 32px}
.states-header{text-align:center;margin-bottom:56px}
.states-eyebrow{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px;display:flex;align-items:center;justify-content:center;gap:10px}
.states-eyebrow::before,.states-eyebrow::after{content:'';display:block;width:18px;height:1px;background:var(--ink3)}
.states-hed{font-family:var(--fd);font-weight:200;font-size:clamp(28px,3.5vw,52px);line-height:1.0;letter-spacing:-.04em;color:var(--forest)}
.states-hed em{font-style:italic;color:var(--copper)}
.states-sub{font-size:14px;color:var(--ink2);line-height:1.7;max-width:500px;margin:14px auto 0}

/* states accordion */
.states-accordion{max-width:680px;margin:0 auto}
.state-acc{border-bottom:1px solid rgba(13,31,19,.08)}
.state-acc:last-child{border-bottom:none}

/* header row */
.state-acc-header{
  width:100%;display:flex;align-items:center;gap:16px;
  padding:22px 4px;background:none;border:none;
  cursor:pointer;font-family:inherit;text-align:left;
  transition:opacity .2s;
}
.state-acc-header:hover{opacity:.7}
.state-acc-title{font-family:var(--fd);font-weight:200;font-size:clamp(20px,3vw,26px);letter-spacing:-.025em;color:var(--forest);line-height:1}
.state-acc-title em{font-style:italic;color:var(--copper)}

/* chip in header */
.state-card-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:rgba(184,92,42,.06);border:0.5px solid rgba(184,92,42,.14);border-radius:12px;width:fit-content;flex-shrink:0}
.state-card-chip-label{font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}
.state-card-chip-val{font-size:9px;color:var(--copper);font-family:var(--fd);font-weight:200}

/* expand icon */
.state-acc-icon{margin-left:auto;width:20px;height:20px;position:relative;flex-shrink:0}
.state-acc-icon::before,.state-acc-icon::after{content:'';position:absolute;background:var(--ink3);border-radius:1px;transition:transform .35s cubic-bezier(.22,.68,0,1)}
.state-acc-icon::before{width:12px;height:1.5px;top:50%;left:50%;transform:translate(-50%,-50%)}
.state-acc-icon::after{width:1.5px;height:12px;top:50%;left:50%;transform:translate(-50%,-50%)}
.state-acc.open .state-acc-icon::after{transform:translate(-50%,-50%) rotate(90deg)}

/* collapsible body */
.state-acc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s cubic-bezier(.22,.68,0,1)}
.state-acc.open .state-acc-body{grid-template-rows:1fr}
.state-acc-content{overflow:hidden}
.state-acc-body .state-visual{width:100%;height:72px;margin-bottom:16px;display:flex;align-items:center;justify-content:flex-start;padding-left:4px}
.state-card-copy{font-size:13px;line-height:1.7;color:var(--ink2);padding:0 4px 24px;max-width:520px}


/* ══ HOW IT WORKS — see bento CSS below ══ */

/* ══ VENUE ══ */
.venue{background:var(--blanc);padding:100px 0;position:relative;z-index:0;overflow:hidden}
.venue::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--copper),transparent);opacity:.25}
.venue-inner{max-width:1160px;margin:0 auto;padding:0 56px;position:relative;z-index:10}
.venue-eyebrow{font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--copper);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.venue-eyebrow::before{content:'';display:block;width:18px;height:1px;background:var(--copper);opacity:.6}
.venue-hed{font-family:var(--fd);font-weight:200;font-size:clamp(32px,4.2vw,62px);line-height:1.0;letter-spacing:-.04em;color:var(--forest);margin-bottom:20px;max-width:800px}
.venue-hed em{font-style:italic;color:var(--copper)}
/* venue hero — text + photo side by side */
.venue-hero{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:center;margin-bottom:48px}
.venue-lead{font-size:15px;line-height:1.85;color:var(--ink2);max-width:520px;margin:0}
.venue-photo-wrap{height:280px;border-radius:20px;overflow:hidden}

/* venue accordion */
.venue-accordion{max-width:680px;margin:0 auto 8px}
.venue-acc{border-bottom:1px solid rgba(13,31,19,.08)}
.venue-acc:last-child{border-bottom:none}
.venue-acc-header{
  width:100%;display:flex;align-items:center;gap:14px;
  padding:20px 4px;background:none;border:none;
  cursor:pointer;font-family:inherit;text-align:left;
  transition:opacity .2s;
}
.venue-acc-header:hover{opacity:.7}
.venue-acc-tag{font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--copper);flex-shrink:0;min-width:90px}
.venue-acc-title{font-family:var(--fd);font-weight:200;font-size:clamp(18px,2.8vw,22px);letter-spacing:-.025em;color:var(--forest);line-height:1.2}
.venue-acc-title em{font-style:italic;color:var(--copper)}
.venue-acc-icon{margin-left:auto;width:20px;height:20px;position:relative;flex-shrink:0}
.venue-acc-icon::before,.venue-acc-icon::after{content:'';position:absolute;background:var(--ink3);border-radius:1px;transition:transform .35s cubic-bezier(.22,.68,0,1)}
.venue-acc-icon::before{width:12px;height:1.5px;top:50%;left:50%;transform:translate(-50%,-50%)}
.venue-acc-icon::after{width:1.5px;height:12px;top:50%;left:50%;transform:translate(-50%,-50%)}
.venue-acc.open .venue-acc-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.venue-acc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s cubic-bezier(.22,.68,0,1)}
.venue-acc.open .venue-acc-body{grid-template-rows:1fr}
.venue-acc-content{overflow:hidden}
.venue-acc-copy{font-size:13px;line-height:1.8;color:var(--ink2);padding:0 4px 20px;max-width:520px;margin-left:104px}

/* boosts */
.boosts-panel{background:var(--forest);padding:48px;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;position:relative;z-index:2}
.bp-eyebrow{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(184,92,42,.8);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.bp-eyebrow::before{content:'';display:block;width:14px;height:1px;background:rgba(184,92,42,.6)}
.bp-hed{font-family:var(--fd);font-weight:200;font-size:clamp(24px,3vw,42px);letter-spacing:-.035em;line-height:1.05;color:var(--blanc);margin-bottom:16px}
.bp-hed em{font-style:italic;color:var(--copper)}
.bp-body{font-size:13px;line-height:1.82;color:rgba(250,250,250,.5);margin-bottom:28px}
.bp-venue-btn{font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:var(--copper);color:var(--blanc);border:none;padding:13px 26px;border-radius:6px;cursor:pointer;transition:opacity .18s}
.bp-venue-btn:hover{opacity:.75}
.bp-boost-row{display:flex;align-items:center;gap:14px;padding:14px 18px;background:rgba(250,250,250,.04);border:0.5px solid rgba(250,250,250,.08);border-radius:8px;margin-bottom:8px;transition:background .2s}
.bp-boost-row:hover{background:rgba(250,250,250,.07)}
.bp-boost-blob{width:28px;height:28px;flex-shrink:0}
.bp-boost-name{font-family:var(--fd);font-weight:200;font-size:14px;letter-spacing:-.01em;color:rgba(250,250,250,.85);margin-bottom:2px}
.bp-boost-state{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--copper)}
.bp-boost-score{font-family:var(--fd);font-weight:200;font-size:16px;color:var(--copper);letter-spacing:-.02em;margin-left:auto}

/* blurred/redacted boost rows */
.bp-boost-row--blurred{opacity:.5;filter:none}
.bp-boost-row--blurred:hover{background:rgba(250,250,250,.04)}
.bp-redacted{width:120px;height:10px;background:rgba(250,250,250,.12);border-radius:4px;margin-bottom:4px}
.bp-coming-soon{margin-top:16px;padding:10px 16px;border:0.5px dashed rgba(250,250,250,.15);border-radius:6px;display:inline-flex;align-items:center;gap:8px}
.bp-coming-dot{width:5px;height:5px;border-radius:50%;background:var(--copper);animation:pulse 2.5s ease infinite}
.bp-coming-soon span{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(250,250,250,.3)}

/* ══ SUPPLIER ══ */
.supplier{background:var(--blanc);padding:64px 0;border-top:0.5px solid var(--border);position:relative;z-index:0}
.supplier-inner{max-width:1160px;margin:0 auto;padding:0 56px;display:flex;align-items:center;justify-content:space-between;gap:48px;position:relative;z-index:10}
.sup-left{max-width:540px}
.sup-eyebrow{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.sup-eyebrow::before{content:'';display:block;width:14px;height:1px;background:var(--ink3)}
.sup-hed{font-family:var(--fd);font-weight:200;font-size:clamp(22px,2.8vw,38px);letter-spacing:-.035em;color:var(--forest);margin-bottom:12px;line-height:1.1}
.sup-hed em{font-style:italic;color:var(--copper)}
.sup-body{font-size:13px;line-height:1.82;color:var(--ink2);margin-bottom:20px}
.sup-form-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.sup-inp{background:var(--white);border:0.5px solid var(--border);border-radius:6px;padding:0 14px;font-family:var(--fb);font-size:12px;font-weight:300;color:var(--ink);outline:none;transition:border-color .2s;height:40px;width:180px}
.sup-inp::placeholder{color:var(--ink3)}
.sup-inp:focus{border-color:rgba(184,92,42,.4)}
.sup-btn{font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;background:var(--forest);color:var(--blanc);border:none;height:40px;padding:0 20px;border-radius:6px;cursor:pointer;transition:opacity .18s}
.sup-btn:hover{opacity:.75}
.sup-ok{display:none;font-size:11px;color:var(--ink2);padding:6px 0}
.sup-ok.on{display:block;animation:fadeUp .4s ease forwards}
.sup-consent{display:flex;align-items:flex-start;gap:8px}
.sup-cb{width:20px;height:20px;border:0.5px solid rgba(28,43,34,.25);border-radius:3px;flex-shrink:0;margin-top:1px;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer;transition:background .2s;position:relative}
.sup-cb:checked{background:var(--copper);border-color:var(--copper)}
.sup-cb:checked::after{content:'✓';position:absolute;top:-1px;left:2px;font-size:9px;color:var(--blanc)}
.sup-consent-lbl{font-size:10px;line-height:1.6;color:var(--ink3)}
.sup-consent-lbl a{color:var(--copper);text-decoration:none}
.sup-cerr{font-size:10px;color:#c0522a;display:none;margin-top:4px}
.sup-cerr.show{display:block}
.sup-badge{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;border:0.5px dashed rgba(28,43,34,.2);border-radius:8px;flex-shrink:0}
.sup-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--copper);animation:pulse 2.5s ease infinite}
.sup-badge-text{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}

/* ══ PRICING ══ */
.pricing{background:var(--blanc);padding:100px 0;position:relative;border-top:0.5px solid var(--border)}
.pricing-inner{max-width:1160px;margin:0 auto;padding:0 56px}
.pricing-eyebrow{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--copper);margin-bottom:20px;display:flex;align-items:center;gap:10px;justify-content:center}
.pricing-eyebrow::before,.pricing-eyebrow::after{content:'';display:block;width:18px;height:1px;background:var(--copper);opacity:.5}
.pricing-hed{font-family:var(--fd);font-weight:200;font-size:clamp(28px,3.5vw,52px);line-height:1.0;letter-spacing:-.04em;color:var(--forest);text-align:center;margin-bottom:14px}
.pricing-hed em{font-style:italic;color:var(--copper)}
.pricing-sub{font-size:14px;color:var(--ink2);line-height:1.7;max-width:520px;margin:0 auto 56px;text-align:center}

/* pricing cards */
.pricing-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:820px;margin:0 auto 56px}
.pricing-card{background:var(--white);border:0.5px solid var(--border);border-radius:20px;padding:40px 32px;display:flex;flex-direction:column;position:relative}
.pricing-card--pro{background:#F7F5F2;border:none;border-top:3px solid var(--copper)}
.pricing-card-badge{position:absolute;top:16px;right:20px;font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--blanc);background:var(--copper);padding:4px 10px;border-radius:10px}
.pricing-card-label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3);margin-bottom:8px}
.pricing-card-tier{font-family:var(--fd);font-weight:200;font-size:clamp(22px,3vw,28px);letter-spacing:-.03em;color:var(--forest);margin-bottom:16px}
.pricing-card-price{font-family:var(--fd);font-weight:200;font-size:clamp(32px,5vw,42px);letter-spacing:-.03em;color:var(--forest);margin-bottom:6px}
.pricing-card-price span{font-size:14px;color:var(--ink2);letter-spacing:0;font-weight:300}
.pricing-card-price-wrap{margin-bottom:6px}
.pricing-card-billed{font-size:11px;color:var(--copper);min-height:16px;margin-bottom:4px}
.pricing-card-desc{font-size:13px;line-height:1.7;color:var(--ink2);margin-bottom:24px}

/* pricing toggle */
.pricing-toggle{display:inline-flex;background:rgba(13,31,19,.06);border-radius:8px;padding:2px;margin-bottom:16px}
.pricing-toggle-btn{font-family:var(--fb);font-size:11px;font-weight:400;padding:6px 14px;border:none;border-radius:6px;background:transparent;color:var(--ink3);cursor:pointer;transition:all .2s}
.pricing-toggle-btn.active{background:var(--white);color:var(--forest);box-shadow:0 1px 4px rgba(13,31,19,.08)}

/* feature list */
.pricing-features{list-style:none;padding:0;margin:0 0 28px}
.pricing-features li{font-size:13px;line-height:1.7;color:var(--ink2);padding:4px 0 4px 22px;position:relative}
.pricing-features li::before{content:'';position:absolute;left:0;top:10px;width:10px;height:6px;border-left:1.5px solid var(--copper);border-bottom:1.5px solid var(--copper);transform:rotate(-45deg)}
.pricing-feat--accent{color:var(--forest)}

/* CTA buttons */
.pricing-cta{font-family:var(--fb);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:14px 28px;border-radius:8px;cursor:pointer;transition:opacity .18s;width:100%;border:none;margin-top:auto}
.pricing-cta:hover{opacity:.75}
.pricing-cta--free{background:transparent;border:1px solid var(--border);color:var(--forest)}
.pricing-cta--pro{background:var(--copper);color:var(--blanc)}
.pricing-trial-note{font-size:11px;color:var(--ink3);text-align:center;margin-top:10px}

/* triggers row */
.pricing-triggers{max-width:820px;margin:0 auto}
.pricing-triggers-label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3);text-align:center;margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:10px}
.pricing-triggers-label::before,.pricing-triggers-label::after{content:'';width:18px;height:1px;background:var(--ink3);opacity:.4}
.pricing-triggers-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2px}
.pricing-trigger{background:#F7F5F2;border-radius:12px;padding:20px 24px;text-align:center}
.pricing-trigger-name{font-family:var(--fd);font-weight:200;font-size:18px;letter-spacing:-.02em;color:var(--forest);margin-bottom:4px}
.pricing-trigger-tiers{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:8px}
.pricing-trigger-tiers--pro{color:var(--copper)}
.pricing-trigger-desc{font-size:12px;line-height:1.6;color:var(--ink2)}

/* ══ WAITLIST ══ */
.waitlist{background:var(--forest);padding:100px 0;position:relative;z-index:2;overflow:hidden}
.waitlist::before{content:'';position:absolute;bottom:-200px;left:-100px;width:600px;height:600px;background:radial-gradient(circle,rgba(184,92,42,.07) 0%,transparent 60%);border-radius:50%;pointer-events:none}
.waitlist-inner{max-width:1160px;margin:0 auto;padding:0 56px}
.waitlist-eyebrow{font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:rgba(184,92,42,.7);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.waitlist-eyebrow::before{content:'';display:block;width:18px;height:1px;background:rgba(184,92,42,.5)}
.waitlist-hed{font-family:var(--fd);font-weight:200;font-size:clamp(36px,5vw,72px);line-height:.97;letter-spacing:-.045em;color:var(--blanc);margin-bottom:16px}
.waitlist-hed em{font-style:italic;color:var(--copper)}
.waitlist-sub{font-size:14px;color:rgba(250,250,250,.5);line-height:1.8;max-width:480px;margin-bottom:64px}
.waitlist-tracks{display:grid;grid-template-columns:1fr 0.5px 1fr}
.wt{padding:40px 48px}
.wt:first-child{padding-left:0}
.wt:last-child{padding-right:0}
.wt-sep{background:rgba(250,250,250,.08)}
.wt-eyebrow{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(250,250,250,.35);margin-bottom:16px}
.wt-title{font-family:var(--fd);font-weight:200;font-size:clamp(24px,3vw,38px);letter-spacing:-.035em;color:var(--blanc);margin-bottom:8px;line-height:1.1}
.wt-title em{font-style:italic;color:var(--copper)}
.wt-sub{font-size:13px;line-height:1.8;color:rgba(250,250,250,.45);margin-bottom:24px}
.wt-label{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:rgba(250,250,250,.35);margin-bottom:8px}
.wt-row{display:flex;flex-direction:column;gap:7px;margin-bottom:10px}
.wt-inp{background:rgba(250,250,250,.06);border:0.5px solid rgba(250,250,250,.12);border-radius:6px;padding:0 14px;font-family:var(--fb);font-size:13px;font-weight:300;color:var(--blanc);outline:none;transition:border-color .2s;height:42px;width:100%}
.wt-inp::placeholder{color:rgba(138,158,144,.3)}
.wt-inp:focus{border-color:rgba(184,92,42,.5)}
.wt-btn{width:100%;font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:var(--copper);color:var(--blanc);border:none;height:42px;border-radius:6px;cursor:pointer;transition:opacity .18s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:7px}
.wt-btn:hover{opacity:.75}
.wt-consent{display:flex;align-items:flex-start;gap:8px;margin:8px 0}
.wt-cb{width:20px;height:20px;border:0.5px solid rgba(138,158,144,.28);border-radius:3px;flex-shrink:0;margin-top:1px;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer;transition:background .2s;position:relative}
.wt-cb:checked{background:var(--copper);border-color:var(--copper)}
.wt-cb:checked::after{content:'✓';position:absolute;top:-1px;left:2px;font-size:9px;color:var(--blanc)}
.wt-consent-lbl{font-size:10px;line-height:1.6;color:rgba(250,250,250,.4)}
.wt-consent-lbl a{color:var(--copper);text-decoration:none}
.wt-cerr{font-size:10px;color:#c0522a;display:none;margin-bottom:6px}
.wt-cerr.show{display:block}
.wt-btn.loading{pointer-events:none;opacity:.6}
.wt-btn.loading svg{display:none}
.wt-btn.loading::after{content:'';width:14px;height:14px;border:2px solid rgba(250,250,250,.3);border-top-color:var(--blanc);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.wt-ok{display:none;font-size:11px;color:rgba(138,158,144,.8);padding:8px 0}
.wt-ok.on{display:flex;align-items:center;gap:8px;animation:fadeUp .5s cubic-bezier(.22,.68,0,1) forwards}
.sup-btn.loading{pointer-events:none;opacity:.6}
.sup-btn.loading::after{content:'';width:12px;height:12px;border:2px solid rgba(250,250,250,.3);border-top-color:var(--blanc);border-radius:50%;animation:spin .6s linear infinite;margin-left:8px;display:inline-block}
.wt-note{font-size:10px;color:rgba(138,158,144,.4);margin-top:6px}

footer{padding:26px 52px;display:flex;align-items:center;justify-content:space-between;border-top:0.5px solid var(--border);background:var(--blanc);position:relative;z-index:2}
.f-l{display:flex;align-items:center;gap:10px}
.f-name{font-family:var(--fd);font-size:10px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--ink3)}
.f-links{display:flex;gap:16px}
.f-link{font-size:10px;color:rgba(28,43,34,.45);letter-spacing:.04em;text-decoration:none;cursor:pointer;transition:color .2s}
.f-link:hover{color:var(--copper)}
.f-r{font-size:10px;color:rgba(28,43,34,.4);letter-spacing:.04em}
.f-social{color:rgba(28,43,34,.3);text-decoration:none;transition:color .2s;display:flex;align-items:center}
.f-social:hover{color:var(--copper)}

.modal-overlay{position:fixed;inset:0;background:rgba(13,31,19,.72);z-index:10000;display:none;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(4px)}
.modal-overlay.open{display:flex}
.modal{background:var(--blanc);border-radius:12px;max-width:640px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 32px 80px rgba(13,31,19,.3)}
.modal-head{padding:26px 30px 18px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-title{font-family:var(--fd);font-size:17px;font-weight:200;color:var(--ink);letter-spacing:-.02em}
.modal-close{width:30px;height:30px;border:none;background:rgba(28,43,34,.06);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}
.modal-close:hover{background:rgba(28,43,34,.12)}
.modal-body{padding:26px 30px;overflow-y:auto;flex:1}
.modal-body h3{font-family:var(--fd);font-size:11px;font-weight:300;color:var(--ink);letter-spacing:.07em;text-transform:uppercase;margin:22px 0 8px}
.modal-body h3:first-child{margin-top:0}
.modal-body p{font-size:13px;line-height:1.8;color:var(--ink2);margin-bottom:10px}
.modal-body a{color:var(--copper);text-decoration:none}

.rv{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.rv.on{opacity:1;transform:none}
.rv.d1{transition-delay:.12s}.rv.d2{transition-delay:.24s}.rv.d3{transition-delay:.36s}.rv.d4{transition-delay:.48s}

/* ══ HOW IT WORKS — CENTRALIZED INTERACTIVE ══ */
.how-section{background:var(--blanc);padding:80px 0 0;position:relative}
.how-section::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}
.how-header{max-width:1160px;margin:0 auto;padding:0 56px 40px}
.how-eyebrow{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.how-eyebrow-line{display:block;width:18px;height:1px;background:var(--ink3)}
.how-hed{font-family:var(--fd);font-weight:200;font-size:clamp(32px,4.2vw,62px);line-height:1.0;letter-spacing:-.04em;color:var(--forest)}
.how-hed em{font-style:italic;color:var(--copper)}

/* stage: 2-col grid */
.how-stage{max-width:1160px;margin:0 auto;padding:0 56px;display:grid;grid-template-columns:340px 1fr;gap:60px;align-items:center;min-height:70vh}

/* text column */
.how-text-col{position:relative;min-height:300px}
.how-text{position:absolute;top:0;left:0;right:0;opacity:0;transform:translateY(12px);transition:opacity .5s cubic-bezier(.22,.68,0,1),transform .5s cubic-bezier(.22,.68,0,1);pointer-events:none}
.how-text.active{opacity:1;transform:none;pointer-events:auto}
.how-text-num{font-family:var(--fd);font-weight:200;font-size:48px;letter-spacing:-.03em;color:var(--copper);opacity:.35;margin-bottom:8px}
.how-text-time{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px}
.how-text-title{font-family:var(--fd);font-weight:200;font-size:clamp(24px,3vw,38px);letter-spacing:-.035em;color:var(--forest);line-height:1.1;margin-bottom:14px}
.how-text-title em{font-style:italic;color:var(--copper)}
.how-text-body{font-size:14px;line-height:1.85;color:var(--ink2);max-width:380px}

/* visual column */
.how-visual{position:relative;min-height:580px;display:flex;justify-content:center;align-items:center}

/* scenes */
.how-scene{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.97);transition:opacity .6s cubic-bezier(.22,.68,0,1),transform .6s cubic-bezier(.22,.68,0,1);pointer-events:none}
.how-scene.active{opacity:1;transform:none;pointer-events:auto}

/* ══ SCENE 0: Wearable → Connection → Blob ══ */
.hw-watch{flex-shrink:0;flex-grow:0;width:140px;opacity:0;transform:translateX(-20px);transition:opacity .6s ease .2s,transform .6s cubic-bezier(.22,.68,0,1) .2s}
.how-scene.active .hw-watch{opacity:1;transform:none}
.hw-watch-svg{width:140px;height:auto;display:block}
.hw-hrv-line{stroke-dasharray:200;stroke-dashoffset:200;transition:stroke-dashoffset 1.5s ease .8s}
.how-scene.active .hw-hrv-line{stroke-dashoffset:0}

.hw-connection{width:140px;height:70px;flex-shrink:0;flex-grow:0;opacity:0;transition:opacity .5s ease .5s}
.how-scene.active .hw-connection{opacity:1}
.hw-connection-path{stroke-dasharray:200;stroke-dashoffset:200;transition:stroke-dashoffset 1.5s ease .6s}
.how-scene.active .hw-connection-path{stroke-dashoffset:0}
.hw-data-particle{opacity:0}
.how-scene.active .hw-data-particle{opacity:1}

.hw-blob{width:180px;height:180px;flex-shrink:0;flex-grow:0;background:radial-gradient(ellipse at 38% 32%,rgba(184,92,42,.55) 0%,rgba(184,92,42,.35) 30%,rgba(184,92,42,.15) 60%,transparent 100%);border-radius:60% 40% 30% 70% / 60% 30% 70% 40%;animation:blobMorph 12s ease-in-out infinite,blobFloat 8s ease-in-out infinite;opacity:0;transform:scale(.8);transition:opacity .6s ease .4s,transform .8s cubic-bezier(.22,.68,0,1) .4s}
.how-scene.active .hw-blob{opacity:1;transform:scale(1)}

/* ══ SCENE 1: Half Phone ══ */
.hw-half-wrap{overflow:hidden;max-height:420px;border-radius:44px 44px 0 0;opacity:0;transform:translateY(40px);transition:opacity .6s ease .1s,transform .8s cubic-bezier(.22,.68,0,1) .1s}
.how-scene.active .hw-half-wrap{opacity:1;transform:none}
.hw-half-phone{position:relative;width:280px;height:580px;background:#0a0a0a;border-radius:44px;overflow:hidden;box-shadow:0 40px 100px rgba(13,31,19,.3),inset 0 0 0 2px rgba(250,250,250,.08)}
.hw-half-notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:100px;height:28px;background:#000;border-radius:16px;z-index:30;box-shadow:0 0 0 2px #0a0a0a}
.hw-half-screen{position:absolute;top:8px;left:8px;right:8px;bottom:8px;border-radius:38px;background:linear-gradient(170deg,#1a1a2e 0%,#2d2d44 100%);overflow:hidden;display:flex;flex-direction:column}
.hw-half-status{position:relative;z-index:10;padding:42px 14px 6px;display:flex;align-items:center}
.hw-half-time{font-family:var(--fd);font-size:11px;font-weight:300;color:rgba(250,250,250,.4);letter-spacing:.02em}
.hw-half-clock{font-family:var(--fd);font-size:52px;font-weight:200;color:var(--blanc);text-align:center;margin-top:16px;letter-spacing:-.03em;opacity:0;transition:opacity .5s ease .4s}
.how-scene.active .hw-half-clock{opacity:1}
.hw-half-date{font-size:9px;color:rgba(250,250,250,.4);text-align:center;letter-spacing:.02em}
.hw-half-notif{margin:28px 14px 0;background:rgba(250,250,250,.08);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:0.5px solid rgba(250,250,250,.1);border-radius:14px;padding:11px 13px;opacity:0;transform:translateY(-16px);transition:opacity .45s ease 1.2s,transform .45s cubic-bezier(.22,.68,0,1) 1.2s}
.how-scene.active .hw-half-notif{opacity:1;transform:none}
.hw-half-notif-app{display:flex;align-items:center;gap:5px;font-size:9px;font-weight:500;color:rgba(250,250,250,.7);margin-bottom:3px}
.hw-half-notif-ago{margin-left:auto;font-weight:300;color:rgba(250,250,250,.3);font-size:8px}
.hw-half-notif-title{font-size:10px;font-weight:500;color:var(--blanc);margin-bottom:1px}
.hw-half-notif-body{font-size:9px;color:rgba(250,250,250,.45);line-height:1.4}

/* ══ SCENE 2: Lens Phone + Cards ══ */
.hw-lens-wrap{position:relative;width:100%;height:580px;display:flex;align-items:center;justify-content:center;overflow:visible}
.hw-lens-strip{display:flex;gap:14px;position:absolute;left:50%;top:50%;margin-top:-275px;z-index:1;transition:transform .8s cubic-bezier(.22,.68,0,1);will-change:transform}
.hw-lens-card{width:260px;height:550px;flex-shrink:0;background:#F6F3EF;border-radius:36px;padding:18px 16px 16px;display:flex;flex-direction:column;filter:blur(3px);opacity:.3;transition:filter .6s ease,opacity .6s ease;box-shadow:0 12px 48px rgba(13,31,19,.1);overflow:hidden}
.hw-lens-card.in-lens{filter:none;opacity:1}

/* card top bar */
.hw-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.hw-card-time{font-family:var(--fd);font-size:11px;font-weight:300;color:var(--ink3);letter-spacing:.02em}
.hw-card-spore{font-size:7px;letter-spacing:.14em;text-transform:uppercase;color:var(--copper);display:flex;align-items:center;gap:5px}
.hw-card-dot{width:5px;height:5px;border-radius:50%;background:var(--copper);display:inline-block;animation:pulse 2.5s ease infinite}

/* venue */
.hw-card-venue-row{margin-bottom:12px}
.hw-card-now-at{font-size:7px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);display:block;margin-bottom:2px}
.hw-card-venue-name{font-family:var(--fd);font-size:17px;font-weight:200;color:var(--forest);letter-spacing:-.02em}

/* health bar */
.hw-card-health-bar{display:flex;gap:0;background:rgba(184,92,42,.06);border-radius:10px;padding:8px 0;margin-bottom:10px}
.hw-card-stat{flex:1;text-align:center;border-right:0.5px solid rgba(184,92,42,.1)}
.hw-card-stat:last-child{border-right:none}
.hw-card-stat-v{font-family:var(--fd);font-size:15px;font-weight:200;color:var(--forest);display:block;line-height:1.1}
.hw-card-stat-u{font-size:9px;font-weight:300;color:var(--ink3)}
.hw-card-stat-l{font-size:6px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-top:1px;display:block}

/* state pills */
.hw-card-pills{display:flex;gap:6px;margin-bottom:12px}
.hw-card-pill{font-family:var(--fb);font-size:8px;font-weight:500;letter-spacing:.04em;padding:5px 10px;border-radius:20px;border:0.5px solid var(--border);color:var(--ink3);background:transparent}
.hw-card-pill.active{background:var(--forest);color:var(--blanc);border-color:var(--forest)}

/* divider */
.hw-card-divider{height:0.5px;background:var(--border);margin-bottom:10px}

/* match label */
.hw-card-match-label{font-size:7px;letter-spacing:.14em;text-transform:uppercase;color:var(--copper);margin-bottom:4px}

/* product name */
.hw-card-product{font-family:var(--fd);font-size:20px;font-weight:200;color:var(--forest);line-height:1.15;letter-spacing:-.02em;margin-bottom:4px}
.hw-card-product em{font-style:italic}

/* modification */
.hw-card-mod-line{font-size:9px;font-weight:500;color:var(--copper);margin-bottom:10px}

/* reasoning */
.hw-card-reason{font-size:9px;color:var(--ink2);line-height:1.65;margin-bottom:0}

/* spacer */
.hw-card-spacer{flex:1;min-height:8px}

/* addon CTA */
.hw-card-addon{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:0.5px solid var(--border);border-radius:8px;font-size:8px;color:var(--ink2);margin-bottom:8px;background:rgba(250,250,250,.6)}
.hw-card-addon-arrow{font-size:14px;color:var(--copper);font-weight:300;line-height:1}

/* main CTA */
.hw-card-cta{text-align:center;padding:12px;background:var(--copper);border-radius:12px;font-family:var(--fb);font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--blanc);flex-shrink:0}

/* phone lens frame */
.hw-phone-lens{position:absolute;z-index:2;width:280px;height:580px;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:44px;pointer-events:none;overflow:hidden}
/* build the frame using border + pseudo for screen cutout */
.hw-phone-lens::before{content:'';position:absolute;inset:0;border-radius:44px;border:8px solid #0a0a0a;box-shadow:inset 0 0 0 1px rgba(250,250,250,.08);z-index:2}
.hw-phone-lens::after{content:'';position:absolute;inset:0;border-radius:44px;box-shadow:0 40px 100px rgba(13,31,19,.25);z-index:0;pointer-events:none}
.hw-lens-notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:100px;height:28px;background:#000;border-radius:16px;z-index:30;box-shadow:0 0 0 2px #0a0a0a}

/* step navigation */
.how-nav{grid-column:1/-1;display:flex;justify-content:center;gap:12px;margin-top:40px}
.how-nav-btn{width:44px;height:44px;border-radius:50%;border:0.5px solid var(--border);background:var(--white);font-family:var(--fd);font-size:15px;font-weight:200;color:var(--ink3);cursor:pointer;transition:all .3s ease}
.how-nav-btn:hover{border-color:rgba(184,92,42,.4);color:var(--copper)}
.how-nav-btn.active{border-color:var(--copper);color:var(--copper);background:rgba(184,92,42,.06)}

/* stat strip */
.how-stats{max-width:1160px;margin:0 auto;padding:56px 56px;display:flex;gap:0;border-top:0.5px solid var(--border)}
.how-stats .stat-item{flex:1;padding:0 24px;border-right:0.5px solid var(--border)}
.how-stats .stat-item:first-child{padding-left:0}
.how-stats .stat-item:last-child{border-right:none}
.how-stats .stat-val{font-family:var(--fd);font-size:24px;font-weight:200;color:var(--copper);letter-spacing:-.03em;display:block;margin-bottom:2px}
.how-stats .stat-lbl{font-size:10px;color:var(--ink3);letter-spacing:.03em}

/* ══ ENGINE STRIP ══ */
.engine-strip{background:var(--forest);padding:100px 48px;position:relative;overflow:hidden}
.engine-strip::before{content:'';position:absolute;inset:0;background:url("../images/engine-bg.png") center center/cover no-repeat;opacity:.45;z-index:0}
.engine-strip::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(13,31,19,.4) 0%,rgba(13,31,19,.6) 50%,rgba(13,31,19,.8) 100%);z-index:0}
.engine-inner{max-width:1160px;margin:0 auto;position:relative;z-index:1}
.engine-header{margin-bottom:56px}
.engine-eyebrow{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(250,250,250,.4);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.engine-eyebrow::before{content:'';display:block;width:16px;height:1px;background:rgba(250,250,250,.2)}
.engine-hed{font-family:var(--fd);font-weight:200;font-size:clamp(28px,3.4vw,48px);line-height:1.05;letter-spacing:-.04em;color:var(--blanc)}
.engine-hed em{font-style:italic;color:var(--copper)}
/* 2x2 glass card grid */
.engine-steps{display:grid;grid-template-columns:1fr 1fr;gap:16px;position:relative}
.engine-step{background:rgba(13,31,19,.55);border:0.5px solid rgba(250,250,250,.1);border-radius:20px;padding:36px 32px;position:relative;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:background .4s ease,border-color .4s ease,transform .4s ease}
.engine-step:hover{background:rgba(13,31,19,.65);border-color:rgba(184,92,42,.25);transform:translateY(-2px)}
.engine-step-top{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.engine-step-icon{
  width:52px;height:52px;border-radius:14px;
  background:rgba(184,92,42,.08);
  border:0.5px solid rgba(184,92,42,.15);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:background .3s,border-color .3s;
}
.engine-step:hover .engine-step-icon{background:rgba(184,92,42,.15);border-color:rgba(184,92,42,.3)}
.engine-step .engine-step-icon{opacity:.4;transition:opacity .5s ease,background .3s,border-color .3s}
.engine-steps.in-view .engine-step .engine-step-icon{opacity:1}
.engine-steps.in-view .engine-step:nth-child(2) .engine-step-icon{transition-delay:.15s}
.engine-steps.in-view .engine-step:nth-child(3) .engine-step-icon{transition-delay:.3s}
.engine-steps.in-view .engine-step:nth-child(4) .engine-step-icon{transition-delay:.45s}
.engine-step-num{font-family:var(--fd);font-weight:200;font-size:32px;letter-spacing:-.03em;color:rgba(250,250,250,.12)}
.engine-step-title{font-family:var(--fd);font-weight:200;font-size:22px;letter-spacing:-.02em;color:var(--blanc);line-height:1.2;margin-bottom:10px}
.engine-step-title em{font-style:italic;color:var(--copper)}
.engine-step-body{font-size:14px;line-height:1.8;color:rgba(250,250,250,.5);max-width:380px}

/* Ken Burns zoom */
.ken-burns{transform:scale(1);transition:transform 8s cubic-bezier(.22,.68,0,1)}
.ken-burns.zooming{transform:scale(1.08)}

/* icon animations */
@keyframes eng-sync{0%,100%{transform:rotate(0deg)}50%{transform:rotate(180deg)}}
@keyframes eng-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
@keyframes eng-scan{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
@keyframes eng-pop{0%,100%{transform:scale(1) rotate(0deg)}50%{transform:scale(1.1) rotate(3deg)}}

/* ══ SIGNAL SECTION ══ */
.signal{background:var(--blanc);padding:80px 0 80px;border-top:0.5px solid var(--border)}
.signal-inner{max-width:1280px;margin:0 auto;padding:0 56px 0;display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:center}
.signal-eyebrow{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--copper);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.signal-eyebrow::before{content:'';display:block;width:16px;height:1px;background:var(--copper);opacity:.6}
.signal-hed{font-family:var(--fd);font-weight:200;font-size:clamp(28px,3.6vw,54px);line-height:1.0;letter-spacing:-.04em;color:var(--forest);margin-bottom:16px}
.signal-hed em{font-style:italic;color:var(--copper)}
.signal-body{font-size:14px;line-height:1.85;color:var(--ink2);margin-bottom:24px;max-width:440px}
.signal-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:0.5px dashed rgba(28,43,34,.2);border-radius:6px}
.signal-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--copper);animation:pulse 2.5s ease infinite}
.signal-badge-text{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}
.signal-pro{display:inline-flex;align-items:center;gap:6px;background:rgba(184,92,42,.08);border:0.5px solid rgba(184,92,42,.18);border-radius:4px;padding:3px 9px;font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--copper);margin-bottom:20px}

/* map visual */

.signal-score-card{
  position:absolute;top:16px;right:16px;
  background:var(--blanc);border:0.5px solid var(--border);
  border-radius:10px;padding:10px 14px;
  box-shadow:0 4px 16px rgba(13,31,19,.1);
  opacity:0;transform:translateY(-6px);
  transition:opacity .4s ease 2s, transform .4s ease 2s;
  z-index:10;
}
.signal-score-card.show{opacity:1;transform:none}
.signal-score-card-name{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:3px}
.signal-score-card-state{font-family:'Raleway',sans-serif;font-weight:200;font-size:14px;color:var(--forest);letter-spacing:-.01em}
.signal-score-card-state em{font-style:italic;color:var(--copper)}

.signal-map-wrap{position:relative}
.signal-map{
  width:100%;
  height:520px;
  max-width:560px;
  background:var(--white);
  border:none;
  border-radius:20px;
  position:relative;overflow:hidden;
  box-shadow:0 16px 56px rgba(13,31,19,.06);
}
.signal-map *,.signal-map .mapboxgl-canvas-container,.signal-map .mapboxgl-canvas{border:none!important;outline:none!important}
/* road lines */
.signal-road{position:absolute;background:rgba(28,43,34,.07);border-radius:2px}

/* venue pins */
.signal-pin{
  position:absolute;
  display:flex;flex-direction:column;align-items:center;
  opacity:0;transform:translateY(-20px);
  transition:opacity .5s cubic-bezier(.22,.68,0,1), transform .6s cubic-bezier(.22,.68,0,1);
}
.signal-pin.drop{opacity:1;transform:translateY(0)}
.signal-pin-head{
  width:22px;height:22px;border-radius:50% 50% 50% 0;
  background:var(--copper);transform:rotate(-45deg);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 12px rgba(184,92,42,.35);
  flex-shrink:0;
}
.signal-pin-head-inner{width:7px;height:7px;border-radius:50%;background:var(--blanc);transform:rotate(45deg)}
.signal-pin-shadow{width:7px;height:3px;border-radius:50%;background:rgba(184,92,42,.2);margin-top:2px}
.signal-pin.dim .signal-pin-head{background:rgba(184,92,42,.35);box-shadow:none}

/* score label on best match */
.signal-score-label{
  position:absolute;top:-28px;left:50%;transform:translateX(-50%);
  background:var(--forest);color:var(--blanc);
  font-family:'Raleway',sans-serif;font-weight:200;font-size:11px;
  padding:3px 8px;border-radius:4px;white-space:nowrap;
  opacity:0;transition:opacity .4s ease .8s;
  letter-spacing:.02em;
}
.signal-pin.drop .signal-score-label{opacity:1}
.signal-score-label::after{
  content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:4px solid transparent;border-top-color:var(--forest);
}

/* user dot */
.signal-user{
  position:absolute;
  width:12px;height:12px;border-radius:50%;
  background:var(--forest);border:2.5px solid var(--blanc);
  box-shadow:0 2px 8px rgba(13,31,19,.25);
  opacity:0;transition:opacity .4s ease;
}
.signal-user.show{opacity:1}
.signal-user-ring{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:28px;height:28px;border-radius:50%;
  border:1.5px solid rgba(13,31,19,.12);
  animation:pulse 2.2s ease infinite;
}

/* route lines */
.signal-route{
  position:absolute;inset:0;
  pointer-events:none;overflow:visible;
}
.signal-route-line{
  stroke-dasharray:80;stroke-dashoffset:80;
  transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1) .5s;
}
.signal-route-line.draw{stroke-dashoffset:0}

/* state chip on map */
.signal-state-chip{
  position:absolute;bottom:16px;left:16px;
  background:var(--blanc);border:0.5px solid var(--border);
  border-radius:8px;padding:8px 12px;
  box-shadow:0 4px 16px rgba(13,31,19,.08);
  opacity:0;transform:translateY(6px);
  transition:opacity .4s ease 1.2s, transform .4s ease 1.2s;
}
.signal-state-chip.show{opacity:1;transform:none}
.signal-state-chip-label{font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:3px}
.signal-state-chip-val{font-family:'Raleway',sans-serif;font-weight:200;font-size:13px;color:var(--forest);letter-spacing:-.01em}
.signal-state-chip-val em{font-style:italic;color:var(--copper)}

/* ══ RESPONSIVE ══ */
@media(max-width:960px){
  nav.topnav,.snav{padding:20px 24px}
  .hero-inner,.how-inner,.venue-inner,.waitlist-inner,.supplier-inner{padding:0 24px}
  .venue-hero{grid-template-columns:1fr;gap:28px}
  .venue-photo-wrap{height:240px}
  .venue-acc-copy{margin-left:0}
  .boosts-panel{grid-template-columns:1fr;gap:32px;padding:32px 24px}
  .waitlist-tracks{grid-template-columns:1fr}
  .wt-sep{display:none}
  .wt,.wt:first-child,.wt:last-child{padding:32px 0}
  .supplier-inner{flex-direction:column;gap:28px}
  nav.topnav{display:none}
  .snav{position:fixed;transform:none}
  .snav-links{display:none}
  .snav-cta{display:none}
  .snav-burger{display:flex}
  .engine-strip{padding:72px 24px}
  .signal-inner{grid-template-columns:1fr;gap:32px}
  .how-stage{grid-template-columns:1fr;gap:32px;padding-left:24px;padding-right:24px}
  .how-text-col{min-height:auto;position:relative}
  .how-text{position:relative;display:none}
  .how-text.active{display:block;text-align:center}
  .how-visual{min-height:440px}
  .hw-watch-svg{width:110px}
  .hw-blob{width:140px;height:140px}
  .hw-connection{width:100px}
  .hw-half-phone{width:260px;height:540px}
  .hw-half-wrap{max-height:360px}
  .hw-phone-lens{width:260px;height:540px}
  .hw-lens-card{width:240px;height:510px}
  .hw-lens-wrap{overflow:hidden}
  .how-section{overflow:hidden}
  .how-header,.how-stats{padding-left:24px;padding-right:24px}
  .how-stats{flex-wrap:wrap;gap:16px}
  .how-stats .stat-item{flex:none;width:calc(50% - 8px);padding:0;border:none}
  footer{padding:22px 24px;flex-direction:column;gap:10px;text-align:center}
  .f-links{justify-content:center}
  .pricing-inner{padding:0 24px}
  .pricing-cards{grid-template-columns:1fr;max-width:420px}
  .pricing-triggers-row{grid-template-columns:1fr;gap:10px}
}
@media(max-width:560px){
  nav.topnav{padding:16px 20px}
  .snav{padding:0 20px}
  .hero-inner{padding:0 20px}
  .hero-sub{margin-bottom:28px}
  .hero-launch{font-size:10px}
  .engine-strip{padding:60px 20px}
  .engine-steps{grid-template-columns:1fr}
  .engine-step{padding:28px 24px}
  .states-track{padding:60px 20px}
  .states-accordion{max-width:100%}
  .state-acc-header{gap:10px;padding:18px 0}
  .state-card-chip{padding:3px 8px}
  .state-card-chip-label{font-size:6px}
  .state-card-chip-val{font-size:8px}
  .signal-inner{padding:0 20px}
  .signal-map{height:360px}
  .how-section{padding:60px 0 0;overflow:hidden}
  .how-visual{min-height:340px}
  .hw-watch-svg{width:90px}
  .hw-blob{width:110px;height:110px}
  .hw-connection{width:70px}
  .hw-half-phone{width:220px;height:460px}
  .hw-half-wrap{max-height:300px}
  .hw-phone-lens{display:none}
  .hw-lens-wrap{height:auto;overflow:hidden}
  .hw-lens-strip{position:relative;left:auto;top:auto;margin-top:0;flex-wrap:wrap;justify-content:center}
  .hw-lens-card{width:100%;max-width:280px;height:auto;margin:0 auto;display:none;border-radius:24px}
  .hw-lens-card.in-lens{display:flex;filter:none;opacity:1}
  .how-header{padding:0 20px 40px}
  .how-stats{padding:40px 20px}
  .how-stats .stat-item{flex:none;width:100%;padding:12px 0;border-right:none;border-bottom:0.5px solid var(--border)}
  .how-stats .stat-item:last-child{border-bottom:none}
  .venue-inner{padding:0 20px}
  .venue-hero{grid-template-columns:1fr;gap:24px}
  .venue-photo-wrap{height:200px}
  .venue-accordion{max-width:100%}
  .venue-acc-header{gap:10px;flex-wrap:wrap}
  .venue-acc-tag{min-width:auto}
  .venue-acc-copy{margin-left:0}
  .boosts-panel{padding:28px 20px}
  .supplier-inner{padding:0 20px}
  .pricing{padding:60px 0}
  .pricing-inner{padding:0 20px}
  .pricing-cards{max-width:100%}
  .pricing-card{padding:28px 24px}
  .pricing-triggers-row{gap:8px}
  .pricing-trigger{padding:16px 18px}
  .waitlist{padding:60px 0}
  .waitlist-inner{padding:0 20px}
  footer{padding:20px}
}