:root{
  --bg:#0c0d10; --panel:#141619; --panel2:#1a1d22; --ink:#f2f0ec;
  --sub:#8b8d93; --line:#23262b; --accent:#e8623a; --accent2:#5ad1c4;
  --purple:#c08be8; --amber:#e8b85a;
}
*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100% }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:'Space Grotesk',sans-serif; font-weight:300;
  -webkit-font-smoothing:antialiased;
}
.display{font-family:'Clash Display','Space Grotesk',sans-serif}
.mono{font-family:'JetBrains Mono',monospace}
a{color:var(--accent2); text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%; display:block}

.container{max-width:1040px; margin:0 auto; padding:0 28px}

.grain{position:fixed; inset:0; pointer-events:none; opacity:.025; z-index:1;
  background-image:radial-gradient(var(--ink) 1px, transparent 1px); background-size:3px 3px}

/* ---------- Header ---------- */
.site-header{position:sticky; top:0; z-index:10; border-bottom:1px solid var(--line);
  background:rgba(12,13,16,.92); backdrop-filter:blur(10px)}
.header-inner{display:flex; justify-content:space-between; align-items:center; padding:18px 28px; gap:12px}
.brand{font-family:'Clash Display',sans-serif; font-size:22px; font-weight:600; color:var(--ink); letter-spacing:-.01em}
.brand span{color:var(--accent)}
.brand:hover{text-decoration:none}
.site-nav{display:flex; gap:24px; flex-wrap:wrap}
.site-nav a{font-size:14px; color:var(--sub); padding:6px 0; position:relative}
.site-nav a:hover{color:var(--ink); text-decoration:none}
.site-nav a.active{color:var(--ink)}
.site-nav a.active::after{content:''; position:absolute; bottom:-4px; left:0; right:0; height:2px; background:var(--accent)}
.nav-toggle{display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px}
.nav-toggle span{width:22px; height:2px; background:var(--ink); transition:.2s}

/* ---------- Shared bits ---------- */
.kicker{color:var(--accent); font-size:12px; letter-spacing:.2em; text-transform:uppercase}
.section-title{margin:60px 0 30px}
.section-title .mono{color:var(--accent); font-size:12px; letter-spacing:.2em; text-transform:uppercase; margin-bottom:12px}
.section-title h1{font-size:46px; margin:0; font-weight:600; line-height:1; letter-spacing:-.02em}
.section-title .sub{color:var(--sub); font-size:17px; margin-top:14px; max-width:600px}

