/* ============================================================
   Styles · betreuer.pro
   Grundlage: docs/design-system.md · docs/wireframe-startseite.md
   ============================================================ */

/* ─── Webfont: Atkinson Hyperlegible (OFL 1.1) ─────────────── */

@font-face {
  font-family: "Atkinson Hyperlegible";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/AtkinsonHyperlegible-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "Atkinson Hyperlegible";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/AtkinsonHyperlegible-Bold.woff2") format("woff2");
}
@font-face {
  font-family: "Atkinson Hyperlegible";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/AtkinsonHyperlegible-Italic.woff2") format("woff2");
}
@font-face {
  font-family: "Atkinson Hyperlegible";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/AtkinsonHyperlegible-BoldItalic.woff2") format("woff2");
}

/* ─── Reset / Base ─────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--text-default);
  background: var(--bg-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, svg { display: block; max-width: 100%; height: auto; }

button, input, select, textarea { font: inherit; color: inherit; }

:focus-visible {
  outline: 3px solid var(--color-green-500);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

a {
  color: var(--link);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color var(--dur) var(--ease);
}
a:hover { color: var(--link-hover); }

h1, h2, h3, h4 { margin: 0 0 var(--space-4); line-height: var(--leading-tight); }
h1 { font-size: var(--text-3xl); font-weight: 700; }
h2 { font-size: var(--text-2xl); font-weight: 700; }
h3 { font-size: var(--text-xl); font-weight: 700; }
h4 { font-size: var(--text-lg); font-weight: 700; }

p { margin: 0 0 var(--space-4); }
ul, ol { margin: 0 0 var(--space-4); padding-left: var(--space-6); }
li + li { margin-top: var(--space-2); }

/* ─── Layout ───────────────────────────────────────────────── */

.container {
  width: 100%;
  max-width: var(--max-content);
  margin: 0 auto;
  padding: 0 var(--space-4);
}

@media (min-width: 768px) {
  .container { padding: 0 var(--space-6); }
}

.section {
  padding: var(--space-12) 0;
}

.section--soft      { background: var(--bg-soft); }
.section--grey      { background: var(--bg-section); }
.section--track-b   { background: var(--bg-track-b); }

@media (min-width: 768px) {
  .section { padding: var(--space-16) 0; }
}

.reading {
  max-width: var(--max-reading);
}

/* Prose-Spalte: für Fließtext innerhalb eines breiten Containers */
.prose-col {
  max-width: var(--max-prose);
}

/* Tabelle auf schmalen Viewports horizontal scrollbar machen */
.table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: var(--space-6) 0;
  border-radius: var(--radius-md);
}
.table-wrap table { min-width: 640px; }

/* ─── Header ───────────────────────────────────────────────── */

.site-header {
  border-bottom: 1px solid var(--line);
  background: var(--bg-body);
  position: sticky;
  top: 0;
  z-index: 50;
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-3) 0;
  position: relative;
}

.brand {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: var(--text-default);
}
.brand:hover { color: var(--text-default); }
.brand img { height: 40px; width: auto; }
.brand__text { font-weight: 700; font-size: var(--text-lg); letter-spacing: -0.01em; }
.brand__sub  { font-size: var(--text-xs); color: var(--text-faint); display: block; font-weight: 400; letter-spacing: 0; }

