/* ══════════════════════════════════════════════════════════
   LE MOT — STYLES
   ══════════════════════════════════════════════════════════ */
:root {
  --ink:       #0e0c0a;
  --ink-2:     #1a1714;
  --ink-3:     #252118;
  --gold:      #c9a84c;
  --gold-dim:  #8a6e2f;
  --cream:     #f0e8d8;
  --cream-dim: #a89880;
  --rose:      #b85c5c;
  --green:     #6a9e72;
  --amber:     #c4883a;
  --card-bg:   #16130f;
  --border:    rgba(201,168,76,0.18);
  --shadow:    0 32px 80px rgba(0,0,0,0.7);
}

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

html, body {
  height: 100%; background: var(--ink); color: var(--cream);
  font-family: 'Cormorant Garamond', Georgia, serif;
  overflow: hidden; -webkit-tap-highlight-color: transparent;
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: ''; position: fixed; inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(201,168,76,0.07) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 80% 90%, rgba(184,92,92,0.05) 0%, transparent 60%);
  pointer-events: none; z-index: 0;
}

#app {
  position: relative; display: flex; flex-direction: column;
  height: 100dvh; max-width: 480px; margin: 0 auto; z-index: 1;
}

/* ── Header ── */
header {
  padding: max(48px, env(safe-area-inset-top, 48px)) 20px 12px;
  display: flex; align-items: center; justify-content: space-between;
  flex-shrink: 0; gap: 8px;
}
.app-title {
  font-family: 'Playfair Display', serif; font-size: 13px; font-weight: 400;
  letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold);
  flex: 1; text-align: center;
}
.app-title span { font-style: italic; letter-spacing: 0.1em; }
.header-btn {
  height: 32px; border: 1px solid var(--border); background: transparent;
  color: var(--gold); border-radius: 16px; cursor: pointer; font-size: 13px;
  font-family: 'Raleway', sans-serif; letter-spacing: 0.05em;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; flex-shrink: 0; padding: 0 12px;
}
.header-btn:active { background: rgba(201,168,76,0.1); border-color: var(--gold); }
.header-btn.icon-btn { width: 32px; padding: 0; font-size: 18px; }
.header-btn.active-mode { background: rgba(201,168,76,0.12); border-color: var(--gold); }

/* ── Tabs ── */
nav { display: flex; justify-content: center; padding: 4px 28px 0; flex-shrink: 0; }
.tab {
  font-family: 'Raleway', sans-serif; font-size: 11px; font-weight: 300;
  letter-spacing: 0.3em; text-transform: uppercase; color: var(--cream-dim);
  padding: 8px 20px; border: none; background: transparent; cursor: pointer;
  position: relative; transition: color 0.3s;
}
.tab::after {
  content: ''; position: absolute; bottom: 0; left: 50%; right: 50%;
  height: 1px; background: var(--gold); transition: left 0.3s, right 0.3s;
}
.tab.active { color: var(--cream); }
.tab.active::after { left: 20%; right: 20%; }
.divider { margin: 12px 28px 0; height: 1px; background: var(--border); flex-shrink: 0; }

/* ── Main ── */
main {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 12px 24px 12px; gap: 14px; overflow: hidden;
}

