/* TreeTrace.dev - REPLAY page styles only (tokens + shell + glass loaded first).
   Reuses .ledger, .snippet, .lens, .btn, .section primitives; adds page-only bits. */

main{padding-top:var(--tt-nav-h)}

/* =========================================================
   PAGE HERO
   ========================================================= */
.rhero{
  position:relative;overflow:hidden;padding:74px 0 60px;
  background:
    radial-gradient(1000px 640px at 88% 30%, rgba(46,91,255,.10), transparent 60%),
    radial-gradient(760px 540px at 2% 0%, rgba(255,255,255,.022), transparent 55%),
    repeating-linear-gradient(0deg, transparent 0 39px, rgba(155,160,166,.03) 39px 40px),
    repeating-linear-gradient(90deg, transparent 0 39px, rgba(155,160,166,.03) 39px 40px);
}
.rhero__inner{max-width:var(--tt-wrap);margin:0 auto;padding:0 28px;max-width:880px}
.rhero .eyebrow{margin-bottom:20px}
.rhero h1{
  font-family:var(--tt-font-display);font-weight:900;text-transform:uppercase;
  font-size:clamp(40px,6vw,76px);line-height:.9;letter-spacing:-.035em;color:var(--tt-paper);
}
.rhero h1 em{font-style:normal;color:var(--tt-ash-2)}
.rhero__kick{margin-top:22px;max-width:560px;font-family:var(--tt-font-serif);font-style:italic;
  font-size:19px;line-height:1.5;color:var(--tt-ash)}
.rhero__sub{margin-top:16px;max-width:620px;font-family:var(--tt-font-mono);font-size:14.5px;
  line-height:1.7;color:var(--tt-ash)}
.rhero__cta{margin-top:28px;display:flex;flex-wrap:wrap;gap:12px;align-items:center}

/* =========================================================
   INTERACTIVE TERMINAL (reconstruct a lineage)
   ========================================================= */
.replaybox{padding:24px 0 88px}
.replaybox .wrap{max-width:var(--tt-wrap)}
.replay-stage{position:relative}

.replay-term.ledger{font-size:13px;line-height:2.0}
.replay-term .ledger__bar .ctrl{
  margin-left:auto;display:inline-flex;align-items:center;gap:9px;
}
.replay-term .replay-btn{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--tt-font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--tt-ash);background:transparent;border:1px solid var(--tt-line);border-radius:6px;
  padding:5px 10px;cursor:pointer;transition:color .2s,border-color .2s;
}
.replay-btn:hover{color:var(--tt-paper);border-color:rgba(155,160,166,.4)}
.replay-btn svg{width:12px;height:12px}
.replay-term .progress{margin-left:8px;display:none;align-items:center;gap:7px;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--tt-signal)}
.replay-term.is-animating .progress{display:flex}
.replay-term .progress i{width:7px;height:7px;border-radius:50%;background:var(--tt-signal);
  box-shadow:0 0 8px var(--tt-signal);animation:tt-pulse 1.6s var(--tt-ease) infinite}
.replay-term.is-done .progress i{animation:none;opacity:.4}

.replay-term .ledger__rows{padding:18px 20px 22px;min-height:300px}
.replay-term .cmd b{color:var(--tt-paper)}
.replay-term .line{
  white-space:pre;color:var(--tt-ash);overflow:hidden;text-overflow:ellipsis;
  transition:opacity .45s var(--tt-ease),transform .45s var(--tt-ease);
}
/* visible by default (progressive enhancement); hidden only while animating */
.replay-term.is-animating .line{opacity:0;transform:translateY(4px)}
.replay-term.is-animating .line.show{opacity:1;transform:none}
.replay-term .glyph{color:var(--tt-ash-2)}
.replay-term .node{color:var(--tt-paper);font-weight:700}
.replay-term .kind{color:var(--tt-signal)}
.replay-term .txt{color:var(--tt-ash)}
/* steered (accepted) path marker */
.replay-term .line.steer .node{color:var(--tt-paper)}
.replay-term .line.steer .glyph{color:var(--tt-signal)}
/* abandoned dead-end: dimmed + struck */
.replay-term .line.dead{color:var(--tt-ash-2)}
.replay-term .line.dead .node{color:var(--tt-ash-2);text-decoration:line-through;font-weight:400}
.replay-term .line.dead .txt{color:var(--tt-ash-2)}
.replay-term .line.dead .x{color:var(--tt-ash);font-weight:700}
.replay-term .tagx{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--tt-ash-2);
  border:1px solid var(--tt-line);border-radius:10px;padding:0 7px;margin-left:4px}