/* Burger-Toggle — nur mobil sichtbar */
.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px; height: 44px;
  padding: 10px;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: border-color var(--dur) var(--ease);
}
.nav-toggle:hover { border-color: var(--line-strong); }
.nav-toggle__bar {
  display: block;
  width: 22px; height: 2px;
  background: var(--text-default);
  transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
  transform-origin: center;
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Desktop-Nav */
.nav ul { list-style: none; padding: 0; margin: 0; display: flex; gap: var(--space-6); }
.nav li + li { margin-top: 0; }  /* globale li+li Regel abfangen */
.nav a { color: var(--text-default); text-decoration: none; font-weight: 500; }
.nav a:hover { color: var(--link); }

.nav-tools { display: flex; gap: var(--space-2); align-items: center; }
.nav-tools a {
  font-size: var(--text-sm);
  text-decoration: none;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  color: var(--text-muted);
}
.nav-tools a:hover { color: var(--text-default); border-color: var(--line-strong); }

/* Mobil: Nav-Panel unter dem Header, erscheint nach Klick */
@media (max-width: 959px) {
  .nav-tools { display: none; }

  .nav {
    position: absolute;
    top: 100%; left: 0; right: 0;
    background: var(--bg-body);
    border-bottom: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
    display: none;
    padding: var(--space-4);
  }
  .nav[data-open="true"] { display: block; }
  .nav ul {
    flex-direction: column;
    gap: 0;
  }
  .nav li + li { margin-top: 0; border-top: 1px solid var(--line); }
  .nav a {
    display: block;
    padding: var(--space-3) var(--space-2);
    font-size: var(--text-base);
  }
  .nav__tools-mobile {
    margin-top: var(--space-4);
    padding-top: var(--space-4);
    border-top: 2px solid var(--line-strong);
    display: flex;
    gap: var(--space-2);
  }
  .nav__tools-mobile a {
    display: inline-block;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    color: var(--text-muted);
  }
}

@media (min-width: 960px) {
  .nav-toggle { display: none; }
  .nav { display: block !important; position: static; box-shadow: none; padding: 0; background: none; border: 0; }
  .nav__tools-mobile { display: none; }
}

/* ─── Hero ─────────────────────────────────────────────────── */

.hero {
  padding: var(--space-12) 0 var(--space-8);
}
@media (min-width: 768px) {
  .hero { padding: var(--space-20) 0 var(--space-12); }
}

.hero__claim {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.015em;
  margin: 0 0 var(--space-8);
  max-width: 34ch;
}
.hero__claim em {
  font-style: normal;
  color: var(--color-green-700);
}

.split {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 720px) {
  .split { grid-template-columns: 1fr 1fr; gap: var(--space-6); }
}

.tile {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  color: inherit;
  background: var(--bg-body);
  border: 1px solid var(--line);
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.tile:hover, .tile:focus-visible {
  box-shadow: var(--shadow-md);
  color: inherit;
}
.tile__label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: var(--color-green-700);
}
.tile__title {
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: var(--leading-tight);
  margin: 0;
}
.tile__text {
  font-size: var(--text-base);
  color: var(--text-muted);
  margin: 0;
  flex: 1;
}
.tile__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 600;
  color: var(--color-green-700);
  margin-top: var(--space-3);
}

.tile--a { background: var(--bg-body); }
.tile--b { background: var(--bg-track-b); border-color: transparent; }

/* ─── Vertrauensleiste ─────────────────────────────────────── */

.trustbar {
  padding: var(--space-6) 0;
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.trustbar__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4) var(--space-6);
}
@media (min-width: 960px) {
  .trustbar__grid { grid-template-columns: repeat(4, 1fr); }
}
.trustbar__item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
}
.trustbar__check {
  flex: 0 0 auto;
  width: 22px; height: 22px;
  display: grid;
  place-items: center;
  background: var(--color-green-500);
  color: var(--color-white);
  border-radius: 50%;
  font-size: 13px;
  font-weight: 700;
  margin-top: 2px;
}
.trustbar__label {
  font-size: var(--text-sm);
  line-height: 1.45;
  color: var(--text-default);
}
.trustbar__label strong { display: block; color: var(--text-default); }
.trustbar__label span   { display: block; color: var(--text-muted); }

/* ─── Live-Status (3 Kacheln) ──────────────────────────────── */

.status-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 720px) {
  .status-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
}