/* ── Summary Screen ── */
.summary-screen {
  display: flex; flex-direction: column; align-items: center;
  gap: 24px; width: 100%; max-width: 320px;
}
.summary-title {
  font-family: 'Playfair Display', serif; font-size: 26px; font-style: italic;
  color: var(--cream); text-align: center;
}
.summary-title span { color: var(--gold); }
.summary-stats {
  display: flex; gap: 0; width: 100%;
  border: 1px solid var(--border); border-radius: 2px; overflow: hidden;
}
.summary-stat {
  flex: 1; padding: 20px 12px; display: flex; flex-direction: column;
  align-items: center; gap: 6px;
  border-right: 1px solid var(--border);
}
.summary-stat:last-child { border-right: none; }
.summary-stat-num {
  font-family: 'Playfair Display', serif; font-size: 36px; font-weight: 400;
}
.summary-stat-num.due   { color: var(--gold); }
.summary-stat-num.new   { color: var(--cream-dim); }
.summary-stat-num.total { color: var(--cream-dim); opacity: 0.5; }
.summary-stat-lbl {
  font-family: 'Raleway', sans-serif; font-size: 9px; font-weight: 300;
  letter-spacing: 0.25em; text-transform: uppercase; color: var(--cream-dim); opacity: 0.6;
}
.summary-message {
  font-family: 'Cormorant Garamond', serif; font-size: 16px; font-style: italic;
  color: var(--cream-dim); opacity: 0.7; text-align: center; line-height: 1.5;
}
.btn-start {
  font-family: 'Raleway', sans-serif; font-size: 11px; font-weight: 300;
  letter-spacing: 0.35em; text-transform: uppercase;
  border: 1px solid rgba(201,168,76,0.4); background: transparent; color: var(--cream);
  padding: 16px 48px; cursor: pointer; transition: all 0.25s; border-radius: 1px; width: 100%;
}
.btn-start:active { background: rgba(201,168,76,0.1); border-color: var(--gold); }

/* ── Progress Chart Button ── */
.btn-progress {
  font-family: 'Raleway', sans-serif; font-size: 10px; font-weight: 300;
  letter-spacing: 0.25em; text-transform: uppercase;
  border: 1px solid rgba(201,168,76,0.2); background: transparent; color: var(--cream-dim);
  padding: 10px 24px; cursor: pointer; transition: all 0.25s; border-radius: 1px; width: 100%;
}
.btn-progress:active { background: rgba(201,168,76,0.06); }

/* ── Progress bar ── */
.progress-bar { width: 100%; max-width: 320px; display: flex; flex-direction: column; align-items: center; gap: 6px; }
.progress-track { width: 100%; height: 1px; background: rgba(255,255,255,0.08); border-radius: 1px; overflow: hidden; }
.progress-fill { height: 100%; background: linear-gradient(90deg, var(--gold-dim), var(--gold)); border-radius: 1px; transition: width 0.5s ease; }
.progress-label { font-family: 'Raleway', sans-serif; font-size: 10px; font-weight: 300; letter-spacing: 0.25em; color: var(--cream-dim); opacity: 0.6; }

/* ── Card ── */
.card-scene { width: 100%; max-width: 340px; height: 260px; perspective: 1200px; cursor: pointer; flex-shrink: 0; }
.card-inner { position: relative; width: 100%; height: 100%; transform-style: preserve-3d; transition: transform 0.55s cubic-bezier(0.4,0,0.2,1); }
.card-inner.flipped { transform: rotateY(180deg); }
.card-face {
  position: absolute; inset: 0; backface-visibility: hidden; -webkit-backface-visibility: hidden;
  border-radius: 2px; padding: 20px 24px;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px;
}
.card-front { background: var(--card-bg); border: 1px solid var(--border); box-shadow: var(--shadow), inset 0 1px 0 rgba(201,168,76,0.1); }
.card-front::before, .card-front::after { content: '✦'; position: absolute; font-size: 7px; color: var(--gold-dim); opacity: 0.5; }
.card-front::before { top: 12px; left: 16px; }
.card-front::after  { bottom: 12px; right: 16px; }
.card-back { background: linear-gradient(145deg, #1c1610, #120f0b); border: 1px solid rgba(201,168,76,0.28); box-shadow: var(--shadow), inset 0 1px 0 rgba(201,168,76,0.15); transform: rotateY(180deg); }

.direction-badge { position: absolute; top: 12px; right: 14px; font-size: 9px; font-family: 'Raleway', sans-serif; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold-dim); opacity: 0.6; }
.due-badge { position: absolute; top: 12px; left: 14px; font-size: 9px; font-family: 'Raleway', sans-serif; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold); opacity: 0.8; }

