:root {
  --navy:  #1B2B4B;
  --gold:  #C9922A;
  --ember: #C0502A;
  --slate: #5A6475;
  --cream: #F7F3EC;
  --white: #FFFFFF;
  --light: #EDEBE6;
  --green: #1A6B45;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  font-family:'Lato',sans-serif;
  background:var(--navy);
  color:var(--cream);
  min-height:100vh;
  overflow-x:hidden;
}

/* ── GRID TEXTURE ── */
body::before {
  content:'';
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(201,146,42,0.04) 59px,rgba(201,146,42,0.04) 60px),
    repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(201,146,42,0.04) 59px,rgba(201,146,42,0.04) 60px);
}

/* ── SCREENS ── */
.screen { display:none; min-height:100vh; position:relative; z-index:1; }
.screen.active { display:flex; flex-direction:column; }

/* ── COVER ── */
#cover {
  align-items:center; justify-content:center;
  text-align:center; padding:3rem 2rem;
}
.cover-inner { max-width:620px; }

.eyebrow {
  font-size:10px; font-weight:700; letter-spacing:0.28em;
  color:var(--gold); text-transform:uppercase; margin-bottom:1.25rem;
  opacity:0; animation:fadeUp .7s ease forwards .2s;
}

.cover-logo {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(14px,3vw,18px); letter-spacing:0.12em;
  color:rgba(201,146,42,0.6); margin-bottom:1.5rem;
  opacity:0; animation:fadeUp .7s ease forwards .3s;
}

.cover-headline {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(52px,10vw,88px);
  line-height:.92; letter-spacing:.03em;
  color:var(--white); margin-bottom:.75rem;
  opacity:0; animation:fadeUp .8s ease forwards .4s;
}
.cover-headline span { color:var(--gold); }

.cover-sub {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(17px,2.5vw,22px); font-style:italic;
  color:rgba(247,243,236,.7); margin-bottom:2rem; line-height:1.5;
  opacity:0; animation:fadeUp .7s ease forwards .55s;
}

.cover-desc {
  font-size:14px; color:var(--slate); line-height:1.8;
  margin-bottom:2.5rem; max-width:480px; margin-left:auto; margin-right:auto;
  opacity:0; animation:fadeUp .7s ease forwards .7s;
}

.btn-primary {
  display:inline-block; background:var(--gold); color:var(--navy);
  font-weight:900; font-size:13px; letter-spacing:.15em;
  text-transform:uppercase; padding:16px 40px; border-radius:999px;
  border:none; cursor:pointer; transition:transform .2s ease, box-shadow .2s ease;
  opacity:0; animation:fadeUp .7s ease forwards .85s;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(201,146,42,.3); }
.btn-primary:active { transform:scale(.97); }

.cover-note {
  font-size:11px; color:rgba(90,100,117,.7); margin-top:1rem;
  opacity:0; animation:fadeUp .7s ease forwards 1s;
}

/* ── QUESTION SCREEN ── */
#quiz { padding:0; }

.quiz-header {
  background:rgba(0,0,0,.2); border-bottom:1px solid rgba(201,146,42,.12);
  padding:1.25rem 2rem; display:flex; align-items:center;
  justify-content:space-between; flex-shrink:0;
}
.quiz-logo {
  font-family:'Bebas Neue',sans-serif;
  font-size:18px; letter-spacing:.1em; color:var(--gold);
}
.quiz-progress-label {
  font-size:12px; font-weight:700; letter-spacing:.12em;
  color:var(--slate); text-transform:uppercase;
}

.progress-bar-wrap {
  width:100%; height:3px; background:rgba(255,255,255,.08);
  position:relative; flex-shrink:0;
}
.progress-bar-fill {
  height:100%; background:var(--gold);
  transition:width .5s cubic-bezier(.4,0,.2,1);
  position:absolute; top:0; left:0;
}

.quiz-body {
  flex:1; display:flex; align-items:center; justify-content:center;
  padding:2rem 1.5rem;
}
.question-card {
  max-width:680px; width:100%;
  animation:fadeUp .5s ease forwards;
}

.q-category {
  font-size:10px; font-weight:700; letter-spacing:.25em;
  color:var(--gold); text-transform:uppercase; margin-bottom:12px;
  display:flex; align-items:center; gap:8px;
}
.q-category::before { content:'✦'; font-size:9px; }

.q-number {
  font-family:'Bebas Neue',sans-serif;
  font-size:13px; letter-spacing:.2em; color:var(--slate);
  margin-bottom:8px;
}

.q-text {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(22px,4vw,32px); line-height:1.35;
  color:var(--white); margin-bottom:.5rem; font-weight:600;
}

.q-nudge {
  font-size:13px; color:var(--slate); margin-bottom:2rem;
  font-style:italic; line-height:1.6;
}

/* ── OPTIONS ── */
.options { display:flex; flex-direction:column; gap:10px; }