/* the leaked-token catch */
.replay-term .warn{color:var(--tt-signal);font-weight:700}
.replay-term .leak{color:#fff;background:var(--tt-signal);padding:0 6px;border-radius:2px;font-weight:700;letter-spacing:.04em}
.replay-term .ok{color:var(--tt-paper);font-weight:700}
.replay-term .headrow .node{color:#fff}
.replay-term .blink-caret{display:inline-block;width:8px;height:1.05em;vertical-align:-2px;
  background:var(--tt-signal);margin-left:2px;animation:tt-blink 1.1s steps(2,start) infinite}
.replay-term.is-done .blink-caret{display:none}

/* glass lens legend floating over the terminal (1x on page) */
.replay-legend.lens{
  position:absolute;right:-14px;bottom:-30px;width:280px;z-index:3;padding:22px 22px 20px;
}
.replay-legend .lbl{font-family:var(--tt-font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--tt-signal);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.replay-legend .lbl i{width:6px;height:6px;border-radius:50%;background:var(--tt-signal);box-shadow:0 0 8px var(--tt-signal)}
.replay-legend dl{display:grid;grid-template-columns:auto 1fr;gap:10px 12px;align-items:start}
.replay-legend dt{font-family:var(--tt-font-mono);font-size:13px;font-weight:700;color:var(--tt-paper);line-height:1.3}
.replay-legend dd{font-family:var(--tt-font-mono);font-size:11.5px;color:var(--tt-ash);line-height:1.4}
.replay-legend .k-steer{color:var(--tt-paper)}
.replay-legend .k-dead{color:var(--tt-ash-2)}
.replay-legend .k-leak{color:#fff;background:var(--tt-signal);padding:0 5px;border-radius:2px;font-size:11px}

/* =========================================================
   COMMAND PILL ROW
   ========================================================= */
.cmdrow{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:30px}
.cmdrow .snippet{font-size:14px}
.cmdrow .note{font-family:var(--tt-font-mono);font-size:12px;color:var(--tt-ash-2);letter-spacing:.04em}

/* =========================================================
   STEERED PATH vs DEAD-ENDS - compare
   ========================================================= */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.cmp{position:relative;padding:30px 28px;border-radius:16px;border:1px solid var(--tt-line);background:var(--tt-surface)}
.cmp--steer{background:
  radial-gradient(420px 220px at 88% 0%, rgba(46,91,255,.10), transparent 70%),var(--tt-surface);
  border-color:rgba(46,91,255,.34)}
.cmp .cmp__k{font-family:var(--tt-font-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;color:var(--tt-ash-2)}
.cmp--steer .cmp__k{color:var(--tt-signal)}
.cmp .cmp__k i{width:7px;height:7px;border-radius:50%;flex:none}
.cmp--steer .cmp__k i{background:var(--tt-signal);box-shadow:0 0 8px var(--tt-signal)}
.cmp--dead .cmp__k i{background:var(--tt-ash-2);outline:1px solid var(--tt-line)}
.cmp h3{font-size:23px;font-weight:800;text-transform:none;letter-spacing:-.01em}
.cmp > p{margin-top:12px;font-family:var(--tt-font-mono);font-size:13.5px;line-height:1.65;color:var(--tt-ash)}
.cmp ul{margin-top:18px;display:flex;flex-direction:column;gap:11px;list-style:none}
.cmp li{position:relative;padding-left:24px;font-family:var(--tt-font-mono);font-size:13px;line-height:1.55;color:var(--tt-ash)}
.cmp li::before{position:absolute;left:0;top:0;font-weight:700}
.cmp--steer li::before{content:"›";color:var(--tt-signal);font-size:16px;top:-1px}
.cmp--dead li::before{content:"✗";color:var(--tt-ash-2);font-size:12px;top:1px}
.cmp code{color:var(--tt-paper);background:rgba(46,91,255,.08);padding:1px 5px;border-radius:4px;font-size:.92em}

/* leaked-token catch callout */
.catch{
  margin-top:24px;display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:center;
  padding:26px 28px;border-radius:16px;border:1px solid rgba(46,91,255,.34);
  background:radial-gradient(560px 220px at 12% 0%, rgba(46,91,255,.10), transparent 70%),var(--tt-surface);
}
.catch__icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--tt-signal);box-shadow:0 8px 22px -8px rgba(46,91,255,.55),inset 0 1px 0 rgba(255,255,255,.28);flex:none}
.catch__icon svg{width:24px;height:24px;stroke:#fff}
.catch h3{font-size:19px;font-weight:800;text-transform:none;letter-spacing:-.01em}
.catch p{margin-top:8px;font-family:var(--tt-font-mono);font-size:13.5px;line-height:1.65;color:var(--tt-ash);max-width:760px}
.catch code{color:var(--tt-paper);background:rgba(46,91,255,.08);padding:1px 5px;border-radius:4px;font-size:.92em}

/* =========================================================
   BIG CTA (reuse home .bigcta look)
   ========================================================= */
.bigcta{text-align:center;max-width:660px;margin:0 auto}
.bigcta h2{font-size:clamp(30px,4vw,48px);font-weight:900;text-transform:uppercase;letter-spacing:-.03em;line-height:.95}
.bigcta p{margin-top:18px;font-family:var(--tt-font-mono);font-size:14.5px;color:var(--tt-ash)}
.bigcta .snippet{margin:28px auto 0;width:max-content;max-width:100%}
.bigcta .cta-row{margin-top:22px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .compare{grid-template-columns:minmax(0,1fr)}
  .replay-legend.lens{position:relative;right:auto;bottom:auto;width:100%;margin-top:18px}
  /* terminal: scroll horizontally instead of forcing the page wide */
  .replay-term .ledger__rows{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .replay-term .line{overflow:visible;text-overflow:clip}
}
@media (max-width:600px){
  .rhero{padding:52px 0 44px}
  .section{padding:60px 0}
  .replay-term.ledger{font-size:11px;line-height:1.95}
  .replay-term .ledger__rows{min-height:260px}
  .catch{grid-template-columns:minmax(0,1fr);gap:14px}
  .cmdrow{gap:12px}
  /* readability: bump core body copy */
  .rhero__sub,.cmp>p,.cmp li,.catch p,.bigcta p{font-size:16px;line-height:1.6}
}

/* reduced-motion: reveal all rows, kill caret/pulse */
@media (prefers-reduced-motion:reduce){
  .replay-term .line{opacity:1;transform:none;transition:none}
  .replay-term .blink-caret{display:none}
}
