:root{
  --bg:#f5f2ec;
  --paper:#fbfaf6;
  --ink:#161513;
  --ink-2:#3a3833;
  --muted:#7a766d;
  --rule:#1614121a;
  --accent:#f0b800;
  --accent-ink:#161513;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Inter",system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.55;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:var(--accent-ink)}

.display{font-family:"Fraunces",serif;font-weight:900;letter-spacing:-0.02em;line-height:0.95}
.serif{font-family:"Fraunces",serif}
.mono-label{
  font-family:"Inter",sans-serif;
  font-weight:600;font-size:11px;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--muted);
}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}

/* HEADER + NAV (shared across pages) */
header.site{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--rule);
}
header.site .row{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.logo{display:flex;align-items:center;gap:10px}
.logo svg{display:block}
.logo .word{font-family:"Fraunces",serif;font-weight:900;font-size:22px;letter-spacing:-0.02em;color:var(--ink);line-height:1}
.logo .word .dot{color:var(--accent)}
.logo .sub{font-family:"Inter",sans-serif;font-weight:600;font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:3px;display:block}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:13px;font-weight:500;color:var(--ink-2);transition:color .2s ease;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-22px;height:2px;background:var(--accent);
}
.nav-cta{
  border:1px solid var(--ink);padding:9px 16px;border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.04em;
  transition:all .2s ease;
}
.nav-cta:hover{background:var(--ink);color:var(--paper)}
.nav-cta.active::after{display:none}
@media (max-width:780px){
  .nav-links a:not(.nav-cta){display:none}
  .logo .sub{display:none}
}

/* HERO */
.hero{position:relative;padding:64px 0 0;overflow:hidden}
.hero .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:end}
.hero h1{font-size:clamp(64px,11vw,168px);margin:0}
.hero h1 .ital{font-style:italic;font-weight:500}
.hero .lede{margin-top:24px;font-size:19px;line-height:1.5;color:var(--ink-2);max-width:48ch}
.hero .meta{display:flex;gap:24px;flex-wrap:wrap;align-items:center;margin-top:36px;padding-top:20px;border-top:1px solid var(--rule)}
.hero .meta .pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;background:var(--ink);color:var(--paper);
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
}
.hero .meta .pill .live{
  width:6px;height:6px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px color-mix(in oklab, var(--accent) 45%, transparent);
  animation:pulse 1.8s infinite;
}
@keyframes pulse{50%{box-shadow:0 0 0 8px transparent}}
.hero .meta .item{font-size:13px;color:var(--muted)}
.hero .meta .item b{color:var(--ink);font-weight:600;font-family:"Fraunces",serif;font-size:15px}
.hero-photo{position:relative;aspect-ratio:4/5;border-radius:6px;overflow:hidden;background:#0f0e0c}
.hero-photo > img{width:100%;height:100%;object-fit:cover;filter:saturate(0.92) contrast(1.05)}
.hero-photo .portrait{
  position:absolute;left:14px;top:14px;
  display:flex;align-items:center;gap:10px;
  background:color-mix(in oklab, var(--paper) 90%, transparent);
  backdrop-filter:blur(8px);
  border-radius:999px;padding:6px 14px 6px 6px;border:1px solid var(--rule);
}
.hero-photo .portrait img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--accent)}
.hero-photo .portrait-meta{display:flex;flex-direction:column;line-height:1.1}
.hero-photo .portrait-meta b{font-family:"Fraunces",serif;font-size:14px;letter-spacing:-0.01em;color:var(--ink)}
.hero-photo .portrait-meta span{font-size:11px;color:var(--muted);font-weight:500}
.hero-photo .tag{
  position:absolute;left:14px;bottom:14px;background:var(--accent);color:var(--accent-ink);
  font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:8px 12px;border-radius:3px;
}
@media (max-width:880px){
  .hero .grid{grid-template-columns:1fr;gap:32px}
  .hero-photo{aspect-ratio:5/4}
}

