/* Halo · shared styles for /results, /onboarding, /dashboard, /login, /admin, /dokument
 * Landing page (index.html) keeps its own inline styles, bezieht aber dieselben
 * Tokens aus assets/tokens.css — der einzigen Quelle der Wahrheit für Farben. */

@import url('/assets/tokens.css');

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  background: var(--c-bg);
  color: var(--c-text);
  line-height: 1.6; font-size: 16px;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, .serif {
  font-family: var(--font-sans);
  font-weight: 700; letter-spacing: -0.02em; line-height: 1.15;
}
a { color: var(--c-green-deep); text-decoration: underline; text-underline-offset: 3px; }
a:hover { color: var(--c-navy); }
button { font-family: inherit; }

/* HEADER */
header.top {
  background: var(--c-navy-deep);
  color: var(--c-surface);
  padding: 18px 0;
  border-bottom: 1px solid rgba(var(--c-green-rgb), 0.25);
}
/* Sticky nur mit In-Page-Navigation (Dashboard) — Nav bleibt sichtbar. */
header.top.has-nav {
  position: sticky; top: 0; z-index: 50;
  padding: 12px 0;
  box-shadow: 0 4px 24px rgba(var(--c-navy-deep-rgb), 0.28);
}
.header-inner {
  max-width: 1180px; margin: 0 auto; padding: 0 24px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px;
}

/* Zentrales Menüband (Dashboard) */
.header-nav {
  display: flex; gap: 4px; flex: 1; justify-content: center;
  flex-wrap: wrap;
}
.header-nav a {
  color: rgba(var(--c-white-rgb), 0.78);
  text-decoration: none; font-size: 14px; font-weight: 500;
  padding: 8px 15px; border-radius: 999px;
  letter-spacing: 0.01em; transition: color .15s, background .15s;
}
.header-nav a:hover {
  color: var(--c-surface); background: rgba(var(--c-white-rgb), 0.08);
}
.header-nav a.active {
  color: var(--c-navy-deep); background: var(--c-green); font-weight: 600;
}
@media (max-width: 860px) {
  .header-nav {
    flex: 1 0 100%; order: 3; justify-content: flex-start;
    gap: 2px; overflow-x: auto; -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
  }
  .header-nav a { white-space: nowrap; padding: 7px 12px; font-size: 13px; }
}
.logo {
  font-family: var(--font-sans); font-size: 26px; font-weight: 600;
  color: var(--c-surface); letter-spacing: -0.01em;
  display: flex; align-items: center; gap: 10px;
  text-decoration: none;
}
.logo .logo-mark { flex-shrink: 0; }
.logo .logo-mark circle { stroke: var(--c-green); }
.logo .logo-mark rect { fill: var(--c-surface); }
.logo .logo-text { line-height: 1; }
.logo:hover { color: var(--c-green-bright); }
.logo:hover .logo-mark circle { stroke: var(--c-green-bright); }
.logo-tag {
  font-family: 'Inter', sans-serif; font-size: 12px; color: var(--c-green);
  letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600;
  margin-left: 16px; opacity: 0.9;
}
.header-meta {
  font-size: 12px; color: rgba(var(--c-white-rgb), 0.65);
  letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500;
}
.header-meta a { color: var(--c-green-bright); text-decoration: none; }
.header-meta a:hover { color: var(--c-surface); }

/* PAGE */
.page {
  max-width: 920px; margin: 0 auto; padding: 48px 24px 80px;
}
.page-narrow { max-width: 640px; }
.page-eyebrow {
  color: var(--c-text-muted); font-size: 12px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 16px;
}
.page h1 {
  font-size: 44px; line-height: 1.1; color: var(--c-navy-deep); margin-bottom: 16px;
}
.page h1 em { color: var(--c-green-bright); font-style: italic; }
.page-sub {
  font-size: 17px; color: var(--c-text-muted); margin-bottom: 36px;
  max-width: 640px;
}

