/* =========================================================
   CRI-Hausmeisterservice – Kunden-Ebene über base.css
   Lädt NACH base.css. Enthält: heller Header, neue Bausteine
   (Hero, Leistungs-Grid, Termin, FAQ) + Recolor der Dunkel-
   Sektionen auf die CRI-CI (Beige/Bordeaux/Anthrazit).
   ========================================================= */

/* ---------- Header: Beige-Bar passend zum Logo ---------- */
body{background:var(--bg);color:var(--text)}
.hd{background:var(--bar);border-bottom:1px solid var(--bar-line)}
.nav a{color:var(--ink)}
.nav a::after{background:var(--accent)}
.nav__home svg{fill:var(--ink)}
.hd .logo img{height:62px}
.hd.is-scrolled .logo img{height:46px}
.hd .burger span,.hd .burger span::before,.hd .burger span::after{background:var(--ink)}
.hd__cta{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;padding:11px 20px;border-radius:999px;background:var(--accent);color:#fff;border:1px solid var(--accent);
  white-space:nowrap;transition:.2s var(--ease)}
.hd__cta:hover{background:var(--accent-d);border-color:var(--accent-d)}
.hd__cta svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.9}
@media(max-width:1080px){
  .nav{background:var(--bar);border-bottom:1px solid var(--bar-line)}
  .nav a{border-bottom:1px solid var(--bar-line)}
  .hd__cta{display:none}
}

/* ---------- HERO (neuer Baustein) ---------- */
.hero{position:relative;background:linear-gradient(180deg,var(--beige),var(--tint));overflow:hidden}
.hero__wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,5vw,64px);align-items:center;
  padding-block:clamp(54px,8vh,104px)}
.hero__eyebrow{color:var(--accent)}
.hero h1{font-size:clamp(2.1rem,5vw,3.5rem);font-weight:300;color:var(--ink);line-height:1.08;letter-spacing:-.02em;margin:6px 0 0}
.hero h1 b{font-weight:700;color:var(--accent)}
.hero__lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--text);max-width:46ch;margin:20px 0 28px;line-height:1.6}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:30px;font-size:13.5px;color:var(--muted)}
.hero__trust span{display:inline-flex;align-items:center;gap:8px}
.hero__trust svg{width:16px;height:16px;fill:none;stroke:var(--accent);stroke-width:2}
.hero__media{position:relative;border-radius:18px;overflow:hidden;background:var(--beige);border:1px solid var(--line);
  box-shadow:0 30px 60px -34px rgba(26,26,24,.45);aspect-ratio:4/3;display:grid;place-items:center}
.hero__media img{width:86%;height:auto}
.hero__ph{position:absolute;bottom:0;left:0;right:0;background:rgba(26,26,24,.72);color:#fff;font-size:12px;
  letter-spacing:.06em;text-transform:uppercase;text-align:center;padding:8px}
@media(max-width:860px){.hero__wrap{grid-template-columns:1fr;gap:30px}.hero__media{order:-1;max-width:460px}}

