/* ============================================================
   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; }
[hidden]{ display:none !important; }

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{ color:var(--waldgruen-2); font-family:var(--font-head); margin:0; font-size:1.25rem; }
.wm-head{ display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin:0 0 1rem; }
.wm-head .btn{ flex:none; }
.wm-head .btn.is-loading{ opacity:.6; pointer-events:none; }

/* ============================================================
   STAMMTISCH (Mitgliederbereich)
   ============================================================ */
.stamm-wrap{ max-width:640px; margin:0 auto; }
.stamm-card{
  background:var(--creme-2); border:1px solid rgba(195,155,72,.4); border-radius:var(--radius);
  padding:1.8rem 1.6rem; box-shadow:var(--shadow-sm);
}
.stamm-tabs{ display:flex; gap:.5rem; margin-bottom:1.2rem; }
.stamm-tabs button{
  flex:1; padding:.6em 1em; border-radius:10px; border:1.5px solid var(--gold); background:transparent;
  font-family:var(--font-body); font-weight:700; color:var(--waldgruen); cursor:pointer;
}
.stamm-tabs button.is-active{ background:var(--waldgruen); color:var(--creme-2); border-color:var(--waldgruen); }
.stamm-form{ display:flex; flex-direction:column; gap:.8rem; }
.stamm-form label{ font-weight:600; font-size:.9rem; color:var(--ink); }
.stamm-form input, .stamm-form textarea{
  width:100%; padding:.7em .9em; border:1.5px solid rgba(108,74,43,.3); border-radius:10px;
  font-family:var(--font-body); font-size:1rem; background:#fff; color:var(--ink);
}
.stamm-form input:focus, .stamm-form textarea:focus{ outline:2px solid var(--gold); border-color:var(--gold); }
.stamm-msg{ text-align:center; font-size:.9rem; padding:.6rem; border-radius:8px; }
.stamm-msg.err{ background:rgba(140,47,42,.12); color:var(--rot); }
.stamm-msg.ok{ background:rgba(154,166,126,.25); color:var(--waldgruen-2); }
.stamm-hint{ text-align:center; font-size:.85rem; color:var(--ink-soft); margin:.8rem 0 0; }

