*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --white:  #FAFAF8;
  --paper:  #F3F0EB;
  --stone:  #E8E3DA;
  --ink:    #1A1710;
  --mid:    #6B6760;
  --soft:   #ABA79F;
  --rule:   #E0DBD2;

  --green:  #2A5E45;
  --green-l:#EBF4EF;
  --green-m:#BDD8CA;
  --terra:  #B84F2D;
  --terra-l:#FAF0EC;
  --terra-m:#EDCABB;
  --blue:   #305D8C;
  --blue-l: #EBF1F8;
  --blue-m: #BAD0E8;
  --amber:  #856020;
  --amber-l:#FBF6EE;
  --amber-m:#E8CFA0;

  --fHead: 'Bricolage Grotesque', system-ui, sans-serif;
  --fBody: 'DM Sans', system-ui, sans-serif;
  --nav-h: 60px;
}

html{scroll-behavior:smooth}
body{background:var(--white);color:var(--ink);font-family:var(--fBody);font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
::selection{background:var(--green-m);color:var(--green)}

/* ── NAV ──────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;padding:0 44px;
  background:rgba(250,250,248,.9);backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  border-bottom:1px solid transparent;transition:border-color .3s;
}
nav.scrolled{border-bottom-color:var(--rule)}
.nav-logo{font-family:var(--fHead);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:8px}
.nav-logo-img{height:28px;width:auto;display:block}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-size:.78rem;font-weight:400;color:var(--mid);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-btn{font-family:var(--fBody);font-size:.78rem;font-weight:500;padding:8px 20px;border-radius:100px;background:var(--ink);color:var(--white);transition:background .2s}
.nav-btn:hover{background:#2e2b22}

/* ── HAMBURGER + MOBILE MENU ─────────────────────────── */
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:6px;flex-direction:column;gap:5px;z-index:110}
.nav-burger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:1px;transition:transform .3s,opacity .3s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mob-menu{
  position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;z-index:99;
  background:rgba(250,250,248,.97);backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.mob-menu.open{opacity:1;pointer-events:auto}
.mob-menu a{font-family:var(--fHead);font-size:1.4rem;font-weight:600;color:var(--mid);transition:color .2s;text-decoration:none}
.mob-menu a:hover{color:var(--ink)}

@media(min-width:601px){.nav-burger,.mob-menu{display:none!important}}
@media(max-width:600px){.nav-burger{display:flex}.nav-btn{display:none}}

/* ── HERO ──────────────────────────────────────────────── */
#hero{
  min-height:100svh;padding:calc(var(--nav-h) + 72px) 44px 72px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.hero-eyebrow{
  font-size:.73rem;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--soft);margin-bottom:28px;
  display:flex;align-items:center;gap:10px;
  opacity:0;animation:fUp .7s .1s ease forwards;
}
.hero-eyebrow::before{content:'';width:20px;height:1px;background:var(--green)}
.hero-h1{
  font-family:var(--fHead);
  font-size:clamp(3.2rem, 6.5vw, 6.5rem);
  font-weight:800;line-height:.96;letter-spacing:-.04em;
  max-width:880px;
  opacity:0;transform:translateY(22px);
  animation:fUp .9s .22s ease forwards;
}
.hero-h1 em{font-style:italic;font-weight:700;color:var(--green)}
.hero-desc{
  font-size:1.05rem;font-weight:300;color:var(--mid);
  max-width:520px;margin-top:30px;line-height:1.75;
  opacity:0;transform:translateY(14px);
  animation:fUp .8s .42s ease forwards;
}

/* ── SHARED ────────────────────────────────────────────── */
section{padding:96px 44px}
.si{max-width:1100px;margin:0 auto}
.stag{display:flex;align-items:center;gap:10px;font-size:.67rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-bottom:40px}
.stag::before{content:'';width:14px;height:2px;background:var(--green);flex-shrink:0}
h2{font-family:var(--fHead);font-size:clamp(2.4rem,5vw,4rem);font-weight:800;line-height:.97;letter-spacing:-.03em}
h2 .mu{color:var(--soft)}

