:root{
  /* Warm editorial off-white — Swiss grid, ink on paper */
  --bg:#f3efe6;
  --bg-2:#ebe5d8;
  --fg:#1a1916;
  --fg-dim:#5a564d;
  --fg-mute:#8a8579;
  --accent:#b8502c;
  --accent2:#3b5a4a;
  --rule:rgba(26,25,22,0.14);
  --rule-strong:rgba(26,25,22,0.28);
  --serif:'Instrument Serif', ui-serif, Georgia, serif;
  --sans:'Inter', ui-sans-serif, system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, 'Menlo', monospace;
  --ease:cubic-bezier(.2,.8,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{scroll-behavior:auto}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--fg);
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
  overflow-x:hidden;
  cursor:none;
}
@media (max-width:900px){ body{ cursor:auto; } }

/* selection */
::selection{ background:var(--accent); color:var(--bg); }

/* grain — subtle paper texture */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:3;
  opacity:.12;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* three canvas */
#three-canvas{
  position:fixed;inset:0;z-index:0;
  width:100vw;height:100vh;
  pointer-events:none;
  opacity:.5;
}

/* progress */
.progress-rail{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:60;
  background:rgba(26,25,22,.08);
}
.progress-fill{
  height:100%;width:0;
  background:var(--fg);
  transition:width .1s linear;
}

/* HUDs */
.meta-hud, .time-hud{
  position:fixed;z-index:40;font-family:var(--mono);font-size:10px;
  color:var(--fg-dim);letter-spacing:.08em;
}
.meta-hud{ left:24px; bottom:24px; }
.time-hud{ right:24px; bottom:24px; display:flex; gap:10px; align-items:center;}
.hud-row{ display:flex; gap:10px; }
.hud-k{ color:var(--fg-mute); }
.hud-v{ color:var(--fg); display:inline-flex; align-items:center; gap:6px; }
.live-dot{width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 8px #10b981;display:inline-block;animation:blink 1.6s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* cursor */
.cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;mix-blend-mode:difference}
.cursor-dot{
  position:absolute;width:6px;height:6px;border-radius:50%;
  background:var(--fg);transform:translate(-50%,-50%);transition:transform .2s var(--ease), opacity .2s;
}
.cursor-ring{
  position:absolute;width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(26,25,22,.55);
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease), height .3s var(--ease), border-color .2s;
}
.cursor-label{
  position:absolute;top:28px;left:28px;font-family:var(--mono);font-size:10px;
  color:var(--bg);letter-spacing:.08em;opacity:0;transition:opacity .2s;
  background:var(--fg);padding:4px 8px;border-radius:2px;white-space:nowrap;
}
.cursor.hover .cursor-ring{width:70px;height:70px;border-color:var(--fg)}
.cursor.hover .cursor-dot{transform:translate(-50%,-50%) scale(0)}
.cursor.drag .cursor-ring{width:80px;height:80px;border-style:dashed}
.cursor.label .cursor-label{opacity:1}

/* loader */
.loader{
  position:fixed;inset:0;z-index:200;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .6s var(--ease), visibility .6s;
}
.loader.done{opacity:0;visibility:hidden}
.loader-inner{width:min(560px,80vw)}
.loader-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--fg-dim);letter-spacing:.1em;}
.loader-bar{height:1px;background:var(--rule);margin:10px 0 10px;overflow:hidden}
.loader-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .1s linear}
.loader-name{margin-top:60px;font-family:var(--serif);font-size:clamp(48px,10vw,140px);line-height:.9;letter-spacing:-.04em;color:var(--fg)}
.ls-italic{font-style:italic;color:var(--fg-dim);margin-left:-.1em}
.ls-serif{display:inline-block}

/* nav */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:20px 32px;
  transition:background .4s,backdrop-filter .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(243,239,230,.82);backdrop-filter:blur(12px);border-color:var(--rule)}
