/* ---------- VIGIL BRAND KIT v2 · security register ---------- */
:root{
  /* darks */
  --onyx:#0A0E14;
  --midnight:#0F1B2E;
  --steel:#1A2540;
  /* lights */
  --paper:#FBFCFD;
  --frost:#F4F6F8;
  --hair:#D5DCE2;
  /* greys */
  --slate:#5A6573;
  --slate-soft:#8B95A3;
  /* trust accent */
  --signal:#2456E0;
  --signal-soft:#4A7BFF;
  --signal-bg:rgba(36,86,224,.08);
  /* alert */
  --crimson:#C92B2B;
  --crimson-deep:#8B1818;
  /* type */
  --display:'Inter','Helvetica Neue',Arial,sans-serif;
  --body:'Inter','Helvetica Neue',Arial,sans-serif;
  --mono:'JetBrains Mono','SF Mono',Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--onyx);font-family:var(--body);font-size:16px;font-weight:400;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
strong{font-weight:700}
a{color:inherit;text-decoration:none}
img,svg,video{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--display);margin:0;letter-spacing:-0.025em}
h1{font-size:clamp(48px,8vw,108px);font-weight:900;line-height:0.96;letter-spacing:-0.035em}
h2{font-size:clamp(34px,5vw,64px);font-weight:800;line-height:1.02;letter-spacing:-0.03em}
h3{font-size:clamp(22px,2.4vw,28px);font-weight:700;line-height:1.15;letter-spacing:-0.02em}
h4{font-size:14px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
p{margin:0 0 1em}

/* emphasis — bold blue, not italic gold */
.em{color:var(--signal);font-weight:900;font-style:normal}
section.dark .em,.hero .em,.waitlist .em{color:var(--signal-soft)}

/* eyebrows + ledes */
.eyebrow{font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--slate);margin:0 0 18px;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";display:inline-block;width:18px;height:2px;background:var(--signal)}
section.dark .eyebrow,.hero .eyebrow,.waitlist .eyebrow{color:var(--slate-soft)}
section.dark .eyebrow::before,.hero .eyebrow::before,.waitlist .eyebrow::before{background:var(--signal-soft)}
.lede{font-family:var(--body);font-weight:400;font-size:clamp(17px,1.5vw,20px);color:var(--onyx);max-width:58ch;line-height:1.55}
.lede strong{font-weight:600}
section.dark .lede,.hero .lede,.waitlist .lede{color:rgba(244,246,248,.82)}

.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:920px;margin:0 auto;padding:0 32px}

/* ---------- nav ---------- */
nav.top{position:sticky;top:0;z-index:50;background:rgba(251,252,253,.92);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--hair)}
nav.top .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:14px}
.brand .mark{font-family:var(--display);font-weight:900;font-size:22px;letter-spacing:-0.02em;color:var(--onyx)}
.brand .mark::after{content:"";display:inline-block;width:6px;height:6px;background:var(--signal);border-radius:50%;margin-left:8px;margin-bottom:2px;vertical-align:middle;animation:livepulse 2.4s ease-out infinite}
@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(36,86,224,.6)}70%{box-shadow:0 0 0 8px rgba(36,86,224,0)}100%{box-shadow:0 0 0 0 rgba(36,86,224,0)}}
.brand .meta{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);padding-left:14px;border-left:1px solid var(--hair)}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--onyx);opacity:.78;transition:opacity .2s ease}
.nav-links a:hover{opacity:1;color:var(--signal)}
.nav-links a.cta{padding:11px 20px;background:var(--onyx);color:var(--paper);opacity:1;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:none;border-radius:2px;border:none}
.nav-links a.cta:hover{background:var(--signal);color:var(--paper)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 28px;border-radius:2px;font-size:13px;font-weight:600;letter-spacing:.04em;transition:all .2s ease;cursor:pointer;border:1px solid transparent;font-family:var(--body)}
.btn.signal{background:var(--signal);color:var(--paper);border-color:var(--signal)}
.btn.signal:hover{background:var(--onyx);border-color:var(--onyx)}
.btn.ink{background:var(--onyx);color:var(--paper);border-color:var(--onyx)}
.btn.ink:hover{background:var(--signal);border-color:var(--signal)}
.btn.outline{background:transparent;color:var(--onyx);border-color:var(--onyx)}
.btn.outline:hover{background:var(--onyx);color:var(--paper)}
.btn.ghost{background:transparent;color:var(--paper);border-color:rgba(244,246,248,.45)}
.btn.ghost:hover{background:var(--paper);color:var(--onyx);border-color:var(--paper)}
.btn::after{content:"→";font-weight:500;opacity:.8;transition:transform .2s}
.btn:hover::after{transform:translateX(4px)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;padding:80px 0 96px;background:var(--onyx);color:var(--paper);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg, rgba(10,14,20,0) 0%, rgba(10,14,20,.35) 45%, rgba(10,14,20,.88) 95%),
  linear-gradient(90deg, rgba(10,14,20,.55) 0%, rgba(10,14,20,0) 40%);
  pointer-events:none;z-index:2}
