/* ============================================================
   Geschmackssache — Page-specific & section components
   ============================================================ */

/* ---- Hero (home intro) ---- */
.hero { justify-content: flex-end; }
.hero__year {
  position: absolute;
  top: calc(var(--nav-h) + var(--space-6));
  right: var(--panel-pad);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-wider);
  color: var(--color-text-dim);
}
.hero__title { color: #fff; }
.hero__title em { font-style: italic; color: var(--color-accent); }
.hero__sub {
  margin-top: var(--space-6);
  max-width: 30ch;
  color: var(--color-text-dim);
}

/* ---- Teaser panel (home sections that link out) ---- */
.teaser__eyebrow { margin-bottom: var(--space-4); }
.teaser__title { font-size: var(--text-2xl); max-width: 16ch; }
.teaser__title em { font-style: italic; color: var(--color-accent); }
.teaser__body { margin: var(--space-6) 0 var(--space-8); max-width: 42ch; color: var(--color-text-dim); }
.teaser__meta {
  display: flex; flex-wrap: wrap; gap: var(--space-8);
  margin-top: var(--space-8);
}
.teaser__meta .stat { display: flex; flex-direction: column; }
.teaser__meta .stat b {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--color-accent);
}
.teaser__meta .stat span {
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-faint);
}

/* Editorial two-column inside a panel */
.split {
  display: grid;
  gap: clamp(2rem, 5vw, 6rem);
  align-items: center;
  width: 100%;
  max-width: 84rem;
}
@media (min-width: 860px) {
  .split { grid-template-columns: 1.1fr 0.9fr; }
  .split--reverse { grid-template-columns: 0.9fr 1.1fr; }
  .split--reverse .split__media { order: -1; }
}
.split__media { width: 100%; max-width: 30rem; }

/* ---- Reservation CTA panel ---- */
.reserve {
  align-items: center;
  text-align: center;
}
/* The POV video is the backdrop now; keep a dark fallback behind it so the
   panel never flashes the wine-red gradient over the (z-index:-1) video. */
.reserve .bg-atmos { background: var(--color-bg-deep); }
.reserve__title { font-size: var(--text-2xl); max-width: 18ch; }
.reserve__title em { font-style: italic; color: var(--color-accent); }
.reserve__phone {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 1.2rem + 5vw, 4.5rem);
  font-weight: 500;
  letter-spacing: 0.01em;
  color: #fff;
  margin: var(--space-8) 0 var(--space-4);
  display: inline-block;
  transition: color var(--dur-normal);
}
.reserve__phone:hover { color: var(--color-accent); }
.reserve__hours { color: var(--color-text-dim); font-size: var(--text-sm); }
.reserve__actions { margin-top: var(--space-8); display: flex; gap: var(--space-4); flex-wrap: wrap; justify-content: center; }

/* ---- Menu page ---- */
.menu-cat__head {
  display: flex; align-items: baseline; gap: var(--space-6);
  margin-bottom: var(--space-8);
}
.menu-cat__head .num {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-accent);
  letter-spacing: var(--tracking-wide);
}
.menu-cat__title { font-size: var(--text-xl); }
.menu-cat__sizes { margin-left: auto; font-size: var(--text-xs); letter-spacing: 0.04em; color: var(--color-text-faint); white-space: nowrap; }
.menu-cat__note { color: var(--color-text-faint); font-size: var(--text-xs); margin-bottom: var(--space-6); max-width: 52ch; }
.menu-cols { display: grid; gap: clamp(2rem, 4vw, 4rem); }
@media (min-width: 760px) { .menu-cols--2 { grid-template-columns: 1fr 1fr; } }
.menu-item__price--multi { font-variant-numeric: tabular-nums; }
.menu-list { width: min(46rem, 100%); }
.menu-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.4em var(--space-6);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-line);
  align-items: baseline;
}
.menu-item__name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--color-text);
}
.menu-item__price {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-accent);
  white-space: nowrap;
}
.menu-item__desc {
  grid-column: 1 / -1;
  color: var(--color-text-dim);
  font-size: var(--text-sm);
  max-width: 52ch;
}
.menu-item__tags { grid-column: 1 / -1; display: flex; gap: 0.5em; margin-top: 0.3em; }
.tag {
  font-size: 0.62rem;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-faint);
  border: 1px solid var(--color-line);
  padding: 0.25em 0.6em;
  border-radius: 999px;
}

/* ---- Event date (H1-style, replaces the old button on the home teaser) ---- */
.event-date {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--color-accent);
  margin-top: var(--space-6);
  letter-spacing: 0.01em;
}

/* Events teaser text: wide column + tighter rhythm so nothing gets clipped.
   The events panel content may use the full panel width (not the narrow teaser column). */
#events > [data-reveal] { max-width: min(72ch, 80vw); }
#events .teaser__title { max-width: 24ch; }
#ev-desc { max-width: 68ch; margin: var(--space-5, 1.25rem) 0 0; }
@media (max-width: 760px) {
  #events > [data-reveal] { max-width: 100%; }
  #ev-desc { max-width: 100%; font-size: var(--text-sm); }
  #events .teaser__title { max-width: 100%; }
  .event-date { font-size: var(--text-lg); margin-top: var(--space-5, 1.25rem); }
}

