/* ============================================================
   internist-wenzel.de — V2 „Von der Nacht in den Tag"
   Editorial-immersives Designsystem · Experiment 06/2026
   Display: Fraunces · Body: Instrument Sans · Akzent: Bordeaux
   ============================================================ */

/* ---------- Fonts (self-hosted, DSGVO) ---------- */
@font-face { font-family: 'Fraunces'; font-style: normal; font-weight: 300; font-display: swap; src: url('fonts/fraunces-v38-latin_latin-ext-300.woff2') format('woff2'); }
@font-face { font-family: 'Fraunces'; font-style: normal; font-weight: 400; font-display: swap; src: url('fonts/fraunces-v38-latin_latin-ext-regular.woff2') format('woff2'); }
@font-face { font-family: 'Fraunces'; font-style: normal; font-weight: 600; font-display: swap; src: url('fonts/fraunces-v38-latin_latin-ext-600.woff2') format('woff2'); }
@font-face { font-family: 'Fraunces'; font-style: italic; font-weight: 400; font-display: swap; src: url('fonts/fraunces-v38-latin_latin-ext-italic.woff2') format('woff2'); }
@font-face { font-family: 'Instrument Sans'; font-style: normal; font-weight: 400; font-display: swap; src: url('fonts/instrument-sans-v4-latin_latin-ext-regular.woff2') format('woff2'); }
@font-face { font-family: 'Instrument Sans'; font-style: normal; font-weight: 500; font-display: swap; src: url('fonts/instrument-sans-v4-latin_latin-ext-500.woff2') format('woff2'); }
@font-face { font-family: 'Instrument Sans'; font-style: normal; font-weight: 600; font-display: swap; src: url('fonts/instrument-sans-v4-latin_latin-ext-600.woff2') format('woff2'); }

/* ---------- Tokens ---------- */
:root {
    /* Himmel-Phasen */
    --night:    #0B0A12;
    --night-lo: #16131F;
    --dawn-hi:  #271320;
    --dawn-lo:  #4A1D2B;
    --day-hi:   #F5F0E8;            /* softes warmes Elfenbein (Standard-Tag-Hintergrund) */
    --day-lo:   #EFE8DC;
    /* Marke */
    --bordeaux: #7A1B2E;
    --ember:    #B43A50;
    --gold:     #C9A35C;
    /* Text */
    --moon:     #F1EDE4;            /* helle Schrift auf Nacht */
    --moon-dim: rgba(241,237,228,.62);
    --moon-faint: rgba(241,237,228,.38);
    --ink:      #1C1712;            /* dunkle Schrift auf Tag */
    --ink-dim:  #5C5346;
    --ink-faint:#8C8273;
    --line-dark: rgba(241,237,228,.14);
    --line-day:  rgba(28,23,18,.14);
    /* V1-Kompatibilität: konvertierte Inhalte nutzen diese Namen — auf die warme
       Palette gemappt, damit keine kühl-grauen Fallbacks (#F5F5F7) durchschlagen */
    --bg-white: #FCFAF6;
    --bg-alt: #EFE8DC;
    --bg-dark: #161617;
    --text-primary: var(--ink);
    --text-secondary: var(--ink-dim);
    --text-tertiary: var(--ink-faint);
    --card-border: var(--line-day);
    --bordeaux-subtle: rgba(122,27,46,.06);
    --bordeaux-light: var(--ember);
    --radius: 16px;
    --radius-sm: 12px;
    --radius-pill: 999px;
    /* Typo */
    --serif: 'Fraunces', Georgia, serif;
    --sans:  'Instrument Sans', -apple-system, sans-serif;
    --ease-out: cubic-bezier(.22,1,.36,1);
    --container: min(1240px, 92vw);
}

/* ---------- Basis ---------- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--sans); font-weight: 400; line-height: 1.65;
    color: var(--moon); background: var(--night);
    -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
    overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
::selection { background: var(--bordeaux); color: var(--moon); }

/* Subseiten sind komplett „Tag" */
body.page-sub { color: var(--ink); background: var(--day-hi); }

/* ---------- Himmel-Ebene (JS interpoliert die Farben) ---------- */
.sky {
    position: fixed; inset: 0; z-index: -2;
    background: linear-gradient(180deg, var(--night) 0%, var(--night-lo) 100%);
}
.sky canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
body.page-sub .sky { background: linear-gradient(180deg, var(--day-hi), var(--day-lo)); }

