/* ============================================================
   Kirchspielkrug Ostenfeld — "Reetdach & Marsch"
   Design-System (handgeschrieben, kein Build)
   ============================================================ */

/* ---------- Fonts (selbst gehostet, DSGVO) ---------- */
@font-face{font-family:"Fraunces";src:url("../assets/fonts/fraunces-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Fraunces";src:url("../assets/fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Fraunces";src:url("../assets/fonts/fraunces-400-italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap;}
@font-face{font-family:"Hanken Grotesk";src:url("../assets/fonts/hanken-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Hanken Grotesk";src:url("../assets/fonts/hanken-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:"Hanken Grotesk";src:url("../assets/fonts/hanken-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;}

/* ---------- Tokens ---------- */
:root{
  /* Farben — abgeleitet aus dem Logo (Salbei-Teal, Ziegel, Reet/Pergament) */
  --reet:#f3ecdb;          /* Pergament/Stroh — dominanter Hintergrund */
  --reet-hell:#fbf7ec;     /* Karten */
  --reet-tief:#e9dec6;     /* abgesetzte Flächen */
  --marsch:#3f5d58;        /* Salbei-Teal — Markenanker */
  --marsch-tief:#2a403c;   /* dunkles Teal — Footer/Headlines */
  --salbei:#6e8c86;        /* helleres Teal */
  --ziegel:#a8543a;        /* Terrakotta — CTA/Akzent */
  --ziegel-tief:#8c4128;
  --korn:#c2982f;          /* Korn-Gold — feine Linien, Preise */
  --korn-hell:#d9b970;
  --tinte:#23302e;         /* Fließtext */
  --tinte-weich:#4c5a56;
  --nebel:#8fa39e;         /* gedämpfte Linien/Sekundärtext */
  --linie:rgba(42,64,60,.14);

  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-text:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --maxw:1180px;
  --radius:16px;
  --radius-s:10px;
  --shadow:0 18px 40px -24px rgba(42,64,60,.45);
  --shadow-soft:0 10px 30px -20px rgba(42,64,60,.5);
  --pad-x:clamp(1.1rem,5vw,2.5rem);
  --section-y:clamp(3.5rem,8vw,7rem);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
html,body{overflow-x:hidden;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  margin:0;
  font-family:var(--font-text);
  font-size:clamp(1rem,.96rem + .25vw,1.09rem);
  line-height:1.65;
  color:var(--tinte);
  background:var(--reet);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;}
a{color:var(--ziegel);text-underline-offset:3px;text-decoration-thickness:1px;}
a:hover{color:var(--ziegel-tief);}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.08;color:var(--marsch-tief);margin:0 0 .5em;letter-spacing:-.01em;}
h1{font-size:clamp(2.4rem,1.6rem + 3.6vw,4.4rem);font-weight:600;}
h2{font-size:clamp(1.85rem,1.35rem + 2.1vw,3rem);}
h3{font-size:clamp(1.28rem,1.1rem + .9vw,1.7rem);}
p{margin:0 0 1.1em;}
ul,ol{margin:0 0 1.1em;padding-left:1.2em;}
strong{font-weight:700;}
:focus-visible{outline:3px solid var(--korn);outline-offset:3px;border-radius:4px;}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x);}
.wrap--narrow{max-width:820px;}
.section{position:relative;padding-block:var(--section-y);}
.section--marsch{background:var(--marsch-tief);color:#e9e1cf;}
.section--marsch h2,.section--marsch h3{color:var(--reet);}
.section--salbei{background:var(--marsch);color:#eef2ec;}
.section--salbei h2,.section--salbei h3{color:#fff;}
.section--cream{background:var(--reet-hell);}
.section--tief{background:var(--reet-tief);}
.lead{font-size:clamp(1.1rem,1rem + .5vw,1.3rem);color:var(--tinte-weich);max-width:60ch;}
.section--marsch .lead,.section--salbei .lead{color:rgba(255,255,255,.82);}
.muted{color:var(--tinte-weich);}
.center{text-align:center;margin-inline:auto;}

/* ---------- Eyebrow / section heads ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-display);font-style:italic;
  font-size:.95rem;letter-spacing:.02em;color:var(--ziegel);
  margin:0 0 .8rem;
}
.eyebrow::before{content:"";width:2.2rem;height:1px;background:var(--korn);}
.section--marsch .eyebrow,.section--salbei .eyebrow{color:var(--korn-hell);}
.section-head{max-width:64ch;margin-bottom:clamp(2rem,4vw,3.2rem);}
.section-head.center{margin-inline:auto;}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ziegel);--fg:#fff;
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-text);font-weight:600;font-size:1rem;line-height:1;
  padding:.95em 1.5em;border-radius:999px;border:1.5px solid transparent;
  background:var(--bg);color:var(--fg);cursor:pointer;text-decoration:none;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease);
  box-shadow:0 10px 22px -14px rgba(168,84,58,.9);
}
.btn:hover{transform:translateY(-2px);background:var(--ziegel-tief);color:#fff;box-shadow:0 16px 28px -16px rgba(168,84,58,.95);}
.btn:active{transform:translateY(0);}
.btn--ghost{--bg:transparent;--fg:var(--marsch-tief);border-color:var(--marsch);box-shadow:none;}
.btn--ghost:hover{--bg:var(--marsch);color:#fff;}
.btn--light{--bg:var(--reet);--fg:var(--marsch-tief);box-shadow:none;}
.btn--light:hover{--bg:#fff;color:var(--marsch-tief);}
.btn--block{display:flex;width:100%;justify-content:center;}
.btn .ic{width:1.1em;height:1.1em;}

/* ---------- Demo banner (neutral, kein R8Relay) ---------- */
.demo-banner{
  background:var(--marsch-tief);color:var(--reet);
  font-size:.82rem;letter-spacing:.03em;text-align:center;
  padding:.45rem 1rem;
}
.demo-banner strong{color:var(--korn-hell);font-weight:600;}

/* ---------- Header / Nav ---------- */
.skip-link{position:absolute;left:.5rem;top:-3rem;z-index:200;background:var(--marsch-tief);color:#fff;padding:.6rem 1rem;border-radius:8px;transition:top .2s;}
.skip-link:focus{top:.5rem;color:#fff;}
.site-header{position:sticky;top:0;z-index:100;background:rgba(243,236,219,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--linie);}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:72px;}
.brand{display:inline-flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--marsch-tief);}
.brand__mark{width:42px;height:42px;flex:0 0 auto;}
.brand__text{display:flex;flex-direction:column;line-height:1;}
.brand__name{font-family:var(--font-display);font-weight:600;font-size:1.16rem;letter-spacing:.005em;}
.brand__sub{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ziegel);margin-top:.28rem;}

.nav{display:flex;align-items:center;gap:.4rem;}
.nav__list{display:flex;align-items:center;gap:.2rem;list-style:none;margin:0;padding:0;}
.nav__link{
  font-family:var(--font-text);font-weight:500;font-size:.98rem;
  color:var(--tinte);text-decoration:none;padding:.55rem .8rem;border-radius:999px;
  position:relative;transition:color .2s,background .2s;
}
.nav__link:hover{color:var(--marsch-tief);background:rgba(110,140,134,.16);}
.nav__link[aria-current="page"]{color:var(--ziegel);}
.nav__link[aria-current="page"]::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.28rem;height:2px;background:var(--korn);border-radius:2px;}
.nav__cta{margin-left:.5rem;}

.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:1px solid var(--linie);border-radius:12px;background:var(--reet-hell);cursor:pointer;}
.nav-toggle span{display:block;width:22px;height:2px;margin-inline:auto;background:var(--marsch-tief);border-radius:2px;transition:transform .3s var(--ease),opacity .2s;}
.nav-backdrop{display:none;}

@media (max-width:920px){
  .nav-toggle{display:flex;}
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(82vw,360px);
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.2rem;
    background:var(--reet-hell);padding:5.5rem 1.6rem 2rem;
    transform:translateX(105%);transition:transform .38s var(--ease);
    box-shadow:-20px 0 50px -30px rgba(42,64,60,.6);z-index:120;overflow-y:auto;
  }
  .nav__list{flex-direction:column;align-items:stretch;gap:.1rem;width:100%;}
  .nav__link{font-size:1.12rem;padding:.85rem .9rem;border-bottom:1px solid var(--linie);border-radius:0;}
  .nav__link[aria-current="page"]::after{display:none;}
  .nav__cta{margin:1.2rem 0 0;}
  .nav-backdrop{display:block;position:fixed;inset:0;background:rgba(42,64,60,.45);opacity:0;visibility:hidden;transition:opacity .3s;z-index:110;}
  body.nav-open{overflow:hidden;}
  body.nav-open .nav{transform:translateX(0);}
  body.nav-open .nav-backdrop{opacity:1;visibility:visible;}
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  body.nav-open .nav-toggle span:nth-child(2){opacity:0;}
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
}

/* ---------- Decoration: blobs, waves, motifs ---------- */
.deco{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
.blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5;}
.section>.wrap{position:relative;z-index:1;}
.divider{display:block;width:100%;height:clamp(40px,6vw,90px);}
.divider svg{width:100%;height:100%;display:block;}
.leaf{position:absolute;color:var(--salbei);opacity:.5;}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(180deg,var(--reet) 0%,var(--reet-hell) 100%);padding-block:clamp(2.5rem,6vw,5rem) clamp(3rem,7vw,6rem);overflow:hidden;}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;}
.hero__content{position:relative;z-index:2;}
.hero h1{margin-bottom:.35em;}
.hero h1 em{font-style:italic;color:var(--ziegel);}
.hero__lead{font-size:clamp(1.1rem,1rem + .6vw,1.35rem);color:var(--tinte-weich);max-width:46ch;}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem;}
.hero__chip{
  display:inline-flex;align-items:center;gap:.6rem;margin-top:1.6rem;
  background:var(--reet-hell);border:1px solid var(--linie);border-radius:999px;
  padding:.5rem .95rem .5rem .7rem;font-size:.92rem;font-weight:500;color:var(--marsch-tief);
  box-shadow:var(--shadow-soft);
}
.hero__chip .dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--nebel);box-shadow:0 0 0 4px rgba(143,163,158,.25);}
.hero__chip.is-open .dot{background:#5e9a64;box-shadow:0 0 0 4px rgba(94,154,100,.25);}
.hero__art{position:relative;z-index:1;}
.hero__art svg{width:100%;height:auto;filter:drop-shadow(0 30px 50px rgba(42,64,60,.25));}
.hero__badge{
  position:absolute;right:4%;top:6%;z-index:3;background:var(--ziegel);color:#fff;
  width:clamp(82px,11vw,118px);height:clamp(82px,11vw,118px);border-radius:50%;
  display:grid;place-content:center;text-align:center;line-height:1.05;
  font-family:var(--font-display);box-shadow:var(--shadow);transform:rotate(-8deg);
}
.hero__badge b{display:block;font-size:clamp(1.5rem,3vw,2.1rem);font-weight:600;}
.hero__badge span{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;}
@media (max-width:820px){
  .hero__grid{grid-template-columns:1fr;}
  .hero__art{order:-1;max-width:520px;margin-inline:auto;}
}

/* ---------- "Heute bei uns" ---------- */
.today{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.2rem;
  background:var(--reet-hell);border:1px solid var(--linie);border-left:5px solid var(--korn);
  border-radius:var(--radius);padding:1.3rem 1.5rem;box-shadow:var(--shadow-soft);
}
.today__label{font-family:var(--font-display);font-style:italic;color:var(--ziegel);font-size:1rem;}
.today__day{font-weight:700;color:var(--marsch-tief);}
.today__dish{font-family:var(--font-display);font-size:clamp(1.15rem,1rem + .8vw,1.5rem);color:var(--marsch-tief);}
.today__price{font-family:var(--font-display);font-weight:600;color:var(--ziegel);font-size:1.3rem;white-space:nowrap;}
@media (max-width:620px){.today{grid-template-columns:1fr;text-align:left;}.today__price{justify-self:start;}}

/* ---------- Pillars / feature cards ---------- */
.cards{display:grid;gap:clamp(1.1rem,2.5vw,1.8rem);}
.cards--3{grid-template-columns:repeat(3,1fr);}
.cards--2{grid-template-columns:repeat(2,1fr);}
@media (max-width:860px){.cards--3{grid-template-columns:1fr;}.cards--2{grid-template-columns:1fr;}}
.card{
  position:relative;background:var(--reet-hell);border:1px solid var(--linie);
  border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.2rem);
  display:flex;flex-direction:column;gap:.4rem;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(194,152,47,.4);}
