/* ================================================================
   FORSTHAUS BRANDT — DNA
   Italian-Editorial Wirtshaus · Müschenbach
   ================================================================ */

@layer reset, tokens, base, components, pages, utilities;
@view-transition { navigation: auto; }

@layer reset {
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; overflow-x: hidden; }
  body { line-height: 1.55; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
  img, picture, video { display: block; max-width: 100%; height: auto; }
  button, input, select, textarea { font: inherit; color: inherit; }
  button { border: 0; background: none; cursor: pointer; }
  a { color: inherit; text-decoration: none; }
  ul, ol { list-style: none; }
  :focus-visible { outline: 2px solid var(--accent); outline-offset: 4px; }
}

@layer tokens {
  :root {
    --bg-primary: #1F1813;
    --bg-secondary: #332821;
    --bg-tertiary: #0E0A07;
    --text-primary: #FFF1DD;
    --text-secondary: rgba(255, 241, 221, 0.78);
    --text-muted: rgba(255, 241, 221, 0.62);
    --accent: #A8362C;             /* solid bg only — Buttons */
    --accent-text: #E07560;        /* small-text only — eyebrows, prices, links — 4.7:1 auf dark BG */
    --accent-hover: #C04534;
    --hairline: rgba(255, 241, 221, 0.16);

    --font-display: 'Crimson Pro', Georgia, serif;
    --font-body: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;

    --fs-hero: clamp(4rem, 9.5vw, 9rem);
    --fs-h1: clamp(2.2rem, 4.8vw, 3.75rem);
    --fs-h2: clamp(1.75rem, 3.6vw, 2.75rem);
    --fs-h3: clamp(1.25rem, 2.2vw, 1.5rem);
    --fs-body-lg: clamp(17px, 1.4vw, 19px);
    --fs-body: 17px;
    --fs-small: 0.875rem;
    --fs-eyebrow: 0.75rem;

    --content-max: 1320px;
    --content-narrow: 760px;
    --gutter: clamp(1.25rem, 4vw, 3rem);
    --section-py: clamp(4rem, 9vw, 8rem);

    --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
    --dur-fast: 200ms;
    --dur-base: 400ms;
  }
}

@layer base {
  body {
    background: var(--bg-primary);
    color: var(--text-primary);
    font-family: var(--font-body);
    font-size: var(--fs-body);
    font-weight: 400;
  }
  h1, h2, h3, h4 {
    font-family: var(--font-display);
    font-weight: 500;
    line-height: 1.05;
    letter-spacing: -0.02em;
  }
  h1 em, h2 em, h3 em { font-style: italic; color: var(--accent-text); font-weight: 400; }
  p { line-height: 1.6; }
  ::selection { background: var(--accent); color: var(--text-primary); }
  .container { container-type: inline-size; }
}

@layer components {
  .container-wide { width: 100%; max-width: var(--content-max); margin-inline: auto; padding-inline: var(--gutter); }
  .container-narrow { width: 100%; max-width: var(--content-narrow); margin-inline: auto; padding-inline: var(--gutter); }
  section { padding-block: var(--section-py); }
  section.tight { padding-block: clamp(2.5rem, 5vw, 4rem); }

  .eyebrow {
    display: inline-block;
    font-family: var(--font-body);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--accent-text);
    font-weight: 500;
    margin-bottom: 1rem;
  }
  .eyebrow.muted { color: var(--text-muted); }

  .btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 2.25rem;
    font-family: var(--font-body);
    font-size: var(--fs-body);
    font-weight: 500;
    border-radius: 2px;
    transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), transform var(--dur-fast) var(--ease-out);
    min-height: 52px;
    letter-spacing: 0.025em;
  }
  .btn-primary { background: var(--accent); color: var(--text-primary); }
  .btn-primary:hover { background: var(--accent-hover); }
  .btn-ghost { background: transparent; color: var(--text-primary); border: 1px solid var(--hairline); }
  .btn-ghost:hover { border-color: var(--accent); color: var(--accent); }
  .btn-link {
    color: var(--accent-text); font-weight: 500; border-bottom: 1px solid currentColor;
    padding: 0.5rem 0; border-radius: 0; min-height: 32px; font-size: var(--fs-small);
    text-transform: uppercase; letter-spacing: 0.06em;
    display: inline-block;
  }
  .btn-link:hover { color: #FFB29A; }

  /* ─── Nav: minimal-link top, no container, distinct from prev branchen ─── */
  .nav {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(31, 24, 19, 0.85);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--hairline);
  }
  .nav-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.125rem var(--gutter);
    width: 100%;
    max-width: var(--content-max);
    margin-inline: auto;
  }
  .nav-logo {
    font-family: var(--font-display);
    font-size: 1.375rem;
    font-style: italic;
    font-weight: 500;
    white-space: nowrap;
  }
  @media (max-width: 480px) {
    .nav-logo { font-size: 1.125rem; }
  }
  .nav-logo .accent { color: var(--accent-text); font-style: normal; font-weight: 600; }
  .nav-list {
    display: none;
    gap: 2.25rem;
    align-items: center;
  }
  @media (min-width: 768px) {
    .nav-list { display: flex; }
  }
  .nav-list a {
    font-size: var(--fs-small);
    color: var(--text-secondary);
    transition: color var(--dur-fast);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 500;
    padding: 0.375rem 0;
    position: relative;
  }
  .nav-list a:hover { color: var(--accent-text); }
  .nav-list a[aria-current="page"] { color: var(--accent-text); }
  .nav-list a[aria-current="page"]::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px; background: var(--accent-text);
  }
  .nav-cta {
    background: var(--accent);
    color: var(--text-primary);
    padding: 0.625rem 1.125rem;
    font-size: var(--fs-small);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: background var(--dur-fast);
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
  }
  .nav-cta:hover { background: var(--accent-hover); }
  @media (max-width: 480px) {
    .nav-cta { display: none; }
  }
  .nav-burger {
    display: flex; flex-direction: column; gap: 4px;
    width: 44px; height: 44px;
    align-items: center; justify-content: center;
  }
  .nav-burger span { display: block; width: 22px; height: 1.5px; background: var(--text-primary); }
  @media (min-width: 768px) { .nav-burger { display: none; } }

  .nav-drawer {
    position: fixed; inset: 0;
    background: var(--bg-primary);
    z-index: 100;
    transform: translateY(-100%);
    transition: transform 0.5s var(--ease-out);
    padding: 4rem var(--gutter) 2rem;
    display: flex; flex-direction: column;
  }
  .nav-drawer.is-open { transform: translateY(0); }
  .nav-drawer-close { position: absolute; top: 1rem; right: 1rem; width: 44px; height: 44px; color: var(--text-primary); font-size: 1.625rem; }
  .nav-drawer ul { display: grid; gap: 0; margin-top: 1rem; }
  .nav-drawer ul a {
    display: block; padding-block: 1rem;
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(2rem, 7vw, 3rem);
    line-height: 1;
    border-bottom: 1px solid var(--hairline);
  }
  .nav-drawer ul a[aria-current="page"] { color: var(--accent); }

  /* Photo */
  .photo {
    overflow: hidden; position: relative; background: var(--bg-secondary);
  }
  .photo img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease-out); }
  .photo:hover img { transform: scale(1.02); }

  /* Footer */
  .footer {
    background: var(--bg-tertiary);
    padding: clamp(3rem, 6vw, 5rem) 0 1.5rem;
    border-top: 1px solid var(--accent);
  }
  .footer-grid {
    display: grid; grid-template-columns: 1fr; gap: 2.5rem;
    padding-bottom: 2.5rem; border-bottom: 1px solid var(--hairline);
  }
  @media (min-width: 768px) { .footer-grid { grid-template-columns: 1.4fr 1fr; gap: 4rem; align-items: end; } }
  .footer-tagline {
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(1.5rem, 2.8vw, 2rem);
    line-height: 1.2;
    margin-top: 0.75rem;
    max-width: 22ch;
  }
  .footer-tagline em { color: var(--accent-text); }
  .footer-meta-row { display: flex; flex-wrap: wrap; gap: 0.75rem 1.75rem; margin-top: 1.25rem; }
  .footer-meta-row a { font-size: var(--fs-small); color: var(--text-secondary); border-bottom: 1px solid var(--hairline); padding-bottom: 2px; transition: color var(--dur-fast); }
  .footer-meta-row a:hover { color: var(--accent-text); border-color: var(--accent-text); }
  .footer-contact h2 {
    font-family: var(--font-body);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase; letter-spacing: 0.18em;
    color: var(--text-muted);
    margin-bottom: 0.875rem;
    font-weight: 500;
  }
  .footer-contact p, .footer-contact address { font-style: normal; line-height: 1.7; color: var(--text-secondary); font-size: var(--fs-small); }
  .footer-contact a:hover { color: var(--accent-text); }
  .footer-base {
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
    padding-top: 1.5rem; font-size: var(--fs-small); color: var(--text-muted);
  }
}

@layer utilities {
  .muted { color: var(--text-secondary); }
  .accent { color: var(--accent); }
  .italic { font-style: italic; }
  .visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  ::view-transition-group(*), ::view-transition-old(*), ::view-transition-new(*) { animation: none !important; }
}

/* ================================================================
   PAGE STYLES
   ================================================================ */
