:root{
  /* === snob's coffee — finale Farbpalette (Stand 05.06.2026) ===
     Quelle: Ressourcen/Homepage/Farbpallette_Snobscoffee_HP.png (Coolors)
     Deep Teal #3C685D · Dark Slate Grey #2F4D46 · Brown Bark #6C4128
     Dim Grey #717168 · Deep Walnut #4C3527 */

  /* Markenpalette (Roh) */
  --teal:#3C685D;
  --teal-deep:#2F4D46;
  --bark:#6C4128;
  --stone:#717168;
  --walnut:#4C3527;

  /* Helle Flächen (warmes Creme, harmoniert mit Erdtönen)
     2026-06-10: --bg auf Cream gehoben (vorher #F5EFE6) →
     deutlich mehr Weißraum, weniger „warmes Café"-Beige,
     eleganter / editorialer (Five-Elephant-Ästhetik). Wer
     den alten Sandton braucht (Bordering / Zonen), nutzt
     gezielt --sand. */
  --bg:#FBF7F0;
  --bg-deep:#F0EADE;
  --cream:#FBF7F0;
  --sand:#F5EFE6;

  /* Semantische Aliase (im Stylesheet weiter genutzt) */
  --ink:#4C3527;            /* Primär-Schrift / dunkle Flächen */
  --ink-soft:#6C5A50;       /* Sekundär-Text, abgestimmt auf Walnut */
  --sage:#3C685D;           /* Akzent grün */
  --sage-deep:#2F4D46;      /* Tiefes Grün für Premium-Flächen */
  --caramel:#A56B42;        /* Warmer Akzent, aus Brown Bark abgeleitet */

  --line:rgba(76,53,39,.14);
  --shadow:0 30px 80px -30px rgba(47,77,70,.35);
  --radius:14px;
  --maxw:1240px;
}
*{box-sizing:border-box}
html{color-scheme:light only}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
/* Headlines — editorial, ruhig, mit kräftigem optischen Anker.
   2026-06-10: line-height von 1.08 → 1.0 (Hot-Take von Five Elephant:
   Display-Sizes brauchen keine Atem-Höhe), letter-spacing -0.02em,
   H1 deutlich größer (Schriftverlauf wird zur Sektion). */
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:400;letter-spacing:-0.02em;line-height:1.0;margin:0;color:var(--ink)}
h1{font-size:clamp(48px,7.5vw,96px);font-weight:400}
h2{font-size:clamp(32px,4.5vw,56px);font-weight:400;line-height:1.05}
h3{font-size:clamp(20px,2vw,28px);font-weight:500;line-height:1.15;letter-spacing:-0.01em}
h4{font-size:18px;font-weight:500;line-height:1.2;letter-spacing:-0.005em}
em{font-style:italic;font-weight:400}
p{margin:0 0 1em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
/* Eyebrow — kleines Sektion-Label oben, mit kurzer Akzentlinie.
   2026-06-10: Linie in Caramel (vorher Sage-Deep) → bringt warmen
   Akzent rein und steht besser im Cream-Umfeld. */
.eyebrow{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--caramel)}
.eyebrow--center{justify-content:center}
/* Default-Abstand zwischen Eyebrow und nachfolgender Headline
   (ersetzt früheren Inline-Style margin-top:18px) */
.eyebrow + h2,
.eyebrow + h3{margin-top:20px}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(245,239,230,.92);-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line);box-shadow:0 2px 0 0 var(--teal)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Fraunces',serif;font-size:26px;font-weight:500;letter-spacing:-0.01em;flex-shrink:0}
.brand-logo{height:42px;width:auto;color:var(--ink);display:block}
.brand-logo svg{height:100%;width:auto;display:block}
.nav-links{display:flex;gap:32px;font-size:15px;font-weight:500}
.nav-links a{position:relative;padding:6px 0;color:var(--ink)}
.nav-links a:hover{color:var(--sage-deep)}
.nav-cta{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--cream);padding:11px 20px;border-radius:999px;font-size:14px;font-weight:600;transition:transform .15s, background .2s;white-space:nowrap}
.nav-cta:hover{background:var(--sage-deep);transform:translateY(-1px)}

.burger{display:none;background:transparent;border:1px solid var(--line);width:48px;height:48px;border-radius:14px;cursor:pointer;padding:0;align-items:center;justify-content:center;color:var(--ink);transition:background .15s, border-color .15s}
.burger:hover,.burger:focus-visible{background:var(--cream);border-color:var(--ink);outline:none}
.burger span{display:block;position:relative;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s, opacity .15s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s}
.burger span::before{top:-6px}
.burger span::after{top:6px}
body.menu-open .burger span{background:transparent}
body.menu-open .burger span::before{transform:translateY(6px) rotate(45deg)}
body.menu-open .burger span::after{transform:translateY(-6px) rotate(-45deg)}

.mobile-drawer{position:fixed;inset:0;background:var(--bg);z-index:60;display:none;flex-direction:column;padding:90px 28px 40px;transform:translateY(-100%);transition:transform .35s cubic-bezier(.6,.2,.2,1);overflow-y:auto}
body.menu-open .mobile-drawer{transform:translateY(0)}
.mobile-drawer a{font-family:'Fraunces',serif;font-size:32px;font-weight:400;color:var(--ink);padding:14px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.mobile-drawer a:after{content:"→";color:var(--sage-deep);font-family:'Inter',sans-serif;font-size:22px}
.mobile-drawer .drawer-cta{background:var(--ink);color:var(--cream);border:none;border-radius:14px;padding:18px 22px;justify-content:center;margin-top:30px;font-size:18px}
.mobile-drawer .drawer-cta:after{content:"→";color:var(--caramel)}
.mobile-drawer .drawer-meta{margin-top:auto;padding-top:30px;font-size:13px;color:var(--ink-soft);text-align:center;letter-spacing:.05em}
.mobile-drawer .drawer-meta a{font-family:'Inter',sans-serif;font-size:14px;display:inline;border:none;padding:0;color:var(--ink);font-weight:600;text-decoration:underline}
.mobile-drawer .drawer-meta a:after{display:none}

/* HERO  (Legacy-Klassen .hero / .hero-grid / .hero-tag / .hero-sub /
   .hero-actions / .hero-visual* wurden 2026-06-08 entfernt — das
   aktive Hero ist die .stage / .hero-stage / .hero-card-Implementierung
   weiter unten in dieser Datei.) */

/* News-Slider (Neuheiten-Karte) — Desktop: schlank & editorial, nicht
   übergroß. 2026-06-10 #4: max-width 760, schmalere Bild-Spalte, kleinere
   Typo, weniger Schatten. Sektion soll Hero ergänzen, nicht erschlagen. */
.news-slider{position:relative;margin:0 auto 16px;max-width:760px}
.news-track{position:relative;overflow:hidden;border-radius:16px;background:var(--cream);border:1px solid var(--line);box-shadow:0 4px 16px -10px rgba(43,24,16,.12)}
.news-slide{position:absolute;inset:0;display:flex;align-items:stretch;opacity:0;transform:translateX(20px);transition:opacity .5s ease, transform .5s ease;pointer-events:none}
.news-slide.is-active{position:relative;opacity:1;transform:none;pointer-events:auto}
.news-slide:not(.is-active){position:absolute}
.news-slider .news-track{min-height:200px}
.news-img{flex:0 0 280px;background:var(--walnut) center 28%/cover no-repeat;position:relative}
.news-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 60%,var(--cream))}
.news-body{flex:1;padding:26px 32px 26px 8px;display:flex;flex-direction:column;justify-content:center;gap:9px;min-width:0;position:relative;z-index:1}
.news-badge{align-self:flex-start;background:var(--teal);color:var(--cream);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;padding:5px 11px;border-radius:999px}
.news-title{font-family:'Fraunces',serif;font-size:22px;font-weight:500;line-height:1.18;color:var(--ink);margin:0;letter-spacing:-0.01em}
.news-sub{font-size:14.5px;color:var(--ink-soft);margin:0;line-height:1.45;max-width:38ch}
.news-arrow{position:absolute;right:18px;bottom:18px;background:var(--ink);color:var(--cream);width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:15px;transition:transform .2s, background .2s;z-index:2}
.news-slide:hover .news-arrow{background:var(--sage-deep);transform:translateX(3px)}
.news-dots{display:flex;gap:7px;justify-content:center;margin-top:18px}
.news-dot{width:7px;height:7px;border-radius:50%;background:rgba(76,53,39,.22);border:none;padding:0;cursor:pointer;transition:background .2s, width .2s}
.news-dot.is-active{background:var(--ink);width:22px;border-radius:999px}

