/* ==========================================================================
   NAVIN — Pizza · Grill · Bar | Design-System (gemeinsam fuer alle Seiten)
   Palette/Typo aus der gedruckten Speisekarte abgeleitet (SPEC §2).
   ========================================================================== */

:root{
  --gruen-900:#0A3527;
  --gruen-800:#0B3B2E;
  --gruen-950:#072A1F;              /* Footer, eine Stufe dunkler */
  --gruen-tinte:#14291F;            /* Fliesstext auf Creme */
  --gold-500:#C6A15B;
  --gold-600:#8A6520;               /* Gold-Text auf Creme (AA-konform fuer jede Textgroesse) */
  --gold-300:#D9BC85;               /* grosses/dekoratives Gold auf Gruen */
  --creme-100:#F6F0E1;
  --creme-50:#FBF7EC;
  --hairline:color-mix(in srgb, var(--gold-500) 40%, transparent);
  --hairline-strong:color-mix(in srgb, var(--gold-500) 65%, transparent);
  --container:72rem;
  --container-menu:46rem;
  --header-h:4rem;
  --catnav-h:3rem;
  --s1:.25rem; --s2:.5rem; --s3:1rem; --s4:1.5rem;
  --s5:2rem; --s6:3rem; --s7:4rem; --s8:6rem;
  --sec-pad:clamp(4rem,10vw,7rem);
  --font-display:'Cinzel','Cinzel Fallback',Georgia,serif;
  --font-serif:'Cormorant Garamond','Cormorant Fallback',Georgia,'Times New Roman',serif;
  --font-sans:'Inter','Inter Fallback',system-ui,-apple-system,'Segoe UI',sans-serif;
}

/* --- Basis ------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:1rem;
  line-height:1.65;
  color:var(--gruen-tinte);
  background:var(--creme-100);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;height:auto}
a{color:inherit}
p{margin:0 0 var(--s3)}
ul,ol{margin:0;padding:0}
h1,h2,h3,h4{margin:0 0 var(--s3);line-height:1.15;font-weight:700}
b,strong{font-weight:600}
:focus-visible{outline:2px solid var(--gold-500);outline-offset:3px;border-radius:2px}
[id]{scroll-margin-top:calc(var(--header-h) + 1rem)}
#menu [id],.menu-cat[id]{scroll-margin-top:calc(var(--header-h) + var(--catnav-h) + 1rem)} /* Anker unter sticky Catnav: index (#menu) + getraenke (Kategorie-Sections) */

.visually-hidden{
  position:absolute;width:1px;height:1px;margin:-1px;padding:0;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
}
.legend-src{margin:.75rem 0 0;font-size:.8rem;opacity:.75}
.subcat-title--highlight{
  border-block:1px solid var(--hairline);padding-block:.6rem;
  color:var(--gruen-900);
}
.menu-foot--group{font-size:.85rem;margin-top:calc(var(--s3) * -0.25);text-align:center;opacity:.85}
.container{max-width:var(--container);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.container--menu{max-width:var(--container-menu)}

/* Sektionsflaechen: gruen <-> creme im Wechsel */
.sec{padding-block:var(--sec-pad)}
.sec--green{background:var(--gruen-800);color:var(--creme-100)}
.sec--green-deep{background:var(--gruen-900);color:var(--creme-100)}
.sec--creme{background:var(--creme-100);color:var(--gruen-tinte)}
.sec--creme-light{background:var(--creme-50);color:var(--gruen-tinte)}

/* Typo-Rollen */
.label-caps{
  font-family:var(--font-display);
  font-weight:400;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.sec-title{
  font-family:var(--font-display);
  font-weight:400;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:clamp(1.5rem,3.4vw,2.2rem);
  text-align:center;
  margin-bottom:var(--s3);
}
.sec--green .sec-title,.sec--green-deep .sec-title{color:var(--gold-300)}
.sec--creme .sec-title,.sec--creme-light .sec-title{color:var(--gruen-900)}
.sec-kicker{
  display:block;
  font-family:var(--font-sans);
  font-weight:600;
  font-size:.75rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  text-align:center;
  margin-bottom:var(--s2);
}
.sec--creme .sec-kicker,.sec--creme-light .sec-kicker{color:var(--gold-600)}
.sec--green .sec-kicker,.sec--green-deep .sec-kicker{color:var(--gold-300)}

/* Gold-Trenner (Haarlinie — Ornament — Haarlinie) */
.orn-divider{
  display:block;
  width:min(16rem,70%);
  margin:0 auto var(--s5);
  color:var(--gold-500);
}
.orn-divider svg{display:block;width:100%}

/* --- Skip-Link ---------------------------------------------------------- */
.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--gold-500);color:var(--gruen-900);
  padding:.6rem 1rem;font-weight:600;z-index:200;border-radius:0 0 4px 0;
}
.skip-link:focus{left:0}

