/* ===========================================================================
   GESUNDHEITSPRAXIS GROB — Redesign (Wegwarte-Blau-Violett, ruhig & natürlich)
   System-Schriften (kein externer Ladevorgang): Georgia (Serif) + system-ui
   =========================================================================== */
:root{
  --brand:#6f77c9;         /* Wegwarte-Blau-Violett (Hauptfarbe) */
  --brand-2:#525bb0;       /* tiefer (Hover/Verläufe) */
  --brand-soft:#eef0fb;    /* heller Tint (Flächen) */
  --green:#7d9b6b;         /* sanftes Natur-Grün (Akzent) */
  --ink:#2a2d3a;           /* Überschriften/Kontrast */
  --ink-2:#565b69;         /* Fließtext */
  --cream:#fbfaf7;         /* warmes Off-White (Seiten-BG) */
  --line:#e8e7e1;          /* zarte Linien */
  --shadow:0 18px 40px rgba(40,42,70,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,'Segoe UI',sans-serif;
  color:var(--ink-2);line-height:1.75;background:var(--cream);font-size:17px;-webkit-font-smoothing:antialiased}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
a{color:var(--brand-2)}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:Georgia,'Iowan Old Style','Times New Roman',serif;line-height:1.2;color:var(--ink);margin:0;font-weight:600}
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:inherit;font-weight:600;
  text-decoration:none;cursor:pointer;border:none;border-radius:999px;padding:13px 26px;font-size:16px;
  background:var(--brand);color:#fff;box-shadow:0 8px 22px rgba(111,119,201,.4);transition:transform .15s,box-shadow .15s,background .15s}
.btn:hover{transform:translateY(-2px);background:var(--brand-2);box-shadow:0 12px 28px rgba(82,91,176,.45)}
.btn.ghost{background:transparent;color:var(--brand-2);box-shadow:none;border:2px solid var(--brand)}
.btn.ghost:hover{background:var(--brand-soft);transform:translateY(-2px)}

/* ----------------------------- HEADER ----------------------------- */
header.site{background:rgba(255,255,255,.95);backdrop-filter:saturate(160%) blur(8px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;box-shadow:0 2px 14px rgba(0,0,0,.04)}
header.site:before{content:"";display:block;height:4px;background:linear-gradient(90deg,var(--brand),var(--brand-2) 60%,var(--green))}
.bar{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:86px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--ink)}
.brand img.logo{height:56px;width:56px;object-fit:cover;border-radius:50%;box-shadow:0 3px 12px rgba(40,42,70,.18)}
.brand .brandtext{display:flex;flex-direction:column;line-height:1.2}
.brand strong{font-family:Georgia,serif;font-size:21px;color:var(--ink)}
.brand small{font-size:12px;color:var(--ink-2);opacity:.8;letter-spacing:.3px}
header nav{display:flex;flex-wrap:wrap;gap:2px;align-items:center}
header nav a{padding:10px 14px;border-radius:9px;text-decoration:none;color:var(--ink);font-weight:500;font-size:15px;position:relative}
header nav a:hover{color:var(--brand-2)}
header nav a.active{color:var(--brand-2)}
header nav a.active:after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:3px;border-radius:3px;background:var(--brand)}
.dd{position:relative}
.dd-menu{position:absolute;left:0;top:100%;background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);padding:10px;min-width:255px;display:none;flex-direction:column;gap:1px;z-index:60}
.dd:hover .dd-menu,.dd:focus-within .dd-menu{display:flex}
.dd-menu a{white-space:nowrap;color:var(--ink);border-radius:9px;padding:9px 13px;font-weight:500;font-size:15px}
.dd-menu a:hover{background:var(--brand-soft);color:var(--brand-2)}
.navt{display:none}.burger{display:none;font-size:28px;cursor:pointer;color:var(--brand-2)}

/* ------------------------- HERO (Split) --------------------------- */
.hero{background:linear-gradient(180deg,#fff,var(--brand-soft));padding:62px 0}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:.5em;background:var(--brand);color:#fff;
  font-weight:600;font-size:13px;letter-spacing:.6px;text-transform:uppercase;padding:7px 15px;border-radius:999px}
.hero h1{font-size:clamp(34px,5vw,54px);margin:.35em 0 .25em;color:var(--ink)}
.hero .lead{font-size:clamp(18px,2.2vw,21px);color:var(--ink-2);margin:0 0 1.5em}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap}
.hero-media img{width:100%;max-height:430px;object-fit:cover;border-radius:22px;box-shadow:var(--shadow)}