.brand{display:flex;gap:12px;align-items:center;text-decoration:none;color:var(--fg)}
.brand-ha{
  width:36px;height:36px;border:1px solid var(--rule-strong);
  display:grid;place-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.1em;
}
.brand-meta{display:flex;flex-direction:column;line-height:1.1}
.brand-line{font-family:var(--mono);font-size:11px;letter-spacing:.1em}
.brand-sub{font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--fg-mute)}
.nav-links{display:flex;gap:6px;justify-self:center}
.nav-link{
  display:flex;gap:6px;align-items:baseline;text-decoration:none;color:var(--fg);
  padding:8px 14px;border-radius:999px;font-size:13px;
  transition:background .25s var(--ease), color .25s;
}
.nav-link:hover{background:rgba(26,25,22,.05)}
.nl-idx{font-family:var(--mono);font-size:9px;color:var(--fg-mute);letter-spacing:.1em}
.nl-t{font-family:var(--sans);font-weight:400}
.nav-cta{
  justify-self:end;display:flex;gap:8px;align-items:center;
  text-decoration:none;color:var(--fg);
  padding:10px 16px;border:1px solid var(--rule-strong);border-radius:999px;
  font-size:13px;font-family:var(--sans);
  transition:background .25s, color .25s, border-color .25s;
}
.nav-cta:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}

/* layout primitives */
.mono{font-family:var(--mono);letter-spacing:.08em}
.section-head{
  position:sticky;top:0;padding:100px 48px 24px;display:flex;gap:16px;align-items:baseline;
}
.section-idx{color:var(--fg-dim);font-size:11px;letter-spacing:.18em}
.section-divider{flex:1;height:1px;background:var(--rule)}
.sec-h{
  font-family:var(--serif);
  font-size:clamp(48px,8vw,120px);
  line-height:.95;letter-spacing:-.03em;
  padding:0 48px;font-weight:400;
}
.sec-h em{font-style:italic;color:var(--fg-dim)}

/* ===== HERO ===== */
.hero{
  position:relative;min-height:100vh;
  padding:140px 48px 60px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto auto auto;
  gap:clamp(24px,4vw,72px);
  min-height:calc(100vh - 200px);
  position:relative;
}
.hero-meta{grid-row:1}
.hero-meta.right{justify-self:end;text-align:right}
.hero-meta .mono{font-size:11px;color:var(--fg-dim);letter-spacing:.15em}
.tag-blink{color:var(--accent2)}

.hero-title{
  grid-column:1/-1;grid-row:2;
  font-family:var(--serif);font-weight:400;
  font-size:clamp(72px,16vw,240px);
  line-height:.86;letter-spacing:-.04em;
  color:var(--fg);
  pointer-events:none;
}
.ht-line{display:block;overflow:hidden}
.ht-italic{font-style:italic;color:var(--fg-dim);padding-left:.15em}
.ht-word{display:inline-flex}
.ht-char{display:inline-block;transform:translateY(110%);opacity:0}
.loaded .ht-char{animation:charIn 1s var(--ease-out) forwards}
.ht-line[data-line="0"] .ht-char{animation-delay:calc(var(--i,0) * 70ms)}
.ht-line[data-line="1"] .ht-char{animation-delay:calc(0.25s + var(--i,0) * 70ms)}
@keyframes charIn{to{transform:translateY(0);opacity:1}}

.hero-caption{
  grid-column:1/2;grid-row:3;display:flex;gap:16px;max-width:520px;
  padding-top:12px;
}
.hc-idx{font-size:11px;color:var(--fg-mute);padding-top:6px}
.hc-text{font-size:16px;line-height:1.6;color:var(--fg-dim);text-wrap:pretty}
.hc-text em{color:var(--fg);font-style:italic;font-family:var(--serif);font-size:1.1em}

.hero-stats{
  grid-column:2/3;grid-row:3;
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:24px;align-self:end;justify-self:end;max-width:420px;
}
.hs-item{border-top:1px solid var(--rule);padding-top:12px}
.hs-n{font-family:var(--serif);font-size:clamp(36px,4.4vw,56px);line-height:1;letter-spacing:-.03em}
.hs-sup{font-size:.32em;color:var(--fg-mute);margin-left:4px;letter-spacing:.1em;font-family:var(--mono);vertical-align:super}
.hs-l{font-size:10px;color:var(--fg-mute);margin-top:8px;letter-spacing:.12em}

.hero-scroll{
  grid-column:1/-1;grid-row:4;display:flex;gap:16px;align-items:center;
  font-size:10px;color:var(--fg-mute);letter-spacing:.15em;padding-top:24px;
  border-top:1px solid var(--rule);
}
.hs-track{flex:0 0 140px;height:1px;background:var(--rule);position:relative}
.hs-dot{position:absolute;top:50%;left:0;width:4px;height:4px;border-radius:50%;background:var(--accent2);transform:translateY(-50%);animation:scrollRun 2.4s var(--ease) infinite}
@keyframes scrollRun{0%{left:0}50%{left:100%}100%{left:0}}

