:root{
  --ink:#161514;
  --ink-raised:#222120;
  --ink-deep:#0B0B0A;
  --line:#403C37;
  --line-soft:#2A2825;
  --paper:#F2F0E9;
  --muted:#B4AEA5;
  --muted-dim:#8A847B;
  --signal:#EE2E31;
  --signal-dim:#9E3A3C;
  --ok:#5E8C6A;

  --serif:"Newsreader",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;

  --maxw:1120px;
  --pad:clamp(20px,5vw,64px);
  --section-y:clamp(72px,11vw,144px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }

body{
  margin:0;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--sans);
  font-size:clamp(16px,1.05vw,17px);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  /* faint blueprint grid */
  background-image:
    linear-gradient(var(--line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size:64px 64px, 64px 64px;
  background-position:center top;
}
body::before{
  /* fade the grid so it only whispers */
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(120% 90% at 50% 0%, transparent 0%, var(--ink) 72%);
}
/* project pages: flat background, no blueprint grid */
body.proj-page{background-image:none}
body.proj-page::before{display:none}

::selection{background:var(--signal);color:var(--ink-deep)}

a{color:inherit;text-decoration:none}
img{max-width:100%}

:focus-visible{
  outline:2px solid var(--signal);
  outline-offset:3px;
  border-radius:2px;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);position:relative;z-index:1}

/* ---------- type ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow .slash{color:var(--signal-dim)}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.01em;margin:0}
.display{
  font-size:clamp(2.6rem,6.4vw,5.1rem);
  font-weight:400;
  line-height:1.02;
  letter-spacing:-.02em;
}
.display em{font-style:italic;color:var(--signal)}
h2{font-size:clamp(1.9rem,3.4vw,2.8rem)}
.lead{
  font-size:clamp(1.05rem,1.5vw,1.22rem);
  color:var(--muted);
  max-width:46ch;
  line-height:1.62;
}
.mono{font-family:var(--mono)}

/* ---------- top bar ---------- */
header.bar{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(10px);
  background:color-mix(in srgb, var(--ink) 78%, transparent);
  border-bottom:1px solid var(--line-soft);
}
.bar-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:60px;
}
.brand{
  font-family:var(--mono);font-size:.82rem;letter-spacing:.04em;
  display:flex;align-items:center;gap:.7ch;color:var(--paper);
}
.brand .dot{width:7px;height:7px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 0 0 var(--signal);animation:beat 2.6s ease-in-out infinite}
@keyframes beat{
  0%,100%{box-shadow:0 0 0 0 rgba(238,46,49,.55)}
  50%{box-shadow:0 0 0 5px rgba(238,46,49,0)}
}
nav.links{display:flex;gap:clamp(14px,2vw,30px);font-family:var(--mono);font-size:.78rem;letter-spacing:.04em}
nav.links a{color:var(--muted);transition:color .2s}
nav.links a:hover{color:var(--paper)}
@media (max-width:680px){ nav.links{display:none} }

