/* ===========================================================
   Process — shared design system for dogelord.com/process
   "Experiments in Motion" — animated, honest pipeline visualizers.
   =========================================================== */
:root{
  --bg:#05060c; --bg2:#080b16;
  --ink:#cdd6f4; --dim:#7889b0; --faint:#4a5878;
  --edge:#ff7a8a;                 /* salmon connectors / work-in-flight */
  --edge-glow:rgba(255,122,138,.55);
  --human:#e9c46a;                /* warm gold — "your move" gates */
  --human-glow:rgba(233,196,106,.55);
  --card:rgba(12,18,34,.82); --card-line:rgba(120,150,220,.16);
  /* agent palette (dogelord canon) */
  --saarvis:#39d3ff; --hh:#ffae5c; --nyx:#c76bff; --minidoge:#5af2a0;
  --publish:#5af2a0; --halper:#5cc8ff; --king:#e9c46a;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:radial-gradient(1200px 700px at 50% -10%, #0c1226 0%, var(--bg) 60%);
  color:var(--ink); font-family:'Inter',sans-serif; -webkit-font-smoothing:antialiased;
  min-height:100vh; overflow-x:hidden;
}
a{color:inherit}
#stars{position:fixed; inset:0; z-index:0; pointer-events:none}
.wrap{position:relative; z-index:1; max-width:1080px; margin:0 auto; padding:24px 20px 80px}
.wrap.wide{max-width:1140px}

/* ---- top nav ---- */
header.top{display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:6px}
.brand a{color:var(--faint); text-decoration:none; font-family:'Space Mono',monospace; font-size:12px; letter-spacing:1px}
.brand a:hover{color:var(--dim)}

/* ---- hero ---- */
.hero{text-align:center; padding:14px 0 18px}
.kicker{font-family:'Space Mono',monospace; font-size:12px; letter-spacing:3px; text-transform:uppercase; color:var(--edge); opacity:.9}
h1{font-size:clamp(28px,5vw,46px); line-height:1.06; margin:10px 0 8px; font-weight:700; letter-spacing:-.5px}
h1 .lo{color:var(--human)} h1 .ag{color:var(--saarvis)}
.sub{color:var(--dim); max-width:640px; margin:0 auto; font-size:15px; line-height:1.55}

/* ---- explainer ---- */
.explain{
  max-width:720px; margin:18px auto 4px; background:var(--card); border:1px solid var(--card-line);
  border-radius:14px; padding:16px 20px; backdrop-filter:blur(10px);
}
.explain h2{font-size:13px; font-family:'Space Mono',monospace; letter-spacing:1.5px; text-transform:uppercase; color:var(--edge); margin:0 0 8px}
.explain p{margin:0 0 8px; color:var(--dim); font-size:14px; line-height:1.6}
.explain p:last-child{margin-bottom:0}
.explain b{color:var(--ink)}
.explain .seal{color:var(--human)}

/* ---- legend + controls + ticker ---- */
.legend{display:flex; gap:18px; justify-content:center; flex-wrap:wrap; margin:22px 0 6px; font-family:'Space Mono',monospace; font-size:11px; color:var(--dim)}
.legend span{display:inline-flex; align-items:center; gap:7px}
.dot{width:9px; height:9px; border-radius:50%}
.controls{display:flex; justify-content:center; gap:12px; margin:14px 0 8px; flex-wrap:wrap}
.btn{
  font-family:'Space Mono',monospace; font-size:13px; letter-spacing:.5px;
  border:1px solid var(--card-line); background:var(--card); color:var(--ink);
  padding:11px 20px; border-radius:10px; cursor:pointer; backdrop-filter:blur(8px);
  transition:transform .12s ease, border-color .2s, box-shadow .2s; text-decoration:none; display:inline-block;
}
.btn:hover{transform:translateY(-1px); border-color:var(--edge-glow)}
.btn.primary{border-color:var(--human-glow); color:var(--human)}
.btn.primary.pulse{animation:btnpulse 1.4s ease-in-out infinite}
@keyframes btnpulse{0%,100%{box-shadow:0 0 0 0 var(--human-glow)}50%{box-shadow:0 0 26px 2px var(--human-glow)}}
.btn:disabled{opacity:.4; cursor:default; transform:none; box-shadow:none; animation:none}
.ticker{text-align:center; font-family:'Space Mono',monospace; font-size:12.5px; color:var(--dim); min-height:20px; margin:6px 0 22px; letter-spacing:.3px}
.ticker b{color:var(--ink)}

