/* ============================================================================
 * App layout & components. All colors/fonts come from theme.css tokens —
 * edit those to re-skin. This file is structure + behavior styling only.
 * ==========================================================================*/

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--leading-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 {
  font-family: var(--font-heading);
  font-weight: var(--fw-medium);
  line-height: var(--leading-heading);
  letter-spacing: var(--tracking-tight);
  margin: 0 0 0.5em;
}
p { margin: 0 0 1em; }
a { color: var(--color-accent); }
strong { font-weight: var(--fw-semibold); }
[hidden] { display: none !important; }

.eyebrow {
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--color-accent);
  font-weight: var(--fw-semibold);
  margin-bottom: 1rem;
}
.muted { color: var(--color-text-muted); }
.soft  { color: var(--color-text-soft); }

/* ── Buttons ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  font-family: var(--font-heading);
  font-size: var(--btn-fs);
  font-weight: var(--btn-weight);
  letter-spacing: var(--btn-tracking);
  text-transform: var(--btn-transform);
  padding: var(--btn-pad);
  border-radius: var(--btn-radius);
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease),
              box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease), opacity .2s;
  text-decoration: none;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }

.btn-primary { background: var(--color-accent); color: var(--color-text-on-accent); }
.btn-primary:hover:not(:disabled) { background: var(--color-accent-hover); box-shadow: var(--shadow-cta); transform: translateY(-1px); }

.btn-ghost { background: transparent; color: var(--color-text); border-color: var(--color-line); }
.btn-ghost:hover:not(:disabled) { border-color: var(--color-text-soft); background: rgba(255,255,255,0.04); }

.btn-gold { background: var(--color-gold); color: var(--color-on-gold); }
.btn-gold:hover:not(:disabled) { background: var(--color-gold-bright); box-shadow: var(--shadow-gold); transform: translateY(-1px); }

.btn-link {
  background: none; border: none; color: var(--color-text-soft); cursor: pointer;
  font-family: var(--font-body); text-transform: none; letter-spacing: 0; padding: 0.4rem 0;
  font-size: var(--fs-sm);
}
.btn-link:hover { color: var(--color-text); }

.btn-row { display: flex; gap: 0.75rem; flex-wrap: wrap; align-items: center; }

/* ── Generic shell ────────────────────────────────────────────────────── */
.shell { min-height: 100dvh; display: flex; flex-direction: column; }
.wrap { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.wrap-wide { max-width: var(--container-wide); }
.screen { flex: 1; padding: clamp(2rem, 6vw, 4.5rem) 0 4rem; animation: fadeUp var(--dur) var(--ease); }

@keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

/* ── Top bar ──────────────────────────────────────────────────────────── */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem var(--gutter); border-bottom: 1px solid var(--color-line-soft);
  position: sticky; top: 0; background: var(--topbar-bg); backdrop-filter: blur(10px); z-index: 20;
}
.brandmark { display: flex; align-items: baseline; gap: 0.55rem; font-family: var(--font-heading); }
.brandmark .rpm { color: var(--color-accent); font-weight: var(--fw-bold); letter-spacing: 0.04em; }
.brandmark .name { font-weight: var(--fw-medium); font-size: var(--fs-lg); }
.topbar-actions { display: flex; gap: 0.5rem; align-items: center; }

/* Slim dev-only bar under the main nav (theme experiment switcher) */
.devbar {
  display: flex; justify-content: flex-end; align-items: center; gap: 0.5rem;
  padding: 0.4rem var(--gutter); background: var(--color-bg-2);
  border-bottom: 1px solid var(--color-line-soft);
}
.devbar:empty { display: none; }

.theme-pick { display: inline-flex; align-items: center; gap: 0.45rem; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-muted); }
.theme-pick select {
  font-family: var(--font-body); font-size: var(--fs-sm); color: var(--color-text);
  background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-sm);
  padding: 0.35rem 0.55rem; cursor: pointer;
}
.theme-pick select:focus { outline: none; border-color: var(--color-accent); }

