/* v9 */
/* ── Reset & base ──────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          #f0ede8;
  --surface:     #ffffff;
  --border:      #ddd8d0;
  --text:        #1a1917;
  --muted:       #8a8680;
  --accent:      #2d5be3;
  --accent-hov:  #1e46c7;
  --badge-bg:    #eef0fb;
  --badge-txt:   #2d5be3;
  --paper:       #f9f7f3;
  --paper-border:#d8d3cb;
  --paper-shadow:0 2px 20px rgba(0,0,0,0.10), 0 1px 4px rgba(0,0,0,0.06);
  --ink:         #1c1a17;
  --font:    system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
  --mono:    ui-monospace, "SF Mono", Consolas, monospace;
  --type:    "Courier New", Courier, monospace;
}

html.dark {
  --bg:          #111010;
  --surface:     #1c1b19;
  --border:      #2e2c29;
  --text:        #cdc9c2;
  --muted:       #5e5c58;
  --accent:      #5b80f5;
  --accent-hov:  #7a9aff;
  --badge-bg:    #1e2340;
  --badge-txt:   #7a9aff;
  --paper:       #181714;
  --paper-border:#2a2825;
  --paper-shadow:0 2px 20px rgba(0,0,0,0.5), 0 1px 4px rgba(0,0,0,0.4);
  --ink:         #b8b4ac;
}

html.dark .badge-lang   { background: #0f2010; color: #5aad5a; }
html.dark .badge-module { background: #1a1030; color: #9b72e8; }
html.dark .cmd-ref code { background: rgba(255,255,255,0.08); }

html { font-size: 17px; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  height: 100dvh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* ── Header ────────────────────────────────────────────────────────────────── */
header {
  border-bottom: 1px solid var(--border);
  padding: 0.625rem 2rem;
  background: var(--surface);
}

.site-name {
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
}

.site-name:hover { color: var(--accent); }

.site-nav-link {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--muted);
  text-decoration: none;
  opacity: 0.7;
}
.site-nav-link:hover { color: var(--accent); opacity: 1; }
body:has(.ms-layout) .site-nav-link { color: var(--ms-muted); }
body:has(.ms-layout) .site-nav-link:hover { color: var(--ms-accent); opacity: 1; }

/* ── Dark-mode toggle ──────────────────────────────────────────────────────── */
.dark-toggle {
  margin-left: auto;
  background: none;
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--muted);
  font-size: 0.75rem;
  padding: 0.2em 0.6em;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
  font-family: var(--font);
}
.dark-toggle:hover { border-color: var(--accent); color: var(--accent); }

/* ── Main ──────────────────────────────────────────────────────────────────── */
main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── Home layout (two-column) ──────────────────────────────────────────────── */
main:has(.home-layout) { overflow-y: auto; }

.home-layout {
  display: flex;
  align-items: flex-start;
  max-width: min(92vw, 1500px);
  margin: 0 auto;
  padding: 2rem 1.5rem 4rem;
  gap: 0;
}

/* ── Project info panel (left 1/3) ─────────────────────────────────────────── */
.project-panel {
  width: 33.333%;
  flex-shrink: 0;
  padding-right: 2rem;
}

.project-panel-inner {
  padding: 1.5rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
}

.eyebrow {
  margin: 0 0 0.5rem;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.project-panel h2 {
  margin: 0 0 1rem;
  font-size: 1.6rem;
  line-height: 1.2;
  color: var(--text);
}

.project-panel h3 {
  margin: 1.5rem 0 0.75rem;
  font-size: 1rem;
  color: var(--text);
}

.project-panel p {
  margin: 0 0 1rem;
  line-height: 1.6;
  color: var(--text);
  font-size: 0.9375rem;
}

.project-panel .lead {
  font-size: 1rem;
}

.project-points {
  margin: 1.25rem 0;
  padding: 1rem;
  border-left: 4px solid var(--text);
  background: var(--bg);
  border-radius: 0 4px 4px 0;
}

.project-points p {
  margin: 0 0 0.5rem;
  font-size: 0.875rem;
}

.project-points p:last-child { margin-bottom: 0; }

.project-panel ul {
  margin: 0 0 1.25rem 1.1rem;
  padding: 0;
}

.project-panel li {
  margin-bottom: 0.45rem;
  line-height: 1.5;
  font-size: 0.9375rem;
  color: var(--text);
}

.writers-callout {
  margin: 1.5rem 0;
  padding: 1rem;
  border-radius: 8px;
  background: var(--badge-bg);
}

.writers-callout strong {
  display: block;
  margin-bottom: 0.5rem;
  font-size: 1rem;
  color: var(--text);
}

.writers-callout p { margin: 0; font-size: 0.875rem; }

.panel-cta { margin-top: 1.5rem !important; }

.cta-link {
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
}

.cta-link:hover { color: var(--accent-hov); }

.cta-sep { margin: 0 0.5rem; color: var(--muted); }

/* ── Projects column (right 2/3) ───────────────────────────────────────────── */
.projects-column {
  flex: 1;
  min-width: 0;
}

.projects-column h1 {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
  color: var(--text);
}

.page-index h1 {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
}

.project-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.project-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.875rem 1.25rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  text-decoration: none;
  color: var(--text);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.project-link:hover {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(45, 91, 227, 0.08);
}

.project-title  { font-weight: 500; }

.project-link-resume {
  border-color: var(--border);
  margin-bottom: 0.5rem;
}
.project-link-resume .project-title { color: var(--text); }

.project-link-new {
  border-color: var(--accent);
  margin-bottom: 1rem;
}
.project-link-new .project-title { color: var(--accent); }

.project-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: var(--muted);
}

.empty-state { color: var(--muted); font-size: 0.9375rem; }

/* ── Badges ────────────────────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 0.15em 0.55em;
  border-radius: 99px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.badge-mode   { background: var(--badge-bg); color: var(--badge-txt); }
.badge-lang   { background: #f0faf0; color: #267326; }
.badge-module { background: #f5f0fb; color: #6b3bbf; }

/* ── Chapter / project bar ─────────────────────────────────────────────────── */
.chapter-bar {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 0.5rem 2rem;
}

.chapter-bar-inner {
  max-width: min(90vw, 1400px);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.bar-project {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
}

.bar-chapter {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.chapter-select {
  font-size: 0.8125rem;
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 0.2em 0.5em;
  background: var(--bg);
  color: var(--text);
  cursor: pointer;
}

.bar-btn {
  font-size: 0.75rem;
  padding: 0.2em 0.6em;
  border: 1px solid var(--border);
  border-radius: 5px;
  background: var(--surface);
  color: var(--muted);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}

.bar-btn:hover { border-color: var(--accent); color: var(--accent); }

.bar-badges {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-wrap: wrap;
}

.sound-toggle-label {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  color: var(--muted);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}

.sound-toggle-label input { cursor: pointer; }

/* ── Page wrapper (write page) — two-page spread ──────────────────────────── */
.page-wrapper {
  flex: 1;
  display: grid;
  grid-template-columns: 3fr 2fr;
  grid-template-rows: 1fr;
  overflow: hidden;
  padding: 1.5rem 2.5rem;
  gap: 0;
}

/* ── Left page — manuscript ────────────────────────────────────────────────── */
.manuscript-sheet {
  background: var(--paper);
  border: 1px solid var(--paper-border);
  border-right: 2px solid var(--border);
  border-radius: 3px 0 0 3px;
  box-shadow: var(--paper-shadow), inset 0 0 0 1px rgba(255,255,255,0.5);
  padding: 1.75rem 2.5rem 1.75rem;
  font-family: var(--type);
  font-size: 1rem;
  color: var(--ink);
  overflow-y: scroll;
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: var(--paper-border) transparent;
  min-height: 0;
}
.manuscript-sheet::-webkit-scrollbar        { width: 7px; }
.manuscript-sheet::-webkit-scrollbar-track  { background: transparent; }
.manuscript-sheet::-webkit-scrollbar-thumb  {
  background: var(--paper-border);
  border-radius: 4px;
}

/* ── Right page — command output + typing ──────────────────────────────────── */
.page-right {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--paper-border);
  border-left: none;
  border-radius: 0 3px 3px 0;
  box-shadow: var(--paper-shadow);
  overflow-y: auto;
  min-height: 0;
}

.manuscript-segment {
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.7;
  margin-bottom: 0.6em;
  color: #0882a0;
}

.manuscript-segment:last-child { margin-bottom: 0; }

.manuscript-empty {
  color: var(--muted);
  font-style: italic;
  font-family: var(--font);
  font-size: 0.9rem;
  line-height: 1.6;
}

/* ── Command output ────────────────────────────────────────────────────────── */
.command-output {
  background: #1a1917;
  color: #d4d0ca;
  font-family: var(--mono);
  font-size: 0.875rem;
  line-height: 1.6;
  padding: 1rem 1.5rem;
  white-space: pre-wrap;
  word-break: break-word;
  border-left: 3px solid var(--accent);
}

.command-error { border-left-color: #c0392b; color: #f5a97f; }

/* ── Typing area ───────────────────────────────────────────────────────────── */
.typing-area {
  flex: 1;
  background: var(--paper);
  border: none;
  border-top: 2px solid var(--border);
  padding: 1.5rem 3rem 2rem;
}

#sentence-field {
  width: 100%;
  font-family: var(--type);
  font-size: 1rem;
  line-height: 2;
  padding: 0.5rem 0;
  border: none;
  border-bottom: 1px solid var(--border);
  background: transparent;
  color: var(--ink);
  resize: none;
  outline: none;
}

#sentence-field::placeholder { color: var(--muted); font-style: italic; }

#sentence-field:focus { border-bottom-color: var(--accent); }

.typing-controls {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 0.875rem;
}

#submit-btn {
  padding: 0.4rem 1.25rem;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 5px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s;
}

