/* ── SEIKIRA DEMO — SHARED STYLES ── */
@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&family=IBM+Plex+Mono:wght@400;500&family=Sora:wght@700&display=swap');

:root {
  --bg:       #0A0E1A;
  --surface:  #0F172A;
  --card:     #161D2F;
  --gold:     #C8A96E;
  --gold-lt:  #dfc08a;
  --text:     #FFFFFF;
  --muted:    #A0AEC0;
  --muted-dk: #64748b;
  --border:   rgba(255,255,255,0.08);
  --green:    #4ade80;
  --red:      #f87171;
  --amber:    #C8A96E;
  --blue:     #4a7fd4;
  --serif:    'Libre Baskerville', serif;
  --sans:     'DM Sans', sans-serif;
  --mono:     'IBM Plex Mono', monospace;
  --sora:     'Sora', sans-serif;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ── DEMO FLOW NAV ── */
.demo-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(10,14,26,0.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  padding: 0 20px;
  height: 52px;
  display: flex; align-items: center; justify-content: space-between;
}
.demo-nav-logo {
  font-family: var(--serif);
  font-size: 16px; font-weight: 700;
  color: var(--gold); text-decoration: none;
}
.demo-nav-steps {
  display: flex; align-items: center; gap: 0;
}
.demo-nav-step {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 16px;
  font-size: 12px; font-weight: 600; letter-spacing: .5px;
  color: var(--muted-dk);
  border-right: 1px solid var(--border);
  text-decoration: none;
  transition: color .15s;
}
.demo-nav-step:last-child { border-right: none; }
.demo-nav-step.active { color: var(--text); }
.demo-nav-step.done { color: var(--muted); }
.demo-nav-dot {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--border); color: var(--muted-dk);
  font-size: 10px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.demo-nav-step.active .demo-nav-dot { background: var(--gold); color: #1b2a3b; }
.demo-nav-step.done .demo-nav-dot { background: #1b2a3b; color: var(--text); }
.demo-nav-exit {
  font-size: 12px; color: var(--muted-dk);
  text-decoration: none; transition: color .15s;
}
.demo-nav-exit:hover { color: var(--muted); }

/* ── CONTEXT BAR ── */
.demo-context-bar {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 20px;
  background: rgba(22,29,47,0.8);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  font-size: 12px; color: var(--muted);
}
.demo-badge {
  font-size: 11px; font-weight: 600; letter-spacing: .5px;
  padding: 3px 10px; border-radius: 20px; border: 1px solid;
}
.demo-badge.reentry    { color: #5eead4; border-color: rgba(94,234,212,0.3); background: rgba(94,234,212,0.08); }
.demo-badge.workforce  { color: #93c5fd; border-color: rgba(147,197,253,0.3); background: rgba(147,197,253,0.08); }
.demo-badge.founder    { color: var(--amber); border-color: rgba(200,169,110,0.3); background: rgba(200,169,110,0.08); }

/* ── TYPEWRITER ── */
.typewriter-bubble {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 0 16px 16px 16px;
  padding: 14px 18px;
  max-width: 420px;
  margin-bottom: 12px;
  font-family: var(--mono);
  font-size: 13px;
  color: var(--muted);
  line-height: 1.8;
  white-space: pre-wrap;
}

/* ── DATA BLOCK ── */
.data-block {
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 6px;
  padding: 14px 18px;
  margin: 8px 0 16px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--muted);
  line-height: 2;
  white-space: pre;
  overflow-x: auto;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .4s ease, transform .4s ease;
}
.data-block.show { opacity: 1; transform: translateY(0); }
.data-block .t-gold  { color: var(--gold); }
.data-block .t-green { color: var(--green); }
.data-block .t-red   { color: var(--red); }
.data-block .t-white { color: var(--text); font-weight: 600; }
.data-block .t-dim   { color: var(--muted-dk); }

/* ── STAT CARD ── */
.stat-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 16px;
  text-align: left;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .4s ease, transform .4s ease;
}
.stat-card.show { opacity: 1; transform: translateY(0); }
.stat-num {
  font-family: var(--sora);
  font-size: 22px; font-weight: 700;
  color: var(--text); line-height: 1; margin-bottom: 6px;
}
.stat-label {
  font-family: var(--sans);
  font-size: 11px; color: #94a3b8; line-height: 1.4;
}
.stat-cite {
  font-family: var(--mono);
  font-size: 9px; color: #475569;
  font-style: italic; margin-top: 6px; line-height: 1.3;
}

/* ── PROGRESS RAIL ── */
.progress-rail {
  padding: 12px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.progress-rail-track {
  height: 3px; background: var(--border);
  border-radius: 2px; overflow: hidden;
}
.progress-rail-fill {
  height: 100%; background: var(--gold);
  border-radius: 2px;
  transition: width .5s ease;
}
.progress-rail-label {
  display: flex; justify-content: space-between;
  font-size: 11px; color: var(--muted-dk);
  margin-bottom: 6px;
}

/* ── STAGE MODULE (right panel) ── */
.stage-panel {
  flex: 1; overflow-y: auto;
  padding: 32px;
  opacity: 0; transform: translateY(12px);
  transition: opacity .3s ease, transform .3s ease;
}
.stage-panel.show { opacity: 1; transform: translateY(0); }
.stage-panel-kicker {
  font-size: 11px; font-weight: 600; letter-spacing: 2px;
  text-transform: uppercase; color: var(--muted-dk);
  margin-bottom: 12px;
}
.stage-panel-title {
  font-family: var(--serif);
  font-size: clamp(20px, 2.5vw, 28px);
  font-weight: 700; color: var(--text);
  line-height: 1.3; margin-bottom: 20px;
}
.stage-panel-body {
  font-size: 15px; color: var(--muted);
  line-height: 1.8; margin-bottom: 28px;
}

/* ── ROLE SWITCHER ── */
.role-switcher {
  display: flex; gap: 0;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 0 20px;
}
.role-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 20px;
  background: none; border: none; border-bottom: 2px solid transparent;
  font-family: var(--sans); font-size: 13px; font-weight: 600;
  color: var(--muted-dk); cursor: pointer;
  transition: color .15s, border-color .15s;
}
.role-btn:hover { color: var(--muted); }
.role-btn.active { color: var(--text); border-bottom-color: var(--gold); }
.role-btn-avatar { font-size: 18px; }

/* ── BOTTOM NAV STRIP ── */
.demo-bottom-nav {
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  background: var(--card);
  display: flex; align-items: center; justify-content: space-between;
  flex-shrink: 0;
}
.btn-prev {
  display: flex; align-items: center; gap: 6px;
  background: none; border: none;
  font-family: var(--sans); font-size: 13px;
  color: var(--muted); cursor: pointer;
  transition: color .15s;
}
.btn-prev:hover { color: var(--text); }
.btn-prev:disabled { opacity: .3; cursor: not-allowed; }
.btn-next {
  display: flex; align-items: center; gap: 8px;
  background: var(--text); color: var(--bg);
  font-family: var(--sans); font-size: 13px; font-weight: 600;
  padding: 10px 24px; border-radius: 6px; border: none; cursor: pointer;
  transition: opacity .15s;
}
.btn-next:hover { opacity: .88; }
.btn-next.gold { background: var(--gold); color: #1b2a3b; }
.stage-counter { font-size: 12px; color: var(--muted-dk); }

/* ── LIVE INDICATOR ── */
.live-dot {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 10px; color: rgba(200,169,110,0.7);
  background: rgba(200,169,110,0.08);
  border: 1px solid rgba(200,169,110,0.15);
  border-radius: 20px; padding: 3px 10px;
}
.live-dot-pulse {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--gold); position: relative;
}
.live-dot-pulse::after {
  content: '';
  position: absolute; inset: -3px;
  border-radius: 50%; background: var(--gold);
  opacity: .4; animation: ping 1.5s ease-out infinite;
}
@keyframes ping {
  0%   { transform: scale(.8); opacity: .6; }
  100% { transform: scale(2); opacity: 0; }
}

/* ── ANIMATIONS ── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.fade-in     { animation: fadeIn .4s ease forwards; }
.fade-in-up  { animation: fadeInUp .5s ease forwards; }

/* ── QUICK REPLY BUTTONS ── */
.quick-replies { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.quick-reply {
  padding: 7px 14px;
  border-radius: 6px; border: 1px solid;
  font-family: var(--sans); font-size: 12px; font-weight: 600;
  cursor: pointer; transition: background .15s, color .15s;
  background: rgba(26,42,26,0.6);
  border-color: rgba(74,222,128,0.3);
  color: var(--green);
}
.quick-reply:hover { background: rgba(26,58,42,0.8); }
.quick-reply.gold {
  background: rgba(200,169,110,0.08);
  border-color: rgba(200,169,110,0.3);
  color: var(--amber);
}
.quick-reply.gold:hover { background: rgba(200,169,110,0.15); }

/* ── UTILITY ── */
.hidden { display: none !important; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