/* BUTTONS */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 10px; padding: 16px 32px; border-radius: 999px;
  font-size: 16px; font-weight: 600; text-decoration: none;
  border: none; cursor: pointer;
  transition: all .2s ease;
}
/* Primär: grün gefüllt — Hauptaktion („Erledigt", „Jetzt erstellen") */
.btn-primary {
  background: var(--c-green); color: var(--c-surface);
  font-weight: 700;
  box-shadow: 0 6px 20px rgba(var(--c-green-rgb), 0.30);
}
.btn-primary:hover, .btn-primary:focus-visible {
  background: var(--c-green-hover); transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(var(--c-green-rgb), 0.38); outline: none;
}
.btn-primary:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
/* Navy gefüllt — Sekundäraktionen wie „Update", „Zubuchbar" */
.btn-navy {
  background: var(--c-navy); color: var(--c-surface);
  box-shadow: 0 6px 20px rgba(var(--c-navy-rgb), 0.20);
}
.btn-navy:hover, .btn-navy:focus-visible {
  background: var(--c-navy-deep); transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(var(--c-navy-rgb), 0.28); outline: none;
}
/* Outline/Ghost auf hellem Grund (z. B. „Zurück") */
.btn-secondary {
  background: var(--c-surface); color: var(--c-navy);
  border: 2px solid var(--c-track);
}
.btn-secondary:hover { border-color: var(--c-green); }
.btn-ghost {
  background: none; color: var(--c-text-muted);
  border: none; padding: 10px 18px;
  text-decoration: underline; text-underline-offset: 4px;
}
.btn-ghost:hover { color: var(--c-text); }
.btn-soon {
  background: var(--c-surface-soft); color: var(--c-text-muted);
  border: 1.5px solid var(--c-track);
  cursor: not-allowed;
  display: inline-flex; align-items: center; gap: 6px;
}
.btn-soon:hover { transform: none; box-shadow: none; }
.soon-tag {
  display: inline-block; font-size: 10px; font-weight: 700;
  padding: 2px 7px; border-radius: 999px;
  background: var(--c-green-soft); color: var(--c-green-deep);
  letter-spacing: 0.05em; text-transform: uppercase;
}

/* CARDS */
.card {
  background: var(--c-surface); border: 1px solid var(--c-track);
  border-radius: 16px; padding: 32px;
  box-shadow: var(--shadow);
  margin-bottom: 24px;
}
.card-tight { padding: 24px; }
/* Dunkles Akzent-Panel: Navy-Fläche, dünner grüner Balken an der Oberkante */
.card-dark {
  background: linear-gradient(135deg, var(--c-navy-deep) 0%, var(--c-navy) 100%);
  color: var(--c-surface); border: none;
  border-top: 3px solid var(--c-green);
  box-shadow: 0 16px 48px rgba(var(--c-navy-rgb), 0.25);
}
.card-dark h2 { color: var(--c-surface); }
.card-dark .muted { color: rgba(var(--c-white-rgb), 0.72); }
.card-dark .page-eyebrow, .card-dark .q-eyebrow { color: var(--c-green); }

/* SCORE */
.score-row {
  display: grid; grid-template-columns: auto 1fr; gap: 28px; align-items: center;
}
.score-num {
  font-family: var(--font-sans); font-size: 72px;
  color: var(--c-green-bright); font-weight: 600; line-height: 1;
}
.score-label {
  font-size: 13px; color: var(--c-text-muted); text-transform: uppercase;
  letter-spacing: 0.12em; font-weight: 600; margin-bottom: 8px;
}
.card-dark .score-label { color: var(--c-green); }
.score-status {
  font-family: var(--font-sans); font-size: 22px; color: var(--c-surface);
  font-weight: 500; line-height: 1.2;
}
.score-meter {
  height: 6px; background: rgba(var(--c-white-rgb), 0.16);
  border-radius: 999px; overflow: hidden; margin-top: 14px;
}
.score-meter-fill {
  height: 100%; background: var(--c-green);
  border-radius: 999px; transition: width .6s ease;
}

/* STATUS GRID */
.status-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; margin-bottom: 32px;
}
.status-box {
  border-radius: 14px; padding: 24px 20px;
  border: 2px solid; transition: all .2s;
}
.status-box.danger { background: var(--c-red-soft); border-color: var(--c-red); }
.status-box.warning { background: var(--c-amber-soft); border-color: var(--c-amber); }
.status-box.success { background: var(--c-green-soft); border-color: var(--c-green); }
.status-icon {
  width: 32px; height: 32px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 700; color: var(--c-surface);
  margin-bottom: 12px;
}
.status-box.danger .status-icon { background: var(--c-red); }
.status-box.warning .status-icon { background: var(--c-amber-deep); }
.status-box.success .status-icon { background: var(--c-green); }
.status-num {
  font-family: var(--font-sans); font-size: 40px; line-height: 1;
  font-weight: 600; margin-bottom: 6px;
}
.status-box.danger .status-num { color: var(--c-red); }
.status-box.warning .status-num { color: var(--c-amber-deep); }
.status-box.success .status-num { color: var(--c-green-deep); }
.status-title {
  font-family: var(--font-sans); font-size: 16px;
  color: var(--c-text); margin-bottom: 4px; font-weight: 600;
}
.status-detail { font-size: 13px; color: var(--c-text); line-height: 1.45; }