#submit-btn:hover  { background: var(--accent-hov); }
#submit-btn:active { transform: translateY(1px); }

.submit-hint {
  font-size: 0.75rem;
  color: var(--muted);
  font-family: var(--mono);
}

.submit-status {
  font-size: 0.8125rem;
  color: var(--muted);
  margin-left: auto;
}

.submit-error { color: #c0392b; }

/* ── Command reference ─────────────────────────────────────────────────────── */
.cmd-ref {
  margin-top: 1.25rem;
  padding: 0.5rem 0;
  border-top: 1px solid var(--border);
  font-size: 0.775rem;
  color: var(--muted);
  line-height: 2;
}

.cmd-ref code {
  font-family: var(--mono);
  color: var(--text);
  background: rgba(0,0,0,0.06);
  padding: 0.05em 0.3em;
  border-radius: 3px;
  font-size: 0.85em;
}

.cmd-ref-title {
  display: block;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 0.68rem;
  color: var(--muted);
  margin-bottom: 0.25rem;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .home-layout { flex-direction: column; padding: 1.5rem 1rem 3rem; }
  .project-panel { width: 100%; padding-right: 0; margin-bottom: 2rem; }
}

@media (max-width: 800px) {
  body { height: auto; overflow: auto; }
  main { overflow: visible; }
  .page-wrapper {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    overflow: visible;
    padding: 1rem 0.75rem;
  }
  .manuscript-sheet {
    overflow-y: visible;
    border-right: 1px solid var(--paper-border);
    border-bottom: 2px solid var(--border);
    border-radius: 3px 3px 0 0;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    min-height: 30vh;
  }
  .page-right {
    overflow-y: visible;
    border-left: 1px solid var(--paper-border);
    border-top: none;
    border-radius: 0 0 3px 3px;
  }
  .typing-area { padding-left: 1.5rem; padding-right: 1.5rem; }
  .chapter-bar { padding: 0.5rem 1rem; }
}

.muted { color: var(--muted); font-size: 0.875rem; }

/* ── Header nav ────────────────────────────────────────────────────────────── */
.header-nav {
  display: flex;
  gap: 0.125rem;
}

.nav-link {
  font-size: 0.8125rem;
  padding: 0.2em 0.65em;
  border-radius: 5px;
  color: var(--muted);
  text-decoration: none;
  transition: color 0.15s, background 0.15s;
}

.nav-link:hover {
  color: var(--accent);
  background: var(--badge-bg);
}

/* ── Source mode badges ─────────────────────────────────────────────────────── */
.char-source-badge {
  display: inline-block;
  padding: 0.1em 0.45em;
  border-radius: 99px;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.source-manual    { background: #eef0fb; color: #2d5be3; }
.source-extracted { background: #f0faf0; color: #267326; }
.source-imported  { background: #f5f0fb; color: #6b3bbf; }
.source-generated { background: #fef8e7; color: #9a6f00; }

html.dark .source-manual    { background: #1e2340; color: #7a9aff; }
html.dark .source-extracted { background: #0f2010; color: #5aad5a; }
html.dark .source-imported  { background: #1a1030; color: #9b72e8; }
html.dark .source-generated { background: #2a1e00; color: #d4a500; }

/* ── Studio layout (two-column: sidebar + main) ─────────────────────────────── */
main:has(.studio-layout) { overflow-y: auto; }
main:has(.dialog-layout)  { overflow-y: auto; }

.studio-layout {
  display: flex;
  height: 100%;
  min-height: 0;
}

/* ── Studio sidebar ─────────────────────────────────────────────────────────── */
.studio-sidebar {
  width: 220px;
  flex-shrink: 0;
  border-right: 1px solid var(--border);
  background: var(--surface);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}

.sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.875rem 1rem 0.625rem;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--surface);
  z-index: 1;
}

.sidebar-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted);
}

.sidebar-new-btn {
  font-size: 0.75rem;
  padding: 0.15em 0.55em;
  border: 1px solid var(--border);
  border-radius: 5px;
  text-decoration: none;
  color: var(--muted);
  transition: border-color 0.15s, color 0.15s;
}

.sidebar-new-btn:hover { border-color: var(--accent); color: var(--accent); }

.sidebar-empty {
  padding: 1rem;
  font-size: 0.85rem;
  color: var(--muted);
}

.char-list {
  list-style: none;
  padding: 0.375rem 0;
}

.char-list-item { display: block; }

.char-list-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  text-decoration: none;
  color: var(--text);
  font-size: 0.875rem;
  transition: background 0.12s;
}

.char-list-link:hover { background: var(--bg); }

.char-list-item.is-active .char-list-link {
  background: var(--badge-bg);
  color: var(--accent);
}

.char-list-name {
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Studio main panel ───────────────────────────────────────────────────────── */
.studio-main {
  flex: 1;
  min-width: 0;
  overflow-y: auto;
  padding: 2rem 2.5rem 4rem;
}

.studio-panel {
  max-width: 760px;
}

.studio-empty-state {
  padding: 3rem 0;
  color: var(--muted);
  font-size: 0.9375rem;
  line-height: 2;
}

.studio-empty-state a { color: var(--accent); }

/* ── Panel header ────────────────────────────────────────────────────────────── */
.panel-title {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 0.25rem;
}

.panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.75rem;
}

.panel-header-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
  padding-top: 0.35rem;
}

.char-id-display {
  font-family: var(--mono);
  font-size: 0.75rem;
  color: var(--muted);
}

/* ── Character form ──────────────────────────────────────────────────────────── */
.char-form { display: flex; flex-direction: column; gap: 0; }

.form-section {
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}

.form-section:last-of-type { border-bottom: none; }

.section-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted);
  margin-bottom: 0.25rem;
}

.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.field-row-3 { grid-template-columns: 1fr 1fr 1fr; }

.field-group {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.field-label {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--muted);
}

.field-input,
.field-select,
.field-textarea {
  font-family: var(--font);
  font-size: 0.9rem;
  color: var(--text);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0.45em 0.7em;
  transition: border-color 0.15s;
  outline: none;
  width: 100%;
}

.field-input:focus,
.field-select:focus,
.field-textarea:focus { border-color: var(--accent); }

.field-textarea { resize: vertical; }

.field-hint {
  font-size: 0.75rem;
  color: var(--muted);
}

/* ── Checkboxes / radios ─────────────────────────────────────────────────────── */
.checkbox-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  padding-top: 0.25rem;
}

.checkbox-stack {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.checkbox-label {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.875rem;
  color: var(--text);
  cursor: pointer;
}

.radio-group {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.radio-label {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.9rem;
  color: var(--text);
  cursor: pointer;
}

.radio-label input[type="radio"] { margin-top: 0.2em; flex-shrink: 0; }

.radio-label .field-hint {
  display: block;
  margin-top: 0.1rem;
}

/* ── Form actions ────────────────────────────────────────────────────────────── */
.form-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding-top: 1.5rem;
}

.btn-primary {
  padding: 0.45rem 1.4rem;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s;
  font-family: var(--font);
}

.btn-primary:hover { background: var(--accent-hov); }
.btn-primary:disabled { opacity: 0.5; cursor: default; }

.btn-muted {
  padding: 0.4rem 0.9rem;
  background: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 0.8125rem;
  color: var(--muted);
  cursor: pointer;
  text-decoration: none;
  transition: border-color 0.15s, color 0.15s;
  font-family: var(--font);
}

.btn-muted:hover { border-color: var(--accent); color: var(--accent); }

.btn-danger {
  padding: 0.4rem 0.9rem;
  background: none;
  border: 1px solid #c0392b;
  border-radius: 6px;
  font-size: 0.8125rem;
  color: #c0392b;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  font-family: var(--font);
}

.btn-danger:hover { background: #c0392b; color: #fff; }

/* ── Dialog generation layout ────────────────────────────────────────────────── */
.dialog-layout {
  display: flex;
  gap: 0;
  height: 100%;
  min-height: 0;
}

.dialog-form-col {
  width: 420px;
  flex-shrink: 0;
  border-right: 1px solid var(--border);
  overflow-y: auto;
  padding: 2rem 2rem 4rem;
}

.dialog-form-col .panel-title { margin-bottom: 1.25rem; }
.dialog-form-col .form-section { padding: 1.25rem 0; }

.dialog-output-col {
  flex: 1;
  min-width: 0;
  overflow-y: auto;
  padding: 2rem 2.5rem 4rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.dialog-output-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.dialog-output-text {
  font-family: var(--type);
  font-size: 0.9375rem;
  line-height: 1.85;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--text);
  background: var(--paper);
  border: 1px solid var(--paper-border);
  border-radius: 6px;
  padding: 1.5rem 2rem;
}

/* ── Write page — character reference strip ──────────────────────────────────── */
.char-ref {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--border);
  font-size: 0.75rem;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.75rem;
}

.char-ref-item {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}

.char-ref-link {
  color: var(--text);
  text-decoration: none;
  font-weight: 500;
}

.char-ref-link:hover { color: var(--accent); }

.char-ref-id {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--muted);
  background: rgba(0,0,0,0.05);
  padding: 0.05em 0.3em;
  border-radius: 3px;
}

html.dark .char-ref-id { background: rgba(255,255,255,0.07); }

.char-ref-dialog-link {
  margin-left: auto;
  color: var(--accent);
  text-decoration: none;
  font-size: 0.75rem;
}

.char-ref-dialog-link:hover { color: var(--accent-hov); }

/* ── Dialog draft editor ─────────────────────────────────────────────────────── */
.draft-editor-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.dialog-draft-editor {
  width: 100%;
  min-height: 320px;
  font-family: var(--type);
  font-size: 0.9375rem;
  line-height: 1.85;
  color: var(--text);
  background: var(--paper);
  border: 1px solid var(--paper-border);
  border-radius: 6px;
  padding: 1.25rem 1.75rem;
  resize: vertical;
  outline: none;
  transition: border-color 0.15s;
}

.dialog-draft-editor:focus { border-color: var(--accent); }

.draft-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 0.75rem;
}