/* Buttons — Bibliothek (Design-System §3) */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:999px;font-weight:600;font-size:15px;cursor:pointer;border:none;transition:transform .15s, background .2s, color .2s}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover{background:var(--sage-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}

/* News-Sektion (schlanke Eigenständige Sektion direkt unter dem Hero,
   ersetzt seit 2026-06-08 die frühere zweispaltige .intro mit Trust-Row)
   2026-06-10 #4: weniger top-Padding, kein 0 unten — sanfter Übergang
   zur Pfade-Sektion, weniger leere Zwischen-Flächen. */
.news{padding:72px 0 32px;background:var(--cream)}
.news-head{margin-bottom:36px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}
.news-head h2{margin-top:0;font-size:clamp(28px,3.6vw,42px)}

/* PATHS — symmetrisches 3er-Grid (Iteration 2026-06-10 #4).
   Vorher: asymmetrisch (Pfad 1 full-height links, Pfade 2+3 stacked
   rechts). Wirkte unausgewogen und zerfasert. Jetzt drei
   gleichgewichtige Karten — wie editorial Reading-Lists. Anker
   #kurse/#events/#b2b sitzen auf den <a class="path"> selbst,
   nicht mehr auf der entfernten Offer-Slider-Sektion. */
.paths{padding:96px 0;background:var(--sand);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.paths-head{display:flex;align-items:end;justify-content:space-between;gap:30px;margin-bottom:64px;flex-wrap:wrap}
.paths-head h2{max-width:540px}
.paths-head p{max-width:380px;color:var(--ink-soft);margin:0;font-size:16px;line-height:1.55}
.path-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.path{position:relative;background:var(--cream);border-radius:18px;overflow:hidden;transition:transform .25s ease, box-shadow .3s ease;border:1px solid var(--line);display:flex;flex-direction:column;scroll-margin-top:96px}
.path:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(76,53,39,.22)}
.path-img{aspect-ratio:4/3;background:var(--walnut) center/cover no-repeat;position:relative}
.path-1 .path-img{background-image:linear-gradient(180deg,transparent 42%,rgba(47,77,70,.78)),url("img/snobs-kurse.jpeg")}
.path-2 .path-img{background-image:linear-gradient(180deg,transparent 42%,rgba(76,53,39,.80)),url("img/snobs-events-barista.jpeg")}
.path-3 .path-img{background-image:linear-gradient(180deg,transparent 42%,rgba(108,65,40,.78)),url("img/snobs-b2b-event.jpeg")}
.path-num{position:absolute;top:18px;left:22px;color:var(--cream);font-family:'Fraunces',serif;font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.path-title{position:absolute;left:22px;bottom:18px;right:22px;color:var(--cream);font-family:'Fraunces',serif;font-size:clamp(22px,2.2vw,28px);font-weight:500;line-height:1.18;letter-spacing:-0.01em}
.path-body{padding:26px 28px 30px;background:var(--cream);display:flex;flex-direction:column;flex:1;gap:14px}
.path-body > p{font-size:14.5px;color:var(--ink-soft);margin:0;line-height:1.5}
.path-meta{list-style:none;margin:0;padding:14px 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
.path-meta li{font-size:13px;line-height:1.4;color:var(--ink-soft);display:flex;flex-wrap:wrap;gap:6px}
.path-meta strong{color:var(--ink);font-weight:600}
.path-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:12.5px;color:var(--ink);border-bottom:1.5px solid var(--ink);padding-bottom:2px;transition:gap .2s, color .2s, border-color .2s;letter-spacing:.06em;text-transform:uppercase;align-self:flex-start;margin-top:auto}
.path:hover .path-link{gap:14px;color:var(--sage-deep);border-color:var(--sage-deep)}

/* PROMISES  (entfernt 2026-06-08 — dunkler Strip mit Icon-Quadrat war
   inhaltliche Wiederholung von .refs/.about. Klassen .promises / .promise
   /.promise-grid / .promise-ico komplett raus.) */

/* ABOUT */
.about{padding:96px 0}
.about-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:80px;align-items:center}
.about-img{aspect-ratio:4/5;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);background:var(--walnut) center/cover no-repeat;background-image:url("img/julien-portrait.jpeg");background-position:center top}
.about h2{margin:18px 0 26px}
.about h2 em{font-style:italic;color:var(--sage-deep);font-weight:400}
.about-text{font-size:17px;color:var(--ink-soft);max-width:520px}
.about-text p{margin-bottom:1.1em}
.about-sig{margin-top:28px;font-family:'Fraunces',serif;font-style:italic;font-size:22px}
.about-sig small{display:block;font-family:'Inter',sans-serif;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);font-style:normal;margin-top:6px}

/* OFFER  (entfernt 2026-06-10 — horizontaler Slider „Konkret. Buchbar.
   Sofort." mit 5 Slides war redundant zu News + Pfaden + /kurse. Klassen
   .offer / .offer-head-row / .offer-head / .offer-nav* / .offer-rail /
   .offer-track / .offer-slide* / .offer-progress* komplett raus.
   IDs #kurse/#events/#b2b sitzen jetzt auf den Pfade-Cards.) */
.refs{padding:96px 0;background:var(--sand);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.refs-head{text-align:center;margin-bottom:48px}
.refs-head p{color:var(--ink-soft);max-width:540px;margin:18px auto 0}
.refs-slider{position:relative;max-width:760px;margin:0 auto;touch-action:pan-y}
/* Grid-Stack: alle Cards in derselben Cell → Container nimmt Höhe der höchsten */
.refs-track{display:grid;grid-template-columns:1fr;align-items:stretch}
.ref-card{
  grid-area:1/1;
  background:var(--cream);border-radius:var(--radius);
  padding:40px 44px;border:1px solid var(--line);
  display:flex;flex-direction:column;gap:22px;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .4s ease, transform .4s ease, visibility 0s linear .4s;
}
.ref-card.is-active{opacity:1;visibility:visible;transform:none;transition:opacity .45s ease, transform .45s ease, visibility 0s linear 0s}
.ref-stars{color:var(--caramel);letter-spacing:3px;font-size:15px}
.ref-quote{font-family:'Fraunces',serif;font-size:22px;line-height:1.45;color:var(--ink);font-weight:400;flex:1;margin:0;quotes:none}
.ref-author{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--line)}
.ref-avatar{width:44px;height:44px;border-radius:50%;background:var(--sage);color:var(--cream);display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:500;flex-shrink:0}
.ref-name{font-weight:600;font-size:14px}
.ref-role{font-size:12px;color:var(--ink-soft)}
/* Dots */
.refs-dots{display:flex;justify-content:center;gap:10px;margin-top:28px}
.refs-dot{
  width:32px;height:32px;border:0;background:transparent;cursor:pointer;
  display:grid;place-items:center;padding:0;border-radius:50%;
  -webkit-tap-highlight-color:transparent;
}
.refs-dot::after{
  content:"";display:block;width:8px;height:8px;border-radius:50%;
  background:rgba(76,53,39,.22);transition:background .2s, transform .2s;
}
.refs-dot:hover::after{background:rgba(76,53,39,.45)}
.refs-dot.is-active::after{background:var(--sage-deep);transform:scale(1.35)}
.refs-dot:focus-visible{outline:2px solid var(--sage-deep);outline-offset:2px}

/* TEASER / TCard  (entfernt 2026-06-08 — Shop-Sektion war an 4 nicht
   existierende Produktbilder geknüpft. Wird zur Phase 6 mit echten
   Assets neu aufgebaut. Bis dahin keine .teaser-/.tcard-Klassen mehr
   in der Bibliothek.) */

/* FAQ — zweistufig: Master-Details + Item-Accordion */
.faq{padding:20px 0 64px;background:var(--cream);border-top:none}
.faq-master{
  max-width:100%;margin:0 auto;
  background:var(--bg);border:1px solid var(--line);border-radius:18px;
  overflow:hidden;
}
.faq-summary{
  list-style:none;cursor:pointer;
  display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;
  gap:18px;padding:22px 26px;
  -webkit-tap-highlight-color:transparent;
  transition:background .2s;
}
.faq-summary::-webkit-details-marker{display:none}
.faq-summary:hover{background:rgba(60,104,93,.04)}
.faq-summary:focus-visible{outline:2px solid var(--sage-deep);outline-offset:-2px}
.faq-summary-eyebrow{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sage-deep);font-weight:600;
  padding:5px 10px;border:1px solid rgba(60,104,93,.25);border-radius:999px;
  background:rgba(60,104,93,.06);
}
.faq-summary-title{
  font-family:'Fraunces',serif;font-weight:500;font-size:22px;
  color:var(--ink);line-height:1.2;
}
.faq-summary-meta{
  font-size:13px;color:var(--ink-soft);font-weight:500;
}
.faq-summary-icon{
  width:32px;height:32px;display:grid;place-items:center;
  background:var(--sage-deep);color:var(--cream);
  border-radius:50%;font-size:22px;line-height:1;
  transition:transform .25s ease;
}
.faq-master[open] .faq-summary-icon{transform:rotate(45deg)}
.faq-body{
  padding:0 26px 22px;
  border-top:1px solid var(--line);
}
.faq-intro{
  color:var(--ink-soft);font-size:14.5px;line-height:1.5;
  margin:20px 0 8px;
}
.faq-list{margin:0}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item:last-child{border-bottom:0}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  width:100%;background:transparent;border:0;cursor:pointer;
  padding:18px 0;text-align:left;color:var(--ink);
  font-family:'Fraunces',serif;font-size:18px;font-weight:500;line-height:1.3;
  transition:color .2s;
  -webkit-tap-highlight-color:transparent;
}
.faq-q:hover{color:var(--sage-deep)}
.faq-q::after{
  content:"+";font-size:20px;line-height:1;color:var(--sage-deep);
  flex-shrink:0;width:28px;height:28px;display:grid;place-items:center;
  border-radius:50%;background:rgba(60,104,93,.08);
  transition:transform .25s ease, background .25s ease, color .25s ease;
}
.faq-item.open .faq-q::after{transform:rotate(45deg);background:var(--sage-deep);color:var(--cream)}
.faq-q:focus-visible{outline:2px solid var(--sage-deep);outline-offset:4px;border-radius:4px}
.faq-a{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .3s ease;
}
.faq-a > div{
  overflow:hidden;color:var(--ink-soft);font-size:15.5px;line-height:1.6;
  min-height:0;
}
.faq-item.open .faq-a{grid-template-rows:1fr}
.faq-item.open .faq-a > div{padding:0 0 18px}

