/* ===========================================================
   Mulham — Portfolio · Editorial
   Light warm off-white · near-black · single blue accent
   =========================================================== */
:root{
  --bg:        oklch(0.972 0.006 85);
  --bg-soft:   oklch(0.955 0.008 85);
  --ink:       oklch(0.205 0.012 60);
  --ink-2:     oklch(0.45 0.012 65);
  --ink-3:     oklch(0.63 0.010 70);
  --line:      oklch(0.885 0.008 80);
  --line-2:    oklch(0.83 0.010 80);
  --accent:    #2563eb;
  --accent-2:  oklch(0.55 0.20 258);
  --accent-soft: oklch(0.93 0.045 256);
  --paper-card: oklch(0.985 0.004 85);

  --serif: ui-serif, Georgia, serif;
  --sans: "Helvetica Neue", Helvetica, Arial, "Segoe UI", sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --ease: cubic-bezier(0.22,0.7,0.18,1);
  --ease-out: cubic-bezier(0.16,0.84,0.24,1);
  --maxw: 1200px;
  --pad: clamp(22px, 5vw, 72px);
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
html:not(.lenis){scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--accent-soft);color:var(--ink);}
a{color:inherit;text-decoration:none;}
img,svg{display:block;}
ul{margin:0;padding:0;list-style:none;}
button{font-family:inherit;color:inherit;background:none;border:none;cursor:pointer;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);width:100%;}
.mono{font-family:var(--mono);font-weight:400;}
.label{
  font-family:var(--mono);font-size:.72rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);
}

/* ---------------- top bar ---------------- */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;gap:14px;
  padding:18px var(--pad);
  mix-blend-mode:normal;
}
.topbar::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(var(--bg),rgba(247,244,238,0));
  opacity:0;transition:opacity .5s var(--ease);
}
.topbar.scrolled::before{opacity:1;}
.topbar .logo{font-weight:700;font-size:1.18rem;letter-spacing:-.02em;}
.topbar .loc{font-size:.7rem;letter-spacing:.22em;color:var(--ink-3);margin-top:2px;}
.topbar .spacer{margin-left:auto;}
.topnav{display:flex;align-items:center;gap:22px;font-size:.78rem;}
.topnav .status{display:inline-flex;align-items:center;gap:8px;color:var(--ink-2);letter-spacing:.04em;white-space:nowrap;}
.topnav .status i{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--accent-2);animation:pulse 2.6s var(--ease) infinite;}
.topnav a{position:relative;color:var(--ink);letter-spacing:.04em;}
.topnav a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:1px;background:var(--ink);transition:right .4s var(--ease);}
.topnav a:hover::after{right:0;}
.lang-toggle{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;
  color:var(--ink-3);background:none;border:1px solid var(--line-2);
  border-radius:4px;padding:4px 9px;cursor:pointer;line-height:1;
  transition:color .25s var(--ease),border-color .25s var(--ease);
}
.lang-toggle:hover{color:var(--ink);border-color:var(--line);}
@keyframes pulse{0%{box-shadow:0 0 0 0 var(--accent-soft);}70%{box-shadow:0 0 0 7px rgba(37,99,235,0);}100%{box-shadow:0 0 0 0 rgba(37,99,235,0);}}

/* ---------------- sections ---------------- */
.section{padding:clamp(96px,15vh,184px) 0;border-top:1px solid var(--line);}
.sec-head{display:flex;align-items:baseline;gap:18px;margin-bottom:clamp(40px,7vh,72px);}
.sec-head .label{white-space:nowrap;}
.sec-head .rule{flex:1;height:1px;background:var(--line);}

/* ---------------- hero / signature ---------------- */
.hero{
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  position:relative;padding-top:84px;padding-bottom:40px;border-top:none;
}
.hero .kicker{margin:0 0 clamp(16px,2.4vh,26px);}
.ai{max-width:1140px;}
/* answer text + its visual share a top baseline and sit close, reading as one
   response panel emitted by the bot (not a floating, centered graphic). */
.hero-body{display:grid;grid-template-columns:1.05fr .95fr;align-items:start;gap:clamp(14px,2.4vw,38px);margin-top:0;}