/* --- Header ------------------------------------------------------------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--gruen-900);
  color:var(--creme-100);
  border-bottom:1px solid var(--hairline);
  min-height:var(--header-h);
}
.header-inner{
  display:flex;align-items:center;gap:var(--s4);
  max-width:var(--container);margin-inline:auto;
  padding:.5rem clamp(1rem,4vw,2rem);
  min-height:var(--header-h);
}
.brand{display:flex;align-items:center;gap:.65rem;text-decoration:none;color:inherit}
.brand-signet{width:2.4rem;height:2.4rem;color:var(--gold-300);flex:none}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:.08em;color:var(--creme-50)}
.brand-tag{font-family:var(--font-display);font-weight:400;font-size:.58rem;letter-spacing:.3em;color:var(--gold-300);text-transform:uppercase}
.main-nav{display:none;margin-left:auto}
.main-nav a{
  text-decoration:none;font-weight:600;font-size:.92rem;color:var(--creme-100);
  padding:.4rem .1rem;margin-inline:.75rem;position:relative;
}
.main-nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;
  background:var(--gold-300);transition:right .3s ease;
}
.main-nav a:hover::after,.main-nav a:focus-visible::after{right:0}
.btn-reserve{margin-left:auto}

/* Buttons */
.btn{
  display:inline-block;text-decoration:none;font-family:var(--font-sans);
  font-weight:600;font-size:.95rem;letter-spacing:.04em;
  padding:.75rem 1.5rem;border-radius:2px;
  transition:transform .25s ease,background-color .25s ease,color .25s ease,box-shadow .25s ease;
}
.btn--gold{background:var(--gold-500);color:var(--gruen-900);border:1px solid var(--gold-500)}
.btn--gold:hover,.btn--gold:focus-visible{background:var(--gold-300);transform:translateY(-1px)}
.btn--outline{background:transparent;color:var(--creme-100);border:1px solid var(--hairline-strong)}
.btn--outline:hover,.btn--outline:focus-visible{border-color:var(--gold-300);color:var(--gold-300)}
.btn--outline-dark{background:transparent;color:var(--gruen-900);border:1px solid var(--gold-600)}
.btn--outline-dark:hover,.btn--outline-dark:focus-visible{background:var(--gold-500);color:var(--gruen-900)}
.btn--small{padding:.45rem .9rem;font-size:.85rem}
.site-header .btn-reserve{display:none}

/* Mobiles Nav als <details> — funktioniert ohne JS */
.mobile-nav{position:relative;margin-left:auto}
.mobile-nav summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;gap:.5rem;
  padding:.5rem;color:var(--creme-100);font-weight:600;font-size:.9rem;
  border:1px solid var(--hairline);border-radius:2px;
}
.mobile-nav summary::-webkit-details-marker{display:none}
.mobile-nav .nav-icon{width:1.2rem;height:1.2rem;color:var(--gold-300)}
.mobile-nav-panel{
  position:absolute;right:0;top:calc(100% + .5rem);
  min-width:14rem;background:var(--gruen-900);
  border:1px solid var(--hairline);border-radius:2px;
  padding:.75rem;display:flex;flex-direction:column;gap:.15rem;
  box-shadow:0 12px 30px rgba(0,0,0,.35);
}
.mobile-nav-panel a{
  text-decoration:none;color:var(--creme-100);font-weight:600;font-size:.95rem;
  padding:.6rem .75rem;border-radius:2px;
}
.mobile-nav-panel a:hover,.mobile-nav-panel a:focus-visible{background:var(--gruen-800);color:var(--gold-300)}
.mobile-nav-panel .btn{margin-top:.5rem;text-align:center}