/* ── Login ────────────────────────────────────────────────────────────── */
.login {
  position: fixed; inset: 0; z-index: 100; display: grid; place-items: center;
  background: var(--login-bg);
  padding: var(--gutter);
}
.login-card {
  width: 100%; max-width: 400px; background: var(--color-surface);
  border: 1px solid var(--color-line); border-radius: var(--radius-lg);
  padding: 2.25rem; box-shadow: var(--shadow-md); text-align: center;
}
.login-card .rpm-badge { color: var(--color-accent); font-weight: var(--fw-bold); letter-spacing: 0.2em; font-size: var(--fs-xs); }
.login-card h1 { font-size: var(--fs-h2); margin-top: 0.5rem; }
.login input {
  width: 100%; margin: 1.25rem 0 0.75rem; padding: 0.9rem 1rem; font-size: var(--fs-body);
  background: var(--color-bg-2); border: 1px solid var(--color-line); border-radius: var(--radius-sm);
  color: var(--color-text); font-family: var(--font-body);
}
.login input:focus { outline: none; border-color: var(--color-accent); }
.login .btn { width: 100%; }
.login .err { color: var(--color-accent); font-size: var(--fs-sm); min-height: 1.2em; margin-top: 0.5rem; }

/* ── Intro / system explanation ──────────────────────────────────────── */
.intro h1 { font-size: var(--fs-display); margin-bottom: 1rem; }
.intro .lede { font-size: var(--fs-lg); color: var(--color-text-soft); }
.pillars { display: grid; gap: 0.85rem; margin: 2rem 0; }
@media (min-width: 720px) { .pillars { grid-template-columns: repeat(3, 1fr); } }
.pillar {
  background: var(--color-surface); border: 1px solid var(--color-line);
  border-radius: var(--radius-md); padding: 1.25rem; border-top: 3px solid var(--color-accent);
}
.pillar:nth-child(2) { border-top-color: var(--color-gold); }
.pillar:nth-child(3) { border-top-color: var(--phase-m); }
.pillar .ltr { font-family: var(--font-heading); font-size: 2rem; font-weight: var(--fw-bold); line-height: 1; }
.pillar:nth-child(1) .ltr { color: var(--color-accent); }
.pillar:nth-child(2) .ltr { color: var(--color-gold); }
.pillar:nth-child(3) .ltr { color: var(--phase-m); }
.pillar h3 { margin: 0.5rem 0 0.35rem; }
.pillar p { color: var(--color-text-muted); font-size: var(--fs-sm); margin: 0; }
.intro-outline { margin-top: 1.5rem; }

/* ── Dashboard (list of maps) ─────────────────────────────────────────── */
.dash-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.map-grid { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 680px) { .map-grid { grid-template-columns: repeat(2, 1fr); } }
.map-card {
  background: var(--color-surface); border: 1px solid var(--color-line);
  border-radius: var(--radius-md); padding: 1.25rem 1.25rem 1rem; cursor: pointer;
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
  display: flex; flex-direction: column; gap: 0.5rem;
}
.map-card:hover { border-color: var(--color-text-soft); transform: translateY(-2px); }
.map-card h3 { margin: 0; }
.map-card .meta { font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.08em; }
.map-card .progress-line { height: 5px; background: var(--color-line); border-radius: 999px; overflow: hidden; margin-top: 0.5rem; }
.map-card .progress-line span { display: block; height: 100%; background: var(--status-done); transition: width var(--dur) var(--ease); }
.map-card .card-actions { display: flex; gap: 0.75rem; margin-top: 0.25rem; }
.map-card .pill { font-size: var(--fs-xs); padding: 0.2rem 0.6rem; border-radius: 999px; align-self: flex-start; }
.pill-done { background: rgba(34,197,94,0.15); color: var(--status-done); }
.pill-progress { background: var(--color-gold-soft); color: var(--color-gold-bright); }
.new-card {
  border-style: dashed; align-items: center; justify-content: center; text-align: center;
  color: var(--color-text-soft); min-height: 120px;
}
.new-card:hover { color: var(--color-text); border-color: var(--color-accent); }

