/* God Form — deep indigo + gold, sacred-geometry calm. */
:root {
  --bg: #0b0a14;
  --bg-2: #14122099;
  --panel: #161427;
  --panel-2: #1d1a33;
  --ink: #e8e4f0;
  --ink-dim: #a9a2c4;
  --ink-faint: #6f6890;
  --gold: #d8b25c;
  --gold-soft: #e7cd8f;
  --indigo: #3a2f70;
  --indigo-glow: #5b49b0;
  --line: #2a2545;
  --danger: #d98a8a;
  --ok: #8fc9a6;
  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: radial-gradient(1200px 700px at 50% -10%, #1a1535 0%, var(--bg) 55%) fixed;
  color: var(--ink);
  font-family: var(--sans);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--gold-soft); text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
.hidden { display: none !important; }

/* ---- top bar ---- */
header.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 26px; border-bottom: 1px solid var(--line);
  position: sticky; top: 0; background: #0b0a14e0; backdrop-filter: blur(10px); z-index: 20;
}
.brand { display: flex; align-items: center; gap: 12px; cursor: pointer; }
.brand .sigil { width: 30px; height: 30px; }
.brand h1 { font-family: var(--serif); font-size: 19px; margin: 0; letter-spacing: .14em;
  color: var(--gold-soft); font-weight: 500; }
.brand small { color: var(--ink-faint); letter-spacing: .22em; font-size: 10px; text-transform: uppercase; }
.topbar nav { display: flex; align-items: center; gap: 18px; font-size: 14px; color: var(--ink-dim); }
.topbar nav a { color: var(--ink-dim); }
.topbar nav a:hover { color: var(--gold-soft); }

/* ---- layout ---- */
main { max-width: 1180px; margin: 0 auto; padding: 0 22px 90px; }

/* ---- auth / landing ---- */
.hero { text-align: center; padding: 70px 16px 30px; }
.hero .sigil-lg { width: 92px; height: 92px; margin: 0 auto 18px; display: block; opacity: .92; }
.hero h2 { font-family: var(--serif); font-size: 44px; margin: 0 0 6px; letter-spacing: .04em;
  background: linear-gradient(180deg, var(--gold-soft), var(--gold)); -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; }
.hero .tagline { color: var(--ink-dim); font-size: 17px; letter-spacing: .1em; text-transform: uppercase; }
.hero .blurb { max-width: 560px; margin: 22px auto 0; color: var(--ink-dim); font-size: 16px; font-family: var(--serif); }

.card {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 1px solid var(--line); border-radius: 16px; padding: 26px;
}
.auth-card { max-width: 400px; margin: 26px auto 0; }
.auth-card h3 { font-family: var(--serif); margin: 0 0 4px; color: var(--gold-soft); font-weight: 500; }
.auth-card p.sub { margin: 0 0 18px; color: var(--ink-faint); font-size: 13px; }
.field { margin-bottom: 13px; }
.field label { display: block; font-size: 12px; color: var(--ink-dim); margin-bottom: 5px; letter-spacing: .04em; }
.field input {
  width: 100%; padding: 11px 13px; border-radius: 9px; border: 1px solid var(--line);
  background: #0e0c1c; color: var(--ink); font-size: 15px; outline: none;
}
.field input:focus { border-color: var(--indigo-glow); }
.btn {
  width: 100%; padding: 12px; border-radius: 9px; border: 1px solid var(--gold);
  background: linear-gradient(180deg, var(--gold-soft), var(--gold)); color: #2a1f08;
  font-weight: 600; font-size: 15px; letter-spacing: .02em;
}
.btn:hover { filter: brightness(1.06); }
.btn.ghost { background: transparent; color: var(--gold-soft); border-color: var(--line); font-weight: 500; }
.btn-row { display: flex; gap: 10px; margin-top: 6px; }
.switch-auth { text-align: center; margin-top: 16px; font-size: 13px; color: var(--ink-faint); }
.switch-auth a { cursor: pointer; }
.msg { font-size: 13px; padding: 9px 11px; border-radius: 8px; margin-bottom: 12px; }
.msg.err { background: #3a1f24; color: var(--danger); border: 1px solid #58323a; }
.msg.ok { background: #1c2e26; color: var(--ok); border: 1px solid #2f5043; }

/* ---- course map ---- */
.course-head { padding: 34px 4px 10px; }
.course-head h2 { font-family: var(--serif); font-size: 32px; margin: 0 0 4px; color: var(--gold-soft); font-weight: 500; }
.course-head .progress-line { color: var(--ink-dim); font-size: 14px; }
.progress-bar { height: 6px; background: #1a1730; border-radius: 4px; margin-top: 12px; overflow: hidden; max-width: 420px; }
.progress-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--indigo-glow), var(--gold)); }

