/* =============================================================================
   Mini's Bistro & Cafe — style.css
   Design System · Mitternachtsblau & Cremeweiß
   Production stylesheet · mobile-first · 2026 techniques
   ============================================================================= */

/* ── 1. SELF-HOSTED FONT (Cormorant Garamond — SIL OFL) ────────────────────── */
@font-face{
  font-family:'Cormorant Garamond';
  font-style:normal;font-weight:400;font-display:swap;
  src:url('fonts/cormorant-garamond-400.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Cormorant Garamond';
  font-style:italic;font-weight:400;font-display:swap;
  src:url('fonts/cormorant-garamond-400-italic.woff2') format('woff2');
}
@font-face{
  font-family:'Cormorant Garamond';
  font-style:normal;font-weight:500;font-display:swap;
  src:url('fonts/cormorant-garamond-500.woff2') format('woff2');
}
@font-face{
  font-family:'Cormorant Garamond';
  font-style:italic;font-weight:500;font-display:swap;
  src:url('fonts/cormorant-garamond-500-italic.woff2') format('woff2');
}

/* ── 2. ANIMATABLE CUSTOM PROPERTIES (@property — 2026) ────────────────────── */
@property --reveal-shift {
  syntax: '<length>';
  inherits: false;
  initial-value: 14px;
}
@property --glow-opacity {
  syntax: '<number>';
  inherits: false;
  initial-value: 0;
}

/* ── 3. DESIGN TOKENS ──────────────────────────────────────────────────────── */
:root{
  color-scheme: light dark;

  /* Brand: Midnight Blue + Cream */
  --midnight:        #0d1b2a;
  --midnight-2:      #142336;
  --midnight-3:      #1b2d44;
  --midnight-deep:   #07111c;

  --cream:           #f4ead5;
  --cream-warm:      #ede0c5;
  --cream-soft:      #faf3e0;
  --cream-mute:      #e6d8b8;

  /* Subtle brass for accents — never carrying critical contrast */
  --brass:           #c9a86a;
  --brass-soft:      #b8965a;

  /* Functional semantic tokens */
  --bg:              var(--cream);
  --bg-inv:          var(--midnight);
  --bg-deep:         var(--midnight-deep);
  --ink:             var(--midnight);
  --ink-inv:         var(--cream);

  /* Lines & muted text */
  --line:            color-mix(in oklab, var(--midnight) 14%, transparent);
  --line-strong:     color-mix(in oklab, var(--midnight) 24%, transparent);
  --line-inv:        color-mix(in oklab, var(--cream) 18%, transparent);
  --line-inv-strong: color-mix(in oklab, var(--cream) 30%, transparent);
  --muted:           color-mix(in oklab, var(--midnight) 62%, transparent);
  --muted-inv:       color-mix(in oklab, var(--cream) 60%, transparent);

  /* Typography */
  --font-display:    'Cormorant Garamond', 'Iowan Old Style', 'Palatino Linotype', Palatino, 'Book Antiqua', Georgia, serif;
  --font-body:       ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;

  /* Fluid type scale (clamp-based) */
  --fs-xs:    clamp(.7rem,  .65rem + .2vw, .8rem);
  --fs-sm:    clamp(.85rem, .8rem  + .25vw, .95rem);
  --fs-base:  clamp(.95rem, .9rem  + .3vw,  1.05rem);
  --fs-lg:    clamp(1.1rem, 1rem   + .5vw,  1.3rem);
  --fs-xl:    clamp(1.3rem, 1.1rem + .8vw,  1.75rem);
  --fs-2xl:   clamp(1.75rem, 1.3rem + 1.5vw, 2.4rem);
  --fs-3xl:   clamp(2.25rem, 1.5rem + 3vw,   3.75rem);
  --fs-4xl:   clamp(3rem, 2rem + 5vw,        5.75rem);
  --fs-display: clamp(4.5rem, 2rem + 12vw,   10.5rem);

  /* Fluid spacing scale */
  --s-1: clamp(.25rem, .5vw, .5rem);
  --s-2: clamp(.5rem, 1vw, .8rem);
  --s-3: clamp(.85rem, 1.75vw, 1.25rem);
  --s-4: clamp(1.25rem, 2.5vw, 1.85rem);
  --s-5: clamp(2rem, 4vw, 3rem);
  --s-6: clamp(3rem, 6vw, 4.5rem);
  --s-7: clamp(4.5rem, 9vw, 7rem);
  --s-8: clamp(6rem, 12vw, 9rem);

  /* Radii */
  --r-xs: 2px;
  --r-sm: 4px;
  --r-md: 10px;
  --r-lg: 18px;
  --r-pill: 999px;

  /* Layout */
  --container: 1280px;
  --container-narrow: 920px;
  --container-read: 680px;

  /* Easing curves */
  --ease-out:     cubic-bezier(.2,.7,.2,1);
  --ease-in-out:  cubic-bezier(.65,.05,.36,1);
  --ease-curtain: cubic-bezier(.7,.05,.2,1);

  /* Durations */
  --t-fast: .2s;
  --t-base: .35s;
  --t-slow: .7s;
  --t-xslow: 1.1s;

  /* Shadows (soft, midnight-tinted) */
  --shadow-sm: 0 1px 2px color-mix(in oklab, var(--midnight) 18%, transparent);
  --shadow-md: 0 8px 22px color-mix(in oklab, var(--midnight) 22%, transparent);
  --shadow-lg: 0 24px 60px color-mix(in oklab, var(--midnight) 30%, transparent);
}

/* ── 4. RESET & BASE ───────────────────────────────────────────────────────── */
*,*::before,*::after{ box-sizing: border-box; }
*{ margin: 0; padding: 0; }

html{
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
  /* 2026: native height-auto animation */
  interpolate-size: allow-keywords;
}
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *,*::before,*::after{
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}

body{
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
  /* Subtle ambient grain (2026 trend — adds depth on flat backgrounds) */
  background-image:
    radial-gradient(ellipse 90% 60% at 50% -10%,
      color-mix(in oklab, var(--brass) 6%, transparent),
      transparent 70%);
}

img, svg, video, picture{
  display: block;
  max-width: 100%;
  height: auto;
}
img{
  font-style: italic;
  background-color: color-mix(in oklab, var(--midnight) 4%, transparent);
}

a{
  color: inherit;
  text-decoration: none;
}

button{
  font: inherit;
  color: inherit;
  background: none;
  border: 0;
  cursor: pointer;
}

input, select, textarea{ font: inherit; color: inherit; }

/* Modern text-wrap */
h1,h2,h3,h4,h5,h6{
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -.015em;
  text-wrap: balance;
}
p{ text-wrap: pretty; }

/* Focus */
:focus-visible{
  outline: 2px solid var(--ink);
  outline-offset: 3px;
  border-radius: var(--r-xs);
}
.on-dark :focus-visible,
.is-dark :focus-visible{ outline-color: var(--ink-inv); }

::selection{
  background: var(--midnight);
  color: var(--cream);
}

/* ── 5. UTILITIES ──────────────────────────────────────────────────────────── */
.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;
}

.container{
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 4vw, 3rem);
}
.container--narrow{ max-width: var(--container-narrow); }
.container--read{ max-width: var(--container-read); }

.label{
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 var(--s-3);
}
.is-dark .label,
.on-dark .label{ color: var(--muted-inv); }

.label--brass{
  color: var(--brass);
  display: inline-flex; align-items: center; gap: .65rem;
}
.label--brass::before,
.label--brass::after{
  content:""; display: inline-block;
  width: 18px; height: 1px;
  background: currentColor; opacity: .6;
}
.label--brass::after{ display: none; }
.label--brass.is-flanked::after{ display: inline-block; }

/* ── 6. BUTTONS ────────────────────────────────────────────────────────────── */
.btn{
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  padding: 1rem 1.85rem;
  border-radius: var(--r-pill);
  font-size: .76rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  line-height: 1;
  border: 1px solid transparent;
  transition:
    background var(--t-fast) var(--ease-out),
    color var(--t-fast) var(--ease-out),
    border-color var(--t-fast) var(--ease-out),
    transform var(--t-fast) var(--ease-out);
  will-change: transform;
  cursor: pointer;
}
.btn:hover{ transform: translateY(-1px); }
.btn:active{ transform: translateY(0); }
.btn__arrow{
  transition: transform var(--t-fast) var(--ease-out);
  display: inline-block;
}
.btn:hover .btn__arrow{ transform: translateX(4px); }