@media (min-width:56rem){
  .main-nav{display:block}
  .mobile-nav{display:none}
  .site-header .btn-reserve{display:inline-block;margin-left:0}
}

/* --- Mobile Bottom-Action-Bar (nur < 768 px) ---------------------------- */
.bottom-bar{display:none}
@media (max-width:47.99rem){
  body{padding-bottom:calc(3.5rem + env(safe-area-inset-bottom))}
  .bottom-bar{
    display:grid;grid-template-columns:1fr 1fr 1fr;
    position:fixed;left:0;right:0;bottom:0;z-index:110;
    background:var(--gruen-900);
    border-top:1px solid var(--hairline);
    padding-bottom:env(safe-area-inset-bottom);
  }
  .bottom-bar a{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;
    padding:.5rem .25rem;text-decoration:none;color:var(--creme-100);
    font-size:.7rem;font-weight:600;letter-spacing:.02em;min-height:3.5rem;
  }
  .bottom-bar a svg{width:1.25rem;height:1.25rem;color:var(--gold-300)}
  .bottom-bar a:active{background:var(--gruen-800)}
}

/* --- Hero ---------------------------------------------------------------- */
.hero{
  position:relative;
  background:var(--gruen-800);
  color:var(--creme-100);
  padding-block:clamp(3rem,8vw,6.5rem);
  overflow:hidden;
}
.hero-frame{
  position:relative;
  max-width:var(--container);margin-inline:auto;
  padding:clamp(1.5rem,5vw,3.5rem) clamp(1rem,4vw,2.5rem);
}
.orn-corner{
  position:absolute;width:clamp(2.6rem,6vw,4.2rem);height:clamp(2.6rem,6vw,4.2rem);
  color:var(--gold-500);pointer-events:none;
}
.orn-corner svg{display:block;width:100%;height:100%}
.orn-corner--tl{top:0;left:0}
.orn-corner--tr{top:0;right:0;transform:scaleX(-1)}
.orn-corner--bl{bottom:0;left:0;transform:scaleY(-1)}
.orn-corner--br{bottom:0;right:0;transform:scale(-1)}
.hero-grid{display:grid;gap:clamp(2rem,5vw,4rem);align-items:center}
@media (min-width:60rem){.hero-grid{grid-template-columns:1.15fr .85fr}}
.hero-title{margin:0 0 var(--s4)}
.hero-title .hero-brand{
  display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(3rem,9vw,5.5rem);letter-spacing:.1em;color:var(--creme-50);
}
.hero-title .hero-what{
  display:block;margin-top:var(--s3);
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(.95rem,2.4vw,1.35rem);letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-300);
}
.hero-sub{
  font-family:var(--font-serif);font-weight:600;
  font-size:clamp(1.2rem,2.6vw,1.55rem);line-height:1.45;
  max-width:34em;margin-bottom:var(--s5);
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:var(--s3);margin-bottom:var(--s4)}
.hero-status{font-size:.9rem;color:var(--gold-300);margin:0}
.hero-media{position:relative}
.hero-media .ph{margin:0;aspect-ratio:4/5;max-height:26rem}
.hero .clip-mask{overflow:hidden;display:block}

/* --- Bild-Platzhalter (AK3) --------------------------------------------- */
.ph{
  display:flex;align-items:center;justify-content:center;text-align:center;
  background:var(--creme-50);
  border:1px solid var(--hairline);
  outline:1px solid var(--hairline);outline-offset:-8px;
  color:var(--gruen-tinte);
  min-height:10rem;margin:0;
  padding:var(--s4);
}
.ph figcaption{font-size:.8rem;letter-spacing:.04em;line-height:1.5;opacity:.75}