/* QUIZ */
.quiz-progress {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 28px;
}
.quiz-progress .label {
  font-family: var(--font-sans);
  font-size: 13px; color: var(--c-green-deep); font-weight: 600;
  white-space: nowrap;
}
.quiz-progress .bar {
  flex: 1; height: 6px; background: var(--c-track);
  border-radius: 999px; overflow: hidden;
}
.quiz-progress .fill {
  height: 100%; background: var(--c-green);
  transition: width .3s ease;
}
.quiz-progress .count {
  font-size: 13px; color: var(--c-text-muted); font-weight: 500;
  white-space: nowrap;
}

.q-eyebrow {
  color: var(--c-text-muted); font-size: 12px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  margin-bottom: 16px;
}
.q-text {
  font-family: var(--font-sans); font-size: 28px; line-height: 1.2;
  color: var(--c-navy-deep); margin-bottom: 10px; font-weight: 500;
}
.q-hint {
  color: var(--c-text-muted); font-size: 14px; margin-bottom: 28px;
  font-style: italic;
}
.answer {
  width: 100%;
  background: var(--c-bg); color: var(--c-text);
  border: 2px solid var(--c-track);
  padding: 18px 24px;
  border-radius: 12px;
  font-size: 16px; font-weight: 500;
  text-align: left; cursor: pointer;
  margin-bottom: 10px;
  transition: all .15s ease;
  display: flex; align-items: center; gap: 14px;
}
.answer:hover, .answer:focus-visible {
  border-color: var(--c-green); background: var(--c-surface);
  outline: none;
}
.answer-circle {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid var(--c-track); flex-shrink: 0;
  transition: all .15s;
}
.answer-square {
  width: 18px; height: 18px; border-radius: 4px;
  border: 2px solid var(--c-track); flex-shrink: 0;
}
.answer:hover .answer-circle, .answer:hover .answer-square { border-color: var(--c-green); }
.answer.selected {
  border-color: var(--c-navy); background: var(--c-navy); color: var(--c-surface);
}
.answer.selected .answer-circle, .answer.selected .answer-square {
  border-color: var(--c-green); background: var(--c-green);
}
.q-select {
  width: 100%;
  background: var(--c-surface); border: 2px solid var(--c-track);
  padding: 16px 20px; border-radius: 12px;
  font-size: 16px; color: var(--c-text);
  font-family: inherit;
}
.q-select:focus { border-color: var(--c-green); outline: none; }

.quiz-nav {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 24px; gap: 12px;
}

/* ACTION LIST (results / dashboard) */
.action-list { list-style: none; padding: 0; }
.action-item {
  display: grid; grid-template-columns: auto 1fr auto; gap: 16px;
  padding: 16px 20px; border-bottom: 1px solid var(--c-track);
  align-items: center;
}
.action-item:last-child { border-bottom: none; }
.action-dot {
  width: 12px; height: 12px; border-radius: 50%;
}
.action-dot.danger { background: var(--c-red); }
.action-dot.warning { background: var(--c-amber); }
.action-dot.success { background: var(--c-green); }
.action-title {
  font-weight: 600; color: var(--c-text); margin-bottom: 2px;
}
.action-detail {
  font-size: 13px; color: var(--c-text-muted);
}
.action-cta {
  font-size: 13px; color: var(--c-green-deep); font-weight: 600;
  text-decoration: underline; text-underline-offset: 3px;
  cursor: pointer; background: none; border: none;
}