/* Variants */
.btn--primary{
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}
.btn--primary:hover{
  background: var(--midnight-2);
  border-color: var(--midnight-2);
}
.btn--ghost{
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}
.btn--ghost:hover{
  background: var(--ink);
  color: var(--cream);
}
.btn--cream{
  background: var(--cream);
  color: var(--ink);
  border-color: var(--cream);
}
.btn--cream:hover{
  background: var(--cream-soft);
  border-color: var(--cream-soft);
}
.btn--outline-cream{
  background: transparent;
  color: var(--cream);
  border-color: var(--line-inv-strong);
}
.btn--outline-cream:hover{
  background: var(--cream);
  color: var(--ink);
  border-color: var(--cream);
}
.btn--brass{
  background: var(--brass);
  color: var(--midnight);
  border-color: var(--brass);
}
.btn--brass:hover{
  background: var(--brass-soft);
  border-color: var(--brass-soft);
}

/* ── 7. SKIP LINK & SCROLL PROGRESS ────────────────────────────────────────── */
.skip{
  position: fixed;
  inset: .5rem auto auto .5rem;
  z-index: 200;
  background: var(--midnight);
  color: var(--cream);
  padding: .75rem 1.1rem;
  border-radius: var(--r-sm);
  font-size: var(--fs-sm);
  letter-spacing: .04em;
  transform: translateY(-150%);
  transition: transform var(--t-fast) var(--ease-out);
}
.skip:focus{ transform: none; }

.scroll-progress{
  position: fixed;
  inset: 0 0 auto 0;
  height: 2px;
  background: var(--brass);
  transform-origin: 0 50%;
  transform: scaleX(0);
  z-index: 100;
  pointer-events: none;
}
/* 2026: scroll-driven animation (no JS needed) */
@supports (animation-timeline: scroll()){
  .scroll-progress{
    animation: progressGrow linear;
    animation-timeline: scroll(root);
  }
  @keyframes progressGrow{
    from{ transform: scaleX(0); }
    to{ transform: scaleX(1); }
  }
}

/* ── 8. NAVIGATION ─────────────────────────────────────────────────────────── */
.nav{
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 60;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: clamp(.85rem, 2vw, 1.25rem);
  padding-inline: clamp(1.25rem, 3vw, 2rem);
  background: color-mix(in oklab, var(--midnight) 78%, transparent);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid transparent;
  color: var(--cream);
  transition:
    border-color var(--t-base) var(--ease-out),
    background var(--t-base) var(--ease-out);
}
.nav.is-scrolled{
  border-bottom-color: var(--line-inv);
  background: color-mix(in oklab, var(--midnight) 88%, transparent);
}

/* On Home only — nav starts transparent over hero (cream bg overlap) */
body.is-home .nav{
  background: color-mix(in oklab, var(--midnight) 50%, transparent);
}
body.is-home .nav.is-scrolled{
  background: color-mix(in oklab, var(--midnight) 92%, transparent);
}

.nav__brand{
  font-family: var(--font-display);
  font-size: clamp(.98rem, 1.4vw, 1.15rem);
  font-weight: 500;
  letter-spacing: .08em;
  color: var(--cream);
}
.nav__brand em{
  font-style: normal;
  opacity: .55;
  margin-inline: .25em;
}

.nav__menu-btn{
  width: 2.75rem;
  height: 2.75rem;
  display: grid;
  place-content: center;
  gap: 5px;
  border-radius: 50%;
  position: relative;
  transition: background var(--t-fast) var(--ease-out);
}
.nav__menu-btn:hover{ background: color-mix(in oklab, var(--cream) 12%, transparent); }
.nav__menu-btn span{
  display: block;
  width: 20px;
  height: 1.5px;
  background: var(--cream);
  transition: transform var(--t-base) var(--ease-out), opacity var(--t-fast) var(--ease-out);
}
.nav__menu-btn[aria-expanded="true"] span:nth-child(1){
  transform: translateY(3.25px) rotate(45deg);
}
.nav__menu-btn[aria-expanded="true"] span:nth-child(2){
  transform: translateY(-3.25px) rotate(-45deg);
}

/* ── 9. OVERLAY MENU ───────────────────────────────────────────────────────── */
.overlay{
  position: fixed;
  inset: 0;
  z-index: 55;
  background: var(--midnight-deep);
  color: var(--cream);
  display: grid;
  grid-template-rows: 1fr auto;
  padding: clamp(5.5rem, 12vw, 8rem) clamp(1.5rem, 5vw, 4rem) clamp(2rem, 5vw, 3rem);
  clip-path: inset(0 0 100% 0);
  transition: clip-path var(--t-slow) var(--ease-curtain);
  pointer-events: none;
}
.overlay.is-open{
  clip-path: inset(0 0 0 0);
  pointer-events: auto;
}

/* Decorative grid lines in overlay (subtle 2026 detail) */
.overlay::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, var(--line-inv) 1px, transparent 1px);
  background-size: clamp(2rem, 8vw, 4rem) 100%;
  opacity: .35;
  pointer-events: none;
  mask-image: linear-gradient(to bottom, transparent, black 30%, black 80%, transparent);
}

.overlay__nav{
  list-style: none;
  display: grid;
  align-content: center;
  gap: clamp(.3rem, 1vw, .5rem);
  position: relative;
  z-index: 1;
}
.overlay__nav li{ overflow: hidden; }
.overlay__nav a{
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 9vw, 5.5rem);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -.015em;
  display: flex;
  align-items: baseline;
  gap: clamp(.75rem, 2vw, 1.5rem);
  transform: translateY(110%);
  transition:
    transform var(--t-slow) var(--ease-out),
    color var(--t-fast) var(--ease-out);
}
.overlay.is-open .overlay__nav a{ transform: none; }
.overlay.is-open .overlay__nav li:nth-child(1) a{ transition-delay: .15s; }
.overlay.is-open .overlay__nav li:nth-child(2) a{ transition-delay: .22s; }
.overlay.is-open .overlay__nav li:nth-child(3) a{ transition-delay: .29s; }
.overlay.is-open .overlay__nav li:nth-child(4) a{ transition-delay: .36s; }

.overlay__nav a span{
  font-family: var(--font-body);
  font-size: .7rem;
  font-weight: 500;
  letter-spacing: .3em;
  color: var(--brass);
  opacity: .9;
}
.overlay__nav a:hover{ color: var(--brass); }
.overlay__nav a[aria-current="page"]{
  font-style: italic;
  color: var(--brass);
}

.overlay__contact{
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  letter-spacing: .12em;
  color: var(--muted-inv);
  font-style: normal;
  position: relative;
  z-index: 1;
}
.overlay__contact a{
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.overlay__contact a:hover{ color: var(--cream); }

/* ── 10. CURTAIN (Home only) ───────────────────────────────────────────────── */
.curtain{
  position: fixed;
  inset: 0;
  z-index: 150;
  background: var(--midnight-deep);
  color: var(--cream);
  display: grid;
  place-items: center;
  text-align: center;
  transition:
    transform var(--t-xslow) var(--ease-curtain),
    opacity var(--t-slow) ease;
}
.curtain.is-done{
  transform: translateY(-100%);
  pointer-events: none;
}
.curtain__intro{
  display: grid;
  gap: 1rem;
  justify-items: center;
}
.curtain__bistro{
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1rem, 2vw, 1.3rem);
  letter-spacing: .08em;
  color: var(--brass);
  opacity: .8;
}
.curtain__name{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(3rem, 10vw, 6rem);
  line-height: 1;
  letter-spacing: -.02em;
}
.curtain__name span{
  display: inline-block;
  opacity: 0;
  transform: translateY(.5em);
  animation: letterIn .65s var(--ease-out) forwards;
}
.curtain__name span:nth-child(1){ animation-delay: .15s; }
.curtain__name span:nth-child(2){ animation-delay: .22s; }
.curtain__name span:nth-child(3){ animation-delay: .29s; }
.curtain__name span:nth-child(4){ animation-delay: .36s; }
.curtain__name span:nth-child(5){ animation-delay: .43s; }
.curtain__name span:nth-child(6){ animation-delay: .5s; }
@keyframes letterIn{ to{ opacity: 1; transform: none; } }

