/* ============================================================
   SYRTAKI GOMMERN — Premium Restaurant Stylesheet
   Palette: Warm Beige · Aegean Blue (Marken-Primär) · Gold-Ornament
   Typography: Playfair Display 800 (display) · Inter (body)
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 18px;
  line-height: 1.65;
  color: var(--ink-soft);
  background: var(--bg-warm);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img, picture, svg, video { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; background: none; border: none; color: inherit; }
a { color: inherit; text-decoration: none; transition: color .3s ease; }
ul { list-style: none; }
input, select, textarea, button { font: inherit; color: inherit; }

:root {
  /* --- Backgrounds: Greek-Flag White + Light Aegean + Dark Aegean --- */
  --bg-warm:      #ffffff;     /* Haupt-Hintergrund: Weiß */
  --bg-deeper:    #d6e2ee;     /* "warme" Sections: Hellblau (Aegean-Mist) */
  --bg-mist:      #f4f8fb;     /* Sehr helles Blau */
  --cream:        #ffffff;     /* Cards & Cream-Sections: Weiß */
  --paper-grain:  #e6ecf3;     /* dezente Hintergrund-Textur */

  /* --- Ink: leicht wärmer, weniger schwarz --- */
  --ink:          #1a1410;
  --ink-soft:     #4f3f33;
  --ink-muted:    #877263;
  --ink-faint:    rgba(26, 20, 16, .55);

  /* --- Aegean (jetzt Marken-Primär, blau-weiß passend zum neuen Logo) --- */
  --aegean:       #1f4d78;     /* Logo-Hauptblau */
  --aegean-deep:  #0e2a47;     /* Marine, Footer, dunkle Flächen */
  --aegean-soft:  #6a8fb2;     /* Hover, dezent */
  --aegean-mist:  #d6e2ee;     /* sehr helles Blau für Backgrounds */

  --action:       #2563a0;     /* CTA-Aktion, frischer als Aegean */
  --action-hover: #1d4e83;
  --action-deep:  #0e2a47;

  /* Aliases für Migration */
  --greek-blue:      var(--aegean);
  --greek-blue-soft: var(--aegean-soft);
  --greek-blue-deep: var(--aegean-deep);
  --greek-blue-ink:  var(--aegean-deep);

  /* --- Gold (jetzt ornamentaler Akzent, passt zu Logo-Säulen) --- */
  --gold:        #b88a3e;
  --gold-soft:   #d8b370;
  --gold-deep:   #7d5a23;
  --gold-leaf:   #e8c989;

  /* --- Bordeaux-Aliase auf Aegean umgebogen (Pivot zu Blau/Weiß) --- */
  --bordeaux:        var(--aegean);
  --bordeaux-hover:  var(--aegean-soft);
  --bordeaux-deep:   var(--aegean-deep);

  /* --- Warn-Akzent für Form-Errors (terracotta, klar non-Bordeaux) --- */
  --warn:        #c0552e;

  /* --- Neue Akzente (Fresken-Inspiration) --- */
  --terracotta:  #a8542b;
  --olive:       #5e6b3d;
  --olive-leaf:  #8a9961;
  --marble-vein: #c9b48a;

  /* --- Borders & Schatten (Aegean-getönt) --- */
  --line:         rgba(14, 42, 71, .10);
  --line-strong:  rgba(14, 42, 71, .22);
  --line-gold:    rgba(184, 138, 62, .38);

  --shadow-soft:  0 1px 2px rgba(14, 42, 71, .05), 0 8px 24px -12px rgba(14, 42, 71, .18);
  --shadow-card:  0 2px 6px rgba(14, 42, 71, .08), 0 18px 45px -22px rgba(14, 42, 71, .32);
  --shadow-luxe:  0 4px 14px rgba(14, 42, 71, .12), 0 32px 80px -28px rgba(14, 42, 71, .48);
  --shadow-gold:  0 12px 32px -14px rgba(184, 138, 62, .55);
  --shadow-bord:  0 14px 36px -16px rgba(14, 42, 71, .55);
  --shadow-aegean: 0 18px 44px -18px rgba(31, 77, 120, .60);

  /* --- Gradients (Hero: neutral dunkler Vignette, kein Farbstich) --- */
  --gradient-hero:      linear-gradient(105deg, rgba(14, 42, 71, .55) 0%, rgba(14, 42, 71, .25) 50%, rgba(14, 42, 71, .05) 80%, rgba(0, 0, 0, 0) 100%);
  --gradient-hero-soft: linear-gradient(180deg, rgba(14, 42, 71, .05) 0%, rgba(14, 42, 71, .55) 100%);
  --gradient-soft:      linear-gradient(180deg, var(--bg-warm), var(--bg-deeper));
  --gradient-gold:      linear-gradient(135deg, var(--gold-leaf) 0%, var(--gold) 50%, var(--gold-deep) 100%);
  --gradient-aegean:    linear-gradient(135deg, var(--action-hover) 0%, var(--action) 55%, var(--action-deep) 100%);
  --gradient-bord:      linear-gradient(135deg, var(--action-hover) 0%, var(--action) 55%, var(--action-deep) 100%);
  --gradient-fresco:    linear-gradient(160deg, #ffffff 0%, #e8eff6 40%, #c4d4e4 75%, #8eafcc 100%);

  /* --- Motion-Tokens (neu, ersetzt monotones cubic-bezier(.2,.7,.3,1)) --- */
  --ease-organic:   cubic-bezier(.22, 1, .36, 1);
  --ease-snap:      cubic-bezier(.34, 1.56, .64, 1);
  --ease-fresco:    cubic-bezier(.45, 0, .15, 1);
  --ease-classical: cubic-bezier(.65, 0, .35, 1);
  --dur-quick:    220ms;
  --dur-base:     520ms;
  --dur-reveal:   900ms;
  --dur-grand:    1600ms;

  --radius-sm: 8px;
  --radius:    14px;
  --radius-lg: 22px;
  --radius-pill: 999px;

  --container: 1280px;
  --container-pad: 2rem;
  --section-pad: 7rem;
  --header-h: 80px;
}

@media (max-width: 768px) {
  :root {
    --container-pad: 1.25rem;
    --section-pad: 4.5rem;
    --header-h: 70px;
  }
  body { font-size: 17px; }
}

/* Typography */
.font-display, h1, h2, h3, h4, h5 {
  font-family: 'Playfair Display', 'Cormorant Garamond', Georgia, serif;
  color: var(--ink);
  letter-spacing: -.015em;
  line-height: 1.08;
}
h1 { font-weight: 800; font-size: clamp(2.6rem, 6vw, 5.4rem); letter-spacing: -.022em; line-height: 1; }
h2 { font-weight: 700; font-size: clamp(2rem, 4.2vw, 3.4rem); letter-spacing: -.018em; line-height: 1.08; }
h3 { font-weight: 700; font-size: clamp(1.35rem, 2.2vw, 1.8rem); letter-spacing: -.012em; }
h4 { font-weight: 700; font-size: 1.2rem; }

p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

.lede {
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  line-height: 1.55;
  color: var(--ink-soft);
  font-weight: 400;
}

.eyebrow {
  display: inline-block;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .32em;
  color: var(--aegean);
  position: relative;
  padding-bottom: 4px;
}
.eyebrow::after {
  content: '';
  position: absolute;
  left: 0; bottom: -2px;
  width: 32px; height: 2px;
  background: var(--aegean);
  opacity: .7;
}

.text-balance { text-wrap: balance; }
.text-pretty  { text-wrap: pretty; }
.text-center  { text-align: center; }

/* Layout */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  position: relative;
}

.section { padding: var(--section-pad) 0; position: relative; }
.section--tight { padding: calc(var(--section-pad) * .6) 0; }
.section--warm  { background: var(--bg-deeper); }
.section--mist  { background: var(--bg-mist); }
.section--cream { background: var(--cream); }
.section--deep  { background: var(--greek-blue-deep); color: rgba(255,253,248,.92); }
.section--deep h1, .section--deep h2, .section--deep h3 { color: #fff; }

.section-head {
  max-width: 720px;
  margin: 0 auto 3.5rem;
  text-align: center;
}
.section-head .eyebrow { margin-bottom: 1.25rem; }
.section-head h2 { margin-bottom: 1rem; }
.section-head p { font-size: 1.1rem; color: var(--ink-soft); }
.section-head--left { margin-left: 0; text-align: left; }
.section-head--left .eyebrow::after { left: 0; }

/* Greek decorative motifs */
.meander {
  height: 12px;
  width: 100%;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='12' viewBox='0 0 48 12'%3E%3Cpath fill='none' stroke='%23c8a157' stroke-width='1.4' d='M0 11 L0 4 L8 4 L8 8 L4 8 L4 6 M16 11 L16 4 L24 4 L24 8 L20 8 L20 6 M32 11 L32 4 L40 4 L40 8 L36 8 L36 6 M48 11 L48 4'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-position: center;
  opacity: .55;
}

.sigil {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--cream);
  border: 1.5px solid var(--gold);
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--greek-blue-deep);
  box-shadow: var(--shadow-soft);
  flex-shrink: 0;
}
.sigil--lg { width: 68px; height: 68px; font-size: 2rem; border-width: 2px; }

/* Header */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  height: var(--header-h);
  transition: background .4s ease, box-shadow .4s ease, border-color .4s ease;
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(214, 226, 238, .9);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  backdrop-filter: blur(18px) saturate(140%);
  border-bottom-color: rgba(31, 77, 120, .18);
  box-shadow: var(--shadow-soft);
}

.nav-inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: .9rem;
  color: var(--ink);
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 1.35rem;
  line-height: 1;
}
.brand-mark {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--cream);
  border: 1.5px solid var(--gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: var(--greek-blue-deep);
  box-shadow: var(--shadow-soft);
  transition: transform .4s ease, box-shadow .4s ease;
}
.brand:hover .brand-mark {
  transform: rotate(-6deg) scale(1.05);
  box-shadow: var(--shadow-card);
}
.brand-sub {
  display: block;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .28em;
  color: var(--gold);
  margin-top: 3px;
}
.brand-text { line-height: 1.05; }

.nav-links {
  display: flex;
  align-items: center;
  gap: 2.3rem;
  font-size: .95rem;
  font-weight: 500;
}
.nav-links a {
  position: relative;
  color: var(--ink);
  padding: 4px 0;
  transition: color .3s ease;
}
.nav-links a::after {
  content: '';
  position: absolute;
  left: 50%; bottom: -4px;
  width: 0; height: 2px;
  background: var(--gold);
  transform: translateX(-50%);
  transition: width .35s ease;
}
.nav-links a:hover, .nav-links a.active { color: var(--greek-blue); }
.nav-links a:hover::after, .nav-links a.active::after { width: 22px; }

.nav-actions {
  display: flex;
  align-items: center;
  gap: .75rem;
}

.menu-btn {
  display: none;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--cream);
  border: 1.5px solid var(--line-strong);
  align-items: center;
  justify-content: center;
  transition: background .3s ease, border-color .3s ease, transform .3s ease;
}
.menu-btn:hover { border-color: var(--aegean); transform: scale(1.05); }
.menu-btn svg { width: 20px; height: 20px; }
.menu-btn .icon-close { display: none; }
.menu-btn.is-open .icon-open { display: none; }
.menu-btn.is-open .icon-close { display: block; }

.nav-mobile {
  position: fixed;
  top: 0; right: -100%;
  width: min(380px, 90vw);
  height: 100dvh;
  background: var(--bg-warm);
  z-index: 99;
  padding: calc(var(--header-h) + 2rem) 2rem 2rem;
  transition: right .45s cubic-bezier(.4,.0,.2,1);
  display: flex;
  flex-direction: column;
  gap: .25rem;
  box-shadow: -30px 0 80px rgba(7, 58, 120, .15);
  overflow-y: auto;
}
.nav-mobile.is-open { right: 0; }
.nav-mobile a {
  display: block;
  padding: 1rem 0;
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--ink);
  border-bottom: 1px solid var(--line);
  transition: color .3s ease, padding .3s ease;
}
.nav-mobile a:hover { color: var(--greek-blue); padding-left: .5rem; }
.nav-mobile-social {
  display: flex;
  gap: 1rem;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--line);
}
.nav-mobile-social a {
  padding: 0;
  border: 0;
  font-size: 0;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--cream);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line-strong);
}
.nav-mobile-social a:hover { padding-left: 0; background: var(--gold); color: white; }
.nav-mobile-social svg { width: 18px; height: 18px; }

.nav-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(7, 58, 120, .35);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  z-index: 98;
  opacity: 0;
  visibility: hidden;
  transition: opacity .4s ease, visibility .4s ease;
}
.nav-backdrop.is-open { opacity: 1; visibility: visible; }

@media (max-width: 1100px) {
  .nav-links { display: none; }
  .menu-btn  { display: inline-flex; }
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  padding: 1rem 1.85rem;
  border-radius: var(--radius-pill);
  font-family: 'Inter', sans-serif;
  font-size: .95rem;
  font-weight: 600;
  white-space: nowrap;
  transition: transform .35s ease, box-shadow .35s ease, background .3s ease, color .3s ease;
  border: 1.5px solid transparent;
  cursor: pointer;
  position: relative;
}
.btn svg { width: 16px; height: 16px; }
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); transition-duration: .1s; }
.btn--sm { padding: .65rem 1.2rem; font-size: .85rem; }
.btn--lg { padding: 1.15rem 2.2rem; font-size: 1rem; }

.btn-reserve {
  background: var(--gradient-bord);
  color: white;
  box-shadow: var(--shadow-bord);
}
.btn-reserve:hover {
  background: var(--bordeaux-hover);
  box-shadow: 0 18px 40px -14px rgba(122, 31, 46, .65);
}

.btn-luxury {
  background: var(--gradient-gold);
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(62, 13, 19, .4);
  box-shadow: var(--shadow-gold);
}
.btn-luxury:hover {
  box-shadow: 0 18px 40px -14px rgba(200, 161, 87, .7);
  color: #ffffff;
}

.btn-primary {
  background: var(--greek-blue);
  color: white;
  box-shadow: 0 8px 22px -10px rgba(13, 94, 175, .55);
}
.btn-primary:hover {
  background: var(--greek-blue-soft);
  box-shadow: 0 14px 30px -12px rgba(13, 94, 175, .7);
}