/* ---------- hero ---------- */
.hero{padding:clamp(56px,10vw,116px) 0 clamp(40px,7vw,72px)}
.hero-grid{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:clamp(28px,5vw,64px);
}
.hero-grid > div:first-child{display:flex;flex-direction:column;align-items:center}
.status{
  display:inline-flex;align-items:center;gap:1ch;line-height:1;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);border:1px solid var(--line);border-radius:999px;
  padding:.4em .85em;margin-bottom:1.6rem;
}
.status .live{
  width:7px;height:7px;border-radius:50%;background:var(--ok);transform:translateY(-1px);
  box-shadow:0 0 0 0 rgba(94,139,106,.55);
  animation:beat-ok 2.6s ease-in-out infinite;
}
@keyframes beat-ok{
  0%,100%{box-shadow:0 0 0 0 rgba(94,139,106,.55)}
  50%{box-shadow:0 0 0 5px rgba(94,139,106,0)}
}
.hero p.lead{margin:1.6rem 0 2.2rem;margin-left:auto;margin-right:auto}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:center}
.pipeline{width:100%;max-width:560px}
.btn{
  font-family:var(--mono);font-size:.82rem;letter-spacing:.03em;
  padding:.85em 1.4em;border-radius:6px;border:1px solid var(--line);
  display:inline-flex;align-items:center;gap:.7ch;transition:.22s ease;
  color:var(--paper);background:transparent;cursor:pointer;
}
.btn:hover{border-color:var(--signal);color:var(--signal);transform:translateY(-1px)}
.btn.primary{background:var(--signal);color:var(--ink-deep);border-color:var(--signal);font-weight:600}
.btn.primary:hover{background:#F2585A;color:var(--ink-deep)}
.btn .arr{transition:transform .22s ease}
.btn:hover .arr{transform:translateX(3px)}

/* ---------- live workflow (signature) ---------- */
.pipeline{
  background:var(--ink-raised);
  border:1px solid var(--line);
  border-radius:16px;
  position:relative;overflow:hidden;
  box-shadow:0 32px 80px -30px rgba(0,0,0,.7);
  width:100%;max-width:1000px;
  margin-top:clamp(24px,5vw,64px);
}
.pipeline::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(238,46,49,.5), transparent);
}
/* header */
.pipeline .cap{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:14px 20px;border-bottom:1px solid var(--line-soft);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;
}
.pipeline .cap .left{display:flex;align-items:center;gap:13px;min-width:0}
.pipeline .lights{display:flex;gap:8px}
.pipeline .lights span{width:12px;height:12px;border-radius:50%;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.18), inset 0 1px 1px rgba(255,255,255,.35);}
.pipeline .lights span:nth-child(1){background:#FF5F57}
.pipeline .lights span:nth-child(2){background:#FEBC2E}
.pipeline .lights span:nth-child(3){background:#28C840}
.pipeline .fname{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pipeline .fname .sl{color:var(--signal);margin:0 .35ch}
.pipeline .fname .doc{color:var(--paper)}
.pipeline .exec{
  display:inline-flex;align-items:center;gap:.7ch;white-space:nowrap;
  letter-spacing:.13em;text-transform:uppercase;color:var(--signal);
}
.pipeline .exec .live{
  width:7px;height:7px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 0 0 rgba(238,46,49,.55);animation:beat 2.4s ease-in-out infinite;
}
/* canvas */
.pipeline .canvas{
  padding:56px 32px;overflow-x:auto;
  background-image:radial-gradient(var(--line-soft) 1.1px, transparent 1.1px);
  background-size:24px 24px;
}
.pipeline .flow{display:flex;align-items:center;justify-content:center;min-width:max-content;margin:0 auto}
/* nodes */
.pipeline .node{
  flex:0 0 auto;width:200px;min-height:96px;position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;
  background:var(--ink-deep);border:1px solid var(--line);border-radius:12px;
  padding:18px 16px;
  transition:border-color .35s ease, box-shadow .35s ease, transform .35s ease;
}
.pipeline .node .head{display:flex;align-items:center;gap:.55ch}
.pipeline .node .ico{width:14px;height:14px;flex:0 0 auto;display:block;
  fill:none;stroke:var(--muted-dim);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  transition:stroke .35s ease;}
.pipeline .node .kind{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dim);transition:color .35s ease}
.pipeline .node .name{font-family:var(--mono);font-size:.9rem;white-space:nowrap;color:var(--muted);transition:color .35s ease}
.pipeline .node .name .mid{color:var(--signal-dim);margin:0 .3ch;transition:color .35s ease}
/* status badge */
.pipeline .node .badge{
  position:absolute;top:12px;right:12px;width:16px;height:16px;border-radius:50%;
  display:grid;place-items:center;opacity:0;transition:opacity .3s ease;
}
.pipeline .node.running .badge{
  opacity:1;border:2px solid rgba(238,46,49,.22);border-top-color:var(--signal);
  animation:spin .7s linear infinite;
}
.pipeline .node.done .badge{opacity:1;background:var(--signal)}
.pipeline .node.done .badge::after{content:"\2713";color:var(--ink-deep);font-size:9px;font-weight:700;line-height:1}
/* node states */
.pipeline .node.running .ico,.pipeline .node.done .ico{stroke:var(--signal)}
.pipeline .node.running .kind,.pipeline .node.done .kind{color:var(--muted)}
.pipeline .node.running .name,.pipeline .node.done .name{color:var(--paper)}
.pipeline .node.running .name .mid,.pipeline .node.done .name .mid{color:var(--signal)}
.pipeline .node.done{border-color:var(--signal-dim)}
.pipeline .node.running{
  border-color:var(--signal);transform:translateY(-2px);
  box-shadow:0 0 0 3px rgba(238,46,49,.10), 0 10px 26px -10px rgba(238,46,49,.5);
}
.pipeline .node.running::after{
  content:"";position:absolute;inset:-1px;border-radius:12px;
  border:1px solid var(--signal);opacity:0;pointer-events:none;
  animation:halo 1.8s ease-out infinite;
}
/* connectors */
.pipeline .link{flex:0 0 auto;position:relative;width:72px;height:14px}
.pipeline .link .wire{
  position:absolute;left:0;right:0;top:50%;height:2px;transform:translateY(-50%);
  background-image:linear-gradient(90deg, var(--signal) 60%, transparent 0);
  background-size:10px 2px;background-repeat:repeat-x;opacity:.18;
  transition:opacity .35s ease;
}
.pipeline .link.flowing .wire{opacity:.6;animation:march 1s linear infinite}
.pipeline .link.passed .wire{opacity:.5}
.pipeline .link .packet{
  position:absolute;top:50%;left:0;width:7px;height:7px;border-radius:50%;background:var(--signal);
  transform:translate(-50%,-50%);box-shadow:0 0 9px 1px rgba(238,46,49,.7);opacity:0;
}
/* comet trail */
.pipeline .link .packet::before{
  content:"";position:absolute;right:50%;top:50%;transform:translateY(-50%);
  width:28px;height:3px;border-radius:3px;
  background:linear-gradient(90deg, transparent, rgba(238,46,49,.65));
}
.pipeline .link.flowing .packet{animation:travel .95s ease-in-out forwards}
@keyframes march{ to{ background-position:10px 0 } }
@keyframes spin{ to{ transform:rotate(360deg) } }
@keyframes halo{ 0%{opacity:.55;transform:scale(1)} 100%{opacity:0;transform:scale(1.05)} }
@keyframes travel{
  0%{left:-2%;opacity:0} 12%{opacity:1} 88%{opacity:1} 100%{left:102%;opacity:0}
}
/* done pill */
.pipeline .done{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:.55ch;
  font-family:var(--mono);font-size:.95rem;
  background:transparent;border:1px solid var(--line);color:var(--muted-dim);
  border-radius:12px;padding:18px 20px;
  transition:color .4s ease, border-color .4s ease, background .4s ease;
}
.pipeline .done.on{
  background:rgba(238,46,49,.10);border-color:var(--signal-dim);color:var(--signal);
  animation:pop .45s ease;
}
.pipeline .done .check{font-weight:600}
@keyframes pop{ 0%{transform:scale(.94)} 55%{transform:scale(1.05)} 100%{transform:scale(1)} }

/* footer: live log + metrics */
.pipeline .foot{
  display:flex;justify-content:space-between;align-items:center;gap:14px 22px;flex-wrap:wrap;
  padding:13px 20px;border-top:1px solid var(--line-soft);
  font-family:var(--mono);font-size:.72rem;
}
.pipeline .log{display:inline-flex;align-items:center;gap:.7ch;color:var(--muted);min-width:0}
.pipeline .log .t{color:var(--muted-dim);flex:0 0 auto}
.pipeline .log .msg{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pipeline .log .cur{width:7px;height:13px;flex:0 0 auto;background:var(--signal);opacity:.85;animation:blink 1s steps(1) infinite}
@keyframes blink{ 50%{opacity:0} }
.pipeline .metrics{display:inline-flex;gap:6px;flex-wrap:wrap}
.pipeline .chip{border:1px solid var(--line);border-radius:6px;padding:.3em .6em;color:var(--muted-dim);white-space:nowrap}
.pipeline .chip b{color:var(--muted);font-weight:500}

@media (prefers-reduced-motion: reduce){
  .brand .dot,.status .live{animation:none}
  .pipeline .link .wire,.pipeline .link .packet,.pipeline .exec .live,
  .pipeline .node.running .badge,.pipeline .node.running::after,
  .pipeline .log .cur,.pipeline .done.on{animation:none}
}

@media (max-width:860px){
  .pipeline{max-width:600px}
  .pipeline .canvas{padding:30px 18px}
}

/* mobile: stack the pipeline top-to-bottom instead of horizontal scroll */
@media (max-width:600px){
  .pipeline .canvas{overflow-x:hidden;padding:26px 18px}
  .pipeline .flow{flex-direction:column;align-items:stretch;min-width:0;width:100%}
  .pipeline .node{width:100%;min-height:0;padding:16px 18px}
  .pipeline .done{align-self:center}
  /* connectors run vertically */
  .pipeline .link{width:14px;height:32px;margin:1px auto}
  .pipeline .link .wire{
    left:50%;right:auto;top:0;bottom:0;width:2px;height:auto;transform:translateX(-50%);
    background-image:linear-gradient(180deg, var(--signal) 60%, transparent 0);
    background-size:2px 10px;background-repeat:repeat-y;
  }
  .pipeline .link.flowing .wire{animation:march-v 1s linear infinite}
  .pipeline .link .packet{left:50%;top:0;transform:translate(-50%,-50%)}
  .pipeline .link .packet::before{
    right:auto;left:50%;top:auto;bottom:50%;transform:translateX(-50%);
    width:3px;height:26px;
    background:linear-gradient(180deg, transparent, rgba(238,46,49,.65));
  }
  .pipeline .link.flowing .packet{animation:travel-v .95s ease-in-out forwards}
}
@keyframes march-v{ to{ background-position:0 10px } }
@keyframes travel-v{
  0%{top:-2%;opacity:0} 12%{opacity:1} 88%{opacity:1} 100%{top:102%;opacity:0}
}

/* ---------- generic section ---------- */
.section{padding:var(--section-y) 0;border-top:1px solid var(--line-soft)}
.section-head{margin-bottom:clamp(32px,5vw,56px);max-width:60ch}
.section-head .eyebrow{margin-bottom:1rem}
.section-head p{color:var(--muted);margin:.9rem 0 0;max-width:52ch}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* ---------- work ---------- */
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:760px){ .work-grid{grid-template-columns:1fr} }
.project{
  display:block;color:inherit;
  background:var(--ink-raised);
  border:1px solid var(--line);
  border-radius:12px;
  padding:26px 26px 24px;
  position:relative;overflow:hidden;
  transition:border-color .25s ease, transform .25s ease;
}
.project:hover{border-color:var(--signal-dim);transform:translateY(-3px)}
.project::after{
  content:"";position:absolute;left:0;top:0;height:2px;width:0;background:var(--signal);
  transition:width .4s ease;
}
.project:hover::after{width:100%}
.p-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px}
.p-status{
  font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);display:inline-flex;align-items:center;gap:.55ch;white-space:nowrap;
  line-height:1;
}
.p-status .d{width:6px;height:6px;border-radius:50%;background:var(--ok);transform:translateY(-1px)}
.p-status.dev .d{background:var(--muted-dim)}
.p-kind{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-dim)}
.project h3{font-size:1.5rem;margin-bottom:.5rem}
.project p{color:var(--muted);margin:0 0 18px;font-size:.97rem}
.stack-tags{display:flex;flex-wrap:wrap;gap:7px}
.tag{
  font-family:var(--mono);font-size:.7rem;color:var(--muted);
  border:1px solid var(--line);border-radius:5px;padding:.3em .6em;
}
.p-link{
  margin-top:18px;display:inline-flex;align-items:center;gap:.5ch;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--muted-dim);
  transition:color .25s ease;
}
.project:hover .p-link{color:var(--signal)}
.p-link .arr{transition:transform .25s ease}
.project:hover .p-link .arr{transform:translateX(3px)}