.status-card {
  background: var(--bg-body);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  box-shadow: var(--shadow-xs);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.status-card h3 {
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin: 0 0 var(--space-1);
  font-weight: 700;
}
.status-card p { margin: 0; }
.status-card__dot {
  display: inline-block;
  width: 10px; height: 10px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: var(--space-2);
}
.status-card__dot--open    { background: var(--color-status-open); }
.status-card__dot--limited { background: var(--color-status-limited); }
.status-card__dot--closed  { background: var(--color-status-closed); }
.status-card__big {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--text-default);
}
.status-card__meta {
  font-size: var(--text-sm);
  color: var(--text-faint);
}
.status-card__cta {
  margin-top: auto;
  font-weight: 600;
  color: var(--color-green-700);
}
.status-card--crisis { background: var(--color-danger-soft); border-color: #E8C7C7; }
.status-card--crisis h3 { color: var(--color-danger); }

/* ─── Doppelqualifikations-Teaser ──────────────────────────── */

.duo {
  background: var(--color-green-100);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
}
@media (min-width: 768px) {
  .duo { padding: var(--space-12); }
}
.duo h2 {
  font-size: var(--text-2xl);
  max-width: 28ch;
}
.duo p { max-width: 60ch; color: var(--text-muted); }
.duo .btn { margin-top: var(--space-4); }

/* ─── Portrait ─────────────────────────────────────────────── */

.portrait {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: center;
}
@media (min-width: 720px) {
  .portrait { grid-template-columns: 200px 1fr; gap: var(--space-10); }
}
.portrait__photo {
  aspect-ratio: 1 / 1;
  background: var(--bg-section);
  border-radius: var(--radius-md);
  display: grid;
  place-items: center;
  color: var(--text-faint);
  font-size: var(--text-sm);
}
.portrait h2 { margin-bottom: var(--space-2); }
.portrait__role { color: var(--text-muted); margin: 0 0 var(--space-4); }
.portrait blockquote {
  margin: 0 0 var(--space-4);
  font-size: var(--text-lg);
  color: var(--text-default);
  border-left: 3px solid var(--color-green-500);
  padding-left: var(--space-4);
}

/* ─── Quick Answers ────────────────────────────────────────── */

.qa-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 720px) {
  .qa-grid { grid-template-columns: 1fr 1fr; gap: var(--space-6); }
}
.qa-card {
  background: var(--bg-body);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: var(--space-8);
}
.qa-card h3 {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-green-700);
  margin-bottom: var(--space-3);
}
.qa-card ul { padding-left: 1.25rem; }
.qa-card li { color: var(--text-muted); }
.qa-card__cta { display: inline-block; margin-top: var(--space-4); font-weight: 600; }

/* ─── Leichte-Sprache-Hinweis ──────────────────────────────── */

.ls-hint {
  padding: var(--space-6) 0;
  background: var(--color-green-100);
  text-align: center;
  font-size: var(--text-base);
}
.ls-hint a { font-weight: 600; }

/* ─── Footer ───────────────────────────────────────────────── */

.site-footer {
  background: var(--color-grey-900);
  color: var(--color-grey-100);
  padding: var(--space-12) 0 var(--space-8);
  font-size: var(--text-sm);
}
.site-footer a {
  color: var(--color-grey-100);
  text-decoration: underline;
  text-decoration-color: rgba(255,255,255,0.3);
}
.site-footer a:hover { color: var(--color-green-500); text-decoration-color: currentColor; }

.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}
@media (min-width: 720px) {
  .footer-grid { grid-template-columns: 1.2fr 1fr 1fr 1fr; gap: var(--space-10); }
}
.footer-col h4 {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-grey-300);
  margin-bottom: var(--space-3);
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li + li { margin-top: var(--space-2); }

.footer-meta {
  margin-top: var(--space-10);
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255,255,255,0.1);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-4);
  color: var(--color-grey-300);
}