/* intro: bar centered & compact, content collapsed */
.hero.intro .hero-body,
.hero.intro .chips{
  height:0;margin:0;opacity:0;overflow:hidden;pointer-events:none;
}
.hero.intro .bar{
  max-width:600px;margin:0 auto;
}
.hero-body .answer{min-width:0;margin-top:0;}
.hero-body .stage-wrap{margin-top:0;max-width:none;}
@media(max-width:880px){
  .hero-body{grid-template-columns:1fr;align-items:stretch;gap:clamp(20px,4vh,34px);}
  /* the grid gap already spaces the stage from the text; drop the extra
     stage-wrap margin so the stacked hero stays compact. */
  .stage-wrap{margin-top:0;}
  /* stacked, the hero is taller than a phone screen — flow from the top and
     scroll instead of vertically centering (which clips the heading off-screen).
     The lone intro bar still gets centered. */
  .hero{justify-content:flex-start;padding-bottom:clamp(28px,5vh,48px);}
  .hero.intro{justify-content:center;}
}

/* query bar */
.bar{
  display:flex;align-items:center;gap:16px;
  margin-top:clamp(16px,2.4vh,24px);
  padding:16px 20px;
  background:var(--paper-card);
  border:1px solid var(--line-2);
  border-radius:14px;
  box-shadow:0 1px 0 rgba(0,0,0,0.02), 0 18px 40px -32px rgba(20,18,14,.5);
  transition:border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.bar.active{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft), 0 18px 40px -30px rgba(37,99,235,.45);}