/* ===== ABOUT ===== */
.about{position:relative;padding-bottom:80px}
.manifesto{padding:40px 48px 48px;max-width:1400px}
.manifesto-line{
  font-family:var(--serif);font-size:clamp(32px,5vw,72px);
  line-height:1.1;letter-spacing:-.02em;font-weight:400;
  color:var(--fg);margin-bottom:8px;text-wrap:balance;
}
.manifesto-line em{font-style:italic;color:var(--accent2)}
.manifesto-line.dim{color:var(--fg-mute)}
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
[data-reveal].in{opacity:1;transform:none}

.about-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;margin:40px 48px 0;
  border-top:1px solid var(--rule);
}
.about-col{padding:32px 24px 0;border-right:1px solid var(--rule)}
.about-col:last-child{border-right:0}
.col-label{font-size:10px;color:var(--fg-mute);letter-spacing:.15em;margin-bottom:20px}
.about-list{list-style:none}
.about-list li{
  padding:12px 0;border-bottom:1px solid var(--rule);
  font-size:16px;color:var(--fg);
  opacity:0;transform:translateX(-10px);transition:all .6s var(--ease-out);
}
.about-list li.in{opacity:1;transform:none}
.skill-groups{display:flex;flex-direction:column;gap:20px}
.skill-group{}
.sg-head{font-size:10px;color:var(--fg-mute);margin-bottom:10px;letter-spacing:.15em}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{
  display:inline-block;font-size:11px;
  padding:5px 10px;border:1px solid var(--rule-strong);border-radius:999px;
  color:var(--fg-dim);font-family:var(--mono);letter-spacing:.05em;
  transition:border-color .25s,color .25s;
}
.chip:hover{border-color:var(--accent);color:var(--fg)}

.current-card{
  border:1px solid var(--rule);padding:16px;border-radius:2px;
  display:flex;flex-direction:column;gap:10px;
}
.cc-row{display:flex;justify-content:space-between;gap:12px;font-size:13px;border-bottom:1px dashed var(--rule);padding-bottom:8px}
.cc-row:last-child{border:0;padding-bottom:0}
.cc-row .mono{font-size:10px;color:var(--fg-mute)}

/* ===== AFFILIATIONS MARQUEE ===== */
.affiliations{
  padding:28px 0 28px;position:relative;
  background:var(--fg);color:var(--bg);
  margin:40px 0;
}
.affiliations .section-head{
  padding:0 48px;margin-bottom:16px;
  display:flex;align-items:center;gap:20px;
}
.affiliations .section-idx{color:rgba(243,239,230,.55);font-family:var(--mono);font-size:11px;letter-spacing:.18em}
.affiliations .section-divider{flex:1;height:1px;background:rgba(243,239,230,.18)}
.marquee{
  overflow:hidden;
  position:relative;
}
.marquee::before,.marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg,var(--fg),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--fg),transparent)}
.marquee-track{
  display:flex;gap:80px;padding:8px 0;width:max-content;
  animation:marquee 40s linear infinite;
}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.m-item{display:flex;align-items:baseline;gap:16px;white-space:nowrap}
.m-idx{color:var(--accent)}
.m-name{font-family:var(--serif);font-size:clamp(26px,3.4vw,44px);letter-spacing:-.02em;color:var(--bg)}
.m-desc{font-size:10px;color:rgba(243,239,230,.55);letter-spacing:.12em;text-transform:uppercase}

/* ===== WORK (HORIZONTAL PIN) ===== */
.work{position:relative}
.work-intro{padding:40px 48px 40px;display:flex;justify-content:space-between;align-items:flex-end;gap:48px;flex-wrap:wrap}
.work-h{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(40px,6vw,88px);line-height:1;letter-spacing:-.03em;text-wrap:balance;
}
.work-h em{font-style:italic;color:var(--fg-dim)}
.work-sub{font-size:11px;color:var(--fg-mute);letter-spacing:.15em}

