/* CCI · WEB · V14 · STYLES */

/* ---------- Tokens ---------- */
:root {
  --ink:        #0A0A0A;
  --ink-2:      #161616;
  --bone:       #F4EFE6;
  --bone-2:     #ECE5D5;
  --bone-3:     #E2D9C4;
  --graphite:   #4A4A4A;
  --graphite-2: #6E6A62;
  --graphite-3: #9A958C;
  --proof:      #1F3B2D;
  --proof-2:    #142A1F;
  --proof-3:    #3F7A5D;

  --grid-max: 1280px;
  --gutter:   clamp(1.25rem, 4vw, 3rem);

  --pad-section:       clamp(4rem, 9vw, 8.5rem);
  --pad-section-tight: clamp(2.4rem, 6vw, 5rem);

  --type-display: clamp(2.6rem, 7.2vw, 5.6rem);
  --type-h1:      clamp(2rem, 5vw, 3.6rem);
  --type-h2:      clamp(1.6rem, 3.4vw, 2.6rem);
  --type-h3:      clamp(1.2rem, 1.8vw, 1.6rem);
  --type-body:    clamp(1rem, 1.2vw, 1.125rem);
  --type-small:   0.875rem;
  --type-meta:    0.6875rem;

  --line-display: 1.04;
  --line-h1:      1.08;
  --line-h2:      1.18;
  --line-body:    1.6;

  --tracking-meta:  0.12em;
  --tracking-small: 0.04em;

  --img-filter: grayscale(100%) contrast(1.08) brightness(0.98);
}

/* Placeholder for image slots awaiting upload */
.media.placeholder{background:var(--ink);color:var(--bone);display:flex;align-items:center;justify-content:center;aspect-ratio:4/5;border:1px solid rgba(244,239,230,0.18)}
.media.placeholder .placeholder-inner{display:flex;flex-direction:column;gap:0.6rem;text-align:center;padding:2rem}
.media.placeholder .placeholder-label{font-family:"IBM Plex Sans",sans-serif;font-size:0.95rem;color:rgba(244,239,230,0.86);max-width:22ch;line-height:1.35}
.media.placeholder .placeholder-path{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.7rem;letter-spacing:0.08em;color:rgba(244,239,230,0.4)}
.media.placeholder .meta{color:rgba(244,239,230,0.55)}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
input,textarea,select,button{font:inherit;color:inherit}

/* ---------- Base ---------- */
html{-webkit-text-size-adjust:100%}
body{background:var(--bone);color:var(--ink);font-family:"IBM Plex Sans",system-ui,-apple-system,sans-serif;font-weight:400;font-size:var(--type-body);line-height:var(--line-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:var(--proof);color:var(--bone)}

.mono{font-family:"IBM Plex Mono",ui-monospace,Menlo,monospace;font-weight:400;letter-spacing:var(--tracking-small)}
.meta{font-family:"IBM Plex Mono",ui-monospace,Menlo,monospace;font-size:var(--type-meta);letter-spacing:var(--tracking-meta);text-transform:uppercase;color:var(--graphite-2)}
.accent{color:var(--proof)}
em,i{font-style:normal;font-weight:500}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--grid-max);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
.rule{border:0;border-top:1px solid var(--ink);margin:0;opacity:0.14}
main{min-height:60vh}
section{padding-top:var(--pad-section);padding-bottom:var(--pad-section)}
section.tight{padding-top:var(--pad-section-tight);padding-bottom:var(--pad-section-tight)}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:var(--bone);border-bottom:1px solid rgba(10,10,10,0.10)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.1rem 0}
.brand{display:flex;align-items:center;gap:0.75rem;font-weight:500;font-size:1rem}
.brand svg{width:28px;height:28px;color:var(--ink)}
.brand-text{line-height:1}
.nav-links{display:flex;align-items:center;gap:1.6rem}
.nav-links a{font-size:0.92rem;font-weight:400;color:var(--ink);opacity:0.74;transition:opacity .14s;padding:0.25rem 0}
.nav-links a:hover,.nav-links a[aria-current="page"]{opacity:1}
.nav-links a[aria-current="page"]{border-bottom:1px solid var(--proof)}

