:root {
  --bg: #f7f3ed;
  --surface: #fffdfa;
  --surface-2: #f1ece4;
  --border: rgba(22, 19, 14, 0.08);
  --text: #191612;
  --muted: #6e665d;
  --accent: #7f77dd;
  --accent-dark: #4d459f;
  --green: #2f7a24;
  --amber: #aa6a12;
  --red: #a32d2d;
  --radius: 18px;
  --radius-small: 10px;
  --shadow: 0 18px 60px rgba(58, 46, 26, 0.08);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background:
    radial-gradient(circle at top left, rgba(127, 119, 221, 0.12), transparent 28%),
    radial-gradient(circle at top right, rgba(29, 158, 117, 0.1), transparent 26%),
    var(--bg);
  color: var(--text);
  font-family: "DM Sans", sans-serif;
}
.hero { padding: 3.5rem 1.25rem 2.5rem; }
.hero-inner, .page { max-width: 980px; margin: 0 auto; }
.eyebrow { margin: 0 0 0.65rem; color: var(--accent-dark); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.78rem; font-weight: 700; }
h1, h2, h3 { margin: 0; }
h1 { font-family: "DM Serif Display", serif; font-size: clamp(2.25rem, 5vw, 3.8rem); line-height: 1.02; letter-spacing: -0.03em; }
.hero-copy, .muted, .status, .session-meta, label span, .symptom-copy, .substances-label, .result-copy, .recommendation-meta, .empty-state { color: var(--muted); }
.hero-copy { max-width: 700px; margin-top: 0.9rem; line-height: 1.6; font-size: 1rem; }
.page { padding: 0 1.25rem 4rem; }
.panel { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); padding: 1.4rem; margin-bottom: 1rem; }
.panel-intro { display: grid; gap: 1rem; }
.panel-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 1rem; }
.panel-actions, .gate-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.admin-toolbar, .admin-summary { display: grid; gap: 0.9rem; }
.admin-toolbar { grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr) auto; align-items: end; margin-bottom: 1rem; }
.admin-summary { grid-template-columns: repeat(4, minmax(0, 1fr)); margin-bottom: 1rem; }
.config-grid, .form-grid { display: grid; gap: 0.9rem; }
.config-grid { grid-template-columns: minmax(0, 1fr) auto; align-items: end; }
.form-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
label { display: flex; flex-direction: column; gap: 0.4rem; }
label span { font-size: 0.86rem; font-weight: 500; }
input[type="text"], input[type="email"], input[type="url"], input[type="date"] { width: 100%; border: 1px solid rgba(25, 22, 18, 0.14); border-radius: var(--radius-small); background: white; font: inherit; color: var(--text); padding: 0.85rem 0.95rem; }
input[type="range"] { width: 100%; accent-color: var(--accent); }
.btn { border: 0; border-radius: 999px; padding: 0.8rem 1.15rem; font: inherit; font-weight: 700; cursor: pointer; }
a.btn { display: inline-flex; align-items: center; justify-content: center; text-decoration: none; }
.btn-primary { background: var(--accent); color: white; }
.btn-primary:hover { background: var(--accent-dark); }
.btn-secondary { background: var(--surface-2); color: var(--text); }
.hero-admin { padding-bottom: 1.5rem; }
.page-admin { max-width: 1040px; }
.status, .session-meta { font-size: 0.95rem; }
.status.error { color: var(--red); }
.status.success, .session-meta.success { color: var(--green); }
.sections { display: grid; gap: 0.95rem; }
.section-card { border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.section-header { display: flex; justify-content: space-between; gap: 1rem; align-items: center; padding: 1rem 1.1rem; background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(241, 236, 228, 0.85)); }
.section-title-group { display: flex; flex-direction: column; gap: 0.3rem; }
.badge { display: inline-flex; align-items: center; width: fit-content; border-radius: 999px; padding: 0.28rem 0.65rem; font-size: 0.75rem; font-weight: 700; background: rgba(127, 119, 221, 0.14); color: var(--accent-dark); }
.section-score { min-width: 90px; text-align: center; border-radius: 999px; padding: 0.45rem 0.8rem; background: rgba(25, 22, 18, 0.06); color: var(--muted); font-size: 0.87rem; font-weight: 700; }
.section-score.low { background: rgba(47, 122, 36, 0.12); color: var(--green); }
.section-score.moderate { background: rgba(170, 106, 18, 0.14); color: var(--amber); }
.section-score.high { background: rgba(163, 45, 45, 0.12); color: var(--red); }
.section-body { padding: 0 1.1rem 1.1rem; }
.symptom-row { display: grid; grid-template-columns: minmax(0, 1fr) 170px 36px; gap: 0.8rem; align-items: center; padding: 0.85rem 0; border-bottom: 1px solid rgba(25, 22, 18, 0.06); }
.symptom-row:last-of-type { border-bottom: 0; }
.score-pill { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 999px; background: rgba(25, 22, 18, 0.06); color: var(--muted); font-weight: 700; }
.score-pill.low { background: rgba(47, 122, 36, 0.12); color: var(--green); }
.score-pill.mid { background: rgba(170, 106, 18, 0.14); color: var(--amber); }
.score-pill.high { background: rgba(163, 45, 45, 0.12); color: var(--red); }
.substances { margin-top: 0.85rem; }
.substances-label { margin-bottom: 0.6rem; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.substances-list { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.substance-chip { border: 1px solid rgba(25, 22, 18, 0.1); border-radius: 999px; padding: 0.5rem 0.8rem; background: white; font: inherit; color: var(--muted); cursor: pointer; }
.substance-chip.active { background: rgba(127, 119, 221, 0.12); border-color: rgba(127, 119, 221, 0.45); color: var(--accent-dark); }
.ranked-results { display: grid; gap: 0.75rem; margin-bottom: 1rem; }
.ranked-card, .recommendation-card { border: 1px solid var(--border); border-radius: var(--radius-small); background: white; padding: 0.95rem 1rem; }
.ranked-top, .recommendation-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.75rem; }
.result-score, .priority-pill { border-radius: 999px; padding: 0.38rem 0.7rem; font-size: 0.82rem; font-weight: 700; }
.priority-pill.p1, .result-score.high { background: rgba(163, 45, 45, 0.12); color: var(--red); }
.priority-pill.p2, .result-score.moderate { background: rgba(170, 106, 18, 0.14); color: var(--amber); }
.priority-pill.p3, .result-score.low { background: rgba(47, 122, 36, 0.12); color: var(--green); }
.result-score.none { background: rgba(25, 22, 18, 0.06); color: var(--muted); }
.chart-shell { border: 1px solid var(--border); border-radius: var(--radius-small); background: white; padding: 1rem; margin-bottom: 1rem; }
#results-chart { width: 100%; display: block; }
.recommendation-list { display: grid; gap: 0.75rem; }
.report-meta { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.75rem; margin-bottom: 1rem; }
.report-meta-card { border: 1px solid var(--border); border-radius: var(--radius-small); background: white; padding: 0.85rem 0.95rem; }
.report-meta-card strong { display: block; margin-bottom: 0.25rem; font-size: 0.82rem; color: var(--muted); }
.summary-card, .admin-card { border: 1px solid var(--border); border-radius: var(--radius-small); background: white; }
.summary-card { padding: 0.9rem 1rem; }
.summary-card strong { display: block; font-size: 1.55rem; font-family: "DM Serif Display", serif; }
.summary-card span { font-size: 0.86rem; color: var(--muted); }
.admin-queue { display: grid; gap: 0.75rem; }
.admin-card { padding: 1rem; }
.admin-card-top, .admin-card-meta, .admin-card-actions { display: flex; gap: 0.75rem; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; }
.admin-card-meta { margin-top: 0.8rem; }
.admin-card-meta .meta-block { min-width: 150px; }
.admin-card-meta strong, .admin-card-actions strong { display: block; font-size: 0.82rem; color: var(--muted); margin-bottom: 0.2rem; }
.admin-tag-list, .result-preview-list { display: flex; gap: 0.45rem; flex-wrap: wrap; margin-top: 0.75rem; }
.admin-tag { display: inline-flex; align-items: center; border-radius: 999px; padding: 0.36rem 0.7rem; font-size: 0.8rem; font-weight: 700; background: rgba(25, 22, 18, 0.06); color: var(--muted); }
.admin-tag.ready { background: rgba(47, 122, 36, 0.12); color: var(--green); }
.admin-tag.pending { background: rgba(170, 106, 18, 0.14); color: var(--amber); }
.admin-tag.sent { background: rgba(47, 122, 36, 0.12); color: var(--green); }
.admin-tag.locked { background: rgba(163, 45, 45, 0.12); color: var(--red); }
.result-preview-chip { display: inline-flex; align-items: center; border-radius: 999px; padding: 0.35rem 0.65rem; font-size: 0.8rem; background: rgba(127, 119, 221, 0.1); color: var(--accent-dark); }
.admin-card textarea { width: 100%; min-height: 74px; border: 1px solid rgba(25, 22, 18, 0.14); border-radius: var(--radius-small); background: white; font: inherit; color: var(--text); padding: 0.85rem 0.95rem; resize: vertical; }
.admin-card .note-row { margin-top: 0.85rem; display: grid; gap: 0.6rem; }
.admin-subtle { color: var(--muted); font-size: 0.88rem; }
.recommendation-dose { margin: 0.45rem 0 0; font-weight: 700; }
.recommendation-meta { margin-top: 0.35rem; font-size: 0.92rem; line-height: 1.5; }
.empty-state { padding: 1rem; border: 1px dashed rgba(25, 22, 18, 0.15); border-radius: var(--radius-small); background: rgba(255, 255, 255, 0.7); }
code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
@media (max-width: 860px) {
  .form-grid, .config-grid, .symptom-row, .admin-toolbar, .admin-summary, .report-meta { grid-template-columns: 1fr; }
  .panel-head, .ranked-top, .recommendation-top, .section-header { flex-direction: column; align-items: flex-start; }
}

@media print {
  :root {
    --bg: white;
    --surface: white;
    --surface-2: white;
    --border: rgba(22, 19, 14, 0.12);
    --shadow: none;
  }

  body {
    background: white;
    font-size: 11pt;
  }

  .hero,
  .panel-intro,
  #admin-panel,
  #assessment-panel,
  .btn,
  #results-status,
  #save-status,
  #connection-status,
  #billing-status,
  #access-token-status,
  #session-status {
    display: none !important;
  }

  .page {
    max-width: none;
    padding: 0;
  }

  .panel {
    border: 0;
    box-shadow: none;
    padding: 0;
    margin: 0 0 1rem;
    break-inside: avoid;
  }

  .panel-head {
    margin-bottom: 0.6rem;
  }

  .chart-shell,
  .ranked-card,
  .recommendation-card,
  .report-meta-card {
    break-inside: avoid;
    box-shadow: none;
  }
}