.work-pin{height:100vh;position:relative;overflow:hidden}
.work-track{
  display:flex;height:100%;will-change:transform;
}
.case{
  flex:0 0 100vw;height:100%;
  display:grid;grid-template-columns:1fr 1fr;
  padding:60px 64px 80px;gap:48px;
  align-items:center;
}
.case-left{display:flex;flex-direction:column;gap:20px;max-width:560px}
.case-right{height:100%;display:flex;align-items:center;justify-content:center}
.case-index{font-size:11px;color:var(--fg-mute)}
.case-tag{font-size:10px;color:var(--accent2);letter-spacing:.2em}
.case-title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(48px,6.5vw,96px);
  line-height:.95;letter-spacing:-.03em;text-wrap:balance;
}
.case-italic{font-style:italic;color:var(--fg-dim);display:block}
.case-body{font-size:16px;line-height:1.6;color:var(--fg-dim);max-width:520px;text-wrap:pretty}
.case-body em{color:var(--fg);font-family:var(--serif);font-size:1.08em}
.case-kv{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:12px;max-width:480px}
.case-kv>div{border-top:1px solid var(--rule);padding-top:10px}
.kv-k{font-size:10px;color:var(--fg-mute);letter-spacing:.15em;display:block}
.kv-v{font-family:var(--serif);font-size:clamp(32px,3.2vw,48px);line-height:1;letter-spacing:-.02em;margin-top:6px}
.kv-s{font-size:.4em;color:var(--fg-mute);margin-left:4px;font-family:var(--mono);vertical-align:super}
.case-tech{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}

.case-right{
  height:100%;display:grid;
  grid-template-columns:auto minmax(0, 1fr) auto;
  grid-template-rows:auto 1fr auto;
  align-items:center;justify-items:center;
  gap:16px 18px;
  padding:20px 0;
}
.case-visual{
  width:100%;min-width:0;aspect-ratio:4/3;
  border:1px solid var(--rule);position:relative;
  grid-column:2;grid-row:2;justify-self:stretch;
  background:
    linear-gradient(rgba(243,239,230,.3),rgba(243,239,230,.3)),
    radial-gradient(circle at 50% 50%, rgba(184,80,44,.08), transparent 60%);
  overflow:hidden;
}
/* Annotation layers in the empty space around visual */
.vis-side{
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--fg-mute);
  display:flex;flex-direction:column;gap:10px;
  align-self:stretch;justify-content:center;
}
.vis-side.left{grid-column:1;grid-row:2;align-items:flex-end;text-align:right;padding-right:8px;border-right:1px dashed rgba(26,25,22,.08)}
.vis-side.right{grid-column:3;grid-row:2;align-items:flex-start;text-align:left;padding-left:8px;border-left:1px dashed rgba(26,25,22,.08)}
.vis-side .vs-row{display:flex;gap:8px;align-items:baseline;opacity:.7}
.vis-side .vs-k{color:var(--fg-mute);opacity:.5;min-width:44px}
.vis-side .vs-v{color:var(--fg);font-weight:500}
.vis-side .vs-v.accent{color:var(--accent)}
.vis-side .vs-v.accent2{color:var(--accent2)}
.vis-side .vs-bar{width:60px;height:1px;background:linear-gradient(90deg, var(--rule-strong), transparent);margin:4px 0}
.vis-top, .vis-bottom{
  grid-column:1 / -1;
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--fg-mute);
  display:flex;justify-content:space-between;align-items:center;width:100%;padding:0 16px;gap:16px;
}
.vis-top{grid-row:1;border-bottom:1px dashed rgba(26,25,22,.08);padding-bottom:10px}
.vis-bottom{grid-row:3;border-top:1px dashed rgba(26,25,22,.08);padding-top:10px;opacity:.7}
.vis-ticks{display:flex;gap:4px;flex:1;align-items:center}
.vis-ticks i{flex:1;height:1px;background:var(--rule);display:block}
.vis-ticks i:nth-child(5n){height:6px;width:1px;flex:0 0 auto;background:var(--rule-strong)}
.vis-label, .vis-foot{
  position:absolute;left:12px;right:12px;font-size:9px;color:var(--fg-mute);letter-spacing:.15em;
  display:flex;justify-content:space-between;
}
.vis-label{top:12px}
.vis-foot{bottom:12px}
.vis-stage{position:absolute;inset:32px;display:flex;align-items:center;justify-content:center}
.blink{animation:blink 1.4s infinite;color:var(--accent2)}