/* ── ABOUT ──────────────────────────────────────────────── */
#about{background:var(--white);border-top:1px solid var(--rule)}
.about-grid{display:grid;grid-template-columns:5fr 4fr;gap:80px;margin-top:48px;align-items:start}
.about-p{font-size:1rem;color:var(--mid);line-height:1.78;margin-bottom:18px}
.about-p strong{color:var(--ink);font-weight:500}
.about-p a{color:var(--green);border-bottom:1px solid rgba(42,94,69,.2);transition:border-color .2s}
.about-p a:hover{border-color:var(--green)}
.chip-block{margin-bottom:24px}
.chip-title{font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);padding-bottom:8px;border-bottom:1px solid var(--rule);margin-bottom:10px}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{font-size:.7rem;padding:4px 11px;border-radius:100px;border:1px solid var(--stone);color:var(--mid);cursor:default;transition:all .15s}
.chip:hover{border-color:var(--green-m);color:var(--green)}
.chip.hi{background:var(--green-l);border-color:var(--green-m);color:var(--green);font-weight:500}

/* ── WORK ───────────────────────────────────────────────── */
#work{background:var(--paper);border-top:1px solid var(--rule)}
.work-top{display:flex;align-items:flex-start;justify-content:space-between;gap:40px;margin-bottom:52px;flex-wrap:wrap}
.work-top-right{max-width:360px;margin-top:12px}
.work-top-right p{font-size:.9rem;color:var(--mid);line-height:1.7}

.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.proj-card{
  background:var(--white);border:1px solid var(--rule);border-radius:12px;
  padding:26px;display:flex;flex-direction:column;gap:12px;
  transition:border-color .2s,transform .22s,box-shadow .22s;
}
.proj-card:hover{border-color:var(--green-m);transform:translateY(-3px);box-shadow:0 10px 36px rgba(42,94,69,.08)}
.proj-bar{width:28px;height:3px;border-radius:2px;flex-shrink:0}
.proj-name{font-family:var(--fHead);font-size:1.08rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}
.proj-org{font-size:.68rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--soft)}
.proj-desc{font-size:.83rem;color:var(--mid);line-height:1.62;flex:1}
.proj-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto;padding-top:4px}
.ptag{font-size:.62rem;font-weight:500;padding:3px 9px;border-radius:100px}
.proj-links{display:flex;gap:10px;padding-top:8px}
.proj-link{color:var(--mid);transition:color .2s;position:relative}
.proj-link:hover{color:var(--ink)}
.proj-link::after{content:attr(title);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(4px);font-family:var(--fBody);font-size:.65rem;font-weight:500;color:var(--white);background:var(--ink);padding:3px 10px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s}
.proj-link:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
.proj-year{font-family:var(--fHead);font-size:1.3rem;font-weight:700;color:var(--mid);margin:48px 0 12px;letter-spacing:-.02em}

/* ── COLLAB ──────────────────────────────────────────────── */
#collab{background:var(--white);border-top:1px solid var(--rule)}
.collab-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;margin-top:48px}
.collab-card{background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:36px;margin-top:0}
.collab-card-tag{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:12px}
.collab-card h3{font-family:var(--fHead);font-size:1.5rem;font-weight:800;letter-spacing:-.02em;line-height:1.1;margin-bottom:14px}
.collab-card p{font-size:.88rem;color:var(--mid);line-height:1.68;margin-bottom:14px}
.collab-card p:last-of-type{margin-bottom:0}
.collab-logos{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}
.logo-pill{font-size:.67rem;font-weight:600;letter-spacing:.06em;padding:5px 12px;border-radius:6px;background:var(--stone);color:var(--mid)}

