/* =====================================================================
   Ristorante Artischocke — 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 ============ */
:root{
  --gruen:#788E5E;
  --gruen-dark:#5f7049;
  --gold:#AE9A64;
  --gold-hell:#C9B788;
  --creme:#F4EDE0;
  --creme-card:#FBF7EF;
  --weiss:#FFFFFF;
  --text:#2B2030;
  --text2:#5f574b;
  --text3:#4c4537;
  --nav-dark:#3c4031;
  --fast-schwarz:#0E0E0E;
  --hell:#FBF6EC;
  --linie:rgba(120,142,94,.16);

  --serif-display:'Cinzel',serif;
  --serif:'Cormorant Garamond',serif;
  --sans:'Hanken Grotesk',sans-serif;
}

/* ============ 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('https://restaurant-artischocke.com/wp-content/uploads/2021/03/artischocke_bg-scaled.jpg');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(120,142,94,.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}
.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__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}

/* ============ 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--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('https://restaurant-artischocke.com/wp-content/uploads/2022/11/IMG_8030.jpg')}
/* 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('https://restaurant-artischocke.com/wp-content/uploads/2022/11/IMG_8030.jpg')}}
.hero-home__inner{max-width:920px}
.hero-home__eyebrow{font-size:13px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold-hell);font-weight:600;margin-bottom:26px}
.hero-home__title{font-family:var(--serif-display);font-weight:600;color:var(--hell);font-size:clamp(40px,7vw,88px);line-height:1.05;letter-spacing:.01em}
.hero-home__title em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--gold-hell);text-transform:none;font-size:clamp(34px,5.6vw,62px)}
.hero-home__lead{max-width:560px;margin:30px auto 0;color:rgba(251,246,236,.88);font-size:18px;line-height:1.7}
.hero-home__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:40px}
.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('https://restaurant-artischocke.com/wp-content/uploads/2021/03/DSC00021.jpg')}
.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('https://restaurant-artischocke.com/wp-content/uploads/2021/03/csm_Web__335_von_420__3bdddc99ce.jpg')}
.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('https://restaurant-artischocke.com/wp-content/uploads/2021/03/DSC00021.jpg')}
.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('https://restaurant-artischocke.com/wp-content/uploads/2022/11/IMG_8030.jpg')}
.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('https://restaurant-artischocke.com/wp-content/uploads/2021/03/DSC00021.jpg')}
.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}
.detailbar__table{margin-top:22px;width:100%;border-collapse:collapse;font-size:16px;color:var(--text3)}
.detailbar__table td{padding:7px 0}
.detailbar__table td.day{color:var(--text2)}
.detailbar__table td.time{text-align:right;font-weight:600;color:var(--text)}
.detailbar__table td.time--rest{color:var(--gruen)}
.detailbar__table tr+tr{border-top:1px solid rgba(120,142,94,.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(120,142,94,.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(120,142,94,.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('https://restaurant-artischocke.com/wp-content/uploads/2021/03/DSC05107.jpg')}
.dishrow__img--pasta{background-image:url('https://restaurant-artischocke.com/wp-content/uploads/2021/03/DSC09196.jpg')}
.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('https://restaurant-artischocke.com/wp-content/uploads/2021/03/DSC00021.jpg')}
.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}
.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(120,142,94,.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('https://restaurant-artischocke.com/wp-content/uploads/2022/01/DSCN9678.jpg')}
.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}

/* ============ 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}
.cat h2{font-family:var(--serif-display);font-weight:500;font-size:clamp(26px,3.4vw,38px);color:var(--text);scroll-margin-top:155px}
.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}
.catbar .inner{display:flex;flex-wrap:nowrap;gap:9px;width:max-content;max-width:100%;margin:0 auto;overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(120,142,94,.4) transparent;-webkit-overflow-scrolling:touch}
.catbar .inner::-webkit-scrollbar{height:5px}
.catbar .inner::-webkit-scrollbar-thumb{background:rgba(120,142,94,.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(120,142,94,.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(120,142,94,.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(120,142,94,.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-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)}