@layer pages {

  /* ─── Hero (#5 Asymmetric-Grid) ─── */
  .hero { padding-top: clamp(3rem, 6vw, 5rem); padding-bottom: 0; }
  .hero-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.875rem;
    margin-bottom: clamp(2.5rem, 5vw, 4rem);
  }
  @media (min-width: 768px) {
    .hero-grid {
      grid-template-columns: 0.8fr 1.8fr 0.8fr;
      grid-template-rows: 1fr 1fr;
      gap: 1rem;
      aspect-ratio: 21/12;
    }
    .hero-grid .hero-cell-text { grid-column: 2 / 3; grid-row: 1 / 2; align-self: end; padding-block: 1.5rem; }
    .hero-grid .hero-cell-cta { grid-column: 2 / 3; grid-row: 2 / 3; align-self: start; padding-block: 1rem; }
    .hero-grid .photo-1 { grid-column: 1 / 2; grid-row: 1 / 3; }
    .hero-grid .photo-2 { grid-column: 3 / 4; grid-row: 1 / 2; }
    .hero-grid .photo-3 { grid-column: 3 / 4; grid-row: 2 / 3; }
  }
  .hero-cell-text h1 {
    font-family: var(--font-display);
    font-size: var(--fs-hero);
    font-weight: 500;
    line-height: 0.97;
    letter-spacing: -0.03em;
    color: var(--text-primary);
  }
  .hero-cell-text h1 em {
    font-style: italic;
    color: var(--accent);
    font-weight: 400;
  }
  .hero-cell-text p {
    margin-top: 1rem;
    color: var(--text-secondary);
    font-size: var(--fs-body-lg);
    max-width: 30ch;
  }
  .hero-cell-cta {
    display: flex; gap: 1.25rem; align-items: center; flex-wrap: wrap;
  }
  .hero-grid .photo {
    width: 100%; aspect-ratio: 4/5;
  }
  /* Mobile: headline + CTA first, then single 3/2 food photo, hide the rest */
  @media (max-width: 767px) {
    .hero-grid .hero-cell-text { order: -2; }
    .hero-grid .hero-cell-cta  { order: -1; }
    .hero-grid .photo-1 { order: 0; aspect-ratio: 3/2; }
    .hero-grid .photo-2, .hero-grid .photo-3 { display: none; }
  }
  @media (min-width: 768px) {
    .hero-grid .photo { aspect-ratio: auto; height: 100%; }
  }

  /* ─── Manifesto ─── */
  .manifesto { padding-block: clamp(4rem, 8vw, 7rem); }
  .manifesto-text {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3.2vw, 2.5rem);
    font-weight: 400;
    line-height: 1.3;
    font-style: italic;
    color: var(--text-primary);
    max-width: 28ch;
    margin-bottom: 1.5rem;
  }
  .manifesto-text em { font-style: normal; color: var(--accent); }
  .manifesto-signature {
    font-size: var(--fs-small);
    color: var(--text-muted);
    letter-spacing: 0.04em;
  }

  /* ─── Section Header ─── */
  .section-header {
    display: grid; gap: 1rem;
    margin-bottom: clamp(2rem, 4vw, 3rem);
    align-items: end;
  }
  @media (min-width: 768px) { .section-header { grid-template-columns: 1fr auto; gap: 2rem; } }
  .section-header h2 {
    font-size: var(--fs-h1);
    line-height: 1.0;
    max-width: 18ch;
  }

  /* ─── Karte-Teaser (3 Highlights) ─── */
  .karte-teaser {
    padding-block: clamp(3rem, 6vw, 5rem);
    background: var(--bg-secondary);
  }
  .karte-grid {
    display: grid; grid-template-columns: 1fr; gap: 2rem;
  }
  @media (min-width: 768px) { .karte-grid { grid-template-columns: repeat(3, 1fr); } }
  .karte-card {
    display: grid;
    gap: 1.25rem;
    transition: transform 0.35s var(--ease-out);
  }
  .karte-card:hover { transform: translateY(-6px); }
  .karte-card:hover .photo img { transform: scale(1.03); }
  .karte-card .photo { aspect-ratio: 4/5; }
  .karte-card-num {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.5rem;
  }
  .karte-card h3 { font-size: var(--fs-h2); line-height: 1.1; }
  .karte-card p { color: var(--text-secondary); line-height: 1.55; max-width: 32ch; }
  .karte-card .karte-price {
    color: var(--accent-text);
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-style: italic;
    margin-top: 0.5rem;
  }

  /* ─── Chef Portrait ─── */
  .chef {
    padding-block: clamp(4rem, 8vw, 7rem);
  }
  .chef-grid {
    display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center;
  }
  @media (min-width: 768px) { .chef-grid { grid-template-columns: 1fr 1.4fr; gap: 4rem; } }
  .chef-photo .photo { aspect-ratio: 4/5; }
  .chef-text h2 { font-size: var(--fs-h1); line-height: 1.0; margin-bottom: 1.25rem; max-width: 16ch; }
  .chef-text p { color: var(--text-secondary); line-height: 1.65; max-width: 50ch; margin-bottom: 1rem; }
  .chef-actions { margin-top: 1.5rem; display: flex; gap: 1.5rem; flex-wrap: wrap; }

  /* ─── Reservierung CTA ─── */
  .reservierung-cta {
    background: linear-gradient(135deg, #2A1A10 0%, #3D1F14 100%);
    color: var(--text-primary);
    padding-block: clamp(4rem, 8vw, 6rem);
    border-top: 2px solid var(--accent);
  }
  .reservierung-cta-inner {
    display: grid; grid-template-columns: 1fr; gap: 2rem; align-items: end;
  }
  @media (min-width: 768px) { .reservierung-cta-inner { grid-template-columns: 1.5fr 1fr; gap: 3rem; } }
  .reservierung-cta h2 {
    font-size: clamp(2.25rem, 5.5vw, 4rem);
    color: var(--text-primary);
    line-height: 1.0;
    max-width: 20ch;
  }
  .reservierung-cta h2 em { color: var(--accent-text); font-style: italic; }
  .reservierung-cta p { color: rgba(255, 241, 221, 0.88); font-size: var(--fs-body-lg); margin-block: 1rem 1.5rem; max-width: 40ch; }
  .reservierung-cta .btn-primary { background: var(--accent); }
  .reservierung-cta .btn-primary:hover { background: var(--accent-hover); }
  .reservierung-cta .btn-ghost { border-color: var(--hairline); }
  .reservierung-cta .btn-ghost:hover { border-color: var(--accent-text); color: var(--accent-text); }

  /* ─── Subpage Hero ─── */
  .subpage-hero { padding-block: clamp(4rem, 8vw, 7rem) clamp(2rem, 4vw, 3rem); }
  .subpage-display {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    line-height: 1.0;
    letter-spacing: -0.015em;
    margin-block: 0.75rem 1rem;
    max-width: 20ch;
  }
  .subpage-display em { font-style: italic; color: var(--accent); }
  .subpage-lead { font-size: var(--fs-body-lg); color: var(--text-secondary); max-width: 56ch; }

  /* ─── Karte Page (Editorial Speisekarte) ─── */
  .karte-tabs {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--hairline);
    margin-bottom: 2.5rem;
    overflow-x: auto;
    scrollbar-width: thin;
    scroll-snap-type: x mandatory;
  }
  .karte-tab {
    padding: 1rem 1.5rem;
    font-family: var(--font-body);
    font-size: var(--fs-small);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-weight: 500;
    color: var(--text-secondary);
    background: transparent;
    border-bottom: 2px solid transparent;
    transition: color var(--dur-fast), border-color var(--dur-fast);
    white-space: nowrap;
    scroll-snap-align: start;
    cursor: pointer;
  }
  .karte-tab.is-active { color: var(--accent-text); border-bottom-color: var(--accent-text); }
  .karte-tab:hover { color: var(--text-primary); }

  .karte-section { display: none; }
  .karte-section.is-active { display: block; animation: tab-in 0.35s var(--ease-out) both; }
  @keyframes tab-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

  .karte-section h2 {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--text-primary);
    font-size: var(--fs-h1);
    margin-bottom: 0.625rem;
    letter-spacing: -0.01em;
    line-height: 1.05;
  }
  .karte-section h2 em { color: var(--accent-text); }
  .karte-section > p {
    color: var(--text-secondary);
    margin-bottom: 0;
    max-width: 64ch;
    font-size: var(--fs-body-lg);
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--hairline);
  }

  .menu-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: 2rem;
  }
  @media (min-width: 768px) { .menu-list { grid-template-columns: repeat(2, 1fr); column-gap: 4rem; } }
  .menu-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.375rem 1.25rem;
    padding-block: 1.25rem;
    border-bottom: 1px solid var(--hairline);
    align-items: baseline;
  }
  .menu-item-name {
    font-family: var(--font-display);
    font-size: clamp(1.125rem, 1.8vw, 1.3rem);
    font-weight: 500;
    color: var(--text-primary);
    letter-spacing: -0.005em;
  }
  .menu-item-name em { color: var(--accent-text); font-style: italic; font-size: 0.9em; margin-left: 0.5rem; }
  .menu-item-desc {
    grid-column: 1 / -1;
    font-size: var(--fs-small);
    color: var(--text-muted);
    line-height: 1.55;
  }
  .menu-item-price {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: clamp(1.125rem, 1.6vw, 1.375rem);
    white-space: nowrap;
    letter-spacing: -0.01em;
  }

  /* ─── Über Page ─── */
  .ueber-section { padding-block: clamp(3rem, 6vw, 5rem); }
  .ueber-section.alt { background: var(--bg-secondary); }
  .ueber-row {
    display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center;
  }
  @media (min-width: 768px) { .ueber-row { grid-template-columns: 1fr 1.4fr; gap: 4rem; } }
  .ueber-row.flip > .photo { order: -1; }
  .ueber-row .photo { aspect-ratio: 4/5; }
  .ueber-row h2 { font-size: var(--fs-h1); line-height: 1.0; margin-bottom: 1rem; max-width: 16ch; }
  .ueber-row p { color: var(--text-secondary); line-height: 1.65; margin-bottom: 1rem; max-width: 50ch; }

  /* ─── Reservierung Page ─── */
  .reservierung-form {
    padding-block: clamp(2rem, 4vw, 3rem);
  }
  .reservierung-grid {
    display: grid; grid-template-columns: 1fr; gap: 1.25rem;
    background: var(--bg-secondary);
    padding: clamp(1.75rem, 3vw, 2.5rem);
  }
  .reservierung-grid::before {
    content: "Reservierung";
    grid-column: 1 / -1;
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: var(--fs-h2);
    margin-bottom: 0.5rem;
  }
  @media (min-width: 768px) { .reservierung-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem 1.25rem; } .reservierung-row.full { grid-column: 1 / -1; } }
  .reservierung-row label {
    display: block;
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--text-muted);
    margin-bottom: 0.5rem;
    font-weight: 500;
  }
  .reservierung-row input, .reservierung-row select, .reservierung-row textarea {
    width: 100%;
    background: transparent;
    color: var(--text-primary);
    border: 0;
    border-bottom: 1px solid var(--hairline);
    padding: 0.625rem 0;
    font-size: var(--fs-body-lg);
    transition: border-color var(--dur-fast);
  }
  .reservierung-row input:focus, .reservierung-row select:focus, .reservierung-row textarea:focus {
    outline: 0; border-color: var(--accent);
  }
  .reservierung-row textarea { min-height: 100px; resize: vertical; }

  /* ─── Anfahrt Strip ─── */
  .anfahrt-strip {
    padding-block: clamp(3rem, 6vw, 5rem);
    background: var(--bg-secondary);
    border-top: 1px solid var(--hairline);
  }
  .anfahrt-grid {
    display: grid; grid-template-columns: 1fr; gap: 2rem;
  }
  @media (min-width: 768px) { .anfahrt-grid { grid-template-columns: repeat(3, 1fr); gap: 3rem; } }
  .anfahrt-grid h2 {
    font-family: var(--font-body);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase; letter-spacing: 0.18em;
    color: var(--accent-text); font-weight: 500;
    margin-bottom: 0.875rem;
  }
  .anfahrt-grid p, .anfahrt-grid address { font-style: normal; line-height: 1.7; color: var(--text-secondary); }
  .anfahrt-grid a:hover { color: var(--accent-text); }

  /* ─── Press / Reviews ─── */
  .press {
    padding-block: clamp(4rem, 8vw, 7rem);
    border-top: 1px solid var(--hairline);
  }
  .press-grid {
    display: grid; grid-template-columns: 1fr; gap: 2rem;
  }
  @media (min-width: 768px) { .press-grid { grid-template-columns: repeat(3, 1fr); gap: 3rem; } }
  .press-quote {
    border-left: 1px solid var(--accent);
    padding: 0.25rem 0 0.25rem 1.5rem;
  }
  .press-quote blockquote {
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(1.125rem, 1.8vw, 1.5rem);
    line-height: 1.35;
    color: var(--text-primary);
    margin-bottom: 1.25rem;
    max-width: 28ch;
  }
  .press-source {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    font-size: var(--fs-small);
  }
  .press-source-name {
    color: var(--accent-text);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-weight: 600;
  }
  .press-source-meta {
    color: var(--text-muted);
    font-style: italic;
  }
  .press-rating-row {
    display: flex; flex-wrap: wrap;
    gap: 1rem 2.5rem;
    margin-top: clamp(2.5rem, 5vw, 4rem);
    padding-top: clamp(2rem, 4vw, 3rem);
    border-top: 1px solid var(--hairline);
  }
  .press-rating {
    display: flex; flex-direction: column; gap: 0.25rem;
  }
  .press-rating-num {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: clamp(1.625rem, 2.6vw, 2rem);
    line-height: 1;
  }
  .press-rating-label {
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-muted);
  }

  /* ─── Wein Pairing ─── */
  .wein-pairing {
    padding-block: clamp(4rem, 8vw, 7rem);
    background: var(--bg-secondary);
  }
  .wein-grid {
    display: grid; grid-template-columns: 1fr; gap: 0;
    border-top: 1px solid var(--hairline);
  }
  @media (min-width: 768px) { .wein-grid { grid-template-columns: repeat(2, 1fr); column-gap: 4rem; } }
  .wein-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-areas: "num name price" ". meta meta" ". pairing pairing";
    gap: 0.25rem 1rem;
    padding-block: 1.5rem;
    border-bottom: 1px solid var(--hairline);
    align-items: baseline;
  }
  .wein-num {
    grid-area: num;
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 0.95rem;
    width: 1.75rem;
  }
  .wein-name {
    grid-area: name;
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 500;
  }
  .wein-name em { color: var(--accent-text); font-style: italic; font-size: 0.92em; }
  .wein-price {
    grid-area: price;
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.125rem;
    white-space: nowrap;
  }
  .wein-meta {
    grid-area: meta;
    font-size: var(--fs-small);
    color: var(--text-muted);
    line-height: 1.55;
  }
  .wein-pairing-tip {
    grid-area: pairing;
    font-size: var(--fs-small);
    color: var(--text-secondary);
    margin-top: 0.5rem;
    padding-left: 0.875rem;
    border-left: 1px solid var(--accent);
    font-style: italic;
  }
  .wein-pairing-tip strong {
    color: var(--accent-text);
    font-style: normal;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.7rem;
    display: block;
    margin-bottom: 0.125rem;
  }

  /* ─── Lieferanten ─── */
  .lieferanten {
    padding-block: clamp(4rem, 8vw, 7rem);
    background: #F5EBD8;
    color: var(--bg-primary);
  }
  .lieferanten .section-header h2,
  .lieferanten .section-header h2 em { color: var(--bg-primary); }
  .lieferanten .eyebrow { color: #7A4A2A; }
  .lieferanten .btn-link { color: #7A4A2A; border-bottom-color: #7A4A2A; }
  .lieferanten .btn-link:hover { color: #A8362C; }
  .lieferanten .lieferant-eyebrow { color: #8A4A2A; }
  .lieferanten .lieferant h3 { color: var(--bg-primary); }
  .lieferanten .lieferant h3 em { color: #8A4A2A; }
  .lieferanten .lieferant p { color: #4A3020; }
  .lieferanten .lieferant-distance { color: #7A5A3A; border-top-color: rgba(74, 48, 32, 0.2); }
  .lieferanten-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  @media (min-width: 768px) {
    .lieferanten-grid { grid-template-columns: repeat(2, 1fr); gap: 3rem 2.5rem; }
  }
  @media (min-width: 1080px) {
    .lieferanten-grid { grid-template-columns: repeat(3, 1fr); }
  }
  .lieferant {
    display: grid; gap: 1rem;
  }
  .lieferant .photo { aspect-ratio: 4/3; }
  .lieferant-eyebrow {
    font-family: var(--font-body);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--accent-text);
    font-weight: 500;
  }
  .lieferant h3 {
    font-size: 1.5rem;
    line-height: 1.15;
  }
  .lieferant h3 em { font-style: italic; color: var(--accent-text); }
  .lieferant p {
    color: var(--text-secondary);
    font-size: var(--fs-small);
    line-height: 1.65;
  }
  .lieferant-distance {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-muted);
    margin-top: 0.25rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--hairline);
  }

  /* ─── Saison / Wild Calendar ─── */
  .saison {
    padding-block: clamp(4rem, 8vw, 7rem);
    background: var(--bg-tertiary);
  }
  .saison-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    border-top: 1px solid var(--hairline);
  }
  @media (min-width: 768px) {
    .saison-row { grid-template-columns: 0.4fr 1.6fr 1fr 1fr; align-items: center; }
  }
  .saison-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    padding-block: 1.5rem;
    border-bottom: 1px solid var(--hairline);
  }
  @media (min-width: 768px) {
    .saison-card {
      grid-template-columns: subgrid;
      grid-column: 1 / -1;
      gap: 1.5rem;
      padding-block: 1.75rem;
      align-items: center;
    }
  }
  .saison-month {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.5rem;
    line-height: 1;
  }
  .saison-card h3 {
    font-size: 1.25rem;
    line-height: 1.2;
  }
  .saison-card h3 em { font-style: italic; color: var(--accent-text); }
  .saison-card .saison-detail {
    font-size: var(--fs-small);
    color: var(--text-secondary);
    line-height: 1.55;
  }
  .saison-card .saison-pairing {
    font-size: var(--fs-small);
    color: var(--text-muted);
    font-style: italic;
  }

  /* ─── Events / Chef Table ─── */
  .events {
    padding-block: clamp(4rem, 8vw, 7rem);
  }
  .events-grid {
    display: grid; grid-template-columns: 1fr; gap: 2rem;
  }
  @media (min-width: 768px) {
    .events-grid { grid-template-columns: repeat(2, 1fr); gap: 2.5rem; }
  }
  .event-card {
    display: grid;
    gap: 1.5rem;
    padding: 0;
    background: var(--bg-secondary);
    border: 1px solid var(--hairline);
    transition: border-color var(--dur-base) var(--ease-out), transform 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
  }
  .event-card:hover {
    border-color: var(--accent);
    transform: translateY(-6px);
    box-shadow: 0 18px 48px -12px rgba(14,10,7,0.65);
  }
  .event-card .photo { aspect-ratio: 16/10; }
  .event-card-body {
    padding: 0 1.75rem 2rem;
    display: grid;
    gap: 1rem;
  }
  .event-card-eyebrow {
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--accent-text);
    font-weight: 500;
  }
  .event-card h3 {
    font-size: 1.625rem;
    line-height: 1.15;
  }
  .event-card h3 em { font-style: italic; color: var(--accent-text); }
  .event-card p {
    color: var(--text-secondary);
    font-size: var(--fs-small);
    line-height: 1.65;
  }
  .event-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--hairline);
    font-size: var(--fs-small);
  }
  .event-meta {
    display: flex; flex-direction: column; gap: 0.125rem;
  }
  .event-meta-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-muted);
  }
  .event-meta-value {
    font-family: var(--font-display);
    color: var(--accent-text);
    font-style: italic;
    font-size: 1.125rem;
  }

  /* ─── FAQ ─── */
  .faq {
    padding-block: clamp(4rem, 8vw, 7rem);
    background: var(--bg-secondary);
  }
  .faq-list {
    display: grid; grid-template-columns: 1fr; gap: 0;
    max-width: 820px;
    margin-inline: auto;
    border-top: 1px solid var(--hairline);
  }
  .faq-item {
    border-bottom: 1px solid var(--hairline);
  }
  .faq-item summary {
    padding: 1.5rem 0;
    cursor: pointer;
    font-family: var(--font-display);
    font-size: 1.25rem;
    line-height: 1.3;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1.5rem;
    transition: color var(--dur-fast);
  }
  .faq-item summary::-webkit-details-marker { display: none; }
  .faq-item summary::after {
    content: "+";
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.5rem;
    transition: transform var(--dur-base) var(--ease-out);
    flex-shrink: 0;
  }
  .faq-item[open] summary::after {
    content: "–";
  }
  .faq-item summary:hover { color: var(--accent-text); }
  .faq-item-body {
    padding: 0 0 1.5rem;
    color: var(--text-secondary);
    line-height: 1.7;
    max-width: 60ch;
  }
  .faq-item-body p + p { margin-top: 0.875rem; }

  /* ─── Gutschein ─── */
  .gutschein {
    padding-block: clamp(4rem, 8vw, 7rem);
  }
  .gutschein-grid {
    display: grid; grid-template-columns: 1fr; gap: 2.5rem;
    align-items: center;
  }
  @media (min-width: 768px) {
    .gutschein-grid { grid-template-columns: 1.2fr 1fr; gap: 4rem; }
  }
  .gutschein-card {
    background: var(--bg-secondary);
    border: 1px solid var(--accent);
    padding: clamp(2rem, 4vw, 3rem);
    display: grid;
    gap: 1.25rem;
  }
  .gutschein-card-eyebrow {
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--accent-text);
    font-weight: 500;
  }
  .gutschein-card h2 {
    font-size: var(--fs-h2);
    line-height: 1.0;
  }
  .gutschein-card h2 em { font-style: italic; color: var(--accent-text); }
  .gutschein-options {
    display: grid; gap: 0.875rem;
    margin-top: 0.5rem;
  }
  .gutschein-option {
    display: flex; justify-content: space-between; align-items: baseline;
    gap: 1rem;
    padding-block: 0.75rem;
    border-bottom: 1px solid var(--hairline);
    font-size: var(--fs-body);
  }
  .gutschein-option:last-child { border-bottom: 0; }
  .gutschein-option-name { color: var(--text-primary); }
  .gutschein-option-price {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.25rem;
  }

  /* ─── Generations Timeline (Über) ─── */
  .timeline-strip {
    padding-block: clamp(3rem, 6vw, 5rem);
    background: var(--bg-tertiary);
    border-top: 1px solid var(--hairline);
    border-bottom: 1px solid var(--hairline);
  }
  .timeline-grid {
    display: grid; grid-template-columns: 1fr; gap: 1.5rem;
  }
  @media (min-width: 768px) {
    .timeline-grid { grid-template-columns: repeat(4, 1fr); gap: 2rem; }
  }
  .timeline-cell {
    border-top: 1px solid var(--accent);
    padding-top: 1rem;
  }
  .timeline-year {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: clamp(2rem, 3.4vw, 2.5rem);
    line-height: 1;
    margin-bottom: 0.5rem;
  }
  .timeline-cell-name {
    font-family: var(--font-display);
    font-size: 1.25rem;
    margin-bottom: 0.25rem;
  }
  .timeline-cell-role {
    font-size: var(--fs-small);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.14em;
  }

  /* ─── Werte ─── */
  .werte-grid {
    display: grid; grid-template-columns: 1fr; gap: 2rem;
    margin-top: clamp(2.5rem, 5vw, 4rem);
  }
  @media (min-width: 768px) { .werte-grid { grid-template-columns: repeat(2, 1fr); gap: 3rem 4rem; } }
  .werte-item {
    border-top: 1px solid var(--accent);
    padding-top: 1.25rem;
  }
  .werte-item h3 {
    font-size: 1.5rem;
    margin-bottom: 0.625rem;
    line-height: 1.2;
  }
  .werte-item h3 em { font-style: italic; color: var(--accent-text); }
  .werte-item p {
    color: var(--text-secondary);
    line-height: 1.65;
    font-size: var(--fs-body);
  }

  /* ─── Kochkurse ─── */
  .kurse-list {
    display: grid; grid-template-columns: 1fr; gap: 0;
    border-top: 1px solid var(--hairline);
  }
  .kurs-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    padding-block: 1.5rem;
    border-bottom: 1px solid var(--hairline);
  }
  @media (min-width: 768px) {
    .kurs-row {
      grid-template-columns: 0.5fr 2fr 1fr 0.7fr 0.6fr;
      align-items: baseline;
      gap: 2rem;
    }
  }
  .kurs-month {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.125rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
  }
  .kurs-name {
    font-family: var(--font-display);
    font-size: 1.25rem;
    line-height: 1.2;
  }
  .kurs-name em { font-style: italic; color: var(--accent-text); }
  .kurs-detail {
    font-size: var(--fs-small);
    color: var(--text-muted);
    line-height: 1.5;
  }
  .kurs-spots {
    font-size: var(--fs-small);
    color: var(--text-secondary);
  }
  .kurs-price {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.125rem;
    text-align: left;
  }
  @media (min-width: 768px) {
    .kurs-price { text-align: right; }
  }

  /* ─── Brunch / Frühstück Highlight ─── */
  .brunch {
    padding-block: clamp(4rem, 8vw, 7rem);
  }
  .brunch-grid {
    display: grid; grid-template-columns: 1fr; gap: 2.5rem;
    align-items: center;
  }
  @media (min-width: 768px) {
    .brunch-grid { grid-template-columns: 1fr 1.1fr; gap: 4rem; }
  }
  .brunch-photos {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, auto);
    gap: 0.75rem;
  }
  .brunch-photos .photo { aspect-ratio: 1; }
  @media (min-width: 600px) {
    .brunch-photos .photo:nth-child(2) { margin-top: 2rem; }
    .brunch-photos .photo:nth-child(3) { margin-top: -1.5rem; }
  }
  .brunch-text h2 {
    font-size: var(--fs-h1);
    line-height: 1.0;
    margin-bottom: 1rem;
    max-width: 16ch;
  }
  .brunch-text h2 em { font-style: italic; color: var(--accent-text); }
  .brunch-text p {
    color: var(--text-secondary);
    line-height: 1.65;
    margin-bottom: 1rem;
    max-width: 50ch;
  }
  .brunch-meta {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem 2rem;
    margin-top: 1.75rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--hairline);
  }
  .brunch-meta-cell {
    display: grid; gap: 0.25rem;
  }
  .brunch-meta-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-muted);
  }
  .brunch-meta-value {
    font-family: var(--font-display);
    font-size: 1.125rem;
    color: var(--text-primary);
  }
  .brunch-meta-value em { font-style: italic; color: var(--accent-text); }

  /* ─── Sommelier Portrait Inline ─── */
  .sommelier {
    padding-block: clamp(4rem, 8vw, 7rem);
    background: var(--bg-tertiary);
  }
  .sommelier-grid {
    display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center;
  }
  @media (min-width: 768px) {
    .sommelier-grid { grid-template-columns: 0.85fr 1.4fr; gap: 4rem; }
  }
  .sommelier .photo { aspect-ratio: 4/5; }
  .sommelier-text h2 {
    font-size: var(--fs-h1);
    line-height: 1.0;
    margin-bottom: 1rem;
    max-width: 16ch;
  }
  .sommelier-text h2 em { font-style: italic; color: var(--accent-text); }
  .sommelier-text p {
    color: var(--text-secondary);
    line-height: 1.65;
    margin-bottom: 1rem;
    max-width: 52ch;
  }
  .sommelier-quote {
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    line-height: 1.4;
    color: var(--text-primary);
    border-left: 1px solid var(--accent);
    padding-left: 1.5rem;
    margin-block: 1.5rem;
    max-width: 36ch;
  }

  /* ─── Allergen / Diet Strip ─── */
  .diet {
    padding-block: clamp(4rem, 7vw, 6rem);
    border-top: 1px solid var(--hairline);
  }
  .diet-row {
    display: grid; grid-template-columns: 1fr; gap: 2rem;
  }
  @media (min-width: 768px) { .diet-row { grid-template-columns: 1fr 1.4fr; gap: 4rem; } }
  .diet-row h2 {
    font-size: var(--fs-h2);
    line-height: 1.0;
    max-width: 14ch;
  }
  .diet-row h2 em { font-style: italic; color: var(--accent-text); }
  .diet-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .diet-list-item {
    display: grid;
    grid-template-columns: 2.5rem 1fr;
    gap: 0.5rem 1rem;
    padding-block: 1rem;
    border-bottom: 1px solid var(--hairline);
  }
  .diet-list-item:first-child { border-top: 1px solid var(--hairline); }
  .diet-tag {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.25rem;
    line-height: 1.2;
  }
  .diet-list-item h3 {
    font-family: var(--font-display);
    font-size: 1.125rem;
    line-height: 1.2;
    margin-bottom: 0.25rem;
  }
  .diet-list-item p {
    grid-column: 2 / 3;
    font-size: var(--fs-small);
    color: var(--text-muted);
    line-height: 1.55;
  }

  /* ─── Dress Code / Note Cards ─── */
  .info-cards {
    padding-block: clamp(3rem, 6vw, 5rem);
    background: var(--bg-secondary);
  }
  .info-grid {
    display: grid; grid-template-columns: 1fr; gap: 1.5rem;
  }
  @media (min-width: 768px) { .info-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; } }
  .info-card {
    padding: 1.75rem;
    border: 1px solid var(--hairline);
    background: var(--bg-primary);
  }
  .info-card-icon {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.75rem;
    line-height: 1;
    margin-bottom: 0.75rem;
  }
  .info-card h3 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
    line-height: 1.2;
  }
  .info-card p {
    color: var(--text-secondary);
    font-size: var(--fs-small);
    line-height: 1.6;
  }

  /* ─── Map Embed ─── */
  .map-embed {
    padding-block: clamp(3rem, 6vw, 5rem);
  }
  .map-frame {
    width: 100%;
    aspect-ratio: 21/9;
    border: 1px solid var(--hairline);
    background: var(--bg-secondary);
    position: relative;
    overflow: hidden;
  }
  @media (max-width: 768px) {
    .map-frame { aspect-ratio: 4/5; }
  }
  .map-pin {
    position: absolute;
    top: 38%;
    left: 52%;
    transform: translate(-50%, -50%);
    width: 1rem;
    height: 1rem;
    background: var(--accent);
    border-radius: 50%;
    box-shadow: 0 0 0 6px rgba(168, 54, 44, 0.35), 0 0 0 18px rgba(168, 54, 44, 0.15);
    animation: map-pulse 2.4s var(--ease-out) infinite;
  }
  @keyframes map-pulse {
    0%, 100% { box-shadow: 0 0 0 6px rgba(168, 54, 44, 0.35), 0 0 0 18px rgba(168, 54, 44, 0.15); }
    50% { box-shadow: 0 0 0 8px rgba(168, 54, 44, 0.45), 0 0 0 26px rgba(168, 54, 44, 0); }
  }
  .map-svg { width: 100%; height: 100%; display: block; }
  .map-caption-strip {
    display: flex; flex-wrap: wrap;
    gap: 1rem 2.5rem;
    padding-top: 1.25rem;
  }
  .map-caption-strip span {
    font-size: var(--fs-small);
    color: var(--text-muted);
    font-family: var(--font-display);
    font-style: italic;
  }
  .map-caption-strip span em { color: var(--accent-text); font-style: normal; }

  /* ─── Hero Video Tile ─── */
  .hero-video {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    background: var(--bg-secondary);
  }
  .photo-video-wrap {
    position: relative;
    overflow: hidden;
  }
  .photo-video-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(14,10,7,0) 50%, rgba(14,10,7,0.55) 100%);
    pointer-events: none;
  }
  .photo-video-credit {
    position: absolute;
    bottom: 0.875rem;
    left: 0.875rem;
    z-index: 2;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    color: rgba(255,241,221,0.86);
    background: rgba(14,10,7,0.42);
    padding: 0.35rem 0.65rem;
    border-left: 1px solid var(--accent);
    backdrop-filter: blur(4px);
  }

  /* ─── Steam / Smoke SVG overlay ─── */
  .photo-steam {
    position: relative;
  }
  .photo-steam::before {
    content: "";
    position: absolute;
    left: 12%;
    right: 12%;
    bottom: 32%;
    height: 60%;
    background: radial-gradient(ellipse at 50% 80%, rgba(255,241,221,0.42) 0%, rgba(255,241,221,0.16) 38%, rgba(255,241,221,0) 70%);
    filter: url(#steam-turbulence) blur(6px);
    mix-blend-mode: screen;
    opacity: 0.85;
    pointer-events: none;
    animation: steam-rise 5.5s ease-in-out infinite;
    transform-origin: 50% 100%;
    z-index: 2;
  }
  @keyframes steam-rise {
    0%   { transform: translateY(8%) scale(0.9, 0.85); opacity: 0.55; }
    50%  { transform: translateY(-12%) scale(1.05, 1.18); opacity: 0.78; }
    100% { transform: translateY(-30%) scale(1.18, 1.4); opacity: 0; }
  }

  /* ─── Editorial km annotations on hero ─── */
  .hero-annotations {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 3;
  }
  .hero-anno {
    position: absolute;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.78rem;
    color: rgba(255,241,221,0.88);
    letter-spacing: 0.04em;
    line-height: 1.3;
    max-width: 14ch;
    text-shadow: 0 1px 8px rgba(14,10,7,0.85);
  }
  .hero-anno::before {
    content: "";
    display: block;
    width: 1.5rem;
    height: 1px;
    background: var(--accent-text);
    margin-bottom: 0.3rem;
  }
  .hero-anno strong {
    display: block;
    font-family: var(--font-body);
    font-style: normal;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--accent-text);
    font-weight: 600;
    margin-bottom: 0.15rem;
  }
  .hero-anno-1 { top: 12%; right: 4%; text-align: left; }
  .hero-anno-2 { bottom: 14%; right: 4%; text-align: left; }
  .hero-anno-3 { bottom: 18%; left: 4%; text-align: left; }
  @media (max-width: 768px) {
    .hero-annotations { display: none; }
  }

  /* ─── Live status badge (open-now pulse) ─── */
  .live-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    margin-top: 1.25rem;
    padding: 0.4rem 0.85rem 0.4rem 0.7rem;
    border: 1px solid var(--hairline);
    background: rgba(14,10,7,0.5);
    font-family: var(--font-body);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-secondary);
    border-radius: 2px;
  }
  .live-dot {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: #4ea96b;
    box-shadow: 0 0 0 0 rgba(78, 169, 107, 0.55);
    animation: live-pulse 2.2s var(--ease-out) infinite;
  }
  @keyframes live-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(78, 169, 107, 0.55); }
    50%      { box-shadow: 0 0 0 7px rgba(78, 169, 107, 0); }
  }
  .live-badge em { font-style: normal; color: var(--text-primary); font-weight: 500; }

  /* ─── Candle flicker ─── */
  .candle-wrap {
    display: inline-flex;
    align-items: flex-end;
    gap: 0.85rem;
    margin-top: 2rem;
  }
  .candle-svg { width: 38px; height: 78px; }
  .candle-flame { transform-origin: 50% 100%; animation: flicker 1.6s ease-in-out infinite alternate; }
  .candle-glow { transform-origin: 50% 70%; animation: candle-glow 1.6s ease-in-out infinite alternate; }
  @keyframes flicker {
    0%   { transform: translateX(-0.6px) scale(0.97, 1.02); opacity: 0.92; }
    25%  { transform: translateX(0.4px) scale(1.02, 0.96); opacity: 1; }
    50%  { transform: translateX(-0.3px) scale(0.99, 1.04); opacity: 0.88; }
    75%  { transform: translateX(0.6px) scale(1.04, 1); opacity: 0.96; }
    100% { transform: translateX(0) scale(1, 1.02); opacity: 1; }
  }
  @keyframes candle-glow {
    0%   { opacity: 0.55; transform: scale(0.96); }
    100% { opacity: 0.85; transform: scale(1.06); }
  }
  .candle-caption {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--text-muted);
    font-size: 0.92rem;
    line-height: 1.4;
    max-width: 22ch;
  }

  /* ─── Heute-auf-der-Karte handwritten strip ─── */
  .heute-strip {
    background: var(--bg-tertiary);
    border-top: 1px solid var(--hairline);
    border-bottom: 1px solid var(--hairline);
    overflow: hidden;
    padding-block: 1rem;
  }
  .heute-strip-inner {
    display: flex; gap: 3rem;
    white-space: nowrap;
    animation: heute-marquee 38s linear infinite;
    will-change: transform;
  }
  .heute-strip-inner > span {
    font-family: 'Crimson Pro', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: clamp(1.375rem, 2.6vw, 1.75rem);
    color: var(--text-primary);
    letter-spacing: 0.01em;
  }
  .heute-strip-inner > span em {
    color: var(--accent-text);
    font-style: italic;
    font-weight: 500;
    border-bottom: 1px dashed var(--accent-text);
    padding-bottom: 1px;
  }
  .heute-strip-inner > span::after {
    content: "·";
    margin-left: 3rem;
    color: var(--accent-text);
  }
  @keyframes heute-marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
  }
  .heute-strip-label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.4rem;
    padding-inline: var(--gutter);
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--accent-text);
    font-weight: 600;
  }
  .heute-strip-label::before {
    content: ""; width: 0.4rem; height: 0.4rem; border-radius: 50%;
    background: var(--accent-text);
  }

  /* ─── Saison playing-card flip ─── */
  .saison-cards {
    display: grid; grid-template-columns: 1fr; gap: 1.25rem;
    margin-top: clamp(2rem, 4vw, 3rem);
  }
  @media (min-width: 600px) {
    .saison-cards { grid-template-columns: repeat(2, 1fr); }
  }
  @media (min-width: 1080px) {
    .saison-cards { grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
  }
  .saison-card-flip {
    perspective: 1400px;
    aspect-ratio: 5/7;
    cursor: pointer;
    background: transparent;
    border: 0;
    padding: 0;
    text-align: left;
    width: 100%;
    border-radius: 2px;
  }
  .saison-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.8s cubic-bezier(0.6, -0.05, 0.3, 1.05);
    transform-style: preserve-3d;
  }
  .saison-card-flip[aria-pressed="true"] .saison-card-inner,
  .saison-card-flip:hover .saison-card-inner,
  .saison-card-flip:focus-visible .saison-card-inner {
    transform: rotateY(180deg);
  }
  .saison-card-face {
    position: absolute;
    inset: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    border: 1px solid var(--hairline);
    background: var(--bg-secondary);
    display: flex; flex-direction: column;
    padding: 1.5rem 1.25rem;
    overflow: hidden;
  }
  .saison-card-front {
    background:
      linear-gradient(180deg, rgba(14,10,7,0.05) 0%, rgba(14,10,7,0.55) 100%),
      var(--bg-secondary);
    background-size: cover;
    background-position: center;
    color: var(--text-primary);
    justify-content: space-between;
  }
  .saison-card-front[data-bg]::before {
    content: "";
    position: absolute; inset: 0;
    background-image: var(--card-bg);
    background-size: cover;
    background-position: center;
    opacity: 0.78;
    z-index: 0;
    transition: opacity 0.6s var(--ease-out);
  }
  .saison-card-flip:hover .saison-card-front::before { opacity: 0.92; }
  .saison-card-front > * { position: relative; z-index: 1; }
  .saison-card-corner {
    position: absolute; top: 0.65rem;
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1rem;
    letter-spacing: 0.04em;
    z-index: 1;
  }
  .saison-card-corner.tl { left: 0.85rem; }
  .saison-card-corner.br { bottom: 0.65rem; right: 0.85rem; top: auto;
    transform: rotate(180deg); transform-origin: center; }
  .saison-card-suit {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: clamp(2.5rem, 5vw, 3.75rem);
    line-height: 1;
    margin-block: auto;
    text-align: center;
  }
  .saison-card-suit-sub {
    text-align: center;
    font-family: var(--font-body);
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--text-secondary);
    margin-top: 0.5rem;
  }
  .saison-card-back {
    transform: rotateY(180deg);
    background: var(--bg-tertiary);
    border-color: var(--accent);
    justify-content: flex-start;
    gap: 0.85rem;
  }
  .saison-card-back-eyebrow {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--accent-text);
    font-weight: 600;
  }
  .saison-card-back h3 {
    font-family: var(--font-display);
    font-size: 1.5rem;
    line-height: 1.15;
    color: var(--text-primary);
  }
  .saison-card-back h3 em { font-style: italic; color: var(--accent-text); }
  .saison-card-back p {
    font-size: var(--fs-small);
    color: var(--text-secondary);
    line-height: 1.55;
  }
  .saison-card-back .pairing {
    margin-top: auto;
    padding-top: 0.75rem;
    border-top: 1px solid var(--hairline);
    font-style: italic;
    font-family: var(--font-display);
    color: var(--accent-text);
    font-size: var(--fs-small);
  }

  .saison-cards-hint {
    margin-top: 0;
    margin-bottom: 1rem;
    font-size: var(--fs-small);
    color: var(--text-muted);
    font-style: italic;
    font-family: var(--font-display);
  }

  /* ─── Floating duck cutout / section divider ─── */
  .duck-divider {
    position: relative;
    height: 0;
    margin-top: clamp(-3rem, -4vw, -5rem);
    margin-bottom: clamp(1rem, 2vw, 2rem);
    pointer-events: none;
    z-index: 4;
  }
  .duck-cutout {
    position: absolute;
    right: clamp(1rem, 6vw, 5rem);
    top: -3rem;
    width: clamp(140px, 18vw, 240px);
    aspect-ratio: 1;
    border-radius: 50%;
    overflow: hidden;
    -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 50%, rgba(0,0,0,0.7) 70%, transparent 100%);
            mask-image: radial-gradient(circle at 50% 50%, #000 50%, rgba(0,0,0,0.7) 70%, transparent 100%);
    box-shadow: 0 30px 60px rgba(14, 10, 7, 0.55);
    transform: rotate(-6deg);
    transition: transform 1s var(--ease-out);
  }
  .duck-cutout img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
  }
  .duck-cutout-label {
    position: absolute;
    left: -3rem;
    bottom: 1.25rem;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.85rem;
    color: var(--text-secondary);
    background: rgba(14,10,7,0.7);
    padding: 0.25rem 0.5rem;
    border-left: 1px solid var(--accent);
    transform: rotate(6deg);
    pointer-events: auto;
  }
  .duck-cutout-label em { color: var(--accent-text); font-style: normal; }
  @media (max-width: 768px) {
    .duck-cutout { width: 110px; right: 1rem; top: -2rem; }
    .duck-cutout-label { left: -2rem; font-size: 0.72rem; }
  }

  .game-silhouette {
    display: block;
    width: 100%;
    max-width: 340px;
    margin: 0 auto;
    color: var(--accent);
    opacity: 0.55;
  }
  .game-silhouette-wrap {
    display: flex; align-items: center; justify-content: center;
    gap: 1.5rem;
    margin-block: clamp(1rem, 2vw, 2rem);
  }
  .game-silhouette-wrap::before,
  .game-silhouette-wrap::after {
    content: ""; flex: 1; height: 1px; background: var(--hairline); max-width: 220px;
  }

  /* ─── Sommelier oval-clipped portrait ─── */
  .sommelier .photo {
    border-radius: 60% / 50%;
    overflow: hidden;
    aspect-ratio: 4/5;
    border: 1px solid var(--hairline);
    box-shadow: 0 20px 50px rgba(14, 10, 7, 0.55);
    position: relative;
  }
  .sommelier .photo::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: 60% / 50%;
    border: 1px solid rgba(168, 54, 44, 0.35);
    pointer-events: none;
  }

  /* ─── Press monogram-marks for ratings ─── */
  .press-mono {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem; height: 2rem;
    border: 1px solid var(--accent);
    color: var(--accent-text);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.95rem;
    margin-bottom: 0.4rem;
    border-radius: 50%;
    background: rgba(168, 54, 44, 0.08);
  }
  .press-rating-row .press-rating { gap: 0.35rem; }

  /* ─── Reservierungs-Uhr (24h busy ring) ─── */
  .uhr-section {
    padding-block: clamp(4rem, 8vw, 7rem);
    background: var(--bg-secondary);
  }
  .uhr-grid {
    display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center;
  }
  @media (min-width: 768px) {
    .uhr-grid { grid-template-columns: 1fr 1.1fr; gap: 4rem; }
  }
  .uhr-text h2 { font-size: var(--fs-h1); line-height: 1.0; max-width: 16ch; margin-bottom: 1rem; }
  .uhr-text h2 em { font-style: italic; color: var(--accent-text); }
  .uhr-text p { color: var(--text-secondary); line-height: 1.65; max-width: 50ch; margin-bottom: 1rem; }
  .uhr-legend {
    display: flex; flex-wrap: wrap; gap: 1rem 1.5rem;
    margin-top: 1.5rem;
    font-size: var(--fs-small);
    color: var(--text-muted);
  }
  .uhr-legend span {
    display: inline-flex; align-items: center; gap: 0.5rem;
  }
  .uhr-legend span::before {
    content: ""; width: 0.65rem; height: 0.65rem; border-radius: 1px;
    background: var(--legend-color, var(--accent));
  }
  .uhr-svg-wrap {
    width: 100%; max-width: 460px; margin: 0 auto;
    aspect-ratio: 1;
    position: relative;
  }
  .uhr-svg { width: 100%; height: 100%; display: block; transform: rotate(-90deg); }
  .uhr-bar {
    fill: none;
    transition: stroke 0.3s var(--ease-out);
  }
  .uhr-bar.lvl-0 { stroke: rgba(255,241,221,0.06); }
  .uhr-bar.lvl-1 { stroke: rgba(168, 54, 44, 0.25); }
  .uhr-bar.lvl-2 { stroke: rgba(168, 54, 44, 0.55); }
  .uhr-bar.lvl-3 { stroke: var(--accent); }
  .uhr-bar.lvl-4 { stroke: var(--accent-hover); }
  .uhr-center {
    position: absolute;
    inset: 0;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center;
    pointer-events: none;
  }
  .uhr-center-time {
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(2rem, 4vw, 3rem);
    color: var(--accent-text);
    line-height: 1;
  }
  .uhr-center-meta {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--text-muted);
    margin-top: 0.4rem;
  }
  .uhr-tick {
    position: absolute;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.78rem;
    color: var(--text-muted);
    transform: translate(-50%, -50%);
  }
  .uhr-tick.t12 { top: 4%;  left: 50%; }
  .uhr-tick.t18 { top: 50%; left: 96%; }
  .uhr-tick.t00 { top: 96%; left: 50%; }
  .uhr-tick.t06 { top: 50%; left: 4%;  }

  /* ────────────────────────────────────────────────────────────
     Allergen + Diet Filter Bar (karte.html)
     Pure-CSS using radio/checkbox state + :has() + attribute selectors.
     No JS framework. Filtering is reversible by clicking same chip again.
     ──────────────────────────────────────────────────────────── */
  .filter-bar {
    position: sticky;
    top: 68px;
    z-index: 30;
    background: rgba(31, 24, 19, 0.92);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-block: 1px solid var(--hairline);
    margin-bottom: 2.5rem;
  }
  @media (max-width: 767px) {
    .filter-bar { top: 60px; }
  }
  .filter-bar-inner {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding-block: 1rem;
  }
  @media (min-width: 768px) {
    .filter-bar-inner { flex-direction: row; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
  }
  .filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  @media (min-width: 480px) {
    .filter-group { flex-direction: row; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
  }
  .filter-label {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--text-muted);
    font-weight: 500;
    flex-shrink: 0;
  }
  .filter-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
  }
  /* hide the actual inputs but keep them accessible */
  .filter-input {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
  }
  .filter-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.55rem 0.85rem;
    border: 1px solid var(--hairline);
    border-radius: 999px;
    font-family: var(--font-body);
    font-size: 0.78rem;
    color: var(--text-secondary);
    cursor: pointer;
    user-select: none;
    background: rgba(255, 241, 221, 0.03);
    transition: background var(--dur-fast) var(--ease-out),
                color var(--dur-fast) var(--ease-out),
                border-color var(--dur-fast) var(--ease-out);
    min-height: 36px;
    line-height: 1.1;
  }
  .filter-pill:hover { color: var(--text-primary); border-color: var(--text-muted); }
  .filter-input:focus-visible + .filter-pill { outline: 2px solid var(--accent-text); outline-offset: 3px; }
  .filter-input:checked + .filter-pill {
    background: var(--accent-text);
    color: var(--bg-primary);
    border-color: var(--accent-text);
    font-weight: 600;
  }
  .filter-pill svg {
    width: 14px; height: 14px;
    flex-shrink: 0;
  }
  .filter-reset {
    background: none; border: none;
    color: var(--text-muted);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    cursor: pointer;
    padding: 0.4rem 0.6rem;
    margin-left: auto;
    border-bottom: 1px solid transparent;
    transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
    min-height: 36px;
  }
  .filter-reset:hover { color: var(--text-primary); border-bottom-color: var(--accent-text); }

  /* Allergen icon strip per menu-item */
  .menu-item-allergens {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.4rem;
    flex-wrap: wrap;
  }
  .menu-item-allergens svg {
    width: 16px; height: 16px;
    color: var(--text-muted);
    opacity: 0.85;
    flex-shrink: 0;
  }
  .menu-item-allergens .badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.68rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
  }
  .menu-item-allergens .badge.is-positive { color: var(--accent-text); }
  .menu-item-allergens .badge.is-positive svg { color: var(--accent-text); opacity: 1; }

  /* Filter result hint */
  .filter-result-hint {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--text-muted);
    font-size: 0.95rem;
    margin-top: 0.4rem;
    display: none;
  }
  body:has(.diet-vegetarisch:checked, .diet-vegan:checked, .diet-glutenfrei:checked,
          .allergen-nuesse:checked, .allergen-lactose:checked, .allergen-eier:checked,
          .allergen-fisch:checked, .allergen-sellerie:checked, .allergen-senf:checked) .filter-result-hint {
    display: block;
  }

  /* ── Filtering logic via :has() on body level ── */
  /* Diet Mode: Vegetarisch — hide non-vegetarian */
  body:has(.diet-vegetarisch:checked) .menu-item:not([data-diet~="vegetarisch"]):not([data-diet~="vegan"]) {
    opacity: 0.18; filter: blur(1.5px); pointer-events: none;
  }
  /* Diet Mode: Vegan */
  body:has(.diet-vegan:checked) .menu-item:not([data-diet~="vegan"]) {
    opacity: 0.18; filter: blur(1.5px); pointer-events: none;
  }
  /* Diet Mode: Glutenfrei */
  body:has(.diet-glutenfrei:checked) .menu-item:not([data-diet~="glutenfrei"]) {
    opacity: 0.18; filter: blur(1.5px); pointer-events: none;
  }
  /* Allergen filters: hide items containing the allergen */
  body:has(.allergen-nuesse:checked)   .menu-item[data-allergens~="nuesse"]   { opacity: 0.18; filter: blur(1.5px); pointer-events: none; }
  body:has(.allergen-lactose:checked)  .menu-item[data-allergens~="lactose"]  { opacity: 0.18; filter: blur(1.5px); pointer-events: none; }
  body:has(.allergen-eier:checked)     .menu-item[data-allergens~="eier"]     { opacity: 0.18; filter: blur(1.5px); pointer-events: none; }
  body:has(.allergen-fisch:checked)    .menu-item[data-allergens~="fisch"]    { opacity: 0.18; filter: blur(1.5px); pointer-events: none; }
  body:has(.allergen-sellerie:checked) .menu-item[data-allergens~="sellerie"] { opacity: 0.18; filter: blur(1.5px); pointer-events: none; }
  body:has(.allergen-senf:checked)     .menu-item[data-allergens~="senf"]     { opacity: 0.18; filter: blur(1.5px); pointer-events: none; }
  .menu-item { transition: opacity 0.4s var(--ease-out), filter 0.4s var(--ease-out); }

  /* ────────────────────────────────────────────────────────────
     Chef's Tasting-Menü Walkthrough (karte.html)
     6 Gänge editorial, vertical scroll-snap, each fills viewport.
     ──────────────────────────────────────────────────────────── */
  .tasting {
    background: var(--bg-tertiary);
    border-block: 1px solid var(--hairline);
    padding-block: 0;
  }
  .tasting-intro {
    padding-block: clamp(4rem, 8vw, 6rem);
    text-align: center;
    border-bottom: 1px solid var(--hairline);
  }
  .tasting-intro h2 {
    font-size: clamp(2rem, 5vw, 3.5rem);
    max-width: 22ch;
    margin: 0.75rem auto 1rem;
    line-height: 1.05;
  }
  .tasting-intro h2 em { font-style: italic; color: var(--accent-text); }
  .tasting-intro .lead {
    color: var(--text-secondary);
    font-size: var(--fs-body-lg);
    max-width: 56ch;
    margin: 0 auto;
  }
  .tasting-intro .menu-meta {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem 2rem;
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--hairline);
  }
  .tasting-intro .menu-meta span {
    font-family: var(--font-body);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--text-muted);
  }
  .tasting-intro .menu-meta em {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1rem;
    color: var(--accent-text);
    text-transform: none;
    letter-spacing: 0;
    margin-left: 0.4rem;
  }

  .tasting-track {
    /* vertical scroll-snap container — each gang fills the viewport */
    scroll-snap-type: y mandatory;
  }
  .tasting-gang {
    scroll-snap-align: start;
    scroll-snap-stop: always;
    min-height: 100vh;
    min-height: 100svh;
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    padding-block: clamp(3rem, 8vw, 6rem);
    border-bottom: 1px solid var(--hairline);
    position: relative;
  }
  @media (min-width: 900px) {
    .tasting-gang { grid-template-columns: 1fr 1.05fr; gap: clamp(2rem, 6vw, 5rem); }
    .tasting-gang.is-flipped { grid-template-columns: 1.05fr 1fr; }
    .tasting-gang.is-flipped .tasting-photo { order: 2; }
    .tasting-gang.is-flipped .tasting-text { order: 1; }
  }
  .tasting-photo {
    position: relative;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: var(--bg-secondary);
  }
  .tasting-photo img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: brightness(0.96) contrast(1.04);
    transition: transform 1.2s var(--ease-out);
  }
  .tasting-gang:hover .tasting-photo img { transform: scale(1.03); }
  .tasting-photo .gang-num {
    position: absolute;
    top: 1.25rem; left: 1.25rem;
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(3rem, 8vw, 5.5rem);
    line-height: 0.9;
    color: var(--text-primary);
    mix-blend-mode: difference;
    opacity: 0.95;
    pointer-events: none;
  }
  .tasting-photo .gang-num small {
    display: block;
    font-family: var(--font-body);
    font-style: normal;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.25em;
    margin-top: 0.4rem;
    opacity: 0.8;
  }
  .tasting-text {
    padding-inline: var(--gutter);
    max-width: 52ch;
  }
  .tasting-text .gang-eyebrow {
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.25em;
    color: var(--accent-text);
    font-weight: 500;
  }
  .tasting-text h3 {
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    line-height: 1.05;
    margin: 0.75rem 0 1.25rem;
    font-weight: 500;
  }
  .tasting-text h3 em { font-style: italic; color: var(--accent-text); font-weight: 400; }
  .tasting-text .gang-story {
    color: var(--text-secondary);
    font-size: var(--fs-body-lg);
    line-height: 1.65;
    max-width: 44ch;
  }
  .tasting-text .gang-story + .gang-story { margin-top: 0.85rem; }
  .pairing-card {
    margin-top: 2rem;
    padding: 1.25rem 1.5rem;
    border-left: 2px solid var(--accent-text);
    background: linear-gradient(90deg, rgba(224, 117, 96, 0.08), transparent);
  }
  .pairing-card .pairing-eyebrow {
    font-family: 'Crimson Pro', Georgia, serif;
    font-style: italic;
    font-weight: 500;
    font-size: 1.15rem;
    color: var(--accent-text);
    line-height: 1;
    display: block;
    margin-bottom: 0.4rem;
    transform: rotate(-1.5deg);
  }
  .pairing-card .pairing-wine {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.15rem;
    color: var(--text-primary);
    line-height: 1.3;
    display: block;
  }
  .pairing-card .pairing-note {
    font-family: 'Crimson Pro', Georgia, serif;
    font-style: italic;
    font-size: 1.05rem;
    color: var(--text-secondary);
    line-height: 1.35;
    margin-top: 0.5rem;
    display: block;
  }
  .tasting-progress {
    position: sticky;
    bottom: 1rem;
    pointer-events: none;
    display: flex;
    justify-content: center;
    margin-top: -3rem;
    z-index: 5;
  }
  .tasting-progress-inner {
    display: inline-flex;
    gap: 0.4rem;
    padding: 0.6rem 1rem;
    background: rgba(14, 10, 7, 0.85);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 999px;
    border: 1px solid var(--hairline);
  }
  .tasting-progress-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: rgba(255, 241, 221, 0.25);
    transition: background var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
  }
  .tasting-progress-dot.is-active {
    background: var(--accent-text);
    transform: scale(1.3);
  }

  /* ────────────────────────────────────────────────────────────
     Smart-Booking Flow (reservierung.html)
     Pure-CSS step routing via radio + :has() — no JS framework.
     5 Steps: Anlass → Personen → Datum/Uhrzeit → Wünsche → Kontakt
     Conditional sub-questions per Anlass.
     ──────────────────────────────────────────────────────────── */

  .smart-booking {
    padding-block: clamp(2rem, 5vw, 4rem);
    background: var(--bg-tertiary);
    border-top: 1px solid var(--hairline);
    border-bottom: 1px solid var(--hairline);
  }
  .smart-booking-inner {
    background: var(--bg-secondary);
    padding: clamp(2rem, 4vw, 3.5rem);
    position: relative;
    border-left: 3px solid var(--accent);
    max-width: 960px;
    margin-inline: auto;
  }
  .smart-booking-inner::before {
    content: "Reservierung";
    display: block;
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: clamp(1.875rem, 4vw, 2.75rem);
    line-height: 1;
    margin-bottom: 0.375rem;
    letter-spacing: -0.01em;
  }
  .smart-booking-inner > .smart-booking-sub {
    color: var(--text-muted);
    font-size: var(--fs-small);
    margin-bottom: 2.25rem;
    font-style: italic;
    font-family: var(--font-display);
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--hairline);
  }

  /* Step indicator */
  .step-bar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--hairline);
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .step-bar::-webkit-scrollbar { display: none; }
  .step-bar-item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-muted);
    transition: color var(--dur-fast);
  }
  .step-bar-num {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 1.6rem; height: 1.6rem;
    border: 1px solid var(--hairline);
    border-radius: 50%;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.85rem;
    color: var(--text-muted);
    background: rgba(14,10,7,0.4);
    transition: border-color var(--dur-fast), color var(--dur-fast), background var(--dur-fast);
  }
  .step-bar-divider {
    flex: 1; height: 1px; min-width: 0.75rem; max-width: 2.5rem;
    background: var(--hairline);
  }

  /* Step bar colors based on currently selected step (via :has()) */
  body:has(#step-1:checked) .step-bar-item[data-for="1"] .step-bar-num,
  body:has(#step-2:checked) .step-bar-item[data-for="1"] .step-bar-num,
  body:has(#step-2:checked) .step-bar-item[data-for="2"] .step-bar-num,
  body:has(#step-3:checked) .step-bar-item[data-for="1"] .step-bar-num,
  body:has(#step-3:checked) .step-bar-item[data-for="2"] .step-bar-num,
  body:has(#step-3:checked) .step-bar-item[data-for="3"] .step-bar-num,
  body:has(#step-4:checked) .step-bar-item[data-for="1"] .step-bar-num,
  body:has(#step-4:checked) .step-bar-item[data-for="2"] .step-bar-num,
  body:has(#step-4:checked) .step-bar-item[data-for="3"] .step-bar-num,
  body:has(#step-4:checked) .step-bar-item[data-for="4"] .step-bar-num,
  body:has(#step-5:checked) .step-bar-item[data-for="1"] .step-bar-num,
  body:has(#step-5:checked) .step-bar-item[data-for="2"] .step-bar-num,
  body:has(#step-5:checked) .step-bar-item[data-for="3"] .step-bar-num,
  body:has(#step-5:checked) .step-bar-item[data-for="4"] .step-bar-num,
  body:has(#step-5:checked) .step-bar-item[data-for="5"] .step-bar-num {
    border-color: var(--accent-text);
    color: var(--accent-text);
    background: rgba(224, 117, 96, 0.08);
  }
  body:has(#step-1:checked) .step-bar-item[data-for="1"],
  body:has(#step-2:checked) .step-bar-item[data-for="2"],
  body:has(#step-3:checked) .step-bar-item[data-for="3"],
  body:has(#step-4:checked) .step-bar-item[data-for="4"],
  body:has(#step-5:checked) .step-bar-item[data-for="5"] {
    color: var(--text-primary);
  }

  /* Hide all step inputs */
  .step-input {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0; margin: -1px;
  }

  /* Steps panels — only show when corresponding radio is checked */
  .step-panel { display: none; animation: tab-in 0.45s var(--ease-out) both; }
  body:has(#step-1:checked) .step-panel[data-step="1"],
  body:has(#step-2:checked) .step-panel[data-step="2"],
  body:has(#step-3:checked) .step-panel[data-step="3"],
  body:has(#step-4:checked) .step-panel[data-step="4"],
  body:has(#step-5:checked) .step-panel[data-step="5"] {
    display: block;
  }

  .step-panel-title {
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(1.5rem, 3vw, 2rem);
    line-height: 1.1;
    margin-bottom: 0.5rem;
    max-width: 22ch;
  }
  .step-panel-title em { font-style: italic; color: var(--accent-text); }
  .step-panel-lead {
    color: var(--text-secondary);
    font-size: var(--fs-body);
    line-height: 1.55;
    margin-bottom: 1.75rem;
    max-width: 50ch;
  }

  /* Step navigation buttons */
  .step-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--hairline);
  }
  .step-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.875rem 1.5rem;
    font-family: var(--font-body);
    font-size: var(--fs-small);
    font-weight: 500;
    border-radius: 2px;
    cursor: pointer;
    background: var(--accent);
    color: var(--text-primary);
    transition: background var(--dur-fast);
    min-height: 48px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border: 0;
  }
  .step-btn:hover { background: var(--accent-hover); }
  .step-btn.is-back {
    background: transparent;
    color: var(--text-secondary);
    border: 1px solid var(--hairline);
  }
  .step-btn.is-back:hover { color: var(--text-primary); border-color: var(--text-muted); }
  .step-btn.is-submit {
    margin-left: auto;
    background: var(--accent);
    font-weight: 600;
  }

  /* Selectable Cards (Anlass) */
  .anlass-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }
  @media (min-width: 600px) { .anlass-grid { grid-template-columns: repeat(3, 1fr); } }
  @media (min-width: 768px) { .anlass-grid { grid-template-columns: repeat(5, 1fr); gap: 0.85rem; } }

  .anlass-input {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden; clip: rect(0,0,0,0);
  }
  .anlass-card {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 1.375rem 1.125rem 1.25rem;
    border: 1px solid var(--hairline);
    border-top: 2px solid transparent;
    background: rgba(14,10,7,0.45);
    cursor: pointer;
    transition: border-color var(--dur-fast), background var(--dur-fast), transform var(--dur-base);
    min-height: 140px;
    text-align: left;
  }
  .anlass-card:hover {
    border-color: var(--text-muted);
    border-top-color: var(--text-muted);
    transform: translateY(-3px);
    background: rgba(14,10,7,0.55);
  }
  .anlass-input:focus-visible + .anlass-card { outline: 2px solid var(--accent-text); outline-offset: 3px; }
  .anlass-input:checked + .anlass-card {
    border-color: var(--accent);
    border-top-color: var(--accent-text);
    background: rgba(168, 54, 44, 0.1);
  }
  .anlass-card-icon {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.5rem;
    line-height: 1;
  }
  .anlass-card-name {
    font-family: var(--font-display);
    font-size: 1.125rem;
    line-height: 1.2;
    color: var(--text-primary);
  }
  .anlass-card-name em { color: var(--accent-text); font-style: italic; }
  .anlass-card-desc {
    font-size: 0.78rem;
    color: var(--text-muted);
    line-height: 1.45;
    margin-top: auto;
    text-transform: none;
    letter-spacing: 0;
  }

  /* Conditional sub-questions per Anlass — show only when matching radio checked */
  .anlass-sub {
    margin-top: 1.5rem;
    padding: 1.25rem 1.5rem;
    border-left: 2px solid var(--accent-text);
    background: linear-gradient(90deg, rgba(224, 117, 96, 0.08), transparent);
    display: none;
  }
  body:has(.anlass-input[value="geburtstag"]:checked) .anlass-sub[data-sub="geburtstag"],
  body:has(.anlass-input[value="jahrestag"]:checked)  .anlass-sub[data-sub="jahrestag"],
  body:has(.anlass-input[value="business"]:checked)   .anlass-sub[data-sub="business"],
  body:has(.anlass-input[value="familie"]:checked)    .anlass-sub[data-sub="familie"],
  body:has(.anlass-input[value="spontan"]:checked)    .anlass-sub[data-sub="spontan"] {
    display: block;
  }
  .anlass-sub-eyebrow {
    font-family: 'Caveat', cursive;
    font-size: 1.125rem;
    color: var(--accent-text);
    transform: rotate(-1.5deg);
    display: inline-block;
    margin-bottom: 0.4rem;
  }
  .anlass-sub-question {
    font-family: var(--font-display);
    font-size: 1.125rem;
    line-height: 1.3;
    margin-bottom: 0.85rem;
    max-width: 40ch;
  }
  .anlass-sub-question em { font-style: italic; color: var(--accent-text); }
  .anlass-sub-options {
    display: flex; flex-wrap: wrap;
    gap: 0.5rem;
  }
  .sub-pill-input {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden; clip: rect(0,0,0,0);
  }
  .sub-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.55rem 0.95rem;
    border: 1px solid var(--hairline);
    background: rgba(14,10,7,0.3);
    border-radius: 999px;
    font-size: 0.78rem;
    color: var(--text-secondary);
    cursor: pointer;
    transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast);
    min-height: 36px;
  }
  .sub-pill:hover { color: var(--text-primary); border-color: var(--text-muted); }
  .sub-pill-input:checked + .sub-pill {
    background: var(--accent-text);
    color: var(--bg-primary);
    border-color: var(--accent-text);
    font-weight: 600;
  }
  .sub-pill-input:focus-visible + .sub-pill { outline: 2px solid var(--accent-text); outline-offset: 3px; }

  /* Personen-Pills */
  .pers-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.55rem;
  }
  @media (min-width: 600px) {
    .pers-grid { grid-template-columns: repeat(6, 1fr); }
  }
  @media (min-width: 768px) {
    .pers-grid { grid-template-columns: repeat(12, 1fr); }
  }
  .pers-input {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden; clip: rect(0,0,0,0);
  }
  .pers-pill {
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1;
    border: 1px solid var(--hairline);
    background: rgba(14,10,7,0.3);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.5rem;
    color: var(--text-primary);
    cursor: pointer;
    transition: border-color var(--dur-fast), background var(--dur-fast), transform var(--dur-fast);
    min-height: 56px;
  }
  .pers-pill:hover { border-color: var(--text-muted); transform: scale(1.04); }
  .pers-input:checked + .pers-pill {
    border-color: var(--accent-text);
    background: rgba(224, 117, 96, 0.12);
    color: var(--accent-text);
  }
  .pers-input:focus-visible + .pers-pill { outline: 2px solid var(--accent-text); outline-offset: 3px; }

  /* Privat-Bereich-Hinweis bei >8 Personen */
  .pers-large-hint {
    margin-top: 1.25rem;
    padding: 1rem 1.25rem;
    border-left: 2px solid var(--accent-text);
    background: linear-gradient(90deg, rgba(224, 117, 96, 0.08), transparent);
    font-size: var(--fs-small);
    color: var(--text-secondary);
    line-height: 1.55;
    display: none;
  }
  body:has(.pers-input[value="9"]:checked) .pers-large-hint,
  body:has(.pers-input[value="10"]:checked) .pers-large-hint,
  body:has(.pers-input[value="11"]:checked) .pers-large-hint,
  body:has(.pers-input[value="12"]:checked) .pers-large-hint {
    display: block;
  }
  .pers-large-hint strong {
    display: block;
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1rem;
    margin-bottom: 0.25rem;
  }

  /* Datum + Uhrzeit Step */
  .datum-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-bottom: 2rem;
  }
  @media (min-width: 600px) { .datum-row { grid-template-columns: 1fr 1.5fr; } }
  .datum-label {
    display: block;
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--text-muted);
    margin-bottom: 0.5rem;
    font-weight: 500;
  }
  .datum-input {
    width: 100%;
    background: rgba(14,10,7,0.45);
    color: var(--text-primary);
    border: 0;
    border-bottom: 2px solid var(--hairline);
    padding: 0.75rem 0.5rem;
    font-size: var(--fs-body-lg);
    font-family: var(--font-body);
    color-scheme: dark;
  }
  .datum-input:focus { outline: 0; border-color: var(--accent-text); }
  /* Date-picker Chrome dark styling */
  .datum-input::-webkit-calendar-picker-indicator {
    filter: invert(0.8) sepia(1) hue-rotate(-25deg);
    cursor: pointer;
    opacity: 0.7;
  }
  .datum-input::-webkit-calendar-picker-indicator:hover { opacity: 1; }

  .uhrzeit-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.55rem;
  }
  @media (min-width: 768px) { .uhrzeit-grid { grid-template-columns: repeat(6, 1fr); gap: 0.75rem; } }
  @media (min-width: 1200px) { .uhrzeit-grid { grid-template-columns: repeat(6, minmax(7.5rem, 1fr)); gap: 1rem; } }
  .uhrzeit-input {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden; clip: rect(0,0,0,0);
  }
  .uhrzeit-pill {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 1rem 0.75rem;
    border: 1px solid var(--hairline);
    border-top: 2px solid transparent;
    background: rgba(14,10,7,0.3);
    cursor: pointer;
    text-align: center;
    transition: border-color var(--dur-fast), background var(--dur-fast);
    min-height: 72px;
  }
  .uhrzeit-pill:hover { border-color: var(--text-muted); }
  .uhrzeit-input:checked + .uhrzeit-pill {
    border-color: var(--accent-text);
    background: rgba(224, 117, 96, 0.1);
  }
  .uhrzeit-input:focus-visible + .uhrzeit-pill { outline: 2px solid var(--accent-text); outline-offset: 3px; }
  .uhrzeit-pill-time {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.25rem;
    color: var(--text-primary);
    line-height: 1;
  }
  .uhrzeit-input:checked + .uhrzeit-pill .uhrzeit-pill-time { color: var(--accent-text); }
  .uhrzeit-pill-avail {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-muted);
    line-height: 1.2;
  }
  .uhrzeit-pill-avail.is-low { color: #d6885a; }
  .uhrzeit-pill-avail.is-full { color: #c25a4a; opacity: 0.85; }
  .uhrzeit-input:disabled + .uhrzeit-pill {
    opacity: 0.4;
    cursor: not-allowed;
  }

  /* Sonderwünsche + Allergen-Vorab Step */
  .wuensche-textarea {
    width: 100%;
    background: rgba(14,10,7,0.3);
    color: var(--text-primary);
    border: 1px solid var(--hairline);
    padding: 0.875rem 1rem;
    font-size: var(--fs-body);
    font-family: var(--font-body);
    line-height: 1.5;
    min-height: 120px;
    resize: vertical;
    transition: border-color var(--dur-fast);
  }
  .wuensche-textarea:focus { outline: 0; border-color: var(--accent-text); }
  .allergen-pre-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.55rem;
    margin-top: 1rem;
  }
  @media (min-width: 600px) { .allergen-pre-list { grid-template-columns: repeat(3, 1fr); } }
  @media (min-width: 768px) { .allergen-pre-list { grid-template-columns: repeat(4, 1fr); } }
  .allergen-pre-input {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden; clip: rect(0,0,0,0);
  }
  .allergen-pre-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.55rem 0.85rem;
    border: 1px solid var(--hairline);
    background: rgba(14,10,7,0.3);
    cursor: pointer;
    font-size: 0.78rem;
    color: var(--text-secondary);
    transition: border-color var(--dur-fast), background var(--dur-fast), color var(--dur-fast);
    min-height: 38px;
  }
  .allergen-pre-pill:hover { color: var(--text-primary); border-color: var(--text-muted); }
  .allergen-pre-input:checked + .allergen-pre-pill {
    border-color: var(--accent-text);
    background: rgba(224, 117, 96, 0.12);
    color: var(--accent-text);
    font-weight: 500;
  }
  .allergen-pre-input:focus-visible + .allergen-pre-pill { outline: 2px solid var(--accent-text); outline-offset: 3px; }

  /* Kontakt Step */
  .kontakt-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  @media (min-width: 600px) { .kontakt-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem 1.25rem; } }
  .kontakt-row label {
    display: block;
    font-size: var(--fs-eyebrow);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--text-muted);
    margin-bottom: 0.6rem;
    font-weight: 500;
  }
  .kontakt-row input {
    width: 100%;
    background: rgba(14,10,7,0.35);
    color: var(--text-primary);
    border: 0;
    border-bottom: 2px solid var(--hairline);
    padding: 0.875rem 0.5rem;
    font-size: var(--fs-body-lg);
    transition: border-color var(--dur-fast), background var(--dur-fast);
  }
  .kontakt-row input:focus { outline: 0; border-color: var(--accent-text); background: rgba(168,54,44,0.05); }
  .kontakt-row input::placeholder { color: var(--text-muted); opacity: 0.65; }
  .kontakt-row.full { grid-column: 1 / -1; }

  /* Reservierungs-Übersicht (final) */
  .booking-summary {
    margin: 1.5rem 0;
    padding: 1.5rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--hairline);
    border-left: 2px solid var(--accent-text);
  }
  .booking-summary-eyebrow {
    font-family: 'Caveat', cursive;
    color: var(--accent-text);
    font-size: 1.15rem;
    transform: rotate(-1deg);
    display: inline-block;
    margin-bottom: 0.5rem;
  }
  .booking-summary dl {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem 1.25rem;
  }
  @media (min-width: 600px) { .booking-summary dl { grid-template-columns: auto 1fr; } }
  .booking-summary dt {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--text-muted);
    padding-top: 0.45rem;
    border-top: 1px solid var(--hairline);
  }
  .booking-summary dt:first-of-type { border-top: 0; padding-top: 0; }
  @media (min-width: 600px) {
    .booking-summary dl > dt + dd { border-top: 1px solid var(--hairline); padding-top: 0.45rem; margin-top: 0; }
    .booking-summary dl > dt:first-of-type + dd { border-top: 0; padding-top: 0; }
  }
  .booking-summary dd {
    font-family: var(--font-display);
    font-size: 1.05rem;
    color: var(--text-primary);
    line-height: 1.4;
  }
  .booking-summary dd em { font-style: italic; color: var(--accent-text); }

  .direct-contact-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.85rem;
    margin-top: 1.5rem;
  }
  @media (min-width: 600px) { .direct-contact-row { grid-template-columns: repeat(2, 1fr); } }
  .direct-contact-card {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    padding: 1.25rem 1.4rem;
    border: 1px solid var(--hairline);
    background: rgba(14,10,7,0.3);
    transition: border-color var(--dur-fast), background var(--dur-fast);
  }
  .direct-contact-card:hover {
    border-color: var(--accent-text);
    background: rgba(224, 117, 96, 0.07);
  }
  .direct-contact-card-eyebrow {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--accent-text);
    font-weight: 600;
  }
  .direct-contact-card-value {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.25rem;
    color: var(--text-primary);
    line-height: 1.2;
  }
  .direct-contact-card-meta {
    font-size: var(--fs-small);
    color: var(--text-muted);
    line-height: 1.4;
  }

  /* "oder" divider */
  .oder-divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 2rem 0 1.25rem;
    color: var(--text-muted);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1rem;
  }
  .oder-divider::before, .oder-divider::after {
    content: ""; flex: 1; height: 1px; background: var(--hairline);
  }

  /* ────────────────────────────────────────────────────────────
     Ueber-Depth (ueber.html) — narrative Familie-Brandt-Geschichte
     4 Generations, Manifest, Forsthaus-Geschichte, Werte, Kollegen
     ──────────────────────────────────────────────────────────── */

  /* Generation Block */
  .gen-block {
    padding-block: clamp(4rem, 8vw, 7rem);
    border-bottom: 1px solid var(--hairline);
  }
  .gen-block:nth-of-type(even) {
    background: var(--bg-secondary);
  }
  .gen-block:nth-of-type(even) .gen-quote {
    border-color: var(--accent-text);
  }
  .gen-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    align-items: start;
  }
  @media (min-width: 900px) {
    .gen-grid { grid-template-columns: 0.85fr 1.3fr; gap: clamp(3rem, 6vw, 5rem); }
    .gen-block.is-flipped .gen-grid > .gen-photo { order: 2; }
    .gen-block.is-flipped .gen-grid > .gen-text { order: 1; }
  }
  .gen-photo {
    position: relative;
    aspect-ratio: 4/5;
    overflow: hidden;
    background: var(--bg-tertiary);
  }
  .gen-photo img {
    width: 100%; height: 100%;
    object-fit: cover;
    filter: sepia(0.18) contrast(1.05) brightness(0.95);
  }
  .gen-photo-meta {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 0.85rem 1rem;
    background: linear-gradient(180deg, transparent, rgba(14,10,7,0.85));
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 0.75rem;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.85rem;
    color: var(--text-secondary);
  }
  .gen-photo-meta em {
    font-style: italic; color: var(--accent-text); font-size: 0.95rem;
  }
  .gen-text {
    display: flex; flex-direction: column;
    gap: 1.25rem;
  }
  .gen-year-label {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: clamp(2.5rem, 5vw, 3.75rem);
    line-height: 0.95;
    letter-spacing: -0.01em;
  }
  .gen-year-label small {
    display: block;
    font-family: var(--font-body);
    font-style: normal;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--text-muted);
    margin-top: 0.4rem;
    font-weight: 500;
  }
  .gen-text h2 {
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    line-height: 1.05;
    max-width: 18ch;
  }
  .gen-text h2 em { font-style: italic; color: var(--accent-text); }
  .gen-story {
    color: var(--text-secondary);
    line-height: 1.7;
    font-size: var(--fs-body-lg);
    max-width: 56ch;
  }
  .gen-story em { color: var(--accent-text); font-style: italic; }
  .gen-story + .gen-story { margin-top: 0.5rem; }
  .gen-quote {
    margin-top: 0.5rem;
    padding: 1rem 1.4rem;
    border-left: 2px solid var(--accent);
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(1.15rem, 2vw, 1.4rem);
    line-height: 1.4;
    color: var(--text-primary);
    max-width: 36ch;
    background: linear-gradient(90deg, rgba(224, 117, 96, 0.06), transparent);
  }
  .gen-quote-source {
    display: block;
    font-family: var(--font-body);
    font-style: normal;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--text-muted);
    margin-top: 0.65rem;
  }
  .gen-signature {
    display: inline-grid;
    grid-template-columns: auto 1fr;
    gap: 0.6rem 1rem;
    align-items: center;
    margin-top: 0.75rem;
    padding: 0.75rem 1rem;
    background: rgba(14,10,7,0.4);
    border: 1px solid var(--hairline);
    border-radius: 2px;
    max-width: 30rem;
  }
  .gen-signature-label {
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--text-muted);
    font-family: var(--font-body);
  }
  .gen-signature-dish {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.05rem;
    color: var(--accent-text);
    line-height: 1.25;
  }

  /* Wild Manifest */
  .wild-manifest {
    padding-block: clamp(5rem, 10vw, 8rem);
    background: var(--bg-tertiary);
    border-block: 1px solid var(--accent);
    position: relative;
    overflow: hidden;
  }
  .wild-manifest::before {
    content: "Wild";
    position: absolute;
    top: -2rem;
    right: -1rem;
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(8rem, 22vw, 18rem);
    line-height: 1;
    color: rgba(224, 117, 96, 0.04);
    pointer-events: none;
    z-index: 0;
  }
  .wild-manifest > * { position: relative; z-index: 1; }
  .wild-manifest-eyebrow {
    font-family: var(--font-body);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.25em;
    color: var(--accent-text);
    font-weight: 500;
    margin-bottom: 1rem;
  }
  .wild-manifest h2 {
    font-size: clamp(2.25rem, 5vw, 3.5rem);
    line-height: 1.0;
    max-width: 16ch;
    margin-bottom: 2rem;
  }
  .wild-manifest h2 em { font-style: italic; color: var(--accent-text); }
  .wild-manifest-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  @media (min-width: 768px) {
    .wild-manifest-grid { grid-template-columns: 1.1fr 1fr; gap: 4rem; }
  }
  .wild-manifest-text p {
    color: var(--text-secondary);
    line-height: 1.75;
    font-size: var(--fs-body-lg);
    margin-bottom: 1.1rem;
    max-width: 56ch;
  }
  .wild-manifest-text p em {
    color: var(--accent-text);
    font-style: italic;
  }
  .wild-manifest-text p strong {
    color: var(--text-primary);
    font-weight: 600;
    font-style: normal;
  }
  .wild-manifest-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
    align-content: start;
  }
  .wild-stat {
    display: flex; flex-direction: column;
    gap: 0.4rem;
    padding: 1.25rem 1rem;
    border: 1px solid var(--hairline);
    border-top: 2px solid var(--accent);
    background: rgba(14,10,7,0.45);
  }
  .wild-stat-num {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: clamp(2rem, 4vw, 2.75rem);
    line-height: 0.95;
  }
  .wild-stat-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--text-muted);
    line-height: 1.4;
  }

  /* Forsthaus-Geschichte (Building Timeline) */
  .haus-history {
    padding-block: clamp(4rem, 8vw, 7rem);
  }
  .haus-history-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    margin-top: clamp(2rem, 4vw, 3rem);
  }
  @media (min-width: 768px) { .haus-history-grid { grid-template-columns: 0.9fr 1.4fr; gap: 4rem; } }
  .haus-history-photo {
    aspect-ratio: 4/5;
    overflow: hidden;
    background: var(--bg-tertiary);
    position: relative;
  }
  .haus-history-photo img {
    width: 100%; height: 100%; object-fit: cover;
    filter: sepia(0.32) contrast(1.05) brightness(0.92);
  }
  .haus-history-photo::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(31,24,19,0.1), rgba(31,24,19,0.55));
    pointer-events: none;
  }
  .haus-timeline {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0;
    column-gap: 2rem;
  }
  .haus-timeline-year {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.5rem;
    line-height: 1;
    padding-block: 1.25rem 0;
    border-top: 1px solid var(--accent);
    grid-column: 1;
    align-self: start;
    min-width: 4.5rem;
  }
  .haus-timeline-event {
    padding-block: 1.25rem 1.5rem;
    border-top: 1px solid var(--hairline);
    grid-column: 2;
  }
  .haus-timeline-event h4 {
    font-family: var(--font-display);
    font-size: 1.25rem;
    line-height: 1.2;
    margin-bottom: 0.4rem;
  }
  .haus-timeline-event h4 em { font-style: italic; color: var(--accent-text); }
  .haus-timeline-event p {
    font-size: var(--fs-small);
    color: var(--text-secondary);
    line-height: 1.65;
    max-width: 50ch;
  }

  /* Werte-Manifest (5 Statements) */
  .werte-manifest {
    padding-block: clamp(4rem, 8vw, 7rem);
    background: var(--bg-secondary);
  }
  .werte-statements {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: clamp(2rem, 4vw, 3rem);
    border-top: 1px solid var(--hairline);
  }
  .werte-statement {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
    padding-block: 1.75rem;
    border-bottom: 1px solid var(--hairline);
  }
  @media (min-width: 768px) {
    .werte-statement {
      grid-template-columns: 4rem 1fr 1.4fr;
      gap: 2rem;
      align-items: baseline;
    }
  }
  .werte-statement-num {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: clamp(1.5rem, 2.4vw, 2rem);
    line-height: 1;
  }
  .werte-statement-claim {
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 2.4vw, 1.625rem);
    line-height: 1.2;
    color: var(--text-primary);
    max-width: 24ch;
  }
  .werte-statement-claim em { font-style: italic; color: var(--accent-text); }
  .werte-statement-explain {
    font-size: var(--fs-body);
    color: var(--text-secondary);
    line-height: 1.65;
    max-width: 56ch;
  }
  .werte-statement-explain em { color: var(--accent-text); font-style: italic; }

  /* Kollegen-Strip */
  .kollegen {
    padding-block: clamp(4rem, 8vw, 7rem);
  }
  .kollegen-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    margin-top: clamp(2rem, 4vw, 3rem);
  }
  @media (min-width: 600px) { .kollegen-grid { grid-template-columns: repeat(2, 1fr); gap: 2.5rem; } }
  @media (min-width: 1080px) { .kollegen-grid { grid-template-columns: repeat(4, 1fr); gap: 2rem; } }
  .kollege {
    display: flex; flex-direction: column;
    gap: 1rem;
  }
  .kollege-photo {
    aspect-ratio: 4/5;
    overflow: hidden;
    background: var(--bg-secondary);
    position: relative;
  }
  .kollege-photo img {
    width: 100%; height: 100%; object-fit: cover;
    filter: brightness(0.94) contrast(1.05);
    transition: transform 1.2s var(--ease-out);
  }
  .kollege:hover .kollege-photo img { transform: scale(1.04); }
  .kollege-photo-tag {
    position: absolute;
    top: 0.85rem; left: 0.85rem;
    padding: 0.3rem 0.6rem;
    background: rgba(14,10,7,0.7);
    backdrop-filter: blur(4px);
    border-left: 1px solid var(--accent-text);
    font-family: var(--font-body);
    font-size: 0.66rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--accent-text);
    font-weight: 600;
  }
  .kollege h3 {
    font-family: var(--font-display);
    font-size: 1.375rem;
    line-height: 1.15;
  }
  .kollege h3 em { font-style: italic; color: var(--accent-text); }
  .kollege-role {
    font-family: var(--font-body);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--text-muted);
    margin-top: -0.4rem;
  }
  .kollege-bio {
    font-size: var(--fs-small);
    color: var(--text-secondary);
    line-height: 1.6;
  }
  .kollege-bio em { color: var(--accent-text); font-style: italic; }

  /* ================================================================
     ROUND 4 — MAGAZINE-EDITORIAL POLISH
     ================================================================ */

  /* ─── Hero Round 4: Asymmetric breathing, fade-in stagger, wavy underline ─── */
  @keyframes hero-breathe-a {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.012); }
  }
  @keyframes hero-breathe-b {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(0.992); }
  }
  @keyframes hero-breathe-c {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.008); }
  }
  @keyframes hero-tile-in {
    from { opacity: 0; filter: blur(10px); transform: translateY(14px); }
    to   { opacity: 1; filter: blur(0);    transform: translateY(0); }
  }
  .hero-grid .photo-1 { animation: hero-tile-in 1.1s var(--ease-out) 0s both, hero-breathe-a 8.4s ease-in-out 1.6s infinite; }
  .hero-grid .photo-2 { animation: hero-tile-in 1.1s var(--ease-out) 0.7s both, hero-breathe-b 9.2s ease-in-out 2.4s infinite; }
  .hero-grid .photo-3 { animation: hero-tile-in 1.1s var(--ease-out) 1.4s both, hero-breathe-c 7.8s ease-in-out 3.1s infinite; }
  .hero-grid .photo {
    transform-origin: 50% 50%;
    will-change: transform;
  }
  .hero-cell-text  { animation: hero-tile-in 1.1s var(--ease-out) 0.4s both; }
  .hero-cell-cta   { animation: hero-tile-in 1.1s var(--ease-out) 1.0s both; }

  /* Wavy underline auf 1 Wort (editorial flourish) */
  .hero-cell-text h1 .wavy {
    text-decoration: underline wavy var(--accent-text);
    text-decoration-thickness: 1.5px;
    text-underline-offset: 0.16em;
  }

  /* Hero CTA cognac-glow on hover */
  .hero-cell-cta .btn-primary {
    transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), transform var(--dur-fast) var(--ease-out);
  }
  .hero-cell-cta .btn-primary:hover {
    box-shadow: 0 0 0 1px rgba(224,117,96,0.35), 0 6px 22px -6px rgba(224,117,96,0.55), 0 14px 40px -16px rgba(224,117,96,0.45);
    transform: translateY(-1px);
  }

  /* Saison-Status Editorial Banner */
  .seasonal-strip {
    margin-top: clamp(1rem, 2vw, 1.5rem);
    padding: 0.875rem 1.25rem;
    border-top: 1px solid rgba(224,117,96,0.45);
    border-bottom: 1px solid rgba(224,117,96,0.18);
    display: flex; align-items: center; gap: 0.875rem; flex-wrap: wrap;
    font-size: var(--fs-small);
    color: var(--text-secondary);
    background: linear-gradient(90deg, rgba(224,117,96,0.06) 0%, rgba(224,117,96,0) 60%);
  }
  .seasonal-strip-eye {
    font-family: var(--font-body);
    font-size: 0.66rem;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--accent-text);
    font-weight: 600;
  }
  .seasonal-strip-text { font-family: var(--font-display); font-style: italic; font-size: 1.05rem; color: var(--text-primary); line-height: 1.3; }
  .seasonal-strip-text em { color: var(--accent-text); font-style: normal; font-weight: 500; }
  .seasonal-strip-tag { margin-left: auto; font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-muted); }

  /* Decorative Side-Candles (zwei zusätzlich, dezent) */
  .candle-deco {
    position: absolute;
    width: 22px; height: 48px;
    pointer-events: none;
    opacity: 0.78;
  }
  .candle-deco svg { width: 100%; height: 100%; display: block; }
  .candle-deco .flame { transform-origin: 50% 100%; animation: flicker 2.1s ease-in-out infinite alternate; }
  .candle-deco .glow  { animation: candle-glow 2.4s ease-in-out infinite alternate; }
  .candle-deco-1 { top: clamp(1rem, 4vw, 3rem); right: clamp(1rem, 5vw, 4rem); }
  .candle-deco-2 { bottom: clamp(1.5rem, 5vw, 4rem); left: clamp(1rem, 5vw, 4rem); width: 18px; height: 40px; }

  /* ─── Botanic Ornament Divider (Eichenblatt-Girlande) ─── */
  .ornament-divider {
    --orn-color: var(--accent-text);
    display: flex; justify-content: center; align-items: center;
    padding: clamp(2rem, 5vw, 3.5rem) var(--gutter);
    color: var(--orn-color);
  }
  .ornament-divider svg { width: clamp(180px, 30vw, 320px); height: auto; display: block; opacity: 0.78; }
  .ornament-divider.with-label { gap: 1.25rem; }
  .ornament-divider-label {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.95rem;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    white-space: nowrap;
  }

  /* ─── Drop-Caps (ornamentaler Cognac-Beginn) ─── */
  .has-dropcap > p:first-of-type::first-letter,
  .has-dropcap > .gen-story:first-of-type::first-letter,
  p.dropcap::first-letter {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 500;
    color: var(--accent-text);
    float: left;
    font-size: 4.4em;
    line-height: 0.86;
    padding: 0.08em 0.18em 0 0;
    margin-right: 0.05em;
    text-shadow: 0 1px 0 rgba(224,117,96,0.18);
  }

  /* ─── Editorial Stempel-Marks ─── */
  .stamp-row {
    display: flex; gap: clamp(1rem, 2.5vw, 2rem); flex-wrap: wrap;
    margin-top: clamp(1.5rem, 3vw, 2.5rem);
    align-items: center;
  }
  .stamp {
    --stamp-color: var(--accent-text);
    display: inline-flex; align-items: center; justify-content: center; flex-direction: column;
    border: 2px double var(--stamp-color);
    padding: 0.7rem 1.1rem;
    color: var(--stamp-color);
    transform: rotate(-3.5deg);
    font-family: var(--font-display);
    font-style: italic;
    line-height: 1.05;
    text-align: center;
    background: rgba(224,117,96,0.04);
    box-shadow: inset 0 0 0 1px rgba(224,117,96,0.18);
    width: 130px;
    min-height: 92px;
    transition: transform var(--dur-base) var(--ease-out);
  }
  .stamp:hover { transform: rotate(-1deg) scale(1.04); }
  .stamp:nth-child(2n) { transform: rotate(2.5deg); }
  .stamp:nth-child(3n) { transform: rotate(-1deg); }
  .stamp-num {
    font-family: var(--font-body);
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--text-muted);
    font-style: normal;
  }
  .stamp-title {
    font-size: 1.05rem;
    font-weight: 500;
    margin-top: 2px;
    line-height: 1.1;
    max-width: 110px;
    overflow-wrap: break-word;
  }
  .stamp-year {
    font-family: var(--font-body);
    font-size: 0.65rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--text-secondary);
    font-style: normal;
    margin-top: 4px;
  }

  /* ─── Reading-time Indicator ─── */
  .reading-time {
    display: inline-flex; align-items: center; gap: 0.5rem;
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--text-muted);
    margin-top: 0.5rem;
  }
  .reading-time::before {
    content: ""; width: 12px; height: 12px;
    border: 1.2px solid currentColor; border-radius: 50%;
    background: linear-gradient(to right, currentColor 50%, transparent 50%);
  }

  /* ─── Page-Numbering (sticky bottom, Roman) ─── */
  .page-num {
    position: fixed;
    bottom: 1.25rem;
    right: 1.25rem;
    z-index: 40;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.78rem;
    color: rgba(255,241,221,0.55);
    background: rgba(31,24,19,0.78);
    backdrop-filter: blur(8px);
    border: 1px solid var(--hairline);
    padding: 0.4rem 0.75rem;
    letter-spacing: 0.05em;
    pointer-events: none;
    user-select: none;
    transition: opacity var(--dur-base) var(--ease-out);
  }
  .page-num em { font-style: normal; color: var(--accent-text); margin-right: 0.4rem; font-weight: 500; }
  @media (max-width: 600px) { .page-num { bottom: 0.75rem; right: 0.75rem; font-size: 0.7rem; padding: 0.3rem 0.55rem; } }

  /* ─── Custom Bullet (Cognac-Knopf) Lists ─── */
  .bullet-list { list-style: none; padding-left: 0; }
  .bullet-list li {
    position: relative;
    padding-left: 1.625rem;
    margin-bottom: 0.625rem;
    color: var(--text-secondary);
  }
  .bullet-list li::before {
    content: "";
    position: absolute;
    left: 0; top: 0.55em;
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--accent-text);
    box-shadow: 0 0 0 3px rgba(224,117,96,0.18);
  }

  /* ─── Soup-Spoon SVG bullet (für Menü-Listen optional) ─── */
  .spoon-list { list-style: none; padding-left: 0; }
  .spoon-list li {
    position: relative;
    padding-left: 2rem;
    margin-bottom: 0.5rem;
    color: var(--text-secondary);
    line-height: 1.5;
  }
  .spoon-list li::before {
    content: "";
    position: absolute;
    left: 0; top: 0.35em;
    width: 22px; height: 14px;
    background-color: var(--accent-text);
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 14'><path d='M3 7 C3 4 5 2 7.5 2 C10 2 12 4 12 7 C12 9 10.5 10.5 8 10.5 L21 10.5 L21 8 L8 8' stroke='black' stroke-width='1.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/><ellipse cx='7.5' cy='6.8' rx='3' ry='4' fill='black'/></svg>") no-repeat center / contain;
            mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 14'><path d='M3 7 C3 4 5 2 7.5 2 C10 2 12 4 12 7 C12 9 10.5 10.5 8 10.5 L21 10.5 L21 8 L8 8' stroke='black' stroke-width='1.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/><ellipse cx='7.5' cy='6.8' rx='3' ry='4' fill='black'/></svg>") no-repeat center / contain;
  }

  /* ─── Pull-Quote (italic Crimson Pro Familie Brandt) ─── */
  .pull-quote-brandt {
    margin: clamp(2rem, 4vw, 3rem) auto;
    padding: 1.5rem clamp(1.5rem, 4vw, 3rem);
    max-width: 60ch;
    border-left: 2px solid var(--accent-text);
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(1.25rem, 2.6vw, 1.65rem);
    line-height: 1.45;
    color: var(--text-primary);
    position: relative;
    background: linear-gradient(90deg, rgba(224,117,96,0.05), transparent);
  }
  .pull-quote-brandt::before {
    content: "\201C";
    position: absolute;
    top: -0.3em; left: 0.4rem;
    font-size: 4em;
    line-height: 1;
    color: rgba(224,117,96,0.32);
    font-family: var(--font-display);
    pointer-events: none;
  }
  .pull-quote-brandt cite {
    display: block;
    margin-top: 0.875rem;
    font-family: var(--font-body);
    font-style: normal;
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent-text);
    font-weight: 500;
  }

  /* ─── Floating Wein-Glas illustration (drift in wein-pairing) ─── */
  .wein-glass-floater {
    position: absolute;
    pointer-events: none;
    z-index: 2;
    width: clamp(70px, 11vw, 130px);
    color: rgba(168,54,44,0.62);
    opacity: 0.85;
    animation: wein-drift 14s ease-in-out infinite;
  }
  .wein-glass-floater svg { width: 100%; height: auto; display: block; filter: drop-shadow(0 6px 14px rgba(31,8,8,0.45)); }
  .wein-glass-floater.f-1 { top: 6%;  right: 4%; animation-delay: 0s; }
  .wein-glass-floater.f-2 { bottom: 8%; left: 3%; transform: rotate(-8deg); animation-delay: 5s; opacity: 0.65; width: clamp(56px, 9vw, 100px); }
  @keyframes wein-drift {
    0%, 100% { transform: translate3d(0, 0, 0) rotate(-2deg); }
    50%      { transform: translate3d(0, -14px, 0) rotate(3deg); }
  }
  .wein-pairing { position: relative; overflow: hidden; }

  /* ─── Pilz / Kräuter / Antike-Flasche cut-out section dividers ─── */
  .ornament-cutout-wrap {
    position: relative;
    padding: clamp(2rem, 5vw, 4rem) var(--gutter);
    display: flex; align-items: center; justify-content: center;
    color: var(--accent-text);
  }
  .ornament-cutout-wrap::before, .ornament-cutout-wrap::after {
    content: ""; height: 1px; flex: 1;
    background: linear-gradient(90deg, transparent, rgba(224,117,96,0.32), transparent);
    max-width: 22vw;
  }
  .ornament-cutout-wrap svg {
    width: clamp(56px, 8vw, 92px);
    height: auto;
    display: block;
    margin-inline: 1.25rem;
    opacity: 0.78;
  }

  /* ─── Wild-Tier XXL Watermark ─── */
  .saison { position: relative; overflow: hidden; }
  .wild-watermark {
    position: absolute;
    pointer-events: none;
    inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: rgba(224,117,96,0.05);
    z-index: 0;
  }
  .wild-watermark svg { width: 86%; max-width: 1200px; height: auto; }
  .saison > .container-wide { position: relative; z-index: 1; }

  /* ─── Footer Signature: Familie Brandt ─── */
  .footer-signature {
    display: flex; flex-direction: column; align-items: flex-start; gap: 0.5rem;
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px dashed rgba(224,117,96,0.25);
  }
  .footer-signature .sig-name {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 500;
    font-size: 1.625rem;
    line-height: 1.1;
    color: var(--accent-text);
    letter-spacing: 0.005em;
  }
  .footer-signature-meta {
    font-family: var(--font-body);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-muted);
  }

  /* ────────────────────────────────────────────────────────────
     ROUND 5 · Küchen-Crew · "In der Küche" (index.html)
     Isolated portraits with mask-image fade, mid-action tags,
     hand-handwritten Caveat annotations between cards, cards
     overlap section background via negative margins.
     ──────────────────────────────────────────────────────────── */
  .kueche-crew {
    position: relative;
    padding-block: var(--section-py);
    background: var(--bg-secondary);
    overflow: visible;
  }
  .kueche-crew::before {
    content: "Küche";
    position: absolute;
    top: 8%;
    left: -2%;
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(8rem, 22vw, 18rem);
    color: rgba(224,117,96,0.04);
    pointer-events: none;
    line-height: 0.85;
    letter-spacing: -0.04em;
    z-index: 0;
  }
  .kueche-crew > .container-wide { position: relative; z-index: 1; }

  .crew-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2.5rem, 5vw, 3.5rem) 0;
    margin-top: clamp(2.5rem, 5vw, 4rem);
    align-items: start;
  }
  @media (min-width: 600px) {
    .crew-grid {
      grid-template-columns: repeat(2, 1fr);
      gap: clamp(3rem, 5vw, 4rem) clamp(1.5rem, 3vw, 2.5rem);
    }
  }
  @media (min-width: 1080px) {
    .crew-grid {
      grid-template-columns: repeat(4, 1fr);
      gap: 4rem 1.75rem;
    }
  }

  .crew-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
    /* lift cards above section background */
    margin-top: clamp(-2rem, -3vw, -3.5rem);
  }
  .crew-card-offset-down {
    margin-top: clamp(0rem, 2vw, 2.5rem);
  }
  @media (max-width: 599px) {
    .crew-card, .crew-card-offset-down { margin-top: 0; }
  }

  .crew-portrait {
    position: relative;
    aspect-ratio: 4/5;
    /* Isolated portrait illusion via radial mask + transparent edges */
    background:
      radial-gradient(ellipse at 50% 38%, rgba(31,24,19,0) 30%, var(--bg-secondary) 78%),
      var(--bg-secondary);
    overflow: hidden;
    border-radius: 2px;
  }
  .crew-portrait img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* fade edges to give "isolated portrait" cut-out feel */
    -webkit-mask-image: radial-gradient(ellipse 80% 92% at 50% 42%, #000 55%, rgba(0,0,0,0.55) 78%, rgba(0,0,0,0) 100%);
    mask-image: radial-gradient(ellipse 80% 92% at 50% 42%, #000 55%, rgba(0,0,0,0.55) 78%, rgba(0,0,0,0) 100%);
    filter: contrast(1.05) saturate(0.96);
    transition: transform 0.9s var(--ease-out), filter 0.6s var(--ease-out);
  }
  .crew-card:hover .crew-portrait img { transform: scale(1.03); filter: contrast(1.08) saturate(1.02); }

  .crew-action-tag {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    font-family: 'Caveat', 'Crimson Pro', cursive;
    font-size: 1.4rem;
    color: var(--accent-text);
    background: rgba(14, 10, 7, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    padding: 0.15rem 0.7rem;
    border-radius: 2px;
    letter-spacing: 0.01em;
    transform: rotate(-2deg);
    z-index: 2;
  }

  .crew-text { padding-inline: 0.25rem; }
  .crew-eyebrow {
    display: block;
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--accent-text);
    font-weight: 600;
    margin-bottom: 0.55rem;
  }
  .crew-card h3 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(1.5rem, 2.4vw, 1.85rem);
    line-height: 1.1;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
  }
  .crew-card h3 em { font-style: italic; color: var(--accent-text); }
  .crew-role {
    display: block;
    font-family: var(--font-body);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-muted);
    margin-bottom: 0.85rem;
  }
  .crew-card p {
    font-size: var(--fs-small);
    color: var(--text-secondary);
    line-height: 1.62;
    margin-bottom: 0.85rem;
  }
  .crew-card p em { color: var(--accent-text); font-style: italic; }
  .crew-mini {
    display: block;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.95rem;
    color: var(--text-muted);
    line-height: 1.45;
    padding-top: 0.65rem;
    border-top: 1px dashed rgba(224,117,96,0.2);
  }

  /* Hand-handwritten Caveat annotations between card pairs.
     Hidden on mobile (no horizontal space). Visible on tablet 2-col
     as full-width decorative line between rows. Hidden again on 4-col
     desktop where they would break the grid rhythm. */
  .crew-anno { display: none; }
  @media (min-width: 600px) and (max-width: 1079px) {
    .crew-anno {
      display: block;
      grid-column: 1 / -1;
      text-align: center;
      font-family: 'Caveat', 'Crimson Pro', cursive;
      font-size: 1.25rem;
      color: var(--accent-text);
      letter-spacing: 0.01em;
      transform: rotate(-1deg);
      padding: 0.5rem 1rem;
      opacity: 0.82;
      pointer-events: none;
    }
    .crew-anno em { font-style: italic; font-weight: 500; }
  }

  .crew-footer-note {
    margin-top: clamp(2.5rem, 5vw, 4rem);
    text-align: center;
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(1rem, 1.6vw, 1.15rem);
    color: var(--text-muted);
    line-height: 1.55;
    max-width: 60ch;
    margin-inline: auto;
    padding-top: 1.5rem;
    border-top: 1px solid var(--hairline);
  }
  .crew-footer-note em {
    color: var(--accent-text);
    font-style: italic;
    font-weight: 500;
  }

  /* ────────────────────────────────────────────────────────────
     ROUND 5 · Mobile-Perfectionierung
     Touch-only states for hover-based components, larger touch
     targets on small screens.
     ──────────────────────────────────────────────────────────── */

  /* Saison-Karten: hover-flip nur auf hover-fähigen Geräten (Maus, Trackpad).
     Auf Touch-Geräten: nur tap-toggle via aria-pressed. Dadurch bleiben
     die Karten nach dem Tap nicht "stuck" geflippt durch :hover-state. */
  @media (hover: none) {
    .saison-card-flip:hover .saison-card-inner,
    .saison-card-flip:focus-visible .saison-card-inner {
      transform: none;
    }
    .saison-card-flip[aria-pressed="true"] .saison-card-inner {
      transform: rotateY(180deg);
    }
    .saison-card-flip:hover .saison-card-front::before { opacity: 0.55; }
  }

  /* Filter-Pills: 44×44 px Touch-Target + horizontal scroll auf Smartphones (WCAG 2.5.5 / Apple HIG) */
  @media (max-width: 767px) {
    .filter-pill { min-height: 44px; padding: 0.65rem 0.9rem; font-size: 0.8rem; white-space: nowrap; }
    .filter-reset { min-height: 44px; padding: 0.6rem 0.8rem; }
    .filter-pills {
      gap: 0.4rem;
      flex-wrap: nowrap;
      overflow-x: auto;
      scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
      padding-bottom: 2px; /* prevent border clipping */
    }
    .filter-pills::-webkit-scrollbar { display: none; }
    .filter-group { flex-direction: row; align-items: center; gap: 0.6rem; }
    .filter-bar-inner { gap: 0.5rem; padding-block: 0.75rem; }
  }

  /* Wizard step buttons: vergrößern auf Mobile, full-width-friendly,
     Buttons nicht abgeschnitten am Rand */
  @media (max-width: 599px) {
    .step-btn {
      min-height: 52px;
      padding: 1rem 1.25rem;
      flex: 1 1 auto;
      justify-content: center;
      font-size: 0.82rem;
    }
    .step-btn.is-submit { margin-left: 0; flex-basis: 100%; }
  }

  /* Anlass cards & person pills: Touch-Komfort */
  @media (max-width: 599px) {
    .anlass-card { min-height: 88px; }
    .pers-pill { min-height: 56px; font-size: 1.5rem; }
    .uhrzeit-pill { min-height: 52px; font-size: 0.95rem; padding: 0.85rem 0.6rem; }
  }

  /* Tasting scroll-snap: auf Mobile sanfter (proximity statt mandatory),
     verhindert "stuck"-Effekt bei kurzen Abschnitten */
  @media (max-width: 767px) {
    .tasting-track { scroll-snap-type: y proximity; }
    .tasting-gang { min-height: auto; padding-block: clamp(2.5rem, 8vw, 4rem); }
  }

  /* Heute-Marquee: bei sehr kleinen Screens Schrift sichtbar lassen,
     animation-duration verlangsamen für Lesbarkeit */
  @media (max-width: 479px) {
    .heute-strip-inner { gap: 2rem; animation-duration: 48s; }
    .heute-strip-inner > span { font-size: 1.15rem; }
    .heute-strip-inner > span::after { margin-left: 2rem; }
    .heute-strip-label { font-size: 0.65rem; }
  }

  /* Reservierungs-Uhr: bei 375px nicht zu groß, lesbare Tick-Labels */
  @media (max-width: 479px) {
    .uhr-svg-wrap { max-width: 320px; }
    .uhr-tick { font-size: 0.7rem; }
    .uhr-center-time { font-size: 1.85rem; }
    .uhr-center-meta { font-size: 0.62rem; letter-spacing: 0.16em; }
    .uhr-legend { gap: 0.5rem 1rem; font-size: 0.72rem; }
  }

  /* Crew portrait: leicht verkleinerte Touch-Cards */
  @media (max-width: 599px) {
    .crew-portrait { aspect-ratio: 5/6; max-width: 320px; margin-inline: auto; width: 100%; }
    .crew-text { text-align: center; }
    .crew-mini { padding-inline: 1rem; }
  }

  /* ─── Reduced motion guards ─── */
  @media (prefers-reduced-motion: reduce) {
    .photo-steam::before,
    .candle-flame, .candle-glow,
    .live-dot,
    .heute-strip-inner,
    .saison-card-inner,
    .duck-cutout,
    .tasting-photo img,
    .kollege-photo img {
      animation: none !important;
      transition: none !important;
    }
    .saison-card-flip[aria-pressed="true"] .saison-card-inner {
      transform: rotateY(180deg);
    }
    .hero-video { display: none; }
    .hero-video-poster { display: block !important; }
    .menu-item { transition: none !important; }
    .tasting-track { scroll-snap-type: none; }
    .tasting-gang { min-height: auto; }
    .step-panel { animation: none !important; }
    .anlass-card:hover, .pers-pill:hover, .kollege:hover .kollege-photo img,
    .crew-card:hover .crew-portrait img { transform: none !important; }
    .crew-portrait img { transition: none !important; }
    .hero-grid .photo-1, .hero-grid .photo-2, .hero-grid .photo-3,
    .hero-cell-text, .hero-cell-cta,
    .candle-deco .flame, .candle-deco .glow,
    .wein-glass-floater {
      animation: none !important;
    }
    .hero-grid .photo-1, .hero-grid .photo-2, .hero-grid .photo-3,
    .hero-cell-text, .hero-cell-cta { opacity: 1 !important; filter: none !important; transform: none !important; }
  }

  /* ────────────────────────────────────────────────────────────
     ROUND 8 · Industry-Essentials
     · .events       — Privatbuchung / Catering / Ganzes Haus
     · .gutschein    — Geschenk-Gutscheine mit handgesetzter Karte
     ──────────────────────────────────────────────────────────── */

  /* ─── Events / Catering / Privatbuchung ─── */
  .events {
    padding-block: clamp(4rem, 8vw, 7rem);
    border-top: 1px solid var(--hairline);
    border-bottom: 1px solid var(--hairline);
    background:
      radial-gradient(circle at 90% 10%, rgba(224,117,96,0.07), transparent 55%),
      var(--bg-primary);
  }
  .events-lead {
    max-width: 58ch;
    color: var(--text-secondary);
    line-height: 1.65;
    margin-bottom: clamp(2rem, 4vw, 3rem);
    font-size: var(--fs-body-lg);
  }
  .events-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  @media (min-width: 720px) { .events-grid { grid-template-columns: repeat(2, 1fr); gap: 1.75rem; } }
  @media (min-width: 1100px) { .events-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; } }
  .event-card {
    display: grid;
    grid-template-rows: auto auto auto 1fr auto;
    gap: 0.5rem;
    padding: clamp(1.5rem, 2.4vw, 2rem) clamp(1.5rem, 2.4vw, 1.85rem);
    background: rgba(255, 241, 221, 0.04);
    border: 1px solid var(--hairline);
    border-top: 2px solid var(--accent-text);
    position: relative;
  }
  .event-card::after {
    content: "";
    position: absolute;
    inset: 8px;
    border: 1px solid rgba(224,117,96,0.08);
    pointer-events: none;
  }
  .event-card-num {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.5rem;
    color: var(--accent-text);
    line-height: 1;
    margin-bottom: 0.5rem;
  }
  .event-card h3 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(1.35rem, 2.2vw, 1.7rem);
    line-height: 1.15;
    color: var(--text-primary);
    margin-bottom: 0.4rem;
  }
  .event-card h3 em { font-style: italic; color: var(--accent-text); }
  .event-card-meta {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-muted);
    padding: 0.4rem 0.65rem;
    border: 1px solid var(--hairline);
    border-radius: 999px;
    align-self: start;
    margin-bottom: 0.75rem;
  }
  .event-card p {
    color: var(--text-secondary);
    line-height: 1.65;
    font-size: var(--fs-small);
    margin-bottom: 1rem;
  }
  .event-card-list {
    list-style: none;
    padding: 0;
    margin: 0.5rem 0 0;
    display: grid;
    gap: 0.35rem;
    border-top: 1px dashed rgba(224,117,96,0.18);
    padding-top: 0.9rem;
  }
  .event-card-list li {
    font-family: var(--font-body);
    font-size: 0.8rem;
    color: var(--text-secondary);
    line-height: 1.5;
    padding-left: 1.1rem;
    position: relative;
  }
  .event-card-list li::before {
    content: "·";
    position: absolute;
    left: 0.25rem;
    top: -0.1rem;
    color: var(--accent-text);
    font-size: 1.4rem;
    line-height: 1;
  }
  .events-foot {
    margin-top: clamp(2.5rem, 5vw, 4rem);
    padding: clamp(1.5rem, 3vw, 2.25rem);
    border: 1px solid var(--hairline);
    border-left: 2px solid var(--accent-text);
    background: rgba(255, 241, 221, 0.03);
    display: grid;
    gap: 0.75rem;
  }
  .events-foot-eyebrow {
    font-family: var(--font-body);
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--accent-text);
    font-weight: 600;
  }
  .events-foot p {
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(1.05rem, 1.6vw, 1.2rem);
    color: var(--text-primary);
    line-height: 1.5;
    max-width: 50ch;
    margin: 0;
  }
  .events-foot-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.5rem;
  }

  /* ─── Geschenk-Gutscheine ─── */
  .gutschein {
    padding-block: clamp(4rem, 8vw, 7rem);
    background: var(--bg-tertiary);
    border-top: 1px solid var(--hairline);
  }
  .gutschein-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2rem, 4vw, 3.5rem);
    align-items: center;
  }
  @media (min-width: 900px) {
    .gutschein-grid { grid-template-columns: 0.9fr 1.1fr; gap: 4rem; }
  }
  .gutschein-card-wrap {
    perspective: 800px;
    display: flex;
    justify-content: center;
    padding: 1rem;
  }
  .gutschein-card {
    --rot: -2.5deg;
    width: 100%;
    max-width: 380px;
    aspect-ratio: 5/3;
    padding: clamp(1.25rem, 2.5vw, 1.75rem);
    background:
      radial-gradient(circle at 30% 20%, rgba(224,117,96,0.14), transparent 60%),
      linear-gradient(155deg, #FFF1DD 0%, #F4E4C3 60%, #E5CFA5 100%);
    color: #1F1813;
    border: 1px solid rgba(31, 24, 19, 0.2);
    box-shadow:
      0 22px 38px rgba(0,0,0,0.55),
      inset 0 0 0 1px rgba(255,255,255,0.45),
      inset 0 0 80px rgba(168, 54, 44, 0.08);
    transform: rotate(var(--rot));
    display: grid;
    grid-template-rows: auto auto 1fr auto auto;
    gap: 0.4rem;
    position: relative;
    font-family: var(--font-display);
  }
  .gutschein-card::before {
    content: "";
    position: absolute;
    inset: 8px;
    border: 1px dashed rgba(168, 54, 44, 0.35);
    pointer-events: none;
  }
  .gutschein-card-corner {
    position: absolute;
    font-family: var(--font-display);
    color: var(--accent);
    font-size: 1.1rem;
    line-height: 1;
  }
  .gutschein-card-corner.tl { top: 14px; left: 14px; }
  .gutschein-card-corner.br { bottom: 14px; right: 14px; }
  .gutschein-card-eyebrow {
    font-family: var(--font-body);
    font-size: 0.62rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: rgba(31, 24, 19, 0.72);
    align-self: center;
    text-align: center;
  }
  .gutschein-card-amount {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(2.5rem, 5vw, 3.4rem);
    color: var(--accent);
    text-align: center;
    line-height: 1;
    letter-spacing: -0.01em;
  }
  .gutschein-card-meta {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.95rem;
    color: rgba(31, 24, 19, 0.78);
    text-align: center;
    margin-top: 0.15rem;
  }
  .gutschein-card-line {
    font-family: 'Caveat', 'Crimson Pro', cursive;
    font-size: 1.1rem;
    color: rgba(31, 24, 19, 0.7);
    text-align: center;
    margin-block: 0.5rem;
    transform: rotate(-1deg);
  }
  .gutschein-card-foot {
    font-family: var(--font-body);
    font-size: 0.6rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: rgba(31, 24, 19, 0.55);
    text-align: center;
  }
  .gutschein-text h2 {
    font-size: var(--fs-h1);
    line-height: 1.0;
    margin-bottom: 1rem;
    max-width: 18ch;
  }
  .gutschein-text > p {
    color: var(--text-secondary);
    line-height: 1.65;
    margin-bottom: 1.5rem;
    max-width: 52ch;
  }
  .gutschein-stufen {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
  }
  @media (min-width: 540px) { .gutschein-stufen { grid-template-columns: repeat(3, 1fr); gap: 0.85rem; } }
  .gutschein-stufe {
    padding: 1rem;
    background: rgba(255, 241, 221, 0.04);
    border: 1px solid var(--hairline);
    display: grid;
    gap: 0.25rem;
    position: relative;
  }
  .gutschein-stufe.is-mid {
    background: rgba(224, 117, 96, 0.06);
    border-color: rgba(224, 117, 96, 0.32);
  }
  .gutschein-stufe.is-mid::before {
    content: "Beliebt";
    position: absolute;
    top: -10px;
    right: 10px;
    font-family: var(--font-body);
    font-size: 0.58rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    background: var(--accent);
    color: var(--text-primary);
    padding: 0.18rem 0.5rem;
    border-radius: 2px;
    font-weight: 600;
  }
  .gutschein-stufe-val {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 500;
    font-size: 1.5rem;
    color: var(--accent-text);
    line-height: 1;
  }
  .gutschein-stufe-name {
    font-family: var(--font-body);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-muted);
    font-weight: 600;
  }
  .gutschein-stufe-desc {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.88rem;
    color: var(--text-secondary);
    line-height: 1.45;
    margin-top: 0.2rem;
  }
  .gutschein-fine {
    font-size: 0.82rem;
    color: var(--text-muted);
    line-height: 1.55;
    margin-bottom: 1.25rem;
    font-style: italic;
    font-family: var(--font-display);
  }
  .gutschein-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem 1.5rem;
  }

  /* Reduced motion: keep gutschein card readable, but stop rotation */
  @media (prefers-reduced-motion: reduce) {
    .gutschein-card { transform: none; }
    .gutschein-card-line { transform: none; }
  }

  /* ================================================================
     ROUND 6 — TOP-NIVEAU POLISH
     ================================================================ */

  /* ─── Manifesto: stärkere typografische Präsenz ─── */
  .manifesto {
    background: linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 60%, var(--bg-primary) 100%);
    border-top: 1px solid var(--hairline);
    border-bottom: 1px solid var(--hairline);
  }
  .manifesto-text {
    font-size: clamp(1.75rem, 3.8vw, 2.875rem);
  }

  /* ─── Section-Rhythm: Crew bekommt stärkere visuelle Trennung ─── */
  .kueche-crew {
    border-top: 1px solid var(--hairline);
  }

  /* ─── Chef-Section: Warm-gradient Hintergrund für Abwechslung ─── */
  .chef {
    background: linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
  }

  /* ─── Press section: subtile Dark-Separierung ─── */
  .press {
    background: var(--bg-primary);
    border-top: 1px solid var(--hairline);
  }

  /* ─── Gutschein section: Warm accent background ─── */
  .gutschein {
    background: var(--bg-secondary);
    border-top: 1px solid var(--hairline);
  }

  /* ─── Stärkere Section-Header Hierarchie ─── */
  .section-header h2 {
    font-size: var(--fs-h1);
    line-height: 0.97;
    max-width: 20ch;
    letter-spacing: -0.025em;
  }

  /* ─── Karte-Teaser: warm amber touch für mehr Premium-Feeling ─── */
  .karte-teaser {
    background: linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-primary) 100%);
    border-top: 1px solid var(--hairline);
  }
  .karte-card h3 {
    font-size: clamp(1.5rem, 2.8vw, 2rem);
    line-height: 1.0;
    letter-spacing: -0.02em;
  }
  .karte-card .karte-price {
    font-size: 1.375rem;
  }

  /* ─── Tages-Empfehlung (Chef's Tafel): Überraschungssektion ─── */
  .tafel {
    padding-block: clamp(5rem, 10vw, 9rem);
    background: var(--bg-tertiary);
    border-top: 1px solid var(--hairline);
    position: relative;
    overflow: hidden;
  }
  .tafel::before {
    content: "Tafel";
    position: absolute;
    top: -5%;
    right: -3%;
    font-family: var(--font-display);
    font-style: italic;
    font-size: clamp(10rem, 26vw, 22rem);
    color: rgba(224,117,96,0.035);
    pointer-events: none;
    line-height: 0.85;
    letter-spacing: -0.04em;
    z-index: 0;
  }
  .tafel > .container-wide { position: relative; z-index: 1; }
  .tafel-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    align-items: center;
  }
  @media (min-width: 768px) {
    .tafel-grid { grid-template-columns: 1fr 1fr; gap: 5rem; }
  }
  .tafel-content h2 {
    font-size: var(--fs-h1);
    line-height: 1.0;
    margin-bottom: 0.75rem;
    letter-spacing: -0.025em;
  }
  .tafel-content h2 em { font-style: italic; color: var(--accent-text); }
  .tafel-content p {
    color: var(--text-secondary);
    line-height: 1.65;
    margin-bottom: 1rem;
    max-width: 50ch;
    font-size: var(--fs-body-lg);
  }
  .tafel-dishes {
    display: grid;
    gap: 0;
    border-top: 1px solid var(--hairline);
  }
  .tafel-dish {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.5rem 1.25rem;
    padding-block: 1.25rem;
    border-bottom: 1px solid var(--hairline);
    align-items: baseline;
  }
  .tafel-dish-num {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 0.9rem;
    width: 1.5rem;
    line-height: 1.4;
  }
  .tafel-dish-name {
    font-family: var(--font-display);
    font-size: clamp(1.1rem, 1.8vw, 1.3rem);
    font-weight: 500;
    color: var(--text-primary);
    letter-spacing: -0.01em;
  }
  .tafel-dish-name em { font-style: italic; color: var(--accent-text); font-size: 0.9em; margin-left: 0.35rem; }
  .tafel-dish-price {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--accent-text);
    font-size: 1.125rem;
    white-space: nowrap;
  }
  .tafel-dish-sub {
    grid-column: 2 / 3;
    font-size: var(--fs-small);
    color: var(--text-muted);
    line-height: 1.45;
    margin-top: 0.1rem;
  }
  .tafel-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.35rem 0.7rem;
    border: 1px solid rgba(224,117,96,0.38);
    background: rgba(224,117,96,0.06);
    font-family: var(--font-body);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--accent-text);
    font-weight: 500;
    margin-bottom: 1rem;
  }
  .tafel-badge::before {
    content: "";
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    background: var(--accent-text);
  }
  .tafel-note {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--hairline);
    font-family: var(--font-display);
    font-style: italic;
    font-size: var(--fs-small);
    color: var(--text-muted);
    line-height: 1.55;
  }

  /* ─── Heute-Strip verstärktes Erscheinungsbild ─── */
  .heute-strip {
    border-top: 2px solid rgba(224,117,96,0.35);
    border-bottom: 2px solid rgba(224,117,96,0.12);
    padding-block: 1.25rem;
  }
  .heute-strip-label {
    font-weight: 600;
    color: var(--accent-text);
  }

  /* ─── Hero: stronger full-screen presence on desktop ─── */
  @media (min-width: 768px) {
    .hero {
      padding-top: clamp(2rem, 4vw, 3rem);
    }
    .hero-grid {
      min-height: calc(100svh - 80px);
    }
  }

  /* ─── Btn-primary stärkere hover shadow ─── */
  .btn-primary:hover {
    box-shadow: 0 4px 20px -4px rgba(168, 54, 44, 0.55);
    transform: translateY(-1px);
  }

  /* ─── Nav-CTA als Reservierungs-Anker: subtle pulse ─── */
  @keyframes nav-cta-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(168, 54, 44, 0); }
    50%      { box-shadow: 0 0 0 4px rgba(168, 54, 44, 0.25); }
  }
  .nav-cta { animation: nav-cta-pulse 4s ease-in-out 3s infinite; }

  /* ─── Lieferanten photo: light-theme overrides for .photo hover ─── */
  .lieferanten .photo img { filter: brightness(0.98) saturate(1.06); }
  .lieferanten .photo:hover img { transform: scale(1.025); filter: brightness(1.02) saturate(1.1); }

  /* ─── Reduced-motion additions ─── */
  @media (prefers-reduced-motion: reduce) {
    .nav-cta { animation: none; }
    .hero { min-height: auto; }
  }
}