/* ===== CONTACT — Premium zweispaltig: Dark Info-Panel + Light Form-Card ===== */
.contact{padding:128px 0;background:var(--cream);border-top:1px solid var(--line)}
.contact-card{
  position:relative;overflow:hidden;
  background:var(--ink);
  color:var(--cream);
  border-radius:28px;
  display:grid;grid-template-columns:1fr 1.15fr;gap:0;
  align-items:stretch;
  box-shadow:0 30px 80px -30px rgba(15,28,25,.55), 0 0 0 1px rgba(76,53,39,.08);
}
/* Atmosphärischer Hintergrund auf der Dark-Seite */
.contact-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:46.5%;
  background:
    radial-gradient(circle at 30% 20%, rgba(165,107,66,.22), transparent 55%),
    radial-gradient(circle at 80% 90%, rgba(60,104,93,.32), transparent 60%),
    linear-gradient(160deg,var(--sage-deep) 0%, var(--ink) 100%);
  pointer-events:none;
}

/* ----- linke Spalte: Info ----- */
.contact-info{position:relative;z-index:1;padding:64px 52px;display:flex;flex-direction:column;gap:0}
.contact-info .eyebrow{color:var(--caramel);margin-bottom:18px}
.contact-info .eyebrow::before{background:var(--caramel)}
.contact-info h2{color:var(--cream);margin:0 0 22px;font-size:clamp(32px,3.4vw,46px);line-height:1.08}
.contact-lead{color:rgba(251,247,240,.75);max-width:380px;margin:0 0 40px;font-size:16px;line-height:1.65}

.contact-channels{list-style:none;padding:0;margin:0 0 36px;display:flex;flex-direction:column;gap:14px}
.contact-channels a{
  display:flex;align-items:center;gap:18px;
  padding:18px 22px;
  background:rgba(251,247,240,.06);
  border:1px solid rgba(251,247,240,.12);
  border-radius:16px;
  color:var(--cream);text-decoration:none;
  transition:background .25s, border-color .25s, transform .2s, box-shadow .25s;
}
.contact-channels a:hover{background:rgba(251,247,240,.11);border-color:rgba(60,104,93,.6);transform:translateY(-2px);box-shadow:0 8px 24px -8px rgba(0,0,0,.3)}
.ch-ico{width:48px;height:48px;border-radius:14px;background:rgba(60,104,93,.35);color:var(--cream);display:grid;place-items:center;flex-shrink:0;transition:background .2s}
.contact-channels a:hover .ch-ico{background:var(--teal)}
.ch-ico svg{width:22px;height:22px}
.ch-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.ch-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(251,247,240,.55);font-weight:500}
.ch-text strong{font-weight:500;font-size:15px;color:var(--cream);font-family:'Fraunces',Georgia,serif;letter-spacing:.005em}

.contact-hours{
  margin-top:auto;
  padding:20px 22px;
  background:rgba(251,247,240,.05);
  border-left:3px solid var(--teal);
  border-radius:0 14px 14px 0;
  font-size:14px;color:rgba(251,247,240,.82);line-height:1.55;
}
.contact-hours .ch-label{display:block;margin-bottom:8px;color:rgba(251,247,240,.55);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500}

/* ----- rechte Spalte: Form ----- */
.contact-form{
  position:relative;z-index:1;
  background:var(--cream);
  color:var(--ink);
  padding:56px 56px 48px;
  display:flex;flex-direction:column;
}
.form-head{margin-bottom:28px}
.form-head h3{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:26px;line-height:1.15;margin:0 0 6px;color:var(--ink)}
.form-head p{margin:0;color:var(--ink-soft);font-size:14px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 18px}
.field{display:flex;flex-direction:column;gap:7px}
.field-full{grid-column:1 / -1}
.field-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.field-label em{color:var(--caramel);font-style:normal;font-weight:700}

.field input[type=text],
.field input[type=email],
.field textarea,
.field select{
  font:inherit;font-size:15px;color:var(--ink);
  background:#fff;
  border:1px solid rgba(76,53,39,.18);
  border-radius:10px;
  padding:13px 15px;
  width:100%;box-sizing:border-box;
  transition:border-color .15s, box-shadow .15s, background .15s;
  -webkit-appearance:none;appearance:none;
}
.field textarea{resize:vertical;min-height:120px;font-family:inherit}
.field input::placeholder,.field textarea::placeholder{color:rgba(76,53,39,.4)}

