/* ============================================================
   ANDREASKLAUSE – Heller Vintage-Look
   Farbwelt: Creme · Sand · Salbei · Waldgrün · Gold · Holzbraun
   ============================================================ */

:root{
  --creme:    #f8f2e2;
  --creme-2:  #fbf7ec;
  --sand:     #e7d6b0;
  --sand-2:   #efe3c6;
  --salbei:   #9aa67e;
  --salbei-2: #aeb892;
  --waldgruen:#3a4a2a;
  --waldgruen-2:#2c3a1f;
  --gold:     #c39b48;
  --gold-2:   #d9b75f;
  --holz:     #6b4a2b;
  --holz-2:   #54371f;
  --rot:      #8c2f2a;       /* Vintage-Rot für Akzente (Plakate) */
  --ink:      #33301f;       /* Fließtext auf hell */
  --ink-soft: #5e5942;

  --shadow:   0 10px 30px rgba(60,45,25,.14);
  --shadow-sm:0 4px 14px rgba(60,45,25,.12);
  --radius:   16px;
  --radius-sm:10px;

  --font-head: 'Playfair Display', Georgia, serif;
  --font-script:'Dancing Script', cursive;
  --font-logo: 'Lilita One', 'Playfair Display', cursive;
  --font-body: 'Mulish', -apple-system, system-ui, sans-serif;
  --logo-brown:#6e3f1e;

  --maxw: 1120px;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; scroll-padding-top:78px; }

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background-color:var(--creme);
  background-image:
    radial-gradient(circle at 20% 10%, rgba(255,255,255,.5), transparent 45%),
    radial-gradient(circle at 80% 90%, rgba(154,166,126,.10), transparent 50%);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

h1,h2,h3{ font-family:var(--font-head); line-height:1.15; margin:0; }
a{ color:var(--waldgruen); }
img{ max-width:100%; display:block; }