/* ============================================================================
 * THE STEPPER  —  expandable checklist (the core experience)
 * ==========================================================================*/
.builder-head { margin-bottom: 1.75rem; }
.builder-head .title-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.builder-head h1 { font-size: var(--fs-h1); margin: 0; }
.builder-progress { font-size: var(--fs-sm); color: var(--color-text-muted); margin-top: 0.35rem; }

.stepper { position: relative; list-style: none; margin: 0; padding: 0; }

/* phase divider rows */
.phase-divider {
  display: flex; align-items: center; gap: 0.75rem;
  margin: 1.5rem 0 0.75rem; padding-left: 3.5rem;
}
.phase-divider:first-child { margin-top: 0; }
.phase-divider .ph-letter {
  font-family: var(--font-heading); font-weight: var(--fw-bold); font-size: var(--fs-sm);
  width: 1.5rem; text-align: center;
}
.phase-divider .ph-name { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tracking-eyebrow); color: var(--color-text-muted); }

/* each step */
.step { position: relative; padding-left: 3.5rem; padding-bottom: 0.5rem; }
/* connector line */
.step::before {
  content: ""; position: absolute; left: 1.05rem; top: 1.9rem; bottom: -0.5rem;
  width: 2px; background: var(--color-line);
}
.step:last-child::before { display: none; }
.step.done::before { background: var(--status-done); }

/* status node */
.node {
  position: absolute; left: 0; top: 0.55rem; width: 2.15rem; height: 2.15rem;
  border-radius: 50%; border: 2px solid var(--status-todo);
  display: grid; place-items: center; background: var(--color-bg);
  color: var(--status-todo); font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  transition: all var(--dur) var(--ease); z-index: 2;
}
.step.active .node { border-color: var(--status-active); color: var(--status-active); box-shadow: 0 0 0 5px rgba(245,181,40,0.12); }
.step.done .node { border-color: var(--status-done); background: var(--status-done); color: #04210f; }
.step.done .node::after { content: "✓"; font-size: 1rem; }
.step.done .node .num { display: none; }

/* clickable header */
.step-head {
  display: flex; align-items: center; gap: 0.75rem; padding: 0.65rem 0;
  cursor: pointer; user-select: none;
}
.step-head h3 { margin: 0; font-size: var(--fs-h3); font-weight: var(--fw-medium); transition: color var(--dur) var(--ease); }
.step.todo .step-head h3 { color: var(--color-text-muted); }
.step.todo .step-head { cursor: default; }
.step.done .step-head h3 { color: var(--color-text-soft); }
.step-head .chev { margin-left: auto; color: var(--color-text-muted); transition: transform var(--dur) var(--ease); flex-shrink: 0; }
.step.expanded .chev { transform: rotate(90deg); }

/* expandable body */
.step-body {
  display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur) var(--ease);
}
.step.expanded .step-body { grid-template-rows: 1fr; }
.step-body > .inner { overflow: hidden; }
.step.expanded .step-body > .inner { overflow: visible; }
.step-pane {
  background: var(--color-surface); border: 1px solid var(--color-line);
  border-radius: var(--radius-md); padding: 1.4rem; margin: 0.25rem 0 1rem;
  animation: fadeIn var(--dur) var(--ease);
}

/* purpose / description block */
.purpose-note { color: var(--color-text-soft); font-size: var(--fs-body); margin-bottom: 1rem; }

/* Tony's words — shown styled by default (play control off until real clips) */
.tony {
  margin: 0 0 1.25rem; padding: 1rem 1.1rem;
  background: var(--color-gold-soft); border: 1px solid rgba(224,169,56,0.22);
  border-radius: var(--radius-md);
}
.tony .src { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-gold-bright); margin-bottom: 0.5rem; }
.tony blockquote {
  margin: 0; padding-left: 1rem; border-left: 2px solid var(--color-gold);
  color: var(--color-text-soft); font-style: italic;
}

