/* ============================================================================
   styles.css — Tom Harpaz portfolio V2 · dark "warm terminal" OS
   ========================================================================== */

/* ---- TOKENS ------------------------------------------------------------- */
:root {
  --bg:#16150F; --surface:#1E1D16; --surface-2:#26241B; --surface-3:#2E2C21;
  --ink:#F4F1E8; --ink-dim:#B7B3A4; --muted:#A6A092;
  --line:rgba(244,241,232,.12); --line-strong:rgba(244,241,232,.22);
  --acid:#B6F23A; --blue:#7C97FF; --coral:#FF7A63;

  --bar-top:48px; --rail-w:190px; --bar-bot:30px;

  --r-win:10px; --r-ctl:6px; --r-pill:999px;
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px; --s7:48px; --s8:64px; --s9:96px;

  --ease:cubic-bezier(.2,.8,.2,1); --fast:140ms; --scene:420ms;

  --sans:"Inter","SF Pro Display",-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
  --mono:ui-monospace,"SF Mono","JetBrains Mono","Menlo","Consolas",monospace;
  --serif:Georgia,"Times New Roman",serif;

  --shadow:0 1px 0 rgba(255,255,255,.04) inset, 0 24px 60px -28px rgba(0,0,0,.8);
}

/* ---- RESET / BASE ------------------------------------------------------- */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow:hidden;
}
button{font-family:inherit;color:inherit;cursor:pointer;background:none;border:none}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
::selection{background:var(--acid);color:var(--bg)}
:focus-visible{outline:2px solid var(--acid);outline-offset:2px;border-radius:3px}

h1,h2,h3{font-weight:600;line-height:1.05;letter-spacing:-.01em}
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--coral)}

.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;
  background-image:repeating-linear-gradient(0deg,#fff 0 1px,transparent 1px 3px);
  mix-blend-mode:overlay}

/* ---- BOOT --------------------------------------------------------------- */
.boot{position:fixed;inset:0;z-index:200;display:grid;place-items:center;background:var(--bg);
  transition:opacity .5s var(--ease)}
.boot.is-done{opacity:0;pointer-events:none}
.boot-window{width:min(540px,90vw);border:1px solid var(--line-strong);border-radius:var(--r-win);
  background:var(--surface);box-shadow:var(--shadow);overflow:hidden}
.boot-bar{display:flex;align-items:center;gap:6px;height:34px;padding:0 12px;
  border-bottom:1px solid var(--line);background:var(--surface-2)}