.btn-outline {
  background: transparent;
  border-color: var(--ink);
  color: var(--ink);
}
.btn-outline:hover { background: var(--ink); color: var(--bg-warm); }

.btn-outline-light {
  background: transparent;
  border-color: rgba(255, 255, 255, .85);
  color: #ffffff;
  font-weight: 700;
  text-shadow: 0 1px 3px rgba(0, 0, 0, .5);
}
.btn-outline-light:hover {
  background: #ffffff;
  color: var(--bordeaux);
  border-color: #ffffff;
  text-shadow: none;
}

.btn-ghost {
  padding: .6rem .2rem;
  color: var(--greek-blue);
  font-weight: 600;
}
.btn-ghost:hover { color: var(--aegean); transform: translateX(4px); }

.phone-pill {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .55rem 1.1rem .55rem .85rem;
  border-radius: var(--radius-pill);
  background: var(--cream);
  border: 1.5px solid var(--line-strong);
  font-size: .92rem;
  font-weight: 600;
  color: var(--ink);
  transition: border-color .3s ease, transform .3s ease, color .3s ease;
}
.phone-pill svg { width: 16px; height: 16px; color: var(--greek-blue); }
.phone-pill:hover {
  border-color: var(--greek-blue);
  color: var(--greek-blue);
  transform: translateY(-2px);
}
@media (max-width: 720px) {
  .phone-pill span { display: none; }
  .phone-pill { padding: .65rem; }
}

/* Hero */
.hero {
  position: relative;
  min-height: 86vh;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding-top: calc(var(--header-h) + 2rem);
  padding-bottom: 4.5rem;
  isolation: isolate;
}
.hero--compact { min-height: 62vh; }
.hero--page    { min-height: 56vh; }

.hero-bg { position: absolute; inset: 0; z-index: -2; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.hero-bg video,
.hero-video { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.hero-overlay { position: absolute; inset: 0; background: var(--gradient-hero); z-index: -1; }

.hero-content { max-width: 760px; color: var(--cream); position: relative; z-index: 5; }
.hero > .container { position: relative; z-index: 5; }
.hero-actions { position: relative; z-index: 6; }
.hero-actions .btn { pointer-events: auto; }
.hero-content .eyebrow { color: #ffffff; opacity: .92; }
.hero-content .eyebrow::after { background: #ffffff; opacity: .6; }
.hero-content h1 {
  color: #ffffff;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  font-family: 'Cinzel', 'Playfair Display', Georgia, serif;
  font-weight: 700;
  letter-spacing: .025em;
  text-transform: uppercase;
  font-size: clamp(2rem, 4.6vw, 3.6rem);
  line-height: 1.15;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
}
.hero-content .lede {
  color: #ffffff;
  max-width: 620px;
  text-shadow: 0 1px 4px rgba(0, 0, 0, .5);
}

.hero-actions {
  display: flex;
  gap: 1rem;
  margin-top: 2.5rem;
  flex-wrap: wrap;
}

.float-badge {
  position: absolute;
  bottom: 2.5rem;
  right: 2.5rem;
  z-index: 2;
  padding: .65rem 1rem .7rem;
  background: rgba(255, 255, 255, .14);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, .35);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  text-align: left;
  display: inline-flex;
  align-items: center;
  gap: .8rem;
}
.float-badge strong {
  font-family: 'Inter', sans-serif;
  font-size: .95rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.1;
  letter-spacing: .01em;
}
.float-badge span {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .78rem;
  font-weight: 500;
  letter-spacing: .04em;
  color: rgba(255, 255, 255, .82);
  line-height: 1;
}
.float-badge span::before {
  content: "★";
  color: #f0c25a;
  font-size: .95rem;
  line-height: 1;
}
@media (max-width: 900px) {
  .float-badge { bottom: 1rem; right: 1rem; padding: .5rem .8rem; gap: .55rem; }
  .float-badge strong { font-size: .85rem; }
  .float-badge span { font-size: .7rem; }
}

.page-hero {
  position: relative;
  padding-top: calc(var(--header-h) + 5rem);
  padding-bottom: 4rem;
  background: var(--gradient-soft);
  overflow: hidden;
  isolation: isolate;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: -1px;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cg fill='none' stroke='%230d5eaf' stroke-width='1' opacity='.04'%3E%3Cpath d='M0 0 L0 30 L60 30 L60 60 L30 60 L30 45'/%3E%3Cpath d='M90 90 L90 120 L150 120 L150 150 L120 150 L120 135'/%3E%3C/g%3E%3C/svg%3E");
  z-index: -1;
}
.page-hero .container { max-width: 900px; text-align: center; }
.page-hero .eyebrow { margin-bottom: 1.5rem; }
.page-hero h1 { margin-bottom: 1.25rem; }
.page-hero .lede { margin: 0 auto; max-width: 620px; }

/* Stats */
.stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem;
  padding: 3rem 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-top: 3rem;
}
.stat { text-align: center; position: relative; }
.stat + .stat::before {
  content: '';
  position: absolute;
  left: -1.25rem; top: 15%;
  width: 1px; height: 70%;
  background: var(--line);
}
.stat-value {
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: clamp(2.2rem, 3.6vw, 3rem);
  color: var(--greek-blue-deep);
  line-height: 1;
  display: block;
}
.stat-label {
  display: block;
  margin-top: .75rem;
  font-size: .8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--ink-muted);
}
@media (max-width: 700px) {
  .stats { grid-template-columns: 1fr; gap: 2rem; }
  .stat + .stat::before { display: none; }
}

/* Cards */
.cards { display: grid; gap: 2rem; }
.cards-2 { grid-template-columns: repeat(2, 1fr); }
.cards-3 { grid-template-columns: repeat(3, 1fr); }
.cards-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) {
  .cards-3, .cards-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .cards-2, .cards-3, .cards-4 { grid-template-columns: 1fr; }
}

.card {
  background: var(--cream);
  padding: 2.5rem;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-card);
  transition: transform .55s cubic-bezier(.2,.7,.3,1),
              box-shadow .55s cubic-bezier(.2,.7,.3,1),
              border-color .4s ease;
  position: relative;
  overflow: hidden;
}
.card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-luxe);
  border-color: var(--aegean-soft);
}
.card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gradient-aegean);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .55s ease;
}
.card:hover::before { transform: scaleX(1); }

.card-icon {
  width: 56px; height: 56px;
  margin-bottom: 1.5rem;
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, rgba(13, 94, 175, .08), rgba(200, 161, 87, .12));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--greek-blue);
  transition: transform .4s ease, background .3s ease;
}
.card-icon svg { width: 26px; height: 26px; }
.card:hover .card-icon {
  transform: scale(1.1) rotate(-4deg);
  background: linear-gradient(135deg, rgba(13, 94, 175, .12), rgba(200, 161, 87, .22));
}

.card h3 { margin-bottom: 1rem; color: var(--ink); }
.card p { color: var(--ink-soft); font-size: .98rem; line-height: 1.65; }
.card-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  margin-top: 1.5rem;
  font-size: .9rem;
  font-weight: 600;
  color: var(--greek-blue);
  transition: color .3s ease, gap .3s ease;
}
.card-link::after { content: '→'; transition: transform .3s ease; }
.card:hover .card-link { color: var(--aegean-deep); gap: .8rem; }
.card:hover .card-link::after { transform: translateX(3px); }

.card-img {
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  box-shadow: var(--shadow-card);
  transition: transform .55s cubic-bezier(.2,.7,.3,1), box-shadow .55s cubic-bezier(.2,.7,.3,1);
}
.card-img:hover { transform: translateY(-8px); box-shadow: var(--shadow-luxe); }
.card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .9s cubic-bezier(.2,.7,.3,1);
}
.card-img:hover img { transform: scale(1.06); }

.card-img-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 2rem 1.5rem 1.25rem;
  background: linear-gradient(180deg, transparent, rgba(7,58,120,.85));
  color: var(--cream);
  font-size: .9rem;
  font-weight: 500;
}
.card-img-caption strong {
  display: block;
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: .25rem;
}

/* Special offer cards */
.special {
  position: relative;
  background: var(--cream);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: transform .55s ease, box-shadow .55s ease;
  display: flex;
  flex-direction: column;
}
.special:hover { transform: translateY(-8px); box-shadow: var(--shadow-luxe); }
.special-img { aspect-ratio: 4/3; overflow: hidden; position: relative; }
.special-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .9s ease;
}
.special:hover .special-img img { transform: scale(1.05); }
.special-body { padding: 2rem 2rem 2.25rem; }
.special-badge {
  position: absolute;
  top: 1rem; right: 1rem;
  background: var(--gradient-gold);
  color: var(--greek-blue-deep);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .25em;
  text-transform: uppercase;
  padding: .45rem .9rem;
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-gold);
  z-index: 2;
}
.special h3 { margin-bottom: .75rem; }
.special-mech {
  margin-top: 1.25rem;
  padding: 1rem 1.2rem;
  background: var(--bg-warm);
  border-left: 3px solid var(--gold);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-size: .92rem;
  color: var(--ink-soft);
}
.special-mech strong { color: var(--greek-blue-deep); font-weight: 700; }
.special-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 1.5rem;
  font-size: .82rem;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: .15em;
}

.three-glyph {
  display: inline-flex;
  align-items: baseline;
  gap: .35rem;
  font-family: 'Playfair Display', serif;
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--gold);
  letter-spacing: -.04em;
  margin-bottom: 1rem;
}
.three-glyph .ths-plus { color: var(--gold-soft); font-size: 1.2rem; opacity: .6; }
.three-glyph .ths-eq   { color: var(--ink-muted); font-size: 1.1rem; opacity: .5; }
.three-glyph .ths-fin  { color: var(--greek-blue); font-size: 2rem; }

/* Split layout */
.split {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 5rem;
  align-items: center;
}
@media (max-width: 900px) {
  .split { grid-template-columns: 1fr; gap: 2.5rem; }
}

.split-img {
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  box-shadow: var(--shadow-luxe);
  aspect-ratio: 4/5;
}
.split-img img { width: 100%; height: 100%; object-fit: cover; }
.split-img-tag {
  position: absolute;
  bottom: 1.25rem;
  left: 1.25rem;
  padding: .65rem 1rem;
  background: var(--cream);
  border-radius: var(--radius-sm);
  font-size: .8rem;
  font-weight: 600;
  color: var(--greek-blue-deep);
  box-shadow: var(--shadow-card);
}
.split-img-tag span {
  display: block;
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--gold-deep);
  margin-bottom: 2px;
}

/* Lunch band */
.lunch-band {
  background: linear-gradient(135deg, var(--greek-blue-deep) 0%, var(--greek-blue) 100%);
  color: var(--cream);
  border-radius: var(--radius-lg);
  padding: 4rem 3rem;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.lunch-band::before {
  content: 'Σ';
  position: absolute;
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 28rem;
  right: -2rem;
  bottom: -8rem;
  color: rgba(200, 161, 87, .12);
  line-height: .8;
  z-index: -1;
  pointer-events: none;
}
.lunch-band .eyebrow { color: #ffffff; opacity: .92; }
.lunch-band .eyebrow::after { background: var(--gold-soft); }
.lunch-band h2 { color: white; margin: 1rem 0; }
.lunch-band p { color: rgba(255,253,248,.88); max-width: 540px; margin-bottom: 2rem; }
.lunch-band-price {
  display: inline-flex;
  align-items: baseline;
  gap: .35rem;
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 3rem;
  color: var(--gold-soft);
  line-height: 1;
  margin-bottom: 2rem;
}
.lunch-band-price span {
  font-size: 1.1rem;
  font-weight: 600;
  color: rgba(255,253,248,.7);
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-right: .5rem;
}
.lunch-band-price small {
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  font-weight: 500;
  color: rgba(255,253,248,.7);
  text-transform: uppercase;
  letter-spacing: .15em;
}

/* Menu blocks */
.menu-block {
  margin-bottom: 4rem;
  padding: 2.5rem;
  background: var(--cream);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--line);
  position: relative;
}
.menu-block:last-of-type { margin-bottom: 0; }

.menu-block-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 1.5rem;
  margin-bottom: 2rem;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.menu-block-head h2 {
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  color: var(--greek-blue-deep);
}
.menu-block-tag {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .28em;
  color: var(--gold-deep);
  padding: .35rem .8rem;
  background: rgba(200, 161, 87, .12);
  border-radius: var(--radius-pill);
}

.menu-list { display: flex; flex-direction: column; }
.menu-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1.25rem;
  padding: 1.25rem 0;
  border-bottom: 1px dashed var(--line);
  align-items: baseline;
}
.menu-item:last-child { border-bottom: 0; }
.menu-item h4 {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  font-size: 1.2rem;
  color: var(--ink);
  margin-bottom: .35rem;
}
.menu-item p { font-size: .95rem; color: var(--ink-soft); margin: 0; }
.menu-item-price {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--greek-blue);
  white-space: nowrap;
  padding-left: 1rem;
}
.menu-item-tag {
  display: inline-block;
  margin-left: .5rem;
  padding: .15rem .55rem;
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--gold-deep);
  background: rgba(200, 161, 87, .15);
  border-radius: var(--radius-pill);
  vertical-align: middle;
}

.menu-feature {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 2rem;
  margin-bottom: 2rem;
  padding: 1.75rem;
  background: var(--bg-warm);
  border-radius: var(--radius);
  border: 1px solid var(--line-gold);
}
.menu-feature-img { border-radius: var(--radius-sm); overflow: hidden; aspect-ratio: 4/3; }
.menu-feature-img img { width: 100%; height: 100%; object-fit: cover; }
.menu-feature-body { display: flex; flex-direction: column; justify-content: center; }
.menu-feature-tag {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .28em;
  color: var(--gold-deep);
  margin-bottom: .5rem;
}
.menu-feature h3 { font-size: 1.5rem; margin-bottom: .75rem; }
.menu-feature-price {
  display: inline-block;
  margin-top: 1rem;
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 1.5rem;
  color: var(--greek-blue);
}
@media (max-width: 700px) {
  .menu-feature { grid-template-columns: 1fr; }
}

