/* ============================================================
   HNO Gemeinschaftspraxis – Stylesheet
   ============================================================ */

:root {
    --primary:      #1a4b7a;
    --primary-dk:   #133960;
    --primary-md:   #2563a8;
    --accent:       #2980b9;
    --bg:           #ffffff;
    --bg-light:     #f2f7fc;
    --text:         #263545;
    --text-muted:   #5a6e82;
    --border:       #dce8f0;
    /* Schriften lokal – keine externe Google-Fonts-Anfrage.
       Solange keine lokalen Font-Dateien vorhanden sind, greift der System-Fallback. */
    --font-s:       'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-serif:   'Lora', Georgia, 'Times New Roman', serif;
    --radius:       10px;
    --radius-lg:    18px;
    --radius-xl:    24px;
    --shadow-sm:    0 2px 12px rgba(26,75,122,.07);
    --shadow:       0 4px 24px rgba(26,75,122,.11);
    --shadow-lg:    0 10px 40px rgba(26,75,122,.18);
    --ease:         0.22s ease;
    --max-w:        1120px;
    --hh:           72px;          /* header height */
}

/* ── Lokale Schriften (TODO) ──────────────────────────────────
   Schrift-Dateien (woff2) nach /assets/fonts/ legen und diesen
   Block einkommentieren. Dann werden Inter/Lora lokal geladen –
   ganz ohne Verbindung zu Google. Bis dahin greift der System-Fallback.

@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 300 700;
    font-display: swap;
    src: url('assets/fonts/inter-variable.woff2') format('woff2');
}
@font-face {
    font-family: 'Lora';
    font-style: normal;
    font-weight: 400 600;
    font-display: swap;
    src: url('assets/fonts/lora-variable.woff2') format('woff2');
}
@font-face {
    font-family: 'Lora';
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url('assets/fonts/lora-italic.woff2') format('woff2');
}
──────────────────────────────────────────────────────────────── */

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html   { scroll-behavior:smooth; scroll-padding-top:var(--hh); }
body   { font-family:var(--font-s); color:var(--text); background:var(--bg); line-height:1.7; -webkit-font-smoothing:antialiased; }
img    { max-width:100%; height:auto; display:block; }
a      { color:var(--primary); text-decoration:none; transition:color var(--ease); }
a:hover{ color:var(--primary-md); }

/* ── Layout ── */
.container      { max-width:var(--max-w); margin:0 auto; padding:0 1.75rem; }
.section        { padding:100px 0; }
.section--light { background:var(--bg-light); }

.section-header {
    text-align:center;
    margin-bottom:3.5rem;
}
.section-header h2 {
    font-family:var(--font-serif);
    font-size:clamp(1.8rem,4vw,2.6rem);
    font-weight:600;
    color:var(--primary);
    line-height:1.2;
    margin-bottom:.5rem;
}
.section-sub {
    color:var(--text-muted);
    font-size:1.05rem;
    max-width:540px;
    margin:0 auto;
}

/* Eyebrow labels */
.eyebrow {
    display:inline-block;
    font-size:.72rem;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.14em;
    color:var(--accent);
    background:rgba(41,128,185,.1);
    padding:.3rem .85rem;
    border-radius:99px;
    margin-bottom:.9rem;
}
.eyebrow--light {
    color:rgba(255,255,255,.9);
    background:rgba(255,255,255,.18);
}