@keyframes bar-shake{0%,100%{transform:translateX(0);}18%{transform:translateX(-6px);}36%{transform:translateX(6px);}54%{transform:translateX(-4px);}72%{transform:translateX(4px);}}
.bar.shake{animation:bar-shake .38s var(--ease);}
.bar-mark{
  flex:0 0 auto;width:22px;height:22px;border-radius:6px;
  background:var(--accent);position:relative;
}
.bar-mark::after{content:"";position:absolute;inset:0;margin:auto;width:8px;height:8px;border:1.6px solid #fff;border-radius:2px;}
.bar-q{
  flex:1;min-width:0;font-family:var(--mono);font-size:clamp(.92rem,1.7vw,1.05rem);
  color:var(--ink);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.caret{display:inline-block;width:2px;height:1.05em;background:var(--accent);vertical-align:-0.18em;margin-left:1px;animation:blink 1.05s steps(1) infinite;}
.bar.thinking .caret{opacity:0;}
@keyframes blink{50%{opacity:0;}}
.bar-state{flex:0 0 auto;display:flex;align-items:center;}
.bar-state .lbl{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);display:inline-flex;align-items:center;gap:7px;}
.bar-state .lbl .ret{font-size:.85rem;}
.bar-state .dots{display:none;gap:5px;align-items:center;}
.bar-state .dots i{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:dot 1.1s var(--ease) infinite;}
.bar-state .dots i:nth-child(2){animation-delay:.16s;}
.bar-state .dots i:nth-child(3){animation-delay:.32s;}
.bar.thinking .bar-state .lbl{display:none;}
.bar.thinking .bar-state .dots{display:inline-flex;}
@keyframes dot{0%,100%{opacity:.25;transform:translateY(0);}40%{opacity:1;transform:translateY(-3px);}}

/* answer */
.answer{margin-top:clamp(20px,3vh,32px);}
.big{
  margin:0;font-weight:700;letter-spacing:-.035em;line-height:1.02;
  font-size:clamp(2rem,4.4vw,3.8rem);text-wrap:balance;
}
.big .w{display:inline-block;will-change:transform,opacity;}
.sub{
  margin:clamp(14px,2vh,20px) 0 0;max-width:640px;
  font-size:clamp(1.02rem,1.5vw,1.22rem);color:var(--ink-2);line-height:1.55;text-wrap:pretty;
}
.tags{display:flex;flex-wrap:wrap;gap:8px 8px;margin-top:clamp(14px,2vh,20px);}
.tags li{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.02em;color:var(--ink-2);
  border:1px solid var(--line-2);border-radius:100px;padding:5px 12px;background:var(--bg);
}

/* ---------------- platform stage (signature visual) ---------------- */
.stage-wrap{margin-top:clamp(20px,3vh,34px);width:100%;max-width:960px;}
.stage{position:relative;width:100%;min-height:340px;display:flex;align-items:center;}
.comp{
  position:absolute;inset:0;display:flex;align-items:center;align-content:center;justify-content:center;
  gap:clamp(14px,2.4vw,28px);flex-wrap:wrap;
}
/* cross — app-icon reveal camera tour (ported from the standalone scene).
   The comp is a clipped viewport; a 1920x1080 "world" is fit-scaled into it
   (.xtour), and a camera layer (.xcam) pans/zooms across the four cards. */
.comp.cross{display:block;overflow:hidden;}
.xtour{position:absolute;left:0;top:0;width:1920px;height:1080px;transform-origin:0 0;will-change:transform;}
.xcam{position:absolute;left:0;top:0;width:1920px;height:1080px;transform-origin:0 0;will-change:transform;}
.xcard{
  position:absolute;overflow:hidden;
  background:linear-gradient(160deg,#fcfbf7 0%,#f3f1ea 100%);
  border:1px solid rgba(180,172,150,.30);
  box-shadow:0 26px 50px -18px rgba(120,110,86,.42),0 6px 14px -6px rgba(120,110,86,.20),inset 0 1px 0 rgba(255,255,255,.85);
}
.xcard.phone{width:320px;height:190px;border-radius:46px 46px 10px 10px;}
.xcard.wide{width:470px;height:190px;border-radius:16px 16px 10px 10px;}
/* iOS notch */
.xnotch{position:absolute;top:16px;left:50%;transform:translateX(-50%);width:88px;height:22px;border-radius:11px;background:#cfccc2;display:flex;align-items:center;justify-content:flex-end;padding-right:8px;}
.xnotch::after{content:"";width:8px;height:8px;border-radius:50%;background:#bdbaae;}
/* Android punch-hole */
.xhole{position:absolute;top:16px;left:50%;transform:translateX(-50%);width:11px;height:11px;border-radius:50%;background:#cfccc2;}
/* browser / desktop header */
.xhead{position:absolute;top:0;left:0;right:0;height:44px;border-bottom:1px solid #e7e3d8;display:flex;align-items:center;padding-left:16px;gap:7px;}
.xhead i{width:9px;height:9px;border-radius:50%;background:#cfccc2;flex:0 0 auto;}
.xtab{margin-left:16px;margin-bottom:-1px;align-self:flex-end;width:156px;height:32px;border-radius:9px 9px 0 0;background:#efece3;border:1px solid #e2ded2;border-bottom:none;display:flex;align-items:center;gap:8px;padding-left:10px;padding-right:12px;}
.xtabline{height:6px;border-radius:3px;background:#d6d2c6;flex:1;}
/* desktop dock */
.xdock{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);height:50px;border-radius:14px;background:#fff;border:1px solid rgba(180,172,150,.30);box-shadow:0 12px 24px -8px rgba(120,110,86,.40),0 2px 6px rgba(120,110,86,.16);display:flex;align-items:center;gap:11px;padding:0 13px;}
.xslot{width:30px;height:30px;border-radius:8px;background:#e7e3d9;flex:0 0 auto;}
/* phone bottom fade */
.xfade{position:absolute;left:0;right:0;bottom:0;height:46px;background:linear-gradient(to bottom,rgba(243,241,234,0) 0%,#f0efe9 92%);}
/* app icon — blue rounded square with a white rounded-square glyph */
.xicon{position:relative;}
.xicon-box{position:absolute;inset:0;background:linear-gradient(150deg,#4d84ff 0%,#2360ea 100%);transform-origin:center;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.2);will-change:transform,opacity;}
.xicon-out{border-style:solid;border-color:rgba(255,255,255,.96);}
.comp.client{gap:clamp(16px,3vw,40px);}
.comp.stack{flex-direction:column;flex-wrap:nowrap;align-items:stretch;gap:10px;max-width:440px;}

/* devices */
.device{
  position:relative;background:var(--paper-card);border:1px solid var(--line-2);
  box-shadow:0 1px 0 rgba(0,0,0,.02), 0 24px 44px -34px rgba(20,18,14,.55);
}
.device .screen{
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:var(--ink-2);background:
    linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%);
  overflow:hidden;
}
.device .plat{
  position:absolute;left:0;right:0;bottom:-22px;text-align:center;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;color:var(--ink-3);
}
.run{font-family:var(--mono);font-size:.72rem;color:var(--ink);letter-spacing:-.01em;}
.run.cta{color:var(--accent);}
.spark{display:block;color:var(--accent);font-size:1.1rem;line-height:1;margin-bottom:5px;}

/* phone */
.dev-phone{width:96px;height:170px;border-radius:17px;padding:8px 6px;}
.dev-phone .notch{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:30px;height:4px;border-radius:4px;background:var(--line-2);}
.dev-phone .screen{width:100%;height:100%;border-radius:11px;padding:8px;}
.dev-phone.ios{border-radius:22px;}
.dev-phone.android .notch{width:7px;height:7px;border-radius:50%;left:50%;}

/* browser */
.dev-browser{width:196px;height:138px;border-radius:11px;padding:0;overflow:hidden;align-self:center;display:flex;flex-direction:column;}
/* browser tab chrome */
.br-chrome{flex-shrink:0;}
.br-strip{display:flex;align-items:flex-end;padding:5px 8px 0;background:var(--bg-soft);border-bottom:1px solid var(--line);}
.br-wdots{display:flex;align-items:center;gap:3px;padding-bottom:4px;margin-right:5px;flex-shrink:0;}
.br-wdots i{width:5px;height:5px;border-radius:50%;background:var(--line-2);}
.br-tab{
  width:38px;
  background:var(--paper-card);border:1px solid var(--line);border-bottom-color:var(--paper-card);
  border-radius:5px 5px 0 0;padding:4px 0;
  position:relative;bottom:-1px;
}
.dev-browser .screen{flex:1;min-height:0;width:100%;flex-direction:column;gap:6px;padding:10px;}
/* window (desktop) */
.dev-window .top{display:flex;align-items:center;gap:5px;padding:8px 10px;border-bottom:1px solid var(--line);background:var(--bg-soft);}
.dev-window .top i{width:7px;height:7px;border-radius:50%;background:var(--line-2);}
.dev-window .screen{width:100%;height:calc(100% - 29px);flex-direction:column;gap:8px;padding:14px;}

/* window (desktop) */
.dev-window{width:200px;height:142px;border-radius:11px;padding:0;overflow:hidden;align-self:center;}

/* mini-ui inside screens */
.ui{display:flex;flex-direction:column;gap:6px;width:100%;align-items:stretch;}
.uiline{height:7px;border-radius:5px;background:var(--line-2);}
.uiline.s{width:62%;}
.uiline.accent{width:44%;background:var(--accent);opacity:.85;}

/* what-he-builds — one app frame with an LLM working inside it:
   a normal interface, then one generated line marked by a single accent spark. */
.comp.build .appframe{width:130px;height:230px;border-radius:26px;}
.appframe .screen{flex-direction:column;align-items:stretch;justify-content:flex-start;gap:10px;padding:16px 12px;}
.appframe .appui{display:flex;flex-direction:column;align-items:stretch;gap:10px;width:100%;}
.appframe .genrow{display:flex;align-items:center;gap:7px;margin-top:7px;}
.appframe .gen-spark{flex:0 0 auto;color:var(--accent);font-size:.82rem;line-height:1;}
.appframe .uiline.gen{flex:1;background:var(--accent);opacity:.85;}

/* status card (client) */
.statuscard{
  background:var(--paper-card);border:1px solid var(--line-2);border-radius:14px;
  padding:20px 22px;display:flex;flex-direction:column;gap:8px;min-width:230px;
  box-shadow:0 1px 0 rgba(0,0,0,.02), 0 24px 44px -34px rgba(20,18,14,.55);
}
.statuscard .st{display:inline-flex;align-items:center;gap:9px;font-size:.92rem;font-weight:600;letter-spacing:-.01em;}
.statuscard .st .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);}
.statuscard .st.sub{font-weight:400;font-size:.78rem;color:var(--ink-3);font-family:var(--mono);letter-spacing:.04em;padding-left:17px;white-space:nowrap;}
.statuscard .cta{margin-top:6px;font-size:.9rem;}

/* timeline (client stage) */
.timeline{
  background:var(--paper-card);border:1px solid var(--line-2);border-radius:14px;
  padding:30px 36px 24px;
  box-shadow:0 1px 0 rgba(0,0,0,.02), 0 24px 44px -34px rgba(20,18,14,.55);
  width:min(440px,94%);
}
.tl-row{display:flex;align-items:flex-start;position:relative;}
.tl-row::before{content:"";position:absolute;top:7px;left:12.5%;right:12.5%;height:1.5px;background:var(--line-2);z-index:0;}
.tl-fill{position:absolute;top:7px;left:12.5%;width:0;height:1.5px;background:var(--accent);z-index:0;}
.tl-point{display:flex;flex-direction:column;align-items:center;gap:12px;flex:1;position:relative;z-index:1;}
.tl-dot{width:15px;height:15px;border-radius:50%;background:var(--bg);border:1.5px solid var(--line-2);transition:background .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease);}
.tl-point.done .tl-dot{background:var(--accent);border-color:var(--accent);}
.tl-point.active .tl-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);}
.tl-lbl{font-family:var(--mono);font-size:.72rem;color:var(--ink-3);letter-spacing:.02em;text-align:center;white-space:nowrap;}
.tl-point.done .tl-lbl,.tl-point.active .tl-lbl{color:var(--ink-2);}
@media(max-width:560px){
  /* use the full stage width and trim side padding so each of the four label
     columns is wide enough; shrink the label type so they don't touch. */
  .timeline{padding:18px 12px 14px;width:100%;}
  .tl-lbl{font-size:.54rem;letter-spacing:0;}
}

/* stack layers */
.layer{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:13px 18px;border:1px solid var(--line-2);border-radius:10px;background:var(--paper-card);
}
.layer.lead{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.layer .lname{font-weight:600;font-size:.96rem;letter-spacing:-.01em;flex:0 1 auto;}
.layer .ltag{font-family:var(--mono);font-size:.72rem;color:var(--ink-3);letter-spacing:.02em;flex-shrink:0;white-space:nowrap;text-align:right;padding-left:14px;}

@media(max-width:560px){
  /* shrink every stage visual on phones so the whole hero — down to the query
     bar — stays on one screen. Each comp must fit within .stage min-height. */
  .dev-browser,.dev-window{width:122px;height:84px;}
  .dev-phone{width:70px;height:84px;}
  .run{font-size:.58rem;}
  .comp.cross{gap:12px clamp(14px,3vw,22px);}
  .comp.build .appframe{width:100px;height:176px;border-radius:20px;}
  .appframe .screen{padding:12px 10px;gap:8px;}
  .comp.stack{gap:7px;}
  .layer{padding:8px 14px;}
  .layer .lname{font-size:.85rem;}
  .layer .ltag{font-size:.66rem;padding-left:10px;}
  .stage{min-height:205px;}
  /* tighten the vertical rhythm on phones so the query bar reaches the screen */
  .hero-body{gap:clamp(14px,3vh,26px);}
  .sub{line-height:1.45;margin-top:clamp(10px,1.6vh,16px);}
  .chips{margin-top:clamp(10px,2vh,18px);}
  .bar{margin-top:clamp(10px,1.6vh,16px);}
}
@media(max-width:400px){
  .dev-browser,.dev-window{width:108px;height:76px;}
  .dev-phone{width:62px;height:76px;}
  .run{font-size:.54rem;}
  .comp.cross{gap:10px 12px;}
  .comp.build .appframe{width:92px;height:160px;}
  .stage{min-height:186px;}
}

/* chips */
.chips{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:clamp(16px,4.5vh,52px);}
.chips .clab{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);}
.chip-row{display:flex;flex-wrap:wrap;gap:9px;}
.chip{
  font-family:var(--mono);font-size:.8rem;letter-spacing:.01em;color:var(--ink-2);white-space:nowrap;
  border:1px solid var(--line-2);border-radius:100px;padding:8px 15px;background:var(--bg);
  transition:all .35s var(--ease);
  position:relative;
}
.chip:hover{color:var(--ink);border-color:var(--ink-3);transform:translateY(-1px);}
.chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink);}
@keyframes chips-attention{0%,100%{opacity:1;}30%{opacity:.3;}65%{opacity:.8;}}
.chip-row.attention{animation:chips-attention .48s ease;}

@property --chip-angle{syntax:'<angle>';initial-value:0deg;inherits:false;}
@keyframes chip-trace{to{--chip-angle:360deg;}}
.chip.tracing::before{
  content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:conic-gradient(from var(--chip-angle),transparent 0deg,transparent 250deg,rgba(37,99,235,.2) 275deg,var(--accent) 325deg,rgba(37,99,235,.2) 355deg,transparent 360deg);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation:chip-trace 2.8s linear;
}

.scrollcue{
  position:absolute;left:var(--pad);bottom:30px;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);
  display:inline-flex;align-items:center;gap:9px;
}
.scrollcue .ln{width:34px;height:1px;background:var(--ink-3);position:relative;overflow:hidden;}
.scrollcue .ln::after{content:"";position:absolute;inset:0;background:var(--accent);transform:translateX(-100%);animation:slide 2.4s var(--ease) infinite;}
@keyframes slide{0%{transform:translateX(-100%);}55%,100%{transform:translateX(100%);}}

/* ---------------- about ---------------- */
.about .lead{
  font-weight:600;letter-spacing:-.02em;line-height:1.18;
  font-size:clamp(1.7rem,4.2vw,3.1rem);max-width:18ch;margin:0;text-wrap:balance;
}
.about .body{margin:clamp(30px,5vh,48px) 0 0;max-width:560px;}
.about .body p{margin:0 0 1.1em;color:var(--ink-2);font-size:clamp(1.02rem,1.4vw,1.18rem);text-wrap:pretty;}
.about .body p:last-child{margin-bottom:0;}
.about .body p.closing{margin-top:.7em;}
.about-grid{display:grid;grid-template-columns:1fr;gap:0;}
.about-left{display:flex;flex-direction:column;}
.about-photo{
  margin-top:32px;width:clamp(180px,22vw,240px);aspect-ratio:1/1;border-radius:10px;
  border:1px solid var(--line);overflow:hidden;
}
.about-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.92);}
@media(min-width:860px){
  .about-grid{grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,90px);align-items:stretch;}
  .about-left{justify-content:space-between;}
  .about-photo{margin-top:0;}
}

/* ---------------- work ---------------- */
.work-list{border-top:1px solid var(--line);}
.work-item{border-bottom:1px solid var(--line);padding:clamp(26px,4vh,40px) 0;cursor:pointer;}
.work-row{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:clamp(16px,3vw,36px);}
.work-item .num{font-family:var(--mono);font-size:.85rem;color:var(--ink-3);letter-spacing:.05em;}
.work-item .title{font-weight:600;letter-spacing:-.02em;font-size:clamp(1.5rem,3.4vw,2.5rem);line-height:1.05;transition:color .4s var(--ease),transform .5s var(--ease);}
.work-item .meta{font-family:var(--mono);font-size:.74rem;color:var(--accent);letter-spacing:.03em;white-space:nowrap;}
.work-item:hover .title,.work-item.open .title{color:var(--accent);transform:translateX(6px);}
.work-item .detail{overflow:hidden;height:0;opacity:0;}
.work-item.open .detail{opacity:1;}
.work-item .detail-in{min-height:0;}
.detail-grid{display:grid;grid-template-columns:1fr;gap:22px;padding-left:0;}
@media(min-width:760px){.detail-grid{grid-template-columns:1.3fr 1fr;gap:clamp(28px,4vw,56px);padding-left:clamp(40px,6vw,84px);}}
.detail-grid p{margin:0;color:var(--ink-2);font-size:1.05rem;max-width:46ch;text-wrap:pretty;}
.detail-grid .stack{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}
.detail-grid .stack span{font-family:var(--mono);font-size:.74rem;color:var(--ink-2);border:1px solid var(--line-2);border-radius:100px;padding:5px 12px;white-space:nowrap;}
.work-links{display:flex;flex-wrap:wrap;gap:22px;margin-top:22px;font-size:.84rem;}
.work-links a{position:relative;color:var(--ink);letter-spacing:.03em;}
.work-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:1px;background:var(--ink);transition:right .4s var(--ease);}
.work-links a:hover::after{right:0;}
.shot{
  border:1px solid var(--line-2);border-radius:10px;aspect-ratio:4/3;
  background:
    repeating-linear-gradient(135deg, var(--bg-soft) 0 9px, var(--paper-card) 9px 18px);
  display:flex;align-items:flex-end;padding:14px;
}
.shot span{font-family:var(--mono);font-size:.7rem;color:var(--ink-3);letter-spacing:.02em;}
.shot img{width:100%;height:100%;object-fit:contain;border-radius:6px;}
/* a shot that holds a real image drops the placeholder striping + frame */
.shot:has(img){background:none;border:none;padding:0;aspect-ratio:auto;cursor:zoom-in;}
.shot:has(img) img{height:auto;display:block;}

/* a shot that plays a video: full-bleed preview with a play affordance */
.shot-video{
  position:relative;overflow:hidden;padding:0;display:block;width:100%;
  border:1px solid var(--line-2);border-radius:10px;aspect-ratio:1280/804;
  background:var(--bg-soft);cursor:zoom-in;
}
.shot-vid{width:100%;height:100%;object-fit:cover;display:block;}
.shot-play{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:13px;
  color:#fff;font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;
  text-transform:uppercase;
  background:oklch(0.15 0.01 60 / .26);transition:background .3s var(--ease);
}
.shot-play svg{
  width:56px;height:56px;padding:15px 14px 15px 16px;box-sizing:border-box;
  border-radius:50%;background:oklch(1 0 0 / .18);
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
  transition:transform .3s var(--ease),background .3s var(--ease);
}
.shot-video:hover .shot-play,
.shot-video:focus-visible .shot-play{background:oklch(0.15 0.01 60 / .08);}
.shot-video:hover .shot-play svg,
.shot-video:focus-visible .shot-play svg{transform:scale(1.09);background:var(--accent);}
.shot-video:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}

