/* ============================================================
   TEAM GREGOR — Designsystem
   Sora-Typografie · 3 Farbwelten · Bewegungs-/Ballett-Metapher
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-size: 16px;
  font-family: var(--font, 'Sora'), system-ui, sans-serif;
  color: var(--c-text);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.6;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
::selection { background: var(--c-accent); color: var(--c-on-accent); }

/* ---------- FONT VARIANTS ---------- */
[data-font="sora"]    { --font: 'Sora'; }
[data-font="jakarta"] { --font: 'Plus Jakarta Sans'; }
[data-font="manrope"] { --font: 'Manrope'; }

/* ============================================================
   FARBWELTEN
   ============================================================ */
/* Variante 1 — Anthrazit / Weiß / Gold */
[data-world="gold"] {
  --c-ink:       #1c1f24;
  --c-ink-2:     #262a31;
  --c-ink-soft:  #34394205;
  --c-bg:        #faf8f4;
  --c-bg-2:      #f1ede5;
  --c-surface:   #ffffff;
  --c-text:      #20242b;
  --c-text-2:    #555a63;
  --c-muted:     #8b8f97;
  --c-line:      #e7e2d8;
  --c-line-2:    #d9d3c6;
  --c-accent:    #c0a056;
  --c-accent-2:  #a5853c;
  --c-accent-soft: #f3ecdc;
  --c-on-accent: #1c1f24;
  --c-on-ink:    #f5f2ec;
  --c-on-ink-2:  #b6aa92;
}
/* Variante 2 — Navy / Weiß / Türkis */
[data-world="navy"] {
  --c-ink:       #0c1c33;
  --c-ink-2:     #13294a;
  --c-bg:        #f5f8fb;
  --c-bg-2:      #e9f0f6;
  --c-surface:   #ffffff;
  --c-text:      #102036;
  --c-text-2:    #495d76;
  --c-muted:     #82909f;
  --c-line:      #e0e8f0;
  --c-line-2:    #cdd9e5;
  --c-accent:    #14b3ac;
  --c-accent-2:  #0d8f89;
  --c-accent-soft: #d7f2f0;
  --c-on-accent: #04201e;
  --c-on-ink:    #eef4fa;
  --c-on-ink-2:  #8fa6c0;
}
/* Variante 3 — Dunkelgrau / Weiß / Kupfer */
[data-world="kupfer"] {
  --c-ink:       #24262a;
  --c-ink-2:     #313438;
  --c-bg:        #f8f6f3;
  --c-bg-2:      #efe9e3;
  --c-surface:   #ffffff;
  --c-text:      #26282c;
  --c-text-2:    #585b60;
  --c-muted:     #8a8c90;
  --c-line:      #e8e2da;
  --c-line-2:    #d8cfc4;
  --c-accent:    #c0764a;
  --c-accent-2:  #a25e38;
  --c-accent-soft: #f3e5da;
  --c-on-accent: #2a160c;
  --c-on-ink:    #f3efea;
  --c-on-ink-2:  #b3a799;
}
/* Variante 4 — Praxis (aktuell): medizinisches Blau / Weiß / Petrol */
[data-world="praxis"] {
  --c-ink:       #1d3a48;
  --c-ink-2:     #274c5d;
  --c-bg:        #ffffff;
  --c-bg-2:      #eef4f8;
  --c-surface:   #ffffff;
  --c-text:      #1f323c;
  --c-text-2:    #4f636e;
  --c-muted:     #87969f;
  --c-line:      #e3ebf0;
  --c-line-2:    #cedce4;
  --c-accent:    #2ea3f2;
  --c-accent-2:  #1c7fc4;
  --c-accent-soft: #dceefb;
  --c-on-accent: #ffffff;
  --c-on-ink:    #eef5fa;
  --c-on-ink-2:  #9cb3c0;
}

/* ============================================================
   LAYOUT PRIMITIVES
   ============================================================ */
.tg-root { min-height: 100vh; position: relative; background: var(--c-bg); color: var(--c-text); font-family: var(--font, 'Sora'), system-ui, sans-serif; }
.wrap { width: min(1240px, 92vw); margin-inline: auto; }
.wrap-narrow { width: min(940px, 92vw); margin-inline: auto; }

.eyebrow {
  display: inline-flex; align-items: center; gap: .55em;
  font-size: clamp(.68rem, .8vw, .78rem);
  font-weight: 600; letter-spacing: .22em; text-transform: uppercase;
  color: var(--c-accent-2);
}
.eyebrow::before {
  content: ""; width: 26px; height: 1.5px; background: var(--c-accent);
  display: inline-block;
}
.eyebrow.center::before { display: none; }