/* Testimonials */
.testimonial {
  background: var(--cream);
  padding: 2.25rem;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-card);
  transition: transform .5s ease, box-shadow .5s ease;
  position: relative;
}
.testimonial:hover { transform: translateY(-6px); box-shadow: var(--shadow-luxe); }
.testimonial-quote {
  position: absolute;
  top: 1rem; left: 1.25rem;
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 4.5rem;
  color: var(--gold);
  opacity: .25;
  line-height: 1;
  pointer-events: none;
}
.testimonial-stars {
  display: inline-flex;
  gap: .15rem;
  color: var(--gold);
  font-size: 1rem;
  margin-bottom: 1rem;
  position: relative;
}
.testimonial-text {
  font-size: 1.02rem;
  color: var(--ink);
  line-height: 1.6;
  font-style: italic;
  margin-bottom: 1.5rem;
  position: relative;
}
.testimonial-meta {
  display: flex;
  align-items: center;
  gap: .85rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--line);
}
.testimonial-avatar {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--gradient-gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 1rem;
  color: var(--greek-blue-deep);
  flex-shrink: 0;
}
.testimonial-author { display: block; font-weight: 600; font-size: .95rem; color: var(--ink); }
.testimonial-source {
  display: block;
  font-size: .78rem;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-top: 2px;
}

/* Gallery */
.gallery {
  /* Echtes Masonry via CSS-columns — jedes Bild behält seine natürliche Proportion, kein Cropping */
  columns: 3;
  column-gap: 1rem;
}
@media (max-width: 900px) { .gallery { columns: 2; } }
@media (max-width: 540px) { .gallery { columns: 1; } }

.gallery-item {
  position: relative;
  display: block;
  break-inside: avoid;
  margin: 0 0 1rem;
  overflow: hidden;
  border-radius: var(--radius);
  cursor: zoom-in;
  box-shadow: var(--shadow-card);
  transition: transform .55s ease, box-shadow .55s ease;
}
.gallery-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-luxe); }
.gallery-item img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .9s cubic-bezier(.2,.7,.3,1);
}
.gallery-item:hover img { transform: scale(1.04); }
.gallery-item-caption {
  position: absolute;
  inset: auto 0 0 0;
  padding: 1.5rem 1.25rem 1rem;
  background: linear-gradient(180deg, transparent, rgba(7,58,120,.85));
  color: white;
  font-size: .9rem;
  font-weight: 500;
  transform: translateY(100%);
  transition: transform .5s ease;
}
.gallery-item-caption strong {
  display: block;
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  margin-bottom: .15rem;
}
.gallery-item:hover .gallery-item-caption { transform: translateY(0); }

.g-w6 { grid-column: span 6; }
.g-w4 { grid-column: span 4; }
.g-w3 { grid-column: span 3; }
.g-w8 { grid-column: span 8; }
.g-h2 { grid-row: span 2; }
.g-h3 { grid-row: span 3; }

.gallery-item--placeholder {
  background: linear-gradient(135deg, var(--bg-warm), var(--bg-deeper));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-muted);
  font-size: .85rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  border: 2px dashed var(--line-gold);
  cursor: default;
}
.gallery-item--placeholder:hover { transform: none; box-shadow: var(--shadow-card); }
.gallery-item--placeholder span { display: flex; align-items: center; gap: .5rem; }
.gallery-item--placeholder svg { width: 22px; height: 22px; opacity: .5; }

@media (max-width: 900px) {
  .gallery { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 100px; }
  .g-w6, .g-w8 { grid-column: span 6; }
  .g-w4 { grid-column: span 3; }
  .g-w3 { grid-column: span 3; }
}

.placeholder-banner {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: rgba(200, 161, 87, .12);
  border: 1px solid var(--line-gold);
  border-left-width: 3px;
  border-radius: var(--radius-sm);
  font-size: .92rem;
  color: var(--ink-soft);
  margin-bottom: 3rem;
}
.placeholder-banner svg {
  width: 20px; height: 20px;
  color: var(--gold-deep);
  flex-shrink: 0;
  margin-top: 1px;
}
.placeholder-banner strong { color: var(--ink); }

/* Lightbox */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(7, 58, 120, .95);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity .4s ease, visibility .4s ease;
}
.lightbox.is-open { opacity: 1; visibility: visible; }
.lightbox-img {
  max-width: 90vw;
  max-height: 85vh;
  border-radius: var(--radius);
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
  object-fit: contain;
}
.lightbox-nav {
  position: absolute;
  top: 50%;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.25);
  color: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .3s ease, transform .3s ease;
  transform: translateY(-50%);
}
.lightbox-nav:hover { background: rgba(255,255,255,.2); transform: translateY(-50%) scale(1.1); }
.lightbox-nav--prev { left: 1.5rem; }
.lightbox-nav--next { right: 1.5rem; }
.lightbox-nav svg { width: 22px; height: 22px; }
.lightbox-close {
  position: absolute;
  top: 1.5rem; right: 1.5rem;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.25);
  color: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .3s ease, transform .3s ease;
}
.lightbox-close:hover { background: rgba(255,255,255,.2); transform: rotate(90deg); }
.lightbox-close svg { width: 18px; height: 18px; }
.lightbox-caption {
  position: absolute;
  bottom: 1.5rem; left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,.85);
  font-size: .9rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* Carousel */
.carousel { position: relative; }
.carousel-track {
  display: flex;
  gap: 1.5rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 1.5rem;
  scroll-padding: var(--container-pad);
}
.carousel-track::-webkit-scrollbar { display: none; }
.carousel-slide {
  flex: 0 0 calc(33.333% - 1rem);
  scroll-snap-align: start;
  min-width: 280px;
}
.carousel-nav {
  display: flex;
  gap: .75rem;
  justify-content: flex-end;
  margin-top: 1rem;
}
.carousel-btn {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--cream);
  border: 1.5px solid var(--gold);
  color: var(--greek-blue-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .3s ease, transform .3s ease, border-color .3s ease;
  box-shadow: var(--shadow-soft);
}
.carousel-btn:hover { background: var(--gold); color: var(--cream); transform: scale(1.05); }
.carousel-btn:disabled { opacity: .35; cursor: not-allowed; transform: none; }
.carousel-btn svg { width: 18px; height: 18px; }

@media (max-width: 900px) {
  .carousel-slide { flex: 0 0 calc(80% - .5rem); }
}

/* Booking form */
.booking {
  background: var(--cream);
  padding: 2.5rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-luxe);
  border: 1px solid var(--line);
  position: relative;
}
.booking-head {
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--line);
}
.booking-head h2 { margin-bottom: .5rem; }
.booking-head p { color: var(--ink-soft); margin: 0; font-size: .95rem; }

.field { display: flex; flex-direction: column; gap: .4rem; margin-bottom: 1rem; }
.field-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-bottom: 1rem;
}
.field-row--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 640px) {
  .field-row, .field-row--3 { grid-template-columns: 1fr; }
}
.field-row > .field { margin-bottom: 0; }

.field label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: .12em;
}
.field label .req { color: var(--warn); margin-left: 2px; }
.field input,
.field select,
.field textarea {
  width: 100%;
  padding: .85rem 1rem;
  border: 1.5px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--bg-mist);
  color: var(--ink);
  font-size: .95rem;
  transition: border-color .3s ease, box-shadow .3s ease, background .3s ease;
}
.field input::placeholder, .field textarea::placeholder { color: var(--ink-muted); }
.field input:hover, .field select:hover, .field textarea:hover { border-color: var(--ink-muted); }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: 0;
  border-color: var(--gold);
  background: var(--cream);
  box-shadow: 0 0 0 4px rgba(200, 161, 87, .15);
}
.field textarea { min-height: 110px; resize: vertical; }

.field.is-invalid input,
.field.is-invalid select,
.field.is-invalid textarea {
  border-color: var(--warn);
  background: rgba(192, 85, 46, .04);
}
.field-error {
  display: none;
  font-size: .82rem;
  color: var(--warn);
  margin-top: 2px;
}
.field.is-invalid .field-error { display: block; }

.booking-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
}
.booking-foot small {
  font-size: .82rem;
  color: var(--ink-muted);
  max-width: 320px;
}

.booking [type="submit"] { position: relative; min-width: 200px; }
.booking [type="submit"][data-loading="true"] { pointer-events: none; opacity: .85; }
.booking [type="submit"][data-loading="true"] .btn-spinner { display: inline-block; }
.btn-spinner {
  display: none;
  width: 14px; height: 14px;
  border: 2px solid currentColor;
  border-bottom-color: transparent;
  border-radius: 50%;
  animation: spin .6s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.toast {
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  background: var(--cream);
  border: 1.5px solid var(--gold);
  border-radius: var(--radius);
  padding: 1.25rem 1.5rem;
  box-shadow: var(--shadow-luxe);
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  max-width: min(440px, calc(100vw - 2rem));
  z-index: 150;
  transition: transform .55s cubic-bezier(.2,.7,.3,1), opacity .4s ease;
  opacity: 0;
}
.toast.is-open { transform: translateX(-50%) translateY(0); opacity: 1; }
.toast svg {
  width: 22px; height: 22px;
  color: var(--gold-deep);
  flex-shrink: 0;
  margin-top: 1px;
}
.toast strong { display: block; color: var(--ink); font-size: .98rem; margin-bottom: .15rem; }
.toast span { font-size: .88rem; color: var(--ink-soft); }

/* Info box */
.info-box {
  background: var(--cream);
  padding: 2.5rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-card);
  height: fit-content;
}
.info-row { display: flex; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid var(--line); }
.info-row:last-child { border-bottom: 0; }
.info-row-icon {
  width: 38px; height: 38px;
  border-radius: var(--radius-sm);
  background: rgba(13, 94, 175, .08);
  color: var(--greek-blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.info-row-icon svg { width: 18px; height: 18px; }
.info-row-body strong {
  display: block;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--ink-muted);
  margin-bottom: .25rem;
}
.info-row-body p,
.info-row-body a { font-size: 1rem; color: var(--ink); margin: 0; }
.info-row-body a:hover { color: var(--greek-blue); }

.map-frame {
  margin-top: 1.5rem;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 16/10;
  border: 1px solid var(--line);
  background: linear-gradient(135deg, var(--bg-warm), var(--bg-deeper));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-muted);
  font-size: .9rem;
}
.map-frame iframe { width: 100%; height: 100%; border: 0; }

/* CTA Band */
.cta-band {
  background: linear-gradient(135deg, var(--greek-blue-deep) 0%, var(--greek-blue) 100%);
  color: var(--cream);
  border-radius: var(--radius-lg);
  padding: 4.5rem 3rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.cta-band::before, .cta-band::after {
  content: '';
  position: absolute;
  width: 240px; height: 240px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,161,87,.18), transparent 70%);
  z-index: -1;
}
.cta-band::before { top: -80px; left: -80px; }
.cta-band::after  { bottom: -100px; right: -80px; }
.cta-band .eyebrow { color: #ffffff; opacity: .92; margin-bottom: 1.5rem; }
.cta-band .eyebrow::after { background: var(--gold-soft); left: 50%; transform: translateX(-50%); }
.cta-band h2 { color: white; max-width: 720px; margin: 0 auto 1rem; }
.cta-band p {
  max-width: 540px;
  margin: 0 auto 2.5rem;
  color: rgba(255,253,248,.85);
  font-size: 1.05rem;
}
.cta-band-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
@media (max-width: 700px) {
  .cta-band { padding: 3rem 1.5rem; }
}

/* Footer */
.footer {
  background: var(--aegean-deep);
  color: rgba(255,255,255,.78);
  padding: 5rem 0 2rem;
  font-size: .92rem;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}
@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
}
@media (max-width: 540px) {
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
}
.footer-brand .brand { color: white; margin-bottom: 1.25rem; }
.footer-brand .brand-mark {
  background: rgba(255,255,255,.08);
  border-color: rgba(214, 226, 238, .55);
  color: #ffffff;
}
.footer-brand p {
  font-size: .92rem;
  line-height: 1.65;
  color: rgba(255,253,248,.6);
  max-width: 320px;
}
.footer-col h4 {
  color: white;
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 1.25rem;
}
.footer-col ul { display: flex; flex-direction: column; gap: .65rem; }
.footer-col a {
  color: rgba(255,253,248,.72);
  transition: color .3s ease, padding-left .3s ease;
}
.footer-col a:hover { color: #ffffff; padding-left: 4px; }
.footer-col li { font-size: .92rem; line-height: 1.5; }

.footer-social { display: flex; gap: .65rem; margin-top: 1.25rem; }
.footer-social a {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,253,248,.08);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,253,248,.7);
  border: 1px solid rgba(255,253,248,.12);
  transition: background .3s ease, color .3s ease, border-color .3s ease;
}
.footer-social a:hover {
  background: #ffffff;
  color: var(--aegean-deep);
  border-color: #ffffff;
  padding-left: 0;
}
.footer-social svg { width: 16px; height: 16px; }

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 2rem;
  border-top: 1px solid rgba(255,253,248,.1);
  font-size: .82rem;
  color: rgba(255,253,248,.5);
  flex-wrap: wrap;
  gap: 1rem;
}
.footer-bottom a:hover { color: #ffffff; }
.footer-meta { display: flex; gap: 1.5rem; }

/* Scroll reveal */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s cubic-bezier(.2,.7,.3,1), transform .9s cubic-bezier(.2,.7,.3,1);
}
[data-reveal].is-revealed { opacity: 1; transform: translateY(0); }
[data-reveal][data-reveal-delay="1"] { transition-delay: .08s; }
[data-reveal][data-reveal-delay="2"] { transition-delay: .16s; }
[data-reveal][data-reveal-delay="3"] { transition-delay: .24s; }
[data-reveal][data-reveal-delay="4"] { transition-delay: .32s; }
[data-reveal="fade"] { transform: none; }
[data-reveal="scale"] { transform: scale(.96); }
[data-reveal="scale"].is-revealed { transform: scale(1); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0s !important;
    transition-duration: 0s !important;
  }
  [data-reveal] { opacity: 1; transform: none; }
}

/* Story / über-uns */
.story-block {
  max-width: 720px;
  margin: 0 auto;
  font-size: 1.08rem;
  line-height: 1.75;
  color: var(--ink-soft);
}
.story-block p { margin-bottom: 1.25rem; }
.story-block p:first-of-type::first-letter {
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 4.2rem;
  float: left;
  line-height: .9;
  margin: .15rem .6rem 0 0;
  color: var(--gold-deep);
}

/* Checklist */
.checklist {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem 2rem;
  max-width: 720px;
  margin: 2rem auto 0;
}
.checklist li {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  padding: .85rem 0;
  font-size: 1rem;
  color: var(--ink);
}
.checklist li::before {
  content: '';
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--greek-blue);
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 14px;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
  margin-top: 2px;
}
@media (max-width: 640px) {
  .checklist { grid-template-columns: 1fr; }
}