.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:none;
  border-color:var(--sage);
  box-shadow:0 0 0 3px rgba(60,104,93,.18);
}
.field input:invalid:not(:placeholder-shown),
.field textarea:invalid:not(:placeholder-shown){border-color:#b94a3b}
.field input:invalid:not(:placeholder-shown):focus,
.field textarea:invalid:not(:placeholder-shown):focus{box-shadow:0 0 0 3px rgba(185,74,59,.18)}

/* Custom Select-Caret */
.select-wrap{position:relative}
.select-wrap::after{
  content:"";position:absolute;right:16px;top:50%;
  width:9px;height:9px;border-right:1.6px solid var(--ink-soft);border-bottom:1.6px solid var(--ink-soft);
  transform:translateY(-70%) rotate(45deg);pointer-events:none;
}
.field select{padding-right:38px;cursor:pointer}

/* Checkbox — DSGVO */
.field-check{flex-direction:row;align-items:flex-start;gap:11px}
.field-check input[type=checkbox]{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;min-width:18px;margin-top:2px;
  border:1.5px solid rgba(76,53,39,.32);border-radius:5px;
  background:#fff;cursor:pointer;
  display:grid;place-items:center;
  transition:border-color .15s, background .15s;
}
.field-check input[type=checkbox]:checked{background:var(--sage);border-color:var(--sage)}
.field-check input[type=checkbox]:checked::after{
  content:"";width:5px;height:9px;border:solid var(--cream);border-width:0 2px 2px 0;transform:rotate(45deg) translate(-1px,-1px);
}
.field-check span{font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.field-check a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}

/* Honeypot */
.hp-field{position:absolute !important;left:-9999px;width:1px;height:1px;opacity:0}

/* Termin-Felder (klappen ein/aus je nach Anliegen) */
.termin-fields[hidden]{display:none !important}
.termin-fields{
  background:rgba(60,104,93,.05);
  border:1px solid rgba(60,104,93,.18);
  border-radius:12px;
  padding:18px 18px 16px;
  animation:slideDown .25s ease-out;
}
.termin-grid{
  display:grid;grid-template-columns:1.2fr 1.2fr .8fr;gap:14px;
}
.termin-grid input[type=date],
.termin-grid input[type=number]{
  font:inherit;font-size:15px;color:var(--ink);
  background:#fff;border:1px solid rgba(76,53,39,.18);border-radius:10px;
  padding:13px 15px;width:100%;box-sizing:border-box;
  transition:border-color .15s, box-shadow .15s;
  -webkit-appearance:none;appearance:none;
}
.termin-grid input[type=date]:focus,
.termin-grid input[type=number]:focus{
  outline:none;border-color:var(--sage);box-shadow:0 0 0 3px rgba(60,104,93,.18);
}
.termin-hint{
  margin:12px 0 0;font-size:12.5px;color:var(--ink-soft);line-height:1.5;
  display:flex;align-items:flex-start;gap:8px;
}
.termin-hint::before{
  content:"✦";color:var(--sage);font-size:13px;flex-shrink:0;line-height:1.3;
}
@keyframes slideDown{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}

/* Footer der Form */
.form-foot{margin-top:24px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.form-note{margin:0;font-size:12.5px;color:var(--ink-soft)}
.form-note em{color:var(--caramel);font-style:normal;font-weight:700}

.form-submit{
  position:relative;
  background:var(--ink);color:var(--cream);
  border:none;cursor:pointer;
  padding:15px 28px;border-radius:999px;
  font-weight:600;font-size:15px;letter-spacing:.01em;
  display:inline-flex;align-items:center;gap:10px;
  transition:background .2s, transform .12s, box-shadow .2s;
  box-shadow:0 8px 20px -8px rgba(76,53,39,.6);
}
.form-submit:hover{background:var(--sage-deep);transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(47,77,70,.55)}
.form-submit:active{transform:translateY(0)}
.form-submit:disabled{opacity:.7;cursor:wait}
.btn-spinner{
  width:14px;height:14px;border-radius:50%;
  border:2px solid rgba(251,247,240,.25);border-top-color:var(--cream);
  animation:spin .7s linear infinite;display:none;
}
.form-submit.is-loading .btn-spinner{display:inline-block}
.form-submit.is-loading .btn-label{opacity:.7}
@keyframes spin{to{transform:rotate(360deg)}}

/* Success / Error */
.form-success[hidden],
.form-error[hidden]{display:none !important}
.form-success{
  position:absolute;inset:0;
  background:var(--cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:40px;gap:14px;
  border-radius:0;
  animation:fadeUp .35s ease-out both;
}
.success-icon{width:64px;height:64px;border-radius:50%;background:var(--sage);color:var(--cream);display:grid;place-items:center;margin-bottom:6px}
.success-icon svg{width:32px;height:32px}
.form-success h4{font-family:'Fraunces',serif;font-weight:500;font-size:24px;margin:0;color:var(--ink)}
.form-success p{margin:0;color:var(--ink-soft);max-width:340px}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.form-error{
  margin-top:18px;padding:14px 16px;border-radius:10px;
  background:rgba(185,74,59,.08);border:1px solid rgba(185,74,59,.25);
  color:#7a2f24;font-size:14px;line-height:1.5;
}
.form-error a{color:#7a2f24;font-weight:600;text-decoration:underline}
.form-error strong{display:block;margin-bottom:2px}

/* ===================== LEGAL PAGES (Impressum / Datenschutz) ===================== */
.legal-page{background:var(--bg);color:var(--ink)}
.legal-nav{padding:22px 0;border-bottom:1px solid var(--line);background:var(--cream)}
.legal-nav .container{display:flex;align-items:center;justify-content:space-between;gap:24px}
.legal-back img{height:42px;width:auto;display:block}
.legal-back-link{font-size:14px;color:var(--ink-soft);text-decoration:none;transition:color .15s}
.legal-back-link:hover{color:var(--caramel)}

.legal{padding:64px 0 96px;background:var(--bg)}
.legal-inner{max-width:760px;margin:0 auto}
.legal-head{margin-bottom:50px;padding-bottom:32px;border-bottom:1px solid var(--line)}
.legal-head h1{
  font-family:'Fraunces',Georgia,serif;font-weight:500;
  font-size:clamp(36px,5vw,58px);line-height:1.05;letter-spacing:-0.015em;
  color:var(--ink);margin:14px 0 14px;
}
.legal-lead{font-size:17px;color:var(--ink-soft);max-width:580px;margin:0;line-height:1.5}

.legal-toc{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:14px;
  padding:24px 28px;
  margin-bottom:50px;
}
.legal-toc strong{
  display:block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;margin-bottom:14px;
}
.legal-toc ol{margin:0;padding-left:22px;color:var(--ink);font-size:15px;line-height:1.9}
.legal-toc a{color:var(--ink);text-decoration:none;transition:color .15s;border-bottom:1px solid transparent}
.legal-toc a:hover{color:var(--caramel);border-bottom-color:var(--caramel)}

.legal-block{margin-bottom:42px}
.legal-block h2{
  font-family:'Fraunces',Georgia,serif;font-weight:500;
  font-size:24px;line-height:1.2;color:var(--ink);
  margin:0 0 14px;padding-top:8px;
  scroll-margin-top:24px;
}
.legal-block p,
.legal-block li{font-size:15.5px;line-height:1.65;color:var(--ink-soft);margin:0 0 12px}
.legal-block ul,
.legal-block ol{padding-left:22px;margin:0 0 16px}
.legal-block li{margin-bottom:6px}
.legal-block a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(76,53,39,.25);transition:text-decoration-color .15s}
.legal-block a:hover{text-decoration-color:var(--caramel)}
.legal-block strong{color:var(--ink);font-weight:600}
.legal-block code{
  background:rgba(76,53,39,.06);padding:2px 6px;border-radius:4px;
  font-family:Consolas,Monaco,monospace;font-size:13.5px;color:var(--ink);
}
.legal-note{
  background:rgba(165,107,66,.08);border:1px solid rgba(165,107,66,.25);
  padding:14px 16px;border-radius:10px;font-size:14px;color:var(--ink-soft);
  margin-top:14px !important;
}

.legal-meta{
  margin-top:60px !important;padding-top:24px;
  border-top:1px solid var(--line);
  font-size:13px;color:var(--ink-soft);text-align:right;font-style:italic;
}

.legal-foot{padding:30px 0;background:var(--cream);border-top:1px solid var(--line);font-size:14px;color:var(--ink-soft)}
.legal-foot .container{display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap}
.legal-foot a{color:var(--ink-soft);text-decoration:none;transition:color .15s}
.legal-foot a:hover{color:var(--caramel)}
.legal-foot span{color:var(--line);opacity:.6}

@media (max-width:880px){
  .legal{padding:40px 0 56px}
  .legal-head{margin-bottom:32px;padding-bottom:24px}
  .legal-toc{padding:18px 22px;margin-bottom:36px}
  .legal-block{margin-bottom:32px}
  .legal-block h2{font-size:20px}
  .legal-block p,.legal-block li{font-size:15px}
  .legal-foot .container{flex-direction:column;gap:8px}
  .legal-foot span{display:none}
}

/* FOOTER
   2026-06-10: foot-statement entfernt (Inhalt verdoppelte sich mit
   der Kontakt-Sektion direkt drüber). Footer ist jetzt rein
   funktional: Logo · Channels · Rechtslinks. Mehr Weißraum oben. */
footer{background:var(--sage-deep);color:var(--cream);position:relative;overflow:visible;padding-top:16px}
footer::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 0%, rgba(60,104,93,.25), transparent 55%),radial-gradient(circle at 0% 100%, rgba(31,56,50,.4), transparent 55%);pointer-events:none}
.foot-meta{position:relative;border-top:1px solid rgba(251,247,240,.15);padding:16px 0;display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center}
.foot-logo{display:inline-flex;align-items:center;gap:0;position:relative}
.foot-logo img{height:120px;width:auto;display:block;margin-top:-30px;margin-bottom:-30px}
.foot-mark{
  display:inline-flex;align-items:center;
  height:72px;margin-left:10px;
  color:var(--cream);
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.25));
  animation:pinkyWave 1.8s cubic-bezier(.34,1.56,.64,1) .6s both;
  transform-origin:90% 100%;
}
.foot-mark img{height:100%;width:auto;max-width:none;object-fit:contain}
.foot-channels{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.foot-channels a{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border:1px solid rgba(251,247,240,.18);border-radius:999px;font-size:13px;font-weight:500;color:rgba(251,247,240,.85);transition:border-color .2s, color .2s, background .2s}
.foot-channels a svg{width:16px;height:16px;flex-shrink:0;opacity:.9}
.foot-channels a:hover{border-color:var(--caramel);color:var(--cream);background:rgba(165,107,66,.18)}
.foot-bottom{position:relative;border-top:1px solid rgba(251,247,240,.1);padding:12px 0 18px;display:flex;justify-content:space-between;gap:14px 26px;flex-wrap:wrap;font-size:12px;color:rgba(251,247,240,.5);letter-spacing:.04em}
.foot-bottom-links{display:flex;flex-wrap:wrap;gap:6px 22px}
.foot-bottom-links a{color:rgba(251,247,240,.55);transition:color .2s}
.foot-bottom-links a:hover{color:var(--caramel)}

/* Header — hide on scroll down, show on scroll up */
.nav-stage{
  transition:transform .35s ease, opacity .3s ease;
}
.nav-stage.nav-hidden{
  transform:translateY(-100%);
  opacity:0;
  pointer-events:none;
}

/* Galerie — slide-in Animationen */
.gal-slide-left{
  opacity:0;
  transform:translateX(-40px);
  transition:opacity .6s ease, transform .6s ease;
}
.gal-slide-right{
  opacity:0;
  transform:translateX(40px);
  transition:opacity .6s ease, transform .6s ease;
}
.gal-slide-left.gal-visible,
.gal-slide-right.gal-visible{
  opacity:1;
  transform:translateX(0);
}
/* Staggered delay für kaskadierten Effekt */
.gal:nth-child(2) { transition-delay:.08s }
.gal:nth-child(3) { transition-delay:.16s }
.gal:nth-child(4) { transition-delay:.24s }
.gal:nth-child(5) { transition-delay:.32s }
.gal:nth-child(6) { transition-delay:.4s }
.gal:nth-child(7) { transition-delay:.48s }
@media (prefers-reduced-motion: reduce){
  .gal-slide-left,.gal-slide-right{opacity:1;transform:none;transition:none}
}


/* ===================================================================== */
/*  STAGE — dunkelgrüne Botanik-Bühne für Nav + Hero (Scott-Style v4)    */
/* ===================================================================== */
/* 2026-06-10 #5: Stage → sauber, ein Ton, kein Radial-Stack mehr.
   Five-Elephant-Ästhetik: ruhig, flächig, kein visuelles Rauschen. */
.stage{
  position:relative;
  background:var(--sage-deep);
  color:var(--cream);
  overflow:visible;
  isolation:isolate;
}
/* Blätter-Textur entfernt (2026-06-10 #5) — visuelles Rauschen,
   wirkt dekorativ-generisch. Klasse bleibt im HTML als leerer Hook
   für spätere subtile Texturen. */
.stage-leaves{
  display:none;
}

/* Nav innerhalb Stage: transparent, helle Typo */
.nav-stage{
  position:relative;z-index:5;
  background:transparent;
  -webkit-backdrop-filter:none;backdrop-filter:none;
  border-bottom:none;
  box-shadow:none;
}
.nav-stage .nav-inner{
  /* Logo links, Pinky-Cup daneben, Nav-Links rechts. */
  display:flex;
  justify-content:flex-start;
  align-items:center;
  height:auto;
  min-height:60px;
  padding:6px 0 4px;
  position:relative;
}
.nav-side{display:flex;align-items:center;gap:24px}
.nav-side-right{justify-content:flex-end;justify-self:end}
.nav-meta-link{
  display:inline-flex;align-items:center;gap:8px;
  color:rgba(251,247,240,.85);
  font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  transition:color .2s;
}
.nav-meta-link:hover{color:var(--caramel)}
.nav-meta-ico{color:var(--caramel);font-size:14px}
.nav-meta-phone{font-variant-numeric:tabular-nums}

/* Brand-Lockup: Logo links, Pinky-Cup rechts daneben */
.brand-start{position:relative;display:inline-flex;align-items:center;gap:0;line-height:0}
.brand-center{justify-self:center} /* Legacy-Fallback */
.nav-side-right{
  margin-left:auto;
  display:flex;align-items:center;gap:24px;
}
.brand-logo-xl{
  height:220px;width:auto;display:block;
  filter:drop-shadow(0 8px 24px rgba(0,0,0,.3));
  margin-top:-60px;
  margin-bottom:-60px;
}
@media (min-width:1280px){
  .brand-logo-xl{height:240px}
}
@media (min-width:1600px){
  .brand-logo-xl{height:260px}
}

/* Rechte Nav-Links in der Stage (hell, dezent) */
.nav-links-stage{display:flex;gap:28px}
.nav-links-stage a{
  color:rgba(251,247,240,.88);font-size:13px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
}
.nav-links-stage a:hover{color:var(--caramel)}

/* Burger hell */
.burger-stage{
  background:transparent;border:1px solid rgba(251,247,240,.25);
  color:var(--cream);width:46px;height:46px;border-radius:12px;
  display:none;
}
.burger-stage span,
.burger-stage span::before,
.burger-stage span::after{background:var(--cream)}
.burger-stage:hover{background:rgba(251,247,240,.08);border-color:var(--caramel)}

/* Hero — full-bleed (Five-Elephant-Stil, Iteration 2026-06-10 #5).
   Kein border-radius, kein box-shadow, kein Padding um die Card.
   Video/Bild füllt die gesamte Stage-Breite aus. Overlay-Text
   ist per max()/clamp()-Padding auf Container-Breite eingerückt. */
.hero-stage{padding:0;position:relative;z-index:2}
.hero-stage .container{max-width:none;padding:0}
.hero-card{
  position:relative;
  border-radius:0;
  overflow:hidden;
  aspect-ratio:2.35/1;
  min-height:520px;
  background:#1a0f08 center/cover no-repeat;
  background-image:
    linear-gradient(180deg, rgba(31,56,50,.08) 0%, rgba(15,28,25,.50) 100%),
    url("img/snobs-hero-coffee-bar.jpeg");
}
.hero-card-media{position:absolute;inset:0}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
  animation:heroFadeIn .8s ease-out both;
}
@media (prefers-reduced-motion: reduce){
  .hero-video{display:none}
}
@keyframes heroFadeIn{from{opacity:0}to{opacity:1}}
.hero-card-overlay{
  position:absolute;left:0;right:0;bottom:0;
  padding:48px max(32px, calc((100vw - var(--maxw))/2 + 24px)) 56px;
  display:flex;flex-direction:column;align-items:flex-start;gap:22px;
  color:var(--cream);
  background:linear-gradient(180deg, transparent 0%, rgba(15,28,25,.38) 60%, rgba(15,28,25,.68) 100%);
}
.hero-claim{
  font-family:'Fraunces',Georgia,serif;
  font-size:clamp(40px,5.2vw,72px);
  font-weight:400;line-height:1.02;letter-spacing:-0.015em;
  color:var(--cream);margin:0;max-width:18ch;
}
.hero-claim em{font-style:italic;color:var(--caramel);font-weight:400}
.hero-card-actions{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.btn-light{
  background:var(--cream);color:var(--walnut);
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;border-radius:999px;
  font-weight:600;font-size:14px;letter-spacing:.06em;text-transform:uppercase;
  border:none;transition:transform .15s, background .2s, color .2s;
}
.btn-light:hover{background:var(--caramel);color:var(--cream);transform:translateY(-2px)}
.hero-card-link{
  color:var(--cream);font-size:13px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  border-bottom:1px solid rgba(251,247,240,.5);padding-bottom:4px;
  transition:color .2s, border-color .2s;
}
.hero-card-link:hover{color:var(--caramel);border-color:var(--caramel)}

/* ===================================================================== */
/*  GALERIE — Eindrücke aus echten Events (Masonry-light)                */
/* ===================================================================== */
/* ===================================================================== */
/* Galerie — kompakt, 3 Spalten, schnelle Übersicht.
   2026-06-10 #6: zurück auf 3 cols, flachere aspect-ratios (4/3),
   weniger Padding (96 statt 128). Nimmt jetzt ~40% weniger Höhe ein. */
.gallery{padding:96px 0;background:var(--cream);border-top:1px solid var(--line)}
.gallery-head{display:flex;align-items:end;justify-content:space-between;gap:30px;margin-bottom:28px;flex-wrap:wrap}
.gallery-title{margin-top:14px;max-width:540px;font-size:clamp(26px,3vw,36px)}
.gallery-sub{max-width:380px;color:var(--ink-soft);margin:0;font-size:14px}
.gallery-grid{
  columns:3;
  column-gap:12px;
}
.gal{
  break-inside:avoid;display:block;
  margin:0 0 12px;
  position:relative;overflow:hidden;border-radius:8px;
  background:var(--walnut);box-shadow:none;
  aspect-ratio:4/3;
}
.gal-tall{aspect-ratio:3/3.8}
.gal-wide{aspect-ratio:16/9}
.gal-img{
  position:absolute;inset:0;
  background-position:center 30%;background-size:cover;background-repeat:no-repeat;
  transition:transform .8s cubic-bezier(.2,.6,.2,1);
}
.gal:hover .gal-img{transform:scale(1.05)}
.gal figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:12px 14px 11px;
  color:var(--cream);font-size:11.5px;font-weight:500;letter-spacing:.01em;
  background:linear-gradient(180deg,transparent 0%,rgba(15,28,25,.78) 100%);
  opacity:0;transform:translateY(4px);
  transition:opacity .25s ease, transform .25s ease;
}
.gal:hover figcaption{opacity:1;transform:none}

