/* LANDING — public homepage. Tokens only; reuses .btn/.eyebrow/.display from styles.css.
   Rules honored: no gradients, no rainbow stripes, no emoji, sentence-case headlines,
   subtle hover lift + one-time scroll fade, prefers-reduced-motion respected. */

.lwrap{max-width:1040px;margin:0 auto;padding:0 var(--gutter)}

/* skip link — visible only on keyboard focus */
.skip{position:absolute;left:-9999px;top:0;z-index:50;background:var(--ink);color:#fff;
  padding:10px 16px;border-radius:0 0 var(--r-sm) 0;font-size:14px;font-weight:600;text-decoration:none}
.skip:focus{left:0}

/* nav */
.lnav{border-bottom:1px solid var(--line);background:var(--paper);position:sticky;top:0;z-index:10}
.lnav-in{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px;padding:18px var(--gutter)}
.lnav .wordmark{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-.01em;
  text-decoration:none;color:var(--ink)}
.lnav-links{display:flex;align-items:center;flex-wrap:wrap;gap:22px}
.lnav-links > a:not(.btn-outline){font-size:14.5px;font-weight:500;color:var(--ink-2);text-decoration:none}
.lnav-links > a:not(.btn-outline):hover{color:var(--accent)}
.lnav-cta{padding:9px 16px;font-size:14px}
/* Support pill — a warm, distinct "give/help" chip (verified contrast var(--secondary-strong) on var(--secondary-soft) = 4.89:1) */
.lnav-links a.support-pill{padding:7px 15px;border-radius:var(--r-pill);background:var(--secondary-soft);color:var(--secondary-strong);
  font-size:14px;font-weight:600;border:1.5px solid transparent}
.lnav-links a.support-pill:hover{color:var(--secondary-strong);background:var(--secondary-hover);border-color:var(--secondary-strong)}
.lnav-links a.support-pill:focus-visible{outline:var(--focus-ring);outline-offset:var(--focus-offset)}
@media(max-width:620px){
  .lnav-links{gap:14px}
  .lnav-links > a:not(.btn-outline):not(.support-pill):first-child{display:none}
}

/* hero */
.hero{border-bottom:1px solid var(--line)}
.hero-in{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
  padding:72px 24px 80px}
.hero-copy .eyebrow{margin-bottom:16px}
.hero-copy h1.display{font-weight:800;font-size:clamp(40px,7vw,68px);margin:0 0 20px}
.hero-copy .sub{font-size:20px;max-width:42ch;margin:0 0 30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:780px){
  .hero-in{grid-template-columns:1fr;gap:32px;padding:48px 24px 56px}
  .hero-photo{order:-1}
}

/* photo slots — a real labelled slot (drop a DC photo in here), not a flat color block.
   No gradient: a plain surface with a thin inner frame and a caption pill. */
.photo{margin:0;border:2px solid var(--ink);border-radius:var(--r);background:var(--surface);
  min-height:300px;display:grid;place-items:center;position:relative}
.photo:after{content:"";position:absolute;inset:14px;border:1px solid var(--line);border-radius:var(--r-sm);
  pointer-events:none}
.photo .photo-note{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  font-weight:600;background:var(--paper);padding:6px 12px;border:1px solid var(--line);border-radius:999px;
  position:relative;z-index:1}
.hero-photo{min-height:340px}
/* Q30 — the real hero photo fills the framed figure (no mat overlay); dimensions set on the <img> = no layout shift */
.hero-photo:has(img){min-height:0;padding:4px}
.hero-photo img{display:block;width:100%;height:auto;border-radius:var(--r-sm)}
.hero-photo:has(img):after{display:none}

/* sections */
.section-pad{padding:72px 0}
.anc-head{max-width:60ch}
.anc-head .display{font-weight:700;font-size:clamp(28px,4.4vw,40px);margin:6px 0 18px}
.anc-head .lead{font-size:18px;line-height:1.6;color:var(--ink-2)}

/* stats */
.stats{list-style:none;margin:40px 0 0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.stats li{border:2px solid var(--ink);border-radius:var(--r);background:var(--surface);padding:22px}
.stats b{display:block;font-family:var(--font-display);font-weight:800;font-size:38px;line-height:1;
  letter-spacing:-.02em;color:var(--accent);margin-bottom:10px}
.stats span{font-size:13.5px;color:var(--muted);line-height:1.4}
@media(max-width:780px){.stats{grid-template-columns:1fr 1fr}}
@media(max-width:440px){.stats{grid-template-columns:1fr}}

/* path */
.path-wrap{border-top:1px solid var(--line);background:var(--surface)}
.path-wrap .display{font-weight:700;font-size:clamp(28px,4.4vw,40px);margin:6px 0 0}
.path{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.pcard{display:block;border:2px solid var(--ink);border-radius:var(--r);background:var(--paper);
  padding:26px;text-decoration:none;color:inherit;box-shadow:0 0 0 transparent;
  transition:transform .14s ease,box-shadow .14s ease}
.pcard:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-pop)}
.pcard .pnum{display:inline-grid;place-items:center;width:38px;height:38px;border:2px solid var(--ink);
  border-radius:999px;font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--accent);
  margin-bottom:16px}