.boot-bar span{width:9px;height:9px;border-radius:50%}
.boot-bar span:nth-child(1){background:#ff5f57}
.boot-bar span:nth-child(2){background:#febc2e}
.boot-bar span:nth-child(3){background:#28c840}
.boot-bar b{margin-left:8px;font:500 11px/1 var(--mono);color:var(--muted)}
.boot-body{padding:20px;min-height:160px;font:13px/1.9 var(--mono);color:var(--ink-dim);white-space:pre-wrap}
.boot-body .ok{color:var(--acid)}

/* ---- APP FRAME (caps + centers the OS on large displays) ---------------- */
.app{position:fixed;inset:0;z-index:5}   /* full-bleed; scales up on large displays (see large-screen media) */

/* ---- MENU BAR ----------------------------------------------------------- */
.menubar{position:absolute;z-index:60;top:0;left:0;right:0;height:var(--bar-top);
  display:flex;align-items:center;justify-content:space-between;padding:0 var(--s4);
  border-bottom:1px solid var(--line);background:rgba(22,21,15,.82);backdrop-filter:blur(14px)}
.brand{display:flex;align-items:center;gap:9px}
.brand-dot{width:8px;height:8px;border-radius:50%;background:var(--acid);box-shadow:0 0 10px var(--acid)}
.brand-mark{font:700 13px/1 var(--mono);letter-spacing:.05em}
.brand-path{font:500 12px/1 var(--mono);color:var(--muted)}
.brand-path i{color:var(--line-strong);font-style:normal;margin:0 2px}
.menubar-right{display:flex;align-items:center;gap:var(--s4)}
.crumb{font:500 12px/1 var(--mono);color:var(--ink-dim)}
.menu-btn{display:none;width:36px;height:36px;border:1px solid var(--line);border-radius:var(--r-ctl);
  place-items:center}
.menu-btn i{width:18px;height:18px}

/* ---- RAIL (file-tree nav) ---------------------------------------------- */
.rail{position:absolute;z-index:50;top:var(--bar-top);bottom:var(--bar-bot);left:0;width:var(--rail-w);
  display:flex;flex-direction:column;padding:var(--s5) var(--s3);
  border-right:1px solid var(--line);background:var(--surface)}
.rail-label,.rail-hint{font:600 10px/1.4 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.rail-label{color:var(--coral);margin:0 var(--s2) var(--s4)}
.rail-hint{margin-top:auto;padding:0 var(--s2);opacity:.6}
.rail-tree{display:flex;flex-direction:column;gap:2px}
.rail-node{display:flex;align-items:center;gap:9px;width:100%;padding:11px 10px;text-align:left;
  border-left:2px solid transparent;border-radius:var(--r-ctl);color:var(--ink-dim);
  font:500 12.5px/1 var(--mono);transition:all var(--fast) var(--ease)}
.rail-node .ix{color:var(--muted);font-size:11px}
.rail-node i{width:15px;height:15px;color:var(--muted)}
.rail-node .rail-logo{width:15px;height:15px;filter:brightness(0) invert(1);opacity:.62}
.rail-node.is-active .rail-logo{opacity:1}
.rail-node:hover{background:var(--surface-2);color:var(--ink)}
.rail-node.is-active{background:var(--surface-2);color:var(--ink);border-left-color:var(--acid)}
.rail-node.is-active i,.rail-node.is-active .ix{color:var(--acid)}
.rail-node .tick{margin-left:auto;color:var(--acid);opacity:0}
.rail-node.is-active .tick{opacity:1}

/* ---- STATUS BAR --------------------------------------------------------- */
.statusbar{position:absolute;z-index:60;bottom:0;left:0;right:0;height:var(--bar-bot);
  display:flex;align-items:center;justify-content:space-between;padding:0 var(--s4);
  border-top:1px solid var(--line);background:var(--surface);font:500 11px/1 var(--mono);color:var(--muted)}
.status-left{display:flex;align-items:center;gap:8px;color:var(--ink-dim)}
.run-dot{width:7px;height:7px;border-radius:50%;background:var(--acid)}
.status-mid{display:none}
.status-claude{display:flex;align-items:center;gap:7px;padding:0 0 0 var(--s4);
  border-left:1px solid var(--line);color:var(--ink-dim);transition:color var(--fast)}
.status-claude{cursor:default}
.status-claude .claude-mark{width:14px;height:14px;filter:brightness(0) invert(1);opacity:.85;transition:opacity var(--fast)}
.status-claude:hover{color:var(--ink)}
.status-claude:hover .claude-mark{opacity:1;animation:claudeBounce .7s var(--ease)}
@keyframes claudeBounce{0%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}60%{transform:translateY(-1px)}}

/* ---- STAGE / SCENES ----------------------------------------------------- */
.stage{position:absolute;top:var(--bar-top);left:var(--rail-w);right:0;bottom:var(--bar-bot);
  z-index:5;padding:var(--s5)}
.scene{position:absolute;inset:var(--s5);opacity:0;pointer-events:none;
  transform:translateY(12px) scale(.996);transition:opacity var(--scene) var(--ease),transform var(--scene) var(--ease)}
.scene.is-active{opacity:1;pointer-events:auto;transform:none}

/* window framing per scene */
.scene-win{display:flex;flex-direction:column;height:100%;border:1px solid var(--line-strong);
  border-radius:var(--r-win);background:var(--surface);box-shadow:var(--shadow);overflow:hidden}
.win-bar{display:flex;align-items:center;gap:10px;height:40px;padding:0 14px;flex:0 0 auto;
  border-bottom:1px solid var(--line);background:var(--surface-2)}
.lights{display:flex;gap:6px}
.lights i{width:9px;height:9px;border-radius:50%}
.lights i:nth-child(1){background:#ff5f57}
.lights i:nth-child(2){background:#febc2e}
.lights i:nth-child(3){background:#28c840}
.win-name{font:500 11.5px/1 var(--mono);color:var(--muted)}
.pager{display:flex;align-items:center;gap:var(--s3);margin-left:auto}
.pager button{font:500 11px/1 var(--mono);color:var(--ink-dim);padding:6px 8px;border-radius:4px;transition:all var(--fast)}
.pager button:hover{color:var(--ink);background:var(--surface-3)}
.pager button:disabled{opacity:.3;cursor:default}
.win-body{flex:1 1 auto;overflow:auto;padding:clamp(24px,4vw,52px);scroll-behavior:smooth}
.win-foot{margin-top:var(--s7);padding-top:var(--s5);border-top:1px solid var(--line)}
.scene-next{display:flex;align-items:center;justify-content:space-between;width:100%;gap:var(--s4)}
.next-back{display:inline-flex;align-items:center;gap:8px;font:500 12px/1 var(--mono);color:var(--muted);padding:8px 0;transition:color var(--fast)}
.next-back:hover{color:var(--ink)}
.next-back i{width:14px;height:14px}
.next-cta{display:inline-flex;align-items:center;gap:12px;padding:14px 22px;border:1px solid var(--acid);
  border-radius:var(--r-ctl);background:transparent;transition:background var(--fast) var(--ease)}
.next-cta .nc-k{font:600 9px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--acid)}
.next-cta .nc-v{font:600 16px/1 var(--sans);color:var(--ink)}
.next-cta i{width:18px;height:18px;color:var(--acid);transition:transform var(--fast) var(--ease)}
.next-cta:hover{background:var(--acid)}
.next-cta:hover .nc-k,.next-cta:hover .nc-v,.next-cta:hover i{color:var(--bg)}
.next-cta:hover i{transform:translateX(4px)}
@media (max-width:560px){.scene-next{flex-direction:column-reverse;align-items:stretch;gap:var(--s3)}.next-cta{justify-content:center}}

/* shared content rhythm */
.scene-head{max-width:760px;margin-bottom:var(--s6)}
.scene-head h1,.scene-head h2{margin:var(--s3) 0 var(--s4)}
.scene-head h1{font-size:clamp(40px,5.4vw,76px);line-height:1.02}
.scene-head h2{font-size:clamp(32px,4.2vw,58px)}
.scene-head .lede{color:var(--ink-dim);font-size:clamp(16px,1.5vw,20px);line-height:1.5;max-width:680px}
em.serif{font-family:var(--serif);font-style:italic;color:var(--blue);font-weight:400}

/* ---- OVERVIEW ----------------------------------------------------------- */
.hero{display:grid;grid-template-columns:1.3fr .9fr;gap:var(--s7);align-items:start}
@media (max-width:1040px){.hero{grid-template-columns:1fr;gap:var(--s6)}}
.hero h1{font-size:clamp(40px,5vw,72px);line-height:1.02;margin:var(--s4) 0}
.hero .lede{color:var(--ink-dim);font-size:clamp(17px,1.6vw,22px);max-width:620px}
.pillars{display:flex;gap:var(--s3);margin-top:var(--s5)}
.pillar{flex:1;padding:var(--s4);border:1px solid var(--line);border-radius:var(--r-ctl);background:var(--surface-2)}
.pillar span{font:600 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase}
.pillar:nth-child(1) span{color:var(--acid)} .pillar:nth-child(2) span{color:var(--blue)} .pillar:nth-child(3) span{color:var(--coral)}
.pillar strong{display:block;margin-top:8px;font-weight:500;color:var(--ink-dim);font-size:13px;line-height:1.4}
@media (max-width:1040px){.pillars{flex-wrap:wrap}}
/* signal console */
.console{border:1px solid var(--line-strong);border-radius:var(--r-win);background:var(--bg);overflow:hidden}
.console-bar{display:flex;align-items:center;gap:8px;height:34px;padding:0 12px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.console-bar .lights i{width:8px;height:8px}
.console-bar b{font:500 11px/1 var(--mono);color:var(--muted)}
.console-body{padding:var(--s5)}
.console-row{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px dashed var(--line)}
.console-row:last-child{border-bottom:none}
.console-row .val{font:600 34px/1 var(--sans);color:var(--ink);min-width:168px;white-space:nowrap}
.console-row .val .suf{color:var(--acid)}
.console-row .val .before{color:var(--coral);text-decoration:line-through;font-size:22px}
.console-row .val .to{color:var(--muted);margin:0 6px;font-size:18px}
.console-row .val .after{color:var(--acid);font-size:24px}
.console-row .lab{font:500 13px/1.4 var(--mono);color:var(--ink-dim)}

/* ---- WORK --------------------------------------------------------------- */
.stat-strip{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);
  border-radius:var(--r-ctl);overflow:hidden;margin:var(--s5) 0 var(--s7)}
.stat-strip .stat{padding:var(--s5);border-right:1px solid var(--line)}
.stat-strip .stat:last-child{border-right:none}
.stat .num{font:600 38px/1 var(--sans);color:var(--ink)}
.stat .num .suf{color:var(--acid)}
.stat .lab{margin-top:8px;font:500 12.5px/1.45 var(--mono);color:var(--muted)}
@media (max-width:760px){.stat-strip{grid-template-columns:1fr}.stat-strip .stat{border-right:none;border-bottom:1px solid var(--line)}}

.cards{display:grid;gap:var(--s5)}
.cards-2{grid-template-columns:repeat(2,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr);margin-top:var(--s5)}
@media (max-width:980px){.cards-2,.cards-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.cards-2,.cards-3{grid-template-columns:1fr}}
.card{position:relative;display:flex;flex-direction:column;min-height:340px;padding:var(--s5);text-align:left;
  border:1px solid var(--line);border-radius:var(--r-win);background:var(--surface-2);
  transition:transform var(--fast) var(--ease),border-color var(--fast)}
.card:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.card-expand{position:absolute;top:16px;right:16px;width:16px;height:16px;color:var(--muted);
  transition:color var(--fast),transform var(--fast)}
.card:hover .card-expand{color:var(--acid);transform:translate(2px,-2px)}
.card-meta{display:flex;align-items:center;gap:8px;font:500 10.5px/1 var(--mono);color:var(--muted);padding-right:28px}
/* example screenshot thumbnail — right-aligned in the foot, doesn't resize the card, no text wrap */
.card-shot{position:relative;flex:0 0 auto;margin-left:auto;height:48px;border:1px solid var(--line);border-radius:var(--r-ctl);
  overflow:hidden;cursor:zoom-in;background:var(--bg);transition:border-color var(--fast),transform var(--fast)}
.card-shot img{display:block;height:48px;width:auto;max-width:160px}
.card-shot:hover{border-color:var(--acid);transform:translateY(-2px)}
.logo-pill.is-big{height:42px}
.logo-pill.is-big img{max-height:42px}
/* centered magnifier (so it's clearly a preview); reveals "preview" on hover */
.shot-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:7px;
  background:rgba(8,8,6,.30);color:#fff;transition:background var(--fast)}
.shot-zoom svg{width:16px;height:16px}
.shot-label{display:none;font:700 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase}
.card-shot:hover .shot-zoom,.panel-shot:hover .shot-zoom{background:rgba(8,8,6,.6)}
.card-shot:hover .shot-label,.panel-shot:hover .shot-label{display:inline}
.card-well{margin:var(--s4) 0;padding:var(--s4);min-height:150px;border:1px solid var(--line);border-radius:var(--r-ctl);
  background:var(--bg);display:grid;place-items:center;overflow:hidden}
.card h3{font-size:22px;margin-bottom:8px}
.card p{color:var(--ink-dim);font-size:14px;line-height:1.55}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:var(--s4)}
.open-cue{font:500 11px/1 var(--mono);color:var(--blue)}

/* ---- CHIPS (Impact / Innovation / Speed) -------------------------------- */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:var(--s4) 0}
.chip{display:flex;align-items:center;gap:8px;padding:6px 11px;border:1px solid var(--line);
  border-radius:var(--r-ctl);background:var(--surface-2)}
.chip::before{content:"";width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.chip--impact::before{background:var(--acid)}
.chip--innovation::before{background:var(--blue)}
.chip--speed::before{background:var(--coral)}
.chip .k{font:600 9px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.chip .v{font:500 12.5px/1 var(--mono);color:var(--ink)}
.chip .k::after{content:" ·"}

/* ---- DETAIL PANEL / POPOVER OVERLAYS ------------------------------------ */
.overlay{position:fixed;inset:0;z-index:120;visibility:hidden;pointer-events:none}
.overlay.is-open{visibility:visible;pointer-events:auto}
.overlay-backdrop{position:absolute;inset:0;width:100%;height:100%;background:rgba(8,8,6,.6);
  opacity:0;transition:opacity var(--scene) var(--ease)}
.overlay.is-open .overlay-backdrop{opacity:1}
.panel{position:absolute;top:0;right:0;bottom:0;width:min(840px,92vw);display:flex;flex-direction:column;
  background:var(--surface);border-left:1px solid var(--line-strong);box-shadow:-30px 0 80px rgba(0,0,0,.5);
  transform:translateX(100%);transition:transform var(--scene) var(--ease)}
.overlay.is-open .panel{transform:none}
.panel-bar,.pop .panel-bar{display:flex;align-items:center;gap:10px;height:40px;padding:0 14px;flex:0 0 auto;
  border-bottom:1px solid var(--line);background:var(--surface-2)}
.panel-barname{font:500 11.5px/1 var(--mono);color:var(--muted)}
.panel-close{margin-left:auto;width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--line);
  border-radius:var(--r-ctl)}
.panel-close i{width:15px;height:15px}
.panel-close:hover{border-color:var(--line-strong)}
.panel-body{flex:1 1 auto;overflow:auto;padding:clamp(26px,4vw,52px)}
/* detail panel: text left, example screenshot pinned top-right (consistent), no wrap */
.panel-head{display:flex;align-items:flex-start;gap:var(--s6);margin-bottom:var(--s5)}
.panel-head-text{flex:1;min-width:0}
.panel-shot{position:relative;flex:0 0 auto;width:300px;border:1px solid var(--line);border-radius:var(--r-ctl);
  overflow:hidden;cursor:zoom-in;background:var(--bg);transition:border-color var(--fast)}
.panel-shot img{display:block;width:100%;height:auto}
.panel-shot:hover{border-color:var(--acid)}
.panel-shot .shot-zoom svg{width:20px;height:20px}
.panel-shot .shot-label{font-size:12px}
@media (max-width:760px){.panel-head{flex-direction:column}.panel-shot{width:100%}}
.panel-body .kicker{font:600 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--coral)}
.panel-body h2{font-size:clamp(30px,4vw,48px);margin:var(--s3) 0 var(--s4);max-width:620px}
.panel-body .summary{color:var(--ink-dim);font-size:17px;line-height:1.55;max-width:640px}
.panel-graphic{margin:var(--s5) 0;padding:var(--s5);border:1px solid var(--line);border-radius:var(--r-ctl);
  background:var(--bg);display:grid;place-items:center;min-height:180px}
.wwh{display:grid;gap:0;margin-top:var(--s4)}
.wwh section{padding:var(--s5) 0;border-top:1px solid var(--line)}
.wwh h4{display:flex;align-items:center;gap:10px;font:600 11px/1 var(--mono);letter-spacing:.12em;
  text-transform:uppercase;color:var(--acid);margin-bottom:10px}
.wwh h4 span{color:var(--muted);font-weight:500}
.wwh--why h4{color:var(--coral)} .wwh--what h4{color:var(--blue)} .wwh--how h4{color:var(--acid)}
.wwh p{color:var(--ink-dim);font-size:15px;line-height:1.65;max-width:680px}
.mech{margin-top:var(--s5);padding-top:var(--s5);border-top:1px solid var(--line)}
.mech>h4{display:flex;align-items:center;gap:10px;font:600 11px/1 var(--mono);letter-spacing:.12em;
  text-transform:uppercase;color:var(--blue);margin-bottom:var(--s4)}
.mech-steps{display:flex;flex-direction:column;gap:var(--s3)}
.mech-step{display:flex;gap:14px;align-items:flex-start}
.mech-n{flex:0 0 auto;width:24px;height:24px;display:grid;place-items:center;border:1px solid var(--line-strong);
  border-radius:50%;font:600 11px/1 var(--mono);color:var(--acid)}
.mech-step b{font:600 14px/1.3 var(--sans);color:var(--ink)}
.mech-step p{margin-top:3px;color:var(--ink-dim);font-size:13.5px;line-height:1.55}
.mech-note{margin-top:var(--s4);padding:var(--s4);border-left:2px solid var(--acid);background:var(--surface-2);
  border-radius:0 var(--r-ctl) var(--r-ctl) 0;color:var(--ink-dim);font-size:13.5px;line-height:1.6}
.scroll-cue{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);padding:7px 14px;
  border:1px solid var(--line-strong);border-radius:999px;background:var(--surface-2);
  font:600 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);
  pointer-events:none;z-index:3;animation:cueBob 1.5s ease-in-out infinite}
@keyframes cueBob{50%{transform:translateX(-50%) translateY(5px)}}

/* PM OS popover */
.pop{position:absolute;left:50%;top:50%;width:min(620px,92vw);
  transform:translate(-50%,-46%) scale(.97);opacity:0;
  border:1px solid var(--line-strong);border-radius:var(--r-win);background:var(--surface);
  box-shadow:var(--shadow);overflow:hidden;transition:transform var(--scene) var(--ease),opacity var(--scene)}
.overlay.is-open .pop{transform:translate(-50%,-50%);opacity:1}
.pop-body{padding:var(--s6)}
.pop-body h3{font-size:26px;margin-bottom:var(--s3)}
.pop-body p{color:var(--ink-dim);font-size:15px;line-height:1.65}
.pop-steps{display:flex;flex-wrap:wrap;gap:8px;margin-top:var(--s5)}
.pop-steps span{padding:8px 10px;border:1px solid var(--line);border-radius:var(--r-ctl);background:var(--bg);
  font:500 11px/1 var(--mono);color:var(--ink-dim)}

/* ---- ENTERPRISE --------------------------------------------------------- */
.through{margin:var(--s4) 0 var(--s5);padding:var(--s4) var(--s5);border-left:2px solid var(--acid);
  background:var(--surface-2);border-radius:0 var(--r-ctl) var(--r-ctl) 0;color:var(--ink-dim);font-size:15px;line-height:1.55;max-width:760px}
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}
@media (max-width:980px){.cases{grid-template-columns:1fr}}
.case{position:relative;display:flex;flex-direction:column;text-align:left;min-height:300px;padding:var(--s5);
  border:1px solid var(--line);border-radius:var(--r-win);background:var(--surface-2);
  transition:transform var(--fast) var(--ease),border-color var(--fast)}