h1, h2, h3, h4 { margin: 0; font-weight: 600; line-height: 1.08; letter-spacing: -0.02em; color: var(--c-text); }
.display {
  font-size: clamp(2.6rem, 7vw, 5.4rem);
  font-weight: 700; letter-spacing: -0.035em; line-height: 0.96;
}
.h2 { font-size: clamp(1.9rem, 3.6vw, 3rem); font-weight: 650; }
.lead { font-size: clamp(1.05rem, 1.5vw, 1.32rem); color: var(--c-text-2); font-weight: 400; line-height: 1.5; }
.muted { color: var(--c-muted); }

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .6em;
  font-weight: 600; font-size: .98rem; letter-spacing: -0.01em;
  padding: .92em 1.5em; border-radius: 100px; border: 1.5px solid transparent;
  transition: transform .35s cubic-bezier(.2,.8,.2,1), background .25s, color .25s, box-shadow .35s, border-color .25s;
  white-space: nowrap;
}
.btn svg { width: 1.05em; height: 1.05em; transition: transform .35s cubic-bezier(.2,.8,.2,1); }
.btn-primary { background: var(--c-accent); color: var(--c-on-accent); box-shadow: 0 8px 22px -10px var(--c-accent); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 30px -12px var(--c-accent); }
.btn-primary:hover svg { transform: translateX(3px); }
.btn-ink { background: var(--c-ink); color: var(--c-on-ink); }
.btn-ink:hover { transform: translateY(-2px); box-shadow: 0 16px 30px -16px var(--c-ink); }
.btn-ink:hover svg { transform: translateX(3px); }
.btn-outline { background: transparent; color: var(--c-text); border-color: var(--c-line-2); }
.btn-outline:hover { border-color: var(--c-accent); color: var(--c-accent-2); transform: translateY(-2px); }
.btn-ghost-light { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.28); backdrop-filter: blur(6px); }
.btn-ghost-light:hover { background: rgba(255,255,255,.18); transform: translateY(-2px); }
.btn-sm { padding: .62em 1.1em; font-size: .88rem; }

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar {
  position: sticky; top: 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.5rem; padding: .85rem 0;
  background: color-mix(in srgb, var(--c-bg) 78%, transparent);
  backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, background .3s;
}
.topbar.scrolled { border-color: var(--c-line); }
.topbar > .wrap { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; width: min(1240px,92vw); }
.brand { display: flex; align-items: center; gap: .7rem; cursor: pointer; }
.brand-mark { width: 38px; height: 38px; flex: none; }
.brand-name { font-weight: 700; letter-spacing: .14em; font-size: .95rem; text-transform: uppercase; }
.brand-name small { display: block; font-size: .58rem; letter-spacing: .26em; color: var(--c-muted); font-weight: 500; margin-top: 2px; }
.nav { display: flex; align-items: center; gap: 2rem; }
.nav-links { display: flex; gap: 1.7rem; }
.nav-links a { font-size: .92rem; font-weight: 500; color: var(--c-text-2); position: relative; padding: .2em 0; transition: color .2s; cursor: pointer; }
.nav-links a::after { content: ""; position: absolute; left: 0; bottom: -2px; height: 1.5px; width: 0; background: var(--c-accent); transition: width .28s ease; }
.nav-links a:hover { color: var(--c-text); }
.nav-links a:hover::after { width: 100%; }
.nav-right { display: flex; align-items: center; gap: 1rem; }
.lang { display: flex; align-items: center; gap: 2px; font-size: .8rem; font-weight: 600; color: var(--c-muted); border: 1px solid var(--c-line-2); border-radius: 100px; padding: 3px; }
.lang button { background: none; border: none; padding: .25em .6em; border-radius: 100px; color: var(--c-muted); font-weight: 600; font-size: .78rem; transition: .2s; }
.lang button.on { background: var(--c-ink); color: var(--c-on-ink); }
.menu-toggle { display: none; background: none; border: none; padding: .5rem; color: var(--c-ink); line-height: 0; cursor: pointer; }
.menu-toggle svg { width: 24px; height: 24px; display: block; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; padding-top: clamp(2rem, 5vw, 4rem); padding-bottom: clamp(3rem, 6vw, 5rem); overflow: hidden; }
.hero-grid { display: grid; gap: 2.4rem; align-items: center; }
.hero-eyebrow-row { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.4rem; }
.hero h1 { margin-bottom: 1.3rem; }
.hero h1 .accentword { color: var(--c-accent-2); }
.hero-sub { max-width: 30ch; margin-bottom: 2rem; }
.hero-cta { display: flex; gap: .8rem; flex-wrap: wrap; }
.hero-stats { display: flex; gap: 2.2rem; margin-top: 2.6rem; flex-wrap: wrap; }
.hero-stat .n { font-size: clamp(1.6rem, 2.4vw, 2.1rem); font-weight: 700; letter-spacing: -0.03em; color: var(--c-text); }
.hero-stat .l { font-size: .82rem; color: var(--c-muted); font-weight: 500; }
.hero-media { position: relative; }
.hero-media image-slot { width: 100%; height: clamp(300px, 48vw, 560px); border-radius: 22px; box-shadow: 0 40px 80px -40px rgba(20,22,28,.4); }
.hero-badge {
  position: absolute; bottom: 18px; left: 18px; right: 18px;
  display: flex; align-items: center; gap: .8rem;
  padding: .8rem 1rem; border-radius: 16px;
  background: color-mix(in srgb, var(--c-ink) 82%, transparent);
  backdrop-filter: blur(10px); color: var(--c-on-ink);
}
.hero-badge .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--c-accent); flex: none; box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-accent) 30%, transparent); }
.hero-badge .t { font-size: .86rem; font-weight: 600; }
.hero-badge .s { font-size: .74rem; color: var(--c-on-ink-2); }