/* Korn-Textur über allem */
.grain {
    position: fixed; inset: -50%; z-index: 2000; pointer-events: none;
    width: 200%; height: 200%; opacity: .55;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.5 0 0 0 0 0.47 0 0 0 0 0.44 0 0 0 0.05 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.anim-js .grain { animation: grainShift 1.2s steps(4) infinite; }
@keyframes grainShift {
    0% { transform: translate(0,0); } 25% { transform: translate(-2%,1%); }
    50% { transform: translate(1%,-2%); } 75% { transform: translate(-1%,2%); } 100% { transform: translate(0,0); }
}

/* ---------- Navigation ---------- */
.v2-nav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    transition: background .5s, backdrop-filter .5s, color .5s, border-color .5s;
    color: var(--moon); border-bottom: 1px solid transparent;
}
.v2-nav .nav-inner {
    width: var(--container); margin: 0 auto;
    display: flex; align-items: center; justify-content: space-between;
    padding: 1.1rem 0; gap: 1.5rem;
}
.v2-nav.day, body.page-sub .v2-nav {
    color: var(--ink);
    background: rgba(245,240,232,.82);
    backdrop-filter: saturate(160%) blur(18px);
    -webkit-backdrop-filter: saturate(160%) blur(18px);
    border-bottom-color: var(--line-day);
}
.v2-logo {
    font-family: var(--serif); font-weight: 600; font-size: 1.05rem;
    letter-spacing: .01em; text-decoration: none; white-space: nowrap;
    display: flex; align-items: baseline; gap: .55rem;
}
.v2-logo .pulse-dot {
    width: 7px; height: 7px; border-radius: 50%; background: var(--ember);
    align-self: center; flex: none;
}
.anim-js .v2-logo .pulse-dot { animation: heart 2.4s ease-in-out infinite; }
@keyframes heart { 0%,100% { opacity: 1; transform: scale(1); } 14% { transform: scale(1.5); } 28% { opacity: .55; transform: scale(1); } }
.v2-links { display: flex; gap: .2rem; list-style: none; }
.v2-links a {
    text-decoration: none; font-size: .88rem; font-weight: 500;
    padding: .45rem .7rem; opacity: .75; transition: opacity .25s;
    position: relative;
}
.v2-links a::after {
    content: ""; position: absolute; left: .7rem; right: .7rem; bottom: .2rem;
    height: 1px; background: currentColor; transform: scaleX(0);
    transform-origin: right; transition: transform .4s var(--ease-out);
}
.v2-links a:hover { opacity: 1; }
.v2-links a:hover::after { transform: scaleX(1); transform-origin: left; }
.v2-cta {
    text-decoration: none; font-size: .85rem; font-weight: 600;
    padding: .6rem 1.4rem; border-radius: 999px; white-space: nowrap;
    background: var(--bordeaux); color: #fff;
    transition: background .3s, transform .3s;
}
.v2-cta:hover { background: var(--ember); }
.v2-burger { display: none; background: none; border: none; cursor: pointer; padding: .6rem; color: inherit; }
.v2-burger span { display: block; width: 22px; height: 1.5px; background: currentColor; margin: 5px 0; transition: transform .3s, opacity .3s; }

@media (max-width: 920px) {
    .v2-links {
        display: none; position: absolute; top: 100%; left: 0; right: 0;
        flex-direction: column; padding: 1rem 4vw 1.5rem;
        background: rgba(12,10,18,.97); backdrop-filter: blur(20px);
    }
    .v2-nav.day .v2-links, body.page-sub .v2-nav .v2-links { background: rgba(245,240,232,.97); }
    .v2-links.open { display: flex; }
    .v2-links a { font-size: 1.05rem; padding: .7rem .2rem; }
    .v2-burger { display: block; }
    .v2-burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
    .v2-burger.open span:nth-child(2) { opacity: 0; }
    .v2-burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
}

/* Mobile: oberen Nav-CTA ausblenden (die fixe untere Termin-Leiste übernimmt) — verhindert Abschneiden */
@media (max-width: 640px) {
    .v2-nav .nav-inner > a.v2-cta:last-child { display: none; }
    .v2-nav .nav-inner { gap: .75rem; }
}

/* ---------- Skip-Link ---------- */
.skip-link {
    position: absolute; left: -9999px; z-index: 999;
    padding: .8rem 1.4rem; background: var(--bordeaux); color: #fff; text-decoration: none;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* ---------- Hero (Nacht) ---------- */
.v2-hero {
    min-height: 100svh; display: flex; flex-direction: column;
    justify-content: center; position: relative;
    padding: 7rem 0 4rem;
}
.v2-hero .container { width: var(--container); margin: 0 auto; }
.hero-eyebrow {
    font-size: .8rem; font-weight: 500; letter-spacing: .32em;
    text-transform: uppercase; color: var(--moon-faint); margin-bottom: 2.2rem;
    display: flex; align-items: center; gap: 1.2rem;
}
.hero-eyebrow::before { content: ""; width: 56px; height: 1px; background: var(--ember); flex: none; }
.v2-hero h1 {
    font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.6rem, 7.2vw, 6.4rem);
    line-height: 1.04; letter-spacing: -.015em; max-width: 16ch;
}
.v2-hero h1 em { font-style: italic; font-weight: 400; color: var(--ember); }
.hero-sub {
    margin-top: 2.4rem; max-width: 56ch; font-size: clamp(1rem, 1.4vw, 1.15rem);
    color: var(--moon-dim); line-height: 1.75;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 3rem; align-items: center; }