/* Helix (CSS/DOM) */
.helix{position:relative;width:100%;height:100%;transform-style:preserve-3d;perspective:1200px}
.rung{
  position:absolute;left:50%;top:50%;width:60%;height:2px;
  transform-origin:center;transform-style:preserve-3d;
  display:flex;align-items:center;justify-content:space-between;
}
.rung::before,.rung::after{
  content:'';width:10px;height:10px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 12px var(--accent);
}
.rung::after{background:var(--accent2);box-shadow:0 0 12px var(--accent2)}
.rung .bar{flex:1;height:1px;background:linear-gradient(90deg,var(--accent),var(--accent2));margin:0 4px}
.scan{
  position:absolute;left:0;right:0;height:40px;top:0;
  background:linear-gradient(180deg,transparent,rgba(59,90,74,.18),transparent);
  animation:scan 3s linear infinite;
}
@keyframes scan{to{top:calc(100% - 40px)}}

/* Artisan viz */
.roof-svg{width:100%;height:100%}
.roof-svg .rl{stroke-dasharray:400;stroke-dashoffset:400;animation:dash 2.4s var(--ease-out) forwards}
.roof-svg .rp{opacity:0;animation:pop .5s var(--ease-out) 2s forwards}
@keyframes dash{to{stroke-dashoffset:0}}
@keyframes pop{to{opacity:1}}
.scan-line{animation:scanX 3s linear infinite}
@keyframes scanX{to{transform:translateX(400px)}}

/* Swarm viz */
.swarm-svg{width:100%;height:100%}
.swarm-svg .nodes circle{filter:drop-shadow(0 0 6px currentColor)}

/* End case */
.case-end{justify-content:center;grid-template-columns:1fr;text-align:center}
.case-end-inner{display:flex;flex-direction:column;gap:24px;align-items:center;max-width:700px;margin:0 auto}
.case-end-title{font-family:var(--serif);font-size:clamp(48px,7vw,96px);line-height:1;letter-spacing:-.03em;font-weight:400}
.case-end-title em{font-style:italic;color:var(--fg-dim)}

.btn-outline{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;border:1px solid var(--rule-strong);border-radius:999px;
  color:var(--fg);text-decoration:none;font-size:14px;
  transition:background .25s,color .25s,border-color .25s;
  background:transparent;cursor:pointer;font-family:var(--sans);
}
.btn-outline:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}

/* ===== TIMELINE ===== */
.timeline-sec{padding-bottom:120px}
.timeline{
  margin:80px 48px 0;position:relative;
  display:grid;
  grid-template-columns:minmax(200px, 20%) 1px 1fr;
  gap:0;
}
.tl-line{
  grid-column:2;
  grid-row:1 / span 99;
  position:relative;
  width:1px;
  background:var(--rule);
  pointer-events:none;
}
.tl-line::after{
  content:'';position:absolute;top:0;left:-1px;width:3px;height:var(--tl-fill,0%);
  background:linear-gradient(180deg, var(--accent), var(--accent2));
  box-shadow:0 0 24px var(--accent), 0 0 8px var(--accent);
  transition:height .15s linear;
}
.tl-item{
  display:contents;
}
.tl-item > .tl-year{
  grid-column:1;
  padding:48px 48px 48px 0;
  text-align:right;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.15em;
  color:var(--fg-mute);
  line-height:1.4;
  position:relative;
  border-bottom:1px solid var(--rule);
}
.tl-item > .tl-year::after{
  content:'';position:absolute;right:-7px;top:56px;width:13px;height:13px;border-radius:50%;
  background:var(--bg);border:1px solid var(--rule-strong);
  z-index:2;transition:all .4s var(--ease);
}
.tl-item.in > .tl-year::after{
  background:var(--accent);border-color:var(--accent);
  box-shadow:0 0 0 6px rgba(184,80,44,.12), 0 0 18px rgba(184,80,44,.35);
}
.tl-card{
  grid-column:3;
  padding:48px 0 48px 56px;
  border-bottom:1px solid var(--rule);
  background:transparent;backdrop-filter:none;
  transition:padding-left .4s var(--ease);
  position:relative;
}
.tl-card::before{
  content:'';position:absolute;left:0;top:56px;width:40px;height:1px;
  background:linear-gradient(90deg, var(--rule-strong), transparent);
}
.tl-item:hover .tl-card{padding-left:72px}
.tl-item:last-child > .tl-year,
.tl-item:last-child .tl-card{border-bottom:0}
.tl-head{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}
.tl-card h4{font-family:var(--serif);font-size:44px;font-weight:400;letter-spacing:-.02em;line-height:1.05;order:2}
.tl-co{font-size:11px;color:var(--accent2);letter-spacing:.18em;order:1;text-transform:uppercase}
.tl-card p{font-size:16px;line-height:1.65;color:var(--fg-dim);margin-bottom:20px;text-wrap:pretty;max-width:64ch}
.tl-card-edu{padding-top:48px}
.tl-card-edu h4{font-size:0}
.edu-row{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.edu-block{border-left:1px solid var(--rule);padding-left:24px}
.edu-h{font-family:var(--serif);font-size:28px;font-weight:400;margin-bottom:8px}
.edu-p{font-size:11px;color:var(--fg-mute);letter-spacing:.12em}
.edu-p{font-size:11px;color:var(--fg-mute);margin-top:4px}

/* ===== PLAYGROUND ===== */
.playground{padding-bottom:80px}
.pg-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  margin:60px 48px 0;border-top:1px solid var(--rule);border-left:1px solid var(--rule);
}
.pg-card{
  border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:32px 28px;display:flex;flex-direction:column;gap:14px;min-height:280px;
  text-decoration:none;color:var(--fg);position:relative;
  transition:background .3s;
}
.pg-card:hover{background:rgba(184,80,44,.06)}
.pg-tag{font-size:10px;color:var(--fg-mute);letter-spacing:.15em}
.pg-h{font-family:var(--serif);font-size:32px;font-weight:400;letter-spacing:-.02em;line-height:1}
.pg-p{font-size:14px;color:var(--fg-dim);line-height:1.5;flex:1;text-wrap:pretty}
.pg-foot{display:flex;justify-content:space-between;font-size:10px;color:var(--fg-mute);letter-spacing:.12em}
.pg-arrow{font-size:16px;color:var(--accent);transition:transform .3s}
.pg-card:hover .pg-arrow{transform:translate(3px,-3px)}