.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  padding:.85em 1.8em; border-radius:999px; font-weight:700; font-size:1rem;
  text-decoration:none; cursor:pointer; border:2px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  letter-spacing:.01em;
}
.btn--primary{ background:var(--waldgruen); color:var(--creme-2); box-shadow:var(--shadow-sm); }
.btn--primary:hover{ background:var(--waldgruen-2); transform:translateY(-2px); box-shadow:var(--shadow); }
.btn--ghost{ background:transparent; color:var(--waldgruen); border-color:var(--gold); }
.btn--ghost:hover{ background:var(--gold); color:#fff; transform:translateY(-2px); }
.btn--block{ width:100%; margin-top:1rem; }

/* ============================================================
   NAVIGATION
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(248,242,226,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(195,155,72,.35);
}
.nav{
  max-width:var(--maxw); margin:0 auto; padding:.6rem 22px;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.nav__brand{ text-decoration:none; display:flex; align-items:center; gap:.6rem; line-height:1.05; }
.nav__brand-logo{ flex:none; width:48px; height:48px; border-radius:10px; }
.nav__brand-text{ display:flex; flex-direction:column; }
.nav__brand-name{ font-family:var(--font-logo); font-size:1.5rem; color:var(--logo-brown); letter-spacing:.01em; }
.nav__brand-sub{ font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); font-weight:700; white-space:nowrap; }

.nav__menu{
  list-style:none; margin:0; padding:0; display:flex; align-items:center; gap:.35rem;
}
.nav__menu a{
  text-decoration:none; color:var(--ink); font-weight:600; font-size:.95rem;
  padding:.5rem .8rem; border-radius:8px; transition:background .15s, color .15s;
}
.nav__menu a:hover{ background:var(--sand-2); color:var(--waldgruen); }
.nav__cta{ background:var(--waldgruen); color:var(--creme-2)!important; }
.nav__cta:hover{ background:var(--waldgruen-2)!important; }

.nav__toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px;
}
.nav__toggle span{ width:26px; height:3px; background:var(--waldgruen); border-radius:3px; transition:.25s; }
.nav__toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; text-align:center; overflow:hidden;
  padding:clamp(3.5rem,9vw,7rem) 22px clamp(2.5rem,6vw,4rem);
  background:
    radial-gradient(ellipse at top, var(--creme-2), var(--creme) 70%),
    linear-gradient(180deg, var(--sand-2), var(--creme));
  border-bottom:6px double var(--gold);
}
.hero__ornament{
  position:absolute; top:8%; font-size:clamp(3rem,8vw,6rem); opacity:.5;
  filter:sepia(.4) hue-rotate(40deg); user-select:none;
}
.hero__ornament--left{ left:4%; transform:rotate(-18deg); }
.hero__ornament--right{ right:4%; transform:rotate(18deg) scaleX(-1); }

.hero__inner{ max-width:760px; margin:0 auto; position:relative; z-index:2; }
.hero__eyebrow{
  font-family:var(--font-script); font-size:clamp(1.3rem,3vw,1.8rem);
  color:var(--rot); margin:0 0 .2rem;
}
.hero__logo-h1{ margin:.6rem 0 1.1rem; line-height:0; }
.hero__logo{
  display:block; width:clamp(190px,32vw,300px); height:auto; margin:0 auto;
  border-radius:28px; background:#fff;
  box-shadow:0 14px 32px rgba(60,45,25,.22);
  animation:logoPop .7s ease both;
}
@keyframes logoPop{ from{ transform:scale(.85); opacity:0; } to{ transform:none; opacity:1; } }
.hero__title{
  font-family:var(--font-logo); font-size:clamp(2.8rem,10vw,5.6rem); color:var(--logo-brown);
  letter-spacing:.01em; margin:0; line-height:1;
  text-shadow:
    -2px -2px 0 #fff5e2, 2px -2px 0 #fff5e2, -2px 2px 0 #fff5e2, 2px 2px 0 #fff5e2,
    0 6px 0 rgba(46,28,14,.18), 0 10px 16px rgba(46,28,14,.18);
}
.hero__tagline{
  font-size:clamp(.85rem,2.4vw,1.1rem); letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold); font-weight:700; margin:.4rem 0 1.4rem;
}
.hero__script{
  font-family:var(--font-script); font-size:clamp(2rem,5vw,3rem);
  color:var(--rot); margin:0 0 1rem; transform:rotate(-2deg);
}
.hero__lead{ font-size:clamp(1rem,2vw,1.18rem); color:var(--ink-soft); max-width:560px; margin:0 auto 2rem; }
.hero__actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero__badge{
  margin-top:2.2rem; display:inline-block; font-family:var(--font-head); font-style:italic;
  font-size:1.15rem; color:var(--waldgruen);
}
.hero__values{
  margin:2.5rem auto 0; max-width:680px; display:flex; flex-wrap:wrap; justify-content:center;
  gap:.5rem 1rem; font-family:var(--font-head); font-style:italic; color:var(--ink-soft);
  position:relative; z-index:2;
}
.hero__values i{ color:var(--gold); font-style:normal; }

/* ============================================================
   SECTIONS (generisch)
   ============================================================ */
.section{ padding:clamp(3rem,7vw,5.5rem) 0; position:relative; }
.section--cream{ background:var(--creme); }
.section--sage{ background:linear-gradient(180deg, var(--salbei-2), var(--salbei)); }
.section--menu{ background:linear-gradient(180deg, var(--sand-2), var(--creme-2)); }
.section--wood{
  background:linear-gradient(135deg, var(--holz), var(--holz-2));
  color:var(--creme-2);
}

.section__kicker{
  text-align:center; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  font-size:.8rem; color:var(--gold); margin:0 0 .5rem;
}
.section--sage .section__kicker{ color:var(--waldgruen-2); }
.section--wood .section__kicker{ color:var(--gold-2); }

.section__title{
  text-align:center; font-size:clamp(1.9rem,5vw,2.9rem); font-weight:700; color:var(--waldgruen);
  margin:0 0 1rem;
}
.section__title--light{ color:var(--creme-2); }
.section--sage .section__title{ color:var(--waldgruen-2); }

.section__intro{
  text-align:center; max-width:640px; margin:0 auto 2.8rem; color:var(--ink-soft);
  font-size:1.08rem;
}
.section--sage .section__intro{ color:var(--waldgruen-2); }

/* ---------- Reveal-Animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   ATMOSPHÄRE – Feature Cards
   ============================================================ */
.feature-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.4rem;
}
.feature-card{
  background:var(--creme-2); border:1px solid rgba(195,155,72,.3); border-radius:var(--radius);
  padding:2rem 1.5rem; text-align:center; box-shadow:var(--shadow-sm);
  transition:transform .2s ease, box-shadow .2s ease;
}
.feature-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.feature-card__icon{
  width:64px; height:64px; margin:0 auto 1rem; display:grid; place-items:center;
  font-size:1.8rem; border-radius:50%; background:var(--sand-2); border:2px solid var(--gold);
}
.feature-card h3{ font-size:1.25rem; color:var(--waldgruen); margin-bottom:.5rem; }
.feature-card p{ margin:0; font-size:.96rem; color:var(--ink-soft); }