.cta{display:inline-flex;align-items:center;gap:0.5rem;background:var(--proof);color:var(--bone);padding:0.75rem 1.15rem;border:0;font-size:0.92rem;font-weight:500;transition:background .14s}
.cta:hover{background:#16291f}
.cta-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.cta-ghost:hover{background:var(--ink);color:var(--bone)}
.cta-mono{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.85rem 1.2rem;background:transparent;color:var(--ink);border:1px solid var(--ink)}
.cta-mono:hover{background:var(--ink);color:var(--bone)}

/* mobile nav drawer rules live in the responsive block below */

/* ---------- Hero ---------- */
.hero{padding-top:clamp(4rem,11vw,8rem);padding-bottom:clamp(3.5rem,8vw,7rem)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:clamp(2rem,6vw,5rem);align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:0.625rem;margin-bottom:1.75rem}
.hero-eyebrow svg{width:18px;height:18px;color:var(--proof)}
.hero h1{font-size:var(--type-display);line-height:var(--line-display);font-weight:500;letter-spacing:-0.012em;margin:0 0 1.6rem;max-width:18ch}
.hero h1 .accent{color:var(--proof)}
.hero .tagline{font-size:clamp(1.2rem,1.8vw,1.55rem);font-weight:400;line-height:1.35;margin:0 0 1.5rem;max-width:34ch;color:var(--ink)}
.hero .lede{font-size:clamp(1.05rem,1.3vw,1.18rem);line-height:1.55;color:var(--graphite);max-width:54ch;margin:0 0 2rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.8rem}
.hero-figure{display:flex;align-items:center;justify-content:center}
.hero-figure svg{width:100%;height:auto;max-width:400px}

/* ---------- Brand hero (home page) ---------- */
.brand-hero{padding-top:clamp(3.5rem,9vw,7rem);padding-bottom:clamp(3rem,8vw,6rem)}
.brand-eyebrow{margin:0 0 1.4rem;display:inline-block}
.brand-wordmark{font-size:clamp(3rem,10vw,8.5rem);line-height:0.96;font-weight:500;letter-spacing:-0.022em;margin:0 0 clamp(2rem,5vw,3.5rem);max-width:none;overflow-wrap:break-word}
.brand-wordmark .accent{color:var(--proof)}
.brand-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:clamp(2rem,5vw,4rem);align-items:start}
.brand-tagline{font-size:clamp(1.2rem,2vw,1.75rem);font-weight:500;line-height:1.3;color:var(--ink);margin:0 0 1.4rem;max-width:36ch}
.brand-hero .lede{font-size:clamp(1.02rem,1.3vw,1.18rem);line-height:1.6;color:var(--graphite);max-width:60ch;margin:0 0 1.8rem}
.brand-hero .hero-figure{align-items:flex-start;padding-top:0.6rem}
.brand-hero .hero-figure svg{max-width:340px}
@media (max-width:1024px){.brand-grid{grid-template-columns:1fr}}

/* ---------- Page head ---------- */
.page-head{padding-top:clamp(3.5rem,8vw,6rem);padding-bottom:clamp(2.5rem,5vw,4rem)}
.page-head .eyebrow{margin-bottom:1.5rem;display:inline-block}
.page-head h1{font-size:var(--type-h1);line-height:var(--line-h1);font-weight:500;letter-spacing:-0.01em;margin:0 0 1.5rem;max-width:22ch}
.page-head h1 .accent{color:var(--proof)}
.page-head .lede{font-size:clamp(1.06rem,1.4vw,1.25rem);line-height:1.55;color:var(--graphite);max-width:62ch;margin:0}
.page-head-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:clamp(2rem,5vw,4rem);align-items:center}
.page-head-figure svg{width:100%;height:auto;max-width:280px;margin-left:auto}

/* ---------- Breakers ---------- */
.breaker-ink{background:var(--ink);color:var(--bone);padding:clamp(4rem,8vw,7rem) 0;text-align:center}
.breaker-proof{background:var(--proof-2);color:var(--bone);padding:clamp(4rem,8vw,7rem) 0;text-align:center}
.breaker-bone{background:var(--bone-2);color:var(--ink);padding:clamp(4rem,8vw,7rem) 0;text-align:center}
.breaker .turnstile{display:inline-flex;justify-content:center;margin-bottom:1.4rem}
.breaker .turnstile svg{width:48px;height:48px}
.breaker-ink .turnstile svg line,.breaker-proof .turnstile svg line{stroke:var(--proof-3)}
.breaker-bone .turnstile svg line{stroke:var(--proof)}
.breaker .lead{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:clamp(1.25rem,2.4vw,2rem);font-weight:400;line-height:1.4;max-width:44ch;margin:0 auto}
.breaker .lead .accent{color:var(--proof-3)}
.breaker-bone .lead .accent{color:var(--proof)}