.btn-day {
    text-decoration: none; font-weight: 600; font-size: .95rem;
    padding: 1rem 2.2rem; border-radius: 999px;
    background: var(--moon); color: var(--night);
    transition: background .3s, color .3s;
}
.btn-day:hover { background: var(--ember); color: #fff; }
.btn-ghost-v2 {
    text-decoration: none; font-weight: 500; font-size: .95rem;
    color: var(--moon-dim); padding: 1rem .4rem;
    border-bottom: 1px solid var(--line-dark);
    transition: color .3s, border-color .3s;
}
.btn-ghost-v2:hover { color: var(--moon); border-color: var(--ember); }
.hero-badges-v2 {
    display: flex; flex-wrap: wrap; gap: .55rem;
    margin-top: 4.5rem; padding-top: 1.8rem; border-top: 1px solid var(--line-dark);
}
/* Pill-Badges wie auf der Hauptseite — angepasst an den dunklen Hero */
.hero-badges-v2 span {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .45rem 1rem; border-radius: 999px;
    font-size: .76rem; font-weight: 500; letter-spacing: .02em;
    color: var(--moon-dim);
    background: rgba(241,237,228,.05);
    border: 1px solid var(--line-dark);
    transition: color .3s, background .3s, border-color .3s, transform .3s var(--ease-out);
}
.hero-badges-v2 span::before {
    content: ""; flex: none; width: 5px; height: 5px; border-radius: 50%;
    background: var(--ember);
}
.anim-js .hero-badges-v2 span::before { animation: badgePulse 2.6s ease-in-out infinite; }
.anim-js .hero-badges-v2 span:nth-child(2)::before { animation-delay: .35s; }
.anim-js .hero-badges-v2 span:nth-child(3)::before { animation-delay: .7s; }
.anim-js .hero-badges-v2 span:nth-child(4)::before { animation-delay: 1.05s; }
.anim-js .hero-badges-v2 span:nth-child(5)::before { animation-delay: 1.4s; }
.hero-badges-v2 span:hover {
    color: var(--moon); background: rgba(180,58,80,.14);
    border-color: rgba(180,58,80,.55); transform: translateY(-2px);
}
@keyframes badgePulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .4; transform: scale(.8); } }
.hero-scroll-hint {
    position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
    font-size: .7rem; letter-spacing: .3em; text-transform: uppercase;
    color: var(--moon-faint); display: flex; flex-direction: column; align-items: center; gap: .7rem;
}
.hero-scroll-hint::after {
    content: ""; width: 1px; height: 44px;
    background: linear-gradient(to bottom, var(--ember), transparent);
}
.anim-js .hero-scroll-hint::after { animation: drip 2.4s var(--ease-out) infinite; }
@keyframes drip { 0% { transform: scaleY(0); transform-origin: top; } 55% { transform: scaleY(1); transform-origin: top; } 56% { transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* EKG-Atemlinie im Hero */
/* EKG im normalen Fluss unter den Badges (kein Überlappen mehr) */
.hero-ekg-v2 { margin-top: 3rem; opacity: .4; pointer-events: none; }
.hero-ekg-v2 svg { width: 100%; height: 56px; display: block; }
.hero-ekg-v2 path { fill: none; stroke: var(--ember); stroke-width: 1.2; }

/* ---------- Kapitel-System ---------- */
.chapter { position: relative; padding: 9rem 0; }
.chapter .container { width: var(--container); margin: 0 auto; }
.chapter-head {
    display: grid; grid-template-columns: auto 1fr; gap: 2rem 3rem;
    align-items: baseline; margin-bottom: 4.5rem;
}
.chapter-no {
    font-family: var(--serif); font-weight: 300; font-style: italic;
    font-size: clamp(3.4rem, 7vw, 6rem); line-height: 1; opacity: .25;
}
.chapter-title-wrap { max-width: 720px; }
.chapter-kicker {
    font-size: .78rem; font-weight: 600; letter-spacing: .3em;
    text-transform: uppercase; margin-bottom: 1.1rem; color: var(--ember);
}
.chapter h2 {
    font-family: var(--serif); font-weight: 300;
    font-size: clamp(2rem, 4.4vw, 3.6rem); line-height: 1.12; letter-spacing: -.01em;
}
.chapter h2 em { font-style: italic; color: var(--ember); }
.chapter-intro { margin-top: 1.6rem; max-width: 58ch; line-height: 1.8; }

/* Themen pro Kapitel */
.theme-night { color: var(--moon); }
.theme-night .chapter-intro { color: var(--moon-dim); }
.theme-day { color: var(--ink); }
.theme-day .chapter-kicker { color: var(--bordeaux); }
.theme-day .chapter-intro { color: var(--ink-dim); }
.theme-day h2 em { color: var(--bordeaux); }

/* ---------- Editorial-Liste (Leistungen) ---------- */
.ed-list { border-top: 1px solid var(--line-day); list-style: none; }
.theme-night .ed-list { border-color: var(--line-dark); }
.ed-row {
    display: grid; grid-template-columns: 1fr auto; gap: 1.5rem 2.4rem;
    align-items: baseline; padding: 1.9rem .2rem;
    border-bottom: 1px solid var(--line-day);
    text-decoration: none; position: relative;
    transition: padding-left .45s var(--ease-out), background .45s;
}
.theme-night .ed-row { border-color: var(--line-dark); }
.ed-row::before {
    content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 0;
    background: var(--bordeaux); transition: width .45s var(--ease-out);
}
.ed-row:hover { padding-left: 1.6rem; }
.ed-row:hover::before { width: 4px; }
.ed-row-idx { display: none; }
.ed-row-main h3 {
    font-family: var(--serif); font-weight: 400;
    font-size: clamp(1.35rem, 2.4vw, 2rem); line-height: 1.2;
    transition: color .3s;
}
.ed-row:hover .ed-row-main h3 { color: var(--bordeaux); }
.theme-night .ed-row:hover .ed-row-main h3 { color: var(--ember); }
.ed-row-main p { margin-top: .45rem; font-size: .92rem; max-width: 64ch; color: var(--ink-dim); }
.theme-night .ed-row-main p { color: var(--moon-dim); }
.ed-row-tag {
    font-size: .68rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
    padding: .3rem .7rem; border: 1px solid currentColor; border-radius: 999px;
    opacity: .55; white-space: nowrap;
}
.ed-row-arrow { font-size: 1.4rem; opacity: .35; transition: opacity .3s, transform .45s var(--ease-out); }
.ed-row:hover .ed-row-arrow { opacity: 1; transform: translateX(6px); color: var(--bordeaux); }
.theme-night .ed-row:hover .ed-row-arrow { color: var(--ember); }
@media (max-width: 700px) {
    .ed-row { grid-template-columns: 1fr auto; }
    .ed-row-idx { display: none; }
}

/* ---------- Stat-Zeilen (riesige Zahlen) ---------- */
.stat-band { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 3rem; margin: 5rem 0 0; }
.stat-item-v2 { border-top: 1px solid var(--line-dark); padding-top: 1.4rem; }
.theme-day .stat-item-v2 { border-color: var(--line-day); }
.stat-num {
    font-family: var(--serif); font-weight: 300;
    font-size: clamp(3.2rem, 6vw, 5.2rem); line-height: 1; letter-spacing: -.02em;
}
.stat-num .unit { font-size: .45em; font-style: italic; opacity: .6; }
.stat-label { margin-top: .8rem; font-size: .88rem; max-width: 30ch; color: var(--moon-dim); }
.theme-day .stat-label { color: var(--ink-dim); }
.stat-src { display: block; margin-top: .4rem; font-size: .7rem; opacity: .45; }

/* ---------- Verbindungs-Dialog (Dämmerung) ---------- */
.duo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.2rem; }
.duo-card {
    text-decoration: none; padding: 2.2rem;
    border: 1px solid var(--line-dark); border-radius: 4px;
    background: rgba(241,237,228,.03);
    transition: background .4s, border-color .4s, transform .4s var(--ease-out);
}
.duo-card:hover { background: rgba(241,237,228,.07); border-color: rgba(180,58,80,.5); transform: translateY(-4px); }
.duo-card h3 {
    font-family: var(--serif); font-weight: 400; font-size: 1.3rem;
    margin-bottom: .9rem; color: var(--moon);
}
.duo-card h3 .x { color: var(--ember); font-style: italic; }
.duo-card p { font-size: .9rem; color: var(--moon-dim); line-height: 1.7; }
.duo-card .duo-more { display: inline-block; margin-top: 1.2rem; font-size: .8rem; font-weight: 600; letter-spacing: .08em; color: var(--ember); }

/* ---------- Versprechen / Ansatz (Tag) ---------- */
.steps-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 0; border-top: 1px solid var(--line-day); border-left: 1px solid var(--line-day); }
.step-cell { border-right: 1px solid var(--line-day); border-bottom: 1px solid var(--line-day); padding: 2.2rem 1.9rem 2.6rem; }
.step-cell .step-no { font-family: var(--serif); font-style: italic; font-size: 2.4rem; font-weight: 300; color: var(--bordeaux); line-height: 1; }
.step-cell h3 { font-family: var(--serif); font-weight: 600; font-size: 1.08rem; margin: 1.1rem 0 .55rem; }
.step-cell p { font-size: .88rem; color: var(--ink-dim); line-height: 1.7; }
/* Nacht-Variante (Kapitel 01 — Hausarztpraxis) */
.steps-grid.night, .steps-grid.night .step-cell { border-color: var(--line-dark); }
.steps-grid.night .step-no { color: var(--ember); font-size: .9rem; font-style: normal; }
.steps-grid.night h3 { color: var(--moon); }
.steps-grid.night p { color: var(--moon-dim); }