/* ============================================================
   HIGHLIGHTS
   ============================================================ */
.highlight-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:1.4rem;
}
.highlight-card{
  background:var(--creme-2); border-radius:var(--radius); padding:1.8rem 1.4rem;
  box-shadow:var(--shadow-sm); border:1px solid rgba(108,74,43,.18); text-align:center;
  transition:transform .2s ease, box-shadow .2s ease;
}
.highlight-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.highlight-card--feature{
  border:2px solid var(--gold);
  background:linear-gradient(180deg,#fff,var(--sand-2));
  position:relative;
}
.highlight-card--feature::after{
  content:"★ Liebling"; position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  background:var(--rot); color:#fff; font-size:.7rem; font-weight:700; letter-spacing:.1em;
  padding:.3em .9em; border-radius:999px; text-transform:uppercase;
}
.highlight-card__emoji{ font-size:2.6rem; margin-bottom:.6rem; }
.highlight-card h3{ font-size:1.3rem; color:var(--rot); margin-bottom:.5rem; }
.highlight-card p{ margin:0 0 .6rem; color:var(--ink-soft); font-size:.96rem; }
.highlight-card__price{
  display:inline-block; font-family:var(--font-head); font-weight:700; color:var(--waldgruen);
  background:var(--sand-2); padding:.25em 1em; border-radius:999px; margin:0!important;
}

/* ============================================================
   SNACKS
   ============================================================ */
.snack-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.6rem;
  max-width:760px; margin:0 auto;
}
.snack-card{
  background:var(--creme-2); border:1px solid rgba(108,74,43,.2); border-radius:var(--radius);
  padding:2rem 1.6rem; text-align:center; box-shadow:var(--shadow-sm);
  transition:transform .2s ease, box-shadow .2s ease;
}
.snack-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.snack-card__emoji{ font-size:3rem; margin-bottom:.5rem; }
.snack-card h3{ color:var(--rot); font-size:1.35rem; margin-bottom:.5rem; }
.snack-card p{ margin:0; color:var(--ink-soft); }
.snack-note{
  text-align:center; margin:2rem auto 0; font-family:var(--font-head); font-style:italic;
  font-size:1.1rem; color:var(--waldgruen);
}

/* ============================================================
   GETRÄNKEKARTE
   ============================================================ */
.menu-filter{
  display:flex; flex-wrap:wrap; justify-content:center; gap:.5rem; margin-bottom:2.5rem;
}
.menu-filter__btn{
  border:1.5px solid var(--gold); background:transparent; color:var(--waldgruen);
  padding:.5em 1.1em; border-radius:999px; font-family:var(--font-body); font-weight:600;
  font-size:.9rem; cursor:pointer; transition:.18s;
}
.menu-filter__btn:hover{ background:var(--sand-2); }
.menu-filter__btn.is-active{ background:var(--waldgruen); color:var(--creme-2); border-color:var(--waldgruen); }