.curtain__line{
  width: 48px;
  height: 1px;
  background: var(--brass);
  opacity: .55;
  margin: .5rem 0;
}
.curtain__sub{
  font-family: var(--font-display);
  font-style: italic;
  opacity: .75;
  font-size: 1rem;
}

.no-js .curtain{ display: none; }

/* ── 11. HERO — Home (full bleed) ──────────────────────────────────────────── */
.hero{
  position: relative;
  min-height: 100svh;
  padding-block: clamp(5rem, 10vw, 7rem) clamp(3rem, 6vw, 5rem);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  display: grid;
  place-items: center;
  text-align: center;
  isolation: isolate;
  background: var(--midnight);
  color: var(--cream);
  overflow: hidden;
}
/* Atmospheric glow (replaces background image — no extra request) */
.hero::before{
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(60% 50% at 50% 30%,
      color-mix(in oklab, var(--brass) 18%, transparent),
      transparent 60%),
    radial-gradient(40% 35% at 80% 80%,
      color-mix(in oklab, var(--cream) 8%, transparent),
      transparent 70%);
  opacity: .9;
  animation: heroGlow 18s ease-in-out infinite alternate;
}
@keyframes heroGlow{
  to{ transform: scale(1.08) translateY(-3%); opacity: 1; }
}

.hero__location{
  position: absolute;
  top: clamp(5.5rem, 11vw, 7.5rem);
  left: 50%;
  transform: translateX(-50%);
  font-size: var(--fs-xs);
  letter-spacing: .5em;
  text-transform: uppercase;
  color: var(--brass);
}

.hero__content{
  max-width: 720px;
  display: grid;
  gap: clamp(.85rem, 1.75vw, 1.4rem);
}
.hero__kicker{
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  letter-spacing: .06em;
  color: var(--muted-inv);
}
.hero__name{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-display);
  line-height: .9;
  letter-spacing: -.025em;
  color: var(--cream);
  margin: 0;
}
.hero__tagline{
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.15rem, 2.2vw, 1.65rem);
  color: var(--brass);
}
.hero__desc{
  max-width: 44ch;
  margin-inline: auto;
  color: var(--muted-inv);
  font-size: var(--fs-base);
}
.hero__cta{
  margin-top: clamp(1.5rem, 3vw, 2.25rem);
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  justify-content: center;
}

/* Decorative seal — only on home hero */
.seal{
  position: absolute;
  right: clamp(1.5rem, 4vw, 3rem);
  bottom: clamp(2rem, 5vw, 4rem);
  width: 170px;
  height: 170px;
  display: grid;
  place-items: center;
  color: var(--brass);
  animation: slowSpin 50s linear infinite;
}
.seal__circle{ position: absolute; inset: 0; }
.seal__inner{
  font-family: var(--font-display);
  font-style: italic;
  font-size: .95rem;
  line-height: 1.25;
  text-align: center;
  color: var(--cream);
  animation: slowSpin 50s linear infinite reverse;
}
@keyframes slowSpin{ to{ transform: rotate(360deg); } }
@media (max-width: 720px){
  .seal{ width: 110px; height: 110px; right: 1rem; bottom: 1.5rem; }
}

.scroll-indicator{
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  font-size: var(--fs-xs);
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--muted-inv);
  animation: bob 2.4s var(--ease-out) infinite;
}
@keyframes bob{
  0%, 100%{ transform: translate(-50%, 0); opacity: .55; }
  50%     { transform: translate(-50%, -6px); opacity: .9; }
}

/* ── 12. PAGE HERO (Speisekarte, Galerie, Kontakt) ─────────────────────────── */
.page-hero{
  position: relative;
  padding-block: clamp(8rem, 14vw, 11rem) clamp(3rem, 6vw, 4.5rem);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  text-align: center;
  background: var(--midnight);
  color: var(--cream);
  overflow: hidden;
  isolation: isolate;
}
.page-hero::before{
  content: "";
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(50% 60% at 50% 100%,
      color-mix(in oklab, var(--brass) 14%, transparent),
      transparent 70%);
}
.page-hero__kicker{
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1.25rem;
}
.page-hero__title{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-4xl);
  line-height: 1;
  letter-spacing: -.02em;
  margin: 0 0 1.5rem;
}
.page-hero__title em{ font-style: italic; font-weight: 400; }
.page-hero__lead{
  max-width: 48ch;
  margin: 0 auto;
  color: var(--muted-inv);
  font-size: var(--fs-lg);
  line-height: 1.55;
}
.page-hero__divider{
  width: 48px;
  height: 1px;
  background: var(--brass);
  margin: clamp(1.5rem, 3vw, 2.25rem) auto;
  opacity: .7;
}

/* ── 13. MARQUEE ──────────────────────────────────────────────────────────── */
.marquee{
  background: var(--midnight-deep);
  color: var(--cream);
  padding-block: clamp(1rem, 2.5vw, 1.5rem);
  overflow: hidden;
  border-block: 1px solid var(--line-inv);
}
.marquee__track{
  display: flex;
  gap: clamp(2rem, 5vw, 4rem);
  white-space: nowrap;
  animation: scrollLeft 40s linear infinite;
  will-change: transform;
}
.marquee:hover .marquee__track{ animation-play-state: paused; }
.marquee__item{
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.2rem, 2.5vw, 1.6rem);
  letter-spacing: .02em;
}
.marquee__star{ opacity: .5; color: var(--brass); }
@keyframes scrollLeft{
  from{ transform: translateX(0); }
  to  { transform: translateX(-50%); }
}

/* ── 14. STORY SECTION ────────────────────────────────────────────────────── */
.story{
  padding-block: var(--s-7);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  max-width: var(--container);
  margin-inline: auto;
  content-visibility: auto;
  contain-intrinsic-size: 1px 800px;
}
.story__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2.5rem, 6vw, 5rem);
  align-items: center;
}
@media (min-width: 900px){
  .story__grid{
    grid-template-columns: 1fr 1fr;
    gap: clamp(3rem, 6vw, 6rem);
  }
}
.story__photo{
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--r-xs);
  background: color-mix(in oklab, var(--midnight) 8%, transparent);
}
.story__photo img,
.story__photo picture{
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease-out);
}
.story__photo:hover img{ transform: scale(1.04); }
.story__photo-tag{
  position: absolute;
  inset: 1rem auto auto 1rem;
  background: var(--cream);
  color: var(--ink);
  padding: .4rem .85rem;
  border-radius: var(--r-pill);
  font-size: var(--fs-xs);
  letter-spacing: .25em;
  text-transform: uppercase;
}

.story__title{
  font-size: var(--fs-3xl);
  margin: 0 0 var(--s-4);
}
.story__title em{ font-style: italic; font-weight: 400; color: var(--brass-soft); }
.story__text{
  color: var(--muted);
  font-size: var(--fs-base);
  line-height: 1.75;
  max-width: 48ch;
}
.story__text--lead{
  font-size: var(--fs-lg);
  color: var(--ink);
}
.story__sig{
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--brass-soft);
  margin: var(--s-4) 0;
}

/* ── 15. REVIEWS / SOCIAL PROOF ───────────────────────────────────────────── */
.reviews{
  padding-block: var(--s-7);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  background: var(--midnight);
  color: var(--cream);
  text-align: center;
  content-visibility: auto;
  contain-intrinsic-size: 1px 600px;
}
.reviews__inner{ max-width: 760px; margin-inline: auto; }
.reviews__stats{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
  max-width: 600px;
  margin-inline: auto;
}
@media (max-width: 540px){
  .reviews__stats{ grid-template-columns: 1fr; gap: var(--s-3); }
}
.reviews__stat strong{
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(2rem, 4vw, 2.6rem);
  color: var(--brass);
  line-height: 1;
  margin-bottom: .55rem;
}
.reviews__stat span{
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted-inv);
}
.reviews__divider{
  width: 32px; height: 1px;
  background: var(--brass);
  opacity: .5;
  margin: clamp(2.5rem, 5vw, 3.75rem) auto clamp(1.75rem, 3vw, 2.5rem);
}
.reviews__cta-text{
  font-size: var(--fs-base);
  color: var(--muted-inv);
  max-width: 38ch;
  margin: 0 auto var(--s-4);
  line-height: 1.6;
}
.reviews__cta{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .85rem;
}