/* ---------- Section head ---------- */
.section-head{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);gap:clamp(2rem,5vw,5rem);align-items:end;margin-bottom:clamp(2rem,4vw,3.5rem)}
.section-head h2{font-size:var(--type-h2);line-height:var(--line-h2);font-weight:500;letter-spacing:-0.008em;margin:0.6rem 0 0;max-width:24ch}
.section-head h2 .accent{color:var(--proof)}
.section-head .sub{margin:0;color:var(--graphite);font-size:1.02rem;line-height:1.55;max-width:50ch}

/* ---------- Prose ---------- */
.prose{max-width:64ch}
.prose p{margin:0 0 1.1rem}
.prose .lede{font-size:1.18rem;color:var(--graphite);margin-bottom:1.4rem}
.prose h2{font-size:var(--type-h2);line-height:var(--line-h2);font-weight:500;margin:2.4rem 0 1rem}
.prose h3{font-size:var(--type-h3);font-weight:500;margin:1.6rem 0 0.5rem}

/* ---------- Doors ---------- */
.doors{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.door{padding:2.4rem 2rem;background:var(--bone-2);display:flex;flex-direction:column;border-top:2px solid var(--ink);min-height:300px;min-width:0}
.door.accent{background:var(--proof-2);color:var(--bone);border-top-color:var(--proof-3)}
.door.accent .meta{color:rgba(244,239,230,0.6)}
.door .meta{margin-bottom:1.4rem}
.door h3{font-size:1.35rem;font-weight:500;line-height:1.2;margin:0 0 0.9rem;max-width:18ch;word-break:break-word}
.door p{font-size:0.95rem;line-height:1.55;margin:0 0 1.6rem;color:var(--graphite);flex:1}
.door.accent p{color:rgba(244,239,230,0.86)}
.door .door-cta{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.85rem 1.1rem;border:1px solid var(--ink);align-self:flex-start;transition:background .14s,color .14s;word-break:break-word;max-width:100%}
.door .door-cta:hover{background:var(--ink);color:var(--bone)}
.door.accent .door-cta{border-color:var(--proof-3);color:var(--proof-3)}
.door.accent .door-cta:hover{background:var(--proof-3);color:var(--ink)}

/* ---------- Compare grid ---------- */
.compare{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.compare > div{padding:1.8rem 1.4rem;background:var(--bone-2);border-top:1px solid var(--ink)}
.compare .us{background:var(--proof-2);color:var(--bone);border-top-color:var(--proof-3)}
.compare .us .meta{color:rgba(244,239,230,0.6)}
.compare h4{font-size:1.15rem;font-weight:500;line-height:1.2;margin:0.8rem 0 0.6rem}
.compare p{font-size:0.9rem;line-height:1.55;color:var(--graphite);margin:0}
.compare .us p{color:rgba(244,239,230,0.86)}

/* ---------- Outcomes ---------- */
.outcomes{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2.5rem}
.outcome{padding:1.4rem;border-top:1px solid rgba(10,10,10,0.16)}
.outcome h4{font-size:1.05rem;font-weight:500;margin:0.6rem 0 0;line-height:1.3;max-width:20ch}

/* ---------- Media ---------- */
figure.media{margin:0}
figure.media img{width:100%;height:auto;display:block;filter:var(--img-filter)}
figure.media figcaption{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--graphite-2);margin-top:0.6rem}
.media-wide{margin:0}
.media-wide img{aspect-ratio:21/9;object-fit:cover}
.media-tall img{aspect-ratio:4/5;object-fit:cover}
.media-square img{aspect-ratio:1/1;object-fit:cover}
.media-split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(1.5rem,3vw,3rem);align-items:center}
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.stat{padding:1.6rem 0;border-top:1px solid rgba(10,10,10,0.16)}
.stat .num{font-family:"IBM Plex Sans",sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:500;letter-spacing:-0.01em;margin:0;line-height:1}
.stat .label{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--graphite-2);margin-top:0.6rem}

/* ---------- Mirror ---------- */
.mirror{list-style:none;counter-reset:m;padding:0;margin:0 0 3rem;max-width:64ch}
.mirror li{counter-increment:m;padding:1.6rem 0;border-top:1px solid rgba(10,10,10,0.12);font-size:1.06rem;line-height:1.55;display:grid;grid-template-columns:3rem 1fr;gap:1rem}
.mirror li::before{content:counter(m,decimal-leading-zero);font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.78rem;letter-spacing:0.08em;color:var(--graphite-2);padding-top:0.25rem}