/* INTRO  (entfernt 2026-06-08 — doppelter Hero-Claim direkt unterhalb der
   .stage hat das große Hero verwässert. News-Slider wurde in eigene
   schlanke .news-Sektion verschoben.) */

/* TABLET — Logo + Nav-Links komprimieren auf mittleren Viewports */
@media (max-width:1199px) and (min-width:881px){
  .brand-logo-xl{height:160px}
  .brand-mark{height:36px;margin-left:8px}
  .nav-stage .nav-inner{min-height:70px;padding:8px 0}
  .nav-links-stage{gap:18px}
  .nav-links-stage a{font-size:12px;letter-spacing:.1em}
  .nav-cta-stage{display:none}
}

/* MOBILE */
@media (max-width:880px){
  .container{padding:0 20px}

  /* Stage-Hintergrund auf Mobile — leaves bereits display:none */

  /* Stage-Nav mobil: Logo links, Burger rechts */
  .nav-stage .nav-inner{display:flex;flex-direction:row;justify-content:space-between;align-items:center;min-height:60px;padding:6px 0;gap:8px}
  .brand-start{position:relative}
  .brand-mark{height:44px;margin-left:6px}
  .nav-side-right{margin-left:auto}
  .nav-side-right .nav-meta-link{display:none}
  .nav-links-stage{display:none}
  .brand-logo-xl{height:100px;margin-top:-20px;margin-bottom:-20px}
  .burger-stage{display:inline-flex;width:44px;height:44px}

  /* Hero-Card mobil — full-bleed Portrait, kompakter. */
  .hero-stage{padding:0}
  .hero-card{aspect-ratio:3/4;min-height:420px}
  .hero-card-overlay{padding:20px 20px 28px;gap:12px;background:linear-gradient(180deg, transparent 0%, rgba(15,28,25,.50) 45%, rgba(15,28,25,.80) 100%)}
  .hero-claim{font-size:28px;line-height:1.05;max-width:none}
  .hero-card-actions{gap:10px;width:100%}
  .btn-light{padding:12px 20px;font-size:13px;min-height:44px;justify-content:center}
  .hero-card-link{font-size:12px}

  /* News-Sektion mobil */
  .news{padding:32px 0 16px}
  .news-head{margin-bottom:20px}

  /* Galerie mobil — 2 Spalten kompakt, aspect 1/1 (quadratisch). */
  .gallery{padding:40px 0}
  .gallery-head{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:16px}
  .gallery-grid{columns:2;column-gap:8px}
  .gal{margin-bottom:8px;aspect-ratio:1/1}
  .gal-tall,.gal-wide{aspect-ratio:1/1}
  .gal figcaption{opacity:1;transform:none;font-size:10px;padding:7px 8px 6px}

  /* Bestehende klassische Nav (falls noch genutzt) */
  .nav-inner{height:64px;gap:10px}
  .brand-logo{height:34px}
  .nav-links{display:none}
  .nav-cta{display:none}
  .burger{display:inline-flex}
  .mobile-drawer{display:flex}

  /* Buttons mobil */
  .btn{padding:14px 22px;font-size:14px;min-height:48px;justify-content:center}
  .btn-primary,.btn-ghost{width:100%}

  /* News-Slider mobil — kompakte Karte zurück (Desktop ist groß/zentriert). */
  .news-slider{max-width:100%}
  .news-slider .news-track{min-height:148px}
  .news-img{flex:0 0 120px}
  .news-body{padding:16px 18px 16px 0;gap:6px}
  .news-title{font-size:16px;line-height:1.2}
  .news-sub{font-size:13px;max-width:none}
  .news-badge{font-size:10px;letter-spacing:.16em;padding:5px 10px}
  .news-arrow{width:36px;height:36px;font-size:15px;right:14px;bottom:14px}
  .news-dots{justify-content:flex-start;padding-left:6px}

  .paths{padding:40px 0 48px}
  .paths-head{margin-bottom:20px;flex-direction:column;gap:8px;align-items:start}
  .paths-head h2{font-size:24px}
  .paths-head p{font-size:13px}
  .path-grid{grid-template-columns:1fr;grid-template-rows:auto;gap:10px;min-height:0}
  .path-img{aspect-ratio:16/9;min-height:0}
  .path-title{font-size:18px;left:16px;bottom:14px;right:16px}
  .path-num{top:14px;left:16px;font-size:11px}
  .path-body{padding:14px 16px 16px}
  .path-body > p{display:none}
  .path-meta{display:none}
  .path-link{font-size:11px}

  .about{padding:40px 0}
  .about-grid{grid-template-columns:1fr;gap:24px}
  .about-img{aspect-ratio:4/3;border-radius:14px}
  .about h2{font-size:24px;margin:10px 0 16px}
  .about-text{font-size:14.5px}
  .about-sig{font-size:20px;margin-top:20px}

  /* OFFER-Mobile-Block entfernt (Sektion gibt es nicht mehr) */

  .refs{padding:40px 0}
  .refs-head{margin-bottom:20px}
  .refs-head p{font-size:14px}
  .refs-slider{max-width:none}
  .ref-card{padding:26px 22px;gap:14px}
  .ref-quote{font-size:18px;line-height:1.4}
  .refs-dots{margin-top:18px}

  .faq{padding:16px 0 40px}
  .faq-master{border-radius:14px}
  .faq-summary{padding:16px 16px;gap:10px;grid-template-columns:auto 1fr auto}
  .faq-summary-meta{display:none}
  .faq-summary-title{font-size:16px}
  .faq-summary-eyebrow{font-size:10px;padding:4px 8px}
  .faq-body{padding:0 16px 16px}
  .faq-q{font-size:15px;gap:10px;padding:14px 0}
  .faq-a > div{font-size:14px}
  .faq-item.open .faq-a > div{padding:0 0 14px}

  .contact{padding:48px 0}
  .contact-card{grid-template-columns:1fr;border-radius:18px}
  .contact-card::before{display:none}
  .contact-info{padding:28px 22px 8px;background:linear-gradient(160deg,var(--sage-deep) 0%, var(--ink) 100%);border-radius:18px 18px 0 0}
  .contact-info h2{font-size:24px}
  .contact-lead{margin-bottom:18px;font-size:14px}
  .contact-channels{margin-bottom:16px}
  .contact-channels a{padding:14px 16px;gap:14px}
  .ch-ico{width:40px;height:40px;border-radius:10px}
  .ch-label{font-size:10px}
  .ch-text strong{font-size:14px}
  .contact-hours{margin-top:8px;margin-bottom:20px;padding:16px 18px;font-size:13px}
  .contact-form{padding:24px 20px 22px;border-radius:0 0 18px 18px}
  .form-head h3{font-size:20px}
  .form-head p{font-size:13px}
  .form-grid{grid-template-columns:1fr;gap:12px}
  .termin-grid{grid-template-columns:1fr;gap:10px}
  .termin-fields{padding:12px}
  .form-foot{flex-direction:column-reverse;align-items:stretch;gap:12px}
  .form-submit{width:100%;justify-content:center;min-height:44px}
  .form-note{text-align:center;font-size:12px}

  .foot-meta{grid-template-columns:1fr;text-align:center;gap:14px;padding:16px 0}
  .foot-logo img{height:100px;margin-top:-20px;margin-bottom:-20px}
  .foot-mark{height:52px;margin-left:8px}
  .foot-ch-mail{display:none}
  .foot-channels{justify-content:center;gap:8px}
  .foot-channels a{padding:6px 10px;font-size:11px;border-radius:999px}
  .foot-channels a svg{width:14px;height:14px}
  .foot-bottom{justify-content:center;text-align:center;gap:8px;padding:12px 0 16px;font-size:11px}
  .foot-bottom-links{justify-content:center;gap:4px 14px}

  section[id],[id]{scroll-margin-top:78px}
  a,button{-webkit-tap-highlight-color:rgba(76,53,39,.08)}
}