/* --- Signature ----------------------------------------------------------- */
.sig-grid{display:grid;gap:var(--s4)}
@media (min-width:48rem){
  .sig-grid{grid-template-columns:repeat(12,1fr)}
  .sig-card:nth-child(1){grid-column:1/span 7}
  .sig-card:nth-child(2){grid-column:8/span 5;margin-top:var(--s6)}
  .sig-card:nth-child(3){grid-column:1/span 5;margin-top:calc(var(--s6) * -1)}
  .sig-card:nth-child(4){grid-column:6/span 7}
}
.sig-card{
  border:1px solid var(--hairline);
  background:var(--creme-50);
  padding:var(--s5) var(--s4);
  display:flex;flex-direction:column;gap:var(--s2);
}
.sig-card h3{
  font-family:var(--font-serif);font-weight:600;
  font-size:clamp(1.35rem,2.6vw,1.7rem);margin:0;
}
.sig-card p{margin:0;font-size:.95rem}
.sig-price{
  font-weight:600;font-variant-numeric:tabular-nums;
  color:var(--gold-600);font-size:1.05rem;margin-top:auto;
}

/* --- Menue (Herzstueck) --------------------------------------------------- */
.catnav{
  position:sticky;top:var(--header-h);z-index:90;
  background:color-mix(in srgb, var(--creme-100) 92%, transparent);
  backdrop-filter:blur(6px);
  border-block:1px solid var(--hairline);
  min-height:var(--catnav-h);
}
.catnav ul{
  display:flex;gap:var(--s2);list-style:none;
  overflow-x:auto;scrollbar-width:thin;
  max-width:var(--container);margin-inline:auto;
  padding:.5rem clamp(1rem,4vw,2rem);
  -webkit-overflow-scrolling:touch;
}
.catnav a{
  display:block;white-space:nowrap;text-decoration:none;
  font-weight:600;font-size:.85rem;color:var(--gruen-tinte);
  padding:.35rem .8rem;border:1px solid transparent;border-radius:999px;
  transition:border-color .25s ease,color .25s ease,background-color .25s ease;
}
.catnav a:hover,.catnav a:focus-visible{border-color:var(--hairline-strong)}
.catnav a.is-active{border-color:var(--gold-600);color:var(--gold-600)}

.menu-cat{padding-block:var(--s6) var(--s3)}
.cat-head{text-align:center;margin-bottom:var(--s5)}
.cat-title{
  font-family:var(--font-display);font-weight:400;letter-spacing:.14em;text-transform:uppercase;
  font-size:clamp(1.2rem,2.6vw,1.6rem);color:var(--gruen-900);margin-bottom:var(--s2);
}
.cat-title .cat-en{
  display:block;margin-top:.35rem;
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  font-size:.72em;letter-spacing:.1em;color:var(--gold-600);text-transform:none;
}
.subcat-title{
  font-family:var(--font-display);font-weight:400;letter-spacing:.14em;text-transform:uppercase;
  text-align:center;font-size:1.02rem;color:var(--gold-600);
  margin:var(--s6) 0 var(--s4);
}
.menu-list{list-style:none;display:flex;flex-direction:column;gap:var(--s4)}
.menu-item{border-bottom:1px solid transparent}
.item-head{display:flex;align-items:baseline;gap:.6rem}
.item-name{
  font-family:var(--font-serif);font-weight:600;
  font-size:1.28rem;line-height:1.25;min-width:0;
}
.item-head::after{
  content:"";flex:1 1 1.5rem;min-width:1.5rem;order:2;
  border-bottom:1px dotted var(--hairline-strong);
  transform:translateY(-.28em);
}
.item-name{order:1}
.item-price{
  order:3;white-space:nowrap;
  font-weight:600;font-variant-numeric:tabular-nums;
  color:var(--gold-600);font-size:1.05rem;
}
.item-price--pair{display:inline-flex;gap:1rem}
.item-price--pair small,.item-size{
  font-weight:400;font-size:.72rem;color:var(--gruen-tinte);opacity:.75;letter-spacing:.02em;
}
.item-desc{margin:.35rem 0 0;font-size:.95rem;max-width:60ch}
.item-desc--en{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  font-size:1.02rem;opacity:.85;
}
.item-meta{margin:.4rem 0 0;display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;font-size:.78rem}
.item-allergens{
  letter-spacing:.08em;font-weight:600;color:var(--gruen-tinte);opacity:.7;
}
.item-allergens::before{content:"Allergene: ";font-weight:400;letter-spacing:.02em}
.badge-vegan{
  display:inline-block;font-weight:600;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gruen-900);background:color-mix(in srgb, var(--gold-500) 28%, var(--creme-50));
  border:1px solid var(--hairline-strong);border-radius:999px;padding:.1rem .6rem;
}
.item-size{font-size:.78rem}