/* ---------- Note block ---------- */
.note-block{background:var(--ink);color:var(--bone);padding:clamp(2rem,4vw,3rem)}
.note-block .meta{color:rgba(244,239,230,0.6)}
.note-block h3{font-size:1.5rem;font-weight:500;line-height:1.2;margin:0.6rem 0 1rem;max-width:30ch}
.note-block p{color:rgba(244,239,230,0.86);max-width:64ch}
.note-block a{color:var(--proof-3);border-bottom:1px solid rgba(63,122,93,0.4)}

/* ---------- Decidr ---------- */
.decidr{background:var(--ink);color:var(--bone);padding:clamp(4rem,8vw,7rem) 0}
.decidr-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);gap:clamp(2rem,5vw,5rem);align-items:start}
.decidr .meta{color:rgba(244,239,230,0.55)}
.decidr h2{font-size:var(--type-h2);line-height:var(--line-h2);font-weight:500;margin:0.6rem 0 1.4rem;max-width:22ch}
.decidr h2 .accent{color:var(--proof-3)}
.decidr p{font-size:1.04rem;line-height:1.6;color:rgba(244,239,230,0.86);max-width:56ch;margin:0 0 1.1rem}
.decidr a.outlink{color:var(--proof-3);border-bottom:1px solid rgba(63,122,93,0.35);padding-bottom:1px}
.decidr-grid ul{list-style:none;padding:0;margin:0}
.decidr-grid li{padding:0.95rem 0;border-top:1px solid rgba(244,239,230,0.12);font-size:0.96rem;color:rgba(244,239,230,0.86)}
.decidr-grid li b{display:block;font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--proof-3);margin-bottom:0.25rem;font-weight:500}

/* ---------- Principals ---------- */
.principals{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(2rem,5vw,4rem)}
.principal{display:grid;grid-template-columns:130px 1fr;gap:1.4rem;align-items:start}
.principal .portrait{width:130px;height:160px;overflow:hidden;background:var(--bone-3)}
.principal .portrait img{width:100%;height:100%;object-fit:cover;filter:var(--img-filter)}
.principal h3{font-size:1.25rem;font-weight:500;margin:0.4rem 0 0.2rem}
.principal .role{font-style:italic;color:var(--graphite);margin:0 0 0.8rem;font-size:0.92rem}
.principal p{font-size:0.95rem;line-height:1.55;margin:0 0 0.9rem;color:var(--ink)}
.creds{display:flex;flex-direction:column;gap:0.45rem;margin-top:1rem}
.creds .cred{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.74rem;line-height:1.5;color:var(--graphite);letter-spacing:0.02em}
.creds .cred b{color:var(--ink);font-weight:500}

/* ---------- Form ---------- */
.form{max-width:46rem;display:grid;gap:1.25rem;margin-top:2rem}
.form label{display:flex;flex-direction:column;gap:0.4rem;font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--graphite-2)}
.form input,.form textarea,.form select{padding:0.85rem 1rem;border:1px solid rgba(10,10,10,0.2);background:var(--bone);font-family:"IBM Plex Sans",sans-serif;font-size:1rem;color:var(--ink);outline:none}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--proof)}
.submit-row{display:flex;align-items:center;gap:1.5rem;margin-top:0.8rem;flex-wrap:wrap}
.submit-row .note{font-size:0.86rem;color:var(--graphite)}

/* ---------- Letters ---------- */
.letters{display:flex;flex-direction:column;gap:0.4rem}
.letter{display:flex;justify-content:space-between;gap:2rem;align-items:flex-start;padding:1.6rem 0;border-bottom:1px solid rgba(10,10,10,0.12);transition:padding .14s}
.letter:hover{padding-left:0.6rem}
.letter h3{font-size:1.2rem;font-weight:500;margin:0.4rem 0 0.4rem}
.letter .preview{color:var(--graphite);font-size:0.95rem;margin:0;max-width:60ch}
.letter .date{align-self:flex-start;white-space:nowrap}