.card-label { font-family: 'Raleway', sans-serif; font-size: 9px; font-weight: 300; letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold); opacity: 0.7; }
.card-word { font-family: 'Playfair Display', serif; font-size: 34px; font-weight: 400; color: var(--cream); text-align: center; line-height: 1.2; }
.card-word.french { font-style: italic; }
.card-word.phrase { font-size: 20px; line-height: 1.4; }
.card-phonetic { font-family: 'Cormorant Garamond', serif; font-size: 14px; font-weight: 300; font-style: italic; color: var(--gold); opacity: 0.85; letter-spacing: 0.05em; text-align: center; }
.card-hint-sentence {
  font-family: 'Cormorant Garamond', serif; font-size: 12px; font-style: italic;
  color: var(--cream-dim); opacity: 0.45; text-align: center; line-height: 1.4;
  padding: 0 8px; margin-top: 2px;
}
.card-tap-hint { font-family: 'Raleway', sans-serif; font-size: 10px; font-weight: 300; letter-spacing: 0.2em; color: var(--cream-dim); opacity: 0.35; text-transform: uppercase; margin-top: 4px; }
.card-category { font-family: 'Cormorant Garamond', serif; font-size: 13px; font-style: italic; color: var(--gold-dim); opacity: 0.8; }
.card-context { font-family: 'Cormorant Garamond', serif; font-size: 13px; font-style: italic; color: var(--cream-dim); opacity: 0.7; text-align: center; line-height: 1.4; padding: 0 8px; }

/* ── Audio button ── */
.audio-btn {
  background: transparent; border: 1px solid rgba(201,168,76,0.25); border-radius: 50%;
  width: 32px; height: 32px; display: flex; align-items: center; justify-content: center;
  color: var(--gold-dim); font-size: 14px; cursor: pointer; transition: all 0.2s;
  flex-shrink: 0;
}
.audio-btn:active { background: rgba(201,168,76,0.12); border-color: var(--gold); color: var(--gold); }
.audio-btn.playing { border-color: var(--gold); color: var(--gold); background: rgba(201,168,76,0.08); }

/* ── Typing mode ── */
.typing-area {
  width: 100%; max-width: 340px; display: flex; flex-direction: column; gap: 10px; flex-shrink: 0;
}
.typing-input {
  width: 100%; background: rgba(255,255,255,0.04); border: 1px solid var(--border);
  border-radius: 1px; padding: 14px 16px; color: var(--cream);
  font-family: 'Playfair Display', serif; font-size: 22px; font-style: italic;
  outline: none; transition: border-color 0.2s; text-align: center; letter-spacing: 0.02em;
}
.typing-input:focus { border-color: var(--gold-dim); }
.typing-input::placeholder { color: var(--cream-dim); opacity: 0.25; font-size: 14px; font-style: normal; font-family: 'Raleway', sans-serif; letter-spacing: 0.2em; }
.typing-input.correct { border-color: var(--green); background: rgba(106,158,114,0.06); }
.typing-input.wrong   { border-color: var(--rose);  background: rgba(184,92,92,0.06); }
.typing-feedback {
  font-family: 'Cormorant Garamond', serif; font-size: 16px; font-style: italic;
  text-align: center; min-height: 24px; transition: all 0.3s;
}
.typing-feedback.correct { color: var(--green); }
.typing-feedback.wrong   { color: var(--rose); }
.typing-submit {
  font-family: 'Raleway', sans-serif; font-size: 10px; font-weight: 300;
  letter-spacing: 0.3em; text-transform: uppercase;
  border: 1px solid rgba(201,168,76,0.3); background: transparent; color: var(--cream);
  padding: 11px; cursor: pointer; transition: all 0.2s; border-radius: 1px;
}
.typing-submit:active { background: rgba(201,168,76,0.08); }

/* ── Next interval preview ── */
.interval-preview {
  display: flex; gap: 10px; width: 100%; max-width: 340px; flex-shrink: 0;
}
.interval-hint {
  flex: 1; text-align: center;
  font-family: 'Raleway', sans-serif; font-size: 8px; font-weight: 300;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--cream-dim); opacity: 0.4;
}