@media (max-width:520px){
  h1{font-size:34px;line-height:1.05}
  h2{font-size:24px}
  .container{padding:0 16px}
  .hero-claim{font-size:24px}
  .hero-card{min-height:360px;aspect-ratio:3/4.2}
  .nav-stage .nav-inner{min-height:50px;padding:4px 0}
  .brand-logo-xl{height:80px;margin-top:-16px;margin-bottom:-16px}
  .brand-mark{height:36px;margin-left:4px}
  .path-img{aspect-ratio:16/10}
  .path-title{font-size:17px}
  .path-body{padding:12px 14px 14px}
  .path-body > p{font-size:12.5px}
  .ref-card{padding:20px 18px;gap:12px;border-radius:14px}
  .ref-quote{font-size:16px}
  .ref-author{padding-top:12px;gap:10px}
  .ref-avatar{width:36px;height:36px;font-size:13px}
  .refs-dot{width:32px;height:32px}
  .refs-dot::after{width:8px;height:8px}
  .foot-channels a{padding:5px 8px;font-size:10px}
  .foot-logo img{height:80px;margin-top:-16px;margin-bottom:-16px}
  .foot-mark{height:40px;margin-left:4px}
  .news-img{flex:0 0 90px}
  .news-title{font-size:14px}
  .news-sub{font-size:12px;display:none}
  .news-arrow{width:30px;height:30px;right:10px;bottom:10px}
  .gallery-grid{columns:2;column-gap:6px}
  .gal{margin-bottom:6px;aspect-ratio:1/1;border-radius:6px}
  .gal-tall,.gal-wide{aspect-ratio:1/1}
}

@media (max-width:380px){
  h1{font-size:34px}
}

/* ===================================================================== */
/*  ITERATION 09.06.2026 — Online-Kurse, Pinky-Cup-Mark, Hero-Trust      */
/*  Quelle: WhatsApp-Verlauf Julien/Tommy (mehr Weiß à la Five Elephant, */
/*  Erkennungssymbol, Online-Kurse-Reiter, stärkerer CTA-Druck).         */
/* ===================================================================== */

/* Marken-Bildmarke „Pinky Cup" neben dem Wortlogo (Stage-Nav).
   2026-06-09: deutlich vergrößert (Julien: „mehr Pinky-Cup").
   Sitzt jetzt ~75 % der Wortlogo-Höhe, mit etwas Negativ-Margin
   nach oben damit die Dampf-Curls über die Nav-Linie hinausragen
   und die Marke „lebt". Übernimmt currentColor → folgt der hellen
   Stage-Typo automatisch. */
.brand-mark{
  /* Pinky-Cup: horizontal am Logo ausgerichtet, mit Abstand. */
  display:inline-flex;align-items:center;
  position:relative;
  margin-left:12px;
  margin-bottom:0;
  height:56px;
  color:var(--cream);
  flex-shrink:0;
  pointer-events:none;
  transform-origin:90% 100%;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.3));
  /* Deutlicher Aufwipp-Effekt + sanftes Nachwippen */
  animation:pinkyWave 1.8s cubic-bezier(.34,1.56,.64,1) .25s both;
}
.brand-mark img{
  display:block;
  height:100%;width:auto;
  max-width:none;
  object-fit:contain;
}
@keyframes pinkyWave{
  0%   {transform:translateY(14px) rotate(-14deg);opacity:0}
  35%  {transform:translateY(-6px) rotate(10deg); opacity:1}
  60%  {transform:translateY(0)    rotate(-5deg); opacity:1}
  80%  {transform:translateY(0)    rotate(3deg);  opacity:1}
  100% {transform:translateY(0)    rotate(0);     opacity:1}
}
@media (min-width:1280px){
  .brand-mark{height:64px;margin-left:14px}
}
@media (prefers-reduced-motion: reduce){
  .brand-mark{animation:none;transform:none}
}

/* Stage-CTA: aus dem stillen Meta-Link wird ein klarer Pill-Button.
   Caramel-Akzent gegen das tiefe Grün → klarer Conversion-Anker. */
.nav-cta-stage{
  background:var(--caramel);color:var(--cream);
  padding:12px 22px;border-radius:999px;
  font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
  border:1px solid transparent;
  transition:transform .15s, background .2s, border-color .2s;
}
.nav-cta-stage:hover{
  background:var(--cream);color:var(--walnut);
  border-color:var(--cream);transform:translateY(-1px);
}

/* „bald"-Badge an Nav-Links (Online-Kurse). Sehr klein, nicht aufdringlich. */
.nav-soon{
  display:inline-block;margin-left:6px;
  font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:2px 7px;border-radius:999px;
  background:var(--caramel);color:var(--cream);
  vertical-align:middle;
  line-height:1.3;
}
.nav-links-stage a.has-soon{display:inline-flex;align-items:center}

/* About-Sektion bleibt auf Body-Cream (Section-Sequenz: Hero → News →
   Paths → About → Offer-dunkel → Refs-sand → Gallery-sand → FAQ →
   Contact). 2026-06-10: war früher .about{background:var(--cream)},
   ist obsolet seit --bg selbst Cream ist. */

/* Offer-Slide „Online-Kurse" — visuell als Coming-Soon markiert */
.offer-slide-soon{position:relative}
.offer-slide-soon .offer-slide-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(15,28,25,.20), rgba(15,28,25,.55));
}
.offer-soon-badge{
  display:inline-block;margin-left:8px;
  font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:2px 7px;border-radius:999px;
  background:var(--caramel);color:var(--cream);
  vertical-align:middle;line-height:1.3;
}

/* Mobile-Drawer: „bald"-Badge konsistent klein halten */
.mobile-drawer .nav-soon{font-size:10px;padding:3px 8px;margin-left:10px}

/* Mobile-Anpassungen für die neuen Elemente */
@media (max-width:880px){
  .brand-mark{height:38px;margin-left:-6px;position:relative}
  /* Stage-CTA-Button auf Mobile ausgeblendet — Burger übernimmt;
     dadurch bleibt die Nav clean. */
  .nav-cta-stage{display:none}
}

@media (max-width:520px){
  .brand-mark{height:28px;margin-left:-4px}
  /* Brand-Lockup mobile: Pinky-Cup darf nicht das Wortlogo erdrücken */
  .brand-logo-xl{height:56px}
}

/* ===================================================================== */
/*  ITERATION 09.06.2026 — /kurse Public-Page (Termine, Filter, Karten) */
/* ===================================================================== */

/* Stage-Variante ohne Hero-Bild: nur Page-Head direkt unter der Nav. */
.stage-compact{padding-bottom:0}
.stage-compact .stage-leaves{opacity:.14}