/* ---------- Kicker ---------- */
.kicker{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:clamp(1rem,1.6vw,1.3rem);line-height:1.4;color:var(--ink);max-width:48ch;margin:0}
.kicker.center{text-align:center;margin:0 auto}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:var(--bone);padding:clamp(2.4rem,5vw,4rem) 0 clamp(1.6rem,3vw,2.4rem)}
footer .footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;align-items:start;padding-bottom:2.4rem;border-bottom:1px solid rgba(244,239,230,0.1)}
footer .footer-brand{display:flex;align-items:center;gap:0.75rem;font-weight:500;font-size:0.95rem;color:var(--bone)}
footer .footer-brand svg{width:24px;height:24px;color:var(--bone)}
footer .footer-col h4{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:0.66rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(244,239,230,0.5);font-weight:400;margin:0 0 0.7rem}
footer .footer-col div,footer .footer-col a{font-size:0.92rem;color:rgba(244,239,230,0.82);line-height:1.7;word-break:break-word}
footer .footer-col a{border-bottom:1px solid rgba(244,239,230,0.16)}
footer .footer-col a:hover{color:var(--proof-3);border-color:var(--proof-3)}
footer .footer-bar{display:flex;justify-content:space-between;gap:1rem;padding-top:1.5rem;flex-wrap:wrap}
footer .footer-bar .meta{color:rgba(244,239,230,0.5)}

/* ---------- Mobile nav toggle ---------- */
.nav-toggle{display:none;width:44px;height:44px;background:transparent;border:0;padding:10px;-webkit-tap-highlight-color:transparent}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:transform .2s,opacity .2s}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
body.nav-open{overflow:hidden}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero-grid,.decidr-grid,.section-head,.media-split,.page-head-grid{grid-template-columns:1fr;gap:2rem}
  .compare,.media-grid{grid-template-columns:repeat(2,1fr)}
  .doors{grid-template-columns:1fr}
  .outcomes,.stats{grid-template-columns:repeat(2,1fr)}
  .principals{grid-template-columns:1fr}
  footer .footer-inner{grid-template-columns:1fr 1fr}
}

@media (max-width:820px){
  .nav-toggle{display:block;order:3;position:relative;z-index:70}
  .nav .cta{order:2;padding:0.55rem 0.9rem;font-size:0.875rem}
  .brand{order:1;flex:1;min-width:0}
  .brand-text{font-size:0.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .nav-links{position:fixed;inset:0;background:var(--bone);flex-direction:column;justify-content:center;align-items:center;gap:1.8rem;transform:translateX(100%);transition:transform .28s ease;z-index:60;padding:6rem 1.5rem 2rem}
  body.nav-open .nav-links{transform:translateX(0)}
  .nav-links a{font-size:1.4rem;opacity:1;padding:0.5rem 0}
  .nav-links a[aria-current="page"]{border-bottom:0;color:var(--proof)}
}

@media (max-width:640px){
  .compare,.outcomes,.stats,.media-grid{grid-template-columns:1fr}
  footer .footer-inner{grid-template-columns:1fr}
  .principal{grid-template-columns:1fr}
  .principal .portrait{width:100%;max-width:200px;height:240px}

  section{padding-top:clamp(2.6rem,9vw,4rem);padding-bottom:clamp(2.6rem,9vw,4rem)}
  .hero,.brand-hero{padding-top:2.4rem;padding-bottom:2rem}

  .hero-figure svg,.brand-hero .hero-figure svg{max-width:240px;margin:0 auto}
  .page-head-figure svg{max-width:200px;margin:0 auto}

  .hero h1,.brand-wordmark{max-width:none}
  .hero .lede,.brand-hero .lede{font-size:1rem}

  .media-tall img,.media.placeholder{aspect-ratio:3/4}

  .door{padding:1.8rem 1.5rem;min-height:0}

  .cta,.cta-ghost,.cta-mono{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
  .door-cta{font-size:0.65rem;padding:0.8rem 0.9rem}
  .form input,.form textarea,.form select{font-size:16px}
  .form .cta{width:100%}
  .submit-row{flex-direction:column;align-items:stretch}

  footer .footer-bar{flex-direction:column;gap:0.4rem}

  .outcomes,.stats{gap:0;margin-top:1.6rem}
  .stat,.outcome{padding:1.2rem 0}

  .letter{flex-direction:column;gap:0.4rem;padding:1.2rem 0}
  .letter:hover{padding-left:0}

  .mirror li{grid-template-columns:1fr;gap:0.4rem;padding:1.2rem 0}

  .breaker{padding:clamp(2.8rem,9vw,4.5rem) 0}
  .breaker .lead{font-size:1.1rem}
}

@media (max-width:420px){
  .brand-text{display:none}
  .nav .cta{font-size:0.78rem;padding:0.5rem 0.7rem;letter-spacing:-0.005em}
}

@media (hover:none){
  .nav-links a:hover,.door:hover,.letter:hover{padding-left:0}
}
