/* =========================================================
   klinikwunschliste.de — Stylesheet
   IBM Plex (self-hosted). Lege die woff2-Dateien nach /fonts/,
   sonst greift automatisch der System-Fallback.
   ========================================================= */

@font-face {
  font-family: "IBM Plex Sans";
  font-style: normal; font-weight: 400; font-display: swap;
  src: url("/fonts/IBMPlexSans-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "IBM Plex Sans";
  font-style: normal; font-weight: 600; font-display: swap;
  src: url("/fonts/IBMPlexSans-SemiBold.woff2") format("woff2");
}
@font-face {
  font-family: "IBM Plex Serif";
  font-style: normal; font-weight: 400; font-display: swap;
  src: url("/fonts/IBMPlexSerif-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "IBM Plex Serif";
  font-style: normal; font-weight: 500; font-display: swap;
  src: url("/fonts/IBMPlexSerif-Medium.woff2") format("woff2");
}
@font-face {
  font-family: "IBM Plex Mono";
  font-style: normal; font-weight: 400; font-display: swap;
  src: url("/fonts/IBMPlexMono-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "IBM Plex Mono";
  font-style: normal; font-weight: 500; font-display: swap;
  src: url("/fonts/IBMPlexMono-Medium.woff2") format("woff2");
}

:root {
  --paper:      oklch(0.987 0.006 90);
  --paper-2:    oklch(0.965 0.008 88);
  --paper-3:    oklch(0.945 0.010 86);
  --ink:        oklch(0.28 0.014 255);
  --ink-soft:   oklch(0.47 0.012 255);
  --ink-faint:  oklch(0.63 0.010 255);
  --line:       oklch(0.90 0.008 88);
  --line-soft:  oklch(0.94 0.006 88);
  --accent:     oklch(0.52 0.088 158);
  --accent-ink: oklch(0.40 0.078 158);
  --accent-bg:  oklch(0.955 0.028 158);
  --accent-line:oklch(0.86 0.045 158);

  --font-sans: "IBM Plex Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-serif:"IBM Plex Serif", Georgia, "Times New Roman", serif;
  --font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  --col: 42rem;
  --wide: 60rem;
}

* { box-sizing: border-box; }

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

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 18px;
  line-height: 1.62;
  font-feature-settings: "kern", "liga";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: var(--accent-ink); text-underline-offset: 2px; text-decoration-thickness: 1px; }
a:hover { color: var(--ink); }

::selection { background: var(--accent-bg); }

/* ---------- Kopf ---------- */
.kopf {
  position: sticky; top: 0; z-index: 20;
  background: color-mix(in oklab, var(--paper) 88%, transparent);
  backdrop-filter: saturate(1.1) blur(8px);
  border-bottom: 1px solid var(--line);
}
.kopf-inner {
  max-width: var(--wide);
  margin: 0 auto;
  padding: 0.85rem 1.5rem;
  display: flex; align-items: center; gap: 1.25rem;
}
.wortmarke {
  font-family: var(--font-mono);
  font-weight: 500;
  letter-spacing: 0.04em;
  font-size: 0.94rem;
  color: var(--ink);
  text-decoration: none;
  white-space: nowrap;
}
.wortmarke span { color: var(--accent); }
.kopf-zeile {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
  border-left: 1px solid var(--line);
  padding-left: 1.1rem;
}
.kopf-cta {
  margin-left: auto;
  font-size: 0.86rem;
  font-weight: 600;
  text-decoration: none;
  color: var(--paper);
  background: var(--accent);
  padding: 0.5rem 1rem;
  border-radius: 999px;
  white-space: nowrap;
  transition: background .15s ease;
}
.kopf-cta:hover { background: var(--accent-ink); color: var(--paper); }

@media (max-width: 620px) {
  .kopf-zeile { display: none; }
}

/* ---------- Fuß ---------- */
.fuss {
  border-top: 1px solid var(--line);
  background: var(--paper-2);
  font-size: 0.9rem;
  color: var(--ink-soft);
}
.fuss-inner {
  max-width: var(--wide);
  margin: 0 auto;
  padding: 2.6rem 1.5rem;
  display: flex; flex-wrap: wrap; gap: 1.6rem 2rem;
  justify-content: space-between; align-items: flex-start;
}
.fuss-marke p { margin: 0.7rem 0 0; color: var(--ink-faint); max-width: 40ch; }
.fuss-links { display: flex; flex-wrap: wrap; gap: 0.4rem 1.4rem; }
.fuss-links a { color: var(--ink-soft); text-decoration: none; }
.fuss-links a:hover { color: var(--ink); text-decoration: underline; }

/* Footer-Variante der KIS-Rechtstexte (schlichter <footer> ohne .fuss) */
footer:not(.fuss) {
  border-top: 1px solid var(--line);
  background: var(--paper-2);
  font-size: 0.9rem;
  color: var(--ink-soft);
}
footer:not(.fuss) .fuss-inner { align-items: center; }

/* ---------- Rechtstexte (Impressum / Datenschutz) ---------- */
.rechtstext {
  max-width: var(--col);
  margin: 0 auto;
  padding: 4rem 1.5rem 3rem;
}
.rechtstext .kicker {
  font-family: var(--font-mono);
  font-size: 0.76rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-ink);
  margin: 0 0 1rem;
}
.rechtstext h1 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(2rem, 5vw, 2.9rem);
  line-height: 1.1; letter-spacing: -0.015em;
  margin: 0.4rem 0 2.2rem;
}
.rechtstext h2 {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 1.24rem;
  margin: 2.6rem 0 0.7rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--line);
}
.rechtstext h3 { font-size: 1.05rem; margin: 1.6rem 0 0.4rem; }
.rechtstext p, .rechtstext li { color: var(--ink-soft); }
.rechtstext p { margin: 0.7rem 0; }
.rechtstext address {
  font-style: normal;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 1.1rem 1.3rem;
  line-height: 1.75;
  color: var(--ink);
}
.rechtstext ul, .rechtstext ol { padding-left: 1.3rem; }
.rechtstext li { margin: 0.35rem 0; }
.rechtstext strong { color: var(--ink); }