.option {
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px; padding:1.1rem 1.25rem;
  cursor:pointer; display:flex; align-items:flex-start; gap:14px;
  transition:all .2s ease; position:relative; overflow:hidden;
}
.option::before {
  content:''; position:absolute; inset:0;
  background:rgba(201,146,42,.07); opacity:0; transition:opacity .2s;
}
.option:hover { border-color:rgba(201,146,42,.4); }
.option:hover::before { opacity:1; }
.option.selected {
  border-color:var(--gold); background:rgba(201,146,42,.1);
}
.option.selected::before { opacity:1; }

.option-dot {
  width:20px; height:20px; border-radius:50%;
  border:1.5px solid rgba(255,255,255,.25);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; margin-top:1px; transition:all .2s ease;
}
.option.selected .option-dot {
  border-color:var(--gold); background:var(--gold);
}
.option.selected .option-dot::after {
  content:''; width:8px; height:8px; border-radius:50%;
  background:var(--navy); display:block;
}

.option-text { font-size:14px; color:rgba(247,243,236,.85); line-height:1.55; }
.option.selected .option-text { color:var(--cream); }

/* ── SCALE ── */
.scale-wrap { display:flex; flex-direction:column; gap:10px; }
.scale-labels {
  display:flex; justify-content:space-between;
  font-size:11px; color:var(--slate); padding:0 2px; font-weight:700; letter-spacing:.05em;
}
.scale-btns { display:flex; gap:8px; }
.scale-btn {
  flex:1; aspect-ratio:1; border-radius:10px;
  border:1.5px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04); cursor:pointer;
  font-family:'Bebas Neue',sans-serif; font-size:18px;
  color:var(--slate); transition:all .2s ease;
  display:flex; align-items:center; justify-content:center;
}
.scale-btn:hover { border-color:rgba(201,146,42,.4); color:var(--gold); }
.scale-btn.selected { border-color:var(--gold); background:rgba(201,146,42,.15); color:var(--gold); }

/* ── NAV ── */
.quiz-nav {
  padding:1.5rem 2rem; display:flex; align-items:center;
  justify-content:space-between; flex-shrink:0;
  border-top:1px solid rgba(255,255,255,.05);
}
.btn-back {
  background:transparent; border:1px solid rgba(255,255,255,.12);
  color:var(--slate); font-size:12px; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  padding:12px 24px; border-radius:999px; cursor:pointer;
  transition:all .2s; font-family:'Lato',sans-serif;
}
.btn-back:hover { border-color:rgba(255,255,255,.3); color:var(--cream); }
.btn-back:disabled { opacity:.3; pointer-events:none; }

.btn-next {
  background:var(--gold); color:var(--navy);
  font-weight:900; font-size:12px; letter-spacing:.15em;
  text-transform:uppercase; padding:14px 32px; border-radius:999px;
  border:none; cursor:pointer; transition:all .2s; font-family:'Lato',sans-serif;
  opacity:.4; pointer-events:none;
}
.btn-next.ready { opacity:1; pointer-events:all; }
.btn-next.ready:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(201,146,42,.35); }

/* ── RESULTS ── */
#results { padding:0; }

.results-header {
  background:rgba(0,0,0,.25); border-bottom:1px solid rgba(201,146,42,.15);
  padding:1.25rem 2rem; text-align:center;
}
.results-header-logo {
  font-family:'Bebas Neue',sans-serif;
  font-size:18px; letter-spacing:.12em; color:var(--gold);
}

.results-body { max-width:780px; margin:0 auto; padding:2.5rem 1.5rem 4rem; }

.results-hero { text-align:center; margin-bottom:3rem; }
.results-eyebrow {
  font-size:10px; font-weight:700; letter-spacing:.28em;
  color:var(--gold); text-transform:uppercase; margin-bottom:12px;
}
.results-name-line {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(36px,7vw,60px); color:var(--white); letter-spacing:.04em;
  line-height:.95; margin-bottom:.5rem;
}
.results-name-line span { color:var(--gold); }
.results-tagline {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(16px,2.5vw,21px); font-style:italic;
  color:rgba(247,243,236,.7); margin-bottom:2rem; line-height:1.5;
}

/* Profile badges */
.profile-badges {
  display:flex; flex-wrap:wrap; gap:8px;
  justify-content:center; margin-bottom:2rem;
}
.profile-badge {
  font-size:11px; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; padding:6px 16px; border-radius:999px;
  border:1px solid rgba(201,146,42,.35);
  background:rgba(201,146,42,.1); color:var(--gold);
}

/* Top paths */
.paths-label {
  font-size:10px; font-weight:700; letter-spacing:.25em;
  color:var(--gold); text-transform:uppercase;
  display:flex; align-items:center; gap:8px; margin-bottom:1.25rem;
}
.paths-label::before { content:'✦'; font-size:9px; }