.stamm-bar{ display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:1.2rem; flex-wrap:wrap; }
.stamm-bar .who{ font-weight:700; color:var(--waldgruen); }
.stamm-bar .who .badge{ background:var(--gold); color:#fff; font-size:.7rem; padding:.15em .6em; border-radius:999px; margin-left:.4rem; }
.btn--small{ padding:.5em 1.1em; font-size:.9rem; }

.board{ list-style:none; margin:0 0 1.2rem; padding:0; display:flex; flex-direction:column; gap:.8rem; max-height:460px; overflow-y:auto; }
.board__item{ background:#fff; border:1px solid rgba(108,74,43,.18); border-radius:12px; padding:.8rem 1rem; }
.board__item.is-host{ border-color:var(--gold); background:#fffbef; }
.board__head{ display:flex; justify-content:space-between; align-items:baseline; gap:.6rem; margin-bottom:.25rem; }
.board__author{ font-weight:700; color:var(--waldgruen); font-size:.95rem; }
.board__author .badge{ background:var(--gold); color:#fff; font-size:.66rem; padding:.1em .5em; border-radius:999px; margin-left:.35rem; }
.board__time{ font-size:.75rem; color:var(--ink-soft); white-space:nowrap; }
.board__body{ margin:0; color:var(--ink); white-space:pre-wrap; word-break:break-word; }
.board__del{ background:none; border:0; color:var(--rot); cursor:pointer; font-size:.78rem; margin-top:.3rem; }
.board__empty{ text-align:center; color:var(--ink-soft); padding:1.5rem; }

.stamm-soon{
  text-align:center; background:#fff7e3; border:1px dashed var(--gold); border-radius:var(--radius);
  padding:1.6rem 1.4rem; color:var(--ink-soft);
}
.stamm-soon h3{ color:var(--waldgruen); margin:0 0 .5rem; }

/* --- Pinnwand: Neuheiten-Feed + Karten (Sprüche & Bilder) --- */
.news-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:1rem; }
.pin{ background:#fff; border:1px solid rgba(108,74,43,.18); border-radius:14px; overflow:hidden;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column; break-inside:avoid; }
.pin--spruch{ background:#fffbef; }
.pin__img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.pin__ph{ width:100%; aspect-ratio:4/3; display:grid; place-items:center; font-size:2rem;
  background:linear-gradient(135deg,var(--sand-2),var(--salbei-2)); color:#fff; }
.pin__caption{ padding:.55rem .8rem; margin:0; font-size:.92rem; color:var(--ink); }
.pin__quote{ font-family:var(--font-head); font-style:italic; color:var(--waldgruen);
  font-size:1.05rem; margin:0; padding:1rem 1.1rem .4rem; }
.pin__meta{ display:flex; justify-content:space-between; gap:.5rem; font-size:.74rem; color:var(--ink-soft);
  padding:.5rem .8rem; border-top:1px dotted rgba(108,74,43,.18); margin-top:auto; align-items:center; }
.pin__author{ font-weight:700; color:var(--waldgruen); }
.pin__author .badge{ background:var(--gold); color:#fff; font-size:.62rem; padding:.05em .45em; border-radius:999px; margin-left:.3rem; }
.pin__del{ background:none; border:0; color:var(--rot); cursor:pointer; font-size:.72rem; }

.pin-board{ columns:3; column-gap:1rem; }
.pin-board .pin{ margin:0 0 1rem; }
.topic-group{ break-inside:avoid; }
.topic-group__title{ font-family:var(--font-head); color:var(--waldgruen-2); font-size:1.25rem;
  border-bottom:2px solid var(--gold); padding-bottom:.35rem; margin:0 0 1rem;
  display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.topic-group__title .cnt{ font-family:var(--font-body); font-size:.7rem; font-weight:700; color:var(--gold);
  background:var(--creme-2); border-radius:999px; padding:.1em .6em; }

.composer-toggle{ display:flex; gap:.5rem; margin-bottom:.8rem; }
.composer-toggle button{ flex:1; padding:.55em; border-radius:8px; border:1.5px solid var(--gold);
  background:transparent; font-weight:700; color:var(--waldgruen); cursor:pointer; font-family:var(--font-body); }
.composer-toggle button.is-active{ background:var(--waldgruen); color:var(--creme-2); border-color:var(--waldgruen); }
.preview-note{ text-align:center; font-size:.88rem; color:var(--ink-soft); background:#fff7e3;
  border:1px dashed var(--gold); border-radius:12px; padding:.8rem 1rem; margin:1.2rem auto 0; max-width:620px; }

.dropzone{ display:flex; flex-direction:column; align-items:center; gap:.3rem; justify-content:center;
  border:2px dashed var(--gold); border-radius:12px; padding:1.4rem 1rem; text-align:center; cursor:pointer;
  background:#fff; color:var(--ink-soft); transition:background .15s, border-color .15s; }
.dropzone:hover, .dropzone:focus{ background:var(--sand-2); outline:none; }
.dropzone.is-drag{ background:var(--sand-2); border-color:var(--waldgruen); color:var(--waldgruen); }
.dz-icon{ font-size:1.8rem; }
.dz-link{ color:var(--waldgruen); font-weight:700; text-decoration:underline; }
.dz-preview{ font-weight:700; color:var(--waldgruen); font-size:.9rem; }
.dz-preview img{ max-height:120px; border-radius:8px; margin-top:.4rem; }

@media (max-width:860px){ .pin-board{ columns:2; } }
@media (max-width:560px){ .pin-board{ columns:1; } }

/* ============================================================
   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; }
}

/* ============================================================
   ✨ POLITUR – Textur, Tiefe & Vintage-Eleganz
   ============================================================ */

/* Feine Papier-Körnung über dem ganzen Hintergrund */
body{
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E"),
    radial-gradient(circle at 18% 8%, rgba(255,255,255,.55), transparent 42%),
    radial-gradient(circle at 84% 92%, rgba(154,166,126,.12), transparent 52%);
}

/* Buttons: sanfter Verlauf + Glanz */
.btn--primary{
  background:linear-gradient(180deg, #45562f, var(--waldgruen) 60%, var(--waldgruen-2));
  border-color:rgba(0,0,0,.05);
}
.btn--primary:hover{ background:linear-gradient(180deg, #4e6135, var(--waldgruen)); }
.btn{ position:relative; overflow:hidden; }
.btn::after{
  content:""; position:absolute; top:0; left:-60%; width:40%; height:100%;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.35), transparent);
  transform:skewX(-18deg); transition:left .6s ease;
}
.btn:hover::after{ left:130%; }

/* Section-Kicker mit Gold-Zierlinien links & rechts */
.section__kicker{
  display:flex; align-items:center; justify-content:center; gap:.85rem;
}
.section__kicker::before, .section__kicker::after{
  content:""; height:2px; width:clamp(24px,7vw,60px); border-radius:2px;
  background:linear-gradient(90deg, transparent, var(--gold));
}
.section__kicker::after{ background:linear-gradient(90deg, var(--gold), transparent); }
.section--wood .section__kicker::before{ background:linear-gradient(90deg, transparent, var(--gold-2)); }
.section--wood .section__kicker::after{ background:linear-gradient(90deg, var(--gold-2), transparent); }

/* Section-Titel mit kleinem Zier-Glyph darunter */
.section__title{ position:relative; padding-bottom:.7rem; }
.section__title::after{
  content:"❦"; position:absolute; left:50%; bottom:-.15rem; transform:translateX(-50%);
  font-size:1.1rem; color:var(--gold); opacity:.85;
}
.section--wood .section__title::after, .section--sage .section__title::after{ color:var(--gold-2); }

/* Karten: weichere Mehrschicht-Schatten, Gold-Akzentkante, lebendigeres Hover */
.feature-card, .highlight-card, .snack-card, .hours-card, .contact-card, .event-item{
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 8px 22px rgba(60,45,25,.10), 0 2px 6px rgba(60,45,25,.06);
  transition:transform .22s ease, box-shadow .22s ease;
}
.feature-card{ position:relative; overflow:hidden; }
.feature-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg, var(--gold), var(--gold-2), var(--gold)); opacity:.85;
}
.feature-card:hover, .highlight-card:hover, .snack-card:hover{
  transform:translateY(-8px);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 18px 38px rgba(60,45,25,.18);
}
.feature-card__icon{ box-shadow:0 4px 12px rgba(60,45,25,.15); transition:transform .22s ease; }
.feature-card:hover .feature-card__icon{ transform:scale(1.08) rotate(-4deg); }

/* Highlight-Emojis & Snack-Emojis leicht beleben */
.highlight-card__emoji, .snack-card__emoji{ transition:transform .22s ease; display:inline-block; }
.highlight-card:hover .highlight-card__emoji, .snack-card:hover .snack-card__emoji{ transform:scale(1.12) rotate(5deg); }

/* Hero: warmes Spotlight hinterm Logo + zarte Vignette */
.hero{ position:relative; }
.hero::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 60% 55% at 50% 38%, rgba(255,247,225,.7), transparent 70%);
}
.hero::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  box-shadow:inset 0 0 120px rgba(108,74,43,.12);
}
.hero__inner, .hero__values{ position:relative; z-index:2; }

/* „seit über 60 Jahren“-Siegel */
.hero__since{
  display:inline-flex; align-items:center; gap:.5rem; margin:0 auto 1rem;
  font-family:var(--font-body); font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  font-size:.7rem; color:var(--holz); background:rgba(255,255,255,.55);
  border:1px solid var(--gold); border-radius:999px; padding:.4em 1.1em;
  box-shadow:0 4px 12px rgba(60,45,25,.1);
}
.hero__since b{ color:var(--rot); }

/* Menü-Karten: feiner Gold-Rahmen beim Hovern */
.menu-block{ transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.menu-block:hover{ transform:translateY(-3px); border-color:var(--gold); box-shadow:0 12px 26px rgba(60,45,25,.12); }

/* Navigation: dezenter Unterstrich-Effekt */
.nav__menu a{ position:relative; }
.nav__menu a:not(.nav__cta)::after{
  content:""; position:absolute; left:.8rem; right:.8rem; bottom:.35rem; height:2px;
  background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .2s ease; border-radius:2px;
}
.nav__menu a:not(.nav__cta):hover::after{ transform:scaleX(1); }

/* Floating-Call etwas edler */
.floating-call{ box-shadow:0 8px 24px rgba(60,45,25,.35); border:2px solid rgba(255,255,255,.25); }

@media (prefers-reduced-motion:reduce){
  .btn::after, .feature-card__icon, .highlight-card__emoji, .snack-card__emoji{ transition:none; }
}

/* ============================================================
   ✨ STAMMTISCH-INNENRAUM – aufgeräumt & stimmig
   ============================================================ */
.stamm-card{ box-shadow:0 10px 28px rgba(60,45,25,.12); }

/* Aktionsleiste (Hallo … / Aktualisieren / Abmelden) */
.stamm-bar{
  background:rgba(255,255,255,.55); border:1px solid rgba(195,155,72,.35);
  border-radius:14px; padding:.65rem .9rem; box-shadow:var(--shadow-sm);
}
.stamm-bar .who{ font-family:var(--font-head); font-size:1.1rem; color:var(--waldgruen); }
/* Admin-Badge hebt sich vom goldenen Wirt-Badge ab */
.badge--admin{ background:var(--rot) !important; color:#fff !important; }

/* News-Banner (vom Cockpit gesteuert, oben über allem) */
.news-banner{
  background:linear-gradient(90deg, var(--waldgruen), var(--waldgruen-2));
  color:var(--creme-2); text-align:center; font-weight:700; font-size:.95rem;
  padding:.6rem 1rem; letter-spacing:.01em;
  border-bottom:2px solid var(--gold);
}
.news-banner span{ display:inline-block; max-width:var(--maxw); }
.stamm-bar .who .badge{ vertical-align:middle; }
.stamm-bar .btn{ width:auto; }
.btn--small{ padding:.45em 1em; font-size:.85rem; border-width:1.5px; }

/* Segment-Umschalter (Anmelden/Konto · Spruch/Bild) – einheitlich */
.stamm-tabs, .composer-toggle{
  background:var(--sand-2); border-radius:999px; padding:5px; gap:4px;
  box-shadow:inset 0 1px 3px rgba(60,45,25,.12); border:0; max-width:340px;
}
.composer-toggle{ max-width:300px; margin-bottom:1rem; }
.stamm-tabs button, .composer-toggle button{
  flex:1; border:0; border-radius:999px; padding:.55em .9em; cursor:pointer;
  font-family:var(--font-body); font-weight:700; font-size:.92rem;
  color:var(--ink-soft); background:transparent; transition:background .18s, color .18s, box-shadow .18s;
}
.stamm-tabs button.is-active, .composer-toggle button.is-active{
  background:var(--waldgruen); color:var(--creme-2); box-shadow:0 3px 9px rgba(60,45,25,.22);
}

/* Eingabefelder: ruhig, abgerundet, weicher Innenschatten, Gold-Fokus */
.stamm-form{ gap:.7rem; }
.stamm-form label{ color:var(--waldgruen); font-weight:700; font-size:.88rem; }
.stamm-form input, .stamm-form textarea{
  border:1.5px solid rgba(108,74,43,.25); border-radius:12px; background:#fffdf8;
  box-shadow:inset 0 2px 5px rgba(60,45,25,.05); padding:.75em .95em;
}
.stamm-form input:focus, .stamm-form textarea:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(195,155,72,.25);
}
.stamm-form textarea{ resize:vertical; min-height:84px; }

/* „Auf die Pinnwand“: angenehme Größe + Icon-Optik */
#postForm > .btn{ align-self:flex-start; padding:.7em 1.6em; }

/* Drag&Drop-Zone harmonisieren */
.dropzone{ border-radius:14px; background:#fffdf8; }

/* Wirt-Panel als eigene Karte */
#hostPanel{ background:rgba(255,255,255,.5); border:1px solid rgba(195,155,72,.3);
  border-radius:14px; padding:1rem 1.1rem; }
#hostPanel .board__item{ background:#fff; }

/* Auf schmalen Screens: kleine Buttons NICHT vollbreit (nur der Senden-Button darf) */
@media (max-width:480px){
  .stamm-bar .btn, .stamm-tabs button, .composer-toggle button, #hostPanel .btn{ width:auto; }
  .stamm-bar{ flex-direction:row; align-items:center; }
  #postForm > .btn{ width:100%; align-self:stretch; }
}