.case-spotlight{position:absolute;top:var(--s4);right:var(--s4);padding:4px 9px;border:1px solid rgba(255,122,99,.5);
  border-radius:999px;font:600 8.5px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--coral)}
.open-cue-lg{font-size:13px;color:var(--acid)}
.cards-label,.cases-label{margin:var(--s6) 0 var(--s4);font:600 11px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--coral)}
.process-label{margin:var(--s5) 0 var(--s3);font:600 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--blue)}
.case:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.case-logo{display:flex;align-items:center;margin-bottom:var(--s4);padding-bottom:var(--s4);border-bottom:1px solid var(--line)}
.case-logo .logo-pill{height:36px}
.case-logo .logo-pill img{max-height:32px;max-width:150px}
.case-logo .logo-pill b{font-size:19px}
.case-role{font:600 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--coral)}
.case h3{font-size:21px;margin:8px 0}
.case p{color:var(--ink-dim);font-size:14px;line-height:1.55}
.case .open-cue{margin-top:auto;padding-top:var(--s4)}

/* Real brand marks in natural color on transparent (no chips). Comcast/L'Oreal use
   pre-whitened local PNGs since their real marks are dark and vanish on the dark theme. */
.logo-pill{position:relative;display:inline-flex;align-items:center;justify-content:center;height:30px}
.logo-pill img{max-height:30px;max-width:120px;width:auto;display:block;border-radius:5px;
  opacity:.85;transition:opacity var(--fast)}