/* Three-step */
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  position: relative;
}
.step {
  text-align: center;
  position: relative;
  padding: 0 .5rem;
}
.step-num {
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 4rem;
  color: var(--gold);
  line-height: 1;
  display: block;
  margin-bottom: .5rem;
  opacity: .6;
}
.step h4 { margin-bottom: .5rem; font-size: 1.25rem; }
.step p { font-size: .95rem; color: var(--ink-soft); }
@media (max-width: 720px) {
  .steps { grid-template-columns: 1fr; }
}

/* Legal */
.legal-content { max-width: 720px; margin: 0 auto; }
.legal-content h2 {
  font-size: 1.5rem;
  margin: 2.5rem 0 1rem;
  color: var(--greek-blue-deep);
}
.legal-content h2:first-child { margin-top: 0; }
.legal-content p { margin-bottom: 1rem; line-height: 1.7; }
.legal-content address {
  font-style: normal;
  padding: 1.25rem 1.5rem;
  background: var(--cream);
  border-left: 3px solid var(--gold);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin-bottom: 1.5rem;
}
.legal-content a {
  color: var(--greek-blue);
  border-bottom: 1px dotted var(--greek-blue);
}
.legal-content a:hover { color: var(--gold-deep); border-color: var(--gold-deep); }

/* 404 */
.error-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  background: linear-gradient(135deg, var(--greek-blue-deep), var(--greek-blue));
  color: var(--cream);
  text-align: center;
}
.error-page-inner {
  max-width: 540px;
  background: var(--cream);
  color: var(--ink);
  padding: 3.5rem 2.5rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-luxe);
}
.error-page-code {
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 7rem;
  line-height: 1;
  color: var(--gold);
  margin-bottom: 1rem;
}

/* Utility */
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: 1rem; }
.mt-2 { margin-top: 2rem; }
.mt-3 { margin-top: 3rem; }
.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: 1rem; }
.mb-2 { margin-bottom: 2rem; }
.gold { color: var(--gold-deep); }
.blue { color: var(--greek-blue); }
.flex-center { display: flex; align-items: center; justify-content: center; }
.gap-1 { gap: 1rem; }
.gap-2 { gap: 2rem; }

@media print {
  .nav, .footer, .nav-mobile, .nav-backdrop, .menu-btn, .booking, .cta-band { display: none !important; }
  body { background: white; color: black; }
}

/* ============================================================
   PHASE 2 — WOW-EFFECT LAYER
   Page-Loader · Marquee · Pillars · Mask-Reveal · Cursor ·
   Letter-Reveal · Sticky-Headlines · Menu Search · 360°
   ============================================================ */

/* ---- Logo brand swap ---- */
.brand-img {
  height: 52px;
  width: auto;
  display: block;
  transition: transform .4s ease;
}
.brand:hover .brand-img { transform: rotate(-1.5deg) scale(1.02); }
@media (max-width: 720px) {
  .brand-img { height: 42px; }
}
.footer-brand .brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ffffff;
  padding: 10px 14px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .15);
}
.footer-brand .brand-img {
  filter: none;
}

/* ============================================================
   1. PAGE-LOAD INTRO (~1.5s, einmalig pro Session)
   ============================================================ */
.page-loader {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: linear-gradient(135deg, var(--aegean) 0%, var(--aegean-deep) 55%, #061a30 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 1.5rem;
  pointer-events: all;
  transition: clip-path 1.2s cubic-bezier(.85,0,.25,1), opacity .6s ease;
  clip-path: circle(150% at 50% 50%);
  overflow: hidden;
}
.page-loader.is-leaving {
  clip-path: circle(0% at 50% 100%);
  pointer-events: none;
}
.page-loader.is-gone {
  display: none;
}

.loader-meander {
  width: 80vw;
  max-width: 540px;
  height: 38px;
  opacity: 0;
  animation: loaderFade .9s ease-out .1s forwards;
}
.loader-meander path {
  stroke-dasharray: 1200;
  stroke-dashoffset: 1200;
  animation: drawMeander 1.3s cubic-bezier(.55,.085,0,.99) .25s forwards;
}
@keyframes drawMeander {
  to { stroke-dashoffset: 0; }
}

.loader-wordmark {
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: clamp(2.2rem, 6vw, 4.2rem);
  color: #ffffff;
  letter-spacing: .1em;
  opacity: 0;
  transform: translateY(20px);
  animation: loaderWord 1s cubic-bezier(.2,.7,.3,1) .55s forwards;
}
.loader-sub {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: .85rem;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: rgba(214, 226, 238, .85);
  opacity: 0;
  transform: translateY(12px);
  animation: loaderWord .8s cubic-bezier(.2,.7,.3,1) .85s forwards;
}
.loader-olive {
  width: 64px; height: 64px;
  opacity: 0;
  transform: rotate(-12deg) scale(.85);
  animation: loaderOlive .9s cubic-bezier(.2,.7,.3,1) .4s forwards;
}
.loader-skip {
  position: absolute;
  bottom: 2rem;
  right: 2rem;
  font-size: .78rem;
  color: rgba(255,255,255,.55);
  letter-spacing: .2em;
  text-transform: uppercase;
  opacity: 0;
  animation: loaderFade .6s ease 1.2s forwards;
  cursor: pointer;
}
.loader-skip:hover { color: #ffffff; }
.loader-skip:hover { color: var(--gold-soft); }

@keyframes loaderFade { to { opacity: 1; } }
@keyframes loaderWord { to { opacity: 1; transform: translateY(0); } }
@keyframes loaderOlive { to { opacity: .9; transform: rotate(0deg) scale(1); } }

/* ============================================================
   2. MARQUEE
   ============================================================ */
.hero-olive-drift {
  position: absolute;
  top: 25%;
  right: 6%;
  width: 80px; height: 80px;
  z-index: 1;
  opacity: .7;
  animation: oliveDrift 8s ease-in-out infinite;
  pointer-events: none;
}
@keyframes oliveDrift {
  0%, 100% { transform: rotate(-3deg) translateY(0); }
  50%      { transform: rotate(3deg) translateY(-12px); }
}
@media (max-width: 720px) { .hero-olive-drift { display: none; } }

/* ============================================================
   4. LETTER-REVEAL (Hero H1)
   ============================================================ */
.letter-reveal {
  display: inline-block;
  overflow: hidden;
}
.letter-reveal .lr-word {
  display: inline-block;
  white-space: nowrap;
  margin-right: .2em;
}
.letter-reveal .lr-char {
  display: inline-block;
  transform: translateY(110%);
  opacity: 0;
  animation: letterRise .9s cubic-bezier(.2,.7,.3,1) forwards;
  animation-delay: calc(var(--i) * 38ms + var(--base, 0ms));
}
@keyframes letterRise {
  to { transform: translateY(0); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .letter-reveal .lr-char { animation: none; transform: none; opacity: 1; }
}

/* ============================================================
   5. MASK-REVEAL (Images on scroll)
   ============================================================ */
.mask-reveal {
  position: relative;
  overflow: hidden;
}
.mask-reveal img,
.mask-reveal video {
  clip-path: inset(100% 0 0 0);
  transform: scale(1.08);
  transition: clip-path 1.1s cubic-bezier(.55,.085,0,.99),
              transform 1.4s cubic-bezier(.2,.7,.3,1);
}
.mask-reveal.is-revealed img,
.mask-reveal.is-revealed video {
  clip-path: inset(0 0 0 0);
  transform: scale(1);
}

/* ============================================================
   6. STICKY SECTION HEADLINE
   ============================================================ */
.sticky-section {
  position: relative;
}
.sticky-section .sticky-head {
  position: sticky;
  top: calc(var(--header-h) + 1rem);
  align-self: start;
}
@media (max-width: 980px) {
  .sticky-section .sticky-head { position: static; }
}

/* ============================================================
   7. GREEK ALPHABET WATERMARK (Section deco)
   ============================================================ */
.greek-watermark {
  position: absolute;
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: clamp(8rem, 18vw, 20rem);
  color: var(--ink);
  opacity: .035;
  letter-spacing: -.05em;
  line-height: 1;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.greek-watermark--right { right: -3rem; top: 20%; }
.greek-watermark--left  { left: -3rem; top: 30%; }

/* ============================================================
   9. PILLAR DECORATIVE STRIP (between sections)
   ============================================================ */
.pillar-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  padding: 1.25rem 0;
  background: var(--bg-warm);
  position: relative;
}
.pillar-strip::before,
.pillar-strip::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,161,87,.4), transparent);
  max-width: 240px;
}
.pillar-strip svg {
  width: 28px; height: 28px;
  opacity: .65;
}

/* ============================================================
   10. MENU STICKY NAV — Search + Veg Filter + Jump-to-Section
   ============================================================ */

/* Page-Hero --menu Modifier: cleanes Aegean-Mist statt Gradient-Soft */
.page-hero--menu {
  background: var(--aegean-mist);
  border-bottom: 1px solid rgba(31, 77, 120, .12);
}
.page-hero--menu::before {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cg fill='none' stroke='%230e2a47' stroke-width='1' opacity='.07'%3E%3Cpath d='M0 0 L0 30 L60 30 L60 60 L30 60 L30 45'/%3E%3Cpath d='M90 90 L90 120 L150 120 L150 150 L120 150 L120 135'/%3E%3C/g%3E%3C/svg%3E");
}

/* Combined sticky nav: contains search + filter + jump-buttons */
.menu-sticky-nav {
  position: sticky;
  top: calc(var(--header-h) - 1px);
  z-index: 40;
  background: rgba(255, 255, 255, .94);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  backdrop-filter: blur(18px) saturate(140%);
  padding: .9rem 0 .65rem;
  border-bottom: 1px solid rgba(31, 77, 120, .18);
  box-shadow: 0 6px 24px -16px rgba(14, 42, 71, .25);
  margin-bottom: 3rem;
}

/* Top row: Search + Veg-Toggle */
.menu-search-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  max-width: 760px;
  margin: 0 auto;
}
.menu-search {
  display: flex;
  align-items: center;
  gap: .85rem;
  flex: 1;
  background: #ffffff;
  border: 1.5px solid rgba(31, 77, 120, .18);
  border-radius: var(--radius-pill);
  padding: .7rem 1.2rem;
  box-shadow: 0 2px 8px -4px rgba(14, 42, 71, .12);
  transition: border-color .25s ease, box-shadow .25s ease;
}
.menu-search:focus-within {
  border-color: var(--aegean);
  box-shadow: 0 0 0 4px rgba(31, 77, 120, .12), 0 4px 14px -4px rgba(14, 42, 71, .25);
}
.menu-search-icon { width: 18px; height: 18px; color: var(--aegean-deep); flex-shrink: 0; }
.menu-search input {
  flex: 1;
  border: 0;
  background: transparent;
  outline: 0;
  font-size: 1rem;
  color: var(--ink);
  min-width: 0;
}
.menu-search input::placeholder { color: var(--ink-muted); }
.menu-search-count {
  font-size: .76rem;
  color: var(--aegean-deep);
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  white-space: nowrap;
}
.menu-search-clear {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--aegean-mist);
  color: var(--aegean-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 600;
  transition: background .2s ease, transform .2s ease;
}
.menu-search-clear:hover { background: var(--aegean); color: #ffffff; transform: rotate(90deg); }
.menu-search-shortcut {
  font-size: .7rem;
  letter-spacing: .15em;
  color: var(--ink-muted);
  border: 1px solid rgba(31, 77, 120, .25);
  padding: .2rem .45rem;
  border-radius: 6px;
  flex-shrink: 0;
}
@media (max-width: 720px) {
  .menu-search-shortcut { display: none; }
  .menu-search-row { flex-direction: column; gap: .5rem; }
  .menu-search { width: 100%; }
}

/* Jump-Navigation: horizontale scrollbare Category-Links */
.menu-jump-nav {
  display: flex;
  align-items: center;
  gap: .25rem;
  margin-top: .75rem;
  padding: 0 .25rem;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-snap-type: x proximity;
}
.menu-jump-nav::-webkit-scrollbar { display: none; }
.menu-jump-nav .jump-link {
  flex-shrink: 0;
  scroll-snap-align: center;
  padding: .5rem .9rem;
  border-radius: var(--radius-pill);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--ink-soft);
  text-decoration: none;
  white-space: nowrap;
  transition: background var(--dur-quick) var(--ease-snap),
              color var(--dur-quick) var(--ease-snap);
  position: relative;
}
.menu-jump-nav .jump-link:hover {
  background: var(--aegean-mist);
  color: var(--aegean-deep);
}
.menu-jump-nav .jump-link.is-active {
  background: var(--aegean);
  color: #ffffff;
  box-shadow: 0 4px 12px -4px rgba(31, 77, 120, .4);
}

mark.search-hit {
  background: linear-gradient(180deg, rgba(31, 77, 120, .18) 0%, rgba(31, 77, 120, .32) 100%);
  color: inherit;
  padding: 0 2px;
  border-radius: 3px;
  font-weight: 700;
}

/* Scroll-Margin für Section-Anker damit Sticky-Nav nicht überschneidet */
.menu-section {
  scroll-margin-top: calc(var(--header-h) + 130px);
}

/* Menu sections + items (vollspeisekarte) */
.menu-section {
  margin-bottom: 5rem;
  position: relative;
}
.menu-section.is-hidden { display: none; }

.menu-section-head {
  display: flex;
  align-items: baseline;
  gap: 1.5rem;
  padding-bottom: 1.25rem;
  margin-bottom: 2rem;
  border-bottom: 1px solid var(--line-gold);
  position: relative;
}
.menu-section-head::after {
  content: '';
  position: absolute;
  bottom: -1px; left: 0;
  width: 80px; height: 2px;
  background: var(--gradient-gold);
}
.menu-cat-num {
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 3.2rem;
  color: var(--gold);
  line-height: .9;
  opacity: .65;
  letter-spacing: -.04em;
}
.menu-section-head h2 {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  color: var(--greek-blue-deep);
  margin: 0;
}
.menu-section-head h2 mark.search-hit { color: var(--greek-blue-deep); }
.menu-cat-sub {
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: .35rem 0 0;
}