/* STAT STRIPE */
.stripe{margin-top:80px;background:var(--ink);color:var(--paper);border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.stripe .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:#2a2825}
.stripe .cell{background:var(--ink);padding:32px 24px}
.stripe .num{font-family:"Fraunces",serif;font-weight:900;font-size:54px;letter-spacing:-0.03em;line-height:1}
.stripe .lbl{margin-top:8px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#a8a49a}
@media (max-width:780px){.stripe .wrap{grid-template-columns:repeat(2,1fr)}}

/* SECTION SHELL */
section{padding:96px 0}
.page-head{padding:72px 0 24px;border-bottom:1px solid var(--rule)}
.page-head h1{font-size:clamp(56px,9vw,128px);margin:8px 0 0;letter-spacing:-0.025em;line-height:.95}
.page-head .crumbs{font-size:12px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.page-head .crumbs span{color:var(--ink)}
.section-head{display:grid;grid-template-columns:160px 1fr;gap:32px;align-items:start;margin-bottom:48px}
.section-head h2{font-size:clamp(38px,5.5vw,68px);margin:0;max-width:18ch}
.section-head .kicker{padding-top:8px}
@media (max-width:780px){.section-head{grid-template-columns:1fr;gap:12px}}

/* ABOUT */
.about{background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.about .body{display:grid;grid-template-columns:1.2fr 1fr;gap:64px}
.about p{font-size:18px;line-height:1.65;color:var(--ink-2);margin:0 0 18px}
.about .lead{font-size:24px;font-family:"Fraunces",serif;font-weight:500;color:var(--ink);line-height:1.35;margin-bottom:24px}
.about-card{border:1px solid var(--rule);border-radius:6px;padding:28px;background:var(--bg)}
.about-card h3{font-family:"Fraunces",serif;font-weight:700;font-size:22px;margin:0 0 4px;letter-spacing:-0.01em}
.about-card .role{color:var(--muted);font-size:13px}
.about-card .card-head{display:flex;align-items:center;gap:14px;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--rule)}
.about-card .avatar{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid var(--accent)}
.about-card ul{list-style:none;padding:0;margin:0}
.about-card li{display:flex;justify-content:space-between;gap:18px;padding:14px 0;border-top:1px dashed var(--rule);font-size:14px}
.about-card li:first-child{border-top:0;padding-top:0}
.about-card li span:first-child{color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.14em;font-weight:600}
.about-card li span:last-child{font-weight:600}
@media (max-width:880px){.about .body{grid-template-columns:1fr;gap:32px}}

/* WRITING / BLOG GRID */
.writing .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:32px}
.post{
  grid-column:span 4;display:flex;flex-direction:column;gap:14px;
  border-top:1px solid var(--ink);padding-top:18px;transition:transform .3s ease;
}
.post:hover{transform:translateY(-3px)}
.post .img{aspect-ratio:4/3;overflow:hidden;border-radius:4px;background:#0f0e0c}
.post .img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.post:hover .img img{transform:scale(1.04)}
.post .meta-row{display:flex;justify-content:space-between;align-items:center;gap:10px}
.post .cat{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.post .date{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}
.post h3{font-family:"Fraunces",serif;font-weight:700;letter-spacing:-0.01em;font-size:26px;line-height:1.15;margin:0}
.post p{margin:0;color:var(--ink-2);font-size:15px;line-height:1.55}
.post .read{margin-top:6px;font-size:12px;font-weight:600;letter-spacing:.05em;border-bottom:1.5px solid var(--ink);align-self:flex-start;padding-bottom:2px}
.post.feature{grid-column:span 8;flex-direction:row;align-items:stretch;gap:32px}
.post.feature .img{flex:1.1;aspect-ratio:auto}
.post.feature .body{flex:1;display:flex;flex-direction:column;gap:14px;justify-content:center}
.post.feature h3{font-size:42px;line-height:1.05}
.post.feature p{font-size:17px}
.post.feature .img img{aspect-ratio:4/4}
.post.alt{grid-column:span 4}
@media (max-width:980px){
  .post,.post.feature,.post.alt{grid-column:span 12}
  .post.feature{flex-direction:column}
}

/* TABLE OF CONTENTS — writing page */
.with-toc{display:grid;grid-template-columns:260px 1fr;gap:64px;align-items:start}
.toc{
  position:sticky;top:88px;
  border-top:1px solid var(--ink);padding-top:18px;
}
.toc .toc-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:18px}
.toc ol{list-style:none;padding:0;margin:0;counter-reset:toc}
.toc li{counter-increment:toc;padding:0;border-bottom:1px dashed var(--rule)}
.toc li a{
  display:flex;gap:14px;align-items:baseline;
  padding:13px 0;
  font-size:14px;color:var(--ink-2);
  transition:color .2s ease, padding-left .25s ease;
  line-height:1.35;
}
.toc li a::before{
  content:"0" counter(toc);font-variant-numeric:tabular-nums;
  font-family:"Fraunces",serif;font-weight:600;color:var(--muted);font-size:12px;
  flex-shrink:0;
}
.toc li a:hover{color:var(--ink);padding-left:6px}
.toc li.active a{color:var(--ink);padding-left:8px;font-weight:600}
.toc li.active a::before{color:var(--accent)}
.toc li.active{border-bottom-color:var(--ink)}
.toc .progress{
  margin-top:20px;height:3px;background:var(--rule);border-radius:2px;overflow:hidden;
}
.toc .progress span{display:block;height:100%;width:0;background:var(--accent);transition:width .15s linear}
@media (max-width:880px){
  .with-toc{grid-template-columns:1fr;gap:32px}
  .toc{position:relative;top:0}
}

/* ARTICLE BODY (writing page) */
article.entry{padding:48px 0 0;border-top:1px solid var(--rule)}
article.entry:first-of-type{border-top:0;padding-top:0}
article.entry .meta-row{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:18px}
article.entry h2{
  font-family:"Fraunces",serif;font-weight:900;letter-spacing:-0.02em;
  font-size:clamp(34px,4.5vw,56px);line-height:1.05;margin:0 0 24px;
  scroll-margin-top:96px;
}
article.entry .cover{aspect-ratio:16/9;overflow:hidden;border-radius:4px;margin:0 0 28px}
article.entry .cover img{width:100%;height:100%;object-fit:cover}
article.entry p{font-size:17px;line-height:1.7;color:var(--ink-2);margin:0 0 18px;max-width:62ch}
article.entry p.lead{font-family:"Fraunces",serif;font-weight:500;font-size:22px;color:var(--ink);line-height:1.4}
article.entry blockquote{
  margin:28px 0;padding:0 0 0 24px;border-left:3px solid var(--accent);
  font-family:"Fraunces",serif;font-style:italic;font-weight:500;
  font-size:22px;color:var(--ink);line-height:1.4;max-width:54ch;
}

/* WHAT WE BUILD */
.build{background:var(--ink);color:var(--paper)}
.build .section-head h2{color:var(--paper)}
.build .section-head .kicker{color:#a8a49a}
.build .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid #2a2825}
.build .item{padding:36px 28px;border-right:1px solid #2a2825;display:flex;flex-direction:column;gap:18px;min-height:340px;position:relative;overflow:hidden;transition:background .3s ease}
.build .item:last-child{border-right:0}
.build .item:hover{background:#1c1a18}
.build .item .num{font-family:"Fraunces",serif;font-weight:500;font-style:italic;font-size:14px;color:var(--accent)}
.build .item h4{font-family:"Fraunces",serif;font-weight:700;letter-spacing:-0.01em;font-size:32px;margin:0}
.build .item p{margin:0;color:#c9c5bc;font-size:14px;line-height:1.55;max-width:34ch}
.build .item .arrow{margin-top:auto;align-self:flex-start;font-size:20px;color:var(--accent)}
@media (max-width:880px){.build .grid{grid-template-columns:1fr}.build .item{border-right:0;border-bottom:1px solid #2a2825}}

/* QUOTE */
.quote{padding:120px 0}
.quote blockquote{margin:0;font-family:"Fraunces",serif;font-weight:500;font-style:italic;font-size:clamp(28px,4vw,52px);line-height:1.2;letter-spacing:-0.015em;max-width:22ch}
.quote .who{margin-top:32px;display:flex;gap:14px;align-items:center;font-size:13px;color:var(--muted)}
.quote .who::before{content:"";display:inline-block;width:48px;height:1px;background:var(--ink)}

/* CONTACT */
.contact{background:var(--paper);border-top:1px solid var(--rule)}
.contact .body{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end}
.contact h2{font-size:clamp(48px,7vw,96px);margin:0;line-height:.95}
.contact .channels{display:flex;flex-direction:column;gap:14px}
.contact .channel{display:flex;justify-content:space-between;align-items:center;padding:18px 0;border-top:1px solid var(--ink);font-size:15px}
.contact .channel:last-child{border-bottom:1px solid var(--ink)}
.contact .channel b{font-family:"Fraunces",serif;font-weight:700;font-size:18px;letter-spacing:-0.01em}
.contact .channel span{font-size:13px;color:var(--muted)}
.contact .channel .arrow{font-weight:600}
@media (max-width:880px){.contact .body{grid-template-columns:1fr}}

/* FOOTER */
footer.site{background:var(--ink);color:#c9c5bc;padding:48px 0 28px}
footer.site .row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;align-items:center}
footer.site .copy{font-size:12px;color:#7a766d}
footer.site .copy b{color:var(--paper);font-family:"Fraunces",serif;font-weight:700}
footer.site a{color:#c9c5bc;font-size:12px;letter-spacing:.04em}
footer.site a:hover{color:var(--accent)}
footer.site .foot-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;
  padding:0 0 32px;border-bottom:1px solid #2a2825;margin-bottom:24px;
}
footer.site .foot-grid h5{font-family:"Fraunces",serif;font-weight:700;color:var(--paper);font-size:14px;margin:0 0 12px;letter-spacing:-0.005em}
footer.site .foot-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
footer.site .foot-grid p{font-size:13px;color:#a8a49a;margin:0;line-height:1.55;max-width:34ch}
footer.site .foot-grid .foot-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
footer.site .foot-grid .foot-logo .word{font-family:"Fraunces",serif;font-weight:900;font-size:20px;color:var(--paper)}
@media (max-width:780px){footer.site .foot-grid{grid-template-columns:1fr 1fr}}

/* reveal */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}