.card__icon{width:54px;height:54px;color:var(--marsch);margin-bottom:.6rem;}
.card__icon svg{width:100%;height:100%;}
.card h3{margin-bottom:.25em;}
.card__more{margin-top:auto;padding-top:.9rem;font-weight:600;color:var(--ziegel);text-decoration:none;display:inline-flex;align-items:center;gap:.45em;}
.card__more .arr{transition:transform .25s var(--ease);}
.card:hover .card__more .arr{transform:translateX(4px);}
.card--link{cursor:pointer;}

/* ---------- Menu lists (Mittagstisch / Catering) ---------- */
.menu{margin-top:1.5rem;}
.menu__group{margin-bottom:clamp(2rem,4vw,3rem);}
.menu__group-title{display:flex;align-items:center;gap:.9rem;font-family:var(--font-display);font-size:1.5rem;color:var(--marsch-tief);margin-bottom:1.1rem;}
.menu__group-title::after{content:"";flex:1;height:1px;background:var(--linie);}
.menu__item{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:.4rem 1rem;padding:.7rem 0;border-bottom:1px dotted var(--linie);}
.menu__item:last-child{border-bottom:0;}
.menu__name{font-weight:600;color:var(--tinte);}
.menu__sup{font-size:.7em;color:var(--nebel);vertical-align:super;}
.menu__desc{grid-column:1/-1;color:var(--tinte-weich);font-size:.95rem;margin-top:-.1rem;}
.menu__price{font-family:var(--font-display);font-weight:600;color:var(--ziegel);font-size:1.15rem;white-space:nowrap;}
.menu__price--soft{color:var(--marsch);}
.allergens{margin-top:1.5rem;font-size:.82rem;color:var(--tinte-weich);background:var(--reet);border-radius:var(--radius-s);padding:.9rem 1.1rem;border:1px solid var(--linie);}
.allergens b{color:var(--marsch-tief);}