/* ---------------- image lightbox ---------------- */
.lightbox{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(20px,5vw,64px);
  background:oklch(0.15 0.01 60 / .82);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:0;visibility:hidden;cursor:zoom-out;
  transition:opacity .3s var(--ease),visibility .3s var(--ease);
}
.lightbox.open{opacity:1;visibility:visible;}
.lightbox-img{
  max-width:100%;max-height:100%;object-fit:contain;
  border-radius:8px;box-shadow:0 24px 70px rgba(0,0,0,.45);
  transform:scale(.96);transition:transform .3s var(--ease-out);
}
.lightbox.open .lightbox-img{transform:scale(1);}
.lightbox-close{
  position:absolute;top:clamp(14px,3vw,30px);right:clamp(14px,3vw,30px);
  width:44px;height:44px;border:none;border-radius:50%;
  background:oklch(1 0 0 / .14);color:#fff;
  font-size:1.7rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .25s var(--ease);
}
.lightbox-close:hover{background:oklch(1 0 0 / .26);}

/* video inside the lightbox + playback-speed controls */
.lightbox-video{
  display:flex;flex-direction:column;align-items:center;gap:16px;
  max-width:100%;max-height:100%;cursor:auto;
}
.lightbox-video[hidden]{display:none;}
.lightbox-vid{
  max-width:100%;max-height:76vh;border-radius:8px;background:#000;
  box-shadow:0 24px 70px rgba(0,0,0,.45);
  transform:scale(.96);transition:transform .3s var(--ease-out);
}
.lightbox.open .lightbox-vid{transform:scale(1);}
.speedbar{
  display:flex;align-items:center;gap:4px;
  background:oklch(1 0 0 / .1);border:1px solid oklch(1 0 0 / .12);
  border-radius:100px;padding:5px 7px;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
}
.speedbar-label{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:oklch(1 0 0 / .5);padding:0 8px 0 6px;
}
.speedbar button{
  font-family:var(--mono);font-size:.76rem;color:#fff;
  background:transparent;border:none;border-radius:100px;
  padding:6px 12px;cursor:pointer;line-height:1;
  transition:background .2s var(--ease),color .2s var(--ease);
}
.speedbar button:hover{background:oklch(1 0 0 / .14);}
.speedbar button.active{background:#fff;color:#161310;font-weight:700;}

/* ---------------- skills ---------------- */
.skills-grid{display:grid;grid-template-columns:1fr;gap:clamp(30px,5vh,46px);}
@media(min-width:720px){.skills-grid{grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,64px);}}
.skill-col h3{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin:0 0 16px;font-weight:500;}
.skill-col ul li{font-size:clamp(1.15rem,2vw,1.5rem);font-weight:500;letter-spacing:-.01em;padding:9px 0;border-top:1px solid var(--line);}
.skill-col ul li:first-child{border-top:none;}