/* FORMS */
.form-row { margin-bottom: 16px; }
.form-row label {
  display: block; font-size: 13px; font-weight: 600; color: var(--c-text);
  margin-bottom: 6px; letter-spacing: 0.02em;
}
.form-row input[type="email"],
.form-row input[type="password"],
.form-row input[type="text"],
.form-row input[type="date"],
.form-row input[type="tel"],
.form-row textarea {
  width: 100%; padding: 14px 18px;
  background: var(--c-surface); border: 2px solid var(--c-track);
  border-radius: 10px; font-size: 16px;
  font-family: inherit; color: var(--c-text);
}
.form-row input:focus, .form-row textarea:focus { border-color: var(--c-green); outline: none; }
.form-error {
  background: var(--c-red-soft); color: var(--c-red-deep);
  padding: 12px 16px; border-radius: 8px;
  font-size: 14px; margin-bottom: 14px;
}
.form-success {
  background: var(--c-green-soft); color: var(--c-green-deep);
  padding: 12px 16px; border-radius: 8px;
  font-size: 14px; margin-bottom: 14px;
}

/* SECTION CHIPS (onboarding) */
.section-chips {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px;
}
.section-chip {
  padding: 6px 12px; border-radius: 999px;
  background: var(--c-surface-soft); border: 1px solid var(--c-track);
  font-size: 12px; font-weight: 600; color: var(--c-text-muted);
  letter-spacing: 0.05em;
}
.section-chip.active {
  background: var(--c-navy); color: var(--c-surface); border-color: var(--c-navy);
}
.section-chip.done {
  background: var(--c-green-soft); color: var(--c-green-deep); border-color: var(--c-green);
}

/* MUTED HELP TEXT */
.help-text { font-size: 13px; color: var(--c-text-muted); }
.center { text-align: center; }
.spacer-12 { height: 12px; } .spacer-24 { height: 24px; } .spacer-32 { height: 32px; }
.flex { display: flex; gap: 12px; align-items: center; }
.flex-col { display: flex; flex-direction: column; gap: 12px; }
.between { justify-content: space-between; }
.w-full { width: 100%; }

/* ONBOARDING COMPACT (fit-viewport) */
.onboarding-page { padding: 20px 18px 28px; max-width: 720px; }
.ob-topbar { margin-bottom: 12px; }
.ob-topbar-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px; color: var(--c-text-muted);
  letter-spacing: 0.06em; margin-bottom: 10px;
  flex-wrap: wrap; gap: 8px;
}
.ob-step { font-weight: 700; text-transform: uppercase; color: var(--c-text-muted); }
.ob-identity { color: var(--c-text-muted); }
.ob-identity strong { color: var(--c-text); font-weight: 600; }
.ob-topbar .section-chips { margin-bottom: 0; }
.ob-topbar .section-chip { padding: 4px 10px; font-size: 11px; }
.ob-card { padding: 22px 24px; margin-bottom: 0; }
.ob-card .quiz-progress { margin-bottom: 16px; }
.ob-card .q-eyebrow { margin-bottom: 8px; font-size: 11px; }
.ob-card .q-text { font-size: 22px; line-height: 1.22; margin-bottom: 6px; }
.ob-card .q-hint { font-size: 13px; margin-bottom: 16px; }
.ob-card .answer { padding: 12px 18px; font-size: 15px; margin-bottom: 8px; }
.ob-card .answer-circle, .ob-card .answer-square { width: 16px; height: 16px; }
.ob-card .q-select { padding: 12px 16px; font-size: 15px; }
.ob-nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 14px; }
.ob-nav .btn { padding: 12px 22px; font-size: 14px; }

/* 2-column answer layout when there are many options (desktop) */
@media (min-width: 600px) {
  .ob-card #answers.answers-cols-2 {
    display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  }
  .ob-card #answers.answers-cols-2 .answer { margin-bottom: 0; }
}
@media (max-width: 720px) {
  .onboarding-page { padding: 14px 14px 24px; }
  .ob-card { padding: 18px 18px; }
  .ob-card .q-text { font-size: 19px; }
  .ob-card .answer { padding: 11px 16px; font-size: 15px; }
}