/* ---------------------------- SECTIONS ---------------------------- */
.section{padding:74px 0}
.section.alt{background:#fff}
.section-head{text-align:center;max-width:760px;margin:0 auto 44px}
.section-head .kicker{font-weight:700;color:var(--brand-2);text-transform:uppercase;letter-spacing:1.5px;font-size:13px;font-family:system-ui,sans-serif}
.section-head h2{font-size:clamp(28px,4vw,40px);margin:.25em 0 .35em}
.section-head h2 .u{box-shadow:inset 0 -.3em 0 var(--brand-soft)}
.section-head p{font-size:18px;color:var(--ink-2);margin:0}

/* Split-Zeile (Bild + Text), z. B. „Corinne Grob" */
.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:center;max-width:1040px;margin:0 auto}
.split.flip{grid-template-columns:1.15fr .85fr}
.split.flip .split-media{order:2}
.split-media img{width:100%;border-radius:20px;box-shadow:var(--shadow);max-height:460px;object-fit:cover}
.split h2{font-size:clamp(26px,3.4vw,36px);margin-bottom:.4em}
.split .cred{color:var(--brand-2);font-weight:600}

/* Therapie-Karten */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 24px;display:flex;flex-direction:column;
  box-shadow:0 8px 22px rgba(40,42,70,.06);transition:transform .18s,box-shadow .18s;text-decoration:none;color:inherit}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--brand)}
.card h3{font-size:21px;margin-bottom:.4em;color:var(--ink)}
.card h3:before{content:"";display:inline-block;width:22px;height:4px;border-radius:3px;background:var(--brand);vertical-align:middle;margin-right:9px}
.card p{margin:0 0 1em;color:var(--ink-2)}
.card .more{margin-top:auto;font-weight:600;color:var(--brand-2)}

/* Galerie */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.gallery a{display:block;overflow:hidden;border-radius:16px;aspect-ratio:4/3;box-shadow:0 8px 20px rgba(40,42,70,.1);cursor:zoom-in}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .45s}
.gallery a:hover img{transform:scale(1.08)}