.pcard h3{font-family:var(--font-display);font-weight:700;font-size:21px;margin:0 0 10px}
.pcard p{font-size:15.5px;line-height:1.55;color:var(--ink-2);margin:0 0 16px}
.pcard .plink{font-size:14.5px;font-weight:600;color:var(--accent)}
.pcard .plink .ar{display:inline-block;transition:transform .14s ease}
.pcard:hover .plink .ar{transform:translateX(4px)}
@media(max-width:780px){.path{grid-template-columns:1fr}}

/* punch band — solid cobalt, big white type (no gradient) */
.punch{background:var(--accent);color:#fff}
/* fills the 1040 container + left-aligned to match the modular sections (HOMEPAGE_CONSISTENCY) */
.punch-in{padding:72px 24px}
.punch-title{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,4.8vw,46px);
  line-height:1.08;letter-spacing:-.02em;margin:0 0 18px;max-width:20ch;color:#fff}
.punch-sub{font-size:17px;line-height:1.55;color:rgba(255,255,255,.88);max-width:52ch;margin:0 0 28px}
.punch .punch-btn{background:#fff;color:var(--ink);border-color:var(--ink)}
.punch .punch-btn:hover{box-shadow:4px 6px 0 rgba(0,0,0,.45)}

/* faq — native details/summary, no motion beyond the marker */
.faq-wrap{border-top:1px solid var(--line)}
.faq-wrap .display{font-weight:700;font-size:clamp(28px,4.4vw,40px);margin:6px 0 0}
.faq{margin-top:28px;max-width:760px}
.faq details{border-top:1px solid var(--line);padding:6px 0}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:16px 36px 16px 0;position:relative;
  font-family:var(--font-display);font-weight:600;font-size:18px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";position:absolute;right:6px;top:14px;font-size:24px;font-weight:400;
  color:var(--accent);line-height:1}
.faq details[open] summary:after{content:"\2013"}
.faq summary:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.faq p{margin:0 0 18px;font-size:16px;line-height:1.6;color:var(--ink-2);max-width:64ch}

/* impact widget strip */
.impact-strip{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  border:2px solid var(--ink);border-radius:var(--r-lg);background:var(--surface);padding:28px 32px;box-shadow:var(--shadow-pop-sm)}
.impact-strip__stats{display:flex;gap:32px;flex-wrap:wrap}
.impact-strip__stat b{display:block;font-family:var(--font-display);font-weight:var(--fw-display-heavy,700);
  font-size:34px;line-height:1;letter-spacing:-.02em;color:var(--accent);font-variant-numeric:tabular-nums}
.impact-strip__stat span{display:block;font-size:13px;color:var(--muted);margin-top:5px;max-width:18ch}
@media(max-width:560px){.impact-strip{flex-direction:column;align-items:flex-start}.impact-strip__stats{gap:20px}}

/* nominate a neighbor */
.nominate{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;
  background:var(--surface);border:2px solid var(--ink);border-radius:var(--r-lg);padding:28px 32px;box-shadow:var(--shadow-pop-sm)}
.nominate-copy{max-width:52ch}
.nominate-title{font-family:var(--font-display);font-weight:var(--fw-display);font-size:clamp(20px,2.6vw,26px);margin:0 0 6px;letter-spacing:-.01em}
.nominate-sub{margin:0;color:var(--ink-2);font-size:15.5px;line-height:1.5}
.nominate-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.nominate-done{font-size:13px;color:var(--muted)}

/* become a CSD member — connect card */
.connect-card{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;
  background:var(--surface);border:2px solid var(--ink);border-radius:var(--r-lg);padding:28px 32px;box-shadow:var(--shadow-pop-sm)}
.connect-card__copy{max-width:56ch}
.connect-title{font-family:var(--font-display);font-weight:var(--fw-display);font-size:clamp(20px,2.6vw,26px);margin:0 0 6px;letter-spacing:-.01em}
.connect-sub{margin:0;color:var(--ink-2);font-size:15.5px;line-height:1.5}

/* partners (logos, consent) + sources (plain text credits) */
.partner-logos{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:26px 40px;margin:14px 0 0;padding:0}
.partner-logos img{height:40px;width:auto;display:block;opacity:.85;transition:opacity var(--dur-fast) var(--ease)}
.partner-logos a:hover img{opacity:1}
.sources-line{font-size:13px;color:var(--muted);margin:0;line-height:1.6}
#partners-row{margin-bottom:22px}

/* footer */
.lfoot{border-top:2px solid var(--ink);background:var(--paper)}
.lfoot-in{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;padding:40px 24px 56px}
.powered{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink-2);margin:0 0 8px}
.foot-note{font-size:13px;color:var(--muted);max-width:46ch;margin:0;line-height:1.5}
/* Q100 — product-planning credit line, footer type + tokens */
.foot-credit{font-size:13px;color:var(--muted);margin:8px 0 0;line-height:1.5}
.foot-links{display:flex;gap:20px;align-items:flex-start}
.foot-links a{font-size:14px;font-weight:500;color:var(--ink-2);text-decoration:none}
.foot-links a:hover{color:var(--accent)}