/* ── Rating buttons ── */
.rating-row { display: flex; gap: 10px; align-items: stretch; width: 100%; max-width: 340px; flex-shrink: 0; }
.btn-rating {
  flex: 1; font-family: 'Raleway', sans-serif; font-size: 9px; font-weight: 300;
  letter-spacing: 0.2em; text-transform: uppercase; border: 1px solid; background: transparent;
  padding: 11px 4px; cursor: pointer; border-radius: 1px; transition: all 0.2s;
  display: flex; flex-direction: column; align-items: center; gap: 3px; line-height: 1.3;
}
.btn-rating .icon { font-size: 13px; }
.btn-rating .next-due { font-size: 8px; opacity: 0.6; letter-spacing: 0.1em; }
.btn-not-well  { border-color: rgba(184,92,92,0.35);  color: var(--rose);  }
.btn-okay      { border-color: rgba(196,136,58,0.35); color: var(--amber); }
.btn-very-good { border-color: rgba(106,158,114,0.35);color: var(--green); }
.btn-not-well:active  { background: rgba(184,92,92,0.12); }
.btn-okay:active      { background: rgba(196,136,58,0.12); }
.btn-very-good:active { background: rgba(106,158,114,0.12); }

/* ── Score ── */
.score-row { display: flex; gap: 20px; align-items: center; flex-shrink: 0; }
.score-item { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.score-num { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 400; color: var(--cream); }
.score-num.s-not-well  { color: var(--rose); }
.score-num.s-okay      { color: var(--amber); }
.score-num.s-very-good { color: var(--green); }
.score-lbl { font-family: 'Raleway', sans-serif; font-size: 8px; font-weight: 300; letter-spacing: 0.2em; text-transform: uppercase; color: var(--cream-dim); opacity: 0.5; }
.score-sep { width: 1px; height: 24px; background: var(--border); }

.btn-skip {
  font-family: 'Raleway', sans-serif; font-size: 10px; font-weight: 300; letter-spacing: 0.3em; text-transform: uppercase;
  border: 1px solid rgba(201,168,76,0.3); background: transparent; color: var(--cream);
  padding: 12px 36px; cursor: pointer; transition: all 0.25s; border-radius: 1px; flex-shrink: 0;
}
.btn-skip:active { background: rgba(201,168,76,0.08); }

.status-msg { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-style: italic; color: var(--cream-dim); opacity: 0.6; text-align: center; }

@keyframes cardEnter {
  from { opacity: 0; transform: translateY(14px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.card-scene.entering { animation: cardEnter 0.35s cubic-bezier(0.4,0,0.2,1) forwards; }

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-6px); }
  40%       { transform: translateX(6px); }
  60%       { transform: translateX(-4px); }
  80%       { transform: translateX(4px); }
}
.shake { animation: shake 0.4s cubic-bezier(0.4,0,0.2,1); }

/* ── Hint generation ── */
.hint-gen-btn {
  font-family: 'Raleway', sans-serif; font-size: 9px; font-weight: 300;
  letter-spacing: 0.2em; text-transform: uppercase;
  border: 1px solid rgba(201,168,76,0.2); background: transparent; color: var(--gold-dim);
  padding: 6px 14px; cursor: pointer; transition: all 0.2s; border-radius: 1px; flex-shrink: 0;
}
.hint-gen-btn:active { background: rgba(201,168,76,0.08); }
.hint-gen-btn:disabled { opacity: 0.3; cursor: not-allowed; }

/* ── List View ── */
.list-view {
  position: fixed; inset: 0; z-index: 50; background: var(--ink);
  max-width: 480px; margin: 0 auto; display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
.list-view.open { transform: translateX(0); }
.list-header {
  padding: max(52px, env(safe-area-inset-top, 52px)) 20px 12px;
  display: flex; align-items: center; gap: 12px; flex-shrink: 0;
  border-bottom: 1px solid var(--border);
}
.list-back { background: transparent; border: none; color: var(--gold); font-family: 'Raleway', sans-serif; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer; padding: 4px 0; }
.list-title { font-family: 'Playfair Display', serif; font-size: 16px; font-style: italic; color: var(--cream); flex: 1; }
.list-count { font-family: 'Raleway', sans-serif; font-size: 10px; color: var(--cream-dim); opacity: 0.5; letter-spacing: 0.2em; }
.list-col-headers { display: grid; grid-template-columns: 1fr 1fr 80px; padding: 10px 20px; flex-shrink: 0; border-bottom: 1px solid var(--border); }
.col-header { font-family: 'Raleway', sans-serif; font-size: 9px; font-weight: 300; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); opacity: 0.7; cursor: pointer; display: flex; align-items: center; gap: 4px; background: transparent; border: none; padding: 0; transition: opacity 0.2s; }
.col-header.sorted { opacity: 1; }
.list-scroll { flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.list-row { display: grid; grid-template-columns: 1fr 1fr 80px; padding: 12px 20px; border-bottom: 1px solid rgba(201,168,76,0.07); cursor: pointer; transition: background 0.15s; }
.list-row:active { background: rgba(201,168,76,0.05); }
.list-cell-fr { font-family: 'Playfair Display', serif; font-size: 15px; font-style: italic; color: var(--cream); }
.list-cell-en { font-family: 'Cormorant Garamond', serif; font-size: 15px; color: var(--cream-dim); padding-left: 8px; }
.list-cell-rating { display: flex; align-items: center; justify-content: flex-end; gap: 4px; }
.rating-dot { width: 8px; height: 8px; border-radius: 50%; }
.rating-dot.not_well  { background: var(--rose); }
.rating-dot.okay      { background: var(--amber); }
.rating-dot.very_good { background: var(--green); }
.rating-dot.new       { background: rgba(255,255,255,0.2); }
.due-indicator { font-family: 'Raleway', sans-serif; font-size: 8px; letter-spacing: 0.1em; color: var(--gold); opacity: 0.8; }

/* ── Modal ── */
.modal-overlay { position: fixed; inset: 0; z-index: 100; background: rgba(0,0,0,0.75); display: flex; align-items: flex-end; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.3s; }
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal { width: 100%; max-width: 480px; background: #1a1610; border: 1px solid var(--border); border-bottom: none; border-radius: 12px 12px 0 0; padding: 28px 28px max(28px, env(safe-area-inset-bottom, 28px)); transform: translateY(100%); transition: transform 0.35s cubic-bezier(0.4,0,0.2,1); }
.modal-overlay.open .modal { transform: translateY(0); }
.modal-title { font-family: 'Playfair Display', serif; font-size: 18px; font-style: italic; color: var(--cream); margin-bottom: 24px; display: flex; justify-content: space-between; align-items: center; }
.modal-close { background: transparent; border: none; color: var(--cream-dim); font-size: 22px; cursor: pointer; line-height: 1; padding: 4px; }
.form-group { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.form-label { font-family: 'Raleway', sans-serif; font-size: 9px; font-weight: 300; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); opacity: 0.8; }
.form-input { background: rgba(255,255,255,0.04); border: 1px solid var(--border); border-radius: 1px; padding: 12px 14px; color: var(--cream); font-family: 'Cormorant Garamond', serif; font-size: 18px; outline: none; transition: border-color 0.2s; width: 100%; }
.form-input:focus { border-color: var(--gold-dim); }
.form-input::placeholder { color: var(--cream-dim); opacity: 0.3; font-style: italic; }
.form-row { display: flex; gap: 12px; }
.form-row .form-group { flex: 1; }
.btn-submit { width: 100%; margin-top: 8px; font-family: 'Raleway', sans-serif; font-size: 11px; font-weight: 300; letter-spacing: 0.3em; text-transform: uppercase; border: 1px solid rgba(201,168,76,0.4); background: transparent; color: var(--cream); padding: 14px; cursor: pointer; transition: all 0.2s; border-radius: 1px; }
.btn-submit:active { background: rgba(201,168,76,0.1); }
.btn-submit:disabled { opacity: 0.4; cursor: not-allowed; }
.btn-delete { width: 100%; margin-top: 8px; font-family: 'Raleway', sans-serif; font-size: 11px; font-weight: 300; letter-spacing: 0.3em; text-transform: uppercase; border: 1px solid rgba(184,92,92,0.3); background: transparent; color: var(--rose); padding: 12px; cursor: pointer; transition: all 0.2s; border-radius: 1px; }
.btn-delete:active { background: rgba(184,92,92,0.1); }

/* ── Hint approval row in modal ── */
.hint-row { display: flex; gap: 8px; align-items: flex-end; }
.hint-row .form-group { flex: 1; margin-bottom: 0; }
.hint-approve-btn {
  height: 46px; flex-shrink: 0; font-family: 'Raleway', sans-serif; font-size: 9px; font-weight: 300;
  letter-spacing: 0.15em; text-transform: uppercase;
  border: 1px solid rgba(201,168,76,0.3); background: transparent; color: var(--gold-dim);
  padding: 0 12px; cursor: pointer; transition: all 0.2s; border-radius: 1px; white-space: nowrap;
}
.hint-approve-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.hint-approve-btn:active { background: rgba(201,168,76,0.1); }
.hint-generating { font-family: 'Cormorant Garamond', serif; font-size: 12px; font-style: italic; color: var(--gold-dim); opacity: 0.7; padding: 4px 0; }

/* ── Progress Chart View ── */
.chart-view {
  position: fixed; inset: 0; z-index: 50; background: var(--ink);
  max-width: 480px; margin: 0 auto; display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
.chart-view.open { transform: translateX(0); }
.chart-header {
  padding: max(52px, env(safe-area-inset-top, 52px)) 20px 12px;
  display: flex; align-items: center; gap: 12px; flex-shrink: 0;
  border-bottom: 1px solid var(--border);
}
.chart-back { background: transparent; border: none; color: var(--gold); font-family: 'Raleway', sans-serif; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; cursor: pointer; padding: 4px 0; }
.chart-title { font-family: 'Playfair Display', serif; font-size: 16px; font-style: italic; color: var(--cream); flex: 1; }
.chart-scroll { flex: 1; overflow-y: auto; padding: 24px 20px; display: flex; flex-direction: column; gap: 32px; }

.chart-section-title {
  font-family: 'Raleway', sans-serif; font-size: 9px; font-weight: 300;
  letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold); opacity: 0.7;
  margin-bottom: 16px;
}
.chart-container { width: 100%; height: 160px; position: relative; }
.chart-empty {
  font-family: 'Cormorant Garamond', serif; font-size: 16px; font-style: italic;
  color: var(--cream-dim); opacity: 0.4; text-align: center; padding: 40px 0;
}

.mastery-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
}
.mastery-card {
  border: 1px solid var(--border); padding: 16px 12px;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.mastery-num {
  font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 400;
}
.mastery-num.known  { color: var(--green); }
.mastery-num.learning { color: var(--amber); }
.mastery-num.new    { color: var(--cream-dim); opacity: 0.5; }
.mastery-lbl {
  font-family: 'Raleway', sans-serif; font-size: 8px; font-weight: 300;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--cream-dim); opacity: 0.5;
  text-align: center;
}

.session-history { display: flex; flex-direction: column; gap: 8px; }
.session-row {
  display: flex; align-items: center; gap: 12px; padding: 10px 0;
  border-bottom: 1px solid rgba(201,168,76,0.06);
}
.session-date { font-family: 'Raleway', sans-serif; font-size: 10px; letter-spacing: 0.1em; color: var(--cream-dim); opacity: 0.5; width: 80px; flex-shrink: 0; }
.session-bars { flex: 1; display: flex; gap: 3px; align-items: center; }
.session-bar { height: 4px; border-radius: 2px; min-width: 2px; }
.session-bar.vg  { background: var(--green); }
.session-bar.ok  { background: var(--amber); }
.session-bar.nw  { background: var(--rose); }
.session-score { font-family: 'Playfair Display', serif; font-size: 13px; color: var(--gold); width: 32px; text-align: right; flex-shrink: 0; }

.toast { position: fixed; bottom: 40px; left: 50%; transform: translateX(-50%); background: var(--ink-3); border: 1px solid var(--border); color: var(--cream); padding: 10px 20px; font-family: 'Raleway', sans-serif; font-size: 11px; letter-spacing: 0.2em; border-radius: 2px; z-index: 200; opacity: 0; transition: opacity 0.3s; pointer-events: none; white-space: nowrap; }
.toast.show { opacity: 1; }

footer-spacer { height: env(safe-area-inset-bottom, 12px); flex-shrink: 0; }