.toc {
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 1.2rem 1.4rem 1.2rem;
  margin: 0 0 2.4rem;
}
.toc p {
  font-family: var(--font-mono);
  font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-faint); margin: 0 0 0.7rem;
}
.toc ol { margin: 0; padding-left: 1.3rem; }
.toc a { color: var(--accent-ink); text-decoration: none; }
.toc a:hover { text-decoration: underline; }

/* ---------- Hero ---------- */
.hero {
  max-width: var(--wide);
  margin: 0 auto;
  padding: 5rem 1.5rem 3.5rem;
}
.kicker {
  font-family: var(--font-mono);
  font-size: 0.76rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-ink);
  margin: 0 0 1.4rem;
}
.hero h1 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(2.4rem, 6vw, 4.1rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0 0 1.5rem;
  max-width: 16ch;
  text-wrap: balance;
}
.lead {
  font-size: clamp(1.1rem, 2.1vw, 1.32rem);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 46ch;
  margin: 0 0 2.4rem;
  text-wrap: pretty;
}
.legende {
  display: flex; flex-wrap: wrap; gap: 1.5rem 2rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--line);
  font-size: 0.9rem;
  color: var(--ink-soft);
}
.legende div { display: flex; align-items: center; gap: 0.6rem; max-width: 34ch; }
.legende .mk {
  flex: none;
  width: 1.4rem; height: 1.4rem; border-radius: 5px;
  display: grid; place-items: center;
  font-size: 0.8rem; font-weight: 700;
}
.legende .mk-ja { background: var(--accent-bg); color: var(--accent-ink); border: 1px solid var(--accent-line); }
.legende .mk-ist { background: var(--paper-2); color: var(--ink-faint); border: 1px dashed var(--line); }