.menu-grid{
  columns:2; column-gap:1.6rem;
}
.menu-block{
  break-inside:avoid; margin:0 0 1.6rem; padding:1.5rem 1.5rem 1.2rem;
  background:var(--creme-2); border:1px solid rgba(108,74,43,.18); border-radius:var(--radius);
  box-shadow:var(--shadow-sm); display:inline-block; width:100%;
  transition:opacity .3s ease;
}
.menu-block--wide{ column-span:all; }
.menu-block__title{
  font-size:1.3rem; color:var(--waldgruen); margin-bottom:.9rem;
  padding-bottom:.5rem; border-bottom:2px solid var(--gold);
  display:flex; align-items:baseline; justify-content:space-between; flex-wrap:wrap; gap:.3rem;
}
.menu-block__units{
  font-family:var(--font-body); font-size:.72rem; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; color:var(--gold); white-space:nowrap;
}
.menu-list{ list-style:none; margin:0; padding:0; }
.menu-list--2col{ columns:2; column-gap:2rem; }
.menu-list li{
  display:flex; justify-content:space-between; align-items:baseline; gap:.8rem;
  padding:.4rem 0; border-bottom:1px dotted rgba(108,74,43,.28); break-inside:avoid;
}
.menu-list li:last-child{ border-bottom:0; }
.mi-name{ color:var(--ink); font-weight:600; font-size:.96rem; }
.mi-name em{ font-style:italic; font-weight:400; color:var(--ink-soft); font-size:.85em; }
.mi-price{ color:var(--waldgruen); font-weight:700; white-space:nowrap; font-size:.92rem; }

.menu-block.is-hidden{ display:none; }

.menu-footnote{
  text-align:center; margin-top:1.5rem; font-size:.8rem; color:var(--ink-soft); line-height:1.7;
}

/* ============================================================
   AKTIONEN
   ============================================================ */
.action-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.5rem;
}
.action-card{
  background:rgba(248,242,226,.08); border:1px solid rgba(217,183,95,.4);
  border-radius:var(--radius); padding:2rem 1.6rem; text-align:center;
  backdrop-filter:blur(2px); transition:transform .2s ease, background .2s ease;
}
.action-card:hover{ transform:translateY(-6px); background:rgba(248,242,226,.14); }
.action-card__icon{
  font-size:2.4rem; margin-bottom:.6rem;
  width:70px; height:70px; margin-inline:auto; display:grid; place-items:center;
  background:rgba(217,183,95,.18); border:2px solid var(--gold-2); border-radius:50%;
}
.action-card h3{ color:var(--gold-2); font-size:1.3rem; margin-bottom:.6rem; }
.action-card p{ margin:0; color:var(--creme-2); font-size:.96rem; }
.action-card strong{ color:#fff; }

/* ============================================================
   KONTAKT / ÖFFNUNGSZEITEN
   ============================================================ */
.contact-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:1.6rem; max-width:860px; margin:0 auto;
}
.hours-card,.contact-card{
  background:var(--creme-2); border:1px solid rgba(195,155,72,.35); border-radius:var(--radius);
  padding:2rem 1.8rem; box-shadow:var(--shadow-sm);
}
.hours-card h3,.contact-card h3{
  color:var(--waldgruen); font-size:1.4rem; margin-bottom:1rem; text-align:center;
  padding-bottom:.6rem; border-bottom:2px solid var(--gold);
}
.hours-list{ list-style:none; margin:0; padding:0; }
.hours-list li{
  display:flex; justify-content:space-between; gap:1rem; padding:.55rem 0;
  border-bottom:1px dotted rgba(108,74,43,.25); font-size:.98rem;
}
.hours-list li:last-child{ border-bottom:0; }
.hours-list li span:first-child{ font-weight:600; color:var(--ink); }
.hours-list li span:last-child{ color:var(--ink-soft); font-weight:600; }
.hours-closed{ color:var(--rot)!important; font-style:italic; }
.hours-card__status{
  margin:1rem 0 0; text-align:center; font-weight:700; padding:.5rem; border-radius:8px;
}
.hours-card__status.is-open{ background:rgba(154,166,126,.25); color:var(--waldgruen-2); }
.hours-card__status.is-closed{ background:rgba(140,47,42,.12); color:var(--rot); }