/* ---------- stack rail (layered) ---------- */
.stack-rail{
  border:1px solid var(--line);border-radius:12px;overflow:hidden;
  background:var(--ink-raised);
}
.layer{
  display:grid;grid-template-columns:200px 1fr;align-items:stretch;
  border-bottom:1px solid var(--line-soft);
}
.layer:last-child{border-bottom:0}
.layer-label{
  display:flex;align-items:center;gap:.8ch;
  padding:22px 24px;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted-dim);
  border-right:1px solid var(--line-soft);
  background:linear-gradient(90deg, color-mix(in srgb, var(--signal) 5%, transparent), transparent);
}
.layer-label .ln{
  color:var(--signal-dim);font-size:.7rem;letter-spacing:.06em;
}
.layer-tools{
  display:flex;flex-wrap:wrap;
}
.layer-tools .item{
  flex:1 1 auto;min-width:150px;
  padding:18px 22px;
  border-right:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:5px;
  transition:background .22s ease;
  position:relative;
}
.layer-tools .item:last-child{border-right:0}
.layer-tools .item::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--signal);opacity:0;transition:opacity .22s ease;
}
.layer-tools .item:hover{background:color-mix(in srgb, var(--signal) 7%, transparent)}
.layer-tools .item:hover::before{opacity:.85}
.layer-tools .item .name{font-family:var(--mono);font-size:.95rem;color:var(--paper);transition:color .22s ease}
.layer-tools .item:hover .name{color:var(--signal)}
.layer-tools .item .role{font-size:.82rem;color:var(--muted)}
@media (max-width:680px){
  .layer{grid-template-columns:1fr}
  .layer-label{
    border-right:0;border-bottom:1px solid var(--line-soft);
    padding:12px 20px;
  }
}