/* ---------- Liste ---------- */
.liste { max-width: var(--wide); margin: 0 auto; padding: 1rem 1.5rem 2rem; }

.kapitel { padding: 3.2rem 0; border-top: 1px solid var(--line); }
.kapitel:first-child { border-top: none; }

.kap-kopf { display: flex; align-items: baseline; gap: 1rem; margin-bottom: 2rem; }
.kap-nr {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--accent);
  letter-spacing: 0.06em;
  flex: none;
  padding-top: 0.4rem;
}
.kap-kopf h2 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(1.5rem, 3.4vw, 2.15rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0;
  text-wrap: balance;
}
.kap-intro {
  margin: -1rem 0 2rem calc(0.82rem + 1rem);
  color: var(--ink-soft);
  max-width: 52ch;
  font-size: 1.02rem;
}

.wunsch-liste { list-style: none; margin: 0; padding: 0; display: grid; gap: 1px; background: var(--line-soft); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.wunsch {
  background: var(--paper);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0 1.1rem;
  padding: 1.25rem 1.4rem;
  transition: background .15s ease;
}
.wunsch:hover { background: var(--paper-2); }
.wunsch .check {
  grid-row: 1 / span 2;
  flex: none;
  width: 1.7rem; height: 1.7rem;
  margin-top: 0.15rem;
  border-radius: 6px;
  background: var(--accent-bg);
  border: 1px solid var(--accent-line);
  color: var(--accent-ink);
  display: grid; place-items: center;
}
.wunsch .check svg { width: 1rem; height: 1rem; }
.wunsch .soll {
  font-weight: 600;
  font-size: 1.08rem;
  line-height: 1.4;
  color: var(--ink);
  margin: 0;
  align-self: center;
  text-wrap: pretty;
}
.wunsch.hat-ist .soll { align-self: end; }
.wunsch .ist {
  grid-column: 2;
  margin: 0.35rem 0 0;
  font-size: 0.92rem;
  color: var(--ink-faint);
  display: flex; gap: 0.5rem; align-items: baseline;
  text-wrap: pretty;
}
.wunsch .ist .label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
  flex: none;
  padding-top: 0.05rem;
}
.wunsch .ist s { text-decoration-color: var(--ink-faint); }

/* ---------- Brücke ---------- */
.bruecke {
  background: var(--accent-ink);
  color: var(--paper);
  margin-top: 1rem;
}
.bruecke-inner {
  max-width: var(--wide);
  margin: 0 auto;
  padding: 5rem 1.5rem;
}
.bruecke .kicker { color: color-mix(in oklab, var(--paper) 80%, var(--accent)); }
.bruecke h2 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(1.9rem, 4.4vw, 2.9rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 0 0 1.6rem;
  max-width: 20ch;
  text-wrap: balance;
}
.bruecke p {
  font-size: clamp(1.05rem, 2vw, 1.24rem);
  line-height: 1.6;
  color: color-mix(in oklab, var(--paper) 88%, transparent);
  max-width: 52ch;
  margin: 0 0 1.3rem;
  text-wrap: pretty;
}
.bruecke a { color: var(--paper); text-decoration-color: color-mix(in oklab, var(--paper) 55%, transparent); }
.bruecke a:hover { text-decoration-color: var(--paper); }
.bruecke a.bruecke-cta {
  display: inline-block;
  margin-top: 1.4rem;
  font-weight: 600; font-size: 1rem;
  text-decoration: none;
  color: var(--accent-ink);
  background: var(--paper);
  padding: 0.85rem 1.6rem;
  border-radius: 999px;
  transition: transform .15s ease;
}
.bruecke a.bruecke-cta:hover { color: var(--accent-ink); transform: translateY(-1px); }
