/* =====================================================================
   Café Rosa — gemeinsames Stylesheet
   Struktur: Tokens · Schriften · Basis · Header · Mobilmenü · Buttons ·
             Hero · Sektionen (Detail, Trust, Über uns, Galerie, Teaser,
             Ambiente, Anlässe, CTA) · Speisekarte · Feiern · Formular ·
             Kontakt · Gutscheine · Footer
   ===================================================================== */

/* ============ TOKENS ============ */
/* BRANDING: Die folgenden Farben/Schriften sind Platzhalter.
   - Farben als HEX einsetzen (z.B. #948474).
   - Abgeleitete Töne (--gruen-dark, --gold-hell) ggf. manuell nachziehen,
     wenn die Primär-/Akzentfarbe stark abweicht.
   - Schriften: Platzhalter MIT Default. Wenn die Schrift gleich bleiben soll,
     den Default einfach eingesetzt lassen (FONT_HEADING=Cinzel,
     FONT_BODY=Hanken Grotesk, FONT_ACCENT=Cormorant Garamond).
     Achtung: Wird der Schriftname geändert, müssen auch die @font-face-Regeln
     unten und die woff2-Dateien in assets/fonts entsprechend angepasst werden. */
:root{
  --gruen:#948474;        /* Default: #948474 (Salbeigrün) */
  --gruen-dark:#796c5f;
  --gold:#C4907A;          /* Default: #C4907A (Gold) */
  --gold-hell:#cfa492;
  --creme:#FAF7F4;             /* Default: #F4EDE0 (Creme-Hintergrund) */
  --creme-card:#faf7f4;
  --weiss:#FFFFFF;
  --text:#3A3530;            /* Default: #2B2030 (Haupttext) */
  --text2:#6B5F57;          /* Default: #5f574b (Sekundärtext) */
  --text3:#6B5F57;
  --nav-dark:#2A221E;
  --fast-schwarz:#2A221E;  /* Default: #0E0E0E (Fast-Schwarz) */
  --hell:#FAF7F4;
  --linie:rgba(148, 132, 116,.16);

  --serif-display:'Cuprum',serif;    /* Default: Cinzel */
  --serif:'Cormorant Garamond',serif;             /* Default: Cormorant Garamond */
  --sans:'Hanken Grotesk',sans-serif;           /* Default: Hanken Grotesk */
}

/* ============ LOKALE SCHRIFTEN ============ */
@font-face{font-family:'Cinzel';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/cinzel-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Cinzel';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/cinzel-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/cormorant-garamond-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:400;font-display:swap;src:url('../fonts/cormorant-garamond-latin-400-italic.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('../fonts/cormorant-garamond-latin-500-italic.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/hanken-grotesk-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/hanken-grotesk-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/hanken-grotesk-latin-700-normal.woff2') format('woff2')}

/* ============ BASIS ============ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{position:relative;width:100%;background:var(--creme);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;overflow-x:clip}
::selection{background:var(--gruen);color:var(--creme)}
@keyframes scrollcue{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(9px);opacity:1}}

.watermark{position:fixed;inset:0;background-image:url('');background-size:760px;background-position:center;opacity:.05;pointer-events:none;z-index:0;mix-blend-mode:multiply}

/* ============ HEADER ============ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:22px clamp(20px,4vw,44px);background:transparent;border-bottom:1px solid transparent;transition:padding .3s ease,background .3s ease,border-color .3s ease,backdrop-filter .3s ease}
.site-header.scrolled{padding:9px clamp(20px,4vw,44px);background:rgba(244,237,224,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(148, 132, 116,.22)}
.site-header::before{content:"";position:absolute;left:0;right:0;top:0;height:150px;z-index:-1;pointer-events:none;background:linear-gradient(180deg,rgba(16,14,9,.55),rgba(16,14,9,0));opacity:1;transition:opacity .3s ease}
.site-header.scrolled::before{opacity:0}
.site-header__left{justify-self:start;display:flex;align-items:center}
.site-nav{display:flex;align-items:center;gap:28px}
.site-nav__link{font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;text-decoration:none;color:var(--hell);transition:color .3s ease}
.site-header.scrolled .site-nav__link{color:var(--nav-dark)}
.site-nav__link:hover{color:var(--gruen)}
/* aktiver Menüpunkt: oben (transparent, dunkler Hero) gold + Unterstrich,
   gescrollt (creme) salbeigrün — currentColor hält den Unterstrich farbgleich */