/* day grid (week) */
.week{display:grid;gap:1rem;}
.day-card{
  display:grid;grid-template-columns:8.5rem 1fr auto;align-items:center;gap:1rem;
  background:var(--reet-hell);border:1px solid var(--linie);border-radius:var(--radius);
  padding:1.1rem 1.4rem;transition:border-color .3s,transform .3s var(--ease),box-shadow .3s;
}
.day-card__day{font-family:var(--font-display);font-size:1.25rem;color:var(--marsch-tief);}
.day-card__dish{color:var(--tinte);}
.day-card__price{font-family:var(--font-display);font-weight:600;color:var(--ziegel);font-size:1.2rem;white-space:nowrap;}
.day-card--rest{opacity:.6;font-style:italic;}
.day-card.is-today{border-color:var(--korn);box-shadow:0 0 0 2px rgba(194,152,47,.35),var(--shadow-soft);background:#fff;}
.day-card .is-today-flag{display:none;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--ziegel);padding:.2rem .55rem;border-radius:999px;margin-left:.6rem;}
.day-card.is-today .is-today-flag{display:inline-block;}
@media (max-width:640px){.day-card{grid-template-columns:1fr auto;}.day-card__day{grid-column:1/-1;}}

/* ---------- Timeline (Chronik) ---------- */
.timeline{position:relative;margin:2.5rem 0 0;padding-left:0;list-style:none;}
.timeline::before{content:"";position:absolute;left:calc(7.5rem + 7px);top:.4rem;bottom:.4rem;width:2px;background:linear-gradient(var(--korn),var(--linie));}
.timeline__item{position:relative;display:grid;grid-template-columns:7.5rem 1fr;gap:1.6rem;padding-bottom:2.2rem;}
.timeline__year{font-family:var(--font-display);font-weight:600;font-size:1.35rem;color:var(--ziegel);text-align:right;}
.timeline__body{position:relative;padding-left:1.6rem;}
.timeline__body::before{content:"";position:absolute;left:-9px;top:.55rem;width:16px;height:16px;border-radius:50%;background:var(--reet-hell);border:3px solid var(--korn);box-shadow:0 0 0 4px var(--reet);}
.timeline__item--accent .timeline__body::before{background:var(--ziegel);border-color:var(--ziegel);}
.timeline__title{font-family:var(--font-display);font-size:1.15rem;color:var(--marsch-tief);margin-bottom:.2rem;}
@media (max-width:620px){
  .timeline::before{left:7px;}
  .timeline__item{grid-template-columns:1fr;gap:.2rem;}
  .timeline__year{text-align:left;padding-left:1.6rem;}
  .timeline__body{padding-left:1.6rem;}
}