.hero .wrap{position:relative;z-index:3;width:100%}
.hero .meta-tr{position:absolute;top:32px;right:32px;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,246,248,.7);display:inline-flex;align-items:center;gap:10px;z-index:3}
.hero .meta-tr::before{content:"";width:7px;height:7px;background:var(--signal-soft);border-radius:50%;animation:livepulse 2s ease-out infinite}
.hero h1{color:var(--paper)}
.hero .lede{color:rgba(244,246,248,.82);margin-top:30px;max-width:62ch}
.hero-cta{display:flex;gap:14px;margin-top:44px;flex-wrap:wrap}
.hero .scroll-cue{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);font-size:10px;letter-spacing:.32em;color:rgba(244,246,248,.55);text-transform:uppercase;font-weight:600;z-index:3}
.hero .scroll-cue::after{content:"";display:block;width:1px;height:36px;margin:10px auto 0;background:linear-gradient(rgba(244,246,248,.55),transparent)}

/* Hero photo + video layers */
.hero.with-photo{background:#000}
.hero.with-photo .photo{position:absolute;inset:0;background:#000 center/cover no-repeat;transform-origin:60% 50%;will-change:transform,opacity;opacity:0;animation:heroFadeZoom 22s ease-out forwards;z-index:0}
.hero.with-photo .photo.home{background-image:url('../img/hero_night.jpg?v=2')}
.hero.with-photo .photo.patrol{background-image:url('../img/hero_patrol.jpg?v=2');transform-origin:50% 60%}
.hero.with-photo .photo.panic{background-image:url('../img/hero_panic.jpg?v=2');transform-origin:50% 50%}
.hero.with-photo .photo.lookout{background-image:url('../img/hero_lookout.jpg?v=2');transform-origin:45% 50%}
.hero.with-photo .hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;animation:heroVideoFade 2s ease-out 0.6s forwards;z-index:1}
@keyframes heroFadeZoom{0%{opacity:0;transform:scale(1.03)}10%{opacity:1}100%{opacity:1;transform:scale(1.10)}}
@keyframes heroVideoFade{to{opacity:1}}
@media (prefers-reduced-motion:reduce){.hero.with-photo .hero-video{display:none}.hero.with-photo .photo{animation:none;opacity:1;transform:none}}

/* trust badge on hero */
.hero .trust-row{display:flex;flex-wrap:wrap;gap:14px 28px;margin-top:48px;font-size:12px;color:rgba(244,246,248,.7);font-weight:500;letter-spacing:.02em}
.hero .trust-row span{display:inline-flex;align-items:center;gap:8px}
.hero .trust-row span::before{content:"";width:14px;height:14px;border-radius:50%;border:2px solid var(--signal-soft);background:rgba(74,123,255,.18);flex-shrink:0;display:inline-block}

/* ---------- sections ---------- */
section{padding:120px 0;border-bottom:1px solid var(--hair);background:var(--paper)}
section.frost{background:var(--frost)}
section.dark{background:var(--onyx);color:var(--paper);border-bottom-color:#1A1F28}
section.midnight{background:var(--midnight);color:var(--paper);border-bottom-color:#1A2540}
.section-head{max-width:780px;margin-bottom:64px}

/* ---------- manifesto band ---------- */
.manifesto{padding:140px 0;background:var(--onyx);color:var(--paper);position:relative;overflow:hidden}
.manifesto::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--signal);z-index:1}
.manifesto .manifesto-line{font-size:clamp(40px,7.5vw,108px);line-height:0.96;max-width:18ch;color:var(--paper);font-weight:900;letter-spacing:-0.04em}
.manifesto .lede{color:rgba(244,246,248,.82);margin-top:36px;max-width:60ch}
.manifesto .lede strong{color:var(--paper);font-weight:700}
.manifesto .closing{margin-top:42px;font-size:18px;font-weight:700;color:var(--paper);letter-spacing:-0.01em}
.manifesto .closing .em{color:var(--signal-soft)}
.manifesto .signed{margin-top:42px;font-size:11px;font-weight:600;color:var(--slate-soft);letter-spacing:.22em;text-transform:uppercase;display:flex;align-items:center;gap:18px}
.manifesto .signed::before{content:"";display:block;width:42px;height:1px;background:var(--signal)}

/* ---------- pillars ---------- */
.pillars{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--hair);border:1px solid var(--hair)}
.pillars.two{grid-template-columns:1fr 1fr}
.pillar{background:var(--paper);padding:56px 44px;display:flex;flex-direction:column;min-height:560px;position:relative;transition:background .2s}
.pillar:hover{background:var(--frost)}
.pillar.dark{background:var(--onyx);color:var(--paper)}
.pillar.dark:hover{background:var(--steel)}
.pillar .num{font-family:var(--display);font-weight:900;font-size:14px;letter-spacing:.18em;color:var(--signal);margin-bottom:28px}
.pillar.dark .num{color:var(--signal-soft)}
.pillar h3{margin-bottom:16px;font-size:26px}
.pillar .pewter{color:var(--slate);font-size:15px;margin-bottom:auto;line-height:1.55}
.pillar.dark .pewter{color:rgba(244,246,248,.65)}
.pillar ul{list-style:none;padding:0;margin:32px 0 0;border-top:1px solid var(--hair)}
.pillar.dark ul{border-color:rgba(244,246,248,.12)}
.pillar li{padding:14px 0;border-bottom:1px solid var(--hair);font-size:14px;display:flex;gap:14px;align-items:flex-start;color:var(--onyx)}
.pillar.dark li{border-color:rgba(244,246,248,.12);color:rgba(244,246,248,.88)}
.pillar li::before{content:"";display:block;width:8px;height:8px;background:var(--signal);margin-top:6px;flex-shrink:0;border-radius:1px}
.pillar.panic li::before{background:var(--crimson)}