.site-nav__link.is-active{position:relative;color:var(--gold-hell)}
.site-header.scrolled .site-nav__link.is-active{color:var(--gruen)}
.site-nav__link.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:currentColor}
.site-header__brand{justify-self:center;display:flex;align-items:center;text-decoration:none}
.site-header__logo{height:80px;width:auto;display:block;transition:height .3s ease,filter .3s ease}
.site-header.scrolled .site-header__logo{height:66px;filter:none}
/* Wortmarke statt Logo, wenn kein echtes Logo vorhanden (Build-Fallback) */
.site-header__wordmark{font-family:var(--serif-display);font-weight:600;font-size:clamp(19px,2.3vw,28px);letter-spacing:.04em;line-height:1;color:var(--hell);white-space:nowrap;transition:color .3s ease}
.site-header.scrolled .site-header__wordmark{color:var(--nav-dark)}
.site-footer__wordmark{font-family:var(--serif-display);font-weight:600;font-size:26px;letter-spacing:.03em;line-height:1.1;color:var(--hell);display:inline-block}
/* Instagram-Button (Header-Icon + Footer-Link), nur wenn https://www.instagram.com/caferosaaschau/ gesetzt */
.site-nav__insta{display:inline-flex;align-items:center;color:var(--hell);transition:color .3s ease}
.site-header.scrolled .site-nav__insta{color:var(--nav-dark)}
.site-nav__insta:hover{color:var(--gruen)}
.site-footer__instagram{display:inline-flex;align-items:center;gap:9px;margin-top:14px;font-size:14px;letter-spacing:.02em;color:var(--hell);text-decoration:none;opacity:.9;transition:opacity .2s ease}
.site-footer__instagram:hover{opacity:1;color:var(--gold-hell)}
.site-header__reserve{justify-self:end;font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--hell);text-decoration:none;background:var(--gruen);padding:11px 22px;border-radius:2px;transition:background .3s ease}
.site-header__reserve:hover{background:var(--gruen-dark)}
.site-header__actions{justify-self:end;display:flex;align-items:center;gap:12px}
.site-header__order{font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:#fff;text-decoration:none;background:#d6342c;padding:11px 22px;border-radius:2px;transition:background .3s ease}
.site-header__order:hover{background:#b82a23}
.site-header__burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:6px;padding:6px}
.site-header__burger-line{display:block;width:26px;height:2px;background:var(--hell);transition:background .3s ease}
.site-header.scrolled .site-header__burger-line{background:var(--nav-dark)}
@media(max-width:920px){
  .site-header{display:flex;justify-content:space-between;align-items:center}
  .site-header__brand{order:0}
  .site-header__left{order:1}
}

/* ============ MOBILMENÜ ============ */
.mobile-menu{display:none;position:fixed;inset:0;z-index:60;background:var(--fast-schwarz);flex-direction:column;align-items:center;justify-content:center;gap:26px}
.mobile-menu__close{position:absolute;top:24px;right:30px;background:none;border:none;color:var(--creme);font-size:34px;cursor:pointer;font-family:var(--serif)}
.mobile-menu__link{font-family:var(--serif-display);font-size:26px;color:var(--creme);text-decoration:none}
.mobile-menu__reserve{margin-top:10px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--hell);text-decoration:none;background:var(--gruen);padding:13px 28px;border-radius:2px}
.mobile-menu__order{margin-top:6px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:#fff;text-decoration:none;background:#d6342c;padding:13px 28px;border-radius:2px}

/* ============ BUTTONS ============ */
.btn{display:inline-block;font-family:inherit;font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;text-decoration:none;border:none;border-radius:2px;cursor:pointer;transition:background .2s ease}
.btn--green{background:var(--gruen);color:var(--hell)}
.btn--green:hover{background:var(--gruen-dark)}
.btn--order{background:#d6342c;color:#fff}
.btn--order:hover{background:#b82a23}
.btn--ghost{color:var(--hell);border:1px solid rgba(251,246,236,.55)}
.btn--ghost:hover{background:rgba(251,246,236,.12)}
.btn--ghost-cta{color:var(--hell);border:1px solid rgba(251,246,236,.5)}
.btn--ghost-cta:hover{background:rgba(251,246,236,.1)}
.btn--md{padding:16px 34px}
.btn--lg{padding:16px 38px}

/* ============ EYEBROWS / KLEINE LABELS ============ */
.eyebrow{font-size:13px;letter-spacing:.34em;text-transform:uppercase;color:var(--gruen);font-weight:600}
.eyebrow--gold{color:var(--gold-hell)}
.eyebrow--28{letter-spacing:.28em}

/* ============ HERO (Startseite, 100vh) ============ */
.hero-home{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:140px 24px 90px;background-size:cover;background-position:center;background-image:linear-gradient(180deg,rgba(18,16,10,.87) 0%,rgba(18,16,10,.48) 38%,rgba(20,18,12,1) 100%),url('../img/img-25.webp')}
/* Desktop: Overlay wieder ~40% heller (Mobil bleibt dunkler) */
@media(min-width:921px){.hero-home{background-image:linear-gradient(180deg,rgba(18,16,10,.62) 0%,rgba(18,16,10,.34) 38%,rgba(20,18,12,.80) 100%),url('../img/img-25.webp')}}
.hero-home__inner{max-width:1020px}
.hero-home__eyebrow{font-size:13px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold-hell);font-weight:600;margin-bottom:26px}
/* H1 = max. 2 Zeilen: Name (1 Zeile) + kursive Unterzeile (1 Zeile). Beide nicht umbrechen
   (white-space:nowrap). clamp() = groß/kräftig per Default, viewport-responsiv. Zusätzlich
   verkleinert site.js (fitHero) bei zu langen Namen/Unterzeilen die Schrift inline, bis sie
   wieder in EINE Zeile passt (statt umzubrechen) — maximal groß, so klein wie nötig. */
.hero-home__title{font-family:var(--serif-display);font-weight:600;color:var(--hell);font-size:clamp(28px,6vw,102px);line-height:1.1;letter-spacing:.01em;white-space:nowrap}
.hero-home__title em{white-space:nowrap;font-family:var(--serif);font-style:italic;font-weight:500;color:var(--gold-hell);text-transform:none;font-size:clamp(25px,4.2vw,76px);line-height:1.2}
/* Einleitung: großzügige Breite → höchstens ~3 Zeilen; text-wrap:pretty verhindert Schusterjungen/Witwen. */
.hero-home__lead{max-width:680px;margin:30px auto 0;color:rgba(251,246,236,.88);font-size:18px;line-height:1.7;text-wrap:pretty}
.hero-home__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:40px}
/* Hero-Reservierungs-Widget (Baustein) — kompakte, auf dem Hero-Bild lesbare Leiste */
.hero-resv{display:flex;flex-wrap:nowrap;align-items:flex-end;justify-content:center;gap:14px;max-width:820px;margin:40px auto 0;padding:18px 20px;background:rgba(20,20,20,.34);backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);border:1px solid rgba(251,246,236,.28);border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.28)}
.hero-resv__field{display:flex;flex-direction:column;gap:7px;text-align:left;flex:1 1 0;min-width:0}
.hero-resv__field label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--hell)}
.hero-resv__field select,.hero-resv__field input{font-family:var(--sans);font-size:15px;padding:12px 13px;border-radius:8px;border:1px solid rgba(251,246,236,.4);background:rgba(251,246,236,.95);color:var(--text);width:100%;box-sizing:border-box;height:46px;cursor:pointer;appearance:auto}
.hero-resv__field select:focus,.hero-resv__field input:focus{outline:none;border-color:var(--gruen);box-shadow:0 0 0 3px rgba(148, 132, 116,.35)}
/* Datumsfeld: GENAU so breit/hoch wie Name/Telefon/Uhrzeit. iOS/Safari rendert input[type=date]
   nativ und ignoriert die Breite (ragt aus der Box) → native Darstellung neutralisieren und ein
   eigenes Kalender-Icon rechts anzeigen (auch wenn noch kein Datum gewählt ist). */