.logo-pill:hover img{opacity:1}
.logo-pill b{display:none;font:600 16px/1 var(--sans);color:var(--ink-dim);white-space:nowrap}
.logo-pill.noimg img{display:none} .logo-pill.noimg b{display:inline}
.logo-pill.noimg:hover b{color:var(--ink)}

.logo-river-label{margin:var(--s7) 0 var(--s4);font:600 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.logo-river{display:flex;flex-wrap:wrap;gap:var(--s5) var(--s6);align-items:center;
  padding:var(--s6) var(--s5);border:1px solid var(--line);border-radius:var(--r-ctl);background:var(--surface-2)}
/* hover tooltip with the company name */
.logo-river .logo-pill::after{content:attr(data-name);position:absolute;bottom:calc(100% + 9px);left:50%;
  transform:translateX(-50%) translateY(4px);padding:6px 10px;background:var(--surface-3);border:1px solid var(--line-strong);
  color:var(--ink);font:600 11px/1 var(--mono);white-space:nowrap;border-radius:6px;box-shadow:var(--shadow);
  opacity:0;pointer-events:none;transition:opacity var(--fast),transform var(--fast);z-index:6}
.logo-river .logo-pill::before{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--line-strong);opacity:0;transition:opacity var(--fast);z-index:6}
.logo-river .logo-pill:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
.logo-river .logo-pill:hover::before{opacity:1}