.kurse-head{
  position:relative;z-index:2;
  padding:8px 0 72px;
  color:var(--cream);
}
.kurse-head .eyebrow{color:var(--caramel)}
.kurse-head .eyebrow::before{background:var(--caramel)}
.kurse-h1{
  font-family:'Fraunces',Georgia,serif;
  font-size:clamp(40px,5.5vw,72px);
  font-weight:400;line-height:1.05;letter-spacing:-0.015em;
  margin:14px 0 16px;color:var(--cream);
}
.kurse-h1 em{font-style:italic;color:var(--caramel);font-weight:400}
.kurse-lead{
  max-width:560px;font-size:17px;line-height:1.55;
  color:rgba(251,247,240,.84);margin:0;
}

/* Aktiver Nav-Link auf der eigenen Seite */
.nav-links-stage a.is-current{color:var(--caramel)}
.nav-links-stage a.is-current::after{
  content:"";display:block;height:2px;background:var(--caramel);
  margin-top:4px;border-radius:1px;
}

/* Hauptbereich der Kurs-Liste */
.kurse-list{
  background:var(--bg);
  padding:64px 0 96px;
  border-top:1px solid var(--line);
}

/* Filter-Chips */
.kurse-filter{
  display:flex;flex-wrap:wrap;gap:10px;
  margin:0 0 36px;
}
.kurse-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:999px;
  background:var(--cream);color:var(--ink-soft);
  border:1px solid var(--line);
  font-family:'Inter',sans-serif;font-size:13px;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;transition:background .2s, color .2s, border-color .2s, transform .15s;
}
.kurse-chip:hover{color:var(--ink);border-color:var(--ink)}
.kurse-chip.is-active{
  background:var(--ink);color:var(--cream);border-color:var(--ink);
}

/* Karten-Grid */
.kurse-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:28px;
}
.kurse-card{
  display:flex;flex-direction:column;
  background:var(--cream);
  border-radius:16px;overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 16px 40px -28px rgba(47,77,70,.30);
  transition:transform .2s, box-shadow .25s;
}
.kurse-card:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 50px -28px rgba(47,77,70,.40);
}
.kurse-card-media{
  aspect-ratio:16/10;
  background:var(--walnut) center/cover no-repeat;
}
.kurse-card-body{
  padding:24px 26px 26px;
  display:flex;flex-direction:column;gap:14px;flex:1;
}
.kurse-card-meta{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
}
.kurse-mode{
  display:inline-flex;align-items:center;
  padding:5px 11px;border-radius:999px;
  font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
}
.kurse-mode-vor-ort{background:var(--sage-deep);color:var(--cream)}
.kurse-mode-online {background:var(--caramel);color:var(--cream)}
.kurse-date{
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  color:var(--ink-soft);letter-spacing:.02em;
}
.kurse-card-title{
  font-family:'Fraunces',Georgia,serif;
  font-size:22px;font-weight:500;line-height:1.18;letter-spacing:-0.005em;
  color:var(--ink);margin:0;
}
.kurse-card-desc{
  font-size:14.5px;color:var(--ink-soft);margin:0;line-height:1.5;
}
.kurse-card-facts{
  list-style:none;margin:0;padding:14px 0 0;
  border-top:1px dashed var(--line);
  display:grid;gap:8px;
  font-size:13.5px;color:var(--ink);
}
.kurse-card-facts li{
  display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:baseline;
}
.kurse-card-facts li span{
  font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);
}
.kurse-card-cta{
  margin-top:6px;align-self:flex-start;
  padding:13px 22px;font-size:14px;letter-spacing:.04em;
}

/* Leerer Filter */
.kurse-empty{
  text-align:center;color:var(--ink-soft);
  padding:48px 24px;font-size:15px;
}
.kurse-empty a{color:var(--ink);font-weight:600;text-decoration:underline}

/* Aside-Box „individuelle Anfrage" */
.kurse-aside{
  margin-top:64px;padding:36px 32px;
  background:var(--cream);border:1px solid var(--line);border-radius:16px;
  display:grid;gap:14px;
}
.kurse-aside h2{
  font-family:'Fraunces',serif;font-size:clamp(22px,2.4vw,30px);
  font-weight:500;margin:0;color:var(--ink);
}
.kurse-aside p{margin:0;color:var(--ink-soft);max-width:560px}
.kurse-aside .btn{align-self:flex-start;margin-top:6px}

@media (max-width:880px){
  .kurse-head{padding:8px 0 48px}
  .kurse-list{padding:40px 0 64px}
  .kurse-grid{gap:18px}
  .kurse-card-body{padding:20px 22px 22px}
  .kurse-aside{padding:28px 22px;margin-top:40px}
}