.hero-resv__field input[type="date"]{-webkit-appearance:none;appearance:none;box-sizing:border-box;width:100%;min-width:0;padding:12px 40px 12px 13px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23555' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;background-size:18px 18px}
/* iOS: Datumswert links ausrichten, nicht schrumpfen/überlaufen */
.hero-resv__field input[type="date"]::-webkit-date-and-time-value{text-align:left;min-width:0;margin:0}
.hero-resv__field input[type="date"]::-webkit-datetime-edit{padding:0}
/* Nativen Kalender-Picker erhalten (klickbar) — aber unsichtbar, das eigene SVG oben ist das Icon */
.hero-resv__field input[type="date"]::-webkit-calendar-picker-indicator{opacity:0;cursor:pointer;width:34px;height:100%;margin:0;padding:0}
/* Button: letztes Element in derselben Reihe, rechtsbündig, feste Breite, bündig mit den Feld-Eingaben */
.hero-resv__btn{flex:0 0 auto;align-self:flex-end;justify-content:center;padding:14px 26px;font-size:13px;white-space:nowrap}
/* Honeypot (unsichtbar, nur für Bots), DSGVO-Hinweis unter dem Widget */
.hero-resv__hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.hero-resv__consent{max-width:760px;margin:14px auto 0;font-size:12px;line-height:1.5;color:rgba(251,246,236,.72);text-align:center}
.hero-resv__consent a{color:inherit;text-decoration:underline}
/* Handy: Felder + Button sauber untereinander */
@media(max-width:620px){.hero-resv{flex-direction:column;flex-wrap:wrap;align-items:stretch;gap:12px;padding:16px}.hero-resv__field{flex:1 1 auto;min-width:0}.hero-resv__btn{flex:1 1 auto;width:100%}}
/* Header-Telefon-Button: Icon + Nummer mittig ausrichten */
.site-header__reserve--tel{display:inline-flex;align-items:center}
.mobile-menu__reserve{display:inline-flex;align-items:center}
.scrollcue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px}
.scrollcue__label{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:rgba(251,246,236,.7)}
.scrollcue__line{display:block;width:1px;height:34px;background:rgba(251,246,236,.6);animation:scrollcue 1.8s ease-in-out infinite}

/* ============ HERO (Unterseiten, 70vh) ============ */
.hero{position:relative;z-index:1;min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:150px 24px 70px;background-size:cover;background-position:center}
.hero--speisekarte{background-image:linear-gradient(180deg,rgba(18,16,10,.62) 0%,rgba(18,16,10,.34) 38%,rgba(20,18,12,.80) 100%),url('../img/img-08.webp')}
.hero--feiern{background-image:linear-gradient(180deg,rgba(18,16,10,.62) 0%,rgba(18,16,10,.34) 38%,rgba(20,18,12,.80) 100%),url('')}
.hero--gutscheine{background-image:linear-gradient(180deg,rgba(18,16,10,.62) 0%,rgba(18,16,10,.34) 38%,rgba(20,18,12,.80) 100%),url('')}
.hero--kontakt{background-image:linear-gradient(180deg,rgba(18,16,10,.62) 0%,rgba(18,16,10,.34) 38%,rgba(20,18,12,.80) 100%),url('../img/img-15.webp')}
.hero--reservierung{background-image:linear-gradient(180deg,rgba(18,16,10,.62) 0%,rgba(18,16,10,.34) 38%,rgba(20,18,12,.80) 100%),url('')}
.hero__badge{display:inline-block;background:var(--gruen);color:var(--hell);font-size:13px;letter-spacing:.42em;text-transform:uppercase;font-weight:600;padding:4px 2px 4px 6px;border-radius:2px}
.hero__title{font-family:var(--serif-display);font-weight:500;color:var(--hell);margin-top:16px}
.hero__title--karte{font-size:clamp(38px,6vw,76px);line-height:1.05}
.hero__title--feiern{font-size:clamp(34px,5.4vw,68px);line-height:1.08;max-width:900px}
.hero__title--breit{font-size:clamp(36px,5.4vw,72px);line-height:1.06}

/* ============ DETAIL-LEISTE (drei Boxen) ============ */
.detailbar{position:relative;z-index:1;background:var(--creme);padding:clamp(64px,8vw,104px) clamp(24px,5vw,56px);border-bottom:1px solid var(--linie)}
.detailbar__grid{display:flex;flex-wrap:wrap;align-items:stretch;gap:22px;max-width:1240px;margin:0 auto}
.detailbar__card{flex:1 1 300px;background:var(--weiss);border:1px solid var(--linie);border-radius:2px;padding:clamp(30px,3vw,42px)}
.detailbar__card--contact{flex:1 1 260px}
.detailbar__label{font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--gruen);font-weight:600}
.detailbar__title{font-family:var(--serif-display);font-weight:500;font-size:26px;color:var(--text);margin-top:12px}
/* Öffnungszeiten-Component (.hours-table) — EINE Darstellung für Start, Kontakt UND Footer.
   Build/renderHoursRows() füllt die Zeilen; im Footer (dunkel) per Kontext umgefärbt. */