/* SUBSCRIPTION LIST (Section F) */
.subs-list { display: flex; flex-direction: column; gap: 8px; }
.sub-row {
  display: grid; grid-template-columns: 1fr 110px 1.4fr 32px; gap: 8px;
  align-items: center;
}
.sub-row input {
  padding: 10px 12px; border: 2px solid var(--c-track);
  border-radius: 8px; font-size: 14px; font-family: inherit;
  background: var(--c-surface); color: var(--c-text);
  width: 100%; min-width: 0;
}
.sub-row input:focus { outline: none; border-color: var(--c-green); }
.sub-remove {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid var(--c-track); background: var(--c-surface);
  color: var(--c-text-muted); font-size: 18px; font-weight: 700;
  cursor: pointer; line-height: 1;
}
.sub-remove:hover { background: var(--c-red-soft); border-color: var(--c-red); color: var(--c-red); }
.sub-add {
  margin-top: 8px;
  background: var(--c-surface-soft); border: 2px dashed var(--c-track);
  color: var(--c-text); padding: 12px 18px; border-radius: 10px;
  font-size: 14px; font-weight: 600; cursor: pointer;
  font-family: inherit; transition: all .15s;
}
.sub-add:hover { border-color: var(--c-green); background: var(--c-surface); }
@media (max-width: 720px) {
  .sub-row { grid-template-columns: 1fr 90px 32px; row-gap: 6px; }
  .sub-row .sub-notes { grid-column: 1 / -1; }
}

/* TRAFFIC LIGHT (big status counts — used on /results, /dashboard) */
.traffic-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; margin-bottom: 28px;
}
.tg-box {
  border-radius: 16px; padding: 26px 16px;
  border: 2px solid; text-align: center;
}
.tg-box.danger { background: var(--c-red-soft); border-color: var(--c-red); }
.tg-box.warning { background: var(--c-amber-soft); border-color: var(--c-amber); }
.tg-box.success { background: var(--c-green-soft); border-color: var(--c-green); }
.tg-icon {
  width: 48px; height: 48px; border-radius: 50%;
  margin: 0 auto 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 700; color: var(--c-surface);
  font-family: var(--font-sans);
}
.tg-box.danger .tg-icon { background: var(--c-red); }
.tg-box.warning .tg-icon { background: var(--c-amber-deep); }
.tg-box.success .tg-icon { background: var(--c-green); }
.tg-num {
  font-family: var(--font-sans); font-size: 56px; line-height: 1;
  font-weight: 600; margin-bottom: 6px;
}
.tg-box.danger .tg-num { color: var(--c-red); }
.tg-box.warning .tg-num { color: var(--c-amber-deep); }
.tg-box.success .tg-num { color: var(--c-green-deep); }
.tg-label {
  font-family: var(--font-sans); font-size: 15px; line-height: 1.25;
  color: var(--c-text); font-weight: 600;
}
@media (max-width: 720px) {
  .traffic-grid { grid-template-columns: 1fr; gap: 10px; }
  .tg-box { display: grid; grid-template-columns: auto auto 1fr; gap: 14px; align-items: center; text-align: left; padding: 18px 16px; }
  .tg-icon { margin: 0; width: 36px; height: 36px; font-size: 18px; }
  .tg-num { margin: 0; font-size: 36px; }
  .tg-label { font-size: 14px; }
}

/* DASHBOARD SEKTIONEN (Single-Page mit Anker-Navigation) */
.dash-section { margin-top: 52px; scroll-margin-top: 84px; }
.dash-section .sec-eyebrow {
  color: var(--c-text-muted); font-size: 12px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 8px;
}
.dash-section .sec-title {
  font-family: var(--font-sans); font-size: 26px; font-weight: 600;
  color: var(--c-navy-deep); margin-bottom: 6px; line-height: 1.2;
}
.dash-section .sec-sub {
  font-size: 15px; color: var(--c-text-muted); margin-bottom: 22px; max-width: 640px;
}

/* Kompakte, on-brand Status-Übersicht (ersetzt die großen Status-Boxen) */
.status-summary {
  display: flex; gap: 10px; flex-wrap: wrap; margin: 4px 0 8px;
}
.ss-item {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; flex: 1; min-width: 160px;
  background: var(--c-surface); border: 1px solid var(--c-track);
  border-radius: 12px;
}
.ss-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.ss-dot.danger { background: var(--c-red); }
.ss-dot.warning { background: var(--c-amber); }
.ss-dot.success { background: var(--c-green); }
.ss-num {
  font-family: var(--font-sans); font-size: 26px; font-weight: 600;
  color: var(--c-navy-deep); line-height: 1; min-width: 22px;
}
.ss-label { font-size: 13.5px; color: var(--c-text-muted); font-weight: 500; }