.menu-list-v2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .25rem 3rem;
}
@media (max-width: 820px) {
  .menu-list-v2 { grid-template-columns: 1fr; gap: 0; }
}

.menu-item-v2 {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  gap: 1rem;
  padding: 1.1rem 0;
  border-bottom: 1px dashed var(--line);
  align-items: baseline;
  transition: opacity .3s ease, background .3s ease, padding .3s ease;
}
.menu-item-v2.is-hidden { display: none; }
.menu-item-v2:hover {
  background: rgba(200, 161, 87, .04);
  padding-left: .5rem;
}
.menu-item-num {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  font-size: 1rem;
  color: var(--gold-deep);
  letter-spacing: .02em;
}
.menu-item-body h4 {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--ink);
  margin-bottom: .25rem;
}
.menu-item-body p {
  font-size: .9rem;
  color: var(--ink-soft);
  line-height: 1.5;
  margin: 0;
}
.menu-item-body sup {
  font-size: .7rem;
  color: var(--gold-deep);
  margin-left: 2px;
}
.menu-item-v2 .menu-item-price {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  font-size: 1.2rem;
  color: var(--greek-blue);
  white-space: nowrap;
  padding-left: .5rem;
}

/* Vegetarian badge */
.veg-badge {
  display: inline-flex;
  align-items: center;
  gap: .3em;
  font-family: 'Inter', sans-serif;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--olive);
  background: rgba(94, 107, 61, .10);
  border: 1px solid rgba(94, 107, 61, .35);
  padding: 3px 8px 3px 6px;
  border-radius: var(--radius-pill);
  vertical-align: middle;
  margin-left: .5em;
  transform: translateY(-2px);
  white-space: nowrap;
}
.veg-badge svg {
  width: 11px;
  height: 11px;
  flex-shrink: 0;
}
.menu-legend {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  margin: 0 0 2rem;
  padding: .6rem 1rem;
  background: rgba(94, 107, 61, .06);
  border: 1px dashed rgba(94, 107, 61, .3);
  border-radius: var(--radius-pill);
  font-size: .85rem;
  color: var(--ink-soft);
}
.menu-legend .veg-badge {
  margin-left: 0;
  transform: none;
}
/* Filter-Toggle pill (live next to search input) */
.menu-search-filters {
  display: flex;
  gap: .5rem;
  margin-top: .75rem;
  flex-wrap: wrap;
}
.filter-pill {
  display: inline-flex;
  align-items: center;
  gap: .4em;
  font-family: 'Inter', sans-serif;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--ink-soft);
  background: var(--cream);
  border: 1.5px solid var(--line-strong);
  padding: .5rem 1rem;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: all var(--dur-quick) var(--ease-snap);
}
.filter-pill svg { width: 14px; height: 14px; }
.filter-pill:hover {
  border-color: var(--olive);
  color: var(--olive);
}
.filter-pill[aria-pressed="true"] {
  background: var(--olive);
  border-color: var(--olive);
  color: var(--cream);
}
.filter-pill[aria-pressed="true"]:hover {
  background: var(--olive-leaf);
}

/* Veg-only filter state */
body.is-veg-only .menu-item-v2:not(.is-veg) { display: none; }
body.is-veg-only .menu-section:not(:has(.is-veg)) { display: none; }

.menu-empty {
  display: none;
  padding: 3rem 2rem;
  text-align: center;
  background: var(--cream);
  border-radius: var(--radius);
  border: 1px dashed var(--line-gold);
  margin: 2rem 0;
}
.menu-empty.is-visible { display: block; }
.menu-empty svg { width: 48px; height: 48px; color: var(--gold-deep); opacity: .6; margin: 0 auto 1rem; }
.menu-empty strong { display: block; font-family: 'Playfair Display', serif; font-size: 1.4rem; margin-bottom: .5rem; color: var(--ink); }
.menu-empty p { color: var(--ink-soft); margin-bottom: 1.5rem; }

/* Welcome block */
.menu-welcome {
  position: relative;
  padding: 3rem 0 4rem;
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}
.menu-welcome::before,
.menu-welcome::after {
  content: '';
  display: block;
  height: 12px;
  margin: 0 auto;
  width: 220px;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='12' viewBox='0 0 48 12'%3E%3Cpath fill='none' stroke='%23c8a157' stroke-width='1.4' d='M0 11 L0 4 L8 4 L8 8 L4 8 L4 6 M16 11 L16 4 L24 4 L24 8 L20 8 L20 6 M32 11 L32 4 L40 4 L40 8 L36 8 L36 6 M48 11 L48 4'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-position: center;
  opacity: .6;
}
.menu-welcome::before { margin-bottom: 2rem; }
.menu-welcome::after  { margin-top: 2rem; }
.menu-welcome h2 {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-weight: 700;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  color: var(--bordeaux);
  margin-bottom: 1.5rem;
  line-height: 1.3;
}
.menu-welcome p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--ink-soft);
  margin-bottom: 1rem;
}
.menu-welcome .signature {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 1.1rem;
  margin-top: 2rem;
  color: var(--ink);
}
.menu-welcome .signature strong {
  display: block;
  font-style: normal;
  font-weight: 800;
  font-size: 1.6rem;
  letter-spacing: .15em;
  color: var(--bordeaux);
  margin-top: .5rem;
}

/* Allergen notice */
.menu-notice {
  margin: 2.5rem auto;
  max-width: 780px;
  padding: 1.5rem 1.75rem;
  background: var(--cream);
  border: 1.5px solid var(--line-gold);
  border-left: 3px solid var(--gold);
  border-radius: var(--radius-sm);
}
.menu-notice strong {
  display: block;
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--bordeaux);
  margin-bottom: .5rem;
}
.menu-notice p { font-size: .95rem; line-height: 1.6; color: var(--ink-soft); margin: 0; }

/* Additives legend */
.menu-additives {
  margin: 4rem auto 0;
  max-width: 880px;
  padding: 2rem;
  background: var(--bg-deeper);
  border-radius: var(--radius);
}
.menu-additives h3 {
  font-size: 1rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 1.5rem;
  font-family: 'Inter', sans-serif;
  font-weight: 700;
}
.menu-additives ol {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .75rem 2rem;
  list-style: none;
  font-size: .85rem;
  color: var(--ink-soft);
  counter-reset: add;
}
.menu-additives li {
  counter-increment: add;
  padding-left: 1.8rem;
  position: relative;
}
.menu-additives li::before {
  content: counter(add);
  position: absolute;
  left: 0; top: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--gold);
  color: var(--cream);
  font-weight: 700;
  font-size: .72rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Featured wine block */
.menu-wine {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2rem;
  align-items: center;
  margin: 3rem 0;
  padding: 2rem;
  background: var(--gradient-aegean);
  color: var(--cream);
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
}
.menu-wine::before {
  content: '🍷';
  position: absolute;
  font-size: 18rem;
  right: -3rem;
  bottom: -5rem;
  opacity: .06;
  pointer-events: none;
}
.menu-wine-tag {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold-soft);
  margin-bottom: .5rem;
}
.menu-wine h3 {
  font-size: 1.6rem;
  color: white;
  margin-bottom: .5rem;
}
.menu-wine p {
  color: rgba(255,253,248,.85);
  font-size: .98rem;
  margin: 0;
}
.menu-wine-price {
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 2rem;
  color: var(--gold-soft);
  white-space: nowrap;
}
.menu-wine-price small {
  display: block;
  font-size: .75rem;
  font-weight: 500;
  color: rgba(255,253,248,.7);
  letter-spacing: .15em;
  text-transform: uppercase;
  margin-top: 4px;
}
@media (max-width: 700px) {
  .menu-wine { grid-template-columns: 1fr; text-align: center; }
}

/* Salat hint */
.menu-side-hint {
  text-align: center;
  font-size: .92rem;
  color: var(--ink-muted);
  font-style: italic;
  padding: 1rem 1.5rem;
  background: var(--bg-mist);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin: 2rem 0;
}
.menu-side-hint strong { color: var(--gold-deep); font-style: normal; }

/* ============================================================
   11. 360°-PANORAMA SECTION
   ============================================================ */
.panorama {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-luxe);
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--greek-blue-deep), var(--greek-blue));
}
.panorama-consent {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2rem;
  color: var(--cream);
  z-index: 2;
  cursor: pointer;
  background: linear-gradient(135deg, rgba(7, 58, 120, .92), rgba(13, 94, 175, .88));
  transition: background .3s ease;
}
.panorama-consent:hover { background: linear-gradient(135deg, rgba(7, 58, 120, .96), rgba(13, 94, 175, .92)); }
.panorama-consent.is-gone { display: none; }
.panorama-consent-icon {
  width: 72px; height: 72px;
  border-radius: 50%;
  background: var(--gradient-gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  color: var(--greek-blue-deep);
  box-shadow: var(--shadow-luxe);
  transition: transform .4s ease;
}
.panorama-consent:hover .panorama-consent-icon { transform: rotate(15deg) scale(1.05); }
.panorama-consent-icon svg { width: 32px; height: 32px; }
.panorama-consent h3 {
  color: white;
  font-size: clamp(1.4rem, 2.8vw, 2rem);
  margin-bottom: .75rem;
}
.panorama-consent p {
  max-width: 460px;
  color: rgba(255,253,248,.85);
  font-size: .98rem;
  margin-bottom: 1.5rem;
}
.panorama-consent small {
  font-size: .78rem;
  color: rgba(255,253,248,.6);
  letter-spacing: .1em;
  max-width: 420px;
  line-height: 1.5;
}
.panorama iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  z-index: 1;
}

/* ============================================================
   12. PARALLAX HELPER
   ============================================================ */
[data-parallax] {
  will-change: transform;
  transition: transform .15s linear;
}

/* ============================================================
   13. PRINT IMPROVEMENTS FOR MENU
   ============================================================ */
@media print {
  .menu-search-wrap, .marquee, .page-loader, .hero-pillars, .hero-olive-drift,
  .cursor-dot, .cursor-ring, .pillar-strip, .greek-watermark { display: none !important; }
  .menu-section { break-inside: avoid; }
  .menu-list-v2 { grid-template-columns: 1fr 1fr !important; }
}


/* ============================================================
   GREEK-PAINTING REDESIGN — Section-by-Section
   Index.html prototype (2026-05-23)
   ============================================================ */

/* --- Shared utilities ----------------------------------------- */
.eyebrow--gold {
  color: #ffffff;
  opacity: .94;
  text-shadow: 0 1px 8px rgba(0, 0, 0, .35);
}
.section-head--left {
  text-align: left;
  max-width: 720px;
  margin-left: 0;
}

/* Generic decor entry hooks (driven by JS IntersectionObserver) */
[data-decor-fade] {
  opacity: 0;
  transition: opacity var(--dur-reveal) var(--ease-organic);
}
[data-decor-fade].is-in { opacity: 1; }

[data-decor-draw] {
  opacity: 0;
  clip-path: inset(100% 0 0 0);
  transition: opacity var(--dur-base) var(--ease-organic),
              clip-path var(--dur-grand) var(--ease-fresco);
}
[data-decor-draw].is-in {
  opacity: 1;
  clip-path: inset(0 0 0 0);
}

@media (prefers-reduced-motion: reduce) {
  [data-decor-draw] { clip-path: none; }
  [data-decor-draw], [data-decor-fade] { transition: opacity .3s linear; }
}


/* ============================================================
   01 HERO — "Das Tor zur Taverne"
   ============================================================ */
.hero--portal {
  position: relative;
  min-height: 92vh;
  overflow: hidden;
}
.hero--portal .hero-bg img {
  animation: heroKenBurns 22s ease-out forwards;
  will-change: transform;
}
@keyframes heroKenBurns {
  from { transform: scale(1.05) translateY(0); }
  to   { transform: scale(1.12) translateY(-1.5%); }
}
.hero--portal .hero-overlay {
  background: var(--gradient-hero);
  z-index: 2;
}