.hours-table{margin-top:22px;width:100%;border-collapse:collapse;font-size:16px;color:var(--text3)}
.hours-table td{padding:7px 0;vertical-align:baseline}
.hours-table td.day{color:var(--text2);white-space:nowrap;padding-right:14px}
.hours-table td.time{text-align:right;font-weight:600;color:var(--text)}
.hours-table td.time--rest{color:var(--gruen)}
.hours-table tr+tr{border-top:1px solid rgba(148, 132, 116,.14)}
.site-footer .hours-table{margin-top:14px;font-size:15px}
.site-footer .hours-table td.day{color:rgba(251,246,236,.66)}
.site-footer .hours-table td.time{color:rgba(251,246,236,.92)}
.site-footer .hours-table td.time--rest{color:var(--gold-hell)}
.site-footer .hours-table tr+tr{border-top-color:rgba(251,246,236,.14)}
.detailbar__hint{margin-top:18px;font-size:14px;line-height:1.65;color:var(--text2);font-style:italic}
.detailbar__addr{margin-top:22px;font-size:17px;line-height:1.85;color:var(--text3)}
.detailbar__sublabel{margin-top:20px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gruen)}
.detailbar__sublabel--mail{margin-top:16px}
.detailbar__value{margin-top:4px;font-size:17px;line-height:1.85}
.detailbar__value a{color:var(--text);text-decoration:none}
.detailbar__value a:hover{color:var(--gruen)}
.detailbar__map{flex:1 1 340px;background:var(--weiss);border:1px solid var(--linie);border-radius:2px;overflow:hidden;position:relative}
.detailbar__map iframe{position:absolute;inset:0;width:100%;height:100%;display:block;border:0;filter:saturate(.9)}
@media(max-width:944px){.detailbar__map{min-height:280px}}

/* ============ STICHPUNKTE / TRUST ============ */
.trust{position:relative;z-index:1;background:var(--weiss);padding:28px 24px;border-bottom:1px solid var(--linie)}
.trust__row{display:flex;flex-wrap:wrap;justify-content:center;gap:32px 28px;max-width:1180px;margin:0 auto}
.trust__item{flex:1 1 220px;display:flex;align-items:center;gap:16px;padding:16px 26px}
.trust__item:not(:first-child){border-left:1px solid rgba(148, 132, 116,.18)}
.trust__big{font-family:var(--serif-display);font-size:21px;color:var(--text);line-height:1}
.trust__small{font-size:13px;letter-spacing:.06em;color:var(--text2);margin-top:4px}

/* ============ ÜBER UNS (Titel über Galerie) ============ */
.intro{position:relative;z-index:1;background:var(--creme);padding:clamp(72px,9vw,110px) 24px clamp(48px,6vw,64px);text-align:center}
.intro__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(30px,4.2vw,50px);line-height:1.14;color:var(--text);margin-top:16px}

/* ============ GALERIE-MOSAIK ============ */
.mosaic{position:relative;z-index:1;background:var(--text)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
/* Render-Optimierung: Offscreen-Kacheln nicht rendern; eigenes Compositing-Layer
   fürs flüssige Scrollen (aspect-ratio hält die Höhe -> kein Layout-Sprung). */
.gallery .tile{position:relative;overflow:hidden;aspect-ratio:1/1;cursor:pointer;transform:translateZ(0);backface-visibility:hidden;content-visibility:auto;contain-intrinsic-size:320px 320px}
.gallery .tile img{width:100%;height:100%;object-fit:cover;display:block;backface-visibility:hidden;transition:transform .5s ease}
/* Overlay animiert nur opacity (GPU), nicht die Hintergrundfarbe */
.gallery .tile::after{content:"";position:absolute;inset:0;background:rgba(43,32,48,.35);opacity:0;transition:opacity .5s ease;pointer-events:none}
/* Hover-Zoom per transform (GPU); will-change nur während Hover, danach freigegeben */
.gallery .tile:hover img{transform:scale(1.06);will-change:transform}
.gallery .tile:hover::after{opacity:1}
@media(max-width:900px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* ============ SPEISEKARTE-TEASER ============ */
.teaser{position:relative;z-index:1;background:var(--creme);padding:118px 24px 70px;text-align:center}
.teaser__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(32px,4.6vw,56px);line-height:1.08;color:var(--text);margin-top:14px}
.teaser__lead{max-width:560px;margin:20px auto 0;font-size:17px;line-height:1.7;color:var(--text2)}
.teaser__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;max-width:1100px;margin:58px auto 0;text-align:left}
.passioni{background:var(--creme-card);border:1px solid var(--linie);padding:34px 30px;border-radius:3px;transition:border-color .2s ease}
.passioni:hover{border-color:rgba(148, 132, 116,.55)}
.passioni__num{font-family:var(--serif);font-size:34px;color:var(--gold);line-height:1}
.passioni__name{font-family:var(--serif-display);font-weight:500;font-size:23px;color:var(--text);margin-top:14px}
.passioni__desc{margin-top:10px;font-size:15px;line-height:1.7;color:var(--text2)}
.teaser__cta{margin-top:70px}
.dishrow{display:flex;flex-wrap:wrap;align-items:center;gap:0;max-width:1160px;margin:96px auto 0;text-align:left}
.dishrow--reverse{flex-wrap:wrap-reverse;margin:48px auto 0;padding-bottom:20px}
.dishrow__img{flex:1 1 420px;min-height:440px;background-size:cover;background-position:center;border-radius:3px}
.dishrow__img--steak{background-image:url('../img/img-27.webp')}
.dishrow__img--pasta{background-image:url('../img/img-39.webp')}
.dishrow__body{flex:1 1 380px;padding:clamp(24px,5vw,64px)}
.dishrow__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(27px,3.4vw,40px);line-height:1.14;color:var(--text);margin-top:16px}
.dishrow__desc{margin-top:20px;font-size:17px;line-height:1.8;color:var(--text2)}

/* ============ AMBIENTE ============ */
.ambiente{position:relative;z-index:1;min-height:84vh;display:flex;align-items:flex-end;padding:64px clamp(28px,6vw,80px);background-size:cover;background-position:center;background-image:linear-gradient(180deg,rgba(18,16,10,.35) 0%,rgba(18,16,10,.4) 40%,rgba(18,16,10,.95) 100%),url('../img/img-16.webp')}
.ambiente__inner{max-width:600px}
.ambiente__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(32px,4.8vw,58px);line-height:1.08;color:var(--hell);margin-top:16px}
.ambiente__text{margin-top:22px;font-size:18px;line-height:1.8;color:rgba(251,246,236,.88)}