/* ---------- flag chips ---------- */
.flag-chips{display:flex;flex-wrap:wrap;gap:10px;margin:24px 0 4px}
.flag-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:2px;border:1px solid rgba(244,246,248,.18);background:rgba(244,246,248,.04);font-size:12px;font-weight:500;color:rgba(244,246,248,.85)}
.flag-chip .pip{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--signal-soft)}
.flag-chip.hit{border-color:var(--signal-soft);background:rgba(74,123,255,.18)}
.flag-chip.hit .pip{background:var(--signal-soft);box-shadow:0 0 0 4px rgba(74,123,255,.25)}

/* ---------- timeline ---------- */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-top:24px}
.t-step{border-top:1px solid rgba(244,246,248,.18);padding-top:24px}
section.dark .t-step{border-color:rgba(244,246,248,.18)}
.t-step .step-num{font-family:var(--display);font-weight:900;font-size:13px;letter-spacing:.18em;color:var(--signal-soft);margin-bottom:18px}
.t-step h4{font-family:var(--body);font-size:18px;font-weight:700;letter-spacing:-0.01em;text-transform:none;margin:0 0 12px;color:var(--paper)}
.t-step p{font-size:14px;color:rgba(244,246,248,.7);margin:0;line-height:1.55}

/* ---------- crime alert ticker (top of page, above cohort bar) ---------- */
.alert-ticker{background:#0A0E14;color:rgba(244,246,248,.85);border-bottom:1px solid rgba(244,246,248,.08);overflow:hidden;font-size:12px;font-weight:500;letter-spacing:.02em;position:relative}
.alert-ticker::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--crimson)}
.alert-ticker .wrap{display:flex;align-items:center;gap:24px;padding:10px 32px}
.alert-ticker .label{flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--crimson);display:inline-flex;align-items:center;gap:8px}
.alert-ticker .label::before{content:"";width:6px;height:6px;background:var(--crimson);border-radius:50%;animation:livepulse 2s ease-out infinite;box-shadow:0 0 0 0 rgba(201,43,43,.6)}
.alert-ticker .track{flex:1;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%)}
.alert-ticker .marquee{display:inline-flex;gap:48px;white-space:nowrap;animation:tickerScroll 80s linear infinite;will-change:transform}
.alert-ticker .marquee span{display:inline-flex;align-items:center;gap:8px}
.alert-ticker .marquee span::before{content:"●";color:var(--crimson);font-size:8px}
.alert-ticker .marquee em{color:var(--signal-soft);font-style:normal;font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:10px;margin-right:6px}
.alert-ticker .source{flex-shrink:0;font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,246,248,.45)}
.alert-ticker .source a{color:rgba(244,246,248,.7);text-decoration:underline;text-decoration-color:rgba(244,246,248,.3);text-underline-offset:3px}
@keyframes tickerScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@media (max-width:700px){.alert-ticker .source{display:none}.alert-ticker .wrap{padding:10px 22px;gap:14px}}