.contact-card__line{ font-size:1.05rem; margin:.6rem 0; }
.contact-card__line a{ font-weight:700; text-decoration:none; }
.contact-card__line a:hover{ text-decoration:underline; }
.contact-card__note{ margin-top:1rem; font-size:.88rem; color:var(--ink-soft); text-align:center; font-style:italic; }

.willkommen-mat{
  text-align:center; margin:3rem auto 0; max-width:340px;
  font-family:var(--font-script); font-size:2rem; color:var(--holz);
  background:var(--sand); border-radius:40% 40% 8px 8px / 60% 60% 8px 8px;
  padding:1.2rem 1rem .8rem; box-shadow:var(--shadow-sm); border:3px solid var(--holz-2);
  transform:rotate(-1deg);
}

/* ============================================================
   VERANSTALTUNGEN (Unterseite)
   ============================================================ */
.page-hero{
  text-align:center; padding:clamp(2.5rem,6vw,4rem) 22px 1rem;
  background:radial-gradient(ellipse at top, var(--creme-2), var(--creme) 75%);
}
.page-hero__logo{ width:clamp(120px,22vw,160px); height:auto; margin:0 auto .6rem; border-radius:22px; box-shadow:0 10px 24px rgba(60,45,25,.2); }
.page-hero h1{
  font-family:var(--font-logo); color:var(--logo-brown); margin:0;
  font-size:clamp(2.2rem,7vw,3.6rem); line-height:1;
  text-shadow:-2px -2px 0 #fff5e2,2px -2px 0 #fff5e2,-2px 2px 0 #fff5e2,2px 2px 0 #fff5e2, 0 6px 14px rgba(46,28,14,.16);
}
.page-hero p{ color:var(--ink-soft); max-width:560px; margin:.8rem auto 0; font-size:1.08rem; }

.event-list{ max-width:720px; margin:0 auto; list-style:none; padding:0; }
.event-item{
  display:flex; gap:1.2rem; align-items:center;
  background:var(--creme-2); border:1px solid rgba(195,155,72,.3); border-radius:var(--radius);
  padding:1.1rem 1.3rem; margin-bottom:1rem; box-shadow:var(--shadow-sm);
}
.event-date{
  flex:none; width:78px; text-align:center; background:var(--waldgruen); color:var(--creme-2);
  border-radius:12px; padding:.55rem .3rem; font-family:var(--font-head);
}
.event-date .d{ display:block; font-size:1.7rem; font-weight:700; line-height:1; }
.event-date .m{ display:block; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; margin-top:.15rem; }
.event-item--recurring .event-date{ background:var(--gold); color:#fff; }
.event-item--recurring .event-date .icon{ font-size:1.6rem; }
.event-body h3{ color:var(--waldgruen); margin:0 0 .25rem; font-size:1.2rem; }
.event-body p{ margin:0; color:var(--ink-soft); font-size:.95rem; }

.notice-box{
  max-width:720px; margin:1.5rem auto 0; text-align:center;
  background:#fff7e3; border:1px dashed var(--gold); border-radius:var(--radius);
  padding:1.2rem 1.4rem; color:var(--ink-soft); font-size:.95rem;
}

/* Hinweis-Banner (z.B. geschlossene Gesellschaft) */
.alert-banner{
  max-width:760px; margin:0 auto; background:#fbe8d4; border:2px solid var(--rot);
  border-radius:var(--radius); padding:1.1rem 1.4rem; text-align:center; color:var(--rot);
  font-size:.98rem; box-shadow:var(--shadow-sm);
}
.alert-banner strong{ display:block; font-family:var(--font-head); font-size:1.2rem; margin-bottom:.25rem; }

/* WM / Tipprunde */
.wm-wrap{ max-width:680px; margin:0 auto; }
.kt-board{ list-style:none; margin:0 0 .7rem; padding:0; background:var(--creme-2);
  border:1px solid rgba(195,155,72,.4); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); }
