/* =========================================================================
   Reusrather Gemeinschaftspraxis – Bento Grid Theme
   Design: Bento Grid Showcase · Apple-style, modular, cards
   Fonts: Libre Bodoni (Display) / Public Sans (Body)
   Palette: Off-white base + ruhiger, medizinischer Teal-Akzent (Farb-Guardrail)
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Libre+Bodoni:wght@400;500;600;700&family=Public+Sans:wght@300;400;500;600;700&display=swap');

:root{
  /* Bento design tokens */
  --grid-gap: 20px;
  --card-radius: 24px;
  --card-bg: #FFFFFF;
  --page-bg: #F5F5F7;

  /* Farbwelt (natürlich, medizinisch, vertrauenswürdig) */
  --ink: #1D1D1F;
  --muted: #6E6E73;
  --line: #E9E9EE;
  --accent: #2C6E6B;      /* ruhiger Teal */
  --accent-600: #235754;
  --accent-050: #E9F2F1;
  --accent-ink: #16413F;

  /* Schatten (soft, apple-like) */
  --shadow: 0 1px 2px rgba(20,20,25,.04), 0 10px 28px rgba(20,20,25,.055);
  --shadow-lg: 0 6px 16px rgba(20,20,25,.07), 0 26px 60px rgba(20,20,25,.12);

  --container: 1200px;
  --radius-sm: 14px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset & Base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:"Public Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
  background:var(--page-bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,video,iframe{ max-width:100%; height:auto; display:block; }
svg{ max-width:100%; height:auto; }
a{ color:var(--accent-600); text-decoration:none; transition:color .2s var(--ease); }
a:hover{ color:var(--accent); }

/* Icon-Guardrail: SVG-Icons bleiben klein und dezent */
.icon{ width:1.4em; height:1.4em; flex:0 0 auto; vertical-align:middle; stroke:currentColor; }
.icon--lg{ width:26px; height:26px; }

h1,h2,h3,h4{ font-family:"Libre Bodoni", Georgia, "Times New Roman", serif; font-weight:600; line-height:1.12; color:var(--ink); margin:0 0 .5em; letter-spacing:-.01em; }
h1{ font-size:clamp(2.2rem, 5vw, 3.5rem); }
h2{ font-size:clamp(1.7rem, 3.4vw, 2.6rem); }
h3{ font-size:clamp(1.2rem, 2vw, 1.5rem); }
p{ margin:0 0 1rem; }
.lead{ font-size:clamp(1.05rem,1.6vw,1.25rem); color:var(--muted); }

.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:clamp(18px,4vw,32px); }
.section{ padding-block:clamp(56px,8vw,104px); }
.section--tight{ padding-block:clamp(40px,6vw,72px); }