.btn{display:inline-block; border-radius:999px; padding:13px 26px; font-size:15px; cursor:pointer; font-family:'Space Grotesk',sans-serif}
.btn-primary{background:var(--accent); color:#1a0d08; border:none; font-weight:500}
.btn-primary:hover{text-decoration:none}
.btn-ghost{background:none; color:var(--ink); border:1px solid var(--line)}
.btn-ghost:hover{text-decoration:none; border-color:var(--sub)}

.card{background:var(--panel); border:1px solid var(--line); border-radius:14px; overflow:hidden; transition:transform .25s, border-color .25s, box-shadow .25s}
a.card:hover, .card-link:hover .card{transform:translateY(-4px); border-color:rgba(232,98,58,.4); box-shadow:0 16px 40px rgba(0,0,0,.5); text-decoration:none}
.card-thumb{height:160px; background-size:cover; background-position:center}
.card-body{padding:24px}
.card-cat{font-size:11px; color:var(--accent); text-transform:uppercase; letter-spacing:.12em; margin-bottom:10px; display:flex; justify-content:space-between}
.card h3{font-size:22px; margin:0 0 12px; line-height:1.18; font-weight:500}
.card p{font-size:15px; line-height:1.6; color:var(--sub); margin:0}
.card .date{font-size:12px; color:var(--sub); margin-top:16px}

.social-row{display:flex; gap:12px; flex-wrap:wrap}
.social-ic{display:inline-flex; align-items:center; justify-content:center; height:40px; padding:0 14px; border-radius:10px;
  border:1px solid var(--line); background:var(--panel); color:var(--sub); font-size:12px; font-family:'JetBrains Mono',monospace;
  transition:color .2s, border-color .2s, transform .2s}
.social-ic:hover{color:var(--ink); border-color:var(--accent); transform:translateY(-2px); text-decoration:none}

/* ---------- Home ---------- */
.hero{padding:72px 0 48px; display:grid; grid-template-columns:1.5fr 1fr; gap:50; align-items:center}
.hero{gap:50px}
.availability{display:inline-flex; align-items:center; gap:9px; border:1px solid var(--line); background:var(--panel); border-radius:999px; padding:6px 14px; margin-bottom:24px}
.availability .dot{width:7px; height:7px; border-radius:50%; background:var(--accent2); box-shadow:0 0 0 3px rgba(90,209,196,.13)}
.availability span{font-size:11px; color:var(--sub); letter-spacing:.08em; font-family:'JetBrains Mono',monospace}
.hero h1{font-size:58px; line-height:.98; margin:0 0 22px; font-weight:600; letter-spacing:-.03em}
.hero .lead{font-size:19px; line-height:1.6; color:var(--sub); max-width:520px}
.hero-actions{margin-top:30px; display:flex; gap:14px; align-items:center; flex-wrap:wrap}
.hero-actions .divider{width:1px; height:28px; background:var(--line); margin:0 2px}
.portrait{aspect-ratio:4/5; border-radius:16px; background:linear-gradient(150deg,#1a1c20,#0c0d10); border:1px solid var(--line);
  display:flex; align-items:flex-end; padding:22px; position:relative; overflow:hidden}
.portrait .glow{position:absolute; top:-40px; right:-40px; width:160px; height:160px; border-radius:50%; background:rgba(232,98,58,.13); filter:blur(40px)}
.portrait .mono{color:var(--sub); font-size:12px}
.portrait img{width:100%; height:100%; object-fit:cover; border-radius:16px}

.metrics{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.metric{border:1px solid var(--line); border-radius:14px; padding:22px 24px; background:var(--panel)}
.metric .k{color:var(--accent); font-size:11px; letter-spacing:.15em; text-transform:uppercase; margin-bottom:8px; font-family:'JetBrains Mono',monospace}
.metric .v{font-family:'Clash Display',sans-serif; font-size:18px; font-weight:500}

.focus-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.focus{border:1px solid var(--line); border-radius:14px; padding:26px 24px; background:var(--panel); position:relative; overflow:hidden}
.focus .bar{position:absolute; top:0; left:0; width:40px; height:3px}
.focus h3{font-size:20px; margin:8px 0 10px; font-weight:500; font-family:'Clash Display',sans-serif}
.focus p{color:var(--sub); font-size:15px; line-height:1.6; margin:0}

.feature{display:grid; grid-template-columns:1.1fr 1fr; border-radius:16px; overflow:hidden; background:var(--panel); border:1px solid var(--line); margin-bottom:20px}
.feature .feature-img{min-height:240px; background-size:cover; background-position:center}
.feature .feature-body{padding:32px; display:flex; flex-direction:column; justify-content:center}
.feature h2{font-size:27px; margin:0 0 12px; line-height:1.12; font-weight:600; font-family:'Clash Display',sans-serif; letter-spacing:-.01em}
.feature p{font-size:15px; line-height:1.6; color:var(--sub); margin:0}

.grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:20px}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}

.contact-band{margin-top:72px; border:1px solid var(--line); border-radius:18px; padding:44px 40px;
  background:linear-gradient(135deg,#16181c,#101115); position:relative; overflow:hidden}
.contact-band .glow{position:absolute; bottom:-60px; right:-40px; width:220px; height:220px; border-radius:50%; background:rgba(232,98,58,.1); filter:blur(50px)}
.contact-inner{position:relative; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:24px}
.contact-band h2{font-size:30px; margin:0 0 8px; font-weight:600; font-family:'Clash Display',sans-serif; letter-spacing:-.02em}
.contact-band p{color:var(--sub); font-size:16px; margin:0; max-width:460px}
.contact-actions{display:flex; flex-direction:column; gap:16px; align-items:flex-start}
.email-btn{border:1px solid var(--accent); color:var(--accent); border-radius:999px; padding:12px 24px; font-size:14px; font-family:'JetBrains Mono',monospace}
.email-btn:hover{background:var(--accent); color:#1a0d08; text-decoration:none}

/* ---------- Biography ---------- */
.bio-grid{display:grid; grid-template-columns:1.4fr 1fr; gap:44px; align-items:start}
.prose{font-size:18px; line-height:1.85; color:#cfd0d2}
.prose p:first-child{margin-top:0}
.facts-label{margin:56px 0 22px}
.facts-label .mono{color:var(--accent2); font-size:12px; letter-spacing:.2em; text-transform:uppercase}
.facts-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.fact{border:1px solid var(--line); border-radius:14px; padding:20px 22px; background:var(--panel); display:flex; gap:16px; align-items:center; transition:transform .2s, border-color .2s, background .2s}
.fact:hover{transform:translateY(-3px); border-color:rgba(90,209,196,.33); background:var(--panel2)}
.fact .ic{font-size:24px; line-height:1}
.fact .label{color:var(--sub); font-size:11px; letter-spacing:.1em; text-transform:uppercase; margin-bottom:4px; font-family:'JetBrains Mono',monospace}
.fact .value{font-family:'Clash Display',sans-serif; font-size:17px; font-weight:500}

/* ---------- Experience ---------- */
.exp-intro{font-size:18px; line-height:1.8; color:#cfd0d2; max-width:680px; margin-top:-10px}
.exp-filters{display:flex; gap:8px; flex-wrap:wrap; margin:32px 0 30px}
.chip{cursor:pointer; border:1px solid var(--line); background:var(--panel); padding:6px 15px; border-radius:999px;
  font-size:12px; font-family:'JetBrains Mono',monospace; color:var(--sub); letter-spacing:.02em; transition:all .2s}
.chip:hover{color:var(--ink); border-color:var(--sub); text-decoration:none}
.chip.on{background:var(--accent); color:#1a0d08; border-color:var(--accent)}
.timeline{position:relative; padding-left:8px}
.timeline .spine{position:absolute; left:7px; top:8px; bottom:8px; width:2px; background:linear-gradient(var(--accent), var(--line))}
.tl-item{display:grid; grid-template-columns:32px 1fr; gap:20px; margin-bottom:18px}
.tl-dot-wrap{display:flex; justify-content:center; padding-top:26px}
.tl-dot{width:14px; height:14px; border-radius:50%; border:3px solid var(--bg); z-index:2}
.tl-card{border:1px solid var(--line); border-radius:14px; padding:22px 24px; background:var(--panel); transition:border-color .25s, transform .25s}
.tl-item:hover .tl-card{border-color:rgba(232,98,58,.33); transform:translateX(4px)}
.tl-head{display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; flex-wrap:wrap; gap:8px}
.tl-meta{display:flex; align-items:center; gap:12px}
.tag-kind{font-size:10px; border-radius:999px; padding:3px 10px; letter-spacing:.08em; text-transform:uppercase; font-family:'JetBrains Mono',monospace}
.tag-current{font-size:10px; color:var(--accent2); border:1px solid rgba(90,209,196,.27); border-radius:999px; padding:3px 10px; letter-spacing:.1em; text-transform:uppercase; font-family:'JetBrains Mono',monospace}
.tl-card h3{font-size:22px; margin:0 0 3px; font-weight:500; font-family:'Clash Display',sans-serif}
.tl-card .org{font-size:15px; margin-bottom:10px}
.tl-card .note{color:var(--sub); font-size:15px; line-height:1.6; margin:0}
.tl-period{color:var(--sub); font-size:13px; font-family:'JetBrains Mono',monospace}

/* ---------- Blog ---------- */
.blog-controls{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; margin-bottom:30px}
.search-form input{border:1px solid var(--line); border-radius:999px; padding:10px 18px; font-size:14px; background:var(--panel); color:var(--ink); min-width:210px; outline:none; font-family:'Space Grotesk',sans-serif}
.search-form input::placeholder{color:var(--sub)}
.blog-feature{display:grid; grid-template-columns:1.1fr 1fr; border-radius:16px; overflow:hidden; background:var(--panel); border:1px solid var(--line); margin-bottom:24px}
.blog-feature .img{min-height:280px; background-size:cover; background-position:center}
.blog-feature .body{padding:34px; display:flex; flex-direction:column; justify-content:center}
.blog-feature h2{font-size:30px; margin:0 0 14px; line-height:1.1; font-weight:600; font-family:'Clash Display',sans-serif; letter-spacing:-.02em}
.blog-feature p{font-size:16px; line-height:1.6; color:var(--sub); margin:0}
.empty{color:var(--sub); font-family:'JetBrains Mono',monospace}

/* ---------- Post ---------- */
.post-wrap{max-width:720px; margin:0 auto}
.back-link{color:var(--accent2); font-size:13px; font-family:'JetBrains Mono',monospace; display:inline-block; margin-top:44px}
.post-meta{color:var(--accent); font-size:12px; letter-spacing:.12em; text-transform:uppercase; margin:22px 0 12px; font-family:'JetBrains Mono',monospace}
.post-wrap h1{font-size:42px; line-height:1.05; margin:0 0 20px; font-weight:600; font-family:'Clash Display',sans-serif; letter-spacing:-.02em}
.post-hero{height:300px; background-size:cover; background-position:center; border-radius:16px; margin:26px 0}
.post-body{font-size:19px; line-height:1.85; color:#cfd0d2}
.post-body h2,.post-body h3,.post-body h4{font-family:'Clash Display',sans-serif; color:var(--ink); font-weight:500; margin-top:1.6em}

/* ---------- Press ---------- */
.press-lead{position:relative; border-radius:18px; overflow:hidden; border:1px solid var(--line); margin-bottom:22px; min-height:320px;
  background-size:cover; background-position:center; display:flex; align-items:flex-end}
.press-lead .wash{position:absolute; inset:0; background:linear-gradient(to top, rgba(7,8,10,.92) 0%, rgba(7,8,10,.4) 55%, transparent 100%)}
.press-lead .lead-body{position:relative; padding:36px; max-width:640px}
.press-lead h2{font-size:34px; margin:12px 0 10px; line-height:1.08; font-weight:600; font-family:'Clash Display',sans-serif; letter-spacing:-.02em}
.press-lead .src{color:#c9cbcf; font-size:13px; font-family:'JetBrains Mono',monospace}
.play{display:flex; align-items:center; justify-content:center; border-radius:50%; background:rgba(255,255,255,.92); color:var(--bg)}
.play-lead{position:absolute; top:42%; left:50%; transform:translate(-50%,-50%); width:64px; height:64px; font-size:22px}
.press-thumb{height:150px; background-size:cover; background-position:center; display:flex; align-items:center; justify-content:center; position:relative}
.type-badge{position:absolute; top:12px; left:12px; font-size:10px; color:#fff; background:rgba(0,0,0,.45); padding:4px 10px; border-radius:999px; letter-spacing:.1em; text-transform:uppercase; backdrop-filter:blur(4px); font-family:'JetBrains Mono',monospace}
.press-thumb .play{width:48px; height:48px; font-size:16px}
.press-card .card-body{display:flex; flex-direction:column; flex:1}
.press-card h3{font-size:18px; margin:0 0 auto; line-height:1.22}
.press-card .src{color:var(--sub); font-size:12px; margin-top:14px; display:flex; align-items:center; gap:8px; font-family:'JetBrains Mono',monospace}
.press-card .src .dot{width:6px; height:6px; border-radius:50%; background:var(--accent2)}

/* ---------- Publications ---------- */
.pub-list{display:flex; flex-direction:column; gap:24px}
.pub-card{display:grid; grid-template-columns:200px 1fr; border:1px solid var(--line); border-radius:16px; background:var(--panel); overflow:hidden}
.pub-card .cover{min-height:200px; background-size:cover; background-position:center; transition:transform .3s}
.pub-card:hover .cover{transform:scale(1.04)}
.pub-card .pub-body{padding:28px; display:flex; flex-direction:column; justify-content:center}
.pub-card .venue{font-size:11px; color:var(--accent); text-transform:uppercase; letter-spacing:.12em; margin-bottom:12px; font-family:'JetBrains Mono',monospace}
.pub-card h3{font-size:24px; margin:0 0 10px; line-height:1.15; font-weight:600; font-family:'Clash Display',sans-serif}
.pub-card .desc{color:var(--sub); font-size:15px; line-height:1.6; margin:0 0 20px}
.pub-foot{display:flex; align-items:center; gap:16px; flex-wrap:wrap}
.dl-btn{display:inline-flex; align-items:center; gap:8px; border:1px solid var(--accent); color:var(--accent); border-radius:999px; padding:10px 20px; font-size:13px; font-family:'JetBrains Mono',monospace}
.dl-btn:hover{background:var(--accent); color:#1a0d08; text-decoration:none}
.pub-pages{color:var(--sub); font-size:12px; font-family:'JetBrains Mono',monospace}

.site-footer{border-top:1px solid var(--line); padding:40px 0 44px; margin-top:40px}
.footer-inner{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:24px}
.footer-meta{color:var(--sub); font-size:12px; margin-top:6px}

/* ---------- Animations ---------- */
@media (prefers-reduced-motion: no-preference){
  main > *{animation:fade .55s cubic-bezier(.2,.7,.2,1)}
  @keyframes fade{from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:none}}
}

/* ============ RESPONSIVE ============ */
@media (max-width:880px){
  .hero{grid-template-columns:1fr; gap:36px}
  .hero h1{font-size:46px}
  .portrait{max-width:360px}
  .bio-grid{grid-template-columns:1fr; gap:32px}
  .feature,.blog-feature{grid-template-columns:1fr}
  .feature .feature-img,.blog-feature .img{min-height:200px; height:200px}
  .focus-grid,.metrics{grid-template-columns:1fr 1fr}
  .facts-grid{grid-template-columns:1fr 1fr}
  .pub-card{grid-template-columns:1fr}
  .pub-card .cover{height:180px; min-height:0}
  .grid-3{grid-template-columns:1fr 1fr}
  .section-title h1{font-size:38px}
}
@media (max-width:600px){
  .container{padding:0 18px}
  .nav-toggle{display:flex}
  .site-nav{display:none; position:absolute; top:100%; left:0; right:0; flex-direction:column; gap:0;
    background:var(--bg); border-bottom:1px solid var(--line); padding:8px 28px 18px}
  .site-nav.open{display:flex}
  .site-nav a{padding:12px 0; border-bottom:1px solid var(--line)}
  .hero{padding:48px 0 36px}
  .hero h1{font-size:38px}
  .hero .lead{font-size:17px}
  .section-title{margin:48px 0 24px}
  .section-title h1{font-size:32px}
  .metrics,.focus-grid,.facts-grid,.grid-2,.grid-3{grid-template-columns:1fr}
  .blog-controls{flex-direction:column; align-items:stretch}
  .search-form input{width:100%}
  .blog-feature h2{font-size:24px}
  .press-lead h2{font-size:26px}
  .post-wrap h1{font-size:32px}
  .contact-band{padding:32px 24px}
  .contact-inner{flex-direction:column; align-items:flex-start}
  .pub-card .pub-body{padding:22px}
}

/* Press — graceful placeholder when an item has no image */
.press-thumb.noimg, .press-lead.noimg{background:linear-gradient(135deg,#1a1d22 0%,#23262b 55%,rgba(232,98,58,.35) 140%)}

/* Press — category filter chips */
.press-filters{display:flex; gap:8px; flex-wrap:wrap; margin:0 0 26px}
.press-filters a.chip{display:inline-flex; align-items:center; gap:7px; padding:7px 15px; border:1px solid var(--line); border-radius:999px; font-size:13px; color:var(--sub); background:var(--panel)}
.press-filters a.chip:hover{color:var(--ink); border-color:var(--sub); text-decoration:none}
.press-filters a.chip.on{background:var(--accent); border-color:var(--accent); color:#fff}
.press-filters .chip-n{opacity:.6; font-size:11px}

/* Experience — grouped sections */
.exp-section{margin-bottom:44px}
.exp-kind{display:flex; align-items:center; gap:10px; font-size:13px; text-transform:uppercase; letter-spacing:.14em; margin:0 0 16px; font-weight:600}
.exp-kind-dot{width:9px; height:9px; border-radius:50%; display:inline-block}