.kt-board li{ display:grid; grid-template-columns:52px 1fr auto; gap:.8rem; align-items:center;
  padding:.6rem 1.1rem; border-bottom:1px dotted rgba(108,74,43,.22); }
.kt-board li:last-child{ border-bottom:0; }
.kt-rank{ font-family:var(--font-head); font-weight:700; color:var(--gold); text-align:center; font-size:1.05rem; }
.kt-name{ font-weight:600; color:var(--ink); }
.kt-pts{ font-weight:700; color:var(--waldgruen); white-space:nowrap; }
.kt-board li.is-host{ background:rgba(195,155,72,.18); }
.kt-board li.is-host .kt-name::after{ content:" · ⭐ Wirtin"; font-size:.72rem; color:var(--gold); font-weight:700; }
.kt-note{ text-align:center; font-size:.85rem; color:var(--waldgruen-2); margin:0; }
.kt-note a{ color:var(--waldgruen-2); font-weight:700; }
.wm-headline{ text-align:center; color:var(--waldgruen-2); font-family:var(--font-head); margin:0 0 1rem; font-size:1.25rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--waldgruen-2); color:var(--creme-2); text-align:center;
  padding:3rem 22px 2.2rem; border-top:6px double var(--gold);
}
.site-footer__logo{ width:96px; height:96px; margin:0 auto .8rem; border-radius:18px; box-shadow:0 8px 20px rgba(0,0,0,.4); }
.site-footer__brand{ font-family:var(--font-logo); font-size:2.2rem; margin:0; color:#fff; letter-spacing:.01em; }
.site-footer__tag{ letter-spacing:.28em; text-transform:uppercase; font-size:.72rem; color:var(--gold-2); margin:.2rem 0 1rem; }
.site-footer__heart{ font-family:var(--font-script); font-size:1.6rem; color:var(--gold-2); margin:0 0 1.4rem; }
.site-footer__nav{ display:flex; flex-wrap:wrap; gap:.4rem 1.4rem; justify-content:center; margin-bottom:1.4rem; }
.site-footer__nav a{ color:var(--creme-2); text-decoration:none; font-size:.92rem; opacity:.85; }
.site-footer__nav a:hover{ opacity:1; text-decoration:underline; }
.site-footer__copy{ font-size:.82rem; opacity:.7; margin:0; }

/* ---------- Floating Call Button ---------- */
.floating-call{
  position:fixed; bottom:22px; right:22px; z-index:60;
  width:58px; height:58px; border-radius:50%; background:var(--waldgruen);
  display:grid; place-items:center; font-size:1.5rem; text-decoration:none;
  box-shadow:var(--shadow); transition:transform .2s, background .2s;
}
.floating-call:hover{ transform:scale(1.1); background:var(--rot); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:860px){
  .contact-grid{ grid-template-columns:1fr; }
}

@media (max-width:760px){
  .nav__toggle{ display:flex; }
  .nav__menu{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:var(--creme-2); border-bottom:3px solid var(--gold);
    padding:.5rem 1rem 1rem; box-shadow:var(--shadow);
    transform:translateY(-12px); opacity:0; pointer-events:none; transition:.22s;
  }
  .nav__menu.is-open{ transform:none; opacity:1; pointer-events:auto; }
  .nav__menu a{ display:block; padding:.85rem .6rem; border-bottom:1px solid rgba(108,74,43,.12); }
  .nav__cta{ text-align:center; margin-top:.5rem; border-radius:8px; }

  .menu-grid{ columns:1; }
  .menu-list--2col{ columns:1; }
}

@media (max-width:480px){
  .hero__ornament{ display:none; }
  .btn{ width:100%; }
  .hero__actions{ flex-direction:column; }
}