.method-label{display:flex;align-items:center;gap:12px;margin:var(--s8) 0 var(--s5);
  font:600 11px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim)}
.method-label::before,.method-label::after{content:"";height:1px;background:var(--line);flex:1}
.method{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4)}
@media (max-width:980px){.method{grid-template-columns:1fr}}
.method-card{padding:var(--s5);border:1px solid var(--line);border-radius:var(--r-ctl);background:var(--surface-2)}
.method-card .idx{font:600 11px/1 var(--mono);color:var(--coral)}
.method-card .mtag{font:600 10px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-left:8px}
.method-card h4{font-size:18px;margin:var(--s3) 0 10px}
.method-card p{color:var(--ink-dim);font-size:13.5px;line-height:1.55}
.method-card .mtags{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--s4)}
.method-card .mtags span{padding:5px 8px;border:1px solid var(--line);border-radius:4px;font:500 9px/1 var(--mono);
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim)}

/* ---- PM OS -------------------------------------------------------------- */
.pmos{display:grid;grid-template-columns:5fr 7fr;gap:var(--s7);align-items:start}
@media (max-width:1040px){.pmos{grid-template-columns:1fr;gap:var(--s6)}}
.pmos-intro h2{font-size:clamp(34px,4.4vw,60px);margin:var(--s3) 0 var(--s4)}
.pmos-intro .subhead{color:var(--ink-dim);font-size:18px;line-height:1.45;margin-bottom:var(--s4)}
.pmos-intro .whatis{color:var(--muted);font-size:14.5px;line-height:1.65}
.pmos-proof{display:flex;flex-wrap:wrap;gap:8px;margin-top:var(--s5)}
.pmos-proof span{padding:8px 10px;border:1px solid var(--line);border-radius:var(--r-ctl);background:var(--surface-2);
  font:500 10px/1 var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim)}