/* ── PUBLICATIONS ─────────────────────────────────────── */
#publications{background:var(--white);border-top:1px solid var(--rule)}
.pub-list{margin-top:48px;display:flex;flex-direction:column}
.pub-item{
  display:grid;grid-template-columns:180px 1fr;gap:32px;align-items:start;
  padding:24px 0;border-top:1px solid var(--rule);
  transition:background .2s;cursor:pointer;
  text-decoration:none;
}
.pub-item:last-child{border-bottom:1px solid var(--rule)}
.pub-item:hover .pub-title{color:var(--green)}
.pub-meta{display:flex;flex-direction:column;gap:5px;padding-top:3px}
.pub-year{font-family:var(--fHead);font-size:1rem;font-weight:700;color:var(--ink)}
.pub-venue{font-size:.68rem;font-weight:500;letter-spacing:.04em;color:var(--soft)}
.pub-title{font-size:.95rem;font-weight:500;color:var(--ink);line-height:1.45;margin-bottom:6px;transition:color .2s}
.pub-authors{font-size:.78rem;color:var(--soft)}

.cited-block{margin-top:52px;padding:28px 32px;background:var(--paper);border:1px solid var(--rule);border-radius:12px}
.cited-label{font-size:.67rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);margin-bottom:20px}
.cited-items{display:flex;flex-direction:column;gap:14px}
.cited-item{display:grid;grid-template-columns:180px 1fr;gap:24px;align-items:baseline}
.cited-venue{font-size:.7rem;font-weight:600;color:var(--green);letter-spacing:.03em}
.cited-title{font-size:.82rem;color:var(--mid);line-height:1.5}
.cited-title em{color:var(--soft);font-style:normal}

/* ── PRESS ───────────────────────────────────────────────── */
#press{background:var(--paper);border-top:1px solid var(--rule)}
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:12px;overflow:hidden;margin-top:48px}
.also-covered{margin-top:36px}
.also-covered-label{font-size:.67rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-bottom:16px}
.also-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:10px;overflow:hidden}
.also-item{background:var(--paper);padding:14px 18px;display:flex;align-items:baseline;justify-content:space-between;gap:16px;transition:background .2s;text-decoration:none}
.also-item:hover{background:var(--white)}
.also-outlet{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);flex-shrink:0;min-width:140px}
.also-title{font-size:.78rem;color:var(--mid);line-height:1.4;flex:1}
.also-arr{font-size:.7rem;color:var(--green);flex-shrink:0}
.pcard{background:var(--paper);padding:28px 24px;display:flex;flex-direction:column;gap:10px;transition:background .2s;cursor:pointer}
.pcard:hover{background:var(--white)}
.pcard-outlet{font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--green)}
.pcard-title{font-family:var(--fHead);font-size:.95rem;font-weight:700;line-height:1.3;color:var(--ink)}
.pcard-desc{font-size:.8rem;color:var(--mid);line-height:1.55;flex:1}
.pcard-link{font-size:.7rem;font-weight:500;color:var(--green);display:inline-flex;align-items:center;gap:4px;margin-top:auto;transition:gap .15s}
.pcard:hover .pcard-link{gap:7px}