.module { margin-top: 30px; }
.module-title { display: flex; align-items: baseline; gap: 12px; border-bottom: 1px solid var(--line); padding-bottom: 8px; }
.module-title .num { font-family: var(--serif); color: var(--gold); font-size: 13px; letter-spacing: .2em; }
.module-title h3 { font-family: var(--serif); margin: 0; font-size: 22px; color: var(--ink); font-weight: 500; }
.week { margin-top: 16px; }
.week-label { font-size: 11px; color: var(--ink-faint); letter-spacing: .22em; text-transform: uppercase; margin-bottom: 8px; }
.day-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(168px, 1fr)); gap: 10px; }
.day-tile {
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 11px; padding: 12px 13px;
  cursor: pointer; transition: border-color .15s, transform .1s; position: relative; min-height: 78px;
}
.day-tile:hover { border-color: var(--indigo-glow); transform: translateY(-1px); }
.day-tile .d-num { font-size: 11px; color: var(--gold); letter-spacing: .14em; }
.day-tile .d-title { font-family: var(--serif); font-size: 15px; color: var(--ink); margin-top: 3px; line-height: 1.3; }
.day-tile .d-tags { margin-top: 8px; display: flex; gap: 7px; font-size: 10px; color: var(--ink-faint); }
.day-tile.locked { opacity: .42; cursor: not-allowed; }
.day-tile.locked:hover { border-color: var(--line); transform: none; }
.day-tile.done { border-color: #3c5a47; }
.day-tile .check { position: absolute; top: 10px; right: 11px; color: var(--ok); font-size: 13px; }
.day-tile .lock { position: absolute; top: 10px; right: 11px; color: var(--ink-faint); font-size: 12px; }

/* ---- lesson ---- */
.lesson { max-width: 740px; margin: 0 auto; padding-top: 28px; }
/* module hero banner — wide, atmospheric, sits above the crumb */
.lesson .day-hero { display: block; width: 100%; height: 200px; object-fit: cover;
  border-radius: 14px; border: 1px solid var(--line); margin-bottom: 22px;
  -webkit-mask-image: linear-gradient(180deg, #000 70%, transparent 100%);
  mask-image: linear-gradient(180deg, #000 70%, transparent 100%); opacity: .94; }
/* the day's archetypal still — square sigil, centered under the principle */
.lesson .day-art { display: block; width: 100%; max-width: 380px; aspect-ratio: 1 / 1;
  object-fit: cover; margin: 22px auto; border-radius: 12px; border: 1px solid var(--line);
  box-shadow: 0 0 0 1px #0006, 0 18px 50px -24px var(--indigo-glow); }
/* concept diagrams — sacred-geometry / diagrammatic line art (SVG). Soft
   panel so the line work reads against the dark field; same family as .day-art */
.lesson .diagram { display: block; width: 100%; max-width: 520px; height: auto;
  margin: 24px auto; padding: 18px; border-radius: 12px; border: 1px solid var(--line);
  background: #100e1c; box-shadow: 0 0 0 1px #0006, 0 18px 50px -24px var(--indigo-glow); }
.lesson .diagram-wheel { max-width: 420px; }
.lesson .crumb { font-size: 12px; color: var(--ink-faint); letter-spacing: .14em; text-transform: uppercase; }
.lesson h2 { font-family: var(--serif); font-size: 34px; margin: 8px 0 2px; color: var(--gold-soft); font-weight: 500; line-height: 1.15; }
.lesson .subtitle { color: var(--ink-dim); font-style: italic; font-family: var(--serif); font-size: 18px; }
.lesson .principle { margin: 18px 0; padding: 14px 18px; border-left: 2px solid var(--gold);
  background: #14122044; font-family: var(--serif); font-style: italic; color: var(--gold-soft); }
.preview-banner { background: #241d3a; border: 1px solid var(--indigo); border-radius: 10px;
  padding: 12px 16px; margin: 16px 0; color: var(--ink-dim); font-size: 14px; }

.audio-wrap { margin: 20px 0; padding: 14px 16px; background: var(--panel); border: 1px solid var(--line); border-radius: 12px; }
.audio-wrap .a-label { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 8px; }
audio { width: 100%; }

.section { margin-top: 30px; }
.section .s-label { font-size: 11px; letter-spacing: .26em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 10px; padding-bottom: 5px; border-bottom: 1px solid var(--line); }
.section .body { font-family: var(--serif); font-size: 18px; color: var(--ink); }
.section .body p { margin: 0 0 15px; }
.section .body em { color: var(--gold-soft); }
.section .body strong { color: #fff; }
.section .body h3 { font-family: var(--serif); font-size: 19px; color: var(--gold-soft); margin: 22px 0 8px; font-weight: 500; }
.section .body ol, .section .body ul { padding-left: 22px; }
.section .body li { margin-bottom: 9px; }
.section.shadow .body { color: var(--ink-dim); }
.section.shadow .s-label { color: #b48fd9; }

.journal { margin-top: 14px; }
.journal textarea {
  width: 100%; min-height: 130px; padding: 14px; border-radius: 11px; border: 1px solid var(--line);
  background: #0e0c1c; color: var(--ink); font-family: var(--serif); font-size: 16px; resize: vertical; outline: none;
}
.journal textarea:focus { border-color: var(--indigo-glow); }
.journal .j-row { display: flex; align-items: center; gap: 12px; margin-top: 9px; }
.journal .saved { font-size: 12px; color: var(--ink-faint); }
.btn-sm { width: auto; padding: 8px 16px; font-size: 13px; }

.lesson-nav { display: flex; justify-content: space-between; align-items: center; margin-top: 44px;
  padding-top: 20px; border-top: 1px solid var(--line); gap: 12px; }
.lesson-nav .complete-toggle { display: flex; align-items: center; gap: 8px; color: var(--ink-dim); font-size: 14px; cursor: pointer; }
.lesson-nav .complete-toggle input { width: 17px; height: 17px; accent-color: var(--gold); }

.locked-note { text-align: center; padding: 60px 20px; color: var(--ink-dim); font-family: var(--serif); font-size: 18px; }

footer { text-align: center; padding: 30px; color: var(--ink-faint); font-size: 12px; letter-spacing: .1em; }
@media (max-width: 640px) {
  .hero h2 { font-size: 34px; }
  .lesson h2 { font-size: 27px; }
  .section .body { font-size: 17px; }
}

/* ---- interactive workbook fields ---- */
.gf-step {
  display: flex; align-items: flex-start; gap: 11px;
  padding: 10px 12px; margin: 6px 0; border-radius: 10px;
  border: 1px solid transparent; transition: background .15s, border-color .15s;
}
.gf-step:hover { background: var(--bg-2); }
.gf-check {
  appearance: none; -webkit-appearance: none; flex: 0 0 auto;
  width: 20px; height: 20px; margin-top: 3px; border-radius: 6px;
  border: 1.5px solid var(--indigo-glow); background: transparent;
  cursor: pointer; position: relative; transition: background .15s, border-color .15s;
}
.gf-check:checked { background: var(--gold); border-color: var(--gold); }
.gf-check:checked::after {
  content: '✓'; position: absolute; inset: 0; display: flex; align-items: center;
  justify-content: center; color: #1a1330; font-size: 13px; font-weight: 700;
}
.gf-step:has(.gf-check:checked) { background: #1a163090; }
.gf-step:has(.gf-check:checked) .gf-step-body { color: var(--ink-faint); }
.gf-step-body { flex: 1; }
.gf-step-num { color: var(--gold); font-weight: 600; margin-right: 3px; }
.gf-bullet { padding: 3px 0 3px 16px; position: relative; }
.gf-bullet::before { content: '◦'; position: absolute; left: 0; color: var(--gold); }

/* fill-in-the-blank inputs */
.gf-blank {
  display: inline-block; min-width: 120px; padding: 1px 8px; margin: 0 2px;
  background: transparent; border: none; border-bottom: 1.5px dashed var(--indigo-glow);
  color: var(--gold-soft); font-family: var(--serif); font-size: inherit; font-style: italic;
  transition: border-color .15s;
}
.gf-blank:focus { outline: none; border-bottom-color: var(--gold); border-bottom-style: solid; }

/* practice timer */
.gf-timer {
  display: inline-flex; align-items: center; gap: 6px; margin-left: 8px;
  padding: 3px 11px; border-radius: 999px; font-size: 12px; letter-spacing: .04em;
  background: var(--indigo); border: 1px solid var(--indigo-glow); color: var(--gold-soft);
  vertical-align: middle; white-space: nowrap;
}
.gf-timer:hover { background: var(--indigo-glow); color: var(--ink); }
.gf-timer.done { background: transparent; border-color: var(--ok); color: var(--ok); }

/* multi-day tracker */
.gf-tracker {
  margin: 14px 0 4px; padding: 14px; border-radius: 12px;
  background: var(--bg-2); border: 1px solid var(--line);
}
.gf-tracker-label {
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-faint); margin-bottom: 10px;
}
.gf-track-row { display: flex; align-items: center; gap: 12px; padding: 4px 0; }
.gf-track-day {
  flex: 0 0 52px; font-size: 12px; color: var(--gold); letter-spacing: .04em;
  font-family: var(--serif);
}
.gf-track-input {
  flex: 1; padding: 7px 11px; border-radius: 8px; border: 1px solid var(--line);
  background: var(--panel); color: var(--ink); font-family: var(--sans); font-size: 14px;
}
.gf-track-input:focus { outline: none; border-color: var(--indigo-glow); }

/* --- The Mirror (Phase 2) --- */
.mirror {
  margin-top: 22px; padding: 20px 22px;
  border: 1px solid var(--line); border-radius: 16px;
  background: linear-gradient(180deg, rgba(58,47,112,.18), rgba(58,47,112,.06));
}
.mirror-head { display: flex; flex-direction: column; gap: 3px; margin-bottom: 14px; }
.mirror-title { color: var(--gold-soft); font-weight: 500; letter-spacing: .04em; }
.mirror-sub { color: var(--ink-faint); font-size: 12.5px; font-style: italic; }
.guide-pick { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid rgba(216,178,92,.14); }
.guide-pick label { color: var(--ink-dim); font-size: 13.5px; display: inline-flex; align-items: center; gap: 6px; cursor: pointer; letter-spacing: .03em; }
.guide-pick input[type=radio] { accent-color: var(--gold); }
.mirror-dial { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.mirror-dial label { color: var(--ink-dim); font-size: 13.5px; display: inline-flex; align-items: center; gap: 5px; cursor: pointer; }
.mirror-dial input[type=radio] { accent-color: var(--gold); }
.mirror-dial .voice-auto { margin-left: auto; padding-left: 14px; border-left: 1px solid var(--line, rgba(255,255,255,.12)); }
.mirror-dial .voice-auto input[type=checkbox] { accent-color: var(--gold); }
.mirror-btn { margin-left: auto; }
.mirror-btn:disabled { opacity: .6; cursor: default; }
.mirror-out { margin-top: 4px; }
.reflection {
  margin-top: 16px; padding: 16px 18px;
  border-left: 2px solid var(--gold); border-radius: 0 10px 10px 0;
  background: rgba(216,178,92,.05);
}
.reflection .r-meta { color: var(--ink-faint); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 8px; }
.reflection p { font-family: var(--serif); color: var(--ink); line-height: 1.7; margin: 0 0 10px; }
.reflection p:last-child { margin-bottom: 0; }
.reflection.r-err { border-left-color: var(--ink-faint); color: var(--ink-faint); font-style: italic; }
.reflection.reflection-chief { border-left-color: #b8472e; background: rgba(184,71,46,.05); }
.reflection.reflection-chief .r-meta { color: #c96a52; }
.reflection .r-audio { display: inline-flex; gap: 4px; align-items: center; vertical-align: middle; }
.reflection .r-speak, .reflection .r-stop { background: none; border: 1px solid rgba(0,0,0,.15); border-radius: 4px; cursor: pointer; font-size: 12px; line-height: 1; padding: 2px 6px; opacity: .65; transition: opacity .15s, background .15s; vertical-align: middle; }
.reflection .r-speak:hover, .reflection .r-stop:hover:not(:disabled) { opacity: 1; }
.reflection .r-speak.playing { opacity: 1; background: rgba(184,71,46,.1); }
.reflection .r-speak:disabled, .reflection .r-stop:disabled { cursor: default; opacity: .3; }

/* ---- the Living Mirror (Phase 3) ---- */
.ink-faint { color: var(--ink-faint); }
.arc-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin: 22px 0 18px; }
.arc-stat { padding: 16px 18px; border: 1px solid var(--line); border-radius: 14px; background: rgba(58,47,112,.10); text-align: center; }
.arc-stat .n { display: block; font-family: var(--serif); font-size: 24px; color: var(--gold-soft); line-height: 1.1; }
.arc-stat .l { display: block; margin-top: 6px; font-size: 11px; color: var(--ink-faint); letter-spacing: .1em; text-transform: uppercase; }
.arc-recurring { margin-bottom: 8px; }
.arc-recurring-label { font-size: 11px; color: var(--ink-faint); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 10px; }
.arc-words { display: flex; flex-wrap: wrap; gap: 8px; }
.arc-word { padding: 5px 11px; border: 1px solid var(--line); border-radius: 999px; font-size: 13px; color: var(--ink-dim); font-family: var(--serif); }
.arc-word em { color: var(--gold); font-style: normal; font-size: 11px; }
.arc-mirror { border-color: var(--indigo-glow); background: linear-gradient(180deg, rgba(58,47,112,.16), rgba(14,12,28,.4)); }
.arc-muted-note, .arc-foot { color: var(--ink-faint); font-size: 13px; }
.arc-muted-note { font-style: italic; padding: 6px 0; }
.arc-foot { margin-top: 14px; }
.arc-mute-toggle { cursor: pointer; font-size: 13px; color: var(--ink-dim); }
.arc-mute-toggle:hover { color: var(--gold-soft); }
.arc-history { margin-top: 28px; }
.arc-history h3 { font-family: var(--serif); font-size: 18px; color: var(--ink); font-weight: 500; margin: 0 0 6px; }
.arc-reflection { border-left-color: var(--indigo-glow); background: rgba(58,47,112,.10); border-radius: 0 12px 12px 0; }

/* ---- the Journey (read-only weave) ---- */
.journey-empty { margin: 28px 0; color: var(--ink-faint); font-family: var(--serif); line-height: 1.7; }
.journey-empty a { color: var(--gold-soft); cursor: pointer; }
.journey-arc { margin: 22px 0 10px; }
.journey-arc h3 { font-family: var(--serif); font-size: 18px; color: var(--ink); font-weight: 500; margin: 0 0 6px; }
.journey-timeline { margin-top: 18px; border-left: 1px solid var(--line); padding-left: 0; }
.journey-day { position: relative; padding: 0 0 26px 22px; }
.journey-day::before { content: ''; position: absolute; left: -5px; top: 6px; width: 9px; height: 9px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 3px var(--bg, #0e0c1c); }
.journey-day-head { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.journey-day-n { font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--gold-soft); cursor: pointer; white-space: nowrap; }
.journey-day-n:hover { color: var(--gold); }
.journey-day-title { font-family: var(--serif); font-size: 17px; color: var(--ink); }
.journey-done { color: var(--gold); font-size: 13px; }
.journey-entry { margin-top: 12px; padding: 14px 16px; border: 1px solid var(--line); border-radius: 10px; background: rgba(255,255,255,.015); }
.journey-entry-meta { color: var(--ink-faint); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 8px; }
.journey-entry-text { font-family: var(--serif); color: var(--ink-dim); line-height: 1.7; white-space: pre-wrap; }

/* ---- go deeper (bounded reply) ---- */
.deepen { margin-top: 16px; padding: 14px 16px; border: 1px dashed var(--line); border-radius: 10px; background: rgba(216,178,92,.03); }
.deepen-label { font-size: 11px; color: var(--ink-faint); letter-spacing: .12em; text-transform: uppercase; margin-bottom: 8px; }
.deepen textarea { width: 100%; min-height: 70px; resize: vertical; background: rgba(0,0,0,.18); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-family: var(--serif); font-size: 15px; line-height: 1.6; padding: 10px 12px; box-sizing: border-box; }
.deepen textarea:focus { outline: none; border-color: var(--gold); }
.deepen .btn { margin-top: 10px; }
.deepen-rest { margin-top: 16px; padding: 12px 14px; color: var(--ink-faint); font-family: var(--serif); font-style: italic; font-size: 14px; border-left: 2px solid var(--line); }
.deeper-audio { margin: 0 0 12px; padding: 10px 12px; background: rgba(216,178,92,.04); }
.deeper-audio audio { width: 100%; }

/* ---- Practitioner: My Clients (mentor home) ---- */
.back-link { display: inline-block; font-size: 13px; color: var(--ink-dim); margin-bottom: 8px; letter-spacing: .04em; }
.back-link:hover { color: var(--gold-soft); }
.clients-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; padding: 8px 4px 40px; }
.client-card {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 1px solid var(--line); border-radius: 14px; padding: 18px 18px 16px;
  cursor: pointer; transition: border-color .15s, transform .15s;
}
.client-card:hover { border-color: var(--indigo-glow); transform: translateY(-2px); }
.client-name { font-family: var(--serif); font-size: 19px; color: var(--gold-soft); margin-bottom: 2px; }
.client-email { font-size: 12px; color: var(--ink-faint); margin-bottom: 12px; }
.client-stats { display: flex; gap: 16px; font-size: 13px; color: var(--ink-dim); margin-bottom: 8px; flex-wrap: wrap; }
.client-stats strong { color: var(--ink); font-size: 16px; font-family: var(--serif); }
.client-last { font-size: 12px; color: var(--ink-faint); letter-spacing: .03em; margin-bottom: 10px; }
.client-arc {
  font-family: var(--serif); font-style: italic; font-size: 13px; color: var(--ink-dim);
  border-top: 1px solid var(--line); padding-top: 10px; line-height: 1.5;
}
.client-arc.faint { color: var(--ink-faint); }

/* ---- B2: weekly "Where They're At" brief panel ---- */
.brief-panel {
  margin: 22px 0 8px; border: 1px solid var(--line); border-radius: 14px;
  background: linear-gradient(180deg, var(--panel), var(--panel-2)); padding: 18px 20px;
}
.brief-loading, .brief-empty {
  color: var(--ink-faint); font-size: 14px; font-family: var(--serif); font-style: italic;
}
.brief-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.brief-head h3 {
  margin: 0; font-family: var(--serif); font-weight: 500; color: var(--gold-soft); font-size: 18px;
}
.btn-sm { width: auto; padding: 7px 14px; font-size: 13px; border-radius: 8px; }
.btn-sm:disabled { opacity: .6; cursor: default; }
.brief-stamp {
  color: var(--ink-faint); font-size: 11px; letter-spacing: .03em;
  text-transform: uppercase; margin: 6px 0 14px;
}
.brief-body { color: var(--ink-dim); font-size: 15px; line-height: 1.6; }
.brief-body .brief-h {
  margin: 16px 0 6px; color: var(--gold-soft); font-family: var(--serif); font-weight: 500;
  font-size: 15px; letter-spacing: .02em;
}
.brief-body .brief-h:first-child { margin-top: 4px; }
.brief-body p { margin: 6px 0; }
.brief-body .brief-ul { margin: 6px 0 6px 2px; padding-left: 18px; }
.brief-body .brief-ul li { margin: 4px 0; }

/* ---- The Workbook (the DO-surface) ---- */
.wb-list { margin-top: 20px; display: flex; flex-direction: column; gap: 18px; }
.wb-card {
  border: 1px solid var(--line); border-radius: 14px; padding: 20px 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.006));
}
.wb-head { display: flex; align-items: baseline; gap: 11px; flex-wrap: wrap; margin-bottom: 6px; }
.wb-day-n { font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--gold-soft); cursor: pointer; white-space: nowrap; }
.wb-day-n:hover { color: var(--gold); }
.wb-title { font-family: var(--serif); font-size: 18px; color: var(--ink); flex: 1; }
.wb-met {
  font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint);
  border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px; white-space: nowrap;
}
.wb-met-deep { color: var(--gold-soft); border-color: var(--gold); background: rgba(216,178,92,.08); }
.wb-sec { margin-top: 14px; }
.wb-sec-label { font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--gold); margin-bottom: 7px; }
.wb-prose { font-family: var(--serif); font-size: 16px; color: var(--ink-dim); line-height: 1.6; }
.wb-prose p { margin: 0 0 9px; }
.wb-prose h4.wb-sub { font-family: var(--serif); font-size: 16px; color: var(--gold-soft); font-weight: 500; margin: 12px 0 6px; }
.wb-prose ul, .wb-prose ol { margin: 6px 0 9px; padding-left: 20px; }
.wb-prose li { margin: 4px 0; }
.wb-prose strong { color: #fff; }
.wb-prose em { color: var(--gold-soft); }
.wb-blank { display: inline-block; min-width: 90px; border-bottom: 1px solid var(--ink-faint); margin: 0 3px; }
.wb-rest { margin-top: 12px; color: var(--ink-faint); font-family: var(--serif); font-style: italic; }
.wb-write { margin-top: 16px; }
.wb-write textarea {
  width: 100%; min-height: 96px; resize: vertical; box-sizing: border-box;
  background: rgba(0,0,0,.18); border: 1px solid var(--line); border-radius: 9px;
  color: var(--ink); font-family: var(--serif); font-size: 16px; line-height: 1.6; padding: 12px 14px;
}
.wb-write textarea:focus { outline: none; border-color: var(--indigo-glow); }
.wb-row { display: flex; align-items: center; gap: 14px; margin-top: 10px; flex-wrap: wrap; }
.wb-row .saved { font-size: 12px; color: var(--ink-faint); }
.wb-respiral { font-size: 12px; color: var(--gold-soft); cursor: pointer; letter-spacing: .04em; }
.wb-respiral:hover { color: var(--gold); }
.wb-export-row { margin-top: 16px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.wb-export { font-size: 13px; color: var(--gold-soft); cursor: pointer; letter-spacing: .04em;
  border: 1px solid var(--line); border-radius: 8px; padding: 7px 14px; }
.wb-export:hover { color: var(--gold); border-color: var(--gold); }
.wb-export-note { font-size: 12px; color: var(--ink-faint); font-style: italic; }
.wb-passes-link { font-size: 12px; color: var(--ink-dim); cursor: pointer; letter-spacing: .04em; }
.wb-passes-link:hover { color: var(--gold-soft); }
.wb-passes { margin-top: 4px; }
.wb-passes-loading, .wb-passes-empty { font-size: 12px; color: var(--ink-faint); font-style: italic; margin-top: 10px; }
.wb-passes-head { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); margin: 14px 0 8px; }
.wb-pass { margin-top: 10px; padding: 12px 14px; border-left: 2px solid var(--indigo-glow); border-radius: 0 9px 9px 0; background: rgba(58,47,112,.10); }
.wb-pass-meta { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 6px; }
.wb-pass-text { font-family: var(--serif); color: var(--ink-dim); line-height: 1.7; white-space: pre-wrap; }

/* The Arc — graphs panel (the work made visible) */
.arc-panel { margin: 4px 0 26px; padding: 18px 18px 8px; border: 1px solid var(--line);
  border-radius: 14px; background: linear-gradient(180deg, var(--panel-2), var(--panel)); }
.arc-summary { cursor: pointer; list-style: none; display: flex; align-items: baseline; gap: 12px; outline: none; }
.arc-summary::-webkit-details-marker { display: none; }
.arc-title { font-family: var(--serif); font-size: 20px; color: var(--gold-soft); }
.arc-sub { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-faint); }
.arc-stats { display: flex; flex-wrap: wrap; gap: 10px; margin: 16px 0 6px; }
.arc-stat { flex: 1 1 90px; min-width: 90px; padding: 12px 10px; text-align: center;
  border: 1px solid var(--line); border-radius: 10px; background: rgba(58,47,112,.10); }
.arc-stat-v { font-family: var(--serif); font-size: 22px; color: var(--gold-soft); line-height: 1.1; }
.arc-stat-k { font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); margin-top: 5px; }
.arc-chart { margin: 20px 0 6px; }
.arc-chart-h { font-family: var(--serif); font-size: 15px; color: var(--ink); margin-bottom: 4px; }
.arc-chart-h span { font-family: var(--sans); font-size: 12px; color: var(--ink-faint); }
.arc-legend { display: flex; gap: 14px; margin: 2px 0 6px; }
.arc-legend .lg { font-size: 11px; color: var(--ink-dim); display: inline-flex; align-items: center; }
.arc-legend .lg::before { content: ''; width: 10px; height: 10px; border-radius: 3px; margin-right: 5px; display: inline-block; }
.lg-c::before { background: var(--gold); }
.lg-j::before { background: var(--indigo-glow); }
.lg-u::before { background: var(--indigo); }
.arc-svg { width: 100%; height: auto; display: block; overflow: visible; }
.arc-row-label { font-size: 12px; fill: var(--ink-dim); font-family: var(--sans); }
.arc-row-val { font-size: 11px; fill: var(--ink-faint); font-family: var(--sans); }
.arc-track { fill: rgba(255,255,255,.05); }
.arc-fill-u { fill: var(--indigo); }
.arc-fill-j { fill: var(--indigo-glow); }
.arc-fill-c { fill: var(--gold); }
.arc-bar-depth { fill: var(--gold); }
.arc-bar-pour { fill: var(--indigo-glow); opacity: .85; }
.arc-bar-cadence { fill: var(--indigo-glow); }
.arc-bar-val { font-size: 11px; fill: var(--gold-soft); font-family: var(--sans); }
.arc-bar-x { font-size: 10px; fill: var(--ink-faint); font-family: var(--sans); }
.arc-axis { stroke: var(--line); stroke-width: 1; }
.arc-empty { font-family: var(--serif); color: var(--ink-dim); font-size: 14px; line-height: 1.7;
  padding: 14px 16px; border-left: 2px solid var(--indigo-glow); border-radius: 0 9px 9px 0; background: rgba(58,47,112,.10); }

/* AI-guided respiral: the Living Journal's offering of where to return */
.rsp-panel { margin: 4px 0 28px; padding: 18px 18px 16px; border: 1px solid var(--line);
  border-radius: 14px; background: linear-gradient(180deg, var(--panel-2), var(--panel)); }
.rsp-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.rsp-title { font-family: var(--serif); font-size: 19px; color: var(--gold-soft); }
.rsp-sub { font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-faint); }
.rsp-body { margin: 6px 0 0; }
.rsp-offering { font-family: var(--serif); color: var(--ink); font-size: 15.5px; line-height: 1.8;
  padding: 14px 16px; margin-top: 12px; border-left: 2px solid var(--gold); border-radius: 0 9px 9px 0;
  background: rgba(58,47,112,.10); }
.rsp-offering p { margin: 0 0 12px; }
.rsp-offering p:last-child { margin-bottom: 0; }
.rsp-gates { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.rsp-gate { font-size: 12.5px; padding: 5px 11px; border: 1px solid var(--line); border-radius: 999px;
  background: rgba(216,178,92,.08); color: var(--gold-soft); cursor: pointer; transition: background .15s; }
.rsp-gate:hover { background: rgba(216,178,92,.18); }
.rsp-row { display: flex; align-items: center; gap: 14px; margin-top: 14px; flex-wrap: wrap; }
.rsp-note { font-size: 12.5px; color: var(--ink-faint); font-style: italic; }
.rsp-empty { font-family: var(--serif); color: var(--ink-dim); font-size: 14px; line-height: 1.7; margin-top: 12px;
  padding: 12px 14px; border-left: 2px solid var(--indigo-glow); border-radius: 0 9px 9px 0; background: rgba(58,47,112,.10); }

/* ====================== public funnel / landing ====================== */
.lp { max-width: 860px; margin: 0 auto; }
.lp-hero { text-align: center; padding: 64px 16px 26px; }
.lp-hero .sigil-lg { width: 96px; height: 96px; margin: 0 auto 18px; display: block; opacity: .92; }
.lp-hero h2 { font-family: var(--serif); font-size: 52px; margin: 0 0 6px; letter-spacing: .04em;
  background: linear-gradient(180deg, var(--gold-soft), var(--gold)); -webkit-background-clip: text;
  background-clip: text; -webkit-text-fill-color: transparent; }
.lp-hero .tagline { color: var(--ink-dim); font-size: 16px; letter-spacing: .22em; text-transform: uppercase; }
.lp-promise { max-width: 580px; margin: 22px auto 0; color: var(--ink-dim); font-size: 18px;
  font-family: var(--serif); line-height: 1.7; }
.lp-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 28px; }
.lp-btn { width: auto; padding: 13px 26px; font-size: 15px; }

.lp-sec { padding: 46px 18px; border-top: 1px solid var(--line); }
.lp-h { font-family: var(--serif); font-size: 28px; color: var(--gold-soft); font-weight: 500;
  text-align: center; margin: 0 0 8px; }
.lp-sub { text-align: center; color: var(--ink-dim); max-width: 560px; margin: 0 auto 26px; font-size: 15px; }

.lp-manifesto { text-align: center; }
.lp-manifesto p { max-width: 640px; margin: 0 auto; font-family: var(--serif); font-size: 21px;
  line-height: 1.8; color: var(--ink); }
.lp-manifesto strong { color: var(--gold-soft); font-weight: 600; }
.lp-manifesto em { color: var(--gold); font-style: italic; }

.lp-wheel { display: block; width: 100%; max-width: 380px; margin: 0 auto 28px; border-radius: 12px;
  border: 1px solid var(--line); background: #100e1c; padding: 14px; }
.gate-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.gate { margin: 0; border: 1px solid var(--line); border-radius: 11px; overflow: hidden; background: var(--bg-2); }
.gate img { display: block; width: 100%; height: 92px; object-fit: cover; opacity: .9; }
.gate.no-img img { display: none; }
.gate figcaption { padding: 9px 11px; font-family: var(--serif); font-size: 14px; color: var(--ink); }
.gate .gate-n { display: block; font-family: var(--sans); font-size: 10px; letter-spacing: .18em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 2px; }

.inside-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.inside-card { border: 1px solid var(--line); border-radius: 14px; padding: 22px;
  background: linear-gradient(180deg, var(--panel), var(--panel-2)); }
.inside-card i { font-size: 24px; color: var(--gold); }
.inside-card h4 { font-family: var(--serif); font-size: 19px; color: var(--gold-soft); font-weight: 500; margin: 10px 0 6px; }
.inside-card p { color: var(--ink-dim); font-size: 14.5px; line-height: 1.6; margin: 0; }

.path-steps { max-width: 620px; margin: 0 auto; padding: 0; list-style: none; counter-reset: step; }
.path-steps li { position: relative; padding: 14px 0 14px 52px; border-bottom: 1px solid var(--line);
  color: var(--ink-dim); font-size: 15px; line-height: 1.6; }
.path-steps li:last-child { border-bottom: 0; }
.path-steps li b { color: var(--ink); }
.path-steps li::before { counter-increment: step; content: counter(step); position: absolute; left: 0; top: 12px;
  width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--gold); color: var(--gold);
  font-family: var(--serif); font-size: 16px; display: flex; align-items: center; justify-content: center; }

.lp-py { background: rgba(58,47,112,.08); border-radius: 16px; }
.lp-py-img { display: block; width: 100%; height: 180px; object-fit: cover; border-radius: 12px; margin-bottom: 22px;
  opacity: .9; -webkit-mask-image: linear-gradient(180deg,#000 72%,transparent); mask-image: linear-gradient(180deg,#000 72%,transparent); }
.lp-py-reframe { max-width: 600px; margin: 0 auto 22px; text-align: center; font-family: var(--serif);
  font-size: 19px; font-style: italic; line-height: 1.7; color: var(--gold-soft); }
.py-included { max-width: 560px; margin: 0 auto 22px; padding: 0; list-style: none; }
.py-included li { display: flex; gap: 11px; align-items: flex-start; padding: 8px 0; color: var(--ink-dim);
  font-size: 15px; line-height: 1.55; }
.py-included li i { color: var(--gold); font-size: 12px; margin-top: 5px; }
.lp-invest { max-width: 600px; margin: 0 auto 26px; text-align: center; color: var(--ink-dim); font-size: 15px; line-height: 1.7; }
.lp-invest strong { color: var(--gold-soft); font-size: 18px; }

.interest-form { max-width: 520px; margin: 0 auto; border: 1px solid var(--line); border-radius: 14px;
  padding: 24px; background: var(--bg-2); }
.interest-form h4 { font-family: var(--serif); font-size: 20px; color: var(--gold-soft); font-weight: 500; margin: 0 0 4px; }
.interest-form .if-note { color: var(--ink-faint); font-size: 13px; margin: 0 0 16px; }
.if-row { display: flex; gap: 10px; }
.if-row input { flex: 1; }
.interest-form input, .interest-form textarea { width: 100%; padding: 11px 13px; border-radius: 9px;
  border: 1px solid var(--line); background: #0e0c1c; color: var(--ink); font-size: 15px; outline: none;
  margin-bottom: 11px; font-family: var(--sans); }
.interest-form input:focus, .interest-form textarea:focus { border-color: var(--indigo-glow); }
.lp-disclaim { max-width: 600px; margin: 22px auto 0; text-align: center; color: var(--ink-faint);
  font-size: 12px; line-height: 1.6; font-style: italic; }

.faq { max-width: 640px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item summary { cursor: pointer; padding: 16px 0; font-family: var(--serif); font-size: 17px;
  color: var(--ink); list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 14px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; color: var(--gold); font-size: 20px; }
.faq-item[open] summary::after { content: '\2212'; }
.faq-item p { margin: 0 0 16px; color: var(--ink-dim); font-size: 15px; line-height: 1.7; }

.lp-begin { text-align: center; }
.lp-begin #authslot { text-align: left; }
.lp-preview-link { margin-top: 16px; }
.lp-preview-link a { font-size: 14px; letter-spacing: .1em; cursor: pointer; }

@media (max-width: 640px) {
  .lp-hero h2 { font-size: 40px; }
  .gate-strip { grid-template-columns: repeat(2, 1fr); }
  .inside-grid { grid-template-columns: 1fr; }
  .if-row { flex-direction: column; gap: 0; }
}

/* ====================== messaging (Phase 3) ====================== */
.nav-dot { display: inline-block; min-width: 16px; padding: 0 5px; height: 16px; line-height: 16px;
  text-align: center; font-size: 10px; border-radius: 8px; background: var(--gold); color: #2a1f08;
  font-weight: 700; vertical-align: middle; }
.msg-panel { margin-top: 22px; border: 1px solid var(--line); border-radius: 14px; padding: 20px;
  background: linear-gradient(180deg, var(--panel), var(--panel-2)); }
.msg-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.msg-head h3 { font-family: var(--serif); font-size: 19px; color: var(--gold-soft); font-weight: 500; margin: 0; }
.msg-thread { display: flex; flex-direction: column; gap: 10px; margin: 10px 0 16px;
  max-height: 420px; overflow-y: auto; }
.msg-empty { color: var(--ink-faint); font-size: 14px; font-style: italic; padding: 8px 0; }
.msg-bubble { max-width: 78%; padding: 10px 14px; border-radius: 14px; font-size: 14.5px; line-height: 1.5; }
.msg-bubble.mine { align-self: flex-end; background: rgba(216,178,92,.14); border: 1px solid var(--line);
  color: var(--ink); border-bottom-right-radius: 4px; }
.msg-bubble.theirs { align-self: flex-start; background: #14122055; border: 1px solid var(--line);
  color: var(--ink); border-bottom-left-radius: 4px; }
.msg-body { white-space: pre-wrap; }
.msg-meta { margin-top: 5px; font-size: 10.5px; color: var(--ink-faint); letter-spacing: .03em; }
.msg-compose { display: flex; gap: 10px; align-items: flex-end; }
.msg-compose textarea { flex: 1; padding: 11px 13px; border-radius: 10px; border: 1px solid var(--line);
  background: #0e0c1c; color: var(--ink); font-size: 15px; font-family: var(--sans); resize: vertical; outline: none; }
.msg-compose textarea:focus { border-color: var(--indigo-glow); }
.msg-compose .btn { width: auto; padding: 11px 20px; }

/* ====================== sessions (Phase 5: Zoom) ====================== */
.meet-panel { margin-top: 22px; border: 1px solid var(--line); border-radius: 14px; padding: 20px;
  background: linear-gradient(180deg, var(--panel), var(--panel-2)); }
.meet-panel:empty { display: none; }
.meet-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.meet-head h3 { font-family: var(--serif); font-size: 19px; color: var(--gold-soft); font-weight: 500; margin: 0; }
.meet-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 10px 0;
  border-bottom: 1px solid var(--line); }
.meet-row:last-of-type { border-bottom: none; }
.meet-row.cancelled { opacity: .5; }
.meet-when { font-size: 13.5px; color: var(--ink); min-width: 190px; }
.meet-topic { flex: 1; font-size: 14.5px; color: var(--ink); }
.meet-dur { color: var(--ink-faint); font-size: 12px; margin-left: 6px; }
.meet-status { font-size: 12px; color: var(--ink-faint); font-style: italic; }
.meet-actions { display: flex; gap: 8px; align-items: center; }
.meet-actions .btn { width: auto; padding: 7px 16px; }
.btn-ghost { background: transparent; border: 1px solid var(--line); color: var(--ink-faint); }
.meet-pass { font-size: 12px; color: var(--ink-faint); }
.meet-compose { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-top: 14px; }
.meet-input { padding: 9px 11px; border-radius: 9px; border: 1px solid var(--line);
  background: #0e0c1c; color: var(--ink); font-size: 14px; font-family: var(--sans); outline: none; }
.meet-input:focus { border-color: var(--indigo-glow); }
.meet-dur-in { width: 72px; }
.meet-topic-in { flex: 1; min-width: 140px; }
.meet-compose .btn { width: auto; padding: 9px 18px; }
.meet-msg { margin-top: 9px; font-size: 13px; color: var(--gold-soft); min-height: 16px; }

/* ====================== motion band (Higgsfield) ====================== */
.lp-motion { max-width: 980px; margin: 8px auto 0; padding: 0 18px; }
.lp-motion-v { display: block; width: 100%; aspect-ratio: 16 / 9; object-fit: cover;
  border-radius: 16px; border: 1px solid var(--line);
  box-shadow: 0 0 0 1px #0006, 0 30px 80px -40px var(--indigo-glow);
  -webkit-mask-image: radial-gradient(120% 120% at 50% 40%, #000 70%, transparent 100%);
  mask-image: radial-gradient(120% 120% at 50% 40%, #000 70%, transparent 100%); }

/* funnel hero background film — atmospheric, scrimmed so the title stays crisp */
.lp-hero { position: relative; overflow: hidden; }
.lp-hero-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  opacity: .42; z-index: 0; pointer-events: none; }
.lp-hero-scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(125% 95% at 50% 28%, transparent 0%, var(--bg) 80%),
              linear-gradient(180deg, rgba(11,10,20,.30), rgba(11,10,20,.72)); }
.lp-hero > .sigil-lg, .lp-hero > h2, .lp-hero > .tagline, .lp-hero > .lp-promise, .lp-hero > .lp-cta { position: relative; z-index: 2; }

/* Deeper Dive — module podcast (NotebookLM) */
.deepdive { margin: 14px 0 6px; padding: 12px 14px; border-left: 2px solid var(--indigo-glow);
  border-radius: 0 10px 10px 0; background: rgba(58,47,112,.10); }
.deepdive audio { width: 100%; margin-top: 8px; }
/* ===== The Map — practitioner dashboard (Slice 1) ===== */
.map-loading { text-align: center; color: var(--ink-dim); padding: 80px 20px; font-family: var(--serif); }

/* --- intake ritual --- */
.intake { max-width: 720px; margin: 0 auto; padding: 40px 0 60px; }
.intake-open { text-align: center; margin-bottom: 34px; }
.intake-kicker { color: var(--gold); letter-spacing: .22em; text-transform: uppercase; font-size: 11px; margin-bottom: 10px; }
.intake-open h2 { font-family: var(--serif); font-size: 38px; margin: 0 0 16px;
  background: linear-gradient(180deg, var(--gold-soft), var(--gold)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.intake-lede { color: var(--ink-dim); font-family: var(--serif); font-size: 16px; max-width: 600px; margin: 0 auto; line-height: 1.7; }
.intake-lede em { color: var(--gold-soft); font-style: italic; }
.intake-block { margin-bottom: 22px; }
.intake-label { font-size: 13px; color: var(--ink); margin-bottom: 7px; letter-spacing: .03em; }
.intake-label span { color: var(--ink-faint); font-size: 12px; letter-spacing: 0; }
.intake-area, .intake-date {
  width: 100%; background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  color: var(--ink); font-family: var(--serif); font-size: 15px; padding: 12px 14px; line-height: 1.6; resize: vertical;
}
.intake-area:focus, .intake-date:focus { border-color: var(--indigo-glow); outline: none; }
.intake-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 22px; }
.intake-pole { background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; padding: 16px; }
.pole-head { font-size: 13px; margin-bottom: 12px; letter-spacing: .02em; }
.pole-head span, .lm-col-head span { display: block; color: var(--ink-faint); font-size: 11px; letter-spacing: .04em; margin-top: 2px; }
.pole-masc { color: var(--gold-soft); }
.pole-fem { color: var(--indigo-glow); }
.goal-row { display: flex; gap: 8px; margin-bottom: 9px; }
.goal-text { flex: 1; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 14px; padding: 9px 11px; }
.goal-target { width: 92px; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 9px 8px; }
.goal-text:focus, .goal-target:focus { border-color: var(--indigo-glow); outline: none; }
.intake-start { max-width: 280px; }
.intake-err { color: var(--danger); font-size: 14px; min-height: 20px; margin: 6px 0; text-align: center; }
.intake-submit { max-width: 340px; margin: 8px auto 0; display: block; }
.intake-foot { text-align: center; color: var(--ink-faint); font-size: 12px; margin-top: 16px; font-style: italic; }

/* --- living map --- */
.livingmap { max-width: 860px; margin: 0 auto; padding: 32px 0 60px; }
.lm-hero { text-align: center; padding: 30px 22px 34px; background: radial-gradient(600px 300px at 50% 0%, #1a153580, transparent);
  border: 1px solid var(--line); border-radius: 16px; margin-bottom: 24px; }
.lm-hero-kicker { color: var(--gold); letter-spacing: .22em; text-transform: uppercase; font-size: 11px; margin-bottom: 8px; }
.lm-hero-week { font-family: var(--serif); font-size: 40px; color: var(--gold-soft); }
.lm-hero-week span { color: var(--ink-faint); font-size: 22px; }
.lm-progress { height: 6px; background: var(--panel-2); border-radius: 4px; overflow: hidden; max-width: 460px; margin: 14px auto 10px; }
.lm-progress > span { display: block; height: 100%; background: linear-gradient(90deg, var(--indigo-glow), var(--gold)); }
.lm-hero-sub { color: var(--ink-dim); font-size: 13px; letter-spacing: .04em; }
.lm-vow { margin-top: 22px; }
.lm-vow-label { color: var(--gold); letter-spacing: .18em; text-transform: uppercase; font-size: 10px; margin-bottom: 6px; }
.lm-vow blockquote { font-family: var(--serif); font-size: 20px; color: var(--ink); font-style: italic; margin: 0 auto; max-width: 560px; line-height: 1.5; }
.lm-aim { margin-top: 14px; color: var(--ink-dim); font-family: var(--serif); font-size: 15px; }
.lm-moon { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 22px; }
.lm-col { background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; padding: 18px; }
.lm-col-head { font-size: 14px; margin-bottom: 14px; letter-spacing: .02em; }
.lm-goal { margin-bottom: 14px; }
.lm-goal-top { display: flex; gap: 8px; font-size: 14px; color: var(--ink); line-height: 1.4; }
.lm-goal-mark { color: var(--gold); }
.lm-goal.is-hit .lm-goal-top { color: var(--ink-faint); }
.lm-bar { height: 5px; background: var(--panel-2); border-radius: 3px; overflow: hidden; margin: 7px 0 4px; }
.lm-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--indigo-glow), var(--gold-soft)); }
.lm-goal-meta { color: var(--ink-faint); font-size: 11px; }
.lm-empty { color: var(--ink-faint); font-size: 13px; font-style: italic; }
.lm-edge { background: var(--panel); border: 1px solid var(--line); border-left: 2px solid var(--gold); border-radius: 12px; padding: 16px 18px; margin-bottom: 22px; }
.lm-edge-label { color: var(--gold); letter-spacing: .14em; text-transform: uppercase; font-size: 10px; margin-bottom: 6px; }
.lm-edge-body { font-family: var(--serif); font-size: 16px; color: var(--ink-dim); font-style: italic; }
.lm-soon { text-align: center; color: var(--ink-faint); font-size: 12px; letter-spacing: .03em; font-style: italic; }

@media (max-width: 640px) {
  .intake-grid, .lm-moon { grid-template-columns: 1fr; }
}

/* ===== Five Pillars — tap-rate (Slice 2) ===== */
.lm-pillars { background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; padding: 18px; margin-bottom: 22px; }
.lm-pillars-head { font-size: 14px; color: var(--ink); margin-bottom: 14px; letter-spacing: .02em; display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.lm-pillars-head span { color: var(--ink-faint); font-size: 12px; }
.pcoh { margin-left: auto; color: var(--gold-soft); font-size: 12px; letter-spacing: .04em; }
.prow { display: flex; align-items: center; gap: 12px; padding: 7px 0; }
.plabel { width: 56px; color: var(--ink-dim); font-size: 13px; }
.pdots { display: flex; gap: 7px; }
.pdot { width: 22px; height: 22px; border-radius: 50%; border: 1px solid var(--line); background: var(--panel);
  padding: 0; transition: background .12s, border-color .12s; }
.pdot:hover { border-color: var(--indigo-glow); }
.pdot.on { background: radial-gradient(circle at 38% 34%, var(--gold-soft), var(--gold)); border-color: var(--gold); }
.ptrend { font-size: 11px; letter-spacing: .03em; margin-left: 4px; }
.ptrend.down { color: var(--danger); }
.ptrend.up { color: var(--ok); }
.ptrend.flat { color: var(--ink-faint); }
.prow-status { min-height: 18px; margin-top: 8px; }
.psaved { font-size: 12px; color: var(--ink-faint); }
.psaved.ok { color: var(--ok); }
.psaved.hint { font-style: italic; }
@media (max-width: 640px) { .pdot { width: 26px; height: 26px; } .plabel { width: 48px; } }

/* ===== Chief Cockpit (Slice 3) ===== */
.cc-row { display: flex; justify-content: space-between; gap: 8px; margin-top: 8px; font-size: 12.5px; color: var(--ink-dim); }
.cc-wk { color: var(--gold-soft); }
.cc-goals { color: var(--ink-dim); }
.cc-track { color: var(--ink-faint); }
.cc-mover.down { color: var(--danger); }
.cc-mover.up { color: var(--ok); }
.cc-empty { color: var(--ink-faint); font-style: italic; }
.client-card .client-last { color: var(--gold); font-size: 11px; letter-spacing: .04em; margin-top: 8px; }

.chief-stack { margin-top: 30px; background: radial-gradient(700px 300px at 50% 0%, #1a153560, transparent);
  border: 1px solid var(--line); border-radius: 16px; padding: 22px; max-width: 720px; }
.chief-head { font-family: var(--serif); font-size: 19px; color: var(--gold-soft); margin-bottom: 4px; }
.chief-head span { font-family: var(--sans); font-size: 12px; color: var(--ink-faint); letter-spacing: .02em; }
.chief-metric { display: flex; justify-content: space-between; gap: 14px; padding: 11px 0; border-bottom: 1px solid #221d3c; }
.cm-q { color: var(--ink-dim); font-size: 14px; }
.cm-a { color: var(--ink); font-size: 14px; text-align: right; }
.chief-vow { margin-top: 14px; color: var(--ink-dim); font-size: 14px; }
.chief-vow em { color: var(--ink); font-family: var(--serif); }

/* read-only lens banner */
.lm-lens-banner { background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 10px 14px; margin-bottom: 18px; color: var(--ink-dim); font-size: 13px; letter-spacing: .02em;
  display: flex; justify-content: space-between; align-items: center; }
.lm-lens-banner a { color: var(--gold-soft); font-size: 12px; }
.pdot.ro { cursor: default; }

/* ===== Meeting→map loop: decisions + composer (Slice 4) ===== */
.lm-decided { background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; padding: 18px; margin-bottom: 22px; }
.lm-decided-head { font-size: 14px; color: var(--ink); margin-bottom: 12px; }
.lm-decided-head span { color: var(--ink-faint); font-size: 12px; }
.lm-dec { display: flex; align-items: baseline; gap: 10px; padding: 8px 0; border-bottom: 1px solid #221d3c; }
.lm-dec:last-child { border-bottom: 0; }
.lm-dec.done .lm-dec-body { color: var(--ink-faint); text-decoration: line-through; }
.lm-dec-kind { color: var(--gold); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; white-space: nowrap; min-width: 96px; }
.lm-dec-body { flex: 1; color: var(--ink); font-family: var(--serif); font-size: 15px; }
.lm-dec-due { color: var(--ink-faint); font-size: 11px; white-space: nowrap; }

.session-composer { background: var(--panel); border: 1px dashed var(--line); border-radius: 14px; padding: 18px; margin-bottom: 22px; }
.sc-head { font-size: 14px; color: var(--gold-soft); margin-bottom: 12px; }
.sc-head span { color: var(--ink-faint); font-size: 12px; }
.sc-row { display: flex; gap: 8px; margin-bottom: 9px; }
.sc-kind { width: 150px; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 9px; }
.sc-body { flex: 1; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 14px; padding: 9px 11px; }
.sc-due { width: 140px; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 9px; }
.sc-kind:focus, .sc-body:focus, .sc-due:focus { border-color: var(--indigo-glow); outline: none; }
.sc-err { color: var(--danger); font-size: 13px; min-height: 18px; margin: 4px 0; }
@media (max-width: 640px) { .sc-row { flex-wrap: wrap; } .sc-kind, .sc-due { width: 100%; } .lm-dec-kind { min-width: 80px; } }

/* ===== Daily practice — Layer 4 (Slice 5) ===== */
.lm-practice { background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; padding: 18px; margin-bottom: 22px; }
.lm-practice-head { font-size: 14px; color: var(--ink); margin-bottom: 14px; }
.lm-practice-head span { color: var(--ink-faint); font-size: 12px; }
.pr-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 8px 0; border-bottom: 1px solid #221d3c; }
.pr-row:last-of-type { border-bottom: 0; }
.pr-deed { flex: 1; color: var(--ink); font-family: var(--serif); font-size: 15px; }
.pr-pole { margin-right: 7px; }
.pr-pole.masc { color: var(--gold-soft); }
.pr-pole.fem { color: var(--indigo-glow); }
.pr-streak { color: var(--gold); font-size: 12px; margin-left: 7px; font-family: var(--sans); }
.pr-states { display: flex; gap: 6px; }
.pr-btn { width: 30px; height: 30px; border-radius: 8px; border: 1px solid var(--line); background: var(--panel); color: var(--ink-faint); font-size: 14px; padding: 0; }
.pr-btn:hover { border-color: var(--indigo-glow); }
.pr-btn.on.done { background: #1f3a2a; border-color: var(--ok); color: var(--ok); }
.pr-btn.on.partial { background: #3a341f; border-color: var(--gold); color: var(--gold); }
.pr-btn.on.skipped { background: #3a1f1f; border-color: var(--danger); color: var(--danger); }
.pr-state-ro { color: var(--ink-faint); font-size: 13px; font-style: italic; }
.pr-add { display: flex; gap: 8px; margin-top: 14px; }
.pr-new { flex: 1; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 14px; padding: 9px 11px; }
.pr-new-goal { width: 200px; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 9px; }
.pr-new:focus, .pr-new-goal:focus { border-color: var(--indigo-glow); outline: none; }
.pr-err { color: var(--danger); font-size: 13px; min-height: 16px; margin-top: 4px; }
@media (max-width: 640px) { .pr-add { flex-wrap: wrap; } .pr-new-goal { width: 100%; } }

/* ===== Drafts review gate (Slice 6) ===== */
.drafts-panel { background: var(--panel); border: 1px solid var(--gold); border-radius: 14px; padding: 18px; margin-bottom: 22px; }
.dr-head { font-size: 14px; color: var(--gold-soft); margin-bottom: 14px; }
.dr-head span { color: var(--ink-faint); font-size: 12px; font-style: italic; }
.dr-row { display: flex; gap: 8px; align-items: center; margin-bottom: 10px; }
.dr-kind { width: 140px; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 8px; }
.dr-body { flex: 1; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 14px; padding: 8px 11px; }
.dr-due { width: 130px; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 8px; }
.dr-kind:focus, .dr-body:focus, .dr-due:focus { border-color: var(--indigo-glow); outline: none; }
.dr-ok { white-space: nowrap; }
.dr-x { width: 32px; height: 32px; border-radius: 8px; border: 1px solid var(--line); background: var(--panel-2); color: var(--danger); font-size: 14px; padding: 0; }
.dr-x:hover { border-color: var(--danger); }
@media (max-width: 640px) { .dr-row { flex-wrap: wrap; } .dr-kind, .dr-due { width: 100%; } .dr-body { width: 100%; } }

/* ===== Practice Library flywheel (Slice 7 / v2) ===== */
.lib-new { background: var(--panel); border: 1px dashed var(--line); border-radius: 14px; padding: 18px; margin-bottom: 22px; max-width: 760px; }
.lib-new-head { font-size: 14px; color: var(--gold-soft); margin-bottom: 12px; }
.lib-in { width: 100%; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 14px; padding: 9px 11px; margin-bottom: 9px; }
.lib-new-row { display: flex; gap: 8px; margin-bottom: 9px; }
.lib-sel { background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 9px; }
.lib-new-row .lib-in { flex: 1; margin-bottom: 0; }
.lib-in:focus, .lib-sel:focus { border-color: var(--indigo-glow); outline: none; }
.lib-err { color: var(--danger); font-size: 13px; min-height: 16px; }
.lib-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }
.lib-card { background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; padding: 16px; }
.lib-title { font-family: var(--serif); font-size: 16px; color: var(--ink); margin-bottom: 6px; }
.lib-detail { color: var(--ink-dim); font-size: 13px; margin-bottom: 8px; }
.lib-edge { color: var(--ink-faint); font-size: 12px; font-style: italic; margin-bottom: 8px; }
.lib-meta { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.lib-chip { font-size: 11px; padding: 3px 8px; border-radius: 99px; background: var(--panel-2); border: 1px solid var(--line); color: var(--ink-dim); }
.lib-chip.pole-masc { color: var(--gold-soft); }
.lib-chip.pole-fem { color: var(--indigo-glow); }
.lib-chip.src { color: var(--ink-faint); }
.lib-pushed { margin-left: auto; color: var(--gold); font-size: 11px; }
/* push picker + promote on the lens */
.lib-push { background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; padding: 16px 18px; margin-bottom: 22px; }
.lib-push-head { font-size: 13px; color: var(--ink); margin-bottom: 10px; }
.lib-push-head span { color: var(--ink-faint); font-size: 12px; }
.lib-push-row { display: flex; gap: 8px; align-items: center; }
.lib-push-sel { flex: 1; background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 9px; }
.lib-push-link { color: var(--gold-soft); font-size: 12px; white-space: nowrap; }
.pr-promote { background: transparent; border: 1px solid var(--line); border-radius: 7px; color: var(--gold-soft); font-size: 11px; padding: 4px 8px; margin-left: 8px; }
.pr-promote:hover { border-color: var(--gold); }
@media (max-width: 640px) { .lib-new-row { flex-wrap: wrap; } .lib-sel { width: 100%; } }

/* ===== Dosha assessment + Food pillar intelligence (Slice 12 / v2) ===== */
.dq { max-width: 820px; margin: 0 auto; }
.dq-section-head { font-family: var(--serif); font-size: 18px; color: var(--gold-soft); margin: 26px 0 12px; }
.dq-section-head span { font-family: var(--sans); font-size: 12px; color: var(--ink-faint); }
.dq-row { padding: 10px 0; border-bottom: 1px solid #221d3c; }
.dq-trait { color: var(--gold); font-size: 12px; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 6px; }
.dq-opts { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
.dq-opt { display: flex; gap: 6px; align-items: flex-start; font-size: 13px; color: var(--ink-dim); cursor: pointer; padding: 6px; border-radius: 8px; }
.dq-opt:hover { background: var(--bg-2); }
.dq-opt input { margin-top: 3px; }
.vk-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.vk-col { background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; padding: 14px; }
.vk-head { font-size: 13px; color: var(--ink); margin-bottom: 10px; }
.vk-head span { display: block; color: var(--ink-faint); font-size: 11px; }
.vk-item { display: flex; gap: 7px; align-items: flex-start; font-size: 13px; color: var(--ink-dim); margin-bottom: 8px; cursor: pointer; }
.vk-item input { margin-top: 3px; }
.dq-err { color: var(--danger); font-size: 14px; min-height: 20px; margin: 12px 0; }
.dq-submit { max-width: 320px; margin: 10px auto 40px; display: block; }

.lm-food { background: var(--bg-2); border: 1px solid var(--line); border-left: 2px solid var(--ok); border-radius: 14px; padding: 18px; margin-bottom: 22px; }
.lm-food-head { font-size: 14px; color: var(--ink); margin-bottom: 8px; display: flex; flex-wrap: wrap; gap: 8px; align-items: baseline; }
.lm-food-tags { color: var(--ink-faint); font-size: 12px; }
.lm-food-frame { color: var(--ink-dim); font-family: var(--serif); font-size: 15px; font-style: italic; margin-bottom: 12px; }
.lm-food-sub { color: var(--gold); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; display: block; margin-bottom: 6px; }
.lm-food-grp { font-size: 13px; color: var(--ink-dim); margin-bottom: 4px; }
.lm-food-k { color: var(--ink); font-weight: 600; margin-right: 4px; }
.lm-food-avoid { margin-top: 10px; font-size: 12px; color: var(--ink-faint); }
.lm-food-reassess { background: transparent; border: 0; color: var(--gold-soft); font-size: 12px; margin-top: 12px; padding: 0; text-decoration: underline; }
@media (max-width: 640px) { .dq-opts, .vk-grid { grid-template-columns: 1fr; } }

/* ===== Moon strip + money tiers (Slice 9 / v2) ===== */
.moon-strip { margin-top: 12px; color: var(--ink-dim); font-size: 13px; letter-spacing: .03em; display: flex; gap: 8px; align-items: center; justify-content: center; flex-wrap: wrap; }
.moon-glyph { font-size: 16px; }
.moon-reset { color: var(--gold); }
.lm-money { background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; padding: 18px; margin-bottom: 22px; }
.lm-money-head { font-size: 14px; color: var(--ink); margin-bottom: 14px; }
.lm-money-head span { color: var(--ink-faint); font-size: 12px; font-style: italic; }
.mt-row { padding: 12px 0; border-bottom: 1px solid #221d3c; }
.mt-row:last-of-type { border-bottom: 0; }
.mt-row.hit { opacity: .92; }
.mt-h { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.mt-label { font-family: var(--serif); font-size: 16px; color: var(--gold-soft); }
.mt-sub { color: var(--ink-faint); font-size: 12px; }
.mt-amt { margin-left: auto; color: var(--ok); font-size: 15px; }
.mt-why { color: var(--ink-dim); font-size: 13px; margin-top: 5px; font-style: italic; }
.mt-celebrate { color: var(--gold); font-size: 13px; margin-top: 5px; }
.mt-inputs { display: flex; gap: 8px; margin-top: 8px; }
.mt-amt-in { width: 110px; }
.mt-why-in { flex: 1; }
.mt-cel-in { flex: 1; }
.mt-inputs input { background: var(--panel); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 13px; padding: 8px 10px; }
.mt-inputs input:focus { border-color: var(--indigo-glow); outline: none; }
.mt-hit { margin-left: auto; background: transparent; border: 1px solid var(--line); border-radius: 7px; color: var(--ink-dim); font-size: 12px; padding: 4px 10px; }
.mt-hit.on { background: #1f3a2a; border-color: var(--ok); color: var(--ok); }
.mt-err { color: var(--danger); font-size: 13px; min-height: 16px; margin: 6px 0; }
@media (max-width: 640px) { .mt-inputs { flex-wrap: wrap; } .mt-amt-in, .mt-why-in, .mt-cel-in { width: 100%; } }

/* ===== New-moon reset ritual (Slice 10 / v2) ===== */
.moon-reset.link { cursor: pointer; text-decoration: underline; }
.rs { max-width: 740px; margin: 0 auto; padding-bottom: 50px; }
.rs-review { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 18px; }
.rs-col, .rs-moneywrap { background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; padding: 16px; }
.rs-moneywrap { margin-bottom: 18px; }
.rs-sub { color: var(--gold); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 10px; }
.rs-col ul, .rs-moneywrap ul { list-style: none; margin: 0; padding: 0; }
.rs-goal, .rs-money { font-size: 14px; color: var(--ink-dim); padding: 5px 0; }
.rs-goal span { color: var(--ink-faint); font-size: 12px; margin-left: 4px; }
.rs-goal.hit, .rs-money.hit { color: var(--ok); }
.rs-money strong { color: var(--gold-soft); text-transform: capitalize; }
.rs-block { margin-bottom: 16px; }
.rs-label { font-size: 13px; color: var(--ink); margin-bottom: 7px; }
.rs-area { width: 100%; background: var(--panel); border: 1px solid var(--line); border-radius: 10px; color: var(--ink); font-family: var(--serif); font-size: 15px; padding: 12px 14px; line-height: 1.6; resize: vertical; }
.rs-area:focus { border-color: var(--indigo-glow); outline: none; }
.rs-err { color: var(--danger); font-size: 14px; min-height: 20px; }
.rs-submit { max-width: 320px; margin: 6px auto 0; display: block; }
.rs-foot { text-align: center; color: var(--ink-faint); font-size: 12px; font-style: italic; margin-top: 14px; }
.rs-past { margin-top: 30px; border-top: 1px solid var(--line); padding-top: 18px; }
.rs-past-row { display: flex; gap: 12px; padding: 7px 0; font-size: 13px; border-bottom: 1px solid #221d3c; }
.rs-past-cyc { color: var(--ink-faint); white-space: nowrap; }
.rs-past-win { color: var(--ink-dim); }
@media (max-width: 640px) { .rs-review { grid-template-columns: 1fr; } }

/* ===== Body-over-star pillar visual (Slice 11 / v2) ===== */
.pillar-star { display: block; width: 100%; max-width: 320px; margin: 4px auto 14px; overflow: visible; }
.star-ring { fill: none; stroke: var(--line); stroke-width: 1; opacity: .6; }
.star-path { fill: none; stroke: var(--gold); stroke-width: 1; opacity: .35; stroke-linejoin: round; }
.fig { stroke: var(--gold-soft); stroke-width: 1; opacity: .3; }
.fig-head { fill: none; stroke: var(--gold-soft); stroke-width: 1; opacity: .4; }
.star-lab { font-family: var(--sans); font-size: 11px; letter-spacing: .04em; opacity: .9; }
.star-v { font-weight: 700; }
.star-coh { font-family: var(--serif); font-size: 26px; fill: var(--gold-soft); }
.star-state { font-family: var(--sans); font-size: 10px; fill: var(--ink-dim); letter-spacing: .06em; }
.star-strong { fill: var(--gold); font-weight: 700; }

/* age rhythm note (Slice 12b) */
.prow-rhythm { margin-top: 12px; padding-top: 10px; border-top: 1px solid #221d3c; color: var(--ink-faint); font-size: 12px; font-style: italic; line-height: 1.5; }

/* ===== Goal setter + auto-suggest (v2) ===== */
.lm-goalset { background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; padding: 18px; margin-bottom: 22px; }
.gs-head { font-size: 14px; color: var(--ink); margin-bottom: 12px; }
.gs-head span { color: var(--ink-faint); font-size: 12px; }
.gs-add { display: flex; gap: 8px; margin-bottom: 9px; }
.gs-in { flex: 1; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); font-size: 14px; padding: 9px 11px; }
.gs-in:focus { border-color: var(--indigo-glow); outline: none; }
.gs-add-btn { background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; color: var(--gold-soft); font-size: 13px; padding: 0 14px; }
.gs-suggest { margin: 10px 0 4px; }
.gs-chips { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 8px; }
.gs-pole-h { font-size: 11px; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 6px; }
.gs-chip { display: block; width: 100%; text-align: left; background: var(--panel); border: 1px solid var(--line); border-radius: 9px;
  color: var(--ink); font-size: 13px; padding: 8px 10px; margin-bottom: 7px; line-height: 1.35; cursor: pointer; }
.gs-chip:hover { border-color: var(--indigo-glow); }
.gs-chip.sun:hover { border-color: var(--gold); }
.gs-err { color: var(--danger); font-size: 13px; min-height: 16px; margin-top: 6px; }
@media (max-width: 640px) { .gs-chips { grid-template-columns: 1fr; } }

/* ── Week Deep Dive (per-week NotebookLM area) ─────────────────────── */
.week-label { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.week-deepdive-link {
  font-size: 11px; letter-spacing: .04em; color: var(--gold-soft);
  border: 1px solid var(--line); border-radius: 999px; padding: 2px 10px;
  cursor: pointer; font-weight: 500; white-space: nowrap;
}
.week-deepdive-link:hover { color: var(--gold); border-color: var(--gold); }
.week-deepdive-cta {
  margin: 18px 0; padding: 12px 14px; border: 1px solid var(--line);
  border-radius: 10px; background: rgba(216, 178, 92, .05);
}
.week-deepdive-cta a { cursor: pointer; color: var(--gold-soft); font-weight: 500; }
.week-deepdive-cta a:hover { color: var(--gold); }
.week-deepdive .crumb a { color: var(--gold-soft); cursor: pointer; }
.deepdive-video { margin: 16px 0; }
.deepdive-video video.day-hero { width: 100%; border-radius: 12px; }
.deepdive-gallery {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px; margin: 8px 0 20px;
}
.deepdive-gallery .day-art { width: 100%; border-radius: 10px; margin: 0; }

/* ── The Practice (daily-practice tracker) ─────────────────────────── */
.pr-today { margin: 18px 0; padding: 16px; border: 1px solid var(--line); border-radius: 12px; background: rgba(216,178,92,.045); }
.pr-pillars { display: flex; flex-wrap: wrap; gap: 8px; margin: 6px 0 12px; }
.pr-pill { font-size: 12.5px; padding: 6px 12px; border-radius: 999px; border: 1px solid var(--line); background: transparent; color: var(--ink-dim); cursor: pointer; }
.pr-pill:hover { border-color: var(--indigo-glow); }
.pr-pill.on { background: linear-gradient(180deg, var(--gold-soft), var(--gold)); color: #2a1f08; border-color: var(--gold); font-weight: 600; }
.pr-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.pr-miss { margin-top: 4px; }
.pr-reason { display: inline-block; font-size: 12.5px; padding: 6px 12px; margin: 4px 6px 0 0; border-radius: 8px; border: 1px solid var(--line); background: transparent; color: var(--ink-dim); cursor: pointer; }
.pr-reason:hover { border-color: var(--gold); color: var(--gold-soft); }
.pr-done-banner { color: var(--gold-soft); font-size: 14px; padding: 6px 0; }
.pr-miss-banner { color: var(--ink-dim); font-size: 14px; padding: 6px 0; line-height: 1.5; }
.pr-msg { font-size: 12px; color: var(--ink-faint); margin-top: 8px; min-height: 14px; }
.pr-readback { margin-top: 22px; }
.pr-stats { display: flex; gap: 20px; font-size: 13px; color: var(--ink-dim); margin: 4px 0 10px; }
.pr-stats b { color: var(--gold-soft); font-size: 16px; }
.pr-dots { display: flex; flex-wrap: wrap; gap: 5px; }
.pr-dot { width: 12px; height: 12px; border-radius: 50%; display: inline-block; }
.pr-dot.held { background: linear-gradient(180deg, var(--gold-soft), var(--gold)); }
.pr-dot.miss { background: var(--indigo); opacity: .5; }

/* The Practice, backed into the Mirror */
.pr-section { margin: 22px 0; padding: 16px; border: 1px solid var(--line); border-radius: 12px; background: rgba(91,73,176,.06); }
.pr-today-label { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-faint); margin: 6px 0 8px; }
.pr-prompt { color: var(--ink-dim); font-size: 14px; line-height: 1.5; margin: .3rem 0 .8rem; }
.pr-pillars-coherence { margin-top: 16px; }
.pr-pillar-bars { display: flex; flex-direction: column; gap: 6px; margin-top: 6px; }
.pr-pbar { display: flex; align-items: center; gap: 10px; font-size: 12.5px; }
.pr-pbar-l { width: 150px; color: var(--ink-dim); flex-shrink: 0; }
.pr-pbar-track { flex: 1; height: 7px; background: rgba(255,255,255,.05); border-radius: 999px; overflow: hidden; }
.pr-pbar-fill { display: block; height: 100%; background: linear-gradient(90deg, var(--indigo-glow), var(--gold)); border-radius: 999px; }
.pr-pbar-n { width: 20px; text-align: right; color: var(--gold-soft); font-variant-numeric: tabular-nums; }
.pr-foot { color: var(--ink-faint); font-size: 12px; margin: .6rem 0 0; }