.explorer{border:1px solid var(--line-strong);border-radius:var(--r-win);background:var(--bg);overflow:hidden}
.explorer-bar{display:flex;align-items:center;gap:8px;height:34px;padding:0 12px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.explorer-bar .lights i{width:8px;height:8px}
.explorer-bar b{font:500 11px/1 var(--mono);color:var(--muted)}
.explorer-body{display:grid;grid-template-columns:200px 1fr;min-height:420px}
@media (max-width:560px){.explorer-body{grid-template-columns:1fr}}
.explorer-tree{padding:12px;border-right:1px solid var(--line);background:var(--surface)}
.explorer-tree .tlabel{font:600 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--coral);margin:4px 6px 12px}
.tnode{display:flex;align-items:center;gap:9px;width:100%;padding:11px 10px;text-align:left;
  border-left:2px solid transparent;border-radius:var(--r-ctl);color:var(--ink-dim);font:500 12px/1 var(--mono);
  transition:all var(--fast)}
.tnode i{width:15px;height:15px;color:var(--muted)}
.tnode:hover{background:var(--surface-2);color:var(--ink)}
.tnode.is-active{background:var(--surface-2);color:var(--ink);border-left-color:var(--acid)}
.tnode.is-active i{color:var(--acid)}
.tnode .tick{margin-left:auto;font-size:9px;color:var(--acid);opacity:0;transition:opacity var(--fast)}
.tnode.is-active .tick{opacity:1}
.explorer-detail{padding:var(--s6)}
.explorer-detail .epath{font:500 12px/1 var(--mono);color:var(--coral)}
.explorer-detail h3{font-size:26px;margin:var(--s3) 0 var(--s3)}
.explorer-detail p{color:var(--ink-dim);font-size:14.5px;line-height:1.65}
.efiles-label{margin:var(--s5) 0 10px;font:600 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.efiles{display:flex;flex-wrap:wrap;gap:8px}
.efile{padding:8px 11px;border:1px solid var(--line);border-radius:var(--r-ctl);background:var(--surface);
  font:500 11px/1 var(--mono);color:var(--ink-dim)}

/* ---- ANTHROPIC ---------------------------------------------------------- */
.anthropic-intro{max-width:820px;margin-bottom:var(--s6)}
.anthropic-intro h2{font-size:clamp(38px,4.8vw,66px)}
.values{border:1px solid var(--line-strong);border-radius:var(--r-win);background:var(--surface-2);overflow:hidden}
.value-tabs{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--line)}
.value-tab{padding:var(--s4) var(--s5);text-align:left;border-right:1px solid var(--line);color:var(--ink-dim);
  transition:background var(--fast)}
.value-tab:last-child{border-right:none}
.value-tab .vno{font:600 11px/1 var(--mono);color:var(--muted)}
.value-tab .vname{display:block;margin-top:8px;font-weight:600;font-size:15px;line-height:1.25;color:var(--ink-dim)}
.value-tab.is-active{background:var(--surface-3)}
.value-tab.is-active .vname{color:var(--ink)}
.value-tab.is-active .vno{color:var(--acid)}
@media (max-width:680px){.value-tabs{grid-template-columns:1fr}.value-tab{border-right:none;border-bottom:1px solid var(--line)}}
.value-stage{display:grid;grid-template-columns:170px 1fr;gap:var(--s6);align-items:center;padding:var(--s7)}
@media (max-width:680px){.value-stage{grid-template-columns:1fr;gap:var(--s4)}}
.value-symbol{width:150px;height:150px;border:1px solid var(--line-strong);border-radius:50%;background:var(--bg);
  display:grid;place-items:center;justify-self:center}
.value-symbol{width:160px;height:160px}
.value-symbol i{width:70px;height:70px;stroke-width:1.5}
.vsym-simple i{color:var(--acid)} .vsym-light i{color:var(--blue)} .vsym-mission i{color:var(--coral)}
.value-copy .vkick{font:600 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--coral)}
.value-copy h3{font-size:30px;margin:var(--s3) 0 var(--s4)}
.value-copy p{color:var(--ink-dim);font-size:16px;line-height:1.65;max-width:640px}