/* Half column left */
.hero-column {
  position: absolute;
  z-index: 3;
  pointer-events: none;
  bottom: -2%;
  width: clamp(120px, 18vw, 220px);
  filter: drop-shadow(0 18px 32px rgba(62, 13, 19, .35));
  animation: heroColumnRise 1.4s var(--ease-fresco) .8s both;
}
.hero-column--left {
  left: -3%;
}
.hero-column img { width: 100%; height: auto; opacity: 1; }
@keyframes heroColumnRise {
  from { opacity: 0; transform: translateY(60px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Top-right baroque scroll corner */
.hero-scroll-corner {
  position: absolute;
  top: calc(var(--header-h) + 1rem);
  right: 1.5rem;
  width: clamp(90px, 12vw, 180px);
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  animation: heroScrollFade 1.6s var(--ease-organic) 1.2s forwards;
  filter: drop-shadow(0 4px 12px rgba(62, 13, 19, .25));
}
.hero-scroll-corner img { width: 100%; opacity: .9; }
@keyframes heroScrollFade {
  to { opacity: .65; }
}

/* Re-position olive drift to lower-third behind text */
.hero--portal .hero-olive-drift {
  top: auto; bottom: 18%;
  right: 8%;
  z-index: 3;
}

/* Scroll cue */
.hero-scroll-cue {
  position: absolute;
  bottom: 1.6rem;
  left: 50%;
  transform: translateX(-50%);
  width: 2px; height: 56px;
  background: linear-gradient(180deg, transparent 0%, #ffffff 40%, transparent 100%);
  z-index: 4;
  opacity: .65;
  pointer-events: none;
}
.hero-scroll-cue span {
  position: absolute;
  top: 0; left: -3px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #ffffff;
  animation: scrollCueDot 2.4s var(--ease-organic) infinite;
}
@keyframes scrollCueDot {
  0%   { top: 0; opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { top: 48px; opacity: 0; }
}

@media (max-width: 900px) {
  .hero--portal { min-height: 78vh; }
  .hero-fresco-top { height: 28vh; }
  .hero-column { width: 110px; bottom: -4%; }
  .hero-scroll-corner { width: 80px; opacity: .5; }
}
@media (prefers-reduced-motion: reduce) {
  .hero--portal .hero-bg img,
  .hero-fresco-top,
  .hero-column,
  .hero-scroll-corner,
  .hero-scroll-cue span { animation: none; }
}


/* ============================================================
   02 STORY-HOOK — "Eine Zeile vom Wirt"
   ============================================================ */
.story-hook {
  position: relative;
  padding: 6rem 0;
  background: var(--cream);
  overflow: hidden;
}
.story-hook-statue {
  position: absolute;
  top: 50%;
  left: -3%;
  transform: translateY(-50%) rotate(-8deg);
  width: 280px;
  height: 380px;
  background-image: url("/assets/images/refs/user/nike-sketch.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: .12;
  filter: grayscale(100%) contrast(1.2);
  pointer-events: none;
  z-index: 1;
}
.story-hook-olive {
  position: absolute;
  top: 50%;
  right: -2%;
  transform: translateY(-50%);
  width: 100px;
  opacity: .35;
  color: var(--olive);
  pointer-events: none;
  z-index: 1;
}
.story-hook-olive img { width: 100%; }
.story-hook-inner {
  position: relative;
  z-index: 2;
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
  padding: 0 1rem;
}
.story-hook-inner .eyebrow {
  color: var(--gold-deep);
  letter-spacing: .26em;
}
.story-hook-quote {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 700;
  font-style: italic;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.4;
  color: var(--ink);
  margin: 1.5rem 0 1.25rem;
}
.story-hook-quote p { margin: 0; }
.story-hook-rule {
  display: inline-block;
  width: 56px;
  height: 2px;
  background: var(--aegean);
  margin: .75rem 0 1rem;
  transform-origin: left;
  transform: scaleX(0);
  animation: storyRuleGrow 1s var(--ease-organic) .6s forwards;
}
@keyframes storyRuleGrow { to { transform: scaleX(1); } }
.story-hook-cite {
  display: block;
  font-style: normal;
  font-size: .82rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

@media (max-width: 720px) {
  .story-hook { padding: 4rem 0; }
  .story-hook-statue { width: 180px; height: 260px; opacity: .08; left: -8%; }
  .story-hook-olive { display: none; }
}


/* ============================================================
   03 PLATE-TRIPTYCH — "Drei Teller"
   ============================================================ */
.plate-triptych {
  position: relative;
  background: var(--bg-warm);
  overflow: hidden;
}
.plate-watermark {
  position: absolute;
  top: 12%; left: -10%;
  width: 140%;
  transform: rotate(-12deg);
  opacity: .04;
  color: var(--gold-deep);
  pointer-events: none;
  z-index: 0;
}
.plate-watermark img { width: 100%; }
.plate-triptych > .container { position: relative; z-index: 1; }
.plate-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem;
  align-items: end;
  margin-top: 3rem;
}
.plate-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.plate-card--1 { transform: translateY(0); }
.plate-card--2 { transform: translateY(-40px); }
.plate-card--3 { transform: translateY(30px); }
.plate-frame {
  position: relative;
  width: clamp(220px, 26vw, 320px);
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  /* Keramik-Teller-Rand: breite weiße Lippe + dünner Aegean-Liner außen + Schatten */
  box-shadow:
    /* innere Glasur-Vertiefung */
    inset 0 0 24px rgba(14, 42, 71, .18),
    inset 0 2px 4px rgba(255, 255, 255, .5),
    /* breiter Tellerrand */
    0 0 0 10px #fafafa,
    0 0 0 11px rgba(14, 42, 71, .12),
    /* dezenter Aegean-Akzent */
    0 0 0 13px var(--aegean),
    /* Schatten unter dem Teller */
    0 18px 36px -10px rgba(14, 42, 71, .35),
    0 32px 60px -16px rgba(14, 42, 71, .4);
  transition: transform var(--dur-base) var(--ease-snap),
              box-shadow var(--dur-base) var(--ease-organic);
  margin: 0;
}
.plate-card:hover .plate-frame {
  transform: scale(1.05) rotate(-2deg);
  box-shadow:
    inset 0 0 24px rgba(14, 42, 71, .22),
    inset 0 2px 4px rgba(255, 255, 255, .5),
    0 0 0 10px #fafafa,
    0 0 0 11px rgba(14, 42, 71, .15),
    0 0 0 13px var(--aegean-deep),
    0 26px 50px -12px rgba(14, 42, 71, .45),
    0 44px 90px -18px rgba(14, 42, 71, .5);
}
.plate-frame img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 8s linear;
}
.plate-card:hover .plate-frame img { transform: scale(1.1); }
.plate-info { margin-top: 1.5rem; max-width: 280px; }
.plate-eyebrow {
  display: inline-block;
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-weight: 700;
  font-size: .92rem;
  color: var(--bordeaux);
  letter-spacing: .04em;
  margin-bottom: .3rem;
}
.plate-info h3 {
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  margin-bottom: .4rem;
  color: var(--ink);
}
.plate-info p {
  font-size: .92rem;
  color: var(--ink-soft);
  line-height: 1.55;
}

@media (max-width: 900px) {
  .plate-grid { grid-template-columns: 1fr; gap: 3rem; }
  .plate-card--1, .plate-card--2, .plate-card--3 { transform: none; }
}


/* ============================================================
   04 LAUREL-STATS — "Im Lorbeer"
   ============================================================ */
.stats-laurel { background: var(--bg-mist); }
.stats-laurel .section-head { text-align: center; margin-bottom: 3rem; }
.laurel-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
  align-items: center;
  justify-items: center;
}
.laurel-stat {
  position: relative;
  width: 220px;
  height: 220px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 1.5rem;
  transition: transform var(--dur-base) var(--ease-organic);
}
.laurel-stat:hover { transform: scale(1.04); }
.laurel-wreath {
  position: absolute;
  inset: 0;
  z-index: 1;
  color: var(--olive);
  pointer-events: none;
  opacity: 0;
  transform: scale(.92);
  transition: opacity var(--dur-reveal) var(--ease-organic),
              transform var(--dur-reveal) var(--ease-organic);
}
.laurel-wreath img { width: 100%; height: 100%; object-fit: contain; }
.laurel-stat.is-in .laurel-wreath {
  opacity: 1;
  transform: scale(1);
}
.laurel-stat:hover .laurel-wreath { transform: scale(1) rotate(3deg); }
.laurel-coin {
  position: absolute;
  inset: 12%;
  z-index: 0;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, var(--gold-leaf) 0%, var(--gold) 50%, var(--gold-deep) 100%);
  opacity: .12;
  filter: blur(2px);
  pointer-events: none;
}
.laurel-value {
  position: relative;
  z-index: 2;
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 800;
  font-size: clamp(2.4rem, 4vw, 3rem);
  line-height: 1;
  color: var(--ink);
  margin-bottom: .25rem;
}
.laurel-label {
  position: relative;
  z-index: 2;
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 600;
}
.laurel-foot {
  text-align: center;
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 1.05rem;
  color: var(--ink-soft);
  margin-top: 2.5rem;
}

@media (max-width: 720px) {
  .laurel-stats { grid-template-columns: 1fr; gap: 1rem; }
  .laurel-stat { width: 200px; height: 200px; }
}


/* ============================================================
   05 ATMOSPHERE — "Innen wie ein Fresko"
   ============================================================ */
.atmosphere {
  position: relative;
  background: var(--bg-deeper);
  overflow: hidden;
}
.atmosphere-fresco {
  position: absolute;
  inset: 0 0 auto 0;
  height: 35%;
  background-image: url("/assets/images/refs/user/ceiling-fresco.png");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  opacity: .14;
  -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,.95) 0%, rgba(0,0,0,0) 100%);
          mask-image: linear-gradient(180deg, rgba(0,0,0,.95) 0%, rgba(0,0,0,0) 100%);
  pointer-events: none;
  z-index: 0;
}
/* Right-side column: removed per Kunden-Wunsch */
.atmosphere-column { display: none; }
.atmosphere > .container { position: relative; z-index: 2; }
.atmosphere-split {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.atmosphere-arch {
  position: relative;
  margin: 0;
  padding-top: 22px;  /* room for meander cap on top */
}

/* Marble/stone arch portal — 3D, authentic Greek look */
.atmosphere-arch-frame {
  position: relative;
  border-radius: 50% 50% 12px 12px / 35% 35% 8px 8px;
  overflow: hidden;
  padding: 16px;
  /* Marble gradient + subtle veining */
  background:
    radial-gradient(ellipse at 30% 15%, rgba(255, 255, 255, .8) 0%, rgba(255, 255, 255, 0) 45%),
    radial-gradient(ellipse at 75% 80%, rgba(180, 168, 140, .25) 0%, rgba(180, 168, 140, 0) 50%),
    linear-gradient(155deg, #f5efe0 0%, #e7ddc3 35%, #d4c6a3 70%, #b8a884 100%);
  box-shadow:
    /* Inner depth: photo recessed into stone */
    inset 0 0 0 1px rgba(125, 90, 35, .35),
    inset 0 2px 8px rgba(125, 90, 35, .4),
    /* Subtle highlight at top of frame for 3D */
    inset 0 1px 0 rgba(255, 255, 255, .7),
    /* Outer: portal floats over the section */
    0 12px 32px -6px rgba(14, 42, 71, .25),
    0 28px 64px -12px rgba(14, 42, 71, .35);
  animation: archGlow 8s var(--ease-organic) infinite;
}
@keyframes archGlow {
  0%, 100% {
    box-shadow:
      inset 0 0 0 1px rgba(125, 90, 35, .35),
      inset 0 2px 8px rgba(125, 90, 35, .4),
      inset 0 1px 0 rgba(255, 255, 255, .7),
      0 12px 32px -6px rgba(14, 42, 71, .25),
      0 28px 64px -12px rgba(14, 42, 71, .35);
  }
  50% {
    box-shadow:
      inset 0 0 0 1px rgba(125, 90, 35, .35),
      inset 0 2px 8px rgba(125, 90, 35, .4),
      inset 0 1px 0 rgba(255, 255, 255, .7),
      0 12px 32px -6px rgba(14, 42, 71, .3),
      0 32px 80px -10px rgba(14, 42, 71, .45);
  }
}
/* Meander pattern cap above the arch — gives authentic Greek temple feel */
.atmosphere-arch::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18%;
  right: 18%;
  height: 22px;
  background-color: var(--gold-deep);
  -webkit-mask: url("/assets/images/decor/meander-border.svg") repeat-x center/auto 22px;
          mask: url("/assets/images/decor/meander-border.svg") repeat-x center/auto 22px;
  opacity: .65;
  filter: drop-shadow(0 2px 3px rgba(14, 42, 71, .2));
  pointer-events: none;
}
.atmosphere-arch-frame img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: 50% 50% 4px 4px / 35% 35% 3px 3px;
  display: block;
  /* Subtle inner shadow on photo so it sits "inside" the stone */
  box-shadow: inset 0 0 24px rgba(14, 42, 71, .15);
}
.atmosphere-corner {
  position: absolute;
  width: 72px;
  z-index: 3;
  color: var(--gold);
  pointer-events: none;
}
.atmosphere-corner--tl { top: -16px; left: -16px; transform: rotate(0deg); }
.atmosphere-corner--tr { top: -16px; right: -16px; transform: scaleX(-1); }
.atmosphere-corner img { width: 100%; }
.atmosphere-text { position: relative; }
.atmosphere-flourish {
  width: clamp(140px, 18vw, 220px);
  color: var(--aegean);
  margin-bottom: 1rem;
  opacity: .75;
}
.atmosphere-flourish img { width: 100%; }
.atmosphere-text h2 {
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  line-height: 1.2;
  margin-bottom: 1.25rem;
}
.atmosphere-text p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--ink-soft);
  margin-bottom: 1.75rem;
}

@media (max-width: 900px) {
  .atmosphere-split { grid-template-columns: 1fr; gap: 2.5rem; }
  .atmosphere-column { display: none; }
}


/* ============================================================
   06 POSTER-PAIR — "Zwei Anlässe" auf antiker Terrasse
   ============================================================ */
.poster-pair-section {
  background: var(--bg-warm);
  position: relative;
  padding: 7rem 0;
  overflow: hidden;
}

/* Terrasse-Background-Modifier (antike griechische Säulenhalle bei Dämmerung) */
.poster-pair-section--terrace {
  background: var(--aegean-deep);
}
.poster-pair-section--terrace .terrace-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.poster-pair-section--terrace .terrace-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(.9);
}
.poster-pair-section--terrace .terrace-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(14, 42, 71, .55) 0%, rgba(14, 42, 71, .25) 40%, rgba(14, 42, 71, .65) 100%),
    radial-gradient(ellipse at 50% 0%, rgba(214, 226, 238, .15) 0%, rgba(0, 0, 0, 0) 60%);
}
.poster-pair-section--terrace > .container {
  position: relative;
  z-index: 2;
}
/* Inverted Section-Head: hellweiß auf Terrasse */
.section-head--inverted h2 { color: #ffffff; text-shadow: 0 2px 12px rgba(0, 0, 0, .35); }
.section-head--inverted p { color: rgba(255, 255, 255, .85); }
.eyebrow--on-dark {
  color: #ffffff;
  opacity: .94;
  text-shadow: 0 1px 6px rgba(0, 0, 0, .3);
}
.eyebrow--on-dark::after { background: #ffffff; opacity: .65; }

.poster-pair {
  display: grid;
  grid-template-columns: 1fr 280px 1fr;
  gap: 2rem;
  align-items: stretch;
  margin-top: 3rem;
  position: relative;
}
.poster-card {
  position: relative;
  min-height: 480px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: 2.5rem;
  box-shadow: var(--shadow-luxe);
  transition: transform var(--dur-base) var(--ease-snap),
              box-shadow var(--dur-base) var(--ease-organic);
}
.poster-card--buffet { transform: rotate(-0.8deg) translateY(8px); }
.poster-card--events { transform: rotate(0.8deg) translateY(8px); z-index: 2; }
.poster-card:hover {
  transform: translateY(-4px) rotate(0deg);
  box-shadow:
    0 4px 16px rgba(14, 42, 71, .25),
    0 32px 80px -16px rgba(14, 42, 71, .55);
}

/* Bronze-Frame Modifier: ornamentale Rahmen mit Mäander-Akzent */
.poster-card--bronze {
  padding: 0;
}
.poster-card--bronze .poster-bg {
  inset: 14px;
  border-radius: calc(var(--radius-lg) - 8px);
  overflow: hidden;
}
.poster-card--bronze .poster-overlay {
  inset: 14px;
  border-radius: calc(var(--radius-lg) - 8px);
}
.poster-card--bronze .poster-content {
  padding: 2.5rem;
}
.poster-card--bronze::before {
  /* Bronze-Border-Gradient (Outer Frame) */
  content: "";
  position: absolute;
  inset: 0;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, #e8c989 0%, #b88a3e 25%, #7d5a23 50%, #b88a3e 75%, #e8c989 100%);
  z-index: 0;
}
.poster-card--bronze::after {
  /* Mäander-Pattern Mini-Band oben innen (subtil) */
  content: "";
  position: absolute;
  top: 22px; left: 30px; right: 30px;
  height: 14px;
  background-color: rgba(255, 255, 255, .35);
  -webkit-mask: url("/assets/images/decor/meander-border.svg") repeat-x center/auto 14px;
          mask: url("/assets/images/decor/meander-border.svg") repeat-x center/auto 14px;
  z-index: 3;
  pointer-events: none;
}
.poster-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.poster-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 8s linear;
}
.poster-card:hover .poster-bg img { transform: scale(1.08); }
.poster-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.poster-overlay--bord {
  background: linear-gradient(165deg,
    rgba(13, 46, 77, .45) 0%,
    rgba(106, 24, 32, .72) 55%,
    rgba(62, 13, 19, .92) 100%);
}
.poster-overlay--aegean {
  background: linear-gradient(165deg,
    rgba(26, 77, 122, .55) 0%,
    rgba(13, 46, 77, .85) 60%,
    rgba(13, 46, 77, .95) 100%);
}
.poster-content {
  position: relative;
  z-index: 2;
  color: var(--cream);
  max-width: 380px;
}
.poster-eyebrow {
  display: inline-block;
  font-size: .78rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--aegean-mist);
  font-weight: 700;
  margin-bottom: .75rem;
}
.poster-content h3 {
  font-size: clamp(1.4rem, 2.4vw, 1.85rem);
  line-height: 1.2;
  margin-bottom: .75rem;
  color: var(--cream);
}
.poster-content p {
  font-size: 1rem;
  line-height: 1.55;
  color: rgba(255, 249, 236, .82);
  margin-bottom: 1.5rem;
}
.poster-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  z-index: 3;
  color: var(--olive);
  opacity: .65;
  pointer-events: none;
}
.poster-divider img {
  width: 50px;
  filter: drop-shadow(0 4px 8px rgba(62, 13, 19, .4));
}