/* one-time scroll fade */
.fade{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.fade.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .fade{opacity:1;transform:none;transition:none}
  .pcard,.btn,.btn-outline{transition:none}
}

/* A1: one primary path — a compact numbered sequence under the hero CTA; secondary link stays quiet */
.hero-secondary{align-self:center;font-weight:600;color:var(--ink-2);text-decoration:underline;text-underline-offset:3px}
.hero-steps{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:9px;max-width:36ch}
.hero-steps li{display:flex;align-items:center;gap:11px;font-size:15px;line-height:1.3;color:var(--ink-2);font-weight:500}
.hero-steps li span{flex:none;width:25px;height:25px;border-radius:50%;border:2px solid var(--ink);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:13px;background:var(--paper)}

/* A7: "What you'll receive" list */
.receive{list-style:none;margin:22px 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.receive li{position:relative;padding:14px 16px 14px 40px;border:2px solid var(--ink);border-radius:11px;background:#fff;font-weight:600;font-size:15px;line-height:1.3}
.receive li::before{content:"";position:absolute;left:16px;top:19px;width:11px;height:7px;border-left:3px solid var(--accent);border-bottom:3px solid var(--accent);transform:rotate(-45deg)}
/* A8: representation block */
.rep{max-width:64ch;display:grid;gap:14px}

/* Two-column prose sections (HOMEPAGE_CONSISTENCY "Prose sections") — readable copy on the left,
   a supporting element on the right; stacks on mobile (copy first). */
.anc-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.anc-grid .stats{margin:0;grid-template-columns:1fr 1fr}
.rep-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.rep-grid .rep{max-width:64ch}
.rep-quote{margin:0;border-left:4px solid var(--accent);padding:8px 0 8px 22px;font-family:var(--font-display);
  font-weight:600;font-size:clamp(19px,2.3vw,23px);line-height:1.35;color:var(--ink)}
.rep-quote__em{color:var(--accent)}
@media(max-width:820px){
  .anc-grid,.rep-grid{grid-template-columns:1fr;gap:26px}
}
@media(max-width:440px){.anc-grid .stats{grid-template-columns:1fr}}

/* Quiz-band mini seat map (QUIZ_BANNER_MOMENT) — the empty seats do the asking */
@media (min-width:900px){ .punch-in{display:grid;grid-template-columns:1fr auto;gap:44px;align-items:center} }
.punch-map{display:block;text-decoration:none;color:inherit;max-width:320px;margin:26px auto 0;border-radius:var(--r-lg);transition:transform .18s var(--ease,ease-out)}
@media (min-width:900px){ .punch-map{margin:0} }
.punch-map:hover,.punch-map:focus-visible{transform:translateY(-3px)}
.punch-map:focus-visible{outline:2px solid #fff;outline-offset:5px}
.punch-map__svg{width:100%;height:auto;display:block;aspect-ratio:100/130}
.punch-map__count{margin:12px 0 0;text-align:center;font-size:15px;color:rgba(255,255,255,.92);line-height:1.4}
.punch-map__count b{font-family:var(--font-num,var(--font-display));font-variant-numeric:tabular-nums;font-size:23px;font-weight:800}
@keyframes punchPulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.25);opacity:1}}
.punch-pulse{animation:punchPulse 4s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){ .punch-pulse{animation:none!important} }

/* Power messaging (POWER_MESSAGING) — one high tenor beat + the ownership claim band */
.lead--tenor{font-size:clamp(19px,2.4vw,25px);line-height:1.4}
.lead--tenor strong{font-weight:var(--fw-semibold,650)}
/* Brand-pink band (Aubrey 2026-07-02: "why can't it be that pink — fun, modern, pops").
   --secondary-strong, NOT --pink: white on the bright pink is 3.5:1 and fails AA for body
   copy; white on the deep pink is 5.8:1 (the v1.1-audited on-white/on-pink pair). Yellow
   strong on it is 4.0:1 -> passes as LARGE text, so the claim's floor is 19px (bold display
   >=18.66px = WCAG large). Tokens only — no hex fallbacks (theme.css always loads first). */