/* ---------- crime watch section ---------- */
.crime-watch{background:var(--onyx);color:var(--paper);padding:140px 0;position:relative;overflow:hidden}
.crime-watch::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--crimson);z-index:1}
.crime-watch h2{color:var(--paper)}
.cw-meta{display:flex;flex-wrap:wrap;gap:24px;align-items:center;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,246,248,.55);margin-top:48px}
.cw-meta .dot{width:8px;height:8px;background:var(--signal-soft);border-radius:50%;animation:livepulse 2s ease-out infinite;display:inline-block;margin-right:8px;vertical-align:middle}
.cw-meta a{color:var(--signal-soft);border-bottom:1px solid rgba(74,123,255,.4);padding-bottom:1px}

/* LGA stat cards */
.cw-lgas{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:56px}
.cw-lga{background:rgba(244,246,248,.04);border:1px solid rgba(244,246,248,.12);padding:32px 28px;transition:background .25s,border-color .25s;cursor:default}
.cw-lga.our:hover{background:rgba(36,86,224,.06);border-color:rgba(36,86,224,.35)}
.cw-lga .lga-name{font-family:var(--display);font-weight:800;font-size:24px;color:var(--paper);letter-spacing:-0.02em}
.cw-lga .lga-suburbs{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,246,248,.5);margin-top:8px;line-height:1.45}
.cw-lga .lga-rate{font-family:var(--display);font-weight:900;font-size:42px;line-height:1;color:var(--crimson);margin-top:24px;letter-spacing:-0.03em;font-variant-numeric:tabular-nums}
.cw-lga .lga-rate small{font-family:var(--body);font-size:11px;font-weight:600;color:rgba(244,246,248,.5);margin-left:8px;letter-spacing:.06em}
.cw-lga .lga-k{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,246,248,.55);margin-top:10px}
.cw-lga .lga-status{margin-top:24px;padding-top:18px;border-top:1px solid rgba(244,246,248,.12);font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:8px;color:var(--signal-soft)}
.cw-lga .lga-status::before{content:"";width:7px;height:7px;background:var(--signal-soft);border-radius:50%}
.cw-lga.not-covered .lga-status{color:rgba(244,246,248,.5)}
.cw-lga.not-covered .lga-status::before{background:rgba(244,246,248,.4)}
.cw-lga .lga-rank{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--crimson);background:rgba(201,43,43,.12);border:1px solid rgba(201,43,43,.35);padding:4px 10px;margin-top:14px}
@media (max-width:900px){.cw-lgas{grid-template-columns:1fr}}

