* { margin:0; padding:0; box-sizing:border-box; }

/* ── Brand Tokens (exact match to homepage) ── */
:root {
  --cream:    #f7f4ef;
  --cream-lt: #faf8f4;
  --white:    #ffffff;
  --ink:      #1a1a1a;
  --ink-soft: #2c2c2c;
  --ink-mid:  #3a3a3a;
  --muted:    #888;
  --border:   #d8d0c0;
  --border-lt:#e0dbd0;
  --gold:     #b8972a;
  --gold-lt:  #c9aa45;
  --correct:  #4a7c59;
  --wrong:    #9b3a3a;
  --radius:   3px;
  --font-display: 'Cormorant Garamond', serif;
  --font-body:    'Montserrat', sans-serif;
}

body {
  background: var(--cream);
  font-family: var(--font-body);
  color: var(--ink);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ── Gold crown header (matches homepage frame) ── */
.lh-crown {
  width: 100%;
  height: 2px;
  background: var(--gold);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 200;
}

/* ── Sticky nav bar ── */
.lh-nav {
  width: 100%;
  background: var(--cream-lt);
  border-bottom: 0.5px solid var(--border);
  padding: 14px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 2px;
  z-index: 100;
  box-shadow: 0 4px 12px rgba(26,20,8,0.04);
}
.lh-nav-logo {
  display: flex;
  align-items: center;
  gap: 14px;
}
.lh-nav-logo img { height: 32px; width: auto; }
.lh-nav-logo-text {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 300;
  color: var(--ink);
  letter-spacing: 3px;
  text-transform: uppercase;
}
.lh-nav-logo-sub {
  font-size: 8px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 500;
  margin-top: 2px;
}
.lh-nav-right {
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  text-align: right;
  line-height: 1.8;
}

/* ── Progress bar ── */
.progress-track {
  width: 100%;
  height: 1px;
  background: var(--border-lt);
  position: sticky;
  top: calc(2px + 62px);
  z-index: 99;
}
.progress-fill {
  height: 1px;
  background: var(--gold);
  transition: width 0.5s ease;
}

/* ── Main wrapper ── */
.lh-wrap {
  width: 100%;
  max-width: 820px;
  padding: 52px 32px 100px;
}

/* ── Progress meta row ── */
.progress-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 28px;
}
.progress-q-label {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
}
.progress-section-pill {
  font-size: 8px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--gold);
  border: 0.5px solid var(--gold);
  padding: 4px 12px;
  font-weight: 500;
}