.gh-graph{display:grid;grid-template-columns:repeat(52,1fr);grid-auto-rows:10px;gap:2px;margin-top:8px}
.gh-cell{background:rgba(26,25,22,.06);border-radius:1px;transition:background .3s}
.gh-cell[data-lvl="1"]{background:rgba(184,80,44,.28)}
.gh-cell[data-lvl="2"]{background:rgba(184,80,44,.5)}
.gh-cell[data-lvl="3"]{background:rgba(184,80,44,.75)}
.gh-cell[data-lvl="4"]{background:var(--accent)}

.now-list{list-style:none;font-size:13px;color:var(--fg-dim);line-height:1.9}

/* ===== CONTACT ===== */
.contact{padding-bottom:40px}
.contact-wrap{padding:40px 48px 60px}
.contact-big{padding:40px 0 80px;border-bottom:1px solid var(--rule)}
.cbig-lead{font-family:var(--serif);font-size:clamp(48px,8vw,120px);line-height:.95;letter-spacing:-.03em;font-weight:400;margin-bottom:32px;text-wrap:balance}
.cbig-mail{
  display:inline-flex;align-items:center;gap:18px;text-decoration:none;color:var(--fg);
  font-family:var(--serif);font-size:clamp(40px,6.5vw,96px);line-height:.95;letter-spacing:-.02em;
  border-bottom:1px solid transparent;transition:border-color .3s;
}
.cbig-mail:hover{border-color:var(--rule-strong)}
.cbm-serif{font-style:italic;color:var(--fg-dim)}
.cbm-at{color:var(--accent)}
.cbm-arrow{width:clamp(48px,5vw,80px);height:clamp(48px,5vw,80px);color:var(--accent2);transition:transform .3s var(--ease-out)}
.cbig-mail:hover .cbm-arrow{transform:translate(6px,-6px)}

.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;padding-top:40px}
.cg-col{padding:24px 24px 0;border-right:1px solid var(--rule)}
.cg-col:last-child{border-right:0}
.cg-k{font-size:10px;color:var(--fg-mute);margin-bottom:18px;letter-spacing:.15em}
.cg-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.cg-list a, .cg-list li{
  display:flex;justify-content:space-between;gap:12px;
  padding:10px 0;border-bottom:1px solid var(--rule);
  text-decoration:none;color:var(--fg);font-size:14px;transition:color .2s;
}
.cg-list a:hover{color:var(--accent2)}
.cg-v{font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:.05em}