/* ---------- Morgenröte-Pause (Übergangssektion, bewusst hoch) ---------- */
/* Die Höhe dieser Sektion bestimmt die Länge des Nacht→Tag-Übergangs:
   v2.js interpoliert den Himmel über genau diese Scroll-Distanz. */
.sunrise-pause { min-height: 280vh; display: grid; place-items: center; padding: 8rem 0; text-align: center; }
.sunrise-quote {
    position: sticky; top: 42vh;
    font-family: var(--serif); font-weight: 300;
    font-size: clamp(1.45rem, 2.8vw, 2.4rem); line-height: 1.55;
    max-width: 34ch; margin: 0 auto; color: var(--moon);
}
.sunrise-quote em { font-style: italic; color: var(--moon); }
.sunrise-quote br + * { color: var(--moon-dim); }
@media (max-width: 700px) { .sunrise-pause { min-height: 215vh; padding: 5rem 0; } .sunrise-quote { top: 38vh; } }

/* ---------- Marquee ---------- */
.v2-marquee { overflow: hidden; padding: 3rem 0; border-top: 1px solid var(--line-day); border-bottom: 1px solid var(--line-day); }
.v2-marquee-track { display: flex; width: max-content; }
.anim-js .v2-marquee-track { animation: v2marquee 60s linear infinite; }
.v2-marquee span {
    white-space: nowrap; padding-right: .6em;
    font-family: var(--serif); font-weight: 300; font-style: italic;
    font-size: clamp(2.2rem, 5vw, 4rem); color: rgba(28,23,18,.16);
}
.v2-marquee .dot { color: rgba(122,27,46,.35); font-style: normal; }
@keyframes v2marquee { to { transform: translateX(-50%); } }

/* ---------- Portrait / Praxis ---------- */
.practice-grid { display: grid; grid-template-columns: minmax(260px, 420px) 1fr; gap: 4.5rem; align-items: start; }
.practice-photo { position: relative; }
.practice-photo img { border-radius: 4px; filter: saturate(.92); width: 100%; object-fit: cover; }
.practice-photo::after {
    content: ""; position: absolute; inset: 1.2rem -1.2rem -1.2rem 1.2rem;
    border: 1px solid var(--line-day); border-radius: 4px; z-index: -1;
}
.practice-text h3 { font-family: var(--serif); font-weight: 400; font-size: 1.6rem; margin: 2rem 0 .8rem; }
.practice-text h3:first-child { margin-top: 0; }
.practice-text p { color: var(--ink-dim); max-width: 62ch; margin-bottom: 1rem; }
.qual-list { list-style: none; margin-top: 1.4rem; }
.qual-list li {
    padding: .85rem 0; border-bottom: 1px solid var(--line-day);
    display: flex; justify-content: space-between; gap: 2rem; font-size: .92rem;
}
.qual-list li span:last-child { color: var(--ink-faint); font-size: .8rem; white-space: nowrap; }
@media (max-width: 860px) { .practice-grid { grid-template-columns: 1fr; } .practice-photo { max-width: 340px; } }