/* ============ ANLÄSSE / OFFERS ============ */
.offers{position:relative;z-index:1;background:var(--creme);padding:118px 24px}
/* 360°-Rundgang-Abschnitt (nur wenn  gefüllt; Embed via consent.js) */
.rundgang{position:relative;z-index:1;background:var(--creme);padding:96px 24px;text-align:center}
.rundgang__head{max-width:680px;margin:0 auto 40px}
.rundgang__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(30px,4.4vw,52px);line-height:1.12;color:var(--text);margin-top:14px}
.rundgang__frame{position:relative;max-width:1000px;margin:0 auto;aspect-ratio:16/9;border-radius:2px;overflow:hidden;border:1px solid var(--linie);background:var(--creme-card)}
.rundgang__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.offers__head{text-align:center;max-width:680px;margin:0 auto}
.offers__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(32px,4.6vw,54px);line-height:1.08;color:var(--text);margin-top:14px}
.offers__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1100px;margin:56px auto 0}
.offer{padding:46px 40px;border-radius:3px;display:flex;flex-direction:column}
.offer--dark{background:var(--text);color:var(--hell)}
.offer--green{background:var(--gruen);color:var(--hell)}
.offer--light{background:var(--creme-card);border:1px solid rgba(148, 132, 116,.2);color:var(--text)}
.offer__title{font-family:var(--serif-display);font-weight:500;font-size:27px}
.offer__title--green{color:var(--gruen)}
.offer__text{margin-top:14px;font-size:16px;line-height:1.8;flex:1}
.offer__text--dark{color:rgba(251,246,236,.82)}
.offer__text--green{color:rgba(251,246,236,.92)}
.offer__text--light{color:var(--text2)}
.offer__link{margin-top:26px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;text-decoration:none}
.offer__link--gold{color:var(--gold-hell)}
.offer__link--gold:hover{color:#fff}
.offer__link--hell{color:var(--hell)}
.offer__link--hell:hover{color:#fff}
.offer__link--green{color:var(--gruen)}
.offer__link--green:hover{color:var(--text)}

/* ============ RESERVIERUNGS-CTA ============ */
.cta{position:relative;z-index:1;text-align:center;padding:108px 24px;background-size:cover;background-position:center;background-image:linear-gradient(180deg,rgba(20,18,12,.72),rgba(20,18,12,.78)),url('../img/img-18.webp')}
.cta__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(32px,4.6vw,54px);line-height:1.1;color:var(--hell);margin-top:14px;max-width:640px;margin-left:auto;margin-right:auto}
.cta__text{max-width:540px;margin:20px auto 0;font-size:18px;line-height:1.75;color:rgba(251,246,236,.86)}
.cta__actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:38px}
/* Weiße Bestell-/CTA-Section (ruhige Unterbrechung zwischen Bild-Sections) */
.order-cta{position:relative;z-index:1;text-align:center;padding:96px 24px;background:var(--weiss)}
.order-cta__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(30px,4.2vw,48px);line-height:1.12;color:var(--text);margin-top:12px;max-width:640px;margin-left:auto;margin-right:auto}
.order-cta__text{max-width:520px;margin:18px auto 0;font-size:18px;line-height:1.7;color:var(--text2)}
.order-cta__actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:34px}

/* ============ SPEISEKARTE (Kategorien) ============ */
.menu{position:relative;z-index:1;background:var(--creme);padding-bottom:clamp(72px,9vw,112px)}
.cat{max-width:900px;margin:clamp(48px,6vw,82px) auto 0;padding:0 24px}
/* scroll-margin-top dynamisch: site.js setzt --cat-scroll-margin = echte Sticky-Bar-Höhe + Abstand
   (Fallback 170px, falls JS aus). So landet die Überschrift immer sauber unter der Kategorieleiste. */
.cat-bereich{font-family:var(--serif-display);font-weight:500;font-size:clamp(26px,3.4vw,38px);color:var(--text);text-align:center;text-decoration:none;max-width:900px;margin:clamp(56px,7vw,90px) auto 0;padding:0 24px;scroll-margin-top:var(--cat-scroll-margin,170px)}
.cat h2{font-family:var(--serif-display);font-weight:500;font-size:clamp(24px,3.2vw,36px);color:var(--text);scroll-margin-top:var(--cat-scroll-margin,170px)}
.cat .hair{display:block;width:52px;height:1px;background:var(--gold);margin:16px 0 6px}
.dish{display:flex;justify-content:space-between;align-items:baseline;gap:22px;padding:14px 0;border-bottom:1px solid var(--linie)}
.dish .name{font-size:17px;color:var(--text);font-weight:600;line-height:1.35}
.dish .name .no{color:var(--gruen);margin-right:11px;font-variant-numeric:tabular-nums}
.dish .desc{margin-top:5px;font-size:14.5px;line-height:1.55;color:var(--text2);max-width:600px}
.dish .price{font-size:17px;color:var(--text);font-weight:600;white-space:nowrap}
.cat .note{margin-top:16px;font-size:14.5px;line-height:1.6;color:var(--text2);font-style:italic}

.catbar{position:sticky;top:84px;z-index:40;background:var(--creme);border-bottom:1px solid var(--linie);padding:12px 24px;text-align:center}
.catbar .inner{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;max-width:1100px;margin:0 auto}
/* Ein-/Ausklapp-Steuerung (Kategorien-Toggle). Ohne JS bleibt die Pillen-Liste sichtbar (Fallback).
   Mit JS: Toggle sichtbar, Liste nur bei .is-open. Startzustand: Desktop offen, Handy zu (site.js). */