/* ── 16. PHILOSOPHY ───────────────────────────────────────────────────────── */
.philosophy{
  padding-block: var(--s-7);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  background: var(--cream);
  color: var(--ink);
  text-align: center;
  content-visibility: auto;
  contain-intrinsic-size: 1px 400px;
}
.philosophy__inner{ max-width: 640px; margin-inline: auto; }
.philosophy__quote{
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--fs-2xl);
  line-height: 1.35;
  margin: 0 0 var(--s-4);
  letter-spacing: -.01em;
}
.philosophy__text{
  font-size: var(--fs-base);
  line-height: 1.7;
  max-width: 460px;
  margin-inline: auto;
  color: var(--muted);
}

/* ── 17. GALLERY TEASER (Home, horizontal carousel) ───────────────────────── */
.gallery-teaser{
  padding-block: var(--s-7);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  background: var(--midnight-2);
  color: var(--cream);
  content-visibility: auto;
  contain-intrinsic-size: 1px 800px;
}
.gallery-teaser__head{
  text-align: center;
  margin-bottom: clamp(2rem, 4vw, 2.75rem);
}
.gallery-teaser__title{
  font-size: var(--fs-3xl);
  margin: 0 0 var(--s-3);
}
.gallery-teaser__title em{ font-style: italic; font-weight: 400; color: var(--brass); }
.gallery-teaser__handle{
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--brass);
  border-bottom: 1px solid currentColor;
  padding-bottom: .2rem;
  transition: opacity var(--t-fast) var(--ease-out);
}
.gallery-teaser__handle:hover{ opacity: .75; }

.gallery-teaser__carousel{
  position: relative;
  margin: clamp(2rem, 4vw, 2.75rem) auto 0;
  max-width: var(--container);
  padding-inline: clamp(2.75rem, 6vw, 4.5rem);
}
.gallery-teaser__viewport{
  overflow: hidden;
  border-radius: var(--r-xs);
}
.gallery-teaser__track{
  list-style: none;
  display: flex;
  gap: 1.25rem;
  transition: transform var(--t-slow) var(--ease-curtain);
  will-change: transform;
}
.gallery-teaser__slide{
  flex: 0 0 calc((100% - 2 * 1.25rem) / 3);
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
  background: color-mix(in oklab, var(--cream) 10%, transparent);
  border-radius: var(--r-xs);
}
.gallery-teaser__slide img,
.gallery-teaser__slide picture{
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .9s var(--ease-out);
}
.gallery-teaser__slide:hover img{ transform: scale(1.04); }
.gallery-teaser__nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: var(--cream);
  color: var(--midnight);
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-size: 1.3rem;
  transition:
    background var(--t-fast) var(--ease-out),
    transform var(--t-fast) var(--ease-out),
    opacity var(--t-fast) var(--ease-out),
    color var(--t-fast) var(--ease-out);
  z-index: 5;
}
.gallery-teaser__nav:hover:not(:disabled){
  background: var(--brass);
  color: var(--midnight);
  transform: translateY(-50%) scale(1.05);
}
.gallery-teaser__nav:disabled{ opacity: .3; cursor: not-allowed; }
.gallery-teaser__nav--prev{ left: 0; }
.gallery-teaser__nav--next{ right: 0; }
.gallery-teaser__dots{
  display: flex;
  justify-content: center;
  gap: .5rem;
  margin-top: 1.75rem;
}
.gallery-teaser__dot{
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: color-mix(in oklab, var(--cream) 25%, transparent);
  transition: background var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.gallery-teaser__dot[aria-current="true"]{
  background: var(--brass);
  transform: scale(1.4);
}
@media (max-width: 900px){
  .gallery-teaser__carousel{ padding-inline: 3.5rem; }
  .gallery-teaser__slide{ flex-basis: calc((100% - 1.25rem) / 2); }
}
@media (max-width: 600px){
  .gallery-teaser__carousel{ padding-inline: 2.75rem; }
  .gallery-teaser__slide{ flex-basis: 100%; }
  .gallery-teaser__nav{ width: 2.5rem; height: 2.5rem; font-size: 1.1rem; }
}
.gallery-teaser__cta{
  text-align: center;
  margin-top: clamp(2rem, 4vw, 3rem);
}

/* ── 18. RESERVE CTA ──────────────────────────────────────────────────────── */
.reserve{
  padding-block: var(--s-7);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  background: var(--midnight-deep);
  color: var(--cream);
  text-align: center;
  content-visibility: auto;
  contain-intrinsic-size: 1px 500px;
}
.reserve__inner{ max-width: 720px; margin-inline: auto; }
.reserve__title{
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-3xl);
  line-height: 1.15;
  letter-spacing: -.01em;
  margin: 0 0 var(--s-5);
}
.reserve__phone{
  display: inline-block;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(2.25rem, 5.5vw, 3.75rem);
  letter-spacing: -.01em;
  color: var(--brass);
  border-bottom: 1px solid color-mix(in oklab, var(--brass) 40%, transparent);
  padding-bottom: .25rem;
  transition:
    opacity var(--t-fast) var(--ease-out),
    border-color var(--t-fast) var(--ease-out);
}
.reserve__phone:hover{
  opacity: .85;
  border-bottom-color: var(--brass);
}
.reserve__address{
  margin-top: var(--s-4);
  font-size: var(--fs-base);
  font-style: normal;
  color: var(--muted-inv);
}

/* ── 19. SPEISEKARTE (Menu Page) ──────────────────────────────────────────── */
.menu{
  padding-block: var(--s-7);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  background: var(--cream);
  color: var(--ink);
}
.menu__inner{
  max-width: var(--container-narrow);
  margin-inline: auto;
}

.menu__intro{
  text-align: center;
  margin-bottom: var(--s-7);
  max-width: 50ch;
  margin-inline: auto;
}
.menu__intro p{
  font-size: var(--fs-lg);
  color: var(--muted);
  line-height: 1.6;
}

.menu__section{
  margin-bottom: var(--s-7);
  scroll-margin-top: 6rem;
}
.menu__section:last-child{ margin-bottom: 0; }
.menu__section-head{
  text-align: center;
  margin-bottom: var(--s-5);
  position: relative;
}
.menu__section-num{
  display: inline-block;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--fs-sm);
  color: var(--brass-soft);
  letter-spacing: .15em;
  margin-bottom: .5rem;
}
.menu__section-title{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-3xl);
  line-height: 1;
  margin: 0;
}
.menu__section-title em{ font-style: italic; font-weight: 400; color: var(--brass-soft); }
.menu__section-sub{
  margin-top: var(--s-2);
  font-style: italic;
  color: var(--muted);
  font-size: var(--fs-base);
}

/* Single menu item */
.menu__list{
  list-style: none;
  display: grid;
  gap: var(--s-4);
  /* 2026: container queries — adapts to available width, not viewport */
  container-type: inline-size;
  container-name: menulist;
}
@container menulist (min-width: 640px){
  .menu__list{ grid-template-columns: 1fr 1fr; gap: var(--s-5) var(--s-6); }
}

.menu__item{
  display: grid;
  gap: .35rem;
}
.menu__item-row{
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: 1rem;
  position: relative;
}
.menu__item-row::before{
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: .35em;
  border-bottom: 1px dotted color-mix(in oklab, var(--ink) 28%, transparent);
  z-index: 0;
}
.menu__item-name{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-xl);
  line-height: 1.2;
  background: var(--cream);
  padding-right: .5rem;
  position: relative;
  z-index: 1;
}
.menu__item-name em{
  font-style: italic;
  font-weight: 400;
}
.menu__item-name .menu__badge{
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--brass);
  margin-left: .5rem;
  vertical-align: middle;
}
.menu__item-price{
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-lg);
  color: var(--brass-soft);
  background: var(--cream);
  padding-left: .5rem;
  position: relative;
  z-index: 1;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.menu__item-desc{
  font-size: var(--fs-sm);
  color: var(--muted);
  line-height: 1.55;
  max-width: 52ch;
}
.menu__item-allergens{
  font-size: var(--fs-xs);
  color: color-mix(in oklab, var(--muted) 80%, transparent);
  letter-spacing: .05em;
  margin-top: .25rem;
}