/* ---------- approach (real sequence -> numbered) ---------- */
/* two-column shell: sticky aside + scrolling steps (single column on mobile) */
.approach{display:grid;grid-template-columns:1fr;gap:26px}
@media (min-width:900px){
  .approach{grid-template-columns:0.92fr 1.08fr;gap:clamp(32px,5vw,76px);align-items:start}
  .approach-aside{position:sticky;top:clamp(96px,20vh,168px);align-self:start}
}
.approach-aside .section-head{margin-bottom:30px}

/* vertical progress track (desktop only) */
.approach-track{list-style:none;margin:0;padding:0;position:relative;display:none}
@media (min-width:900px){ .approach-track{display:block} }
.approach-track::before{
  content:"";position:absolute;left:6px;top:14px;bottom:14px;width:2px;background:var(--line-soft);
}
.approach-track .tk{
  position:relative;display:flex;align-items:center;gap:14px;padding:11px 0;
  font-family:var(--mono);font-size:.92rem;color:var(--muted-dim);transition:color .4s ease;
}
.approach-track .tk-dot{
  position:relative;z-index:1;flex:none;width:14px;height:14px;border-radius:50%;
  border:2px solid var(--line);background:var(--ink);transition:border-color .4s ease, background .4s ease, box-shadow .4s ease;
}
.approach-track .tk-k{letter-spacing:.08em;color:var(--muted-dim);transition:color .4s ease}
.approach-track .tk-l{letter-spacing:.02em}
.approach-track .tk.done .tk-dot{border-color:var(--signal-dim);background:var(--signal-dim)}
.approach-track .tk.active{color:var(--paper)}
.approach-track .tk.active .tk-k{color:var(--signal)}
.approach-track .tk.active .tk-dot{border-color:var(--signal);background:var(--signal);box-shadow:0 0 0 5px rgba(238,46,49,.14)}