/* ---------- Partner ---------- */
.partner-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.2rem; }
.partner-card {
    text-decoration: none; border: 1px solid var(--line-day); border-radius: 4px;
    padding: 2rem; background: rgba(255,255,255,.4);
    transition: border-color .35s, transform .35s var(--ease-out);
}
.partner-card:hover { border-color: var(--bordeaux); transform: translateY(-4px); }
.partner-card img { height: 40px; width: auto; object-fit: contain; object-position: left; margin-bottom: 1.2rem; filter: grayscale(1) opacity(.75); transition: filter .35s; }
.partner-card:hover img { filter: none; }
.partner-card h3 { font-family: var(--serif); font-weight: 600; font-size: 1.02rem; margin-bottom: .5rem; }
.partner-card p { font-size: .85rem; color: var(--ink-dim); line-height: 1.65; }

/* ---------- Kontakt ---------- */
.contact-wrap { display: grid; grid-template-columns: 1.2fr 1fr; gap: 4rem; }
.contact-big {
    font-family: var(--serif); font-weight: 300;
    font-size: clamp(1.9rem, 3.6vw, 3rem); line-height: 1.2; max-width: 14ch;
}
.contact-big a { text-decoration: none; border-bottom: 2px solid rgba(122,27,46,.35); transition: border-color .3s, color .3s; }
.contact-big a:hover { color: var(--bordeaux); border-color: var(--bordeaux); }
.contact-meta { margin-top: 2.2rem; font-size: .95rem; color: var(--ink-dim); line-height: 2; }
.contact-meta a { color: var(--ink); text-decoration: none; border-bottom: 1px solid var(--line-day); }
.contact-meta a:hover { color: var(--bordeaux); }
.v2-hours { width: 100%; border-collapse: collapse; }
.v2-hours caption { text-align: left; font-family: var(--serif); font-size: 1.25rem; font-weight: 400; padding-bottom: 1rem; }
.v2-hours th { text-align: left; font-weight: 600; font-size: .9rem; padding: .8rem 0; border-bottom: 1px solid var(--line-day); width: 38%; vertical-align: top; }
.v2-hours td { font-size: .9rem; color: var(--ink-dim); padding: .8rem 0; border-bottom: 1px solid var(--line-day); }
.map-consent-v2 {
    margin-top: 3.5rem; border: 1px dashed var(--line-day); border-radius: 4px;
    padding: 3rem 2rem; text-align: center; cursor: pointer; transition: border-color .3s, background .3s;
}
.map-consent-v2:hover { border-color: var(--bordeaux); background: rgba(255,255,255,.45); }
.map-consent-v2 p { font-size: .85rem; color: var(--ink-dim); max-width: 52ch; margin: .6rem auto 0; }
.map-consent-v2 strong { font-family: var(--serif); font-weight: 600; font-size: 1.05rem; }
.map-consent-v2 .map-hint { font-size: .75rem; color: var(--ink-faint); }
.map-frame { margin-top: 3.5rem; border-radius: 4px; overflow: hidden; height: 420px; }
.map-frame iframe { width: 100%; height: 100%; border: 0; }
.emergency-v2 {
    margin-top: 3rem; padding: 1.2rem 1.6rem; border-left: 3px solid var(--bordeaux);
    background: rgba(122,27,46,.06); font-size: .9rem; color: var(--ink-dim);
}
@media (max-width: 860px) { .contact-wrap { grid-template-columns: 1fr; gap: 3rem; } }

/* ---------- Footer ---------- */
.v2-footer { padding: 5rem 0 3rem; border-top: 1px solid var(--line-day); color: var(--ink-dim); }
.v2-footer .container { width: var(--container); margin: 0 auto; }
.footer-cols { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; }
.footer-brand-v2 { font-family: var(--serif); font-weight: 600; font-size: 1.1rem; color: var(--ink); margin-bottom: .8rem; }
.footer-col-v2 .fh { font-size: .72rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 1.1rem; }
.footer-col-v2 a { display: block; text-decoration: none; font-size: .88rem; padding: .28rem 0; color: var(--ink-dim); transition: color .25s; }
.footer-col-v2 a:hover { color: var(--bordeaux); }
.footer-base { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; margin-top: 4rem; padding-top: 1.6rem; border-top: 1px solid var(--line-day); font-size: .78rem; color: var(--ink-faint); }
.footer-base a { color: inherit; text-decoration: none; margin-right: 1.4rem; }
.footer-base a:hover { color: var(--bordeaux); }
@media (max-width: 860px) { .footer-cols { grid-template-columns: 1fr 1fr; gap: 2rem; } }