.path-card {
  border-radius:14px; margin-bottom:1rem; overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  animation:fadeUp .5s ease forwards;
}
.path-card:nth-child(2) { animation-delay:.1s; opacity:0; }
.path-card:nth-child(3) { animation-delay:.2s; opacity:0; }

.path-top {
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:center; gap:1rem; padding:1.25rem 1.5rem;
  background:rgba(255,255,255,.05);
}
.path-rank {
  font-family:'Bebas Neue',sans-serif;
  font-size:42px; line-height:1; letter-spacing:.02em;
}
.path-rank.r1 { color:var(--gold); }
.path-rank.r2 { color:var(--slate); }
.path-rank.r3 { color:rgba(90,100,117,.6); }

.path-name-wrap {}
.path-name {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(22px,4vw,30px); letter-spacing:.04em; color:var(--white);
  line-height:1;
}
.path-subtitle {
  font-size:12px; color:var(--slate); margin-top:3px; font-style:italic;
}

.path-score-wrap { text-align:right; }
.path-score-num {
  font-family:'Bebas Neue',sans-serif;
  font-size:32px; color:var(--gold); line-height:1;
}
.path-score-label { font-size:10px; color:var(--slate); letter-spacing:.1em; }

.path-bar-wrap {
  padding:0 1.5rem; background:rgba(255,255,255,.03);
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
}
.path-bar-track {
  height:4px; background:rgba(255,255,255,.06); border-radius:2px; margin:12px 0;
}
.path-bar-fill {
  height:100%; border-radius:2px; background:var(--gold);
  transition:width 1s cubic-bezier(.4,0,.2,1);
}

.path-body { padding:1.25rem 1.5rem; background:rgba(0,0,0,.15); }
.path-why { font-size:13px; color:rgba(247,243,236,.75); line-height:1.75; margin-bottom:1rem; }

.path-examples-label {
  font-size:10px; font-weight:700; letter-spacing:.15em;
  color:var(--gold); text-transform:uppercase; margin-bottom:8px;
}
.path-examples { display:flex; flex-wrap:wrap; gap:6px; }
.path-example {
  font-size:11px; padding:4px 12px; border-radius:999px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  color:rgba(247,243,236,.7);
}

/* Dimension bars */
.dimensions-section { margin:2.5rem 0; }
.dim-row { margin-bottom:1.25rem; }
.dim-header { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; }
.dim-name { font-size:13px; font-weight:700; color:var(--cream); }
.dim-score { font-size:13px; color:var(--gold); font-weight:700; }
.dim-bar-track { height:6px; background:rgba(255,255,255,.07); border-radius:3px; }
.dim-bar-fill { height:100%; border-radius:3px; background:linear-gradient(90deg,var(--navy) 0%,var(--gold) 100%); transition:width 1.2s cubic-bezier(.4,0,.2,1); }
.dim-desc { font-size:12px; color:var(--slate); margin-top:4px; line-height:1.5; }

/* Values summary */
.values-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin:1.5rem 0; }
.value-card {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
  border-radius:10px; padding:1rem;
}
.value-card-label { font-size:10px; font-weight:700; letter-spacing:.15em; color:var(--gold); text-transform:uppercase; margin-bottom:4px; }
.value-card-text { font-size:13px; color:rgba(247,243,236,.8); line-height:1.6; }

/* Action steps */
.next-steps { margin-top:2.5rem; }
.step-row {
  display:grid; grid-template-columns:44px 1fr;
  gap:1rem; margin-bottom:1rem;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
  border-radius:10px; padding:1rem; align-items:center;
}
.step-num {
  width:36px; height:36px; border-radius:50%;
  background:var(--gold); color:var(--navy);
  font-family:'Bebas Neue',sans-serif; font-size:18px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.step-text { font-size:13px; color:rgba(247,243,236,.8); line-height:1.6; }
.step-text strong { color:var(--cream); }

.cta-block {
  background:rgba(201,146,42,.08); border:1px solid rgba(201,146,42,.25);
  border-radius:14px; padding:2rem; text-align:center; margin-top:2.5rem;
}
.cta-block h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:28px; color:var(--white); letter-spacing:.05em; margin-bottom:6px;
}
.cta-block p {
  font-family:'Cormorant Garamond',serif; font-size:17px;
  font-style:italic; color:rgba(247,243,236,.7); margin-bottom:1.25rem;
}

.btn-restart {
  background:transparent; border:1px solid rgba(201,146,42,.4);
  color:var(--gold); font-size:11px; font-weight:700;
  letter-spacing:.15em; text-transform:uppercase;
  padding:10px 24px; border-radius:999px; cursor:pointer;
  transition:all .2s; font-family:'Lato',sans-serif; margin-top:.75rem;
}
.btn-restart:hover { background:rgba(201,146,42,.1); }

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

@media(max-width:560px){
  .scale-btn { font-size:14px; }
  .values-grid { grid-template-columns:1fr; }
  .path-top { grid-template-columns:auto 1fr; }
  .path-score-wrap { display:none; }
}