/* steps: card fallback (mobile + reduced-motion), scrollytelling on desktop */
.approach-steps{display:flex;flex-direction:column;gap:18px}
.astep{position:relative;padding:26px 24px;border:1px solid var(--line);border-radius:12px;background:var(--ink-raised)}
/* per-step line-art glyph that draws itself in when the step is active */
.astep-glyph{display:block;width:54px;height:54px;margin-bottom:20px;color:var(--muted-dim);transition:color .5s ease}
.astep.active .astep-glyph{color:var(--signal)}
.astep-glyph svg{display:block;width:100%;height:100%;overflow:visible}
.astep-glyph .g-draw{
  fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1;stroke-dashoffset:1;
  transition:stroke-dashoffset .7s ease, stroke .5s ease;
}
.astep-glyph .g-dot{
  fill:currentColor;opacity:0;transform:scale(.3);transform-origin:center;transform-box:fill-box;
  transition:opacity .4s ease, transform .4s ease, fill .5s ease;
}
.astep.active .astep-glyph .g-draw{stroke-dashoffset:0}
.astep.active .astep-glyph .g-dot{opacity:1;transform:none}
.astep-glyph svg > *:nth-child(2){transition-delay:.12s}
.astep-glyph svg > *:nth-child(3){transition-delay:.24s}
.astep-glyph svg > *:nth-child(4){transition-delay:.36s}
.astep-glyph svg > *:nth-child(5){transition-delay:.48s}
@media (prefers-reduced-motion: reduce){
  .astep-glyph .g-draw{stroke-dashoffset:0;transition:none}
  .astep-glyph .g-dot{opacity:1;transform:none;transition:none}
}
.astep .num{font-family:var(--mono);font-size:.8rem;color:var(--signal);letter-spacing:.1em;display:block;margin-bottom:14px}
.astep h3{font-size:clamp(1.4rem,3vw,2.1rem);line-height:1.15;margin-bottom:.7rem}
.astep p{color:var(--muted);margin:0;font-size:1.02rem;max-width:46ch}