/* ── Buchungsmodal ─────────────────────────── */
.book-overlay{position:fixed;inset:0;z-index:9999;background:rgba(42,27,18,.55);display:none;align-items:center;justify-content:center;padding:20px}
.book-overlay.is-open{display:flex}
.book-modal{background:var(--cream,#FBF7F0);border-radius:14px;width:100%;max-width:440px;padding:32px 28px 28px;position:relative;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px -16px rgba(0,0,0,.3)}
.book-close{position:absolute;top:12px;right:14px;background:none;border:0;font-size:28px;color:var(--ink-soft);cursor:pointer;line-height:1;padding:4px}
.book-close:hover{color:var(--walnut)}
.book-modal h2{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:22px;color:var(--walnut);margin:0 0 4px}
.book-kurs{font-size:14px;color:var(--ink-soft);margin:0 0 20px}
.book-modal label{display:block;font-size:13px;font-weight:500;color:var(--walnut);margin:0 0 4px}
.book-modal label small{font-weight:400;color:var(--ink-soft)}
.book-modal input[type=text],
.book-modal input[type=email],
.book-modal input[type=tel],
.book-modal select,
.book-modal textarea{width:100%;padding:10px 12px;border:1px solid rgba(76,53,39,.18);border-radius:8px;font:inherit;font-size:15px;background:#fff;margin-bottom:14px;color:var(--ink)}
.book-modal input:focus,.book-modal select:focus,.book-modal textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(60,104,93,.15)}
.book-modal textarea{min-height:60px;resize:vertical}
.book-consent{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--ink-soft);margin:4px 0 18px;cursor:pointer}
.book-consent input{margin-top:2px;flex-shrink:0}
.book-consent a{color:var(--teal)}
.book-status{padding:10px 12px;border-radius:8px;font-size:14px;margin-bottom:14px;background:rgba(60,104,93,.1);color:var(--teal-deep)}
.book-status-err{background:rgba(185,74,59,.1);color:#7a2f24}
.book-submit{width:100%;justify-content:center}
.book-done{text-align:center;padding:24px 0}
.book-done h3{font-family:'Fraunces',Georgia,serif;font-weight:500;color:var(--walnut);margin:0 0 8px}
.book-done p{color:var(--ink-soft);font-size:15px;margin:0}
.kurse-card-cta.is-past{opacity:.5;cursor:default;pointer-events:none}



/* ===== NEWSLETTER ===== */
.newsletter{padding:80px 0;background:linear-gradient(180deg, var(--bg-deep) 0%, var(--cream) 100%)}
.newsletter-card{max-width:780px;margin:0 auto;background:var(--ink);color:var(--cream);border-radius:24px;padding:48px 44px;display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;box-shadow:0 20px 60px -20px rgba(15,28,25,.45)}
.newsletter-text h2{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:30px;color:var(--cream);margin:0 0 10px;line-height:1.15}
.newsletter-text p{margin:0;color:rgba(251,247,240,.78);font-size:15px;line-height:1.55}
.newsletter-form{display:flex;flex-direction:column;gap:10px}
.newsletter-form input[type=email]{padding:13px 16px;border:1px solid rgba(251,247,240,.2);border-radius:10px;font:inherit;font-size:15px;background:rgba(251,247,240,.08);color:var(--cream)}
.newsletter-form input[type=email]::placeholder{color:rgba(251,247,240,.45)}
.newsletter-form input[type=email]:focus{outline:none;border-color:var(--caramel);background:rgba(251,247,240,.12)}
.newsletter-form .btn-primary{padding:13px 16px;background:var(--caramel);color:var(--ink);border:0;border-radius:10px;font:inherit;font-weight:600;cursor:pointer;font-size:15px}
.newsletter-form .btn-primary:hover{background:#bd7c4f}
.newsletter-form .btn-primary:disabled{opacity:.6;cursor:wait}
.nl-consent{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:rgba(251,247,240,.65);line-height:1.4;cursor:pointer}
.nl-consent input{margin-top:2px;flex-shrink:0;accent-color:var(--caramel)}
.nl-consent a{color:var(--caramel);text-decoration:underline}
.newsletter-status{font-size:13px;margin-top:4px;min-height:18px}
.newsletter-status.ok{color:#9dd6c1}
.newsletter-status.err{color:#f3a89a}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

@media (max-width:760px){
  .newsletter{padding:48px 0}
  .newsletter-card{grid-template-columns:1fr;padding:32px 24px;gap:20px}
  .newsletter-text h2{font-size:24px}
}

/* ===== COOKIE-BANNER ===== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9998;background:var(--ink);color:var(--cream);padding:18px 22px;display:none;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;box-shadow:0 -10px 30px -10px rgba(0,0,0,.3);font-size:14px;line-height:1.5}
.cookie-banner.is-visible{display:flex}
.cookie-banner p{margin:0;flex:1;min-width:260px;color:rgba(251,247,240,.88)}
.cookie-banner a{color:var(--caramel);text-decoration:underline}
.cookie-banner-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-banner button{background:transparent;border:1px solid rgba(251,247,240,.4);color:var(--cream);padding:9px 18px;border-radius:8px;font:inherit;cursor:pointer}
.cookie-banner button:hover{background:rgba(251,247,240,.08)}
.cookie-banner button.btn-accept{background:var(--caramel);border-color:var(--caramel);color:var(--ink);font-weight:600}
.cookie-banner button.btn-accept:hover{background:#bd7c4f}

/* ============================================================
   Consent-Banner (snobs-analytics.js) — dezent, freundlich
   ============================================================ */
#snob-consent{position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;display:flex;justify-content:center;pointer-events:none;animation:snobConsentIn .35s ease-out both}
#snob-consent.snob-consent--out{animation:snobConsentOut .28s ease-in forwards}
.snob-consent__box{pointer-events:auto;max-width:780px;width:100%;background:#FBF7F0;color:#2F4D46;border:1px solid #e6dcc7;border-radius:14px;box-shadow:0 12px 40px rgba(60,40,20,.18);padding:14px 16px;display:flex;align-items:center;gap:16px;font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif}
.snob-consent__text{flex:1;min-width:0}
.snob-consent__text strong{color:#3C685D;font-weight:600}
.snob-consent__text a{color:#A56B42;text-decoration:underline;text-underline-offset:2px}
.snob-consent__text a:hover{color:#6C4128}
.snob-consent__actions{display:flex;gap:8px;flex-shrink:0}
.snob-consent__btn{border:0;cursor:pointer;font:600 13px/1 inherit;padding:10px 16px;border-radius:999px;transition:.15s;white-space:nowrap}
.snob-consent__btn--ghost{background:transparent;color:#4C3527;border:1px solid #d8cdb6}
.snob-consent__btn--ghost:hover{background:#fff;border-color:#A56B42}
.snob-consent__btn--accept{background:#3C685D;color:#fff}
.snob-consent__btn--accept:hover{background:#2F4D46}
@media (max-width:620px){
  .snob-consent__box{flex-direction:column;align-items:stretch;gap:10px;padding:14px}
  .snob-consent__actions{justify-content:flex-end}
}
@keyframes snobConsentIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes snobConsentOut{to{opacity:0;transform:translateY(20px)}}

/* ============================================================
   Newsletter-Opt-in im Formular (dezent)
   ============================================================ */
.field-check-soft{margin-top:-6px}
.field-check-soft input{accent-color:#A56B42}
.field-check-soft span{font-size:13px;color:var(--ink-soft,#717168)}
.book-consent-soft{font-size:13px;color:var(--ink-soft,#717168);margin-top:-2px;display:flex;gap:8px;align-items:flex-start;cursor:pointer}
.book-consent-soft input{margin-top:3px;accent-color:#A56B42;flex-shrink:0}

/* ============================================================
   Blog-Layout (public)
   ============================================================ */
.blog-body{background:#FBF7F0;font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;color:#2F4D46;margin:0}
.blog-body .site-header{background:#fff;border-bottom:1px solid #ece5d2;padding:14px 0}
.blog-body .site-header .container{display:flex;justify-content:space-between;align-items:center}
.blog-body .brand img{height:34px;display:block}
.blog-body .site-nav{display:flex;gap:18px;font-size:14px}
.blog-body .site-nav a{color:#4C3527;text-decoration:none;padding:4px 0;border-bottom:2px solid transparent;transition:.15s}
.blog-body .site-nav a:hover,.blog-body .site-nav a.is-active{color:#3C685D;border-bottom-color:#A56B42}
.blog-body .container{max-width:960px;margin:0 auto;padding:0 24px}

.blog-page{padding:48px 0 80px}
.blog-head{text-align:center;margin-bottom:48px}
.blog-head .eyebrow{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:#A56B42;margin:0 0 8px;font-weight:600}
.blog-head h1{font-family:Georgia,"Times New Roman",serif;font-size:48px;color:#2F4D46;margin:0 0 16px;line-height:1.1}
.blog-head .lead{font-size:18px;color:#6C4128;max-width:600px;margin:0 auto;line-height:1.5}

.blog-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.blog-card{background:#fff;border-radius:14px;overflow:hidden;border:1px solid #ece5d2;transition:.2s;box-shadow:0 2px 8px rgba(60,40,20,.04)}
.blog-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(60,40,20,.12);border-color:#A56B42}
.blog-card__link{display:flex;flex-direction:column;text-decoration:none;color:inherit;height:100%}
.blog-card__media{aspect-ratio:16/9;overflow:hidden;background:#FBF7F0}
.blog-card__media img{width:100%;height:100%;object-fit:cover;transition:.4s}
.blog-card:hover .blog-card__media img{transform:scale(1.04)}
.blog-card__body{padding:18px 20px 22px;flex:1;display:flex;flex-direction:column}
.blog-card__title{font-family:Georgia,serif;font-size:22px;color:#2F4D46;margin:0 0 8px;line-height:1.25}
.blog-card__excerpt{color:#6C4128;font-size:14px;margin:0 0 16px;flex:1;line-height:1.5}
.blog-card__meta{font-size:12px;color:#A56B42;display:flex;gap:6px;align-items:center}
.blog-card__meta .dot{opacity:.5}

.blog-empty{text-align:center;padding:60px 20px;background:#fff;border-radius:14px;border:1px dashed #d6c9a6}
.blog-empty p{color:#6C4128;margin:0 0 16px}

/* ----- Einzelner Beitrag ----- */
.blog-post{padding:32px 0 80px}
.breadcrumbs{font-size:13px;color:#A56B42;margin-bottom:24px;display:flex;gap:6px;flex-wrap:wrap}
.breadcrumbs a{color:#A56B42;text-decoration:none}
.breadcrumbs a:hover{text-decoration:underline}
.breadcrumbs .current{color:#6C4128;font-weight:500}

.blog-post__head{text-align:center;margin-bottom:32px;max-width:720px;margin-left:auto;margin-right:auto}
.blog-post__head h1{font-family:Georgia,serif;font-size:42px;color:#2F4D46;line-height:1.15;margin:0 0 16px}
.blog-post__meta{font-size:14px;color:#A56B42;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.blog-post__meta .dot{opacity:.5}
.blog-post__lead{font-size:19px;color:#6C4128;line-height:1.55;margin:20px 0 0;font-style:italic}

.blog-post__cover{margin:0 0 40px;border-radius:16px;overflow:hidden;max-width:920px;margin-left:auto;margin-right:auto}
.blog-post__cover img{width:100%;height:auto;display:block}

.blog-post__body{max-width:720px;margin:0 auto;font-size:17px;line-height:1.8;color:#2F4D46}
.blog-post__body h2{font-family:Georgia,serif;font-size:32px;color:#2F4D46;margin:48px 0 16px;line-height:1.2}
.blog-post__body h3{font-family:Georgia,serif;font-size:24px;color:#3C685D;margin:36px 0 12px}
.blog-post__body h4{font-size:18px;color:#6C4128;margin:24px 0 10px;font-weight:700}
.blog-post__body p{margin:0 0 18px}
.blog-post__body a{color:#A56B42;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.blog-post__body a:hover{color:#6C4128}
.blog-post__body img{max-width:100%;height:auto;border-radius:10px;margin:24px auto;display:block}
.blog-post__body figure{margin:32px 0;text-align:center}
.blog-post__body figcaption{font-size:13px;color:#A56B42;margin-top:8px;font-style:italic}
.blog-post__body blockquote{border-left:4px solid #A56B42;background:#fff;padding:18px 24px;margin:28px 0;border-radius:0 8px 8px 0;font-style:italic;color:#6C4128;font-size:18px}
.blog-post__body blockquote p{margin:0}
.blog-post__body ul,.blog-post__body ol{padding-left:26px;margin:0 0 20px}
.blog-post__body ul li,.blog-post__body ol li{margin-bottom:6px}
.blog-post__body code{background:#fff;border:1px solid #ece5d2;padding:2px 8px;border-radius:4px;font-size:14px;color:#6C4128}
.blog-post__body pre{background:#2F4D46;color:#FBF7F0;padding:18px 22px;border-radius:10px;overflow:auto;margin:24px 0;font-size:14px;line-height:1.5}
.blog-post__body pre code{background:transparent;border:0;color:inherit;padding:0}
.blog-post__body hr{border:0;border-top:2px solid #ece5d2;margin:36px auto;max-width:120px}

.blog-post__tags{list-style:none;padding:0;margin:36px auto 0;max-width:720px;display:flex;flex-wrap:wrap;gap:8px}
.blog-post__tags li{background:#fff;border:1px solid #ece5d2;color:#A56B42;padding:4px 12px;border-radius:999px;font-size:13px}

.blog-post__cta{margin:60px auto 0;max-width:720px;padding:32px;background:#fff;border-radius:14px;text-align:center;border:1px solid #ece5d2}
.blog-post__cta h3{font-family:Georgia,serif;font-size:24px;color:#2F4D46;margin:0 0 8px}
.blog-post__cta p{color:#6C4128;margin:0 0 18px}
.blog-post__cta .btn{margin:0 4px}

@media (max-width:720px){
  .blog-head h1{font-size:34px}
  .blog-post__head h1{font-size:30px}
  .blog-post__body{font-size:16px}
  .blog-post__body h2{font-size:26px}
  .blog-post__body h3{font-size:20px}
  .blog-grid{grid-template-columns:1fr}
}

.legal-foot{background:#2F4D46;color:#FBF7F0;padding:32px 0;margin-top:60px}
.legal-foot .legal-nav{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin-bottom:12px}
.legal-foot .legal-nav a{color:#FBF7F0;text-decoration:none;font-size:14px;opacity:.85}
.legal-foot .legal-nav a:hover{opacity:1;text-decoration:underline}
.legal-foot-meta{text-align:center;font-size:13px;opacity:.7;margin:0}