/* Crime feed */
.cw-feed{margin-top:64px;background:rgba(244,246,248,.04);border:1px solid rgba(244,246,248,.12)}
.cw-feed-head{padding:20px 28px;border-bottom:1px solid rgba(244,246,248,.12);display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.cw-feed-head .title{font-family:var(--display);font-weight:800;font-size:20px;color:var(--paper);letter-spacing:-0.01em}
.cw-feed-head .updated{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,246,248,.55);display:inline-flex;align-items:center;gap:10px}
.cw-feed-head .updated .dot{width:7px;height:7px;background:var(--signal-soft);border-radius:50%;animation:livepulse 2s ease-out infinite}
.cw-item{display:grid;grid-template-columns:120px 110px 1fr 140px;gap:24px;padding:18px 28px;border-bottom:1px solid rgba(244,246,248,.08);align-items:start;font-size:13px}
.cw-item:last-child{border-bottom:none}
.cw-item .ago{color:rgba(244,246,248,.55);font-variant-numeric:tabular-nums;font-weight:500;font-size:12px}
.cw-item .type{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);padding-top:1px}
.cw-item .type.theft{color:#E0A24A}
.cw-item .type.attempted{color:rgba(244,246,248,.7)}
.cw-item .type.alert{color:var(--signal-soft)}
.cw-item .what{color:rgba(244,246,248,.85);line-height:1.5}
.cw-item .where{color:rgba(244,246,248,.55);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;text-align:right}
.cw-item .src{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--signal-soft);margin-top:6px;border-bottom:1px solid rgba(74,123,255,.3);padding-bottom:1px}
.cw-item .src:hover{color:var(--paper);border-bottom-color:var(--paper)}
.cw-feed-foot{padding:18px 28px;font-size:11px;font-weight:500;color:rgba(244,246,248,.5);line-height:1.55;border-top:1px solid rgba(244,246,248,.12);background:rgba(244,246,248,.02)}
.cw-feed-foot a{color:var(--signal-soft);border-bottom:1px solid rgba(74,123,255,.4);padding-bottom:1px}
@media (max-width:760px){
  .cw-item{grid-template-columns:1fr;gap:6px;padding:18px 22px}
  .cw-item .where{text-align:left}
}

/* What we do about it band */
.cw-action{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;margin-top:64px;padding:48px;background:linear-gradient(135deg,rgba(36,86,224,.12),rgba(36,86,224,0.03));border:1px solid rgba(74,123,255,.3);border-radius:2px}
.cw-action h3{color:var(--paper);font-size:28px;margin-bottom:12px}
.cw-action p{color:rgba(244,246,248,.78);font-size:15px;line-height:1.55;max-width:50ch}
.cw-action .right{display:flex;flex-direction:column;justify-content:center;gap:14px}
@media (max-width:900px){.cw-action{grid-template-columns:1fr;padding:32px}}