@media (min-width:900px) and (prefers-reduced-motion: no-preference){
  .approach-steps{gap:0}
  /* glyph sits in a left gutter, vertically centered with the text */
  .astep{
    min-height:66vh;display:flex;flex-direction:row;align-items:center;
    gap:clamp(22px,2.4vw,38px);
    padding:0;border:0;border-radius:0;background:transparent;
    opacity:.25;transform:translateY(12px);
    transition:opacity .55s ease, transform .55s ease;
  }
  .astep.active{opacity:1;transform:none}
  .astep-glyph{flex:0 0 auto;margin-bottom:0;width:60px;height:60px}
  .astep-body{flex:1;min-width:0}
}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:start}
@media (max-width:760px){ .about-grid{grid-template-columns:1fr} }
.about-grid p{color:var(--muted);font-size:1.05rem;margin:0 0 1.2rem;max-width:50ch}
.about-grid p strong{color:var(--paper);font-weight:500}
.facts{border:1px solid var(--line);border-radius:12px;overflow:hidden}
@media (min-width:761px){
  /* keep the at-a-glance card in view while reading the taller bio column */
  .facts{position:sticky;top:88px;align-self:start}
}
.fact{display:flex;justify-content:space-between;gap:20px;padding:16px 20px;border-bottom:1px solid var(--line-soft)}
.fact:last-child{border-bottom:0}
.fact .k{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-dim)}
.fact .v{font-size:.95rem;color:var(--paper);text-align:right}

/* ---------- voice assistant ---------- */
.voice{
  display:grid;grid-template-columns:minmax(0,.8fr) 1fr;gap:clamp(16px,2.5vw,28px);
  align-items:stretch;
  background:var(--ink-raised);border:1px solid var(--line);border-radius:16px;
  padding:clamp(16px,2.5vw,24px);
  position:relative;overflow:hidden;
  box-shadow:0 32px 80px -30px rgba(0,0,0,.7);
}
.voice::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;z-index:3;
  background:linear-gradient(90deg, transparent, rgba(238,46,49,.5), transparent);
}
@media (max-width:720px){ .voice{grid-template-columns:1fr} }

/* left column: the real human — photo + real-voice intro */
.voice-human{display:flex;flex-direction:column;gap:12px;min-width:0}

/* photo */
.voice-photo{
  position:relative;flex:1 1 auto;border-radius:12px;overflow:hidden;min-height:240px;
  border:1px solid var(--line-soft);display:grid;place-items:center;
  background:radial-gradient(120% 120% at 30% 18%, #232220, var(--ink-deep));
}
.voice-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:scale(1.4);transform-origin:50% 100%}
.voice-photo .photo-fallback{font-family:var(--serif);font-size:4rem;color:var(--muted-dim)}
.voice-photo .photo-tag{
  position:absolute;left:12px;bottom:12px;z-index:2;
  display:inline-flex;align-items:center;gap:.55ch;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--paper);background:color-mix(in srgb, var(--ink-deep) 68%, transparent);
  border:1px solid var(--line);border-radius:999px;padding:.4em .7em;backdrop-filter:blur(4px);
}
.voice-photo .photo-tag .d{width:6px;height:6px;border-radius:50%;background:var(--ok)}

/* console */
.voice-console{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:15px;
  padding:clamp(22px,3vw,34px) clamp(12px,2vw,22px);
}