/* Stone-Relief Bridge: zentrale Branding-Insel zwischen den 2 Cards */
.poster-relief {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  z-index: 3;
  padding: 0 .5rem;
}
.poster-relief-frame {
  position: relative;
  width: 100%;
  max-width: 260px;
  border-radius: 50%;
  overflow: hidden;
  aspect-ratio: 1;
  background:
    linear-gradient(135deg, #f5efe0 0%, #ddd0b0 100%);
  padding: 12px;
  box-shadow:
    inset 0 0 0 1px rgba(125, 90, 35, .35),
    inset 0 2px 6px rgba(125, 90, 35, .3),
    inset 0 1px 0 rgba(255, 255, 255, .6),
    0 8px 24px -4px rgba(14, 42, 71, .35),
    0 24px 56px -12px rgba(14, 42, 71, .45);
}
.poster-relief-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 50%;
  filter: sepia(.18) saturate(.85);
}
.poster-relief-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .6rem;
  color: #ffffff;
  text-align: center;
}
.poster-relief-mark {
  width: 56px;
  height: auto;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, .35));
}
.poster-relief-tag {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: .82rem;
  letter-spacing: .12em;
  color: rgba(255, 255, 255, .85);
  text-shadow: 0 1px 6px rgba(0, 0, 0, .3);
}

/* Light ghost-button for use on dark poster cards */
.btn-ghost-light {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .55rem 0;
  font-weight: 700;
  font-size: .92rem;
  color: #ffffff;
  letter-spacing: .04em;
  border-bottom: 1px solid currentColor;
  transition: color var(--dur-quick) var(--ease-snap), gap var(--dur-quick) var(--ease-snap);
}
.btn-ghost-light:hover {
  color: var(--cream);
  gap: .9rem;
}

@media (max-width: 900px) {
  .poster-pair-section--terrace { padding: 4.5rem 0; }
  .poster-pair { grid-template-columns: 1fr; gap: 2rem; }
  .poster-card,
  .poster-card--buffet,
  .poster-card--events { transform: none; min-height: 360px; }
  .poster-divider { width: 100%; height: 50px; }
  .poster-divider img { transform: rotate(90deg); }
  .poster-relief { flex-direction: row; gap: 2rem; }
  .poster-relief-frame { max-width: 180px; }
}
@media (max-width: 560px) {
  .poster-relief { flex-direction: column; }
}


/* ============================================================
   07 SINGLE-QUOTE — "Ein einziger Gast"
   ============================================================ */
.single-quote {
  position: relative;
  padding: 7rem 0;
  background: var(--cream);
  overflow: hidden;
}
.single-quote-statue {
  position: absolute;
  bottom: -8%;
  left: -5%;
  width: 360px;
  height: 480px;
  background-image: url("/assets/images/refs/user/nike-sketch.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: .10;
  filter: grayscale(100%);
  pointer-events: none;
  z-index: 1;
}
.single-quote-accent {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  width: 60px;
  color: var(--aegean);
  opacity: .5;
  pointer-events: none;
  z-index: 1;
  transform: rotate(0deg);
}
.single-quote-accent img { width: 100%; }
.single-quote > .container { position: relative; z-index: 2; }
.single-quote-inner {
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
}
.single-quote-inner .eyebrow {
  color: var(--gold-deep);
  letter-spacing: .26em;
}
.single-quote-stars {
  display: flex;
  justify-content: center;
  gap: .25rem;
  margin: 1.25rem 0 1.5rem;
  font-size: 1.8rem;
  color: var(--gold);
  text-shadow: 0 1px 3px rgba(125, 90, 35, .25);
}
.single-quote-stars span {
  opacity: 0;
  transform: scale(.5);
  animation: starPop .5s var(--ease-snap) forwards;
}
.single-quote-stars span:nth-child(1) { animation-delay: .15s; }
.single-quote-stars span:nth-child(2) { animation-delay: .23s; }
.single-quote-stars span:nth-child(3) { animation-delay: .31s; }
.single-quote-stars span:nth-child(4) { animation-delay: .39s; }
.single-quote-stars span:nth-child(5) { animation-delay: .47s; }
@keyframes starPop {
  to { opacity: 1; transform: scale(1); }
}
.single-quote-text {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 700;
  font-style: italic;
  font-size: clamp(1.55rem, 2.8vw, 2.2rem);
  line-height: 1.42;
  color: var(--ink);
  margin: 0 0 1.5rem;
}
.single-quote-text p { margin: 0; }
.single-quote-meta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .82rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 600;
  margin-bottom: 1.5rem;
}
.single-quote-author { color: var(--bordeaux); }
.single-quote-dot { color: var(--gold); }
.single-quote-link {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: .92rem;
  font-weight: 600;
  color: var(--ink-soft);
  letter-spacing: .04em;
  border-bottom: 1px solid var(--line-gold);
  padding-bottom: .15rem;
  transition: color var(--dur-quick) var(--ease-snap),
              border-color var(--dur-quick) var(--ease-snap);
}
.single-quote-link:hover {
  color: var(--bordeaux);
  border-color: var(--bordeaux);
}

@media (max-width: 720px) {
  .single-quote { padding: 4.5rem 0; }
  .single-quote-statue { width: 220px; height: 300px; opacity: .07; }
}


/* ============================================================
   08 CLOSING-PORTAL — "Das letzte Wort"
   ============================================================ */
.closing-portal {
  position: relative;
  padding: 6rem 0;
  min-height: 70vh;
  overflow: hidden;
  display: flex;
  align-items: center;
}
.closing-portal-bg {
  position: absolute; inset: 0;
  z-index: 0;
}
.closing-portal-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(.75);
}
.closing-portal-overlay {
  position: absolute; inset: 0;
  z-index: 1;
  background: linear-gradient(165deg,
    rgba(13, 46, 77, .88) 0%,
    rgba(26, 77, 122, .72) 45%,
    rgba(13, 46, 77, .82) 80%,
    rgba(62, 13, 19, .65) 100%);
  mix-blend-mode: multiply;
}
.closing-portal-fresco {
  position: absolute;
  inset: 0 0 auto 0;
  height: 35%;
  z-index: 2;
  background-image: url("/assets/images/refs/user/ceiling-fresco.png");
  background-size: cover;
  background-position: top center;
  opacity: .18;
  -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
          mask-image: linear-gradient(180deg, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
  pointer-events: none;
}
.closing-portal-column {
  position: absolute;
  bottom: 0;
  width: clamp(110px, 14vw, 180px);
  z-index: 3;
  pointer-events: none;
  filter: drop-shadow(0 18px 32px rgba(0, 0, 0, .45));
  opacity: 0;
  transition: opacity 1.2s var(--ease-organic), transform 1.2s var(--ease-fresco);
}
.closing-portal-column img { width: 100%; }
.closing-portal-column--left {
  left: -2%;
  transform: translateX(-60px);
}
.closing-portal-column--right {
  right: -2%;
  transform: translateX(60px) scaleX(-1);
}
.closing-portal.is-in .closing-portal-column--left {
  opacity: 1; transform: translateX(0);
}
.closing-portal.is-in .closing-portal-column--right {
  opacity: 1; transform: translateX(0) scaleX(-1);
}
.closing-portal > .container { position: relative; z-index: 4; }
.closing-portal-inner {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  color: var(--cream);
}
.closing-portal-headline {
  font-size: clamp(1.85rem, 4vw, 2.85rem);
  line-height: 1.18;
  margin: 1.25rem 0 1rem;
  color: #ffffff;
  background-image: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, .85) 50%, transparent 100%);
  background-size: 200% 100%;
  background-position: -100% 0;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
          background-clip: text;
  animation: goldSweep 6s var(--ease-organic) 1s infinite;
}
.closing-portal-headline.text-balance,
.closing-portal-headline {
  color: #ffffff;
  -webkit-text-fill-color: #ffffff;
}
@keyframes goldSweep {
  0% { background-position: -100% 0; }
  60% { background-position: 200% 0; }
  100% { background-position: 200% 0; }
}
.closing-portal-lede {
  font-size: 1.1rem;
  color: rgba(255, 249, 236, .85);
  margin-bottom: 2rem;
}
.closing-portal-actions {
  display: flex;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.closing-portal-hours {
  font-size: .82rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--aegean-mist);
  margin-top: .5rem;
}

@media (max-width: 720px) {
  .closing-portal { padding: 4.5rem 0; min-height: 60vh; }
  .closing-portal-column { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  .closing-portal-headline { animation: none; }
}


/* ============================================================
   09 FOOTER WAVE
   ============================================================ */
.footer-wave {
  position: relative;
  overflow: hidden;
  height: 80px;
  margin-top: -40px;
  pointer-events: none;
}
.footer-wave img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: footerWaveLoop 40s linear infinite;
}
.footer-wave--dup {
  left: 100%;
}
@keyframes footerWaveLoop {
  from { transform: translateX(0); }
  to   { transform: translateX(-100%); }
}
@media (prefers-reduced-motion: reduce) {
  .footer-wave img { animation: none; }
}


/* ============================================================
   GALERIE / IMPRESSIONEN — Mockup-Redesign
   ============================================================ */

/* Compact Hero (kürzer als Standard page-hero) */
.page-hero--compact {
  padding-top: calc(var(--header-h) + 3rem);
  padding-bottom: 2rem;
  text-align: center;
}
.page-hero--compact .lede { max-width: 620px; margin: 1rem auto 0; }

/* 3-Image Header Strip */
.gallery-strip-section {
  padding: 1.5rem 0 4rem;
  background: #ffffff;
}
.gallery-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.gallery-strip-item {
  margin: 0;
  aspect-ratio: 5 / 4;
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow:
    0 2px 8px rgba(14, 42, 71, .08),
    0 18px 40px -16px rgba(14, 42, 71, .22);
  transition: transform var(--dur-base) var(--ease-organic),
              box-shadow var(--dur-base) var(--ease-organic);
}
.gallery-strip-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 8s linear;
}
.gallery-strip-item:hover {
  transform: translateY(-4px);
  box-shadow:
    0 4px 14px rgba(14, 42, 71, .12),
    0 28px 56px -16px rgba(14, 42, 71, .38);
}
.gallery-strip-item:hover img { transform: scale(1.05); }

@media (max-width: 720px) {
  .gallery-strip { grid-template-columns: 1fr; gap: 1rem; }
}

/* Virtueller Rundgang Split */
.virtual-tour-section {
  background: var(--aegean-mist);
  padding: 5rem 0;
}
.virtual-tour-split {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 3.5rem;
  align-items: center;
}
.virtual-tour-text { max-width: 480px; }
.virtual-tour-text h2 {
  font-size: clamp(1.85rem, 3.4vw, 2.6rem);
  line-height: 1.2;
  margin: 1rem 0 1.25rem;
}
.virtual-tour-text p {
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--ink-soft);
}
.virtual-tour-media {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: #000;
  box-shadow:
    0 4px 16px rgba(14, 42, 71, .15),
    0 32px 70px -18px rgba(14, 42, 71, .45);
  /* Bronze frame around the preview/embed */
  padding: 8px;
  background:
    linear-gradient(135deg, #e8c989 0%, #b88a3e 50%, #7d5a23 100%);
}
.virtual-tour-preview {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: calc(var(--radius-lg) - 6px);
  overflow: hidden;
  background: #000;
}
.virtual-tour-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.65);
}
.virtual-tour-cta {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  cursor: pointer;
  background: linear-gradient(180deg, rgba(14, 42, 71, .2) 0%, rgba(14, 42, 71, .55) 100%);
  transition: background var(--dur-base) var(--ease-organic);
}
.virtual-tour-cta:hover {
  background: linear-gradient(180deg, rgba(14, 42, 71, .1) 0%, rgba(14, 42, 71, .45) 100%);
}
.virtual-tour-cta .btn svg {
  width: 18px;
  height: 18px;
  margin-right: .25rem;
}
.virtual-tour-cta small {
  display: block;
  font-size: .72rem;
  color: rgba(255, 255, 255, .8);
  letter-spacing: .04em;
  text-align: center;
  max-width: 320px;
  padding: 0 1rem;
  text-shadow: 0 1px 3px rgba(0, 0, 0, .6);
}
/* Hide CTA once iframe loaded */
.virtual-tour-media iframe {
  position: absolute;
  inset: 8px;
  width: calc(100% - 16px);
  height: calc(100% - 16px);
  border: 0;
  border-radius: calc(var(--radius-lg) - 6px);
}
.virtual-tour-media iframe + .virtual-tour-preview,
.virtual-tour-media:has(iframe) .virtual-tour-preview { display: none; }