/* ---- CONTACT ------------------------------------------------------------ */
.contact-wrap{display:grid;place-content:center;height:100%;text-align:center;max-width:760px;margin:0 auto}
.contact-wrap h2{font-size:clamp(34px,4.6vw,62px);margin:var(--s4) 0 var(--s6)}
.contact-actions{display:flex;flex-wrap:wrap;gap:var(--s4);justify-content:center;align-items:center}
.btn-primary{display:inline-flex;align-items:center;gap:9px;height:50px;padding:0 22px;border-radius:var(--r-ctl);
  background:var(--acid);color:var(--bg);font-weight:650;box-shadow:0 2px 0 rgba(0,0,0,.5);transition:transform var(--fast),box-shadow var(--fast)}
.btn-primary:hover{text-decoration:none}
.btn-primary:active{transform:translateY(2px);box-shadow:0 0 0 rgba(0,0,0,.5)}
.btn-primary i{width:17px;height:17px}
.btn-text{padding:12px 4px;border-bottom:1px solid var(--line-strong);color:var(--ink);font-weight:600}
.btn-text:hover{text-decoration:none;border-color:var(--acid);color:var(--acid)}
.contact-note{margin-top:var(--s7);font:500 12px/1 var(--mono);color:var(--muted)}

/* ---- DIAGRAM KIT -------------------------------------------------------- */
.diagram{width:100%;font-family:var(--mono)}
.dg-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px}
.dg-col{display:flex;flex-direction:column;align-items:center;gap:4px}
.dg-node{display:inline-flex;align-items:center;gap:7px;padding:8px 11px;border:1px solid var(--line);
  border-radius:var(--r-ctl);background:var(--surface-2);font:500 11.5px/1 var(--mono);color:var(--ink-dim);
  opacity:0;transform:translateY(6px);animation:dgIn .4s var(--ease) forwards;animation-delay:calc(var(--i,0)*70ms)}
.dg-node i{width:13px;height:13px;color:var(--muted)}
.dg-node.is-acid{border-color:rgba(182,242,58,.4);color:var(--ink)}
.dg-node.is-acid i{color:var(--acid)}
.dg-node.is-term b{color:var(--acid)}
.dg-arrow{color:var(--muted);font-size:13px;opacity:0;animation:dgIn .4s var(--ease) forwards;animation-delay:calc(var(--i,0)*70ms)}
.dg-anno{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:14px;font:500 13px/1 var(--mono)}
.dg-anno .is-before,.dg-anno s{color:var(--coral)}
.dg-anno .to,.dg-anno .dg-to{color:var(--muted)}
.dg-anno .is-after{color:var(--acid);font-weight:700;font-size:15px}
.dg-anno span{color:var(--muted)}
.dg-token{margin-top:6px;padding:7px 11px;border:1px dashed rgba(182,242,58,.4);border-radius:var(--r-ctl);
  color:var(--acid);font:500 11px/1 var(--mono);opacity:0;animation:dgIn .4s var(--ease) forwards;animation-delay:calc(var(--i,0)*70ms)}
.dg-fan{display:flex;flex-direction:column;align-items:center;gap:12px}
.dg-fan-in{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;max-width:340px}
.dg-fan-out{display:flex;align-items:center;gap:10px}
.dg-brief-rows{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-top:4px}
.dg-brief-rows span{font:500 11px/1.4 var(--mono);color:var(--ink-dim);padding:5px 8px;border:1px solid var(--line);border-radius:4px;
  opacity:0;animation:dgIn .4s var(--ease) forwards;animation-delay:.4s}
.dg-loop{color:var(--acid);font-size:16px;margin-left:4px;opacity:0;animation:dgIn .4s var(--ease) forwards;animation-delay:calc(var(--i,0)*70ms)}
.dg-tree{display:flex;flex-direction:column;align-items:center;gap:10px}
.dg-tree-leaves{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;max-width:340px}
.dg-leaf{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid var(--line);border-radius:var(--r-ctl);
  background:var(--surface-2);font:500 11px/1 var(--mono);color:var(--ink-dim);
  opacity:0;animation:dgIn .4s var(--ease) forwards;animation-delay:calc(var(--i,0)*70ms)}
.dg-branch{color:var(--muted)}

@keyframes dgIn{to{opacity:1;transform:none}}

/* ---- SCREENSHOT LIGHTBOX ------------------------------------------------ */
.shot-overlay .overlay-backdrop{background:rgba(8,8,6,.85)}
.shot-frame{position:absolute;top:50%;left:50%;transform:translate(-50%,-47%) scale(.97);opacity:0;
  width:min(1180px,94vw);transition:transform var(--scene) var(--ease),opacity var(--scene)}
.overlay.is-open .shot-frame{transform:translate(-50%,-50%) scale(1);opacity:1}
.shot-frame img{width:100%;height:auto;max-height:90vh;object-fit:contain;display:block;
  border:1px solid var(--line-strong);border-radius:var(--r-win);box-shadow:var(--shadow)}
.shot-close{position:absolute;top:-16px;right:-16px;width:34px;height:34px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--line-strong);border-radius:50%;color:var(--ink);z-index:2}
.shot-close i{width:16px;height:16px}