/* ---------- founding cohort bar ---------- */
.cohort-bar{background:var(--onyx);color:var(--paper);padding:18px 0;border-bottom:1px solid #1A1F28;position:relative;overflow:hidden}
.cohort-bar::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--signal)}
.cohort-bar .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px}
.cohort-bar .label{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--signal-soft);display:inline-flex;align-items:center;gap:10px}
.cohort-bar .label::before{content:"";width:8px;height:8px;background:var(--signal-soft);border-radius:50%;animation:livepulse 2s ease-out infinite}
.cohort-bar .count{font-family:var(--display);font-weight:800;font-size:18px;color:var(--paper);letter-spacing:-0.01em;font-variant-numeric:tabular-nums}
.cohort-bar .count em{color:var(--signal-soft);font-style:normal;margin-right:4px}
.cohort-bar .progress{flex:1;height:6px;background:rgba(244,246,248,.08);border-radius:2px;overflow:hidden;min-width:160px;max-width:340px}
.cohort-bar .progress .bar{height:100%;background:linear-gradient(90deg,var(--signal),var(--signal-soft));border-radius:2px;width:26%;box-shadow:0 0 12px rgba(74,123,255,.5)}
.cohort-bar .price{font-family:var(--display);font-weight:800;font-size:16px;color:var(--paper)}
.cohort-bar .price s{opacity:.4;font-weight:500;margin-right:8px}
@media (max-width:700px){.cohort-bar .wrap{flex-direction:column;align-items:flex-start;gap:10px}.cohort-bar .progress{width:100%;max-width:none}}

