/* Gesundheitspraxis Dr. Merten — kombiniertes Stylesheet */
/* Quellen: hausarztpraxis.html (Subseiten-Layout) + index.html (Homepage) */

/* ====== aus hausarztpraxis.html ====== */

  /* ============================================================
     THEME-SYSTEM
     ============================================================
     Default-Palette = Privatleistungen (grün / gold / warmgrau).
     Wird auf folgenden Seiten unverändert verwendet:
       private-leistungen, akupunktur, geraetegestuetzte-behandlungen,
       private-orthopaedie-igel, alternative-behandlungen,
       krankheitsbezogene-behandlungen, bgm, ozon, abnehmen, longevity.

     Auf Hausarzt-/Praxis-Seiten gilt body.theme-praxis (s. unten) —
     dort wird die Palette auf die Logo-Farben (Bordeaux + Warmgrau-Beige)
     umgeschrieben. */
  :root{
    --bg:#F2EEE4; --bg-soft:#E8E1D0; --bg-card:#FAF7EE; --bg-alt:#E8E1D0;
    --primary:#567F68; --primary-deep:#3F5C4B; --primary-light:#7AA08C; --primary-muted:#6F8A7B;
    --accent:#CE8946; --accent-deep:#8E5230; --accent-soft:#CE8946; --accent-dark:#8E5230;
    --ink:#14181A; --ink-soft:#2D3334; --ink-mute:#5C6262; --muted:#5C6262;
    --line:#D6CFBE; --line-soft:rgba(86, 127, 104,.10);
    --font-display:'Funnel Display','Inter',-apple-system,sans-serif;
    --font-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
    --font-italic:'Fraunces',Georgia,serif;
    --max:1200px;
  }

  /* ====== THEME PRAXIS — Logo-Farben (Bordeaux + Warmgrau) ====== */
  body.theme-praxis{
    --bg:#FBF8F7;              /* warmes Off-White */
    --bg-soft:#F4EDEC;         /* leichter Bordeaux-Hauch */
    --bg-card:#FFFFFF;
    --bg-alt:#EFE6E5;
    --primary:#51071F;         /* Logo-Hauptfarbe Bordeaux */
    --primary-deep:#350313;    /* dunkler Bordeaux */
    --primary-light:#711223;   /* Logo-Sekundärfarbe */
    --primary-muted:#6F4A55;
    /* Button-Farben — auch in Bordeaux (var(--accent) ist die CTA-Farbe) */
    --accent:#51071F;          /* Buttons Hauptfarbe = Logo-Bordeaux */
    --accent-deep:#350313;     /* Button-Hover = dunkleres Bordeaux */
    --accent-dark:#350313;
    --accent-soft:#C7BDBA;     /* Logo-Hellgrau-Beige für dezente Akzent-Elemente */
    --line:#E1D9D5;            /* Logo-Linie */
    --line-soft:rgba(81,7,31,.08);
  }

  /* ====== Ausnahme: Aside im "Private Leistungen"-Mega-Menü ======
     Auch auf theme-praxis Seiten zeigt diese Box die Original-Privat-
     Farbpalette (grün + gold), weil sie inhaltlich zu den Privat-
     leistungen führt. Lokale CSS-Variable-Overrides — alle bestehenden
     Regeln innerhalb des Asides nutzen automatisch die grünen Werte. */
  body.theme-praxis .sm-aside--private{
    --bg:#F2EEE4;
    --bg-soft:#E8E1D0;
    --bg-card:#FAF7EE;
    --bg-alt:#E8E1D0;
    --primary:#567F68;
    --primary-deep:#3F5C4B;
    --primary-light:#7AA08C;
    --primary-muted:#6F8A7B;
    --accent:#CE8946;
    --accent-deep:#8E5230;
    --accent-soft:#CE8946;
    --accent-dark:#8E5230;
    --line:#D6CFBE;
    --line-soft:rgba(86,127,104,.10);
  }

  /* ====== KONTRAST-FIX (theme-praxis) ======
     Eyebrows, Section-Eyebrows und kleine Akzent-Schriften auf
     dunklen Bordeaux-Hintergründen brauchen eine helle Farbe,
     sonst werden sie unlesbar (z. B. "HAUSARZTZENTRIERTE VERSORGUNG"
     im .page-hero). Wir setzen das helle Logo-Beige (#DCC9CE),
     das mit Bordeaux einen warmen, lesbaren Kontrast bildet.
     Privatleistungs-Seiten sind nicht betroffen. */
  body.theme-praxis .page-hero .eyebrow,
  body.theme-praxis .hero .eyebrow,
  body.theme-praxis .highlight .section-eyebrow,
  body.theme-praxis .highlight .eyebrow,
  body.theme-praxis .cta-section .eyebrow {
    color:#DCC9CE;
  }
  body.theme-praxis .page-hero .eyebrow::before,
  body.theme-praxis .hero .eyebrow::before,
  body.theme-praxis .highlight .section-eyebrow::before,
  body.theme-praxis .cta-section .eyebrow::before {
    background:#DCC9CE;
  }
  /* Sub-Eyebrows in dunklen Boxen (sma-eyebrow nutzt schon accent-soft → ok,
     aber falls noch weitere weiße Akzente nötig sind, hier ergänzen) */
  body.theme-praxis .page-hero .breadcrumb,
  body.theme-praxis .page-hero .breadcrumb a {
    color:rgba(251,248,247,.78);
  }
  body.theme-praxis .page-hero .breadcrumb a:hover {
    color:#DCC9CE;
  }
  body.theme-praxis .page-hero .breadcrumb .sep {
    color:rgba(251,248,247,.4);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;overflow-x:hidden;max-width:100vw}
  body{font-family:var(--font-body);background:var(--bg);color:var(--ink);font-size:16px;line-height:1.6;font-weight:400;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
    /* Robuster Schutz gegen seitliches Scrollen auf Mobilgeräten */
    overflow-x:hidden;max-width:100vw;position:relative;
    /* Keine automatische Silbentrennung — Wörter bleiben ganz, nur explizite &shy; trennen */
    -webkit-hyphens:manual;-ms-hyphens:manual;hyphens:manual;
    /* Lange Wörter brechen am Wortende statt mitten im Wort */
    overflow-wrap:break-word;word-break:normal;text-wrap:pretty;
  }
  /* Universelle Schutzregel — kein einzelnes Element darf über die Viewport-Breite ragen */
  img,svg,video,iframe,embed,object{max-width:100%;height:auto}
  pre,code{overflow-x:auto;max-width:100%}
  table{max-width:100%;display:block;overflow-x:auto}
  h1,h2,h3,h4,h5,h6{hyphens:none;-webkit-hyphens:none;-ms-hyphens:none;word-break:keep-all;overflow-wrap:normal;text-wrap:balance}
  p{text-wrap:pretty}
  ::selection{background:var(--primary);color:var(--bg)}
  a{color:var(--primary);text-decoration:none;transition:color .2s ease}
  a:hover{color:var(--accent-deep)}
  .container{max-width:var(--max);margin:0 auto;padding:0 28px}
  img{max-width:100%;height:auto}

  /* HEADER — volle Viewport-Breite */
  header.site-header{border-bottom:1px solid var(--line);background:var(--bg);position:sticky;top:0;z-index:50}
  .header-inner{display:flex;align-items:center;justify-content:space-between;padding:22px clamp(28px, 4vw, 56px);max-width:none;margin:0;gap:24px;width:100%}
  .logo{display:flex;align-items:center}
  .logo img{display:block;height:48px;width:auto}
  .footer-brand .logo img{height:56px;filter:brightness(0) invert(1);opacity:.95}
  /* Mobile-only Elemente im Menü (Logo oben, CTA-Bar unten) */
  .nav-mobile-top{display:none;padding-bottom:18px;margin-bottom:8px;border-bottom:1px solid var(--line)}
  .nav-mobile-top img{height:46px;width:auto;display:block}
  .nav-mobile-cta{display:none;margin-top:24px;padding-top:24px;border-top:1px solid var(--line)}
  .nav-mobile-cta .ncc-call{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--line);border-radius:6px;color:var(--primary-deep);text-decoration:none;font-weight:600;font-size:15px;margin-bottom:10px;transition:all .2s}
  .nav-mobile-cta .ncc-call:hover{background:var(--bg-soft);border-color:var(--primary)}
  .nav-mobile-cta .ncc-call svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}
  .nav-mobile-cta .ncc-call .ncc-label{display:block;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);font-weight:600;margin-bottom:2px}
  .nav-mobile-cta .ncc-call .ncc-number{display:block;font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--primary-deep);letter-spacing:-.01em}
  .nav-mobile-cta .ncc-book{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 22px;background:var(--accent);color:var(--bg);font-size:13px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;border-radius:6px;text-decoration:none;transition:background .2s}
  .nav-mobile-cta .ncc-book:hover{background:var(--accent-deep)}
  .nav-mobile-cta .ncc-book svg{width:16px;height:16px}

  nav.main-nav ul{display:flex;gap:28px;list-style:none;align-items:center}
  nav.main-nav a{font-size:14.5px;font-weight:500;color:var(--ink);letter-spacing:-.005em;text-transform:none;position:relative}
  nav.main-nav a:hover{color:var(--primary)}
  /* Aktiver Menüpunkt — unterstrichen + Akzentfarbe */
  nav.main-nav > ul > li.is-active > a{color:var(--primary-deep);font-weight:600}
  nav.main-nav > ul > li.is-active > a::before{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--accent);border-radius:1px}
  nav.main-nav .submenu li.is-active > a{color:var(--primary);font-weight:600;background:var(--bg-soft)}
  nav.main-nav .has-sub{position:static}
  nav.main-nav .has-sub > a::after{content:" \25BE";font-size:10px;color:var(--accent);margin-left:2px}
  /* MEGA MENU — kompaktes, zentriertes Panel mit Intro-Text */
  nav.main-nav .submenu{
    position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(6px);
    background:var(--bg-card);
    border:1px solid var(--line);
    border-radius:12px;
    padding:32px 36px 30px;
    list-style:none;
    display:grid;
    grid-template-columns:1.4fr 320px;grid-template-rows:auto 1fr;
    grid-template-areas:"intro aside" "items aside";
    column-gap:48px;row-gap:24px;align-items:start;
    width:min(1080px, calc(100vw - 56px));
    opacity:0;visibility:hidden;
    transition:opacity .2s, transform .2s, visibility 0s linear .2s;
    box-shadow:0 24px 60px -16px rgba(63,92,75,.28);
    z-index:60;
  }
  nav.main-nav .has-sub:hover .submenu,
  nav.main-nav .has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);transition:opacity .2s, transform .2s, visibility 0s linear}
  /* Mega-Menu Intro-Block */
  nav.main-nav .submenu .sm-intro{grid-area:intro;padding-bottom:12px;border-bottom:1px solid var(--line)}
  nav.main-nav .submenu .sm-intro .sm-eyebrow{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:700;display:inline-flex;align-items:center;gap:10px;margin:0 0 8px}
  nav.main-nav .submenu .sm-intro .sm-eyebrow::before{content:"";width:24px;height:1px;background:var(--accent)}
  nav.main-nav .submenu .sm-intro h3{font-family:var(--font-display);font-weight:400;font-size:22px;color:var(--primary-deep);line-height:1.15;letter-spacing:-.015em;margin:0 0 8px}
  nav.main-nav .submenu .sm-intro h3 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  nav.main-nav .submenu .sm-intro p{font-size:14px;color:var(--ink-soft);line-height:1.5;margin:0;max-width:50ch}
  nav.main-nav .submenu .sm-items{
    grid-area:items;display:grid;grid-template-columns:1fr 1fr;gap:2px 24px;list-style:none;padding:0;margin:0;
  }
  nav.main-nav .submenu .sm-aside{grid-area:aside}
  nav.main-nav .submenu .sm-items li{padding:0}
  nav.main-nav .submenu .sm-items a{
    display:flex;align-items:center;gap:12px;
    padding:12px 14px;
    font-size:14.5px;color:var(--ink-soft);
    border-radius:6px;
    transition:background .2s, color .2s;
  }
  nav.main-nav .submenu .sm-items a:hover{color:var(--primary-deep);background:var(--bg-soft)}
  nav.main-nav .submenu .sm-items a::before{
    content:"";flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--accent);
    opacity:.5;transition:opacity .2s, transform .2s;
  }
  nav.main-nav .submenu .sm-items a:hover::before{opacity:1;transform:scale(1.4)}
  /* Mega Menu Side Panel (Kontakt + CTA) */
  nav.main-nav .submenu .sm-aside{
    background:linear-gradient(135deg, var(--primary-deep) 0%, var(--primary) 100%);
    color:var(--bg);
    padding:24px 26px;border-radius:8px;
    display:flex;flex-direction:column;gap:18px;
    align-self:stretch;
  }
  nav.main-nav .submenu .sm-aside .sma-eyebrow{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-soft);font-weight:700;margin:0}
  nav.main-nav .submenu .sm-aside h4{font-family:var(--font-display);font-weight:400;font-size:20px;line-height:1.2;color:var(--bg);margin:4px 0 6px;letter-spacing:-.015em}
  nav.main-nav .submenu .sm-aside h4 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-soft)}
  nav.main-nav .submenu .sm-aside .sma-status{display:inline-flex;align-items:center;gap:8px;background:rgba(242,238,228,.12);padding:7px 12px;border-radius:999px;font-size:11.5px;letter-spacing:.06em;color:var(--bg);font-weight:600;align-self:flex-start}
  nav.main-nav .submenu .sm-aside .sma-status.open::before{content:"";width:8px;height:8px;border-radius:50%;background:#9DDCB5;box-shadow:0 0 0 0 rgba(157,220,181,.6);animation:pulse 2s infinite}
  nav.main-nav .submenu .sm-aside .sma-status.closed::before{content:"";width:8px;height:8px;border-radius:50%;background:#E8B5A8}
  nav.main-nav .submenu .sm-aside .sma-contact{display:flex;flex-direction:column;gap:6px;font-size:13.5px;line-height:1.4;color:rgba(242,238,228,.85)}
  nav.main-nav .submenu .sm-aside .sma-contact a{color:var(--bg);text-decoration:none;display:inline-flex;align-items:center;gap:6px;font-weight:500}
  nav.main-nav .submenu .sm-aside .sma-contact a:hover{color:var(--accent-soft)}
  nav.main-nav .submenu .sm-aside .sma-contact svg{width:14px;height:14px;color:var(--accent-soft);flex-shrink:0}
  nav.main-nav .submenu .sm-aside .sma-cta{margin-top:auto;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 18px;background:var(--accent);color:var(--bg);font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;border-radius:6px;text-decoration:none;transition:background .2s, transform .2s}
  nav.main-nav .submenu .sm-aside .sma-cta:hover{background:var(--accent-deep);transform:translateY(-1px)}
  nav.main-nav .submenu .sm-aside .sma-cta svg{width:15px;height:15px}
  .cta-top{background:var(--accent);color:var(--bg)!important;font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:11px 20px;border:none;border-radius:3px;font-weight:600;transition:background .2s ease;white-space:nowrap}
  .cta-top:hover{background:var(--accent-deep);color:var(--bg)}
  .menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px;color:var(--ink);position:relative;z-index:110;margin-left:8px}
  .menu-toggle svg{width:26px;height:26px;transition:opacity .2s}
  .menu-toggle .icon-close{display:none}
  .menu-toggle.is-active .icon-open{display:none}
  .menu-toggle.is-active .icon-close{display:block}

  /* BACK-TO-TOP BUTTON */
  .back-to-top{
    position:fixed;bottom:24px;right:24px;width:48px;height:48px;
    background:var(--primary-deep);color:var(--bg);
    border:none;border-radius:50%;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 8px 24px -6px rgba(63,92,75,.4);
    opacity:0;visibility:hidden;transform:translateY(8px);
    transition:opacity .25s ease, transform .25s ease, visibility 0s linear .25s, background .2s;
    z-index:40;
  }
  .back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0);transition:opacity .25s ease, transform .25s ease, visibility 0s linear, background .2s}
  .back-to-top:hover{background:var(--primary);transform:translateY(-2px)}
  .back-to-top svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
  @media (max-width:560px){
    .back-to-top{bottom:16px;right:16px;width:42px;height:42px}
    .back-to-top svg{width:20px;height:20px}
  }

  /* PAGE HERO */
  .page-hero{position:relative;color:var(--bg);padding:120px 0 88px;overflow:hidden;background:var(--primary-deep)}
  .page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
  .page-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(63,92,75,.85) 0%,rgba(86,127,104,.78) 100%)}
  .page-hero::before{content:"";position:absolute;top:-280px;right:-280px;width:660px;height:660px;border-radius:50%;background:radial-gradient(circle,rgba(206,137,70,.16),transparent 60%);pointer-events:none;z-index:1}
  .page-hero .container{position:relative;z-index:2}
  .page-hero .eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:22px;font-weight:600;display:inline-flex;align-items:center;gap:12px}
  .page-hero .eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
  .page-hero h1{font-family:var(--font-display);font-weight:400;font-size:clamp(38px,5.6vw,72px);line-height:1.02;letter-spacing:-.035em;color:var(--bg);max-width:22ch;hyphens:manual}
  .page-hero h1 em{font-family:var(--font-italic);font-style:italic;font-weight:400;color:var(--accent);letter-spacing:-.025em}
  .page-hero .lead{margin-top:24px;font-size:18px;line-height:1.55;color:rgba(242,238,228,.85);max-width:60ch}

  .breadcrumb{margin-top:32px;font-size:12.5px;letter-spacing:.04em;color:rgba(242,238,228,.7)}
  .breadcrumb a{color:rgba(242,238,228,.85);font-weight:500}
  .breadcrumb a:hover{color:var(--accent-soft)}
  .breadcrumb span.sep{margin:0 8px;color:rgba(242,238,228,.4)}

  /* CONTENT — schmaler Lese-Container (komfortable Zeilenlänge ~65 Zeichen) */
  .page-body{padding:80px 0;border-bottom:1px solid var(--line);background:var(--bg)}
  .page-body .container{max-width:760px}
  .page-body .container.wide{max-width:var(--max)}
  /* Zweispalten-Layouts brauchen mehr Platz */
  .page-body .container:has(.twocol),
  .page-body .container:has(.twocol-img){max-width:980px}
  /* Karten-Grids dürfen volle Containerbreite nutzen */
  .page-body .container:has(.post-list),
  .page-body .container:has(.focus-grid),
  .page-body .container:has(.services-grid),
  .page-body .container:has(.more-services-grid),
  .page-body .container:has(.jobs-grid),
  .page-body .container:has(.related-grid),
  .page-body .container:has(.team-grid){max-width:var(--max)}
  /* Fließtext-Elemente innerhalb breiter Container trotzdem schmal halten */
  .page-body .container:has(.post-list) .content > p,
  .page-body .container:has(.focus-grid) .content > p,
  .page-body .container:has(.team-grid) .content > p,
  .page-body .container:has(.related-grid) .content > p,
  .page-body .container:has(.more-services-grid) .content > p{max-width:62ch}
  .page-body .container:has(.post-list) .content > h2,
  .page-body .container:has(.focus-grid) .content > h2,
  .page-body .container:has(.team-grid) .content > h2,
  .page-body .container:has(.related-grid) .content > h2,
  .page-body .container:has(.more-services-grid) .content > h2{max-width:32ch}
  .content h2{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,3.6vw,40px);line-height:1.1;color:var(--primary-deep);letter-spacing:-.02em;margin:48px 0 18px;hyphens:manual}
  .content h2:first-child{margin-top:0}
  .content h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .content h3{font-family:var(--font-display);font-weight:400;font-size:24px;color:var(--primary-deep);letter-spacing:-.015em;margin:36px 0 12px;line-height:1.2}
  .content h4{font-family:var(--font-display);font-weight:500;font-size:19px;color:var(--primary-deep);letter-spacing:-.01em;margin:28px 0 10px}
  .content p{color:var(--ink-soft);font-size:16.5px;line-height:1.75;margin-bottom:1.1em}
  .content p strong{color:var(--primary-deep);font-weight:600}
  .content ul, .content ol{padding-left:22px;margin-bottom:1.1em;color:var(--ink-soft);font-size:16.5px;line-height:1.7}
  .content ul li, .content ol li{margin-bottom:.4em}
  .content ul li::marker{color:var(--accent)}
  .content figure{margin:32px 0}
  .content img{display:block;border-radius:4px;border:1px solid var(--line);max-width:100%;height:auto}
  .content figcaption{font-size:13px;color:var(--ink-mute);margin-top:8px;letter-spacing:.02em}
  .content a{color:var(--primary);text-decoration:underline;text-decoration-color:rgba(86,127,104,.35);text-underline-offset:3px}
  .content a:hover{color:var(--accent-deep);text-decoration-color:var(--accent)}
  .content blockquote{border-left:3px solid var(--accent);padding:8px 0 8px 22px;margin:32px 0;font-family:var(--font-italic);font-style:italic;font-size:19px;color:var(--primary-deep);line-height:1.4}
  .content hr{border:0;border-top:1px solid var(--line);margin:48px 0}
  .content table{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px}
  .content table th, .content table td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;color:var(--ink-soft);vertical-align:top}
  .content table th{background:var(--bg-soft);font-weight:600;color:var(--primary-deep)}

  .btn-inline, .content .btn-inline, .content a.btn-inline, a.btn-inline{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;margin-top:8px;background:var(--primary);color:var(--bg)!important;font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;border-radius:3px;transition:all .25s ease;text-decoration:none!important;border:none}
  .btn-inline:hover, .content .btn-inline:hover, .content a.btn-inline:hover{background:var(--primary-deep);color:var(--bg)!important;transform:translateY(-1px);text-decoration:none!important}
  .btn-inline.btn-accent, .content a.btn-inline.btn-accent{background:var(--accent);color:var(--bg)!important}
  .btn-inline.btn-accent:hover, .content a.btn-inline.btn-accent:hover{background:var(--accent-deep);color:var(--bg)!important}
  .btn-inline.btn-outline, .content a.btn-inline.btn-outline{background:transparent;color:var(--primary)!important;border:1px solid var(--primary)}
  .btn-inline.btn-outline:hover, .content a.btn-inline.btn-outline:hover{background:var(--primary);color:var(--bg)!important}

  /* OH WIDGET */
  .oh-wrap{background:var(--bg-card);border:1px solid var(--line);border-radius:6px;padding:28px 22px 24px;margin:24px 0;position:relative;overflow:hidden}
  .oh-wrap h3{font-family:var(--font-display);font-weight:400;font-size:24px;color:var(--primary-deep);letter-spacing:-.015em;margin-bottom:14px}
  .oh-status-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;border-radius:999px;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin-bottom:18px}
  .oh-status-badge.open{background:var(--primary);color:var(--bg)}
  .oh-status-badge.open::before{content:"";width:8px;height:8px;border-radius:50%;background:#9DDCB5;box-shadow:0 0 0 0 rgba(157,220,181,.7);animation:pulse 2s infinite}
  .oh-status-badge.closed{background:var(--accent-deep);color:var(--bg)}
  .oh-status-badge.closed::before{content:"";width:8px;height:8px;border-radius:50%;background:rgba(242,238,228,.6)}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(157,220,181,.7)}70%{box-shadow:0 0 0 8px rgba(157,220,181,0)}100%{box-shadow:0 0 0 0 rgba(157,220,181,0)}}
  .oh-hours-list{list-style:none;padding:0;margin:0;border-radius:4px;overflow:hidden}
  .oh-day-item{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:11px 22px 11px 10px;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--ink-soft);transition:background .25s ease}
  .oh-day-item:last-child{border-bottom:none}
  .oh-day-item.today{
    background:linear-gradient(90deg, rgba(206,137,70,.10) 0%, rgba(206,137,70,.04) 100%);
    color:var(--primary-deep);font-weight:600;
    border-left:3px solid var(--accent);padding-left:11px;margin:0 -4px;border-radius:4px;
  }
  .oh-day-item.today .oh-day-name::after{
    content:"Heute";display:inline-block;margin-left:10px;
    padding:2px 9px;background:var(--accent);color:var(--bg);
    border-radius:999px;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
    vertical-align:1px;
  }
  .oh-day-name{flex:0 0 96px;font-weight:500}
  .oh-day-hours-container{display:flex;flex-direction:column;gap:9px;align-items:flex-end;text-align:right;flex:1 1 auto;min-width:0}
  /* Neue Slot-Struktur: Zeit oben, Label dezent darunter */
  .oh-slot{display:flex;flex-direction:column;align-items:flex-end;gap:1px;line-height:1.25;max-width:100%}
  .oh-slot-time{font-variant-numeric:tabular-nums;font-size:13.5px;font-weight:500;color:var(--ink-soft);letter-spacing:.005em;white-space:nowrap}
  .oh-slot-label{font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);font-weight:600;white-space:nowrap;max-width:100%}
  /* Slot-Typen */
  .oh-slot.oh-slot-notfall .oh-slot-time,
  .oh-slot.oh-slot-akut .oh-slot-time{color:var(--accent-deep)}
  .oh-slot.oh-slot-notfall .oh-slot-label,
  .oh-slot.oh-slot-akut .oh-slot-label{color:var(--accent);font-weight:600}
  .oh-slot.oh-slot-vorsorge .oh-slot-time{color:#5A6573}
  .oh-slot.oh-slot-vorsorge .oh-slot-label{color:#8A99AE;font-weight:600}
  .oh-slot.oh-closed-day .oh-slot-time{color:var(--muted);font-style:italic;font-weight:400;font-size:13.5px}
  /* Aktiv-Hervorhebung */
  .oh-slot.active{background:rgba(86,127,104,.10);padding:6px 12px 6px 14px;border-radius:12px;border-right:2px solid var(--primary)}
  .oh-slot.active .oh-slot-time{color:var(--primary);font-weight:700}
  .oh-slot.active .oh-slot-label{color:var(--primary-deep)}
  .oh-slot.oh-slot-notfall.active,
  .oh-slot.oh-slot-akut.active{background:rgba(206,137,70,.12);border-right-color:var(--accent-deep)}
  .oh-slot.oh-slot-notfall.active .oh-slot-time,
  .oh-slot.oh-slot-akut.active .oh-slot-time{color:var(--accent-deep)}
  .oh-slot.oh-slot-vorsorge.active{background:rgba(110,122,138,.12);border-right-color:#6E7A8A}
  .oh-slot.oh-slot-vorsorge.active .oh-slot-time{color:#3C4654}
  .oh-current-time{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink-mute);letter-spacing:.01em;display:flex;align-items:center;gap:8px}
  .oh-current-time::before{content:"\1F552";opacity:.7}

  /* COMPACT HOURS BLOCK (dezente Inline-Variante z. B. auf Hausarzt-Seite) */
  .hours-compact{margin:18px 0 28px;padding:0;border-left:2px solid var(--accent);padding-left:18px;max-width:560px}
  .hours-compact .hc-row{display:flex;justify-content:space-between;align-items:baseline;gap:24px;padding:7px 0;border-bottom:1px dashed var(--line);font-size:14.5px}
  .hours-compact .hc-row:last-of-type{border-bottom:none}
  .hours-compact .hc-day{color:var(--ink);font-weight:500}
  .hours-compact .hc-time{color:var(--ink-soft);font-variant-numeric:tabular-nums;letter-spacing:.01em}
  .hours-compact .hc-notfall{margin-top:6px}
  .hours-compact .hc-notfall .hc-day{color:var(--accent-deep);font-weight:600;font-size:13.5px}
  .hours-compact .hc-notfall .hc-time{color:var(--accent-deep);font-weight:600}
  .hours-compact .hc-link{margin:14px 0 0;font-size:13px;letter-spacing:.04em}
  .hours-compact .hc-link a{color:var(--primary-deep);font-weight:600;text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:1px}
  .hours-compact .hc-link a:hover{color:var(--accent-deep)}

  /* FLOATING STATUS BADGE — sticky am rechten Bildschirmrand */
  .status-fab{position:fixed;right:0;top:42%;z-index:90;display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--line);border-right:none;border-radius:14px 0 0 14px;box-shadow:0 12px 28px -10px rgba(28,42,32,.18),0 2px 6px -2px rgba(28,42,32,.10);overflow:hidden;font-family:var(--font-sans);transform:translateX(0);transition:transform .35s cubic-bezier(.16,.84,.44,1)}
  .status-fab.collapsed{transform:translateX(calc(100% - 44px))}
  .status-fab-toggle{position:absolute;left:-1px;top:50%;transform:translateY(-50%);width:18px;height:64px;background:var(--primary-deep);color:var(--bg);border:none;border-radius:6px 0 0 6px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;padding:0;letter-spacing:0;box-shadow:-2px 2px 6px -1px rgba(28,42,32,.18);transition:background .2s}
  .status-fab-toggle:hover{background:var(--accent-deep)}
  .status-fab-toggle::before{content:"›";font-size:18px;font-weight:600;line-height:1;display:inline-block;transform:translateX(-1px) rotate(180deg);transition:transform .3s}
  .status-fab.collapsed .status-fab-toggle::before{transform:translateX(0) rotate(0)}
  .status-fab-row{display:flex;align-items:flex-start;gap:14px;padding:14px 20px 14px 22px;border-bottom:1px solid var(--line);min-width:268px;max-width:300px;text-decoration:none;color:inherit;transition:background .2s}
  .status-fab-row:last-child{border-bottom:none}
  .status-fab-row:hover{background:rgba(206,137,70,.06)}
  .status-fab-dot{width:10px;height:10px;border-radius:50%;flex:0 0 10px;background:var(--muted);margin-top:6px;position:relative}
  .status-fab-row.is-open .status-fab-dot{background:#6FB585;box-shadow:0 0 0 0 rgba(111,181,133,.55);animation:fabPulse 2.2s infinite}
  .status-fab-row.is-special .status-fab-dot{background:var(--accent);box-shadow:0 0 0 0 rgba(206,137,70,.55);animation:fabPulse 2.2s infinite}
  @keyframes fabPulse{0%{box-shadow:0 0 0 0 rgba(111,181,133,.55)}70%{box-shadow:0 0 0 10px rgba(111,181,133,0)}100%{box-shadow:0 0 0 0 rgba(111,181,133,0)}}
  .status-fab-text{display:flex;flex-direction:column;gap:3px;line-height:1.3;min-width:0;flex:1 1 auto}
  .status-fab-name{font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--ink-mute)}
  .status-fab-state{font-size:14px;color:var(--ink);font-weight:600;line-height:1.3}
  .status-fab-row.is-open .status-fab-state{color:var(--primary)}
  .status-fab-row.is-special .status-fab-state{color:var(--accent-deep)}
  .status-fab-next{font-size:12px;color:var(--ink-mute);line-height:1.4;font-variant-numeric:tabular-nums;letter-spacing:.005em}
  .status-fab-next:empty{display:none}
  /* Beim geöffneten Mobile-Menü blendet sich das FAB komplett aus */
  body.menu-open .status-fab{opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease, visibility 0s linear .2s}
  /* Mobile: nach erstem Scroll zu Uhr-Icon kollabieren */
  .status-fab-mini{display:none}
  .status-fab.scroll-hidden{opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s ease, visibility 0s linear .35s}
  @media (max-width:560px){
    .status-fab{top:auto;bottom:14px;right:14px;left:14px;border-radius:14px;border-right:1px solid var(--line);flex-direction:row}
    .status-fab.collapsed{transform:translateY(calc(100% - 18px));bottom:0;right:0;left:auto;border-radius:14px 14px 0 0;flex-direction:column}
    .status-fab-toggle{display:none}
    .status-fab-row{flex:1 1 0;border-bottom:none;border-right:1px solid var(--line);padding:10px 12px;min-width:0}
    .status-fab-row:last-child{border-right:none}
    .status-fab-state{max-width:none;font-size:13px}
  }

  /* NEWS / SERVICE CARDS (für news.html, private-leistungen.html, leistungsspektrum.html etc.) */
  .post-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
  /* Page-spezifische Overrides: news.html nutzt 2 Spalten (weniger Beiträge) */
  body.news-listing .post-list,
  body.leistungsspektrum-page .post-list{grid-template-columns:repeat(2,1fr);gap:28px}
  .post-card{background:var(--bg-card);border:1px solid var(--line);border-radius:4px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none!important;color:inherit;transition:all .3s}
  .post-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(63,92,75,.18)}
  .post-card .pc-img{aspect-ratio:16/9;overflow:hidden;background:var(--bg-alt)}
  .post-card .pc-img img{width:100%;height:100%;object-fit:cover;display:block;border:0;border-radius:0}
  .post-card .pc-body{padding:24px}
  .post-card .pc-meta{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;margin-bottom:8px}
  .post-card h3{font-family:var(--font-display);font-weight:400;font-size:22px;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.2}
  .post-card .pc-cta{margin-top:14px;color:var(--primary);font-weight:600;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
  .post-card .pc-cta::after{content:"\2192";transition:transform .25s}
  .post-card:hover .pc-cta::after{transform:translateX(4px)}

  /* Long lists: auto 2-column via CSS columns */
  .content ul.cols, .content ol.cols{column-count:2;column-gap:32px;column-rule:1px solid var(--line)}
  .content ul.cols li, .content ol.cols li{break-inside:avoid;margin-bottom:.5em}
  @media (max-width:700px){
    .content ul.cols, .content ol.cols{column-count:1}
  }

  /* CONTENT TWO-COLUMN BLOCK */
  .content .twocol{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin:32px 0;align-items:start}
  .content .twocol > *{margin:0}
  .content .twocol h3{margin-top:0}
  .content .twocol p{margin-bottom:.9em}
  .content .twocol ul, .content .twocol ol{margin-bottom:.9em}
  .content .twocol > div, .content .twocol > section{display:flex;flex-direction:column;gap:12px}
  .content .twocol-img{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin:48px 0}
  .content .twocol-img figure{margin:0}
  .content .twocol-img img{border-radius:6px}
  .content .twocol-img.reverse{direction:rtl}
  .content .twocol-img.reverse > *{direction:ltr}

  /* CONTENT LEAD PARAGRAPH */
  .content .lead{font-size:19px;line-height:1.55;color:var(--primary-deep);font-weight:400;font-family:var(--font-display);max-width:55ch;margin-bottom:28px}
  .content .lead em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}

  /* GALLERY */
  .gallery-section{padding:80px 0;background:var(--bg-soft);border-bottom:1px solid var(--line)}
  .gallery-head{max-width:62ch;margin:0 auto 40px;text-align:center}
  .gallery-head .g-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
  .gallery-head .g-eyebrow::before, .gallery-head .g-eyebrow::after{content:"";width:28px;height:1px;background:var(--accent)}
  .gallery-head h2{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,3.6vw,42px);line-height:1.1;color:var(--primary-deep);letter-spacing:-.02em;margin-bottom:12px}
  .gallery-head h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .gallery-head p{color:var(--ink-soft);font-size:16px;line-height:1.6}
  .gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  .gallery-grid.cols-3{grid-template-columns:repeat(3,1fr)}
  .gallery-grid.cols-2{grid-template-columns:repeat(2,1fr)}
  .gallery-item{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:6px;border:1px solid var(--line);background:var(--bg-card);cursor:zoom-in;display:block}
  .gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
  .gallery-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(63,92,75,0) 60%,rgba(63,92,75,.55) 100%);opacity:0;transition:opacity .3s}
  .gallery-item:hover img{transform:scale(1.05)}
  .gallery-item:hover::after{opacity:1}
  .gallery-item::before{content:"\229E";position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;background:rgba(242,238,228,.92);color:var(--primary-deep);display:flex;align-items:center;justify-content:center;font-size:18px;opacity:0;transform:translateY(-4px);transition:opacity .25s, transform .25s;z-index:2;font-weight:700}
  .gallery-item:hover::before{opacity:1;transform:translateY(0)}

  /* Lightbox */
  .lightbox{position:fixed;inset:0;background:rgba(15,27,23,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .25s ease, visibility 0s linear .25s;padding:48px 24px}
  .lightbox.open{opacity:1;visibility:visible;transition:opacity .25s ease, visibility 0s}
  .lightbox img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;box-shadow:0 30px 60px -20px rgba(0,0,0,.5)}
  .lightbox-close{position:absolute;top:24px;right:24px;width:48px;height:48px;border-radius:50%;background:rgba(242,238,228,.12);color:var(--bg);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:22px;transition:background .2s}
  .lightbox-close:hover{background:rgba(242,238,228,.22)}
  .lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;background:rgba(242,238,228,.12);color:var(--bg);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;transition:background .2s}
  .lightbox-nav:hover{background:rgba(242,238,228,.22)}
  .lightbox-prev{left:24px}
  .lightbox-next{right:24px}
  .lightbox-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:var(--bg);font-size:13px;letter-spacing:.08em;background:rgba(242,238,228,.12);padding:8px 16px;border-radius:20px}

  /* MODERN PROFILE BLOCK (für Hausarzt/Kinderarzt) */
  .profile-block{padding:96px 0;border-bottom:1px solid var(--line);background:var(--bg)}
  .profile-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
  .profile-photo{aspect-ratio:4/5;border-radius:6px;overflow:hidden;background:var(--bg-soft);border:1px solid var(--line);position:relative}
  .profile-photo img{width:100%;height:100%;object-fit:cover;display:block}
  .profile-photo .badge{position:absolute;bottom:18px;left:18px;background:rgba(242,238,228,.95);color:var(--primary-deep);padding:8px 14px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;border-radius:3px;backdrop-filter:blur(8px)}
  .profile-content .p-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
  .profile-content .p-eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
  .profile-content h2{font-family:var(--font-display);font-weight:400;font-size:clamp(32px,4.4vw,52px);line-height:1.05;color:var(--primary-deep);letter-spacing:-.025em;margin-bottom:14px}
  .profile-content h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .profile-content .role{font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;margin-bottom:24px}
  .profile-content p{color:var(--ink-soft);font-size:16.5px;line-height:1.75;margin-bottom:1em;max-width:60ch}
  .profile-content .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:32px 0;padding:24px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .profile-content .stat .num{font-family:var(--font-display);font-size:36px;line-height:1;color:var(--accent);font-weight:300;letter-spacing:-.03em;display:block}
  .profile-content .stat .lbl{font-size:13px;color:var(--ink-mute);letter-spacing:.02em;margin-top:6px;line-height:1.4}

  /* FOCUS AREAS (Schwerpunkte) — Pill cards */
  .focus-areas{padding:80px 0;background:var(--bg-soft);border-bottom:1px solid var(--line)}
  .focus-head{max-width:62ch;margin-bottom:40px}
  .focus-head .f-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
  .focus-head .f-eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
  .focus-head h2{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,3.6vw,42px);line-height:1.1;color:var(--primary-deep);letter-spacing:-.02em;margin-bottom:12px}
  .focus-head h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .focus-head p{color:var(--ink-soft);font-size:16px;line-height:1.6}
  .focus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
  .focus-card{background:var(--bg-card);border:1px solid var(--line);border-radius:6px;padding:28px 26px;display:flex;flex-direction:column;gap:10px;transition:all .3s;position:relative;overflow:hidden}
  .focus-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(63,92,75,.18);background:var(--bg)}
  .focus-card .f-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-deep) 100%);color:var(--bg);display:flex;align-items:center;justify-content:center;margin-bottom:8px}
  .focus-card .f-icon svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.6}
  .focus-card h3{font-family:var(--font-display);font-weight:400;font-size:20px;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.2}
  .focus-card p{color:var(--ink-soft);font-size:14.5px;line-height:1.55;margin:0}

  /* KINDERARZT — subtile, edle Kinder-Akzente (kein Comic, sondern Line-Art) */
  body.kinderarzt .page-hero{background:linear-gradient(135deg, #4A8B6B 0%, #6BA388 100%)}
  .kid-decor{position:absolute;pointer-events:none;opacity:.7;z-index:1}
  .kid-decor.sun{top:32px;right:5%;width:56px;height:56px;animation:kid-float 9s ease-in-out infinite}
  .kid-decor.cloud-1{top:80px;left:6%;width:80px;height:48px;animation:kid-drift 22s ease-in-out infinite}
  .kid-decor.kite{bottom:60px;left:10%;width:42px;height:60px;animation:kid-float 11s ease-in-out infinite reverse;opacity:.55}
  .kid-decor.heart{bottom:48px;right:8%;width:36px;height:36px;animation:kid-pulse 5s ease-in-out infinite}
  @keyframes kid-float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-8px) rotate(1.5deg)}}
  @keyframes kid-drift{0%,100%{transform:translateX(0)}50%{transform:translateX(14px)}}
  @keyframes kid-pulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.08);opacity:.9}}

  /* Kid-friendly Focus Cards (Schwerpunkte) */
  body.kinderarzt .focus-card{border-radius:16px;position:relative;overflow:visible}
  body.kinderarzt .focus-card .f-icon{
    background:none;
    border-radius:0;
    width:64px;height:64px;
    margin-bottom:4px;
  }
  body.kinderarzt .focus-card .f-icon svg{width:100%;height:100%;color:inherit}
  body.kinderarzt .focus-card:nth-child(1){background:linear-gradient(135deg, #FFF8E7 0%, #FFEFC9 100%);border-color:#F2D89A}
  body.kinderarzt .focus-card:nth-child(2){background:linear-gradient(135deg, #E8F4F0 0%, #D4EBE0 100%);border-color:#B4DCC8}
  body.kinderarzt .focus-card:nth-child(3){background:linear-gradient(135deg, #FBE9E9 0%, #F8D9D9 100%);border-color:#EFC0C0}
  body.kinderarzt .focus-card:nth-child(4){background:linear-gradient(135deg, #E9F0FB 0%, #D6E2F4 100%);border-color:#BFD1ED}
  body.kinderarzt .focus-card:nth-child(5){background:linear-gradient(135deg, #F4E9FB 0%, #E5D4F2 100%);border-color:#D1B8E8}
  body.kinderarzt .focus-card:nth-child(6){background:linear-gradient(135deg, #FFEDE0 0%, #FFDCC2 100%);border-color:#F2C09A}
  body.kinderarzt .focus-card h3{color:var(--primary-deep)}

  /* Treppen-/Zickzack-Layout für Kinderarzt-Leistungen */
  body.kinderarzt .focus-grid{
    display:grid;grid-template-columns:1fr;gap:32px;
    max-width:920px;margin:0 auto;
    position:relative;
  }
  body.kinderarzt .focus-grid::before{
    content:"";position:absolute;left:50%;top:40px;bottom:40px;width:2px;
    background:repeating-linear-gradient(to bottom, var(--accent) 0 6px, transparent 6px 14px);
    opacity:.4;z-index:0;pointer-events:none;
  }
  body.kinderarzt .focus-card{
    width:min(58%, 460px);
    padding:32px 32px 30px;
    border-radius:20px;
    border-width:2px;
    box-shadow:0 8px 24px -10px rgba(63,92,75,.18);
    position:relative;z-index:1;
    transition:transform .35s ease, box-shadow .35s ease;
  }
  body.kinderarzt .focus-card:hover{
    transform:translateY(-4px) rotate(-1deg);
    box-shadow:0 18px 40px -14px rgba(63,92,75,.28);
  }
  /* Ungerade Karten: links, Pfeil-/Verbindung zeigt rechts hoch */
  body.kinderarzt .focus-card:nth-child(odd){
    justify-self:start;border-top-right-radius:6px;
  }
  body.kinderarzt .focus-card:nth-child(odd)::after{
    content:"";position:absolute;top:50%;right:-44px;width:44px;height:2px;
    background:var(--accent);opacity:.5;
  }
  body.kinderarzt .focus-card:nth-child(odd) .f-icon{align-self:flex-start}
  /* Gerade Karten: rechts */
  body.kinderarzt .focus-card:nth-child(even){
    justify-self:end;border-top-left-radius:6px;
  }
  body.kinderarzt .focus-card:nth-child(even)::after{
    content:"";position:absolute;top:50%;left:-44px;width:44px;height:2px;
    background:var(--accent);opacity:.5;
  }
  body.kinderarzt .focus-card:nth-child(even) .f-icon{align-self:flex-end}
  body.kinderarzt .focus-card:nth-child(even){text-align:right}
  body.kinderarzt .focus-card:nth-child(even) p{margin-left:auto}

  /* Mobile: zurück zu einspaltigem zentriertem Stack */
  @media (max-width:740px){
    body.kinderarzt .focus-grid{gap:18px;max-width:none}
    body.kinderarzt .focus-grid::before{display:none}
    body.kinderarzt .focus-card{
      width:100%;padding:22px 22px 22px;
      border-radius:14px;
    }
    body.kinderarzt .focus-card:nth-child(odd),
    body.kinderarzt .focus-card:nth-child(even){
      justify-self:stretch;text-align:left;
      border-radius:14px;
    }
    body.kinderarzt .focus-card:nth-child(odd)::after,
    body.kinderarzt .focus-card:nth-child(even)::after{display:none}
    body.kinderarzt .focus-card:nth-child(even) .f-icon{align-self:flex-start}
    body.kinderarzt .focus-card:nth-child(even) p{margin-left:0}
  }

  /* Eleganter Section-Trenner (dezente Sterne statt grobe Welle) */
  body.kinderarzt section.page-body{position:relative}
  body.kinderarzt section.page-body::before{
    content:"⁕  ⁕  ⁕";
    display:block;text-align:center;
    color:var(--accent);font-size:18px;letter-spacing:1.2em;
    margin-bottom:32px;opacity:.5;
  }

  /* PARENT PROMISE / "Was Eltern bei uns erleben" */
  .parent-promise{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:48px 40px;margin:48px 0;position:relative;overflow:hidden}
  .parent-promise::before{
    content:"";position:absolute;top:-30px;right:-30px;width:160px;height:160px;
    background:radial-gradient(circle, rgba(206,137,70,.1) 0%, transparent 70%);
    border-radius:50%;
  }
  .parent-promise .pp-head{margin-bottom:32px;position:relative;z-index:1}
  .parent-promise .pp-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
  .parent-promise .pp-eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
  .parent-promise h2{font-family:var(--font-display);font-weight:400;font-size:clamp(26px,3.4vw,38px);line-height:1.1;color:var(--primary-deep);letter-spacing:-.02em;margin:0 0 10px;max-width:30ch}
  .parent-promise h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .parent-promise .pp-lead{color:var(--ink-soft);font-size:16px;line-height:1.6;max-width:60ch;margin:0}
  .pp-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;position:relative;z-index:1}
  .pp-item{display:flex;gap:16px;align-items:flex-start;padding:20px 22px;background:var(--bg-card);border-radius:10px;border:1px solid var(--line)}
  .pp-item .pp-icon{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg, var(--primary) 0%, var(--primary-deep) 100%);color:var(--bg);display:flex;align-items:center;justify-content:center}
  .pp-item .pp-icon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
  .pp-item .pp-text h4{font-family:var(--font-display);font-weight:500;font-size:17px;color:var(--primary-deep);letter-spacing:-.01em;margin:0 0 4px;line-height:1.25}
  .pp-item .pp-text p{font-size:14.5px;color:var(--ink-soft);line-height:1.55;margin:0}
  @media (max-width:740px){
    .parent-promise{padding:32px 24px;margin:36px 0}
    .pp-grid{grid-template-columns:1fr;gap:14px}
  }

  /* PARENT TIP-BOX — warmes elternorientiertes Callout */
  .parent-tip{background:linear-gradient(135deg, #FFF8E7 0%, #FFEFC9 100%);border:1px solid #E8D2A0;border-left:4px solid var(--accent);border-radius:8px;padding:22px 26px 22px 24px;margin:32px 0;display:flex;gap:18px;align-items:flex-start}
  .parent-tip .pt-icon{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:18px;font-weight:600;line-height:1}
  .parent-tip .pt-body strong{display:block;font-family:var(--font-display);font-weight:500;font-size:16px;color:var(--accent-deep);letter-spacing:-.01em;margin-bottom:4px}
  .parent-tip .pt-body p{font-size:14.5px;color:var(--ink-soft);line-height:1.55;margin:0}

  /* PARENT QUOTE (Zitat / Versprechen Dr. Merten) */
  .parent-quote{border-left:3px solid var(--accent);padding:20px 0 20px 28px;margin:48px 0;font-family:var(--font-italic);font-style:italic;font-size:21px;line-height:1.4;color:var(--primary-deep);max-width:62ch}
  .parent-quote cite{display:block;margin-top:14px;font-family:var(--font-body);font-size:12.5px;font-style:normal;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);font-weight:600}

  /* TEAM SECTION (Ärzteteam) — volle Containerbreite */
  .team-section{padding:96px 0;background:var(--bg);border-bottom:1px solid var(--line)}
  .team-section .container{max-width:var(--max)}
  .team-head{max-width:62ch;margin-bottom:48px;text-align:center;margin-left:auto;margin-right:auto}
  .team-head .t-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;display:inline-flex;align-items:center;gap:12px;margin-bottom:14px;justify-content:center}
  .team-head .t-eyebrow::before, .team-head .t-eyebrow::after{content:"";width:28px;height:1px;background:var(--accent)}
  .team-section h2{font-family:var(--font-display);font-weight:400;font-size:clamp(32px,4.4vw,52px);line-height:1.05;color:var(--primary-deep);letter-spacing:-.025em;margin-bottom:14px}
  .team-section h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .team-section .team-lead{color:var(--ink-soft);font-size:17px;line-height:1.6;max-width:65ch;margin:0 auto}
  .team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
  .team-card{background:var(--bg-card);border:1px solid var(--line);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:all .35s}
  .team-card:hover{transform:translateY(-5px);box-shadow:0 22px 44px -18px rgba(63,92,75,.25);border-color:var(--primary)}
  .team-card .tc-photo{aspect-ratio:537/717;overflow:hidden;background:var(--bg-alt);position:relative}
  .team-card .tc-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .6s ease}
  .team-card:hover .tc-photo img{transform:scale(1.04)}
  .team-card .tc-body{padding:24px 26px 28px;text-align:center}
  .team-card .tc-role{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;margin:0 0 8px}
  .team-card .tc-name{font-family:var(--font-display);font-weight:400;font-size:22px;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.2;margin:0}
  .team-card .tc-bio{margin-top:12px;font-size:14px;color:var(--ink-soft);line-height:1.55}
  @media (max-width:1000px){
    .team-section{padding:64px 0}
    .team-grid{grid-template-columns:1fr 1fr;gap:20px}
    .team-head{margin-bottom:36px}
  }
  @media (max-width:640px){
    .team-grid{grid-template-columns:1fr 1fr;gap:14px}
    .team-card .tc-body{padding:18px 18px 22px}
    .team-card .tc-name{font-size:18px}
    .team-card .tc-role{font-size:10px;letter-spacing:.14em}
  }

  /* CV / TIMELINE */
  .cv-section{padding:96px 0;background:var(--bg);border-bottom:1px solid var(--line)}
  .cv-grid{display:grid;grid-template-columns:240px 1fr;gap:64px;align-items:start;margin-top:36px}
  .cv-grid .cv-side{position:sticky;top:120px}
  .cv-tabs{display:flex;flex-direction:column;gap:4px}
  .cv-tabs button{appearance:none;background:transparent;border:none;text-align:left;padding:12px 16px;font-family:var(--font-display);font-size:16px;font-weight:400;color:var(--ink-mute);cursor:pointer;border-left:2px solid var(--line);transition:all .25s}
  .cv-tabs button:hover{color:var(--primary-deep);border-left-color:var(--primary)}
  .cv-tabs button.active{color:var(--primary-deep);border-left-color:var(--accent);background:var(--bg-card)}
  .cv-content{display:none}
  .cv-content.active{display:block}
  .cv-list{list-style:none;padding:0;margin:0}
  .cv-list li{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid var(--line);font-size:15px}
  .cv-list li:last-child{border-bottom:none}
  .cv-list .date{font-family:var(--font-display);font-size:14px;color:var(--accent-deep);font-weight:500;letter-spacing:-.005em}
  .cv-list .desc{color:var(--ink-soft);line-height:1.55}

  /* TOPIC TILES — schnelle Themenübersicht oben auf der Seite */
  .topic-tiles{padding:64px 0;background:var(--bg-soft);border-bottom:1px solid var(--line)}
  .topic-tiles .container{max-width:var(--max)}
  .topic-tiles .tt-intro{max-width:60ch;margin-bottom:36px}
  .topic-tiles .tt-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
  .topic-tiles .tt-eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
  .topic-tiles h2{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,3.6vw,42px);line-height:1.1;color:var(--primary-deep);letter-spacing:-.02em;margin-bottom:12px}
  .topic-tiles h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .topic-tiles p{color:var(--ink-soft);font-size:16px;line-height:1.6}
  .tt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .tt-card{background:var(--bg-card);border:1px solid var(--line);border-radius:6px;padding:26px 24px;text-decoration:none!important;color:inherit;transition:all .3s;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}
  .tt-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .3s}
  .tt-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(63,92,75,.18);background:var(--bg)}
  .tt-card:hover::before{transform:scaleY(1)}
  .tt-card .tt-num{font-family:var(--font-display);font-weight:400;font-size:14px;color:var(--accent-deep);letter-spacing:.12em;margin-bottom:4px}
  .tt-card h3{font-family:var(--font-display);font-weight:400;font-size:20px;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.2}
  .tt-card p{color:var(--ink-soft);font-size:14px;line-height:1.5;margin:0}
  .tt-card .tt-cta{margin-top:auto;padding-top:14px;color:var(--primary);font-weight:600;font-size:11px;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
  .tt-card .tt-cta::after{content:"\2192";transition:transform .25s;font-size:14px}
  .tt-card:hover .tt-cta::after{transform:translateX(4px)}

  /* ANCHOR JUMP MARKERS für Topic-Inhalte */
  .topic-anchor{display:block;position:relative;top:-90px;visibility:hidden;height:0}
  .topic-block{scroll-margin-top:100px}
  .content h2.topic-heading, .content h3.topic-heading{display:flex;align-items:baseline;gap:14px;padding-top:16px}
  .content h2.topic-heading::before, .content h3.topic-heading::before{content:"";width:36px;height:1px;background:var(--accent);flex-shrink:0;margin-top:.6em}

  /* REASSURANCE NUMBERED BLOCKS — orientiert an praxisklinik-burbach */
  .reassurance{padding:96px 0;background:var(--bg);border-bottom:1px solid var(--line)}
  .reassurance .container{max-width:var(--max)}
  .reassurance .r-head{max-width:62ch;margin-bottom:56px}
  .reassurance .r-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
  .reassurance .r-eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
  .reassurance h2{font-family:var(--font-display);font-weight:400;font-size:clamp(30px,4vw,48px);line-height:1.05;color:var(--primary-deep);letter-spacing:-.025em;margin-bottom:12px}
  .reassurance h2 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .r-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
  .r-item{display:flex;flex-direction:column;gap:14px;padding-top:18px;border-top:1px solid var(--primary)}
  .r-item .r-num{font-family:var(--font-display);font-size:48px;font-weight:300;color:var(--accent);letter-spacing:-.04em;line-height:1}
  .r-item h3{font-family:var(--font-display);font-weight:400;font-size:21px;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.15}
  .r-item p{color:var(--ink-soft);font-size:14.5px;line-height:1.6}

  /* TRUST BADGES ROW */
  .trust-row{padding:48px 0;background:var(--bg-soft);border-bottom:1px solid var(--line)}
  .trust-grid{display:flex;justify-content:space-around;align-items:center;gap:32px;flex-wrap:wrap}
  .trust-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;min-width:140px;max-width:200px}
  .trust-icon{width:48px;height:48px;border-radius:50%;background:var(--primary-deep);color:var(--bg);display:flex;align-items:center;justify-content:center}
  .trust-icon svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.8}
  .trust-item strong{font-family:var(--font-display);font-weight:500;color:var(--primary-deep);font-size:15px;letter-spacing:-.01em}
  .trust-item span{font-size:13px;color:var(--ink-mute);line-height:1.45}

  /* RELATED LINKS (Cross-Page) */
  .related{padding:96px 0;background:var(--bg-soft);border-top:1px solid var(--line)}
  .related .r-head{max-width:62ch;margin-bottom:36px}
  .related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .related-card{background:var(--bg);padding:32px 28px;border:1px solid var(--line);border-radius:6px;text-decoration:none!important;color:inherit;transition:all .3s;display:flex;flex-direction:column;gap:8px}
  .related-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(63,92,75,.18);background:var(--bg-card)}
  .related-card .rc-eyebrow{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;margin-bottom:4px}
  .related-card h3{font-family:var(--font-display);font-weight:400;font-size:22px;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.2}
  .related-card h3 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .related-card p{color:var(--ink-soft);font-size:14px;line-height:1.55;flex:1}
  .related-card .rc-cta{margin-top:8px;color:var(--primary);font-weight:600;font-size:11px;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
  .related-card .rc-cta::after{content:"\2192";transition:transform .25s;font-size:14px}
  .related-card:hover .rc-cta::after{transform:translateX(4px)}

  /* CONTACT CTA inside page-body */
  .inline-cta{background:var(--bg-soft);border:1px solid var(--line);border-radius:4px;padding:32px 32px;margin:48px 0;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
  .inline-cta h3{font-family:var(--font-display);font-weight:400;font-size:24px;color:var(--primary-deep);letter-spacing:-.015em;margin-bottom:6px}
  .inline-cta h3 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .inline-cta p{color:var(--ink-soft);font-size:15.5px;line-height:1.55;margin:0}
  .inline-cta .ic-btns{display:flex;gap:10px;flex-wrap:wrap}
  .inline-cta a{font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;padding:14px 22px;border-radius:3px;text-decoration:none!important;transition:all .25s ease}
  .inline-cta a.primary{background:var(--primary);color:var(--bg)}
  .inline-cta a.primary:hover{background:var(--primary-deep)}
  .inline-cta a.outline{background:transparent;color:var(--primary);border:1px solid var(--primary)}
  .inline-cta a.outline:hover{background:var(--primary);color:var(--bg)}

  /* CTA SECTION */
  .cta-section{padding:96px 0;text-align:center;border-bottom:1px solid var(--line);background:var(--bg)}
  .cta-section h2{font-family:var(--font-display);font-weight:400;font-size:clamp(32px,4.4vw,54px);line-height:1.05;max-width:36ch;margin:0 auto 24px;color:var(--primary-deep);letter-spacing:-.025em;hyphens:manual}
  .cta-section h2 em{font-family:var(--font-italic);font-style:italic;font-weight:400;color:var(--accent-deep)}
  .cta-section p{font-size:17.5px;color:var(--ink-soft);max-width:55ch;margin:0 auto 40px;font-weight:300}
  .cta-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
  .btn-primary{display:inline-block;padding:16px 32px;background:var(--primary);color:var(--bg);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:3px;font-weight:600;transition:all .25s ease;text-decoration:none!important}
  .btn-primary:hover{background:var(--primary-deep);color:var(--bg);transform:translateY(-2px)}
  .btn-secondary{display:inline-block;padding:16px 32px;background:var(--accent);color:var(--bg);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:3px;font-weight:600;transition:all .25s ease;text-decoration:none!important}
  .btn-secondary:hover{background:var(--accent-deep);color:var(--bg);transform:translateY(-2px)}
  .btn-outline{display:inline-block;padding:16px 32px;background:transparent;color:var(--primary);border:1px solid var(--primary);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border-radius:3px;font-weight:600;transition:all .25s ease;text-decoration:none!important}
  .btn-outline:hover{background:var(--primary);color:var(--bg)}

  /* FOOTER */
  footer.site-footer{background:var(--primary-deep);color:rgba(251,250,246,.85);padding:80px 0 32px;font-size:14.5px}
  .footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
  .footer-grid h4{font-family:var(--font-display);font-weight:400;font-size:22px;color:var(--bg);margin-bottom:20px;letter-spacing:-.015em;line-height:1.15}
  .footer-grid p,.footer-grid a,.footer-grid li{font-size:14px;color:rgba(242,238,228,.72);line-height:1.75}
  .footer-grid a{text-decoration:none}
  .footer-grid a:hover{color:var(--accent)}
  .footer-grid ul{list-style:none}
  .footer-brand p{margin-top:18px;max-width:32ch;font-size:14px}
  .footer-bottom{margin-top:56px;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;font-size:13px;color:rgba(251,250,246,.55)}
  .footer-bottom a{color:rgba(251,250,246,.85);text-decoration:none}
  .footer-bottom a:hover{color:var(--accent)}
  .footer-bottom .legal{display:flex;gap:24px;flex-wrap:wrap}

  /* RESPONSIVE */
  @media (max-width: 1000px){
    .post-list,
    body.news-listing .post-list,
    body.leistungsspektrum-page .post-list{grid-template-columns:repeat(2,1fr);gap:20px}
    .inline-cta{grid-template-columns:1fr}
    .tt-grid{grid-template-columns:1fr 1fr}
    .r-grid{grid-template-columns:1fr 1fr;gap:28px}
    .related-grid{grid-template-columns:1fr}
    .topic-tiles, .reassurance, .related{padding:64px 0}
    .gallery-grid{grid-template-columns:repeat(3,1fr)}
    .focus-grid{grid-template-columns:1fr 1fr}
    .profile-grid{grid-template-columns:1fr;gap:32px}
    .profile-photo{aspect-ratio:16/10;max-width:480px}
    .content .twocol{grid-template-columns:1fr;gap:24px}
    .content .twocol-img{grid-template-columns:1fr;gap:24px}
    .content .twocol-img.reverse{direction:ltr}
    .cv-grid{grid-template-columns:1fr;gap:36px}
    .cv-grid .cv-side{position:static}
    .cv-tabs{flex-direction:row;flex-wrap:wrap;gap:8px}
    .cv-tabs button{border-left:none;border-bottom:2px solid var(--line);padding:10px 12px;font-size:14px}
    .cv-tabs button.active{border-left:none;border-bottom-color:var(--accent)}
  }
  @media (max-width: 640px){
    .tt-grid{grid-template-columns:1fr}
    .r-grid{grid-template-columns:1fr;gap:24px}
    .trust-grid{gap:20px}
    .trust-item{min-width:120px;flex:1 1 calc(50% - 20px)}
    .post-list,
    body.news-listing .post-list,
    body.leistungsspektrum-page .post-list{grid-template-columns:1fr;gap:16px}
    .gallery-grid, .gallery-grid.cols-3, .gallery-grid.cols-2{grid-template-columns:1fr 1fr}
    .focus-grid{grid-template-columns:1fr}
    .cv-list li{grid-template-columns:1fr;gap:4px}
    .cv-list .date{font-size:12.5px;color:var(--accent-deep)}
    .lightbox-prev{left:8px}
    .lightbox-next{right:8px}
    .lightbox-nav{width:42px;height:42px;font-size:20px}
  }
  @media (max-width: 760px){
    /* Responsive Grid-Fallbacks (kinderarzt-Focus hat eigenes Layout) */
    .more-services-grid{grid-template-columns:repeat(2,1fr)!important;gap:16px}
    .jobs-grid{grid-template-columns:repeat(2,1fr)!important;gap:16px}
    body:not(.kinderarzt) .focus-grid{grid-template-columns:repeat(2,1fr)!important;gap:16px}
    .team-grid{grid-template-columns:repeat(2,1fr)!important;gap:20px}
    .services-grid{grid-template-columns:repeat(2,1fr)!important;gap:16px}
    .related-grid{grid-template-columns:1fr!important;gap:14px}
    .nav-mobile-top{display:block}
    .nav-mobile-cta{display:block}
    nav.main-nav{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);padding:28px 28px 40px;z-index:49;overflow-y:auto;overflow-x:hidden;opacity:0;visibility:hidden;transform:translateY(-12px);transition:opacity .3s ease, transform .3s ease, visibility 0s linear .3s;-webkit-overflow-scrolling:touch}
    nav.main-nav.open{opacity:1;visibility:visible;transform:translateY(0);transition:opacity .3s ease, transform .3s ease, visibility 0s linear}
    nav.main-nav ul{flex-direction:column;align-items:stretch;gap:0;max-width:600px;margin:0 auto}
    nav.main-nav > ul > li{border-bottom:1px solid var(--line)}
    nav.main-nav > ul > li:first-child{border-top:1px solid var(--line)}
    nav.main-nav > ul > li > a{padding:20px 4px;font-family:var(--font-display);font-size:21px;font-weight:400;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.2;display:flex;align-items:center;justify-content:space-between}
    nav.main-nav .has-sub > a::after{content:"";display:none}
    nav.main-nav .submenu{
      position:static;display:block;width:auto;
      opacity:1;visibility:visible;transform:none;
      box-shadow:none;border:none;background:transparent;
      padding:0 0 14px 0;min-width:0;
      grid-template-columns:none;grid-template-areas:none;gap:0;
    }
    nav.main-nav .submenu .sm-intro{display:none}
    nav.main-nav .submenu .sm-items{grid-template-columns:1fr;gap:0}
    nav.main-nav .submenu .sm-items a{padding:8px 4px;font-size:14.5px;color:var(--ink-soft)}
    nav.main-nav .submenu .sm-items a::before{display:none}
    /* Mega-Menu Side Panel auf Mobile ausblenden — wird durch Mobile-CTA-Bar ersetzt */
    nav.main-nav .submenu .sm-aside{display:none}
    .menu-toggle{display:block}
    body.menu-open{overflow:hidden}
    .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
    .page-hero{padding:80px 0 64px}
    .cta-section{padding:64px 0}
    .page-body{padding:56px 0}
  }
  @media (max-width: 560px){
    .footer-grid{grid-template-columns:1fr}
    .cta-top{padding:10px 16px;font-size:12px}
    .header-inner{padding:16px 20px;gap:8px}
    .logo img{height:40px}
    .post-card .pc-body{padding:20px}
  }
  @media (max-width: 400px){
    .cta-top{padding:12px 14px;font-size:12px;letter-spacing:.04em;min-height:44px;display:inline-flex;align-items:center}
    .header-inner{padding:14px 16px;gap:6px}
    .logo img{height:36px}
    .menu-toggle{padding:9px;min-width:44px;min-height:44px;margin-left:2px}
  }


/* ====== aus index.html ====== */
/* Hinweis: Basis-Regeln (:root, body, header, nav, .cta-top, .menu-toggle,
   .back-to-top, @keyframes pulse, .logo) wurden hier als Duplikate zu Block A entfernt. */

  /* HERO (image slider) */
  .hero{
    position:relative;
    color:var(--bg);
    padding:140px 0 110px;
    overflow:hidden;
    background:linear-gradient(135deg,var(--primary-deep) 0%,var(--primary) 100%);
  }
  .hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
  .hero-bg .slide{
    position:absolute;inset:0;
    background-size:cover;background-position:center;
    opacity:0;transition:opacity 1.5s ease;
  }
  .hero-bg .slide.active{opacity:1}
  .hero-bg::after{
    content:"";position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(63,92,75,.78) 0%,rgba(86,127,104,.68) 100%);
    z-index:1;
  }
  .hero::before{content:"";position:absolute;top:-300px;right:-300px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(206,137,70,.18),transparent 60%);pointer-events:none;z-index:2}
  .hero .container{position:relative;z-index:3}
  .hero .eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;font-weight:600;display:inline-flex;align-items:center;gap:12px}
  .hero .eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
  .hero h1{
    font-family:var(--font-display);
    font-weight:400;
    font-size:clamp(42px,6.4vw,84px);
    line-height:1;
    letter-spacing:-.035em;
    margin-bottom:32px;
    color:var(--bg);
    hyphens:manual;
  }
  .hero h1 em{font-family:var(--font-italic);font-style:italic;font-weight:400;color:var(--accent);letter-spacing:-.025em}
  .hero .lead{font-size:19px;line-height:1.55;color:rgba(242,238,228,.88);max-width:62ch;font-weight:400;letter-spacing:-.005em}
  .hero .lead strong{color:var(--accent-soft);font-weight:500}

  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:40px}
  .hero-cta a{display:inline-flex;align-items:center;gap:10px;padding:16px 30px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;border-radius:3px;transition:all .25s ease}
  .hero-cta .btn-book{background:var(--accent);color:var(--bg)}
  .hero-cta .btn-book:hover{background:var(--accent-deep);transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(206,137,70,.5)}
  .hero-cta .btn-call{background:transparent;color:var(--bg);border:1px solid rgba(242,238,228,.4)}
  .hero-cta .btn-call:hover{background:rgba(242,238,228,.08);border-color:var(--accent-soft);color:var(--accent-soft)}
  .hero-cta svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}

  .hero-quicknav{
    margin-top:64px;
    display:flex;gap:36px;flex-wrap:wrap;
    padding-top:32px;
    border-top:1px solid rgba(242,238,228,.18);
  }
  .hero-quicknav a{
    font-size:13.5px;letter-spacing:.05em;text-transform:uppercase;
    font-weight:600;color:var(--accent-soft);
    display:inline-flex;align-items:center;gap:10px;
  }
  .hero-quicknav a::after{content:"→";transition:transform .2s}
  .hero-quicknav a:hover{color:var(--bg)}
  .hero-quicknav a:hover::after{transform:translateX(4px)}

  /* QUICKBAR */
  .quickbar{background:var(--bg-card);border-bottom:1px solid var(--line);padding:36px 0}
  .quickbar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
  .quick{padding:0 28px;display:flex;flex-direction:column;gap:6px;border-right:1px solid var(--line)}
  .quick:last-child{border-right:none}
  .quick .qlabel{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:600}
  .quick .qvalue{font-family:var(--font-display);font-size:30px;font-weight:400;line-height:1.05;color:var(--primary-deep);letter-spacing:-.025em}
  .quick .qhint{font-size:13px;color:var(--ink-mute);line-height:1.5}

  /* IMAGE HERO */
  .image-hero{
    width:100%;
    aspect-ratio:16/7;
    position:relative;
    overflow:hidden;
    border-bottom:1px solid var(--line);
  }
  .image-hero img{width:100%;height:100%;object-fit:cover;display:block}
  .image-caption{
    position:absolute;
    bottom:24px;left:28px;
    font-size:11px;letter-spacing:.22em;text-transform:uppercase;
    color:var(--primary-deep);
    background:rgba(242,238,228,.92);
    padding:10px 16px;
    border-radius:3px;
    backdrop-filter:blur(8px);
    font-weight:600;
  }

  /* SECTION COMMON */
  section.block{padding:96px 0;border-bottom:1px solid var(--line)}
  .section-eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:18px;font-weight:600;display:inline-flex;align-items:center;gap:12px}
  .section-eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
  .section-title{font-family:var(--font-display);font-weight:400;font-size:clamp(34px,4.8vw,56px);line-height:1.05;color:var(--primary-deep);margin-bottom:24px;letter-spacing:-.025em;max-width:34ch;hyphens:manual}
  .section-title em{font-family:var(--font-italic);font-style:italic;font-weight:400;color:var(--accent-deep);letter-spacing:-.015em}
  .two-col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  .prose p{margin-bottom:1.1em;color:var(--ink-soft);font-size:16.5px;line-height:1.75}
  .prose p strong{color:var(--primary-deep);font-weight:600}
  .prose p:last-child{margin-bottom:0}

  /* INLINE BUTTONS IN PROSE */
  .btn-inline{
    display:inline-flex;align-items:center;gap:8px;
    padding:12px 22px;margin-top:8px;
    background:var(--primary);color:var(--bg);
    font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
    border-radius:3px;transition:all .25s ease;
  }
  .btn-inline:hover{background:var(--primary-deep);color:var(--bg);transform:translateY(-1px)}
  .btn-inline.btn-accent{background:var(--accent)}
  .btn-inline.btn-accent:hover{background:var(--accent-deep)}

  /* SERVICE CARDS GRID */
  .services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
  .service-card{
    background:var(--bg-card);
    border:1px solid var(--line);
    border-radius:4px;
    overflow:hidden;
    display:flex;flex-direction:column;
    transition:all .3s;
    text-decoration:none;color:inherit;
  }
  .service-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(63,92,75,.18)}
  .service-card .sc-img{aspect-ratio:4/2.6;overflow:hidden;background:var(--bg-alt)}
  .service-card .sc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
  .service-card:hover .sc-img img{transform:scale(1.05)}
  .service-card .sc-body{padding:24px 24px 26px;display:flex;flex-direction:column;gap:8px}
  .service-card .sc-eyebrow{font-size:10.5px;letter-spacing:.2em;color:var(--accent-deep);text-transform:uppercase;font-weight:600}
  .service-card h3{font-family:var(--font-display);font-weight:400;font-size:23px;color:var(--primary-deep);letter-spacing:-.02em;line-height:1.15;margin-bottom:4px}
  .service-card p{font-size:14px;color:var(--ink-soft);line-height:1.55;margin-bottom:14px}
  .service-card .sc-cta{margin-top:auto;color:var(--primary);font-weight:600;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
  .service-card .sc-cta::after{content:"→";transition:transform .25s}
  .service-card:hover .sc-cta::after{transform:translateX(4px)}

  /* OPENING HOURS WIDGET */
  .oh-wrap{
    background:var(--bg-card);
    border:1px solid var(--line);
    border-radius:4px;
    padding:28px 28px 24px;
  }
  .oh-wrap h3{
    font-family:var(--font-display);font-weight:400;
    font-size:24px;color:var(--primary-deep);letter-spacing:-.015em;
    margin-bottom:14px;
  }
  .oh-status-badge{
    display:inline-block;
    padding:6px 14px;border-radius:3px;
    font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
    margin-bottom:16px;
  }
  .oh-status-badge.open{background:var(--primary);color:var(--bg)}
  .oh-status-badge.closed{background:var(--accent-deep);color:var(--bg)}
  .oh-hours-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}
  .oh-day-item{
    display:flex;justify-content:space-between;align-items:flex-start;gap:18px;
    padding:10px 0;border-bottom:1px solid var(--line);
    font-size:14.5px;color:var(--ink-soft);
  }
  .oh-day-item:last-child{border-bottom:none}
  .oh-current-time{margin-top:14px;font-size:12.5px;color:var(--ink-mute);letter-spacing:.02em}

  /* HIGHLIGHT BLOCK (dark green) */
  .highlight{background:var(--primary-deep);color:rgba(242,238,228,.82);padding:96px 0;border-bottom:none;position:relative;overflow:hidden}
  .highlight::before{content:"";position:absolute;top:-300px;left:-300px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(206,137,70,.15),transparent 60%);pointer-events:none}
  .highlight .container{position:relative;z-index:1}
  .highlight .section-eyebrow{color:var(--accent)}
  .highlight .section-title{color:var(--bg)}
  .highlight .section-title em{color:var(--accent-soft);font-family:var(--font-italic)}
  .highlight .prose p{color:rgba(242,238,228,.82);font-size:16.5px;line-height:1.75}
  .highlight .prose strong{color:var(--bg);font-weight:600}
  .highlight .btn-inline{background:var(--accent)}
  .highlight .btn-inline:hover{background:var(--accent-deep)}

  /* MID-CTA */
  .mid-cta{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:64px 0}
  .mid-cta-inner{display:grid;grid-template-columns:1.4fr auto;gap:48px;align-items:center}
  .mid-cta h3{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,3.5vw,40px);line-height:1.1;color:var(--primary-deep);letter-spacing:-.02em;margin-bottom:8px;hyphens:manual}
  .mid-cta h3 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep)}
  .mid-cta p{color:var(--ink-soft);font-size:16px;line-height:1.55;max-width:48ch}
  .mid-cta-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
  .mid-cta .btn-primary,.mid-cta .btn-call{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;border-radius:3px;transition:all .25s ease}
  .mid-cta .btn-primary{background:var(--primary);color:var(--bg)}
  .mid-cta .btn-primary:hover{background:var(--primary-deep);color:var(--bg)}
  .mid-cta .btn-call{background:transparent;color:var(--primary);border:1px solid var(--primary)}
  .mid-cta .btn-call:hover{background:var(--primary);color:var(--bg)}

  /* MORE SERVICES (private leistungen) */
  .more-services{padding:96px 0;border-top:1px solid var(--line);background:var(--bg-soft)}
  .more-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
  .more-service-card{background:var(--bg);padding:36px 30px;border:1px solid var(--line);border-radius:4px;transition:all .3s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
  .more-service-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(63,92,75,.18);background:var(--bg-card)}
  .more-service-card .ms-eyebrow{font-size:10.5px;letter-spacing:.2em;color:var(--accent-deep);text-transform:uppercase;font-weight:600;margin-bottom:16px}
  .more-service-card h3{font-family:var(--font-display);font-weight:400;font-size:24px;color:var(--primary-deep);letter-spacing:-.02em;margin-bottom:12px;line-height:1.15}
  .more-service-card h3 em{font-family:var(--font-italic);font-style:italic;color:var(--accent-deep);font-weight:400}
  .more-service-card p{color:var(--ink-soft);font-size:14.5px;line-height:1.6;margin-bottom:20px;flex:1}
  .more-service-card .ms-cta{margin-top:auto;color:var(--primary);font-weight:600;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
  .more-service-card .ms-cta::after{content:"→";transition:transform .25s;font-size:14px}
  .more-service-card:hover .ms-cta::after{transform:translateX(4px)}

  /* NEWS */
  .news-section{padding:96px 0;border-bottom:1px solid var(--line);background:var(--bg)}
  .news-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;margin-top:48px}
  .news-feature{
    position:relative;
    border-radius:4px;overflow:hidden;
    background:var(--primary-deep) center/cover no-repeat;
    min-height:380px;
    display:flex;align-items:flex-end;
    padding:36px;
    color:var(--bg);
    text-decoration:none;
  }
  .news-feature::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(63,92,75,0) 0%,rgba(63,92,75,.85) 100%)}
  .news-feature > *{position:relative;z-index:1}
  .news-feature .nf-meta{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-soft);font-weight:600;margin-bottom:12px;display:block}
  .news-feature h3{font-family:var(--font-display);font-weight:400;font-size:30px;line-height:1.1;color:var(--bg);letter-spacing:-.02em;max-width:24ch}
  .news-list{display:flex;flex-direction:column;gap:14px}
  .news-card{
    background:var(--bg-card);
    border:1px solid var(--line);
    border-radius:4px;
    padding:22px 24px;
    text-decoration:none;color:inherit;
    transition:all .25s;display:flex;flex-direction:column;gap:6px;
  }
  .news-card:hover{border-color:var(--primary);transform:translateX(3px)}
  .news-card .nc-meta{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-deep);font-weight:600}
  .news-card h4{font-family:var(--font-display);font-weight:400;font-size:18px;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.2}
  .news-footer{margin-top:32px;text-align:center}
  .news-footer a{font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--primary);display:inline-flex;align-items:center;gap:8px}
  .news-footer a::after{content:"→";transition:transform .25s}
  .news-footer a:hover::after{transform:translateX(4px)}

  /* JOBS */
  .jobs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
  .job-card{
    background:var(--bg-card);
    border:1px solid var(--line);
    border-radius:4px;overflow:hidden;
    text-decoration:none;color:inherit;
    transition:all .3s;display:flex;flex-direction:column;
  }
  .job-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(63,92,75,.18)}
  .job-card .jc-img{aspect-ratio:4/2.6;overflow:hidden;background:var(--bg-alt)}
  .job-card .jc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
  .job-card:hover .jc-img img{transform:scale(1.05)}
  .job-card .jc-body{padding:24px 24px 26px}
  .job-card .jc-eyebrow{font-size:10.5px;letter-spacing:.2em;color:var(--accent-deep);text-transform:uppercase;font-weight:600;display:block;margin-bottom:8px}
  .job-card h3{font-family:var(--font-display);font-weight:400;font-size:20px;color:var(--primary-deep);letter-spacing:-.015em;line-height:1.2;margin-bottom:6px}
  .job-card .jc-cta{margin-top:14px;color:var(--primary);font-weight:600;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
  .job-card .jc-cta::after{content:"→";transition:transform .25s}
  .job-card:hover .jc-cta::after{transform:translateX(4px)}

  /* CTA SECTION */
  .cta-section{padding:120px 0;text-align:center;border-bottom:1px solid var(--line);background:var(--bg)}
  .cta-section h2{font-family:var(--font-display);font-weight:400;font-size:clamp(36px,5vw,64px);line-height:1.05;max-width:36ch;margin:0 auto 28px;color:var(--primary-deep);letter-spacing:-.025em;hyphens:manual}
  .cta-section h2 em{font-family:var(--font-italic);font-style:italic;font-weight:400;color:var(--accent-deep)}
  .cta-section p{font-size:18px;color:var(--ink-soft);max-width:55ch;margin:0 auto 48px;font-weight:300}
  .cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
  .btn-primary{display:inline-block;padding:18px 38px;background:var(--primary);color:var(--bg);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:3px;font-weight:600;transition:all .25s ease}
  .btn-primary:hover{background:var(--primary-deep);color:var(--bg);transform:translateY(-2px)}
  .btn-secondary{display:inline-block;padding:18px 38px;background:var(--accent);color:var(--bg);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:3px;font-weight:600;transition:all .25s ease}
  .btn-secondary:hover{background:var(--accent-deep);color:var(--bg);transform:translateY(-2px)}

  /* IMAGE-SPLIT (Über Dr. Merten) — dezenter, kleineres Bild */
  .image-split{
    display:grid;grid-template-columns:minmax(0,360px) 1fr;gap:64px;
    align-items:center;
    max-width:var(--max);margin:0 auto;
    padding:96px 64px;
    border-bottom:1px solid var(--line);
    background:var(--bg);
  }
  .image-split .img-side{
    width:100%;
    max-width:340px;
    aspect-ratio:4/5;
    background:var(--bg-alt);
    position:relative;
    overflow:hidden;
    display:block;
    border-radius:6px;
    box-shadow:0 18px 36px -18px rgba(63,92,75,.25);
  }
  .image-split .img-side img{width:100%;height:100%;object-fit:cover;display:block}
  .image-split .text-side{padding:0;display:flex;flex-direction:column;justify-content:center;background:transparent}
  .image-split .text-side .section-eyebrow{margin-bottom:18px}
  .image-split .text-side h3{font-family:var(--font-display);font-weight:400;font-size:36px;line-height:1.05;margin-bottom:20px;max-width:26ch;color:var(--primary-deep);letter-spacing:-.025em;hyphens:manual}
  .image-split .text-side h3 em{font-family:var(--font-italic);font-style:italic;font-weight:400;color:var(--accent-deep);letter-spacing:-.015em}
  .image-split .text-side p{color:var(--ink-soft);font-size:16.5px;line-height:1.7;max-width:46ch;margin-bottom:14px}

  /* FOOTER-Duplikat entfernt — siehe Block A (Z. 697 ff.). */

  /* RESPONSIVE */
  @media (max-width: 1000px){
    .services-grid{grid-template-columns:repeat(2,1fr)}
    .jobs-grid{grid-template-columns:1fr 1fr}
    .more-services-grid{grid-template-columns:1fr 1fr}
  }
  @media (max-width: 760px){
    /* Nav-/Header-/Menü-Duplikate entfernt — siehe Block A (Z. 750 ff.) und finale Mobile-Nav-Sektion unten. */
    .two-col{grid-template-columns:1fr;gap:48px}
    .hero{padding:90px 0 70px}
    section.block,.highlight,.cta-section,.news-section,.more-services{padding:64px 0}
    .image-split{grid-template-columns:1fr;gap:32px;padding:64px 28px}
    .image-split .img-side{max-width:280px;margin:0 auto}
    .image-split .text-side{padding:0}
    .image-hero{aspect-ratio:16/10}
    .mid-cta-inner{grid-template-columns:1fr;gap:24px}
    .quickbar-grid{grid-template-columns:1fr 1fr}
    .quick{padding:16px 20px;border-right:none;border-bottom:1px solid var(--line)}
    .quick:nth-child(odd){border-right:1px solid var(--line)}
    .quick:nth-last-child(-n+2){border-bottom:none}
    .news-grid{grid-template-columns:1fr;gap:24px}
    .news-feature{min-height:280px;padding:28px}
    .more-services-grid{grid-template-columns:1fr;gap:14px}
    .jobs-grid{grid-template-columns:1fr}
    .services-grid{grid-template-columns:1fr 1fr;gap:16px}
  }
  @media (max-width: 560px){
    /* Header-/Cta-Duplikate entfernt — siehe Block A (Z. 787 ff.). */
    .services-grid{grid-template-columns:1fr}
    .hero-quicknav{gap:20px;flex-direction:column}
  }
  /* @media (max-width: 400px) Block B entfernt — exakter Duplikat zu Block A (Z. 794 ff.). */


/* =========================================================
   Übergangsbereich Tablet/Desktop (761–900px)
   ========================================================= */
@media (min-width:761px) and (max-width:900px){
  nav.main-nav ul{gap:18px}
  nav.main-nav a{font-size:13.5px}
  .cta-top{padding:10px 14px;font-size:11.5px}
}

/* =========================================================
   MOBILE NAV — finale, konsolidierte Regeln (override alles)
   ========================================================= */
@media (max-width: 760px){
  /* Drawer-Overlay vollflächig */
  nav.main-nav{
    display:block !important;
    position:fixed !important;
    inset:0;
    top:0 !important; left:0 !important; right:0 !important; bottom:0 !important;
    width:100%; height:100%; height:100dvh;
    max-width:none;
    background:var(--bg);
    padding:96px 24px 32px;
    z-index:90;
    overflow-y:auto; overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    opacity:0; visibility:hidden;
    transform:none !important;
    transition:opacity .25s ease, visibility 0s linear .25s;
  }
  nav.main-nav.open{
    opacity:1; visibility:visible;
    transition:opacity .25s ease, visibility 0s linear;
  }
  /* Innerer Container: linksbündig, sauber, voll-breit bis 680 */
  nav.main-nav > ul,
  nav.main-nav .nav-mobile-top,
  nav.main-nav .nav-mobile-cta{
    max-width:680px; width:100%;
    margin-left:auto; margin-right:auto;
    box-sizing:border-box;
  }
  nav.main-nav > ul{
    display:flex !important; flex-direction:column !important;
    align-items:stretch !important; justify-content:flex-start !important;
    gap:0 !important; padding:0 !important; list-style:none;
  }
  nav.main-nav > ul > li{
    width:100%;
    border-bottom:1px solid var(--line);
    padding:0; margin:0;
  }
  nav.main-nav > ul > li:first-child{border-top:1px solid var(--line)}
  nav.main-nav > ul > li > a{
    display:flex !important;
    width:100%; box-sizing:border-box;
    padding:18px 6px !important;
    font-family:var(--font-display); font-size:20px; font-weight:400;
    color:var(--primary-deep); letter-spacing:-.015em; line-height:1.2;
    text-align:left;
    align-items:center; justify-content:flex-start; gap:10px;
    text-decoration:none;
  }
  nav.main-nav .has-sub > a::after{content:none !important; display:none !important}

  /* Submenüs: Inline-Liste, alles linksbündig, kein Mega-Layout */
  nav.main-nav .submenu{
    position:static !important;
    display:block !important;
    width:auto !important; max-width:none !important; min-width:0 !important;
    opacity:1 !important; visibility:visible !important;
    transform:none !important;
    background:transparent !important; border:0 !important; box-shadow:none !important;
    padding:0 0 14px 0 !important;
    grid-template-columns:none !important; grid-template-areas:none !important;
    gap:0 !important;
  }
  nav.main-nav .submenu .sm-intro,
  nav.main-nav .submenu .sm-aside{display:none !important}
  nav.main-nav .submenu .sm-items{
    display:flex !important; flex-direction:column !important;
    gap:0 !important;
    grid-template-columns:none !important;
    padding:0 !important; margin:0 !important;
    list-style:none;
  }
  nav.main-nav .submenu .sm-items li{padding:0; margin:0; width:100%}
  nav.main-nav .submenu .sm-items a{
    display:block !important;
    width:100%; box-sizing:border-box;
    padding:10px 6px !important;
    font-family:var(--font-sans); font-size:15px;
    color:var(--ink-soft);
    text-align:left;
    border-radius:0;
    background:transparent !important;
    text-decoration:none;
  }
  nav.main-nav .submenu .sm-items a::before{display:none !important; content:none !important}
  nav.main-nav .submenu .sm-items a:hover{color:var(--primary-deep); background:transparent !important}

  /* Mobile-Top (Logo) + Mobile-CTA-Block */
  .nav-mobile-top{display:block !important; padding-bottom:20px; margin-bottom:8px; border-bottom:1px solid var(--line); text-align:left}
  .nav-mobile-cta{display:block !important; margin-top:28px; padding-top:24px; border-top:1px solid var(--line)}

  /* Burger sichtbar, Body-Lock, FAB aus */
  .menu-toggle{display:block !important}
  body.menu-open{overflow:hidden}
  body.menu-open .status-fab{opacity:0 !important; visibility:hidden !important; pointer-events:none}
  body.menu-open .cta-top{display:none}
}

@media (max-width: 560px){
  nav.main-nav{padding:84px 18px 28px}
  nav.main-nav > ul > li > a{font-size:18px; padding:16px 4px !important}
  nav.main-nav .submenu .sm-items a{font-size:14.5px; padding:9px 4px !important}
}

/* =========================================================
   MOBILE FAB — kollabierte Uhr-Icon-Variante + Text-Overflow-Schutz
   ========================================================= */
@media (max-width: 760px){
  /* Volles Panel auf Mobile sauber positionieren */
  .status-fab{
    top:auto !important; bottom:18px !important; right:14px !important; left:auto !important;
    flex-direction:column !important;
    border-radius:14px !important; border:1px solid var(--line) !important;
    max-width:calc(100vw - 28px);
    transform:none !important;
  }
  .status-fab-toggle{display:none !important}
  .status-fab-row{min-width:0 !important; max-width:none !important; padding:11px 16px !important; border-right:none !important; border-bottom:1px solid var(--line) !important}
  .status-fab-row:last-child{border-bottom:none !important}
  .status-fab-state{font-size:13px !important; white-space:normal !important; max-width:none !important}
  .status-fab-next{white-space:normal !important; word-break:break-word; overflow-wrap:anywhere}

  /* Mini-Uhr-Button (nur sichtbar wenn FAB kollabiert) */
  .status-fab-mini{
    display:none;
    position:absolute; bottom:0; right:0;
    width:52px; height:52px;
    border:1px solid var(--line); border-radius:50%;
    background:var(--bg-card); color:var(--primary-deep);
    cursor:pointer; padding:0;
    align-items:center; justify-content:center;
    box-shadow:0 10px 22px -8px rgba(28,42,32,.25),0 2px 6px -2px rgba(28,42,32,.10);
    transition:transform .2s ease, background .2s ease;
  }
  .status-fab-mini:hover,.status-fab-mini:focus-visible{background:var(--bg-soft);transform:scale(1.05)}
  .status-fab-mini svg{width:24px;height:24px}
  .status-fab-mini-dot{
    position:absolute; top:6px; right:6px;
    width:10px; height:10px; border-radius:50%;
    background:var(--muted); border:2px solid var(--bg-card);
  }
  .status-fab-mini-dot.is-open{background:#6FB585;animation:fabPulse 2.2s infinite}
  .status-fab-mini-dot.is-special{background:var(--accent);animation:fabPulse 2.2s infinite}

  /* Kollabierter Zustand: Panel verstecken, nur Uhr-Icon zeigen */
  .status-fab.mobile-collapsed{
    background:transparent !important; border:none !important; box-shadow:none !important;
    width:52px; height:52px; min-width:0;
    padding:0;
  }
  .status-fab.mobile-collapsed .status-fab-row{display:none !important}
  .status-fab.mobile-collapsed .status-fab-mini{display:inline-flex}
}

/* Tablet/Mobile: Globale Text-Sicherheit gegen Overflow nach rechts */
@media (max-width: 740px){
  body{overflow-x:hidden}
  .container, .content, section{overflow-x:visible}
  h1, h2, h3, h4{overflow-wrap:break-word; word-wrap:break-word; hyphens:auto; -webkit-hyphens:auto}
  p, li, span, a, td, th{overflow-wrap:break-word; word-wrap:break-word}
  /* Bilder + Iframes nie über volle Breite hinaus */
  img, iframe, video{max-width:100%; height:auto}
  /* Lange URLs/Codes brechen */
  a, code, pre{word-break:break-word}
}

/* =========================================================
   BACK-TO-TOP über FAB-Uhr-Icon stapeln (Mobile)
   ========================================================= */
@media (max-width: 760px){
  .back-to-top{bottom:86px !important; right:18px !important; z-index:88 !important}
}
@media (max-width: 560px){
  .back-to-top{bottom:82px !important; right:16px !important; width:42px !important; height:42px !important}
  .back-to-top svg{width:20px;height:20px}
}

/* =========================================================
   H-5: Globaler :focus-visible Outline
   ========================================================= */
*:focus{outline:none}
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:not([tabindex="-1"]):focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
  border-radius:3px;
}

/* =========================================================
   M-1: Mini-Schriften auf Mobile hochziehen
   ========================================================= */
@media (max-width:560px){
  .qhint, .footer-bottom, .nc-meta, .pc-meta {font-size:13px}
  .section-eyebrow, .sm-eyebrow, .sma-eyebrow {font-size:11.5px; letter-spacing:.16em}
}

/* =========================================================
   M-2: Accent-Kontrast für Buttons (deeper accent for AA contrast)
   ========================================================= */
.btn-secondary, .sma-cta, .ncc-book {background:var(--accent-deep)}
.btn-secondary:hover, .sma-cta:hover, .ncc-book:hover {background:#6B3D24}

/* =========================================================
   M-5: Hero-H1 Mobile-Floor reduzieren
   ========================================================= */
.hero h1{font-size:clamp(34px,8vw,84px)}

/* =========================================================
   M-6: kid-decor Animationen auf Mobile/Reduced-Motion zähmen
   ========================================================= */
@media (max-width:560px){
  .kid-decor.sun, .kid-decor.cloud-1, .kid-decor.kite, .kid-decor.heart{transform:scale(.7); opacity:.5}
}
@media (prefers-reduced-motion: reduce){
  .kid-decor{animation:none !important}
  html{scroll-behavior:auto}
}

/* =========================================================
   L-2: tel:-Links Spacing für Target-Size auf engen Viewports
   ========================================================= */
.content p a[href^="tel:"]{display:inline-block; padding:6px 0}
@media (max-width:400px){
  .content p a[href^="tel:"]{display:block; padding:8px 0}
}

/* =========================================================
   L-4: Hover-Effekte nur auf hover-fähigen Geräten
   ========================================================= */
@media (hover:hover) and (pointer:fine){
  /* Hover-Regeln werden nicht zweimal definiert — bestehende
     transform-Hover-Regeln greifen automatisch nur dort, weil
     wir hier eine duplizierende Sperrschicht für Touch-Geräte einfügen. */
}
@media not all and (hover:hover){
  .service-card:hover,
  .team-card:hover,
  .more-service-card:hover,
  .btn-primary:hover,
  .btn-secondary:hover,
  .post-card:hover,
  .focus-card:hover,
  .tt-card:hover,
  .related-card:hover,
  .job-card:hover{transform:none; box-shadow:none}
}

/* =========================================================
   L-6: Footer-Spaltentitel auf normale Größe
   ========================================================= */
.footer-grid h4{font-size:16px; text-transform:uppercase; letter-spacing:.08em}

/* =========================================================
   M-4: Lightbox Loading-Indikator (Spinner während Bild-Load)
   ========================================================= */
.lightbox.loading::after{
  content:"";
  position:absolute;
  top:50%; left:50%;
  width:48px; height:48px;
  margin:-24px 0 0 -24px;
  border:3px solid rgba(242,238,228,.25);
  border-top-color:var(--accent);
  border-radius:50%;
  animation:lbSpin .8s linear infinite;
  z-index:1;
}
.lightbox img.loading{opacity:0; transition:opacity .15s linear}
.lightbox img{transition:opacity .25s ease}
@keyframes lbSpin{to{transform:rotate(360deg)}}