/* ── SPEAKING ────────────────────────────────────────────── */
#speaking{background:var(--white);border-top:1px solid var(--rule)}
.talk-list{margin-top:48px;display:flex;flex-direction:column}
.talk-item{display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;padding:22px 0;border-top:1px solid var(--rule)}
.talk-item:last-child{border-bottom:1px solid var(--rule)}
.talk-year{font-family:var(--fHead);font-size:.8rem;font-weight:700;color:var(--soft);min-width:44px}
.talk-body{}
.talk-event{font-family:var(--fHead);font-size:1rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.talk-sub{font-size:.78rem;color:var(--mid);margin-top:3px}
.talk-badge{font-size:.62rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:100px;white-space:nowrap;align-self:flex-start}

/* ── WRITING ─────────────────────────────────────────────── */
#writing{background:var(--white);border-top:1px solid var(--rule)}
.writing-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:20px;flex-wrap:wrap}
.see-all{font-size:.78rem;font-weight:500;color:var(--mid);border-bottom:1px solid var(--rule);padding-bottom:2px;transition:all .2s}
.see-all:hover{color:var(--green);border-color:var(--green)}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.post-card{background:var(--white);border:1px solid var(--rule);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,transform .22s,box-shadow .22s}
.post-card:hover{border-color:var(--green-m);transform:translateY(-3px);box-shadow:0 10px 36px rgba(42,94,69,.08)}
.post-stripe{height:4px}
.post-body{padding:22px;display:flex;flex-direction:column;gap:9px;flex:1}
.post-cat{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.post-title{font-family:var(--fHead);font-size:1rem;font-weight:700;line-height:1.28;letter-spacing:-.01em}
.post-exc{font-size:.8rem;color:var(--mid);line-height:1.58;flex:1}
.post-foot{padding:13px 22px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center}
.post-meta{font-size:.67rem;color:var(--soft)}
.post-arr{font-size:.78rem;color:var(--green);font-weight:500}

/* ── CONTACT ──────────────────────────────────────────────── */
#contact{background:var(--white);border-top:1px solid var(--rule)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:48px;align-items:start}
.contact-left p{font-size:1rem;color:var(--mid);line-height:1.75;margin-top:20px;margin-bottom:28px}
.clinks{display:flex;flex-direction:column;gap:8px}
.clink{display:inline-flex;align-items:center;gap:10px;font-size:.82rem;color:var(--mid);padding:10px 16px;border-radius:8px;border:1px solid var(--stone);background:var(--white);transition:all .2s}
.clink:hover{border-color:var(--green-m);color:var(--green);background:var(--green-l)}
.clink svg{width:15px;height:15px;flex-shrink:0;opacity:.5}
.form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fld{display:flex;flex-direction:column;gap:5px}
.fld label{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}
.fld input,.fld textarea{font-family:var(--fBody);font-size:.88rem;font-weight:300;padding:11px 15px;border-radius:8px;border:1px solid var(--stone);background:var(--white);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;resize:none}
.fld input:focus,.fld textarea:focus{border-color:var(--green-m);box-shadow:0 0 0 3px rgba(42,94,69,.08)}
.fld textarea{height:120px;line-height:1.6}
.hp-field{position:absolute;left:-9999px;height:0;width:0;overflow:hidden;opacity:0;pointer-events:none}
.form-submit{align-self:flex-start;font-family:var(--fBody);font-size:.82rem;font-weight:500;padding:12px 28px;border-radius:100px;background:var(--green);color:var(--white);border:none;cursor:pointer;transition:background .2s}
.form-submit:hover{background:#1e4a35}
#contact h2{margin-bottom: 30px;}

/* ── FOOTER ───────────────────────────────────────────────── */
footer{background:var(--ink);color:rgba(255,255,255,.4);padding:0}
.ft-inner{max-width:1100px;margin:0 auto;padding:64px 44px 36px}

.ft-top{display:grid;grid-template-columns:1fr auto;gap:64px;align-items:start}

.ft-brand{display:flex;flex-direction:column;gap:14px}
.ft-logo{font-family:var(--fHead);font-size:1.1rem;font-weight:700;color:rgba(255,255,255,.7);letter-spacing:-.02em;transition:color .2s;display:flex;align-items:center;gap:8px}
.ft-logo:hover{color:#fff}
.ft-logo-img{height:28px;width:auto;display:block;filter:invert(1);opacity:.7}
.ft-tagline{font-size:.82rem;line-height:1.6;color:rgba(255,255,255,.22);max-width:280px}

.ft-cols{display:flex;gap:56px;flex-wrap:wrap}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.ft-col-title{font-size:.58rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.18);margin-bottom:14px}
.ft-col a{font-size:.78rem;color:rgba(255,255,255,.35);transition:color .2s}
.ft-col a:hover{color:var(--green-m)}

.ft-rule{height:1px;background:rgba(255,255,255,.06);margin:40px 0 24px}

.ft-bottom{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ft-copy{font-size:.68rem;color:rgba(255,255,255,.2)}
.ft-dot{font-size:.68rem;color:rgba(255,255,255,.1)}
.ft-note{font-size:.68rem;color:rgba(255,255,255,.5);}

/* ── ANIMATIONS ───────────────────────────────────────────── */
@keyframes fIn{from{opacity:0}to{opacity:1}}
@keyframes fUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.rev{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
.rev.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:960px){
  section{padding:72px 24px}
  nav{padding:0 24px}
  #hero{padding-left:24px;padding-right:24px}
  .about-grid,.collab-inner,.contact-grid{grid-template-columns:1fr;gap:48px}
  .proj-grid{grid-template-columns:1fr 1fr}
  .posts-grid{grid-template-columns:1fr 1fr}
  .press-grid{grid-template-columns:1fr 1fr}
  .hero-kpis{max-width:100%}
  .talk-item{grid-template-columns:auto 1fr}
  .talk-badge{display:none}
  .pub-item{grid-template-columns:100px 1fr;gap:20px}
  .cited-item{grid-template-columns:1fr;gap:4px}
  .also-list{grid-template-columns:1fr}
  .also-outlet{min-width:auto}
}
@media(max-width:600px){
  .nav-links{display:none}
  .proj-grid,.posts-grid{grid-template-columns:1fr}
  .press-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .kpi{min-width:50%;border-bottom:1px solid var(--rule)}
  .ft-inner{padding:40px 24px 28px}
  .ft-top{grid-template-columns:1fr;gap:36px}
  .ft-cols{gap:32px}
  .ft-tagline{max-width:100%}
  .pub-item{grid-template-columns:1fr;gap:6px}
  .pub-meta{flex-direction:row;gap:10px}
}

/* ── BLOG: LISTING ────────────────────────────────────────── */
.blog-hero{
  padding:calc(var(--nav-h) + 80px) 44px 0;
  background:var(--white);
}
.blog-hero-header{
  display:flex;flex-direction:column;gap:20px;
  padding-bottom:56px;border-bottom:1px solid var(--rule);
}
.blog-hero-label{
  display:flex;align-items:center;gap:12px;
  font-size:.65rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--soft);
}
.blog-hero-line{width:20px;height:2px;background:var(--green);flex-shrink:0}
.blog-hero-title{
  font-family:var(--fHead);
  font-size:clamp(2.8rem,5.5vw,5rem);
  font-weight:800;line-height:.94;letter-spacing:-.04em;
}
.blog-hero-title span{color:var(--soft);font-weight:700}

/* Featured post */
.blog-featured{
  display:grid;grid-template-columns:6px 1fr;gap:0;
  margin-top:56px;text-decoration:none;color:inherit;
  border-radius:16px;overflow:hidden;
  background:var(--paper);border:1px solid var(--rule);
  transition:border-color .3s,box-shadow .3s,transform .25s;
}
.blog-featured:hover{
  border-color:var(--green-m);
  box-shadow:0 16px 48px rgba(42,94,69,.07);
  transform:translateY(-2px);
}
.blog-featured-accent{border-radius:4px 0 0 4px;flex-shrink:0}
.blog-featured-content{padding:44px 48px}
.blog-featured-meta{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:.72rem;color:var(--soft);margin-bottom:20px;
}
.blog-featured-cat{
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;
}
.blog-featured-dot{opacity:.4}
.blog-featured-title{
  font-family:var(--fHead);
  font-size:clamp(1.6rem,3vw,2.4rem);
  font-weight:800;line-height:1.06;letter-spacing:-.03em;
  margin-bottom:16px;
  transition:color .2s;
}
.blog-featured:hover .blog-featured-title{color:var(--green)}
.blog-featured-excerpt{
  font-size:.95rem;color:var(--mid);line-height:1.72;
  max-width:640px;margin-bottom:24px;
}
.blog-featured-read{
  font-size:.78rem;font-weight:500;color:var(--green);
  display:inline-flex;align-items:center;gap:6px;
}
.blog-featured-arrow{transition:transform .2s}
.blog-featured:hover .blog-featured-arrow{transform:translateX(4px)}

/* Archive section */
.blog-archive{
  padding:0 44px 96px;background:var(--white);
}
.blog-archive-label{
  font-size:.6rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--soft);
  padding:48px 0 0;
}
.blog-archive-list{margin-top:16px}

.blog-entry{
  display:grid;grid-template-columns:140px 1fr auto;gap:32px;
  align-items:start;
  padding:32px 0;border-top:1px solid var(--rule);
  text-decoration:none;color:inherit;
  transition:background .15s;
}
.blog-entry:last-child{border-bottom:1px solid var(--rule)}

.blog-entry-left{display:flex;flex-direction:column;gap:4px;padding-top:4px}
.blog-entry-date{
  font-family:var(--fHead);font-size:.8rem;font-weight:600;
  color:var(--soft);letter-spacing:-.01em;
}
.blog-entry-time{font-size:.68rem;color:var(--stone)}

.blog-entry-body{display:flex;flex-direction:column;gap:8px}
.blog-entry-cat{
  display:flex;align-items:center;gap:7px;
  font-size:.6rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;
}
.blog-entry-pip{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.blog-entry-title{
  font-family:var(--fHead);font-size:1.22rem;font-weight:700;
  line-height:1.2;letter-spacing:-.02em;
  transition:color .2s;
}
.blog-entry:hover .blog-entry-title{color:var(--green)}
.blog-entry-excerpt{
  font-size:.84rem;color:var(--mid);line-height:1.6;
  max-width:560px;
}

.blog-entry-arrow{
  font-size:.82rem;color:var(--soft);
  padding-top:6px;
  transition:color .2s,transform .2s;
}
.blog-entry:hover .blog-entry-arrow{color:var(--green);transform:translateX(3px)}

@media(max-width:960px){
  .blog-hero{padding-left:24px;padding-right:24px}
  .blog-archive{padding-left:24px;padding-right:24px}
  .blog-featured-content{padding:28px 24px}
  .blog-entry{grid-template-columns:100px 1fr auto;gap:20px}
}
@media(max-width:600px){
  .blog-entry{grid-template-columns:1fr;gap:8px;padding:24px 0}
  .blog-entry-left{flex-direction:row;gap:10px;align-items:center}
  .blog-entry-arrow{display:none}
  .blog-featured{grid-template-columns:4px 1fr}
  .blog-featured-content{padding:22px 18px}
}

/* ── BLOG: SINGLE POST ────────────────────────────────────── */
.post-single{padding:0 44px 96px}
.post-back{display:inline-block;font-size:.78rem;color:var(--mid);margin-bottom:40px;transition:color .2s}
.post-back:hover{color:var(--green)}
.post-single-cat{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.post-single-title{font-family:var(--fHead);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;margin-bottom:18px}
.post-single-meta{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--soft);margin-bottom:48px;padding-bottom:28px;border-bottom:1px solid var(--rule)}
.print-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:1px solid var(--rule);border-radius:6px;padding:4px 12px;font-family:var(--fBody);font-size:.75rem;color:var(--mid);cursor:pointer;transition:color .2s,border-color .2s}
.print-btn:hover{color:var(--ink);border-color:var(--mid)}
.post-share{display:flex;gap:10px;flex-wrap:wrap;margin-top:48px;padding-top:24px;border-top:1px solid var(--rule)}
.share-btn{display:inline-flex;align-items:center;gap:5px;font-family:var(--fBody);font-size:.75rem;font-weight:500;color:var(--mid);padding:6px 14px;border:1px solid var(--rule);border-radius:6px;text-decoration:none;transition:color .2s,border-color .2s}
.share-btn:hover{color:var(--ink);border-color:var(--mid)}
.share-bsky:hover{color:#0085ff}
.share-linkedin:hover{color:#0a66c2}
.share-email:hover{color:var(--green)}
.print-header{display:none}
.print-references{display:none}
.print-ref-num{display:none}
.post-authors{font-weight:500;color:var(--ink)}
.post-content{font-size:1rem;color:var(--mid);line-height:1.82}
.post-content h2{font-size:1.4rem;color:var(--ink);margin:40px 0 16px;line-height:1.2}
.post-content h3{font-size:1.15rem;color:var(--ink);margin:32px 0 12px;line-height:1.25}
.post-content p{margin-bottom:18px}
.post-content a{color:var(--green);border-bottom:1px solid rgba(42,94,69,.2);transition:border-color .2s}
.post-content a:hover{border-color:var(--green)}
.post-content ul,.post-content ol{margin:0 0 18px 24px}
.post-content li{margin-bottom:6px}
.post-content blockquote{border-left:3px solid var(--green-m);padding:12px 20px;margin:24px 0;color:var(--mid);background:var(--paper);border-radius:0 8px 8px 0}
.post-content pre{background:var(--ink);color:var(--white);padding:20px 24px;border-radius:8px;overflow-x:auto;margin:24px 0;font-size:.85rem;line-height:1.6}
.post-content code{font-size:.88em;background:var(--stone);padding:2px 6px;border-radius:4px}
.post-content pre code{background:none;padding:0;border-radius:0}
/* Post images — editorial breakout */
.post-content figure{
  margin:40px -60px;
  position:relative;
}
.post-content figure img{
  display:block;width:100%;height:auto;
  border-radius:10px;
  border:1px solid var(--rule);
  box-shadow:0 8px 40px rgba(26,23,16,.06), 0 1px 3px rgba(26,23,16,.04);
}
.post-content figure figcaption{
  margin-top:12px;padding:0 60px;
  font-size:.75rem;color:var(--soft);line-height:1.55;
  letter-spacing:.01em;
  text-align:center;
}
.post-content figure figcaption::before{
  content:'';display:block;width:16px;height:1.5px;
  background:var(--green-m);margin:0 auto 8px;border-radius:1px;
}
/* Fallback for bare img (no figure wrapper) */
.post-content img{max-width:100%;height:auto;border-radius:10px;margin:32px 0;border:1px solid var(--rule);box-shadow:0 8px 40px rgba(26,23,16,.06), 0 1px 3px rgba(26,23,16,.04)}
.post-content hr{border:none;height:1px;background:var(--rule);margin:40px 0}
.post-content strong{color:var(--ink);font-weight:500}

/* Blog card as link */
a.post-card{text-decoration:none;color:inherit}

/* ── 404 ──────────────────────────────────────────────── */
.e404{min-height:100svh;display:flex;align-items:center;padding:calc(var(--nav-h) + 48px) 44px 72px}
.e404-inner{max-width:640px}
.e404-badge{font-family:var(--fBody);font-size:.68rem;font-weight:600;letter-spacing:.12em;color:var(--terra);text-transform:uppercase;margin-bottom:16px}
.e404-title{font-family:var(--fHead);font-size:clamp(2rem,5vw,3.2rem);font-weight:800;color:var(--ink);line-height:1.1;margin-bottom:32px}
.e404-terminal{background:var(--ink);color:rgba(255,255,255,.7);font-family:'DM Sans',monospace;font-size:.78rem;line-height:1.8;padding:24px 28px;border-radius:10px;margin-bottom:28px;overflow:hidden}
.e404-line{opacity:0;animation:e404in .3s forwards}
.e404-prompt{color:var(--green);font-weight:600}
.e404-cmd{color:#fff}
.e404-muted{color:rgba(255,255,255,.35)}
.e404-err{color:var(--terra);font-weight:500}
.e404-suggest{color:rgba(255,255,255,.5)}
.e404-delay1{animation-delay:.8s}
.e404-delay2{animation-delay:1.6s}
.e404-delay3{animation-delay:2.4s}
.e404-delay4{animation-delay:3.4s}
.e404-delay5{animation-delay:4.2s}
@keyframes e404in{to{opacity:1}}
.e404-cmd::after{content:'';display:inline-block;width:8px;height:1.1em;background:var(--green);vertical-align:text-bottom;margin-left:2px;animation:e404blink 1s step-end infinite}
@keyframes e404blink{50%{opacity:0}}
.e404-note{font-size:.85rem;color:var(--mid);margin-bottom:28px;font-style:italic}
.e404-actions{display:flex;gap:12px;flex-wrap:wrap}
.e404-btn{font-family:var(--fBody);font-size:.82rem;font-weight:500;padding:10px 24px;border-radius:100px;background:var(--ink);color:var(--white);text-decoration:none;transition:background .2s}
.e404-btn:hover{background:#2e2b22}
.e404-btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule)}
.e404-btn-ghost:hover{background:var(--stone);border-color:var(--mid)}

@media(max-width:960px){
  .post-single{padding:0 24px 72px}
  .post-content figure{margin-left:0;margin-right:0}
  .post-content figure figcaption{padding:0}
}

/* ── PRINT ──────────────────────────────────────────────── */
@media print{
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  body{background:#fff;color:#000;font-size:11pt;line-height:1.7}
  nav,.mob-menu,.print-btn,.print-only-hide,.post-back,footer,.post-reading-time{display:none!important}
  .print-header{display:flex!important;align-items:center;gap:8px;font-family:var(--fHead);font-size:14pt;font-weight:700;color:#000;margin-bottom:24px}
  .print-header-logo{height:28px;width:auto}
  .post-single{padding:0!important}
  .post-single .si{max-width:100%}
  .print-cover{display:flex;flex-direction:column;justify-content:center;min-height:100vh;box-sizing:border-box;break-after:page}
  .print-cover .print-header{margin-bottom:auto}
  .print-cover .post-single-meta{margin-bottom:auto}
  .post-single-title{font-size:22pt;color:#000;margin-bottom:8px}
  .post-single-cat{color:#555!important}
  .post-single-meta{border-bottom:none;padding-bottom:0;margin-bottom:24px;color:#555}
  .post-content{color:#222;font-size:11pt}
  .post-content h2{color:#000;font-size:14pt;margin:28px 0 10px;page-break-after:avoid;break-after:avoid;page-break-inside:avoid;break-inside:avoid}
  .post-content h3{color:#000;font-size:12pt;page-break-after:avoid;break-after:avoid;page-break-inside:avoid;break-inside:avoid}
  .post-content p{orphans:3;widows:3}
  .post-content img{max-width:100%;page-break-inside:avoid}
  .post-content pre{border:1px solid #ccc;padding:12px;font-size:9pt;white-space:pre-wrap;word-wrap:break-word;page-break-inside:avoid}
  .post-content a{color:#000;text-decoration:underline}
  .post-content a::after{content:none}
  .print-ref-num{font-size:8pt;color:#555;margin-left:1px}
  .print-references{display:block!important;margin-top:32px}
  .print-ref-num{display:inline!important}
  .print-refs-title{font-family:var(--fHead);font-size:12pt;font-weight:700;color:#000;margin-bottom:8px;padding-top:16px;border-top:1px solid #ccc}
  .print-refs-list{font-size:8pt;color:#555;padding-left:20px;line-height:1.6}
  .print-refs-list li{word-break:break-all}
  @page{
    margin:0;
    @top-left{content:none}
    @top-center{content:none}
    @top-right{content:none}
    @bottom-left{content:none}
    @bottom-center{content:none}
    @bottom-right{content:none}
  }
  .post-single .si{padding:1.5cm 2cm}
}