/* Hero variant: FOTO (full-bleed overlay) */
[data-hero="foto"] .hero { padding: 0; }
[data-hero="foto"] .hero-fullbleed { position: relative; min-height: clamp(560px, 82vh, 820px); display: flex; align-items: flex-end; }
[data-hero="foto"] .hero-fullbleed image-slot { position: absolute; inset: 0; width: 100%; height: 100%; border-radius: 0; }
[data-hero="foto"] .hero-scrim { position: absolute; inset: 0; background: linear-gradient(180deg, color-mix(in srgb,var(--c-ink) 26%,transparent) 0%, transparent 32%, color-mix(in srgb,var(--c-ink) 30%,transparent) 60%, color-mix(in srgb,var(--c-ink) 88%,transparent) 100%); }
[data-hero="foto"] .hero-fullbleed .hero-inner { position: relative; z-index: 2; padding-bottom: clamp(2.4rem,5vw,4.4rem); color: #fff; }
[data-hero="foto"] .hero-fullbleed h1 { color: #fff; }
[data-hero="foto"] .hero-fullbleed h1 .accentword { color: var(--c-accent); }
[data-hero="foto"] .hero-fullbleed .hero-sub { color: rgba(255,255,255,.85); }
[data-hero="foto"] .hero-fullbleed .hero-stat .n { color: #fff; }
[data-hero="foto"] .hero-fullbleed .hero-stat .l { color: rgba(255,255,255,.7); }
[data-hero="foto"] .hero-media-side { display: none; }

/* Hero variant: SPLIT (text left, photo right) */
[data-hero="split"] .hero-grid { grid-template-columns: 1.02fr 1fr; }
[data-hero="split"] .hero-fullbleed { display: none; }

/* Hero variant: GRAFISCH (abstract motion, framed photo) */
[data-hero="grafisch"] .hero-grid { grid-template-columns: 1.1fr .9fr; }
[data-hero="grafisch"] .hero-fullbleed { display: none; }
[data-hero="grafisch"] .hero-media image-slot { border-radius: 200px 200px 22px 22px; }
[data-hero="grafisch"] .hero { background: linear-gradient(180deg, var(--c-bg) 0%, var(--c-bg-2) 100%); }

/* Motion lines (ballet metaphor) */
.motion-lines { position: absolute; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.motion-lines svg { position: absolute; width: 120%; height: 120%; }
.motion-lines path { fill: none; stroke: var(--c-accent); opacity: .16; }
.motion-lines .l-soft { stroke: var(--c-accent); opacity: .08; }
@keyframes drawline { from { stroke-dashoffset: var(--len); } to { stroke-dashoffset: 0; } }
.hero > .wrap, .hero-fullbleed { position: relative; z-index: 2; }

/* ============================================================
   PHILOSOPHIE STRIP
   ============================================================ */
.philo { padding: clamp(3rem,6vw,5.5rem) 0; }
.philo-inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,5rem); align-items: end; }
.philo-quote { font-size: clamp(1.5rem, 2.8vw, 2.4rem); font-weight: 500; line-height: 1.25; letter-spacing: -0.02em; }
.philo-quote .hl { color: var(--c-accent-2); }
.philo-side p { color: var(--c-text-2); margin: 0 0 1rem; }
.philo-marks { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.4rem; }
.chip { display: inline-flex; align-items: center; gap: .45em; padding: .5em 1em; border-radius: 100px; background: var(--c-surface); border: 1px solid var(--c-line); font-size: .85rem; font-weight: 500; color: var(--c-text-2); }
.chip .d { width: 6px; height: 6px; border-radius: 50%; background: var(--c-accent); }

/* ============================================================
   SYMPTOM-/BESCHWERDE-LEISTE
   ============================================================ */
.symptombar { border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); background: var(--c-surface); position: relative; z-index: 3; }
.symptombar-inner { display: flex; align-items: center; gap: 1.4rem; padding: 1.05rem 0; }
.symptombar-label { display: inline-flex; align-items: center; gap: .55rem; font-weight: 600; font-size: .92rem; letter-spacing: -0.01em; color: var(--c-text); white-space: nowrap; flex: none; }
.symptombar-label svg { width: 1.15em; height: 1.15em; color: var(--c-accent); }
.symptom-chips { display: flex; gap: .5rem; flex-wrap: wrap; }
.symptom-chip { display: inline-flex; align-items: center; padding: .5em 1.05em; border-radius: 100px; border: 1px solid var(--c-line-2); background: var(--c-bg); font-family: inherit; font-size: .88rem; font-weight: 500; color: var(--c-text-2); transition: border-color .22s, color .22s, background .22s, transform .22s; }
.symptom-chip:hover { border-color: var(--c-accent); color: var(--c-accent-2); background: var(--c-accent-soft); transform: translateY(-2px); }
@keyframes cardflash {
  0%   { box-shadow: 0 0 0 0 color-mix(in srgb, var(--c-accent) 55%, transparent); }
  22%  { box-shadow: 0 0 0 5px color-mix(in srgb, var(--c-accent) 45%, transparent); }
  100% { box-shadow: 0 24px 50px -30px rgba(20,22,28,.45); }
}
.tcard.flash { animation: cardflash 2s cubic-bezier(.2,.8,.2,1); border-color: var(--c-accent); }

/* ============================================================
   TEAM-MODULE
   ============================================================ */
.teams { padding: clamp(2.5rem,5vw,4rem) 0 clamp(3.5rem,7vw,6rem); }
.section-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 2rem; margin-bottom: 2.6rem; flex-wrap: wrap; }
.section-head .st h2 { margin-top: .7rem; }
.section-head .sd { max-width: 34ch; color: var(--c-text-2); }

.teams-top { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
.teams-row2 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; margin-top: 1.4rem; }

