/* ============================================================
   CLEAR SKIES PROJECT — site chrome
   Vanilla layout/components on top of the brand tokens
   (colors_and_type.css) + evidence layer (evidence.css).
   Brutalist: sharp corners, hard offset shadows, mono labels.
   ============================================================ */

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* skip link */
.skip-link{position:absolute;left:14px;top:-60px;z-index:300;background:var(--ink);color:#fff;font-family:var(--font-mono);font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:12px 18px;text-decoration:none;transition:top .2s}
.skip-link:focus{top:14px;color:#fff}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{font-family:var(--font-body);font-weight:600;font-size:.98rem;padding:.85em 1.6em;border-radius:4px;border:none;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.5em;white-space:nowrap;min-height:44px;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),background var(--dur-base),color var(--dur-base),border-color var(--dur-base)}
.btn-primary{background:var(--azure);color:#fff;box-shadow:var(--shadow-azure)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(10,99,194,.8);background:var(--azure-deep);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-dawn{background:var(--dawn);color:var(--dawn-ink);font-weight:700}
.btn-dawn:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(255,122,77,.7);background:#ff8d63;color:var(--dawn-ink)}
.btn .arrow{transition:transform var(--dur-fast) var(--ease-out)}
.btn:hover .arrow{transform:translateX(3px)}
.btn-block{width:100%}

/* ============================================================
   SECTION SHELL + SHARED TYPE HELPERS
   ============================================================ */
section.block{padding:var(--sp-9) 0}
.kicker{margin-bottom:22px}
.sec-head{font-size:var(--t-xxl);max-width:20ch;line-height:1.02;letter-spacing:-.025em}
.sec-lede{margin-top:24px;font-size:var(--t-md);color:var(--fg-2);line-height:1.62;max-width:60ch}
.body-col{max-width:62ch}
.body-col p{font-size:1.12rem;line-height:1.66;color:var(--ink);margin-top:20px}
.body-col p:first-child{margin-top:28px}
section[id]{scroll-margin-top:90px}
.divider{border:0;border-top:1px solid var(--line)}

.pull{font-family:var(--font-display);font-weight:700;font-style:normal;font-size:clamp(1.5rem,3.2vw,2.2rem);line-height:1.18;color:var(--ink);border-left:3px solid var(--azure);padding-left:26px;margin-top:44px;max-width:30ch;letter-spacing:-.015em}
.section-bg-warm{background:var(--paper-warm);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* numbered point lists (HOW / WHAT) */
.point-list{list-style:none;margin:48px 0 0;padding:0;display:grid;gap:0;border-top:2px solid var(--ink)}
.point{display:grid;grid-template-columns:64px 1fr;gap:24px;padding:28px 0;border-bottom:1px solid var(--line);align-items:start}
.point__n{font-family:var(--font-mono);font-weight:700;font-size:1.2rem;color:var(--azure);line-height:1.2;padding-top:4px}
.point__b{font-size:1.12rem;line-height:1.6;color:var(--ink)}
.point__b strong{font-weight:700}
@media(max-width:620px){.point{grid-template-columns:48px 1fr;gap:16px}}

/* two-up grid for WHAT (4 points) */
.what-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:48px;border-top:2px solid var(--ink)}
.what-cell{padding:30px 30px 30px 0;border-bottom:1px solid var(--line)}
.what-cell:nth-child(even){padding-left:40px;border-left:1px solid var(--line)}
.what-cell__n{font-family:var(--font-mono);font-weight:700;font-size:1.05rem;color:var(--dawn-text);letter-spacing:.04em}
.what-cell__t{font-family:var(--font-display);font-weight:800;font-size:1.25rem;line-height:1.1;letter-spacing:-.01em;margin:12px 0 10px}
.what-cell__b{font-size:1.02rem;line-height:1.55;color:var(--ink-soft)}
@media(max-width:720px){.what-grid{grid-template-columns:1fr}.what-cell:nth-child(even){padding-left:0;border-left:none}}

/* ============================================================
   NAV
   ============================================================ */
.csp-nav{position:fixed;top:0;left:0;right:0;z-index:200;background:transparent;border-bottom:1px solid transparent;transition:background .35s,border-color .35s,backdrop-filter .35s}
.csp-nav.scrolled,.csp-nav.solid{backdrop-filter:blur(12px);background:rgba(244,247,250,.86);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand{font-family:var(--font-display);font-weight:800;font-size:1.02rem;letter-spacing:.01em;text-transform:uppercase;display:flex;align-items:center;gap:.6em;color:#fff;text-decoration:none;transition:color .35s;min-height:44px}
.csp-nav.scrolled .brand,.csp-nav.solid .brand{color:var(--ink)}
.brand .dot{width:12px;height:12px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--dawn),var(--azure));box-shadow:0 0 0 4px rgba(10,99,194,.12);flex:none}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a:not(.btn){color:rgba(255,255,255,.88);text-decoration:none;font-size:.94rem;font-weight:500;transition:color .2s;display:inline-flex;align-items:center;min-height:44px}
.csp-nav.scrolled .nav-links a:not(.btn),.csp-nav.solid .nav-links a:not(.btn){color:var(--ink-soft)}
.csp-nav.scrolled .nav-links a:not(.btn):hover,.csp-nav.solid .nav-links a:not(.btn):hover{color:var(--ink)}
.nav-links .btn-primary{color:#fff}
.nav-toggle{display:none;background:transparent;border:1.5px solid currentColor;color:#fff;border-radius:4px;width:44px;height:44px;cursor:pointer;align-items:center;justify-content:center}
.csp-nav.scrolled .nav-toggle,.csp-nav.solid .nav-toggle{color:var(--ink)}
.nav-toggle svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none}
@media(max-width:860px){
  .nav-toggle{display:inline-flex}
  .nav-links{position:absolute;top:74px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:8px 28px 20px;max-height:0;overflow:hidden;transition:max-height .3s var(--ease-out)}
  .nav-links a:not(.btn){color:var(--ink-soft);padding:6px 0;border-bottom:1px solid var(--line)}
  .nav-links .btn{margin-top:14px}
  .csp-nav.open .nav-links{max-height:420px}
  .csp-nav.open{backdrop-filter:blur(12px);background:rgba(244,247,250,.96)}
  .csp-nav.open .brand,.csp-nav.open .nav-toggle{color:var(--ink)}
}

/* ============================================================
   HERO (homepage)
   ============================================================ */
.csp-hero{position:relative;padding:172px 0 90px;min-height:94vh;display:flex;align-items:center;overflow:hidden;background:#0c1726 center 30%/cover no-repeat}
.hero-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 32%;z-index:0}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(8,15,28,.82) 0%,rgba(8,15,28,.5) 28%,rgba(8,15,28,.28) 55%,rgba(8,15,28,.62) 100%),linear-gradient(100deg,rgba(8,15,28,.78) 0%,rgba(8,15,28,.4) 50%,rgba(8,15,28,.08) 82%)}
.hero-inner{position:relative;z-index:2;max-width:62ch}
.csp-hero .eyebrow{color:#9ecbf2}
.hero-eyebrow{margin-bottom:28px}
.csp-hero h1{font-size:var(--t-mega);max-width:15ch;color:#fff;text-shadow:0 2px 30px rgba(6,12,24,.45)}
.csp-hero h1 .accent{font-style:italic;font-weight:600;color:#ffcaa8}
.hero-sub{margin-top:28px;max-width:54ch;font-size:1.2rem;color:#dbe7f2;font-weight:400;line-height:1.62;text-shadow:0 1px 18px rgba(6,12,24,.5)}
.hero-quiet{margin-top:18px;max-width:52ch;font-family:var(--font-body);font-style:italic;font-size:1.05rem;color:#bcd0e3;line-height:1.55}
.hero-cta{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.csp-hero .ghost-light{border-color:rgba(255,255,255,.7);color:#fff}
.csp-hero .ghost-light:hover{background:#fff;color:var(--ink);border-color:#fff}
.hero-note{margin-top:26px;font-family:var(--font-mono);font-size:.82rem;letter-spacing:.04em;color:#c2d3e3}

/* ============================================================
   "YOU CAN'T OPT OUT" — ink band (WHY)
   ============================================================ */
.csp-ink{background:var(--ink);color:var(--paper);padding:96px 0}
.csp-ink .wrap{max-width:940px}
.csp-ink h2{color:#fff}
.csp-ink .body-col p{color:#cddae6}
.csp-ink .body-col p strong{color:#fff}

/* ============================================================
   METHOD MODULE (reused from system)
   ============================================================ */
.method-title{max-width:none;font-size:clamp(2rem,4.4vw,3.2rem)}
.method-title .arrow{color:var(--dawn-text);font-style:normal;padding:0 .06em}
.method-grid{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;padding:0}
@media(max-width:860px){.method-grid{grid-template-columns:1fr;gap:16px}}
.method-cell{position:relative;display:flex;min-width:0}
.pillar-method{position:relative;flex:1;display:flex;flex-direction:column;gap:16px;background:var(--white);border:2px solid var(--ink);border-radius:0;padding:28px 24px 26px;box-shadow:3px 3px 0 var(--ink);text-decoration:none;color:inherit;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.pillar-method::after{content:"";position:absolute;left:0;top:0;width:100%;height:2px;background:var(--azure);transform:scaleX(0);transform-origin:left;transition:transform var(--dur-base) var(--ease-out)}
.pillar-method:hover,.pillar-method:focus-visible{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--ink)}
.pillar-method:hover::after,.pillar-method:focus-visible::after{transform:scaleX(1)}
.method-cell:not(:first-child)::before{content:"";position:absolute;z-index:1;top:42px;left:-25px;width:25px;height:2px;background:var(--azure)}
@media(max-width:860px){.method-cell:not(:first-child)::before{top:-16px;left:38px;width:2px;height:16px}}
.pillar-method__index{font-family:var(--font-mono);font-weight:700;font-size:1.55rem;line-height:1;color:var(--azure);letter-spacing:.02em}
.pillar-method__title{font-family:var(--font-display);font-weight:800;font-size:1.5rem;line-height:1.04;letter-spacing:-.01em;text-transform:uppercase;color:var(--ink);margin:0}
.pillar-method__desc{font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--ink-soft);margin:0}

/* ============================================================
   "DRAW THE LINE" — claim lists with confidence badges
   ============================================================ */
.line-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:48px;align-items:start}
@media(max-width:820px){.line-grid{grid-template-columns:1fr}}
.claim-block{background:var(--white);border:2px solid var(--ink);box-shadow:var(--shadow-hard);padding:26px 26px 28px;display:flex;flex-direction:column;gap:18px}
.claim-block__head{display:flex;flex-direction:column;gap:12px}
.claim-block__title{font-family:var(--font-display);font-weight:800;font-size:1.25rem;line-height:1.12;letter-spacing:-.01em;max-width:30ch}
.claim-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.claim-list li{display:flex;gap:13px;align-items:baseline;font-size:1.02rem;line-height:1.5;color:var(--ink)}
.claim-list li::before{content:"";flex:none;width:8px;height:8px;margin-top:.5em;background:var(--ink)}
.line-close{margin-top:40px;font-family:var(--font-display);font-weight:700;font-size:clamp(1.3rem,2.6vw,1.7rem);line-height:1.3;max-width:36ch;letter-spacing:-.01em;border-left:3px solid var(--dawn);padding-left:24px}

/* ============================================================
   STAKE band (ink)
   ============================================================ */
.stake .body-col p{font-size:1.18rem}

/* ============================================================
   FORMS — petition + newsletter (the backend hooks)
   ============================================================ */
.form-card{background:var(--white);border:2px solid var(--ink);box-shadow:var(--shadow-hard);padding:32px 32px 30px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.field .req{color:var(--dawn-text);margin-left:.2em}
.fld{font-family:var(--font-body);font-size:1rem;padding:.85em 1.05em;border:1.5px solid var(--ink);border-radius:4px;background:#fff;color:var(--ink);width:100%;min-height:44px;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}
.fld::placeholder{color:#7e93a6}
.fld:focus{outline:3px solid var(--ink);outline-offset:2px}
.fld[aria-invalid="true"]{border-color:var(--c-misinformation);box-shadow:0 0 0 2px rgba(194,54,47,.18)}
.field-hint{font-size:.82rem;color:var(--ink-soft)}
.field-error{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.04em;color:var(--c-misinformation);min-height:1em}
.petition-grid{display:grid;grid-template-columns:1fr 1.4fr .8fr;gap:16px;align-items:end}
@media(max-width:720px){.petition-grid{grid-template-columns:1fr}}
.form-foot{margin-top:20px;display:flex;flex-direction:column;gap:14px}
.form-micro{font-size:.86rem;color:var(--ink-soft);line-height:1.5;max-width:60ch}
.form-success,.form-error{font-family:var(--font-body);font-size:.98rem;line-height:1.5;padding:14px 16px;border-radius:4px;display:none}
.form-success{background:rgba(21,122,78,.1);border:1.5px solid var(--c-documented);color:#0c5436}
.form-error{background:rgba(194,54,47,.08);border:1.5px solid var(--c-misinformation);color:#9a2a24}
.form-success.show,.form-error.show{display:block}

/* petition section layout */
.petition{background:var(--paper-warm);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.planks{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:44px}
@media(max-width:820px){.planks{grid-template-columns:1fr}}
.plank{border-top:2px solid var(--ink);padding-top:20px}
.plank__k{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--azure)}
.plank__t{font-family:var(--font-display);font-weight:800;font-size:1.3rem;letter-spacing:-.01em;margin:10px 0 12px}
.plank__b{font-size:1.02rem;line-height:1.58;color:var(--ink-soft)}
.petition-form-wrap{margin-top:48px}

/* newsletter — embed slot + fallback */
.newsletter{background:var(--ink);color:#fff;padding:96px 0;position:relative;overflow:hidden}
.newsletter .wrap{max-width:780px;text-align:center;position:relative;z-index:1}
.news-sky{position:absolute;inset:0;z-index:0;background:radial-gradient(80% 120% at 18% 0%,#1b4e8f 0%,transparent 55%),radial-gradient(90% 100% at 88% 100%,#c2502e 0%,transparent 50%),linear-gradient(160deg,var(--azure-deep),#0a1626)}
.newsletter h2{color:#fff;font-size:clamp(2rem,4.4vw,3rem)}
.newsletter .eyebrow{color:#9ecbf2;justify-content:center}
.newsletter p{margin-top:18px;font-size:1.12rem;color:#cdddf0;line-height:1.6}
#newsletter-embed{margin:32px auto 0;max-width:520px;min-height:96px;border:1.5px dashed rgba(255,255,255,.4);border-radius:4px;background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;padding:20px;color:#9fb6cc;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;text-align:center;line-height:1.6}
.news-fallback{margin:22px auto 0;max-width:520px}
.news-or{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#9fb6cc;margin:24px 0 12px}
.news-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.news-row .fld{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.35);color:#fff;min-width:260px;flex:1}
.news-row .fld::placeholder{color:#a9c0d6}
.news-row .fld:focus{outline-color:var(--paper)}
.newsletter .form-micro{color:#9fb6cc;margin:18px auto 0;text-align:center}
.newsletter .form-success,.newsletter .form-error{text-align:left;margin:18px auto 0;max-width:520px}

/* ============================================================
   BLOG POST CARDS (homepage row + index grid)
   ============================================================ */
.posts-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
@media(max-width:900px){.posts-row{grid-template-columns:1fr}}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px}
@media(max-width:960px){.post-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.post-grid{grid-template-columns:1fr}}

.post-card{display:flex;flex-direction:column;gap:14px;background:var(--white);border:2px solid var(--ink);border-radius:0;padding:24px 24px 22px;text-decoration:none;color:inherit;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);box-shadow:0 0 0 var(--ink);position:relative}
.post-card::after{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:linear-gradient(90deg,var(--azure),var(--dawn));transform:scaleX(0);transform-origin:left;transition:transform var(--dur-base) var(--ease-out)}
.post-card:hover,.post-card:focus-visible{transform:translate(-4px,-4px);box-shadow:8px 8px 0 var(--ink)}
.post-card:hover::after,.post-card:focus-visible::after{transform:scaleX(1)}
.post-card__cat{display:inline-flex;width:fit-content;font-family:var(--font-mono);font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--azure);border:1.5px solid var(--azure);padding:.35em .6em;border-radius:0}
.post-card__title{font-family:var(--font-display);font-weight:800;font-size:1.3rem;line-height:1.1;letter-spacing:-.015em;color:var(--ink)}
.post-card__meta{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.04em;color:var(--ink-soft);display:flex;flex-wrap:wrap;gap:.5em;align-items:center}
.post-card__meta time{color:var(--ink)}
.post-card__excerpt{font-size:1rem;line-height:1.55;color:var(--ink-soft);flex:1}
.post-card__read{font-family:var(--font-mono);font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--azure-deep);display:inline-flex;align-items:center;gap:.5em}
.post-card:hover .post-card__read{color:var(--ink)}
.post-card__read .arrow{transition:transform var(--dur-fast) var(--ease-out)}
.post-card:hover .post-card__read .arrow{transform:translateX(3px)}

.latest-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.see-all{font-family:var(--font-mono);font-weight:700;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;color:var(--azure-deep);display:inline-flex;align-items:center;gap:.5em;min-height:44px}
.see-all:hover{color:var(--ink)}
.see-all .arrow{transition:transform var(--dur-fast) var(--ease-out)}
.see-all:hover .arrow{transform:translateX(3px)}

/* ============================================================
   BLOG INDEX page header
   ============================================================ */
.page-head{padding:148px 0 56px;border-bottom:1px solid var(--line);background:var(--paper)}
.page-head h1{font-size:clamp(2.6rem,6vw,4.6rem);max-width:16ch}
.page-head .lede{margin-top:24px;font-size:var(--t-md);color:var(--ink-soft);max-width:56ch}
.cat-bar{display:flex;gap:10px;flex-wrap:wrap;margin:36px 0 8px}
.cat-chip{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);border:1.5px solid var(--ink);padding:.5em .85em;border-radius:0;background:#fff;cursor:pointer;min-height:44px;display:inline-flex;align-items:center;transition:background var(--dur-fast),color var(--dur-fast)}
.cat-chip:hover{background:var(--ink);color:#fff}
.cat-chip[aria-pressed="true"]{background:var(--ink);color:#fff}
.blog-list-section{padding:56px 0 var(--sp-9)}

/* ============================================================
   BLOG POST (article)
   ============================================================ */
.article{padding:140px 0 var(--sp-8)}
.article-inner{max-width:none}
.article-head{max-width:760px;margin:0 auto}
.article-eyebrow{font-family:var(--font-mono);font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--azure);display:flex;flex-wrap:wrap;gap:.6em;align-items:center}
.article-eyebrow .sep{color:var(--line)}
.article-eyebrow time{color:var(--ink-soft)}
.article-title{margin-top:22px;font-size:clamp(2.4rem,5.4vw,4rem);line-height:1.02;letter-spacing:-.03em;max-width:18ch}
.article-byline{margin-top:26px;display:flex;align-items:center;gap:14px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0}
.byline-avatar{width:44px;height:44px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--dawn),var(--azure));flex:none}
.byline-meta{font-family:var(--font-mono);font-size:.8rem;color:var(--ink-soft);line-height:1.5}
.byline-meta strong{display:block;font-family:var(--font-body);font-size:1rem;font-weight:700;color:var(--ink);letter-spacing:0}

.lead-figure{margin:44px auto 0;max-width:980px}
.lead-figure img{width:100%;border:2px solid var(--ink);box-shadow:var(--shadow-hard);border-radius:0}
.lead-figure figcaption{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-soft);letter-spacing:.02em;margin-top:14px;line-height:1.5}

/* Section media — brutalist framed images in the WHY / HOW / WHAT sections */
.section-media{margin:44px 0 4px;border:2px solid var(--ink);box-shadow:var(--shadow-hard);background:var(--white);overflow:hidden}
.section-media img{width:100%;height:auto;display:block;aspect-ratio:3/2;object-fit:cover}
.csp-ink .section-media{border-color:#fff;box-shadow:6px 6px 0 rgba(0,0,0,.4)}
@media (max-width:680px){.section-media{box-shadow:4px 4px 0 var(--ink);margin:32px 0 4px}}

.article-body{max-width:680px;margin:48px auto 0}
.article-body p{font-size:1.18rem;line-height:1.7;color:var(--ink);margin-top:24px}
.article-body p:first-child{margin-top:0}
.article-body h2{font-family:var(--font-display);font-weight:800;font-size:1.9rem;letter-spacing:-.02em;line-height:1.1;margin:52px 0 0}
.article-body h3{font-family:var(--font-display);font-weight:700;font-size:1.35rem;letter-spacing:-.01em;margin:40px 0 0}
.article-body ul,.article-body ol{margin:20px 0 0;padding-left:1.3em}
.article-body li{font-size:1.12rem;line-height:1.65;margin-top:10px}
.article-body a{color:var(--azure);text-decoration:underline;text-underline-offset:2px}
.article-body a:hover{color:var(--azure-deep)}
.article-pull{font-family:var(--font-display);font-weight:700;font-style:normal;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.2;letter-spacing:-.02em;color:var(--ink);border-left:4px solid var(--dawn);padding-left:28px;margin:52px 0;max-width:30ch}
.article-evidence{margin:48px auto;max-width:680px;display:flex;flex-direction:column;gap:16px}
.article-evidence .evidence-card{max-width:none}
.article-evidence__cap{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}

.sources{max-width:680px;margin:60px auto 0;border-top:2px solid var(--ink);padding-top:24px}
.sources h2{font-family:var(--font-display);font-weight:800;font-size:1.2rem;letter-spacing:.02em;text-transform:uppercase;margin:0 0 18px}
.sources ol{list-style:none;counter-reset:src;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.sources li{counter-increment:src;display:grid;grid-template-columns:36px 1fr;gap:12px;font-family:var(--font-mono);font-size:.82rem;line-height:1.55;color:var(--ink-soft)}
.sources li::before{content:"[" counter(src) "]";color:var(--azure);font-weight:700}
.sources a{color:var(--azure);text-decoration:underline;text-underline-offset:2px;word-break:break-word}

.share-row{max-width:680px;margin:44px auto 0;display:flex;align-items:center;gap:14px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:28px}
.share-row__label{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.share-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;min-height:44px;padding:.5em 1em;border:1.5px solid var(--ink);background:#fff;color:var(--ink);font-family:var(--font-mono);font-size:.76rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:0;cursor:pointer;text-decoration:none;transition:background var(--dur-fast),color var(--dur-fast)}
.share-btn:hover{background:var(--ink);color:#fff}

.back-link{font-family:var(--font-mono);font-weight:700;font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;color:var(--azure-deep);display:inline-flex;align-items:center;gap:.5em;min-height:44px}
.back-link:hover{color:var(--ink)}

/* ============================================================
   FOOTER
   ============================================================ */
.csp-footer{background:var(--ink);color:#8ea2b5;padding:64px 0 44px}
.foot-top{display:grid;grid-template-columns:1.3fr 2fr;gap:40px;border-bottom:1px solid var(--ink-line);padding-bottom:34px}
@media(max-width:760px){.foot-top{grid-template-columns:1fr}}
.foot-brand{font-family:var(--font-display);color:#fff;font-size:1.15rem;font-weight:800;text-transform:uppercase;letter-spacing:.01em;display:flex;align-items:center;gap:.5em}
.foot-brand .dot{width:12px;height:12px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--dawn),var(--azure));flex:none}
.foot-mission{max-width:44ch;margin-top:14px;font-size:.96rem;line-height:1.6}
.foot-links{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 26px}
@media(max-width:480px){.foot-links{grid-template-columns:1fr}}
.foot-links a{color:#8ea2b5;text-decoration:none;font-size:.95rem;transition:color .2s;display:inline-flex;align-items:center;min-height:44px}
.foot-links a:hover{color:#fff}
.foot-bottom{margin-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;align-items:center}
.foot-credo{font-family:var(--font-mono);font-size:.78rem;font-weight:700;letter-spacing:.1em;color:#6f859a;max-width:60ch;line-height:1.6}
.foot-credo .em{color:var(--dawn)}
.foot-copy{font-size:.82rem;color:#6f859a}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.sr{transform:translateY(22px);transition:transform .7s var(--ease-out)}
.sr.in{transform:none}
.reveal-load{transform:translateY(16px);transition:transform .75s var(--ease-out)}
body.loaded .reveal-load{transform:none}
.d1{transition-delay:.05s}.d2{transition-delay:.16s}.d3{transition-delay:.28s}.d4{transition-delay:.42s}.d5{transition-delay:.56s}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,122,77,.55)}70%{box-shadow:0 0 0 12px rgba(255,122,77,0)}100%{box-shadow:0 0 0 0 rgba(255,122,77,0)}}
@media(prefers-reduced-motion:reduce){.reveal-load,.sr{transition:none;transform:none}.post-card,.pillar-method{transition:none}}