.cf{display:flex;flex-direction:column;gap:12px}
.cf-row{display:flex;flex-direction:column;gap:4px;border-bottom:1px solid var(--rule);padding-bottom:8px}
.cf-k{font-size:10px;color:var(--fg-mute);letter-spacing:.15em}
.cf input, .cf textarea{
  background:transparent;border:0;color:var(--fg);font-family:var(--sans);font-size:14px;
  outline:0;resize:none;padding:2px 0;
}
.cf-submit{
  margin-top:8px;align-self:flex-start;
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 22px;border:1px solid var(--rule-strong);border-radius:999px;
  color:var(--fg);background:transparent;font-size:13px;cursor:pointer;
  font-family:var(--sans);transition:background .25s,color .25s,border-color .25s;
}
.cf-submit:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}

.footer{
  display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;
  padding:24px 48px;border-top:1px solid var(--rule);
  font-size:10px;letter-spacing:.15em;color:var(--fg-mute);
}
.foot-c{text-align:center}
.foot-r{text-align:right}
.footer a{color:var(--fg-dim);text-decoration:none}
.footer a:hover{color:var(--fg)}

/* Tweaks */
.tweaks{
  position:fixed;right:20px;top:90px;z-index:80;width:280px;
  background:rgba(243,239,230,.92);backdrop-filter:blur(16px);
  border:1px solid var(--rule-strong);padding:18px;
  display:flex;flex-direction:column;gap:12px;
  transform:translateX(320px);transition:transform .4s var(--ease);
  font-size:12px;
}
.tweaks.open{transform:none}
.tw-head{font-size:11px;color:var(--fg-mute);letter-spacing:.2em;padding-bottom:8px;border-bottom:1px solid var(--rule)}
.tw-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.tw-row .mono{font-size:10px;color:var(--fg-dim)}
.tw-val{min-width:22px;text-align:right}
.tw-row input[type="color"]{width:40px;height:24px;border:1px solid var(--rule);background:transparent;cursor:pointer}
.tw-row input[type="range"]{flex:1;accent-color:var(--accent)}
.tw-toggle input{accent-color:var(--accent)}
.tw-hint{font-size:9px;color:var(--fg-mute);border-top:1px solid var(--rule);padding-top:10px;text-align:center}

/* Konami */
.konami[hidden]{ display:none !important; }
.konami{
  position:fixed;inset:0;z-index:120;display:grid;place-items:center;
  background:rgba(243,239,230,.88);backdrop-filter:blur(8px);
}
.tweaks[hidden]{ display:none !important; }
.konami-inner{text-align:center;max-width:500px;padding:40px}
.k-h{font-family:var(--serif);font-size:64px;margin:16px 0;letter-spacing:-.03em}
.k-p{color:var(--fg-dim);margin-bottom:24px}

/* responsive */
@media (max-width:900px){
  .nav{grid-template-columns:auto 1fr auto;padding:14px 20px}
  .nav-links{display:none}
  .hero{padding:100px 20px 40px}
  .hero-grid{grid-template-columns:1fr}
  .hero-meta.right{display:none}
  .hero-stats{grid-column:1;grid-row:4;justify-self:start;max-width:100%}
  .hero-caption{grid-column:1;grid-row:3}
  .section-head,.sec-h,.manifesto,.work-intro,.contact-wrap{padding-left:20px;padding-right:20px}
  .about-grid,.pg-grid,.contact-grid{grid-template-columns:1fr;margin-left:20px;margin-right:20px}
  .about-col,.cg-col{border-right:0;border-bottom:1px solid var(--rule)}
  .pg-card{border-right:0;min-height:auto}
  .timeline{margin:40px 20px 0;padding-left:0;grid-template-columns:auto 1px 1fr;gap:0}
  .tl-item > .tl-year{padding:24px 16px 24px 0;font-size:10px}
  .tl-card{padding:24px 0 24px 24px}
  .tl-card h4{font-size:24px}
  .tl-card::before{width:16px}
  .work-pin{height:auto}
  .work-track{flex-direction:column;height:auto}
  .case{grid-template-columns:1fr;flex:0 0 auto;padding:40px 20px;min-height:auto}
  .edu-row{grid-template-columns:1fr}
  .footer{grid-template-columns:1fr;gap:8px;text-align:left;padding:24px 20px}
  .foot-c,.foot-r{text-align:left}
}