/* Sticky category jump bar */
.menu__jump{
  position: sticky;
  top: 4.5rem;
  z-index: 30;
  background: color-mix(in oklab, var(--cream) 92%, transparent);
  backdrop-filter: saturate(160%) blur(10px);
  -webkit-backdrop-filter: saturate(160%) blur(10px);
  border-block: 1px solid var(--line);
  margin-bottom: var(--s-6);
  padding-block: .75rem;
}
.menu__jump-list{
  list-style: none;
  display: flex;
  flex-wrap: nowrap;
  gap: 1.5rem;
  overflow-x: auto;
  scrollbar-width: none;
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}
.menu__jump-list::-webkit-scrollbar{ display: none; }
.menu__jump-list a{
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
  padding-block: .5rem;
  border-bottom: 1px solid transparent;
  scroll-snap-align: start;
  transition:
    color var(--t-fast) var(--ease-out),
    border-color var(--t-fast) var(--ease-out);
}
.menu__jump-list a:hover{ color: var(--ink); }
.menu__jump-list a.is-current{
  color: var(--ink);
  border-bottom-color: var(--brass);
}

/* Allergen legend */
.menu__legend{
  margin-top: var(--s-6);
  padding: var(--s-4);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: color-mix(in oklab, var(--cream) 60%, white);
  font-size: var(--fs-sm);
  color: var(--muted);
  line-height: 1.6;
}
.menu__legend h3{
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: .75rem;
}

/* ── 20. GALERIE PAGE — editorial masonry-style grid ──────────────────────── */
.gallery-page{
  padding-block: var(--s-7);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  background: var(--midnight);
  color: var(--cream);
}
.gallery-page__intro{
  max-width: 560px;
  margin: 0 auto var(--s-6);
  text-align: center;
  color: var(--muted-inv);
  font-size: var(--fs-base);
  line-height: 1.7;
}

.gallery-page__grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(.5rem, 1.5vw, 1.25rem);
  max-width: var(--container);
  margin-inline: auto;
}
@media (min-width: 760px){
  .gallery-page__grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1100px){
  .gallery-page__grid{ grid-template-columns: repeat(4, 1fr); }
}

.gallery-page__item{
  position: relative;
  overflow: hidden;
  border-radius: var(--r-xs);
  background: var(--midnight-3);
  cursor: zoom-in;
  /* Different aspect ratios for editorial rhythm */
  aspect-ratio: 1 / 1;
}
.gallery-page__item:nth-child(7n+1){ aspect-ratio: 3 / 4; }
.gallery-page__item:nth-child(7n+4){ aspect-ratio: 3 / 4; }
.gallery-page__item:nth-child(7n+6){ aspect-ratio: 4 / 5; }

.gallery-page__item img,
.gallery-page__item picture{
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .9s var(--ease-out), filter var(--t-base) var(--ease-out);
}
.gallery-page__item:hover img,
.gallery-page__item:focus-visible img{
  transform: scale(1.05);
  filter: brightness(1.08);
}
/* Brass overlay tint on hover (2026 mood) */
.gallery-page__item::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,
    color-mix(in oklab, var(--midnight) 70%, transparent) 0%,
    transparent 55%);
  opacity: 0;
  transition: opacity var(--t-base) var(--ease-out);
  pointer-events: none;
}
.gallery-page__item:hover::after{ opacity: 1; }