.ownership-wrap{background:var(--secondary-strong);color:var(--on-secondary)}
.ownership-claim{max-width:64ch;margin:0 auto;font-family:var(--font-display);font-size:clamp(19px,2.2vw,23px);line-height:1.5;text-align:center}
.ownership-claim strong{color:var(--yellow,#FFD23D)}
.ownership-more{text-align:center;margin:16px 0 0}
.ownership-more .link{color:var(--on-secondary)}

/* Footer columns (FOOTER_REORG_SPEC) — 4 cols >=900, 2 cols 600-900, 1 col <600 (headers kept) */
.foot-cols{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:26px 22px}
@media (max-width:900px){ .foot-cols{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:600px){ .foot-cols{grid-template-columns:1fr} }
.foot-colhead{margin:0 0 8px;opacity:.85}
.foot-col ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.foot-col li{line-height:1.25}
.foot-col .link{display:inline-block;padding:3px 0;min-height:24px}

/* The 60-second front door (FRONT_DOOR_SPEC) — the hero answer machine */
.fd-form{margin:22px 0 6px}
.fd-label{display:block;font-weight:600;font-size:14px;margin:0 0 8px}
.fd-row{display:flex;gap:10px;flex-wrap:wrap}
.fd-row input{flex:1;min-width:220px;font:inherit;font-size:16px;padding:13px 16px;border:2px solid var(--ink);border-radius:var(--r-sm,10px);background:#fff;box-sizing:border-box}
.fd-row input:focus{outline:none;box-shadow:0 0 0 3px var(--focus-color,rgba(34,56,255,.45))}
/* Q108 P1-3 — clean two-row stack for the front-door lookup on a phone */
@media(max-width:560px){.fd-row input{min-width:0;flex:1 1 100%}.fd-row .btn{width:100%}}
.fd-msg{font-size:14px;color:var(--ink-2);margin:8px 0 0;min-height:1em}
.fd-result{border:2px solid var(--ink);border-radius:var(--r-lg,16px);background:var(--surface,#fff);box-shadow:var(--shadow-pop);padding:20px 22px;margin:14px 0 0}
.fd-seat{font-family:var(--font-display);font-weight:800;font-size:19px;margin:0 0 4px}
.fd-status{font-weight:700;margin:0 0 8px;color:var(--ink-2)}
.fd-status--opp{color:var(--seat-nocand,#FF2E7E)}
.fd-path{font-size:14px;color:var(--ink-2);line-height:1.5;margin:0 0 14px}
.fd-doors{display:flex;flex-wrap:wrap;gap:10px}
/* Q92 inline widget watch offer (partner-attributed) */
.fd-watch{margin:14px 0 0;display:grid;gap:8px}
.fd-watch__t{margin:0;font-weight:700;font-size:15px}
.fd-watch__row{display:flex;flex-wrap:wrap;gap:8px}
.fd-watch__row input{flex:1 1 180px;min-width:150px;min-height:44px;font-size:16px;padding:8px 12px;border:1.5px solid var(--line-strong);border-radius:var(--r,10px);background:var(--surface,#fff);color:var(--ink)}
.fd-watch__consent{display:flex;gap:8px;align-items:flex-start;font-size:13.5px;color:var(--ink-2)}
.fd-watch__consent input{margin-top:3px;min-width:18px;min-height:18px}
.fd-watch__msg{margin:0;font-size:13px;color:var(--ink-2)}
.fd-watch__ok{margin:14px 0 0;font-weight:600}

/* Q96 — overwhelm fallback banner (front-door CTA swap) */
.fd-overwhelm{margin:8px 0 0;padding:16px 18px;border:2px solid var(--ink);border-radius:14px;background:var(--surface-sunken,#EFECE2)}
.fd-ow-msg{margin:0 0 12px;font-weight:600}

/* Q88 citywide petition pulse — a quiet front-door stat line during the petition window (hidden until
   pulse.js confirms window + k-anon floor). Tokens only; no color bar. */
.pulse-band{display:inline-flex;align-items:center;gap:9px;margin:14px 0 0;padding:9px 15px;border-radius:999px;
  background:var(--surface-sunken,#EFECE2);border:1.5px solid var(--line);font-size:14px;color:var(--ink-2);line-height:1.35}
.pulse-band__dot{flex:0 0 auto;width:9px;height:9px;border-radius:50%;background:var(--accent)}
.pulse-band__n{font-weight:var(--fw-bold,800);color:var(--accent);font-variant-numeric:tabular-nums}