.catbar__toggle{display:none;align-items:center;gap:8px;margin:0 auto;background:var(--creme-card);border:1px solid rgba(148, 132, 116,.3);border-radius:999px;padding:8px 18px;font-family:inherit;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--text);cursor:pointer;transition:color .2s ease,border-color .2s ease,background .2s ease}
.catbar__toggle:hover{color:var(--gruen);border-color:var(--gruen);background:rgba(148, 132, 116,.08)}
.catbar__chevron{transition:transform .25s ease}
.catbar.is-open .catbar__chevron{transform:rotate(180deg)}
.catbar.js .catbar__toggle{display:inline-flex}
.catbar.js .inner{display:none}
.catbar.js.is-open .inner{display:flex;margin-top:12px}
.catbar .inner::-webkit-scrollbar{height:5px}
.catbar .inner::-webkit-scrollbar-thumb{background:rgba(148, 132, 116,.4);border-radius:999px}
.catbar a{flex:0 0 auto;white-space:nowrap;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--text);text-decoration:none;background:var(--creme-card);border:1px solid rgba(148, 132, 116,.3);border-radius:999px;padding:7px 14px;transition:color .2s ease,border-color .2s ease,background .2s ease}
.catbar a:hover{color:var(--gruen);border-color:var(--gruen);background:rgba(148, 132, 116,.08)}

/* ============ FEIERN: Anlässe-Karten + Vielfalt ============ */
.section{position:relative;z-index:1;padding:clamp(72px,9vw,112px) 24px}
.section--creme{background:var(--creme)}
.section--center{text-align:center}
.section__inner{max-width:760px;margin:0 auto}
.section__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(30px,4.4vw,52px);line-height:1.12;color:var(--text);margin-top:14px}
.section__text{margin-top:28px;font-size:18px;line-height:1.85;color:var(--text2)}

.anlaesse{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;max-width:1100px;margin:48px auto 0}
.anlass{flex:1 1 180px;max-width:210px;background:var(--weiss);border:1px solid var(--linie);border-radius:2px;padding:34px 22px;text-align:center}
.anlass svg{display:block;margin:0 auto}
.anlass p{font-family:var(--serif-display);font-weight:500;font-size:19px;color:var(--text);margin-top:16px;line-height:1.2}
.anlaesse-outro{max-width:760px;margin:48px auto 0;text-align:center;font-size:18px;line-height:1.85;color:var(--text2)}

.vielfalt{position:relative;z-index:1;background:var(--gruen);padding:clamp(72px,9vw,112px) 24px;text-align:center}
.vielfalt__inner{max-width:760px;margin:0 auto}
.vielfalt__eyebrow{font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:#FFFFFF;font-weight:600}
.vielfalt__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(30px,4.4vw,52px);line-height:1.12;color:#FFFFFF;margin-top:14px}
.vielfalt__text{margin-top:28px;font-size:18px;line-height:1.85;color:#FFFFFF}

/* ============ FORMULAR ============ */
.formsec{position:relative;z-index:1;background:var(--creme-card);padding:clamp(72px,9vw,108px) 24px;border-top:1px solid var(--linie)}
.formsec__head{text-align:center;max-width:760px;margin:0 auto 44px}
.formsec__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(30px,4.4vw,50px);line-height:1.12;color:var(--text);margin-top:14px}
.formwrap{max-width:760px;margin:0 auto;padding:0 24px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px}
.field{display:flex;flex-direction:column}
.field.full{grid-column:1/-1}
.field label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text2);font-weight:600;margin-bottom:8px}
.field input,.field textarea{font-family:inherit;font-size:16px;color:var(--text);background:var(--weiss);border:1px solid rgba(148, 132, 116,.3);border-radius:2px;padding:12px 14px;width:100%}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gruen)}
.field textarea{resize:vertical;min-height:120px}
.form-stack .field{margin-bottom:18px}
.form-stack--ta140 .field textarea{min-height:140px}
.form-stack--ta130 .field textarea{min-height:130px}
.form-narrow{max-width:640px;margin:0 auto}
.frow{display:flex;gap:16px;flex-wrap:wrap}
.frow .field{flex:1 1 150px}
.dsgvo{display:flex;align-items:flex-start;gap:12px}
.dsgvo input{width:18px;height:18px;margin-top:3px;accent-color:var(--gruen);flex:0 0 auto}
.dsgvo label{font-size:14px;line-height:1.6;color:var(--text2);font-weight:400;letter-spacing:normal;text-transform:none;margin:0}
.dsgvo label a{color:var(--gruen);text-decoration:none}
@media(max-width:640px){.fgrid{grid-template-columns:1fr}}

/* Feiern-Formular (Grid-Variante) Spezial-Abstände */
.fgrid .dsgvo{grid-column:1/-1;margin-top:4px}
.fgrid .form-actions{grid-column:1/-1;margin-top:6px;display:flex}
.fgrid .form-actions .btn{align-self:flex-start}

/* Reservierung/Kontakt gestapeltes Formular */
.form-stack .dsgvo{margin:6px 0 22px}
.form-stack .dsgvo--res{margin:6px 0 24px}
.form-stack__lead{text-align:center;font-size:17px;line-height:1.8;color:var(--text2)}
.form-stack__form{margin-top:40px}

/* ============ KONTAKT-LAYOUT ============ */
.contact{position:relative;z-index:1;background:var(--creme);padding:clamp(72px,9vw,112px) 24px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,76px);max-width:1120px;margin:0 auto;align-items:start}
@media(max-width:840px){.contact-grid{grid-template-columns:1fr}}
.contact__col{display:flex;flex-direction:column;gap:18px}
.contact-box{background:var(--weiss);border:1px solid var(--linie);border-radius:2px;padding:clamp(26px,3vw,34px)}
.info-block{margin-bottom:34px}
.info-block--22{margin-bottom:22px}
.info-block--0{margin-bottom:0}
.info-block .eyebrow{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--gruen);font-weight:600}
.info-block .val{margin-top:4px;font-size:17px;line-height:1.75;color:var(--text)}
.info-block a{color:var(--text);text-decoration:none;transition:color .2s ease}
.info-block a:hover{color:var(--gruen)}
.contact-box__hint{margin-top:16px;font-size:14px;line-height:1.65;color:var(--text2);font-style:italic}
.contact-map{position:relative;height:300px;overflow:hidden;border-radius:2px;border:1px solid var(--linie)}
.contact-map iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.9)}
.contact-photo{width:100%;height:100%;object-fit:cover;display:block}
.contact-form__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(26px,3.2vw,38px);line-height:1.12;color:var(--text);margin-bottom:26px}