/* AI-Agent-Sektion: nächste Schritte | Companion nebeneinander */
.agent-grid {
  display: grid; grid-template-columns: 1fr 1.25fr; gap: 20px; align-items: start;
}
.agent-grid #halo-companion { min-width: 0; }
.agent-grid .hc-root { max-width: none; }
@media (max-width: 860px) {
  .agent-grid { grid-template-columns: 1fr; }
  .agent-grid .hc-root { max-width: 560px; }
}
.next-steps-card { background: var(--c-surface); border: 1px solid var(--c-track); border-radius: 16px; padding: 22px 24px; box-shadow: var(--shadow); }
.next-steps-card h3 {
  font-family: var(--font-sans); font-size: 18px; color: var(--c-navy-deep);
  font-weight: 600; margin-bottom: 14px;
}
.ns-item {
  display: grid; grid-template-columns: auto 1fr; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid var(--c-track);
}
.ns-item:last-of-type { border-bottom: none; }
.ns-dot { width: 9px; height: 9px; border-radius: 50%; margin-top: 6px; }
.ns-dot.danger { background: var(--c-red); }
.ns-dot.warning { background: var(--c-amber); }
.ns-dot.success { background: var(--c-green); }
.ns-label { font-weight: 600; font-size: 15px; color: var(--c-text); }
.ns-reason { font-size: 13px; color: var(--c-text-muted); margin-top: 2px; line-height: 1.45; }
.ns-cta { display: inline-block; margin-top: 6px; font-size: 13px; font-weight: 600; color: var(--c-green-deep); text-decoration: underline; text-underline-offset: 3px; }
.ns-empty { font-size: 14px; color: var(--c-text-muted); }