/* ---------- founding cohort full section ---------- */
.cohort-hero{background:var(--onyx);color:var(--paper);padding:120px 0;position:relative;overflow:hidden}
.cohort-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 20% 30%,rgba(36,86,224,.18),transparent 70%);pointer-events:none}
.cohort-hero .wrap{position:relative;z-index:1}
.cohort-hero h2{color:var(--paper)}
.cohort-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(244,246,248,.12);border:1px solid rgba(244,246,248,.12);margin-top:64px}
.cohort-stat{background:var(--onyx);padding:32px 28px}
.cohort-stat .v{font-family:var(--display);font-weight:900;font-size:clamp(34px,4.5vw,52px);line-height:1;color:var(--paper);letter-spacing:-0.03em;font-variant-numeric:tabular-nums}
.cohort-stat .v.signal{color:var(--signal-soft)}
.cohort-stat .k{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,246,248,.55);margin-top:14px}
@media (max-width:900px){.cohort-stats{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.cohort-stats{grid-template-columns:1fr}}

/* ---------- pricing tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
.tier{background:var(--paper);border:1px solid var(--hair);padding:40px 32px;display:flex;flex-direction:column;min-height:600px;position:relative;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;border-radius:2px}
.tier:hover{transform:translateY(-4px);border-color:var(--onyx);box-shadow:0 30px 60px rgba(10,14,20,.08)}
.tier.featured{background:var(--onyx);color:var(--paper);border-color:var(--onyx)}
.tier.featured .pewter,.tier.featured .tier-tag{color:rgba(244,246,248,.6)}
.tier .tier-name{font-family:var(--display);font-weight:800;font-size:28px;margin-bottom:8px;letter-spacing:-0.02em}
.tier .tier-tag{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);margin-bottom:32px}
.tier.featured .tier-tag{color:var(--signal-soft)}
.tier .price{font-family:var(--display);font-weight:900;font-size:72px;line-height:1;margin-bottom:6px;letter-spacing:-0.04em}
.tier .price small{font-family:var(--body);font-weight:500;font-size:13px;letter-spacing:.02em;color:var(--slate);margin-left:6px}
.tier.featured .price small{color:rgba(244,246,248,.6)}
.tier .per{font-size:12px;font-weight:600;color:var(--slate);margin-bottom:32px;letter-spacing:.06em;text-transform:uppercase}
.tier.featured .per{color:rgba(244,246,248,.55)}
.tier ul{list-style:none;padding:0;margin:0 0 32px;flex:1}
.tier li{padding:12px 0;border-bottom:1px solid var(--hair);font-size:14px;display:flex;gap:12px;align-items:flex-start}
.tier.featured li{border-color:rgba(244,246,248,.14)}
.tier li::before{content:"✓";color:var(--signal);font-weight:900;flex-shrink:0}
.tier.featured li::before{color:var(--signal-soft)}
.tier .ribbon{position:absolute;top:18px;right:18px;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--paper);background:var(--signal);padding:5px 10px;border-radius:2px}

/* ---------- proof / phone mock ---------- */
.proof{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.phone{position:relative;background:#000;border-radius:36px;padding:18px;box-shadow:0 30px 80px rgba(0,0,0,.45);max-width:340px;margin:0 auto;border:1px solid #1F2126}
.phone .screen{background:#0F1115;border-radius:24px;padding:24px 22px;color:var(--paper);min-height:540px;font-size:13px}
.phone .top-bar{display:flex;justify-content:space-between;font-size:11px;color:rgba(244,246,248,.55);margin-bottom:20px;font-weight:500}
.phone .screen h5{font-family:var(--display);font-weight:800;font-size:18px;margin:0 0 4px;letter-spacing:-0.01em}
.phone .screen .sub{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,246,248,.5);margin-bottom:24px;font-weight:600}
.log-item{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid rgba(244,246,248,.1);font-size:12px}
.log-item .when{color:rgba(244,246,248,.55);font-variant-numeric:tabular-nums}
.log-item .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--signal-soft);margin-right:8px;vertical-align:middle}
.phone .panic{margin-top:28px;text-align:center;text-decoration:none;color:inherit;display:block}
.phone .panic-btn{display:inline-flex;align-items:center;justify-content:center;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#E54545,#7A1010);color:var(--paper);font-family:var(--display);font-weight:900;font-size:18px;letter-spacing:.04em;text-transform:uppercase;border:6px solid rgba(244,246,248,.06);box-shadow:0 0 0 1px rgba(201,43,43,.5),0 20px 50px rgba(201,43,43,.4);position:relative}
.phone .panic-btn::after{content:"";position:absolute;inset:-12px;border-radius:50%;border:1px solid rgba(201,43,43,.4);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{transform:scale(.92);opacity:.9}100%{transform:scale(1.18);opacity:0}}
.phone .panic-label{display:block;margin-top:16px;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(244,246,248,.55);font-weight:600}

/* ---------- alert tree ---------- */
.tree{display:grid;grid-template-columns:1fr;gap:1px;background:rgba(244,246,248,.12);border:1px solid rgba(244,246,248,.12);max-width:580px}
.tree-row{display:grid;grid-template-columns:auto 1fr auto;gap:18px;padding:18px 22px;background:var(--onyx);align-items:center;font-size:13px}
.tree-row .who{color:rgba(244,246,248,.85)}
.tree-row .when{color:var(--signal-soft);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-variant-numeric:tabular-nums;font-weight:600}
.tree-row .icon{width:10px;height:10px;background:var(--signal-soft);border-radius:50%}
.tree-row.live .icon{background:var(--crimson);box-shadow:0 0 0 4px rgba(201,43,43,.25)}

/* ---------- coverage band ---------- */
.coverage{padding:120px 0;background:var(--frost);border-bottom:1px solid var(--hair)}
.coverage-list{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);margin-top:48px;border:1px solid var(--hair)}
.cov{background:var(--paper);padding:28px 26px;display:flex;flex-direction:column;gap:8px;min-height:140px;position:relative;transition:background .2s}
.cov:hover{background:var(--frost)}
.cov .name{font-family:var(--display);font-weight:800;font-size:22px;line-height:1.05;letter-spacing:-0.015em}
.cov .pc{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--slate)}
.cov .stat{margin-top:auto;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
.cov .stat::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--slate-soft)}
.cov.open .stat{color:var(--signal)} .cov.open .stat::before{background:var(--signal);box-shadow:0 0 0 3px rgba(36,86,224,.18)}
.cov.soon .stat{color:var(--slate)} .cov.waitlist .stat{color:var(--slate-soft)}

/* ---------- faq ---------- */
.faq{max-width:820px;margin:0 auto}
.faq details{border-bottom:1px solid var(--hair);padding:24px 0}
.faq summary{font-family:var(--display);font-weight:700;font-size:20px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;letter-spacing:-0.015em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--signal);font-weight:300;font-size:28px;line-height:1;transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq details p{margin-top:14px;color:var(--slate);max-width:64ch;font-size:15px}