.eyebrow{
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:"Public Sans",sans-serif; font-weight:600; font-size:.82rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--accent-600);
  background:var(--accent-050); padding:.4rem .8rem; border-radius:999px;
}
.section-head{ max-width:760px; margin-bottom:clamp(28px,4vw,44px); }
.section-head .lead{ margin-top:.6rem; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55rem; cursor:pointer;
  font-family:"Public Sans",sans-serif; font-weight:600; font-size:1rem;
  padding:.85rem 1.5rem; border-radius:999px; border:1px solid transparent;
  min-height:48px; transition:transform .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease), color .2s var(--ease);
}
.btn--primary{ background:var(--accent); color:#fff; box-shadow:0 8px 20px rgba(44,110,107,.28); }
.btn--primary:hover{ background:var(--accent-600); color:#fff; transform:translateY(-2px); box-shadow:0 12px 26px rgba(44,110,107,.34); }
.btn--ghost{ background:#fff; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--accent); color:var(--accent-600); transform:translateY(-2px); }
.btn--light{ background:rgba(255,255,255,.16); color:#fff; border-color:rgba(255,255,255,.4); }
.btn--light:hover{ background:rgba(255,255,255,.28); color:#fff; transform:translateY(-2px); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(245,245,247,.82); backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:2rem; min-height:74px; }
.brand{ display:flex; align-items:center; gap:.7rem; font-family:"Libre Bodoni",serif; font-weight:600; font-size:1.18rem; color:var(--ink); line-height:1.1; }
.brand:hover{ color:var(--ink); }
.brand__mark{ width:42px; height:42px; border-radius:12px; background:var(--accent); color:#fff; display:grid; place-items:center; flex:0 0 auto; }
.brand__mark .icon{ width:22px; height:22px; }
.brand small{ display:block; font-family:"Public Sans",sans-serif; font-weight:500; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }

.nav__menu{ display:flex; align-items:center; gap:.4rem; list-style:none; margin:0; padding:0; }
.nav__menu a{ display:block; padding:.55rem .95rem; border-radius:10px; color:var(--ink); font-weight:500; font-size:.98rem; transition:background .18s var(--ease), color .18s var(--ease); }
.nav__menu a:hover, .nav__menu .current-menu-item > a{ background:#fff; color:var(--accent-600); box-shadow:var(--shadow); }
.nav__actions{ display:flex; align-items:center; gap:.8rem; }

.nav__toggle{ display:none; align-items:center; justify-content:center; width:48px; height:48px; border:1px solid var(--line); background:#fff; border-radius:12px; cursor:pointer; color:var(--ink); }
.nav__toggle .icon{ width:24px; height:24px; }

/* ---------- Bento Grid ---------- */
.bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:var(--grid-gap);
}
.card{
  background:var(--card-bg);
  border:1px solid var(--line);
  border-radius:var(--card-radius);
  box-shadow:var(--shadow);
  padding:clamp(22px,3vw,34px);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  min-width:0;
}
.card--hover:hover, a.card:hover{ transform:scale(1.02); box-shadow:var(--shadow-lg); }
.card--media{ padding:0; overflow:hidden; }
.card--media img{ width:100%; height:100%; object-fit:cover; }
.card--accent{ background:var(--accent); color:#fff; border-color:transparent; }
.card--accent h2,.card--accent h3{ color:#fff; }
.card--soft{ background:var(--accent-050); border-color:transparent; }

/* Spans */
.col-3{ grid-column:span 3; }
.col-4{ grid-column:span 4; }
.col-5{ grid-column:span 5; }
.col-6{ grid-column:span 6; }
.col-7{ grid-column:span 7; }
.col-8{ grid-column:span 8; }
.col-12{ grid-column:span 12; }
.row-2{ grid-row:span 2; }

/* ---------- Hero ---------- */
.hero{ padding-top:clamp(36px,5vw,60px); }
.hero__grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:var(--grid-gap); align-items:stretch; }
.hero__intro{ display:flex; flex-direction:column; justify-content:center; padding:clamp(30px,4vw,52px); }
.hero__intro h1{ margin-top:.6rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.4rem; }
.hero__meta{ display:flex; flex-wrap:wrap; gap:1.4rem; margin-top:1.8rem; padding-top:1.4rem; border-top:1px solid var(--line); }
.hero__meta div{ display:flex; align-items:center; gap:.55rem; font-size:.95rem; color:var(--muted); }
.hero__meta .icon{ color:var(--accent); }
.hero__media{ position:relative; min-height:340px; }
.hero__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(200deg,transparent 45%,rgba(22,65,63,.35)); }
.hero__badge{
  position:absolute; left:20px; bottom:20px; z-index:2;
  background:rgba(255,255,255,.92); backdrop-filter:blur(6px);
  border-radius:16px; padding:.85rem 1.1rem; display:flex; align-items:center; gap:.7rem;
  box-shadow:var(--shadow); font-weight:600; font-size:.95rem;
}
.hero__badge .icon{ color:var(--accent); }

/* ---------- Info-Kacheln ---------- */
.info-card{ display:flex; flex-direction:column; gap:.5rem; }
.info-card__ico{ width:48px; height:48px; border-radius:14px; background:var(--accent-050); color:var(--accent-600); display:grid; place-items:center; margin-bottom:.4rem; }
.info-card__ico .icon{ width:24px; height:24px; }
.info-card h3{ margin:0; }
.info-card .muted{ color:var(--muted); font-size:.98rem; }
.info-card--accent .info-card__ico{ background:rgba(255,255,255,.18); color:#fff; }
.info-card--accent .muted{ color:rgba(255,255,255,.85); }

.stat{ font-family:"Libre Bodoni",serif; font-size:clamp(2rem,4vw,2.8rem); line-height:1; margin:.2rem 0; }

/* Kontaktzeilen (Icon dezent neben Text) */
.contact-line{ display:flex; align-items:center; gap:.6rem; margin:.35rem 0; }
.contact-line .icon{ color:var(--accent); flex-shrink:0; }
.contact-line a{ color:inherit; }
.card--accent .contact-line .icon{ color:#fff; }

/* Hours list */
.hours{ list-style:none; margin:.4rem 0 0; padding:0; }
.hours li{ display:flex; justify-content:space-between; gap:1rem; padding:.5rem 0; border-bottom:1px solid var(--line); font-size:.97rem; }
.hours li:last-child{ border-bottom:0; }
.hours span:first-child{ color:var(--muted); }
.hours span:last-child{ font-weight:600; }
.card--accent .hours li{ border-color:rgba(255,255,255,.22); }
.card--accent .hours span:first-child{ color:rgba(255,255,255,.82); }

/* ---------- Leistungen ---------- */
.service{ display:flex; flex-direction:column; height:100%; }
.service__ico{ width:52px; height:52px; border-radius:15px; background:var(--accent-050); color:var(--accent-600); display:grid; place-items:center; margin-bottom:1rem; }
.service__ico .icon{ width:26px; height:26px; }
.service h3{ margin-bottom:.4rem; }
.service p{ color:var(--muted); margin:0; }
.service__more{ margin-top:auto; padding-top:1rem; display:inline-flex; align-items:center; gap:.4rem; font-weight:600; color:var(--accent-600); }
.service__more .icon{ width:18px; height:18px; transition:transform .2s var(--ease); }
a.card:hover .service__more .icon{ transform:translateX(4px); }

/* ---------- Slider (CPT slide) ---------- */
.slider{ position:relative; }
.slider__track{
  display:grid; grid-auto-flow:column; grid-auto-columns:100%;
  overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth;
  gap:var(--grid-gap); border-radius:var(--card-radius);
  -ms-overflow-style:none; scrollbar-width:none;
}
.slider__track::-webkit-scrollbar{ display:none; }
.slide{
  scroll-snap-align:center; position:relative; min-height:clamp(320px,46vw,480px);
  border-radius:var(--card-radius); overflow:hidden; background:#0f2b2a;
}
.slide img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.slide__overlay{ position:absolute; inset:0; background:linear-gradient(90deg,rgba(15,43,42,.82),rgba(15,43,42,.25) 70%); }
.slide__body{ position:relative; z-index:2; max-width:560px; height:100%; display:flex; flex-direction:column; justify-content:center; padding:clamp(26px,5vw,54px); color:#fff; }
.slide__body h3{ color:#fff; font-size:clamp(1.5rem,3vw,2.2rem); }
.slide__body p{ color:rgba(255,255,255,.9); }
.slider__nav{ display:flex; gap:.6rem; justify-content:center; margin-top:1.2rem; }
.slider__dot{ width:10px; height:10px; border-radius:999px; border:0; background:var(--line); cursor:pointer; transition:width .25s var(--ease), background .25s var(--ease); padding:0; }
.slider__dot.is-active{ width:30px; background:var(--accent); }

/* ---------- Praxis-Intro (Text + Bild) ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:var(--grid-gap); align-items:center; }
.split .card--media{ min-height:clamp(300px,40vw,460px); }
.check-list{ list-style:none; margin:1.2rem 0 0; padding:0; display:grid; gap:.7rem; }
.check-list li{ display:flex; align-items:flex-start; gap:.7rem; }
.check-list .icon{ color:var(--accent); margin-top:.15rem; flex-shrink:0; }

/* ---------- Kontakt ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--grid-gap); align-items:start; }
.contact-form-card .wpcf7, .contact-form-card form{ margin-top:.6rem; }
.contact-form-card input:not([type=submit]):not([type=checkbox]):not([type=radio]),
.contact-form-card textarea, .contact-form-card select{
  width:100%; padding:.8rem 1rem; border:1px solid var(--line); border-radius:12px;
  font:inherit; background:#fff; color:var(--ink); margin-top:.35rem; transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.contact-form-card input:focus, .contact-form-card textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-050); }
.contact-form-card input[type=submit]{
  margin-top:.6rem; background:var(--accent); color:#fff; border:0; border-radius:999px;
  padding:.85rem 1.6rem; font-weight:600; cursor:pointer; min-height:48px; transition:background .2s var(--ease), transform .2s var(--ease);
}
.contact-form-card input[type=submit]:hover{ background:var(--accent-600); transform:translateY(-2px); }
.map-embed{ border-radius:var(--card-radius); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); }
.map-embed iframe{ width:100%; height:100%; min-height:280px; border:0; display:block; }

/* ---------- Footer ---------- */
.site-footer{ background:#12201f; color:#cdd8d6; padding-block:clamp(48px,7vw,80px) 2rem; margin-top:clamp(40px,6vw,80px); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:clamp(24px,4vw,48px); }
.site-footer h4{ font-family:"Public Sans",sans-serif; font-size:.85rem; letter-spacing:.12em; text-transform:uppercase; color:#8ba7a4; margin:0 0 1rem; }
.site-footer a{ color:#cdd8d6; }
.site-footer a:hover{ color:#fff; }
.footer-menu{ list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
.footer-brand .brand{ color:#fff; }
.footer-brand .brand small{ color:#8ba7a4; }
.footer-brand p{ color:#9fb2b0; max-width:34ch; margin-top:1rem; }
.footer-contact .contact-line{ color:#cdd8d6; }
.footer-contact .contact-line .icon{ color:#5fb3ad; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:2.6rem; padding-top:1.4rem; display:flex; flex-wrap:wrap; gap:.8rem 1.4rem; justify-content:space-between; font-size:.9rem; color:#8ba7a4; }
.footer-bottom a{ color:#8ba7a4; }

/* ---------- Generischer Seiteninhalt (Gutenberg) ---------- */
.page-hero{ padding-block:clamp(48px,7vw,86px) clamp(28px,4vw,44px); }
.page-hero .container{ max-width:820px; }
.entry{ background:#fff; border:1px solid var(--line); border-radius:var(--card-radius); box-shadow:var(--shadow); padding:clamp(26px,5vw,60px); }
.entry> *{ max-width:760px; margin-inline:auto; }
.entry h2{ margin-top:1.8rem; }
.entry h3{ margin-top:1.4rem; }
.entry ul,.entry ol{ padding-left:1.3rem; }
.entry li{ margin:.4rem 0; }
.entry img{ border-radius:var(--radius-sm); }
.entry .wp-block-columns{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,36px); max-width:760px; margin-inline:auto; }
.entry .wp-block-column{ min-width:0; }
.entry .wp-block-group.has-background{ border-radius:var(--card-radius); padding:clamp(20px,3vw,32px); }
.entry .wp-block-separator{ border:0; border-top:1px solid var(--line); max-width:760px; margin:2.2rem auto; }

/* ---------- Utility ---------- */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; }
.skip-link{ position:absolute; left:-9999px; top:0; background:#fff; padding:.6rem 1rem; border-radius:8px; z-index:200; }
.skip-link:focus{ left:12px; top:12px; }
:focus-visible{ outline:3px solid var(--accent); outline-offset:2px; border-radius:6px; }

/* Reveal-Animation */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }

/* =========================================================================
   Responsive – Mobile First mitgedacht
   ========================================================================= */
@media (max-width:1024px){
  .col-3{ grid-column:span 6; }
  .col-4{ grid-column:span 6; }
  .col-5{ grid-column:span 6; }
  .col-7{ grid-column:span 12; }
  .col-8{ grid-column:span 12; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:900px){
  .nav__menu{
    position:fixed; inset:0 0 0 auto; width:min(84vw,340px);
    flex-direction:column; align-items:stretch; gap:.3rem;
    background:#fff; box-shadow:var(--shadow-lg); padding:88px 20px 28px;
    transform:translateX(100%); transition:transform .32s var(--ease); z-index:120;
  }
  .nav__menu.is-open{ transform:none; }
  .nav__menu a{ padding:.85rem 1rem; font-size:1.05rem; }
  .nav__toggle{ display:inline-flex; }
  .nav-backdrop{ position:fixed; inset:0; background:rgba(15,25,24,.4); opacity:0; visibility:hidden; transition:opacity .3s var(--ease); z-index:110; }
  .nav-backdrop.is-open{ opacity:1; visibility:visible; }
  .hero__grid{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .hero__media{ min-height:280px; order:-1; }
}
@media (max-width:600px){
  body{ font-size:16px; }
  :root{ --grid-gap:14px; --card-radius:20px; }
  .col-3,.col-4,.col-5,.col-6,.col-7,.col-8{ grid-column:span 12; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; }
  .hero__meta{ gap:.8rem 1.2rem; }
  .btn{ width:100%; justify-content:center; }
  .hero__cta .btn{ width:100%; }
  .entry .wp-block-columns{ grid-template-columns:1fr; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