/* ---------- Rooms (Übernachten) ---------- */
.room{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,3vw,2.4rem);align-items:center;}
.room--flip .room__media{order:2;}
.room__media svg{width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow);}
.price-tag{display:inline-flex;align-items:baseline;gap:.4rem;background:var(--reet);border:1px solid var(--linie);border-radius:999px;padding:.5rem 1rem;font-weight:600;color:var(--marsch-tief);margin:.3rem .5rem .3rem 0;}
.price-tag b{font-family:var(--font-display);color:var(--ziegel);font-size:1.2rem;}
.feature-list{list-style:none;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem 1.2rem;}
.feature-list li{display:flex;align-items:flex-start;gap:.55rem;}
.feature-list .tick{flex:0 0 auto;width:1.15rem;height:1.15rem;color:var(--korn);margin-top:.2rem;}
@media (max-width:760px){.room{grid-template-columns:1fr;}.room--flip .room__media{order:0;}.feature-list{grid-template-columns:1fr;}}

/* ---------- Festmenü-Konfigurator (I-Tüpfelchen) ---------- */
.builder{display:grid;grid-template-columns:1.35fr .85fr;gap:clamp(1.4rem,3vw,2.6rem);align-items:start;margin-top:1.5rem;}
.builder__steps{display:grid;gap:clamp(1.2rem,2.5vw,2rem);}
.step{background:var(--reet-hell);border:1px solid var(--linie);border-radius:var(--radius);padding:clamp(1.2rem,2.5vw,1.8rem);}
.step__head{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem;}
.step__num{flex:0 0 auto;width:2.1rem;height:2.1rem;border-radius:50%;background:var(--marsch);color:#fff;font-family:var(--font-display);font-weight:600;display:grid;place-content:center;}
.step__title{font-family:var(--font-display);font-size:1.3rem;color:var(--marsch-tief);}
.step__hint{font-size:.85rem;color:var(--nebel);margin-left:auto;}
.choice{display:block;position:relative;cursor:pointer;margin-bottom:.7rem;}
.choice:last-child{margin-bottom:0;}
.choice input{position:absolute;opacity:0;inset:0;cursor:pointer;}
.choice__card{
  border:1.5px solid var(--linie);border-radius:var(--radius-s);padding:.9rem 1.1rem;
  display:flex;align-items:flex-start;gap:.85rem;transition:border-color .2s,background .2s,box-shadow .2s;background:var(--reet);
}
.choice__tick{flex:0 0 auto;width:1.3rem;height:1.3rem;border-radius:50%;border:2px solid var(--nebel);margin-top:.15rem;display:grid;place-content:center;transition:.2s;}
.choice__tick::after{content:"";width:.55rem;height:.55rem;border-radius:50%;background:#fff;transform:scale(0);transition:transform .2s var(--ease);}
.choice__name{font-weight:600;color:var(--tinte);}
.choice__desc{font-size:.88rem;color:var(--tinte-weich);margin-top:.15rem;}
.choice input:checked + .choice__card{border-color:var(--ziegel);background:#fff;box-shadow:0 0 0 2px rgba(168,84,58,.18);}
.choice input:checked + .choice__card .choice__tick{border-color:var(--ziegel);background:var(--ziegel);}
.choice input:checked + .choice__card .choice__tick::after{transform:scale(1);}
.choice input:focus-visible + .choice__card{outline:3px solid var(--korn);outline-offset:2px;}

/* Summary "Menükarte" — sticky on desktop */
.summary{position:sticky;top:96px;}
.summary-card{
  background:var(--reet-hell);border:1px solid var(--korn);border-radius:var(--radius);
  padding:clamp(1.4rem,3vw,2rem);box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.summary-card::before,.summary-card::after{content:"";position:absolute;left:1.4rem;right:1.4rem;height:1px;background:repeating-linear-gradient(90deg,var(--korn) 0 6px,transparent 6px 12px);opacity:.5;}
.summary-card::before{top:1rem;}
.summary-card::after{bottom:1rem;}
.summary-card__kicker{text-align:center;font-family:var(--font-display);font-style:italic;color:var(--ziegel);margin-bottom:.2rem;}
.summary-card__title{text-align:center;font-family:var(--font-display);font-size:1.5rem;color:var(--marsch-tief);margin-bottom:1.2rem;}
.summary-line{padding:.7rem 0;border-bottom:1px dotted var(--linie);}
.summary-line:last-of-type{border-bottom:0;}
.summary-line .ico{font-style:italic;font-family:var(--font-display);color:var(--ziegel);font-size:.9rem;display:block;}
.summary-line .val{color:var(--tinte);font-weight:600;}
.summary-line .empty{color:var(--nebel);font-weight:400;font-style:italic;}
.summary__count{text-align:center;font-size:.85rem;color:var(--tinte-weich);margin:1rem 0;}
.summary__count b{color:var(--marsch-tief);}
.summary__actions{display:grid;gap:.6rem;margin-top:1rem;}
@media (max-width:900px){.builder{grid-template-columns:1fr;}.summary{position:static;}}

/* ---------- Standort / info ---------- */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,3vw,2.4rem);align-items:stretch;}
.info-card{background:var(--reet-hell);border:1px solid var(--linie);border-radius:var(--radius);padding:clamp(1.4rem,3vw,2rem);}
.info-card h3{display:flex;align-items:center;gap:.6rem;}
.info-card .ic{width:1.4rem;height:1.4rem;color:var(--ziegel);}
.contact-list{list-style:none;padding:0;margin:0;display:grid;gap:.7rem;}
.contact-list a{color:var(--marsch-tief);text-decoration:none;font-weight:600;}
.contact-list a:hover{color:var(--ziegel);}
.hours-table{width:100%;border-collapse:collapse;}
.hours-table th,.hours-table td{text-align:left;padding:.5rem 0;border-bottom:1px dotted var(--linie);}
.hours-table td:last-child{text-align:right;font-weight:600;color:var(--marsch-tief);}
.hours-table tr.is-today td{color:var(--ziegel);}
.hours-table tr.is-rest td:last-child{color:var(--nebel);font-style:italic;font-weight:400;}
.map-placeholder{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--linie);min-height:260px;background:var(--reet-tief);}
.map-placeholder svg{width:100%;height:100%;display:block;}
.map-placeholder .pin{position:absolute;left:50%;top:48%;transform:translate(-50%,-100%);color:var(--ziegel);width:2.4rem;height:2.4rem;filter:drop-shadow(0 6px 8px rgba(0,0,0,.25));}
.map-placeholder .map-note{position:absolute;left:0;right:0;bottom:0;background:rgba(42,64,60,.85);color:var(--reet);font-size:.8rem;padding:.5rem .8rem;text-align:center;}
@media (max-width:760px){.info-grid{grid-template-columns:1fr;}}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem;margin-top:1.5rem;}
.faq__item{background:var(--reet-hell);border:1px solid var(--linie);border-radius:var(--radius-s);overflow:hidden;}
.faq__q{cursor:pointer;list-style:none;padding:1.05rem 1.3rem;font-family:var(--font-display);font-size:1.1rem;color:var(--marsch-tief);display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.faq__q::-webkit-details-marker{display:none;}
.faq__q .plus{flex:0 0 auto;width:1.3rem;height:1.3rem;position:relative;transition:transform .3s var(--ease);}
.faq__q .plus::before,.faq__q .plus::after{content:"";position:absolute;inset:0;margin:auto;background:var(--ziegel);}
.faq__q .plus::before{width:100%;height:2px;}
.faq__q .plus::after{width:2px;height:100%;}
.faq__item[open] .faq__q .plus{transform:rotate(135deg);}
.faq__a{padding:0 1.3rem 1.2rem;color:var(--tinte-weich);}
.faq__a p:last-child{margin-bottom:0;}

/* ---------- Forms ---------- */
.form{display:grid;gap:1.1rem;}
.field{display:grid;gap:.4rem;}
.field__row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;}
.field label{font-weight:600;font-size:.95rem;color:var(--marsch-tief);}
.field .req{color:var(--ziegel);}
.field input,.field textarea,.field select{
  font-family:inherit;font-size:1rem;color:var(--tinte);
  background:var(--reet-hell);border:1.5px solid var(--linie);border-radius:var(--radius-s);
  padding:.8rem 1rem;width:100%;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ziegel);box-shadow:0 0 0 3px rgba(168,84,58,.15);}