@media (max-width: 900px) {
  .virtual-tour-split { grid-template-columns: 1fr; gap: 2.5rem; }
  .virtual-tour-section { padding: 3.5rem 0; }
}


/* ============================================================
   BEWERTUNGEN — Polaroid-Collage Hero
   ============================================================ */
.page-hero--with-collage,
.page-hero--reviews {
  padding-top: calc(var(--header-h) + 3rem);
  padding-bottom: 4rem;
  background: #ffffff;
}
.reviews-hero-text { text-align: left; }
.reviews-hero-text .lede {
  margin: 1rem 0 0;
  max-width: 460px;
}
/* Marquee: horizontaler Infinite-Scroll mit Kunden-Fotos */
.reviews-marquee {
  position: relative;
  overflow: hidden;
  width: 100%;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.reviews-marquee-track {
  display: flex;
  gap: 1.5rem;
  width: max-content;
  animation: marqueeScroll 45s linear infinite;
  will-change: transform;
}
.reviews-marquee:hover .reviews-marquee-track {
  animation-play-state: paused;
}
@keyframes marqueeScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.marquee-photo {
  flex-shrink: 0;
  width: 240px;
  margin: 0;
  background: #ffffff;
  padding: 10px 10px 14px;
  border: 1px solid rgba(31, 77, 120, .18);
  border-radius: var(--radius);
  box-shadow:
    0 2px 6px rgba(14, 42, 71, .08),
    0 14px 32px -16px rgba(14, 42, 71, .35);
  transition: transform var(--dur-base) var(--ease-snap),
              box-shadow var(--dur-base) var(--ease-organic);
}
.marquee-photo:hover {
  transform: translateY(-6px) scale(1.03);
  box-shadow:
    0 4px 14px rgba(14, 42, 71, .12),
    0 24px 48px -18px rgba(14, 42, 71, .5);
}
.marquee-photo img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  display: block;
  border-radius: 6px;
}
.marquee-photo figcaption {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  padding: .8rem .2rem .2rem;
  text-align: center;
}
.marquee-photo figcaption strong {
  font-family: 'Playfair Display', serif;
  font-size: .95rem;
  color: var(--ink);
  letter-spacing: .02em;
}
.marquee-photo figcaption span {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .12em;
  color: var(--gold-deep);
  text-transform: uppercase;
}

@media (prefers-reduced-motion: reduce) {
  .reviews-marquee-track { animation: none; }
}
@media (max-width: 900px) {
  .reviews-hero-split { grid-template-columns: 1fr; gap: 2.5rem; }
  .reviews-marquee { order: 2; }
  .marquee-photo { width: 200px; }
  .marquee-photo img { height: 240px; }
}



/* ============================================================
   PHOTO-COLLAGE (Events) + PHOTO-STRIP (Buffet)
   ============================================================ */

/* Events-Collage: 1 grosses + 3 kleine Fotos in 2x2-Grid */
.photo-collage-section { position: relative; }
.photo-collage {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 1.25rem;
  margin-top: 2.5rem;
}
.photo-collage-item {
  margin: 0;
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  aspect-ratio: 4 / 5;
  background: var(--bg-deeper, #d6e2ee);
  box-shadow: 0 2px 8px rgba(14, 42, 71, .08), 0 14px 40px -12px rgba(14, 42, 71, .22);
  transition: transform .6s var(--ease-organic), box-shadow .6s var(--ease-organic);
  isolation: isolate;
}
.photo-collage-item--lg {
  grid-row: 1 / span 2;
  aspect-ratio: auto;
}
.photo-collage-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.2s var(--ease-organic), filter .6s var(--ease-organic);
  filter: saturate(.97);
}
.photo-collage-item::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset 0 0 0 1px rgba(192, 158, 100, .32);
  z-index: 1;
}
.photo-collage-item:hover {
  transform: translateY(-6px);
  box-shadow: 0 6px 18px rgba(14, 42, 71, .15), 0 30px 64px -16px rgba(14, 42, 71, .38);
}
.photo-collage-item:hover img {
  transform: scale(1.06);
  filter: saturate(1.04);
}

@media (max-width: 760px) {
  .photo-collage {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }
  .photo-collage-item--lg {
    grid-row: auto;
    aspect-ratio: 4 / 5;
  }
}

/* Buffet-Strip: 3-Spalten-Grid, responsive */
.photo-strip-section { position: relative; }
.photo-strip-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin-top: 2.5rem;
}
.photo-strip-item {
  margin: 0;
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  aspect-ratio: 4 / 5;
  background: var(--bg-deeper, #d6e2ee);
  box-shadow: 0 2px 8px rgba(14, 42, 71, .08), 0 12px 36px -12px rgba(14, 42, 71, .2);
  transition: transform .55s var(--ease-organic), box-shadow .55s var(--ease-organic);
  isolation: isolate;
}
.photo-strip-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.1s var(--ease-organic), filter .55s var(--ease-organic);
  filter: saturate(.95);
}
.photo-strip-item::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset 0 0 0 1px rgba(192, 158, 100, .32);
  z-index: 1;
}
.photo-strip-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 16px rgba(14, 42, 71, .14), 0 26px 58px -14px rgba(14, 42, 71, .34);
}
.photo-strip-item:hover img {
  transform: scale(1.06);
  filter: saturate(1.04);
}

@media (max-width: 900px) {
  .photo-strip-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .photo-strip-grid { grid-template-columns: 1fr; }
}

/* Reduced-Motion: kein Hover-Animation-Boost */
@media (prefers-reduced-motion: reduce) {
  .photo-collage-item, .photo-collage-item img,
  .photo-strip-item, .photo-strip-item img {
    transition: none !important;
  }
  .photo-collage-item:hover, .photo-strip-item:hover { transform: none; }
  .photo-collage-item:hover img, .photo-strip-item:hover img { transform: none; }
}

/* ============================================================
   HERO POSTCARD — Familiärer Postkarten-Look (Hori-Wunsch)
   ============================================================ */
.hero--postcard {
  position: relative;
  min-height: 92vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 8rem 0 6rem;
}
.hero-overlay--postcard {
  background:
    radial-gradient(ellipse at 30% 40%, rgba(14, 42, 71, .35) 0%, rgba(14, 42, 71, .65) 70%, rgba(14, 42, 71, .8) 100%);
  z-index: 1;
}
.hero-postcard-wrap {
  position: relative;
  z-index: 5;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Die Postkarte selbst */
.postcard {
  position: relative;
  width: 100%;
  max-width: 720px;
  padding: clamp(2rem, 4.5vw, 3.5rem) clamp(1.75rem, 4vw, 3.2rem) clamp(1.25rem, 3vw, 1.75rem);
  background:
    /* dezente Papier-Faserung */
    repeating-linear-gradient(0deg, rgba(125, 90, 35, .025) 0px, rgba(125, 90, 35, .025) 1px, transparent 1px, transparent 3px),
    repeating-linear-gradient(90deg, rgba(125, 90, 35, .015) 0px, rgba(125, 90, 35, .015) 1px, transparent 1px, transparent 3px),
    linear-gradient(155deg, #fdf8ec 0%, #f5ecd5 50%, #ede0c0 100%);
  border-radius: 4px;
  transform: rotate(-1.2deg);
  box-shadow:
    /* Schatten innen oben: alte Stockflecken */
    inset 0 1px 0 rgba(255, 255, 255, .6),
    inset 0 0 80px rgba(125, 90, 35, .12),
    /* Schatten außen: hebt aus dem Video */
    0 4px 12px rgba(0, 0, 0, .15),
    0 18px 40px rgba(0, 0, 0, .28),
    0 38px 80px -10px rgba(0, 0, 0, .35);
  /* leicht angeknitterte Kanten */
  background-clip: padding-box;
  border: 1px solid rgba(125, 90, 35, .15);
}
.postcard::before {
  /* Dekorative gestrichelte Trennlinie (typische Postkarten-Mitte) */
  content: "";
  position: absolute;
  top: 50%;
  bottom: 8%;
  left: 50%;
  width: 1px;
  background: repeating-linear-gradient(180deg, rgba(125, 90, 35, .35) 0 6px, transparent 6px 12px);
  opacity: 0;
  pointer-events: none;
}
.postcard::after {
  /* Eselsohr unten rechts */
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 28px;
  height: 28px;
  background: linear-gradient(135deg, transparent 50%, rgba(125, 90, 35, .18) 50%, rgba(125, 90, 35, .35) 80%);
  border-bottom-right-radius: 4px;
  pointer-events: none;
}

/* Stempel oben rechts */
.postcard-stamp {
  position: absolute;
  top: clamp(1rem, 2.5vw, 1.75rem);
  right: clamp(1rem, 3vw, 2rem);
  width: clamp(95px, 13vw, 130px);
  height: clamp(95px, 13vw, 130px);
  color: #8a3a2a;
  opacity: .88;
  transform: rotate(8deg);
  pointer-events: none;
  /* leichter Druckfehler-Effekt */
  filter: blur(.3px);
  mix-blend-mode: multiply;
}
.postcard-stamp svg { width: 100%; height: 100%; }

/* Briefmarke oben links */
.postcard-marke {
  position: absolute;
  top: clamp(1.1rem, 2.5vw, 1.75rem);
  left: clamp(1.1rem, 3vw, 2rem);
  width: clamp(70px, 9vw, 95px);
  height: clamp(85px, 11vw, 115px);
  transform: rotate(-3deg);
  pointer-events: none;
}
.postcard-marke-inner {
  width: 100%;
  height: 100%;
  background: linear-gradient(155deg, #b08d4a 0%, #8a6a30 100%);
  border-radius: 3px;
  padding: 6px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  color: #fdf8ec;
  /* Briefmarken-Zacken via background-image */
  background-image:
    radial-gradient(circle at 0% 50%, transparent 4px, #b08d4a 4.5px),
    radial-gradient(circle at 100% 50%, transparent 4px, #b08d4a 4.5px),
    radial-gradient(circle at 50% 0%, transparent 4px, #b08d4a 4.5px),
    radial-gradient(circle at 50% 100%, transparent 4px, #b08d4a 4.5px),
    linear-gradient(155deg, #b08d4a 0%, #8a6a30 100%);
  box-shadow: 0 2px 6px rgba(0, 0, 0, .25);
  position: relative;
}
.postcard-marke-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px dashed rgba(255, 255, 255, .4);
  pointer-events: none;
}
.postcard-marke-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: .55rem;
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
}
.postcard-marke-icon {
  font-size: 1.8rem;
  line-height: 1;
  text-shadow: 0 1px 2px rgba(0, 0, 0, .3);
}
.postcard-marke-price {
  font-family: 'Playfair Display', serif;
  font-size: .9rem;
  font-weight: 700;
}

/* Body — handgeschriebener Brief */
.postcard-body {
  position: relative;
  z-index: 2;
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
  max-width: 580px;
}
.postcard-greeting {
  font-family: 'Caveat', cursive;
  font-size: clamp(1.6rem, 2.8vw, 2.1rem);
  color: #2a4264;
  margin: 0 0 .25rem;
  font-weight: 600;
}
.postcard-message {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2rem, 5vw, 3.6rem);
  font-weight: 700;
  line-height: 1.05;
  color: #1a3050;
  margin: 0 0 1.4rem;
  letter-spacing: -.01em;
}
.postcard-message em {
  font-family: 'Caveat', cursive;
  font-style: normal;
  color: #8a3a2a;
  font-weight: 700;
  font-size: 1.15em;
  margin-left: .1em;
}
.postcard-text {
  font-family: 'Inter', sans-serif;
  font-size: clamp(.95rem, 1.2vw, 1.05rem);
  line-height: 1.65;
  color: rgba(26, 48, 80, .82);
  margin: 0 0 1.4rem;
  max-width: 480px;
}
.postcard-signature {
  font-family: 'Caveat', cursive;
  font-size: clamp(1.4rem, 2.2vw, 1.75rem);
  color: #2a4264;
  margin: 0;
  font-weight: 600;
  font-style: italic;
}

/* Untere Meta-Zeile: Adresse + Aktionen */
.postcard-meta {
  position: relative;
  z-index: 2;
  margin-top: clamp(2rem, 4vw, 2.75rem);
  padding-top: clamp(1rem, 2vw, 1.5rem);
  border-top: 1px dashed rgba(125, 90, 35, .35);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.postcard-address {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  font-family: 'Inter', sans-serif;
  font-size: .82rem;
  color: rgba(26, 48, 80, .75);
  line-height: 1.4;
}
.postcard-address-label {
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 600;
  color: rgba(26, 48, 80, .55);
  margin-bottom: .2rem;
}
.postcard-address-phone {
  margin-top: .3rem;
  font-weight: 600;
  color: #1a3050;
}
.postcard-actions {
  display: flex;
  gap: 1.25rem;
  align-items: center;
}
.postcard-link {
  font-family: 'Inter', sans-serif;
  font-size: .9rem;
  font-weight: 600;
  color: rgba(26, 48, 80, .75);
  text-decoration: none;
  padding: .4rem 0;
  border-bottom: 1px solid rgba(26, 48, 80, .3);
  transition: color .3s ease, border-color .3s ease;
  letter-spacing: .02em;
}
.postcard-link:hover { color: #8a3a2a; border-color: #8a3a2a; }
.postcard-link--primary {
  color: #8a3a2a;
  border-color: #8a3a2a;
  font-weight: 700;
}
.postcard-link--primary:hover {
  color: #1a3050;
  border-color: #1a3050;
}

/* Mobile: weniger Rotation, kompakter */
@media (max-width: 720px) {
  .hero--postcard { padding: 6rem 0 4rem; }
  .postcard {
    transform: rotate(-.5deg);
    padding: 2.5rem 1.5rem 1.25rem;
  }
  .postcard-marke { display: none; }
  .postcard-stamp { width: 80px; height: 80px; top: .75rem; right: .75rem; }
  .postcard-body { margin-top: 1rem; }
  .postcard-meta { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .postcard-actions { width: 100%; justify-content: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
  .postcard { transform: rotate(0); }
}