/* Einstellungen / Konto */
.settings-card { background: var(--c-surface); border: 1px solid var(--c-track); border-radius: 16px; padding: 26px 28px; box-shadow: var(--shadow); margin-bottom: 18px; }
.settings-row { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 12px 0; border-bottom: 1px solid var(--c-track); flex-wrap: wrap; }
.settings-row:last-child { border-bottom: none; }
.settings-row .sr-label { font-size: 13px; color: var(--c-text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; }
.settings-row .sr-value { font-size: 15px; color: var(--c-text); font-weight: 500; }
details.answers-details > summary {
  cursor: pointer; font-weight: 600; color: var(--c-navy-deep);
  font-size: 15px; padding: 6px 0; list-style: none;
}
details.answers-details > summary::-webkit-details-marker { display: none; }
details.answers-details > summary::before { content: '▸ '; color: var(--c-green); }
details.answers-details[open] > summary::before { content: '▾ '; }
/* Dezente Danger-Zone (Konto löschen) */
.danger-zone { border: 1px solid var(--c-track); border-radius: 12px; padding: 18px 20px; background: var(--c-surface); }
.danger-zone summary { cursor: pointer; font-size: 14px; color: var(--c-text-muted); list-style: none; font-weight: 500; }
.danger-zone summary::-webkit-details-marker { display: none; }
.danger-zone summary::before { content: '▸ '; }
.danger-zone[open] summary::before { content: '▾ '; }
.btn-danger-text {
  background: none; border: none; color: var(--c-red); cursor: pointer;
  font-family: inherit; font-size: 14px; font-weight: 600;
  text-decoration: underline; text-underline-offset: 3px; padding: 0;
}

/* TOPIC CARDS */
.category-block { margin-bottom: 28px; }
.category-header {
  font-family: var(--font-sans); font-size: 13px; font-weight: 600;
  color: var(--c-text-muted); text-transform: uppercase; letter-spacing: 0.12em;
  margin: 0 0 14px 4px;
}
.topic-card {
  display: grid; grid-template-columns: auto 1fr auto; gap: 18px;
  align-items: center; padding: 18px 22px;
  background: var(--c-surface); border: 1px solid var(--c-track);
  border-radius: 12px; margin-bottom: 10px;
  border-left-width: 4px;
  transition: all .15s;
}
.topic-card:hover { border-color: var(--c-green); box-shadow: 0 4px 14px rgba(var(--c-navy-rgb), 0.06); }
.topic-card.status-good { border-left-color: var(--c-green); }
.topic-card.status-partial { border-left-color: var(--c-amber); }
.topic-card.status-action { border-left-color: var(--c-red); }
.topic-card.status-unknown { border-left-color: var(--c-text-muted); }
.topic-icon {
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; color: var(--c-surface); font-weight: 700;
  flex-shrink: 0;
}
.status-good .topic-icon { background: var(--c-green); }
.status-partial .topic-icon { background: var(--c-amber-deep); }
.status-action .topic-icon { background: var(--c-red); }
.status-unknown .topic-icon { background: var(--c-text-muted); }
.topic-body { min-width: 0; }
.topic-title {
  font-family: var(--font-sans); font-size: 18px;
  font-weight: 600; color: var(--c-navy-deep); margin-bottom: 4px;
  line-height: 1.2;
}
.topic-state {
  font-size: 13px; font-weight: 600; margin-bottom: 4px;
  letter-spacing: 0.02em;
}
.topic-state.good { color: var(--c-green-deep); }
.topic-state.action { color: var(--c-red); }
.topic-state.partial { color: var(--c-amber-deep); }
.topic-state.unknown { color: var(--c-text-muted); }
.topic-advice { font-size: 13px; color: var(--c-text); line-height: 1.5; opacity: 0.85; }
.topic-cta {
  flex-shrink: 0;
}
.topic-cta .btn {
  padding: 10px 18px; font-size: 13px;
  white-space: nowrap;
}
@media (max-width: 720px) {
  .topic-card { grid-template-columns: auto 1fr; gap: 12px; padding: 16px; }
  .topic-cta { grid-column: 1 / -1; margin-top: 6px; }
  .topic-cta .btn { width: 100%; }
}

/* SITE FOOTER (auto-mounted via Halo.renderFooter) */
.site-footer {
  background: var(--c-navy-deep); color: rgba(var(--c-white-rgb), 0.7);
  padding: 32px 24px; margin-top: 56px;
  border-top: 1px solid rgba(var(--c-green-rgb), 0.25);
}
.site-footer-inner {
  max-width: 760px; margin: 0 auto; text-align: center;
}
.footer-disclaimer {
  font-size: 13px; line-height: 1.6;
  color: rgba(var(--c-white-rgb), 0.78);
  margin-bottom: 14px;
}
.footer-disclaimer strong { color: var(--c-green-bright); }
.footer-links {
  margin-bottom: 12px; display: flex; gap: 18px;
  justify-content: center; flex-wrap: wrap;
}
.footer-links a {
  font-size: 13px; color: rgba(var(--c-white-rgb), 0.78);
  text-decoration: none; border-bottom: 1px solid rgba(var(--c-green-rgb), 0.4);
  padding-bottom: 1px;
}
.footer-links a:hover { color: var(--c-green-bright); border-bottom-color: var(--c-green-bright); }
.footer-meta {
  font-size: 12px; color: rgba(var(--c-white-rgb), 0.5);
  letter-spacing: 0.04em;
}

/* DOKUMENTEN-GENERATOR (doc-engine.js / dokument.html) */
.doc-info {
  background: var(--c-surface-soft); border: 1px solid var(--c-track);
  border-radius: 12px; padding: 16px 20px; margin-bottom: 14px;
  font-size: 14px; line-height: 1.55; color: var(--c-text);
}
.doc-info p + p { margin-top: 10px; }
.doc-info-warn {
  background: var(--c-amber-soft); border-color: var(--c-amber);
  color: var(--c-text);
}
.doc-field { margin-bottom: 18px; }
.doc-label {
  display: block; font-size: 14px; font-weight: 600; color: var(--c-text);
  margin-bottom: 8px;
}
.doc-req { color: var(--c-red); }
.doc-field-hint {
  font-size: 13px; color: var(--c-text-muted); margin: -4px 0 10px;
}
.doc-opt-hint {
  display: block; font-size: 12px; font-weight: 400; color: var(--c-text-muted);
  margin-top: 2px;
}
/* Nicht-blockierender Sanity-Check-Hinweis unter einem Eingabefeld */
.doc-field-warn {
  background: var(--c-amber-soft); border: 1px solid var(--c-amber);
  border-radius: 10px; padding: 10px 14px; margin-top: 8px;
  font-size: 13px; line-height: 1.5; color: var(--c-amber-deep);
}

/* PERSONEN · Sicht-Switcher (assets/persons.js, Dashboard-Kopf) */
.view-switch {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  margin-top: 14px;
}
.view-switch-eyebrow {
  font-size: 12px; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--c-text-muted);
}
.view-switch-label { font-size: 14px; color: var(--c-text-muted); }
.view-switch-select {
  font-family: inherit; font-size: 15px; font-weight: 600;
  color: var(--c-navy-deep); background: var(--c-surface);
  border: 1px solid var(--c-track); border-radius: 999px;
  padding: 8px 36px 8px 16px; cursor: pointer;
  -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%2334C270' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center;
}
.view-switch-select:focus { outline: none; border-color: var(--c-green); }
.view-add {
  background: none; border: none; cursor: pointer;
  color: var(--c-green-deep); font-size: 13px; font-weight: 600;
  text-decoration: underline; text-underline-offset: 3px;
}
.view-add:hover { color: var(--c-navy); }
.intake-card .intake-answers { margin-top: 10px; }
.intake-card .answer { margin-bottom: 10px; }