/* ---------- Split-Text & Reveals ---------- */
.anim-js .stw { display: inline-block; overflow: hidden; vertical-align: bottom; }
.anim-js .stw > span { display: inline-block; transform: translateY(112%); will-change: transform; }
.anim-js .rv { opacity: 0; transform: translateY(28px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.anim-js .rv.in { opacity: 1; transform: none; }
.anim-js .rv-d1 { transition-delay: .08s; } .anim-js .rv-d2 { transition-delay: .16s; } .anim-js .rv-d3 { transition-delay: .24s; }

/* ---------- Mobile CTA ---------- */
.mobile-cta-v2 { display: none; }
@media (max-width: 700px) {
    .mobile-cta-v2 {
        display: block; position: fixed; bottom: 0; left: 0; right: 0; z-index: 90;
        padding: .8rem 4vw calc(.8rem + env(safe-area-inset-bottom));
        background: rgba(245,240,232,.92); backdrop-filter: blur(14px);
        border-top: 1px solid var(--line-day);
    }
    .mobile-cta-v2 a { display: block; text-align: center; }
    .chapter { padding: 5.5rem 0; }
    .chapter-head { grid-template-columns: 1fr; gap: 1rem; }
}

/* ============================================================
   SUBSEITEN — Re-Skin der bestehenden Inhalts-Klassen (Tag)
   ============================================================ */
body.page-sub main { padding-top: 5.2rem; }
.page-hero { padding: 4.5rem 0 3rem; border-bottom: 1px solid var(--line-day); }
.page-hero .container, .content-section .container { width: var(--container); margin: 0 auto; }
.breadcrumb { font-size: .78rem; letter-spacing: .04em; color: var(--ink-faint); margin-bottom: 1.6rem; }
.breadcrumb a { color: inherit; text-decoration: none; border-bottom: 1px solid var(--line-day); }
.breadcrumb a:hover { color: var(--bordeaux); }
.page-hero h1 {
    font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.1rem, 5vw, 3.8rem); line-height: 1.1; letter-spacing: -.01em; max-width: 22ch;
}
.page-hero .lead { margin-top: 1.4rem; max-width: 58ch; font-size: 1.05rem; color: var(--ink-dim); line-height: 1.75; }
.content-section { padding: 4.5rem 0; }
.content-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 4.5rem; align-items: start; }
@media (max-width: 980px) { .content-grid { grid-template-columns: 1fr; } }
.content-main h2 {
    font-family: var(--serif); font-weight: 400; font-size: clamp(1.5rem, 2.8vw, 2.2rem);
    line-height: 1.18; margin: 2.8rem 0 1.1rem;
}
.content-main h2:first-child { margin-top: 0; }
.content-main h3 { font-family: var(--serif); font-weight: 600; font-size: 1.18rem; margin: 2rem 0 .7rem; }
.content-main p { margin-bottom: 1.1rem; color: var(--ink-dim); max-width: 70ch; }
.content-main ul, .content-main ol { margin: 0 0 1.2rem 1.2rem; color: var(--ink-dim); }
.content-main li { margin-bottom: .55rem; }
.content-main strong { color: var(--ink); font-weight: 600; }
.content-main a { color: var(--bordeaux); text-decoration: none; border-bottom: 1px solid rgba(122,27,46,.3); }
.content-main a:hover { border-color: var(--bordeaux); }
.content-main img, .content-main picture img { border-radius: 4px; }
.content-main table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: .92rem; }
.content-main table th, .content-main table td { text-align: left; padding: .7rem .6rem; border-bottom: 1px solid var(--line-day); vertical-align: top; }
.content-main table th { font-weight: 600; }
.content-sidebar { position: sticky; top: 6rem; }
.sidebar-card, .info-box {
    border: 1px solid var(--line-day); border-radius: 16px; padding: 1.5rem 1.6rem;
    background: #FCFAF6; margin-bottom: 1.2rem; font-size: .92rem;
    box-shadow: 0 1px 2px rgba(28,23,18,.04), 0 10px 28px rgba(28,23,18,.05);
}
.info-box strong { font-family: var(--serif); font-weight: 600; font-size: 1.05rem; display: block; margin-bottom: .6rem; color: var(--ink); }
/* Sidebar-Card-Titel als feines Eyebrow-Label mit Trennlinie darunter */
.sidebar-card h3, .sidebar-card h4 {
    font-family: var(--sans); font-weight: 600; font-size: .7rem;
    text-transform: uppercase; letter-spacing: .15em; color: var(--bordeaux);
    margin: 0; padding-bottom: .55rem; border-bottom: 1px solid var(--line-day);
}
.sidebar-card p, .info-box p { color: var(--ink-dim); margin-bottom: .7rem; }
.info-box a, .sidebar-card p a { color: var(--bordeaux); }
/* Verwandte Links als saubere, einzeln tappbare Zeilen (statt Inline-Run-on) */
.sidebar-link {
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    padding: .85rem 0; text-decoration: none; color: var(--ink);
    font-weight: 500; line-height: 1.35;
    border-bottom: 1px solid var(--line-day);
    transition: color .25s var(--ease-out), padding-left .3s var(--ease-out);
}
.sidebar-card h3 + .sidebar-link, .sidebar-card h4 + .sidebar-link { padding-top: .65rem; }
.sidebar-link:last-child { border-bottom: 0; padding-bottom: .15rem; }
.sidebar-link .arrow { color: var(--bordeaux); flex: none; transition: transform .3s var(--ease-out); }
.sidebar-link:hover { color: var(--bordeaux); padding-left: .35rem; }
.sidebar-link:hover .arrow { transform: translateX(5px); }
.sidebar-link:focus-visible { outline: 2px solid var(--bordeaux); outline-offset: 3px; border-radius: 6px; }
.info-box.igel { border-left: 3px solid var(--bordeaux); }