/* Lightbox (native <dialog> — 2026 standard) */
.lightbox{
  width: min(94vw, 1100px);
  max-height: 92vh;
  border: 0;
  padding: 0;
  background: var(--midnight-deep);
  color: var(--cream);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.lightbox::backdrop{
  background: color-mix(in oklab, var(--midnight-deep) 90%, transparent);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.lightbox img{
  width: 100%;
  max-height: 80vh;
  object-fit: contain;
  display: block;
}
.lightbox__close{
  position: absolute;
  inset: .75rem .75rem auto auto;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: var(--cream);
  color: var(--midnight);
  display: grid;
  place-items: center;
  font-size: 1.25rem;
  z-index: 2;
  transition: background var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.lightbox__close:hover{ background: var(--brass); transform: scale(1.06); }
.lightbox__nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 3rem; height: 3rem;
  border-radius: 50%;
  background: color-mix(in oklab, var(--cream) 95%, transparent);
  color: var(--midnight);
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 1.4rem;
  z-index: 2;
  transition: background var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.lightbox__nav:hover{ background: var(--brass); }
.lightbox__nav--prev{ left: .75rem; }
.lightbox__nav--next{ right: .75rem; }
.lightbox__caption{
  padding: .85rem 1rem;
  font-size: var(--fs-sm);
  color: var(--muted-inv);
  text-align: center;
}
@media (max-width: 600px){
  .lightbox__nav{ width: 2.5rem; height: 2.5rem; font-size: 1.15rem; }
}

/* ── 21. KONTAKT PAGE ──────────────────────────────────────────────────────── */
.contact{
  padding-block: var(--s-7);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  background: var(--cream);
  color: var(--ink);
}
.contact__grid{
  max-width: var(--container);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
}
@media (min-width: 900px){
  .contact__grid{
    grid-template-columns: 1.1fr 1fr;
    gap: var(--s-6);
    align-items: start;
  }
}

.contact__cards{
  display: grid;
  gap: var(--s-3);
}
.contact-card{
  padding: var(--s-4);
  background: color-mix(in oklab, var(--cream) 85%, white);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  transition: border-color var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.contact-card:hover{
  border-color: var(--line-strong);
  box-shadow: var(--shadow-md);
}
.contact-card__label{
  display: flex;
  align-items: center;
  gap: .65rem;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--brass-soft);
  margin-bottom: .85rem;
}
.contact-card__label svg{
  width: 16px; height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
}
.contact-card__value{
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 500;
  line-height: 1.3;
  font-style: normal;
}
.contact-card__value a{
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 20%, transparent);
  transition: border-color var(--t-fast) var(--ease-out);
}
.contact-card__value a:hover{ border-bottom-color: var(--brass); }
.contact-card__list{
  list-style: none;
  display: grid;
  gap: .35rem;
}
.contact-card__list li{
  display: grid;
  grid-template-columns: minmax(8ch, auto) 1fr;
  gap: 1.5rem;
  align-items: baseline;
  font-size: var(--fs-base);
  padding-block: .15rem;
}
.contact-card__list li span:first-child{
  color: var(--muted);
  font-size: var(--fs-sm);
  letter-spacing: .04em;
}
.contact-card__list li.is-today{
  color: var(--brass-soft);
  font-weight: 500;
}
.contact-card__list li.is-today span:first-child{
  color: var(--brass-soft);
}

.contact__map{
  position: relative;
  aspect-ratio: 4 / 5;
  background: var(--midnight);
  color: var(--cream);
  border-radius: var(--r-md);
  overflow: hidden;
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  isolation: isolate;
}
.contact__map::before{
  content: "";
  position: absolute;
  inset: 0; z-index: -1;
  background:
    radial-gradient(80% 60% at 30% 20%,
      color-mix(in oklab, var(--brass) 16%, transparent), transparent 65%),
    radial-gradient(60% 50% at 80% 90%,
      color-mix(in oklab, var(--cream) 8%, transparent), transparent 70%);
}
.contact__map-coords{
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--brass);
}
.contact__map-place{
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  line-height: 1;
  margin: var(--s-4) 0 var(--s-2);
}
.contact__map-address{
  font-family: var(--font-body);
  font-style: normal;
  color: var(--muted-inv);
  font-size: var(--fs-base);
  line-height: 1.6;
  margin-bottom: var(--s-4);
}
.contact__map-link{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .85rem 1.5rem;
  border-radius: var(--r-pill);
  background: var(--cream);
  color: var(--midnight);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  align-self: flex-start;
  transition: background var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.contact__map-link:hover{
  background: var(--brass);
  transform: translateY(-1px);
}

.contact__directions{
  max-width: var(--container);
  margin: var(--s-7) auto 0;
  padding-top: var(--s-5);
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
}
@media (min-width: 720px){
  .contact__directions{ grid-template-columns: repeat(3, 1fr); }
}
.contact__directions h3{
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: var(--fs-xl);
  margin-bottom: .5rem;
  color: var(--brass-soft);
}
.contact__directions p{
  font-size: var(--fs-sm);
  color: var(--muted);
  line-height: 1.65;
}

/* ── 22. FOOTER ────────────────────────────────────────────────────────────── */
.footer{
  background: var(--midnight-deep);
  color: var(--cream);
  padding-block: clamp(3rem, 7vw, 5rem) clamp(1.5rem, 3vw, 2.5rem);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
  border-top: 1px solid var(--line-inv);
}
.footer__grid{
  max-width: var(--container);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 4vw, 3rem);
}
@media (min-width: 720px){
  .footer__grid{ grid-template-columns: 1.5fr 1fr 1fr 1fr; }
}
.footer__brand{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-xl);
  letter-spacing: .02em;
  display: inline-block;
  margin-bottom: .5rem;
  color: var(--cream);
}
.footer__brand em{ font-style: normal; opacity: .5; }
.footer__tag{
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-base);
  color: var(--brass);
  margin: 0;
}
.footer h3{
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1rem;
}
.footer__list{
  list-style: none;
  display: grid;
  gap: .5rem;
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: var(--muted-inv);
}
.footer__list a{
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.footer__list a:hover{
  border-bottom-color: var(--brass);
  color: var(--cream);
}
.footer__bottom{
  max-width: var(--container);
  margin: clamp(2.5rem, 5vw, 4rem) auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--line-inv);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
  font-size: var(--fs-xs);
  color: var(--muted-inv);
}
.footer__bottom a{
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.footer__bottom a:hover{ border-bottom-color: var(--brass); color: var(--cream); }

/* ── 23. SCROLL TO TOP ────────────────────────────────────────────────────── */
.to-top{
  position: fixed;
  right: clamp(1rem, 2vw, 1.75rem);
  bottom: clamp(1rem, 2vw, 1.75rem);
  width: clamp(2.75rem, 4vw, 3rem);
  height: clamp(2.75rem, 4vw, 3rem);
  border-radius: 50%;
  background: var(--midnight);
  color: var(--cream);
  border: 1px solid var(--line-inv);
  font-size: 1.05rem;
  display: grid;
  place-items: center;
  opacity: 0;
  pointer-events: none;
  transform: translateY(.75rem);
  transition:
    opacity var(--t-base) var(--ease-out),
    transform var(--t-base) var(--ease-out),
    background var(--t-fast) var(--ease-out),
    color var(--t-fast) var(--ease-out);
  z-index: 90;
  box-shadow: var(--shadow-md);
}
.to-top.is-visible{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.to-top:hover{ background: var(--brass); color: var(--midnight); }

/* ── 24. REVEAL ANIMATIONS (IntersectionObserver-driven) ──────────────────── */
[data-reveal]{
  opacity: 0;
  transform: translateY(var(--reveal-shift, 14px));
  transition:
    opacity var(--t-slow) var(--ease-out),
    transform var(--t-slow) var(--ease-out),
    --reveal-shift var(--t-slow) var(--ease-out);
  transition-delay: var(--reveal-delay, 0s);
}
[data-reveal].is-visible{
  opacity: 1;
  transform: none;
  --reveal-shift: 0px;
}
[data-reveal="clip"]{
  clip-path: inset(8% 0 8% 0);
  transition: clip-path var(--t-xslow) var(--ease-out), opacity var(--t-slow) var(--ease-out);
}
[data-reveal="clip"].is-visible{ clip-path: inset(0 0 0 0); }

/* Stagger reveals (parent w/ data-stagger animates children) */
[data-stagger] > *{
  opacity: 0;
  transform: translateY(12px);
  transition: opacity var(--t-slow) var(--ease-out), transform var(--t-slow) var(--ease-out);
}
[data-stagger].is-visible > *{ opacity: 1; transform: none; }
[data-stagger].is-visible > *:nth-child(1){ transition-delay: 0s; }
[data-stagger].is-visible > *:nth-child(2){ transition-delay: .08s; }
[data-stagger].is-visible > *:nth-child(3){ transition-delay: .16s; }
[data-stagger].is-visible > *:nth-child(4){ transition-delay: .24s; }
[data-stagger].is-visible > *:nth-child(5){ transition-delay: .32s; }
[data-stagger].is-visible > *:nth-child(6){ transition-delay: .40s; }

/* ── 25. VIEW TRANSITIONS (2026 native) ───────────────────────────────────── */
@view-transition{ navigation: auto; }
::view-transition-old(root),
::view-transition-new(root){
  animation-duration: .4s;
  animation-timing-function: cubic-bezier(.4,0,.2,1);
}
::view-transition-old(root){
  animation-name: fadeOut;
}
::view-transition-new(root){
  animation-name: fadeIn;
}
@keyframes fadeOut{ to{ opacity: 0; } }
@keyframes fadeIn{ from{ opacity: 0; } }

/* ── 26. PRINT ────────────────────────────────────────────────────────────── */
@media print{
  .nav, .overlay, .curtain, .marquee, .to-top, .scroll-indicator, .seal,
  .gallery-teaser__nav, .gallery-teaser__dots, .menu__jump{
    display: none !important;
  }
  body{ background: #fff; color: #000; }
  .hero, .page-hero{ min-height: auto; padding: 2rem 1rem; }
  .reviews, .footer, .reserve{ background: #fff; color: #000; }
  a{ text-decoration: underline; }
}

/* =============================================================================
   ── ENHANCEMENT LAYER · v2 · DISZIPLINIERT ──────────────────────────────────
   Prinzipien:
   - KEIN Filmgrain, KEIN mix-blend-mode (Performance + keine Pixelung)
   - Reveal-Animations OHNE filter:blur (verursacht Pixelung + leere Bereiche)
   - Effekte nur dort wo sie wirken — nicht überall pauschal
   - Mobile-first reduziert: Hover/Tilt/Spotlight aus auf Touch
   - Responsive: alle absolute/fixed Elemente getestet < 600px / < 900px
   ============================================================================= */

/* ── 27. SOFT AURORA · Hero & Page-Hero (sauber, performant) ─────────────── */
.hero{ overflow: hidden; }
.hero__aurora{
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.hero__aurora::before,
.hero__aurora::after{
  content:"";
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  will-change: transform;
}
.hero__aurora::before{
  width: 55vw;
  height: 55vw;
  max-width: 700px;
  max-height: 700px;
  background: radial-gradient(circle,
    color-mix(in oklab, var(--brass) 35%, transparent),
    transparent 70%);
  top: 10%;
  left: 5%;
  animation: auroraFloat1 24s ease-in-out infinite alternate;
}
.hero__aurora::after{
  width: 45vw;
  height: 45vw;
  max-width: 600px;
  max-height: 600px;
  background: radial-gradient(circle,
    color-mix(in oklab, var(--cream) 18%, transparent),
    transparent 70%);
  bottom: 5%;
  right: 8%;
  animation: auroraFloat2 28s ease-in-out infinite alternate;
}
@keyframes auroraFloat1{
  0%   { transform: translate(0, 0) scale(1); }
  100% { transform: translate(4%, -3%) scale(1.06); }
}
@keyframes auroraFloat2{
  0%   { transform: translate(0, 0) scale(1); }
  100% { transform: translate(-3%, 4%) scale(1.08); }
}
@media (prefers-reduced-motion: reduce){
  .hero__aurora::before,
  .hero__aurora::after{ animation: none; }
}
@media (max-width: 720px){
  .hero__aurora::before,
  .hero__aurora::after{ filter: blur(40px); }
}

/* Stellt sicher, dass Hero-Inhalt VOR der Aurora liegt */
.hero__location,
.hero__content,
.seal,
.scroll-indicator{ position: relative; z-index: 2; }

/* ── 28. PAGE-HERO · Subtilerer Aurora-Hauch ─────────────────────────────── */
.page-hero{ overflow: hidden; }
.page-hero__aurora{
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.page-hero__aurora::before{
  content:"";
  position: absolute;
  width: 80vw;
  height: 50vw;
  max-width: 900px;
  max-height: 500px;
  border-radius: 50%;
  background: radial-gradient(ellipse,
    color-mix(in oklab, var(--brass) 22%, transparent),
    transparent 70%);
  filter: blur(50px);
  top: 30%;
  left: 50%;
  transform: translateX(-50%);
  will-change: transform;
  animation: auroraPulse 18s ease-in-out infinite alternate;
}
@keyframes auroraPulse{
  0%, 100% { transform: translateX(-50%) scale(1); opacity: .8; }
  50%      { transform: translateX(-50%) scale(1.1); opacity: 1; }
}
@media (prefers-reduced-motion: reduce){
  .page-hero__aurora::before{ animation: none; }
}

.page-hero > *{ position: relative; z-index: 1; }

/* ── 29. HERO-NAME · Letter-Reveal (sauber, ohne Shimmer-Loop) ───────────── */
.hero__name{ perspective: 800px; }
.hero__name .letter{
  display: inline-block;
  opacity: 0;
  transform: translateY(.4em);
  animation: letterIn .7s var(--ease-out) forwards;
}
.hero__name .letter:nth-child(1){ animation-delay: 1.55s; }
.hero__name .letter:nth-child(2){ animation-delay: 1.63s; }
.hero__name .letter:nth-child(3){ animation-delay: 1.71s; }
.hero__name .letter:nth-child(4){ animation-delay: 1.79s; }
.hero__name .letter:nth-child(5){ animation-delay: 1.87s; }
.hero__name .letter:nth-child(6){ animation-delay: 1.95s; }
@keyframes letterIn{
  to{ opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce){
  .hero__name .letter{
    opacity: 1;
    transform: none;
    animation: none;
  }
}

/* ── 30. POLISHED BUTTONS · Magnetic + Subtle Glow ───────────────────────── */
.btn{
  position: relative;
  isolation: isolate;
  transition:
    background var(--t-fast) var(--ease-out),
    color var(--t-fast) var(--ease-out),
    border-color var(--t-fast) var(--ease-out),
    transform .35s cubic-bezier(.34,1.3,.64,1),
    box-shadow var(--t-base) var(--ease-out);
}
.btn:hover{
  transform: translate(var(--tx, 0px), var(--ty, -2px));
  box-shadow:
    0 10px 24px color-mix(in oklab, var(--midnight) 25%, transparent);
}
.btn:active{
  transform: translate(0, 0);
  transition-duration: .1s;
}
.btn__arrow{
  display: inline-block;
  transition: transform .35s cubic-bezier(.34,1.3,.64,1);
}
.btn:hover .btn__arrow{ transform: translateX(5px); }

/* Touch: alles aus */
@media (hover: none){
  .btn:hover{ transform: none; box-shadow: none; }
}

/* ── 31. 3D-TILT · NUR Kontakt-Karten + Galerie-Items ────────────────────── */
.contact-card,
.gallery-page__item{
  transition:
    transform .4s cubic-bezier(.2,.7,.2,1),
    box-shadow .4s var(--ease-out),
    border-color var(--t-fast) var(--ease-out);
}
.tilt-active{
  transform:
    perspective(900px)
    rotateX(var(--rx, 0deg))
    rotateY(var(--ry, 0deg))
    translateY(-3px);
  box-shadow: 0 20px 40px -12px color-mix(in oklab, var(--midnight) 35%, transparent);
}
@media (hover: none){
  .tilt-active{ transform: none !important; box-shadow: none !important; }
}
@media (prefers-reduced-motion: reduce){
  .tilt-active{ transform: none !important; }
}

/* ── 32. SPOTLIGHT · NUR Hero (klein, leicht, sauber) ────────────────────── */
.hero__spotlight{
  position: absolute;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle,
    color-mix(in oklab, var(--brass) 14%, transparent) 0%,
    transparent 70%);
  pointer-events: none;
  opacity: 0;
  z-index: 1;
  transform: translate(-50%, -50%);
  transition: opacity .5s var(--ease-out);
  will-change: transform, opacity;
}
.hero.is-tracked .hero__spotlight{ opacity: 1; }
@media (hover: none), (prefers-reduced-motion: reduce){
  .hero__spotlight{ display: none; }
}

/* ── 33. NAV-BRAND · Subtiler Hover ──────────────────────────────────────── */
.nav__brand{
  position: relative;
  transition: color var(--t-fast) var(--ease-out);
}
.nav__brand:hover em{ color: var(--brass); }

/* ── 34. RESERVE PHONE · Sanfter Glow (statisch, kein Pulse) ─────────────── */
.reserve__phone{
  position: relative;
  isolation: isolate;
}
.reserve__phone::before{
  content:"";
  position: absolute;
  inset: -1rem -1.5rem;
  background: radial-gradient(ellipse at center,
    color-mix(in oklab, var(--brass) 22%, transparent),
    transparent 65%);
  filter: blur(18px);
  opacity: .45;
  z-index: -1;
  transition: opacity var(--t-base) var(--ease-out);
}
.reserve__phone:hover::before{ opacity: .75; }

/* ── 35. SCROLL-PROGRESS · Brass-Gradient ────────────────────────────────── */
.scroll-progress{
  background: linear-gradient(90deg,
    color-mix(in oklab, var(--brass) 80%, var(--brass-soft)),
    var(--brass));
  box-shadow: 0 0 8px color-mix(in oklab, var(--brass) 50%, transparent);
}

/* ── 36. LIVE-STATUS-BADGE · Floating bottom-left ────────────────────────── */
.live-badge{
  position: fixed;
  bottom: clamp(1rem, 2vw, 1.5rem);
  left: clamp(1rem, 2vw, 1.5rem);
  z-index: 80;
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .6rem .95rem;
  background: color-mix(in oklab, var(--midnight-deep) 88%, transparent);
  -webkit-backdrop-filter: blur(12px) saturate(160%);
  backdrop-filter: blur(12px) saturate(160%);
  border: 1px solid color-mix(in oklab, var(--cream) 12%, transparent);
  border-radius: var(--r-pill);
  color: var(--cream);
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 500;
  box-shadow: 0 8px 24px color-mix(in oklab, var(--midnight) 35%, transparent);
  opacity: 0;
  transform: translateY(.5rem);
  transition:
    opacity .5s var(--ease-out),
    transform .5s var(--ease-out);
  pointer-events: auto;
}
.live-badge.is-visible{ opacity: 1; transform: none; }
.live-badge.is-hidden{ opacity: 0; pointer-events: none; }

.live-badge__dot{
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #4ade80;
  flex-shrink: 0;
  position: relative;
}
.live-badge__dot::after{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: inherit;
  animation: livePing 2.2s ease-out infinite;
}
.live-badge--closed .live-badge__dot{ background: #f87171; }
.live-badge--closed .live-badge__dot::after{ animation: none; }
@keyframes livePing{
  0%   { transform: scale(1); opacity: .7; }
  100% { transform: scale(2.6); opacity: 0; }
}
@media (prefers-reduced-motion: reduce){
  .live-badge__dot::after{ animation: none; }
}
@media (max-width: 540px){
  .live-badge{
    font-size: 10px;
    padding: .5rem .8rem;
    letter-spacing: .08em;
  }
}

/* ── 37. REVIEWS · KARUSSELL (Hauptattraktion) ───────────────────────────── */
.reviews__carousel{
  position: relative;
  max-width: 740px;
  margin: clamp(2rem, 5vw, 3.5rem) auto 0;
  padding: clamp(2rem, 4vw, 3rem) clamp(1rem, 3vw, 2rem) clamp(1.5rem, 3vw, 2rem);
}

.reviews__quote-mark{
  position: absolute;
  top: -2rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-display);
  font-size: clamp(5rem, 12vw, 8rem);
  line-height: 1;
  color: var(--brass);
  opacity: .25;
  pointer-events: none;
  user-select: none;
}

.reviews__viewport{
  overflow: hidden;
  border-radius: var(--r-sm);
}

.reviews__track{
  list-style: none;
  display: flex;
  margin: 0;
  padding: 0;
  transition: transform .6s var(--ease-curtain);
  will-change: transform;
}

.reviews__slide{
  flex: 0 0 100%;
  min-width: 0;
  padding-inline: clamp(.5rem, 2vw, 1.5rem);
  display: grid;
  gap: clamp(1rem, 2vw, 1.5rem);
  text-align: center;
}

.reviews__stars{
  display: inline-flex;
  justify-content: center;
  gap: .25rem;
  color: var(--brass);
}
.reviews__stars svg{
  width: 18px;
  height: 18px;
}

.reviews__text{
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.1rem, 2.2vw, 1.55rem);
  line-height: 1.55;
  color: var(--cream);
  max-width: 56ch;
  margin-inline: auto;
  text-wrap: balance;
}

.reviews__meta{
  display: grid;
  gap: .35rem;
  margin-top: .5rem;
}

.reviews__author{
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--brass);
}

.reviews__date{
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--muted-inv);
  letter-spacing: .05em;
}

.reviews__source{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  justify-content: center;
  margin-top: .25rem;
  font-size: var(--fs-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted-inv);
}
.reviews__source svg{ width: 12px; height: 12px; }

/* Controls */
.reviews__controls{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: clamp(1.5rem, 3vw, 2.25rem);
}

.reviews__nav{
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 50%;
  background: transparent;
  color: var(--cream);
  border: 1px solid color-mix(in oklab, var(--cream) 25%, transparent);
  display: grid;
  place-items: center;
  font-size: 1rem;
  font-family: var(--font-body);
  cursor: pointer;
  transition:
    background var(--t-fast) var(--ease-out),
    border-color var(--t-fast) var(--ease-out),
    color var(--t-fast) var(--ease-out),
    transform var(--t-fast) var(--ease-out);
}
.reviews__nav:hover:not(:disabled){
  background: var(--brass);
  border-color: var(--brass);
  color: var(--midnight);
  transform: scale(1.06);
}
.reviews__nav:disabled{
  opacity: .25;
  cursor: not-allowed;
}

.reviews__dots{
  display: flex;
  gap: .5rem;
  align-items: center;
}
.reviews__dot{
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: color-mix(in oklab, var(--cream) 25%, transparent);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition:
    width var(--t-fast) var(--ease-out),
    background var(--t-fast) var(--ease-out);
}
.reviews__dot[aria-current="true"]{
  width: 22px;
  border-radius: var(--r-pill);
  background: var(--brass);
}

/* Loading-Skeleton (kurz sichtbar während fetch) */
.reviews__carousel.is-loading .reviews__viewport{
  min-height: 200px;
  display: grid;
  place-items: center;
}
.reviews__carousel.is-loading .reviews__viewport::before{
  content: "Bewertungen werden geladen…";
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--muted-inv);
}

/* Mobile reviews */
@media (max-width: 540px){
  .reviews__carousel{
    padding: 2rem .5rem 1rem;
  }
  .reviews__quote-mark{ top: -1.25rem; }
  .reviews__nav{
    width: 2.1rem;
    height: 2.1rem;
    font-size: .9rem;
  }
}

/* ── 38. STORY-PHOTO · sanfter Hover ─────────────────────────────────────── */
.story__photo-tag{
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  background: color-mix(in oklab, var(--cream) 80%, transparent);
  box-shadow: 0 4px 12px color-mix(in oklab, var(--midnight) 15%, transparent);
}

/* ── 39. GALLERY-PAGE · Sauberer Hover ───────────────────────────────────── */
.gallery-page__item{
  border-radius: var(--r-sm);
}
.gallery-page__item img{
  border-radius: inherit;
}

/* ── 40. TO-TOP · Glaseffekt ─────────────────────────────────────────────── */
.to-top{
  background: color-mix(in oklab, var(--midnight) 85%, transparent);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border: 1px solid color-mix(in oklab, var(--brass) 35%, transparent);
}
.to-top:hover{
  background: var(--brass);
  color: var(--midnight);
  border-color: var(--brass);
}

/* ── 41. FOOTER · Subtler Brass-Strich am Oberrand ───────────────────────── */
.footer{ position: relative; }
.footer::before{
  content:"";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: clamp(120px, 30vw, 280px);
  height: 1px;
  background: linear-gradient(90deg,
    transparent,
    color-mix(in oklab, var(--brass) 80%, transparent),
    transparent);
}

/* ── 42. RESPONSIVE FIXES · Critical Layout Repairs ──────────────────────── */
/* Stat-Block: 3-Spalter zu 1-Spalter bei klein, dazwischen 2-Spalter */
@media (min-width: 360px) and (max-width: 600px){
  .reviews__stats{
    grid-template-columns: repeat(3, 1fr);
    gap: var(--s-2);
  }
  .reviews__stat strong{
    font-size: clamp(1.5rem, 6vw, 2rem);
  }
  .reviews__stat span{
    font-size: 10px;
    letter-spacing: .15em;
  }
}

/* Hero-CTA: Buttons wrappen sauber */
.hero__cta{ flex-wrap: wrap; justify-content: center; }
@media (max-width: 480px){
  .hero__cta .btn{
    flex: 1 1 auto;
    min-width: 0;
  }
}

/* Marquee soll nie horizontal überlaufen */
.marquee{ max-width: 100vw; overflow: hidden; }

/* Seal auf Mobile nicht über CTA-Buttons drüber */
@media (max-width: 720px){
  .seal{
    width: 90px;
    height: 90px;
    right: .85rem;
    bottom: 1rem;
  }
  .seal__inner{ font-size: .75rem; }
}
@media (max-width: 480px){
  .seal{ display: none; }
  .hero__location{
    font-size: 10px;
    letter-spacing: .35em;
  }
}

/* Nav-Brand auf sehr kleinen Screens kürzer */
@media (max-width: 380px){
  .nav__brand{
    font-size: .85rem;
    letter-spacing: .04em;
  }
}

/* Story-Grid: stabil zwischen 720-900 */
@media (min-width: 720px) and (max-width: 899px){
  .story__grid{
    grid-template-columns: 1fr;
    max-width: 600px;
    margin-inline: auto;
  }
}

/* Page-Hero: nicht zu viel padding-top bei Tablets */
@media (min-width: 720px) and (max-width: 1100px){
  .page-hero{
    padding-block: clamp(6rem, 11vw, 8rem) clamp(2.5rem, 5vw, 3.5rem);
  }
}

/* Hero: passt sich an Höhe an */
@media (max-height: 700px) and (min-width: 720px){
  .hero{ min-height: 600px; }
}

/* Reserve-Section: Phone nicht zu groß auf Mobile */
@media (max-width: 480px){
  .reserve__phone{
    font-size: clamp(1.85rem, 7vw, 2.5rem);
  }
  .reserve__phone::before{
    inset: -.5rem -.75rem;
  }
}

/* Contact-Map: Aspect-Ratio fixen bei Mid-Sized */
@media (min-width: 600px) and (max-width: 899px){
  .contact__map{ aspect-ratio: 16 / 10; }
}

/* Gallery-Teaser-Nav: bei sehr kleinen Screens innerhalb des Containers */
@media (max-width: 360px){
  .gallery-teaser__carousel{
    padding-inline: 2.25rem;
  }
  .gallery-teaser__nav{
    width: 2.1rem;
    height: 2.1rem;
    font-size: .95rem;
  }
}

/* Footer: Stack early auf Tablet */
@media (min-width: 720px) and (max-width: 899px){
  .footer__grid{
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
}

/* ── 43. REVEAL-ANIMATION · OHNE BLUR (war Performance-Killer) ───────────── */
/* Override des [data-reveal] aus dem Original — minimaler Move + opacity */
[data-reveal]{
  --reveal-shift: 12px;
}
[data-stagger] > *{
  /* Original-Behavior bleibt */
}

/* ── 44. POLIERTE OVERLAY-NAV · Brass-Underline beim Hover ───────────────── */
.overlay__nav a{ position: relative; transition: color var(--t-fast) var(--ease-out), padding-left var(--t-base) var(--ease-out); }
.overlay__nav a::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: -.25rem;
  width: 0;
  height: 1px;
  background: var(--brass);
  transition: width var(--t-base) var(--ease-out);
}
.overlay__nav a:hover::after{ width: 2rem; }
@media (hover: none){
  .overlay__nav a:hover::after{ width: 0; }
}

/* =============================================================================
   ── END ENHANCEMENT LAYER v2 ────────────────────────────────────────────────
   ============================================================================= */