@font-face{font-family:"Departure Mono";src:url("../fonts/DepartureMono-Regular.otf") format("opentype");font-weight:400;font-display:swap}
@font-face{font-family:"Space Grotesk";src:url("../fonts/SpaceGrotesk-VariableFont_wght.ttf") format("truetype");font-weight:300 700;font-display:swap}
:root{
  --em:#16A85A;--em-b:#1FD27A;--fo:#014A2E;--fo-d:#022601;
  --mi:#B5F0C9;--nv:#03171F;--nv2:#0A2128;--nv3:#122A33;
  --pa:#FAF8F4;--f4:#736A62;--f5:#333740;--f1:#F0EEE9;
  --pi:#F3C9C7;--ye:#F7E26E;--li:#D8F25E;
  --mo:"Departure Mono","VT323",ui-monospace,monospace;
  --bd:"Space Grotesk",system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--bd);font-size:17px;line-height:1.55;color:var(--f5);background:var(--pa);-webkit-font-smoothing:antialiased;text-wrap:pretty}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 56px}
.wrap-narrow{max-width:780px;margin:0 auto;padding:0 56px}

/* ── NAV ── */
.site-nav{position:sticky;top:0;z-index:100;background:rgba(3,23,31,.95);border-bottom:1px solid rgba(181,240,201,.12);backdrop-filter:blur(8px)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 56px;max-width:1280px;margin:0 auto;gap:24px}
.logo{font:20px/1 var(--mo);color:var(--mi);display:flex;align-items:baseline}
.logo .e{color:var(--em)}
.logo .sup{font-size:10px;letter-spacing:.16em;margin-left:9px;opacity:.7}
.nav-links{display:flex;gap:28px}
.nav-links a{font:10px/1 var(--mo);letter-spacing:.16em;text-transform:uppercase;color:var(--mi);opacity:.6;transition:opacity 120ms}
.nav-links a:hover{opacity:1}
.nav-links a.active{opacity:1;color:var(--em)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:15px 24px;font:11px/1 var(--mo);letter-spacing:.14em;text-transform:uppercase;border:1.5px solid transparent;cursor:pointer;transition:all 120ms}
.btn-p{background:var(--em);color:var(--fo-d);border-color:var(--em)}
.btn-p:hover{background:var(--em-b);border-color:var(--em-b)}
.btn-gm{background:transparent;color:var(--mi);border-color:rgba(181,240,201,.4)}
.btn-gm:hover{background:var(--mi);color:var(--fo-d)}
.tag{display:inline-block;padding:5px 12px 4px;font:10px/1 var(--mo);letter-spacing:.18em;text-transform:uppercase}
.tag-y{background:var(--ye);color:#022601}
.tag-p{background:var(--pi);color:var(--nv)}
.tag-l{background:var(--li);color:#022601}
.tag-m{background:var(--mi);color:#022601}
.tag-e{background:transparent;border:1px solid rgba(22,168,90,.35);color:var(--em)}

/* ── BLOG HERO ── */
.bl-hero{background:var(--nv);color:var(--mi);padding:96px 0 72px;position:relative;overflow:hidden}
.bl-bp{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.bl-hero-inner{position:relative;z-index:1}
.bl-back{display:inline-flex;align-items:center;gap:10px;font:9px/1 var(--mo);letter-spacing:.2em;text-transform:uppercase;color:var(--mi);opacity:.45;margin-bottom:36px;transition:opacity 120ms}
.bl-back:hover{opacity:1}
.bl-eyebrow{font:10px/1 var(--mo);letter-spacing:.22em;text-transform:uppercase;color:var(--em);display:block;margin-bottom:14px}
.bl-hero h1{font:clamp(44px,6vw,80px)/1.0 var(--mo);color:#fff;margin-bottom:4px}
.bl-hero h1 .punc{color:var(--em)}
.bl-hero .sub{font:clamp(20px,2.5vw,32px)/1.2 var(--bd);font-weight:300;color:var(--mi);opacity:.6;margin-bottom:20px}
.bl-hero .lede{font:clamp(15px,1.2vw,18px)/1.65 var(--bd);color:var(--mi);opacity:.6;max-width:52ch}

/* ── LISTING ── */
.bl-strip{background:var(--fo-d);border-bottom:1px solid rgba(181,240,201,.08)}
.bl-strip-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;max-width:1280px;margin:0 auto;padding:18px 56px}
.bl-strip-note{font:9px/1 var(--mo);letter-spacing:.18em;text-transform:uppercase;color:var(--mi);opacity:.38}
.bl-list{padding:72px 0}
.bl-post-row{display:grid;grid-template-columns:140px 100px 1fr 72px;align-items:start;gap:16px 28px;padding:26px 0;border-bottom:1px solid rgba(20,30,35,.08);transition:background 120ms;cursor:pointer}
.bl-post-row:first-child{border-top:1px solid rgba(20,30,35,.08)}
.bl-post-row:hover{background:var(--f1);margin:0 -24px;padding:26px 24px}
.bl-post-row:hover .bl-pt{color:var(--em)}
.bl-pd{font:9px/1 var(--mo);letter-spacing:.14em;text-transform:uppercase;color:var(--f4);opacity:.55;padding-top:4px}
.bl-pc{font:9px/1 var(--mo);letter-spacing:.14em;text-transform:uppercase;padding-top:4px}
.bl-pt{font:clamp(16px,1.4vw,20px)/1.25 var(--bd);font-weight:600;color:var(--nv);letter-spacing:-.012em;margin-bottom:6px;transition:color 120ms}
.bl-px{font:14px/1.6 var(--bd);color:var(--f4);max-width:56ch}
.bl-pr{font:9px/1 var(--mo);letter-spacing:.1em;text-transform:uppercase;color:var(--f4);opacity:.45;text-align:right;padding-top:4px}

/* ── NEWSLETTER BAND ── */
.nl-band{background:var(--nv);padding:52px 0}
.nl-band-inner{display:grid;grid-template-columns:1fr auto;align-items:center;gap:48px}
.nl-band-l{display:flex;flex-direction:column;gap:10px}
.nl-band-eyebrow{font:9px/1 var(--mo);letter-spacing:.22em;text-transform:uppercase;color:var(--em)}
.nl-band-h{font:clamp(20px,2vw,28px)/1.2 var(--bd);font-weight:600;color:#fff}
.nl-band-p{font:15px/1.6 var(--bd);color:var(--mi);opacity:.55;max-width:48ch}
.nl-band-proof{font:9px/1 var(--mo);letter-spacing:.16em;text-transform:uppercase;color:var(--mi);opacity:.3}

/* ── POST HERO ── */
.ph-hero{background:var(--nv);color:var(--mi);padding:80px 0 60px;position:relative;overflow:hidden}
.ph-hero-inner{position:relative;z-index:1}
.ph-meta{display:flex;align-items:center;flex-wrap:wrap;gap:10px 18px;margin-bottom:24px}
.ph-date{font:9px/1 var(--mo);letter-spacing:.18em;text-transform:uppercase;color:var(--mi);opacity:.4}
.ph-read{font:9px/1 var(--mo);letter-spacing:.18em;text-transform:uppercase;color:var(--mi);opacity:.4}
.ph-sep{color:var(--mi);opacity:.18;font:11px var(--mo)}
.ph-hero h1{font:clamp(28px,4vw,56px)/1.08 var(--bd);font-weight:600;letter-spacing:-.022em;color:#fff;max-width:22ch;margin-bottom:14px}
.ph-lede{font:clamp(16px,1.3vw,20px)/1.6 var(--bd);color:var(--mi);opacity:.65;max-width:52ch}

/* ── POST BODY ── */
.post-body{padding:72px 0 56px}
.post-content h2{font:clamp(20px,2vw,28px)/1.2 var(--bd);font-weight:600;color:var(--nv);letter-spacing:-.015em;margin:40px 0 12px}
.post-content h3{font:clamp(16px,1.4vw,20px)/1.3 var(--bd);font-weight:600;color:var(--nv);margin:28px 0 8px}
.post-content p{font:17px/1.7 var(--bd);color:var(--f4);margin-bottom:18px}
.post-content p strong{color:var(--f5);font-weight:600}
.post-content ul,.post-content ol{margin:0 0 18px 0;padding-left:0;display:flex;flex-direction:column;gap:8px}
.post-content li{font:17px/1.65 var(--bd);color:var(--f4);padding-left:20px;position:relative}
.post-content li::before{content:"—";position:absolute;left:0;color:var(--em);font:14px/1 var(--mo)}
.post-content blockquote{margin:32px 0;padding:20px 24px;border-left:3px solid var(--em);background:var(--f1)}
.post-content blockquote p{font:18px/1.6 var(--bd);font-weight:500;color:var(--f5);margin:0}
.post-section-tag{font:9px/1 var(--mo);letter-spacing:.22em;text-transform:uppercase;color:var(--em);display:block;margin:48px 0 16px;padding-top:48px;border-top:1px solid rgba(20,30,35,.08)}
.post-rule{height:1px;background:rgba(20,30,35,.08);margin:40px 0}

/* ── AUTHOR BLOCK ── */
.author-block{display:flex;align-items:flex-start;gap:20px;padding:28px 32px;background:var(--nv);margin:56px 0 0}
.author-img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid rgba(181,240,201,.2)}
.author-info{display:flex;flex-direction:column;gap:6px}
.author-label{font:8px/1 var(--mo);letter-spacing:.22em;text-transform:uppercase;color:var(--em)}
.author-name{font:16px/1.2 var(--bd);font-weight:600;color:#fff}
.author-bio{font:13px/1.6 var(--bd);color:var(--mi);opacity:.55;max-width:52ch}

/* ── POST NAV ── */
.post-nav{background:var(--pa);padding:48px 0;border-top:1px solid rgba(20,30,35,.08)}
.post-nav-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:center}
.post-nav-prev,.post-nav-next{display:flex;flex-direction:column;gap:5px}
.post-nav-next{align-items:flex-end}
.post-nav-dir{font:8px/1 var(--mo);letter-spacing:.22em;text-transform:uppercase;color:var(--f4);opacity:.5}
.post-nav-title{font:clamp(13px,1.1vw,16px)/1.3 var(--bd);font-weight:500;color:var(--nv);transition:color 120ms;max-width:28ch}
.post-nav-prev:hover .post-nav-title,.post-nav-next:hover .post-nav-title{color:var(--em)}
.post-nav-cta{display:flex;flex-direction:column;align-items:center;gap:8px}
.post-nav-note{font:8px/1 var(--mo);letter-spacing:.18em;text-transform:uppercase;color:var(--f4);opacity:.45}

/* ── FOOTER ── */
.site-footer{background:var(--fo-d);color:var(--mi);padding:72px 0 28px}
.foot-grid{display:grid;grid-template-columns:1fr 2fr;gap:64px;margin-bottom:48px}
.foot-logo{font:44px/1 var(--mo)}
.foot-logo .e{color:var(--em)}
.foot-logo .lbl{font-size:13px;letter-spacing:.12em;display:block;margin-top:8px;opacity:.5}
.foot-line{font:13px/1.55 var(--bd);color:var(--mi);opacity:.3;margin-top:12px;max-width:28ch}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.foot-col .ch{font:8px/1 var(--mo);letter-spacing:.22em;text-transform:uppercase;color:var(--em);margin-bottom:13px;display:block}
.foot-col ul{display:flex;flex-direction:column;gap:9px}
.foot-col li{font:13px/1.4 var(--bd);color:var(--mi);opacity:.42;transition:opacity 120ms}
.foot-col li:hover{opacity:1}
.foot-base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:22px;border-top:1px solid rgba(181,240,201,.1);font:8px/1 var(--mo);letter-spacing:.14em;text-transform:uppercase;color:var(--mi);opacity:.25}

/* ── RESPONSIVE ── */
@media(max-width:980px){
  .wrap,.wrap-narrow,.nav-inner,.bl-strip-inner{padding-inline:24px}
  .bl-post-row{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}
  .bl-pr{text-align:left}
  .nl-band-inner{grid-template-columns:1fr}
  .post-nav-grid{grid-template-columns:1fr 1fr}
  .post-nav-cta{display:none}
  .foot-grid{grid-template-columns:1fr;gap:36px}
  .foot-cols{grid-template-columns:repeat(2,1fr)}
  .nav-links{display:none}
}
@media(max-width:560px){
  .bl-post-row{grid-template-columns:1fr}
  .foot-cols{grid-template-columns:1fr}
}