/* ---------------- contact ---------------- */
.contact .avail{display:inline-flex;align-items:center;gap:9px;color:var(--ink-2);font-size:.8rem;letter-spacing:.05em;margin:0 0 clamp(28px,5vh,44px);}
.contact .avail .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);}
.copywrap{position:relative;display:block;}
.email-hero{
  position:relative;display:inline-block;text-align:left;overflow:hidden;
  font-weight:700;letter-spacing:-.03em;line-height:1.0;
  font-size:clamp(2rem,6.2vw,4.6rem);padding-bottom:.08em;
}
.email-hero .lbl{display:inline-block;background-image:linear-gradient(var(--accent),var(--accent));background-size:100% 2px;background-repeat:no-repeat;background-position:0 100%;transition:transform .45s var(--ease),opacity .3s,background-size .4s var(--ease);}
.email-hero:hover .lbl{background-size:100% 3px;}
.email-hero .ok{
  position:absolute;left:0;top:0;display:inline-flex;align-items:center;gap:.3em;
  color:var(--accent);transform:translateY(112%);transition:transform .5s var(--ease-out);
}
.email-hero.copied .lbl{transform:translateY(-112%);opacity:0;}
.email-hero.copied .ok{transform:translateY(0);}
.email-hero .ok svg{width:.78em;height:.78em;}
.email-hero.copied .ok svg path{stroke-dasharray:24;stroke-dashoffset:24;animation:draw .55s .14s var(--ease) forwards;}
@keyframes draw{to{stroke-dashoffset:0;}}
.contact-sub{margin:clamp(28px,5vh,44px) 0 0;max-width:540px;color:var(--ink-2);font-size:clamp(1.02rem,1.4vw,1.18rem);text-wrap:pretty;}
.links{display:flex;gap:24px;margin-top:clamp(26px,4vh,40px);font-size:.84rem;}
.links a{position:relative;color:var(--ink);letter-spacing:.03em;}
.links a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:1px;background:var(--ink);transition:right .4s var(--ease);}
.links a:hover::after{right:0;}
/* cursor-following hint: a small tooltip that sits just above the pointer
   wherever it is over the email. JS sets left/top to the cursor; the transform
   anchors the pill's bottom-centre above that point. On copy, JS swaps its text
   to the "copied to clipboard" confirmation in place (see copyEmail). */