.field textarea{min-height:140px;resize:vertical;}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.consent{display:flex;align-items:flex-start;gap:.7rem;font-size:.92rem;color:var(--tinte-weich);}
.consent input{margin-top:.25rem;width:1.15rem;height:1.15rem;flex:0 0 auto;accent-color:var(--ziegel);}
.form__note{font-size:.82rem;color:var(--nebel);}
.form__status{display:none;padding:.9rem 1.1rem;border-radius:var(--radius-s);font-weight:500;}
.form__status.ok{display:block;background:rgba(94,154,100,.15);border:1px solid #5e9a64;color:#356b3a;}
.form__status.err{display:block;background:rgba(168,84,58,.12);border:1px solid var(--ziegel);color:var(--ziegel-tief);}
@media (max-width:560px){.field__row{grid-template-columns:1fr;}}

/* ---------- Callout / CTA band ---------- */
.callout{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--marsch);color:#fff;padding:clamp(2rem,5vw,3.5rem);text-align:center;}
.callout h2{color:#fff;}
.callout .lead{color:rgba(255,255,255,.85);margin-inline:auto;}
.callout__actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-top:1.6rem;}

/* ---------- Footer ---------- */
.site-footer{background:var(--marsch-tief);color:#cdd8d2;}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(1.6rem,4vw,3rem);padding-block:clamp(2.6rem,5vw,4rem);}
.footer__brand .brand__name,.footer__brand .brand__sub{color:#fff;}
.footer__brand .brand{color:#fff;}
.footer p{color:rgba(255,255,255,.72);}
.footer h4{font-family:var(--font-display);color:var(--korn-hell);font-size:1.05rem;margin:0 0 1rem;font-weight:600;}
.footer__list{list-style:none;padding:0;margin:0;display:grid;gap:.55rem;}
.footer__list a{color:rgba(255,255,255,.82);text-decoration:none;}
.footer__list a:hover{color:#fff;}
.footer__nap{font-style:normal;line-height:1.8;color:rgba(255,255,255,.82);}
.footer__nap a{color:rgba(255,255,255,.82);text-decoration:none;}
.footer__nap a:hover{color:#fff;}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:1.3rem;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;align-items:center;justify-content:space-between;font-size:.85rem;color:rgba(255,255,255,.6);}
.footer__bottom a{color:rgba(255,255,255,.7);text-decoration:none;}
.footer__bottom a:hover{color:#fff;}
.footer__legal{display:flex;flex-wrap:wrap;gap:1.2rem;}
@media (max-width:760px){.footer__grid{grid-template-columns:1fr 1fr;}.footer__brand{grid-column:1/-1;}}
@media (max-width:480px){.footer__grid{grid-template-columns:1fr;}}

/* ---------- Reveal on scroll (reduced-motion safe) ---------- */
/* KEIN Entrance-Hide. Inhalt ist IMMER voll sichtbar.
   Jede opacity:0-Variante (JS-gated via IntersectionObserver, oder CSS-Animation mit
   fill:both) kann in Hintergrund-Tabs / Headless / bei JS-Aussetzern auf 0 „hängen
   bleiben" → leere Seite. Darum bewusst entfernt. Dezente Microinteractions bleiben
   über :hover-Transitions an Karten/Buttons (verstecken nie Inhalt). */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;}
  .btn,.card,.day-card{transition:none!important;}
}

/* gentle sway for leaf motifs (paused for reduced-motion via above) */
@keyframes sway{0%,100%{transform:rotate(-2deg);}50%{transform:rotate(2deg);}}
.leaf--anim{transform-origin:bottom center;animation:sway 7s ease-in-out infinite;}

/* breadcrumb / page hero */
.page-hero{position:relative;background:var(--marsch-tief);color:var(--reet);padding-block:clamp(3rem,7vw,5.5rem) clamp(2rem,4vw,3rem);overflow:hidden;}
.page-hero h1{color:#fff;}
.page-hero .eyebrow{color:var(--korn-hell);}
.page-hero .lead{color:rgba(255,255,255,.82);}
.breadcrumb{font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:1rem;}
.breadcrumb a{color:rgba(255,255,255,.75);text-decoration:none;}
.breadcrumb a:hover{color:#fff;}

/* helpers */
.stack-lg>*+*{margin-top:1.4rem;}
.tag{display:inline-block;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--marsch);background:rgba(110,140,134,.16);border-radius:999px;padding:.3rem .7rem;font-weight:600;}