/* ---- pipeline ---- */
.pipe{position:relative}
svg.links{position:absolute; inset:0; width:100%; height:100%; z-index:0; pointer-events:none; overflow:visible}
.stage{
  position:relative; z-index:1; width:min(440px,86%); margin:0 auto 46px;
  background:var(--card); border:1px solid var(--card-line); border-radius:16px;
  padding:16px 18px; backdrop-filter:blur(10px); box-shadow:0 10px 40px rgba(0,0,0,.35);
  opacity:.55; transition:opacity .4s, border-color .4s, box-shadow .4s, transform .4s;
}
@media(min-width:760px){
  .stage{width:48%; margin-bottom:30px}
  .stage.L{margin-left:0; margin-right:auto}
  .stage.R{margin-left:auto; margin-right:0}
}
.stage.active{opacity:1; border-color:var(--accent,var(--edge-glow)); box-shadow:0 0 0 1px var(--accent,var(--edge-glow)), 0 14px 50px rgba(0,0,0,.5); transform:translateY(-2px)}
.stage.done{opacity:.92}
.stage.gate{border-style:dashed}
.stage.gate.waiting{opacity:1; border-color:var(--human); box-shadow:0 0 34px var(--human-glow)}
.srow{display:flex; align-items:center; gap:11px}
.ico{width:38px; height:38px; flex:0 0 38px; border-radius:10px; display:grid; place-items:center; font-size:19px; background:rgba(255,255,255,.04); border:1px solid var(--card-line)}
.stage.active .ico{border-color:var(--accent)}
.meta{flex:1; min-width:0}
.tag{font-family:'Space Mono',monospace; font-size:10.5px; letter-spacing:1.5px; text-transform:uppercase; color:var(--faint)}
.stage.active .tag{color:var(--accent)}
.who{font-weight:600; font-size:16px; line-height:1.2; margin-top:1px}
.who small{color:var(--dim); font-weight:400; font-size:12.5px}
.desc{color:var(--dim); font-size:13.5px; line-height:1.5; margin:10px 0 0}
.pill{display:inline-block; font-family:'Space Mono',monospace; font-size:10px; letter-spacing:.5px; color:var(--accent,var(--edge)); border:1px solid var(--card-line); border-radius:999px; padding:2px 8px; margin:8px 6px 0 0}
.gatebtn{margin-top:13px; display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.gatehint{font-family:'Space Mono',monospace; font-size:11px; color:var(--human)}
.sealed{margin-top:10px; font-family:'Space Mono',monospace; font-size:10.5px; color:var(--human); border:1px dashed var(--human-glow); border-radius:8px; padding:6px 9px; display:inline-block}

/* ---- viz: vault graph / funnel / scanner share this shell ---- */
.viz{margin-top:12px; background:radial-gradient(120% 120% at 50% 30%, rgba(57,211,255,.06), rgba(4,8,18,.7)); border:1px solid var(--card-line); border-radius:12px; padding:8px 8px 6px; overflow:hidden}
.viz canvas{display:block; width:100%; height:188px; border-radius:8px}
.vcap{font-family:'Space Mono',monospace; font-size:10.5px; color:var(--dim); margin:6px 4px 2px; display:flex; align-items:center; gap:7px}
.vdot{width:8px; height:8px; border-radius:50%; background:var(--human); box-shadow:0 0 8px var(--human-glow); animation:vp 1.6s ease-in-out infinite}
@keyframes vp{0%,100%{opacity:.55}50%{opacity:1}}

/* ---- footer ---- */
footer{margin-top:50px; text-align:center; color:var(--faint); font-size:12px; line-height:1.7}
footer a{color:var(--dim); text-decoration:none}
footer a:hover{color:var(--ink)}

/* ===========================================================
   HUB gallery
   =========================================================== */
.hubsec{margin:34px 0 10px}
.hubsec h3{font-family:'Space Mono',monospace; font-size:13px; letter-spacing:2px; text-transform:uppercase; color:var(--ink); margin:0 0 4px; display:flex; align-items:center; gap:10px}
.hubsec h3 .bar{height:1px; flex:1; background:linear-gradient(90deg,var(--card-line),transparent)}
.hubsec .secnote{color:var(--faint); font-size:12.5px; margin:0 0 16px}
.grid{display:grid; gap:16px; grid-template-columns:1fr}
@media(min-width:640px){.grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.grid{grid-template-columns:1fr 1fr 1fr}}
.cardlink{
  display:block; text-decoration:none; background:var(--card); border:1px solid var(--card-line);
  border-radius:14px; padding:16px 16px 15px; backdrop-filter:blur(10px);
  transition:transform .14s ease, border-color .2s, box-shadow .2s; position:relative; overflow:hidden;
}
.cardlink:hover{transform:translateY(-3px); border-color:var(--accent,var(--edge-glow)); box-shadow:0 14px 44px rgba(0,0,0,.5)}
.cardlink .ch{display:flex; align-items:center; gap:10px}
.cardlink .cico{width:34px; height:34px; flex:0 0 34px; border-radius:9px; display:grid; place-items:center; font-size:17px; background:rgba(255,255,255,.04); border:1px solid var(--card-line)}
.cardlink h4{margin:0; font-size:15.5px; font-weight:600; color:var(--ink)}
.cardlink .hook{color:var(--dim); font-size:13px; line-height:1.5; margin:11px 0 0}
.cardlink .go{margin-top:12px; font-family:'Space Mono',monospace; font-size:11px; letter-spacing:.5px; color:var(--accent,var(--edge))}
.cardlink .stripe{position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--accent,var(--edge))}
.cardlink.soon{opacity:.55}
.cardlink.soon .go{color:var(--faint)}
.badge{font-family:'Space Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; color:var(--human); border:1px solid var(--human-glow); border-radius:999px; padding:2px 7px; margin-left:auto}