.menu-note{
  border:1px solid var(--hairline);
  background:var(--creme-50);
  padding:var(--s3) var(--s4);
  text-align:center;font-size:.92rem;
  margin:0 0 var(--s5);
}
.menu-note .note-en{
  display:block;font-family:var(--font-serif);font-style:italic;font-weight:500;font-size:1rem;opacity:.85;
}
.menu-foot{margin-top:var(--s6);text-align:center;font-size:.92rem}
.allergen-note{
  max-width:46rem;margin:var(--s6) auto var(--s3);
  text-align:center;font-size:.92rem;
  border:1px solid var(--hairline);
  background:var(--creme-50);
  padding:var(--s3) var(--s4);
}
.allergen-legend{
  max-width:46rem;margin:0 auto var(--s4);
  border:1px solid var(--hairline);
  background:var(--creme-50);
}
.allergen-legend summary{
  cursor:pointer;padding:var(--s3) var(--s4);
  font-weight:600;font-size:.95rem;color:var(--gruen-900);
}
.allergen-legend[open] summary{border-bottom:1px solid var(--hairline)}
.allergen-legend .legend-body{padding:var(--s3) var(--s4)}
.legend-table{width:100%;border-collapse:collapse;font-size:.88rem}
.legend-table th,.legend-table td{
  text-align:left;padding:.4rem .6rem;border-bottom:1px solid var(--hairline);vertical-align:top;
}
.legend-table th{font-family:var(--font-sans);font-weight:600;width:3rem}
.pdf-links{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--s3);margin-top:var(--s4)}
.pdf-links a{
  display:inline-flex;align-items:center;gap:.5rem;
  text-decoration:none;font-weight:600;font-size:.92rem;color:var(--gruen-900);
  border:1px solid var(--gold-600);border-radius:2px;padding:.6rem 1.1rem;
  transition:background-color .25s ease,color .25s ease;
}
.pdf-links a:hover,.pdf-links a:focus-visible{background:var(--gold-500);color:var(--gruen-900)}
.pdf-links svg{width:1.1rem;height:1.1rem;flex:none}

/* --- Bar-Teaser (gruen) --------------------------------------------------- */
.bar-highlights{
  list-style:none;display:grid;gap:var(--s3);
  max-width:38rem;margin:0 auto var(--s5);
}
.bar-highlight{
  display:flex;align-items:baseline;gap:.6rem;
  border-bottom:1px solid var(--hairline);padding-bottom:var(--s3);
}
.bar-highlight .bh-name{font-family:var(--font-serif);font-weight:600;font-size:1.2rem;order:1;min-width:0}
.bar-highlight::after{
  content:"";flex:1 1 1.5rem;min-width:1.5rem;order:2;
  border-bottom:1px dotted var(--hairline);transform:translateY(-.28em);
}
.bar-highlight .bh-price{
  order:3;white-space:nowrap;font-weight:600;font-variant-numeric:tabular-nums;color:var(--creme-50);
}
.center{text-align:center}

/* --- Ueber uns / Fakten --------------------------------------------------- */
.fact-list{list-style:none;display:grid;gap:var(--s3);max-width:38rem;margin:var(--s5) auto 0}
.fact-list li{display:flex;gap:.75rem;align-items:flex-start}
.fact-list svg{width:1.1rem;height:1.1rem;flex:none;color:var(--gold-600);margin-top:.25rem}
.placeholder-text{
  border:1px dashed var(--hairline-strong);
  padding:var(--s4);text-align:center;font-size:.95rem;
  max-width:38rem;margin:0 auto;
  color:var(--gruen-tinte);background:var(--creme-50);
}
.sec--green .placeholder-text,.sec--green-deep .placeholder-text{
  color:var(--creme-100);background:transparent;
}