/* ---------- Glasfenster-Karten (z. B. Qualifikationen auf „Über mich") ---------- */
.qual-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; margin: 2rem 0; }
.qual-card {
    padding: 1.5rem 1.6rem; border-radius: 16px;
    background: rgba(255,255,255,.45);
    -webkit-backdrop-filter: saturate(150%) blur(16px);
    backdrop-filter: saturate(150%) blur(16px);
    border: 1px solid rgba(255,255,255,.55);
    box-shadow: 0 1px 2px rgba(28,23,18,.04), 0 14px 34px rgba(28,23,18,.07);
}
.qual-card h4 {
    font-family: var(--sans); font-weight: 600; font-size: .7rem;
    text-transform: uppercase; letter-spacing: .15em; color: var(--bordeaux);
    margin: 0; padding-bottom: .55rem; border-bottom: 1px solid var(--line-day);
}
.qual-card ul { list-style: none; padding: 0; margin: 0; }
.qual-card li {
    font-size: .9rem; color: var(--ink-dim); line-height: 1.4;
    padding: .65rem 0; border-bottom: 1px solid var(--line-day);
}
.qual-card li:last-child { border-bottom: 0; padding-bottom: 0; }
@media (max-width: 600px) { .qual-grid { grid-template-columns: 1fr; gap: 1rem; } }
sup.ref, .ref-link { font-size: .7em; color: var(--bordeaux); text-decoration: none; }
.references-section { margin-top: 3.5rem; padding-top: 1.8rem; border-top: 1px solid var(--line-day); font-size: .82rem; color: var(--ink-faint); }
.references-section ol { margin-left: 1.2rem; }
.references-section li { margin-bottom: .45rem; }
.hours-table { width: 100%; border-collapse: collapse; }
.hours-table th, .hours-table td { text-align: left; padding: .6rem 0; border-bottom: 1px solid var(--line-day); font-size: .9rem; }
.hours-table th { font-weight: 600; width: 42%; }
.hours-table td { color: var(--ink-dim); }
.emergency-bar { margin-top: 2.5rem; padding: 1.1rem 1.5rem; border-left: 3px solid var(--bordeaux); background: rgba(122,27,46,.06); font-size: .9rem; color: var(--ink-dim); }
.faq-item { border-bottom: 1px solid var(--line-day); }
.faq-item summary { cursor: pointer; padding: 1.1rem 0; font-weight: 600; list-style: none; }
.faq-item .faq-answer { padding: 0 0 1.2rem; color: var(--ink-dim); }
.btn-primary, .btn-outline, .footer-doctolib-btn {
    display: inline-block; text-decoration: none; font-weight: 600; font-size: .92rem;
    padding: .85rem 1.9rem; border-radius: 999px; transition: background .3s, color .3s, border-color .3s;
}
.btn-primary { background: var(--bordeaux); color: #fff; }
.btn-primary:hover { background: var(--ember); }
.btn-outline { border: 1px solid rgba(122,27,46,.4); color: var(--bordeaux); }
.btn-outline:hover { border-color: var(--bordeaux); background: rgba(122,27,46,.06); }

/* ---------- Reduced Motion ---------- */
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
    .anim-js .rv, .anim-js .stw > span { opacity: 1 !important; transform: none !important; }
    .grain { display: none; }
}

/* ---------- View Transitions ---------- */
@view-transition { navigation: auto; }

/* ============================================================
   Hero-Identität (wie Hauptseite) + Himmelskörper
   ============================================================ */

/* Zentrierter Identitäts-Hero */
.hero-centered { text-align: center; }
.hero-centered .hero-eyebrow { justify-content: center; }
.hero-centered .hero-eyebrow::after { content: ""; width: 56px; height: 1px; background: var(--ember); flex: none; }
.hero-ekg-id { display: flex; justify-content: center; color: var(--ember); margin-bottom: 1.4rem; }
.hero-name-v2 {
    font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.1rem, 4.6vw, 3.4rem);
    letter-spacing: .02em; line-height: 1.18;
    color: var(--moon); margin: .7rem 0 .4rem;
}
.hero-name-v2 strong { font-weight: 600; }
.hero-location-v2 { font-size: .85rem; letter-spacing: .08em; opacity: .65; margin-bottom: 2.4rem; }
.v2-hero h1.hero-tagline {
    font-size: clamp(1.35rem, 2.6vw, 2rem);
    font-weight: 300; max-width: 640px; margin: 0 auto;
}
.hero-centered .hero-actions { justify-content: center; }
.hero-centered .hero-badges-v2 { justify-content: center; }

/* Mond — sinkt beim Scrollen, Position via JS (scroll-getrieben) */
.moon {
    position: absolute; top: 9vh; left: 50%; margin-left: -36px;
    width: 72px; height: 72px; border-radius: 50%;
    background: radial-gradient(circle at 38% 35%, rgba(253,251,244,.72) 0%, rgba(239,234,217,.6) 55%, rgba(222,214,194,.5) 100%);
    box-shadow: 0 0 34px 10px rgba(240,235,220,.08), 0 0 110px 40px rgba(240,235,220,.035);
    will-change: transform, opacity;
}
.moon::after {
    content: ''; position: absolute; inset: 0; border-radius: 50%;
    background:
        radial-gradient(circle at 62% 58%, rgba(0,0,0,.05) 0 8%, transparent 9%),
        radial-gradient(circle at 40% 68%, rgba(0,0,0,.045) 0 6%, transparent 7%),
        radial-gradient(circle at 55% 30%, rgba(0,0,0,.04) 0 10%, transparent 11%);
}

