/* ══════════════════════════════════════════════════════
   LILA Practice Portal — Unified Stylesheet
   portal-unified.css
══════════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  /* ── COLOR ── */
  --bg: #080808;
  --surface: #0e0e0e;
  --surface-2: #141414;
  --surface-3: rgba(255,255,255,.14);
  --edge: rgba(255,255,255,.07);
  --edge-hi: rgba(255,255,255,.13);
  --gold: #C8A951;
  --gold-hi: #d4b35a;
  --gold-dim: rgba(200,169,81,.25);
  --gold-glow: rgba(200,169,81,.07);
  --crimson: #C8102E;
  --red: #C8102E;
  --crimson-dim: rgba(200,16,46,.16);
  --text: #f0ebe0;
  --text-2: rgba(240,235,224,.55);
  --text-3: rgba(240,235,224,.22);

  /* ── MOTION ── */
  --ease: cubic-bezier(0.16,1,0.3,1);
  --t-fast: 280ms;
  --t-mid: 560ms;
  --t-slow: 840ms;

  /* ── SHAPE ── */
  --r: 14px;
  --r-sm: 10px;
  --r-lg: 20px;

  /* ── LAYOUT ── */
  --sb-w: 240px;
  --sb-w-c: 64px;
  --hh: 80px;
  --panel-w: 320px;

  /* ── SPACING SCALE ── */
  --sp-1: 8px;
  --sp-2: 12px;
  --sp-3: 16px;
  --sp-4: 24px;
  --sp-5: 40px;
  --sp-6: 60px;

  /* ── TYPOGRAPHY SCALE (Montserrat UI labels) ── */
  --label-xs: .57rem;  --track-xs: .11em;
  --label-sm: .63rem;  --track-sm: .16em;
  --label-md: .70rem;  --track-md: .14em;
  /* Wide-track cinematic labels */
  --track-lg: .22em;
  --track-xl: .30em;
  --track-2xl: .32em;

  /* ── TAB BAR ── */
  --tab-pad: 12px;

  /* ── CARD — BASE ── */
  --card-bg: rgba(255,255,255,.018);
  --card-border: 1px solid var(--edge);
  --card-pad: 20px 24px;

  /* ── CARD — FEATURE (gradient, Home standard) ── */
  --card-bg-feat: linear-gradient(155deg, rgba(200,169,81,.06), rgba(200,16,46,.03));
  --card-border-feat: 1px solid rgba(200,169,81,.18);

  /* ── ALIASES (legacy compatibility) ── */
  --bg-1:   #0e0e0e;
  --bg-2:   #141414;
  --border: rgba(255,255,255,.09);
  --radius: 14px;
  --text-1: #f0ebe0;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { height: 100%; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Cormorant Garamond', serif;
  height: 100%;
  overflow: hidden;
}
button { font-family: inherit; cursor: pointer; }
textarea, input { font-family: inherit; }
a { text-decoration: none; color: inherit; }

/* ── GRAIN OVERLAY ── */
.grain {
  position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity: .55;
}

/* ══════════════════════════════════════════════════════
   TOPBAR
══════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════
   TOPBAR — Personal bar (user info lives here only)
══════════════════════════════════════════════════════ */
.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 300;
  height: var(--hh);
  background: rgba(8,8,8,.97);
  border-bottom: 1px solid var(--edge);
  display: flex; align-items: center;
  backdrop-filter: blur(24px);
}
.topbar::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(200,16,46,.28) 30%, rgba(200,169,81,.4) 65%, transparent 100%);
}

/* ── Left zone: avatar + greeting ── */
.tb-left {
  display: flex; align-items: center; gap: 14px;
  padding: 0 0 0 20px;
  flex-shrink: 0;
}
.tb-lila-back {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: 'Montserrat', sans-serif;
  font-size: .48rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(200,169,81,.4);
  text-decoration: none;
  border: 1px solid rgba(200,169,81,.12);
  border-radius: 99px;
  padding: 5px 11px;
  transition: color .2s, border-color .2s, background .2s;
  white-space: nowrap;
  flex-shrink: 0;
}
.tb-lila-back:hover {
  color: rgba(200,169,81,.8);
  border-color: rgba(200,169,81,.35);
  background: rgba(200,169,81,.05);
}
body.light-mode .tb-lila-back {
  color: rgba(100,70,10,.45);
  border-color: rgba(100,70,10,.15);
}
body.light-mode .tb-lila-back:hover {
  color: rgba(100,70,10,.8);
  border-color: rgba(100,70,10,.35);
  background: rgba(100,70,10,.05);
}

/* Tooltip */
.tb-lila-back { position: relative; }
.tb-lila-back::after {
  content: attr(data-tooltip);
  position: absolute;
  top: calc(100% + 10px);
  left: 0; transform: translateY(-4px);
  font-family: 'Montserrat', sans-serif;
  font-size: .48rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  white-space: nowrap;
  background: rgba(10,10,10,.97);
  color: var(--text);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  padding: 7px 13px;
  box-shadow: 0 4px 20px rgba(0,0,0,.5);
  pointer-events: none;
  opacity: 0;
  transition: opacity 160ms var(--ease), transform 160ms var(--ease);
  z-index: 9999;
}
.tb-lila-back:hover::after {
  opacity: 1;
  transform: translateY(0);
}
body.light-mode .tb-lila-back::after {
  background: rgba(240,234,222,.98);
  color: rgba(24,21,15,.85);
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}
.tb-sigil {
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  margin-right: 2px;
}
.tb-sigil svg { display: block; }
.tb-greeting-wrap {
  display: flex; flex-direction: column; gap: 2px;
}
.tb-greeting {
  font-family: 'Playfair Display', serif;
  font-size: 1.22rem; font-weight: 700; color: var(--text); line-height: 1.1;
  white-space: nowrap;
}
.tb-greeting em { font-style: italic; color: var(--crimson); }
.tb-date {
  font-family: 'Montserrat', sans-serif;
  font-size: .48rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase;
  color: var(--text-3); white-space: nowrap;
}

/* ── Flex spacer ── */
.tb-spacer { flex: 1; }

/* ── LILA Portal brand — pinned to true topbar centre ── */
.tb-brand-center {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem; font-weight: 700;
  color: rgba(240,235,224,.18);
  letter-spacing: .04em; white-space: nowrap;
}
.tb-brand-center em { font-style: italic; color: rgba(200,169,81,.32); }

/* Account actions — slides out leftward from avatar */
.tb-account-actions {
  display: flex; align-items: center; gap: 0;
  height: 100%;
  max-width: 0; overflow: hidden; opacity: 0;
  position: relative;
  transition: max-width var(--t-slow) var(--ease),
              opacity var(--t-mid) var(--ease);
}
.tb-account-actions::before {
  content: ''; position: absolute; left: 0; top: 15%; bottom: 15%; width: 1px;
  background: linear-gradient(to bottom, transparent, var(--edge) 40%, var(--edge) 60%, transparent);
  opacity: 0; transition: opacity var(--t-mid) var(--ease);
  pointer-events: none;
}
.tb-right.open .tb-account-actions {
  max-width: 640px; opacity: 1;
}
.tb-right.open .tb-account-actions::before { opacity: 1; }

/* Identity block — name + tier on one row, notification below */
.tb-action-identity {
  display: flex; flex-direction: column; justify-content: center;
  gap: 5px; padding: 0 20px; flex-shrink: 0;
}
.tb-action-top-row {
  display: flex; align-items: baseline; gap: 12px;
}
.tb-action-name {
  font-family: 'Playfair Display', serif;
  font-size: .82rem; font-weight: 700; font-style: italic;
  color: var(--text); white-space: nowrap; line-height: 1;
}
.tb-action-tier {
  font-family: 'Montserrat', sans-serif;
  font-size: .46rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase;
  color: rgba(200,169,81,.6); white-space: nowrap; line-height: 1;
}

.tb-action-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 0 20px; height: 100%;
  font-family: 'Montserrat', sans-serif;
  font-size: .56rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(240,235,224,.4); text-decoration: none; background: none; border: none;
  cursor: pointer; white-space: nowrap;
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.tb-action-btn:hover { color: var(--text); background: none; }
.tb-action-signout:hover { color: var(--crimson); background: none; box-shadow: 0 1px 0 rgba(200,16,46,.25) inset; }
.tb-action-settings:hover { color: var(--gold); background: none; box-shadow: 0 1px 0 rgba(200,169,81,.3) inset; }
.tb-action-sep {
  width: 1px; height: 16px; flex-shrink: 0;
  background: linear-gradient(to bottom, transparent, rgba(255,255,255,.07), transparent);
}
.tb-action-close {
  padding: 0 20px; height: 100%;
  font-family: 'Montserrat', sans-serif; font-size: .6rem;
  color: var(--text-3); background: none; border: none; cursor: pointer;
  white-space: nowrap;
  transition: color var(--t-fast) var(--ease);
}
.tb-action-close:hover { color: var(--text); }
/* ── Theme toggle (dark ↔ light) ── */
.tb-theme-toggle {
  flex-shrink: 0; position: relative;
  display: flex; align-items: center; justify-content: center;
  background: none; border: none; cursor: pointer;
  width: 36px; height: 36px; margin-right: 6px;
  color: var(--text-3); border-radius: 50%;
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.tb-theme-toggle:hover { color: var(--text); background: rgba(255,255,255,.04); }

/* Icon swap */
.tb-theme-icon-moon { display: none; }
body.light-mode .tb-theme-icon-sun  { display: none; }
body.light-mode .tb-theme-icon-moon { display: block; }
body.light-mode .tb-theme-toggle:hover { background: rgba(0,0,0,.05); }

/* Tooltip */
.tb-theme-toggle::after {
  content: attr(aria-label);
  position: absolute; top: calc(100% + 10px); left: 50%;
  transform: translateX(-50%);
  white-space: nowrap; pointer-events: none;
  font-family: 'Montserrat', sans-serif;
  font-size: .48rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text);
  background: rgba(10,10,10,.97);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px; padding: 7px 13px;
  box-shadow: 0 4px 20px rgba(0,0,0,.5);
  opacity: 0; transition: opacity 160ms var(--ease); z-index: 9000;
}
.tb-theme-toggle:hover::after { opacity: 1; }
body.light-mode .tb-theme-toggle::after {
  background: rgba(240,234,222,.98); border-color: rgba(0,0,0,.1);
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}

/* ════════════════════════════════════════════════════════
   REDUCE MOTION — accessibility preference
════════════════════════════════════════════════════════ */
body.lila-reduce-motion *,
body.lila-reduce-motion *::before,
body.lila-reduce-motion *::after {
  transition-duration: 0.01ms !important;
  animation-duration: 0.01ms !important;
  animation-iteration-count: 1 !important;
}

/* ════════════════════════════════════════════════════════
   FONT SIZE — html-level scaling (rem-based cascade)
════════════════════════════════════════════════════════ */
html.text-sm { font-size: 14px; }
/* default: 16px (no class needed) */
html.text-lg { font-size: 18px; }

/* ════════════════════════════════════════════════════════
   LINE SPACING — writing + reading areas
════════════════════════════════════════════════════════ */
/* Compact */
body.line-compact .write-area,
body.line-compact .arc-chapter-body,
body.line-compact .arc-chapter-body p,
body.line-compact .jnl-entry-body  { line-height: 1.55; }

/* Airy */
body.line-airy .write-area,
body.line-airy .arc-chapter-body,
body.line-airy .arc-chapter-body p,
body.line-airy .jnl-entry-body     { line-height: 2.1; }

/* ════════════════════════════════════════════════════════
   HIGH CONTRAST — stronger borders + text opacity
════════════════════════════════════════════════════════ */
body.high-contrast {
  --border:  rgba(255,255,255,.28);
  --edge:    rgba(255,255,255,.22);
  --edge-hi: rgba(255,255,255,.38);
  --text-2:  rgba(240,235,224,.92);
  --text-3:  rgba(240,235,224,.68);
}
body.high-contrast.light-mode {
  --border:  rgba(0,0,0,.22);
  --edge:    rgba(0,0,0,.18);
  --edge-hi: rgba(0,0,0,.32);
  --text-2:  rgba(24,21,15,.88);
  --text-3:  rgba(24,21,15,.62);
}

/* ════════════════════════════════════════════════════════
   SEPIA MODE — warm amber candlelight palette
════════════════════════════════════════════════════════ */
body.sepia-mode {
  --bg:          #100c07;
  --surface:     #1a1510;
  --surface-2:   #201b12;
  --surface-3:   rgba(210,175,105,.11);
  --edge:        rgba(210,175,105,.09);
  --edge-hi:     rgba(210,175,105,.18);
  --gold:        #c8a045;
  --gold-hi:     #d4ac4e;
  --gold-dim:    rgba(200,160,69,.24);
  --gold-glow:   rgba(200,160,69,.08);
  --crimson:     #b83020;
  --crimson-dim: rgba(184,48,32,.15);
  --text:        #ece3c8;
  --text-2:      rgba(236,227,200,.52);
  --text-3:      rgba(236,227,200,.22);
  --bg-1:        #1a1510;
  --bg-2:        #201b12;
  --border:      rgba(210,175,105,.09);
  --text-1:      #ece3c8;
}

/* HIGH CONTRAST override for sepia — must come after sepia-mode to win the cascade */
body.high-contrast.sepia-mode {
  --border:  rgba(210,175,105,.30);
  --edge:    rgba(210,175,105,.24);
  --edge-hi: rgba(210,175,105,.42);
  --text-2:  rgba(236,227,200,.90);
  --text-3:  rgba(236,227,200,.65);
}

/* ── Topbar ── */
body.sepia-mode .topbar {
  background: rgba(16,12,7,.97);
}
body.sepia-mode .topbar::after {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,160,69,.45) 25%, rgba(200,160,69,.45) 75%, transparent);
}

/* ── Sidebar ── */
body.sepia-mode .sidebar { background: rgba(15,11,7,.98); }

/* ── Focus overlay (journal writing) ── */
body.sepia-mode .focus-overlay { background: rgba(10,8,5,.96); }

/* ════════════════════════════════════════════════════════
   LIGHT MODE — comprehensive token + element overrides
════════════════════════════════════════════════════════ */
body.light-mode {
  --bg:        #e8e2d6;
  --surface:   #dfd8ca;
  --surface-2: #d5cdbf;
  --surface-3: #cac3b5;
  --edge:      rgba(0,0,0,.12);
  --edge-hi:   rgba(0,0,0,.22);
  --text:      #18150f;
  --text-2:    rgba(24,21,15,.62);
  --text-3:    rgba(24,21,15,.44);
  --gold-glow: rgba(200,169,81,.06);
  /* Section aliases for light mode */
  --bg-1:   #ede7db;
  --bg-2:   #e4ddd1;
  --border: rgba(0,0,0,.12);
  --radius: 12px;
  --text-1: #18150f;
}

/* ── Topbar ── */
body.light-mode .topbar { background: rgba(224,217,204,.98); border-bottom-color: rgba(0,0,0,.04); }
body.light-mode .topbar::after { opacity: 0; }
body.light-mode .topbar::after {
  background: linear-gradient(90deg, transparent 0%, rgba(200,16,46,.16) 30%, rgba(200,169,81,.24) 65%, transparent 100%);
}
/* Brand centre: hardcoded light rgba → dark */
body.light-mode .tb-brand-center { color: rgba(24,21,15,.5); }
body.light-mode .tb-brand-center em { color: rgba(200,169,81,.75); }
/* Date + icon — unified secondary gray */
body.light-mode .tb-date { color: rgba(24,21,15,.5); }
body.light-mode .tb-theme-toggle { color: rgba(24,21,15,.5); }
/* Action buttons: hardcoded light text */
body.light-mode .tb-action-btn { color: rgba(24,21,15,.5); }
body.light-mode .tb-action-btn:hover { color: var(--text); }
body.light-mode .tb-action-close { color: rgba(24,21,15,.28); }
body.light-mode .tb-action-close:hover { color: var(--text); }
/* Focus-toggle tooltip */
body.light-mode .tb-focus-toggle::after {
  background: rgba(232,226,214,.99); border-color: rgba(0,0,0,.1);
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}

/* ── Account panel ── */
body.light-mode .tb-account-actions { background: rgba(224,217,204,.99); border-color: transparent; box-shadow: none; }
body.light-mode .tb-action-sep { background: linear-gradient(to bottom, transparent, rgba(0,0,0,.1), transparent); }
body.light-mode .tb-action-btn:hover { background: rgba(0,0,0,.05); }
body.light-mode .tb-action-settings:hover { background: none; color: #8A6C20; box-shadow: 0 1px 0 rgba(200,169,81,.4) inset; }
body.light-mode .tb-action-signout:hover { background: none; color: var(--crimson); box-shadow: 0 1px 0 rgba(200,16,46,.3) inset; }
body.light-mode .tb-theme-toggle::after { background: rgba(232,226,214,.99); border-color: rgba(0,0,0,.1); box-shadow: 0 4px 20px rgba(0,0,0,.12); }

/* ── Sidebar ── */
body.light-mode .sidebar { background: rgba(216,209,196,.99); border-right: 1px solid rgba(0,0,0,.09); }
/* Nav items: hardcoded light-text rgba */
body.light-mode .sb-item { color: rgba(24,21,15,.48); }
body.light-mode .sb-item:hover { color: rgba(24,21,15,.78); background: rgba(0,0,0,.06); border-color: rgba(0,0,0,.09); }
body.light-mode .sb-item.active { color: var(--text); background: rgba(200,16,46,.09); border-color: rgba(200,16,46,.18); }
/* Section toggle */
body.light-mode .sb-toggle { color: rgba(24,21,15,.55); border-top-color: rgba(0,0,0,.09); }
body.light-mode .sb-toggle:hover { color: rgba(24,21,15,.85); }
body.light-mode .sb-toggle .sb-toggle-icon { color: #B8943A; opacity: 1; }
/* Sign out */
body.light-mode .sb-signout { color: rgba(24,21,15,.55); }
body.light-mode .sb-signout:hover { color: rgba(24,21,15,.85); }
body.light-mode .sb-signout .sb-icon { color: #A82030; opacity: 1; }
/* SOON badge: hardcoded white border + light text */
body.light-mode .sb-badge.soon { border-color: rgba(0,0,0,.16); color: rgba(24,21,15,.38); }
/* Scroll chevron hint */
body.light-mode .col-scroll-hint { background: rgba(0,0,0,.07); border-color: rgba(0,0,0,.1); color: rgba(24,21,15,.45); }

/* ── Stats strip ── */
body.light-mode .hss-cell { border-bottom-color: rgba(0,0,0,.09); }
body.light-mode .hss-cell + .hss-cell { border-left-color: rgba(0,0,0,.09); }
#view-tracker .hss-cell { border-bottom: none; }

/* ── Right-panel soft card grouping ── */
body.light-mode .rp-card,
body.light-mode .ti-card {
  background: rgba(255,255,255,.5);
  border-color: rgba(0,0,0,.07);
  border-top-color: rgba(160,130,50,.22);
}

/* ── Arc ring ── */
body.light-mode .arc-ring-track { stroke: rgba(0,0,0,.09); }

/* ── Guide view ── */
body.light-mode .guide-card { background: rgba(0,0,0,.03); }

/* Fix #5: Body map SVG silhouette — white paths invisible on cream in light mode */
body.light-mode .bm-svg path,
body.light-mode .bm-svg ellipse { stroke: rgba(0,0,0,.14) !important; }
body.light-mode .bm-svg text    { fill:   rgba(0,0,0,.3)  !important; }

/* Fix #6: Arc prompt card — gradient too faint on cream */
body.light-mode .arc-prompt {
  background: linear-gradient(155deg, rgba(200,16,46,.06), rgba(200,169,81,.05));
  border-color: rgba(200,169,81,.22);
}

/* Fix #7a: Intention card — gradient invisible on cream */
body.light-mode .intention-card {
  background: linear-gradient(155deg, rgba(200,169,81,.08), rgba(200,16,46,.04));
  border-color: rgba(200,169,81,.22);
}

/* Fix #7b: Letter card — gradient invisible on cream */
body.light-mode .letter-card {
  background: linear-gradient(155deg, rgba(200,169,81,.08), rgba(200,16,46,.04));
  border-color: rgba(200,169,81,.2);
}

/* ── Journal / write tabs ── */
body.light-mode .tab-bar { background: rgba(0,0,0,.08); }
body.light-mode .tab-btn.active { background: #fff; box-shadow: 0 1px 5px rgba(0,0,0,.12); outline: 1px solid rgba(200,169,81,.6); color: var(--text); }
body.light-mode .ap-label { color: rgba(160,120,20,.85); }
body.light-mode .cf-info { color: rgba(24,21,15,.45); }
body.light-mode .cf-label { color: rgba(24,21,15,.6); }
body.light-mode .cm-label { color: rgba(24,21,15,.5); }
body.light-mode .cm-value { color: rgba(24,21,15,.78); }
body.light-mode .cf-response-note { color: rgba(24,21,15,.4); }
body.light-mode .help-footer-text { color: rgba(24,21,15,.65); }
body.light-mode .write-area { background: rgba(0,0,0,.04); border-color: rgba(200,169,81,.22); }
body.light-mode .entry-card { background: rgba(0,0,0,.03); }
body.light-mode .entry-card:hover { border-color: rgba(0,0,0,.18); }

/* ── Focus capture overlay ── */
body.light-mode .focus-overlay { background: rgba(200,193,180,.78); backdrop-filter: blur(20px); }
body.light-mode .focus-panel { background: var(--surface); border: 1px solid rgba(0,0,0,.12); box-shadow: 0 16px 48px rgba(0,0,0,.14); }
body.light-mode .focus-field { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }
body.light-mode .focus-header { border-bottom-color: rgba(0,0,0,.1); }
body.light-mode .focus-footer { border-top-color: rgba(0,0,0,.1); }
body.light-mode .focus-save { border-color: rgba(0,0,0,.16); }
body.light-mode .focus-char-count { color: rgba(24,21,15,.3); }
body.light-mode .focus-hint { color: rgba(24,21,15,.28); }
body.light-mode .focus-mode-btn { border-color: rgba(0,0,0,.12); }
body.light-mode .focus-mode-btn:hover { border-color: rgba(0,0,0,.24); }

/* ── Quick capture (home inline) ── */
body.light-mode .quick-capture { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }
body.light-mode .quick-capture:focus-within { border-color: rgba(200,169,81,.38); }
body.light-mode .qc-field { background: transparent; }

/* ── Practice steps bar ── */
body.light-mode .pstep { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }
body.light-mode .pstep:hover { border-color: rgba(0,0,0,.18); }
body.light-mode .pstep.done { background: rgba(200,169,81,.07); border-color: rgba(200,169,81,.22); }
body.light-mode .pstep.now  { background: rgba(200,16,46,.06); border-color: rgba(200,16,46,.22); }
/* Step progress pills */
body.light-mode .step-pill.now { background: rgba(0,0,0,.06); }
body.light-mode .step-num { background: rgba(0,0,0,.08); }
/* Mood picker */
body.light-mode .mood-card { background: rgba(0,0,0,.04); }
body.light-mode .mood-card:hover { border-color: rgba(0,0,0,.18); }
/* Breathwork options */
body.light-mode .breath-opt:hover { border-color: rgba(0,0,0,.18); }
/* Arc right panel — hardcoded dark wash */
/* arc-right-panel background removed — parchment bg is uniform, only tiles elevate */
/* Today checklist */
body.light-mode .today-checklist-card { background: rgba(0,0,0,.05); }
/* Week dots */
body.light-mode .wd.ahead { background: rgba(0,0,0,.04); }
/* Progress bar tracks */
body.light-mode .hc-bar-track,
body.light-mode .mc-bar-track,
body.light-mode .prog-track { background: rgba(0,0,0,.1) !important; }
/* Habit grid future cells */
body.light-mode .hg-cell.hg-future { background: rgba(0,0,0,.07); }
/* Heatmap empty cells */
body.light-mode .heat-cell.h-empty { background: rgba(0,0,0,.08); }
/* Habit tracker grid */
body.light-mode .ag-cell.empty { background: rgba(0,0,0,.08); border-color: rgba(0,0,0,.06); }
/* Milestones */
body.light-mode .ms-card { background: rgba(0,0,0,.03); }

/* ── Reflection ── */
body.light-mode .sw-textarea { background: rgba(0,0,0,.04); border-color: rgba(200,169,81,.22); }
body.light-mode .pl-card { background: rgba(0,0,0,.03); }
body.light-mode .pl-card:hover { border-color: rgba(0,0,0,.18); }
body.light-mode .wr-q-card { background: rgba(0,0,0,.03); }
body.light-mode .past-entry { background: rgba(0,0,0,.03); }
body.light-mode .theme-tag { background: rgba(0,0,0,.06); }

/* ── Recent entries (home right panel) ── */
body.light-mode .re-card { border-color: rgba(0,0,0,.1); background: rgba(0,0,0,.02); }
body.light-mode .re-card:hover { border-color: rgba(0,0,0,.18); background: rgba(0,0,0,.05); }
body.light-mode .re-card-icon { background: rgba(0,0,0,.08); }

/* ── Avatar initial letter ── */
body.light-mode .tb-avatar-sm { color: rgba(24,21,15,.75); }
/* Notification dot border — matches topbar bg so it looks cut-out */
body.light-mode .tb-notif-dot { border-color: rgba(224,217,204,.98); }

/* ── Recent entry icon ── */
body.light-mode .re-icon { background: rgba(0,0,0,.08); }

/* ── Buttons: light-mode overrides now in main button block ── */

/* ── Focus Mode toggle ── */
.tb-focus-toggle {
  flex-shrink: 0; position: relative;
  display: flex; align-items: center; justify-content: center;
  background: none; border: none; cursor: pointer;
  width: 36px; height: 36px; margin-right: 20px;
  color: var(--text-3);
  border-radius: 50%;
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.tb-focus-toggle:hover {
  color: var(--text); background: rgba(255,255,255,.04);
}
.tb-focus-toggle.active {
  color: var(--crimson);
  background: rgba(200,16,46,.08);
}
/* Tooltip drops below button */
.tb-focus-toggle::after {
  content: 'Focus Mode';
  position: absolute; top: calc(100% + 10px); left: 50%;
  transform: translateX(-50%);
  white-space: nowrap; pointer-events: none;
  font-family: 'Montserrat', sans-serif;
  font-size: .48rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text);
  background: rgba(10,10,10,.97);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px; padding: 7px 13px;
  box-shadow: 0 4px 20px rgba(0,0,0,.5);
  opacity: 0; transition: opacity 160ms var(--ease);
  z-index: 9000;
}
.tb-focus-toggle:hover::after { opacity: 1; }

/* ── Global Focus Mode — body-level states ── */

/* Topbar dims to near-invisible, returns fully on hover */
body.focus-mode .topbar {
  opacity: 0.08;
  transition: opacity 0.5s var(--ease);
}
body.focus-mode .topbar:hover {
  opacity: 1;
  transition: opacity 0.15s var(--ease);
}

/* Subtle gold left-edge glow on content — signals active focus state */
body.focus-mode .main::before {
  content: '';
  position: fixed; left: var(--sb-w-c); top: var(--hh); bottom: 0;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(200,169,81,.18) 30%, rgba(200,169,81,.18) 70%, transparent);
  pointer-events: none; z-index: 10;
  transition: left var(--t-slow) var(--ease);
}

/* Home: dim stats strip so content is the focus */
body.focus-mode .home-stats-strip {
  opacity: 0.35;
  transition: opacity var(--t-mid) var(--ease);
}
body.focus-mode .home-stats-strip:hover {
  opacity: 1;
}

/* ── Section-specific Focus Mode behaviours ── */
/* Transitions live on BASE elements — focus-mode only sets target values */

/* View header collapse handled by JS (precise height measurement) */

/* ── JOURNAL ── */
body.focus-mode #view-journal .two-col    { grid-template-columns: 1fr 0px; }
body.focus-mode #view-journal .col-right  { opacity: 0; pointer-events: none; }
body.focus-mode #view-journal .write-area { min-height: 52vh; font-size: 1.12rem; line-height: 1.85; }
body.focus-mode #view-journal .voice-rec-area { min-height: 52vh; justify-content: center; }

/* ── PRACTICE ── */
body.focus-mode #view-arc .steps-bar  { opacity: 0; pointer-events: none; } /* height by JS */
body.focus-mode #view-arc .two-col        { grid-template-columns: 1fr 0px; }
body.focus-mode #view-arc .arc-right-panel { opacity: 0; pointer-events: none; }

/* ── REFLECTION ── */
body.focus-mode #view-reflection .two-col        { grid-template-columns: 1fr 0px; }
body.focus-mode #view-reflection .col-right      { opacity: 0; pointer-events: none; }
body.focus-mode #view-reflection .prompt-library { opacity: 0; pointer-events: none; max-height: 0; }
body.focus-mode #view-reflection .sw-textarea    { min-height: 44vh; font-size: 1.08rem; line-height: 1.85; }

/* ── THE WORK ── */
body.focus-mode #view-the-work .two-col          { grid-template-columns: 1fr 0px; }
body.focus-mode #view-the-work .col-right        { opacity: 0; pointer-events: none; }

/* ── TRACKER ── header handled by JS, no extra rules needed */

/* ── GUIDE (future) ── */
body.focus-mode #view-my-guide .guide-content { max-width: 640px; margin: 0 auto; font-size: 1.08em; line-height: 1.9; }

/* ── Right zone: avatar circle → account actions ── */
.tb-right {
  flex-shrink: 0; height: 100%; padding: 0 32px 0 0;
  display: flex; align-items: center;
  position: relative;
}
.tb-avatar-btn {
  background: none; border: none; cursor: zoom-in; padding: 0;
  position: relative;
  transition: transform var(--t-fast) var(--ease);
}
.tb-avatar-btn.card-open { cursor: zoom-out; }

/* Notification dot — top-right of avatar ring */
@keyframes notif-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(200,169,81,.5); }
  50%       { box-shadow: 0 0 0 4px rgba(200,169,81,.0); }
}
.tb-notif-dot {
  display: none;
  position: absolute; top: 1px; right: 1px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold);
  border: 1.5px solid rgba(8,8,8,.97);
  animation: notif-pulse 2s ease-in-out infinite;
}
.tb-notif-dot.active { display: block; }

/* Notification text in expanded panel */
.tb-action-notif {
  display: none;
  font-family: 'Montserrat', sans-serif;
  font-size: .44rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(200,169,81,.75); white-space: nowrap; line-height: 1;
  padding: 3px 8px; border-radius: 99px;
  background: rgba(200,169,81,.08);
  border: 1px solid rgba(200,169,81,.18);
}
.tb-action-notif.active { display: inline-flex; align-items: center; gap: 5px; }

/* Static ring + soft glow breathe */
@keyframes avatar-glow {
  0%, 100% { box-shadow: 0 0 6px rgba(200,169,81,.12), 0 0 0 1.5px rgba(200,169,81,.28); }
  50%       { box-shadow: 0 0 14px rgba(200,169,81,.28), 0 0 0 1.5px rgba(200,169,81,.5); }
}

.tb-avatar-sm {
  width: 36px; height: 36px; border-radius: 50%; overflow: hidden;
  background: linear-gradient(135deg, rgba(200,169,81,.1), rgba(200,16,46,.07));
  border: 1.5px solid rgba(200,169,81,.36);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Playfair Display', serif; font-size: .82rem; font-weight: 700;
  color: rgba(240,235,224,.82);
  animation: avatar-glow 3.6s ease-in-out infinite;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.tb-avatar-initial {
  position: relative; z-index: 1;
  transition: opacity var(--t-fast) var(--ease);
}
.tb-avatar-photo {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover; border-radius: 50%;
  opacity: 0; z-index: 2;
  transition: opacity var(--t-mid) var(--ease);
}
.tb-avatar-sm.has-photo .tb-avatar-initial { opacity: 0; }
.tb-avatar-sm.has-photo .tb-avatar-photo  { opacity: 1; }
.tb-avatar-sm.av-sq { border-radius: 10px !important; transition: border-radius .35s cubic-bezier(.4,0,.2,1), transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); }
.tb-avatar-sm.av-sq .tb-avatar-photo { border-radius: 8px !important; }

/* + photo badge — bottom-right of avatar button, appears on hover */
.tb-avatar-add {
  position: absolute; bottom: 0; right: 0;
  width: 15px; height: 15px; border-radius: 50%;
  background: var(--gold); border: 2px solid var(--bg);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif; font-size: 9px; font-weight: 700;
  color: #0a0a0a; line-height: 1;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  z-index: 10; cursor: pointer;
}
.tb-avatar-btn:hover .tb-avatar-add {
  opacity: 1; pointer-events: all; transform: scale(1.08);
}

/* Hover: scale + stronger glow, pause animation */
.tb-avatar-btn:hover .tb-avatar-sm {
  transform: scale(1.14);
  animation: none;
  box-shadow: 0 0 20px rgba(200,169,81,.35), 0 0 0 2px rgba(200,169,81,.6);
  border-color: rgba(200,169,81,.65);
}

/* Avatar tooltips — both anchored to the button so right:0 stays in viewport */
.tb-avatar-btn::after,
.tb-avatar-btn::before {
  font-family: 'Montserrat', sans-serif;
  font-size: .48rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  white-space: nowrap; pointer-events: none;
  position: absolute; top: calc(100% + 10px); right: 0;
  border-radius: 8px; padding: 7px 13px;
  background: rgba(10,10,10,.97); color: var(--text);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 4px 20px rgba(0,0,0,.5);
  opacity: 0; transition: opacity 160ms var(--ease), transform 160ms var(--ease);
  transform: translateY(-4px);
  z-index: 9999;
}
/* "My Account" — shown on hover, hidden when + badge hovered or menu open */
.tb-avatar-btn::after { content: 'My Account'; }
.tb-avatar-btn.card-open::after { content: 'Close'; }
.tb-avatar-btn:hover::after { opacity: 1; transform: translateY(0); }
.tb-avatar-btn:has(.tb-avatar-add:hover)::after { opacity: 0 !important; transform: translateY(-4px) !important; }

/* "Upload photo" — only shown when + badge hovered */
.tb-avatar-btn::before { content: 'Upload photo'; }
.tb-avatar-btn:has(.tb-avatar-add:hover)::before { opacity: 1; transform: translateY(0); }

/* Light mode */
body.light-mode .tb-avatar-btn::after,
body.light-mode .tb-avatar-btn::before {
  background: rgba(240,234,222,.98); color: rgba(24,21,15,.85);
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}

/* ══════════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════════ */
.sidebar {
  position: fixed; top: var(--hh); left: 0; bottom: 0;
  width: var(--sb-w);
  background: rgba(9,9,9,.98);
  display: flex; flex-direction: column;
  z-index: 200; overflow: hidden;
  transition: width var(--t-slow) var(--ease);
}

/* Collapsed sidebar — icon-only */
.sidebar.collapsed { width: var(--sb-w-c); }

/* Hover-to-peek: temporarily expand while keeping collapsed state */
.sidebar.collapsed.sb-peek {
  width: var(--sb-w);
  box-shadow: 4px 0 24px rgba(0,0,0,.45);
  z-index: 200;
}
.sidebar.collapsed.sb-peek .sb-group-label,
.sidebar.collapsed.sb-peek .sb-label-wrap,
.sidebar.collapsed.sb-peek .sb-footer-label { opacity: 1; max-width: 200px; pointer-events: auto; }
.sidebar.collapsed.sb-peek .sb-item { padding: 7px 14px; justify-content: flex-start; }
.sidebar.collapsed.sb-peek .sb-item .sb-icon { margin-right: 10px; }
.sidebar.collapsed.sb-peek .sb-group { opacity: 1; height: auto; padding: revert; overflow: visible; }
.sidebar.collapsed .sb-group-label { opacity: 0; pointer-events: none; }
.sidebar.collapsed .sb-label-wrap { opacity: 0; max-width: 0; overflow: hidden; pointer-events: none; }
.sidebar.collapsed .sb-item {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  padding: 0; gap: 0;
  margin: 2px auto;
  border-radius: var(--r);
}
.sidebar.collapsed .sb-item .sb-icon { margin: 0; flex-shrink: 0; }
.sidebar.collapsed .sb-footer-label { opacity: 0; max-width: 0; overflow: hidden; pointer-events: none; }
.sidebar.collapsed .sb-toggle { justify-content: center; padding: 11px 0; }

/* Collapse toggle — lives at bottom of footer, styled like a nav item */
.sb-toggle {
  display: flex; align-items: center; gap: 14px;
  padding: 11px 24px; width: 100%;
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(240,235,224,.5); background: none; border: none; cursor: pointer;
  border-top: 1px solid var(--edge);
  transition: color var(--t-fast) var(--ease);
  text-align: left; margin-top: 2px;
}
.sb-toggle:hover { color: rgba(240,235,224,.85); }
.sb-toggle-icon {
  flex-shrink: 0; color: rgba(200,169,81,.7); opacity: 1;
  transition: transform var(--t-slow) var(--ease), opacity var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.sb-toggle:hover .sb-toggle-icon { color: #C8A951; opacity: 1; transform: translateX(-5px); }
.sidebar.collapsed .sb-toggle-icon { transform: rotate(180deg); }
.sidebar.collapsed .sb-toggle:hover .sb-toggle-icon { transform: rotate(180deg) translateX(-5px); }

/* Main area slides with sidebar */
.main { transition: left var(--t-slow) var(--ease); }
.main.sb-collapsed { left: var(--sb-w-c); }

/* Nav */
.sb-nav { flex: 1; overflow-y: auto; padding: 12px 0 8px; }
.sb-nav::-webkit-scrollbar { width: 0; }

/* Section group labels */
.sb-group {
  font-family: 'Montserrat', sans-serif;
  font-size: .50rem; font-weight: 600; letter-spacing: .28em; text-transform: uppercase;
  color: var(--text-3);
  padding: 18px 26px 6px;
  display: flex; align-items: center; gap: 10px;
}
.sb-group::after {
  content: ''; flex: 1; height: 1px;
  background: rgba(255,255,255,.05);
}
.sidebar.collapsed .sb-group { opacity: 0; height: 0; padding: 0; overflow: hidden;
  transition: opacity var(--t-mid) var(--ease), height var(--t-slow) var(--ease), padding var(--t-slow) var(--ease); }
.sb-group-label { transition: opacity var(--t-mid) var(--ease), height var(--t-slow) var(--ease), padding var(--t-slow) var(--ease); }

.sb-item {
  display: flex; align-items: center; gap: 13px;
  padding: 11px 14px;
  margin: 2px 12px;
  border-radius: var(--r);
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(240,235,224,.32); border: 1px solid transparent; background: none; width: calc(100% - 24px);
  position: relative; cursor: pointer;
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  text-align: left;
}
.sb-item:hover {
  color: rgba(240,235,224,.65);
  background: rgba(255,255,255,.03);
  border-color: rgba(255,255,255,.05);
}
.sb-item.active {
  color: var(--text);
  background: rgba(200,16,46,.08);
  border-color: rgba(200,16,46,.18);
}

.sb-icon {
  width: 18px; height: 18px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  opacity: .35; color: currentColor;
  transition: opacity var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.sb-icon svg { display: block; }
.sb-item:hover .sb-icon { opacity: .8; }
.sb-item.active .sb-icon { opacity: 1; }

/* Per-item icon colors — distinct, fully saturated */
.sb-item[data-view="home"]       .sb-icon { color: #C8A030; }
.sb-item[data-view="journal"]    .sb-icon { color: #B84848; }
.sb-item[data-view="arc"]        .sb-icon { color: #C8102E; }
.sb-item[data-view="reflection"] .sb-icon { color: #3D8C82; }
.sb-item[data-view="tracker"]    .sb-icon { color: #B87020; }
.sb-item[data-view="my-guide"]   .sb-icon { color: #8A6C20; }
.sb-item[data-view="the-work"]   .sb-icon { color: #A04828; }
.sb-item[data-view="journey"]    .sb-icon { color: #7A4E28; }
.sb-item[data-view="orders"]     .sb-icon { color: #6E5830; }
.sb-item[data-view="settings"]   .sb-icon { color: #8A7828; }
.sb-item[data-view="help"]       .sb-icon { color: #3A7870; }
.sb-item[data-view="contact"]    .sb-icon { color: #2E7868; }

/* Active state: slightly brighter */
.sb-item[data-view="home"].active       .sb-icon { color: #D4AE3A; }
.sb-item[data-view="journal"].active    .sb-icon { color: #C85858; }
.sb-item[data-view="arc"].active        .sb-icon { color: #E01030; }
.sb-item[data-view="reflection"].active .sb-icon { color: #4A9C92; }
.sb-item[data-view="tracker"].active    .sb-icon { color: #C87E28; }
.sb-item[data-view="my-guide"].active   .sb-icon { color: #9A7C28; }
.sb-item[data-view="the-work"].active   .sb-icon { color: #B05830; }
.sb-item[data-view="journey"].active    .sb-icon { color: #8A5E30; }
.sb-item[data-view="orders"].active     .sb-icon { color: #7E6838; }
.sb-item[data-view="settings"].active   .sb-icon { color: #9A8830; }
.sb-item[data-view="help"].active       .sb-icon { color: #488880; }
.sb-item[data-view="contact"].active    .sb-icon { color: #3A8878; }

.sb-label-wrap {
  display: flex; align-items: center; gap: 10px; flex: 1;
  overflow: hidden; white-space: nowrap;
  transition: opacity var(--t-mid) var(--ease), max-width var(--t-slow) var(--ease);
  max-width: 200px; opacity: 1;
}
.sidebar.collapsed .sb-label-wrap { opacity: 0; max-width: 0; pointer-events: none; }
.sidebar.collapsed .sb-group-label { opacity: 0; height: 0; padding: 0; overflow: hidden; transition: opacity var(--t-mid) var(--ease), height var(--t-slow) var(--ease), padding var(--t-slow) var(--ease); }
.sb-group-label { transition: opacity var(--t-mid) var(--ease), height var(--t-slow) var(--ease), padding var(--t-slow) var(--ease); }
.sb-footer-label { transition: opacity var(--t-mid) var(--ease), max-width var(--t-slow) var(--ease); max-width: 100px; opacity: 1; overflow: hidden; white-space: nowrap; }
.sidebar.collapsed .sb-footer-label { opacity: 0; max-width: 0; }

.sb-badge {
  font-family: 'Montserrat', sans-serif; font-size: .58rem; letter-spacing: .08em;
  padding: 2px 8px; border-radius: 99px; margin-left: auto; flex-shrink: 0;
}
.sb-badge.soon {
  background: transparent; border: 1px solid rgba(255,255,255,.14); color: rgba(240,235,224,.35);
}
.sb-badge.ia {
  background: transparent;
  border: 1px solid var(--gold-dim); color: var(--gold);
}

/* Fix #9: Soon-state sidebar item — visually muted, cursor signals disabled */
.sb-item-soon { opacity: .52; cursor: default; }
.sb-item-soon:hover { background: none !important; border-color: transparent !important; }

/* Coming-soon toast */
.lila-toast {
  position: fixed; bottom: 32px; left: 50%; transform: translateX(-50%) translateY(12px);
  background: var(--surface); border: 1px solid var(--edge-hi);
  border-radius: var(--r); padding: 11px 22px;
  font-family: 'Montserrat', sans-serif; font-size: .60rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--text-2);
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
  opacity: 0; pointer-events: none; z-index: 700;
  transition: opacity .22s var(--ease), transform .22s var(--ease);
}
.lila-toast.visible { opacity: 1; transform: translateX(-50%) translateY(0); }
body.light-mode .lila-toast { box-shadow: 0 8px 32px rgba(0,0,0,.12); }

/* ─── Theme transition — View Transitions API crossfade ─── */
::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 420ms;
  animation-timing-function: cubic-bezier(.4,0,.2,1);
}

/* Footer — sign out styled as nav item */
.sb-footer {
  border-top: 1px solid var(--edge); padding: 4px 0 0; flex-shrink: 0;
}
.sb-signout {
  display: flex; align-items: center; gap: 14px;
  padding: 13px 24px; width: 100%;
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(240,235,224,.55); background: none; border: none; cursor: pointer;
  transition: color var(--t-fast) var(--ease);
  text-align: left;
}
.sb-signout:hover { color: var(--crimson); }
.sb-signout .sb-icon {
  color: rgba(200,16,46,.65); opacity: 1;
  transition: color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.sb-signout:hover .sb-icon { color: var(--crimson); opacity: 1; transform: translateX(5px); }

/* Collapsed sidebar — hover label tooltip */
.sb-tooltip {
  position: fixed; z-index: 9000; pointer-events: none;
  transform: translateY(-50%);
  background: rgba(10,10,10,.97);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  padding: 8px 14px;
  font-family: 'Montserrat', sans-serif;
  font-size: .63rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  color: var(--text);
  white-space: nowrap;
  box-shadow: 0 4px 24px rgba(0,0,0,.55);
  opacity: 0;
  transition: opacity 180ms var(--ease);
}
.sb-tooltip.visible { opacity: 1; }
body.light-mode .sb-tooltip {
  background: rgba(224,217,204,.99);
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 4px 24px rgba(0,0,0,.13);
}

/* ══════════════════════════════════════════════════════
   MAIN + VIEW SYSTEM
══════════════════════════════════════════════════════ */
/* Main container — never scrolls itself; views handle their own scroll */
.main {
  position: fixed; top: var(--hh); left: var(--sb-w); right: 0; bottom: 0;
  overflow: hidden;
}

/* Non-home views: single column, scrolls as a unit */
.view {
  display: none;
  height: 100%; overflow-y: auto; overflow-x: hidden;
  animation: view-in var(--t-mid) var(--ease) both;
}
.view::-webkit-scrollbar { display: none; }
.view.active { display: block; }

/* Home view: two columns, each scroll independently */
#view-home.active {
  display: flex; flex-direction: column; height: 100%; overflow: hidden;
}
#view-home .view-header { flex-shrink: 0; }
/* Home stats strip — number + label with accent bar */
.home-stats-strip {
  display: grid; grid-template-columns: repeat(4, 1fr);
  width: 100%; margin-bottom: 36px;
  animation: view-in var(--t-mid) var(--ease) both;
}
.hss-cell {
  display: flex; align-items: center; gap: 14px;
  padding: 22px 0 22px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  transition: opacity var(--t-fast) var(--ease);
}
.hss-cell:hover { opacity: .72; }
.hss-cell + .hss-cell { padding-left: 32px; border-left: 1px solid rgba(255,255,255,.05); }

/* Accent bar — thin vertical gold rule */
.hss-accent {
  width: 2px; height: 32px; flex-shrink: 0; border-radius: 2px;
  background: linear-gradient(to bottom, var(--gold), rgba(200,169,81,.2));
}
.hss-accent-arc {
  background: linear-gradient(to bottom, var(--crimson), rgba(200,16,46,.15));
}

.hss-body { display: flex; flex-direction: column; gap: 4px; }
.hss-num {
  font-family: 'Playfair Display', serif;
  font-size: 1.45rem; font-weight: 700; color: var(--text); line-height: 1;
  display: flex; align-items: baseline; gap: 3px;
}
.hss-of {
  font-family: 'Montserrat', sans-serif;
  font-size: .56rem; color: var(--text-3); letter-spacing: .04em; font-weight: 400;
}
.hss-lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: .54rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text-3);
}

.home-grid {
  flex: 1; min-height: 0;
  display: grid; grid-template-columns: 1fr var(--panel-w);
  overflow: hidden;
}
.home-col-wrap {
  position: relative; overflow: hidden; min-height: 0;
}
.home-left {
  overflow-y: auto; overflow-x: hidden;
  height: 100%;
  padding: 32px 48px 80px;
  scrollbar-width: none;
}
.home-right {
  overflow-y: auto; overflow-x: hidden;
  height: 100%;
  padding: 32px 28px 80px;
  scrollbar-width: none;
}

/* Scroll chevron hint */
.col-scroll-hint {
  position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%);
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(240,235,224,.5);
  pointer-events: none;
  opacity: 1;
  transition: opacity var(--t-slow) var(--ease);
  animation: hint-bob 2.4s ease-in-out infinite;
}
.col-scroll-hint.hidden { opacity: 0; }
@keyframes hint-bob {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(4px); }
}

.home-left::-webkit-scrollbar,
.home-right::-webkit-scrollbar { display: none; }

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

/* ══════════════════════════════════════════════════════
   SHARED COMPONENTS
══════════════════════════════════════════════════════ */

/* View header */
.view-header {
  padding: 40px 48px 32px;
  display: flex; align-items: flex-end; justify-content: space-between; gap: 24px;
  overflow: hidden;
}
.vh-left {}
.vh-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: .63rem; font-weight: 600; letter-spacing: .32em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 8px;
  display: flex; align-items: center; gap: 8px;
}
.vh-eyebrow::before { content: ''; width: 14px; height: 1px; background: var(--text-3); }
.vh-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 900; color: var(--text); line-height: 1.05;
}
.vh-title em { font-style: italic; color: var(--crimson); }
.vh-sub { font-size: 1rem; color: var(--text-2); margin-top: 6px; }
.vh-stats { display: flex; gap: 20px; }
.vh-stat { text-align: right; }
.vh-stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 1.4rem; font-weight: 700; color: var(--gold);
  display: block; line-height: 1;
}
.vh-stat-lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: .67rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--text-3); margin-top: 3px;
}

/* Two-column layout */
.two-col { display: grid; grid-template-columns: 1fr var(--panel-w); transition: grid-template-columns var(--t-slow) var(--ease); }
.col-left { padding: 36px 48px 80px; }
.col-right { padding: 28px 28px 80px; overflow: hidden; transition: opacity 0.35s var(--ease); }

/* Arc has an extra arc-panel wrapper between the flex container and two-col —
   make it a flex child so two-col can fill remaining height */
#view-arc .arc-panel.active {
  flex: 1; min-height: 0; overflow: hidden;
  display: flex; flex-direction: column;
}
/* Arc column wrappers — position: relative so scroll hints can anchor to them */
#view-arc .arc-col-wrap {
  position: relative; overflow: hidden; min-height: 0;
}
/* Journal column wrappers */
#view-journal .jnl-col-wrap {
  position: relative; overflow: hidden; min-height: 0;
}
/* Reflection column wrappers */
#view-reflection .ref-col-wrap {
  position: relative; overflow: hidden; min-height: 0;
}
/* The Work column wrapper */
#view-the-work .tw-col-wrap {
  position: relative; overflow: hidden; min-height: 0;
}
/* Single-column view wrappers */
.view-scroll-wrap {
  overflow-y: auto; overflow-x: hidden;
  height: 100%; scrollbar-width: none;
}
.view-scroll-wrap::-webkit-scrollbar { display: none; }
/* Override these views to not scroll themselves — wrapper does it */
#view-my-guide, #view-help, #view-contact, #view-journey,
#view-orders, #view-settings {
  overflow: hidden; position: relative;
}
/* ── Independent column scroll — Journal, Reflection, Arc & The Work ── */
#view-journal.active, #view-reflection.active, #view-arc.active,
#view-the-work.active {
  display: flex; flex-direction: column; height: 100%; overflow: hidden;
}
#view-journal .view-header, #view-reflection .view-header,
#view-arc .view-header, #view-the-work .view-header { flex-shrink: 0; }
#view-journal .two-col,
#view-reflection .two-col,
#view-arc .two-col,
#view-the-work .two-col {
  flex: 1; min-height: 0; overflow: hidden;
  /* Lock each grid row to the available height so col-left/col-right
     get a concrete, bounded height — required for independent scroll */
  grid-template-rows: minmax(0, 100%);
}
#view-journal .col-left,
#view-journal .col-right,
#view-reflection .col-left,
#view-reflection .col-right,
#view-arc .col-left,
#view-arc .col-right,
#view-the-work .col-left,
#view-the-work .col-right {
  overflow-y: auto; overflow-x: hidden; height: 100%; scrollbar-width: none;
}
#view-arc .col-left::-webkit-scrollbar,
#view-arc .col-right::-webkit-scrollbar { display: none; }
.arc-right-panel { padding: 24px 22px 80px; }
#view-journal .col-left::-webkit-scrollbar,
#view-journal .col-right::-webkit-scrollbar,
#view-reflection .col-left::-webkit-scrollbar,
#view-reflection .col-right::-webkit-scrollbar,
#view-the-work .col-left::-webkit-scrollbar,
#view-the-work .col-right::-webkit-scrollbar { display: none; }

.sec-divider { height: 1px; background: var(--edge); margin: 24px 0; opacity: .4; }

/* Right panel soft card grouping */
.rp-card {
  background: rgba(255,255,255,.022);
  border-radius: var(--r);
  padding: 22px 22px 20px;
  margin-bottom: 16px;
}

/* Right panel section label */
.rp-label {
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); font-weight: 600; letter-spacing: var(--track-sm); text-transform: uppercase;
  color: var(--text-3); margin-bottom: var(--sp-2); margin-top: var(--sp-4);
  display: flex; align-items: center; gap: var(--sp-2);
}
.rp-label:first-child { margin-top: 0; }
.rp-label::before {
  content: '';
  width: 14px; height: 1px; flex-shrink: 0;
  background: linear-gradient(to right, var(--gold), rgba(200,169,81,.2));
}
.rp-label::after { content: none; }

/* Card */
.card {
  background: var(--surface);
  border: 1px solid var(--edge); border-top-color: var(--edge-hi);
  border-radius: var(--r); overflow: hidden;
  position: relative;
}

/* Progress bar */
.prog-track { height: 3px; background: rgba(255,255,255,.05); border-radius: 99px; overflow: hidden; }
.prog-fill { height: 100%; background: linear-gradient(to right, var(--crimson), var(--gold)); border-radius: 99px; width: 0; transition: width 1.6s var(--ease); }

/* Badges */
.ia-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  padding: 3px 9px; border-radius: 4px;
  background: rgba(200,169,81,.1); border: 1px solid rgba(200,169,81,.22);
  color: var(--gold);
}

/* ══════════════════════════════════════════
   BUTTON SYSTEM — v2
══════════════════════════════════════════ */
.btn {
  font-family: 'Montserrat', sans-serif;
  font-size: .6rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase;
  padding: 12px 26px; border-radius: var(--r);
  border: none; cursor: pointer;
  transition:
    background .2s ease,
    border-color .2s ease,
    box-shadow .2s ease,
    color .2s ease,
    transform .12s ease,
    opacity .2s ease;
  display: inline-flex; align-items: center; gap: 8px;
  position: relative; overflow: hidden;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.btn .ripple {
  position: absolute; border-radius: 50%;
  transform: scale(0); animation: ripple-out .5s linear;
  pointer-events: none; background: rgba(255,255,255,.18);
}
body.light-mode .btn .ripple { background: rgba(0,0,0,.1); }
@keyframes ripple-out { to { transform: scale(4); opacity: 0; } }
.btn:active { transform: scale(.97); }

/* 1 — Primary */
.btn-primary {
  background: linear-gradient(120deg, rgba(200,16,46,.24) 0%, rgba(200,169,81,.17) 100%);
  border: 1px solid var(--gold-dim);
  color: var(--gold-hi);
  box-shadow: 0 1px 0 rgba(200,169,81,.07) inset;
}
.btn-primary:hover {
  background: linear-gradient(120deg, rgba(200,16,46,.36) 0%, rgba(200,169,81,.28) 100%);
  border-color: rgba(200,169,81,.48);
  box-shadow: 0 0 22px rgba(200,169,81,.13), 0 1px 0 rgba(200,169,81,.1) inset;
}
.btn-primary.loading { pointer-events: none; color: transparent; }
.btn-primary.loading::after {
  content: ''; position: absolute; top: 50%; left: 50%;
  width: 14px; height: 14px; margin: -7px 0 0 -7px;
  border: 2px solid rgba(200,169,81,.3); border-top-color: var(--gold-hi);
  border-radius: 50%; animation: btn-spin .7s linear infinite;
}
.btn-primary.success { background: rgba(74,143,66,.18); border-color: rgba(74,143,66,.35); color: #6abf6a; pointer-events: none; }
.btn-primary.done-today { background: rgba(200,169,81,.08); border-color: var(--gold-dim); color: rgba(200,169,81,.7); cursor: default; }
body.light-mode .btn-primary {
  background: linear-gradient(120deg, rgba(200,16,46,.14) 0%, rgba(200,169,81,.18) 100%);
  border-color: rgba(154,120,40,.35); color: var(--gold-hi);
}
body.light-mode .btn-primary:hover {
  background: linear-gradient(120deg, rgba(200,16,46,.22) 0%, rgba(200,169,81,.28) 100%);
  border-color: rgba(154,120,40,.55); box-shadow: 0 0 18px rgba(154,120,40,.14);
}

/* 2 — Secondary */
.btn-secondary {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--text-2);
}
.btn-secondary:hover { background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.18); color: var(--text-1); }
body.light-mode .btn-secondary {
  background: rgba(255,255,255,.6); border-color: rgba(0,0,0,.12);
  color: var(--text-2); box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
body.light-mode .btn-secondary:hover {
  background: #fff; border-color: rgba(0,0,0,.2);
  color: var(--text-1); box-shadow: 0 2px 8px rgba(0,0,0,.09);
}

/* 3 — Ghost */
.btn-ghost {
  background: none; border: none;
  color: var(--text-3); padding: 8px 4px;
  letter-spacing: .16em; overflow: visible;
  transition: color .2s ease, transform .22s cubic-bezier(.34,1.56,.64,1);
}
.btn-ghost:hover { color: var(--text-2); transform: translateX(3px); }
.btn-ghost:active { transform: none; }
.btn-ghost::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 0; height: 1px; background: var(--text-3);
  transition: width .28s cubic-bezier(.4,0,.2,1); pointer-events: none;
}
.btn-ghost:hover::after { width: 100%; }
body.light-mode .btn-ghost { color: rgba(24,21,15,.38); }
body.light-mode .btn-ghost:hover { color: rgba(24,21,15,.65); }
body.light-mode .btn-ghost::after { background: rgba(24,21,15,.28); }

/* 4a — Pro CTA (non-members) */
.btn-pro {
  background: linear-gradient(120deg, rgba(200,169,81,.46) 0%, rgba(200,16,46,.22) 100%);
  border: 1px solid rgba(200,169,81,.7);
  color: #e8c96a;
  box-shadow: 0 0 18px rgba(200,169,81,.22), 0 1px 0 rgba(255,220,120,.15) inset;
  overflow: hidden;
  text-shadow: 0 0 12px rgba(200,169,81,.4);
}
.btn-pro::before { content: '✦ '; font-size: .5em; opacity: 1; letter-spacing: 0; }
.btn-pro::after {
  content: ''; position: absolute; top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,220,120,.22), transparent);
  animation: pro-shimmer 3s ease-in-out infinite; pointer-events: none;
}
@keyframes pro-shimmer {
  0%   { left: -60%; opacity: 0; }
  20%  { opacity: 1; }
  50%  { left: 130%; opacity: 1; }
  51%  { opacity: 0; }
  100% { left: 130%; opacity: 0; }
}
.btn-pro:hover {
  background: linear-gradient(120deg, rgba(200,169,81,.6) 0%, rgba(200,16,46,.3) 100%);
  border-color: rgba(200,169,81,.9); color: #f0d880;
  box-shadow: 0 0 32px rgba(200,169,81,.36), 0 1px 0 rgba(255,220,120,.2) inset;
  text-shadow: 0 0 16px rgba(200,169,81,.6);
}
body.light-mode .btn-pro {
  background: linear-gradient(120deg, rgba(154,120,40,.38) 0%, rgba(200,16,46,.14) 100%);
  border-color: rgba(154,120,40,.72); color: #6b4f10;
  box-shadow: 0 0 14px rgba(154,120,40,.22); text-shadow: none;
}
body.light-mode .btn-pro:hover {
  background: linear-gradient(120deg, rgba(154,120,40,.52) 0%, rgba(200,16,46,.22) 100%);
  border-color: rgba(154,120,40,.9); box-shadow: 0 0 24px rgba(154,120,40,.32);
}

/* 4b — Pro Member (post-upgrade) */
.btn-pro-member {
  background: linear-gradient(120deg, rgba(200,169,81,.38) 0%, rgba(200,16,46,.18) 100%);
  border: 1px solid rgba(200,169,81,.62); color: #e8c96a;
  box-shadow: 0 0 14px rgba(200,169,81,.18), 0 1px 0 rgba(255,220,120,.12) inset;
  text-shadow: 0 0 10px rgba(200,169,81,.3);
  animation: pro-breathe 2.8s ease-in-out infinite;
}
.btn-pro-member::before { content: '✦ '; font-size: .5em; opacity: 1; letter-spacing: 0; }
.btn-pro-member:hover {
  background: linear-gradient(120deg, rgba(200,169,81,.52) 0%, rgba(200,16,46,.26) 100%);
  border-color: rgba(200,169,81,.85); color: #f0d880;
  box-shadow: 0 0 26px rgba(200,169,81,.3), 0 1px 0 rgba(255,220,120,.18) inset;
  text-shadow: 0 0 14px rgba(200,169,81,.5); animation: none;
}
body.light-mode .btn-pro-member {
  background: linear-gradient(120deg, rgba(154,120,40,.28) 0%, rgba(200,16,46,.1) 100%);
  border-color: rgba(154,120,40,.62); color: #6b4f10;
  box-shadow: 0 0 10px rgba(154,120,40,.18); text-shadow: none;
}
body.light-mode .btn-pro-member:hover {
  background: linear-gradient(120deg, rgba(154,120,40,.42) 0%, rgba(200,16,46,.18) 100%);
  border-color: rgba(154,120,40,.82); box-shadow: 0 0 20px rgba(154,120,40,.28); animation: none;
}
@keyframes pro-breathe {
  0%, 100% { box-shadow: 0 0 10px rgba(200,169,81,.14), 0 1px 0 rgba(255,220,120,.1) inset; }
  50%       { box-shadow: 0 0 22px rgba(200,169,81,.3),  0 1px 0 rgba(255,220,120,.16) inset; }
}

/* 5 — Destructive */
.btn-destructive {
  background: rgba(200,16,46,.08);
  border: 1px solid rgba(200,16,46,.2);
  color: rgba(220,60,60,.78);
}
.btn-destructive:hover { animation: destructive-warn 1s ease-in-out infinite; }
@keyframes destructive-warn {
  0%, 100% { background: rgba(200,16,46,.18); border-color: rgba(200,16,46,.4); color: rgba(220,60,60,.95); box-shadow: 0 0 0 rgba(200,16,46,0); }
  50%       { background: rgba(200,16,46,.72); border-color: rgba(220,40,60,.9); color: #fff; box-shadow: 0 0 22px rgba(200,16,46,.5); }
}
body.light-mode .btn-destructive { background: rgba(200,16,46,.06); border-color: rgba(200,16,46,.18); color: rgba(180,30,30,.75); }
body.light-mode .btn-destructive:hover { background: rgba(200,16,46,.14); border-color: rgba(200,16,46,.35); color: rgba(180,30,30,.95); }

/* 6 — Locked */
.btn-locked {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  color: var(--text-3); cursor: default;
  font-size: .56rem; padding: 7px 13px;
  letter-spacing: .14em; pointer-events: auto;
}
.btn-locked::before { content: '🔒 '; font-size: .7em; }
.btn-locked:hover { border-color: rgba(200,169,81,.2); color: rgba(240,235,224,.4); }
.btn-locked:active { transform: none; }
body.light-mode .btn-locked { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: var(--text-3); }
body.light-mode .btn-locked:hover { border-color: rgba(154,120,40,.25); }

/* Disabled */
.btn:disabled, .btn.is-disabled { opacity: .32; pointer-events: none; }

/* Size modifiers */
.btn-sm { font-size: .54rem; padding: 8px 16px; letter-spacing: .18em; }
.btn-lg { font-size: .66rem; padding: 15px 34px; }
.btn-pill { border-radius: 99px !important; }

/* ── Signature animations ── */
@keyframes btn-spin { to { transform: rotate(360deg); } }

.btn-primary::before {
  content: ''; position: absolute; left: 0; top: -110%;
  width: 100%; height: 100%;
  background: linear-gradient(180deg, transparent 0%, rgba(200,169,81,.13) 50%, transparent 100%);
  pointer-events: none; opacity: 0;
}
.btn-primary:not(.loading):not(.success):hover::before { animation: primary-sweep .55s cubic-bezier(.4,0,.2,1) forwards; }
@keyframes primary-sweep {
  0%   { top: -110%; opacity: 0; }
  15%  { opacity: 1; }
  100% { top: 110%; opacity: 0; }
}
.btn-secondary::before {
  content: ''; position: absolute; inset: 0;
  background: rgba(255,255,255,.07);
  transform: scaleX(0); transform-origin: left center;
  transition: transform .32s cubic-bezier(.4,0,.2,1);
  pointer-events: none; border-radius: inherit;
}
.btn-secondary:hover::before { transform: scaleX(1); }
@keyframes locked-shake {
  0%   { transform: translateX(0); }
  14%  { transform: translateX(-6px); }
  28%  { transform: translateX(6px); }
  42%  { transform: translateX(-4px); }
  57%  { transform: translateX(4px); }
  71%  { transform: translateX(-2px); }
  85%  { transform: translateX(2px); }
  100% { transform: translateX(0); }
}
.btn-locked.is-shaking { animation: locked-shake .42s ease !important; border-color: rgba(200,169,81,.45) !important; color: rgba(200,169,81,.55) !important; }
@keyframes destructive-thump {
  0%   { transform: translateY(0) scale(1); }
  18%  { transform: translateY(4px) scale(.97); }
  42%  { transform: translateY(-5px) scale(1.03); }
  62%  { transform: translateY(2px) scale(.99); }
  80%  { transform: translateY(-1px) scale(1.01); }
  100% { transform: translateY(0) scale(1); }
}
.btn-destructive.is-shaking { animation: destructive-thump .45s cubic-bezier(.36,.07,.19,.97) !important; }

/* Pulse dot */
.pulse-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--crimson);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1);} 50%{opacity:.35;transform:scale(.65);} }

/* Focus ring */
*:focus-visible { outline: 2px solid rgba(200,169,81,.5); outline-offset: 2px; border-radius: 4px; }

/* ══════════════════════════════════════════════════════
   HOME VIEW
══════════════════════════════════════════════════════ */
/* Intention card */
.intention-card {
  border-radius: var(--r); border: 1px solid rgba(200,169,81,.16);
  background: linear-gradient(155deg, rgba(200,169,81,.04), rgba(200,16,46,.02));
  padding: 20px 24px; margin-bottom: 24px;
  position: relative; overflow: hidden;
  cursor: pointer; transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.intention-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(to bottom, var(--gold), var(--crimson));
}
.intention-card:hover { border-color: rgba(200,169,81,.28); box-shadow: 0 4px 20px rgba(200,169,81,.05); }
.intention-card.editing { cursor: default; border-color: rgba(200,169,81,.32); }
.intention-top {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px;
}
.intention-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .70rem; letter-spacing: .22em; text-transform: uppercase; color: var(--gold);
}
.intention-edit-btn {
  font-family: 'Montserrat', sans-serif;
  font-size: .67rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-3); background: none; border: none; padding: 0;
  transition: color var(--t-fast) var(--ease);
}
.intention-edit-btn:hover { color: var(--gold); }
.intention-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.25rem; font-style: italic; color: var(--text); line-height: 1.6;
}
.intention-card:not(.editing) .intention-edit-row { display: none; }
.intention-card.editing .intention-text { display: none; }
.intention-card.editing .intention-edit-btn { display: none; }
.intention-edit-row { margin-top: 12px; }
.intention-textarea {
  width: 100%; background: rgba(255,255,255,.03); border: 1px solid rgba(200,169,81,.2);
  border-radius: var(--r-sm); padding: 12px 16px;
  font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; font-style: italic;
  color: var(--text); outline: none; resize: none; line-height: 1.6; min-height: 72px;
  transition: border-color var(--t-fast) var(--ease);
}
.intention-textarea:focus { border-color: rgba(200,169,81,.4); }
.intention-actions { display: flex; gap: 8px; margin-top: 8px; justify-content: flex-end; }

/* Practice steps */
.practice-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 16px; }
.pstep {
  border-radius: var(--r-sm); border: 1px solid var(--edge);
  background: rgba(255,255,255,.016); padding: 14px 10px; text-align: center;
  cursor: pointer; transition: all var(--t-mid) var(--ease); position: relative;
}
.pstep:hover { border-color: rgba(255,255,255,.12); transform: translateY(-1px); }
.pstep.done { border-color: rgba(200,169,81,.18); background: rgba(200,169,81,.04); }
.pstep.now { border-color: rgba(200,16,46,.28); background: rgba(200,16,46,.04); box-shadow: 0 0 14px rgba(200,16,46,.05); }
.pstep-check {
  position: absolute; top: 7px; right: 7px;
  width: 14px; height: 14px; border-radius: 50%;
  background: rgba(200,169,81,.15); border: 1px solid var(--gold-dim);
  display: flex; align-items: center; justify-content: center;
  font-size: .65rem; color: var(--gold);
}
.pstep:not(.done) .pstep-check { display: none; }
.pstep-live-dot { position: absolute; top: 7px; right: 7px; }
.pstep:not(.now) .pstep-live-dot { display: none; }
.pstep-icon { font-size: 1.2rem; display: block; margin-bottom: 5px; }
.pstep-name {
  font-family: 'Montserrat', sans-serif;
  font-size: .70rem; font-weight: 600; letter-spacing: .13em; text-transform: uppercase;
  color: var(--text-3); display: block; transition: color var(--t-fast) var(--ease);
}
.pstep.done .pstep-name { color: rgba(200,169,81,.7); }
.pstep.now .pstep-name { color: rgba(200,16,46,.8); }
.pstep-meta {
  font-family: 'Montserrat', sans-serif;
  font-size: .60rem; letter-spacing: .08em; color: var(--text-3); margin-top: 3px;
}

/* Practice CTA — full-width, prominent */
.practice-cta {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 28px; border-radius: var(--r); margin-bottom: 28px;
  width: 100%;
  background: linear-gradient(110deg, rgba(200,16,46,.26), rgba(200,169,81,.1));
  border: 1px solid rgba(200,16,46,.32); border-top-color: rgba(200,169,81,.22);
  cursor: pointer; position: relative; overflow: hidden;
  box-shadow: 0 4px 32px rgba(200,16,46,.1);
  transition: all var(--t-mid) var(--ease);
}
.practice-cta::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: linear-gradient(to bottom, var(--crimson), var(--gold));
}
.practice-cta:hover {
  background: linear-gradient(110deg, rgba(200,16,46,.36), rgba(200,169,81,.16));
  box-shadow: 0 6px 44px rgba(200,16,46,.18);
  transform: translateY(-1px);
}
.pcta-left { display: flex; align-items: center; gap: 14px; padding-left: 6px; }
.pcta-icon { font-size: 1.05rem; }
.pcta-text {
  font-family: 'Montserrat', sans-serif;
  font-size: .8rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text);
}
.pcta-sub {
  font-family: 'Cormorant Garamond', serif;
  font-size: .9rem; font-style: italic; color: var(--text-2); margin-top: 3px;
}
@keyframes arrow-nudge {
  0%, 60%, 100% { transform: translateX(0); opacity: 1; }
  30%            { transform: translateX(5px); opacity: .7; }
}
.pcta-arrow {
  color: var(--gold); font-size: 1.05rem; flex-shrink: 0;
  display: inline-block;
  animation: arrow-nudge 2.2s ease-in-out infinite;
}

/* IA Arc Prompt */
.arc-prompt {
  border-radius: var(--r); border: 1px solid rgba(200,169,81,.16);
  background: linear-gradient(155deg, rgba(200,16,46,.05), rgba(200,169,81,.03));
  padding: 20px 24px; margin-bottom: 24px;
  position: relative; overflow: hidden;
}
.arc-prompt::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(to bottom, var(--crimson), var(--gold));
}
.ap-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.ap-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .70rem; letter-spacing: .22em; text-transform: uppercase; color: var(--gold);
}
.ap-actions { display: flex; gap: 8px; }
.ap-btn {
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); letter-spacing: var(--track-xs); text-transform: uppercase;
  padding: 5px 13px; border-radius: 99px; border: 1px solid var(--gold-dim);
  background: none; color: var(--text-3);
  transition: all var(--t-fast) var(--ease);
}
.ap-btn:hover { color: var(--gold); border-color: var(--gold); }
.ap-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem; font-style: italic; color: var(--text); line-height: 1.65; margin-bottom: 12px;
}
.ap-footer { display: flex; align-items: center; justify-content: space-between; }
.ap-note {
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
}

/* Quick capture */
.quick-capture {
  display: flex; align-items: center; gap: 10px;
  border-radius: var(--r-sm); border: 1px solid var(--edge);
  background: rgba(255,255,255,.016); padding: 12px 14px; margin-bottom: 24px;
  transition: border-color var(--t-fast) var(--ease);
}
.quick-capture:focus-within { border-color: rgba(255,255,255,.12); }
.qc-field {
  flex: 1; background: none; border: none; outline: none;
  font-family: 'Cormorant Garamond', serif; font-size: .98rem; font-style: italic;
  color: var(--text);
}
.qc-field::placeholder { color: var(--text-3); }
.qc-actions { display: flex; gap: 6px; }
.qc-field { cursor: text; }

/* ══════════════════════════════════════════════════════
   FOCUS MODE OVERLAY
══════════════════════════════════════════════════════ */
@keyframes focus-in {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.focus-overlay {
  position: fixed; inset: 0; z-index: 500;
  background: rgba(5,5,5,.96);
  backdrop-filter: blur(20px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-mid) var(--ease);
}
.focus-overlay.active {
  opacity: 1; pointer-events: all;
}
.focus-panel {
  width: 100%; max-width: 680px;
  display: flex; flex-direction: column; gap: 0;
  animation: focus-in var(--t-mid) var(--ease) both;
}

/* Header */
.focus-header {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  margin-bottom: 28px;
}
.focus-label {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase;
  color: var(--text-3);
}
.focus-close {
  background: none; border: none;
  font-size: .75rem; color: var(--text-3);
  cursor: pointer; padding: 4px 8px;
  transition: color var(--t-fast) var(--ease);
}
.focus-close:hover { color: var(--text); }

/* Writing area */
.focus-field {
  width: 100%; min-height: 260px; max-height: 50vh;
  background: none; border: none; outline: none; resize: none;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.45rem; font-style: italic; font-weight: 400;
  color: var(--text); line-height: 1.7;
  caret-color: var(--crimson);
}
.focus-field::placeholder {
  color: rgba(240,235,224,.14);
}

/* Footer */
.focus-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.06);
  margin-top: 24px; gap: 12px;
}
.focus-footer-left  { display: flex; align-items: center; gap: 10px; }
.focus-footer-right { display: flex; align-items: center; gap: 16px; }

/* Write / Voice toggle pills */
.focus-mode-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 99px;
  font-family: 'Montserrat', sans-serif;
  font-size: .50rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  color: var(--text-3); cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.focus-mode-btn:hover { color: var(--text); border-color: rgba(255,255,255,.14); }
.focus-mode-btn.focus-mode-active {
  color: var(--gold);
  background: rgba(200,169,81,.08);
  border-color: rgba(200,169,81,.22);
}

/* Char count */
.focus-char-count {
  font-family: 'Montserrat', sans-serif;
  font-size: .48rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-3);
}

/* Hint */
.focus-hint {
  font-family: 'Montserrat', sans-serif;
  font-size: .46rem; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(240,235,224,.15);
}

/* Save button */
.focus-save {
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase;
  color: var(--text); background: none;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--r); padding: 10px 22px;
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.focus-save:hover {
  background: rgba(200,16,46,.08);
  border-color: rgba(200,16,46,.28);
  color: var(--text);
}

/* Recent entries */
.re-card {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; border-radius: var(--r-sm);
  border: 1px solid var(--edge); background: rgba(255,255,255,.016);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
  position: relative; overflow: hidden; margin-bottom: 8px;
}
.re-card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; }
.re-card.voice::before { background: var(--crimson); }
.re-card.written::before { background: var(--gold); }
.re-card:hover { border-color: rgba(255,255,255,.1); background: rgba(255,255,255,.028); }
.re-icon {
  width: 30px; height: 30px; border-radius: 7px;
  background: rgba(255,255,255,.04); display: flex; align-items: center; justify-content: center;
  font-size: .85rem; flex-shrink: 0;
}
.re-body { flex: 1; min-width: 0; }
.re-title {
  font-family: 'Playfair Display', serif; font-size: .9rem; font-weight: 700;
  color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.re-preview {
  font-size: .8rem; color: var(--text-2); font-style: italic;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px;
}
.re-meta { text-align: right; flex-shrink: 0; }
.re-date {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
}

/* Right panel: Arc circle ring */
.arc-ring-wrap {
  display: flex; flex-direction: column; align-items: center;
  padding: 4px 0 14px;
  margin-bottom: 0;
}
.arc-ring-svg-wrap {
  position: relative; width: 164px; height: 164px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.arc-ring-svg {
  position: absolute; inset: 0; width: 100%; height: 100%;
}
.arc-ring-track {
  fill: none; stroke: rgba(255,255,255,.07); stroke-width: 7;
}
.arc-ring-fill {
  fill: none;
  stroke: url(#arcRingGrad);
  stroke-width: 8;
  stroke-linecap: round;
  stroke-dasharray: 314.16;
  stroke-dashoffset: 314.16;
  transform: rotate(-90deg); transform-origin: 60px 60px;
  transition: stroke-dashoffset 1.8s cubic-bezier(0.16,1,0.3,1);
  filter: drop-shadow(0 0 6px rgba(200,16,46,.3));
}
.arc-ring-center {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; position: relative; z-index: 1;
}
.arc-ring-num {
  font-family: 'Playfair Display', serif;
  font-size: 2.6rem; font-weight: 900; line-height: 1;
}
.arc-ring-of-30 {
  font-family: 'Montserrat', sans-serif;
  font-size: .56rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--text-3); margin-top: 3px;
}
.arc-ring-unit {
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--text-3);
}
.arc-ring-info { text-align: center; margin-bottom: 14px; }
.arc-ring-days-left {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem; font-style: italic; color: var(--text-2); margin-bottom: 5px;
}
.arc-ring-chapter-name {
  font-family: 'Montserrat', sans-serif;
  font-size: .60rem; letter-spacing: .14em; text-transform: uppercase; color: var(--text-3);
}
.arc-ring-cta {
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); font-weight: 600; letter-spacing: var(--track-md); text-transform: uppercase;
  color: var(--gold); background: none; border: 1px solid var(--gold-dim);
  padding: 8px 22px; border-radius: 99px;
  transition: all var(--t-fast) var(--ease); cursor: pointer;
}
.arc-ring-cta:hover { background: var(--gold-glow); border-color: var(--gold); }

/* Legacy arc mini grid (kept for other views that may reference it) */
.arc-mini-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 3px; margin-bottom: 8px;
}
.ag-cell {
  aspect-ratio: 1; border-radius: 3px; cursor: pointer;
  transition: transform .12s ease, opacity .12s ease;
}
.ag-cell:hover { transform: scale(1.15); opacity: .8; }
.ag-cell.done { background: rgba(200,169,81,.38); }
.ag-cell.today { background: var(--crimson); box-shadow: 0 0 8px rgba(200,16,46,.45); }
.ag-cell.ms { background: linear-gradient(135deg, rgba(200,16,46,.45), rgba(200,169,81,.35)); }
.ag-cell.empty { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.04); }
.arc-mini-meta {
  display: flex; justify-content: space-between;
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
  margin-bottom: 8px;
  padding-bottom: 0;
}

/* Guide card */
.guide-card {
  border-radius: var(--r-sm); border: 1px solid var(--edge);
  background: rgba(255,255,255,.02); padding: 14px 16px;
  cursor: pointer; transition: border-color var(--t-fast) var(--ease);
  margin-bottom: 0;
}
.guide-card:hover { border-color: rgba(200,169,81,.18); }
.guide-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.guide-chapter { font-size: .88rem; color: var(--text-2); font-style: italic; }
.guide-pct { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700; color: var(--gold); }
.guide-meta {
  display: flex; justify-content: space-between;
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
  margin-top: 6px;
}

/* Mood week bars */
.mood-week { display: flex; gap: 4px; margin-bottom: 6px; }
.mood-col { display: flex; flex-direction: column; align-items: center; gap: 3px; flex: 1; }
.mood-bar { width: 100%; border-radius: 3px; transition: height var(--t-slow) var(--ease); min-height: 0; }
.mood-day {
  font-family: 'Montserrat', sans-serif;
  font-size: .56rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-3);
}

/* Next milestone */
.milestone-next {
  border-radius: var(--r-sm); border: 1px solid rgba(200,169,81,.14);
  background: linear-gradient(155deg, rgba(200,169,81,.04), rgba(200,16,46,.02));
  padding: 14px 16px;
}
.mn-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-3);
  margin-bottom: 8px;
}
.mn-title {
  font-family: 'Playfair Display', serif; font-size: .98rem; font-weight: 700; color: var(--gold);
  margin-bottom: 4px;
}
.mn-desc { font-size: .88rem; color: var(--text-2); line-height: 1.5; }
.mn-countdown {
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; letter-spacing: .14em; text-transform: uppercase; color: var(--text-3);
  margin-top: 8px;
}

/* Time Capsule status (home right panel) */
.capsule-status {
  border-radius: var(--r-sm);
  background: repeating-linear-gradient(-45deg, rgba(200,169,81,.025) 0px, rgba(200,169,81,.025) 1px, transparent 1px, transparent 9px),
              linear-gradient(135deg, rgba(200,169,81,.05), rgba(200,16,46,.04));
  border: 1px solid rgba(200,169,81,.22); border-top-color: rgba(200,169,81,.4);
  padding: 14px 16px;
  display: flex; align-items: center; gap: 12px;
  position: relative; overflow: hidden;
}
.capsule-status::before {
  content: ''; position: absolute; left: 0; right: 0; top: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.capsule-lock { font-size: 1.3rem; flex-shrink: 0; }
.capsule-info { flex: 1; }
.capsule-title {
  font-family: 'Playfair Display', serif; font-size: .76rem; font-weight: 700; color: var(--gold);
  margin-bottom: 3px;
}
.capsule-sub {
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
}
.capsule-days {
  font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 900; color: var(--gold);
  line-height: 1; flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════
   JOURNAL VIEW
══════════════════════════════════════════════════════ */
/* Tab bar */
.tab-bar {
  display: grid; grid-template-columns: repeat(3, 1fr);
  padding: 3px; background: rgba(0,0,0,.15);
  border-radius: calc(var(--r-sm) + 2px); margin-bottom: var(--sp-4);
}
.tab-btn {
  padding: 11px 10px; background: transparent; border: none;
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); font-weight: 600; letter-spacing: var(--track-sm); text-transform: uppercase;
  color: var(--text-3); cursor: pointer; border-radius: 6px;
  transition: all var(--t-fast) var(--ease); outline: 1px solid transparent;
  display: flex; align-items: center; justify-content: center; gap: var(--sp-1);
}
.tab-btn:hover:not(.active) { color: var(--text-2); }
.tab-btn.active {
  background: rgba(255,255,255,.1);
  box-shadow: 0 1px 6px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.07);
  outline: 1px solid rgba(200,169,81,.55);
  color: var(--text);
}
.tab-panel { display: none; }
.tab-panel.active { display: block; animation: view-in var(--t-mid) var(--ease) both; }

/* Write area */
.write-area {
  width: 100%; min-height: 160px; background: rgba(255,255,255,.02);
  border: 1px solid var(--edge); border-radius: var(--r); padding: 20px 24px;
  font-family: 'Cormorant Garamond', serif; font-size: 1.15rem;
  color: var(--text); outline: none; resize: none; line-height: 1.75;
  transition: border-color var(--t-fast) var(--ease),
              min-height 0.55s var(--ease),
              font-size 0.35s var(--ease);
}
.write-area:focus { border-color: rgba(200,169,81,.28); }
.write-area::placeholder { color: var(--text-3); }
.write-actions { display: flex; align-items: center; justify-content: space-between; margin-top: 10px; }
.write-meta {
  font-family: 'Montserrat', sans-serif;
  font-size: .67rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-3);
}

/* Voice recorder */
.voice-rec-area {
  border: 1px solid var(--edge); border-radius: var(--r); padding: 28px 24px;
  text-align: center; margin-bottom: 16px;
}
.voice-rec-btn {
  width: 64px; height: 64px; border-radius: 50%;
  background: radial-gradient(circle, rgba(200,16,46,.18), rgba(200,16,46,.06));
  border: 2px solid rgba(200,16,46,.3); font-size: 1.4rem;
  cursor: pointer; transition: all var(--t-mid) var(--ease);
  display: flex; align-items: center; justify-content: center; margin: 0 auto 16px;
}
.voice-rec-btn:hover { background: radial-gradient(circle, rgba(200,16,46,.28), rgba(200,16,46,.12)); }
.voice-rec-btn.recording {
  background: radial-gradient(circle, rgba(200,16,46,.35), rgba(200,16,46,.15));
  border-color: var(--crimson); animation: rec-pulse 1.5s ease-in-out infinite;
}
@keyframes rec-pulse { 0%,100%{box-shadow:0 0 0 0 rgba(200,16,46,.3);} 50%{box-shadow:0 0 0 14px rgba(200,16,46,0);} }
.voice-rec-status {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-3);
}
.voice-waveform { display: flex; align-items: center; justify-content: center; gap: 2px; height: 32px; margin: 14px 0; }
.wv-bar { width: 3px; border-radius: 99px; background: rgba(200,16,46,.4); animation: wv-anim 0.8s ease-in-out infinite; }
@keyframes wv-anim { 0%,100%{height:4px;opacity:.3;} 50%{height:20px;opacity:1;} }

/* Entry list */
.entry-card {
  border: 1px solid var(--edge); border-radius: var(--r);
  background: rgba(255,255,255,.016);
  margin-bottom: 8px; overflow: hidden; cursor: pointer;
  transition: border-color var(--t-fast) var(--ease);
  position: relative;
}
.entry-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px;
  border-radius: 2px 0 0 2px;
}
.entry-card.written::before { background: var(--gold); opacity: .7; }
.entry-card.voice::before   { background: var(--crimson); opacity: .7; }
.entry-card.video::before   { background: rgba(140,120,240,1); opacity: .7; }
.entry-card:hover { border-color: rgba(255,255,255,.1); }
.entry-card.expanded { border-color: rgba(200,169,81,.2); }
.entry-head {
  display: flex; align-items: center; gap: 12px; padding: 14px 16px;
}
.entry-type-dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
}
.entry-type-dot.voice { background: var(--crimson); }
.entry-type-dot.written { background: var(--gold); }
.entry-info { flex: 1; min-width: 0; }
.entry-title {
  font-family: 'Playfair Display', serif; font-size: .95rem; font-weight: 700;
  color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.entry-preview {
  font-size: .65rem; color: var(--text-2); font-style: italic;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px;
}
.entry-meta { text-align: right; flex-shrink: 0; }
.entry-date {
  font-family: 'Montserrat', sans-serif;
  font-size: .60rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
}
.entry-mood {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-size: .56rem; letter-spacing: .1em; text-transform: uppercase;
  margin-top: 4px;
  padding: 2px 7px; border-radius: 20px;
  background: rgba(255,255,255,.05);
  color: var(--text-3);
}
.entry-expand-body {
  max-height: 0; overflow: hidden;
  transition: max-height var(--t-slow) var(--ease), padding var(--t-mid) var(--ease);
  border-top: 0px solid var(--edge);
}
.entry-card.expanded .entry-expand-body {
  max-height: 400px; padding: 0 16px 16px;
  border-top-width: 1px;
}
.entry-full-text { font-size: 1rem; color: var(--text-2); line-height: 1.72; margin-bottom: 14px; padding-top: 14px; }
.entry-expand-actions { display: flex; gap: 8px; }
.entry-expand-actions button[disabled] { opacity: .35; cursor: not-allowed; pointer-events: none; }

.jnl-mode-icon { font-size: .9rem; }

/* ─────────────────────────────────────────────
   JOURNAL — PANELS
───────────────────────────────────────────── */
.jnl-panel { display: none; }
.jnl-panel.active { display: block; animation: view-in var(--t-mid) var(--ease) both; }

/* Title input */
.jnl-title-input {
  width: 100%; background: transparent; border: none;
  border-bottom: 1px solid var(--edge);
  padding: 8px 2px 10px;
  font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700;
  color: var(--text); outline: none; margin-bottom: 14px;
  transition: border-color var(--t-fast) var(--ease);
}
.jnl-title-input:focus { border-bottom-color: rgba(200,169,81,.4); }
.jnl-title-input::placeholder { color: var(--text-3); font-weight: 400; font-style: italic; }

/* ─────────────────────────────────────────────
   JOURNAL — MOOD ROW
───────────────────────────────────────────── */
.jnl-mood-row { margin: 14px 0 0; }
.jnl-mood-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase;
  color: var(--text-3); display: block; margin-bottom: 8px;
}
.jnl-moods { display: flex; flex-wrap: wrap; gap: 6px; }
.mood-tag {
  padding: 5px 11px; border-radius: 99px;
  border: 1px solid var(--edge); background: transparent;
  font-family: 'Montserrat', sans-serif;
  font-size: .59rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3); cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.mood-tag:hover { border-color: rgba(255,255,255,.15); color: var(--text-2); }
.mood-tag.active { border-color: var(--gold); color: var(--gold); background: var(--gold-glow); }

/* ─────────────────────────────────────────────
   JOURNAL — VOICE STUDIO
───────────────────────────────────────────── */
.voice-studio {
  border: 1px solid var(--edge); border-radius: var(--r);
  padding: 28px 24px; text-align: center; margin-bottom: 16px;
}
.vs-timer {
  font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 900;
  color: var(--text); letter-spacing: .04em; margin-bottom: 18px;
}
.vs-waveform {
  display: flex; align-items: center; justify-content: center;
  gap: 3px; height: 40px; margin-bottom: 20px;
}
.vs-bar {
  width: 3px; border-radius: 99px; background: rgba(200,16,46,.5);
  animation: wv-anim 0.7s ease-in-out infinite;
}
@keyframes wv-anim { 0%,100%{height:4px;opacity:.25;} 50%{height:30px;opacity:1;} }
.vs-rec-btn {
  width: 60px; height: 60px; border-radius: 50%;
  background: radial-gradient(circle, rgba(200,16,46,.18), rgba(200,16,46,.06));
  border: 2px solid rgba(200,16,46,.3);
  font-size: 1.2rem; font-weight: 700; color: var(--crimson);
  cursor: pointer; transition: all var(--t-mid) var(--ease);
  display: inline-flex; align-items: center; justify-content: center;
  margin: 0 auto 14px;
}
.vs-rec-btn:hover { background: radial-gradient(circle, rgba(200,16,46,.28), rgba(200,16,46,.12)); border-color: var(--crimson); }
.vs-rec-btn.recording {
  background: radial-gradient(circle, rgba(200,16,46,.35), rgba(200,16,46,.15));
  border-color: var(--crimson); animation: rec-pulse 1.5s ease-in-out infinite;
}
.vs-status {
  font-family: 'Montserrat', sans-serif;
  font-size: .61rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-3);
}

/* ─────────────────────────────────────────────
   JOURNAL — VIDEO STUDIO
───────────────────────────────────────────── */
.video-studio { margin-bottom: 16px; }
.vid-viewfinder {
  position: relative; width: 100%; aspect-ratio: 16/9;
  background: #0a0a0a; border: 1px solid var(--edge);
  border-radius: var(--r); overflow: hidden; margin-bottom: 14px;
  display: flex; align-items: center; justify-content: center;
}
.vid-preview {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; display: none; border-radius: var(--r);
}
.vid-overlay {
  position: absolute; inset: 0; padding: 12px;
  display: flex; align-items: flex-start; justify-content: space-between;
  pointer-events: none;
}
.vid-rec-badge {
  display: flex; align-items: center; gap: 6px;
  background: rgba(200,16,46,.85); border-radius: 99px;
  padding: 4px 10px;
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem; font-weight: 800; letter-spacing: .16em; color: #fff;
}
.vid-rec-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #fff; animation: rec-pulse 1s ease-in-out infinite;
}
.vid-overlay-timer {
  font-family: 'Montserrat', sans-serif;
  font-size: .65rem; font-weight: 700; letter-spacing: .1em;
  color: rgba(255,255,255,.9);
  text-shadow: 0 1px 4px rgba(0,0,0,.6);
}
.vid-no-camera {
  text-align: center; padding: 32px 20px;
}
.vid-controls {
  display: flex; align-items: center; justify-content: center;
  gap: 16px; margin-bottom: 6px;
}

/* ─────────────────────────────────────────────
   JOURNAL — FILTER BAR + ENHANCED ENTRIES
───────────────────────────────────────────── */
.jnl-filter-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px; flex-wrap: wrap; gap: 10px;
}
.jnl-filter-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; font-weight: 600; letter-spacing: .15em;
  text-transform: uppercase; color: var(--text-3);
}
.jnl-filter-tabs { display: flex; gap: 6px; flex-wrap: wrap; }
.jnl-filter-btn {
  padding: 7px 14px; background: rgba(255,255,255,.05); border: none;
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-xs); font-weight: 600; letter-spacing: var(--track-xs); text-transform: uppercase;
  color: var(--text-3); cursor: pointer; border-radius: 20px;
  outline: 1px solid transparent;
  transition: all var(--t-fast) var(--ease);
}
.jnl-filter-btn:hover:not(.active) { color: var(--text-2); background: rgba(255,255,255,.08); }
.jnl-filter-btn.active {
  background: rgba(255,255,255,.1); color: var(--text);
  outline: 1px solid rgba(200,169,81,.55);
  box-shadow: 0 1px 6px rgba(0,0,0,.4);
}

/* Entry type badge (replaces old dot) */
.entry-type-badge {
  width: 30px; height: 30px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; flex-shrink: 0;
}
.entry-type-badge.voice   { background: rgba(200,16,46,.12); }
.entry-type-badge.written { background: rgba(200,169,81,.1); }
.entry-type-badge.video   { background: rgba(100,80,200,.12); }

/* Voice entry waveform preview */
.entry-waveform {
  display: flex; align-items: flex-end; gap: 2px;
  height: 20px; margin-top: 4px;
}
.ewv-bar {
  width: 3px; min-height: 4px; border-radius: 99px;
  background: rgba(200,16,46,.35);
}
.entry-duration {
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem; letter-spacing: .1em; color: var(--text-3);
  margin-top: 3px;
}

/* Video entry thumbnail */
.entry-video-thumb {
  display: flex; align-items: center; gap: 8px; margin-top: 4px;
}
.evt-placeholder {
  width: 52px; height: 32px; border-radius: 5px;
  background: #0a0a0a; border: 1px solid var(--edge);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.evt-duration {
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem; letter-spacing: .1em; color: var(--text-3);
}

/* Mood colour chips on past entries — pill style */
.entry-mood.mood-grounded  { color: #6abf6a; background: rgba(106,191,106,.12); }
.entry-mood.mood-open      { color: #7ab8f5; background: rgba(122,184,245,.12); }
.entry-mood.mood-heavy     { color: #a07ef5; background: rgba(160,126,245,.12); }
.entry-mood.mood-clear     { color: var(--gold); background: rgba(200,169,81,.12); }
.entry-mood.mood-alive     { color: #f5a623; background: rgba(245,166,35,.12); }
.entry-mood.mood-resistant { color: var(--crimson); background: rgba(200,16,46,.1); }
.entry-mood.mood-tender    { color: #f5a0b0; background: rgba(245,160,176,.12); }

/* ── Light mode overrides ── */
body.light-mode .jnl-title-input { color: #18150f; border-bottom-color: rgba(0,0,0,.12); }
body.light-mode .jnl-title-input::placeholder { color: rgba(24,21,15,.35); }
body.light-mode .mood-tag { border-color: rgba(0,0,0,.12); color: rgba(24,21,15,.5); }
body.light-mode .mood-tag:hover { border-color: rgba(0,0,0,.22); color: rgba(24,21,15,.75); }
body.light-mode .mood-tag.active { background: rgba(200,169,81,.12); }
body.light-mode .voice-studio { background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.1); }
body.light-mode .vs-timer { color: #18150f; }
body.light-mode .vid-viewfinder { background: #e0d8cc; border-color: rgba(0,0,0,.1); }
body.light-mode .jnl-filter-btn { background: rgba(0,0,0,.05); }
body.light-mode .jnl-filter-btn:hover:not(.active) { background: rgba(0,0,0,.08); }
body.light-mode .jnl-filter-btn.active { background: #fff; box-shadow: 0 1px 5px rgba(0,0,0,.12); outline: 1px solid rgba(200,169,81,.6); color: var(--text); }
body.light-mode .ref-tabs { background: rgba(0,0,0,.08); }
body.light-mode .ref-tab.active { background: #fff; box-shadow: 0 1px 5px rgba(0,0,0,.12); outline: 1px solid rgba(200,169,81,.6); color: var(--text); }
body.light-mode .fchip { background: rgba(0,0,0,.05); }
body.light-mode .fchip:hover:not(.active) { background: rgba(0,0,0,.08); }
body.light-mode .fchip.active { background: #fff; box-shadow: 0 1px 5px rgba(0,0,0,.12); outline: 1px solid rgba(200,169,81,.6); color: var(--text); }
body.light-mode .entry-type-badge.written { background: rgba(200,169,81,.15); }
body.light-mode .entry-type-badge.voice   { background: rgba(200,16,46,.08); }
body.light-mode .entry-type-badge.video   { background: rgba(100,80,200,.08); }
body.light-mode .ewv-bar { background: rgba(200,16,46,.25); }
body.light-mode .evt-placeholder { background: #d8d0c5; border-color: rgba(0,0,0,.1); }

/* ═══════════════════════════════════════════════════════
   RHYTHM — HEALTH DATA
═══════════════════════════════════════════════════════ */

/* ── Readiness Banner ── */
.rhy-readiness {
  display: flex; align-items: center; gap: 20px;
  border-radius: var(--r); padding: 18px 22px; margin-bottom: 20px;
  border: 1px solid; flex-wrap: wrap;
}
.rhy-ready-good {
  background: rgba(106,191,106,.08);
  border-color: rgba(106,191,106,.25);
}
.rhy-ready-ok {
  background: rgba(245,166,35,.08);
  border-color: rgba(245,166,35,.25);
}
.rhy-ready-low {
  background: rgba(200,16,46,.08);
  border-color: rgba(200,16,46,.25);
}
.rhy-ready-score-wrap { text-align: center; flex-shrink: 0; }
.rhy-ready-score {
  font-family: 'Playfair Display', serif; font-size: 2.4rem; font-weight: 900;
  line-height: 1;
}
.rhy-ready-good .rhy-ready-score { color: #6abf6a; }
.rhy-ready-ok  .rhy-ready-score  { color: #f5a623; }
.rhy-ready-low .rhy-ready-score  { color: var(--crimson); }
.rhy-ready-score-label {
  font-family: 'Montserrat', sans-serif; font-size: .55rem;
  letter-spacing: .18em; text-transform: uppercase; color: var(--text-3); margin-top: 2px;
}
.rhy-ready-center { flex: 1; min-width: 160px; }
.rhy-ready-title {
  font-family: 'Playfair Display', serif; font-size: 1.05rem; font-weight: 700;
  color: var(--text); margin-bottom: 4px;
}
.rhy-ready-sub {
  font-family: 'Montserrat', sans-serif; font-size: .65rem; color: var(--text-2);
  line-height: 1.5;
}
.rhy-ready-factors {
  display: flex; flex-direction: column; gap: 5px; flex-shrink: 0;
}
.rhy-factor {
  font-family: 'Montserrat', sans-serif; font-size: .6rem;
  letter-spacing: .08em; color: var(--text-2); display: flex; align-items: center; gap: 6px;
}

/* ── Health Snapshot Strip ── */
.rhy-snapshot {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 8px; margin-bottom: 20px;
}
.rhy-snap-tile {
  border: 1px solid var(--edge); border-radius: var(--r-sm);
  padding: 12px 10px; text-align: center;
  background: rgba(255,255,255,.016);
  transition: border-color var(--t-fast) var(--ease);
}
.rhy-snap-tile:hover { border-color: rgba(255,255,255,.1); }
.rst-icon { font-size: 1.2rem; margin-bottom: 5px; }
.rst-value {
  font-family: 'Playfair Display', serif; font-size: .95rem; font-weight: 700;
  color: var(--text); line-height: 1;
}
.rst-unit {
  font-family: 'Montserrat', sans-serif; font-size: .5rem;
  letter-spacing: .1em; color: var(--text-3); margin-left: 1px;
}
.rst-label {
  font-family: 'Montserrat', sans-serif; font-size: .55rem;
  letter-spacing: .12em; text-transform: uppercase; color: var(--text-3);
  margin: 4px 0 6px;
}
.rst-sparkline { width: 100%; height: 18px; display: block; }

/* ── Body Data Cards Grid ── */
.rhy-cards-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 12px; margin-bottom: 8px;
}
.rhy-card {
  border: 1px solid var(--edge); border-radius: var(--r);
  background: rgba(255,255,255,.016); overflow: hidden;
  cursor: pointer; transition: border-color var(--t-fast) var(--ease);
}
.rhy-card:hover { border-color: rgba(255,255,255,.1); }
.rhy-card.open  { border-color: rgba(200,169,81,.2); }
.rhy-card-head {
  display: flex; align-items: center; gap: 10px; padding: 14px 14px;
}
.rhy-card-icon { font-size: 1.3rem; flex-shrink: 0; }
.rhy-card-info { flex: 1; min-width: 0; }
.rhy-card-title {
  font-family: 'Montserrat', sans-serif; font-size: .62rem;
  font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--text-2);
}
.rhy-card-value {
  font-family: 'Playfair Display', serif; font-size: .92rem; font-weight: 700;
  color: var(--text); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rhy-card-badge {
  font-family: 'Montserrat', sans-serif; font-size: .52rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 99px; flex-shrink: 0;
}
.rhy-card-badge.good { background: rgba(106,191,106,.15); color: #6abf6a; }
.rhy-card-badge.ok   { background: rgba(245,166,35,.12);  color: #f5a623; }
.rhy-card-badge.sync { background: rgba(200,169,81,.1);   color: var(--gold); }
.rhy-card-chevron {
  font-size: .75rem; color: var(--text-3); flex-shrink: 0;
  transition: transform var(--t-fast) var(--ease);
}
.rhy-card.open .rhy-card-chevron { transform: rotate(180deg); }
.rhy-card-body {
  max-height: 0; overflow: hidden;
  transition: max-height .5s var(--ease), padding .35s var(--ease);
  border-top: 0px solid var(--edge);
}
.rhy-card.open .rhy-card-body {
  max-height: 600px; padding: 0 14px 14px;
  border-top-width: 1px;
}

/* ── Sleep card internals ── */
.sleep-meta-row {
  display: flex; justify-content: space-between;
  font-family: 'Montserrat', sans-serif; font-size: .6rem;
  letter-spacing: .08em; color: var(--text-3); margin: 10px 0 10px;
}
.sleep-stages-bar {
  display: flex; height: 8px; border-radius: 99px; overflow: hidden; gap: 2px;
  margin-bottom: 8px;
}
.ssb-seg { border-radius: 99px; height: 100%; }
.ssb-seg.light { background: #7ab8f5; }
.ssb-seg.deep  { background: #3b6de8; }
.ssb-seg.rem   { background: #9b59b6; }
.ssb-seg.awake { background: rgba(255,255,255,.2); }
.sleep-stages-legend {
  display: flex; flex-wrap: wrap; gap: 6px 12px;
  font-family: 'Montserrat', sans-serif; font-size: .57rem;
  letter-spacing: .08em; color: var(--text-3); margin-bottom: 12px;
}
.ssl-dot {
  display: inline-block; width: 6px; height: 6px;
  border-radius: 50%; margin-right: 3px; vertical-align: middle;
}
.ssl-dot.light { background: #7ab8f5; }
.ssl-dot.deep  { background: #3b6de8; }
.ssl-dot.rem   { background: #9b59b6; }
.ssl-dot.awake { background: rgba(255,255,255,.25); }

/* ── Movement / Steps Ring ── */
.steps-ring-wrap {
  display: flex; align-items: center; gap: 14px; padding: 10px 0 12px;
}
.steps-ring-svg { width: 80px; height: 80px; flex-shrink: 0; }
.ring-track { fill: none; stroke: rgba(255,255,255,.06); stroke-width: 6; }
.ring-fill  {
  fill: none; stroke: #6abf6a; stroke-width: 6;
  stroke-linecap: round;
  transform: rotate(-90deg); transform-origin: 40px 40px;
  transition: stroke-dashoffset 1s var(--ease);
}
.ring-pct {
  fill: var(--text); font-family: 'Playfair Display', serif;
  font-size: 13px; font-weight: 700;
}
.ring-sub-txt {
  fill: var(--text-3); font-family: 'Montserrat', sans-serif;
  font-size: 6px; letter-spacing: .05em; text-transform: uppercase;
}
.steps-ring-stats { flex: 1; }
.srs-row {
  display: flex; gap: 6px; align-items: baseline;
  margin-bottom: 5px;
}
.srs-val {
  font-family: 'Playfair Display', serif; font-size: .95rem;
  font-weight: 700; color: var(--text);
}
.srs-lbl {
  font-family: 'Montserrat', sans-serif; font-size: .57rem;
  letter-spacing: .08em; color: var(--text-3);
}
.srs-workout {
  font-family: 'Montserrat', sans-serif; font-size: .6rem;
  color: var(--text-2); margin-top: 6px;
}

/* ── Nutrition card internals ── */
.nutr-connect-row {
  padding: 10px 0 12px; border-bottom: 1px solid var(--edge); margin-bottom: 12px;
}
.ncr-label {
  font-family: 'Montserrat', sans-serif; font-size: .57rem;
  letter-spacing: .12em; text-transform: uppercase; color: var(--text-3);
  margin-bottom: 7px;
}
.ncr-apps { display: flex; flex-wrap: wrap; gap: 6px; }
.ncr-app-btn {
  padding: 5px 10px; border-radius: var(--r-sm);
  border: 1px solid var(--edge); background: rgba(255,255,255,.03);
  font-family: 'Montserrat', sans-serif; font-size: .58rem;
  font-weight: 600; letter-spacing: .08em; color: var(--text-2);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
}
.ncr-app-btn:hover { border-color: rgba(200,169,81,.3); color: var(--gold); background: var(--gold-glow); }
.macro-bars { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.macro-row { display: flex; align-items: center; gap: 8px; }
.macro-label {
  font-family: 'Montserrat', sans-serif; font-size: .57rem;
  letter-spacing: .08em; color: var(--text-3); width: 54px; flex-shrink: 0;
}
.macro-track {
  flex: 1; height: 5px; border-radius: 99px;
  background: rgba(255,255,255,.06); overflow: hidden;
}
.macro-fill { height: 100%; border-radius: 99px; transition: width 1s var(--ease); }
.macro-fill.cal     { background: var(--gold); }
.macro-fill.protein { background: #6abf6a; }
.macro-fill.carbs   { background: #7ab8f5; }
.macro-fill.fat     { background: #f5a623; }
.macro-fill.water   { background: #58c8f0; }
.macro-val {
  font-family: 'Montserrat', sans-serif; font-size: .6rem;
  font-weight: 600; color: var(--text-2); width: 36px; text-align: right; flex-shrink: 0;
}
.nutr-manual-toggle {
  background: none; border: none; padding: 0;
  font-family: 'Montserrat', sans-serif; font-size: .6rem;
  font-weight: 600; letter-spacing: .1em; color: var(--text-3);
  cursor: pointer; transition: color var(--t-fast) var(--ease);
}
.nutr-manual-toggle:hover { color: var(--gold); }
.nutr-manual-form {
  margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--edge);
}
.nmf-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.nmf-field { display: flex; flex-direction: column; gap: 4px; }
.nmf-field label {
  font-family: 'Montserrat', sans-serif; font-size: .56rem;
  letter-spacing: .12em; text-transform: uppercase; color: var(--text-3);
}
.nmf-input {
  background: rgba(255,255,255,.04); border: 1px solid var(--edge);
  border-radius: var(--r-sm); padding: 6px 8px;
  font-family: 'Montserrat', sans-serif; font-size: .7rem; color: var(--text);
  outline: none; width: 100%;
  transition: border-color var(--t-fast) var(--ease);
}
.nmf-input:focus { border-color: rgba(200,169,81,.3); }
.nmf-save { justify-content: flex-end; align-items: flex-end; }

/* ── Recovery card internals ── */
.recovery-stats {
  display: flex; gap: 8px; padding: 10px 0 12px; justify-content: space-between;
}
.rec-stat { flex: 1; text-align: center; }
.rec-stat-val {
  font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700;
  color: var(--text);
}
.rec-stat-val span {
  font-family: 'Montserrat', sans-serif; font-size: .52rem;
  color: var(--text-3); margin-left: 2px; font-weight: 400;
}
.rec-stat-label {
  font-family: 'Montserrat', sans-serif; font-size: .55rem;
  letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
  margin: 3px 0;
}
.rec-stat-trend {
  font-family: 'Montserrat', sans-serif; font-size: .57rem; color: var(--text-3);
}
.rec-stat-trend.up { color: #6abf6a; }

/* ── Shared sparkline row (inside cards) ── */
.rhy-trend-row {
  display: flex; align-items: center; gap: 10px;
  padding-top: 10px; border-top: 1px solid var(--edge);
}
.rhy-trend-label {
  font-family: 'Montserrat', sans-serif; font-size: .56rem;
  letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
  white-space: nowrap;
}
.rhy-sparkline { flex: 1; height: 28px; }

/* ── Today's Practice label ── */
.rhy-practice-label {
  display: flex; align-items: center; justify-content: space-between;
  margin: 16px 0 16px;
  font-family: 'Montserrat', sans-serif;
  font-size: .65rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-2);
}
.rpl-meta { color: var(--text-3); font-weight: 400; }

/* ── Connect Devices Card (right panel) ── */
.rhy-connect-card {
  border: 1px solid var(--edge); border-radius: var(--r);
  padding: 16px; margin-bottom: 14px;
  background: rgba(255,255,255,.016);
}
.rcc-title {
  font-family: 'Playfair Display', serif; font-size: .95rem; font-weight: 700;
  color: var(--text); margin-bottom: 3px;
}
.rcc-sub {
  font-family: 'Montserrat', sans-serif; font-size: .58rem;
  letter-spacing: .1em; color: var(--text-3); margin-bottom: 12px;
}
.rcc-devices { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.rcc-device-btn {
  display: flex; align-items: center; gap: 8px;
  width: 100%; padding: 8px 10px;
  border: 1px solid var(--edge); border-radius: var(--r-sm);
  background: rgba(255,255,255,.02);
  font-family: 'Montserrat', sans-serif; font-size: .61rem;
  font-weight: 600; letter-spacing: .08em; color: var(--text-2);
  cursor: pointer; text-align: left;
  transition: all var(--t-fast) var(--ease);
}
.rcc-device-btn:hover {
  border-color: rgba(200,169,81,.3); color: var(--gold);
  background: var(--gold-glow);
}
.rcc-note {
  font-family: 'Montserrat', sans-serif; font-size: .56rem;
  letter-spacing: .07em; color: var(--text-3); line-height: 1.5;
}

/* ── Device rows (rp-card system) ── */
.dev-row {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 9px 0; border: none; border-bottom: 1px solid var(--edge);
  background: transparent; cursor: pointer; text-align: left;
  transition: opacity var(--t-fast) var(--ease);
}
.dev-row:last-of-type { border-bottom: none; }
.dev-row:hover { opacity: .7; }
.dev-row-icon { font-size: 1rem; flex-shrink: 0; }
.dev-row-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: .95rem; font-style: italic; color: var(--text-2); flex: 1;
}
.dev-row-action {
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; letter-spacing: .16em; text-transform: uppercase; color: var(--text-3);
}
.dev-note {
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; letter-spacing: .08em; color: var(--text-3);
  margin-top: 10px; line-height: 1.6; margin-bottom: var(--sp-4);
}
.dev-note-link {
  background: none; border: none; padding: 0; cursor: pointer;
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; letter-spacing: .08em;
  color: var(--gold); opacity: .75;
  transition: opacity .2s;
}
.dev-note-link:hover { opacity: 1; }

/* ── Connected row state ── */
.dev-row.connected { cursor: pointer; opacity: 1 !important; }
.dev-row.connected:hover { opacity: .85 !important; }
.dev-row.connected.active { background: var(--gold-dim); border-radius: 6px; }
.dev-row.connected .dev-row-action {
  color: rgba(100,185,120,.75);
  letter-spacing: .12em;
}
.dev-row.connected .dev-row-name { color: var(--text); }

/* ── Device Connect Wizard ── */
.dcw-device-hero {
  display: flex; align-items: center; justify-content: center;
  width: 58px; height: 58px; border-radius: 16px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--edge-hi);
  margin: 0 auto 20px;
}
.dcw-device-hero svg { display: block; }

.dcw-metrics {
  display: flex; flex-wrap: wrap; gap: 6px;
  justify-content: center; margin: 18px 0 24px;
}
.dcw-metric {
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: rgba(200,169,81,.65);
  background: rgba(200,169,81,.07);
  border: 1px solid rgba(200,169,81,.16);
  border-radius: 99px; padding: 4px 10px;
}

.dcw-ios-note {
  font-family: 'Cormorant Garamond', serif;
  font-size: .88rem; line-height: 1.65;
  color: var(--text-2); text-align: center;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--edge);
  border-radius: var(--r-sm);
  padding: 16px 18px; margin-bottom: 22px;
}

/* Light mode overrides */
body.light-mode .dcw-device-hero {
  background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1);
}
body.light-mode .dcw-metric {
  color: rgba(130,100,30,.7);
  background: rgba(130,100,30,.07);
  border-color: rgba(130,100,30,.18);
}
body.light-mode .dcw-ios-note {
  background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.08);
}
body.sepia-mode .dcw-device-hero {
  background: rgba(210,175,105,.06); border-color: rgba(210,175,105,.15);
}
/* Checklist rows in right panel — flat, no card wrapper */
.arc-right-panel .check-item {
  border-bottom: 1px solid var(--edge);
  border-radius: 0; padding: 9px 0;
}
.arc-right-panel .check-item:last-of-type { border-bottom: none; }

/* ── Device panel collapse ── */
.dev-panel-toggle {
  display: flex; align-items: center; justify-content: center;
  width: 100%; background: none; border: none; border-top: 1px solid var(--edge);
  padding: 7px 0 2px; cursor: pointer;
  color: var(--text-3); transition: color .2s;
  margin-top: 6px;
}
.dev-panel-toggle:hover { color: var(--text-2); }
#dev-panel-chevron { transition: transform .25s ease; transform: rotate(180deg); }

/* Collapsed state — hide unconnected rows + note only; connected rows stay as-is */
#dev-panel-card.dev-collapsed .dev-row:not(.connected) { display: none; }
#dev-panel-card.dev-collapsed .dev-note                { display: none; }
#dev-panel-card.dev-collapsed #dev-panel-chevron       { transform: rotate(0deg); }

/* Inline detail panel */
.dev-inline-detail {
  border-top: 1px solid var(--edge);
  padding: 10px 0 6px;
  margin-top: 2px;
}
.dev-pop-header { margin-bottom: 10px; }
.dev-pop-name {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: .88rem; font-weight: 600; color: var(--text);
  margin-bottom: 3px;
}
.dev-pop-status {
  font-family: 'Montserrat', sans-serif;
  font-size: .6rem; letter-spacing: .08em;
  color: rgba(100,185,120,.85);
}
.dev-pop-disconnect {
  font-family: 'Montserrat', sans-serif;
  font-size: .6rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3);
  background: none; border: 1px solid var(--border);
  border-radius: 6px; padding: 5px 12px; cursor: pointer;
  transition: color .2s, border-color .2s;
}
.dev-pop-disconnect:hover { color: #c0392b; border-color: rgba(192,57,43,.35); }

/* ── Light mode overrides ── */
body.light-mode .rhy-ready-good { background: rgba(106,191,106,.06); border-color: rgba(106,191,106,.2); }
body.light-mode .rhy-ready-ok   { background: rgba(245,166,35,.06);  border-color: rgba(245,166,35,.2); }
body.light-mode .rhy-ready-low  { background: rgba(200,16,46,.05);   border-color: rgba(200,16,46,.2); }
body.light-mode .rhy-snap-tile  { background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.09); }
body.light-mode .rhy-card       { background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.09); }
body.light-mode .rhy-card:hover { border-color: rgba(0,0,0,.16); }
body.light-mode .ring-track     { stroke: rgba(0,0,0,.07); }
body.light-mode .macro-track    { background: rgba(0,0,0,.06); }
body.light-mode .ncr-app-btn    { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.1); color: rgba(24,21,15,.6); }
body.light-mode .nmf-input      { background: #fff; border-color: rgba(0,0,0,.12); color: #18150f; }
body.light-mode .rhy-connect-card { background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.09); }
body.light-mode .rcc-device-btn { background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.09); color: rgba(24,21,15,.6); }
body.light-mode .ssb-seg.awake  { background: rgba(0,0,0,.12); }
body.light-mode .ssl-dot.awake  { background: rgba(0,0,0,.2); }

/* Journal right panel */
.capsule-panel {
  border-radius: var(--r); overflow: hidden;
  border: 1px solid rgba(200,169,81,.2); border-top-color: rgba(200,169,81,.4);
  background: repeating-linear-gradient(-45deg, rgba(200,169,81,.025) 0px, rgba(200,169,81,.025) 1px, transparent 1px, transparent 9px),
              rgba(0,0,0,.3);
  padding: 20px;
}
body.light-mode .capsule-panel {
  background: repeating-linear-gradient(-45deg, rgba(200,169,81,.03) 0px, rgba(200,169,81,.03) 1px, transparent 1px, transparent 9px),
              rgba(200,169,81,.06);
  border-color: rgba(200,169,81,.2); border-top-color: rgba(200,169,81,.35);
}
.cp-top { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.cp-lock { font-size: 1.5rem; }
.cp-title {
  font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700; color: var(--gold);
}
.cp-sub {
  font-family: 'Montserrat', sans-serif;
  font-size: .67rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
}
.cp-counter {
  font-family: 'Playfair Display', serif; font-size: 2.2rem; font-weight: 900; color: var(--gold);
  line-height: 1; margin-bottom: 4px;
}
.cp-counter-label {
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); letter-spacing: var(--track-sm); text-transform: uppercase; color: var(--text-3);
  margin-bottom: var(--sp-2);
}
.cp-arc-complete {
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-xs); letter-spacing: var(--track-xs); text-transform: uppercase;
  color: var(--text-3); margin-top: var(--sp-1);
}

/* Letter to Future Self */
.letter-card {
  border-radius: var(--r); border: var(--card-border-feat);
  background: var(--card-bg-feat);
  padding: var(--card-pad); position: relative; overflow: hidden;
}
.letter-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(to bottom, var(--gold), var(--crimson));
}
.letter-title {
  font-family: 'Playfair Display', serif; font-size: 1rem; font-weight: 700;
  color: var(--text); margin-bottom: 6px;
}
.letter-sub { font-size: .88rem; color: var(--text-2); line-height: 1.55; margin-bottom: 14px; }
.letter-actions { display: flex; gap: 8px; }

/* ══════════════════════════════════════════════════════
   PRACTICE VIEW
══════════════════════════════════════════════════════ */

/* Steps bar */
.steps-bar {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: var(--edge);
  border-radius: var(--r-sm); overflow: hidden;
  margin-bottom: 32px;
}
.step-pill {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  padding: var(--tab-pad); background: var(--surface); border: none;
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); font-weight: 600; letter-spacing: var(--track-sm); text-transform: uppercase;
  color: var(--text-3); cursor: pointer;
  transition: all var(--t-mid) var(--ease);
}
.step-pill.done { color: rgba(200,169,81,.7); background: rgba(200,169,81,.04); }
.step-pill.now { color: var(--text); background: rgba(255,255,255,.04); }
.step-num {
  width: 17px; height: 17px; border-radius: 50%;
  background: rgba(255,255,255,.06); border: none;
  display: flex; align-items: center; justify-content: center;
  font-size: .62rem; font-weight: 700; flex-shrink: 0;
  transition: all var(--t-mid) var(--ease);
}
.step-pill.done .step-num { background: rgba(200,169,81,.18); color: var(--gold); }
.step-pill.now .step-num { background: var(--crimson); color: #fff; }

/* Step panels */
.step-panel { display: none; }
.step-panel.active { display: block; animation: view-in var(--t-slow) var(--ease) both; }
.step-heading {
  font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 700; color: var(--text);
  margin-bottom: 6px;
}
.step-sub { font-size: 1rem; color: var(--text-2); line-height: 1.65; margin-bottom: 24px; max-width: 500px; }
.step-nav { display: flex; align-items: center; justify-content: space-between; margin-top: 28px; padding-top: 20px; border-top: 1px solid var(--edge); }

/* Mood grid */
.mood-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 20px; }
.mood-card {
  border-radius: var(--r); border: 1px solid var(--edge);
  background: rgba(255,255,255,.02); padding: 14px 10px; text-align: center;
  cursor: pointer; transition: all var(--t-mid) var(--ease);
}
.mood-card:hover { border-color: rgba(255,255,255,.12); transform: translateY(-1px); }
.mood-card.selected { border-color: var(--gold-dim); background: var(--gold-glow); }
.mood-emoji { font-size: 1.4rem; margin-bottom: 6px; display: block; }
.mood-name {
  font-family: 'Montserrat', sans-serif;
  font-size: .70rem; letter-spacing: .14em; text-transform: uppercase; color: var(--text-3);
  transition: color var(--t-fast) var(--ease);
}
.mood-card.selected .mood-name { color: var(--gold); }
.mood-note {
  width: 100%; background: rgba(255,255,255,.02); border: 1px solid var(--edge);
  border-radius: var(--r-sm); padding: 12px 16px;
  font-family: 'Cormorant Garamond', serif; font-size: 1rem; font-style: italic;
  color: var(--text); outline: none; resize: none; min-height: 64px; line-height: 1.6;
  transition: border-color var(--t-fast) var(--ease);
}
.mood-note:focus { border-color: rgba(200,169,81,.25); }
.mood-note::placeholder { color: var(--text-3); }

/* Breathwork */
.breath-selector { display: flex; gap: 8px; margin-bottom: 24px; }
.breath-opt {
  flex: 1; padding: 12px 10px; border-radius: var(--r);
  border: 1px solid var(--edge); background: none; cursor: pointer; text-align: center;
  transition: all var(--t-mid) var(--ease);
}
.breath-opt:hover { border-color: rgba(255,255,255,.12); }
.breath-opt.active { border-color: rgba(200,169,81,.28); background: var(--gold-glow); }
.bo-name {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-2); display: block; margin-bottom: 2px; transition: color var(--t-fast) var(--ease);
}
.breath-opt.active .bo-name { color: var(--gold); }
.bo-desc { font-size: .8rem; color: var(--text-3); }

.breath-circle-wrap { display: flex; flex-direction: column; align-items: center; gap: 20px; padding: 32px 0; }
.breath-outer {
  width: 200px; height: 200px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; position: relative;
  background: radial-gradient(circle at center, rgba(200,169,81,.06) 0%, transparent 72%);
}
.breath-ring-1 { position: absolute; inset: -18px; border-radius: 50%; border: 1px solid rgba(200,169,81,.15); animation: ring-pulse 4s ease-in-out infinite; }
.breath-ring-2 { position: absolute; inset: -34px; border-radius: 50%; border: 1px solid rgba(200,169,81,.07); animation: ring-pulse 4s ease-in-out infinite .6s; }
.breath-ring-3 { position: absolute; inset: -52px; border-radius: 50%; border: 1px solid rgba(200,169,81,.03); animation: ring-pulse 4s ease-in-out infinite 1.1s; }
@keyframes ring-pulse { 0%,100%{opacity:0;transform:scale(.94);} 50%{opacity:1;transform:scale(1.04);} }
.breath-circle {
  width: 130px; height: 130px; border-radius: 50%;
  background: radial-gradient(circle at 40% 35%, rgba(200,169,81,.14), rgba(200,16,46,.06) 60%, transparent);
  border: 1.5px solid rgba(200,169,81,.28);
  box-shadow: 0 0 28px rgba(200,169,81,.1), inset 0 0 18px rgba(200,169,81,.05);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
  transition: all 4s ease-in-out;
}
.breath-circle.expand { transform: scale(1.42); background: radial-gradient(circle, rgba(200,169,81,.18), rgba(200,16,46,.1)); border-color: rgba(200,169,81,.45); box-shadow: 0 0 40px rgba(200,169,81,.12); }
.breath-circle.hold { border-color: rgba(200,169,81,.55); box-shadow: 0 0 28px rgba(200,169,81,.15); }
.breath-circle.exhale { transform: scale(.72); background: radial-gradient(circle, rgba(200,16,46,.07), rgba(200,169,81,.03)); border-color: rgba(200,16,46,.18); box-shadow: none; }
.breath-phase-label { font-family: 'Montserrat', sans-serif; font-size: .63rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--text-2); }
.breath-count-num { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 900; color: var(--text); line-height: 1; }

.post-breath-panel { display: none; animation: view-in var(--t-mid) var(--ease) both; }
.post-breath-panel.visible { display: block; }
.pbp-title { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700; color: var(--text); margin-bottom: 14px; }
.pbp-opts { display: flex; flex-wrap: wrap; gap: 8px; }
.pbp-btn {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; letter-spacing: .12em; text-transform: uppercase;
  padding: 8px 16px; border-radius: 99px;
  border: 1px solid var(--edge); background: none; color: var(--text-3);
  transition: all var(--t-fast) var(--ease);
}
.pbp-btn:hover { border-color: rgba(200,169,81,.25); color: var(--text-2); }
.pbp-btn.selected { border-color: var(--gold-dim); background: var(--gold-glow); color: var(--gold); }

/* IA tier badge on breathwork options */
.ia-badge {
  font-family: 'Montserrat', sans-serif;
  font-size: .42rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  padding: 1px 5px; border-radius: 3px;
  background: rgba(200,169,81,.12); border: 1px solid rgba(200,169,81,.28);
  color: var(--gold); vertical-align: middle; margin-left: 4px;
}

/* Guide — Mark as Read button */
.gr-mark-read {
  font-size: .62rem; letter-spacing: .1em; padding: 10px 20px;
}
.gr-mark-done {
  border-color: rgba(200,169,81,.35) !important;
  background: rgba(200,169,81,.08) !important;
  color: var(--gold) !important;
  box-shadow: none !important;
}
.gr-mark-done::before { display: none !important; }

/* Guide — coming-soon chapter content */
.gr-coming {
  color: var(--text-3); font-style: italic;
  padding: 24px 0;
}

/* Body map */
.body-map-wrap { display: flex; gap: 28px; align-items: flex-start; }
.bm-svg { width: 130px; flex-shrink: 0; }
.bm-hotspot { cursor: pointer; }
.bm-hotspot circle { fill: rgba(200,169,81,.07); stroke: rgba(200,169,81,.18); stroke-width: 1.5; transition: all .2s ease; }
.bm-hotspot:hover circle { fill: rgba(200,169,81,.18); stroke: rgba(200,169,81,.45); }
.bm-hotspot.marked circle { fill: rgba(200,169,81,.22); stroke: var(--gold); }
.bm-right { flex: 1; }
.bm-title { font-family: 'Playfair Display', serif; font-size: 1.05rem; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.bm-sub { font-size: .9rem; color: var(--text-2); line-height: 1.55; margin-bottom: 14px; }
.bm-tags { display: flex; flex-direction: column; gap: 6px; min-height: 48px; margin-bottom: 14px; }
.bm-tag {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 12px; border-radius: var(--r-sm);
  background: rgba(200,169,81,.07); border: 1px solid var(--gold-dim);
}
.bm-tag-name { font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); flex: 1; }
.bm-tag-rm { background: none; border: none; color: var(--text-3); font-size: .75rem; transition: color var(--t-fast) var(--ease); }
.bm-tag-rm:hover { color: var(--crimson); }
.bm-empty { font-size: .88rem; color: var(--text-3); font-style: italic; }
.bm-feelings { display: flex; gap: 6px; flex-wrap: wrap; }
.bm-feeling {
  font-family: 'Montserrat', sans-serif; font-size: .70rem; letter-spacing: .1em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 99px; border: 1px solid var(--edge); background: none; color: var(--text-3);
  transition: all var(--t-fast) var(--ease);
}
.bm-feeling:hover { color: var(--text-2); border-color: rgba(255,255,255,.12); }
.bm-feeling.selected { color: var(--gold); border-color: var(--gold-dim); background: var(--gold-glow); }

/* Complete */
.complete-wrap { text-align: center; padding: 48px 0; }
.complete-icon { font-size: 3rem; display: block; margin-bottom: 16px; animation: pop .5s var(--ease) both; }
@keyframes pop { from{transform:scale(0);opacity:0;} to{transform:scale(1);opacity:1;} }
.complete-title { font-family: 'Playfair Display', serif; font-size: 1.8rem; font-weight: 900; font-style: italic; color: var(--text); margin-bottom: 8px; }
.complete-sub { font-size: 1rem; color: var(--text-2); line-height: 1.7; max-width: 400px; margin: 0 auto 28px; }
.complete-stats { display: flex; border: 1px solid var(--edge); border-radius: var(--r-sm); overflow: hidden; margin-bottom: 28px; }
.cs-stat { flex: 1; padding: 14px; text-align: center; border-right: 1px solid var(--edge); }
.cs-stat:last-child { border-right: none; }
.cs-stat-num { font-family: 'Playfair Display', serif; font-size: 1.4rem; font-weight: 700; color: var(--gold); display: block; }
.cs-stat-lbl { font-family: 'Montserrat', sans-serif; font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; color: var(--text-3); margin-top: 3px; display: block; }
.complete-actions { display: flex; gap: 10px; justify-content: center; }

/* Right panel — practice */
.today-checklist-card {
  border: 1px solid var(--edge); border-radius: var(--r-sm);
  background: rgba(255,255,255,.02); padding: 16px; margin-bottom: 20px;
}
.tcl-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.tcl-title {
  font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .22em; text-transform: uppercase; color: var(--text-3);
}
.tcl-live { display: flex; align-items: center; gap: 5px; font-family: 'Montserrat', sans-serif; font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(200,16,46,.7); }
.check-item { display: flex; align-items: center; gap: 10px; padding: 7px 8px; border-radius: var(--r-sm); transition: background var(--t-fast) var(--ease); }
.check-item.done { background: rgba(200,169,81,.04); }
.check-circle {
  width: 15px; height: 15px; border-radius: 50%; flex-shrink: 0;
  border: 1.5px solid var(--edge);
  display: flex; align-items: center; justify-content: center;
  font-size: .4rem; color: var(--gold);
  transition: all var(--t-fast) var(--ease);
}
.check-item.done .check-circle { background: rgba(200,169,81,.14); border-color: var(--gold); }
.check-item.done .check-circle::after { content: '✓'; }
.check-name { font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-3); flex: 1; transition: color var(--t-fast) var(--ease); }
.check-item.done .check-name { color: rgba(200,169,81,.7); }
.check-time { font-family: 'Montserrat', sans-serif; font-size: .60rem; letter-spacing: .08em; color: var(--text-3); }

/* Week dots */
.week-dots { display: flex; gap: 5px; margin-bottom: 20px; }
.wd-wrap { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.wd {
  width: 26px; height: 26px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif; font-size: .64rem; font-weight: 600;
  transition: all var(--t-mid) var(--ease);
}
.wd.done { background: rgba(200,169,81,.14); border: 1.5px solid rgba(200,169,81,.3); color: var(--gold); }
.wd.today { background: var(--crimson); color: #fff; box-shadow: 0 0 10px rgba(200,16,46,.3); }
.wd.miss { background: rgba(200,16,46,.06); border: 1.5px solid rgba(200,16,46,.14); color: rgba(200,16,46,.4); }
.wd.ahead { background: rgba(255,255,255,.03); border: 1px solid var(--edge); color: var(--text-3); }
.wd-day { font-family: 'Montserrat', sans-serif; font-size: .56rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-3); }

/* Heatmap */
.heat-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; margin-bottom: 8px; }
.heat-cell { aspect-ratio: 1; border-radius: 3px; cursor: pointer; transition: transform .12s ease, opacity .12s ease; }
.heat-cell:hover { transform: scale(1.18); opacity: .8; }
.heat-cell.h-empty { background: rgba(255,255,255,.04); }
.heat-cell.h-done { background: rgba(200,169,81,.2); }
.heat-cell.h-full { background: rgba(200,169,81,.36); }
.heat-cell.h-today { background: var(--crimson); box-shadow: 0 0 5px rgba(200,16,46,.3); }

/* ══════════════════════════════════════════════════════
   REFLECTION VIEW
══════════════════════════════════════════════════════ */
.arc-panel { display: none; }
.arc-panel.active { display: block; }

.ref-tabs {
  display: grid; grid-template-columns: 1fr 1fr;
  padding: 3px; background: rgba(0,0,0,.15);
  border-radius: calc(var(--r-sm) + 2px); margin-bottom: var(--sp-4);
}
.ref-tabs-3 { grid-template-columns: 1fr 1fr 1fr; }
.ref-tab {
  padding: 11px 10px; background: transparent; border: none;
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); font-weight: 600; letter-spacing: var(--track-sm); text-transform: uppercase;
  color: var(--text-3); cursor: pointer; border-radius: 6px;
  display: flex; align-items: center; justify-content: center; gap: var(--sp-1);
  transition: all var(--t-fast) var(--ease); outline: 1px solid transparent;
}
.ref-tab:hover:not(.active) { color: var(--text-2); }
.ref-tab.active {
  background: rgba(255,255,255,.1);
  box-shadow: 0 1px 6px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.07);
  outline: 1px solid rgba(200,169,81,.55);
  color: var(--text);
}

/* ── Filter chips — Journey & Journal past-entries ── */
.fchip-bar { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: var(--sp-4); }
.fchip {
  padding: 9px 16px; background: rgba(255,255,255,.05); border: none;
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); font-weight: 600; letter-spacing: var(--track-sm); text-transform: uppercase;
  color: var(--text-3); cursor: pointer; border-radius: 20px;
  outline: 1px solid transparent;
  transition: all var(--t-fast) var(--ease);
}
.fchip:hover:not(.active) { color: var(--text-2); background: rgba(255,255,255,.08); }
.fchip.active {
  background: rgba(255,255,255,.1); color: var(--text);
  outline: 1px solid rgba(200,169,81,.55);
  box-shadow: 0 1px 6px rgba(0,0,0,.4);
}
.ref-panel { display: none; }
.ref-panel.active { display: block; animation: view-in var(--t-mid) var(--ease) both; }

/* Shadow work prompt */
.sw-prompt-card {
  border-radius: var(--r); border: 1px solid rgba(200,169,81,.18);
  background: linear-gradient(155deg, rgba(200,16,46,.05), rgba(200,169,81,.03));
  padding: 24px; margin-bottom: 20px; position: relative; overflow: hidden;
}
.sw-prompt-card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: linear-gradient(to bottom, var(--crimson), var(--gold)); }
.sw-header { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 14px; }
.sw-label { font-family: 'Montserrat', sans-serif; font-size: .70rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; min-width: 0; }
.sw-next-btn {
  font-family: 'Montserrat', sans-serif; font-size: var(--label-md); letter-spacing: var(--track-xs); text-transform: uppercase;
  padding: 5px 13px; border-radius: 99px; border: 1px solid var(--gold-dim); background: none; color: var(--text-3);
  transition: all var(--t-fast) var(--ease);
}
.sw-next-btn:hover { color: var(--gold); border-color: var(--gold); }
.sw-prompt-text {
  font-family: 'Cormorant Garamond', serif; font-size: 1.3rem; font-style: italic;
  color: var(--text); line-height: 1.65; margin-bottom: 8px;
}
.sw-prompt-note { font-size: .9rem; color: var(--text-2); line-height: 1.6; }

.sw-textarea {
  width: 100%; min-height: 140px; background: rgba(255,255,255,.02);
  border: 1px solid var(--edge); border-radius: var(--r); padding: 18px 20px;
  font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; color: var(--text);
  outline: none; resize: none; line-height: 1.75;
  transition: border-color var(--t-fast) var(--ease),
              min-height 0.55s var(--ease),
              font-size 0.35s var(--ease);
  margin-bottom: 12px;
}
.sw-textarea:focus { border-color: rgba(200,169,81,.28); }
.sw-textarea::placeholder { color: var(--text-3); }
.sw-textarea.error { border-color: rgba(200,16,46,.4); }
.sw-save-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.sw-word-count { font-family: 'Montserrat', sans-serif; font-size: .67rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3); }

/* Prompt library */
.prompt-library {
  display: flex; flex-direction: column; gap: 8px;
  max-height: 4000px; overflow: hidden;
  transition: max-height 0.6s var(--ease), opacity 0.3s var(--ease);
}
/* ── Shadow Work next preview ── */
.sw-next-card {
  background: rgba(255,255,255,.01); border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--r-sm); padding: 14px 16px; margin-bottom: 10px;
  cursor: pointer; opacity: .6; transition: opacity .2s var(--ease), background .2s var(--ease);
}
.sw-next-card:hover { opacity: .85; background: rgba(255,255,255,.025); }
.sw-next-eyebrow {
  font-family: 'Montserrat', sans-serif; font-size: .54rem; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase; color: var(--text-3); margin-bottom: 6px;
}
.sw-next-text {
  font-family: 'Cormorant Garamond', serif; font-size: .9rem; font-style: italic;
  color: var(--text-2); line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* ── Shadow Work chapter rows ── */
.sw-chapter-row {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 0; border-bottom: 1px solid rgba(255,255,255,.04);
  cursor: pointer; transition: opacity .2s var(--ease);
}
.sw-chapter-row:last-child { border-bottom: none; }
.sw-chapter-row.locked { opacity: .3; cursor: default; pointer-events: none; }
.sw-chapter-row:not(.locked):hover { opacity: .65; }
.sw-ch-num {
  font-family: 'Montserrat', sans-serif; font-size: .54rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: var(--text-3); flex-shrink: 0; width: 34px;
}
.sw-ch-name {
  font-family: 'Cormorant Garamond', serif; font-size: .98rem; font-style: italic;
  color: var(--text-2); flex: 1;
}
.sw-ch-progress {
  font-family: 'Montserrat', sans-serif; font-size: .54rem; font-weight: 600;
  letter-spacing: .08em; color: var(--text-3); flex-shrink: 0;
}
.sw-ch-progress.complete { color: var(--gold); }

/* Weekly Review */
/* ── Weekly Review stepper ── */
.wr-stepper { display: flex; align-items: center; margin-bottom: 26px; }
.wr-dot {
  width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif; font-size: .5rem; font-weight: 700; letter-spacing: .01em;
  border: 1.5px solid rgba(255,255,255,.12); color: var(--text-3);
  transition: all .25s var(--ease); cursor: default;
}
.wr-dot.answered { background: var(--gold); border-color: var(--gold); color: #0a0a0a; cursor: pointer; }
.wr-dot.answered:hover { opacity: .85; }
.wr-dot.active { border-color: var(--gold); color: var(--gold); box-shadow: 0 0 0 3px rgba(200,169,81,.12); }
.wr-dot.locked { opacity: .3; }
.wr-dot-line { flex: 1; height: 1px; background: rgba(255,255,255,.08); margin: 0 3px; }
.wr-dot-line.filled { background: rgba(200,169,81,.35); }

/* ── Weekly Review question card ── */
.wr-q-card {
  background: rgba(255,255,255,.016); border: 1px solid var(--edge);
  border-top: 1px solid rgba(200,169,81,.18); border-radius: var(--r-sm);
  padding: 20px 22px 18px; margin-bottom: 14px;
  transition: opacity .2s var(--ease), transform .2s var(--ease);
}
.wr-q-eyebrow {
  font-family: 'Montserrat', sans-serif; font-size: .58rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; color: rgba(200,169,81,.65); margin-bottom: 10px;
}
.wr-q-text {
  font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700;
  color: var(--text); line-height: 1.4; margin-bottom: 8px;
}
.wr-q-note {
  font-family: 'Cormorant Garamond', serif; font-size: .9rem; font-style: italic;
  color: var(--text-3); line-height: 1.5;
}

/* ── Weekly Review textarea + controls ── */
.wr-textarea {
  width: 100%; background: none; border: none; border-bottom: 1px solid var(--edge);
  padding: 12px 0; font-family: 'Cormorant Garamond', serif; font-size: 1rem;
  color: var(--text); outline: none; line-height: 1.7; resize: none; min-height: 100px;
  transition: border-color var(--t-fast) var(--ease);
}
.wr-textarea:focus { border-bottom-color: rgba(200,169,81,.35); }
.wr-textarea::placeholder { color: var(--text-3); }
.wr-save-row { display: flex; align-items: center; justify-content: space-between; margin-top: 12px; gap: 12px; }
.wr-word-count { font-family: 'Montserrat', sans-serif; font-size: .58rem; letter-spacing: .06em; color: var(--text-3); flex-shrink: 0; }
.wr-btn-row { display: flex; align-items: center; gap: 10px; }
.wr-back-btn {
  font-family: 'Montserrat', sans-serif; font-size: .6rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3); background: none; border: none; cursor: pointer; padding: 6px 0;
  transition: color .2s var(--ease);
}
.wr-back-btn:hover { color: var(--text-2); }
#wr-continue-btn:disabled { opacity: .35; cursor: not-allowed; pointer-events: none; }

/* ── Weekly Review completion state ── */
.wr-complete { text-align: center; padding: 28px 16px 20px; }
.wr-complete-sigil { font-size: 2rem; color: var(--gold); opacity: .7; margin-bottom: 14px; }
.wr-complete-heading { font-family: 'Playfair Display', serif; font-size: 1.25rem; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.wr-complete-sub { font-family: 'Cormorant Garamond', serif; font-size: .92rem; font-style: italic; color: var(--text-3); line-height: 1.55; }

/* ── WR right panel ── */
.wr-answer-card {
  background: rgba(255,255,255,.016); border: 1px solid var(--edge);
  border-radius: var(--r-sm); padding: 12px 14px; margin-bottom: 8px;
}
.wr-answer-q {
  font-family: 'Montserrat', sans-serif; font-size: .55rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; color: rgba(200,169,81,.6); margin-bottom: 5px;
}
.wr-answer-text {
  font-family: 'Cormorant Garamond', serif; font-size: .88rem; color: var(--text-2); line-height: 1.55;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.wr-past-chip {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(255,255,255,.016); border: 1px solid var(--edge);
  border-radius: var(--r-sm); padding: 10px 14px; margin-bottom: 6px;
  cursor: pointer; transition: background .2s var(--ease);
}
.wr-past-chip:hover { background: rgba(255,255,255,.03); }
.wr-past-chip-label { font-family: 'Montserrat', sans-serif; font-size: .6rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--text-2); }
.wr-past-chip-meta { font-family: 'Cormorant Garamond', serif; font-size: .78rem; font-style: italic; color: var(--text-3); }

/* Past reflections (right panel) */
.past-entry {
  border-radius: var(--r); border: var(--card-border);
  background: var(--card-bg); padding: var(--sp-2) var(--sp-3); margin-bottom: var(--sp-1);
  position: relative; overflow: hidden;
  animation: view-in var(--t-slow) var(--ease) both;
}
.past-entry::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px;
  background: linear-gradient(to bottom, var(--gold), transparent);
}
.pe-prompt { font-size: .88rem; color: var(--text-2); font-style: italic; margin-bottom: 5px; line-height: 1.45; padding-left: var(--sp-1); }
.pe-date { font-family: 'Montserrat', sans-serif; font-size: var(--label-xs); letter-spacing: var(--track-xs); text-transform: uppercase; color: var(--text-3); padding-left: var(--sp-1); }
.rp-empty { font-size: .88rem; color: var(--text-3); font-style: italic; padding: var(--sp-2) 0; }

/* Themes */
.themes-wrap { display: flex; flex-wrap: wrap; gap: var(--sp-1); }
.theme-tag {
  font-family: 'Montserrat', sans-serif; font-size: var(--label-xs); letter-spacing: var(--track-xs); text-transform: uppercase;
  padding: 5px 12px; border-radius: 99px; background: rgba(255,255,255,.04); border: 1px solid var(--edge); color: var(--text-3);
  transition: all var(--t-fast) var(--ease);
}
.theme-tag.lg { font-size: var(--label-sm); padding: 6px 14px; border-color: rgba(200,169,81,.22); color: var(--text-2); background: rgba(200,169,81,.05); }

/* ══════════════════════════════════════════════════════
   TRACKER VIEW — SPLIT LAYOUT
══════════════════════════════════════════════════════ */

/* View container: flex column so header + stats stay fixed above split */
#view-tracker.active {
  display: flex; flex-direction: column; height: 100%; overflow: hidden;
}
#view-tracker .view-header { flex-shrink: 0; }

/* Stats strip — full width between header and split, Home inline style */

/* Two-column split */
.tracker-two-col {
  display: grid;
  grid-template-columns: 1fr var(--panel-w);
  flex: 1; min-height: 0; overflow: hidden;
  transition: grid-template-columns var(--t-slow) var(--ease);
}
.tracker-col-wrap {
  position: relative; overflow: hidden; min-height: 0;
}

/* Left scroll column */
.tracker-left {
  overflow-y: auto; overflow-x: hidden;
  height: 100%;
  padding: 16px 24px 80px 24px;
  scrollbar-width: none;
}
.tracker-left::-webkit-scrollbar { display: none; }

/* Right scroll column */
.tracker-right {
  overflow-y: auto; overflow-x: hidden;
  height: 100%;
  padding: 0 22px 80px;
  scrollbar-width: none;
}
.tracker-right::-webkit-scrollbar { display: none; }

/* Section labels inside split columns */
.trk-rpl { padding: 20px 0 12px; }
.trk-rpl:first-child { padding-top: 4px; }

/* Focus mode — collapse right panel + release max-width caps */
body.focus-mode #view-tracker .tracker-two-col      { grid-template-columns: 1fr 0px; }
body.focus-mode #view-tracker .tracker-right        { opacity: 0; pointer-events: none; }
body.focus-mode #view-tracker .mp-grid              { max-width: none; }
body.focus-mode #view-tracker .mp-heatmap-section   { max-width: none; }

/* Habit card */
.habit-card {
  border-radius: var(--r); border: 1px solid var(--edge); border-top-color: var(--edge-hi);
  background: var(--surface); padding: 24px; margin-bottom: 16px;
  overflow: hidden;
  transition: border-color var(--t-mid) var(--ease);
}
.habit-card.flashed { border-color: rgba(200,169,81,.35); }
.hc-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 16px; }
.hc-title { font-family: 'Playfair Display', serif; font-size: 1.2rem; font-weight: 700; color: var(--text); margin-bottom: 3px; }
.hc-sub { font-size: .78rem; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hc-streak { text-align: right; flex-shrink: 0; }
.hc-streak-num { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 900; color: var(--gold); display: block; line-height: 1; }
.hc-streak-lbl { font-family: 'Montserrat', sans-serif; font-size: .64rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-3); white-space: nowrap; }
.habit-grid { display: grid; grid-template-columns: repeat(10, 1fr); gap: 3px; margin-bottom: 12px; }
.hg-cell { aspect-ratio: 1; border-radius: 3px; cursor: pointer; transition: transform .1s ease; }
.hg-cell:hover { transform: scale(1.12); }
.hg-cell.hg-done { background: rgba(200,169,81,.2); }
.hg-cell.hg-today { background: var(--crimson); box-shadow: 0 0 5px rgba(200,16,46,.3); }
.hg-cell.hg-miss { background: rgba(200,16,46,.08); }
.hg-cell.hg-future { background: rgba(255,255,255,.04); }
.hc-prog-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.hc-prog-bar,
.hc-bar-track { flex: 1; height: 4px; background: rgba(255,255,255,.05); border-radius: 99px; overflow: hidden; }
.hc-prog-fill { height: 100%; background: linear-gradient(to right, var(--crimson), var(--gold)); border-radius: 99px; width: 0; transition: width 1.2s var(--ease); }
.hc-prog-pct { font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .1em; color: var(--gold); flex-shrink: 0; }
.hc-footer { display: flex; align-items: center; justify-content: space-between; }
.hc-logged { font-family: 'Montserrat', sans-serif; font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3); }
/* .hc-tap-btn → replaced by .btn.btn-primary (done-today state handled in button system) */

/* Mood correlation */
.mood-corr { border-radius: var(--r); border: 1px solid var(--edge); background: var(--surface); padding: 24px; margin-bottom: 16px; }
.mc-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; }
.mc-title { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700; color: var(--text); margin-bottom: 3px; }
.mc-insight { font-size: .9rem; color: var(--text-2); font-style: italic; }
.mc-bars { display: flex; flex-direction: column; gap: 10px; }
.mc-bar-row { display: flex; align-items: center; gap: 12px; }
.mc-mood { font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-2); width: 80px; flex-shrink: 0; }
.mc-bar-track { flex: 1; height: 6px; background: rgba(255,255,255,.05); border-radius: 99px; overflow: hidden; }
.mc-bar-fill { height: 100%; border-radius: 99px; width: 0; transition: width 1.2s var(--ease); }
.mc-pct { font-family: 'Montserrat', sans-serif; font-size: .70rem; letter-spacing: .08em; color: var(--text-3); width: 32px; text-align: right; flex-shrink: 0; }

/* Milestones */
.milestones-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.ms-card {
  border-radius: var(--r); border: var(--card-border);
  background: var(--card-bg); padding: var(--sp-4); position: relative; overflow: hidden;
  opacity: .62;
}
.ms-card.earned { border-color: rgba(200,169,81,.28); background: rgba(200,169,81,.04); opacity: 1; }
.ms-card.imminent { opacity: .75; }
.ms-card.capsule {
  background: repeating-linear-gradient(-45deg, rgba(200,169,81,.025) 0px, rgba(200,169,81,.025) 1px, transparent 1px, transparent 9px),
              linear-gradient(135deg, rgba(200,169,81,.06), rgba(200,16,46,.05));
  border-color: rgba(200,169,81,.32); border-top-color: rgba(200,169,81,.5);
  box-shadow: 0 0 22px rgba(200,169,81,.09), 0 0 48px rgba(200,169,81,.04);
  animation: p-capsule-glow 3.5s ease-in-out infinite;
  opacity: 1;
}
@keyframes p-capsule-glow {
  0%,100% { box-shadow: 0 0 22px rgba(200,169,81,.09), 0 0 48px rgba(200,169,81,.04); }
  50%      { box-shadow: 0 0 32px rgba(200,169,81,.16), 0 0 72px rgba(200,169,81,.08); }
}
.ms-lock-icon {
  position: absolute; top: 10px; right: 10px;
  color: rgba(200,169,81,.35); display: flex;
}
.ms-card.earned .ms-lock-icon { display: none; }
.ms-day { font-family: 'Montserrat', sans-serif; font-size: .64rem; letter-spacing: .18em; text-transform: uppercase; color: var(--text-3); margin-bottom: 6px; }
.ms-card.earned .ms-day { color: rgba(200,169,81,.6); }
.ms-title { font-family: 'Playfair Display', serif; font-size: .95rem; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.ms-card.earned .ms-title { color: var(--gold); }
.ms-desc { font-size: .84rem; color: var(--text-2); line-height: 1.45; }
.ms-unlock { font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3); margin-top: 8px; }
.ms-card.capsule .ms-title { color: var(--gold); }
.ms-capsule-counter { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 900; color: var(--gold); line-height: 1; margin-top: 6px; }
.ms-capsule-lbl { font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-3); }

/* ══════════════════════════════════════════════════════
   GUIDE VIEW
══════════════════════════════════════════════════════ */
.guide-chapter-pills { display: flex; gap: 6px; margin-bottom: 28px; flex-wrap: wrap; }
.gcp {
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif; font-size: .62rem; font-weight: 700;
  border: 1.5px solid var(--edge); background: none; color: var(--text-3);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
}
.gcp:hover { border-color: var(--edge-hi); color: var(--text-2); }
.gcp-done { border-color: rgba(200,169,81,.3); color: var(--gold); background: rgba(200,169,81,.05); }
.gcp-active { border-color: var(--crimson); color: #fff; background: var(--crimson); box-shadow: 0 0 12px rgba(200,16,46,.25); }
.gcp-locked { opacity: .35; cursor: not-allowed; }

.guide-reading { padding: 32px 36px 40px; border-radius: var(--r); border: 1px solid transparent; }
.gr-eyebrow {
  font-family: 'Montserrat', sans-serif; font-size: .56rem; font-weight: 600;
  letter-spacing: .24em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 14px;
}
.gr-title {
  font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700;
  color: var(--text); line-height: 1.2; margin-bottom: 24px;
}
.gr-title em { color: var(--crimson); }
.gr-divider { height: 1px; background: var(--edge); margin-bottom: 28px; opacity: .6; }
.gr-content { max-width: 620px; }
.gr-content p {
  font-family: 'Cormorant Garamond', serif; font-size: 1.12rem;
  color: var(--text-2); line-height: 1.85; margin-bottom: 20px;
}
.gr-content p em { color: var(--text); font-style: italic; }

.gr-prompt {
  border-left: 2px solid var(--gold); padding: 16px 20px;
  background: var(--gold-glow); border-radius: 0 var(--r-sm) var(--r-sm) 0;
  margin: 32px 0;
}
.gr-prompt-label {
  font-family: 'Montserrat', sans-serif; font-size: .56rem; font-weight: 600;
  letter-spacing: .22em; text-transform: uppercase; color: var(--gold); margin-bottom: 8px;
}
.gr-prompt-text {
  font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; font-style: italic;
  color: var(--text); line-height: 1.6;
}
.gr-nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 8px; }
.gr-nav-btn { flex: 1; }

.guide-prog-wrap { margin-top: 12px; }
.guide-prog-label {
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--text-2);
}
.guide-prog-pct { color: var(--gold); font-weight: 700; }
.guide-prog-meta {
  font-family: 'Montserrat', sans-serif; font-size: .60rem; letter-spacing: .08em;
  color: var(--text-3); margin-top: 6px;
}
.guide-ch-list { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.gch-done  { opacity: .7; }
.gch-active { border-color: rgba(200,16,46,.28) !important; background: rgba(200,16,46,.04) !important; }
.gch-locked { opacity: .38; cursor: not-allowed; pointer-events: none; }

/* ══════════════════════════════════════════════════════
   HELP CENTER VIEW
══════════════════════════════════════════════════════ */
.help-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; padding: 0 48px 0; align-items: start; }
/* Active question gold accent */
.faq-item:has(.faq-q.open) { box-shadow: inset 2px 0 0 rgba(200,169,81,.7); }

/* Search */
.help-search-wrap { position:relative; margin-bottom:24px; display:flex; align-items:center; }
.help-search-icon { position:absolute; left:14px; color:var(--text-3); pointer-events:none; flex-shrink:0; }
.help-search { width:100%; background:var(--surface-2); border:1px solid var(--edge); border-radius:8px; padding:11px 40px 11px 40px; font-family:'Cormorant Garamond',serif; font-size:.98rem; color:var(--text); outline:none; transition:border-color .25s var(--ease); }
.help-search::placeholder { color:var(--text-3); }
.help-search:focus { border-color:rgba(200,169,81,.4); }
.help-search-clear { position:absolute; right:12px; background:none; border:none; cursor:pointer; color:var(--text-3); font-size:.75rem; padding:4px; transition:color .2s; }
.help-search-clear:hover { color:var(--text); }

/* No results */
.help-no-results { font-family:'Cormorant Garamond',serif; font-size:.95rem; font-style:italic; color:var(--text-2); padding:20px 0; line-height:1.7; }
.hnr-link { background:none; border:none; cursor:pointer; font-family:'Cormorant Garamond',serif; font-size:.95rem; font-style:italic; color:var(--gold); text-decoration:underline; text-underline-offset:3px; padding:0; }

/* Full-width footer — standalone, overrides .help-footer */
.help-footer.help-footer-full { display:flex; align-items:center; gap:20px; padding:28px 48px 80px; border-top:1px solid var(--edge); margin-top:24px; max-width:1100px; margin-left:auto; margin-right:auto; }
body.light-mode .help-search { background:rgba(0,0,0,.04); border-color:rgba(0,0,0,.1); }
body.light-mode .help-search:focus { border-color:rgba(200,169,81,.5); }

.faq-category { margin-bottom: 40px; }
.faq-cat-label {
  font-family: 'Montserrat', sans-serif; font-size: .58rem; font-weight: 700;
  letter-spacing: .24em; text-transform: uppercase; color: var(--text-3);
  margin-bottom: 12px;
}
.faq-item {
  background: var(--surface-2);
  border: 1px solid var(--edge);
  border-radius: var(--r-sm);
  margin-bottom: 8px;
  overflow: hidden;
}
.faq-q {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px; background: none; border: none; cursor: pointer;
  font-family: 'Cormorant Garamond', serif; font-size: 1.05rem; font-weight: 600;
  color: var(--text); text-align: left; gap: 16px;
  transition: color var(--t-fast) var(--ease);
}
.faq-q:hover { color: var(--gold); }
.faq-chevron {
  font-size: .7rem; color: var(--text-3); flex-shrink: 0;
  transition: transform var(--t-fast) var(--ease);
}
.faq-q.open .faq-chevron { transform: rotate(180deg); color: var(--gold); }
.faq-q.open { color: var(--text); }
.faq-a {
  font-family: 'Cormorant Garamond', serif; font-size: .98rem;
  color: var(--text-2); line-height: 1.75;
  max-height: 0; overflow: hidden; padding: 0 18px;
  transition: max-height 0.4s var(--ease), padding 0.3s var(--ease), opacity 0.3s;
  opacity: 0;
}
.faq-a.open { max-height: 600px; padding: 0 18px 18px; opacity: 1; }
.help-footer {
  display: flex; align-items: center; gap: 20px;
  padding: 28px 0; border-top: 1px solid var(--edge); margin-top: 8px;
}
.help-footer-text {
  font-family: 'Cormorant Garamond', serif; font-size: 1.05rem;
  font-style: italic; color: var(--text-2);
}

/* ── Help right panel ── */
.help-right { position: sticky; top: 72px; background: var(--surface-2); border: 1px solid var(--edge); border-radius: 12px; overflow: hidden; }
.hrp-panel { display: none; padding: 28px; }
.hrp-panel.active { display: block; animation: hrpFadeIn .3s var(--ease-premium) forwards; }
@keyframes hrpFadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.hrp-panel.hrp-leaving { display:block !important; animation:hrpFadeOut .18s var(--ease-premium) forwards; pointer-events:none; }
@keyframes hrpFadeOut { to { opacity:0; transform:translateY(-8px); } }

/* Default — Editorial */
.hrp-editorial { display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:324px; text-align:center; padding:20px 0; }
.hrp-ed-sigil { margin-bottom:22px; }
.hrp-ed-eyebrow { font-family:'Montserrat',sans-serif; font-size:.52rem; font-weight:700; letter-spacing:.28em; text-transform:uppercase; color:var(--text-3); margin-bottom:14px; }
.hrp-ed-headline { font-family:'Cormorant Garamond',serif; font-size:1.55rem; font-weight:300; color:var(--text); line-height:1.35; margin-bottom:28px; }
.hrp-ed-headline em { color:var(--gold); font-style:italic; }
.hrp-ed-cats { display:flex; flex-direction:column; gap:0; width:100%; }
.hrp-ed-cat {
  font-family:'Cormorant Garamond',serif; font-size:.95rem; font-style:italic;
  color:var(--text-2); padding:9px 0; border-top:1px solid var(--edge);
  background:none; border-left:none; border-right:none; border-bottom:none;
  text-align:left; cursor:pointer; width:100%;
  display:flex; align-items:center; justify-content:space-between;
  transition: color var(--t-fast) var(--ease);
}
.hrp-ed-cats .hrp-ed-cat:last-child { border-bottom:1px solid var(--edge); }
.hrp-ed-cat:hover { color:var(--text-1); }
.hrp-ed-cat-arrow {
  font-style:normal; font-size:.8rem; opacity:0;
  transform:translateX(-4px);
  transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.hrp-ed-cat:hover .hrp-ed-cat-arrow { opacity:1; transform:translateX(0); }

/* Shared panel elements */
.hrp-label { font-family:'Montserrat',sans-serif; font-size:.54rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--text-3); margin-bottom:18px; }
.hrp-note { font-family:'Cormorant Garamond',serif; font-size:.82rem; font-style:italic; color:var(--text-3); margin-top:16px; display:flex; align-items:center; gap:8px; }

/* PRO badge */
.faq-pro-badge { font-family:'Montserrat',sans-serif; font-size:.44rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); border:1px solid rgba(200,169,81,.4); padding:2px 6px; border-radius:3px; margin-left:6px; vertical-align:middle; flex-shrink:0; }

/* Pro comparison table */
.hrp-pro-table { width:100%; }
.hrp-pro-col-head { display:grid; grid-template-columns:1fr 44px 44px; gap:4px; margin-bottom:10px; padding-bottom:10px; border-bottom:1px solid var(--edge); }
.hrp-col-label { font-family:'Montserrat',sans-serif; font-size:.54rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--text-2); text-align:center; line-height:1.4; }
.hrp-col-label.hrp-col-pro { color:var(--gold); }
.hrp-col-price { font-family:'Cormorant Garamond',serif; font-size:.78rem; font-weight:400; letter-spacing:0; text-transform:none; color:var(--text-3); display:block; }
.hrp-pro-row { display:grid; grid-template-columns:1fr 44px 44px; align-items:center; gap:4px; padding:7px 0; border-bottom:1px solid rgba(255,255,255,.04); font-family:'Cormorant Garamond',serif; font-size:.88rem; color:var(--text-2); }
.hrp-pro-divider { margin-top:6px; border-top:1px solid var(--edge); padding-top:13px; }
.hrp-check { text-align:center; color:var(--text-3); }
.hrp-check.hrp-check-pro { color:var(--gold); }
.hrp-dash { text-align:center; color:var(--text-3); font-size:.8rem; }
.hrp-trial-note { font-family:'Cormorant Garamond',serif; font-size:.82rem; font-style:italic; color:var(--text-3); margin-top:14px; text-align:center; }

/* Practice steps */
.hrp-steps { display:flex; flex-direction:column; }
.hrp-step { display:flex; align-items:flex-start; gap:14px; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hrp-step:last-child { border-bottom:none; }
.hrp-step-num { font-family:'Montserrat',sans-serif; font-size:.58rem; font-weight:700; letter-spacing:.08em; color:var(--text-3); flex-shrink:0; min-width:22px; margin-top:2px; }
.hrp-step-name { font-family:'Cormorant Garamond',serif; font-size:1rem; font-weight:600; color:var(--text); margin-bottom:2px; }
.hrp-step-desc { font-family:'Cormorant Garamond',serif; font-size:.84rem; color:var(--text-2); }

/* Arc visual */
.hrp-arc-vis { margin:6px 0 18px; }
.hrp-arc-bar { height:6px; background:var(--surface-3); border-radius:3px; overflow:hidden; margin-bottom:8px; }
.hrp-arc-fill { height:100%; width:0; border-radius:3px; background:linear-gradient(90deg,var(--red),var(--gold)); }
.hrp-panel[data-panel="arc"].active .hrp-arc-fill { animation:arcBarFill .9s .15s var(--ease-premium) forwards; }
@keyframes arcBarFill { to { width:40%; } }
.hrp-arc-day-labels { display:flex; justify-content:space-between; font-family:'Montserrat',sans-serif; font-size:.52rem; font-weight:500; letter-spacing:.1em; color:var(--text-3); }
.hrp-arc-desc { font-family:'Cormorant Garamond',serif; font-size:.88rem; color:var(--text-2); line-height:1.65; margin-bottom:16px; }
.hrp-arc-tools { display:flex; flex-wrap:wrap; gap:6px; }
.hrp-arc-tool { font-family:'Montserrat',sans-serif; font-size:.5rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); border:1px solid var(--edge); border-radius:3px; padding:4px 10px; }

/* Time Capsule flow */
.hrp-capsule-flow { display:flex; flex-direction:column; }
.hrp-cf-step { display:flex; align-items:baseline; gap:12px; padding:10px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hrp-cf-step:last-child { border-bottom:none; }
.hrp-cf-num { font-family:'Montserrat',sans-serif; font-size:.56rem; font-weight:700; letter-spacing:.08em; color:var(--text-3); flex-shrink:0; min-width:22px; }
.hrp-cf-name { font-family:'Cormorant Garamond',serif; font-size:1rem; font-weight:600; color:var(--text); min-width:68px; }
.hrp-cf-info { font-family:'Cormorant Garamond',serif; font-size:.84rem; color:var(--text-2); }
.hrp-cf-step.hrp-cf-open .hrp-cf-name { color:var(--gold); }
.hrp-cf-arrow { font-size:.7rem; color:var(--text-3); padding-left:22px; }

/* Milestones */
.hrp-milestones { display:flex; flex-direction:column; }
.hrp-milestone { display:grid; grid-template-columns:52px 1fr; grid-template-rows:auto auto; gap:0 12px; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hrp-milestone:last-child { border-bottom:none; }
.hrp-ms-day { font-family:'Montserrat',sans-serif; font-size:.58rem; font-weight:700; letter-spacing:.06em; color:var(--gold); grid-row:1; padding-top:2px; }
.hrp-ms-name { font-family:'Cormorant Garamond',serif; font-size:.98rem; font-weight:600; color:var(--text); grid-column:2; grid-row:1; }
.hrp-ms-desc { font-family:'Cormorant Garamond',serif; font-size:.82rem; color:var(--text-2); grid-column:2; grid-row:2; }

/* Tracker heatmap */
.hrp-tracker-body { display:flex; gap:28px; align-items:center; }
.hrp-hm-col { flex:0 0 220px; }
.hrp-hm-stats { flex:1; display:flex; flex-direction:column; gap:24px; }
.hrp-hm-stat-num { font-family:'Cormorant Garamond',serif; font-size:2.8rem; font-weight:700; color:var(--gold-hi); line-height:1; }
.hrp-hm-stat-label { font-size:.52rem; letter-spacing:.28em; text-transform:uppercase; color:var(--text-3); margin-top:5px; }
.hrp-heatmap { display:grid; grid-template-columns:repeat(6,1fr); gap:5px; margin-bottom:14px; }
.hrp-hm-cell { aspect-ratio:1; border-radius:4px; background:var(--surface-3); }
.hrp-hm-cell.f { background:linear-gradient(135deg,var(--red),var(--gold)); opacity:.85; }
.hrp-hm-legend { display:flex; align-items:center; gap:10px; font-family:'Cormorant Garamond',serif; font-size:.82rem; color:var(--text-2); }
.hrp-hm-dot { width:10px; height:10px; border-radius:2px; background:var(--surface-3); flex-shrink:0; }
.hrp-hm-dot.f { background:linear-gradient(135deg,var(--red),var(--gold)); }

/* Chapters */
.hrp-chapters { display:flex; flex-direction:column; }
.hrp-chapter { display:flex; align-items:center; gap:10px; padding:10px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hrp-chapter:last-child { border-bottom:none; }
.hrp-ch-num { font-family:'Montserrat',sans-serif; font-size:.52rem; font-weight:700; letter-spacing:.08em; color:var(--text-3); flex-shrink:0; min-width:28px; }
.hrp-ch-title { font-family:'Cormorant Garamond',serif; font-size:.9rem; color:var(--text-2); flex:1; }
.hrp-chapter.hrp-ch-open .hrp-ch-title { color:var(--text); }
.hrp-ch-tag { font-family:'Montserrat',sans-serif; font-size:.46rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--gold); flex-shrink:0; }
.hrp-ch-tag.hrp-ch-lock { color:var(--text-3); }

/* Focus Mode key */
.hrp-focus-wrap { display:flex; flex-direction:column; gap:14px; }
.hrp-key-wrap { display:flex; justify-content:center; padding:18px 0 6px; }
.hrp-key { width:64px; height:64px; border:1.5px solid var(--edge); border-radius:12px; display:flex; align-items:center; justify-content:center; font-family:'Montserrat',sans-serif; font-size:1.6rem; font-weight:600; color:var(--text); box-shadow:0 5px 0 var(--edge); background:var(--surface-3); }
.hrp-focus-or { font-family:'Cormorant Garamond',serif; font-size:.88rem; color:var(--text-2); text-align:center; font-style:italic; }
.hrp-focus-desc { font-family:'Cormorant Garamond',serif; font-size:.9rem; color:var(--text-2); line-height:1.65; text-align:center; }

/* Light mode overrides */
body.light-mode .help-right { background:#f5f2ee; border-color:rgba(0,0,0,.1); }
body.light-mode .hrp-pro-row { border-color:rgba(0,0,0,.06); }
body.light-mode .hrp-pro-divider { border-color:rgba(0,0,0,.1); }
body.light-mode .hrp-pro-col-head { border-color:rgba(0,0,0,.1); }
body.light-mode .hrp-step { border-color:rgba(0,0,0,.06); }
body.light-mode .hrp-cf-step { border-color:rgba(0,0,0,.06); }
body.light-mode .hrp-milestone { border-color:rgba(0,0,0,.06); }
body.light-mode .hrp-chapter { border-color:rgba(0,0,0,.06); }
body.light-mode .hrp-hm-cell { background:rgba(0,0,0,.09); }
body.light-mode .hrp-hm-dot { background:rgba(0,0,0,.09); }
body.light-mode .hrp-key { background:#ede8e2; border-color:rgba(0,0,0,.15); box-shadow:0 5px 0 rgba(0,0,0,.15); }
body.light-mode .hrp-arc-bar { background:rgba(0,0,0,.1); }
body.light-mode .hrp-arc-tool { border-color:rgba(0,0,0,.12); }
body.light-mode .faq-pro-badge { border-color:rgba(200,169,81,.5); }

/* ── Animations on panel activation ── */
.hrp-panel[data-panel="focus"].active .hrp-key { animation:keyPress .5s .2s var(--ease-premium) both; }
@keyframes keyPress { 0%,100% { transform:translateY(0); box-shadow:0 5px 0 var(--edge); } 45% { transform:translateY(4px); box-shadow:0 1px 0 var(--edge); } }

.hrp-panel[data-panel="milestones"].active .hrp-milestone { animation:hrpFadeIn .3s var(--ease-premium) both; }
.hrp-panel[data-panel="milestones"].active .hrp-milestone:nth-child(1) { animation-delay:.06s; }
.hrp-panel[data-panel="milestones"].active .hrp-milestone:nth-child(2) { animation-delay:.13s; }
.hrp-panel[data-panel="milestones"].active .hrp-milestone:nth-child(3) { animation-delay:.20s; }
.hrp-panel[data-panel="milestones"].active .hrp-milestone:nth-child(4) { animation-delay:.27s; }

.hrp-panel[data-panel="practice"].active .hrp-step { animation:hrpFadeIn .3s var(--ease-premium) both; }
.hrp-panel[data-panel="practice"].active .hrp-step:nth-child(1) { animation-delay:.06s; }
.hrp-panel[data-panel="practice"].active .hrp-step:nth-child(2) { animation-delay:.13s; }
.hrp-panel[data-panel="practice"].active .hrp-step:nth-child(3) { animation-delay:.20s; }
.hrp-panel[data-panel="practice"].active .hrp-step:nth-child(4) { animation-delay:.27s; }

.hrp-panel[data-panel="capsule"].active .hrp-cf-step { animation:hrpFadeIn .3s var(--ease-premium) both; }
.hrp-panel[data-panel="capsule"].active .hrp-cf-step:nth-child(1) { animation-delay:.06s; }
.hrp-panel[data-panel="capsule"].active .hrp-cf-step:nth-child(3) { animation-delay:.13s; }
.hrp-panel[data-panel="capsule"].active .hrp-cf-step:nth-child(5) { animation-delay:.20s; }
.hrp-panel[data-panel="capsule"].active .hrp-cf-step:nth-child(7) { animation-delay:.27s; }

.hrp-panel[data-panel="guide"].active .hrp-chapter { animation:hrpFadeIn .25s var(--ease-premium) both; }
.hrp-panel[data-panel="guide"].active .hrp-chapter:nth-child(1) { animation-delay:.04s; }
.hrp-panel[data-panel="guide"].active .hrp-chapter:nth-child(2) { animation-delay:.09s; }
.hrp-panel[data-panel="guide"].active .hrp-chapter:nth-child(3) { animation-delay:.14s; }
.hrp-panel[data-panel="guide"].active .hrp-chapter:nth-child(4) { animation-delay:.19s; }
.hrp-panel[data-panel="guide"].active .hrp-chapter:nth-child(5) { animation-delay:.24s; }
.hrp-panel[data-panel="guide"].active .hrp-chapter:nth-child(6) { animation-delay:.29s; }

.hrp-panel[data-panel="portal"].active .hrp-pm-item { animation:hrpFadeIn .25s var(--ease-premium) both; }

/* ── Portal map ── */
.hrp-portal-map { display:flex; flex-direction:column; gap:14px; }
.hrp-pm-group-label { font-family:'Montserrat',sans-serif; font-size:.5rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--text-3); margin-bottom:6px; }
.hrp-pm-item { font-family:'Cormorant Garamond',serif; font-size:.92rem; color:var(--text-2); padding:4px 0 4px 12px; border-left:1px solid var(--edge); margin-bottom:2px; transition:color .2s, border-color .2s; }
.hrp-pm-item:hover { color:var(--text); border-color:var(--gold); }

/* ── Intention (step 1 highlighted) ── */
.hrp-intention { display:flex; flex-direction:column; }
.hrp-int-step { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hrp-int-step:last-child { border-bottom:none; }
.hrp-int-num { font-family:'Montserrat',sans-serif; font-size:.56rem; font-weight:700; letter-spacing:.08em; color:var(--text-3); flex-shrink:0; min-width:22px; }
.hrp-int-body { display:flex; flex-direction:column; gap:2px; }
.hrp-int-name { font-family:'Cormorant Garamond',serif; font-size:1rem; font-weight:600; }
.hrp-int-step.hrp-int-dim .hrp-int-name { color:var(--text-3); }
.hrp-int-step.hrp-int-dim .hrp-int-num { opacity:.35; }
.hrp-int-step.hrp-int-active .hrp-int-name { color:var(--gold); }
.hrp-int-tag { font-family:'Montserrat',sans-serif; font-size:.5rem; letter-spacing:.08em; color:var(--gold); opacity:.75; }

/* ── Independence (always accessible) ── */
.hrp-ind-list { display:flex; flex-direction:column; }
.hrp-ind-item { display:flex; align-items:center; gap:12px; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hrp-ind-item:last-child { border-bottom:none; }
.hrp-ind-dot { width:7px; height:7px; border-radius:50%; background:var(--gold); flex-shrink:0; opacity:.65; }
.hrp-ind-name { font-family:'Cormorant Garamond',serif; font-size:1rem; font-weight:600; color:var(--text); flex:1; }
.hrp-ind-status { font-family:'Montserrat',sans-serif; font-size:.5rem; font-weight:500; letter-spacing:.08em; text-transform:uppercase; color:var(--text-3); }

/* ── Missed a day ── */
.hrp-missed { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:4px; }
.hrp-missed-card { padding:16px 12px; border:1px solid var(--edge); border-radius:8px; text-align:center; }
.hrp-mc-reset { border-color:rgba(200,16,46,.25); }
.hrp-mc-safe { border-color:rgba(200,169,81,.3); }
.hrp-mc-thing { font-family:'Montserrat',sans-serif; font-size:.5rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--text-3); margin-bottom:8px; }
.hrp-mc-result { font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:600; margin-bottom:4px; }
.hrp-mc-reset .hrp-mc-result { color:var(--red); }
.hrp-mc-safe .hrp-mc-result { color:var(--gold); }
.hrp-mc-sub { font-family:'Cormorant Garamond',serif; font-size:.8rem; color:var(--text-3); }

/* ── Avatar / profile photo ── */
.hrp-avatar-vis { display:flex; flex-direction:column; align-items:center; gap:20px; padding:20px 0; }
.hrp-av-outer { position:relative; }
.hrp-av-circle { width:72px; height:72px; border-radius:50%; background:var(--surface-3); border:1px solid var(--edge); display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:600; color:var(--text-2); }
.hrp-av-badge { position:absolute; bottom:2px; right:2px; width:22px; height:22px; border-radius:50%; background:var(--red); color:#fff; font-family:'Montserrat',sans-serif; font-size:.75rem; font-weight:700; display:flex; align-items:center; justify-content:center; animation:avPulse 2s .5s var(--ease-premium) infinite; }
@keyframes avPulse { 0%,100% { transform:scale(1); } 50% { transform:scale(1.2); } }
.hrp-av-text { font-family:'Cormorant Garamond',serif; font-size:.88rem; color:var(--text-2); text-align:center; line-height:1.65; }

/* ── Theme toggle visual ── */
.hrp-theme-vis { display:flex; align-items:center; justify-content:center; gap:14px; padding:18px 0; }
.hrp-theme-side { display:flex; flex-direction:column; align-items:center; gap:8px; }
.hrp-ts-preview { width:80px; height:52px; background:#111; border-radius:6px; border:1px solid var(--edge); padding:7px; display:flex; flex-direction:column; gap:5px; }
.hrp-ts-preview-light { background:#ede8e0; border-color:rgba(0,0,0,.1); }
.hrp-ts-bar { height:7px; background:rgba(255,255,255,.1); border-radius:2px; }
.hrp-ts-bar-light { background:rgba(0,0,0,.1); }
.hrp-ts-line { height:4px; background:rgba(255,255,255,.06); border-radius:2px; }
.hrp-ts-line-light { background:rgba(0,0,0,.07); }
.hrp-ts-short { width:55%; }
.hrp-ts-label { font-family:'Montserrat',sans-serif; font-size:.52rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--text-3); }
.hrp-theme-arrow { font-size:1rem; color:var(--gold); opacity:.5; }

/* ── Privacy ── */
.hrp-privacy { display:flex; flex-direction:column; align-items:center; gap:16px; text-align:center; padding:8px 0; }
.hrp-prv-lock { color:var(--gold); opacity:.6; }
.hrp-prv-items { display:flex; flex-direction:column; gap:7px; width:100%; text-align:left; }
.hrp-prv-item { font-family:'Cormorant Garamond',serif; font-size:.92rem; color:var(--text-2); display:flex; align-items:center; gap:10px; }
.hrp-prv-dot { width:5px; height:5px; border-radius:50%; background:var(--gold); flex-shrink:0; opacity:.55; }
.hrp-prv-tagline { font-family:'Cormorant Garamond',serif; font-size:.88rem; font-style:italic; color:var(--text-3); }

/* ── Billing ── */
.hrp-billing { display:flex; flex-direction:column; }
.hrp-bill-row { display:flex; justify-content:space-between; align-items:baseline; gap:12px; padding:10px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hrp-bill-row:last-child { border-bottom:none; }
.hrp-bill-key { font-family:'Montserrat',sans-serif; font-size:.5rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); flex-shrink:0; }
.hrp-bill-val { font-family:'Cormorant Garamond',serif; font-size:.9rem; color:var(--text-2); text-align:right; }

/* ── Payment ── */
.hrp-payment-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:4px; }
.hrp-pay-card { border:1px solid var(--edge); border-radius:6px; padding:11px 6px; text-align:center; font-family:'Montserrat',sans-serif; font-size:.54rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--text-2); }

/* ── Devices ── */
.hrp-devices { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
.hrp-dev { display:flex; flex-direction:column; align-items:center; gap:8px; text-align:center; }
.hrp-dev-icon { height:52px; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; }
.hrp-dev-screen { width:52px; height:34px; border:1.5px solid var(--edge); border-radius:3px; background:var(--surface-3); }
.hrp-dev-stand { width:14px; height:6px; background:var(--edge); margin:0 auto; }
.hrp-dev-base { width:26px; height:2px; background:var(--edge); margin:0 auto; border-radius:1px; }
.hrp-dev-phone { width:26px; height:42px; border:1.5px solid var(--edge); border-radius:6px; background:var(--surface-3); display:flex; align-items:center; justify-content:center; }
.hrp-dev-phone-screen { width:17px; height:28px; border-radius:2px; background:var(--surface-2); }
.hrp-dev-name { font-family:'Cormorant Garamond',serif; font-size:.98rem; font-weight:600; color:var(--text); }
.hrp-dev-note { font-family:'Cormorant Garamond',serif; font-size:.78rem; color:var(--text-3); }
.hrp-browsers-row { display:flex; flex-wrap:wrap; gap:6px; justify-content:center; }
.hrp-browser { font-family:'Montserrat',sans-serif; font-size:.5rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); border:1px solid var(--edge); border-radius:3px; padding:4px 8px; }

/* Light mode overrides for new panels */
body.light-mode .hrp-missed-card { background:rgba(0,0,0,.03); }
body.light-mode .hrp-pay-card { background:rgba(0,0,0,.03); }
body.light-mode .hrp-pm-item { border-color:rgba(0,0,0,.1); color:rgba(24,21,15,.6); }
body.light-mode .hrp-ind-item { border-color:rgba(0,0,0,.06); }
body.light-mode .hrp-int-step { border-color:rgba(0,0,0,.06); }
body.light-mode .hrp-bill-row { border-color:rgba(0,0,0,.06); }
body.light-mode .hrp-dev-screen { background:#e0dbd4; }
body.light-mode .hrp-dev-phone { background:#e0dbd4; }
body.light-mode .hrp-dev-phone-screen { background:#f0ede8; }

/* ══════════════════════════════════════════════════════
   CONTACT VIEW
══════════════════════════════════════════════════════ */
.contact-layout {
  display: grid; grid-template-columns: 1fr 280px; gap: 48px;
  padding: 0 48px 80px; align-items: start;
}
.contact-form-wrap { min-width: 0; }
.contact-aside { min-width: 0; }
.cf-reply-to {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 24px; padding: 10px 14px;
  background: rgba(255,255,255,.03); border: 1px solid var(--edge);
  border-radius: var(--r-sm);
}
.cf-reply-label {
  font-family: 'Montserrat', sans-serif; font-size: .58rem;
  font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text-3); flex-shrink: 0;
}
.cf-reply-email {
  font-size: .85rem; color: var(--gold); font-family: 'Montserrat', sans-serif;
}
.cf-field { margin-bottom: 24px; }
.cf-label {
  display: block; font-family: 'Montserrat', sans-serif;
  font-size: .58rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 8px;
}
.cf-select, .cf-textarea {
  width: 100%; background: var(--surface);
  border: 1px solid var(--edge); border-radius: var(--r);
  padding: 14px 16px; font-family: 'Cormorant Garamond', serif;
  font-size: 1.02rem; color: var(--text); outline: none;
  transition: border-color var(--t-fast) var(--ease);
  appearance: none;
}
.cf-select:focus, .cf-textarea:focus { border-color: rgba(200,169,81,.35); }
.cf-textarea { resize: none; line-height: 1.7; }
.cf-textarea::placeholder { color: var(--text-3); }
.cf-footer {
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  padding-top: 4px;
}
.cf-response-note {
  display: flex; align-items: center; gap: 7px;
  font-family: 'Montserrat', sans-serif; font-size: .58rem; letter-spacing: .08em;
  color: var(--text-3);
}
.cf-submit {
  font-family: 'Montserrat', sans-serif; font-size: .56rem; font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--text); background: none;
  border: 1px solid var(--edge-hi); border-radius: var(--r);
  padding: 12px 28px; cursor: pointer; white-space: nowrap;
  transition: all var(--t-fast) var(--ease);
}
.cf-submit:hover { border-color: var(--gold); color: var(--gold); }
.cf-submit.sent { border-color: rgba(200,169,81,.4); color: var(--gold); cursor: default; }

.contact-method { margin-bottom: 14px; }
.cm-label {
  font-family: 'Montserrat', sans-serif; font-size: .58rem; letter-spacing: .16em;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 3px;
}
.cm-value { font-size: .92rem; color: var(--text-2); }
.cm-email-link { color: var(--text-2); text-decoration: underline; text-underline-offset: 3px; }
.cm-email-link:hover { color: var(--text-1); }

/* ══════════════════════════════════════════════════════
   SIGN OUT CONFIRMATION
══════════════════════════════════════════════════════ */
.signout-confirm {
  position: fixed; inset: 0; z-index: 600;
  display: flex; align-items: center; justify-content: center;
  background: rgba(5,5,5,.7); backdrop-filter: blur(12px);
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-mid) var(--ease);
}
.signout-confirm.active { opacity: 1; pointer-events: all; }
body.light-mode .signout-confirm { background: rgba(20,16,12,.72); backdrop-filter: blur(20px) saturate(.5); }
.signout-inner {
  background: var(--surface);
  border: 1px solid var(--edge-hi);
  border-radius: var(--r-lg);
  padding: 36px 40px;
  text-align: center;
  box-shadow: 0 24px 64px rgba(0,0,0,.45);
  animation: focus-in var(--t-mid) var(--ease) both;
}
body.light-mode .signout-inner { box-shadow: 0 24px 64px rgba(0,0,0,.14); }
.signout-msg {
  font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 700;
  color: var(--text); margin-bottom: 6px;
}
.signout-sub {
  font-family: 'Montserrat', sans-serif; font-size: .60rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 28px;
}
.signout-actions { display: flex; gap: 12px; justify-content: center; }
.signout-cancel {
  font-family: 'Montserrat', sans-serif; font-size: .58rem; font-weight: 600;
  letter-spacing: .16em; text-transform: uppercase;
  padding: 11px 28px; border-radius: var(--r);
  background: none; border: 1px solid var(--edge); color: var(--text-2);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
}
.signout-cancel:hover { border-color: var(--edge-hi); color: var(--text); }
.signout-yes {
  font-family: 'Montserrat', sans-serif; font-size: .58rem; font-weight: 600;
  letter-spacing: .16em; text-transform: uppercase;
  padding: 11px 28px; border-radius: var(--r);
  background: rgba(200,16,46,.1); border: 1px solid rgba(200,16,46,.3); color: var(--crimson);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
}
.signout-yes:hover { background: rgba(200,16,46,.18); border-color: rgba(200,16,46,.5); }

/* Contact sent state */
.contact-sent {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 60px 40px; text-align: center;
}
.contact-sent-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(200,169,81,.1); border: 1.5px solid rgba(200,169,81,.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; color: var(--gold); margin-bottom: 20px;
}
.contact-sent-title {
  font-family: 'Playfair Display', serif; font-size: 1.4rem; font-weight: 700;
  color: var(--text); margin-bottom: 8px;
}
.contact-sent-sub {
  font-family: 'Montserrat', sans-serif; font-size: .60rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--text-3); line-height: 1.7;
}

/* ══════════════════════════════════════════════════════
   LIGHT MODE — GUIDE / HELP / CONTACT / SIGN OUT
══════════════════════════════════════════════════════ */

/* Guide view */
body.light-mode .guide-chapter-pills { border-bottom-color: rgba(0,0,0,.09); }
body.light-mode .gcp { background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1); color: rgba(24,21,15,.55); }
body.light-mode .gcp:hover:not(.gcp-locked) { border-color: rgba(200,169,81,.5); color: var(--text); }
body.light-mode .gcp-active { background: rgba(200,169,81,.12); border-color: rgba(200,169,81,.4); color: var(--text); }
body.light-mode .gcp-done { background: rgba(200,169,81,.07); }
body.light-mode .gcp-locked { color: rgba(24,21,15,.28); border-color: rgba(0,0,0,.07); }
body.light-mode .guide-reading {
  background: rgba(255,255,255,.45);
  border-color: rgba(0,0,0,.07);
  box-shadow: 0 2px 16px rgba(0,0,0,.05);
}
body.light-mode .gr-divider { background: rgba(0,0,0,.1); }
body.light-mode .gr-prompt { background: rgba(200,169,81,.07); border-color: rgba(200,169,81,.2); }
body.light-mode .guide-prog-wrap { background: transparent; }
body.light-mode .guide-ch-list { border-left-color: rgba(0,0,0,.09); }
body.light-mode .gch { color: rgba(24,21,15,.5); }
body.light-mode .gch:hover:not(.gch-locked) { color: var(--text); background: rgba(0,0,0,.04); }
body.light-mode .gch-active { color: var(--text); background: rgba(200,169,81,.08); }
body.light-mode .gch-locked { color: rgba(24,21,15,.25); }

/* Help center */
body.light-mode .faq-category { border-color: rgba(0,0,0,.09); }
body.light-mode .faq-cat-label { color: rgba(24,21,15,.38); }
body.light-mode .vh-eyebrow { color: rgba(24,21,15,.42); }
body.light-mode .vh-eyebrow::before { background: rgba(24,21,15,.42); }
body.light-mode .faq-item { border-bottom-color: rgba(0,0,0,.07); }
body.light-mode .faq-q { color: rgba(24,21,15,.75); }
body.light-mode .faq-q:hover { color: var(--text); background: rgba(0,0,0,.03); }
body.light-mode .faq-q.open { color: var(--text); }
body.light-mode .faq-chevron { color: rgba(24,21,15,.4); }
body.light-mode .faq-a { color: rgba(24,21,15,.62); }
body.light-mode .help-footer { border-top-color: rgba(0,0,0,.09); }

/* Contact */
body.light-mode .cf-select,
body.light-mode .cf-textarea { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.12); color: var(--text); }
body.light-mode .cf-select:focus,
body.light-mode .cf-textarea:focus { border-color: rgba(200,169,81,.4); background: rgba(0,0,0,.02); }
body.light-mode .cf-textarea::placeholder { color: rgba(24,21,15,.35); }
body.light-mode .cf-submit { color: var(--text); border-color: rgba(0,0,0,.2); }
body.light-mode .cf-submit:hover { border-color: rgba(200,169,81,.55); color: #7a6423; }
body.light-mode .contact-sent-icon { background: rgba(200,169,81,.08); }

/* Sign out modal */
body.light-mode .signout-inner { background: rgba(224,217,204,.98); border-color: rgba(0,0,0,.12); }

/* ══════════════════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════════════════ */
/* anim-1 through anim-5 defined below at line ~4215 — single canonical definition */

/* ══════════════════════════════════════════════════════
   CARD STANDARD SYSTEM
   Each tier earns its effects based on what the card IS.
══════════════════════════════════════════════════════ */

/* ── Shared scanline mixin ── */
.card::after, .habit-card::after, .today-checklist-card::after,
.mood-corr::after, .ms-card::after,
.intention-card::after, .sw-prompt-card::after, .letter-card::after,
.re-card::after, .past-entry::after,
.rhy-card.open::after {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  pointer-events: none; z-index: 1;
  background: repeating-linear-gradient(0deg, transparent 0px, transparent 3px, rgba(255,255,255,.009) 3px, rgba(255,255,255,.009) 4px);
}

/* ── Tier 1 — Primary content surfaces ── */
.card, .habit-card, .today-checklist-card, .mood-corr, .ms-card {
  box-shadow: 0 1px 0 rgba(255,255,255,.04) inset, 0 24px 48px rgba(0,0,0,.28);
  position: relative; overflow: hidden;
}

/* ── Tier 2 — Editorial surfaces (gold border/accent already on each) ── */
.intention-card, .sw-prompt-card, .letter-card, .re-card, .past-entry {
  box-shadow: 0 1px 0 rgba(255,255,255,.04) inset, 0 24px 48px rgba(0,0,0,.28);
  position: relative; overflow: hidden;
}
/* capsule-panel has its own diagonal texture — shadow only, no scanline */
.capsule-panel {
  box-shadow: 0 1px 0 rgba(255,255,255,.04) inset, 0 24px 48px rgba(0,0,0,.28);
}

/* ── Tier 3 — Action surfaces (shadow + lift already present) ── */
.pstep, .mood-card {
  box-shadow: 0 2px 12px rgba(0,0,0,.22);
}

/* ── Tier 4 — List tiles ── */
.entry-card, .guide-card, .pl-card,
.rhy-snap-tile, .rhy-connect-card {
  box-shadow: 0 1px 0 rgba(255,255,255,.02) inset, 0 4px 16px rgba(0,0,0,.18);
  position: relative;
}

/* ── Expandable cards — T3 closed, T1 open ── */
.rhy-card {
  box-shadow: 0 2px 12px rgba(0,0,0,.22);
  position: relative; overflow: hidden;
}
.rhy-card.open {
  box-shadow: 0 1px 0 rgba(255,255,255,.04) inset, 0 24px 48px rgba(0,0,0,.28);
}

/* ── Light mode shadow adjustments ── */
body.light-mode .card, body.light-mode .habit-card,
body.light-mode .today-checklist-card, body.light-mode .mood-corr,
body.light-mode .ms-card, body.light-mode .intention-card,
body.light-mode .sw-prompt-card, body.light-mode .letter-card,
body.light-mode .re-card, body.light-mode .past-entry,
body.light-mode .capsule-panel, body.light-mode .rhy-card.open {
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset, 0 4px 24px rgba(0,0,0,.08);
}
body.light-mode .pstep, body.light-mode .mood-card {
  box-shadow: 0 2px 8px rgba(0,0,0,.1);
}
body.light-mode .entry-card, body.light-mode .guide-card,
body.light-mode .pl-card, body.light-mode .rhy-snap-tile,
body.light-mode .wr-q-card, body.light-mode .rhy-connect-card,
body.light-mode .rhy-card {
  box-shadow: 0 1px 0 rgba(255,255,255,.6) inset, 0 2px 8px rgba(0,0,0,.06);
}

/* ╔══════════════════════════════════════════════════════════════════
   ║  CINEMATIC OVERRIDES
   ║  Applied on top of portal-unified styles.
   ║  Touches: tokens, atmosphere, motion, type, texture, depth.
   ╚══════════════════════════════════════════════════════════════════ */

/* ── 1. Deeper, warmer blacks ────────────────────────────────────── */
:root {
  --bg:        #060504;
  --surface:   #0c0a08;
  --surface-2: #121009;
  --edge:      rgba(255,255,255,.065);
  --edge-hi:   rgba(255,255,255,.12);
  /* Slightly warmer text to match warmer bg */
  --text:   #f4ede0;
  --text-2: rgba(244,237,224,.54);
  --text-3: rgba(244,237,224,.22);
  /* Richer, two-temperature gold */
  --gold:     #c9aa52;
  --gold-hi:  #e2c06a;
  --gold-dim: rgba(201,170,82,.24);
  --gold-glow: rgba(201,170,82,.09);
  /* Deeper crimson for ambient use */
  --crimson:     #c4102b;
  --crimson-dim: rgba(196,16,43,.15);
  /* Cinematic motion — slower, more deliberate */
  --t-fast: 220ms;
  --t-mid:  480ms;
  --t-slow: 780ms;
  /* ── Section aliases (used by settings, practice, journey, pieces) ── */
  --bg-1:   #0c0a08;
  --bg-2:   #121009;
  --border: rgba(255,255,255,.09);
  --radius: 12px;
  --text-1: #f4ede0;
}
html { background: #060504; }

/* ── 2. Vignette — projector-cone atmosphere ─────────────────────── */
body::after {
  content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(ellipse 85% 75% at 52% 38%,
    transparent 18%,
    rgba(0,0,0,.28) 55%,
    rgba(0,0,0,.62) 100%
  );
}

/* ── 3. Topbar — gradient bleed into content below ───────────────── */
.topbar { position: relative; }
.topbar::after {
  content: ''; position: absolute; left: 0; right: 0; top: 100%;
  height: 56px; pointer-events: none; z-index: 10;
  background: linear-gradient(to bottom, rgba(6,5,4,.72), transparent);
}

/* ── 4. Grain — slightly more pronounced ────────────────────────── */
.grain { opacity: .048; }

/* ── 5. Sidebar — slightly richer dark ──────────────────────────── */
.sidebar { background: rgba(8,6,5,.98); }

/* ── 6. Cards — inset top-edge highlight (surface catch light) ───── */
.rp-card,
.card,
.habit-card,
.arc-prompt,
.intention-card,
.letter-card,
.entry-card,
.re-card {
  box-shadow:
    0 1px 0 rgba(255,255,255,.04) inset,
    0 24px 48px rgba(0,0,0,.28);
}
/* Tighter scanline texture on cards — like film grain on surfaces */
.rp-card::after,
.habit-card::after {
  content: ''; position: absolute; inset: 0;
  border-radius: inherit; pointer-events: none; z-index: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent 0px,
    transparent 3px,
    rgba(255,255,255,.009) 3px,
    rgba(255,255,255,.009) 4px
  );
}
.rp-card { position: relative; overflow: hidden; }
.habit-card { position: relative; overflow: hidden; }

/* ── 7. Gold — gradient treatment on key display elements ─────────── */
.arc-ring-num,
.vh-stat-num,
.hss-num {
  background: linear-gradient(160deg, var(--gold-hi) 0%, var(--gold) 55%, #a07820 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* Gold progress fills — warmer gradient */
.prog-fill {
  background: linear-gradient(90deg, rgba(201,170,82,.55) 0%, var(--gold-hi) 100%);
}
/* Gold accents on arc ring */
.arc-ring-fill {
  stroke: url(#arcRingGradCin);
  filter: drop-shadow(0 0 6px rgba(201,170,82,.35));
}

/* ── 8. Arc ring — glow + richer gradient ────────────────────────── */
.arc-ring-svg-wrap svg {
  overflow: visible;
}
.arc-ring-track { stroke: rgba(255,255,255,.055); }
.arc-ring-fill  {
  stroke: url(#arcRingGrad);
  /* Glow: outer shadow on the SVG wrapper, not on fill (avoids filter lag) */
}
.arc-ring-svg-wrap {
  filter: drop-shadow(0 0 16px rgba(201,170,82,.14))
          drop-shadow(0 0 40px rgba(196,16,43,.07));
}

/* ── 10. Typography — wider labels, richer hierarchy ─────────────── */
.rp-label {
  letter-spacing: var(--track-xl);
  color: rgba(244,237,224,.22);
}
body.light-mode .rp-label { color: rgba(24,21,15,.4); }
.vh-eyebrow {
  letter-spacing: var(--track-2xl);
  font-size: .54rem;
  color: var(--text-3);
}
/* Slightly looser on stat labels */
.hss-lbl,
.vh-stat-lbl,
.rp-label {
  letter-spacing: var(--track-lg);
}
/* Arc ring number — larger and more dramatic */
.arc-ring-num {
  font-size: 3.2rem;
  font-weight: 900;
  line-height: 1;
}
.arc-ring-of-30 { letter-spacing: .18em; font-size: .56rem; margin-top: 2px; }
/* Larger stat strip numbers */
.hss-num { font-size: 1.9rem; }
/* View title — more dramatic italic weight */
.vh-title em { font-style: italic; }
/* Topbar greeting — slightly larger */
.tb-greeting { font-size: 1.06rem; }

/* ── 11. Cinematic reveals — slower drift, wider stagger ─────────── */
@keyframes fade-up-in {
  from { opacity: 0; transform: translateY(7px); }
  to   { opacity: 1; transform: translateY(0); }
}
.anim-1 { animation: fade-up-in var(--t-slow) var(--ease) 80ms  both; }
.anim-2 { animation: fade-up-in var(--t-slow) var(--ease) 200ms both; }
.anim-3 { animation: fade-up-in var(--t-slow) var(--ease) 330ms both; }
.anim-4 { animation: fade-up-in var(--t-slow) var(--ease) 460ms both; }
.anim-5 { animation: fade-up-in var(--t-slow) var(--ease) 590ms both; }

/* ── 12. View transitions — dissolve in, not snap ─────────────────── */
.view { animation: view-dissolve 520ms cubic-bezier(0.16,1,0.3,1) both; }
@keyframes view-dissolve {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── 13. Stats strip — dividers feel more engraved ───────────────── */
.hss-cell + .hss-cell { border-left-color: rgba(255,255,255,.045); }
.home-stats-strip      { border-bottom-color: rgba(255,255,255,.045); }

/* ── 14. Arc prompt — more atmospheric border ────────────────────── */
.arc-prompt {
  border-color: rgba(201,170,82,.18);
  background: linear-gradient(155deg, rgba(196,16,43,.055), rgba(201,170,82,.035));
}
.arc-prompt::before {
  background: linear-gradient(to bottom, var(--crimson), var(--gold-hi));
}

/* ── 15. Practice CTA button — richer glow on hover ──────────────── */
.practice-cta {
  background: linear-gradient(135deg, rgba(196,16,43,.28) 0%, rgba(201,170,82,.12) 100%);
  border-color: rgba(196,16,43,.35);
}
.practice-cta:hover {
  background: linear-gradient(135deg, rgba(196,16,43,.38) 0%, rgba(201,170,82,.18) 100%);
  box-shadow: 0 0 32px rgba(196,16,43,.18), 0 8px 32px rgba(0,0,0,.4);
}

/* ── 16. Focus overlay — deeper cinematic backdrop ───────────────── */
.focus-overlay {
  background: rgba(3,2,2,.82);
  backdrop-filter: blur(28px) saturate(0.7);
}
.focus-panel {
  box-shadow:
    0 0 0 1px rgba(255,255,255,.07),
    0 32px 80px rgba(0,0,0,.65),
    0 0 60px rgba(201,170,82,.04);
}

/* ── 17. Sidebar active item — left accent only, no outward glow bleed ── */
.sb-item.active {
  background: linear-gradient(90deg, rgba(196,16,43,.18), rgba(196,16,43,.06));
  border-color: rgba(196,16,43,.35);
  box-shadow: inset 3px 0 0 rgba(196,16,43,.7);
}

/* ── 18. Topbar account actions panel — deeper glass ─────────────── */
.tb-account-actions {
  background: rgba(10,8,6,.97);
  box-shadow: 0 8px 40px rgba(0,0,0,.7);
  backdrop-filter: blur(20px);
}

/* ── 19. Signout confirm — more dramatic backdrop ─────────────────── */
.signout-confirm { background: rgba(2,2,2,.78); backdrop-filter: blur(24px) saturate(0.6); }
.signout-inner   { box-shadow: 0 32px 80px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.07); }

/* ── 20. Milestone cards — earned state warmer glow ──────────────── */
.ms-card.earned {
  border-color: rgba(201,170,82,.25);
  box-shadow: 0 0 28px rgba(201,170,82,.07), 0 1px 0 rgba(255,255,255,.04) inset;
}
.ms-card.imminent {
  border-color: rgba(196,16,43,.3);
  box-shadow: 0 0 28px rgba(196,16,43,.08), 0 1px 0 rgba(255,255,255,.04) inset;
}

/* ── 21. Guide reading area — paper-like warmth ──────────────────── */
.guide-reading {
  background: rgba(201,170,82,.025);
  border-color: rgba(201,170,82,.1);
  box-shadow: 0 1px 0 rgba(255,255,255,.035) inset, 0 24px 48px rgba(0,0,0,.22);
}

/* ── 22. Scroll hint arrows — more delicate ──────────────────────── */
.col-scroll-hint { color: rgba(244,237,224,.12); }

/* ── 23. Habit grid cells — richer done state ─────────────────────── */
.hg-cell.done { background: rgba(201,170,82,.3); box-shadow: 0 0 6px rgba(201,170,82,.15); }
.hg-cell.today { box-shadow: 0 0 0 1.5px var(--gold-hi), 0 0 10px rgba(201,170,82,.2); }

/* ── CINEMATIC LIGHT MODE — warm parchment + same depth ────────────── */
body.light-mode {
  --gold-hi: #c09535;
}
body.light-mode::after {
  background: radial-gradient(ellipse 85% 75% at 52% 38%,
    transparent 18%,
    rgba(0,0,0,.06) 55%,
    rgba(0,0,0,.16) 100%
  );
}
body.light-mode .topbar::after {
  background: linear-gradient(to bottom, rgba(224,217,204,.65), transparent);
}
body.light-mode .arc-ring-num,
body.light-mode .vh-stat-num,
body.light-mode .hss-num {
  background: linear-gradient(160deg, #b8890a 0%, #8a6315 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
body.light-mode .practice-cta {
  background: linear-gradient(135deg, rgba(196,16,43,.14) 0%, rgba(201,170,82,.08) 100%);
}
body.light-mode .rp-card,
body.light-mode .card,
body.light-mode .ti-card {
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset, 0 4px 24px rgba(0,0,0,.08);
}

/* ═══════════════════════════════════════════════════════════════
   MY PRACTICE — stats strip
═══════════════════════════════════════════════════════════════ */
.mp-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 28px;
}
@media (max-width: 700px) { .mp-stats { grid-template-columns: repeat(2,1fr); } }
.mps-stat {
  background: var(--surface);
  border: 1px solid var(--edge);
  border-top-color: var(--edge-hi);
  border-radius: var(--r);
  padding: 18px 20px;
  text-align: center;
}
.mps-value {
  font-family: 'Playfair Display', serif;
  font-size: 1.9rem; font-weight: 700;
  color: var(--gold); line-height: 1;
  margin-bottom: 6px;
  text-shadow: 0 0 24px rgba(200,169,81,.18);
}
.mps-label {
  font-size: .68rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3);
}

/* ═══════════════════════════════════════════════════════════════
   MY PRACTICE — program banner
═══════════════════════════════════════════════════════════════ */
.mp-grid {
  padding: 4px 0 40px;
  max-width: 1100px;
}
.mp-banner {
  background: var(--surface);
  border: 1px solid var(--edge);
  border-radius: var(--r);
  padding: 36px 40px 32px;
  position: relative;
  overflow: hidden;
}
.mp-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(200,16,46,.04) 0%, rgba(200,169,81,.03) 100%);
  pointer-events: none;
}
.mp-banner-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 28px;
}
.mp-banner-left { flex: 1; }
.mp-banner-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 10px;
}
.mp-banner-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.6rem; font-style: italic; font-weight: 600;
  color: var(--text);
  line-height: 1.1;
  margin-bottom: 8px;
}
.mp-banner-sub {
  font-size: .88rem;
  color: var(--text-3);
  line-height: 1.5;
}
.mp-banner-right {
  text-align: right;
  flex-shrink: 0;
  padding-top: 4px;
}
.mp-banner-day {
  font-family: 'Playfair Display', serif;
  font-size: 3.6rem; font-weight: 900;
  color: var(--gold);
  line-height: 1;
  text-shadow: 0 0 32px rgba(200,169,81,.2);
}
.mp-banner-of {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-3);
  margin-top: 4px;
}
.mp-banner-progress { margin-bottom: 28px; }
.mp-banner-prog-bar {
  height: 4px;
  background: rgba(255,255,255,.05);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 10px;
}
.mp-banner-prog-fill {
  height: 100%;
  background: linear-gradient(to right, var(--crimson), var(--gold));
  border-radius: 99px;
  transition: width .8s var(--ease);
}
.mp-banner-prog-meta {
  display: flex;
  justify-content: space-between;
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-3);
}
.mp-banner-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.mp-banner-next {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px 10px;
  flex: 1;
}
.mp-banner-next-arrow { color: var(--gold); font-size: .9rem; flex-shrink: 0; }
.mp-banner-next-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem; font-style: italic;
  color: var(--text-2);
}
.mp-banner-last {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; font-weight: 500;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3);
  flex-basis: 100%; padding-left: 18px;
}
.mp-banner-actions { display: flex; gap: 10px; flex-shrink: 0; }
.mp-card {
  background: var(--surface);
  border: 1px solid var(--edge);
  border-top-color: var(--edge-hi);
  border-radius: var(--r);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: border-color .2s, box-shadow .2s;
}
.mp-card:hover { border-color: rgba(201,170,82,.25); box-shadow: 0 4px 24px rgba(0,0,0,.18); }
.mp-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.mp-card-icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: linear-gradient(135deg, rgba(201,170,82,.15) 0%, rgba(196,16,43,.08) 100%);
  border: 1px solid rgba(201,170,82,.18);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold-hi); flex-shrink: 0;
}
.mp-badge {
  font-size: .62rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  padding: 3px 9px; border-radius: 99px;
}
.mp-badge.active   { background: rgba(201,170,82,.12); color: var(--gold-hi); border: 1px solid rgba(201,170,82,.25); }
.mp-badge.complete { background: rgba(60,180,90,.1);  color: #5cb87a; border: 1px solid rgba(60,180,90,.2); }
.mp-badge.paused   { background: rgba(130,130,160,.1); color: var(--text-3); border: 1px solid var(--border); }
.mp-card-name  { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-style: italic; color: var(--text-1); line-height: 1.3; }
.mp-card-sub   { font-size: .8rem; color: var(--text-3); line-height: 1.5; }
.mp-progress-wrap { display: flex; flex-direction: column; gap: 6px; }
.mp-progress-meta { display: flex; justify-content: space-between; font-size: .72rem; color: var(--text-3); }
.mp-progress-bar  { height: 3px; background: var(--border); border-radius: 99px; overflow: hidden; }
.mp-progress-fill { height: 100%; background: linear-gradient(to right, var(--crimson), var(--gold)); border-radius: 99px; transition: width .6s ease; }
.mp-next-up {
  display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
  padding: 10px 14px;
  background: rgba(201,170,82,.04);
  border: 1px solid rgba(201,170,82,.12);
  border-radius: 8px;
  margin-top: -2px;
}
.mp-next-arrow { color: var(--gold-hi); font-size: .85rem; flex-shrink: 0; }
.mp-next-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: .92rem; font-style: italic; color: var(--text-2);
  flex: 1;
}
.mp-last-text {
  font-size: .64rem; font-weight: 500; letter-spacing: .06em;
  color: var(--text-3); text-transform: uppercase;
  white-space: nowrap;
}
.mp-card-actions { display: flex; gap: 10px; margin-top: 4px; }
.mp-card-actions .btn { flex: 1; font-size: .75rem; padding: 8px 12px; }

/* ═══════════════════════════════════════════════════════════════
   MY PRACTICE — heatmap
═══════════════════════════════════════════════════════════════ */
.mp-heatmap-section {
  background: var(--surface);
  border: 1px solid var(--edge);
  border-top-color: var(--edge-hi);
  border-radius: var(--r);
  padding: 24px;
  margin-bottom: 20px;
  max-width: 1100px;
}
.mph-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px; flex-wrap: wrap; gap: 12px;
}
.mph-title {
  font-size: .78rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-2);
}
.mph-legend { display: flex; gap: 16px; }
.mph-leg {
  display: flex; align-items: center; gap: 6px;
  font-size: .64rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-3);
}
.mph-leg-dot {
  width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0;
}
.mph-leg-dot.done   { background: var(--gold-hi); }
.mph-leg-dot.today  { background: var(--crimson); }
.mph-leg-dot.future { background: var(--border); border: 1px solid var(--border); }
.mph-grid {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 6px;
  margin-bottom: 16px;
}
.mph-day {
  aspect-ratio: 1;
  border-radius: var(--r);
  display: flex; align-items: center; justify-content: center;
  cursor: default;
  position: relative;
  transition: transform .15s;
}
.mph-day:hover { transform: scale(1.12); z-index: 2; }
.mph-day.done   { background: linear-gradient(135deg, var(--crimson), var(--gold)); }
.mph-day.today  {
  background: var(--crimson);
  box-shadow: 0 0 10px rgba(196,16,43,.4);
  animation: todayPulse 2.5s ease-in-out infinite;
}
.mph-day.future { background: var(--surface); border: 1px solid var(--edge); }
.mph-day-num {
  font-size: .58rem; font-weight: 700; line-height: 1;
  color: rgba(255,255,255,.3);
  pointer-events: none;
}
.mph-day.done   .mph-day-num { color: rgba(255,255,255,.6); }
.mph-day.future .mph-day-num { color: var(--text-3); }
.mph-day.today  .mph-day-num { color: rgba(255,255,255,.8); }
@keyframes todayPulse {
  0%,100% { box-shadow: 0 0 8px rgba(196,16,43,.35); }
  50%      { box-shadow: 0 0 18px rgba(196,16,43,.6); }
}
.mph-footer {
  display: flex; justify-content: space-between;
  font-size: .68rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-3); padding-top: 12px;
  border-top: 1px solid var(--edge);
}
.mph-footer span { white-space: nowrap; }

/* ═══════════════════════════════════════════════════════════════
   MY PRACTICE — achievements
═══════════════════════════════════════════════════════════════ */
.mp-achievements-section {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
  margin-bottom: 40px;
  max-width: 1100px;
}
.mpa-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px;
}
.mpa-title {
  font-size: .78rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-2);
}
.mpa-count {
  font-size: .66rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--gold-hi);
}
.mpa-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 12px;
}
.mpa-badge {
  display: flex; flex-direction: column; align-items: center;
  gap: 6px; padding: 16px 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.02);
  text-align: center;
  transition: border-color .2s, background .2s, transform .2s;
  cursor: default;
}
.mpa-badge.earned {
  background: rgba(201,170,82,.06);
  border-color: rgba(201,170,82,.2);
}
.mpa-badge.earned:hover {
  background: rgba(201,170,82,.1);
  border-color: rgba(201,170,82,.35);
  transform: translateY(-2px);
}
.mpa-badge.locked { opacity: .4; }
.mpa-icon {
  font-size: 1.2rem;
  color: var(--gold-hi);
  line-height: 1;
}
.mpa-badge.locked .mpa-icon { color: var(--text-3); }
.mpa-label {
  font-size: .68rem; font-weight: 600;
  letter-spacing: .07em; text-transform: uppercase;
  color: var(--text-1); line-height: 1.2;
}
.mpa-badge.locked .mpa-label { color: var(--text-3); }
.mpa-desc {
  font-family: 'Cormorant Garamond', serif;
  font-size: .76rem; color: var(--text-3);
  line-height: 1.3;
}

/* Light mode overrides for new sections */
body.light-mode .mp-heatmap-section,
body.light-mode .mp-achievements-section,
body.light-mode .mps-stat { background: var(--surface); }
body.light-mode .habit-card { background: var(--surface); border-color: rgba(0,0,0,.07); }
body.light-mode .mph-day.future { background: rgba(0,0,0,.06); }
body.light-mode .mpa-badge { background: rgba(0,0,0,.02); }
body.light-mode .mpa-badge.earned { background: rgba(201,170,82,.08); }

/* ═══════════════════════════════════════════════════════════════
   MY JOURNEY — timeline and stats
═══════════════════════════════════════════════════════════════ */
.journey-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 32px;
}
@media (max-width: 680px) { .journey-stats { grid-template-columns: repeat(2,1fr); } }
.jstat {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  text-align: center;
}
.jstat-value {
  font-family: 'Playfair Display', serif;
  font-size: 2rem; font-weight: 700; color: var(--gold-hi);
  line-height: 1;
  margin-bottom: 6px;
}
.jstat-label { font-size: .72rem; color: var(--text-3); letter-spacing: .08em; text-transform: uppercase; }
.journey-timeline { display: flex; flex-direction: column; gap: 0; padding-bottom: 40px; }
.jt-month-group { margin-bottom: 28px; }
.jt-month-label {
  font-size: .68rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-3); padding: 0 0 10px;
  border-bottom: 1px solid var(--border); margin-bottom: 14px;
}
.jt-entry {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 16px 18px;
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); margin-bottom: 10px;
  transition: border-color .18s, box-shadow .18s;
  cursor: default;
}
.jt-entry:hover { border-color: rgba(201,170,82,.2); box-shadow: 0 2px 12px rgba(0,0,0,.12); }
.jt-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold-hi); flex-shrink: 0; margin-top: 6px;
  box-shadow: 0 0 6px rgba(201,170,82,.35);
}
.jt-dot.journal    { background: var(--gold-hi); }
.jt-dot.practice   { background: var(--crimson); box-shadow: 0 0 6px var(--crimson-dim); }
.jt-dot.milestone  { background: #5cb87a; box-shadow: 0 0 6px rgba(92,184,122,.35); }
.jt-dot.reflection { background: #8b7fe8; box-shadow: 0 0 6px rgba(139,127,232,.35); }
.jt-body { flex: 1; min-width: 0; }
.jt-top { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-1); margin-bottom: var(--sp-1); }
.jt-type-badge {
  font-size: var(--label-xs); font-weight: 600; letter-spacing: var(--track-sm); text-transform: uppercase;
  padding: 2px var(--sp-1); border-radius: 99px;
  background: rgba(201,170,82,.1); color: var(--gold-hi); border: 1px solid rgba(201,170,82,.2);
}
.jt-type-badge.practice   { background: rgba(200,16,46,.08);   color: rgba(200,16,46,.8);  border-color: rgba(200,16,46,.2); }
.jt-type-badge.milestone  { background: rgba(92,184,122,.1);   color: #5cb87a;             border-color: rgba(92,184,122,.25); }
.jt-type-badge.reflection { background: rgba(139,127,232,.1);  color: #8b7fe8;             border-color: rgba(139,127,232,.25); }
.jt-date { font-size: var(--label-xs); color: var(--text-3); }
.jt-title { font-size: .88rem; font-weight: 600; color: var(--text-1); margin-bottom: 4px; line-height: 1.3; }
.jt-snippet { font-size: .82rem; color: var(--text-2); line-height: 1.6; max-height: 0; overflow: hidden; transition: max-height .3s var(--ease), opacity .3s var(--ease); opacity: 0; }
.jt-entry.expanded .jt-snippet { max-height: 200px; opacity: 1; }
.jt-expand-icon { flex-shrink: 0; color: var(--text-3); margin-top: 2px; transition: transform .25s var(--ease), color .18s; }
.jt-entry.expanded .jt-expand-icon { transform: rotate(180deg); color: var(--gold); }
.jt-entry { cursor: pointer; }
.journey-empty-cta { display: flex; justify-content: center; padding: var(--sp-3) 0 var(--sp-5); }
/* .ref-tabs-5 removed — Journey filters now use .fchip-bar */

/* ═══════════════════════════════════════════════════════════════
   MY JOURNEY — upgraded shell (jny-* classes)
═══════════════════════════════════════════════════════════════ */

/* Streak badge — lives inside nav bar left */
.jny-streak {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .54rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 600;
  color: var(--gold-hi); background: rgba(200,169,81,.07);
  border: 1px solid rgba(200,169,81,.2); border-radius: 20px;
  padding: 4px 10px; flex-shrink: 0;
}
/* Divider between streak badge and time range pills */
.jny-nav-divider {
  width: 1px; height: 16px; background: var(--border);
  margin: 0 4px; flex-shrink: 0;
}
.jny-streak-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--gold-hi); flex-shrink: 0; }

/* Nav bar — split left/right */
.jny-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 48px 24px; gap: 12px;
}
.jny-nav-left  { display: flex; gap: 5px; }
.jny-nav-right {
  display: flex; align-items: center; gap: 4px;
  border-left: 1px solid var(--border); padding-left: 12px;
}
.jny-pill {
  background: none; border: 1px solid transparent; border-radius: 20px;
  padding: 5px 14px; font-size: .58rem; letter-spacing: .07em; text-transform: uppercase;
  color: var(--text-3); cursor: pointer; font-family: 'Montserrat', sans-serif; font-weight: 600;
  transition: all .16s var(--ease);
}
.jny-nav-left .jny-pill { border-color: var(--border); }
.jny-pill:hover { color: var(--text-2); border-color: rgba(255,255,255,.1); }
.jny-pill.active-l { background: rgba(200,169,81,.08); border-color: rgba(200,169,81,.3); color: var(--gold-hi); }
.jny-pill.active-r { color: var(--text-1); border-color: rgba(255,255,255,.14); background: rgba(255,255,255,.04); }

/* Stats strip — 5 cells */
.jny-strip {
  display: flex; border: 1px solid var(--border); border-radius: var(--r-sm);
  overflow: hidden; margin: 0 48px 24px; background: var(--bg-2);
}
.jny-s-cell {
  flex: 1; padding: 14px 18px; border-right: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 5px;
}
.jny-s-cell:last-child { border-right: none; }
.jny-s-val {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem; font-weight: 400; line-height: 1; color: var(--text-1);
  transition: opacity .2s var(--ease);
}
.jny-s-val em { font-style: italic; color: var(--gold-hi); }
.jny-s-val .trend { font-size: .55rem; font-family: 'Montserrat', sans-serif; margin-left: 2px; }
.jny-s-val .trend.up { color: var(--green); }
.jny-s-lbl {
  font-size: .5rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-3); font-family: 'Montserrat', sans-serif; font-weight: 600;
}

/* Moments Earned */
.jny-moments {
  border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-sm);
  background: var(--bg-2); margin: 0 48px 24px; overflow: hidden;
}
.jny-moments-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 18px; cursor: pointer; user-select: none;
  transition: background .14s var(--ease);
}
.jny-moments-hdr:hover { background: rgba(255,255,255,.02); }
.jny-moments-title { font-size: .52rem; letter-spacing: .16em; text-transform: uppercase; color: var(--text-3); font-weight: 600; }
.jny-moments-count { font-size: .54rem; color: var(--gold-hi); letter-spacing: .06em; font-weight: 600; }
.jny-moments-grid {
  display: flex; flex-wrap: wrap; gap: 8px; padding: 0 14px 14px;
  border-top: 1px solid var(--border);
}
.jny-moments-grid.collapsed { display: none; }
.jny-moment {
  display: flex; align-items: flex-start; gap: 10px;
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 10px 12px; flex: 1; min-width: 190px;
}
.jny-moment.locked { opacity: .3; }
.jny-moment-icon { font-size: .85rem; flex-shrink: 0; line-height: 1.5; }
.jny-moment-name { font-size: .65rem; color: var(--text-1); font-weight: 600; margin-bottom: 2px; }
.jny-moment-desc { font-size: .56rem; color: var(--text-3); line-height: 1.55; }

/* On This Day */
.jny-otd {
  display: flex; align-items: flex-start; gap: 14px;
  background: linear-gradient(to right, rgba(200,169,81,.06), transparent);
  border: 1px solid rgba(200,169,81,.18); border-radius: var(--r-sm);
  padding: 14px 16px; margin: 0 48px 20px; cursor: pointer;
  transition: border-color .18s var(--ease);
}
.jny-otd:hover { border-color: rgba(200,169,81,.36); }
.jny-otd-left { flex-shrink: 0; display: flex; flex-direction: column; align-items: center; gap: 3px; padding-top: 2px; }
.jny-otd-icon { font-size: .72rem; color: var(--gold-hi); }
.jny-otd-ago  { font-size: .46rem; letter-spacing: .1em; text-transform: uppercase; color: var(--gold-hi); font-weight: 600; white-space: nowrap; }
.jny-otd-body { flex: 1; min-width: 0; }
.jny-otd-eyebrow { font-size: .48rem; letter-spacing: .13em; text-transform: uppercase; color: var(--text-3); font-weight: 600; margin-bottom: 4px; }
.jny-otd-title   { font-size: .76rem; color: var(--text-1); font-weight: 600; margin-bottom: 4px; line-height: 1.3; }
.jny-otd-snippet { font-size: .63rem; color: var(--text-2); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.jny-otd-cta { flex-shrink: 0; font-size: .56rem; color: var(--gold-hi); font-weight: 600; white-space: nowrap; align-self: center; letter-spacing: .04em; }

/* Timeline container */
.jny-timeline { display: flex; flex-direction: column; padding: 0 48px 80px; }
.jny-month-grp { margin-bottom: 28px; }
.jny-month-lbl {
  font-size: .52rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase;
  color: var(--text-3); padding-bottom: 10px;
  border-bottom: 1px solid var(--border); margin-bottom: 10px;
}

/* Journal / Reflection row — expandable */
.jny-row {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 13px 15px; background: var(--bg-2);
  border: 1px solid var(--border); border-radius: var(--r-sm);
  margin-bottom: 2px; cursor: pointer; transition: border-color .15s var(--ease);
}
.jny-row:hover { border-color: rgba(200,169,81,.18); }
.jny-row.open  { border-color: rgba(200,169,81,.22); }
.jny-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.jny-dot.journal    { background: var(--gold-hi); box-shadow: 0 0 5px rgba(200,169,81,.3); }
.jny-dot.reflection { background: #8b7fe8; box-shadow: 0 0 5px rgba(139,127,232,.3); }
.jny-dot.practice   { background: var(--crimson); box-shadow: 0 0 4px rgba(200,16,46,.25); margin-top: 0; }
.jny-row-body { flex: 1; min-width: 0; }
.jny-row-top { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; flex-wrap: wrap; }
.jny-tag {
  font-size: .47rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 600;
  padding: 2px 7px; border-radius: 10px; border: 1px solid transparent;
}
.jny-tag.journal    { color: var(--gold-hi);  border-color: rgba(200,169,81,.22);  background: rgba(200,169,81,.07); }
.jny-tag.reflection { color: #8b7fe8; border-color: rgba(139,127,232,.22); background: rgba(139,127,232,.07); }
.jny-wc    { font-size: .47rem; letter-spacing: .07em; text-transform: uppercase; font-weight: 600; color: var(--text-3); background: rgba(255,255,255,.04); border: 1px solid var(--border); border-radius: 8px; padding: 2px 6px; }
.jny-date-grp { margin-left: auto; display: flex; align-items: center; gap: 5px; }
.jny-rel   { font-size: .54rem; color: var(--text-3); }
.jny-abs   { font-size: .5rem; color: var(--text-3); opacity: .55; }
.jny-title   { font-size: .7rem; color: var(--text-1); font-weight: 600; margin-bottom: 3px; line-height: 1.3; }
.jny-snippet { font-size: .63rem; color: var(--text-2); line-height: 1.65; max-height: 0; overflow: hidden; opacity: 0; transition: max-height .28s var(--ease), opacity .28s var(--ease); }
.jny-row.open .jny-snippet { max-height: 200px; opacity: 1; }
.jny-chevron { flex-shrink: 0; color: var(--text-3); font-size: .65rem; margin-top: 3px; transition: transform .22s var(--ease), color .18s; }
.jny-row.open .jny-chevron { transform: rotate(90deg); color: var(--gold-hi); }

/* Practice row — compact single line */
.jny-practice {
  display: flex; align-items: center; gap: 11px;
  padding: 8px 15px; background: var(--bg-2);
  border: 1px solid var(--border); border-radius: var(--r-sm); margin-bottom: 2px;
}
.jny-prac-lbl  { font-size: .6rem; color: var(--text-2); flex: 1; }
.jny-prac-lbl span { color: var(--text-3); font-size: .57rem; }
.jny-prac-day  {
  font-size: .5rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 600;
  color: var(--crimson); opacity: .7; background: rgba(200,16,46,.07);
  border: 1px solid rgba(200,16,46,.15); border-radius: 8px; padding: 2px 6px;
}
.jny-prac-date { font-size: .54rem; color: var(--text-3); }

/* Milestone row — elevated full-width card */
.jny-milestone {
  background: linear-gradient(135deg, rgba(106,191,106,.05) 0%, rgba(200,169,81,.02) 100%);
  border: 1px solid rgba(106,191,106,.22); border-radius: var(--r-sm);
  padding: 16px 18px; margin-bottom: 2px;
}
.jny-ms-top { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.jny-ms-badge {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  background: rgba(106,191,106,.12); border: 1px solid rgba(106,191,106,.3);
  display: flex; align-items: center; justify-content: center; font-size: .72rem;
}
.jny-ms-eyebrow { font-size: .47rem; letter-spacing: .14em; text-transform: uppercase; color: #6abf6a; font-weight: 600; margin-bottom: 2px; }
.jny-ms-date    { font-size: .54rem; color: var(--text-3); }
.jny-ms-title   { font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; font-weight: 400; font-style: italic; color: var(--text-1); margin-bottom: 5px; line-height: 1.25; }
.jny-ms-sub     { font-size: .62rem; color: var(--text-2); line-height: 1.6; }

/* Journey section label */
.jny-section-lbl {
  font-size: .52rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text-3); font-weight: 600; margin: 0 48px 14px; padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}

/* Journey empty state */
.jny-empty {
  margin: 0 48px 80px; padding: 48px 32px; text-align: center;
  border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--bg-2);
}
.jny-empty-icon { font-size: 1.4rem; opacity: .18; margin-bottom: 12px; }
.jny-empty-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem; font-weight: 300; font-style: italic;
  color: var(--text-2); margin-bottom: 6px;
}
.jny-empty-sub { font-size: .65rem; color: var(--text-3); line-height: 1.6; margin-bottom: 20px; }
.jny-empty-cta { display: flex; justify-content: center; }

/* Light mode */
/* Journey light mode */
body.light-mode .jny-streak { background: rgba(160,130,40,.08); border-color: rgba(160,130,40,.22); }
body.light-mode .jny-moment { background: var(--bg-3); }
body.light-mode .jny-otd { background: linear-gradient(to right, rgba(160,130,40,.05), transparent); }
body.light-mode .jny-milestone { background: linear-gradient(135deg, rgba(80,160,80,.04) 0%, rgba(160,130,40,.02) 100%); }
/* Journey nav pills — light mode */
body.light-mode .jny-nav-left .jny-pill { border-color: rgba(0,0,0,.14); }
body.light-mode .jny-pill:hover { border-color: rgba(0,0,0,.2); color: var(--text-2); }
body.light-mode .jny-pill.active-r { border-color: rgba(0,0,0,.14); background: rgba(0,0,0,.05); color: var(--text-1); }

/* Investments light mode */
/* Nav pills */
body.light-mode .ord-sw-btn:hover,
body.light-mode .ord-filter-pill:hover { border-color: rgba(0,0,0,.14); color: var(--text-2); }
body.light-mode .ord-filter-pill.active { border-color: rgba(0,0,0,.14); background: rgba(0,0,0,.05); color: var(--text-1); }
/* Toggle switch */
body.light-mode .ord-toggle-slider { background: rgba(0,0,0,.16); }
body.light-mode .ord-toggle-slider::before { background: rgba(255,255,255,.88); }
body.light-mode .ord-toggle input:checked + .ord-toggle-slider { background: rgba(160,130,40,.28); }
/* Table & grid separators */
body.light-mode .ord-billing-table td { border-bottom-color: rgba(0,0,0,.06); }
body.light-mode .ord-feature-row { border-bottom-color: rgba(0,0,0,.06); }
/* Download link */
body.light-mode .ord-dl-link { border-bottom-color: rgba(0,0,0,.16); }
body.light-mode .ord-dl-link:hover { border-bottom-color: rgba(0,0,0,.32); color: var(--text-2); }
/* Billing reminder bg */
body.light-mode .ord-billing-reminder { background: rgba(0,0,0,.03); }

/* ═══════════════════════════════════════════════════════════════
   MY PIECES — purchased content grid
═══════════════════════════════════════════════════════════════ */
.pieces-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 18px;
  padding: 4px 0 40px;
}
.piece-card {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: border-color .2s, box-shadow .2s, transform .2s;
  cursor: pointer;
}
.piece-card:hover { border-color: rgba(201,170,82,.28); box-shadow: 0 6px 28px rgba(0,0,0,.2); transform: translateY(-2px); }
.piece-cover {
  height: 140px;
  background: linear-gradient(135deg, rgba(201,170,82,.1) 0%, rgba(10,10,10,0) 100%);
  display: flex; align-items: center; justify-content: center;
  color: rgba(201,170,82,.3); border-bottom: 1px solid var(--border);
  position: relative;
}
.piece-cover-text {
  font-family: 'Playfair Display', serif;
  font-size: 1.8rem; font-weight: 700; font-style: italic;
  color: rgba(201,170,82,.18); user-select: none; line-height: 1;
  text-align: center; padding: 0 12px;
}
.piece-badge {
  position: absolute; top: 10px; right: 10px;
  font-size: .58rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 99px;
  background: rgba(10,10,10,.7); border: 1px solid var(--border);
  color: var(--text-2); backdrop-filter: blur(4px);
}
.piece-info { padding: 16px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.piece-title { font-size: .95rem; font-weight: 600; color: var(--text-1); line-height: 1.3; }
.piece-purchased { font-size: .68rem; color: var(--text-3); letter-spacing: .03em; }
.piece-actions { padding: 12px 16px 16px; }
.piece-actions .btn { width: 100%; font-size: .74rem; padding: 8px 12px; }

/* My Guide — Discover / catalog section */
.mg-discover { margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--border); }
.mg-discover-eyebrow {
  font-size: .55rem; letter-spacing: .32em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 20px;
}
.mg-catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.mg-catalog-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
  transition: border-color .2s var(--ease-premium), transform .2s var(--ease-premium);
}
.mg-catalog-card:hover { border-color: rgba(200,169,81,.28); transform: translateY(-2px); }
.mg-cat-cover {
  height: 120px;
  background: linear-gradient(135deg, rgba(200,169,81,.06) 0%, rgba(10,10,10,0) 100%);
  display: flex; align-items: center; justify-content: center;
  border-bottom: 1px solid var(--border); position: relative;
}
.mg-cat-initial {
  font-family: 'Playfair Display', serif;
  font-size: 2.4rem; font-weight: 700; font-style: italic;
  color: rgba(200,169,81,.15); user-select: none;
}
.mg-cat-info { padding: 14px 16px; flex: 1; display: flex; flex-direction: column; gap: 7px; }
.mg-cat-title { font-size: .88rem; font-weight: 600; color: var(--text-1); line-height: 1.3; }
.mg-cat-desc { font-size: .72rem; color: var(--text-2); line-height: 1.6; }
.mg-cat-footer { padding: 10px 16px 14px; border-top: 1px solid var(--border); margin-top: auto; }
.mg-cat-cta {
  font-size: .58rem; font-weight: 600; letter-spacing: .18em;
  text-transform: uppercase; color: var(--gold-hi);
}
.mg-catalog-card:hover .mg-cat-cta { opacity: .75; }

/* ═══════════════════════════════════════════════════════════════
   MY GUIDE — TWO-COLUMN LAYOUT
═══════════════════════════════════════════════════════════════ */

/* My Guide uses the same two-column flex pattern as The Work */
#view-my-guide.active {
  display: flex; flex-direction: column; height: 100%; overflow: hidden;
}
#view-my-guide .view-header { flex-shrink: 0; }
#view-my-guide .two-col {
  flex: 1; min-height: 0; overflow: hidden;
}
#view-my-guide .mg-col-wrap {
  position: relative; overflow: hidden; min-height: 0;
}
#view-my-guide .col-left,
#view-my-guide .col-right {
  overflow-y: auto; overflow-x: hidden; height: 100%; scrollbar-width: none;
}
#view-my-guide .col-left::-webkit-scrollbar,
#view-my-guide .col-right::-webkit-scrollbar { display: none; }

/* Focus mode — collapse right panel */
body.focus-mode #view-my-guide .two-col   { grid-template-columns: 1fr 0px; }
body.focus-mode #view-my-guide .col-right { opacity: 0; pointer-events: none; }

/* Stack label */
.mg-stack-label {
  font-size: .55rem; letter-spacing: .28em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 16px;
  display: flex; align-items: center; gap: 10px;
}
.mg-stack-label::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}

/* ── ACCORDION STACK ── */
.mg-stack { display: flex; flex-direction: column; gap: 12px; margin-bottom: 40px; }

.mg-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  transition: border-color .22s var(--ease);
}
.mg-card:hover       { border-color: var(--border-hi); }
.mg-card.open        { border-color: rgba(200,169,81,.28); }
.mg-card.done        { border-color: rgba(76,175,130,.2); }
.mg-card--locked     { opacity: .65; }
.mg-card--locked:hover { opacity: .85; border-color: rgba(200,169,81,.18); }

/* Colour bar */
.mg-bar { height: 2px; width: 100%; }

/* Card header */
.mg-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px; cursor: pointer; gap: 12px; user-select: none;
}
.mg-header--locked { cursor: default; }
.mg-header-left  { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; }
.mg-header-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

/* Step badge */
.mg-badge {
  font-size: .5rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 20px; flex-shrink: 0; white-space: nowrap;
  background: var(--bg-3); border: 1px solid var(--border); color: var(--text-3);
}
.mg-card.open .mg-badge        { background: rgba(200,169,81,.14); border-color: rgba(200,169,81,.35); color: var(--gold-hi); }
.mg-card.done .mg-badge        { background: rgba(76,175,130,.1);  border-color: rgba(76,175,130,.3);  color: #4caf82; }
.mg-badge--locked              { opacity: .5; }

.mg-title-wrap { flex: 1; min-width: 0; }
.mg-type  { font-size: .5rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--text-3); margin-bottom: 3px; }
.mg-title { font-family: 'Playfair Display', serif; font-size: 1.05rem; font-weight: 700; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mg-title em { font-style: italic; color: var(--gold-hi); }
.mg-card.done .mg-title        { color: var(--text-2); }
.mg-card--locked .mg-title     { color: var(--text-3); }

/* Lock icon */
.mg-lock-icon { color: var(--text-3); opacity: .5; }

/* Progress pips */
.mg-pips { display: flex; gap: 4px; }
.mg-pip {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--bg-3); border: 1px solid var(--border); transition: all .2s;
}
.mg-pip.done       { background: var(--gold-hi); border-color: var(--gold-hi); }
.mg-pip.active     { background: transparent; border-color: var(--gold-hi); box-shadow: 0 0 0 2px rgba(200,169,81,.18); }
.mg-pip.done-green { background: #4caf82; border-color: #4caf82; }
.mg-count   { font-size: .6rem; color: var(--text-3); min-width: 26px; text-align: right; }
.mg-chevron { color: var(--text-3); transition: transform .3s var(--ease); }
.mg-card.open .mg-chevron { transform: rotate(180deg); }

/* Expandable body */
.mg-body { max-height: 0; overflow: hidden; transition: max-height .38s var(--ease); }
.mg-card.open .mg-body { max-height: 540px; }
.mg-body-inner { padding: 0 18px 20px; }

.mg-desc { font-size: .88rem; color: var(--text-2); line-height: 1.65; margin-bottom: 16px; }

/* Chapter chips */
.mg-ch-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 7px; margin-bottom: 18px; }
.mg-ch-chip {
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: var(--r-sm, 8px); padding: 8px 6px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  cursor: pointer; transition: all .2s; text-align: center;
}
.mg-ch-chip:hover               { border-color: var(--border-hi); }
.mg-ch-chip.done                { background: rgba(200,169,81,.12); border-color: rgba(200,169,81,.3); }
.mg-ch-chip.done-green          { background: rgba(76,175,130,.1);  border-color: rgba(76,175,130,.28); }
.mg-ch-chip.active              { border-color: rgba(200,169,81,.5); background: rgba(200,169,81,.07); }
.mg-ch-name { font-size: .48rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--text-2); line-height: 1.3; }
.mg-ch-chip.done .mg-ch-name        { color: var(--gold-hi); }
.mg-ch-chip.done-green .mg-ch-name  { color: #4caf82; }
.mg-ch-chip.active .mg-ch-name      { color: var(--gold-hi); }
.mg-ch-time { font-size: .42rem; color: var(--text-3); }

/* Footer row */
.mg-footer     { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.mg-footer-cta { display: flex; align-items: center; gap: 10px; }
.mg-status     { font-size: .52rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3); }
.mg-status.in-progress { color: var(--gold-hi); }
.mg-status.complete    { color: #4caf82; }
.mg-restart {
  font-size: .5rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3); cursor: pointer; border: none; background: none; padding: 0;
  transition: color .2s;
}
.mg-restart:hover { color: var(--text-2); }

/* Locked card footer */
.mg-locked-footer {
  padding: 10px 18px 16px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  border-top: 1px solid var(--border);
}
.mg-locked-label {
  font-size: .55rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3);
}

/* Light-mode overrides */
body.light-mode .mg-card         { background: #fff; }
body.light-mode .mg-ch-chip      { background: rgba(0,0,0,.02); }
body.light-mode .mg-ch-chip:hover{ background: rgba(0,0,0,.05); }
body.light-mode .mg-ch-chip.done { background: rgba(200,169,81,.07); }

/* ═══════════════════════════════════════════════════════════════
   SETTINGS
═══════════════════════════════════════════════════════════════ */
.settings-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  padding: 0 48px 60px; align-items: stretch;
}
.settings-col { display: flex; flex-direction: column; gap: 24px; }
.settings-full { grid-column: 1 / -1; margin-top: 16px; }
.settings-section {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.settings-danger { border-color: rgba(200,16,46,.2); }
.ss-header {
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border);
}
.ss-title { font-size: .88rem; font-weight: 600; color: var(--text-1); margin-bottom: 3px; }
.ss-sub   { font-size: .76rem; color: var(--text-3); }
.ss-body  { padding: 20px 24px; display: flex; flex-direction: column; gap: 16px; }
.ss-field { display: flex; flex-direction: column; gap: 7px; }
.ss-label { font-size: .74rem; font-weight: 500; color: var(--text-2); letter-spacing: .05em; }
.ss-input {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  padding: 10px 14px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem; color: var(--text-1);
  width: 100%; box-sizing: border-box;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
}
.ss-input:focus { border-color: rgba(201,170,82,.45); box-shadow: 0 0 0 3px rgba(201,170,82,.08); }
body.light-mode .ss-input { background: #fff; border-color: rgba(0,0,0,.16); }
.ss-textarea { resize: none; line-height: 1.6; min-height: 62px; }
.ss-field-hint { font-size: .68rem; color: var(--text-3); margin-top: 4px; }
.ss-time-input { width: 100px; padding: 7px 12px; font-size: .84rem; flex-shrink: 0; text-align: center; letter-spacing: .04em; }
.ss-time-input::-webkit-calendar-picker-indicator { display: none; }
.ss-select { padding: 7px 12px; font-size: .84rem; flex-shrink: 0; min-width: 120px; cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='rgba(240,236,228,.4)' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px; }
.ss-weekly-row { display: flex; gap: 8px; align-items: center; }
.ss-security-note { font-family: 'Cormorant Garamond', serif; font-size: .82rem; color: var(--text-3); line-height: 1.6; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--border); }
.ss-reminder-time-row { display: none; }
.ss-reminder-time-row.visible { display: flex; }
.ss-pref-row-col { flex-direction: column; align-items: flex-start; gap: 10px; }
.ss-mode-group { display: flex; gap: 6px; }
.ss-mode-btn {
  font-family: 'Montserrat', sans-serif; font-size: .62rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 99px; border: 1px solid var(--border);
  background: transparent; color: var(--text-3); cursor: pointer;
  transition: background .18s, color .18s, border-color .18s;
}
.ss-mode-btn:hover { color: var(--text-2); border-color: var(--text-3); }
.ss-mode-btn.active {
  background: rgba(200,169,81,.12); color: var(--gold);
  border-color: rgba(200,169,81,.35);
}
.ss-actions { display: flex; align-items: center; gap: 14px; margin-top: 4px; }
.ss-msg { font-size: .78rem; }
.ss-msg.ok  { color: #5cb87a; }
.ss-msg.err { color: #e05c5c; }
.ss-msg.hidden { display: none; }
/* Preference toggle rows */
.ss-pref-row {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 8px 0; border-bottom: 1px solid var(--border);
}
.ss-pref-row:last-child { border-bottom: none; }
.ss-pref-label { font-size: .84rem; color: var(--text-1); margin-bottom: 3px; }
.ss-pref-hint  { font-size: .72rem; color: var(--text-3); }
.ss-toggle {
  width: 42px; height: 24px; border-radius: 99px;
  background: var(--border); border: none; cursor: pointer;
  position: relative; transition: background .2s; flex-shrink: 0;
  padding: 0;
}
.ss-toggle.on { background: var(--gold-hi); }
.ss-toggle-thumb {
  position: absolute; top: 3px; left: 3px;
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; transition: left .2s;
  pointer-events: none;
}
.ss-toggle.on .ss-toggle-thumb { left: 21px; }
/* ── Settings v2 — tabbed layout ── */
#view-settings .settings-tabs { margin: 0 48px 36px; }
#view-settings .tab-panel     { padding: 0 48px 80px; }
.settings-tabs {
  display: grid; grid-template-columns: repeat(5, 1fr);
  padding: 3px; background: rgba(0,0,0,.15);
  border-radius: calc(var(--r-sm) + 2px);
  margin-bottom: 36px;
  overflow-x: auto; scrollbar-width: none;
}
.settings-tabs::-webkit-scrollbar { display: none; }
.st-tab-btn {
  padding: 11px 10px; background: transparent; border: none;
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-sm); font-weight: 600;
  letter-spacing: var(--track-sm); text-transform: uppercase;
  color: var(--text-3); cursor: pointer; border-radius: 6px;
  transition: all var(--t-fast) var(--ease); outline: 1px solid transparent;
  display: flex; align-items: center; justify-content: center;
  white-space: nowrap;
}
.st-tab-btn:hover:not(.active) { color: var(--text-2); }
.st-tab-btn.active {
  background: rgba(255,255,255,.1);
  box-shadow: 0 1px 6px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.07);
  outline: 1px solid rgba(200,169,81,.55);
  color: var(--text);
}
body.light-mode .st-tab-btn.active { background: #fff; box-shadow: 0 1px 5px rgba(0,0,0,.12); outline: 1px solid rgba(200,169,81,.6); color: var(--text); }

/* Settings cards */
.ss-card {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--r); overflow: hidden;
  margin-bottom: 20px;
}
.ss-card:last-child { margin-bottom: 0; }
.ss-card-header {
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border);
}
.ss-card-title {
  font-size: .72rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-1); margin-bottom: 4px;
}
.ss-card-sub {
  font-family: 'Cormorant Garamond', serif;
  font-size: .92rem; color: var(--text-3); font-style: italic;
}

/* Two-column field grid */
.ss-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* Pill group */
/* ── Theme picker cards ── */
.theme-card-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  width: 100%;
}
.theme-pick-card {
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  text-align: left;
  padding: 0;
  transition: border-color .2s;
}
.theme-pick-card:hover  { border-color: rgba(200,160,69,.3); }
.theme-pick-card.active { border-color: var(--gold); }

.tpc-preview {
  height: 52px; width: 100%;
  position: relative; overflow: hidden;
}
.tpc-preview::before, .tpc-preview::after { content: ''; position: absolute; border-radius: 2px; }
.tpc-sys { background: linear-gradient(135deg, #0a0a0a 50%, #f0ece3 50%); }
.tpc-sys::before { top: 12px; left: 8px; width: 34%; height: 4px; background: rgba(200,160,69,.35); }
.tpc-sys::after  { top: 20px; left: 8px; width: 22%; height: 3px; background: rgba(200,160,69,.18); }
.tpc-drk { background: #0a0a0a; }
.tpc-drk::before { top: 12px; left: 8px; right: 8px; height: 4px; background: rgba(200,160,69,.28); }
.tpc-drk::after  { top: 20px; left: 8px; width: 55%; height: 3px; background: rgba(240,235,224,.1); }
.tpc-lgt { background: #f0ece3; }
.tpc-lgt::before { top: 12px; left: 8px; right: 8px; height: 4px; background: rgba(139,90,20,.22); }
.tpc-lgt::after  { top: 20px; left: 8px; width: 55%; height: 3px; background: rgba(24,21,15,.12); }
.tpc-sep { background: #100c07; }
.tpc-sep::before { top: 12px; left: 8px; right: 8px; height: 4px; background: rgba(200,160,69,.35); }
.tpc-sep::after  { top: 20px; left: 8px; width: 55%; height: 3px; background: rgba(236,227,200,.12); }

.tpc-footer {
  padding: 8px 9px 10px;
  border-top: 1px solid var(--edge);
  display: flex; align-items: flex-start; justify-content: space-between; gap: 5px;
}
.tpc-footer-text { flex: 1; min-width: 0; }
.tpc-name {
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 3px;
}
.theme-pick-card.active .tpc-name { color: var(--gold); }
.tpc-desc {
  font-family: 'Montserrat', sans-serif;
  font-size: .54rem; color: var(--text-3); line-height: 1.5; letter-spacing: .02em;
}
.theme-pick-card.active .tpc-desc { color: var(--text-2); }
.tpc-radio {
  width: 12px; height: 12px; border-radius: 50%;
  border: 1.5px solid var(--border); flex-shrink: 0; margin-top: 1px;
}
.theme-pick-card.active .tpc-radio {
  background: var(--gold); border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(200,160,69,.15);
}

/* ── Line spacing live preview ── */
.ls-preview {
  width: 100%;
  background: var(--surface-2);
  border: 1px solid var(--edge);
  border-radius: 8px;
  padding: 14px 16px 12px;
  position: relative;
  margin-top: 2px;
}
.ls-preview-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: .9rem; color: var(--text-2);
  line-height: 1.75; /* default: comfortable */
  transition: line-height .25s ease;
  margin: 0;
}
.ls-preview-label {
  position: absolute; top: 10px; right: 12px;
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-3);
  transition: opacity .15s;
}

/* ── Writing Prompts preview card ── */
.wp-preview {
  width: 100%;
  background: var(--surface-2);
  border: 1px solid var(--edge);
  border-radius: 8px;
  padding: 14px 16px 13px;
  margin-top: 2px;
  overflow: hidden;
  max-height: 120px;
  opacity: 1;
  transition: max-height .3s var(--ease), opacity .25s var(--ease), padding .3s var(--ease);
}
.wp-preview.hidden {
  max-height: 0;
  opacity: 0;
  padding-top: 0;
  padding-bottom: 0;
  pointer-events: none;
}
.wp-preview-eyebrow {
  font-size: .52rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--gold); opacity: .7; margin-bottom: 6px;
}
.wp-preview-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: .92rem; font-style: italic; color: var(--text-2); line-height: 1.5;
  margin-bottom: 8px;
}
.wp-preview-cta {
  font-size: .58rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3);
}

.pill-group { display: flex; gap: 6px; flex-wrap: wrap; }
.pill-btn {
  font-family: 'Montserrat', sans-serif;
  font-size: .65rem; font-weight: 600;
  letter-spacing: .09em; text-transform: uppercase;
  padding: 6px 14px; border-radius: 99px;
  border: 1px solid var(--border);
  background: transparent; color: var(--text-3);
  cursor: pointer;
  transition: background .18s var(--ease), color .18s var(--ease), border-color .18s var(--ease);
}
.pill-btn:hover { color: var(--text-2); border-color: rgba(255,255,255,.16); }
.pill-btn.active { background: var(--gold-lo); color: var(--gold-hi); border-color: rgba(200,169,81,.38); }
.pill-btn[disabled] { opacity: .4; cursor: default; pointer-events: none; }

/* Radio group */
.radio-group { display: flex; flex-direction: column; gap: 10px; }
.radio-row {
  display: flex; align-items: center; gap: 12px; cursor: pointer;
}
.radio-dot {
  width: 18px; height: 18px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  flex-shrink: 0; position: relative;
  transition: border-color .18s var(--ease);
}
.radio-row.active .radio-dot { border-color: var(--gold-hi); }
.radio-row.active .radio-dot::after {
  content: ''; position: absolute;
  top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 8px; height: 8px;
  border-radius: 50%; background: var(--gold-hi);
}
.radio-text { font-size: .8rem; color: var(--text-2); transition: color .18s var(--ease); }
.radio-row.active .radio-text { color: var(--text-1); }

/* ss-pref-row column variant */
.ss-pref-row-col { flex-direction: column; align-items: flex-start; gap: 12px; }
.ss-pref-row-col .ss-pref-info { width: 100%; }

/* Danger zone rows */
.ss-danger-row {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 8px 0; border-bottom: 1px solid rgba(200,16,46,.1);
}
.ss-danger-row:last-child { border-bottom: none; }
.ss-danger-card { border-color: rgba(200,16,46,.18); }
/* Your Plan section */
.ss-plan-tier {
  font-family: 'Cormorant Garamond', serif; font-size: 1.35rem; font-weight: 600;
  color: var(--text-1); margin-bottom: 8px; display: flex; align-items: center; gap: 10px;
}
.ss-plan-tier-pro { color: var(--gold); }
.ss-plan-badge {
  font-family: 'Montserrat', sans-serif; font-size: .52rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  background: rgba(255,255,255,.07); color: var(--text-2);
  border: 1px solid var(--edge); padding: 3px 8px; border-radius: 4px;
}
.ss-plan-badge-pro {
  background: rgba(200,169,81,.1); color: var(--gold);
  border-color: rgba(200,169,81,.3);
}
.ss-plan-desc { font-family: 'Cormorant Garamond', serif; font-size: .98rem; color: var(--text-2); line-height: 1.65; margin-bottom: 14px; }
.ss-plan-billing { font-family: 'Montserrat', sans-serif; font-size: .72rem; font-weight: 600; letter-spacing: .1em; color: var(--gold); margin-bottom: 16px; }
.ss-plan-features { display: flex; flex-direction: column; gap: 7px; margin-bottom: 18px; }
.ss-plan-feature {
  font-family: 'Cormorant Garamond', serif; font-size: .92rem; color: var(--text-2);
  padding-left: 14px; position: relative;
}
.ss-plan-feature::before { content: '—'; position: absolute; left: 0; color: var(--text-3); font-size: .8rem; }
/* .btn-danger + .btn-delete → replaced by .btn.btn-destructive */
.signout-yes-delete { background: rgba(200,16,46,.15) !important; }
.signout-yes-delete:hover { background: rgba(200,16,46,.28) !important; }
.signout-yes-delete:disabled { opacity: .35; pointer-events: none; }
.delete-confirm-input {
  width: 100%; box-sizing: border-box; margin: 18px 0 4px;
  text-align: center; letter-spacing: .12em; font-size: 1rem;
}

/* ── 2FA WIZARD (v2) — always dark, always cinematic ──────── */
@keyframes wiz-emerge {
  from { opacity: 0; transform: translateY(20px) scale(.975); }
  to   { opacity: 1; }
  /* filter:blur removed from BOTH from and to — any non-none filter value
     (including blur(0)) creates a CSS stacking context for the full animation
     duration, causing a hit-test / visual position mismatch in Chrome & Safari.
     The entrance still looks clean with just opacity + translateY + scale. */
}
@keyframes wiz-ring-breathe {
  0%, 100% { transform: scale(1);    opacity: .22; }
  50%       { transform: scale(1.08); opacity: .1; }
}
@keyframes wiz-ring-rotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes wiz-scan-line {
  0%   { top: 10%; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { top: 90%; opacity: 0; }
}
@keyframes wiz-check-in {
  0%   { stroke-dashoffset: 70; opacity: 0; }
  40%  { opacity: 1; }
  100% { stroke-dashoffset: 0; opacity: 1; }
}
@keyframes wiz-gold-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(200,169,81,0); }
  50%       { box-shadow: 0 0 0 8px rgba(200,169,81,.06); }
}
@keyframes wiz-shimmer {
  from { transform: translateX(-100%) skewX(-12deg); }
  to   { transform: translateX(200%)  skewX(-12deg); }
}

/* Card */
.wiz-card {
  background: #0a0908;
  background-image:
    radial-gradient(ellipse at 50% -5%,  rgba(200,169,81,.12) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 105%, rgba(160,20,40,.06)  0%, transparent 50%),
    radial-gradient(ellipse at 0%   50%, rgba(200,169,81,.03) 0%, transparent 40%),
    radial-gradient(ellipse at 100% 50%, rgba(200,169,81,.03) 0%, transparent 40%);
  border: 1px solid rgba(255,255,255,.07);
  border-top: 1px solid rgba(200,169,81,.55);
  border-radius: 24px;
  width: 500px;
  padding: 44px 44px 40px;
  text-align: center;
  box-shadow:
    0 80px 160px rgba(0,0,0,.95),
    0 24px 48px  rgba(0,0,0,.6),
    0 0 0 1px    rgba(255,255,255,.03),
    inset 0 1px 0 rgba(255,255,255,.07),
    inset 0 -1px 0 rgba(0,0,0,.4);
  position: relative; overflow: hidden;
  isolation: isolate; /* own stacking context — keeps ::after behind children */
  /* animation lives on .wiz-card.entering only — base style must NOT have it
     or removing the class causes a restart loop and permanent stacking context */
}
.wiz-card::before {
  content: '';
  position: absolute; top: -1px; left: 50%; transform: translateX(-50%);
  width: 100px; height: 2px;
  background: linear-gradient(90deg, transparent, rgba(200,169,81,1), transparent);
  border-radius: 0 0 2px 2px; filter: blur(.5px);
  pointer-events: none;
}
.wiz-card::after {
  content: ''; position: absolute; inset: 0; border-radius: 24px;
  z-index: -1; pointer-events: none;
  background: radial-gradient(ellipse at 50% 0%, rgba(200,169,81,.04) 0%, transparent 60%);
}

/* Step counter */
.wiz-step-counter {
  font-size: .45rem; font-weight: 700; letter-spacing: .3em; text-transform: uppercase;
  color: rgba(200,169,81,.4); margin-bottom: 30px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
}
.wiz-step-counter-bar { display: flex; gap: 5px; align-items: center; }
.wiz-step-pip {
  height: 2px; width: 14px; border-radius: 99px;
  background: rgba(255,255,255,.1);
  transition: all .35s cubic-bezier(.22,.68,0,1.2);
}
.wiz-step-pip.done   { background: rgba(200,169,81,.4); }
.wiz-step-pip.active { background: rgba(200,169,81,.9); width: 28px; }
.wiz-step-pip.hidden { opacity: 0; width: 0; margin: 0; }

/* Eyebrow / title / sub */
.wiz-eyebrow {
  font-size: .47rem; font-weight: 700; letter-spacing: .38em; text-transform: uppercase;
  color: rgba(200,169,81,.6); margin-bottom: 14px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
}
.wiz-eyebrow::before, .wiz-eyebrow::after {
  content: ''; display: block; width: 20px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,169,81,.4));
}
.wiz-eyebrow::after { transform: scaleX(-1); }
.wiz-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem; font-weight: 600; font-style: italic;
  color: rgba(245,240,228,1); line-height: 1.15; margin-bottom: 12px; letter-spacing: -.01em;
}
.wiz-sub {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.02rem; color: rgba(240,235,224,.38); line-height: 1.8;
  margin: 0 auto 32px; max-width: 360px;
}
.wiz-msg {
  font-family: 'Cormorant Garamond', serif; font-size: .9rem; font-style: italic;
  min-height: 1.2em; margin-bottom: 10px;
}
.wiz-msg.ok  { color: rgba(80,190,120,.8); }
.wiz-msg.err { color: rgba(215,80,80,.8); }

/* Method list */
.method-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 24px; }
.method-card {
  display: flex; align-items: center; gap: 16px;
  padding: 17px 20px; border-radius: 14px;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
  cursor: pointer; text-align: left;
  transition: all .25s cubic-bezier(.22,.68,0,1.2);
  position: relative; overflow: hidden;
}
.method-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(200,169,81,.07) 50%, transparent 60%);
  transform: translateX(-100%) skewX(-12deg);
}
.method-card:hover::before { animation: wiz-shimmer .5s ease forwards; }
.method-card:hover {
  border-color: rgba(200,169,81,.3); background: rgba(200,169,81,.04);
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(0,0,0,.6), 0 0 0 1px rgba(200,169,81,.1);
}
.method-card:active { transform: translateY(0) scale(.99); }
.method-card.recommended {
  border-color: rgba(200,169,81,.2); background: rgba(200,169,81,.035);
  animation: wiz-gold-pulse 4s ease-in-out infinite;
}
.method-card.recommended:hover {
  border-color: rgba(200,169,81,.48); background: rgba(200,169,81,.08); animation: none;
}
.method-card.weak { opacity: .55; }
.method-card.weak:hover { opacity: .9; }
.method-icon {
  width: 42px; height: 42px; flex-shrink: 0; border-radius: 11px;
  display: flex; align-items: center; justify-content: center;
  position: relative; z-index: 1;
  transition: transform .25s cubic-bezier(.22,.68,0,1.2);
}
.method-card:hover .method-icon { transform: scale(1.08); }
.method-card.recommended .method-icon { background: rgba(200,169,81,.1); border: 1px solid rgba(200,169,81,.25); }
.method-card:not(.recommended) .method-icon { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); }
.method-card.weak .method-icon { background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.05); }
.method-body { flex: 1; min-width: 0; position: relative; z-index: 1; }
.method-label {
  font-size: .6rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(240,235,224,.92); margin-bottom: 5px;
  display: flex; align-items: center; gap: 8px;
}
.method-badge { font-size: .42rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; padding: 2px 8px; border-radius: 99px; }
.method-badge.gold   { background: rgba(200,169,81,.12); border: 1px solid rgba(200,169,81,.3); color: rgba(200,169,81,.85); }
.method-badge.muted  { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); color: rgba(240,235,224,.3); }
.method-hint { font-family: 'Cormorant Garamond', serif; font-size: .92rem; color: rgba(240,235,224,.32); line-height: 1.45; }
.method-card.recommended .method-hint { color: rgba(240,235,224,.48); }
.method-arrow {
  flex-shrink: 0; z-index: 1; opacity: 0;
  transform: translateX(-5px);
  transition: opacity .2s, transform .25s cubic-bezier(.22,.68,0,1.2);
}
.method-card:hover .method-arrow { opacity: .35; transform: translateX(0); }
.method-sep { display: flex; align-items: center; gap: 12px; margin: 4px 0; }
.method-sep-line { flex: 1; height: 1px; background: rgba(255,255,255,.05); }
.method-sep-text { font-size: .43rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: rgba(240,235,224,.18); }

/* Biometric */
.bio-wrap { position: relative; width: 120px; height: 120px; margin: 0 auto 24px; }
.bio-ring-a { position: absolute; inset: -16px; border-radius: 50%; border: 1px dashed rgba(200,169,81,.15); animation: wiz-ring-rotate 18s linear infinite; }
.bio-ring-b { position: absolute; inset: -6px; border-radius: 50%; border: 1px solid rgba(200,169,81,.1); animation: wiz-ring-breathe 3.2s ease-in-out infinite; }
.bio-circle { width: 120px; height: 120px; border-radius: 50%; background: radial-gradient(ellipse at 50% 30%, rgba(200,169,81,.09), rgba(200,169,81,.02)); border: 1px solid rgba(200,169,81,.2); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.bio-scan-line { position: absolute; left: 15%; right: 15%; height: 1px; background: linear-gradient(90deg, transparent, rgba(200,169,81,.7), transparent); top: 10%; animation: wiz-scan-line 2.4s cubic-bezier(.4,0,.6,1) infinite; filter: blur(.5px); }
.bio-platform-chips { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin-bottom: 20px; }
.bio-chip { display: inline-flex; align-items: center; gap: 6px; font-size: .46rem; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; color: rgba(240,235,224,.35); background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.07); border-radius: 99px; padding: 6px 12px; }

/* Security label */
.sec-label { display: inline-flex; align-items: center; gap: 7px; font-size: .46rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; margin-bottom: 28px; justify-content: center; }
.sec-label-dot { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }
.sec-label.high  { color: rgba(80,190,120,.7); }
.sec-label.high  .sec-label-dot { background: rgba(80,190,120,.7); box-shadow: 0 0 6px rgba(80,190,120,.4); }
.sec-label.best  { color: rgba(80,190,120,.85); }
.sec-label.best  .sec-label-dot { background: rgba(80,190,120,.85); box-shadow: 0 0 8px rgba(80,190,120,.5); }
.sec-label.basic { color: rgba(200,169,81,.55); }
.sec-label.basic .sec-label-dot { background: rgba(200,169,81,.55); }

/* QR */
.qr-frame { position: relative; margin: 0 auto 18px; width: 148px; height: 148px; }
.qr-frame::before, .qr-frame::after { content: ''; position: absolute; width: 16px; height: 16px; z-index: 2; }
.qr-frame::before { top: -2px; left: -2px; border-top: 2px solid rgba(200,169,81,.6); border-left: 2px solid rgba(200,169,81,.6); border-radius: 3px 0 0 0; }
.qr-frame::after  { top: -2px; right: -2px; border-top: 2px solid rgba(200,169,81,.6); border-right: 2px solid rgba(200,169,81,.6); border-radius: 0 3px 0 0; }
.qr-frame-bl { position: absolute; width: 16px; height: 16px; bottom: -2px; left: -2px; border-bottom: 2px solid rgba(200,169,81,.6); border-left: 2px solid rgba(200,169,81,.6); border-radius: 0 0 0 3px; z-index: 2; }
.qr-frame-br { position: absolute; width: 16px; height: 16px; bottom: -2px; right: -2px; border-bottom: 2px solid rgba(200,169,81,.6); border-right: 2px solid rgba(200,169,81,.6); border-radius: 0 0 3px 0; z-index: 2; }
.qr-surface { width: 148px; height: 148px; background: #f5f2ec; border-radius: 10px; display: flex; align-items: center; justify-content: center; overflow: hidden; position: relative; }
.qr-inner-grid { width: 116px; height: 116px; background-color: #f5f2ec; background-image: linear-gradient(#1a1610 100%, transparent 0), linear-gradient(#1a1610 100%, transparent 0), linear-gradient(#1a1610 100%, transparent 0), radial-gradient(circle, #1a1610 40%, transparent 40%); background-size: 28px 28px, 28px 28px, 28px 28px, 5px 5px; background-position: 0 0, 88px 0, 0 88px, 0 0; background-repeat: no-repeat, no-repeat, no-repeat, repeat; display: flex; align-items: center; justify-content: center; }
.qr-logo-mark { width: 26px; height: 26px; border-radius: 5px; background: #f5f2ec; border: 1.5px solid #1a1610; display: flex; align-items: center; justify-content: center; z-index: 2; }
.manual-key-block { display: flex; align-items: center; gap: 10px; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.07); border-radius: 10px; padding: 11px 16px; margin-bottom: 18px; cursor: pointer; transition: all .2s; }
.manual-key-block:hover { border-color: rgba(200,169,81,.25); background: rgba(200,169,81,.03); }
.manual-key-code { flex: 1; font-family: 'Courier New', monospace; font-size: .66rem; color: rgba(240,235,224,.4); letter-spacing: .15em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.manual-key-btn { font-size: .46rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: rgba(200,169,81,.55); flex-shrink: 0; padding: 4px 8px; border: 1px solid rgba(200,169,81,.2); border-radius: 5px; background: rgba(200,169,81,.06); transition: all .18s; }
.manual-key-block:hover .manual-key-btn { color: rgba(200,169,81,.9); border-color: rgba(200,169,81,.4); }

/* Phone / SMS */
.phone-row { display: flex; gap: 8px; margin-bottom: 16px; }
.phone-cc { width: 76px; flex-shrink: 0; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.09); border-radius: 10px; padding: 13px 10px; font-family: 'Montserrat', sans-serif; font-size: .68rem; font-weight: 600; color: rgba(240,235,224,.6); text-align: center; cursor: pointer; transition: border-color .18s; }
.phone-cc:hover { border-color: rgba(200,169,81,.28); }
.phone-input { flex: 1; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.09); border-radius: 10px; padding: 13px 15px; font-family: 'Montserrat', sans-serif; font-size: .78rem; color: rgba(240,235,224,.85); outline: none; transition: border-color .2s, background .2s; }
.phone-input::placeholder { color: rgba(240,235,224,.2); }
.phone-input:focus { border-color: rgba(200,169,81,.42); background: rgba(200,169,81,.025); }
.sms-notice { display: flex; align-items: flex-start; gap: 10px; background: rgba(200,169,81,.04); border: 1px solid rgba(200,169,81,.13); border-radius: 10px; padding: 12px 15px; margin-bottom: 20px; text-align: left; }
.sms-notice-text { font-family: 'Cormorant Garamond', serif; font-size: .88rem; color: rgba(200,169,81,.55); line-height: 1.6; }

/* Code digits */
.code-row { display: flex; gap: 9px; justify-content: center; margin-bottom: 16px; }
.code-digit { width: 50px; height: 60px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.09); border-radius: 12px; font-family: 'Montserrat', sans-serif; font-size: 1.4rem; font-weight: 600; color: rgba(240,235,224,.95); text-align: center; outline: none; caret-color: rgba(200,169,81,.9); transition: border-color .18s, background .18s, transform .15s; }
.code-digit:focus { border-color: rgba(200,169,81,.5); background: rgba(200,169,81,.04); transform: translateY(-1px); }
.code-digit.filled { border-color: rgba(200,169,81,.3); background: rgba(200,169,81,.035); }
.code-foot { font-family: 'Cormorant Garamond', serif; font-size: .9rem; color: rgba(240,235,224,.28); margin-bottom: 16px; }
.code-foot a { color: rgba(200,169,81,.5); text-decoration: none; cursor: pointer; transition: color .15s; }
.code-foot a:hover { color: rgba(200,169,81,.85); }

/* Backup codes */
.backup-panel { background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.06); border-radius: 14px; padding: 20px; margin-bottom: 14px; position: relative; overflow: hidden; }
.backup-panel::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(200,169,81,.2), transparent); }
.backup-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 24px; }
.backup-code-item { display: flex; align-items: center; gap: 8px; }
.backup-code-num { font-size: .42rem; font-weight: 700; letter-spacing: .1em; color: rgba(200,169,81,.3); width: 14px; text-align: right; flex-shrink: 0; }
.backup-code-val { font-family: 'Courier New', monospace; font-size: .72rem; color: rgba(240,235,224,.58); letter-spacing: .12em; padding: 5px 0; user-select: all; }
.backup-code-val:hover { color: rgba(240,235,224,.85); }
.backup-actions { display: flex; gap: 8px; justify-content: center; margin-bottom: 16px; }
.backup-action { display: inline-flex; align-items: center; gap: 6px; font-family: 'Montserrat', sans-serif; font-size: .48rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: rgba(240,235,224,.38); background: none; border: 1px solid rgba(255,255,255,.08); border-radius: 99px; padding: 8px 14px; cursor: pointer; transition: all .18s; }
.backup-action:hover { color: rgba(240,235,224,.75); border-color: rgba(255,255,255,.2); }
.backup-alert { display: flex; gap: 10px; align-items: flex-start; background: rgba(180,30,50,.05); border: 1px solid rgba(180,30,50,.14); border-radius: 10px; padding: 12px 15px; margin-bottom: 26px; text-align: left; }
.backup-alert-text { font-family: 'Cormorant Garamond', serif; font-size: .88rem; color: rgba(210,80,80,.65); line-height: 1.6; }

/* Success */
.success-emblem { width: 84px; height: 84px; margin: 0 auto 26px; border-radius: 50%; background: radial-gradient(ellipse at 50% 30%, rgba(200,169,81,.1), rgba(200,169,81,.03)); border: 1px solid rgba(200,169,81,.22); display: flex; align-items: center; justify-content: center; box-shadow: 0 0 0 8px rgba(200,169,81,.04), 0 0 0 16px rgba(200,169,81,.015); animation: wiz-gold-pulse 3s ease-in-out infinite; }
.wiz-checkmark { animation: wiz-check-in .55s .1s cubic-bezier(.22,.68,0,1.2) forwards; }
.success-method-tag { display: inline-flex; align-items: center; gap: 8px; font-size: .5rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(200,169,81,.7); background: rgba(200,169,81,.07); border: 1px solid rgba(200,169,81,.2); border-radius: 99px; padding: 7px 16px; margin-bottom: 28px; }
.success-method-tag::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: rgba(200,169,81,.7); box-shadow: 0 0 6px rgba(200,169,81,.4); flex-shrink: 0; }

/* Disable */
.disable-emblem { width: 60px; height: 60px; margin: 0 auto 22px; border-radius: 50%; background: rgba(180,30,50,.06); border: 1px solid rgba(180,30,50,.18); display: flex; align-items: center; justify-content: center; }

/* Wizard buttons */
.btn-row { display: flex; gap: 10px; justify-content: center; position: relative; z-index: 1; }
.wiz-btn { font-family: 'Montserrat', sans-serif; font-size: .56rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; border-radius: 99px; padding: 14px 30px; cursor: pointer; transition: all .22s cubic-bezier(.22,.68,0,1.2); position: relative; overflow: hidden; }
.wiz-btn::before { content: ''; position: absolute; inset: 0; background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.06) 50%, transparent 60%); transform: translateX(-100%) skewX(-12deg); }
.wiz-btn:hover::before { animation: wiz-shimmer .45s ease forwards; }
.wiz-btn:active { transform: scale(.97); }
.wiz-btn-primary { background: linear-gradient(135deg, rgba(200,169,81,.2), rgba(200,169,81,.12)); border: 1px solid rgba(200,169,81,.45); color: rgba(200,169,81,.95); box-shadow: 0 4px 16px rgba(200,169,81,.08), inset 0 1px 0 rgba(255,255,255,.06); }
.wiz-btn-primary:hover { background: linear-gradient(135deg, rgba(200,169,81,.3), rgba(200,169,81,.2)); border-color: rgba(200,169,81,.7); box-shadow: 0 8px 28px rgba(200,169,81,.18); transform: translateY(-1px); }
.wiz-btn-primary:disabled { opacity: .3; cursor: default; transform: none !important; pointer-events: none; }
.wiz-btn-primary.loading { pointer-events: none; color: transparent; }
.wiz-btn-primary.loading::after { content: ''; position: absolute; top: 50%; left: 50%; width: 13px; height: 13px; margin: -6.5px 0 0 -6.5px; border: 1.5px solid rgba(200,169,81,.3); border-top-color: rgba(200,169,81,.9); border-radius: 50%; animation: btn-spin .7s linear infinite; }
.wiz-btn-ghost { background: none; border: 1px solid rgba(255,255,255,.09); color: rgba(240,235,224,.32); }
.wiz-btn-ghost:hover { border-color: rgba(255,255,255,.22); color: rgba(240,235,224,.65); transform: translateY(-1px); }
.wiz-btn-danger { background: rgba(180,30,50,.08); border: 1px solid rgba(180,30,50,.28); color: rgba(215,80,80,.9); }
.wiz-btn-danger:hover { background: rgba(180,30,50,.16); border-color: rgba(180,30,50,.5); box-shadow: 0 6px 24px rgba(180,30,50,.15); transform: translateY(-1px); }
.wiz-btn-danger:disabled { opacity: .3; cursor: default; transform: none !important; pointer-events: none; }
.wiz-btn-danger.loading { pointer-events: none; color: transparent; }
.wiz-btn-danger.loading::after { content: ''; position: absolute; top: 50%; left: 50%; width: 13px; height: 13px; margin: -6.5px 0 0 -6.5px; border: 1.5px solid rgba(215,80,80,.3); border-top-color: rgba(215,80,80,.9); border-radius: 50%; animation: btn-spin .7s linear infinite; }

/* Settings hint — active 2FA state */
.ss-pref-hint-active { display: inline-flex; align-items: center; gap: 5px; font-size: .48rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: rgba(80,190,120,.75); font-family: 'Montserrat', sans-serif; }

/* ═══════════════════════════════════════════════════════════════
   SHARED — Empty States
═══════════════════════════════════════════════════════════════ */
.empty-state {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 60px 24px;
  color: var(--text-3);
}
.empty-icon { margin-bottom: 18px; opacity: .4; }
.empty-title { font-size: 1rem; font-weight: 600; color: var(--text-2); margin-bottom: 8px; }
.empty-sub   { font-size: .82rem; line-height: 1.6; max-width: 320px; }
.hidden { display: none !important; }

/* Light mode overrides */
body.light-mode .mp-card,
body.light-mode .jstat,
body.light-mode .jt-entry,
body.light-mode .piece-card,
body.light-mode .settings-section,
body.light-mode .tw-pillar-card,
body.light-mode .tw-reflection {
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset, 0 2px 12px rgba(0,0,0,.06);
}
body.light-mode .tw-tag {
  border-color: rgba(0,0,0,.16);
  color: rgba(24,21,15,.5);
}
body.light-mode .ss-input { background: #fff; }
body.light-mode .ss-toggle { background: rgba(0,0,0,.12); }
body.light-mode .ss-toggle.on { background: var(--gold-hi); }

/* ── My Orders — light mode ── */
body.light-mode .piece-cover {
  background: linear-gradient(135deg, rgba(200,169,81,.1) 0%, rgba(232,226,214,0) 100%) !important;
  border-bottom-color: rgba(0,0,0,.08);
}
body.light-mode .piece-cover-merch {
  background: linear-gradient(135deg, rgba(0,0,0,.05) 0%, rgba(232,226,214,0) 100%) !important;
}
body.light-mode .piece-cover-text { color: rgba(200,169,81,.28); }
body.light-mode .piece-badge {
  background: rgba(255,255,255,.7); border-color: rgba(0,0,0,.1); color: var(--text-2);
}
body.light-mode .orders-empty-header .empty-icon {
  background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1);
}
body.light-mode .orders-featured-label { border-top-color: rgba(0,0,0,.1); color: var(--text-3); }
body.light-mode .piece-tagline { color: var(--text-3); }
/* .btn-ghost-gold → replaced by .btn.btn-pro (guides) or .btn.btn-primary (merch) */
body.light-mode .phys-order-icon {
  background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1);
}
body.light-mode .phys-card { box-shadow: 0 1px 0 rgba(255,255,255,.7) inset, 0 2px 8px rgba(0,0,0,.05); }

/* ── COPYRIGHT FOOTER ─────────────────────── */
.lila-copyright {
  position: fixed;
  bottom: 0;
  left: var(--sb-w);
  right: var(--panel-w);
  text-align: center;
  padding: 14px 24px;
  font-size: .73rem;
  letter-spacing: .07em;
  color: var(--text-2);
  opacity: 0;
  user-select: none;
  pointer-events: none;
  z-index: 10;
  background: linear-gradient(transparent, rgba(10,10,10,.6));
  transition: opacity .5s var(--ease);
}
.lila-copyright.visible { opacity: .82; }
.lila-copyright.visible a { pointer-events: auto; }
.main.sb-collapsed ~ footer.lila-copyright { left: var(--sb-w-c); }
.lila-copyright-sep { margin: 0 .5em; opacity: .45; }
.lila-copyright a { color: inherit; text-decoration: none; }
.lila-copyright a:hover { opacity: .75; text-decoration: underline; }
body.light-mode .lila-copyright { color: rgba(24,21,15,.7); background: linear-gradient(transparent, rgba(220,212,198,.65)); }

/* ══════════════════════════════════════════════════════════
   VIEW BODY — shared content wrapper
   Matches view-header's horizontal padding (--view-pad).
   The Work, My Practice, My Orders, My Journey all use this.
══════════════════════════════════════════════════════════ */
.view-body { padding: 0 48px 80px; }

/* ══════════════════════════════════════════════════════════
   THE WORK VIEW
══════════════════════════════════════════════════════════ */
.tw-intro {
  font-size: .8rem;
  color: var(--text-2);
  line-height: 1.75;
  max-width: 580px;
  margin-bottom: 28px;
}

.tw-progress {
  font-size: .55rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 16px;
  min-height: 1em;
}
.tw-progress-count { color: var(--gold-hi); }

/* ── The Work: Pillar Accordion Cards (B+C) ── */
.tw-pillar-stack {
  display: flex; flex-direction: column; gap: 12px; margin-bottom: 32px;
}

.tw-pillar-card {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  transition: border-color .22s var(--ease);
}
.tw-pillar-card:not(.open):hover { border-color: rgba(255,255,255,.15); }
.tw-pillar-card--sacred-human:not(.open):hover { border-color: rgba(200,16,46,.32); }
.tw-pillar-card--truestory:not(.open):hover     { border-color: rgba(200,169,81,.28); }
.tw-pillar-card--mother-earth:not(.open):hover  { border-color: rgba(74,143,66,.32); }
.tw-pillar-card--sacred-human.open  { border-color: rgba(200,16,46,.28); }
.tw-pillar-card--truestory.open     { border-color: rgba(200,169,81,.26); }
.tw-pillar-card--mother-earth.open  { border-color: rgba(74,143,66,.28); }

/* Top color bar */
.tw-pillar-bar { height: 3px; }
.tw-pillar-card--sacred-human  .tw-pillar-bar { background: linear-gradient(90deg, #C8102E, rgba(200,16,46,.2)); }
.tw-pillar-card--truestory     .tw-pillar-bar { background: linear-gradient(90deg, #C8A951, rgba(200,169,81,.2)); }
.tw-pillar-card--mother-earth  .tw-pillar-bar { background: linear-gradient(90deg, #4a8f42, rgba(74,143,66,.2)); }

/* Header */
.tw-pillar-header {
  display: flex; align-items: center; gap: 16px;
  padding: 20px 24px; cursor: pointer; user-select: none;
  transition: background .18s;
}
.tw-pillar-header:hover { background: rgba(255,255,255,.018); }
.tw-pillar-card.open .tw-pillar-header { padding-bottom: 18px; border-bottom: 1px solid var(--edge); }

.tw-pillar-h-info { flex: 1; }
.tw-pillar-love {
  font-family: 'Montserrat', sans-serif;
  font-size: .46rem; font-weight: 600; letter-spacing: .34em; text-transform: uppercase; margin-bottom: 3px;
}
.tw-pillar-card--sacred-human  .tw-pillar-love { color: #C8102E; }
.tw-pillar-card--truestory     .tw-pillar-love { color: #C8A951; }
.tw-pillar-card--mother-earth  .tw-pillar-love { color: #4a8f42; }

.tw-pillar-num-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .42rem; letter-spacing: .24em; text-transform: uppercase; color: var(--text-3); margin-left: 8px;
}
.tw-pillar-title-h {
  font-family: 'Playfair Display', serif;
  font-size: 1.45rem; font-weight: 800; line-height: 1.05; color: var(--text-1);
}
.tw-pillar-card--sacred-human  .tw-pillar-title-h em { color: #C8102E; font-style: italic; }
.tw-pillar-card--truestory     .tw-pillar-title-h em { color: #C8A951; font-style: italic; }
.tw-pillar-card--mother-earth  .tw-pillar-title-h em { color: #4a8f42; font-style: italic; }

.tw-pillar-h-right { display: flex; align-items: center; gap: 18px; flex-shrink: 0; }
.tw-pillar-pips-compact { display: flex; gap: 3px; }
.tw-pip-sm { height: 2px; width: 16px; border-radius: 2px; background: var(--border); transition: background .2s; }
.tw-pip-sm.done   { background: var(--gold-hi); }
.tw-pip-sm.active { background: var(--crimson); }
.tw-pillar-count {
  font-family: 'Montserrat', sans-serif;
  font-size: .45rem; letter-spacing: .18em; text-transform: uppercase; color: var(--text-3); white-space: nowrap;
}
.tw-pillar-chevron {
  width: 22px; height: 22px; display: flex; align-items: center; justify-content: center;
  color: var(--text-3); transition: transform .28s cubic-bezier(.4,0,.2,1), color .18s; flex-shrink: 0;
}
.tw-pillar-card.open .tw-pillar-chevron { transform: rotate(180deg); color: var(--text-2); }

/* Expandable body */
.tw-pillar-body { max-height: 0; overflow: hidden; transition: max-height .38s cubic-bezier(.4,0,.2,1); }
.tw-pillar-card.open .tw-pillar-body { max-height: 600px; }
.tw-pillar-body-inner { padding: 22px 24px 24px; }

/* Desc + stat row */
.tw-pillar-top-row { display: grid; grid-template-columns: 1fr 80px; gap: 24px; margin-bottom: 20px; align-items: start; }
.tw-pillar-desc { font-size: .82rem; color: var(--text-2); line-height: 1.75; }
.tw-pillar-stat { text-align: right; }
.tw-pillar-stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 2rem; font-weight: 800; color: var(--text-1); line-height: 1; margin-bottom: 2px;
}
.tw-pillar-stat-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .42rem; letter-spacing: .16em; text-transform: uppercase; color: var(--text-3);
}

/* Chapter chips — 6 across */
.tw-pillar-ch-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 7px; margin-bottom: 20px; }
.tw-pillar-ch-chip {
  font-family: 'Montserrat', sans-serif;
  font-size: .43rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-3); border: 1px solid var(--border); border-radius: 3px;
  padding: 10px 4px; text-align: center; cursor: pointer;
  transition: color .15s, border-color .15s, background .15s;
  display: flex; flex-direction: column; align-items: center; gap: 5px;
}
.tw-pillar-ch-chip:hover { color: var(--text-1); border-color: rgba(255,255,255,.22); background: rgba(255,255,255,.03); }
.tw-pillar-ch-chip.done   { color: var(--gold-hi); border-color: rgba(200,169,81,.25); background: rgba(200,169,81,.05); }
.tw-pillar-ch-chip.active { color: var(--text-1); border-color: rgba(255,255,255,.2); background: rgba(255,255,255,.04); }
.tw-pillar-ch-name { line-height: 1.2; }
.tw-pillar-ch-time { font-size: .38rem; color: var(--text-3); letter-spacing: .08em; }
.tw-pillar-ch-chip.done   .tw-pillar-ch-time { color: rgba(212,179,90,.45); }
.tw-pillar-ch-chip.active .tw-pillar-ch-time { color: var(--text-3); }
.tw-pillar-ch-chip:hover  .tw-pillar-ch-time { color: rgba(240,235,224,.35); }

/* Footer */
.tw-pillar-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 16px; border-top: 1px solid var(--edge);
}
.tw-pillar-footer-cta { display: flex; align-items: center; gap: 14px; }
.tw-pillar-status {
  font-family: 'Montserrat', sans-serif;
  font-size: .45rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-3);
}
.tw-pillar-status.in-progress { color: var(--gold-hi); }
.tw-pillar-status.complete    { color: var(--gold-hi); }
.tw-pillar-restart {
  font-family: 'Montserrat', sans-serif;
  font-size: .43rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--text-3); cursor: pointer; transition: color .15s;
}
.tw-pillar-restart:hover { color: var(--text-2); }

/* Completed state */
.tw-pillar-card--sacred-human.complete  { border-color: rgba(200,16,46,.22); }
.tw-pillar-card--truestory.complete     { border-color: rgba(200,169,81,.22); }
.tw-pillar-card--mother-earth.complete  { border-color: rgba(74,143,66,.22); }

/* Legacy aliases kept for light-mode box-shadow rule above */
.tw-card { display: none; }

.tw-love {
  font-size: .55rem;
  font-weight: 600;
  letter-spacing: .38em;
  text-transform: uppercase;
  color: var(--gold-hi);
  margin-bottom: 4px;
}
.tw-number {
  font-size: .55rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 10px;
}
.tw-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1.1;
  color: var(--text-1);
  margin-bottom: 10px;
}
.tw-title em { font-style: italic; color: var(--gold-hi); }
.tw-desc {
  font-size: .75rem;
  color: var(--text-2);
  line-height: 1.65;
  flex: 1;
  margin-bottom: 14px;
}
.tw-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 16px; }
.tw-tag {
  font-size: .52rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text-3);
  border: 1px solid var(--border);
  padding: 3px 8px;
  border-radius: 2px;
}

.tw-footer { margin-top: auto; padding-top: 14px; border-top: 1px solid var(--border); }

.tw-cta {
  font-size: .58rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold-hi);
}
.tw-card:hover .tw-cta { opacity: .8; }

.tw-pips { display: flex; gap: 3px; margin-bottom: 10px; }
.tw-pip { height: 2px; flex: 1; background: var(--border); border-radius: 2px; }
.tw-pip.done { background: var(--gold-hi); }
.tw-pip.active { background: var(--crimson); }

.tw-resume-main {
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text-1);
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 6px;
}
.tw-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--crimson); flex-shrink: 0; }
.tw-resume-sub {
  font-size: .57rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--text-3);
  cursor: pointer;
}
.tw-resume-sub:hover { color: var(--text-2); }

/* Reflection strip */
.tw-reflection {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-left: 3px solid rgba(200,169,81,.4);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-top: 8px;
}
.tw-ref-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.tw-ref-eyebrow {
  font-size: .55rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold-hi);
  opacity: .7;
  margin-bottom: 7px;
}
.tw-ref-question {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-style: italic;
  color: var(--text-1);
  line-height: 1.5;
}
.tw-ref-btn { white-space: nowrap; flex-shrink: 0; }

@media (max-width: 960px) {
  .tw-grid  { grid-template-columns: 1fr; }
}

/* ── Right panel cards ── */
.tw-rp-card { padding: 14px 16px; }

.tw-rp-big-stat {
  font-family: 'Playfair Display', serif;
  font-size: 2rem; font-weight: 800;
  color: var(--text-1); line-height: 1;
  margin: 10px 0 2px;
}
.tw-rp-big-stat span { font-size: 1rem; color: var(--text-3); font-weight: 400; }
.tw-rp-sub {
  font-size: .6rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 12px;
}
.tw-rp-bar-wrap {
  height: 3px; background: var(--edge); border-radius: 3px;
  overflow: hidden; margin-bottom: 7px;
}
.tw-rp-bar {
  height: 100%; border-radius: 3px;
  background: linear-gradient(90deg, var(--crimson), var(--gold));
  transition: width .6s var(--ease);
}
.tw-rp-pct {
  font-size: .58rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--gold-hi);
}

/* Continue reading card */
.tw-rp-cont-pill {
  display: inline-block;
  font-size: .5rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--text-3); border: 1px solid var(--border);
  padding: 2px 7px; border-radius: 2px; margin-bottom: 8px;
}
.tw-rp-cont-ch {
  font-family: 'Playfair Display', serif;
  font-size: .92rem; font-weight: 700; font-style: italic;
  color: var(--text-1); line-height: 1.25; margin-bottom: 3px;
}
.tw-rp-cont-pillar {
  font-size: .6rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 2px;
}
.tw-rp-cont-btn { margin-top: 10px !important; }
.tw-rp-cont-done {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: .9rem; color: var(--gold-hi); text-align: center;
  padding: 8px 0;
}
.tw-rp-empty {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: .85rem; color: var(--text-3); text-align: center;
  padding: 6px 0;
}

/* Streak card */
.tw-rp-streak-row { display: flex; align-items: baseline; gap: 6px; margin-top: 8px; }
.tw-rp-streak-num {
  font-family: 'Playfair Display', serif;
  font-size: 2rem; font-weight: 800; color: var(--gold-hi); line-height: 1;
}
.tw-rp-streak-label {
  font-size: .6rem; letter-spacing: .16em; text-transform: uppercase; color: var(--text-3);
}

/* Pillar progress bars */
.tw-rp-pillar-row { margin-bottom: 12px; }
.tw-rp-pillar-row:last-child { margin-bottom: 0; }
.tw-rp-pillar-head {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 5px;
}
.tw-rp-pillar-name {
  font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-2);
}
.tw-rp-pillar-meta {
  font-size: .58rem; letter-spacing: .08em; color: var(--text-3);
}
.tw-rp-pillar-track {
  height: 3px; background: var(--edge); border-radius: 3px; overflow: hidden;
}
.tw-rp-pillar-fill {
  height: 100%; border-radius: 3px; transition: width .5s var(--ease);
}

/* Pro panel */
.tw-rp-pro { border-color: rgba(200,169,81,.14) !important; }
.tw-rp-pro-list {
  list-style: none; padding: 0; margin: 10px 0 12px;
  display: flex; flex-direction: column; gap: 2px;
}
.tw-rp-pro-list li {
  cursor: pointer; padding: 5px 0 5px 16px; position: relative;
  border-radius: 5px;
  transition: background var(--t-fast) var(--ease);
}
.tw-rp-pro-list li::before {
  content: '✦'; position: absolute; left: 0; top: 6px;
  font-size: .46rem; color: var(--gold-hi); opacity: .45;
}
.tw-rp-pro-list li:hover { background: rgba(255,255,255,.03); }

/* Feature label */
.pro-feat-label {
  display: block;
  font-size: .65rem; color: var(--text-3);
  transition: color var(--t-fast) var(--ease);
  line-height: 1.3;
}
.tw-rp-pro-list li:hover .pro-feat-label { color: var(--text-2); }

/* Feature description — slides in on hover */
.pro-feat-desc {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: .76rem; font-style: italic;
  color: var(--text-3); line-height: 1.5;
  max-height: 0; overflow: hidden; opacity: 0;
  transition: max-height .28s var(--ease), opacity .22s var(--ease), padding-top .22s var(--ease);
  padding-top: 0;
}
.tw-rp-pro-list li:hover .pro-feat-desc {
  max-height: 60px; opacity: 1; padding-top: 4px;
}

.tw-rp-pro-btn { width: 100%; justify-content: center; }

/* ── Pro Features card — collapse control ────────────────── */
.pro-feat-card-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pro-feat-toggle {
  background: none; border: none; cursor: pointer;
  color: var(--text-3); line-height: 1;
  padding: 0 2px; margin-left: 8px; flex-shrink: 0;
  display: flex; align-items: center;
  transition: color var(--t-fast) var(--ease);
}
.pro-feat-toggle:hover { color: var(--text-1); }
.pro-feat-chevron {
  display: block;
  transition: transform .3s var(--ease);
  transform: rotate(180deg); /* default: pointing up = open */
}
.pro-feat-card.collapsed .pro-feat-chevron {
  transform: rotate(0deg); /* pointing down = closed */
}
.pro-feat-body {
  max-height: 600px; overflow: hidden;
  transition: max-height .35s var(--ease), opacity .3s var(--ease);
  opacity: 1;
}
.pro-feat-card.collapsed .pro-feat-body {
  max-height: 0; opacity: 0; overflow: hidden;
}

/* Light mode overrides — pillar chips */
body.light-mode .tw-pillar-ch-chip        { background: rgba(0,0,0,.02); }
body.light-mode .tw-pillar-ch-chip:hover  { background: rgba(0,0,0,.05); }
body.light-mode .tw-pillar-ch-chip.done   { background: rgba(200,169,81,.07); }
body.light-mode .tw-pillar-ch-chip.active { background: rgba(200,16,46,.04); }

/* ══════════════════════════════════════════════════════════
   MY ORDERS VIEW
══════════════════════════════════════════════════════════ */
.orders-panel { }
.orders-panel.hidden { display: none; }
.orders-browse-cta {
  padding: var(--sp-4) 0 var(--sp-5);
  border-top: 1px solid var(--edge);
  margin-top: var(--sp-3);
}
.orders-browse-link, .orders-viewall-link {
  font-size: var(--label-sm); letter-spacing: var(--track-sm);
  text-transform: uppercase; color: var(--gold);
  text-decoration: none; opacity: .7;
  transition: opacity .18s var(--ease);
}
.orders-browse-link:hover, .orders-viewall-link:hover { opacity: 1; }
.orders-viewall {
  padding: var(--sp-4) 0 var(--sp-2);
  text-align: center;
}

/* Empty state — polished */
.orders-empty-header {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 48px 24px 36px;
}
.orders-empty-header .empty-icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: rgba(255,255,255,.04); border: 1px solid var(--edge);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-3); margin-bottom: 18px;
}
.orders-empty-header .empty-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.35rem; font-weight: 600; font-style: italic;
  color: var(--text-1); margin-bottom: 8px;
}
.orders-empty-header .empty-sub {
  font-size: .78rem; color: var(--text-3); max-width: 320px; line-height: 1.6;
}

/* Featured products in empty state */
.orders-featured { padding: 0 0 48px; }
.orders-featured-label {
  font-size: .6rem; font-weight: 600; letter-spacing: .18em;
  text-transform: uppercase; color: var(--text-3);
  padding: 0 4px 16px; border-top: 1px solid var(--edge);
  padding-top: 28px; margin-bottom: 4px;
}
.orders-featured-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.piece-card-featured { opacity: .85; }
.piece-card-featured:hover { opacity: 1; }
.piece-cover-lg { height: 180px !important; }
.piece-cover-merch {
  background: linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(10,10,10,0) 100%) !important;
}
.piece-info-featured { padding: 18px 18px 14px; gap: 8px; }
.piece-tagline {
  font-size: .72rem; color: var(--text-3);
  font-style: italic; line-height: 1.5; letter-spacing: .01em;
}
/* .btn-ghost-gold removed — see .btn.btn-pro and .btn.btn-primary */

/* Physical order cards */
.physical-grid { display: flex; flex-direction: column; gap: 12px; }
.phys-card {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.phys-info { flex: 1; }
.phys-name { font-size: .8rem; font-weight: 600; color: var(--text-1); margin-bottom: 3px; }
.phys-meta { font-size: .65rem; color: var(--text-3); letter-spacing: .04em; }
.phys-status {
  font-size: .55rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
}
.phys-status.shipped { color: var(--gold-hi); background: rgba(200,169,81,.1); border: 1px solid rgba(200,169,81,.2); }
.phys-status.processing { color: var(--text-2); background: var(--bg-3); border: 1px solid var(--border); }
.phys-status.delivered { color: #5a9a5a; background: rgba(90,154,90,.1); border: 1px solid rgba(90,154,90,.2); }
.phys-order-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: rgba(255,255,255,.04); border: 1px solid var(--edge);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-3); flex-shrink: 0;
}
.phys-track-link {
  display: inline-block; margin-top: 5px;
  font-size: .66rem; color: var(--gold); letter-spacing: .04em;
  text-decoration: none; transition: opacity .15s;
}
.phys-track-link:hover { opacity: .72; }

/* ══════════════════════════════════════════════════════════
   BODY CHECK-IN — ZONE CARD GRID (Step 3 of Rhythm)
══════════════════════════════════════════════════════════ */
.bc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 20px 0 24px;
}
.bc-card {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--edge);
  border-radius: 12px;
  padding: 14px;
  cursor: pointer;
  transition: border-color .2s var(--ease), background .2s var(--ease), box-shadow .2s;
  user-select: none;
  position: relative;
}
.bc-card:hover { border-color: rgba(200,169,81,.3); }
.bc-card.checked {
  border-color: rgba(200,169,81,.45);
  background: rgba(200,169,81,.06);
}
.bc-card.checked .bc-check {
  background: var(--gold-hi);
  border-color: var(--gold-hi);
  color: #000;
}
.bc-card.checked .bc-state { color: rgba(100,210,140,.8); }
.bc-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 10px;
}
.bc-icon { font-size: 1.2rem; line-height: 1; }
.bc-check {
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--edge);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: background .18s, border-color .18s;
  color: transparent;
}
.bc-name {
  font-family: 'Montserrat', sans-serif;
  font-size: .68rem; font-weight: 600;
  letter-spacing: .02em;
  color: var(--text);
  margin-bottom: 3px;
}
.bc-state {
  font-family: 'Montserrat', sans-serif;
  font-size: .6rem; letter-spacing: .04em;
  color: var(--text-3);
  transition: color .2s;
}
/* Feelings row */
.bc-feelings { margin-bottom: 24px; }
.bc-feel-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 10px;
}
.bc-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.bc-chip {
  padding: 6px 14px;
  border-radius: 100px;
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; font-weight: 500; letter-spacing: .04em;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--edge);
  color: var(--text-2);
  cursor: pointer;
  transition: all .2s var(--ease);
}
.bc-chip:hover { border-color: rgba(200,169,81,.3); color: var(--text); }
.bc-chip.active {
  background: rgba(200,169,81,.12);
  border-color: rgba(200,169,81,.4);
  color: var(--gold-hi);
}
/* Light mode overrides */
body.light-mode .bc-card { background: rgba(0,0,0,.03); }
body.light-mode .bc-card:hover { border-color: rgba(150,100,30,.3); }
body.light-mode .bc-card.checked { background: rgba(150,100,30,.06); border-color: rgba(150,100,30,.35); }
body.light-mode .bc-chip { background: rgba(0,0,0,.04); color: var(--text-2); }
body.light-mode .bc-chip.active { background: rgba(150,100,30,.1); border-color: rgba(150,100,30,.35); }
/* Light mode FAQ */
body.light-mode .faq-item { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.07); }

/* ── 18. Journal right panel ─────────────────────────────────────── */
.jnl-rp-stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  margin-bottom: var(--sp-4);
}
.jnl-rp-stat { padding: 10px 0; text-align: center; }
.jnl-rp-stat + .jnl-rp-stat { border-left: 1px solid var(--edge); }
.jnl-rp-num {
  font-family: 'Playfair Display', serif;
  font-size: 1.9rem; font-weight: 700; line-height: 1;
  background: linear-gradient(160deg, var(--gold-hi) 0%, var(--gold) 55%, #a07820 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
body.light-mode .jnl-rp-num {
  background: linear-gradient(160deg, #b8890a 0%, #8a6315 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.jnl-rp-lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: .54rem; font-weight: 600; letter-spacing: .18em;
  text-transform: uppercase; color: var(--text-3); margin-top: 5px;
}
.jnl-rp-mode-stat {
  font-family: 'Montserrat', sans-serif;
  font-size: .54rem; font-weight: 600; letter-spacing: .18em;
  text-transform: uppercase; color: var(--gold);
  margin-bottom: var(--sp-3);
}
.jnl-rp-card {
  padding: 10px 0;
  border-bottom: 1px solid var(--edge);
}
.jnl-rp-card:last-child { border-bottom: none; }
.jnl-rp-card-top {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px;
}
.jnl-rp-card-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: .95rem; font-style: italic; color: var(--text-2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 155px;
}
.jnl-rp-card-type { font-size: .75rem; opacity: .45; }
.jnl-rp-card-meta { display: flex; align-items: center; justify-content: space-between; }
.jnl-rp-card-date {
  font-family: 'Montserrat', sans-serif;
  font-size: .54rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-3);
}
.jnl-rp-card-mood {
  font-family: 'Montserrat', sans-serif;
  font-size: .52rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--gold);
  padding: 2px 6px; border-radius: 20px;
  background: rgba(200,169,81,.1);
}
.jnl-rp-card-mood.mood-grounded  { color: #6abf6a; background: rgba(106,191,106,.12); }
.jnl-rp-card-mood.mood-open      { color: #7ab8f5; background: rgba(122,184,245,.12); }
.jnl-rp-card-mood.mood-heavy     { color: #a07ef5; background: rgba(160,126,245,.12); }
.jnl-rp-card-mood.mood-clear     { color: var(--gold); background: rgba(200,169,81,.12); }
.jnl-rp-card-mood.mood-alive     { color: #f5a623; background: rgba(245,166,35,.12); }
.jnl-rp-card-mood.mood-resistant { color: var(--crimson); background: rgba(200,16,46,.1); }
.jnl-rp-card-mood.mood-tender    { color: #f5a0b0; background: rgba(245,160,176,.12); }
.jnl-rp-empty {
  font-family: 'Cormorant Garamond', serif;
  font-size: .95rem; font-style: italic; color: var(--text-3);
  text-align: center; padding: var(--sp-5) 0;
}

/* ── 19. Inline-style evacuation — token-mapped classes ─────────── */

/* Tracker milestone cards — unlock label */
.ms-unlock { color: var(--text-3); }

/* Tracker empty state — primary CTA spacing */
.mp-empty .btn { margin-top: var(--sp-4); }

/* Recent entries — mood pill */
.re-mood {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-size: .55rem; letter-spacing: .1em; text-transform: uppercase;
  margin-top: 4px; padding: 2px 7px; border-radius: 20px;
  color: var(--gold); background: rgba(200,169,81,.1);
}
.re-mood.mood-grounded  { color: #6abf6a; background: rgba(106,191,106,.12); }
.re-mood.mood-open      { color: #7ab8f5; background: rgba(122,184,245,.12); }
.re-mood.mood-heavy     { color: #a07ef5; background: rgba(160,126,245,.12); }
.re-mood.mood-clear     { color: var(--gold); background: rgba(200,169,81,.12); }
.re-mood.mood-alive     { color: #f5a623; background: rgba(245,166,35,.12); }
.re-mood.mood-resistant { color: var(--crimson); background: rgba(200,16,46,.1); }
.re-mood.mood-tender    { color: #f5a0b0; background: rgba(245,160,176,.12); }

/* Journal write-actions — button group wrapper */
.write-btn-group {
  display: flex;
  gap: var(--sp-1);
}

/* Video panel — no-camera placeholder icon */
.vid-placeholder-icon {
  font-size: 2.5rem;
  opacity: .35;
  display: block;
  margin-bottom: var(--sp-1);
}

/* Video panel — status message spacing */
#vid-status { margin-top: var(--sp-1); }

/* Breathwork — cycles counter label */
.breath-cycles-lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: var(--label-xs);
  letter-spacing: var(--track-md);
  text-transform: uppercase;
  color: var(--text-3);
}

/* Arc right panel — "X of 30 days complete" caption */
.dp-days-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .26rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: var(--sp-4);
}

/* Arc right panel — mini progress card */
.dp-arc-mini {
  padding: 14px;
}
.dp-arc-mini-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-1);
}
.dp-arc-mini-day {
  font-family: 'Montserrat', sans-serif;
  font-size: .28rem;
  letter-spacing: var(--track-md);
  text-transform: uppercase;
  color: var(--gold);
}
.dp-arc-mini-of {
  font-family: 'Montserrat', sans-serif;
  font-size: .26rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-3);
}
.dp-arc-mini-chapter {
  font-family: 'Montserrat', sans-serif;
  font-size: .26rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-top: 6px;
}

/* Guide reading panel — prog-track top spacing */
.guide-prog-wrap .prog-track { margin-top: var(--sp-1); }

/* Guide chapter list — pct badge states */
.guide-pct-active { color: var(--crimson); }
.guide-pct-locked { color: var(--text-3); }

/* Prompt library — status label base color */
.pl-status { color: var(--text-3); }

/* ══════════════════════════════════════════════════════
   TRACKER — THIS WEEK STRIP
══════════════════════════════════════════════════════ */
.tw-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 8px;
}
.tw-stat {
  background: var(--surface);
  border: 1px solid var(--edge);
  border-top-color: var(--edge-hi);
  border-radius: var(--r);
  padding: 14px 12px;
  text-align: center;
}
.tw-value {
  font-family: 'Playfair Display', serif;
  font-size: 1.9rem; font-weight: 700;
  color: var(--gold); line-height: 1;
  margin-bottom: 5px;
  text-shadow: 0 0 24px rgba(200,169,81,.18);
}
.tw-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .6rem; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase;
  color: var(--text-2); margin-bottom: 2px;
  line-height: 1.3;
}
.tw-sub {
  font-family: 'Montserrat', sans-serif;
  font-size: .55rem; letter-spacing: .04em; text-transform: uppercase;
  color: var(--text-3); line-height: 1.3;
}

/* ══════════════════════════════════════════════════════
   TRACKER — INSIGHTS GRID
══════════════════════════════════════════════════════ */
.tracker-insights-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 16px;
}
.ti-card {
  background: var(--surface);
  border: 1px solid var(--edge);
  border-top: 1px solid rgba(200,169,81,.22);
  border-radius: var(--r);
  padding: 22px 22px 20px;
  box-shadow: 0 1px 0 rgba(255,255,255,.02) inset, 0 4px 16px rgba(0,0,0,.18);
  position: relative;
}
.ti-card.full { grid-column: 1 / -1; }
.ti-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: .6rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(200,169,81,.7); margin-bottom: 8px;
}
.ti-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem; font-style: italic;
  color: var(--text-2); margin-bottom: 18px;
}
.ti-big {
  font-family: 'Playfair Display', serif;
  font-size: 3rem; font-weight: 900;
  color: var(--gold); line-height: 1;
  text-shadow: 0 0 32px rgba(200,169,81,.22);
}
.ti-big-of {
  font-size: 1.1rem; font-weight: 400; color: var(--text-3);
}
.ti-sub-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-2); opacity: .55; margin-top: 5px; margin-bottom: 14px;
}
.ti-prog-bar {
  height: 4px; background: rgba(255,255,255,.05);
  border-radius: 99px; overflow: hidden; margin-bottom: 10px;
}
.ti-prog-fill {
  height: 100%;
  background: linear-gradient(to right, var(--crimson), var(--gold));
  border-radius: 99px; transition: width .8s var(--ease);
}
.ti-note {
  font-family: 'Cormorant Garamond', serif;
  font-size: .88rem; font-style: italic; color: var(--text-3);
}
.ti-divider {
  height: 1px; background: rgba(255,255,255,.06); margin: 14px 0;
}
.ti-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 6px;
}
.ti-row-label {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-3);
}
.ti-row-value {
  font-family: 'Montserrat', sans-serif;
  font-size: .72rem; font-weight: 700;
  color: var(--gold);
}
.ti-mood-bars { display: flex; flex-direction: column; gap: 10px; }
.ti-mood-row { display: flex; align-items: center; gap: 12px; }
.ti-mood-name {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-2); width: 90px; flex-shrink: 0;
}
.ti-mood-track {
  flex: 1; height: 6px; background: rgba(255,255,255,.05);
  border-radius: 99px; overflow: hidden;
}
.ti-mood-fill {
  height: 100%;
  background: linear-gradient(to right, var(--crimson), var(--gold));
  border-radius: 99px; transition: width .8s var(--ease);
}
.ti-mood-count {
  font-family: 'Montserrat', sans-serif;
  font-size: .62rem; color: var(--text-3); width: 18px; text-align: right;
}
.ti-empty-note {
  font-size: .84rem; color: var(--text-3); font-style: italic;
}
.ti-zones { display: flex; flex-wrap: wrap; gap: 8px; }
.ti-zone-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: .6rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  padding: 5px 10px; border-radius: 99px;
  background: rgba(255,255,255,.04); border: 1px solid var(--edge);
  color: var(--text-2);
}
.ti-zone-count {
  color: var(--gold); margin-left: 4px;
}
@media (max-width: 700px) {
  .tracker-insights-grid { grid-template-columns: 1fr; }
  .tw-strip { grid-template-columns: repeat(3, 1fr); }
}

/* ══════════════════════════════════════════════════════
   DEMO MODE CARD
══════════════════════════════════════════════════════ */
.demo-card {
  position: fixed;
  bottom: 32px;
  right: 32px;
  width: 320px;
  background: var(--surface);
  border: 1px solid var(--edge);
  border-top-color: rgba(200,169,81,.35);
  border-radius: var(--r);
  padding: 28px 28px 24px;
  z-index: 9999;
  box-shadow: 0 24px 64px rgba(0,0,0,.5), 0 0 0 1px rgba(200,169,81,.06);
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
  transition: opacity .4s var(--ease), transform .4s var(--ease);
}
.demo-card--visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.demo-card__close {
  position: absolute;
  top: 14px;
  right: 16px;
  background: none;
  border: none;
  color: var(--text-3);
  font-size: .8rem;
  cursor: pointer;
  padding: 4px;
  line-height: 1;
  transition: color var(--t-fast) var(--ease);
}
.demo-card__close:hover { color: var(--text); }
.demo-card__eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.demo-card__title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.3rem;
  font-style: italic;
  font-weight: 600;
  color: var(--text);
  line-height: 1.25;
  margin-bottom: 10px;
}
.demo-card__body {
  font-size: .82rem;
  color: var(--text-2);
  line-height: 1.6;
  margin-bottom: 20px;
}
.demo-card__actions {
  display: flex;
  gap: 10px;
}
.demo-card__btn {
  flex: 1;
  font-family: 'Montserrat', sans-serif;
  font-size: .64rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 10px 14px;
  border-radius: var(--r);
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.demo-card__btn--secondary {
  background: transparent;
  border: 1px solid var(--edge);
  color: var(--text-2);
}
.demo-card__btn--secondary:hover { border-color: var(--edge-hi); color: var(--text); }
.demo-card__btn--primary {
  background: linear-gradient(110deg, rgba(200,16,46,.22), rgba(200,169,81,.14));
  border: 1px solid var(--gold-dim);
  color: var(--gold);
}
.demo-card__btn--primary:hover { background: linear-gradient(110deg, rgba(200,16,46,.32), rgba(200,169,81,.22)); }

/* ═══════════════════════════════════════════
   AVATAR CROP & UPLOAD SYSTEM
═══════════════════════════════════════════ */

/* Drag anywhere overlay */
.av-drag-overlay {
  position: fixed; inset: 0; z-index: 9050;
  background: rgba(4,4,3,.78); backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .2s var(--ease);
}
body.av-dragging .av-drag-overlay { opacity: 1; }
.av-drag-inner {
  font-family: 'Playfair Display', serif; font-size: 1.6rem; font-style: italic;
  color: var(--gold); letter-spacing: .02em; text-align: center;
}

/* Crop modal backdrop — always dark regardless of portal theme */
.av-crop-modal {
  position: fixed; inset: 0; z-index: 9100;
  background: rgba(4,4,3,.90) !important; backdrop-filter: blur(20px) !important;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .4s var(--ease);
}
body.av-cropping .av-crop-modal { opacity: 1; pointer-events: all; }

/* Card — always deep crimson regardless of portal theme */
.av-crop-card,
body.light-mode .av-crop-card {
  background: #1c0808;
  border: 1px solid rgba(200,169,81,.4);
  border-radius: 24px; padding: 38px 44px 44px;
  display: flex; flex-direction: column; gap: 0;
  box-shadow: 0 40px 100px rgba(0,0,0,.85), 0 0 0 1px rgba(200,169,81,.18),
              inset 0 1px 0 rgba(255,255,255,.05);
  color: #f0ebe0; max-width: 90vw;
  transition: border-radius .35s cubic-bezier(.4,0,.2,1);
}

/* Card header */
.av-crop-card-header {
  margin-bottom: 30px;
}
.av-crop-card-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.6rem; font-weight: 400; font-style: italic;
  letter-spacing: .02em; line-height: 1;
  color: rgba(240,232,219,1);
}
.av-crop-card-sub {
  font-family: 'Montserrat', sans-serif;
  font-size: .42rem; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(240,232,219,.38); margin-top: 8px;
}

/* Two-column body */
.av-crop-body { display: flex; align-items: stretch; gap: 52px; }

/* Left — crop preview */
.av-crop-left { display: flex; flex-direction: column; align-items: center; gap: 24px; }
.av-left-actions { display: flex; flex-direction: column; gap: 10px; width: 240px; }

.av-crop-wrap {
  position: relative; width: 240px; height: 240px;
  cursor: grab; user-select: none;
}
.av-crop-wrap:active { cursor: grabbing; }

.av-crop-circle {
  width: 200px; height: 200px; border-radius: 50%; overflow: hidden;
  border: 2px solid rgba(200,169,81,.55);
  box-shadow: 0 0 0 3000px rgba(4,4,3,.88);
  position: relative; z-index: 1; background: #1a1510;
  transition: border-radius .3s var(--ease);
}
.av-crop-circle.sq { border-radius: 14px; }

.av-crop-photo { width: 100%; height: 100%; object-fit: cover; pointer-events: none; transform-origin: center; }

.av-crop-placeholder {
  width: 100%; height: 100%;
  background: linear-gradient(135deg, #2e2820 0%, #1a1410 50%, #251e18 100%);
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem; opacity: .18;
}

.av-crop-handles {
  position: absolute; inset: -10px; border-radius: 50%;
  z-index: 2; pointer-events: none;
  transition: border-radius .3s var(--ease);
}
.av-crop-handles.sq { border-radius: 22px; }

/* Zoom */
.av-zoom-row { display: flex; align-items: center; gap: 8px; width: 240px; }
.av-zoom-lbl { font-size: .44rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(240,235,224,.45); flex-shrink: 0; }
.av-zoom-val { font-size: .44rem; letter-spacing: .06em; color: rgba(200,169,81,.9); font-family: 'Montserrat', sans-serif; flex-shrink: 0; min-width: 28px; text-align: right; }
.av-zoom-track {
  flex: 1; height: 4px; background: rgba(255,255,255,.1); border-radius: 2px;
  position: relative; cursor: pointer;
}
.av-zoom-fill { height: 100%; background: var(--gold); border-radius: 2px; width: 30%; }
.av-zoom-thumb {
  position: absolute; top: -7px; left: 30%; width: 18px; height: 18px; border-radius: 50%;
  background: var(--gold); border: 2px solid #1c0808; margin-left: -9px;
  cursor: grab; box-shadow: 0 2px 8px rgba(200,169,81,.4);
}
.av-zoom-thumb:active { cursor: grabbing; transform: scale(1.15); }

/* Right panel */
.av-crop-right { display: flex; flex-direction: column; justify-content: flex-start; gap: 0; min-width: 230px; }
.av-right-section {
  flex: 1;
  padding: 28px 0;
}
.av-right-section:first-child { padding-top: 0; }

.av-crop-section {
  font-size: .52rem; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(240,232,219,.65); padding-bottom: 7px;
}
/* Gold accent line under standalone section headings (e.g. Shape) */
.av-right-section > .av-crop-section {
  border-bottom: 1px solid rgba(200,169,81,.28);
}

/* Shape toggle */
.av-shape-toggle { display: flex; gap: 8px; margin-top: 10px; width: 100%; }
.av-shape-btn {
  flex: 1; padding: 10px 12px; border-radius: 10px; border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.03); color: rgba(240,232,219,.55); cursor: pointer;
  font-family: 'Montserrat', sans-serif; font-size: .46rem; letter-spacing: .12em;
  text-transform: uppercase; transition: all .22s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column; align-items: center; gap: 7px;
}
.av-shape-btn.active {
  border-color: rgba(200,169,81,.65); background: rgba(200,169,81,.12);
  color: rgba(200,169,81,1);
  box-shadow: 0 0 14px rgba(200,169,81,.18), inset 0 1px 0 rgba(200,169,81,.12);
}
.av-shape-btn:hover:not(.active) { border-color: rgba(255,255,255,.18); color: rgba(240,232,219,.75); background: rgba(255,255,255,.05); }
.av-shape-icon { width: 26px; height: 26px; border: 1.5px solid currentColor; transition: border-radius .3s; }
.av-shape-icon.circle { border-radius: 50%; }
.av-shape-icon.square { border-radius: 5px; }

/* Rotation */
.av-crop-section-row {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 7px; border-bottom: 1px solid rgba(200,169,81,.28);
}
.av-crop-section-row .av-crop-section { padding-bottom: 0; }
.av-rot-slider-row { display: flex; align-items: center; gap: 8px; margin-top: 10px; }
.av-rot-row { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
.av-rot-btn {
  width: 32px; height: 32px; border-radius: 10px; border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.03); color: rgba(240,232,219,.5); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s cubic-bezier(.4,0,.2,1); flex-shrink: 0;
}
.av-rot-btn:hover { border-color: rgba(200,169,81,.45); color: rgba(200,169,81,.9); background: rgba(200,169,81,.07); }
.av-rot-btn svg { pointer-events: none; }
.av-rot-lbl {
  font-size: .62rem; letter-spacing: .08em;
  color: rgba(200,169,81,1); font-family: 'Montserrat', sans-serif; white-space: nowrap;
}

/* Adjustments */
.av-adj-list { display: flex; flex-direction: column; gap: 16px; margin-top: 10px; }
.av-adj-row  { display: flex; align-items: center; gap: 8px; }
.av-adj-lbl  {
  font-size: .42rem; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(240,235,224,.45); font-family: 'Montserrat', sans-serif;
  width: 64px; flex-shrink: 0;
}
.av-adj-val  {
  font-size: .42rem; letter-spacing: .06em; color: rgba(200,169,81,.65);
  font-family: 'Montserrat', sans-serif; width: 26px; text-align: right; flex-shrink: 0;
}
.av-flip-btn {
  display: flex; align-items: center; gap: 6px; margin-top: 10px;
  font-family: 'Montserrat', sans-serif; font-size: .44rem; letter-spacing: .13em;
  text-transform: uppercase; background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.1); border-radius: 8px; padding: 7px 12px;
  color: rgba(240,232,219,.45); cursor: pointer; transition: all .2s; width: 100%;
  justify-content: center;
}
.av-flip-btn:hover { border-color: rgba(200,169,81,.4); color: rgba(200,169,81,.85); background: rgba(200,169,81,.06); }
.av-flip-btn.active { border-color: rgba(200,169,81,.6); color: rgba(200,169,81,1); background: rgba(200,169,81,.1); }
.av-flip-btn svg { pointer-events: none; flex-shrink: 0; }
.av-reset-all-btn {
  font-family: 'Montserrat', sans-serif; font-size: .38rem; letter-spacing: .14em;
  text-transform: uppercase; background: none; border: none; padding: 0;
  color: rgba(200,169,81,.4); cursor: pointer; transition: color .2s;
}
.av-reset-all-btn:hover { color: rgba(200,169,81,.85); }

/* Preview strip — canvas elements, no border-radius/overflow needed */
.av-preview-strip { display: flex; gap: 10px; align-items: center; margin-top: 10px; }
.av-prev {
  display: block; flex-shrink: 0;
  border-radius: 0; /* canvas draws its own shape */
}
.av-prev.lg { width: 56px; height: 56px; }
.av-prev.md { width: 40px; height: 40px; }
.av-prev.sm { width: 28px; height: 28px; }

/* Remove */
.av-remove-btn {
  font-family: 'Montserrat', sans-serif; font-size: .46rem; letter-spacing: .12em;
  text-transform: uppercase; background: none;
  border: 1px solid rgba(200,16,46,.25); border-radius: 10px; padding: 9px 14px;
  color: rgba(200,16,46,.6); cursor: pointer; transition: all .2s;
  text-align: center; width: 100%;
}
.av-remove-btn:hover { border-color: rgba(200,16,46,.5); color: var(--crimson); background: rgba(200,16,46,.06); }

/* Confirm row */
.av-confirm-row { display: flex; gap: 10px; }
.av-btn-cancel {
  flex: 1; font-family: 'Montserrat', sans-serif; font-size: .5rem; letter-spacing: .12em;
  text-transform: uppercase; padding: 10px; border-radius: 10px;
  border: 1px solid var(--edge); background: transparent; color: var(--text-2);
  cursor: pointer; transition: all .2s;
}
.av-btn-cancel:hover { border-color: rgba(255,255,255,.2); color: var(--text); background: rgba(255,255,255,.04); }
.av-btn-confirm {
  flex: 2; font-family: 'Montserrat', sans-serif; font-size: .5rem; letter-spacing: .12em;
  text-transform: uppercase; padding: 10px; border-radius: 10px;
  border: none; background: var(--gold); color: #0a0a0a; font-weight: 600;
  cursor: pointer; transition: opacity .2s;
}
.av-btn-confirm:hover { opacity: .85; }

/* Toast */
.av-btn-confirm.av-btn-disabled {
  opacity: .3; cursor: not-allowed; pointer-events: none;
}
.av-toast {
  position: fixed; bottom: 36px; left: 50%; transform: translateX(-50%) translateY(16px);
  background: rgba(28,8,8,.92); border: 1px solid rgba(200,169,81,.5);
  border-radius: 99px; padding: 12px 28px;
  font-family: 'Montserrat', sans-serif; font-size: .48rem; letter-spacing: .18em;
  text-transform: uppercase; color: rgba(200,169,81,1);
  box-shadow: 0 8px 32px rgba(0,0,0,.5), 0 0 0 1px rgba(200,169,81,.12);
  opacity: 0; pointer-events: none; z-index: 9200;
  transition: opacity .35s var(--ease), transform .35s var(--ease);
}
.av-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ── SVG icon display (replacing emoji) ──────────────────────────────────── */
.rst-icon svg, .rhy-card-icon svg, .bc-icon svg,
.pstep-icon svg, .capsule-lock svg { display: block; }
.dev-row-icon svg { display: block; }
.mood-emoji svg { display: block; margin: 0 auto; }
.jnl-mode-icon svg { display: inline; vertical-align: middle; }
.vid-placeholder-icon svg { display: block; margin: 0 auto; }

/* ── PORTAL SVG ICON ANIMATIONS ─────────────────────────────────────────── */

/* Base transform setup */
.pstep .pstep-icon svg *,
.rhy-snap-tile .rst-icon svg *,
.rhy-card .rhy-card-icon svg *,
.mood-card .mood-emoji svg *,
.bc-card .bc-icon svg *,
.dev-row .dev-row-icon svg *,
.ref-tab .jnl-mode-icon svg *,
.capsule-lock svg *,
.sb-item .sb-icon svg * { transform-box: fill-box; transform-origin: center; }

/* ── Keyframes ────────────────────────────────────────────────────────────── */
@keyframes p-eye-blink    { 0%,30%,80%,100%{transform:scaleY(1)} 50%,65%{transform:scaleY(.06)} }
@keyframes p-hrv-pulse    { 0%,100%{transform:scaleY(1)} 50%{transform:scaleY(1.4)} }
@keyframes p-bars-shrink  { 0%,100%{transform:scaleY(1)} 50%{transform:scaleY(.5)} }
@keyframes p-flame-outer  { 0%,100%{transform:rotate(0deg) scaleX(1)} 25%{transform:rotate(-3.5deg) scaleX(.92)} 60%{transform:rotate(3deg) scaleX(1.08)} }
@keyframes p-flame-inner  { 0%,100%{transform:scaleX(1) scaleY(1)} 35%{transform:scaleX(1.25) scaleY(.88)} 65%{transform:scaleX(.8) scaleY(1.12)} }
@keyframes p-rhr-beat     { 0%,100%{transform:scale(1)} 35%{transform:scale(1.4)} 65%{transform:scale(.9)} }
@keyframes p-moon-drift   { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-2.5px,-2px)} }
@keyframes p-sun-rise     { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-4px)} }
@keyframes p-star-twinkle { 0%,100%{transform:rotate(0deg) scale(1)} 50%{transform:rotate(18deg) scale(1.12)} }
@keyframes p-check-pop    { 0%,100%{transform:scale(1)} 50%{transform:scale(1.1)} }
@keyframes p-breathe-wave { 0%,100%{transform:scaleY(1)} 50%{transform:scaleY(1.5)} }
@keyframes p-body-pulse   { 0%,100%{transform:scale(1)} 50%{transform:scale(1.1)} }
@keyframes p-pen-write    { 0%,100%{transform:translate(0,0) rotate(0deg)} 40%{transform:translate(-1.5px,-1.5px) rotate(-7deg)} 70%{transform:translate(1px,1px) rotate(3deg)} }
@keyframes p-mic-pump     { 0%,100%{transform:scaleY(1)} 50%{transform:scaleY(1.18)} }
@keyframes p-vid-flash    { 0%,75%,100%{opacity:1} 80%,95%{opacity:.2} }
@keyframes p-lock-rattle  { 0%,100%{transform:rotate(0deg)} 20%{transform:rotate(-8deg)} 40%{transform:rotate(8deg)} 60%{transform:rotate(-5deg)} 80%{transform:rotate(5deg)} }
@keyframes p-ground-press { 0%,100%{transform:translateY(0)} 50%{transform:translateY(2.5px)} }
@keyframes p-clear-expand { 0%,100%{transform:scale(1)} 50%{transform:scale(1.12)} }
@keyframes p-heavy-press  { 0%,100%{transform:translateY(0) scaleX(1)} 50%{transform:translateY(3px) scaleX(1.12)} }
@keyframes p-anxious-jit  { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-2px)} 75%{transform:translateX(2px)} }
@keyframes p-tender-l     { 0%,100%{transform:translateX(0)} 50%{transform:translateX(3px)} }
@keyframes p-tender-r     { 0%,100%{transform:translateX(0)} 50%{transform:translateX(-3px)} }
@keyframes p-restless-spin{ 0%{transform:rotate(0deg)} 100%{transform:rotate(360deg)} }
@keyframes p-open-l       { 0%,100%{transform:translateX(0)} 50%{transform:translateX(-3px)} }
@keyframes p-open-r       { 0%,100%{transform:translateX(0)} 50%{transform:translateX(3px)} }
@keyframes p-numb-fade    { 0%,100%{opacity:1} 50%{opacity:.14} }
@keyframes p-leaf-sway    { 0%,100%{transform:rotate(0deg)} 35%{transform:rotate(-6deg)} 70%{transform:rotate(6deg)} }
@keyframes p-head-nod     { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-2px)} }
@keyframes p-heart-beat   { 0%,100%{transform:scale(1)} 25%{transform:scale(1.18)} 50%{transform:scale(1)} 75%{transform:scale(1.1)} }
@keyframes p-shoulder     { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-3px)} }
@keyframes p-spine-flex   { 0%,100%{transform:scaleX(1)} 50%{transform:scaleX(1.2)} }
@keyframes p-legs-walk    { 0%,100%{transform:rotate(0deg)} 25%{transform:rotate(-6deg)} 75%{transform:rotate(6deg)} }
@keyframes p-ah-pulse     { 0%,100%{transform:scale(1)} 40%{transform:scale(1.18)} 65%{transform:scale(.93)} }
@keyframes p-garmin-glow  { 0%,100%{opacity:1} 50%{opacity:.5} }
@keyframes p-whoop-w      { 0%,100%{transform:scaleX(1)} 50%{transform:scaleX(1.18)} }
@keyframes p-oura-ring    { 0%,100%{stroke-width:1.8} 50%{stroke-width:3.2} }
@keyframes p-fitbit-pop   { 0%,100%{transform:scale(1)} 50%{transform:scale(1.6)} }
@keyframes p-gfit-seg     { 0%,100%{opacity:1} 50%{opacity:.25} }
@keyframes p-nav-scale    { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }
@keyframes p-nav-rotate   { 0%{transform:rotate(0deg)} 100%{transform:rotate(360deg)} }
@keyframes p-nav-bounce   { 0%,100%{transform:translateY(0)} 40%{transform:translateY(-2px)} 70%{transform:translateY(1px)} }
@keyframes p-nav-scan     { 0%,100%{transform:scaleX(1)} 50%{transform:scaleX(.75)} }
@keyframes p-nav-flash    { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes p-nav-jitter   { 0%,100%{transform:rotate(0deg)} 25%{transform:rotate(12deg)} 75%{transform:rotate(-9deg)} }
@keyframes p-nav-lift     { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-2px)} }

/* ── Practice Steps ─────────────────────────────────────────────────────── */
.pstep[data-step="star"]:hover .pstep-icon svg path { animation: p-star-twinkle 1.2s ease-in-out infinite; }
.pstep[data-step="check"]:hover .pstep-icon svg { animation: p-check-pop 1s ease-in-out infinite; }
.pstep[data-step="breathe"]:hover .pstep-icon svg path { animation: p-breathe-wave 2s ease-in-out infinite; }
.pstep[data-step="body"]:hover .pstep-icon svg circle,
.pstep[data-step="body"]:hover .pstep-icon svg path { animation: p-body-pulse 1.2s ease-in-out infinite; }

/* ── Journal Mode Tabs ──────────────────────────────────────────────────── */
.ref-tab[data-mode="written"]:hover .jnl-mode-icon svg path { animation: p-pen-write 1.3s ease-in-out infinite; }
.ref-tab[data-mode="voice"]:hover .jnl-mode-icon svg path:nth-child(1) { animation: p-mic-pump 1s ease-in-out infinite; }
.ref-tab[data-mode="video"]:hover .jnl-mode-icon svg rect { animation: p-vid-flash 2s ease-in-out infinite; }

/* ── Time Capsule Lock ──────────────────────────────────────────────────── */
.capsule-lock:hover svg rect { animation: p-lock-rattle 1.2s ease-in-out infinite; }

/* ── Health Snapshot Tiles ──────────────────────────────────────────────── */
.rhy-snap-tile[data-stat="sleep"]:hover .rst-icon svg path { animation: p-eye-blink 2.5s ease-in-out infinite; }
.rhy-snap-tile[data-stat="hrv"]:hover .rst-icon svg path { animation: p-hrv-pulse 1s ease-in-out infinite; }
.rhy-snap-tile[data-stat="steps"]:hover .rst-icon svg path { animation: p-bars-shrink 1.2s ease-in-out infinite; transform-origin: 50% 100%; }
.rhy-snap-tile[data-stat="cal"]:hover .rst-icon svg path:nth-child(1) { animation: p-flame-outer .75s ease-in-out infinite; transform-origin: 50% 100%; }
.rhy-snap-tile[data-stat="cal"]:hover .rst-icon svg path:nth-child(2) { animation: p-flame-inner .75s ease-in-out infinite .15s; transform-origin: 50% 100%; }
.rhy-snap-tile[data-stat="hr"]:hover .rst-icon svg circle { animation: p-rhr-beat .85s ease-in-out infinite; }
.rhy-snap-tile[data-stat="hr"]:hover .rst-icon svg path { animation: p-rhr-beat .85s ease-in-out infinite .2s; }

/* ── Rhythm Cards ────────────────────────────────────────────────────────── */
.rhy-card[data-rhy="sleep"]:hover .rhy-card-icon svg path { animation: p-eye-blink 2.5s ease-in-out infinite; }
.rhy-card[data-rhy="movement"]:hover .rhy-card-icon svg path { animation: p-bars-shrink 1.2s ease-in-out infinite; transform-origin: 50% 100%; }
.rhy-card[data-rhy="nutrition"]:hover .rhy-card-icon svg path { animation: p-leaf-sway 1.8s ease-in-out infinite; transform-origin: 50% 100%; }
.rhy-card[data-rhy="recovery"]:hover .rhy-card-icon svg path { animation: p-hrv-pulse 1s ease-in-out infinite; }

/* Moon/Sun in bed-wake row */
.sleep-stats-row:hover .sleep-moon svg path,
.srs-times span:hover svg path { animation: p-moon-drift 4s ease-in-out infinite; }

/* ── Mood Cards ──────────────────────────────────────────────────────────── */
.mood-card[onclick*="Grounded"]:hover .mood-emoji svg path:nth-child(1) { animation: p-ground-press 1.8s ease-in-out infinite; }
.mood-card[onclick*="Clear"]:hover .mood-emoji svg path { animation: p-clear-expand 1.4s ease-in-out infinite; }
.mood-card[onclick*="Heavy"]:hover .mood-emoji svg path { animation: p-heavy-press 1.5s cubic-bezier(.16,1,.3,1) infinite; }
.mood-card[onclick*="Anxious"]:hover .mood-emoji svg path { animation: p-anxious-jit .35s ease-in-out infinite; }
.mood-card[onclick*="Tender"]:hover .mood-emoji svg path:nth-child(1) { animation: p-tender-l 1.5s ease-in-out infinite; }
.mood-card[onclick*="Tender"]:hover .mood-emoji svg path:nth-child(2) { animation: p-tender-r 1.5s ease-in-out infinite; }
.mood-card[onclick*="Restless"]:hover .mood-emoji svg path { transform-box: view-box; transform-origin: 50% 50%; animation: p-restless-spin 2.5s linear infinite; }
.mood-card[onclick*="Open"]:hover .mood-emoji svg path:nth-child(1) { animation: p-open-l 1.7s ease-in-out infinite; }
.mood-card[onclick*="Open"]:hover .mood-emoji svg path:nth-child(2) { animation: p-open-r 1.7s ease-in-out infinite; }
.mood-card[onclick*="Numb"]:hover .mood-emoji svg path { animation: p-numb-fade 3s ease-in-out infinite; }

/* ── Body Check Zones ────────────────────────────────────────────────────── */
.bc-card[data-zone="head"]:hover .bc-icon svg circle { animation: p-head-nod 1.2s ease-in-out infinite; }
.bc-card[data-zone="head"]:hover .bc-icon svg path { animation: p-head-nod 1.2s ease-in-out infinite .05s; }
.bc-card[data-zone="chest"]:hover .bc-icon svg path { animation: p-heart-beat .8s ease-in-out infinite; }
.bc-card[data-zone="core"]:hover .bc-icon svg path:nth-child(1) { animation: p-flame-outer .75s ease-in-out infinite; transform-origin: 50% 100%; }
.bc-card[data-zone="core"]:hover .bc-icon svg path:nth-child(2) { animation: p-flame-inner .75s ease-in-out infinite .15s; transform-origin: 50% 100%; }
.bc-card[data-zone="shoulders"]:hover .bc-icon svg path { animation: p-shoulder 1.4s ease-in-out infinite; }
.bc-card[data-zone="back"]:hover .bc-icon svg path:nth-child(2),
.bc-card[data-zone="back"]:hover .bc-icon svg path:nth-child(3),
.bc-card[data-zone="back"]:hover .bc-icon svg path:nth-child(4),
.bc-card[data-zone="back"]:hover .bc-icon svg path:nth-child(5) { animation: p-spine-flex 1.5s ease-in-out infinite; }
.bc-card[data-zone="legs"]:hover .bc-icon svg path:nth-child(1) { animation: p-legs-walk 1.2s ease-in-out infinite; transform-origin: 50% 0%; }
.bc-card[data-zone="legs"]:hover .bc-icon svg path:nth-child(2) { animation: p-legs-walk 1.2s ease-in-out infinite .3s; transform-origin: 50% 0%; }

/* ── Device Rows ─────────────────────────────────────────────────────────── */
.dev-row[onclick*="apple-health"]:hover .dev-row-icon svg path { animation: p-ah-pulse .85s ease-in-out infinite; }
.dev-row[onclick*="garmin"]:hover .dev-row-icon svg path { animation: p-garmin-glow 1.2s ease-in-out infinite; }
.dev-row[onclick*="whoop"]:hover .dev-row-icon svg path:nth-child(2) { animation: p-whoop-w .9s ease-in-out infinite; }
.dev-row[onclick*="oura"]:hover .dev-row-icon svg circle { animation: p-oura-ring 1.5s ease-in-out infinite; }
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(5),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(8)  { animation: p-fitbit-pop .7s ease-in-out infinite; }
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(2),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(3),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(4),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(6),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(7),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(9),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(10),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(11) { animation: p-fitbit-pop .7s ease-in-out infinite .14s; }
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(1),
.dev-row[onclick*="fitbit"]:hover .dev-row-icon svg circle:nth-child(12) { animation: p-fitbit-pop .7s ease-in-out infinite .28s; }
.dev-row[onclick*="google-fit"]:hover .dev-row-icon svg path:nth-child(1) { animation: p-gfit-seg 1.6s ease-in-out infinite; }
.dev-row[onclick*="google-fit"]:hover .dev-row-icon svg path:nth-child(2) { animation: p-gfit-seg 1.6s ease-in-out infinite .2s; }
.dev-row[onclick*="google-fit"]:hover .dev-row-icon svg path:nth-child(3) { animation: p-gfit-seg 1.6s ease-in-out infinite .4s; }
.dev-row[onclick*="google-fit"]:hover .dev-row-icon svg path:nth-child(4) { animation: p-gfit-seg 1.6s ease-in-out infinite .6s; }

/* ── Nav Sidebar ─────────────────────────────────────────────────────────── */
.sb-item[data-view="home"]:hover .sb-icon svg path        { animation: p-nav-scale 1.5s ease-in-out infinite; }
.sb-item[data-view="journal"]:hover .sb-icon svg rect     { animation: p-nav-scale 1.2s ease-in-out infinite; }
.sb-item[data-view="arc"]:hover .sb-icon svg circle:nth-child(1) { animation: p-nav-scale 1.4s ease-in-out infinite; }
.sb-item[data-view="reflection"]:hover .sb-icon svg path:last-child { animation: p-nav-flash 1.2s ease-in-out infinite; }
.sb-item[data-view="tracker"]:hover .sb-icon svg line     { animation: p-nav-scan 1.3s ease-in-out infinite; }
.sb-item[data-view="my-guide"]:hover .sb-icon svg line    { animation: p-nav-scan 1.3s ease-in-out infinite; }
.sb-item[data-view="the-work"]:hover .sb-icon svg         { animation: p-nav-rotate 4s linear infinite; transform-origin: center; }
.sb-item[data-view="journey"]:hover .sb-icon svg path     { animation: p-nav-bounce 1.2s ease-in-out infinite; }
.sb-item[data-view="orders"]:hover .sb-icon svg circle    { animation: p-nav-bounce 1.2s ease-in-out infinite; }
.sb-item[data-view="settings"]:hover .sb-icon svg         { animation: p-nav-rotate 2s linear infinite; transform-origin: center; }
.sb-item[data-view="help"]:hover .sb-icon svg path:nth-child(2)  { animation: p-nav-jitter 1.3s ease-in-out infinite; }
.sb-item[data-view="contact"]:hover .sb-icon svg path:last-child { animation: p-nav-lift 1.2s ease-in-out infinite; }

/* ── Health stat icon colors ─────────────────────────────────────────────── */
.rhy-snap-tile[data-stat="sleep"]  .rst-icon svg { color: #c8a951; }
.rhy-snap-tile[data-stat="hrv"]    .rst-icon svg { color: #c8102e; }
.rhy-snap-tile[data-stat="steps"]  .rst-icon svg { color: #6abf6a; }
.rhy-snap-tile[data-stat="cal"]    .rst-icon svg { color: #f5a623; }
.rhy-snap-tile[data-stat="hr"]     .rst-icon svg { color: #c8102e; }

/* Rhythm card icon colors */
.rhy-card[data-rhy="sleep"]      .rhy-card-icon svg { color: #c8a951; }
.rhy-card[data-rhy="movement"]   .rhy-card-icon svg { color: #6abf6a; }
.rhy-card[data-rhy="nutrition"]  .rhy-card-icon svg { color: #8bc34a; }
.rhy-card[data-rhy="recovery"]   .rhy-card-icon svg { color: #c8102e; }

/* Rhy-factor inline icons (readiness row — fixed order) */
.rhy-readiness .rhy-factor:nth-child(1) span svg { color: #c8a951; }
.rhy-readiness .rhy-factor:nth-child(2) span svg { color: #c8102e; }
.rhy-readiness .rhy-factor:nth-child(3) span svg { color: #6abf6a; }

/* ══════════════════════════════════════════════════════
   JOURNAL — UPGRADED COMPONENTS (2026-05-14)
══════════════════════════════════════════════════════ */

/* anim-6 / anim-7 — extends existing anim-N scale */
.anim-6 { animation: fade-up-in var(--t-slow) var(--ease) 420ms both; }
.anim-7 { animation: fade-up-in var(--t-slow) var(--ease) 520ms both; }

/* ── Daily Invitation card ── */
.jnl-invitation {
  background: linear-gradient(135deg, rgba(200,169,81,.07) 0%, rgba(200,169,81,.03) 100%);
  border: 1px solid rgba(200,169,81,.18);
  border-radius: 12px;
  padding: 18px 20px 16px;
  margin-bottom: 22px;
}
.jnl-inv-eyebrow {
  font-size: .68rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--gold); opacity: .7; margin-bottom: 8px;
}
.jnl-inv-text {
  font-size: .95rem; line-height: 1.55; color: var(--text-2);
  font-style: italic; margin-bottom: 12px;
}
.jnl-inv-btn {
  background: none; border: none; padding: 0; cursor: pointer;
  font-size: .78rem; letter-spacing: .06em; color: var(--gold);
  opacity: .75; transition: opacity var(--t-fast) var(--ease);
}
.jnl-inv-btn:hover { opacity: 1; }
body.light-mode .jnl-invitation { background: rgba(200,169,81,.06); border-color: rgba(200,169,81,.25); }

/* ── Pro chip (inline badge) ── */
.jnl-pro-chip {
  display: inline-flex; align-items: center;
  font-size: .63rem; letter-spacing: .09em;
  color: var(--gold); opacity: .75;
  background: rgba(200,169,81,.1);
  border: 1px solid rgba(200,169,81,.2);
  border-radius: 20px; padding: 1px 6px;
  margin-left: 5px; vertical-align: middle;
  cursor: pointer; transition: opacity var(--t-fast) var(--ease);
}
.jnl-pro-chip:hover { opacity: 1; }

/* ── Shared section label ── */
.jnl-section-lbl {
  font-size: .7rem; letter-spacing: .09em; text-transform: uppercase;
  color: var(--text-3); display: block; margin-bottom: 7px;
}

/* ── Formatting toolbar ── */
.jnl-toolbar {
  display: flex; align-items: center; gap: 2px;
  padding: 6px 8px; margin-bottom: 10px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 8px;
}
.jnl-tool-btn {
  background: none; border: none; cursor: pointer;
  padding: 4px 8px; border-radius: 5px;
  color: var(--text-3); font-size: .82rem;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  display: flex; align-items: center; gap: 4px;
}
.jnl-tool-btn:hover { background: rgba(255,255,255,.07); color: var(--text-2); }
.jnl-tool-wide { padding: 4px 10px; font-size: .75rem; }
.jnl-toolbar-div { width: 1px; height: 16px; background: rgba(255,255,255,.08); margin: 0 4px; }
body.light-mode .jnl-toolbar { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.08); }
body.light-mode .jnl-tool-btn { color: rgba(24,21,15,.4); }
body.light-mode .jnl-tool-btn:hover { background: rgba(0,0,0,.06); color: rgba(24,21,15,.75); }

/* ── Templates row ── */
.jnl-templates {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap; margin-bottom: 12px;
}
.jnl-tpl-list { display: flex; gap: 6px; flex-wrap: wrap; flex: 1; }
.jnl-tpl-chip {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px; padding: 4px 11px;
  font-size: .73rem; color: var(--text-3);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
  white-space: nowrap;
}
.jnl-tpl-chip:hover { border-color: rgba(200,169,81,.3); color: var(--gold); background: rgba(200,169,81,.06); }
body.light-mode .jnl-tpl-chip { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: rgba(24,21,15,.45); }

/* ── Session timer ── */
.jnl-timer-row {
  display: flex; align-items: center; gap: 8px;
  margin: 10px 0 14px; flex-wrap: wrap;
}
.jnl-timer-lbl { font-size: .7rem; letter-spacing: .09em; text-transform: uppercase; color: var(--text-3); }
.jnl-timer-chips { display: flex; gap: 5px; }
.jnl-timer-chip {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 20px; padding: 3px 10px;
  font-size: .73rem; color: var(--text-3);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
}
.jnl-timer-chip:hover { color: var(--text-2); border-color: rgba(255,255,255,.14); }
.jnl-timer-chip.active { background: rgba(200,169,81,.1); border-color: rgba(200,169,81,.35); color: var(--gold); }
.jnl-timer-display {
  font-size: .85rem; font-variant-numeric: tabular-nums;
  color: var(--gold); letter-spacing: .04em; margin-left: auto;
  min-width: 36px; text-align: right;
}
body.light-mode .jnl-timer-chip { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }

/* ── Theme tags ── */
.jnl-theme-row { margin: 14px 0 0; }
.jnl-themes { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.theme-tag {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 20px; padding: 4px 12px;
  font-size: .72rem; color: var(--text-3);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
  letter-spacing: .03em;
}
.theme-tag:hover { border-color: rgba(255,255,255,.15); color: var(--text-2); }
.theme-tag.active { border-color: rgba(140,200,140,.4); color: rgba(160,220,160,.9); background: rgba(140,200,140,.08); }
body.light-mode .theme-tag { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: rgba(24,21,15,.45); }
body.light-mode .theme-tag:hover { border-color: rgba(0,0,0,.2); color: rgba(24,21,15,.7); }
body.light-mode .theme-tag.active { border-color: rgba(60,140,60,.4); color: rgba(40,120,40,.85); background: rgba(60,140,60,.08); }

/* ── AI Reflection card ── */
.jnl-ai-card {
  display: flex; align-items: flex-start; gap: 12px;
  margin-top: 16px; padding: 14px 16px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; cursor: pointer;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.jnl-ai-card:hover { border-color: rgba(200,169,81,.25); background: rgba(200,169,81,.04); }
.jnl-ai-icon {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(200,169,81,.1); border: 1px solid rgba(200,169,81,.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); flex-shrink: 0; margin-top: 1px;
}
.jnl-ai-title { font-size: .82rem; color: var(--text-2); margin-bottom: 3px; }
.jnl-ai-sub { font-size: .73rem; color: var(--text-3); line-height: 1.5; }
body.light-mode .jnl-ai-card { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.08); }

/* ── Voice: transcription row ── */
.jnl-transcribe-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; margin-bottom: 12px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 9px; cursor: pointer;
  transition: border-color var(--t-fast) var(--ease);
}
.jnl-transcribe-row:hover { border-color: rgba(200,169,81,.25); }
.jnl-transcribe-left { display: flex; align-items: center; gap: 8px; font-size: .8rem; color: var(--text-3); }
.jnl-toggle {
  width: 34px; height: 19px; border-radius: 20px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.1);
  position: relative; flex-shrink: 0;
}
.jnl-toggle-knob {
  width: 13px; height: 13px; border-radius: 50%;
  background: rgba(255,255,255,.3);
  position: absolute; top: 2px; left: 2px;
  transition: left var(--t-fast) var(--ease);
}
body.light-mode .jnl-transcribe-row { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.08); }

/* ── Voice: limit row ── */
.vs-limit-row {
  display: flex; align-items: center; gap: 6px;
  margin-top: 10px; justify-content: center;
}
.vs-limit-basic { font-size: .72rem; color: var(--text-3); }
.vs-limit-sep   { font-size: .72rem; color: var(--text-3); opacity: .4; }
.vs-limit-pro   { font-size: .72rem; color: var(--gold); opacity: .65; cursor: pointer; transition: opacity var(--t-fast) var(--ease); }
.vs-limit-pro:hover { opacity: 1; }

/* ── Ambient audio ── */
.jnl-ambient-row { margin: 14px 0 0; }
.jnl-ambient-chips { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }
.jnl-ambient-chip {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 20px; padding: 4px 12px;
  font-size: .73rem; color: var(--text-3);
  cursor: pointer; transition: all var(--t-fast) var(--ease);
}
.jnl-ambient-chip:hover { border-color: rgba(200,169,81,.3); color: var(--gold); background: rgba(200,169,81,.06); }
body.light-mode .jnl-ambient-chip { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }

/* ── Video Pro bar ── */
.jnl-video-pro-bar {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap; margin-bottom: 10px;
}
/* .jnl-vpro-btn → replaced by .btn.btn-locked */

/* ── Search bar ── */
.jnl-search-wrap {
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 9px; padding: 0 12px;
  margin-bottom: 12px;
  transition: border-color var(--t-fast) var(--ease);
}
.jnl-search-wrap:focus-within { border-color: rgba(200,169,81,.28); }
.jnl-search-icon { color: var(--text-3); flex-shrink: 0; }
.jnl-search-input {
  flex: 1; background: none; border: none; outline: none;
  padding: 9px 0; font-size: .82rem; color: var(--text);
  font-family: inherit;
}
.jnl-search-input::placeholder { color: var(--text-3); }
.jnl-search-clear {
  background: none; border: none; cursor: pointer;
  color: var(--text-3); font-size: .8rem; padding: 4px;
  transition: color var(--t-fast) var(--ease);
}
.jnl-search-clear:hover { color: var(--text-2); }
body.light-mode .jnl-search-wrap { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }
body.light-mode .jnl-search-input { color: #18150f; }

/* ── Right panel: 30-day calendar ── */
.jnl-cal {
  display: grid; grid-template-columns: repeat(10, 1fr);
  gap: 4px; padding-top: 4px;
}
.jnl-cal-dot {
  width: 100%; aspect-ratio: 1;
  border-radius: 3px;
  background: rgba(255,255,255,.06);
}
.jnl-cal-dot.has-entry { background: var(--gold); opacity: .75; }
.jnl-cal-dot.today { box-shadow: 0 0 0 1px rgba(200,169,81,.6); }
body.light-mode .jnl-cal-dot { background: rgba(0,0,0,.08); }
body.light-mode .jnl-cal-dot.has-entry { background: var(--gold); opacity: .65; }

/* ── Right panel: writing stats ── */
.jnl-write-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0; }
.jnl-wstat { text-align: center; padding: 8px 4px; }
.jnl-wstat + .jnl-wstat { border-left: 1px solid var(--edge); }
.jnl-wstat-num {
  font-size: 1.35rem; font-weight: 600; color: var(--text);
  letter-spacing: -.02em; line-height: 1;
  margin-bottom: 4px;
}
.jnl-wstat-lbl { font-size: .65rem; color: var(--text-3); letter-spacing: .05em; text-transform: uppercase; }
body.light-mode .jnl-wstat-num { color: #18150f; }

/* ── Right panel: mood distribution ── */
.jnl-mood-dist { display: flex; flex-direction: column; gap: 6px; padding-top: 2px; }
.jnl-mood-bar-row { display: flex; align-items: center; gap: 8px; }
.jnl-mood-bar-lbl { font-size: .72rem; color: var(--text-3); min-width: 62px; }
.jnl-mood-bar-track {
  flex: 1; height: 4px; border-radius: 2px;
  background: rgba(255,255,255,.06);
  overflow: hidden;
}
.jnl-mood-bar-fill {
  height: 100%; border-radius: 2px;
  background: var(--gold); opacity: .6;
  transition: width .6s var(--ease);
}
.jnl-mood-bar-n { font-size: .68rem; color: var(--text-3); min-width: 14px; text-align: right; }
body.light-mode .jnl-mood-bar-track { background: rgba(0,0,0,.08); }

/* ── Right panel: streak card ── */
.jnl-streak-body { font-size: .82rem; color: var(--text-3); line-height: 1.55; padding-top: 2px; }
.jnl-streak-num { font-size: 1.8rem; font-weight: 600; color: var(--gold); line-height: 1; margin-bottom: 4px; }
.jnl-streak-next { font-size: .73rem; color: var(--text-3); margin-top: 6px; }
.jnl-streak-milestones { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.jnl-ms-pip {
  font-size: .68rem; padding: 3px 8px; border-radius: 20px;
  border: 1px solid rgba(255,255,255,.08); color: var(--text-3);
}
.jnl-ms-pip.earned { border-color: var(--gold); color: var(--gold); background: rgba(200,169,81,.08); }

/* ── Right panel: pattern detection ── */
.jnl-patterns-card { cursor: pointer; transition: border-color var(--t-fast) var(--ease); }
.jnl-patterns-card:hover { border-color: rgba(200,169,81,.25); }
.jnl-pattern-rows { display: flex; flex-direction: column; gap: 6px; padding: 4px 0 10px; }
.jnl-pattern-row { display: flex; justify-content: space-between; align-items: center; }
.jnl-pattern-word { font-size: .8rem; color: var(--text-2); font-style: italic; }
.jnl-pattern-n { font-size: .73rem; color: var(--text-3); }
.jnl-pattern-lock {
  font-size: .72rem; color: var(--gold); opacity: .6;
  padding-top: 6px; border-top: 1px solid rgba(255,255,255,.06);
}
.jnl-patterns-card:hover .jnl-pattern-lock { opacity: .9; }
body.light-mode .jnl-pattern-lock { border-top-color: rgba(0,0,0,.08); }

/* ── Entry card: theme tag display ── */
.entry-theme-tag {
  display: inline-block;
  font-size: .65rem; padding: 1px 7px;
  border: 1px solid rgba(140,200,140,.3); border-radius: 20px;
  color: rgba(140,200,140,.8); margin-left: 6px;
  vertical-align: middle;
}
body.light-mode .entry-theme-tag { border-color: rgba(40,120,40,.3); color: rgba(40,120,40,.75); }

/* ══════════════════════════════════════════════
   PREVIEW MODE BANNER
══════════════════════════════════════════════ */
:root { --pb-h: 38px; }

.preview-banner {
  display: none; /* shown via JS when in demo mode */
  position: fixed;
  top: var(--hh); left: 0; right: 0;
  height: var(--pb-h);
  z-index: 299;
  pointer-events: none; /* don't swallow scroll events passing over the banner */
  background: rgba(14,11,4,.93);
  border-top: 1px solid rgba(200,169,81,.22);
  border-bottom: 1px solid rgba(200,169,81,.38);
  align-items: center; justify-content: center;
  gap: 12px;
  backdrop-filter: blur(16px);
  box-shadow: 0 2px 18px rgba(0,0,0,.45);
}
.preview-banner.active { display: flex; }

.preview-banner-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
  box-shadow: 0 0 6px rgba(200,169,81,.7);
  animation: pulse-dot 2.4s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: .85; transform: scale(1);    box-shadow: 0 0 6px rgba(200,169,81,.55); }
  50%       { opacity: 1;   transform: scale(1.3); box-shadow: 0 0 10px rgba(200,169,81,.9); }
}
.preview-banner-text {
  font-size: .73rem; letter-spacing: .08em;
  color: rgba(200,169,81,.95);
  text-transform: uppercase;
}
.preview-banner-text, .preview-banner-dot { pointer-events: none; }
.preview-banner-btn {
  pointer-events: auto; /* restore clickability for the button only */
  background: rgba(200,169,81,.14);
  border: 1px solid rgba(200,169,81,.5);
  border-radius: 20px;
  padding: 4px 14px;
  font-size: .71rem; letter-spacing: .06em;
  color: var(--gold); cursor: pointer;
  transition: all var(--t-fast) var(--ease);
  margin-left: 6px;
}
.preview-banner-btn:hover {
  background: rgba(200,169,81,.26);
  border-color: rgba(200,169,81,.8);
  box-shadow: 0 0 12px rgba(200,169,81,.2);
}

/* Shift layout down when banner is active */
body.preview-mode .sidebar { top: calc(var(--hh) + var(--pb-h)); }
body.preview-mode .main    { top: calc(var(--hh) + var(--pb-h)); }
body.preview-mode footer.lila-copyright { bottom: 0; } /* footer unaffected */

body.light-mode .preview-banner {
  background: rgba(24,18,4,.9);
  border-top-color: rgba(200,169,81,.18);
  border-bottom-color: rgba(200,169,81,.35);
}

/* ════════════════════════════════════════════════════════
   MY ORDERS v3 — ord-* namespace
════════════════════════════════════════════════════════ */

/* ── Pane system ── */
.ord-pane { display: none; }
.ord-pane.active { display: block; }


/* ── View switcher ── */
/* ── Split nav bar ── */
.ord-switcher {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 48px 24px; gap: 12px;
}
.ord-sw-left  { display: flex; gap: 5px; }
.ord-sw-right { display: flex; align-items: center; gap: 4px; }
.ord-sw-right.hidden { display: none; }

/* Shared pill base — both sides use same size/shape */
.ord-sw-btn,
.ord-filter-pill {
  background: none; border: 1px solid transparent; border-radius: 20px;
  padding: 5px 14px; font-size: .58rem; letter-spacing: .07em; text-transform: uppercase;
  color: var(--text-3); cursor: pointer; font-family: 'Montserrat', sans-serif; font-weight: 600;
  transition: all .16s var(--ease);
}
.ord-sw-btn:hover,
.ord-filter-pill:hover { color: var(--text-2); border-color: rgba(255,255,255,.1); }

/* Pane buttons — gold active (you are HERE) */
.ord-sw-btn { border-color: var(--border); }
.ord-sw-btn.active { background: rgba(200,169,81,.08); border-color: rgba(200,169,81,.3); color: var(--gold-hi); }

/* Filter pills — white active (what you're SEEING) */
.ord-filter-pill.active { color: var(--text-1); border-color: rgba(255,255,255,.14); background: rgba(255,255,255,.04); }

/* Soft divider between left and right groups */
.ord-sw-right { border-left: 1px solid var(--border); padding-left: 12px; }

.ord-filter-count { font-size: .56rem; color: var(--text-3); letter-spacing: .04em; margin-left: 2px; }

/* ── Type tag on order rows ── */
.ord-type-tag {
  display: inline-flex; align-items: center; vertical-align: middle;
  font-size: .48rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 600;
  font-family: 'Montserrat', sans-serif;
  padding: 2px 7px; border-radius: 10px; margin-left: 7px; line-height: 1;
  border: 1px solid transparent; position: relative; top: -1px;
}
.ord-type-tag.phys { color: var(--amber); border-color: rgba(232,160,48,.22); background: rgba(232,160,48,.07); }
.ord-type-tag.digi { color: var(--gold-hi); border-color: rgba(200,169,81,.22); background: rgba(200,169,81,.07); }

/* ── Summary strip ── */
.ord-summary-strip {
  display: flex; border: 1px solid var(--border); border-radius: var(--r-sm);
  overflow: hidden; margin-bottom: 20px; background: var(--bg-2);
}
.ord-s-cell {
  flex: 1; padding: 14px 18px;
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 5px;
}
.ord-s-cell:last-child { border-right: none; }
.ord-s-val {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem; font-weight: 400; line-height: 1; color: var(--text-1);
  transition: opacity .2s var(--ease);
}
.ord-s-val em { font-style: italic; color: var(--gold-hi); }
.ord-s-lbl {
  font-size: .5rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-3); font-family: 'Montserrat', sans-serif; font-weight: 600;
}

/* ── Orders list container ── */
.ord-list {
  border: 1px solid var(--border); border-radius: var(--r-sm); overflow: hidden;
}
.ord-list:empty { display: none; }

/* ── Order row ── */
.ord-row + .ord-row { border-top: 1px solid var(--border); }
.ord-row-header {
  display: grid;
  grid-template-columns: 76px 1fr 108px 96px 126px 30px;
  align-items: center; padding: 0 18px; height: 52px;
  cursor: pointer; background: var(--bg-2);
  transition: background .14s var(--ease);
  user-select: none;
}
.ord-row-header:hover { background: var(--bg-1); }
.ord-row.open .ord-row-header { background: var(--bg-1); }
.ord-row-num   { font-size: .62rem; color: var(--text-3); letter-spacing: .03em; }
.ord-row-name  {
  font-family: 'Cormorant Garamond', serif;
  font-size: .98rem; font-weight: 400; color: var(--text-1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  padding-right: 14px;
}
.ord-row-date   { font-size: .63rem; color: var(--text-2); }
.ord-row-amount { font-size: .73rem; color: var(--text-1); font-weight: 500; }
.ord-row-status { display: flex; align-items: center; }
.ord-row-chevron {
  display: flex; align-items: center; justify-content: flex-end;
  color: var(--text-3);
}
.ord-row-chevron svg { transition: transform .25s var(--ease); }
.ord-row.open .ord-row-chevron svg { transform: rotate(180deg); }

/* ── Badges ── */
.ord-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 20px;
  font-size: .58rem; letter-spacing: .06em; text-transform: uppercase;
  font-family: 'Montserrat', sans-serif; font-weight: 600; white-space: nowrap;
}
.ord-badge-dot { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }
.ord-badge-gold   { background: rgba(200,169,81,.08); border: 1px solid rgba(200,169,81,.28); color: var(--gold-hi); }
.ord-badge-gold   .ord-badge-dot { background: var(--gold-hi); }
.ord-badge-green  { background: rgba(76,175,125,.08); border: 1px solid rgba(76,175,125,.28); color: #6abf6a; }
.ord-badge-green  .ord-badge-dot { background: #6abf6a; }
.ord-badge-amber  { background: rgba(232,160,48,.08); border: 1px solid rgba(232,160,48,.28); color: #e8a030; }
.ord-badge-amber  .ord-badge-dot { background: #e8a030; }
.ord-badge-paid   { background: rgba(76,175,125,.08); border: 1px solid rgba(76,175,125,.28); color: #6abf6a; }
.ord-badge-paid   .ord-badge-dot { background: #6abf6a; }
.ord-badge-trial  { background: rgba(200,169,81,.08); border: 1px solid rgba(200,169,81,.28); color: var(--gold-hi); }
.ord-badge-trial  .ord-badge-dot { background: var(--gold-hi); }

/* ── Order detail ── */
.ord-row-detail {
  overflow: hidden; max-height: 0;
  background: var(--bg-1);
  transition: max-height .32s var(--ease);
}
.ord-row.open .ord-row-detail { max-height: 900px; }
.ord-row.open .ord-row-header { border-bottom: 1px solid var(--border); }
.ord-detail-inner { padding: 20px 22px 0; }
.ord-detail-grid { display: grid; grid-template-columns: 1fr 250px; gap: 22px; margin-bottom: 18px; }
.ord-detail-label {
  font-size: .52rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 10px; font-family: 'Montserrat', sans-serif;
}
/* Items */
.ord-item-row {
  display: flex; align-items: center; gap: 11px;
  padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.04);
}
.ord-item-row:last-child { border-bottom: none; }
.ord-item-thumb {
  width: 34px; height: 34px; border-radius: 5px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Cormorant Garamond', serif; font-size: .88rem;
  font-style: italic; font-weight: 500; color: rgba(255,255,255,.45);
}
.ord-item-name {
  flex: 1; font-family: 'Cormorant Garamond', serif;
  font-size: .92rem; font-weight: 400; color: var(--text-1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ord-item-sub  { font-size: .6rem; color: var(--text-3); margin-top: 2px; }
.ord-item-price { font-size: .68rem; color: var(--text-2); flex-shrink: 0; }
/* Order info col */
.ord-info-col {
  background: rgba(255,255,255,.02); border: 1px solid var(--border);
  border-radius: 7px; padding: 14px; align-self: start;
}
.ord-info-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 4px 0; border-bottom: 1px solid rgba(255,255,255,.04);
}
.ord-info-row:last-child { border-bottom: none; }
.ord-info-key { font-size: .6rem; color: var(--text-3); }
.ord-info-val { font-size: .65rem; color: var(--text-2); text-align: right; max-width: 138px; }
.ord-info-val .hl  { color: var(--text-1); font-weight: 600; }
.ord-info-val .gld { color: var(--gold-hi); }
.ord-info-val .grn { color: #6abf6a; }
.ord-info-val .amb { color: #e8a030; }
.ord-tracking-link {
  color: var(--gold-hi); text-decoration: none; font-size: .65rem;
  display: inline-flex; align-items: center; gap: 3px;
  transition: opacity .14s var(--ease);
}
.ord-tracking-link:hover { opacity: .72; }

/* ── Tracking bar ── */
.ord-tracking-wrap { border-top: 1px solid var(--border); padding: 18px 0 16px; }
.ord-tracking-label {
  font-size: .52rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 16px; font-family: 'Montserrat', sans-serif;
}
.ord-tracking-steps { display: flex; align-items: flex-start; padding: 0 10px; }
.ord-tracking-step  { display: flex; flex-direction: column; align-items: center; flex: 1; position: relative; }
.ord-step-top { display: flex; align-items: center; width: 100%; }
.ord-step-dot {
  width: 9px; height: 9px; border-radius: 50%;
  flex-shrink: 0; position: relative; z-index: 2; margin: 0 auto;
}
.ord-step-dot.done    { background: #6abf6a; box-shadow: 0 0 0 2px rgba(106,191,106,.18); }
.ord-step-dot.active  { background: #e8a030; box-shadow: 0 0 0 3px rgba(232,160,48,.15); }
.ord-step-dot.pending { background: var(--bg-1); border: 1.5px solid var(--border); }
.ord-step-line {
  position: absolute; top: 4px; height: 1.5px;
  left: calc(50% + 5px); right: calc(-50% + 5px); z-index: 1;
}
.ord-step-line.done    { background: rgba(106,191,106,.3); }
.ord-step-line.pending { background: var(--border); }
.ord-tracking-step:last-child .ord-step-line { display: none; }
.ord-step-label { font-size: .56rem; color: var(--text-3); margin-top: 6px; text-align: center; white-space: nowrap; }
.ord-step-date  { font-size: .52rem; color: var(--text-3); margin-top: 2px; text-align: center; opacity: .6; }
.ord-step-label.done   { color: var(--text-2); }
.ord-step-label.active { color: #e8a030; }

/* ── Review prompt ── */
.ord-review-prompt {
  border-top: 1px solid var(--border); padding: 14px 0;
  display: flex; align-items: center; justify-content: space-between;
}
.ord-review-text { font-size: .7rem; color: var(--text-2); font-family: 'Cormorant Garamond', serif; font-style: italic; }
.ord-review-stars { display: flex; gap: 4px; cursor: pointer; }
.ord-review-star { font-size: .95rem; color: var(--text-3); transition: color .12s var(--ease); line-height: 1; }
.ord-review-star:hover, .ord-review-star.active { color: var(--gold-hi); }

/* ── Actions row ── */
.ord-actions-row {
  border-top: 1px solid var(--border);
  padding: 12px 0 16px; display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
}
.ord-actions-meta { margin-left: auto; font-size: .6rem; color: var(--text-3); font-style: italic; }
.ord-btn-gold {
  background: rgba(200,169,81,.08); border: 1px solid rgba(200,169,81,.3); color: var(--gold-hi);
  transition: all .15s var(--ease);
}
.ord-btn-gold:hover { background: rgba(200,169,81,.15); border-color: rgba(200,169,81,.55); }

/* ── Empty state ── */
.ord-empty {
  padding: 48px 32px; text-align: center;
  border: 1px solid var(--border); border-radius: var(--r-sm);
  background: var(--bg-2);
}
.ord-empty.hidden { display: none; }
.ord-empty-icon   { font-size: 1.4rem; opacity: .18; margin-bottom: 12px; }
.ord-empty-title  {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem; font-weight: 300; font-style: italic;
  color: var(--text-2); margin-bottom: 6px;
}
.ord-empty-sub { font-size: .65rem; color: var(--text-3); line-height: 1.6; }

/* ════════════════════════════════════════
   SUBSCRIPTIONS PANE
════════════════════════════════════════ */

/* ── Annual nudge ── */
.ord-annual-nudge {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; border-radius: var(--r-sm); margin-bottom: 18px;
  background: linear-gradient(to right, rgba(200,169,81,.06), transparent);
  border: 1px solid rgba(200,169,81,.18);
}
.ord-an-icon  { color: var(--gold-hi); font-size: .8rem; flex-shrink: 0; }
.ord-an-text  { flex: 1; }
.ord-an-title { font-size: .7rem; color: var(--text-1); font-weight: 500; margin-bottom: 2px; }
.ord-an-sub   { font-size: .62rem; color: var(--text-3); }
.ord-an-btn {
  background: rgba(200,169,81,.1); border: 1px solid rgba(200,169,81,.3);
  color: var(--gold-hi); font-family: 'Montserrat', sans-serif; font-size: .58rem;
  font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  padding: 6px 14px; border-radius: var(--r-sm); cursor: pointer;
  transition: all .15s var(--ease); white-space: nowrap; flex-shrink: 0;
}
.ord-an-btn:hover { background: rgba(200,169,81,.18); border-color: rgba(200,169,81,.55); }
.ord-an-dismiss {
  background: none; border: none; color: var(--text-3); cursor: pointer;
  font-size: .85rem; padding: 4px; line-height: 1; flex-shrink: 0;
  transition: color .14s var(--ease);
}
.ord-an-dismiss:hover { color: var(--text-2); }

/* ── Plan card ── */
.ord-plan-card {
  border: 1px solid rgba(200,169,81,.22); border-radius: var(--r-sm);
  background: linear-gradient(135deg, rgba(200,169,81,.04) 0%, transparent 60%), var(--bg-2);
  padding: 20px 22px; margin-bottom: 22px;
  position: relative; overflow: hidden;
}
.ord-plan-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(to right, transparent, rgba(200,169,81,.28), transparent);
}
.ord-plan-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 14px; }
.ord-plan-eyebrow { font-size: .5rem; letter-spacing: .22em; text-transform: uppercase; color: var(--text-3); margin-bottom: 4px; }
.ord-plan-name { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; font-weight: 300; line-height: 1.1; }
.ord-plan-name em { font-style: italic; color: var(--gold-hi); }
.ord-active-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 20px;
  border: 1px solid rgba(106,191,106,.28); background: rgba(106,191,106,.06);
  font-size: .58rem; letter-spacing: .06em; text-transform: uppercase; color: #6abf6a;
  font-family: 'Montserrat', sans-serif; font-weight: 600;
}
.ord-pulse-dot {
  width: 6px; height: 6px; border-radius: 50%; background: #6abf6a;
  animation: ord-pulse 2s ease-in-out infinite;
}
@keyframes ord-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(106,191,106,.5); }
  50%       { opacity: .8; box-shadow: 0 0 0 4px rgba(106,191,106,0); }
}
/* Payment method */
.ord-plan-payment {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 14px; padding: 9px 12px;
  border: 1px solid var(--border); border-radius: 7px;
  background: rgba(255,255,255,.02);
}
.ord-pp-icon { color: var(--text-3); flex-shrink: 0; }
.ord-pp-text { flex: 1; font-size: .66rem; color: var(--text-2); }
.ord-pp-edit {
  font-size: .58rem; color: var(--text-3); background: none; border: none; cursor: pointer;
  border-bottom: 1px solid var(--border); font-family: 'Montserrat', sans-serif;
  transition: color .14s; padding: 0;
}
.ord-pp-edit:hover { color: var(--text-2); }
/* Trial bar */
.ord-trial-bar {
  margin-bottom: 14px; padding: 12px;
  border: 1px solid rgba(232,160,48,.18); border-radius: 7px;
  background: rgba(232,160,48,.04);
}
.ord-trial-bar.hidden { display: none; }
.ord-trial-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 9px; }
.ord-trial-label { font-size: .62rem; color: #e8a030; letter-spacing: .04em; }
.ord-trial-days  { font-size: .6rem; color: var(--text-3); font-style: italic; font-family: 'Cormorant Garamond', serif; }
.ord-trial-track { height: 3px; background: rgba(255,255,255,.07); border-radius: 2px; overflow: hidden; }
.ord-trial-fill  { height: 100%; border-radius: 2px; background: linear-gradient(to right, #e8a030, rgba(232,160,48,.5)); }
.ord-trial-note  { font-size: .58rem; color: var(--text-3); margin-top: 6px; font-style: italic; }
/* Plan meta strip */
.ord-plan-meta {
  display: grid; grid-template-columns: repeat(4,1fr);
  border: 1px solid var(--border); border-radius: 7px;
  overflow: hidden; margin-bottom: 14px; background: rgba(255,255,255,.02);
}
.ord-pm-cell { padding: 11px 14px; border-right: 1px solid var(--border); display: flex; flex-direction: column; gap: 3px; }
.ord-pm-cell:last-child { border-right: none; }
.ord-pm-val  { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; font-weight: 400; line-height: 1; }
.ord-pm-gold { font-style: italic; color: var(--gold-hi); }
.ord-pm-md   { font-size: 1rem !important; }
.ord-pm-lbl  { font-size: .52rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-3); }
/* Plan actions + note */
.ord-plan-actions { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.ord-plan-note    { font-size: .62rem; color: var(--text-3); line-height: 1.5; font-style: italic; margin-bottom: 14px; }
/* Billing reminder */
.ord-billing-reminder {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border: 1px solid var(--border); border-radius: 7px;
  background: rgba(255,255,255,.02);
}
.ord-br-label { font-size: .66rem; color: var(--text-2); margin-bottom: 2px; }
.ord-br-sub   { font-size: .58rem; color: var(--text-3); }
.ord-billing-reminder > div:first-child { flex: 1; }
.ord-toggle { position: relative; width: 34px; height: 18px; display: inline-block; cursor: pointer; }
.ord-toggle input { opacity: 0; width: 0; height: 0; }
.ord-toggle-slider {
  position: absolute; cursor: pointer; inset: 0;
  background: rgba(255,255,255,.1); border-radius: 20px;
  transition: background .2s var(--ease);
}
.ord-toggle-slider::before {
  content: ''; position: absolute;
  width: 12px; height: 12px; border-radius: 50%;
  left: 3px; top: 3px; background: rgba(255,255,255,.35);
  transition: transform .2s var(--ease), background .2s var(--ease);
}
.ord-toggle input:checked + .ord-toggle-slider { background: rgba(200,169,81,.22); }
.ord-toggle input:checked + .ord-toggle-slider::before { transform: translateX(16px); background: var(--gold-hi); }

/* ── Section blocks ── */
.ord-section-block { margin-bottom: 24px; }
.ord-section-heading {
  font-size: .54rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 14px; padding-bottom: 9px;
  border-bottom: 1px solid var(--border); font-family: 'Montserrat', sans-serif;
}
.ord-features-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px 0; }
.ord-feature-row {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,.04);
}
.ord-feature-row:nth-child(odd) { padding-right: 20px; }
.ord-feat-check { color: var(--gold-hi); font-size: .66rem; flex-shrink: 0; line-height: 1; }
.ord-feat-name  { font-size: .68rem; color: var(--text-2); }

/* ── Billing table ── */
.ord-billing-wrap {
  border: 1px solid var(--border); border-radius: var(--r-sm); overflow: hidden;
}
.ord-billing-table {
  width: 100%; border-collapse: collapse;
}
.ord-billing-table thead tr { background: var(--bg-2); }
.ord-billing-table th {
  padding: 9px 14px; text-align: left;
  font-size: .52rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-3); font-family: 'Montserrat', sans-serif; font-weight: 600;
  border-bottom: 1px solid var(--border);
}
.ord-billing-table td {
  padding: 11px 14px; font-size: .68rem; color: var(--text-2);
  border-bottom: 1px solid rgba(255,255,255,.04); vertical-align: middle;
}
.ord-billing-table tr:last-child td { border-bottom: none; }
.ord-billing-table tbody tr { background: var(--bg-2); transition: background .12s var(--ease); }
.ord-billing-table tbody tr:hover { background: var(--bg-1); }
.ord-bt-cell { display: flex; align-items: center; gap: 9px; }
.ord-dl-link {
  font-size: .6rem; color: var(--text-3); text-decoration: none;
  border-bottom: 1px solid var(--border);
  transition: color .14s var(--ease), border-color .14s var(--ease);
}
.ord-dl-link:hover { color: var(--text-2); border-color: rgba(255,255,255,.18); }

/* ── Referral card ── */
.ord-referral-card {
  border: 1px solid var(--border); border-radius: var(--r-sm);
  background: var(--bg-2); padding: 18px 20px; margin-bottom: 22px;
}
.ord-ref-heading {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem; font-weight: 300; font-style: italic;
  color: var(--text-1); margin-bottom: 4px;
}
.ord-ref-sub  { font-size: .63rem; color: var(--text-3); line-height: 1.55; margin-bottom: 12px; }
.ord-ref-row  { display: flex; align-items: center; gap: 8px; }
.ord-ref-field {
  flex: 1; background: rgba(255,255,255,.03); border: 1px solid var(--border);
  border-radius: 6px; padding: 8px 11px;
  font-size: .65rem; color: var(--text-3); user-select: all;
}
.ord-ref-copy {
  background: none; border: 1px solid var(--border); border-radius: 6px;
  padding: 8px 14px; font-size: .6rem; color: var(--text-2);
  font-family: 'Montserrat', sans-serif; font-weight: 600; letter-spacing: .06em;
  text-transform: uppercase; cursor: pointer; transition: all .15s var(--ease); flex-shrink: 0;
}
.ord-ref-copy:hover { border-color: rgba(255,255,255,.15); color: var(--text-1); }
.ord-ref-copy.copied { border-color: rgba(106,191,106,.4); color: #6abf6a; }

/* ── Subscriptions footer ── */
.ord-sub-footer {
  margin-bottom: 32px; padding: 14px 18px;
  border: 1px solid var(--border); border-radius: 7px; background: var(--bg-2);
  font-size: .62rem; color: var(--text-3); font-style: italic;
  font-family: 'Cormorant Garamond', serif; line-height: 1.7;
}

/* ════════════════════════════════════════
   CANCEL MODAL
════════════════════════════════════════ */
.ord-modal-overlay {
  display: none; position: fixed; inset: 0; z-index: 750;
  background: rgba(0,0,0,.7); backdrop-filter: blur(5px);
  align-items: center; justify-content: center;
}
.ord-modal-overlay.open { display: flex; }
.ord-modal-card {
  background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--r-sm);
  padding: 26px 26px 22px; max-width: 400px; width: 90%;
  position: relative; animation: ord-slide-up .2s var(--ease);
}
@keyframes ord-slide-up {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.ord-modal-close {
  position: absolute; top: 14px; right: 16px;
  background: none; border: none; color: var(--text-3); font-size: 1rem;
  cursor: pointer; line-height: 1; transition: color .14s;
}
.ord-modal-close:hover { color: var(--text-2); }
.ord-modal-eyebrow { font-size: .5rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-3); margin-bottom: 5px; }
.ord-modal-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem; font-weight: 300; margin-bottom: 4px;
}
.ord-modal-title em { font-style: italic; color: var(--crimson); }
.ord-modal-sub { font-size: .65rem; color: var(--text-3); margin-bottom: 18px; line-height: 1.5; }
.ord-loss-list {
  list-style: none; margin-bottom: 16px;
  border: 1px solid var(--border); border-radius: 7px; overflow: hidden;
  background: rgba(255,255,255,.02);
}
.ord-loss-item {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 12px; border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: .68rem; color: var(--text-2);
}
.ord-loss-item:last-child { border-bottom: none; }
.ord-loss-icon { color: var(--text-3); font-size: .6rem; flex-shrink: 0; }
.ord-modal-pause-note {
  font-size: .64rem; color: var(--text-3); margin-bottom: 14px;
  font-style: italic; font-family: 'Cormorant Garamond', serif; line-height: 1.55;
  border-left: 2px solid rgba(200,169,81,.22); padding-left: 11px;
}
.ord-modal-actions { display: flex; flex-direction: column; gap: 6px; }
.ord-modal-btn    { width: 100%; justify-content: center; }
.ord-modal-divider { height: 1px; background: var(--border); margin: 2px 0; }

/* ══════════════════════════════════════════════════════════════
   CONFIRMATION MODAL SYSTEM — wiz-card state machines
   (sign-out, delete, export, session-expired)
══════════════════════════════════════════════════════════════ */

/* Hard-block overlay: backdrop is non-interactive but card is still clickable.
   MUST be scoped to .active — without it the inactive modal's card would sit on
   top of every other modal and intercept all pointer events. */
.signout-confirm.hard-block { pointer-events: none; }
.signout-confirm.hard-block.active .wiz-card { pointer-events: all; }

/* Card entrance animation via toggled class */
.wiz-card.entering {
  animation: wiz-emerge .38s cubic-bezier(.16,.87,.32,1.1) both;
}

/* ── Loading state ── */
.wiz-loading {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 8px 0 4px;
}
.wiz-spinner {
  width: 36px; height: 36px; border-radius: 50%; margin: 0 auto 28px;
  border: 2px solid rgba(255,255,255,.06);
  animation: wiz-spin .95s linear infinite;
}
.wiz-spinner.gold {
  border-top-color: rgba(200,169,81,.6);
  border-right-color: rgba(200,169,81,.18);
}
.wiz-spinner.crimson {
  border-top-color: rgba(200,16,46,.55);
  border-right-color: rgba(200,16,46,.14);
}
@keyframes wiz-spin { to { transform: rotate(360deg); } }
.wiz-loading .wiz-title { font-size: 1.55rem; color: rgba(245,240,228,.55); }
.wiz-loading .wiz-sub   { margin-bottom: 0; font-size: .88rem; color: rgba(240,235,224,.25); }

/* ── Dismiss progress bar ── */
.wiz-done-btn { margin: 18px auto 4px; display: block; min-width: 120px; }

.dismiss-bar {
  width: 100%; height: 1px; border-radius: 99px; margin-top: 28px; overflow: hidden;
}
.dismiss-bar-fill { height: 100%; width: 0%; border-radius: 99px; }
.dismiss-bar.gold { background: rgba(200,169,81,.1); }
.dismiss-bar.gold .dismiss-bar-fill { background: rgba(200,169,81,.4); }
.dismiss-bar.red  { background: rgba(200,16,46,.08); }
.dismiss-bar.red  .dismiss-bar-fill { background: rgba(200,16,46,.35); }
.dismiss-bar-fill.running-gold { animation: dismiss-fill-gold 1.9s linear forwards; }
.dismiss-bar-fill.running-red  { animation: dismiss-fill-red  2.6s linear forwards; }
@keyframes dismiss-fill-gold { from { width: 0% } to { width: 100% } }
@keyframes dismiss-fill-red  { from { width: 0% } to { width: 100% } }

/* ── Sign-out success emblem — breathing gold ring ── */
.emblem-signout {
  width: 80px; height: 80px; margin: 0 auto 24px; border-radius: 50%;
  background: radial-gradient(ellipse at 50% 30%, rgba(200,169,81,.09), transparent);
  border: 1px solid rgba(200,169,81,.2);
  display: flex; align-items: center; justify-content: center;
  animation: so-ring-breathe 2.6s ease-in-out infinite;
}
@keyframes so-ring-breathe {
  0%, 100% { box-shadow: 0 0 0 5px rgba(200,169,81,.04); }
  50%       { box-shadow: 0 0 0 12px rgba(200,169,81,.08); }
}
.signout-check {
  stroke-dasharray: 32; stroke-dashoffset: 32;
  opacity: 0;
  animation: check-draw .55s .08s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes check-draw {
  0%   { stroke-dashoffset: 32; opacity: 1; }
  100% { stroke-dashoffset: 0;  opacity: 1; }
}

/* ── Sign-out soft-error emblem — muted neutral ── */
.emblem-signout-warn {
  width: 64px; height: 64px; margin: 0 auto 22px; border-radius: 50%;
  background: radial-gradient(ellipse at 50% 30%, rgba(240,235,224,.04), transparent);
  border: 1px solid rgba(240,235,224,.1);
  display: flex; align-items: center; justify-content: center;
}

/* ── Eyebrow colour variants ── */
.wiz-eyebrow.crimson { color: rgba(200,16,46,.4); }
.wiz-eyebrow.crimson::before, .wiz-eyebrow.crimson::after {
  background: linear-gradient(90deg, transparent, rgba(200,16,46,.25));
}
.wiz-eyebrow.error-tag { color: rgba(200,16,46,.5); }
.wiz-eyebrow.error-tag::before, .wiz-eyebrow.error-tag::after {
  background: linear-gradient(90deg, transparent, rgba(200,16,46,.3));
}
.wiz-eyebrow.muted { color: rgba(240,235,224,.25); }
.wiz-eyebrow.muted::before, .wiz-eyebrow.muted::after {
  background: linear-gradient(90deg, transparent, rgba(240,235,224,.12));
}

/* ── Delete success emblem — crimson dissolve ── */
.emblem-delete {
  width: 80px; height: 80px; margin: 0 auto 24px; border-radius: 50%;
  background: radial-gradient(ellipse at 50% 30%, rgba(200,16,46,.07), transparent);
  border: 1px solid rgba(200,16,46,.2);
  display: flex; align-items: center; justify-content: center;
  animation: delete-dissolve 2.4s .9s ease-in forwards;
}
@keyframes delete-dissolve {
  0%   { opacity: 1; transform: scale(1);   filter: blur(0); }
  100% { opacity: 0; transform: scale(.78); filter: blur(4px); }
}
.delete-x-1 {
  stroke-dasharray: 20; stroke-dashoffset: 20;
  animation: stroke-draw .32s .08s ease-out forwards;
}
.delete-x-2 {
  stroke-dasharray: 20; stroke-dashoffset: 20;
  animation: stroke-draw .32s .32s ease-out forwards;
}
@keyframes stroke-draw { to { stroke-dashoffset: 0; } }

/* ── Export success emblem — gold arrow drops into tray ── */
.emblem-export {
  width: 80px; height: 80px; margin: 0 auto 24px; border-radius: 50%;
  background: radial-gradient(ellipse at 50% 60%, rgba(200,169,81,.1), transparent);
  border: 1px solid rgba(200,169,81,.22);
  display: flex; align-items: center; justify-content: center;
  animation: export-settle 2s ease-in-out infinite;
}
@keyframes export-settle {
  0%, 100% { box-shadow: 0 0 0 4px rgba(200,169,81,.04); }
  50%       { box-shadow: 0 0 0 8px rgba(200,169,81,.07); }
}
.dl-shaft {
  stroke-dasharray: 16; stroke-dashoffset: 16;
  animation: stroke-draw .2s .04s ease-out forwards;
}
.dl-head {
  stroke-dasharray: 22; stroke-dashoffset: 22;
  animation: stroke-draw .28s .2s ease-out forwards;
}
.dl-tray {
  stroke-dasharray: 20; stroke-dashoffset: 20;
  animation: stroke-draw .24s .44s ease-out forwards;
}

/* ── Session expired icon ── */
.session-icon {
  width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 28px;
  background: radial-gradient(ellipse at 50% 30%, rgba(200,169,81,.07), transparent);
  border: 1px solid rgba(200,169,81,.18);
  display: flex; align-items: center; justify-content: center;
}

/* ── Error states ── */
.wiz-error-icon {
  width: 52px; height: 52px; border-radius: 50%; margin: 0 auto 22px;
  background: radial-gradient(ellipse at 50% 30%, rgba(200,16,46,.06), transparent);
  border: 1px solid rgba(200,16,46,.16);
  display: flex; align-items: center; justify-content: center;
}
.wiz-error-glyph {
  font-size: 1.1rem; color: rgba(200,16,46,.4);
  font-family: 'Montserrat', sans-serif; font-weight: 700; line-height: 1;
  letter-spacing: 0;
}
.wiz-error-note {
  font-size: .44rem; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(200,16,46,.3); margin-top: 20px;
}
.wiz-error-note a {
  color: rgba(200,169,81,.38); text-decoration: none;
  border-bottom: 1px solid rgba(200,169,81,.18);
  transition: color .16s ease, border-color .16s ease;
}
.wiz-error-note a:hover { color: rgba(200,169,81,.7); border-color: rgba(200,169,81,.4); }

/* ── Type-to-confirm input ── */
.wiz-input {
  width: 100%; font-family: 'Montserrat', sans-serif; font-size: .62rem;
  letter-spacing: .18em; text-transform: uppercase;
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px; padding: 13px 16px; color: var(--text);
  margin-bottom: 24px; text-align: center; outline: none;
  transition: border-color 160ms var(--ease);
  box-sizing: border-box;
  position: relative; z-index: 1;
}
.wiz-input:focus { border-color: rgba(180,30,50,.4); }
.wiz-input::placeholder { color: rgba(240,235,224,.2); }

/* ══════════════════════════════════════════════════════════════
   TOAST SYSTEM
══════════════════════════════════════════════════════════════ */
.toast-stack {
  position: fixed; bottom: 28px; right: 28px; z-index: 800;
  display: flex; flex-direction: column-reverse; gap: 10px;
  align-items: flex-end; pointer-events: none;
}
.toast {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 16px; border-radius: 10px;
  width: 300px; pointer-events: all;
  font-family: 'Montserrat', sans-serif;
  font-size: .5rem; font-weight: 500; letter-spacing: .05em; line-height: 1.55;
  backdrop-filter: blur(20px);
  box-shadow: 0 8px 32px rgba(0,0,0,.65), 0 0 0 1px rgba(255,255,255,.04);
  animation: toast-in .3s cubic-bezier(.16,.87,.32,1.1) both;
  position: relative; overflow: hidden;
}
.toast.leaving { animation: toast-out .24s ease-in forwards; }
@keyframes toast-in  { from { opacity: 0; transform: translateX(16px) scale(.96); } to { opacity: 1; transform: none; } }
@keyframes toast-out { from { opacity: 1; transform: none; } to { opacity: 0; transform: translateX(16px) scale(.96); } }
.toast-error   { background: rgba(18,7,9,.94);  border: 1px solid rgba(200,46,46,.22);  color: rgba(240,235,224,.7); }
.toast-success { background: rgba(6,13,9,.94);  border: 1px solid rgba(70,160,70,.2);   color: rgba(240,235,224,.7); }
.toast-warning { background: rgba(14,11,5,.94); border: 1px solid rgba(200,169,81,.2);  color: rgba(240,235,224,.7); }
.toast-info    { background: rgba(7,9,14,.94);  border: 1px solid rgba(90,130,200,.18); color: rgba(240,235,224,.7); }
.toast-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.toast-error   .toast-dot { background: rgba(220,70,70,.85); }
.toast-success .toast-dot { background: rgba(70,180,70,.85); }
.toast-warning .toast-dot { background: rgba(200,169,81,.85); }
.toast-info    .toast-dot { background: rgba(100,140,210,.85); }
.toast-body  { flex: 1; min-width: 0; }
.toast-title { font-weight: 700; color: rgba(240,235,224,.88); margin-bottom: 1px; }
.toast-msg   { font-size: .46rem; color: rgba(240,235,224,.45); }
.toast-action {
  display: inline-block; margin-top: 7px; font-size: .43rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; cursor: pointer;
  color: rgba(200,169,81,.55); background: none; border: none;
  font-family: 'Montserrat', sans-serif; padding: 0;
  transition: color .14s ease;
}
.toast-action:hover { color: rgba(200,169,81,.95); }
.toast-close {
  background: none; border: none; cursor: pointer; color: rgba(240,235,224,.18);
  font-size: .75rem; line-height: 1; padding: 0; flex-shrink: 0;
  transition: color .14s ease; margin-top: 1px;
}
.toast-close:hover { color: rgba(240,235,224,.55); }
.toast-timer {
  position: absolute; bottom: 0; left: 0; height: 2px; border-radius: 0 0 10px 10px;
}
.toast-error   .toast-timer { background: rgba(200,70,70,.35); }
.toast-success .toast-timer { background: rgba(70,180,70,.35); }
.toast-warning .toast-timer { background: rgba(200,169,81,.35); }
.toast-info    .toast-timer { background: rgba(100,140,210,.35); }
.toast-timer.running-4s { animation: timer-shrink 4.0s linear forwards; }
.toast-timer.running-2s { animation: timer-shrink 2.5s linear forwards; }
.toast-timer.running-5s { animation: timer-shrink 5.0s linear forwards; }
@keyframes timer-shrink { from { width: 100%; } to { width: 0%; } }

/* ══════════════════════════════════════════════════════════════
   SITE BANNERS
══════════════════════════════════════════════════════════════ */
.site-banner {
  position: fixed; top: 0; left: 0; right: 0; z-index: 900;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 10px 24px;
  font-family: 'Montserrat', sans-serif; font-size: .47rem;
  font-weight: 600; letter-spacing: .09em;
  transform: translateY(-100%);
  transition: transform .32s cubic-bezier(.16,.87,.32,1.1);
}
.site-banner.visible { transform: translateY(0); }
.site-banner.bn-offline  { background: rgba(18,13,5,.97); border-bottom: 1px solid rgba(200,169,81,.18); color: rgba(200,169,81,.7); }
.site-banner.bn-online   { background: rgba(5,13,8,.97);  border-bottom: 1px solid rgba(70,160,70,.2);   color: rgba(120,195,120,.7); }
.site-banner.bn-degraded { background: rgba(18,7,5,.97);  border-bottom: 1px solid rgba(200,70,50,.2);   color: rgba(220,110,90,.65); }
.banner-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.bn-offline  .banner-dot { background: rgba(200,169,81,.75); box-shadow: 0 0 6px rgba(200,169,81,.4); }
.bn-online   .banner-dot { background: rgba(70,190,70,.75);  box-shadow: 0 0 6px rgba(70,190,70,.4); }
.bn-degraded .banner-dot { background: rgba(220,90,70,.75);  box-shadow: 0 0 6px rgba(220,90,70,.4); }
.banner-left  { display: flex; align-items: center; gap: 10px; }
.banner-right { display: flex; align-items: center; gap: 16px; }
.banner-action {
  font-size: .42rem; letter-spacing: .12em; text-transform: uppercase;
  background: none; border: none; cursor: pointer; font-family: 'Montserrat', sans-serif;
  font-weight: 700; opacity: .55; transition: opacity .14s ease; padding: 0;
  color: inherit;
}
.banner-action:hover { opacity: 1; }
.banner-dismiss {
  background: none; border: none; cursor: pointer;
  color: rgba(240,235,224,.2); font-size: .85rem; line-height: 1;
  padding: 0; transition: color .14s ease;
}
.banner-dismiss:hover { color: rgba(240,235,224,.55); }

/* ══════════════════════════════════════════════════════════════
   SECTION LOAD FAILURES
══════════════════════════════════════════════════════════════ */
.section-err-wrap {
  display: flex; gap: 14px; flex-wrap: wrap; justify-content: center;
  width: 100%;
}
.section-err-box {
  flex: 1; min-width: 240px; max-width: 340px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.09);
  border-radius: 16px; padding: 44px 28px; text-align: center;
}
.section-err-icon {
  width: 40px; height: 40px; border-radius: 50%; margin: 0 auto 16px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
  display: flex; align-items: center; justify-content: center;
}
.section-err-title {
  font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; font-style: italic;
  color: rgba(240,235,224,.5); margin-bottom: 7px;
}
.section-err-sub {
  font-size: .44rem; font-family: 'Montserrat', sans-serif; letter-spacing: .07em;
  color: rgba(240,235,224,.28); line-height: 1.75; margin-bottom: 18px;
}
.section-err-retry {
  font-family: 'Montserrat', sans-serif; font-size: .44rem; font-weight: 600;
  letter-spacing: .15em; text-transform: uppercase; padding: 8px 18px;
  border-radius: 6px; background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1); color: rgba(240,235,224,.4);
  cursor: pointer; transition: all .16s ease;
}
.section-err-retry:hover { background: rgba(255,255,255,.08); color: rgba(240,235,224,.65); }

/* ══════════════════════════════════════════════════════════════
   LIGHT MODE — wiz-card modal system + all new UI states
══════════════════════════════════════════════════════════════ */

/* ── Card shell ── */
body.light-mode .wiz-card {
  background: #f6f2ea;
  background-image:
    radial-gradient(ellipse at 50% -5%,  rgba(160,130,40,.1)  0%, transparent 50%),
    radial-gradient(ellipse at 50% 105%, rgba(200,16,46,.04)  0%, transparent 50%),
    radial-gradient(ellipse at 0%   50%, rgba(160,130,40,.03) 0%, transparent 40%),
    radial-gradient(ellipse at 100% 50%, rgba(160,130,40,.03) 0%, transparent 40%);
  border: 1px solid rgba(0,0,0,.09);
  border-top: 1px solid rgba(160,130,40,.45);
  box-shadow:
    0 40px 80px rgba(0,0,0,.18),
    0 12px 32px rgba(0,0,0,.1),
    0 0 0 1px rgba(0,0,0,.04),
    inset 0 1px 0 rgba(255,255,255,.8),
    inset 0 -1px 0 rgba(0,0,0,.04);
}
body.light-mode .wiz-card::before {
  background: linear-gradient(90deg, transparent, rgba(160,130,40,.75), transparent);
}
body.light-mode .wiz-card::after {
  background: radial-gradient(ellipse at 50% 0%, rgba(160,130,40,.04) 0%, transparent 60%);
}

/* ── Step counter & pips ── */
body.light-mode .wiz-step-counter { color: rgba(130,100,30,.55); }
body.light-mode .wiz-step-pip     { background: rgba(0,0,0,.12); }
body.light-mode .wiz-step-pip.done   { background: rgba(130,100,30,.4); }
body.light-mode .wiz-step-pip.active { background: rgba(130,100,30,.85); }

/* ── Eyebrow ── */
body.light-mode .wiz-eyebrow {
  color: rgba(130,100,30,.7);
}
body.light-mode .wiz-eyebrow::before, body.light-mode .wiz-eyebrow::after {
  background: linear-gradient(90deg, transparent, rgba(130,100,30,.35));
}
body.light-mode .wiz-eyebrow.crimson { color: rgba(180,20,40,.45); }
body.light-mode .wiz-eyebrow.crimson::before, body.light-mode .wiz-eyebrow.crimson::after {
  background: linear-gradient(90deg, transparent, rgba(180,20,40,.25));
}
body.light-mode .wiz-eyebrow.error-tag { color: rgba(180,20,40,.55); }
body.light-mode .wiz-eyebrow.error-tag::before, body.light-mode .wiz-eyebrow.error-tag::after {
  background: linear-gradient(90deg, transparent, rgba(180,20,40,.3));
}
body.light-mode .wiz-eyebrow.muted { color: rgba(24,21,15,.3); }
body.light-mode .wiz-eyebrow.muted::before, body.light-mode .wiz-eyebrow.muted::after {
  background: linear-gradient(90deg, transparent, rgba(24,21,15,.12));
}

/* ── Title / sub / msg ── */
body.light-mode .wiz-title { color: rgba(24,21,15,.96); }
body.light-mode .wiz-sub   { color: rgba(24,21,15,.62); }
body.light-mode .wiz-loading .wiz-title { color: rgba(24,21,15,.45); }
body.light-mode .wiz-loading .wiz-sub   { color: rgba(24,21,15,.28); }

/* ── Loading spinner ── */
body.light-mode .wiz-spinner { border-color: rgba(0,0,0,.06); }
body.light-mode .wiz-spinner.gold {
  border-top-color:  rgba(160,130,40,.65);
  border-right-color: rgba(160,130,40,.2);
}
body.light-mode .wiz-spinner.crimson {
  border-top-color:  rgba(200,16,46,.5);
  border-right-color: rgba(200,16,46,.15);
}

/* ── Dismiss bar ── */
body.light-mode .dismiss-bar.gold { background: rgba(160,130,40,.12); }
body.light-mode .dismiss-bar.gold .dismiss-bar-fill { background: rgba(160,130,40,.5); }
body.light-mode .dismiss-bar.red  { background: rgba(200,16,46,.08); }
body.light-mode .dismiss-bar.red  .dismiss-bar-fill { background: rgba(200,16,46,.4); }

/* ── Success / state emblems ── */
body.light-mode .emblem-signout {
  background: radial-gradient(ellipse at 50% 30%, rgba(160,130,40,.12), transparent);
  border-color: rgba(160,130,40,.3);
}
body.light-mode .emblem-signout-warn {
  background: radial-gradient(ellipse at 50% 30%, rgba(24,21,15,.04), transparent);
  border-color: rgba(24,21,15,.12);
}
body.light-mode .emblem-delete {
  background: radial-gradient(ellipse at 50% 30%, rgba(200,16,46,.08), transparent);
  border-color: rgba(200,16,46,.22);
}
body.light-mode .emblem-export {
  background: radial-gradient(ellipse at 50% 60%, rgba(160,130,40,.12), transparent);
  border-color: rgba(160,130,40,.28);
}
body.light-mode .session-icon {
  background: radial-gradient(ellipse at 50% 30%, rgba(160,130,40,.09), transparent);
  border-color: rgba(160,130,40,.24);
}

/* ── Error icon / glyph / note ── */
body.light-mode .wiz-error-icon {
  background: radial-gradient(ellipse at 50% 30%, rgba(200,16,46,.07), transparent);
  border-color: rgba(200,16,46,.2);
}
body.light-mode .wiz-error-glyph { color: rgba(180,20,40,.55); }
body.light-mode .wiz-error-note  { color: rgba(180,20,40,.45); }
body.light-mode .wiz-error-note a {
  color: rgba(130,100,30,.6);
  border-bottom-color: rgba(130,100,30,.25);
}
body.light-mode .wiz-error-note a:hover {
  color: rgba(130,100,30,.9);
  border-bottom-color: rgba(130,100,30,.5);
}

/* ── Type-to-confirm input ── */
body.light-mode .wiz-input {
  background: rgba(255,255,255,.75);
  border-color: rgba(0,0,0,.14);
  color: rgba(24,21,15,.9);
}
body.light-mode .wiz-input:focus  { border-color: rgba(180,30,50,.35); }
body.light-mode .wiz-input::placeholder { color: rgba(24,21,15,.28); }

/* ── Cursor belt-and-suspenders ── */
body.light-mode .wiz-card .btn { cursor: pointer; }

/* ══════════════════════════════════════════════════════════════
   LIGHT MODE — 2FA Wizard: method selection cards
══════════════════════════════════════════════════════════════ */
body.light-mode .method-card {
  background: rgba(255,255,255,.7);
  border-color: rgba(0,0,0,.13);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
body.light-mode .method-card:hover {
  background: rgba(255,255,255,.9);
  border-color: rgba(130,100,30,.45);
  box-shadow: 0 8px 28px rgba(0,0,0,.12), 0 0 0 1px rgba(130,100,30,.18);
}
body.light-mode .method-card.recommended {
  background: rgba(255,252,242,.85);
  border-color: rgba(130,100,30,.35);
  box-shadow: 0 2px 10px rgba(130,100,30,.1), 0 0 0 1px rgba(130,100,30,.08);
}
body.light-mode .method-card.recommended:hover {
  background: rgba(255,252,242,1);
  border-color: rgba(130,100,30,.55);
  box-shadow: 0 8px 28px rgba(0,0,0,.12), 0 0 0 1px rgba(130,100,30,.2);
}
body.light-mode .method-card:not(.recommended) .method-icon {
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.1);
}
body.light-mode .method-label        { color: rgba(24,21,15,1); }
body.light-mode .method-hint         { color: rgba(24,21,15,.58); }
body.light-mode .method-card.recommended .method-hint { color: rgba(24,21,15,.68); }
body.light-mode .method-badge.muted  { background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1); color: rgba(24,21,15,.38); }
body.light-mode .method-sep-line     { background: rgba(0,0,0,.1); }
body.light-mode .method-sep-text     { color: rgba(24,21,15,.32); }

/* ── Biometric screen ── */
body.light-mode .bio-chip {
  color: rgba(24,21,15,.58);
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.12);
}

/* ── Manual key (TOTP) ── */
body.light-mode .manual-key-block {
  background: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.09);
}
body.light-mode .manual-key-block:hover {
  border-color: rgba(130,100,30,.28);
  background: rgba(130,100,30,.03);
}
body.light-mode .manual-key-code { color: rgba(24,21,15,.68); }
body.light-mode .manual-key-btn  {
  color: rgba(130,100,30,.65);
  border-color: rgba(130,100,30,.22);
  background: rgba(130,100,30,.06);
}
body.light-mode .manual-key-block:hover .manual-key-btn {
  color: rgba(130,100,30,.9);
  border-color: rgba(130,100,30,.42);
}

/* ── Phone / SMS ── */
body.light-mode .phone-cc {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.1);
  color: rgba(24,21,15,.65);
}
body.light-mode .phone-input {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.1);
  color: rgba(24,21,15,.9);
}
body.light-mode .phone-input::placeholder { color: rgba(24,21,15,.25); }
body.light-mode .phone-input:focus {
  border-color: rgba(130,100,30,.42);
  background: rgba(130,100,30,.025);
}
body.light-mode .sms-notice      { background: rgba(130,100,30,.05); border-color: rgba(130,100,30,.14); }
body.light-mode .sms-notice-text { color: rgba(130,100,30,.65); }

/* ── OTP / verification code digits ── */
body.light-mode .code-digit {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.1);
  color: rgba(24,21,15,.9);
}
body.light-mode .code-digit:focus {
  border-color: rgba(130,100,30,.5);
  background: rgba(130,100,30,.04);
}
body.light-mode .code-digit.filled {
  border-color: rgba(130,100,30,.3);
  background: rgba(130,100,30,.035);
}
body.light-mode .code-foot        { color: rgba(24,21,15,.3); }
body.light-mode .code-foot a      { color: rgba(130,100,30,.55); }
body.light-mode .code-foot a:hover{ color: rgba(130,100,30,.9); }

/* ── Backup codes ── */
body.light-mode .backup-panel { background: rgba(0,0,0,.025); border-color: rgba(0,0,0,.07); }
body.light-mode .backup-panel::before {
  background: linear-gradient(90deg, transparent, rgba(130,100,30,.2), transparent);
}
body.light-mode .backup-code-val       { color: rgba(24,21,15,.62); }
body.light-mode .backup-code-val:hover { color: rgba(24,21,15,.9); }
body.light-mode .backup-action         { color: rgba(24,21,15,.42); border-color: rgba(0,0,0,.1); }
body.light-mode .backup-action:hover   { color: rgba(24,21,15,.78); border-color: rgba(0,0,0,.22); }

/* ── Ghost wizard button ── */
body.light-mode .wiz-btn-ghost       { border-color: rgba(0,0,0,.12); color: rgba(24,21,15,.38); }
body.light-mode .wiz-btn-ghost:hover { border-color: rgba(0,0,0,.25); color: rgba(24,21,15,.65); }

/* ══════════════════════════════════════════════════════════════
   LIGHT MODE — Toast system
══════════════════════════════════════════════════════════════ */
body.light-mode .toast {
  box-shadow: 0 4px 20px rgba(0,0,0,.14), 0 0 0 1px rgba(0,0,0,.06);
}
body.light-mode .toast-error {
  background: rgba(255,250,250,.97);
  border-color: rgba(200,46,46,.2);
  color: rgba(24,21,15,.7);
}
body.light-mode .toast-success {
  background: rgba(248,254,250,.97);
  border-color: rgba(50,150,80,.2);
  color: rgba(24,21,15,.7);
}
body.light-mode .toast-warning {
  background: rgba(255,252,244,.97);
  border-color: rgba(160,130,40,.25);
  color: rgba(24,21,15,.7);
}
body.light-mode .toast-info {
  background: rgba(248,251,255,.97);
  border-color: rgba(80,120,200,.2);
  color: rgba(24,21,15,.7);
}
body.light-mode .toast-title { color: rgba(24,21,15,.88); }
body.light-mode .toast-msg   { color: rgba(24,21,15,.45); }
body.light-mode .toast-action { color: rgba(130,100,30,.65); }
body.light-mode .toast-action:hover { color: rgba(130,100,30,1); }
body.light-mode .toast-close { color: rgba(24,21,15,.2); }
body.light-mode .toast-close:hover { color: rgba(24,21,15,.55); }
body.light-mode .toast-error   .toast-timer { background: rgba(200,70,70,.3); }
body.light-mode .toast-success .toast-timer { background: rgba(50,150,80,.3); }
body.light-mode .toast-warning .toast-timer { background: rgba(160,130,40,.35); }
body.light-mode .toast-info    .toast-timer { background: rgba(80,120,200,.3); }

/* ══════════════════════════════════════════════════════════════
   LIGHT MODE — Site banners
══════════════════════════════════════════════════════════════ */
body.light-mode .site-banner.bn-offline {
  background: rgba(252,248,238,.97);
  border-bottom-color: rgba(160,130,40,.22);
  color: rgba(130,100,30,.8);
}
body.light-mode .site-banner.bn-online {
  background: rgba(244,252,246,.97);
  border-bottom-color: rgba(50,150,80,.2);
  color: rgba(40,120,60,.75);
}
body.light-mode .site-banner.bn-degraded {
  background: rgba(255,248,246,.97);
  border-bottom-color: rgba(200,70,50,.18);
  color: rgba(180,70,50,.75);
}
body.light-mode .banner-action { color: inherit; }
body.light-mode .banner-dismiss { color: rgba(24,21,15,.22); }
body.light-mode .banner-dismiss:hover { color: rgba(24,21,15,.55); }

/* ══════════════════════════════════════════════════════════════
   LIGHT MODE — Section load failures
══════════════════════════════════════════════════════════════ */
body.light-mode .section-err-box {
  background: rgba(255,255,255,.7);
  border-color: rgba(0,0,0,.09);
}
body.light-mode .section-err-icon {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.1);
}
body.light-mode .section-err-title { color: rgba(24,21,15,.55); }
body.light-mode .section-err-sub   { color: rgba(24,21,15,.35); }
body.light-mode .section-err-retry {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.1);
  color: rgba(24,21,15,.5);
}
body.light-mode .section-err-retry:hover {
  background: rgba(0,0,0,.08);
  border-color: rgba(0,0,0,.18);
  color: rgba(24,21,15,.75);
}