/* intro memo player (sits under the photo) */
.memo{
  display:inline-flex;align-items:center;gap:12px;width:100%;
  background:var(--ink-deep);border:1px solid var(--line);border-radius:10px;
  padding:11px 13px;cursor:pointer;color:var(--paper);text-align:left;
  transition:border-color .2s ease;
}
.memo:hover{border-color:var(--signal-dim)}
.memo-ico{
  width:30px;height:30px;flex:0 0 auto;border-radius:50%;
  display:grid;place-items:center;background:var(--signal);color:var(--ink-deep);
  font-size:.66rem;line-height:1;
}
.memo-text{display:flex;flex-direction:column;gap:1px;min-width:0}
.memo-title{font-family:var(--mono);font-size:.78rem;color:var(--paper)}
.memo-sub{font-family:var(--mono);font-size:.66rem;color:var(--muted-dim)}
.memo-wave{margin-left:auto;display:flex;align-items:center;gap:3px;height:18px;opacity:.45}
.memo-wave i{width:3px;height:6px;background:var(--muted-dim);border-radius:2px}
.memo.playing .memo-wave{opacity:1}
.memo.playing .memo-wave i{background:var(--signal);animation:wave 1s ease-in-out infinite}
.memo.playing .memo-wave i:nth-child(2){animation-delay:.15s}
.memo.playing .memo-wave i:nth-child(3){animation-delay:.3s}
.memo.playing .memo-wave i:nth-child(4){animation-delay:.45s}
.memo.playing .memo-wave i:nth-child(5){animation-delay:.6s}
@keyframes wave{0%,100%{height:5px}50%{height:16px}}

.voice .mic{
  width:96px;height:96px;border-radius:50%;border:none;cursor:pointer;
  display:grid;place-items:center;position:relative;margin-bottom:4px;
  background:var(--signal);color:var(--ink-deep);
  transition:transform .2s ease, background .2s ease;
}
.voice .mic:hover{transform:translateY(-2px);background:#F2585A}
.voice .mic svg{width:34px;height:34px;fill:none;stroke:currentColor;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.voice .mic::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  border:1px solid var(--signal);opacity:0;pointer-events:none;
}
.voice .mic.live{background:#F2585A}
.voice .mic.live::after{animation:ring 1.6s ease-out infinite}
@keyframes ring{0%{opacity:.6;transform:scale(1)}100%{opacity:0;transform:scale(1.45)}}
.voice .vstatus{font-family:var(--mono);font-size:.82rem;letter-spacing:.04em;color:var(--paper)}
.voice .vnote{color:var(--muted);max-width:48ch;font-size:.97rem;margin:0}
.voice .vchips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.voice .vchip{font-family:var(--mono);font-size:.7rem;color:var(--muted);
  border:1px solid var(--line);border-radius:5px;padding:.35em .7em}
.voice .disclaimer{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted-dim)}
@media (prefers-reduced-motion: reduce){
  .voice .mic.live::after,.memo.playing .memo-wave i{animation:none}
}

/* ---------- contact ---------- */
.contact{text-align:left}
.contact .display{max-width:18ch;margin-bottom:1.6rem}
.contact .lead{margin-bottom:2.2rem}
.contact .cta-row{justify-content:flex-start}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line-soft);padding:34px 0;margin-top:var(--section-y)}
.foot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;color:var(--muted-dim)}
.foot-inner a{color:var(--muted)}
.foot-inner a:hover{color:var(--signal)}