/* ─── Buttons ──────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background: var(--color-green-700);
  color: var(--color-white);
  border: 1px solid var(--color-green-700);
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: var(--text-base);
  text-decoration: none;
  cursor: pointer;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.btn:hover { background: var(--color-green-600); color: var(--color-white); border-color: var(--color-green-600); }
.btn--ghost {
  background: transparent;
  color: var(--text-default);
  border: 1.5px solid var(--line-strong);
}
.btn--ghost:hover { background: var(--bg-soft); color: var(--text-default); border-color: var(--text-default); }

/* ─── Hinweis-Boxen ────────────────────────────────────────── */

.note {
  padding: var(--space-4) var(--space-6);
  border-left: 4px solid var(--color-info);
  background: var(--color-info-soft);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-size: var(--text-sm);
}
.note--danger {
  border-color: var(--color-danger);
  background: var(--color-danger-soft);
}
.note--green {
  border-color: var(--color-green-500);
  background: var(--color-green-100);
}

/* ─── Punktelisten-Seite (USP) ─────────────────────────────── */

.usp-list { counter-reset: usp; list-style: none; padding: 0; }
.usp-list > li {
  counter-increment: usp;
  position: relative;
  padding: var(--space-6) 0 var(--space-6) 60px;
  border-top: 1px solid var(--line);
}
.usp-list > li:last-child { border-bottom: 1px solid var(--line); }
.usp-list > li::before {
  content: counter(usp, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: var(--space-6);
  font-weight: 700;
  font-size: var(--text-lg);
  color: var(--color-green-700);
  letter-spacing: -0.02em;
}
.usp-list h3 {
  margin-bottom: var(--space-2);
  font-size: var(--text-lg);
}
.usp-list p { margin: 0; color: var(--text-muted); }

/* ─── Prosa (Impressum, Datenschutz) ───────────────────────── */

.prose h2 {
  margin-top: var(--space-10);
  padding-top: var(--space-6);
  border-top: 1px solid var(--line);
}
.prose h2:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }
.prose h3 { margin-top: var(--space-6); }
.prose p, .prose li { color: var(--text-muted); }
.prose dl dt { font-weight: 600; margin-top: var(--space-3); }
.prose dl dd { margin: 0; color: var(--text-muted); }

/* ─── FAQ (details/summary) ────────────────────────────────── */

.faq-category {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-green-700);
  font-weight: 700;
  margin: var(--space-10) 0 var(--space-4);
}
.faq-category:first-of-type { margin-top: 0; }

.faq-item {
  border-top: 1px solid var(--line);
  padding: var(--space-5) 0;
}
.faq-item:last-of-type { border-bottom: 1px solid var(--line); }

.faq-item > summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
  font-weight: 600;
  font-size: var(--text-lg);
  color: var(--text-default);
  line-height: var(--leading-snug);
  padding-right: var(--space-1);
}
.faq-item > summary::-webkit-details-marker { display: none; }
.faq-item > summary::after {
  content: "+";
  flex: 0 0 auto;
  color: var(--color-green-700);
  font-weight: 300;
  font-size: 1.6em;
  line-height: 1;
  transition: transform var(--dur) var(--ease);
}
.faq-item[open] > summary::after {
  content: "×";
  color: var(--color-grey-700);
}
.faq-item > summary:hover { color: var(--color-green-700); }
.faq-item > summary:focus-visible { outline-offset: 4px; }

.faq-answer {
  margin-top: var(--space-3);
  color: var(--text-muted);
}
.faq-answer p { margin: 0 0 var(--space-3); }
.faq-answer p:last-child { margin-bottom: 0; }
.faq-answer .ref {
  font-size: var(--text-sm);
  color: var(--text-faint);
  font-style: italic;
}

/* ─── Utilities ────────────────────────────────────────────── */

.meta-line {
  font-size: var(--text-sm);
  color: var(--text-faint);
  margin-bottom: var(--space-6);
}
.lead {
  font-size: var(--text-lg);
  color: var(--text-muted);
  max-width: 60ch;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: auto;
}
.skip-link:focus {
  position: fixed;
  left: var(--space-4);
  top: var(--space-4);
  background: var(--color-green-700);
  color: var(--color-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  z-index: 100;
  text-decoration: none;
}