/* ---- TEAM CARD (base) ---- */
.tcard {
  position: relative; display: flex; flex-direction: column;
  background: var(--c-surface); border: 1px solid var(--c-line);
  border-radius: 20px; overflow: hidden; isolation: isolate;
  transition: transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .5s cubic-bezier(.2,.8,.2,1), border-color .4s;
  cursor: pointer;
}
.tcard-media { position: relative; overflow: hidden; }
.tcard-media image-slot { width: 100%; height: 100%; border-radius: 0; transition: transform .7s cubic-bezier(.2,.8,.2,1); }
.tcard.big .tcard-media { aspect-ratio: 4 / 3.3; }
.tcard.small .tcard-media { aspect-ratio: 4 / 2.7; }
.tcard-num { position: absolute; top: 14px; left: 14px; z-index: 3; font-size: .72rem; font-weight: 700; letter-spacing: .12em; color: #fff; background: color-mix(in srgb,var(--c-ink) 55%,transparent); backdrop-filter: blur(6px); padding: .35em .7em; border-radius: 100px; }
.tcard-tag { position: absolute; top: 14px; right: 14px; z-index: 3; font-size: .68rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--c-on-accent); background: var(--c-accent); padding: .35em .7em; border-radius: 100px; }
.tcard-body { padding: 1.3rem 1.4rem 1.45rem; display: flex; flex-direction: column; flex: 1; gap: .55rem; }
.tcard.big .tcard-body { padding: 1.6rem 1.7rem 1.7rem; }
.tcard-title { font-size: 1.18rem; font-weight: 650; letter-spacing: -0.02em; display: flex; align-items: center; gap: .5rem; }
.tcard.big .tcard-title { font-size: clamp(1.35rem,1.9vw,1.7rem); }
.tcard-sub { font-size: .72rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--c-accent-2); margin-bottom: -.2rem; }
.tcard-desc { font-size: .94rem; color: var(--c-text-2); line-height: 1.5; }
.tcard-foot { margin-top: auto; padding-top: 1rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.tcard-link { display: inline-flex; align-items: center; gap: .5em; font-size: .9rem; font-weight: 600; color: var(--c-text); transition: gap .3s, color .3s; }
.tcard-link.is-cta { color: var(--c-accent-2); font-weight: 650; }
.tcard-link.is-soon { color: var(--c-muted); font-weight: 500; }
[data-card="overlay"] .tcard-link.is-cta { color: #fff; }
[data-card="overlay"] .tcard-link.is-soon { color: rgba(255,255,255,.72); }
.tcard-link svg { width: 1.05em; height: 1.05em; transition: transform .35s cubic-bezier(.2,.8,.2,1); }
.tcard-members { display: flex; align-items: center; }
.tcard-members .av { width: var(--av-size, 42px); height: var(--av-size, 42px); border-radius: 50%; border: 2.5px solid var(--c-surface); margin-left: calc(var(--av-overlap, 13px) * -1); background: var(--c-bg-2); overflow: hidden; flex: none; box-shadow: 0 2px 6px -2px rgba(20,22,28,.35); }
.tcard-members .av:first-child { margin-left: 0; }
.tcard-members .av-slot { display: block; }
.tcard-members .av-ph { display: grid; place-items: center; color: var(--c-muted); }
.tcard-members .av-ph svg { width: 56%; height: 56%; }
.tcard-members .more { background: var(--c-ink); color: var(--c-on-ink); display: grid; place-items: center; font-size: .78rem; font-weight: 700; }

/* ---- HOVER VARIANTS ---- */
[data-hover="lift"] .tcard:hover { transform: translateY(-8px); box-shadow: 0 30px 60px -34px rgba(20,22,28,.5); border-color: var(--c-line-2); }
[data-hover="lift"] .tcard:hover .tcard-link { gap: .85em; color: var(--c-accent-2); }
[data-hover="lift"] .tcard:hover .tcard-link svg { transform: translateX(4px); }

[data-hover="zoom"] .tcard:hover { transform: translateY(-4px); box-shadow: 0 28px 55px -34px rgba(20,22,28,.5); }
[data-hover="zoom"] .tcard:hover .tcard-media image-slot { transform: scale(1.07); }
[data-hover="zoom"] .tcard:hover .tcard-link svg { transform: translateX(4px); }

[data-hover="reveal"] .tcard { }
[data-hover="reveal"] .tcard::after { content: ""; position: absolute; inset: 0; border: 2px solid var(--c-accent); border-radius: 20px; opacity: 0; transform: scale(.98); transition: opacity .4s, transform .4s; pointer-events: none; z-index: 4; }
[data-hover="reveal"] .tcard:hover { transform: translateY(-5px); box-shadow: 0 30px 60px -36px rgba(20,22,28,.5); }
[data-hover="reveal"] .tcard:hover::after { opacity: 1; transform: scale(1); }
[data-hover="reveal"] .tcard:hover .tcard-media image-slot { transform: scale(1.04); }
[data-hover="reveal"] .tcard:hover .tcard-link svg { transform: translateX(4px); }

/* ---- CARD STYLE VARIANTS ---- */
/* overlay: text sits on the photo */
[data-card="overlay"] .tcard-media { aspect-ratio: auto; }
[data-card="overlay"] .tcard.big .tcard-media { min-height: 420px; }
[data-card="overlay"] .tcard.small .tcard-media { min-height: 300px; }
[data-card="overlay"] .tcard-media { height: 100%; }
[data-card="overlay"] .tcard { min-height: 320px; }
[data-card="overlay"] .tcard.big { min-height: 420px; }
[data-card="overlay"] .tcard-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, color-mix(in srgb,var(--c-ink) 86%,transparent) 100%); z-index: 1; }
[data-card="overlay"] .tcard-body { position: absolute; inset: auto 0 0 0; z-index: 3; color: #fff; padding: 1.6rem 1.5rem 1.5rem; }
[data-card="overlay"] .tcard.big .tcard-body { padding: 1.9rem 1.8rem 1.7rem; }
[data-card="overlay"] .tcard-title { color: #fff; }
[data-card="overlay"] .tcard-desc { color: rgba(255,255,255,.82); }
[data-card="overlay"] .tcard-foot { border: none; }
[data-card="overlay"] .tcard-link { color: #fff; }
[data-card="overlay"] .tcard-members .av { border-color: rgba(255,255,255,.85); }

/* minimal: no photo emphasis, clean card */
[data-card="minimal"] .tcard { background: var(--c-surface); }
[data-card="minimal"] .tcard.big .tcard-media { aspect-ratio: 5/2.2; }
[data-card="minimal"] .tcard.small .tcard-media { aspect-ratio: 5/2; }
[data-card="minimal"] .tcard-num { background: var(--c-bg-2); color: var(--c-text-2); }

/* ---- MODULE LAYOUT: MAGAZIN ---- */
[data-modules="magazin"] .teams-top { grid-template-columns: 1.5fr 1fr; grid-template-rows: auto auto; }
[data-modules="magazin"] .teams-top .tcard:nth-child(1) { grid-row: span 2; }
[data-modules="magazin"] .teams-top .tcard:nth-child(1) .tcard-media { aspect-ratio: 4/4.4; }
[data-modules="magazin"] .teams-row2 { grid-template-columns: repeat(3,1fr); }
@media (max-width: 860px) {
  [data-modules="magazin"] .teams-top { grid-template-columns: 1fr; }
  [data-modules="magazin"] .teams-top .tcard:nth-child(1) { grid-row: auto; }
  [data-modules="magazin"] .teams-top .tcard:nth-child(1) .tcard-media { aspect-ratio: 4/3; }
}

/* ============================================================
   ZUKUNFTS-MODULE (Bald verfügbar)
   ============================================================ */
.future { padding: clamp(3rem,6vw,5.5rem) 0; }
.future-inner { background: var(--c-ink); border-radius: 28px; padding: clamp(2rem,4vw,3.4rem); position: relative; overflow: hidden; color: var(--c-on-ink); }
.future-inner .motion-lines path { opacity: .2; }
.future-inner .motion-lines .l-soft { opacity: .1; }
.future-head { position: relative; z-index: 2; max-width: 52ch; margin-bottom: 2.4rem; }
.future-head .eyebrow { color: var(--c-accent); }
.future-head h2 { color: #fff; margin-top: .8rem; }
.future-head p { color: var(--c-on-ink-2); margin-top: .8rem; }
.future-grid { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
.fcard { background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.1); border-radius: 16px; padding: 1.3rem 1.35rem; transition: background .3s, transform .4s, border-color .3s; }
.fcard:hover { background: rgba(255,255,255,.08); transform: translateY(-4px); border-color: rgba(255,255,255,.2); }
.fcard-ic { width: 40px; height: 40px; border-radius: 11px; background: color-mix(in srgb,var(--c-accent) 22%, transparent); display: grid; place-items: center; color: var(--c-accent); margin-bottom: .9rem; }
.fcard-ic svg { width: 20px; height: 20px; }
.fcard h4 { color: #fff; font-size: 1.02rem; font-weight: 600; display: flex; align-items: center; gap: .6rem; }
.fcard p { color: var(--c-on-ink-2); font-size: .86rem; margin: .45rem 0 0; line-height: 1.5; }
.soon { font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--c-accent); border: 1px solid color-mix(in srgb,var(--c-accent) 40%,transparent); padding: .2em .5em; border-radius: 100px; }

/* ============================================================
   CTA BAND
   ============================================================ */
.ctaband { padding: 0 0 clamp(3.5rem,7vw,6rem); }
.ctaband-inner { position: relative; overflow: hidden; border-radius: 28px; background: linear-gradient(135deg, var(--c-accent) 0%, var(--c-accent-2) 100%); padding: clamp(2.4rem,5vw,4rem); display: grid; grid-template-columns: 1.4fr 1fr; gap: 2rem; align-items: center; }
.ctaband-inner h2 { color: var(--c-on-accent); font-size: clamp(1.7rem,3vw,2.6rem); }
.ctaband-inner p { color: color-mix(in srgb,var(--c-on-accent) 78%, transparent); margin: .8rem 0 0; max-width: 40ch; }
.ctaband-actions { display: flex; gap: .8rem; justify-content: flex-end; flex-wrap: wrap; }
.ctaband .btn-ink { background: var(--c-ink); }
.ctaband-inner .motion-lines path { stroke: var(--c-on-accent); opacity: .14; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--c-ink); color: var(--c-on-ink); padding: clamp(3rem,5vw,4.5rem) 0 2rem; }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 2rem; padding-bottom: 2.8rem; border-bottom: 1px solid rgba(255,255,255,.1); }
.footer .brand-name { color: #fff; }
.footer .brand-name small { color: var(--c-on-ink-2); }
.footer-blurb { color: var(--c-on-ink-2); font-size: .92rem; margin: 1.1rem 0 0; max-width: 32ch; }
.footer h5 { color: #fff; font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; margin: 0 0 1.1rem; }
.footer-col a, .footer-col p { display: block; color: var(--c-on-ink-2); font-size: .92rem; margin-bottom: .6rem; transition: color .2s; cursor: pointer; }
.footer-col a:hover { color: var(--c-accent); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding-top: 1.6rem; flex-wrap: wrap; }
.footer-bottom p { color: var(--c-on-ink-2); font-size: .82rem; margin: 0; }
.footer-bottom .links { display: flex; gap: 1.4rem; }
.footer-bottom .links a { color: var(--c-on-ink-2); font-size: .82rem; cursor: pointer; }

/* ============================================================
   DETAIL PAGE
   ============================================================ */
.back-link { display: inline-flex; align-items: center; gap: .5em; font-size: .9rem; font-weight: 600; color: var(--c-text-2); margin: 1.6rem 0 0; transition: gap .3s, color .2s; cursor: pointer; }
.back-link:hover { gap: .8em; color: var(--c-text); }
.back-link svg { width: 1.1em; height: 1.1em; }

.dhero { padding: 1.5rem 0 clamp(3rem,5vw,4.5rem); position: relative; overflow: hidden; }
.dhero-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(2rem,4vw,3.5rem); align-items: center; margin-top: 1.6rem; }
.dhero h1 { font-size: clamp(2.4rem,5vw,4rem); letter-spacing: -0.035em; margin-bottom: 1.2rem; }
.dhero .lead { margin-bottom: 1.8rem; }
.dhero-media image-slot { width: 100%; height: clamp(320px, 44vw, 540px); border-radius: 22px; box-shadow: 0 40px 80px -42px rgba(20,22,28,.45); }
.dhero-facts { display: flex; gap: 2rem; margin-top: 1.4rem; flex-wrap: wrap; }
.dfact .n { font-size: 1.7rem; font-weight: 700; letter-spacing: -0.03em; color: var(--c-accent-2); }
.dfact .l { font-size: .8rem; color: var(--c-muted); }

.section { padding: clamp(2.8rem,5vw,4.5rem) 0; }
.section.alt { background: var(--c-bg-2); }

/* members */
.members { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 1.2rem; margin-top: 2.4rem; }
.mcard { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 18px; overflow: hidden; transition: transform .45s cubic-bezier(.2,.8,.2,1), box-shadow .45s; }
.mcard:hover { transform: translateY(-6px); box-shadow: 0 26px 50px -34px rgba(20,22,28,.45); }
.mcard image-slot { width: 100%; aspect-ratio: 1/1.08; border-radius: 0; }
.mcard-body { padding: 1.1rem 1.2rem 1.3rem; }
.mcard-name { font-size: 1.05rem; font-weight: 650; letter-spacing: -0.01em; }
.mcard-role { font-size: .85rem; color: var(--c-accent-2); font-weight: 600; margin-top: .15rem; }
.mcard-tags { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .8rem; }
.mtag { font-size: .72rem; color: var(--c-text-2); background: var(--c-bg-2); border-radius: 100px; padding: .3em .7em; }

/* accordion */
.accordion { margin-top: 2.2rem; border-top: 1px solid var(--c-line); }
.acc-item { border-bottom: 1px solid var(--c-line); }
.acc-head { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: 1.4rem 0; background: none; border: none; text-align: left; color: var(--c-text); }
.acc-head:hover { color: var(--c-accent-2); }
.acc-head .at { display: flex; align-items: center; gap: 1rem; }
.acc-head .ai { width: 34px; height: 34px; flex: none; border-radius: 9px; background: var(--c-accent-soft); color: var(--c-accent-2); display: grid; place-items: center; font-weight: 700; font-size: .82rem; }
.acc-head .atitle { font-size: clamp(1.05rem,1.6vw,1.28rem); font-weight: 600; letter-spacing: -0.01em; }
.acc-icon { width: 30px; height: 30px; flex: none; border-radius: 50%; border: 1.5px solid var(--c-line-2); display: grid; place-items: center; transition: transform .4s, background .3s, border-color .3s, color .3s; color: var(--c-text-2); }
.acc-item.open .acc-icon { transform: rotate(45deg); background: var(--c-accent); border-color: var(--c-accent); color: var(--c-on-accent); }
.acc-panel { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .42s cubic-bezier(.2,.8,.2,1); }
.acc-item.open .acc-panel { grid-template-rows: 1fr; }
.acc-panel-inner { overflow: hidden; }
.acc-content { padding: 0 0 1.6rem 3rem; color: var(--c-text-2); max-width: 70ch; }
.acc-content p { margin: 0 0 1rem; }
.acc-method-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap: .8rem; margin-top: 1rem; }
.method { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 14px; padding: 1rem 1.1rem; }
.method h5 { margin: 0 0 .3rem; font-size: .96rem; color: var(--c-text); font-weight: 600; }
.method p { margin: 0; font-size: .85rem; }
.prosbox { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1rem; }
.prosbox ul { margin: .5rem 0 0; padding-left: 0; list-style: none; }
.prosbox li { display: flex; gap: .6em; align-items: flex-start; font-size: .9rem; margin-bottom: .5rem; }
.prosbox li svg { width: 1.05em; height: 1.05em; flex: none; margin-top: .2em; }
.prosbox .pro li svg { color: var(--c-accent-2); }
.prosbox .con li svg { color: var(--c-muted); }
.prosbox h5 { margin: 0; font-size: .78rem; text-transform: uppercase; letter-spacing: .1em; color: var(--c-muted); }
.steps { counter-reset: step; margin-top: 1rem; }
.step { display: flex; gap: 1rem; padding: .7rem 0; }
.step .sn { counter-increment: step; width: 28px; height: 28px; flex: none; border-radius: 50%; background: var(--c-ink); color: var(--c-on-ink); display: grid; place-items: center; font-size: .82rem; font-weight: 700; }
.step .sn::before { content: counter(step); }
.step .stx h5 { margin: 0; font-size: .96rem; color: var(--c-text); }
.step .stx p { margin: .2rem 0 0; font-size: .88rem; }

/* videos */
.videos { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.2rem; margin-top: 2.4rem; }
.vcard { border-radius: 18px; overflow: hidden; background: var(--c-surface); border: 1px solid var(--c-line); transition: transform .45s cubic-bezier(.2,.8,.2,1), box-shadow .45s; }
.vcard:hover { transform: translateY(-5px); box-shadow: 0 26px 50px -34px rgba(20,22,28,.4); }
.vthumb { position: relative; aspect-ratio: 16/10; background: var(--c-ink); overflow: hidden; }
.vthumb image-slot { position: absolute; inset: 0; width: 100%; height: 100%; border-radius: 0; }
.vthumb::after { content: ""; position: absolute; inset: 0; background: color-mix(in srgb,var(--c-ink) 30%, transparent); }
.vplay { position: absolute; z-index: 2; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 58px; height: 58px; border-radius: 50%; background: rgba(255,255,255,.92); display: grid; place-items: center; color: var(--c-ink); transition: transform .4s, background .3s; }
.vcard:hover .vplay { transform: translate(-50%,-50%) scale(1.1); background: var(--c-accent); color: var(--c-on-accent); }
.vplay svg { width: 22px; height: 22px; margin-left: 3px; }
.vlabel { position: absolute; z-index: 2; top: 12px; left: 12px; font-size: .68rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: #fff; background: color-mix(in srgb,var(--c-ink) 55%, transparent); backdrop-filter: blur(6px); padding: .3em .7em; border-radius: 100px; }
.vbody { padding: 1rem 1.2rem 1.2rem; }
.vbody h4 { font-size: 1rem; font-weight: 600; }
.vbody p { font-size: .85rem; color: var(--c-text-2); margin: .3rem 0 0; }

/* zuweiser box */
.referral { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; margin-top: 2.4rem; }
.refcard { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 18px; padding: 1.6rem 1.7rem; }
.refcard .eyebrow { margin-bottom: .8rem; }
.refcard h4 { font-size: 1.2rem; font-weight: 600; }
.refcard p { color: var(--c-text-2); font-size: .92rem; margin: .6rem 0 1.2rem; }

/* ============================================================
   ENTRANCE ANIMATIONS
   ============================================================ */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1); }
  .reveal.in { opacity: 1; transform: none; }
  .reveal[data-d="1"] { transition-delay: .08s; }
  .reveal[data-d="2"] { transition-delay: .16s; }
  .reveal[data-d="3"] { transition-delay: .24s; }
  .reveal[data-d="4"] { transition-delay: .32s; }
  .reveal[data-d="5"] { transition-delay: .40s; }
}