/* ── Section intro card ── */
.section-intro {
  background: var(--cream-lt);
  border: 0.5px solid var(--border);
  border-top: 2px solid var(--gold);
  padding: 52px 52px 44px;
  display: none;
  text-align: center;
}
.section-intro.active { display: block; }
.section-intro .sec-eyebrow {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 16px;
}
.section-intro h2 {
  font-family: var(--font-display);
  font-size: clamp(28px,4vw,42px);
  font-weight: 300;
  color: var(--ink);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.section-intro p {
  font-size: 13px;
  color: var(--ink-mid);
  line-height: 1.9;
  font-weight: 400;
  max-width: 480px;
  margin: 0 auto 36px;
}
.lh-rule {
  width: 36px;
  height: 1px;
  background: var(--gold);
  margin: 0 auto 36px;
}

/* ── Question card ── */
.question-card {
  background: var(--white);
  border: 0.5px solid var(--border);
  border-top: 2px solid var(--gold);
  padding: 52px 52px 40px;
  display: none;
  animation: fadeUp 0.35s ease;
}
.question-card.active { display: block; }

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

/* ── Question anatomy ── */
.q-eyebrow {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 18px;
}
.q-stem {
  font-family: var(--font-display);
  font-size: clamp(20px,3vw,28px);
  font-weight: 300;
  color: var(--ink);
  line-height: 1.45;
  margin-bottom: 10px;
}
.q-sub {
  font-size: 14px;
  color: var(--ink-mid);
  line-height: 1.9;
  margin-bottom: 28px;
  font-weight: 400;
}
.q-sub p { margin-bottom: 5px; }

/* ── Image placeholder ── */
.q-image {
  width: 100%;
  background: var(--cream);
  border: 0.5px solid var(--border);
  min-height: 200px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 28px;
  position: relative;
  overflow: hidden;
}
.q-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.q-image .img-ref {
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
}
.q-image .img-slot {
  width: 32px; height: 32px;
  border: 0.5px solid var(--border);
  display: flex; align-items: center; justify-content: center;
}
.q-image .img-slot svg { width:16px; height:16px; stroke: var(--border); }

/* ── Image grid (4-option) ── */
.img-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 28px;
}
.img-opt {
  border: 0.5px solid var(--border);
  background: var(--cream-lt);
  cursor: pointer;
  transition: border-color 0.2s;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 16px 12px 14px;
  gap: 10px;
  position: relative;
}
.img-opt:hover { border-color: var(--gold); }
.img-opt.selected { border-color: var(--gold); background: #fdf9ef; }
.img-opt.correct  { border-color: var(--correct); background: #f3f7f4; }
.img-opt.wrong    { border-color: var(--wrong);   background: #fdf4f4; }
.img-opt-img {
  width: 100%; height: 100px;
  background: var(--cream);
  border: 0.5px solid var(--border-lt);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.img-opt-img img { width:100%; height:100%; object-fit:cover; }
.img-opt-img .slot-txt {
  font-size: 10px;
  letter-spacing: 1px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 500;
}
.img-opt-label {
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--ink-mid);
  font-weight: 600;
  text-align: center;
}
.img-opt.correct .img-opt-label { color: var(--correct); }
.img-opt.wrong .img-opt-label   { color: var(--wrong); }
.img-opt.selected .img-opt-label { color: var(--gold); }

/* ── Multiple choice (text) ── */
.mc-list { list-style: none; display: flex; flex-direction: column; gap: 8px; margin-bottom: 28px; }
.mc-item {
  border: 0.5px solid var(--border);
  background: var(--cream-lt);
  padding: 14px 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 14px;
  color: var(--ink-mid);
  font-weight: 400;
  transition: border-color 0.2s, background 0.2s;
}
.mc-item:hover { border-color: var(--gold); background: #fdf9ef; }
.mc-item.selected { border-color: var(--gold); background: #fdf9ef; }
.mc-item.correct  { border-color: var(--correct); background: #f3f7f4; }
.mc-item.wrong    { border-color: var(--wrong);   background: #fdf4f4; }
.mc-letter {
  width: 26px; height: 26px;
  border: 0.5px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px;
  letter-spacing: 1px;
  color: var(--muted);
  font-weight: 600;
  flex-shrink: 0;
  transition: all 0.2s;
}
.mc-item.selected .mc-letter { background: var(--gold); border-color: var(--gold); color: #fff; }
.mc-item.correct  .mc-letter { background: var(--correct); border-color: var(--correct); color: #fff; }
.mc-item.wrong    .mc-letter { background: var(--wrong); border-color: var(--wrong); color: #fff; }

/* ── True / False ── */
.tf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 28px; }
.tf-item {
  border: 0.5px solid var(--border);
  background: var(--cream-lt);
  padding: 18px;
  cursor: pointer;
  text-align: center;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ink-mid);
  font-weight: 600;
  transition: all 0.2s;
}
.tf-item:hover { border-color: var(--gold); }
.tf-item.selected { border-color: var(--gold); background: #fdf9ef; color: var(--gold); }
.tf-item.correct  { border-color: var(--correct); background: #f3f7f4; color: var(--correct); }
.tf-item.wrong    { border-color: var(--wrong);   background: #fdf4f4; color: var(--wrong); }

/* ── Text answer ── */
.text-ans {
  width: 100%;
  background: var(--cream-lt);
  border: 0.5px solid var(--border);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 14px;
  padding: 16px 20px;
  resize: vertical;
  line-height: 1.8;
  min-height: 72px;
  margin-bottom: 28px;
  transition: border-color 0.2s;
  font-weight: 400;
}
.text-ans:focus { outline: none; border-color: var(--gold); }
.text-ans.large { min-height: 144px; }

/* ── Reading passage ── */
.reading-passage {
  background: var(--cream);
  border-left: 2px solid var(--gold);
  padding: 24px 28px;
  margin-bottom: 28px;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 300;
  color: var(--ink-soft);
  line-height: 2;
}
.reading-passage p { margin-bottom: 2px; }

/* ── Voice recorder ── */
.voice-recorder {
  background: var(--cream);
  border: 0.5px solid var(--border);
  padding: 24px 28px;
  margin-bottom: 28px;
}
.rec-label {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.rec-dot-static {
  width: 6px; height: 6px;
  background: var(--gold);
  border-radius: 50%;
}
.rec-controls { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.btn-rec {
  background: transparent;
  border: 0.5px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 10px 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: background 0.2s;
}
.btn-rec:hover { background: rgba(184,151,42,0.06); }
.btn-rec.recording { border-color: var(--wrong); color: var(--wrong); }
.rec-pulse {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}
.btn-rec.recording .rec-pulse { background: var(--wrong); animation: blink 0.9s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

.btn-playback {
  background: transparent;
  border: 0.5px solid var(--border);
  color: var(--muted);
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 10px 16px;
  cursor: pointer;
  transition: all 0.2s;
}
.btn-playback:hover:not(:disabled) { border-color: var(--gold); color: var(--gold); }
.btn-playback:disabled { opacity: 0.25; cursor: not-allowed; }

.rec-timer {
  font-size: 12px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  font-weight: 400;
}
.rec-badge {
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--correct);
  font-weight: 600;
  display: none;
  align-items: center;
  gap: 5px;
}
.rec-badge.show { display: flex; }

/* ── Audio player ── */
.audio-player {
  background: var(--cream);
  border: 0.5px solid var(--border);
  border-left: 2px solid var(--gold);
  padding: 20px 24px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 18px;
}
.btn-audio {
  width: 38px; height: 38px;
  border: 0.5px solid var(--gold);
  background: transparent;
  color: var(--gold);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
  transition: background 0.2s;
}
.btn-audio:hover:not(:disabled) { background: rgba(184,151,42,0.08); }
.btn-audio:disabled { opacity: 0.2; cursor: not-allowed; }
.audio-meta { flex: 1; }
.audio-title { font-size: 12px; letter-spacing: 1px; color: var(--ink-mid); margin-bottom: 4px; font-weight: 400; }
.audio-plays { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); font-weight: 500; }
.audio-bar { width:100%; height:1px; background: var(--border-lt); margin-top:10px; }
.audio-bar-fill { height:1px; background: var(--gold); width:0%; transition: width 0.1s linear; }
.listen-note {
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 20px;
  font-weight: 400;
  letter-spacing: 0.5px;
}
.listen-note.depleted { color: var(--wrong); }

/* ── Navigation ── */
.nav-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
  padding-top: 28px;
  border-top: 0.5px solid var(--border-lt);
  flex-wrap: wrap;
  gap: 12px;
}
.btn-back {
  background: transparent;
  border: 0.5px solid var(--border);
  color: var(--muted);
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 12px 22px;
  cursor: pointer;
  transition: all 0.2s;
}
.btn-back:hover:not(:disabled) { border-color: var(--ink); color: var(--ink); }
.btn-back:disabled { opacity: 0.2; cursor: not-allowed; }
.btn-skip {
  background: transparent;
  border: none;
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--muted);
  cursor: pointer;
  text-decoration: underline;
  text-decoration-color: var(--border);
  transition: color 0.2s;
  padding: 4px;
}
.btn-skip:hover { color: var(--ink-mid); }
.btn-advance {
  background: var(--gold);
  border: none;
  color: #fff;
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 14px 32px;
  cursor: pointer;
  transition: background 0.2s;
}
.btn-advance:hover { background: var(--gold-lt); }

/* ── Divider diamond ── */
.lh-divider {
  display: flex; align-items: center; gap: 14px;
  margin: 36px 0 28px;
}
.lh-divider::before, .lh-divider::after {
  content: ''; flex: 1; height: 0.5px; background: var(--border-lt);
}
.lh-diamond {
  width: 5px; height: 5px;
  background: var(--gold);
  transform: rotate(45deg);
}

/* ── Start screen ── */
#start-screen {
  width: 100%;
  max-width: 680px;
  padding: 80px 32px;
  text-align: center;
}
.start-logo img { height: 56px; margin-bottom: 36px; }
.start-title {
  font-family: var(--font-display);
  font-size: clamp(32px,5vw,56px);
  font-weight: 300;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 6px;
}
.start-sub {
  font-size: 9px;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 52px;
}
.start-meta {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1px;
  background: var(--border);
  border: 0.5px solid var(--border);
  margin-bottom: 44px;
}
.start-meta-item {
  background: var(--cream-lt);
  padding: 22px 16px;
  text-align: center;
}
.start-meta-val {
  font-family: var(--font-display);
  font-size: 34px;
  font-weight: 300;
  color: var(--gold);
  margin-bottom: 5px;
}
.start-meta-lbl {
  font-size: 8px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
}
.start-form { text-align: left; margin-bottom: 32px; }
.form-row { margin-bottom: 16px; }
.form-row label {
  display: block;
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 7px;
}
.form-row input {
  width: 100%;
  background: var(--cream-lt);
  border: 0.5px solid var(--border);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 14px;
  padding: 13px 16px;
  font-weight: 400;
  transition: border-color 0.2s;
}
.form-row input:focus { outline: none; border-color: var(--gold); }
.btn-begin {
  width: 100%;
  background: var(--gold);
  border: none;
  color: #fff;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 18px;
  cursor: pointer;
  transition: background 0.2s;
}
.btn-begin:hover { background: var(--gold-lt); }
.start-notice {
  font-size: 11px;
  color: var(--muted);
  margin-top: 18px;
  line-height: 1.8;
  font-weight: 400;
}

/* ── Summary screen ── */
#summary-screen {
  display: none;
  width: 100%;
  max-width: 820px;
  padding: 52px 32px 100px;
}
.summary-head {
  background: var(--white);
  border: 0.5px solid var(--border);
  border-top: 2px solid var(--gold);
  padding: 52px;
  text-align: center;
  margin-bottom: 1px;
}
.summary-seal {
  width: 52px; height: 52px;
  border: 0.5px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 24px;
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--gold);
  font-style: italic;
}
.summary-head h2 {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 300;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 8px;
}
.summary-head p { font-size: 12px; color: var(--muted); letter-spacing: 1px; font-weight: 400; }

.score-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1px;
  background: var(--border);
  margin-bottom: 28px;
}
.score-card {
  background: var(--white);
  padding: 28px 20px;
  text-align: center;
  border: 0.5px solid transparent;
}
.score-lbl {
  font-size: 8px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 12px;
}
.score-val {
  font-family: var(--font-display);
  font-size: 38px;
  font-weight: 300;
  color: var(--gold);
  margin-bottom: 4px;
}
.score-sub { font-size: 10px; color: var(--muted); font-weight: 400; letter-spacing: 0.5px; }
.score-card.manual .score-val { font-size: 16px; font-style: italic; font-weight: 400; color: var(--muted); }

.summary-section {
  background: var(--white);
  border: 0.5px solid var(--border);
  padding: 32px 40px;
  margin-bottom: 1px;
}
.summary-section h3 {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 20px;
}
.s-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 11px 0;
  border-bottom: 0.5px solid var(--border-lt);
  font-size: 13px;
}
.s-row:last-child { border-bottom: none; }
.s-q { color: var(--ink-mid); flex: 1; font-weight: 400; line-height: 1.5; }
.s-a { text-align: right; max-width: 52%; word-break: break-word; font-weight: 500; color: var(--ink); font-size: 12px; letter-spacing: 0.3px; }
.s-a.dim { color: var(--muted); font-style: italic; font-size: 11px; }

.btn-print {
  width: 100%;
  background: transparent;
  border: 0.5px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 18px;
  cursor: pointer;
  margin-top: 28px;
  transition: background 0.2s;
}
.btn-print:hover { background: rgba(184,151,42,0.05); }

/* ── Responsive ── */
@media (max-width: 600px) {
  .lh-wrap, #summary-screen { padding: 32px 16px 80px; }
  .question-card, .section-intro, .summary-head { padding: 32px 24px; }
  .start-meta { grid-template-columns: 1fr; }
  .score-grid { grid-template-columns: repeat(2,1fr); }
  .img-grid { grid-template-columns: 1fr 1fr; }
  .nav-bar { flex-direction: column; align-items: stretch; text-align: center; }
  .btn-back, .btn-advance { width: 100%; }
}

@media print {
  .lh-crown, .lh-nav, .progress-track { display: none; }
  .btn-print, .nav-bar { display: none; }
  * { background: white !important; color: black !important; }
  .question-card, .section-intro { border: 1px solid #ccc !important; }
}
/* ══ Two-column assessment layout ═════════════════════════════════ */
.lhye-assessment-layout {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  display: none;
  flex-direction: row;
  align-items: flex-start;
  gap: 0;
  padding: 0 16px;
}

/* Question area takes remaining space */
.lhye-question-area {
  flex: 1;
  min-width: 0;
}
.lhye-question-area .lh-wrap {
  max-width: 100%;
  padding-right: 24px;
}

/* ══ Nav panel — right sidebar on desktop ══════════════════════════ */
.lhye-nav-panel {
  width: 200px;
  flex-shrink: 0;
  background: var(--white);
  border: 0.5px solid var(--border);
  border-top: 2px solid var(--gold);
  padding: 16px 14px;
  position: sticky;
  top: 80px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
  align-self: flex-start;
}
.lhye-nav-panel-label {
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.lhye-nav-panel-label span {
  color: var(--gold);
  font-size: 11px;
  letter-spacing: 0;
  font-weight: 500;
}
.lhye-nav-panel-label span { color: var(--gold); }
.lhye-nav-tiles {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.lhye-nav-tile {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
  border: 0.5px solid var(--border);
  background: var(--cream-lt);
  color: var(--muted);
  transition: all 0.15s;
  font-family: var(--font-body);
  position: relative;
}
.lhye-nav-tile:hover { border-color: var(--gold); color: var(--gold); }
/* Current */
.lhye-nav-tile.current {
  border-color: var(--gold);
  background: var(--gold);
  color: #fff;
}
/* Answered */
.lhye-nav-tile.answered {
  border-color: #4a7c59;
  background: #f3f7f4;
  color: #4a7c59;
}
/* Visited but skipped */
.lhye-nav-tile.skipped {
  border-color: #9b3a3a;
  background: #fdf4f4;
  color: #9b3a3a;
}
/* Section divider tile */
.lhye-nav-section-break {
  width: 100%;
  height: 1px;
  background: var(--border-lt);
  margin: 6px 0 2px;
}
.lhye-nav-section-name {
  width: 100%;
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 6px;
}
/* Legend */
.lhye-nav-legend {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 12px;
}
.lhye-nav-legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 8px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
}
.lhye-nav-legend-dot {
  width: 10px;
  height: 10px;
  border: 0.5px solid;
}
.lhye-nav-legend-dot.d-grey   { border-color: var(--border); background: var(--cream-lt); }
.lhye-nav-legend-dot.d-gold   { border-color: var(--gold); background: var(--gold); }
.lhye-nav-legend-dot.d-green  { border-color: #4a7c59; background: #f3f7f4; }
.lhye-nav-legend-dot.d-red    { border-color: #9b3a3a; background: #fdf4f4; }

/* ══ Waveform recorder (candidate) ════════════════════════════════ */
.lhye-waveform-wrap {
  margin-top: 12px;
  display: none;
}
.lhye-waveform-wrap.visible { display: block; }
.lhye-waveform-canvas {
  width: 100%;
  height: 56px;
  background: var(--cream);
  border: 0.5px solid var(--border);
  display: block;
}
.lhye-waveform-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}
.lhye-wf-play {
  background: transparent;
  border: 0.5px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 8px 16px;
  cursor: pointer;
  transition: background 0.2s;
}
.lhye-wf-play:hover { background: rgba(184,151,42,0.08); }
.lhye-wf-time {
  font-size: 11px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}
.lhye-wf-bar {
  flex: 1;
  height: 1px;
  background: var(--border-lt);
  position: relative;
  cursor: pointer;
}
.lhye-wf-bar-fill {
  height: 1px;
  background: var(--gold);
  width: 0%;
  transition: width 0.1s linear;
  pointer-events: none;
}

/* ══ Mobile: nav panel stacks above question ══════════════════════ */
@media (max-width: 768px) {
  .lhye-assessment-layout {
    flex-direction: column;
    padding: 0 8px;
  }
  .lhye-nav-panel {
    width: 100%;
    position: static;
    max-height: none;
    overflow-y: visible;
    margin-bottom: 16px;
    border-top: 2px solid var(--gold);
  }
  .lhye-nav-tiles { flex-direction: row; flex-wrap: wrap; }
  .lhye-nav-legend { flex-direction: row; flex-wrap: wrap; gap: 8px; }
  .lhye-question-area .lh-wrap { padding-right: 0; }
}

/* ══ Save & Next / Skip / Submit buttons ══════════════════════════ */
.btn-save-next {
  background: var(--gold);
  border: none;
  color: #fff;
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 14px 24px;
  cursor: pointer;
  transition: background 0.2s;
}
.btn-save-next:hover { background: var(--gold-lt); }

.btn-submit-final {
  background: #4a7c59;
  border: none;
  color: #fff;
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 14px 32px;
  cursor: pointer;
  transition: background 0.2s;
}
.btn-submit-final:hover { background: #3d6b4a; }

/* ══ Two-button listening player ══════════════════════════════════ */
.audio-player-v2 {
  background: var(--cream);
  border: 0.5px solid var(--border);
  border-left: 2px solid var(--gold);
  padding: 20px 24px;
  margin-bottom: 20px;
}
.audio-player-label {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 16px;
}
.audio-two-btns {
  display: flex;
  gap: 12px;
  align-items: center;
}
.btn-listen {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 12px 22px;
  cursor: pointer;
  transition: all 0.2s;
  border: 0.5px solid;
}
.btn-listen-1 {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.btn-listen-1:hover:not(:disabled) { background: var(--gold-lt); border-color: var(--gold-lt); }
.btn-listen-2 {
  background: transparent;
  border-color: var(--border);
  color: var(--muted);
}
.btn-listen-2:not(:disabled):hover { border-color: var(--gold); color: var(--gold); }
.btn-listen-2:not(:disabled) {
  border-color: var(--gold);
  color: var(--gold);
}
.btn-listen:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}
.btn-listen.used {
  background: var(--cream-lt) !important;
  border-color: var(--border) !important;
  color: var(--muted) !important;
  opacity: 0.6;
}
.listen-icon { font-size: 12px; }