/* CTA-Band */
.cta{background:linear-gradient(120deg,var(--brand),var(--brand-2));color:#fff;text-align:center;padding:66px 24px}
.cta h2{color:#fff;font-size:clamp(26px,4vw,38px);margin-bottom:.3em}
.cta p{font-size:19px;max-width:620px;margin:0 auto 1.5em;opacity:.95}
.cta .btn{background:#fff;color:var(--brand-2);box-shadow:0 8px 22px rgba(0,0,0,.18)}
.cta .btn:hover{background:var(--cream)}

/* ------------------- INHALTSSEITEN (Unterseiten) ------------------ */
.content{padding:52px 24px 70px;max-width:880px}
.content h1{font-size:clamp(30px,5vw,44px);margin:.1em 0 .5em;color:var(--ink)}
.content h1:after{content:"";display:block;width:80px;height:5px;border-radius:4px;margin-top:.35em;background:var(--brand)}
.content h2{font-size:27px;margin:1.5em 0 .5em;color:var(--ink)}
.content h2:before{content:"";display:inline-block;width:20px;height:4px;border-radius:3px;background:var(--brand);vertical-align:middle;margin-right:9px}
.content h3{font-size:20px;color:var(--brand-2);margin:1.2em 0 .4em}
.content p{margin:.85em 0}.content ul,.content ol{margin:.85em 0;padding-left:1.4em}.content li{margin:.35em 0}
.content img{margin:1.3em 0;border-radius:16px;box-shadow:var(--shadow);max-width:520px}
.content figure{margin:1.4em 0}.content figcaption{font-size:14px;color:#8a8a8a;text-align:center;margin-top:.5em}
.content blockquote{border-left:5px solid var(--brand);margin:1.2em 0;padding:.55em 1.3em;background:var(--brand-soft);border-radius:0 14px 14px 0;font-style:italic}
.content a{font-weight:600}
.content table{border-collapse:collapse;width:100%;margin:1.2em 0}.content td,.content th{border:1px solid var(--line);padding:10px}

/* ----------------------------- FOOTER (schlank) ------------------- */
footer.site{background:var(--ink);color:#b7bac6;padding:26px 0;border-top:3px solid var(--brand)}
footer.site .footbar{display:flex;flex-wrap:wrap;gap:10px 24px;align-items:center;justify-content:space-between}
footer.site .copy{margin:0;font-size:13.5px;opacity:.85}
footer.site .flinks{display:flex;gap:20px;flex-wrap:wrap}
footer.site a{color:#cfd1da;text-decoration:none;font-size:14px}
footer.site a:hover{color:#fff}

/* ------------------- ÜBER MICH (Zeitleiste etc.) ------------------ */
.wrap.narrow{max-width:820px}
.block-h{font-family:Georgia,'Times New Roman',serif;font-weight:600;font-size:clamp(24px,3.4vw,32px);color:var(--ink);margin:1.7em 0 .6em}
.block-h:first-child{margin-top:0}
.block-h:before{content:"";display:inline-block;width:20px;height:4px;border-radius:3px;background:var(--brand);vertical-align:middle;margin-right:10px}
.timeline{list-style:none;padding:0;margin:1.1em 0 0}
.timeline li{display:flex;gap:18px;padding:13px 2px;border-bottom:1px solid var(--line)}
.timeline li:last-child{border-bottom:none}
.timeline .yr{flex:0 0 118px;font-weight:700;color:var(--brand-2);font-variant-numeric:tabular-nums}
@media(max-width:540px){.timeline li{flex-direction:column;gap:2px}.timeline .yr{flex:none}}
.content .backlink{margin-top:2.6em;font-weight:600}

/* ----------------------------- KONTAKT ---------------------------- */
.contact{display:grid;grid-template-columns:1fr 1.15fr;gap:34px;align-items:stretch;max-width:1000px;margin:0 auto}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:34px;box-shadow:0 8px 22px rgba(40,42,70,.06);display:flex;flex-direction:column}
.contact-card h3{font-size:24px;margin-bottom:.5em}
.contact-card address{font-style:normal;font-size:19px;line-height:1.7;color:var(--ink);margin:.2em 0 1em}
.contact-card .ci{margin:.35em 0;color:var(--ink-2)}
.contact-card .ci a{color:var(--brand-2);font-weight:600}
.contact-card .btn{margin-top:auto;align-self:flex-start}
.map{display:block;position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);min-height:300px}
.map img{width:100%;height:100%;object-fit:cover;display:block}
.map .map-cta{position:absolute;left:14px;top:14px;background:#fff;color:var(--brand-2);font-weight:600;font-size:14px;padding:8px 14px;border-radius:999px;box-shadow:0 4px 14px rgba(0,0,0,.18)}
@media(max-width:860px){.contact{grid-template-columns:1fr}.map{min-height:260px}}

/* ----------------------------- LIGHTBOX --------------------------- */
.lb{position:fixed;inset:0;background:rgba(20,20,28,.92);display:none;align-items:center;justify-content:center;padding:24px;z-index:200;cursor:zoom-out}
.lb.open{display:flex}
.lb img{max-width:95vw;max-height:90vh;border-radius:12px;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.lb .x{position:absolute;top:14px;right:24px;color:#fff;font-size:42px;line-height:1;cursor:pointer;opacity:.85}
.lb .x:hover{opacity:1}

/* ------------------------ SCROLL-EINBLENDUNG ---------------------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none}}

/* ---------------------------- RESPONSIVE -------------------------- */
@media(max-width:860px){
  .burger{display:block;order:3}
  header nav{display:none;flex-direction:column;width:100%;align-items:stretch;padding-top:8px}
  .navt:checked ~ nav{display:flex}
  .dd-menu{position:static;display:flex;box-shadow:none;border:none;padding-left:14px;min-width:0}
  .hero .wrap{grid-template-columns:1fr;gap:30px}
  .hero-media{order:-1}
  .split,.split.flip{grid-template-columns:1fr;gap:26px}
  .split.flip .split-media{order:0}
  .section{padding:50px 0}
}
