:root{
  --bg:#f4f1ea; --ink:#1a1a1a; --mute:#6b6357;
  --line:#d9d2c2; --accent:#b4391f; --card:#ebe6d8;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0e0e10; --ink:#ece7dc; --mute:#8a857a;
    --line:#24241f; --accent:#ff6a3d; --card:#17171a;
  }
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.wrap{max-width:780px;margin:0 auto;padding:clamp(2rem,6vw,5rem) clamp(1.25rem,5vw,2rem)}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:.82em;letter-spacing:-.01em}
.serif{font-family:'Fraunces',Georgia,serif;font-variation-settings:"opsz" 144}
a{color:inherit;text-decoration:none;border-bottom:1px solid var(--line);transition:border-color .2s,color .2s}
a:hover{border-color:var(--accent);color:var(--accent)}

header{padding-top:1rem;position:relative}
.tick{color:var(--mute);font-family:'JetBrains Mono',monospace;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:3.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.tick .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block;margin-right:.5em;animation:pulse 2.2s infinite ease-in-out}
@keyframes pulse{0%,100%{opacity:.35}50%{opacity:1}}
h1{
  font-family:'Fraunces',Georgia,serif;font-weight:400;
  font-size:clamp(3rem,9vw,6rem);line-height:.95;letter-spacing:-.035em;
  font-variation-settings:"opsz" 144,"SOFT" 30;margin-bottom:1.5rem;
}
h1 em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 144,"SOFT" 100}
.lede{
  font-family:'Fraunces',serif;font-size:clamp(1.15rem,2.2vw,1.4rem);
  line-height:1.5;color:var(--ink);max-width:58ch;font-weight:300;margin-bottom:2rem;
}
.lede em{font-style:italic}
.meta{display:flex;flex-wrap:wrap;gap:.4rem 1.25rem;color:var(--mute);font-size:.88rem;margin-bottom:4rem}
.meta span{display:inline-flex;align-items:center;gap:.45rem}

section{padding:3rem 0;border-top:1px solid var(--line)}
h2{
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--mute);margin-bottom:2rem;
  display:flex;align-items:center;gap:.75rem;
}
h2::before{content:"";width:1.5rem;height:1px;background:var(--mute)}

.prose p{margin-bottom:1rem;color:var(--ink);max-width:62ch}
.prose p + p{color:var(--mute)}
.prose h3{font-family:'Fraunces',serif;font-weight:500;font-size:1.4rem;margin:2rem 0 .8rem;letter-spacing:-.015em}
.prose ul{margin:1rem 0 1rem 1.25rem;color:var(--mute)}
.prose li{margin-bottom:.4rem}
.prose code{font-family:'JetBrains Mono',monospace;font-size:.85em;background:var(--card);padding:.1em .4em;border-radius:3px;border:1px solid var(--line)}

.projects{display:flex;flex-direction:column;gap:0}
.proj{
  display:grid;grid-template-columns:4rem 1fr auto;
  gap:1.5rem;align-items:baseline;
  padding:1.4rem 0;border-bottom:1px solid var(--line);
  transition:padding-left .25s ease;
  position:relative;border-top:none;color:inherit;
}
.proj:last-child{border-bottom:none}
.proj:hover{padding-left:1rem;color:inherit;border-color:var(--line)}
.proj:hover .num{color:var(--accent)}
.proj:hover h3{color:var(--accent)}
.proj .num{font-family:'JetBrains Mono',monospace;font-size:.8rem;color:var(--mute);transition:color .25s;padding-top:.15rem}
.proj .body h3{font-family:'Fraunces',serif;font-weight:500;font-size:1.25rem;letter-spacing:-.015em;margin-bottom:.3rem;transition:color .25s}
.proj .body p{color:var(--mute);font-size:.95rem;line-height:1.5}
.proj .stack{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--mute);text-align:right;white-space:nowrap;opacity:.7}
.proj .tag{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--accent);text-transform:uppercase;letter-spacing:.12em;margin-left:.5rem}
@media (max-width:560px){
  .proj{grid-template-columns:2.5rem 1fr;gap:1rem}
  .proj .stack{grid-column:2;text-align:left;margin-top:.5rem}
}

.edu{display:flex;flex-direction:column;gap:1.5rem}
.edu-row{display:grid;grid-template-columns:9rem 1fr;gap:1.5rem;align-items:baseline}
.edu-row time{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--mute);letter-spacing:.02em}
.edu-row .what strong{font-weight:500}
.edu-row .what .where{color:var(--mute);display:block;font-size:.92rem;margin-top:.15rem}
.edu-row .what .detail{color:var(--mute);font-size:.85rem;margin-top:.3rem;font-style:italic}
@media (max-width:560px){.edu-row{grid-template-columns:1fr}.edu-row time{font-size:.72rem}}

.skills{display:flex;flex-wrap:wrap;gap:.4rem}
.skills span{
  font-family:'JetBrains Mono',monospace;font-size:.78rem;
  padding:.35rem .7rem;background:var(--card);border:1px solid var(--line);
  border-radius:2px;color:var(--ink);transition:all .2s;
}
.skills span:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}

.contact{display:flex;flex-direction:column;gap:.7rem;font-family:'JetBrains Mono',monospace;font-size:.9rem}
.contact a{display:inline-flex;align-items:baseline;gap:.75rem;border:none;width:fit-content}
.contact a::before{content:"→";color:var(--mute);transition:transform .2s,color .2s}
.contact a:hover::before{transform:translateX(4px);color:var(--accent)}
.contact .k{color:var(--mute);min-width:4.5rem;display:inline-block}

footer{margin-top:4rem;padding-top:2rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;color:var(--mute);font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.05em;gap:1rem;flex-wrap:wrap}

.reveal{opacity:0;transform:translateY(12px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Project page specifics */
.back{
  font-family:'JetBrains Mono',monospace;font-size:.78rem;
  color:var(--mute);letter-spacing:.05em;border:none;
  display:inline-flex;align-items:center;gap:.4rem;margin-bottom:2.5rem;
}
.back::before{content:"←";transition:transform .2s}
.back:hover{color:var(--accent)}
.back:hover::before{transform:translateX(-4px)}
.kicker{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:.18em;margin-bottom:1rem}
.page-title{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(2.2rem,6vw,3.8rem);line-height:1;
  letter-spacing:-.025em;margin-bottom:1.5rem;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.summary{font-family:'Fraunces',serif;font-size:1.2rem;line-height:1.5;color:var(--ink);max-width:58ch;font-weight:300;margin-bottom:2rem}
.facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1.5rem;margin:2rem 0 3rem;padding:1.5rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.fact .label{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--mute);text-transform:uppercase;letter-spacing:.15em;margin-bottom:.35rem}
.fact .val{font-size:.95rem}