/* question + input */
.q-label { font-size: var(--fs-h3); font-weight: var(--fw-medium); margin-bottom: 0.5rem; }
.coach-prompt { color: var(--color-text-muted); font-size: var(--fs-sm); font-style: italic; margin-bottom: 0.85rem; }
.answer {
  width: 100%; min-height: 120px; resize: vertical; padding: 0.9rem 1rem;
  background: var(--color-bg-2); border: 1px solid var(--color-line); border-radius: var(--radius-sm);
  color: var(--color-text); font-family: var(--font-body); font-size: var(--fs-body); line-height: 1.55;
}
.answer:focus { outline: none; border-color: var(--color-accent); }

.step-actions { display: flex; gap: 0.75rem; margin-top: 1rem; align-items: center; flex-wrap: wrap; }
.step-actions .spacer { flex: 1; }

/* AI feedback */
.ai-block { margin-top: 1rem; animation: fadeUp var(--dur) var(--ease); }
.ai-bubble {
  display: flex; gap: 0.75rem; padding: 1rem; border-radius: var(--radius-md);
  background: var(--color-bg-2); border: 1px solid var(--color-line);
}
.ai-bubble .ava {
  width: 2.1rem; height: 2.1rem; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center;
  font-family: var(--font-heading); font-weight: var(--fw-bold); font-size: 0.8rem;
  background: var(--color-accent); color: #fff;
}
.ai-bubble.insight .ava { background: var(--status-done); color: #04210f; }
.ai-bubble .ai-text { font-size: var(--fs-body); }
.ai-bubble .ai-name { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-text-muted); margin-bottom: 0.2rem; }
.deepen-tag { font-size: var(--fs-xs); color: var(--color-gold-bright); margin-left: 0.5rem; }

.advance-row { display: flex; align-items: center; gap: 0.9rem; margin-top: 0.9rem; flex-wrap: wrap; animation: fadeUp var(--dur) var(--ease); }
.advance-row .countdown { font-size: var(--fs-sm); color: var(--color-text-muted); }
.advance-row .countdown b { color: var(--status-active); font-variant-numeric: tabular-nums; }
.advance-row .stay-btn { font-size: var(--fs-sm); }

.thinking { display: inline-flex; gap: 0.3rem; align-items: center; color: var(--color-text-muted); font-size: var(--fs-sm); }
.thinking .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--color-text-muted); animation: blink 1.2s infinite; }
.thinking .dot:nth-child(2) { animation-delay: .2s; } .thinking .dot:nth-child(3) { animation-delay: .4s; }
@keyframes blink { 0%,100%{opacity:.25} 50%{opacity:1} }