/* ── Buttons ── */
.btn {
    display:inline-block;
    padding:.8rem 2rem;
    border-radius:var(--radius);
    font-weight:600;
    font-size:.95rem;
    border:2px solid transparent;
    cursor:pointer;
    transition:all var(--ease);
    text-align:center;
}
.btn--primary { background:var(--primary); color:#fff; border-color:var(--primary); }
.btn--primary:hover { background:var(--primary-dk); border-color:var(--primary-dk); color:#fff; transform:translateY(-1px); box-shadow:var(--shadow); }
.btn--outline { background:transparent; color:var(--primary); border-color:var(--primary); }
.btn--outline:hover { background:var(--primary); color:#fff; transform:translateY(-1px); }
.btn--sm     { padding:.55rem 1.3rem; font-size:.875rem; }

/* ── Header ── */
.header {
    position:sticky; top:0; z-index:200;
    background:#fff; border-bottom:1px solid var(--border);
    height:var(--hh);
    transition:box-shadow var(--ease);
}
.header.scrolled { box-shadow:0 2px 24px rgba(26,75,122,.13); }
.header__inner   { display:flex; align-items:center; justify-content:space-between; height:100%; }

.header__logo          { display:flex; align-items:center; gap:.75rem; text-decoration:none; }
.header__logo-img      { height:60px; width:auto; object-fit:contain; }
.header__logo-fallback { display:none; flex-direction:column; }
.logo-title { font-size:1rem; font-weight:700; color:var(--primary); line-height:1.2; }
.logo-sub   { font-size:.72rem; color:var(--text-muted); }

.nav__list  { display:flex; list-style:none; gap:.1rem; align-items:center; }
.nav__link  { display:block; padding:.5rem .85rem; font-size:.875rem; font-weight:500; color:var(--text); border-radius:var(--radius); transition:all var(--ease); }
.nav__link:hover,.nav__link.active { color:var(--primary); background:var(--bg-light); }
.nav__link--cta { background:var(--primary); color:#fff!important; margin-left:.4rem; white-space:nowrap; }
.nav__link--cta:hover { background:var(--primary-dk)!important; color:#fff!important; }
.nav__link--book { background:var(--accent); color:#fff!important; white-space:nowrap; }
.nav__link--book:hover { background:var(--primary)!important; color:#fff!important; }

.nav-toggle { display:none; flex-direction:column; justify-content:center; gap:5px; background:none; border:none; cursor:pointer; padding:.5rem; border-radius:var(--radius); }
.nav-toggle span { display:block; width:24px; height:2px; background:var(--primary); border-radius:2px; transition:all var(--ease); }
.nav-toggle.is-active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-toggle.is-active span:nth-child(2) { opacity:0; transform:translateX(-6px); }
.nav-toggle.is-active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── Hero ── */
.hero {
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    overflow:hidden;
    color:#fff;
    background:#08122a;   /* Fallback während Bild lädt */
}

/* ── Hero Premium ── */
.hero-premium {
  position: relative;
  min-height: 92vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  background: #071827;
}

.hero-slider,
.hero-slide {
  position: absolute;
  inset: 0;
}

.hero-slide {
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.4s ease;
}

.hero-slide.active {
  opacity: 1;
}

.hero-dark {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      90deg,
      rgba(7, 24, 39, 0.96) 0%,
      rgba(7, 24, 39, 0.88) 30%,
      rgba(7, 24, 39, 0.55) 55%,
      rgba(7, 24, 39, 0.38) 100%
    );
  z-index: 1;
}

.hero-content-premium {
  position: relative;
  z-index: 2;
  max-width: 760px;
  padding-left: clamp(28px, 7vw, 90px);
  padding-right: 24px;
  color: white;
}

.hero-eyebrow {
  color: #D4890A;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 700;
  font-size: 0.9rem;
  margin-bottom: 22px;
}

.hero-content-premium h1 {
  font-family: "Lora", serif;
  font-size: clamp(2.4rem, 3.8vw, 4rem);
  line-height: 1.1;
  margin: 0 0 26px;
  color: white;
  font-weight: 600;
}

.hero-text {
  max-width: 620px;
  font-size: clamp(1.05rem, 1.35vw, 1.35rem);
  line-height: 1.7;
  color: rgba(255,255,255,0.9);
  margin-bottom: 36px;
}

.hero-buttons {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  margin-bottom: 42px;
}

.hero-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: 0 30px;
  border-radius: 10px;
  font-weight: 700;
  text-decoration: none;
  transition: all 0.25s ease;
}

.hero-btn-primary {
  background: #D4890A;
  color: #071827;
  box-shadow: 0 12px 30px rgba(212,137,10,0.35);
}

.hero-btn-primary:hover {
  transform: translateY(-2px);
  background: #E5970C;
}

.hero-btn-secondary {
  color: white;
  border: 1px solid rgba(255,255,255,0.7);
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(6px);
}

.hero-btn-secondary:hover {
  background: rgba(255,255,255,0.15);
  transform: translateY(-2px);
}

.hero-badges-premium {
  display: flex;
  gap: 26px;
  flex-wrap: wrap;
  color: rgba(255,255,255,0.92);
  font-weight: 600;
}

.hero-badges-premium div {
  padding-right: 22px;
  border-right: 1px solid rgba(255,255,255,0.25);
}

.hero-badges-premium div:last-child {
  border-right: none;
}

.hero-scroll-premium {
  position: absolute;
  z-index: 3;
  left: 50%;
  bottom: 28px;
  transform: translateX(-50%);
  color: white;
  font-size: 2.4rem;
  text-decoration: none;
  opacity: 0.9;
}

@media (max-width: 768px) {
  .hero-premium {
    min-height: 86vh;
  }

  .hero-dark {
    background: rgba(7, 24, 39, 0.72);
  }

  .hero-content-premium {
    padding: 120px 24px 70px;
  }

  .hero-badges-premium {
    flex-direction: column;
    gap: 12px;
  }

  .hero-badges-premium div {
    border-right: none;
  }
}

/* ── Willkommen / Split ── */
.split { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.split__text .eyebrow { margin-bottom:.7rem; }
.split__text h2 {
    font-family:var(--font-serif);
    font-size:clamp(1.7rem,3.5vw,2.5rem);
    font-weight:600; color:var(--primary);
    line-height:1.15; margin-bottom:1.2rem;
}
.split__text .lead { font-size:1.08rem; font-weight:500; color:var(--text); margin-bottom:1rem; }
.split__text p     { font-size:.97rem; color:var(--text); margin-bottom:1rem; line-height:1.75; }
.split__image {
    border-radius:var(--radius-xl); overflow:hidden;
    box-shadow:var(--shadow-lg); aspect-ratio:4/3; margin:0;
}
.split__image img { width:100%; height:100%; object-fit:cover; transition:transform .55s ease; }
.split__image:hover img { transform:scale(1.04); }

.kpi-row { display:flex; gap:2.5rem; margin-top:2rem; padding-top:2rem; border-top:1px solid var(--border); }
.kpi { display:flex; flex-direction:column; gap:.15rem; }
.kpi strong { font-size:1.5rem; font-weight:700; color:var(--primary); font-family:var(--font-serif); }
.kpi span   { font-size:.8rem; color:var(--text-muted); }

/* ── Philosophie ── */
.philosophie { position:relative; padding:110px 0; color:#fff; overflow:hidden; }
.philosophie__bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.philosophie__overlay {
    position:absolute; inset:0;
    background:linear-gradient(135deg, rgba(8,24,50,.9) 0%, rgba(26,75,122,.82) 100%);
}
.philosophie__content { position:relative; text-align:center; }
.philosophie__content h2 {
    font-family:var(--font-serif);
    font-size:clamp(1.9rem,4.5vw,3rem);
    font-weight:600; margin-bottom:1rem; line-height:1.15;
}
.philosophie__lead { font-size:1.1rem; opacity:.85; max-width:600px; margin:0 auto 3.5rem; line-height:1.75; }
.pillars { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.pillar {
    background:rgba(255,255,255,.1);
    border:1px solid rgba(255,255,255,.18);
    border-radius:var(--radius-lg); padding:2.25rem 2rem;
    backdrop-filter:blur(6px); text-align:left;
    transition:background var(--ease), transform var(--ease);
}
.pillar:hover { background:rgba(255,255,255,.17); transform:translateY(-5px); }
.pillar__icon {
    width:46px; height:46px; border-radius:50%;
    background:rgba(255,255,255,.2); display:flex;
    align-items:center; justify-content:center;
    font-size:1.1rem; font-weight:700; margin-bottom:1.2rem;
}
.pillar h3 { font-family:var(--font-serif); font-size:1.3rem; font-weight:600; margin-bottom:.75rem; }
.pillar p  { font-size:.95rem; opacity:.84; line-height:1.65; }

/* ── Services ── */
.services { display:grid; grid-template-columns:repeat(2,1fr); gap:1.75rem; }
.service-card {
    background:#fff; border:1px solid var(--border);
    border-radius:var(--radius-lg); overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:transform var(--ease), box-shadow var(--ease);
}
.service-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.service-card__img  { width:100%; height:230px; overflow:hidden; margin:0; }
.service-card__img img { width:100%; height:100%; object-fit:cover; transition:transform .55s ease; }
.service-card:hover .service-card__img img { transform:scale(1.06); }
.service-card__body { padding:1.85rem; }
.service-card__body h3 { font-family:var(--font-serif); font-size:1.4rem; font-weight:600; color:var(--primary); margin-bottom:1rem; }
.service-card__body ul  { list-style:none; display:flex; flex-direction:column; gap:.55rem; }
.service-card__body li  { padding-left:1.4rem; position:relative; font-size:.91rem; color:var(--text); line-height:1.5; }
.service-card__body li::before { content:'›'; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:1.15rem; line-height:1.4; }

/* ── Gallery ── */
.gallery {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:8px;
    margin-top:0;
}
.gallery__item {
    position:relative; overflow:hidden; margin:0;
    aspect-ratio:4/3;
    border-radius:var(--radius);
    box-shadow:var(--shadow-sm);
}
.gallery__item img {
    width:100%; height:100%;
    object-fit:cover;
    transition:transform .6s ease;
    display:block;
}
.gallery__item:hover img { transform:scale(1.05); }
.gallery__item figcaption {
    position:absolute; bottom:0; left:0; right:0;
    background:linear-gradient(transparent, rgba(8,24,50,.72));
    color:rgba(255,255,255,.92); font-size:.8rem; font-weight:500;
    padding:2.5rem 1.1rem .85rem;
    opacity:0; transition:opacity var(--ease);
    border-radius:0 0 var(--radius) var(--radius);
}
.gallery__item:hover figcaption { opacity:1; }

/* ── Team ── */
.team-section-label {
    font-family:var(--font-serif);
    font-size:1.25rem; font-weight:600;
    color:var(--primary);
    margin:0 0 1.5rem;
    padding-bottom:.75rem;
    border-bottom:2px solid var(--border);
}

/* Doctors */
.doctors-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-bottom:3.5rem; }
.doctor-card {
    background:#fff; border:1px solid var(--border);
    border-radius:var(--radius-lg); overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:box-shadow var(--ease);
}
.doctor-card:hover { box-shadow:var(--shadow-lg); }
.doctor-card__photo {
    width:100%; height:300px; overflow:hidden;
    margin:0; background:#dce8f0;
}
.doctor-card__photo img { width:100%; height:100%; object-fit:cover; object-position:top; transition:transform .5s ease; }
.doctor-card:hover .doctor-card__photo img { transform:scale(1.04); }
.doctor-card__info { padding:2rem; }
.doctor-card__info h4 { font-family:var(--font-serif); font-size:1.2rem; font-weight:600; color:var(--primary); margin-bottom:.3rem; }
.doctor-card__spec  { font-size:.84rem; color:var(--accent); font-weight:600; margin-bottom:.2rem; }
.doctor-card__since { font-size:.78rem; color:var(--text-muted); margin-bottom:.85rem; }
.doctor-card__info p { font-size:.92rem; color:var(--text); line-height:1.65; }

/* Photo placeholders */
.photo-placeholder {
    width:100%; height:100%;
    display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:.75rem;
    background:linear-gradient(145deg,#dce8f0,#c8d9ea);
}
.photo-placeholder svg { width:90px; height:90px; opacity:.55; }
.photo-placeholder span {
    font-size:.75rem; color:var(--text-muted); font-style:italic;
    background:rgba(255,255,255,.6); padding:.2rem .7rem; border-radius:99px;
}
.photo-placeholder--sm svg   { width:54px; height:54px; }
.photo-placeholder--sm       { gap:.4rem; }

/* Team photo (Gruppenbild) */
.team-photo {
    background:#fff; border:1px solid var(--border);
    border-radius:var(--radius-lg); overflow:hidden;
    box-shadow:var(--shadow-sm);
}
.team-photo img { width:100%; height:auto; display:block; }
.team-photo .photo-placeholder--team { height:380px; }
.photo-placeholder--team svg { width:120px; height:120px; }
.team-photo figcaption {
    padding:1.1rem 1.25rem; text-align:center;
    font-size:.9rem; color:var(--text-muted); font-style:italic;
}

/* ── Termin ── */
.termin {
    background:linear-gradient(135deg,var(--primary) 0%,#1b6499 55%,#177990 100%);
    color:#fff; padding:90px 0;
}
.termin__inner {
    display:grid; grid-template-columns:1fr 1fr;
    gap:4.5rem; align-items:center;
}
.termin__text h2 {
    font-family:var(--font-serif);
    font-size:clamp(2rem,4vw,2.8rem);
    font-weight:600; line-height:1.15; margin-bottom:1rem;
}
.termin__text p { font-size:1rem; opacity:.85; line-height:1.75; max-width:420px; }
.termin__box { display:flex; flex-direction:column; gap:1rem; }

.termin__book {
    display:flex; align-items:center; gap:1rem;
    background:#fff; color:var(--primary);
    border-radius:var(--radius-lg); padding:1.35rem 2rem;
    text-decoration:none; box-shadow:var(--shadow);
    transition:transform var(--ease), box-shadow var(--ease);
}
.termin__book:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); color:var(--primary); }
.termin__book-icon { font-size:2rem; line-height:1; }
.termin__book-text { font-size:1.25rem; font-weight:700; line-height:1.2; }
.termin__book-text small { display:block; font-size:.78rem; font-weight:500; color:var(--text-muted); margin-top:.25rem; }

.termin__phone {
    display:flex; align-items:center; gap:1.3rem;
    background:rgba(255,255,255,.15);
    border:1px solid rgba(255,255,255,.28);
    border-radius:var(--radius-lg); padding:1.5rem 2rem;
    color:#fff; transition:background var(--ease), transform var(--ease);
}
.termin__phone:hover { background:rgba(255,255,255,.22); color:#fff; transform:translateY(-2px); }
.termin__phone-icon  { font-size:2.2rem; }
.termin__phone strong { display:block; font-size:1.8rem; font-weight:700; line-height:1; margin-bottom:.2rem; }
.termin__phone small  { font-size:.82rem; opacity:.72; }

.termin__email {
    display:flex; align-items:center; gap:.9rem;
    background:rgba(255,255,255,.1);
    border:1px solid rgba(255,255,255,.2);
    border-radius:var(--radius); padding:1rem 1.5rem;
    color:rgba(255,255,255,.88); font-size:.9rem;
    transition:background var(--ease);
}
.termin__email:hover { background:rgba(255,255,255,.17); color:#fff; }

.termin__hours { background:rgba(0,0,0,.15); border-radius:var(--radius); padding:1.2rem 1.5rem; display:flex; flex-direction:column; gap:.7rem; }
.termin__hour  { display:flex; justify-content:space-between; font-size:.9rem; padding-bottom:.7rem; border-bottom:1px solid rgba(255,255,255,.12); }
.termin__hour:last-child { border-bottom:none; padding-bottom:0; }
.termin__hour span    { opacity:.75; }
.termin__hour strong  { font-weight:600; }
.termin__hour--closed span,
.termin__hour--closed strong { opacity:.4; }

/* ── Kontakt ── */
.contact-grid {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:1.5rem; align-items:start;
}
.contact-card {
    background:#fff; border:1px solid var(--border);
    border-radius:var(--radius-lg); padding:2rem;
    box-shadow:var(--shadow-sm);
}
.contact-card h3 {
    font-family:var(--font-serif); font-size:1.1rem; font-weight:600;
    color:var(--primary); margin-bottom:1.3rem;
    padding-bottom:.8rem; border-bottom:2px solid var(--border);
}
.contact-photo {
    border-radius:var(--radius-lg); overflow:hidden;
    aspect-ratio:4/3; margin:0; box-shadow:var(--shadow);
}
.contact-photo img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.contact-photo:hover img { transform:scale(1.04); }
.contact-list { display:flex; flex-direction:column; gap:1.1rem; }
.contact-row  { display:flex; gap:.85rem; font-size:.9rem; line-height:1.55; }
.contact-icon { font-size:1.1rem; flex-shrink:0; margin-top:.1rem; }
.contact-row a { color:var(--primary); font-weight:600; }
.contact-row a:hover { text-decoration:underline; }
.map-box {
    min-height:140px; background:var(--bg-light);
    border:2px dashed var(--border); border-radius:var(--radius);
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    text-align:center; padding:2rem 1.5rem; gap:1.25rem;
    color:var(--text-muted); font-size:.9rem; line-height:1.65;
}

/* ── Footer ── */
.footer { background:var(--primary); color:rgba(255,255,255,.78); padding:3rem 0 2rem; }
.footer__inner { display:flex; flex-direction:column; align-items:center; gap:1.3rem; text-align:center; }
.footer .logo-title { color:#fff; font-size:1rem; }
.footer .logo-sub   { color:rgba(255,255,255,.5); }
.footer__nav { display:flex; gap:1.75rem; flex-wrap:wrap; justify-content:center; }
.footer__nav a { color:rgba(255,255,255,.68); font-size:.88rem; }
.footer__nav a:hover { color:#fff; }
.footer__legal { display:flex; gap:1.5rem; }
.footer__legal a { color:rgba(255,255,255,.48); font-size:.82rem; }
.footer__legal a:hover { color:rgba(255,255,255,.8); }
.footer__copy { font-size:.76rem; color:rgba(255,255,255,.3); }

/* ── Legal pages ── */
.legal-page { padding:80px 0; }
.legal-content { max-width:780px; }
.legal-content h1 {
    font-family:var(--font-serif); font-size:clamp(1.8rem,4vw,2.4rem);
    color:var(--primary); margin-bottom:2.5rem;
    padding-bottom:1.25rem; border-bottom:2px solid var(--border);
}
.legal-content section { margin-bottom:2.25rem; }
.legal-content h2 { font-size:1.1rem; font-weight:700; color:var(--primary); margin-bottom:.75rem; }
.legal-content p,.legal-content li { font-size:.95rem; color:var(--text); line-height:1.75; margin-bottom:.5rem; }
.legal-content ul { padding-left:1.25rem; display:flex; flex-direction:column; gap:.3rem; }
.legal-content a  { font-weight:500; }

/* Logos der Institutionen im Impressum */
.legal-logo { display:block; height:56px; width:auto; margin-bottom:.9rem; }
.legal-members { list-style:none; padding-left:0 !important; gap:1.1rem !important; }
.legal-members li { display:flex; align-items:center; gap:1rem; margin-bottom:0; }
.legal-members li img { height:54px; width:auto; flex-shrink:0; }

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */

@media (max-width: 1024px) {
    .pillars { gap:1.25rem; }
}

@media (max-width: 900px) {
    .section { padding:72px 0; }
    .split { grid-template-columns:1fr; gap:2.5rem; }
    .split__image { order:-1; max-height:320px; }
    .services { grid-template-columns:1fr; }
    .contact-grid { grid-template-columns:1fr; }
    .termin__inner { grid-template-columns:1fr; gap:2.5rem; }
    .gallery { grid-template-columns:1fr 1fr; }
}

@media (max-width: 768px) {
    .section { padding:60px 0; }

    /* Mobile nav */
    .nav-toggle { display:flex; }
    .nav {
        position:fixed; top:var(--hh); left:0; right:0;
        background:#fff; border-bottom:1px solid var(--border);
        box-shadow:0 8px 24px rgba(0,0,0,.1);
        transform:translateY(-110%); opacity:0; pointer-events:none;
        transition:transform .3s ease, opacity .3s ease; z-index:199;
    }
    .nav.is-open { transform:translateY(0); opacity:1; pointer-events:all; }
    .nav__list   { flex-direction:column; padding:1.25rem 1rem; gap:.25rem; }
    .nav__link   { width:100%; padding:.85rem 1rem; }
    .nav__link--cta { margin-left:0; text-align:center; }

    /* Buttons in voller Breite auf Mobilgeräten */
    .btn { width:100%; text-align:center; }

    /* Philosophie */
    .pillars { grid-template-columns:1fr; }

    /* Team */
    .doctors-grid { grid-template-columns:1fr; }
    .doctor-card__photo { height:260px; }
    .team-photo .photo-placeholder--team { height:300px; }

    /* KPI */
    .kpi-row { gap:1.5rem; flex-wrap:wrap; }

    /* Gallery */
    .gallery { grid-template-columns:1fr 1fr; gap:6px; }
}

@media (max-width: 520px) {
    .gallery { grid-template-columns:1fr; gap:6px; }
    .kpi-row { gap:1rem; }
}