/* --- Galerie -------------------------------------------------------------- */
.gallery-grid{display:grid;gap:var(--s3)}
@media (min-width:48rem){
  .gallery-grid{grid-template-columns:repeat(12,1fr)}
  .gallery-grid figure:nth-child(1){grid-column:1/span 7;min-height:16rem}
  .gallery-grid figure:nth-child(2){grid-column:8/span 5}
  .gallery-grid figure:nth-child(3){grid-column:1/span 4}
  .gallery-grid figure:nth-child(4){grid-column:5/span 4;min-height:14rem}
  .gallery-grid figure:nth-child(5){grid-column:9/span 4}
  .gallery-grid figure:nth-child(6){grid-column:1/span 12;min-height:12rem}
}
.sec--green .ph,.sec--green-deep .ph{
  background:var(--gruen-900);color:var(--creme-100);
  border-color:var(--hairline);
}

/* --- FAQ ------------------------------------------------------------------ */
.faq-list{max-width:46rem;margin-inline:auto}
.faq-item{border-bottom:1px solid var(--hairline)}
.faq-item summary{
  cursor:pointer;list-style:none;position:relative;
  padding:var(--s4) var(--s6) var(--s4) 0;
  font-family:var(--font-serif);font-weight:600;font-size:1.2rem;color:var(--gruen-900);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";position:absolute;right:.25rem;top:50%;transform:translateY(-50%);
  font-family:var(--font-sans);font-weight:400;font-size:1.4rem;color:var(--gold-600);
}
.faq-item[open] summary::after{content:"–"}
.faq-answer{padding:0 0 var(--s4);max-width:60ch}

/* --- Kontakt ---------------------------------------------------------------- */
.contact-grid{display:grid;gap:var(--s6)}
@media (min-width:56rem){.contact-grid{grid-template-columns:1.1fr .9fr}}
.contact-nap{
  font-family:var(--font-serif);font-weight:600;font-style:normal;
  font-size:clamp(1.3rem,2.6vw,1.7rem);line-height:1.5;margin-bottom:var(--s4);
}
.contact-actions{display:flex;flex-wrap:wrap;gap:var(--s3);margin-bottom:var(--s3)}
.contact-note{font-size:.95rem;margin-bottom:var(--s2)}
.contact-note a{color:var(--gold-300);font-weight:600;text-decoration-color:var(--hairline-strong)}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.hours-table{width:100%;border-collapse:collapse;font-size:.95rem;min-width:16rem}
.hours-table caption{
  text-align:left;font-family:var(--font-display);font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;color:var(--gold-300);
  padding-bottom:var(--s3);font-size:1rem;
}
.hours-table th,.hours-table td{
  text-align:left;padding:.55rem .5rem;border-bottom:1px solid var(--hairline);
}
.hours-table th{font-weight:600}

/* --- Footer ------------------------------------------------------------------ */
.site-footer{
  background:var(--gruen-950);color:var(--creme-100);
  padding:var(--s7) 0 var(--s6);font-size:.92rem;
}
.footer-grid{display:grid;gap:var(--s5)}
@media (min-width:48rem){.footer-grid{grid-template-columns:1.2fr 1fr 1fr}}
.footer-nap{font-style:normal;line-height:1.7}
.footer-nap a{color:inherit}
.footer-nap .nap-name{font-family:var(--font-display);font-weight:400;letter-spacing:.1em;font-size:1rem;color:var(--gold-300);display:block;margin-bottom:.35rem}
.footer-h{font-family:var(--font-sans);font-weight:600;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-300);margin-bottom:var(--s3)}
.footer-links{list-style:none;display:grid;gap:.4rem}
.footer-links a{color:var(--creme-100);text-decoration:none}
.footer-links a:hover,.footer-links a:focus-visible{color:var(--gold-300);text-decoration:underline}
.footer-bottom{
  border-top:1px solid var(--hairline);margin-top:var(--s5);padding-top:var(--s4);
  display:flex;flex-wrap:wrap;gap:var(--s3);justify-content:space-between;font-size:.85rem;
}
.footer-bottom a{color:var(--creme-100)}