/* Dezenter Onboarding-Fortschritts-Hinweis unter der Checkliste */
.continue-hint {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 8px 16px;
  margin-top: 18px; padding: 12px 16px;
  background: var(--c-surface-soft); border: 1px solid var(--c-track);
  border-radius: 10px;
}
.continue-hint .help-text { margin: 0; }
.continue-hint-link {
  font-size: 13px; font-weight: 600; white-space: nowrap;
  color: var(--c-green-deep); text-decoration: none;
}
.continue-hint-link:hover { color: var(--c-navy); text-decoration: underline; }
/* Hinweis-Banner im Dokument-Wizard: für wen wird erstellt? */
.doc-person-banner {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: var(--c-green-soft); border: 1px solid var(--c-green);
  border-radius: 12px; padding: 12px 16px; margin-bottom: 16px;
  font-size: 14px; color: var(--c-text);
}
.doc-person-banner a { color: var(--c-green-deep); }
.answer.selected .doc-opt-hint { color: rgba(var(--c-white-rgb), 0.75); }
.doc-person {
  background: var(--c-surface); border: 1px solid var(--c-track);
  border-radius: 12px; padding: 18px 20px; margin-bottom: 12px;
}
.doc-person-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px; color: var(--c-navy);
}
.doc-review-block {
  border: 1px solid var(--c-track); border-radius: 12px;
  padding: 18px 20px; margin-bottom: 14px; background: var(--c-surface);
}
.doc-review-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 10px;
}
.doc-review-head h3 { font-size: 17px; color: var(--c-navy-deep); }
.doc-review-block dl { font-size: 14px; }
.doc-review-block dt { font-weight: 600; color: var(--c-text-muted); margin-top: 8px; font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; }
.doc-review-block dd { margin: 2px 0 0; color: var(--c-text); }

/* Editierbare Dokument-Vorschau */
.doc-preview {
  background: var(--c-surface); border: 1px solid var(--c-track);
  border-radius: 12px; padding: 36px 40px; margin-bottom: 20px;
  font-family: var(--font-doc); font-size: 15px; line-height: 1.65;
  counter-reset: docsec;
}
.doc-preview:focus-within { border-color: var(--c-green); outline: none; }
.doc-preview h2 {
  font-size: 18px; color: var(--c-navy); margin: 22px 0 8px;
  counter-increment: docsec;
}
.doc-preview h2::before { content: counter(docsec) '. '; }
.doc-preview h3 { font-size: 15.5px; color: var(--c-text); margin: 14px 0 6px; }
.doc-preview p { margin-bottom: 10px; }
.doc-preview-title {
  font-family: var(--font-doc); font-size: 26px;
  color: var(--c-navy-deep); margin-bottom: 4px;
}
.doc-preview-edithint {
  font-size: 13px; color: var(--c-text-muted); margin-bottom: 12px;
}
@media (max-width: 720px) {
  .doc-preview { padding: 22px 18px; }
}

/* RESPONSIVE */
@media (max-width: 720px) {
  .page { padding: 32px 18px 60px; }
  .page h1 { font-size: 32px; }
  .status-grid { grid-template-columns: 1fr; }
  .score-row { grid-template-columns: 1fr; gap: 16px; text-align: center; }
  .score-num { font-size: 56px; }
  .header-inner { flex-direction: column; gap: 6px; align-items: flex-start; }
  /* Mit Menüband Reihen-Layout beibehalten (Logo links, Abmelden rechts,
     Nav als scrollbares Band darunter). */
  header.top.has-nav .header-inner { flex-direction: row; flex-wrap: wrap; align-items: center; gap: 10px; }
  .logo-tag { margin-left: 0; }
}