/* ---- Events page ---- */
.event-card {
  width: min(34rem, 100%);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  padding: var(--space-8);
  background: linear-gradient(160deg, var(--color-surface), transparent);
  transition: border-color var(--dur-normal), transform var(--dur-normal) var(--ease-out-expo);
}
.event-card:hover { border-color: var(--color-accent); transform: translateY(-4px); }
.event-card__date {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-accent);
}
.event-card__title { font-size: var(--text-xl); margin: var(--space-3) 0 var(--space-4); }
.event-card__body { color: var(--color-text-dim); font-size: var(--text-sm); }
.event-card__meta {
  margin-top: var(--space-6);
  display: flex; gap: var(--space-6);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  letter-spacing: 0.04em;
}

/* ---- Contact page ---- */
.contact-grid {
  display: grid;
  gap: clamp(2rem, 5vw, 5rem);
  width: 100%;
  max-width: 70rem;
}
@media (min-width: 800px) { .contact-grid { grid-template-columns: 1fr 1fr; } }
.contact-block h3 {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-3);
  font-weight: 400;
}
.contact-block p, .contact-block a { color: var(--color-text-dim); }
.contact-block a:hover { color: var(--color-text); }
.contact-block .big {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-text);
}
.hours-table { width: 100%; border-collapse: collapse; }
.hours-table td { padding: 0.5em 0; border-bottom: 1px solid var(--color-line); font-size: var(--text-sm); }
.hours-table td:last-child { text-align: right; color: var(--color-text); }
.hours-table td:first-child { color: var(--color-text-dim); }

/* ---- Legal pages (Impressum / Datenschutz) — readable vertical ---- */
.legal {
  min-height: 100dvh;
  max-width: 50rem;
  margin-inline: auto;
  padding: calc(var(--nav-h) + var(--space-16)) var(--gutter) var(--space-24);
}
.legal h1 { font-size: var(--text-2xl); margin-bottom: var(--space-8); }
.legal h2 {
  font-size: var(--text-lg);
  margin: var(--space-12) 0 var(--space-3);
  color: var(--color-text);
}
.legal h3 { font-size: var(--text-base); margin: var(--space-6) 0 var(--space-2); font-family: var(--font-sans); letter-spacing: 0.02em; text-transform: uppercase; color: var(--color-accent); font-weight: 400; }
.legal p, .legal li { color: var(--color-text-dim); font-size: var(--text-sm); max-width: 64ch; }
.legal p + p { margin-top: var(--space-3); }
.legal ul { list-style: disc; padding-left: 1.2em; margin-top: var(--space-2); }
.legal a { color: var(--color-accent); }
.legal__back { display: inline-block; margin-bottom: var(--space-8); }
.legal__note {
  margin-top: var(--space-12);
  padding: var(--space-6);
  border: 1px dashed var(--color-line);
  border-radius: var(--radius);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
}

/* ============================================================
   Mobile: horizontal pin mode keeps panels at viewport height,
   so dense menu lists must be compacted to fit without clipping.
   ============================================================ */
@media (max-width: 760px) {
  .panel {
    padding-top: max(var(--panel-pad), calc(var(--nav-h) + var(--space-3)));
    padding-bottom: clamp(4.5rem, 4rem + 6vw, 6rem);
  }
  .menu-list { width: 100%; }
  .menu-cat__head { margin-bottom: var(--space-4); gap: var(--space-3); }
  .menu-cat__title { font-size: var(--text-lg); }
  .menu-item { padding: 0.4rem 0; gap: 0.15em 1rem; }
  .menu-item__name { font-size: 1rem; }
  .menu-item__price { font-size: 0.9rem; }
  .menu-item__desc { font-size: 0.72rem; line-height: 1.35; }
  .menu-cols { gap: var(--space-6); }
  .teaser__title { font-size: var(--text-xl); }
}

/* Very dense dual-category DRINK panels: 2 compact columns even on phones
   (names + prices only) so 12–16 items don't stack past the screen.
   Food panels keep their single-column layout WITH descriptions. */
@media (max-width: 760px) {
  .menu-cols--drinks { grid-template-columns: 1fr 1fr; gap: var(--space-4); }
  .menu-cols--drinks .menu-item { padding: 0.3rem 0; }
  .menu-cols--drinks .menu-item__name { font-size: 0.8rem; line-height: 1.2; }
  .menu-cols--drinks .menu-item__price { font-size: 0.72rem; }
  .menu-cols--drinks .menu-item__desc,
  .menu-cols--drinks .menu-cat__sizes { display: none; }
  .menu-cols--drinks .menu-cat__title { font-size: var(--text-base); }
}

/* ---- Section index number watermark ---- */
.panel__no {
  position: absolute;
  top: calc(var(--nav-h) + var(--space-4));
  left: var(--panel-pad);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider);
  color: var(--color-text-faint);
}