/* ---- Leistungs-Akkordeon (Home) ---- */
.leist-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem; margin-top: 1.1rem; }
.leist-cols h5 { margin: 0 0 .7rem; font-size: .74rem; text-transform: uppercase; letter-spacing: .12em; color: var(--c-muted); font-weight: 600; }
.leist-tags { display: flex; flex-wrap: wrap; gap: .4rem; }
.leist-tags span { font-size: .82rem; color: var(--c-text-2); background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 100px; padding: .35em .85em; }
.leist-list { list-style: none; margin: 0; padding: 0; }
.leist-list li { display: flex; gap: .55em; align-items: flex-start; font-size: .92rem; color: var(--c-text-2); margin-bottom: .55rem; }
.leist-list li svg { width: 1.05em; height: 1.05em; color: var(--c-accent-2); flex: none; margin-top: .18em; }
@media (max-width: 700px) { .leist-cols { grid-template-columns: 1fr; gap: 1.1rem; } }

/* ============================================================
   TRUST BAR (Kassen / IGEL)
   ============================================================ */
.trustbar { background: var(--c-ink); color: var(--c-on-ink); position: relative; z-index: 3; }
.trustbar-inner { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; padding: 1.05rem 0; }
.trust-item { display: flex; align-items: center; gap: .7rem; }
.trust-item > svg { width: 1.3rem; height: 1.3rem; color: var(--c-accent); flex: none; }
.trust-item .tt { font-weight: 650; font-size: .95rem; color: #fff; letter-spacing: -0.01em; }
.trust-item .ts { font-size: .8rem; color: var(--c-on-ink-2); }
@media (max-width: 820px) { .trustbar-inner { grid-template-columns: 1fr 1fr; gap: 1rem 1.2rem; } }
@media (max-width: 470px) { .trustbar-inner { grid-template-columns: 1fr; } }

/* ============================================================
   KOMPETENZ / MITGLIEDSCHAFTEN
   ============================================================ */
.komp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: start; }
.komp-head h2 { margin-top: .7rem; }
.komp-head p { color: var(--c-text-2); margin: .9rem 0 0; max-width: 42ch; }
.komp-tag { display: inline-block; margin-top: 1.1rem; font-size: .68rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--c-accent-2); background: var(--c-accent-soft); border-radius: 100px; padding: .4em .85em; }
.komp-list { display: flex; flex-direction: column; border-top: 1px solid var(--c-line); }
.komp-item { display: flex; align-items: center; gap: .9rem; padding: 1rem .2rem; border-bottom: 1px solid var(--c-line); font-size: 1rem; color: var(--c-text); font-weight: 500; }
.komp-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--c-accent); flex: none; }
.komp-partners { margin-top: clamp(2rem, 4vw, 3rem); display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.komp-plabel { font-size: .74rem; text-transform: uppercase; letter-spacing: .12em; color: var(--c-muted); font-weight: 600; flex: none; }
.komp-logos { display: flex; gap: 1rem; flex-wrap: wrap; }
.komp-logo { width: 120px; height: 60px; background: var(--c-bg-2); border: 1px solid var(--c-line); }
@media (max-width: 820px) { .komp-grid { grid-template-columns: 1fr; gap: 1.6rem; } }

/* ============================================================
   BOOKING MODAL
   ============================================================ */
.modal-overlay { position: fixed; inset: 0; z-index: 200; display: grid; place-items: center; padding: 1.5rem; background: color-mix(in srgb, var(--c-ink) 55%, transparent); backdrop-filter: blur(6px); animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; } to { opacity: 1; } }
.modal { position: relative; width: min(480px, 100%); background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 24px; padding: 2.2rem 2.2rem 2rem; box-shadow: 0 50px 100px -40px rgba(20,22,28,.6); animation: pop .35s cubic-bezier(.2,.8,.2,1); }
@keyframes pop { from { opacity: 0; transform: translateY(16px) scale(.97); } to { opacity: 1; transform: none; } }
.modal-x { position: absolute; top: 1.1rem; right: 1.1rem; width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--c-line); background: var(--c-bg); color: var(--c-text-2); font-size: .8rem; display: grid; place-items: center; transition: .2s; }
.modal-x:hover { background: var(--c-ink); color: var(--c-on-ink); border-color: var(--c-ink); }
.modal-title { font-size: 1.5rem; font-weight: 650; margin: .6rem 0 1.4rem; letter-spacing: -0.02em; }
.modal-options { display: flex; flex-direction: column; gap: .6rem; }
.modal-opt { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem 1.2rem; border-radius: 14px; border: 1px solid var(--c-line); background: var(--c-bg); color: var(--c-text); font-weight: 500; font-size: .98rem; text-align: left; transition: .25s; }
.modal-opt svg { width: 1.1em; height: 1.1em; color: var(--c-muted); transition: transform .3s, color .3s; }
.modal-opt:hover { border-color: var(--c-accent); background: var(--c-accent-soft); transform: translateX(3px); }
.modal-opt:hover svg { color: var(--c-accent-2); transform: translateX(3px); }
.modal-steps { display: flex; gap: .4rem; justify-content: center; margin-top: 1.6rem; }
.modal-steps span { width: 28px; height: 4px; border-radius: 4px; background: var(--c-line-2); transition: .3s; }
.modal-steps span.on { background: var(--c-accent); }
.modal-done { text-align: center; padding: .5rem 0; }
.modal-done-ic { width: 56px; height: 56px; margin: 0 auto 1.1rem; border-radius: 50%; background: var(--c-accent-soft); color: var(--c-accent-2); display: grid; place-items: center; }
.modal-done-ic svg { width: 28px; height: 28px; }
.modal-done p { color: var(--c-text-2); margin: 0 0 1.4rem; max-width: 36ch; margin-inline: auto; }
/* !important: overrides .modal p margin-bottom reset above */
.modal-alt { font-size: .88rem; margin-top: 1.2rem !important; }
.modal-alt a { color: var(--c-accent-2); font-weight: 600; }
.twk-note { font-size: .72rem; line-height: 1.45; color: var(--c-muted, #888); padding: 0 2px 4px; margin-top: -2px; }

/* ---- CREDENTIALS ---- */
.credentials {
  background: var(--c-bg-2, var(--c-bg));
  border-top: 1px solid var(--c-line-2);
  border-bottom: 1px solid var(--c-line-2);
  padding: 1.6rem 0;
}
.credentials-inner {
  display: flex;
  flex-wrap: wrap;
  gap: .9rem 2.4rem;
}
.credential-item {
  display: flex;
  align-items: flex-start;
  gap: .55rem;
  font-size: .9rem;
  color: var(--c-text-2);
  line-height: 1.4;
  flex: 1 1 200px;
}
.credential-item svg { width: 15px; height: 15px; flex: none; color: var(--c-accent); margin-top: 2px; }

/* ---- PATIENT EDITORIAL ---- */
.editorial-blocks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.6rem;
  margin-top: 2rem;
}
.editorial-block {
  background: var(--c-bg-2, var(--c-bg));
  border: 1px solid var(--c-line);
  border-radius: var(--r-card, 16px);
  padding: 1.8rem;
}
.editorial-block h3 { font-size: 1.05rem; margin-bottom: .7rem; }
.editorial-block p { color: var(--c-text-2); font-size: .93rem; margin: 0; }
.warning-list { list-style: none; padding: 0; margin: 0 0 1rem; display: flex; flex-direction: column; gap: .5rem; }
.warning-list li { display: flex; align-items: flex-start; gap: .55rem; font-size: .91rem; color: var(--c-text-2); }
.warning-list li svg { flex: none; width: 15px; height: 15px; color: var(--c-accent-2); margin-top: 3px; }
.urgency-cta {
  margin-top: 2.4rem;
  background: var(--c-accent-soft);
  border: 1px solid color-mix(in srgb, var(--c-accent) 25%, transparent);
  border-radius: var(--r-card, 16px);
  padding: 1.8rem 2rem;
  max-width: 640px;
}
.urgency-cta strong { display: block; font-size: 1rem; color: var(--c-text); margin-bottom: .4rem; }
.urgency-cta p { color: var(--c-text-2); margin: 0 0 1.2rem; font-size: .93rem; }

/* ---- SCROLL TO TOP ---- */
.scroll-top {
  position: fixed;
  bottom: 1.4rem;
  right: 1.2rem;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--c-bg-2, var(--c-bg));
  border: 1px solid var(--c-line-2);
  color: var(--c-text-2);
  display: none;
  place-items: center;
  cursor: pointer;
  z-index: 90;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .22s, transform .22s, background .18s, color .18s;
  box-shadow: 0 2px 12px -4px rgba(0,0,0,.15);
}
.scroll-top svg { width: 20px; height: 20px; pointer-events: none; }
.scroll-top.visible { opacity: 1; transform: none; }
.scroll-top:hover { background: var(--c-accent-soft); color: var(--c-accent-2); }
@media (max-width: 768px) {
  .scroll-top { display: grid; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1000px) {
  .footer-top { grid-template-columns: 1fr 1fr; gap: 2rem 1.5rem; }
  .teams-top, .teams-row2, [data-modules="magazin"] .teams-top { grid-template-columns: 1fr 1fr; }
  .videos { grid-template-columns: 1fr 1fr; }
}
/* ---------- MOBILE NAV ---------- */
.mobile-nav-overlay {
  position: fixed; inset: 0; z-index: 59;
  background: color-mix(in srgb, var(--c-ink) 40%, transparent);
  backdrop-filter: blur(4px);
  animation: fade .2s ease;
}
.mobile-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-line);
  padding: 5rem 1.5rem 2rem;
  box-shadow: 0 24px 60px -20px rgba(20,22,28,.25);
  animation: slideDown .28s cubic-bezier(.2,.8,.2,1);
}
@keyframes slideDown {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}
.mobile-nav-links { display: flex; flex-direction: column; gap: .2rem; margin-bottom: 1.8rem; }
.mobile-nav-links a {
  display: block; padding: .9rem 0; font-size: 1.3rem; font-weight: 600;
  color: var(--c-text); border-bottom: 1px solid var(--c-line);
  transition: color .2s; cursor: pointer;
}
.mobile-nav-links a:hover { color: var(--c-accent-2); }
.mobile-nav-footer { display: flex; flex-direction: column; gap: 1rem; }