.copyhint{
  position:absolute;left:0;top:0;z-index:5;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;
  background:var(--ink);color:var(--bg);padding:7px 13px;border-radius:8px;
  white-space:nowrap;pointer-events:none;
  opacity:0;transform:translate(-50%,calc(-100% - 8px));
  transition:opacity .2s var(--ease),transform .2s var(--ease);
}
.copyhint::after{content:"";position:absolute;left:50%;bottom:-4px;width:8px;height:8px;background:var(--ink);transform:translateX(-50%) rotate(45deg);}
.copyhint.show{opacity:1;transform:translate(-50%,calc(-100% - 14px));}

/* ---------------- footer ---------------- */
.footer{border-top:1px solid var(--line);padding:40px 0;}
.footer .wrap{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;}
.footer .mono{font-size:.74rem;color:var(--ink-3);letter-spacing:.04em;}
.footer a.top{font-family:var(--mono);font-size:.74rem;color:var(--ink-2);letter-spacing:.1em;text-transform:uppercase;}

/* ---------------- reveal helper (no-JS safe: visible by default) ---------------- */
[data-reveal]{will-change:transform,opacity;}

/* ---------------- responsive ---------------- */
@media(max-width:720px){
  .topbar .loc{display:none;}
  .work-row{grid-template-columns:auto 1fr;}
  .work-item .meta{display:none;}
  .bar{padding:13px 15px;gap:11px;}
  .bar-state .lbl .txt{display:none;}
  .scrollcue{display:none;}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:0.001ms !important;animation-iteration-count:1 !important;transition-duration:0.001ms !important;scroll-behavior:auto !important;}
  .caret{display:none;}
}