/* ============ GUTSCHEINE ============ */
.hinweis{position:relative;z-index:1;background:var(--creme);padding:clamp(84px,11vw,140px) 24px;text-align:center}
.hinweis__inner{max-width:640px;margin:0 auto}
.hinweis__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(30px,4.4vw,52px);line-height:1.14;color:var(--text);margin-top:16px}
.hinweis__text{margin-top:28px;font-size:18px;line-height:1.85;color:var(--text2)}
.hinweis__contacts{margin-top:44px;display:flex;flex-direction:column;gap:18px;align-items:center}
.hinweis__label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gruen);font-weight:600}
.hinweis__value{margin-top:6px;font-size:16px}
.hinweis__value a{text-decoration:none}
.hinweis__value--addr{line-height:1.7;color:var(--text)}
.hinweis__phone{font-family:var(--serif);font-size:28px;color:var(--text);text-decoration:none}
.hinweis__phone:hover{color:var(--gruen)}
.hinweis__mail{color:var(--gruen);text-decoration:none;font-weight:600}
.hinweis__mail:hover{color:var(--gruen-dark)}
.hinweis__cta{margin-top:44px}

/* ============ FOOTER ============ */
.site-footer{position:relative;z-index:1;background:var(--fast-schwarz);color:var(--hell);padding:84px clamp(28px,6vw,64px) 40px}
.site-footer__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:48px;max-width:1180px;margin:0 auto}
.site-footer__logo{height:72px;width:auto;opacity:1}
.site-footer__about{margin-top:20px;font-size:15px;line-height:1.8;color:rgba(251,246,236,.7);max-width:280px}
.site-footer__label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-hell);font-weight:600}
.site-footer__text{margin-top:16px;font-size:16px;line-height:1.9;color:rgba(251,246,236,.85)}
.site-footer__links{margin-top:16px;font-size:16px;line-height:1.9}
.site-footer__nav{margin-top:16px;font-size:16px;line-height:2.1}
.site-footer__ferien{margin-top:16px;font-size:14px;line-height:1.7;color:rgba(251,246,236,.6)}
.site-footer a{color:rgba(251,246,236,.85);text-decoration:none;transition:color .2s ease}
.site-footer a:hover{color:var(--gold-hell)}
.site-footer__bottom{max-width:1180px;margin:56px auto 0;padding-top:26px;border-top:1px solid rgba(251,246,236,.14);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center}
.site-footer__copy{font-size:13px;color:rgba(251,246,236,.5)}
.site-footer__grazie{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--gold-hell)}

/* ============ RECHTSSEITEN (Impressum / Datenschutz) ============ */
.pagehead{position:relative;z-index:1;background:var(--creme);padding:140px 24px clamp(36px,5vw,56px);text-align:center}
.pagehead__title{font-family:var(--serif-display);font-weight:500;font-size:clamp(30px,4.4vw,52px);line-height:1.12;color:var(--text);margin-top:16px}
.legal{position:relative;z-index:1;background:var(--creme);padding:0 24px clamp(64px,9vw,110px)}
.legal__inner{max-width:760px;margin:0 auto;color:var(--text2);font-size:17px;line-height:1.85}
.legal__inner h2{font-family:var(--serif-display);font-weight:500;font-size:clamp(22px,3vw,30px);line-height:1.25;color:var(--text);margin:36px 0 12px}
.legal__inner h2:first-child{margin-top:0}
.legal__inner p{margin-bottom:14px}
.legal__inner a{color:var(--gruen);text-decoration:none}
.legal__inner a:hover{color:var(--gruen-dark)}
/* Header auf den hellen Rechtsseiten lesbar (kein dunkler Hero): dunkler Text, kein Verlauf */
body.page-impressum .site-header::before,
body.page-datenschutz .site-header::before,
body.page-404 .site-header::before{opacity:0}
body.page-impressum .site-header:not(.scrolled) .site-nav__link,
body.page-datenschutz .site-header:not(.scrolled) .site-nav__link,
body.page-404 .site-header:not(.scrolled) .site-nav__link{color:var(--nav-dark)}
body.page-impressum .site-header:not(.scrolled) .site-header__burger-line,
body.page-datenschutz .site-header:not(.scrolled) .site-header__burger-line,
body.page-404 .site-header:not(.scrolled) .site-header__burger-line{background:var(--nav-dark)}

/* ============ CONSENT: untere Leiste + Google-Maps-Platzhalter ============ */
.consent-bar{position:fixed;left:0;right:0;bottom:0;z-index:55;background:var(--fast-schwarz);color:var(--hell);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 24px;padding:14px clamp(20px,4vw,40px);box-shadow:0 -6px 24px rgba(0,0,0,.25);transform:translateY(100%);transition:transform .35s ease}
.consent-bar.is-visible{transform:translateY(0)}
.consent-bar__text{font-size:13.5px;line-height:1.55;color:rgba(251,246,236,.85);max-width:760px}
.consent-bar__text a{color:var(--gold-hell);text-decoration:underline}
.consent-bar__actions{display:flex;gap:10px;flex:0 0 auto}
.consent-bar__btn{padding:11px 22px}
.consent-bar__ghost{font-family:inherit;font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--hell);background:transparent;border:1px solid rgba(251,246,236,.4);border-radius:2px;padding:11px 22px;cursor:pointer;transition:background .2s ease,border-color .2s ease}
.consent-bar__ghost:hover{background:rgba(251,246,236,.1);border-color:rgba(251,246,236,.7)}

.map-consent{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;background:var(--creme-card);color:var(--text2)}
.map-consent__inner{max-width:380px}
.map-consent__icon{color:var(--gruen)}
.map-consent__text{font-size:13.5px;line-height:1.6;color:var(--text2);margin:12px 0 16px}
.map-consent .btn{padding:12px 26px}