.banner { padding: 0.75rem 1rem; border-radius: var(--radius-sm); font-size: var(--fs-sm); margin-top: 0.75rem; }
.banner-warn { background: var(--color-gold-soft); color: var(--color-gold-bright); border: 1px solid rgba(224,169,56,0.3); }
.banner-err  { background: var(--color-accent-soft); color: #ff8b94; border: 1px solid rgba(225,29,45,0.3); }

.build-btn.pulse { animation: pulseGold 2.2s var(--ease) infinite; }
@keyframes pulseGold {
  0%, 100% { box-shadow: 0 0 0 0 rgba(224,169,56,0.0); }
  50%      { box-shadow: var(--shadow-gold); }
}

/* ── Generation ceremony ──────────────────────────────────────────────── */
.ceremony { position: fixed; inset: 0; z-index: 80; display: grid; place-items: center; background: var(--ceremony-bg); text-align: center; padding: var(--gutter); }
.ceremony .line { font-family: var(--font-heading); font-size: var(--fs-h2); color: var(--color-text); opacity: 0; transition: opacity .8s var(--ease); }
.ceremony .line.show { opacity: 1; }
.ceremony .spark { color: var(--color-gold-bright); }

/* ============================================================================
 * THE MAP  (final deliverable — premium gold-on-black)
 * ==========================================================================*/
.map-doc {
  background: var(--map-bg);
  border: 1px solid var(--color-line); border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 5vw, 3.25rem); box-shadow: var(--shadow-md);
}
.map-doc .map-eyebrow { color: var(--color-gold); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; font-size: var(--fs-xs); font-weight: var(--fw-semibold); }
.map-doc .map-title { font-size: var(--fs-display); margin: 0.5rem 0 0.25rem; }
.map-doc .map-for { color: var(--color-text-muted); font-size: var(--fs-sm); margin-bottom: 2rem; }
.map-section { padding: 1.75rem 0; border-top: 1px solid var(--color-line); }
.map-section:first-of-type { border-top: none; }
.map-section h2 {
  font-size: var(--fs-h3); text-transform: uppercase; letter-spacing: 0.12em; font-weight: var(--fw-semibold);
  color: var(--color-gold); margin-bottom: 0.85rem; display: flex; align-items: center; gap: 0.6rem;
}
.map-section .sec-num { color: var(--color-text-muted); font-variant-numeric: tabular-nums; }
.map-section p { font-size: var(--fs-lg); color: var(--color-text); }
.map-statement { font-size: var(--fs-h3); font-style: italic; color: var(--color-gold-bright); border-left: 3px solid var(--color-gold); padding-left: 1rem; margin-top: 1rem; }

.map-plan { display: grid; gap: 1rem; }
.plan-cat { background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-md); padding: 1rem 1.25rem; }
.plan-cat h4 { margin: 0 0 0.6rem; font-size: var(--fs-lg); color: var(--color-text); }
.plan-cat ul { margin: 0; padding-left: 1.1rem; }
.plan-cat li { margin-bottom: 0.4rem; color: var(--color-text-soft); }

.map-days { list-style: none; margin: 0; padding: 0; counter-reset: day; }
.map-days li { display: flex; gap: 0.85rem; align-items: flex-start; padding: 0.65rem 0; border-bottom: 1px solid var(--color-line-soft); }
.map-days li::before { counter-increment: day; content: counter(day); flex-shrink: 0; width: 1.75rem; height: 1.75rem; border-radius: 50%; background: var(--color-accent-soft); color: var(--color-accent); display: grid; place-items: center; font-weight: var(--fw-semibold); font-size: var(--fs-sm); }
.map-days .d-time { margin-left: auto; color: var(--color-gold); font-size: var(--fs-sm); white-space: nowrap; }

.map-callout { background: var(--color-accent-soft); border: 1px solid rgba(225,29,45,0.35); border-radius: var(--radius-md); padding: 1.5rem; font-size: var(--fs-lg); }
.map-commit { text-align: center; }
.map-commit .commit-text { font-size: var(--fs-h3); color: var(--color-gold-bright); font-style: italic; }
.map-commit .sign-line { margin-top: 2.5rem; border-top: 1px solid var(--color-line); padding-top: 0.5rem; color: var(--color-text-muted); font-size: var(--fs-sm); display: inline-block; min-width: 240px; }

.map-toolbar { display: flex; gap: 0.75rem; flex-wrap: wrap; justify-content: center; margin-top: 2rem; }

/* print */
@media print {
  .topbar, .map-toolbar, .login { display: none !important; }
  body { background: #fff; color: #000; }
  .map-doc { background: #fff; border: none; box-shadow: none; color: #000; }
  .map-doc .map-title, .map-section p, .plan-cat li, .map-callout { color: #000; }
}

/* small screens */
@media (max-width: 560px) {
  .step, .phase-divider { padding-left: 3rem; }
  .node { width: 1.9rem; height: 1.9rem; top: 0.45rem; }
  .step::before { left: 0.93rem; }
}