/* ---- MOBILE NAV --------------------------------------------------------- */
.mobilenav .overlay-backdrop{background:rgba(8,8,6,.7)}
.mobilenav-panel{position:absolute;top:0;left:0;bottom:0;width:min(300px,82vw);padding:calc(var(--bar-top) + 20px) var(--s5) var(--s5);
  background:var(--surface);border-right:1px solid var(--line-strong);transform:translateX(-105%);
  transition:transform var(--scene) var(--ease);display:flex;flex-direction:column;gap:4px}
.mobilenav.is-open .mobilenav-panel{transform:none}
.mobilenav-panel .rail-node{font-size:14px}

/* ---- RESPONSIVE CHROME -------------------------------------------------- */
@media (max-width:860px){
  .rail{display:none}
  .stage{left:0}
  .menu-btn{display:grid}
  .crumb{display:none}
}
@media (max-width:680px){
  .stage{padding:var(--s3)}
  .scene{inset:var(--s3)}
  .scene-win{min-width:0}
  .win-bar{min-width:0}
  .win-bar .pager{display:none}              /* top pager off on phones; footer pager + menu remain */
  .win-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .win-body{padding:var(--s4);overflow-x:hidden}
  .win-foot{flex-direction:column;gap:var(--s4)}
  .win-foot .pager{flex-wrap:wrap;gap:var(--s3) var(--s4)}
  .scene-win{max-width:100%}
  .cards,.stat-strip,.cases,.method{grid-template-columns:1fr;min-width:0}
  .card,.case,.method-card,.stat,.win-body{min-width:0}
  .card-well,.panel-graphic,.diagram{overflow:hidden;max-width:100%}
  .hero{grid-template-columns:1fr}
  .scene-head h1,.scene-head h2,.hero h1,.contact-wrap h2,.pmos-intro h2{overflow-wrap:anywhere}
}

/* ---- LARGE DISPLAYS (fill the screen, don't letterbox) ------------------ */
@media (min-width:1700px){
  :root{--rail-w:240px;--bar-top:56px;--bar-bot:36px}
  .menubar{padding:0 var(--s6)}
  .rail{padding:var(--s6) var(--s4)}
  .rail-node{font-size:14px;padding:13px 12px}
  .rail-node i,.rail-node .rail-logo{width:17px;height:17px}
  .stage{padding:var(--s7)}
  /* vertically center shorter scenes so the bottom isn't blank; long scenes still scroll */
  .win-body{display:flex;flex-direction:column;justify-content:safe center;padding:clamp(44px,4vw,76px)}
  .scene-head{max-width:940px}
  .scene-head h1{font-size:clamp(64px,5vw,98px)}
  .scene-head h2{font-size:clamp(50px,4.6vw,82px)}
  .scene-head .lede{font-size:clamp(20px,1.5vw,26px);max-width:840px}
  .hero{gap:var(--s8)}
  .hero h1{font-size:clamp(72px,5.4vw,112px)}
  .hero .lede{font-size:clamp(22px,1.7vw,28px);max-width:720px}
  .pillar strong{font-size:14px}
  .console-row .val{font-size:40px}
  .cards{gap:var(--s6)} .card{min-height:400px} .card h3{font-size:25px}
  .card p,.case p{font-size:15px}
  .case{min-height:340px} .case h3{font-size:24px}
  .value-stage{padding:var(--s8)}
  .value-symbol{width:200px;height:200px} .value-symbol i{width:88px;height:88px}
  .value-copy h3{font-size:36px} .value-copy p{font-size:19px;max-width:720px}
  .pmos{gap:var(--s8)} .pmos-intro h2{font-size:clamp(48px,4.4vw,76px)}
  .explorer-body{min-height:520px}
  .logo-pill{height:34px} .logo-pill img{max-height:34px}
  .contact-wrap h2{font-size:clamp(48px,4.6vw,80px)}
  /* bump the small // labels, all-caps eyebrows, and small paragraphs on big screens */
  .eyebrow{font-size:12px}
  .cards-label,.cases-label,.process-label,.logo-river-label,.method-label{font-size:12.5px}
  .rail-label{font-size:11px} .crumb,.win-name{font-size:13px}
  .card-meta{font-size:12px}
  .pillar span{font-size:11px} .pillar strong{font-size:15px}
  .chip .v{font-size:14px}
  .console-row .lab{font-size:14px}
  .method-card .mtag,.method-card .idx{font-size:12px} .method-card h4{font-size:20px} .method-card p{font-size:14.5px}
  .mech>h4,.wwh h4{font-size:13px}
  .wwh p,.mech-step p,.panel-body .summary{font-size:16px}
  .panel-body .kicker,.case-role,.case-spotlight{font-size:11px}
  .pmos-proof span,.efile,.tnode{font-size:13px}
  .statusbar{font-size:12px} .pager button{font-size:11px}
}
@media (min-width:2300px){
  :root{--rail-w:280px}
  .win-body{padding:clamp(60px,4vw,110px)}
  .scene-head h1{font-size:108px} .hero h1{font-size:120px}
  .cards{gap:var(--s7)} .card{min-height:440px}
  .eyebrow,.process-label,.logo-river-label{font-size:13px}
  .cards-label,.cases-label,.method-label{font-size:13.5px}
  .card-meta,.crumb,.win-name{font-size:13.5px}
  .card p,.case p,.wwh p,.mech-step p,.panel-body .summary{font-size:17px}
}

/* ---- REDUced MOTION ----------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .dg-node,.dg-arrow,.dg-leaf,.dg-token,.dg-loop,.dg-brief-rows span{opacity:1;transform:none}
}