.site-footer__consent{font-family:inherit;font-size:13px;color:rgba(251,246,236,.5);background:none;border:none;padding:0;cursor:pointer;text-decoration:underline;transition:color .2s ease}
.site-footer__consent:hover{color:var(--gold-hell)}

/* ============ FORMULAR: Feedback-Banner + Honeypot ============ */
.formmsg{max-width:760px;margin:0 auto 24px;padding:14px 18px;border-radius:2px;font-size:15px;line-height:1.55}
.formmsg--ok{background:rgba(148, 132, 116,.14);border:1px solid rgba(148, 132, 116,.55);color:#2A221E}
.formmsg--err{background:rgba(168,58,48,.10);border:1px solid rgba(168,58,48,.45);color:#8a2b21}
/* Honeypot: off-screen (nicht display:none), für Menschen unsichtbar */
.hp{position:absolute !important;left:-9999px !important;top:auto;width:1px;height:1px;overflow:hidden}

/* ============ GOOGLE-BEWERTUNGEN (statischer Slider, Vanilla-JS) ============ */
.reviews-section{position:relative;z-index:1;padding:96px clamp(20px,5vw,80px);background:var(--creme)}
.reviews__head{text-align:center;margin-bottom:34px}
.reviews__title{font-family:var(--serif-display);font-weight:600;color:var(--text);font-size:clamp(26px,4.2vw,42px);line-height:1.1;margin-top:12px}

/* --- Sterne: graue Basis + Gold-Overlay (Breite = Anteil, erlaubt halbe Sterne) --- */
.stars{position:relative;display:inline-block;font-size:17px;line-height:1;letter-spacing:2px;white-space:nowrap;font-family:Arial,sans-serif}
.stars--lg{font-size:20px}
.stars__base{color:rgba(43,32,48,.20)}
.stars__fill{position:absolute;top:0;left:0;width:0;overflow:hidden;color:var(--gold)}

/* --- Summary-Box --- */
.reviews-summary{max-width:780px;margin:0 auto 42px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:clamp(16px,3vw,30px);background:var(--creme-card);border:1px solid var(--linie);border-radius:4px;padding:22px clamp(20px,4vw,34px)}
.reviews-summary__google{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--text);font-size:15px}
.reviews-summary__divider{width:1px;align-self:stretch;background:var(--linie)}
.reviews-summary__score{font-family:var(--serif-display);font-size:46px;line-height:1;color:var(--text)}
.reviews-summary__col{display:flex;flex-direction:column;gap:5px}
.reviews-summary__count{font-size:14px;color:var(--text2)}
.reviews-summary__count span{font-weight:700;color:var(--text)}
@media(max-width:560px){.reviews-summary__divider{display:none}.reviews-summary__write{width:100%;text-align:center}}

/* --- Slider --- */
.reviews-slider{position:relative;max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:10px}
.reviews-viewport{overflow:hidden;flex:1}
.reviews-track{display:flex;gap:18px;transition:transform .55s cubic-bezier(.4,0,.2,1);will-change:transform}
.review-card{flex:0 0 calc((100% - 36px)/3);box-sizing:border-box;background:var(--creme-card);border:1px solid var(--linie);border-radius:4px;padding:22px 22px 24px;display:flex;flex-direction:column;position:relative}
@media(max-width:991px){.review-card{flex-basis:calc((100% - 18px)/2)}}
@media(max-width:599px){.review-card{flex-basis:100%}}

.review-card__head{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding-right:26px}
.review-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}
.review-avatar--1{background:#E6F1FB;color:#185FA5}
.review-avatar--2{background:#E1F5EE;color:#0F6E56}
.review-avatar--3{background:#FAEEDA;color:#854F0B}
.review-avatar--4{background:#EEEDFE;color:#534AB7}
.review-avatar--5{background:#FBEAF0;color:#993556}
.review-meta{min-width:0}
.review-author{font-weight:700;color:var(--text);font-size:15px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.review-date{font-size:13px;color:var(--text2)}
.review-card__g{position:absolute;top:18px;right:18px;line-height:0;opacity:.95}
.review-stars{margin-bottom:10px}
.review-text{color:var(--text2);font-size:15px;line-height:1.65;margin:0}
/* Zeilen-Begrenzung + "Mehr lesen" nur wenn JS aktiv (ohne JS: voller Text, gut für SEO) */
.reviews-js .review-text{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:5;overflow:hidden}
.reviews-js .review-text.is-expanded{-webkit-line-clamp:unset;display:block;overflow:visible}
.review-more{align-self:flex-start;margin-top:10px;background:none;border:none;padding:0;color:var(--gruen);font-family:inherit;font-weight:600;font-size:13px;letter-spacing:.03em;cursor:pointer}
.review-more:hover{text-decoration:underline}

.reviews-arrow{flex-shrink:0;width:46px;height:46px;border-radius:50%;border:1px solid var(--linie);background:var(--weiss);color:var(--text);font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease,border-color .2s ease}
.reviews-arrow:hover{background:var(--gruen);color:var(--hell);border-color:var(--gruen)}
.reviews-arrow:disabled{opacity:.35;cursor:default;background:var(--weiss);color:var(--text);border-color:var(--linie)}
@media(max-width:599px){.reviews-arrow{display:none}}

.reviews-dots{display:flex;justify-content:center;gap:9px;margin-top:26px}
.reviews-dot{width:9px;height:9px;padding:0;border:none;border-radius:50%;background:var(--linie);cursor:pointer;transition:background .2s ease,transform .2s ease}
.reviews-dot.is-active{background:var(--gruen);transform:scale(1.25)}

/* Hero-Eyebrow in Akzentfarbe + weiße Unterzeile (HERO_EYEBROW_AKZENT=JA) */
.hero-home__eyebrow{display:inline-block;background:#C4907A;color:#fff;padding:3px;font-size:12px}
.hero-home__title em{color:#fff}