/* Sonne — glüht in der Morgenröte am Horizont auf, steigt in den Tag */
.sun {
    position: absolute; left: 50%; bottom: -130px; margin-left: -80px;
    width: 160px; height: 160px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,220,166,.7) 0%, rgba(242,166,94,.5) 42%, rgba(242,166,94,0) 72%);
    box-shadow: 0 0 90px 34px rgba(242,150,80,.16), 0 0 240px 100px rgba(242,150,80,.07);
    opacity: 0; will-change: transform, opacity;
    filter: blur(3px);
}

/* Horizont-Glut — verdichtet die Morgenröte am unteren Bildrand */
.horizon-glow {
    position: absolute; left: 0; right: 0; bottom: 0; height: 44vh;
    background: linear-gradient(180deg, transparent 0%, rgba(214,106,85,.26) 76%, rgba(240,150,90,.4) 100%);
    opacity: 0; will-change: opacity;
}

@media (max-width: 640px) {
    .moon { width: 60px; height: 60px; top: 8vh; margin-left: -30px; }
    .sun { width: 120px; height: 120px; margin-left: -60px; }
}

/* Hinweis-Kasten im Kapitel (Lebensstil-Begleitung bei GLP-1) */
.chapter-note {
    margin-top: 3rem; max-width: 760px;
    padding: 1.6rem 1.9rem;
    border-left: 3px solid var(--bordeaux);
    background: rgba(122,27,46,.05);
    border-radius: 0 10px 10px 0;
}
.chapter-note h3 {
    font-family: var(--serif); font-weight: 600; font-size: 1.08rem;
    margin-bottom: .6rem;
}
.chapter-note p { font-size: .95rem; line-height: 1.7; margin: 0; }
.chapter-note a { color: var(--bordeaux); text-underline-offset: 3px; }

/* Sanfte Eyebrow im Identitäts-Hero: Kursive statt Versalien+EKG (passt zur Nacht) */
.hero-eyebrow-soft,
.hero-eyebrow-soft::before,
.hero-centered .hero-eyebrow-soft::after { all: revert; }
.hero-eyebrow-soft {
    display: block;
    font-family: var(--serif); font-style: italic; font-weight: 400;
    font-size: 1.1rem; letter-spacing: .01em; text-transform: none;
    color: var(--moon-dim); margin-bottom: 1.1rem;
}
.hero-eyebrow-soft .soft-accent { color: var(--ember); }

/* Variante A: stille Kapitälchen-Eyebrow (gewählt 06/2026) */
.hero-eyebrow-caps,
.hero-eyebrow-caps::before,
.hero-centered .hero-eyebrow-caps::after { all: revert; }
.hero-eyebrow-caps {
    display: block;
    font-family: var(--sans); font-size: .72rem; font-weight: 600;
    letter-spacing: .32em; text-transform: uppercase;
    color: var(--moon-faint); margin-bottom: 1.5rem;
}
@media (max-width: 640px) {
    .hero-eyebrow-caps { font-size: .64rem; letter-spacing: .22em; }
}

/* ============================================================
   Epworth-Selbsttest (ESS)
   ============================================================ */
.est-progress {
    font-size: .85rem; color: var(--ink-faint); margin-bottom: 1.4rem;
    font-variant-numeric: tabular-nums;
}
.est-q {
    border: 1px solid var(--line-day); border-radius: 12px;
    padding: 1.3rem 1.4rem; margin-bottom: 1rem; background: rgba(255,255,255,.5);
}
.est-q legend {
    font-weight: 600; font-size: .98rem; padding: 0 .2rem;
    color: var(--ink);
}
.est-q .est-no { color: var(--bordeaux); font-family: var(--serif); font-style: italic; margin-right: .4rem; }
.est-opts { display: grid; grid-template-columns: repeat(4, 1fr); gap: .5rem; margin-top: .9rem; }
.est-opts label {
    display: flex; flex-direction: column; align-items: center; gap: .15rem;
    border: 1px solid var(--line-day); border-radius: 10px;
    padding: .6rem .4rem; cursor: pointer; text-align: center;
    font-size: .78rem; line-height: 1.35; color: var(--ink-dim);
    transition: border-color .2s, background .2s, color .2s;
    user-select: none;
}
.est-opts label:hover { border-color: var(--bordeaux); }
.est-opts input { position: absolute; opacity: 0; pointer-events: none; }
.est-opts label:has(input:checked) {
    background: var(--bordeaux); border-color: var(--bordeaux); color: #fff;
}
.est-opts label:has(input:focus-visible) { outline: 2px solid var(--bordeaux); outline-offset: 2px; }
.est-opts .est-val { font-family: var(--serif); font-size: 1.15rem; font-weight: 600; }
.est-result {
    margin-top: 2rem; padding: 1.7rem 1.9rem; border-radius: 12px;
    border-left: 4px solid var(--bordeaux); background: rgba(122,27,46,.05);
    display: none;
}
.est-result.show { display: block; }
.est-result h3 { font-family: var(--serif); font-weight: 600; margin-bottom: .5rem; }
.est-result .est-score { font-family: var(--serif); font-size: 2.2rem; font-weight: 600; color: var(--bordeaux); }
.est-result p { font-size: .95rem; line-height: 1.7; }
.est-reset {
    margin-top: 1rem; background: none; border: 1px solid var(--line-day);
    border-radius: 999px; padding: .45rem 1.1rem; font-size: .82rem;
    cursor: pointer; color: var(--ink-dim); font-family: var(--sans);
}
.est-reset:hover { border-color: var(--bordeaux); color: var(--bordeaux); }
.est-disclaimer { font-size: .82rem; color: var(--ink-faint); margin-top: 1.2rem; line-height: 1.6; }
@media (max-width: 640px) {
    .est-opts { grid-template-columns: repeat(2, 1fr); }
}