/* --- Unterseiten (Karten/Rechtstexte) ---------------------------------------- */
.page-hero{
  background:var(--gruen-800);color:var(--creme-100);
  padding-block:clamp(2.5rem,7vw,4.5rem);text-align:center;
}
.page-hero h1{
  font-family:var(--font-display);font-weight:700;letter-spacing:.08em;
  font-size:clamp(1.7rem,4.5vw,2.6rem);margin-bottom:var(--s2);
}
.page-hero p{max-width:46rem;margin:0 auto;font-family:var(--font-serif);font-weight:600;font-size:1.15rem}
.legal{max-width:46rem;margin-inline:auto}
.legal h2{
  font-family:var(--font-display);font-weight:400;letter-spacing:.1em;text-transform:uppercase;
  font-size:1.15rem;color:var(--gruen-900);margin:var(--s6) 0 var(--s3);
}
.legal ul{padding-left:1.2rem;display:grid;gap:.35rem}

/* ==========================================================================
   Motion (SPEC §6) — Inhalte sind OHNE JS/IO/bei reduced-motion sofort
   sichtbar: alle Verstecke haengen ausschliesslich an .has-io.
   ========================================================================== */
.has-io .reveal{transition:opacity .7s ease,transform .7s ease}
.has-io .reveal--rise:not(.is-in){opacity:0;transform:translateY(24px)}
.has-io .reveal--fade:not(.is-in){opacity:0}
.has-io .reveal--scale:not(.is-in){opacity:0;transform:scale(.97)}
.has-io .reveal--clip{transition:clip-path .9s cubic-bezier(.2,.6,.2,1),opacity .9s ease}
.has-io .reveal--clip:not(.is-in){clip-path:inset(0 0 92% 0);opacity:0}
.has-io .reveal--clip.is-in{clip-path:inset(0 0 0% 0)}

/* Gestaffeltes Rise (Signature, Galerie) */
.has-io .stagger>*{transition:opacity .65s ease,transform .65s ease}
.has-io .stagger:not(.is-in)>*{opacity:0;transform:translateY(24px)}
.has-io .stagger.is-in>*:nth-child(1){transition-delay:0ms}
.has-io .stagger.is-in>*:nth-child(2){transition-delay:80ms}
.has-io .stagger.is-in>*:nth-child(3){transition-delay:160ms}
.has-io .stagger.is-in>*:nth-child(4){transition-delay:240ms}
.has-io .stagger.is-in>*:nth-child(5){transition-delay:320ms}
.has-io .stagger.is-in>*:nth-child(6){transition-delay:400ms}

/* Linien-Draw fuer Ornament-Trenner + Hero-Ecken (pathLength="1" im SVG) */
.has-io .reveal--draw path{
  stroke-dasharray:1;stroke-dashoffset:0;
  transition:stroke-dashoffset 1.1s ease .1s;
}
.has-io .reveal--draw:not(.is-in) path{stroke-dashoffset:1}

/* Hero: Headline-Rise unter clip-Maske */
.has-io .mask-rise .mask-line{transition:transform .8s cubic-bezier(.2,.65,.25,1)}
.has-io .mask-rise:not(.is-in) .mask-line{transform:translateY(110%)}
.has-io .mask-rise.is-in .mask-line{transform:translateY(0)}
.has-io .mask-rise .mask-line--2{transition-delay:.12s}
.has-io .mask-rise .mask-line--3{transition-delay:.24s}

/* Parallax nur auf der Hero-Bildflaeche */
.hero-media [data-parallax]{will-change:transform}

/* Reduced Motion: alles statisch & voll nutzbar (Doppelschutz zu den JS-Guards) */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.001s !important;
    animation-iteration-count:1 !important;
    transition-duration:.001s !important;
  }
  .has-io .reveal:not(.is-in),
  .has-io .stagger:not(.is-in)>*,
  .has-io .mask-rise:not(.is-in) .mask-line{opacity:1;transform:none;clip-path:none}
  .has-io .reveal--draw:not(.is-in) path{stroke-dashoffset:0}
}

@media print{
  .site-header,.bottom-bar,.catnav,.skip-link{display:none}
  .sec{padding-block:1.5rem}
}