@media (max-width: 820px) {
  .nav-links { display: none; }
  .nav-cta { display: none; }
  .menu-toggle { display: inline-flex; }
  .symptombar-inner { flex-direction: column; align-items: flex-start; gap: .8rem; }
  .symptom-chips { flex-wrap: nowrap; overflow-x: auto; width: 100%; padding-bottom: 4px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .symptom-chips::-webkit-scrollbar { display: none; }
  .symptom-chip { flex: none; }
  .hero-grid, [data-hero="split"] .hero-grid, [data-hero="grafisch"] .hero-grid { grid-template-columns: 1fr; }
  .hero-media { order: -1; }
  .philo-inner { grid-template-columns: 1fr; gap: 1.6rem; }
  .future-grid { grid-template-columns: 1fr 1fr; }
  .ctaband-inner { grid-template-columns: 1fr; }
  .ctaband-actions { justify-content: flex-start; }
  .dhero-grid { grid-template-columns: 1fr; }
  .dhero-media { order: -1; }
  .prosbox, .referral { grid-template-columns: 1fr; }
  .section-head { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .section-head .sd { max-width: 100%; }
  .teams-row2, [data-modules="magazin"] .teams-row2 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .teams-top, .teams-row2, [data-modules="magazin"] .teams-top, [data-modules="magazin"] .teams-row2, .future-grid, .videos { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }
  .acc-content { padding-left: 0; }
  .hero-cta { flex-direction: column; }
  .hero-cta .btn { width: 100%; justify-content: center; }
  .hero-stats { gap: 1.4rem; }
  .brand-name small { display: none; }
  .dhero-facts { gap: 1.2rem; }
  .members { grid-template-columns: 1fr 1fr; }
  .komp-partners { overflow-x: auto; }
}