/* ---------- project detail page ---------- */
.proj-hero{padding:clamp(40px,7vw,88px) 0 clamp(20px,4vw,36px)}
.back-link{
  font-family:var(--mono);font-size:.76rem;letter-spacing:.04em;color:var(--muted);
  display:inline-flex;align-items:center;gap:.6ch;margin-bottom:clamp(24px,4vw,44px);
  transition:color .2s ease;
}
.back-link:hover{color:var(--signal)}
.back-link .arr{transition:transform .2s ease}
.back-link:hover .arr{transform:translateX(-3px)}
.proj-meta{display:flex;flex-wrap:wrap;gap:10px 16px;align-items:center;margin-bottom:1.4rem}
.proj-title{font-size:clamp(2.2rem,5.4vw,3.8rem);line-height:1.02;letter-spacing:-.02em;margin-bottom:1.2rem}
.proj-summary{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--muted);max-width:60ch;line-height:1.6;margin:0 0 1.6rem}
.proj-grid{display:grid;grid-template-columns:1.55fr .9fr;gap:clamp(28px,5vw,56px);align-items:start}
/* let the sidebar column fill the row height so the sticky spec has room to travel */
.proj-grid > aside{align-self:stretch}
@media (max-width:760px){
  .proj-grid{grid-template-columns:1fr}
  .spec{position:static}
}
.proj-section{margin-bottom:clamp(28px,4vw,44px)}
.proj-section:last-child{margin-bottom:0}
.proj-section h2{font-size:clamp(1.5rem,2.6vw,2rem);margin-bottom:1rem}
.proj-section p{color:var(--muted);max-width:64ch;margin:0 0 1rem}
.proj-section ul{color:var(--muted);max-width:64ch;margin:0;padding-left:1.2em}
.proj-section li{margin-bottom:.55rem}
.proj-section li::marker{color:var(--signal-dim)}
.proj-section li strong{color:var(--paper);font-weight:500}
.spec{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--ink-raised);position:sticky;top:84px}
.spec .row{display:flex;justify-content:space-between;gap:16px;padding:14px 18px;border-bottom:1px solid var(--line-soft)}
.spec .row:last-child{border-bottom:0}
.spec .k{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-dim)}
.spec .v{font-size:.92rem;color:var(--paper);text-align:right}
.metrics-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:1.4rem}
@media (max-width:560px){ .metrics-row{grid-template-columns:1fr} }
.metric{border:1px solid var(--line);border-radius:12px;padding:20px;background:var(--ink-raised)}
.metric .big{font-family:var(--serif);font-size:1.9rem;color:var(--signal);display:block;line-height:1}
.metric .lbl{font-family:var(--mono);font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);display:block;margin-top:8px}
.proj-next{text-align:left}
.proj-next h2{max-width:20ch;margin-bottom:1.2rem}
.proj-next .cta-row{justify-content:flex-start}

/* ---------- project proof / screenshots ---------- */
.proof{display:grid;gap:18px}
.proof.two{grid-template-columns:1fr 1fr}
@media (max-width:680px){ .proof.two{grid-template-columns:1fr} }
.shot{
  margin:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;
  background:var(--ink-raised);box-shadow:0 24px 60px -34px rgba(0,0,0,.7);
}
.shot .bar{
  display:flex;align-items:center;gap:13px;padding:11px 14px;border-bottom:1px solid var(--line-soft);
  font-family:var(--mono);font-size:.7rem;letter-spacing:.04em;color:var(--muted);
}
.shot .lights{display:flex;gap:7px;flex:0 0 auto}
.shot .lights span{width:11px;height:11px;border-radius:50%;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.18), inset 0 1px 1px rgba(255,255,255,.35)}
.shot .lights span:nth-child(1){background:#FF5F57}
.shot .lights span:nth-child(2){background:#FEBC2E}
.shot .lights span:nth-child(3){background:#28C840}
.shot .bar .fname{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.shot .bar .fname .sl{color:var(--signal)}
.shot .frame{
  position:relative;aspect-ratio:16/10;overflow:hidden;
  background:
    radial-gradient(var(--line-soft) 1.1px, transparent 1.1px) 0 0/22px 22px,
    var(--ink-deep);
}
/* auto-cycling slides — image fills the frame (crops overflow), crossfading */
.shot .slides{position:absolute;inset:0}
.shot .slide{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;
  opacity:0;transition:opacity .6s ease;
}
.shot .slide.on{opacity:1}
.shot .dots:not(:empty){
  position:absolute;left:50%;transform:translateX(-50%);bottom:10px;z-index:3;
  display:flex;gap:6px;padding:6px 9px;border-radius:999px;
  background:color-mix(in srgb, var(--ink-deep) 55%, transparent);backdrop-filter:blur(4px);
}
.shot .dots .dot{
  width:7px;height:7px;border-radius:50%;background:var(--muted-dim);opacity:.5;cursor:pointer;
  transition:background .3s ease, opacity .3s ease, transform .2s ease;
}
.shot .dots .dot:hover{opacity:1;transform:scale(1.25)}
.shot .dots .dot.on{background:var(--signal);opacity:1}
.shot .ph{
  position:absolute;inset:0;z-index:4;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:24px;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--muted-dim);
}
.shot .ph svg{width:30px;height:30px;fill:none;stroke:var(--muted-dim);stroke-width:1.5;
  stroke-linecap:round;stroke-linejoin:round}
.shot .ph code{color:var(--muted);font-size:.7rem}
.shot figcaption{
  padding:12px 14px;border-top:1px solid var(--line-soft);
  font-family:var(--mono);font-size:.7rem;letter-spacing:.02em;color:var(--muted);
}