/* ---------- waitlist ---------- */
.waitlist{background:var(--onyx);color:var(--paper);text-align:center;padding:120px 32px;position:relative;overflow:hidden}
.waitlist::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 50% 30%,rgba(36,86,224,.18),transparent 70%);pointer-events:none}
.waitlist > *{position:relative;z-index:1}
.waitlist h2{color:var(--paper)}
.waitlist form{display:flex;gap:0;max-width:520px;margin:40px auto 0;border:1px solid rgba(244,246,248,.3);border-radius:2px;overflow:hidden;background:rgba(244,246,248,.04)}
.waitlist input{flex:1;background:transparent;border:0;padding:18px 24px;color:var(--paper);font-family:var(--body);font-size:14px;outline:none;font-weight:500}
.waitlist input::placeholder{color:rgba(244,246,248,.4)}
.waitlist button{padding:0 28px;background:var(--signal);color:var(--paper);border:0;font-size:12px;font-weight:700;letter-spacing:.04em;cursor:pointer;font-family:var(--body)}
.waitlist button:hover{background:var(--signal-soft)}
.waitlist .tiny{margin-top:18px;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,246,248,.45)}
.waitlist .thanks{display:none;margin-top:24px;color:var(--signal-soft);font-weight:600}
.waitlist.sent .thanks{display:block}
.waitlist.sent form{opacity:.4;pointer-events:none}

/* ---------- footer ---------- */
footer{background:var(--onyx);color:rgba(244,246,248,.65);padding:64px 0 40px;font-size:13px;border-top:1px solid #1A1F28}
footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
footer h6{font-family:var(--body);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--paper);margin:0 0 16px}
footer a{display:block;padding:6px 0;color:rgba(244,246,248,.65);transition:color .2s;font-weight:500}
footer a:hover{color:var(--signal-soft)}
footer .legal{grid-column:1/-1;border-top:1px solid rgba(244,246,248,.12);margin-top:32px;padding-top:24px;display:flex;justify-content:space-between;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(244,246,248,.4)}

/* ---------- split + kvs ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.kvs{display:grid;grid-template-columns:1fr 1fr;gap:32px 48px;margin-top:24px}
.kvs .k{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);margin-bottom:8px}
.kvs .v{font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-0.015em}

/* ---------- principles ---------- */
.principles{display:grid;grid-template-columns:1fr 1fr;gap:0 48px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- responsive ---------- */
@media (max-width:900px){
  section{padding:80px 0}
  .manifesto{padding:96px 0}
  .pillars,.pillars.two{grid-template-columns:1fr}
  .pillar{padding:48px 28px;min-height:auto}
  .timeline{grid-template-columns:1fr 1fr;gap:32px}
  .tiers{grid-template-columns:1fr;gap:18px}
  .proof{grid-template-columns:1fr;gap:48px}
  .split{grid-template-columns:1fr;gap:40px}
  .coverage-list{grid-template-columns:1fr 1fr}
  footer .wrap{grid-template-columns:1fr 1fr;gap:32px}
  .principles{grid-template-columns:1fr}
}
@media (max-width:600px){
  .wrap,.wrap-narrow{padding:0 22px}
  .nav-links{gap:18px}
  .nav-links a:not(.cta){display:none}
  .brand .meta{display:none}
  .hero{min-height:78vh;padding:60px 0 80px}
  .hero .meta-tr{display:none}
  .timeline{grid-template-columns:1fr}
  .coverage-list{grid-template-columns:1fr}
  .coverage{padding:80px 0}
  .waitlist form{flex-direction:column;border-radius:2px}
  .waitlist input{text-align:center;padding:18px}
  .waitlist button{padding:18px}
  footer .wrap{grid-template-columns:1fr}
  footer .legal{flex-direction:column;gap:10px;align-items:flex-start}
}