/* ── Delta review panel ──────────────────────────────────────────────────────── */
.delta-panel {
  margin-top: 1.5rem;
  border-top: 2px solid var(--border);
  padding-top: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.delta-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.delta-character {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.delta-char-name {
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--text);
}

.delta-labels {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.delta-label {
  display: inline-block;
  padding: 0.18em 0.6em;
  border-radius: 99px;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  font-family: var(--mono);
}

.conf-high { background: #eaf4ea; color: #276227; }
.conf-med  { background: #fef8e0; color: #8a6000; }
.conf-low  { background: #f5f0fb; color: #6b3bbf; }

html.dark .conf-high { background: #0f2010; color: #5aad5a; }
html.dark .conf-med  { background: #2a1e00; color: #d4a500; }
html.dark .conf-low  { background: #1a1030; color: #9b72e8; }

.delta-updates-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8375rem;
}

.delta-updates-table thead th {
  text-align: left;
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  padding: 0.25rem 0.5rem 0.5rem 0;
  border-bottom: 1px solid var(--border);
}

.delta-updates-table tbody td {
  padding: 0.4rem 0.5rem 0.4rem 0;
  vertical-align: middle;
  color: var(--text);
  border-bottom: 1px solid var(--border);
}

.delta-updates-table tbody tr:last-child td { border-bottom: none; }

.update-arrow {
  font-family: var(--mono);
  font-size: 0.8rem;
  padding: 0.1em 0.4em;
  border-radius: 4px;
}

.conf-pill {
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.15em 0.5em;
  border-radius: 99px;
}

.update-arrow.conf-high, .conf-pill.conf-high { background: #eaf4ea; color: #276227; }
.update-arrow.conf-med,  .conf-pill.conf-med  { background: #fef8e0; color: #8a6000; }
.update-arrow.conf-low,  .conf-pill.conf-low  { background: #f5f0fb; color: #6b3bbf; }

html.dark .update-arrow.conf-high, html.dark .conf-pill.conf-high { background: #0f2010; color: #5aad5a; }
html.dark .update-arrow.conf-med,  html.dark .conf-pill.conf-med  { background: #2a1e00; color: #d4a500; }
html.dark .update-arrow.conf-low,  html.dark .conf-pill.conf-low  { background: #1a1030; color: #9b72e8; }

.delta-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding-top: 0.5rem;
}

/* ── Field tooltips ─────────────────────────────────────────────────────────── */
.field-label {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.field-tip {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  background: var(--border);
  color: var(--muted);
  font-size: 0.65rem;
  font-weight: 700;
  cursor: default;
  flex-shrink: 0;
  line-height: 1;
  user-select: none;
}

.field-tip::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 0.4rem);
  left: 50%;
  transform: translateX(-50%);
  width: 220px;
  padding: 0.45rem 0.6rem;
  background: var(--text);
  color: var(--bg);
  font-size: 0.72rem;
  font-weight: 400;
  line-height: 1.4;
  border-radius: 4px;
  white-space: normal;
  z-index: 200;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.12s;
}

.field-tip:hover::after {
  opacity: 1;
}

/* ── Segment numbers ────────────────────────────────────────────────────────── */
.manuscript-segment  { display: flex; gap: 0.75rem; align-items: flex-start; }
.seg-num             { flex: 0 0 1.6rem; text-align: right; padding-top: 0.15em;
                       font-family: "JetBrains Mono", monospace; font-size: 0.72rem;
                       color: var(--text-muted, #888); user-select: none; line-height: 1.6; }
.seg-body            { flex: 1; min-width: 0; }

/* ── Edit banner ─────────────────────────────────────────────────────────────── */
.edit-banner { background: #7c6000; color: #ffe87c; border-radius: 4px;
               padding: 0.35rem 0.75rem; font-size: 0.82rem; margin-bottom: 0.5rem; }

/* ── Segment inline editor ──────────────────────────────────────────────────── */
.seg-body                     { position: relative; }
.seg-edit-btn                 { position: absolute; top: 4px; right: 4px; background: none; border: 1px solid var(--border); border-radius: 3px; padding: 1px 6px; font-size: 0.72rem; cursor: pointer; opacity: 0; transition: opacity 0.15s; color: var(--text-muted, #888); line-height: 1.4; }
.manuscript-segment:hover .seg-edit-btn { opacity: 1; }
.seg-editor                   { padding: 0.25rem 0; }
.seg-editor-ta                { width: 100%; font-family: 'Courier New', monospace; font-size: 0.85rem; padding: 0.4rem; border: 1px solid var(--border); border-radius: 3px; background: var(--bg); color: var(--text); resize: vertical; }
.seg-editor-btns              { display: flex; gap: 0.5rem; margin-top: 0.4rem; }
.seg-editor-btns button       { padding: 3px 10px; font-size: 0.8rem; border-radius: 3px; cursor: pointer; border: 1px solid var(--border); background: var(--bg); color: var(--text); }
.seg-editor-btns .seg-save-btn { background: var(--accent, #2563eb); color: #fff; border-color: transparent; }
.seg-editor-btns .seg-save-btn:disabled { opacity: 0.6; cursor: default; }

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .studio-sidebar { width: 180px; }
  .field-row-3 { grid-template-columns: 1fr 1fr; }
  .dialog-form-col { width: 340px; padding: 1.5rem; }
}

@media (max-width: 700px) {
  .studio-layout { flex-direction: column; }
  .studio-sidebar { width: 100%; border-right: none; border-bottom: 1px solid var(--border); }
  .studio-main { padding: 1.25rem 1rem 3rem; }
  .field-row, .field-row-3 { grid-template-columns: 1fr; }
  .dialog-layout { flex-direction: column; }
  .dialog-form-col { width: 100%; border-right: none; border-bottom: 1px solid var(--border); }
  .panel-header { flex-direction: column; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   MANUSCRIPT — Three-panel writing environment
   ═══════════════════════════════════════════════════════════════════════════ */

/* Manuscript colour tokens — light (cream) default */
:root {
  --ms-bg:          #f7f3ec;
  --ms-bg-mid:      #ede8df;
  --ms-bg-soft:     #faf7f2;
  --ms-surface:     #ffffff;
  --ms-surface-hi:  #f0ebe0;
  --ms-text:        #1e1610;
  --ms-muted:       #6b5040;
  --ms-faint:       #a8917c;
  --ms-accent:      #8b5e3c;
  --ms-accent-soft: rgba(139,94,60,0.10);
  --ms-border:      rgba(100,75,50,0.15);
  --ms-border-hi:   rgba(100,75,50,0.28);
  --ms-danger:      #c04040;
  --ms-font-editor: "Lora", Georgia, "Times New Roman", serif;
  --ms-font-ui:     system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --ms-font-mono:   "JetBrains Mono", monospace;
}

/* Manuscript colour tokens — dark (warm literary desk) */
html.dark {
  --ms-bg:          #1a1511;
  --ms-bg-mid:      #201a14;
  --ms-bg-soft:     #231e18;
  --ms-surface:     #2a2218;
  --ms-surface-hi:  #352a1e;
  --ms-text:        #ede5d8;
  --ms-muted:       #b09880;
  --ms-faint:       #7a6855;
  --ms-accent:      #d4ac50;
  --ms-accent-soft: rgba(212,172,80,0.15);
  --ms-border:      rgba(180,155,110,0.22);
  --ms-border-hi:   rgba(180,155,110,0.42);
  --ms-danger:      #d05050;
}

/* Override body for manuscript pages */
main:has(.ms-layout) {
  background: var(--ms-bg);
  overflow: hidden;
}

/* ── Three-panel grid ──────────────────────────────────────────────────────── */
.ms-layout {
  display: flex;
  flex-direction: row;
  height: 100%;
  min-height: 0;
  background: var(--ms-bg);
  color: var(--ms-text);
  font-family: var(--ms-font-ui);
  font-size: 1rem;
}

/* ── Header override for manuscript pages ──────────────────────────────────── */
main:has(.ms-layout) ~ * { display: none; }
body:has(.ms-layout) header {
  background: var(--ms-bg);
  border-bottom-color: var(--ms-border);
}
body:has(.ms-layout) body { background: var(--ms-bg); }
body:has(.ms-layout) .site-name { color: var(--ms-muted); }
body:has(.ms-layout) .site-name:hover { color: var(--ms-accent); }
body:has(.ms-layout) .dark-toggle { color: var(--ms-faint); border-color: var(--ms-border); background: none; }
body:has(.ms-layout) .dark-toggle:hover { color: var(--ms-accent); border-color: var(--ms-accent); }

/* ── LEFT PANEL ────────────────────────────────────────────────────────────── */
.ms-left {
  width: 230px;
  flex-shrink: 0;
  background: var(--ms-bg);
  border-right: 1px solid var(--ms-border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.ms-left-inner {
  flex: 1;
  overflow-y: auto;
  padding: 1rem 0.875rem 2rem;
  scrollbar-width: thin;
  scrollbar-color: var(--ms-border) transparent;
}

.ms-left-inner::-webkit-scrollbar { width: 5px; }
.ms-left-inner::-webkit-scrollbar-thumb { background: var(--ms-border); border-radius: 3px; }

.ms-project-header {
  margin-bottom: 1.25rem;
  padding-bottom: 0.875rem;
  border-bottom: 1px solid var(--ms-border);
}

.ms-project-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--ms-text);
  line-height: 1.3;
  margin-bottom: 0.2rem;
}

.ms-project-type {
  font-size: 0.675rem;
  font-family: var(--ms-font-mono);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ms-accent);
}

.ms-section-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ms-faint);
  margin: 0 0 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.ms-divider {
  height: 1px;
  background: var(--ms-border);
  margin: 1rem 0;
}

/* Chapter list */
.ms-chapter-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 1px;
  margin-bottom: 0.5rem;
}

.ms-chapter-item {
  display: flex;
  align-items: center;
  border-radius: 5px;
  padding: 0.35rem 0.5rem;
  gap: 0.25rem;
  cursor: pointer;
  transition: background 0.12s;
}

.ms-chapter-item:hover { background: var(--ms-surface); }
.ms-chapter-item.active { background: var(--ms-accent-soft); }
.ms-chapter-item.active .ms-chapter-name { color: var(--ms-accent); }

.ms-chapter-name {
  flex: 1;
  min-width: 0;
  font-size: 0.8125rem;
  color: var(--ms-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
}

.ms-chapter-actions {
  display: none;
  align-items: center;
  gap: 1px;
  flex-shrink: 0;
}

.ms-chapter-item:hover .ms-chapter-actions { display: flex; }

.ms-ch-btn {
  background: none;
  border: none;
  color: var(--ms-faint);
  font-size: 0.7rem;
  padding: 2px 4px;
  cursor: pointer;
  border-radius: 3px;
  line-height: 1;
  transition: color 0.12s, background 0.12s;
}

.ms-ch-btn:hover { color: var(--ms-text); background: var(--ms-surface-hi); }
.ms-ch-btn-delete:hover { color: var(--ms-danger); }

.ms-new-chapter-btn {
  width: 100%;
  background: none;
  border: 1px dashed var(--ms-border);
  border-radius: 5px;
  color: var(--ms-faint);
  font-size: 0.775rem;
  padding: 0.35rem 0;
  cursor: pointer;
  transition: border-color 0.12s, color 0.12s;
  font-family: var(--ms-font-ui);
  margin-top: 0.25rem;
}

.ms-new-chapter-btn:hover { border-color: var(--ms-accent); color: var(--ms-accent); }

/* AI panel */
.ms-ai-panel {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ms-select {
  width: 100%;
  font-size: 0.8rem;
  font-family: var(--ms-font-ui);
  background: var(--ms-surface);
  color: var(--ms-text);
  border: 1px solid var(--ms-border);
  border-radius: 5px;
  padding: 0.35em 0.6em;
  cursor: pointer;
  outline: none;
}

.ms-select:focus { border-color: var(--ms-accent); }

.ms-custom-instruction {
  width: 100%;
  font-size: 0.775rem;
  font-family: var(--ms-font-ui);
  background: var(--ms-surface);
  color: var(--ms-text);
  border: 1px solid var(--ms-border);
  border-radius: 5px;
  padding: 0.4em 0.6em;
  resize: vertical;
  outline: none;
  min-height: 2.5rem;
}

.ms-custom-instruction::placeholder { color: var(--ms-faint); }
.ms-custom-instruction:focus { border-color: var(--ms-accent); }

.ms-run-btn {
  width: 100%;
  background: var(--ms-accent-soft);
  border: 1px solid var(--ms-accent);
  color: var(--ms-accent);
  border-radius: 5px;
  font-size: 0.8rem;
  font-family: var(--ms-font-ui);
  padding: 0.4rem 0;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}

.ms-run-btn:hover:not(:disabled) { background: var(--ms-accent); color: var(--ms-bg); }
.ms-run-btn:disabled { opacity: 0.4; cursor: default; }

.ms-ai-status {
  font-size: 0.72rem;
  color: var(--ms-muted);
  min-height: 1rem;
  font-family: var(--ms-font-mono);
}

/* BYOK panel */
.ms-byok-panel {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.ms-input {
  width: 100%;
  font-size: 0.8rem;
  font-family: var(--ms-font-ui);
  background: var(--ms-surface);
  color: var(--ms-text);
  border: 1px solid var(--ms-border);
  border-radius: 5px;
  padding: 0.35em 0.6em;
  outline: none;
}

.ms-input::placeholder { color: var(--ms-faint); }
.ms-input:focus { border-color: var(--ms-accent); }

.ms-validate-btn {
  width: 100%;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  color: var(--ms-muted);
  border-radius: 5px;
  font-size: 0.775rem;
  font-family: var(--ms-font-ui);
  padding: 0.35rem 0;
  cursor: pointer;
  transition: border-color 0.12s, color 0.12s;
}

.ms-validate-btn:hover { border-color: var(--ms-accent); color: var(--ms-accent); }

.ms-byok-status {
  font-size: 0.7rem;
  font-family: var(--ms-font-mono);
  color: var(--ms-muted);
  min-height: 1rem;
}

.ms-byok-status.ok  { color: #5aad5a; }
.ms-byok-status.err { color: #e07070; }

.ms-byok-indicator {
  font-size: 0.75rem;
  cursor: default;
  user-select: none;
  color: var(--ms-faint);
}

.ms-byok-indicator.active { color: #5aad5a; }

.ms-export-link {
  display: block;
  font-size: 0.775rem;
  color: var(--ms-faint);
  text-decoration: none;
  padding: 0.3rem 0;
  transition: color 0.12s;
}

.ms-export-link:hover { color: var(--ms-accent); }

/* Authors list in left panel */
.ms-authors-list {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.ms-author-item {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.4rem;
}

.ms-author-name {
  font-size: 0.775rem;
  color: var(--ms-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.ms-author-code {
  font-family: var(--ms-font-mono);
  font-size: 0.68rem;
  color: var(--ms-faint);
  background: var(--ms-surface);
  padding: 0.05em 0.35em;
  border-radius: 3px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Quote author picker ───────────────────────────────────────────────────── */
.ms-quote-search {
  position: relative;
  margin-bottom: 0.5rem;
  z-index: 300;
}

#qt-author-search {
  width: 100%;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: 5px;
  color: var(--ms-text);
  font-size: 0.82rem;
  padding: 0.35rem 0.55rem;
  outline: none;
  font-family: var(--ms-font-ui);
  box-sizing: border-box;
}

#qt-author-search::placeholder { color: var(--ms-faint); }

#qt-author-search:focus {
  border-color: var(--ms-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--ms-accent) 18%, transparent);
}

.ms-author-hint {
  min-height: 1.2em;
  font-size: 0.75rem;
  color: var(--ms-accent);
  padding: 0.15rem 0.1rem 0;
  letter-spacing: 0.01em;
}

.ms-author-dropdown {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  right: 0;
  background: var(--ms-bg-mid, #201a14);
  border: 1px solid var(--ms-border-hi);
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.55);
  max-height: 220px;
  overflow-y: auto;
  z-index: 400;
}

.ms-author-dropdown-item {
  padding: 0.4rem 0.65rem;
  font-size: 0.82rem;
  color: var(--ms-muted);
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ms-author-dropdown-item:hover,
.ms-author-dropdown-item.active {
  background: var(--ms-accent-soft);
  color: var(--ms-accent);
}

.ms-author-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-bottom: 0.4rem;
}

.ms-author-chip {
  font-size: 0.7rem;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: 20px;
  color: var(--ms-muted);
  padding: 0.15em 0.6em;
  cursor: pointer;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
  white-space: nowrap;
  user-select: none;
}

.ms-author-chip:hover {
  background: var(--ms-accent-soft);
  border-color: var(--ms-accent);
  color: var(--ms-accent);
}

.ms-influences {
  margin-top: 0.5rem;
  padding: 0.5rem 0.6rem;
  background: var(--ms-surface);
  border-radius: 5px;
  border: 1px solid var(--ms-border);
}
.ms-influences-label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--ms-faint);
  margin-bottom: 0.35rem;
}
.ms-influences-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 0.4rem;
}
.ms-infl-chip {
  font-size: 0.72rem;
  padding: 2px 7px;
  border-radius: 3px;
  background: var(--ms-bg-mid, #201a14);
  border: 1px solid var(--ms-border);
  color: var(--ms-muted);
  cursor: pointer;
  white-space: nowrap;
}
.ms-infl-chip:hover { color: var(--ms-text); border-color: var(--ms-accent); }
.ms-infl-chip.indexed { color: var(--ms-accent); }
.ms-influences-graph-link {
  font-size: 0.7rem;
  color: var(--ms-faint);
  text-decoration: none;
  display: block;
  margin-top: 0.2rem;
}
.ms-influences-graph-link:hover { color: var(--ms-accent); }

.ms-oxford-hint {
  margin-top: 0.6rem;
  font-size: 0.7rem;
  color: var(--ms-faint);
  line-height: 1.5;
}

.ms-oxford-hint code {
  font-family: var(--ms-font-mono);
  font-size: 0.85em;
  color: var(--ms-muted);
  background: var(--ms-surface);
  padding: 0.05em 0.3em;
  border-radius: 3px;
}

/* ── CENTER PANEL ──────────────────────────────────────────────────────────── */
.ms-center {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  background: var(--ms-bg-soft);
  overflow: hidden;
}

.ms-chapter-strip {
  display: flex;
  align-items: center;
  padding: 0.5rem 2rem 0.5rem 2.5rem;
  background: var(--ms-bg);
  border-bottom: 1px solid var(--ms-border);
  gap: 1rem;
  flex-shrink: 0;
}

.ms-chapter-strip-title {
  font-size: 0.775rem;
  font-family: var(--ms-font-mono);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--ms-muted);
}

.ms-save-indicator {
  font-size: 0.7rem;
  font-family: var(--ms-font-mono);
  color: var(--ms-faint);
  min-width: 4rem;
  text-align: right;
}

.ms-save-indicator.saving { color: var(--ms-muted); }
.ms-save-indicator.saved  { color: #5aad5a; }
.ms-save-indicator.error  { color: #e07070; }

.ms-sound-toggle {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.68rem;
  font-family: var(--ms-font-mono);
  color: var(--ms-faint);
  cursor: pointer;
  user-select: none;
  margin-left: auto;
}

.ms-sound-toggle input { cursor: pointer; accent-color: var(--ms-accent); }

.ms-editor {
  flex: 1;
  min-height: 0;
  width: 100%;
  padding: 2.5rem 3.5rem 2rem 4rem;
  font-family: var(--ms-font-editor);
  font-size: 1.0625rem;
  line-height: 1.85;
  color: var(--ms-text);
  background: transparent;
  border: none;
  outline: none;
  resize: none;
  scrollbar-width: thin;
  scrollbar-color: var(--ms-border) transparent;
}

.ms-editor::-webkit-scrollbar { width: 6px; }
.ms-editor::-webkit-scrollbar-thumb { background: var(--ms-border); border-radius: 3px; }
.ms-editor::placeholder { color: var(--ms-faint); font-style: italic; }

/* ── Command zone ────────────────────────────────────────────────────────────── */
.ms-command-output {
  flex-shrink: 0;
  max-height: 220px;
  overflow-y: auto;
  background: var(--ms-surface);
  border-top: 1px solid var(--ms-border);
  position: relative;
  scrollbar-width: thin;
  scrollbar-color: var(--ms-border) transparent;
}

.ms-command-output::-webkit-scrollbar { width: 5px; }
.ms-command-output::-webkit-scrollbar-thumb { background: var(--ms-border); border-radius: 3px; }

.ms-command-text {
  font-family: var(--ms-font-mono);
  font-size: 0.8rem;
  line-height: 1.65;
  color: var(--ms-text);
  white-space: pre-wrap;
  word-break: break-word;
  padding: 0.75rem 4rem 0.75rem 4rem;
  margin: 0;
  border-left: 3px solid var(--ms-accent);
}

.ms-command-text.is-error { border-left-color: var(--ms-danger); color: #e07070; }

.ms-command-dismiss {
  position: absolute;
  top: 0.4rem;
  right: 0.6rem;
  background: none;
  border: none;
  color: var(--ms-faint);
  font-size: 0.9rem;
  cursor: pointer;
  padding: 2px 4px;
  line-height: 1;
  transition: color 0.1s;
}

.ms-command-dismiss:hover { color: var(--ms-text); }

.ms-command-zone {
  flex-shrink: 0;
  background: var(--ms-bg);
  border-top: 1px solid var(--ms-border);
  padding: 0.5rem 4rem 0.4rem;
}

.ms-command-form {
  display: flex;
  gap: 0.4rem;
  align-items: center;
}

.ms-command-input {
  flex: 1;
  font-family: var(--ms-font-mono);
  font-size: 0.8125rem;
  background: var(--ms-surface);
  color: var(--ms-text);
  border: 1px solid var(--ms-border);
  border-radius: 4px;
  padding: 0.35em 0.7em;
  outline: none;
  transition: border-color 0.12s;
}

.ms-command-input::placeholder { color: var(--ms-faint); }
.ms-command-input:focus { border-color: var(--ms-accent); }

.ms-command-run {
  font-family: var(--ms-font-mono);
  font-size: 0.775rem;
  padding: 0.35em 0.85em;
  background: var(--ms-surface);
  color: var(--ms-muted);
  border: 1px solid var(--ms-border);
  border-radius: 4px;
  cursor: pointer;
  transition: border-color 0.12s, color 0.12s;
  white-space: nowrap;
}

.ms-command-run:hover { border-color: var(--ms-accent); color: var(--ms-accent); }
.ms-command-run:disabled { opacity: 0.4; cursor: default; }

.ms-command-ref {
  font-size: 0.67rem;
  font-family: var(--ms-font-mono);
  color: var(--ms-faint);
  padding-top: 0.3rem;
  line-height: 2;
  display: flex;
  flex-wrap: wrap;
  gap: 0 0.5rem;
  align-items: baseline;
}

.ms-cmd-group { white-space: nowrap; }

.ms-cmd-sep {
  color: var(--ms-border-hi);
  font-size: 0.75rem;
  line-height: 2;
}

.ms-command-ref code {
  color: var(--ms-muted);
  background: var(--ms-surface);
  padding: 0.05em 0.3em;
  border-radius: 3px;
  font-size: 0.9em;
}

.ms-editor-footer {
  padding: 0.35rem 2.5rem 0.35rem 4rem;
  background: var(--ms-bg);
  border-top: 1px solid var(--ms-border);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.ms-wordcount {
  font-size: 0.68rem;
  font-family: var(--ms-font-mono);
  color: var(--ms-faint);
}

/* ── RIGHT PANEL ───────────────────────────────────────────────────────────── */
.ms-right {
  width: 310px;
  flex-shrink: 0;
  background: var(--ms-bg);
  border-left: 1px solid var(--ms-border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.ms-memory-tabs {
  display: flex;
  border-bottom: 1px solid var(--ms-border);
  flex-shrink: 0;
}

.ms-tab {
  flex: 1;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--ms-faint);
  font-size: 0.67rem;
  font-family: var(--ms-font-ui);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 0.6rem 0.2rem;
  white-space: nowrap;
  cursor: pointer;
  transition: color 0.12s, border-color 0.12s;
  margin-bottom: -1px;
}

.ms-tab:hover { color: var(--ms-muted); }
.ms-tab.active { color: var(--ms-accent); border-bottom-color: var(--ms-accent); }

.ms-tab-panel {
  display: none;
  flex: 1;
  overflow-y: auto;
  padding: 0.875rem;
  scrollbar-width: thin;
  scrollbar-color: var(--ms-border) transparent;
}

.ms-tab-panel.active { display: flex; flex-direction: column; }
.ms-tab-panel::-webkit-scrollbar { width: 5px; }
.ms-tab-panel::-webkit-scrollbar-thumb { background: var(--ms-border); border-radius: 3px; }

.ms-memory-list {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.ms-memory-item {
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: 6px;
  padding: 0.6rem 0.75rem;
}

.ms-memory-item-header {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  margin-bottom: 0.3rem;
}

.ms-memory-name {
  flex: 1;
  font-size: 0.8125rem;
  color: var(--ms-text);
  line-height: 1.3;
}

.ms-memory-role {
  font-size: 0.65rem;
  font-family: var(--ms-font-mono);
  color: var(--ms-accent);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  flex-shrink: 0;
  padding-top: 0.1rem;
}

.ms-memory-delete {
  background: none;
  border: none;
  color: var(--ms-faint);
  font-size: 0.85rem;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  flex-shrink: 0;
  transition: color 0.12s;
}

.ms-memory-delete:hover { color: var(--ms-danger); }

.ms-memory-desc {
  font-size: 0.775rem;
  color: var(--ms-muted);
  line-height: 1.5;
  margin-bottom: 0.2rem;
}

.ms-memory-notes {
  font-size: 0.725rem;
  color: var(--ms-faint);
  font-style: italic;
  line-height: 1.4;
}

.ms-memory-empty {
  font-size: 0.8rem;
  color: var(--ms-faint);
  font-style: italic;
  padding: 0.5rem 0;
}

.ms-memory-add-btn {
  width: 100%;
  margin-top: 0.625rem;
  background: none;
  border: 1px dashed var(--ms-border);
  border-radius: 5px;
  color: var(--ms-faint);
  font-size: 0.775rem;
  font-family: var(--ms-font-ui);
  padding: 0.35rem 0;
  cursor: pointer;
  transition: border-color 0.12s, color 0.12s;
  flex-shrink: 0;
}

.ms-memory-add-btn:hover { border-color: var(--ms-accent); color: var(--ms-accent); }

/* ── Modal ─────────────────────────────────────────────────────────────────── */
.ms-modal {
  background: var(--ms-surface);
  color: var(--ms-text);
  border: 1px solid var(--ms-border-hi);
  border-radius: 10px;
  padding: 0;
  max-width: 480px;
  width: 90vw;
  box-shadow: 0 8px 40px rgba(0,0,0,0.6);
}

.ms-modal::backdrop { background: rgba(0,0,0,0.55); }

.ms-modal-inner { padding: 1.5rem; }

.ms-modal-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--ms-accent);
  font-family: var(--ms-font-mono);
  margin-bottom: 1rem;
  letter-spacing: 0.04em;
}

.ms-modal-field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin-bottom: 0.75rem;
}

.ms-modal-label {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--ms-faint);
}

.ms-modal-input,
.ms-modal-textarea {
  width: 100%;
  font-size: 0.875rem;
  font-family: var(--ms-font-ui);
  background: var(--ms-bg-mid);
  color: var(--ms-text);
  border: 1px solid var(--ms-border);
  border-radius: 5px;
  padding: 0.45em 0.7em;
  outline: none;
  transition: border-color 0.12s;
}

.ms-modal-input:focus,
.ms-modal-textarea:focus { border-color: var(--ms-accent); }

.ms-modal-textarea { resize: vertical; min-height: 4rem; }

.ms-modal-actions {
  display: flex;
  gap: 0.6rem;
  margin-top: 1.25rem;
}

.ms-modal-save {
  padding: 0.45rem 1.25rem;
  background: var(--ms-accent);
  color: var(--ms-bg);
  border: none;
  border-radius: 5px;
  font-size: 0.875rem;
  font-weight: 600;
  font-family: var(--ms-font-ui);
  cursor: pointer;
  transition: opacity 0.15s;
}

.ms-modal-save:hover { opacity: 0.88; }

.ms-modal-cancel {
  padding: 0.45rem 1rem;
  background: none;
  border: 1px solid var(--ms-border);
  border-radius: 5px;
  font-size: 0.875rem;
  font-family: var(--ms-font-ui);
  color: var(--ms-muted);
  cursor: pointer;
  transition: border-color 0.12s, color 0.12s;
}

.ms-modal-cancel:hover { border-color: var(--ms-border-hi); color: var(--ms-text); }

/* ── AI result modal (Phase 1C) ──────────────────────────────────────────────── */
.ms-ai-modal {
  background: var(--ms-surface);
  color: var(--ms-text);
  border: 1px solid var(--ms-border-hi);
  border-radius: 10px;
  padding: 0;
  width: 92vw;
  max-width: 960px;
  max-height: 88vh;
  box-shadow: 0 8px 48px rgba(0,0,0,0.55);
}

/* Only apply flex layout when the dialog is actually open */
.ms-ai-modal[open] {
  display: flex;
  flex-direction: column;
}

.ms-ai-modal::backdrop { background: rgba(0,0,0,0.55); }

.ms-ai-modal-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

/* Header */
.ms-ai-modal-header {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.25rem 0.75rem;
  border-bottom: 1px solid var(--ms-border);
  flex-shrink: 0;
}

.ms-ai-modal-title {
  font-size: 0.875rem;
  font-weight: 600;
  font-family: var(--ms-font-mono);
  color: var(--ms-accent);
  letter-spacing: 0.04em;
  flex: 1;
  min-width: 0;
}

.ms-ai-modal-context {
  font-size: 0.7rem;
  font-family: var(--ms-font-mono);
  color: var(--ms-muted);
  line-height: 1.6;
  flex: 1;
  min-width: 0;
}

.ms-ai-modal-context span {
  display: inline-block;
  margin-right: 0.75rem;
  white-space: nowrap;
}

.ms-ai-modal-close {
  background: none;
  border: none;
  color: var(--ms-faint);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
  flex-shrink: 0;
  transition: color 0.1s;
}

.ms-ai-modal-close:hover { color: var(--ms-text); }

/* Bodies */
.ms-ai-body {
  flex: 1;
  min-height: 0;
  display: flex;
  overflow: hidden;
}

.ms-ai-preview-body {
  gap: 0;
}

.ms-ai-report-body {
  padding: 0;
}

.ms-ai-col {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--ms-border);
}

.ms-ai-col:last-child { border-right: none; }

.ms-ai-col-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ms-faint);
  padding: 0.5rem 1rem 0.35rem;
  border-bottom: 1px solid var(--ms-border);
  flex-shrink: 0;
}

.ms-ai-text {
  flex: 1;
  min-height: 0;
  width: 100%;
  font-family: var(--ms-font-editor);
  font-size: 0.9rem;
  line-height: 1.75;
  background: var(--ms-bg-soft);
  color: var(--ms-text);
  border: none;
  padding: 1rem 1.25rem;
  resize: none;
  outline: none;
  scrollbar-width: thin;
  scrollbar-color: var(--ms-border) transparent;
}

.ms-ai-report-text {
  background: var(--ms-bg-mid);
  font-family: var(--ms-font-mono);
  font-size: 0.825rem;
  line-height: 1.7;
  padding: 1rem 1.5rem;
  white-space: pre-wrap;
}

/* Footer */
.ms-ai-modal-footer {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.75rem 1.25rem;
  border-top: 1px solid var(--ms-border);
  flex-shrink: 0;
}

.ms-ai-btn {
  padding: 0.4rem 1.1rem;
  border-radius: 5px;
  font-size: 0.8125rem;
  font-family: var(--ms-font-ui);
  cursor: pointer;
  transition: opacity 0.15s, border-color 0.12s, color 0.12s;
  border: 1px solid var(--ms-border);
  background: none;
  color: var(--ms-muted);
}

.ms-ai-btn:hover { border-color: var(--ms-border-hi); color: var(--ms-text); }

.ms-ai-btn-primary {
  background: var(--ms-accent);
  color: var(--ms-bg);
  border-color: transparent;
  font-weight: 600;
}

.ms-ai-btn-primary:hover { opacity: 0.88; color: var(--ms-bg); }

.ms-ai-saved-badge {
  font-size: 0.75rem;
  font-family: var(--ms-font-mono);
  color: #5aad5a;
  margin-left: auto;
}

/* ── Panel header with help icon ─────────────────────────────────────────────── */
.ms-panel-header {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.5rem 0 0.4rem;
  margin-bottom: 0.25rem;
  border-bottom: 1px solid var(--ms-border);
  flex-shrink: 0;
}

.ms-panel-header-title {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ms-faint);
  flex: 1;
}

.ms-help-btn {
  background: none;
  border: 1px solid var(--ms-border);
  border-radius: 50%;
  width: 1.1rem;
  height: 1.1rem;
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--ms-faint);
  cursor: pointer;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: color 0.12s, border-color 0.12s;
  position: relative;
}

.ms-help-btn:hover { color: #9b72e8; border-color: #9b72e8; }

/* Floating tooltip bubble — purple border, position: fixed via JS */
.ms-tooltip-bubble {
  position: fixed;
  z-index: 9999;
  width: 240px;
  background: var(--ms-surface);
  border: 1.5px solid #9b72e8;
  border-radius: 8px;
  padding: 0.65rem 0.85rem;
  font-size: 0.75rem;
  font-family: var(--ms-font-ui);
  font-weight: 400;
  line-height: 1.55;
  color: var(--ms-text);
  box-shadow: 0 4px 20px rgba(155,114,232,0.2), 0 2px 10px rgba(0,0,0,0.35);
  pointer-events: none;
}

.ms-tooltip-bubble::before {
  content: "";
  position: absolute;
  right: 0.65rem;
  top: -5px;
  width: 8px;
  height: 8px;
  background: var(--ms-surface);
  border-left: 1.5px solid #9b72e8;
  border-top: 1.5px solid #9b72e8;
  transform: rotate(45deg);
}

/* ── Export tab panel ────────────────────────────────────────────────────────── */
.ms-export-ui {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  padding-top: 0.25rem;
}

.ms-export-group-label {
  font-size: 0.63rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ms-faint);
  margin-top: 0.6rem;
  margin-bottom: 0.15rem;
}

.ms-export-group-label:first-child { margin-top: 0; }

.ms-export-check,
.ms-export-radio {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.8rem;
  color: var(--ms-muted);
  cursor: pointer;
  padding: 0.1rem 0;
}

.ms-export-check input,
.ms-export-radio input {
  accent-color: var(--ms-accent);
  cursor: pointer;
  flex-shrink: 0;
}

.ms-export-run-btn {
  margin-top: 0.75rem;
  width: 100%;
  padding: 0.45rem 0;
  background: var(--ms-accent);
  color: var(--ms-bg);
  border: none;
  border-radius: 5px;
  font-size: 0.8125rem;
  font-weight: 600;
  font-family: var(--ms-font-ui);
  cursor: pointer;
  transition: opacity 0.15s;
}

.ms-export-run-btn:hover   { opacity: 0.88; }
.ms-export-run-btn:disabled { opacity: 0.4; cursor: default; }

.ms-export-status {
  font-size: 0.72rem;
  font-family: var(--ms-font-mono);
  color: var(--ms-muted);
  min-height: 1.2rem;
  padding-top: 0.2rem;
}

.ms-export-status.err { color: var(--ms-danger); }
.ms-export-status.ok  { color: #5aad5a; }

.ms-export-note {
  font-size: 0.68rem;
  color: var(--ms-faint);
  line-height: 1.4;
  margin-top: 0.25rem;
}

.ms-cmd-help-btn {
  margin-left: auto;
  vertical-align: middle;
}

/* ── Custom action picker ────────────────────────────────────────────────────── */
.ms-picker {
  position: relative;
}

.ms-picker-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem;
  font-size: 0.8rem;
  font-family: var(--ms-font-ui);
  background: var(--ms-surface);
  color: var(--ms-text);
  border: 1px solid var(--ms-border);
  border-radius: 5px;
  padding: 0.35em 0.6em;
  cursor: pointer;
  text-align: left;
  outline: none;
  transition: border-color 0.12s;
}

.ms-picker-trigger:hover,
.ms-picker-trigger:focus { border-color: var(--ms-accent); }

.ms-picker-arrow {
  color: var(--ms-faint);
  font-size: 0.7rem;
  flex-shrink: 0;
  pointer-events: none;
}

.ms-picker-dropdown {
  position: fixed;
  z-index: 8888;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border-hi);
  border-radius: 6px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.35);
  overflow-y: auto;
  max-height: 320px;
  padding: 0.25rem 0;
}

.ms-picker-group-label {
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ms-faint);
  padding: 0.5rem 0.75rem 0.2rem;
}

.ms-picker-option {
  display: block;
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  font-size: 0.8rem;
  font-family: var(--ms-font-ui);
  color: var(--ms-muted);
  padding: 0.3rem 0.75rem;
  cursor: pointer;
  transition: background 0.1s, color 0.1s;
}

.ms-picker-option:hover  { background: var(--ms-surface-hi); color: var(--ms-text); }
.ms-picker-option.active { color: var(--ms-accent); font-weight: 500; }

/* ── Memory status panel (left panel) ───────────────────────────────────────── */
.ms-memory-status-panel {
  margin: 0.5rem 0 0.25rem;
}

.ms-status-chapter-name {
  font-size: 0.75rem;
  color: var(--ms-muted);
  margin-bottom: 0.4rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ms-refresh-memory-btn {
  width: 100%;
  background: none;
  border: 1px solid var(--ms-border);
  border-radius: 5px;
  color: var(--ms-muted);
  font-size: 0.73rem;
  font-family: var(--ms-font-ui);
  padding: 0.3rem 0;
  cursor: pointer;
  transition: border-color 0.12s, color 0.12s;
  margin-bottom: 0.4rem;
}

.ms-refresh-memory-btn:hover:not(:disabled) { border-color: var(--ms-accent); color: var(--ms-accent); }
.ms-refresh-memory-btn:disabled { opacity: 0.4; cursor: default; }

.ms-status-badges {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.ms-status-badge {
  display: inline-block;
  font-size: 0.63rem;
  font-family: var(--ms-font-mono);
  padding: 0.1em 0.4em;
  border-radius: 3px;
  width: fit-content;
}

.ms-status-current { color: #5aad5a; background: rgba(90,173,90,0.10); }
.ms-status-stale   { color: #c09040; background: rgba(192,144,64,0.10); }
.ms-status-missing { color: var(--ms-faint); background: var(--ms-surface); }
.ms-status-pending { color: #9b72e8; background: rgba(155,114,232,0.12); }

/* ── Suggestions panel (right panel tabs) ────────────────────────────────────── */
.ms-suggestions-panel {
  margin-top: 0.625rem;
  border-top: 1px solid var(--ms-border);
  padding-top: 0.5rem;
  flex-shrink: 0;
}

.ms-suggestions-divider {
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #9b72e8;
  margin-bottom: 0.35rem;
}

.ms-suggestion-item {
  background: var(--ms-surface);
  border: 1px solid rgba(155,114,232,0.22);
  border-radius: 5px;
  padding: 0.4rem 0.5rem;
  margin-bottom: 0.3rem;
}

.ms-suggestion-name {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--ms-text);
  display: block;
}

.ms-suggestion-ctx {
  font-size: 0.7rem;
  color: var(--ms-faint);
  font-style: italic;
  display: block;
  margin-top: 0.1rem;
  line-height: 1.4;
}

.ms-suggestion-actions {
  display: flex;
  gap: 0.3rem;
  margin-top: 0.3rem;
}

.ms-suggestion-add,
.ms-suggestion-dismiss {
  font-size: 0.7rem;
  font-family: var(--ms-font-ui);
  padding: 0.15em 0.55em;
  border-radius: 3px;
  cursor: pointer;
  transition: background 0.1s, color 0.1s;
  border: 1px solid;
}

.ms-suggestion-add {
  background: rgba(155,114,232,0.12);
  color: #9b72e8;
  border-color: rgba(155,114,232,0.3);
}

.ms-suggestion-add:hover { background: #9b72e8; color: #fff; }

.ms-suggestion-dismiss {
  background: none;
  color: var(--ms-faint);
  border-color: var(--ms-border);
}

.ms-suggestion-dismiss:hover { color: var(--ms-text); border-color: var(--ms-border-hi); }

/* ── Disabled project link (home page) ──────────────────────────────────────── */
.project-link-disabled {
  opacity: 0.45;
  cursor: default;
  pointer-events: none;
  user-select: none;
}

/* ── Token entry row (home page) ─────────────────────────────────────────────── */
.token-entry-row {
  margin: 0.75rem 0 0.5rem;
}

.token-entry-form {
  display: flex;
  gap: 0.4rem;
}

.token-entry-input {
  flex: 1;
  font-family: var(--mono);
  font-size: 0.8125rem;
  padding: 0.5em 0.75em;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text);
  outline: none;
  transition: border-color 0.15s;
}

.token-entry-input::placeholder { color: var(--muted); }
.token-entry-input:focus { border-color: var(--accent); }

.token-entry-btn {
  padding: 0.5em 1em;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 0.8125rem;
  font-family: var(--font);
  color: var(--muted);
  cursor: pointer;
  white-space: nowrap;
  transition: border-color 0.15s, color 0.15s;
}

.token-entry-btn:hover { border-color: var(--accent); color: var(--accent); }

/* ── Activate page ───────────────────────────────────────────────────────────── */
.activate-error {
  background: #fef2f2;
  border: 1px solid #fca5a5;
  color: #b91c1c;
  border-radius: 6px;
  padding: 0.6rem 0.875rem;
  font-size: 0.875rem;
  margin-bottom: 1rem;
}

html.dark .activate-error {
  background: #2a1010;
  border-color: #c04040;
  color: #f87171;
}

.activate-form {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 1.25rem;
}

.activate-input {
  font-family: var(--mono);
  font-size: 0.9rem;
  padding: 0.65em 0.875em;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text);
  outline: none;
  transition: border-color 0.15s;
}

.activate-input::placeholder { color: var(--muted); }
.activate-input:focus { border-color: var(--accent); }

.activate-btn {
  padding: 0.6em 1.5em;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  transition: background 0.15s;
  align-self: flex-start;
}

.activate-btn:hover { background: var(--accent-hov); }

.activate-hint {
  font-size: 0.8375rem;
  color: var(--muted);
  line-height: 1.6;
}

.activate-hint a { color: var(--accent); }

/* ── Beta request form (home page / writers callout) ─────────────────────────── */
.beta-request-toggle {
  margin-top: 0.75rem;
  background: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0.4em 0.9em;
  font-size: 0.8125rem;
  font-family: var(--font);
  color: var(--accent);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.beta-request-toggle:hover { background: var(--badge-bg); border-color: var(--accent); }

.beta-request-form-wrap {
  margin-top: 0.75rem;
}

.beta-request-form {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.beta-hp {
  position: absolute;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
  tab-index: -1;
}

.beta-email-input,
.beta-notes-input {
  font-family: var(--font);
  font-size: 0.875rem;
  padding: 0.5em 0.75em;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text);
  outline: none;
  width: 100%;
  transition: border-color 0.15s;
}

.beta-email-input::placeholder,
.beta-notes-input::placeholder { color: var(--muted); }

.beta-email-input:focus,
.beta-notes-input:focus { border-color: var(--accent); }

.beta-notes-input { resize: vertical; min-height: 3.5rem; }

.beta-form-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.beta-submit-btn {
  padding: 0.45em 1.25em;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 0.875rem;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  transition: background 0.15s;
  white-space: nowrap;
}

.beta-submit-btn:hover:not(:disabled) { background: var(--accent-hov); }
.beta-submit-btn:disabled { opacity: 0.5; cursor: default; }

.beta-form-status {
  font-size: 0.8rem;
  color: var(--muted);
}

.beta-success {
  font-size: 0.875rem;
  color: #267326;
  margin: 0;
  padding: 0.5rem 0;
}

html.dark .beta-success { color: #5aad5a; }

/* Beta confirmed page */
.beta-confirmed-box {
  padding: 1.25rem 1.5rem;
  border-radius: 8px;
  border: 1px solid;
  font-size: 0.9375rem;
  line-height: 1.65;
}

.beta-confirmed-box p { margin: 0 0 0.6rem; }
.beta-confirmed-box p:last-child { margin: 0; }
.beta-confirmed-box a { color: var(--accent); }

.beta-confirmed-ok  { background: #f0faf0; border-color: #a3d9a3; color: #1a4a1a; }
.beta-confirmed-err { background: #fef2f2; border-color: #fca5a5; color: #7f1d1d; }

html.dark .beta-confirmed-ok  { background: #0f2010; border-color: #3a7a3a; color: #a3d9a3; }
html.dark .beta-confirmed-err { background: #2a1010; border-color: #c04040; color: #f87171; }