/* ---------- LEISTUNGS-GRID (neuer Baustein) ---------- */
.leistungen{background:var(--bg)}
.leistungen__head{max-width:680px;margin:0 0 40px}
.leistungen__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.leistung-card{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:28px 26px;
  display:flex;flex-direction:column;gap:12px;transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.leistung-card:hover{transform:translateY(-4px);box-shadow:0 26px 50px -30px rgba(26,26,24,.4);border-color:var(--beige)}
.leistung-card__ic{width:52px;height:52px;border-radius:12px;background:var(--tint);display:grid;place-items:center;color:var(--accent)}
.leistung-card__ic svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.7}
.leistung-card h3{font-size:1.22rem;font-weight:500;color:var(--ink)}
.leistung-card p{font-size:15px;line-height:1.6;color:var(--text)}
.leistung-card--more{background:var(--accent);border-color:var(--accent)}
.leistung-card--more .leistung-card__ic{background:rgba(255,255,255,.16);color:#fff}
.leistung-card--more h3,.leistung-card--more p{color:#fff}
.leistung-card--more p{color:rgba(255,255,255,.86)}

/* ---------- TERMIN (Platzhalter-Baustein) ---------- */
.termin{background:var(--tint);border-block:1px solid var(--line)}
.termin__inner{display:grid;grid-template-columns:1fr .9fr;gap:clamp(28px,5vw,60px);align-items:center}
.termin__box{background:var(--white);border:1px dashed var(--accent);border-radius:16px;padding:34px 30px;text-align:center}
.termin__box .ic{width:60px;height:60px;border-radius:50%;background:var(--tint);display:grid;place-items:center;margin:0 auto 16px;color:var(--accent)}
.termin__box .ic svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:1.7}
.termin__box h3{font-size:1.3rem;font-weight:500;color:var(--ink);margin-bottom:6px}
.termin__box p{color:var(--text);font-size:15px;margin-bottom:18px}
.termin__hours{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:var(--accent);font-size:15px;
  background:var(--tint);border-radius:999px;padding:9px 18px}
.termin__soon{margin-top:16px;font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
@media(max-width:780px){.termin__inner{grid-template-columns:1fr;gap:28px}}

/* ---------- FAQ (neuer Baustein, ohne JS) ---------- */
.faq{background:var(--bg)}
.faq__head{max-width:640px;margin:0 0 36px}
.faq__list{max-width:820px}
.faq__item{border-top:1px solid var(--line)}
.faq__item:last-child{border-bottom:1px solid var(--line)}
.faq__item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:22px 4px;font-size:1.08rem;font-weight:500;color:var(--ink)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary .pl{position:relative;width:20px;height:20px;flex:0 0 20px}
.faq__item summary .pl::before,.faq__item summary .pl::after{content:"";position:absolute;background:var(--accent);transition:.22s var(--ease)}
.faq__item summary .pl::before{top:9px;left:0;width:20px;height:2px}
.faq__item summary .pl::after{left:9px;top:0;width:2px;height:20px}
.faq__item[open] summary .pl::after{transform:rotate(90deg);opacity:0}
.faq__item p{padding:0 4px 24px;color:var(--text);font-size:15.5px;line-height:1.7;max-width:70ch}

/* ---------- Recolor der Dunkel-Sektionen auf CRI ---------- */
/* Snapshot „Über uns": kein Foto, warmes Anthrazit + Beige-Akzente */
.snap-photo::before{background:var(--ink)!important;background-image:none!important}
.snap-photo .eyebrow{color:var(--beige)}.snap-photo .eyebrow::before{background:var(--beige)}
.snap-photo .point__no{color:var(--beige)}
.snap-photo .point{border-top-color:rgba(255,255,255,.12)}
.snap-photo .point:last-child{border-bottom-color:rgba(255,255,255,.12)}
.anfrage-card{background:#000}
.anfrage-card .btn{background:var(--accent);border-color:var(--accent)}
.anfrage-card .btn:hover{background:#fff;color:var(--accent);border-color:#fff}

/* Keyfacts: warmes Anthrazit, Beige-Zahlen */
.facts{background:var(--ink)}
.facts__num{color:var(--beige)}
.facts__label{color:rgba(255,255,255,.62)}

/* Kontakt: warmes Anthrazit statt Foto, Beige-Eyebrow */
.kontakt-sec{background:var(--ink)}
.kontakt-sec::before{background:var(--ink)!important;background-image:none!important}
.kontakt-sec .eyebrow{color:var(--beige)}.kontakt-sec .eyebrow::before{background:var(--beige)}
.kontakt-sec .card{background:#221f1c;border-color:rgba(255,255,255,.10)}
.kontakt-sec .seg button.is-active{color:var(--accent)}
.kontakt-sec .btn--accent{background:var(--accent);border-color:var(--accent);color:#fff}
.kontakt-sec .btn--accent:hover{background:#fff;color:var(--accent);border-color:#fff}

/* FAB: Bordeaux */
.fab-call{background:var(--accent);border-color:var(--accent)}
.fab-call:hover{background:var(--accent-d);border-color:var(--accent-d)}

/* Footer-Logo auf dunklem Grund lesbar: Beige-Chip (Logo-Hintergrund = Beige) */
.ft .logo{background:var(--beige);padding:10px 16px;border-radius:12px}
.ft .logo img{height:54px}

/* =========================================================
   CRI – Erweiterung v0.2 (Bild-Hintergründe, Inhaber,
   Cookie-Banner, Rechtsseiten)
   ========================================================= */

/* ---------- Hintergrund-Bild-Mechanik (statt Farbe) ----------
   Beliebige Dunkel-Sektion bekommt ein Foto per Inline-Variable:
   <section class="snap-photo" style="--shot:url('.../foto.jpg')"> … */
.snap-photo::before{background:var(--ink)!important;
  background-image:linear-gradient(180deg,rgba(20,18,16,.72),rgba(20,18,16,.86)),var(--shot,none)!important;
  background-size:cover!important;background-position:center!important}
.kontakt-sec::before{background:var(--ink)!important;
  background-image:linear-gradient(180deg,rgba(20,18,16,.78),rgba(20,18,16,.9)),var(--shot,none)!important;
  background-size:cover!important;background-position:center!important}
/* Hero kann ebenfalls ein Foto bekommen (heller Beige-Schleier über dem Bild) */
.hero.has-photo{background:var(--beige)}
.hero.has-photo::before{content:"";position:absolute;inset:0;z-index:0;
  background-image:linear-gradient(180deg,rgba(223,203,176,.86),rgba(241,231,214,.92)),var(--shot,none);
  background-size:cover;background-position:center}
.hero.has-photo .hero__wrap{position:relative;z-index:1}

/* ---------- Inhaber-Vorstellung (neuer Baustein) ---------- */
.inhaber{background:var(--tint)}
.inhaber__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,64px);align-items:center}
.inhaber__photo{position:relative;aspect-ratio:4/5;border-radius:18px;overflow:hidden;background:var(--beige);
  border:1px solid var(--line);box-shadow:0 30px 60px -34px rgba(26,26,24,.45);display:grid;place-items:center}
.inhaber__photo img{width:100%;height:100%;object-fit:cover}
.inhaber__ph{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--accent)}
.inhaber__ph svg{width:54px;height:54px;fill:none;stroke:currentColor;stroke-width:1.4}
.inhaber__ph span{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.inhaber__role{color:var(--accent);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.inhaber__name{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:300;color:var(--ink);line-height:1.15;margin-bottom:18px}
.inhaber p{font-size:16px;line-height:1.75;color:var(--text);max-width:56ch;margin-bottom:14px}
.inhaber__sign{margin-top:8px;font-weight:700;color:var(--ink)}
.inhaber__sign small{display:block;font-weight:400;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:12px;margin-top:2px}
@media(max-width:820px){.inhaber__grid{grid-template-columns:1fr;gap:30px}.inhaber__photo{max-width:360px}}

/* ---------- Cookie-Banner ---------- */
.cookie{position:fixed!important;left:50%!important;right:auto!important;top:auto!important;bottom:24px!important;
  transform:translateX(-50%);margin:0!important;
  width:min(960px,calc(100% - 32px));z-index:2147483000;background:var(--ink);color:#fff;
  border-radius:14px;box-shadow:0 24px 60px -22px rgba(0,0,0,.6);padding:18px 22px;
  display:flex;flex-wrap:wrap;align-items:center;gap:14px 22px}
.cookie.is-hidden{display:none}
.cookie__txt{flex:1 1 300px;font-size:14px;line-height:1.6;color:rgba(255,255,255,.85)}
.cookie__txt a{color:var(--accent-foot);text-decoration:underline}
.cookie__btns{display:flex;gap:10px;flex:0 0 auto;margin-left:auto}
.cookie__btn{font-family:var(--font);font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  padding:11px 18px;border-radius:8px;cursor:pointer;border:1px solid transparent;white-space:nowrap;transition:.18s var(--ease)}
.cookie__btn--ok{background:var(--accent);color:#fff;border-color:var(--accent)}
.cookie__btn--ok:hover{background:var(--accent-d);border-color:var(--accent-d)}
.cookie__btn--min{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.cookie__btn--min:hover{border-color:#fff}
.cookie-open .fab-group{display:none}   /* schwebende Buttons aus, solange Banner offen */
@media(max-width:560px){.cookie{bottom:12px}.cookie__btns{width:100%;margin-left:0}.cookie__btn{flex:1}}

/* ---------- Rechtsseiten (Impressum / Datenschutz via page.php) ---------- */
.legal{padding-block:var(--sec)}
.legal__wrap{max-width:860px}
.legal h1{font-size:clamp(2rem,4vw,2.8rem);font-weight:300;color:var(--ink);margin-bottom:10px}
.legal__intro{color:var(--muted);margin-bottom:36px}
.legal h2{font-size:1.4rem;font-weight:500;color:var(--ink);margin:34px 0 12px}
.legal h3{font-size:1.1rem;font-weight:600;color:var(--ink);margin:22px 0 8px}
.legal p,.legal li{font-size:16px;line-height:1.75;color:var(--text)}
.legal p{margin-bottom:14px}
.legal ul{margin:0 0 16px 20px}
.legal li{margin-bottom:6px}
.legal a{color:var(--accent);text-decoration:underline}
.legal .ph{background:var(--tint);border:1px dashed var(--accent);border-radius:6px;padding:1px 8px;color:var(--accent-d);font-weight:600}

/* =========================================================
   CRI – Erweiterung v0.3 (Bildergalerie / Karussell + Stock)
   ========================================================= */
/* Hero-Bildfläche zeigt jetzt ein (Stock-)Foto vollflächig */
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media{aspect-ratio:4/3}

/* ---------- Karussell-Galerie (neuer Baustein) ---------- */
.galerie{margin-top:52px}
.galerie__viewport{position:relative;overflow:hidden;border-radius:16px;border:1px solid var(--line);background:var(--tint)}
.galerie__track{display:flex;transition:transform .5s var(--ease)}
.galerie__slide{flex:0 0 100%;position:relative}
.galerie__slide img{display:block;width:100%;height:clamp(300px,42vw,520px);object-fit:cover}
.galerie__cap{position:absolute;left:0;right:0;bottom:0;padding:22px 26px;color:#fff;font-weight:700;font-size:1.15rem;letter-spacing:.01em;
  background:linear-gradient(0deg,rgba(20,18,16,.78),rgba(20,18,16,0))}
.galerie__nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;
  background:rgba(20,18,16,.55);color:#fff;border:0;display:grid;place-items:center;cursor:pointer;transition:.2s var(--ease)}
.galerie__nav:hover{background:var(--accent)}
.galerie__nav svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2}
.galerie__nav--prev{left:14px}.galerie__nav--next{right:14px}
.galerie__dots{display:flex;gap:8px;justify-content:center;margin-top:18px}
.galerie__dot{width:9px;height:9px;border-radius:50%;background:var(--line);border:0;cursor:pointer;padding:0;transition:.2s var(--ease)}
.galerie__dot.is-active{background:var(--accent);width:26px;border-radius:6px}
@media(max-width:560px){.galerie__nav{width:40px;height:40px}.galerie__cap{font-size:1rem;padding:16px 18px}}

/* =========================================================
   CRI – Erweiterung v0.4 (Termin-Auswahl: Wochentag + Uhrzeit)
   ========================================================= */
.termin__head{max-width:660px;margin:0 0 34px}
.booking{padding:clamp(22px,3.2vw,38px)}
.booking__step{margin-bottom:24px}
.booking__lbl{display:block;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.booking__opts{display:flex;flex-wrap:wrap;gap:10px}
.bk-chip{font-family:var(--font);font-size:14px;font-weight:600;color:var(--ink);background:var(--tint);
  border:1px solid var(--line);border-radius:10px;padding:11px 18px;cursor:pointer;transition:.15s var(--ease);line-height:1}
.bk-chip:hover{border-color:var(--accent);color:var(--accent)}
.bk-chip.is-sel{background:var(--accent);border-color:var(--accent);color:#fff}
.booking__opts--times .bk-chip{min-width:78px;text-align:center;font-weight:500}
.booking__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.booking .field label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}
.booking .field input{width:100%;font-family:var(--font);font-size:15px;color:var(--ink);background:#fff;
  border:1px solid var(--line);border-radius:10px;padding:12px 14px;transition:.15s var(--ease)}
.booking .field input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(134,29,50,.12)}
.booking__summary{margin:6px 0 14px;padding:14px 16px;border-radius:10px;background:var(--tint);
  border-left:3px solid var(--accent);font-size:15px;color:var(--text)}
.booking__summary b{color:var(--ink)}
.booking__err{margin:0 0 12px;color:var(--accent-d);font-size:14px;font-weight:600}
.booking__send{margin-top:4px}
.booking__note{margin-top:14px;font-size:13px;color:var(--muted)}
.booking__done{display:flex;align-items:center;gap:16px;padding:6px 4px}
.booking__done svg{flex:none;width:40px;height:40px;padding:8px;border-radius:50%;background:var(--accent);
  fill:none;stroke:#fff;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.booking__done strong{color:var(--ink)}
@media(max-width:560px){.booking__row{grid-template-columns:1fr}.booking__opts--times .bk-chip{min-width:70px;padding:10px 12px}}
