/* ============================================================
   OOLIO — Kitchen · Bar · Oil
   Warm editorial minimalism × Apple-inspired motion
   ============================================================ */

:root {
  /* Official OOLIO brand palette */
  --verde: #3F4D1E;       /* Verde Antico — primary */
  --olive-night: #1B2014; /* darkest surface */
  --base: #ECECEC;        /* light neutral */
  --tuscany: #E6D7BF;     /* warm sand neutral */
  --chianti: #8A2A2C;     /* accent red */

  /* legacy names remapped onto the brand palette */
  --burgundy: var(--olive-night);
  --espresso: #1E2417;
  --cream: #F4ECDC;
  --cream-2: #FBF6EC;
  --terracotta: var(--chianti);
  --ochre: #8C7A43;

  --btn-bg: var(--verde);
  --hero-overlay: 0.42;
  --radius: 18px;
  --radius-sm: 12px;

  --font-display: "Poppins", "Helvetica Neue", sans-serif;
  --font-body: "Karla", "Helvetica Neue", sans-serif;
  --font-wordmark: "Fredoka", "Poppins", "Helvetica Neue", sans-serif;

  /* Apple-style easing + timing */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-std: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-emph: cubic-bezier(0.2, 0, 0, 1);
  --dur-quick: 180ms;
  --dur-base: 320ms;
  --dur-slow: 800ms;

  /* layered, Apple-style material depth (ambient + key + contact) */
  --shadow-soft:
    0 1px 1px rgba(43, 33, 24, 0.04),
    0 6px 16px -10px rgba(43, 33, 24, 0.18),
    0 22px 48px -28px rgba(43, 33, 24, 0.24);
  --shadow-lift:
    0 2px 3px rgba(43, 33, 24, 0.06),
    0 14px 30px -14px rgba(43, 33, 24, 0.22),
    0 40px 80px -36px rgba(43, 33, 24, 0.34);
  /* hairline border + faint top highlight for a "lit-from-above" card surface */
  --hairline: color-mix(in srgb, var(--espresso), transparent 91%);
  --card-highlight: inset 0 1px 0 color-mix(in srgb, #fff, transparent 35%);

  --ease-spring: cubic-bezier(0.34, 1.4, 0.5, 1);
}

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  background: var(--cream);
  color: var(--espresso);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }
a { color: inherit; }

.container {
  width: min(100% - 3rem, 1180px);
  margin-inline: auto;
}
.container-narrow { width: min(100% - 3rem, 760px); margin-inline: auto; }

section { scroll-margin-top: 5.5rem; }

/* ---------- scroll progress bar ---------- */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  width: 100%;
  transform: scaleX(0);
  transform-origin: 0 50%;
  background: linear-gradient(90deg, var(--ochre), var(--terracotta), var(--burgundy));
  z-index: 200;
  will-change: transform;
}

/* ---------- ambient warm glow ---------- */
.ambient {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.ambient span {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.16;
  will-change: transform;
}
.ambient span:nth-child(1) { width: 46vw; height: 46vw; left: -10vw; top: 12vh; background: var(--ochre); animation: drift1 26s ease-in-out infinite; }
.ambient span:nth-child(2) { width: 38vw; height: 38vw; right: -8vw; top: 48vh; background: var(--terracotta); opacity: 0.1; animation: drift2 32s ease-in-out infinite; }
@keyframes drift1 { 0%,100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(40px,-30px,0); } }
@keyframes drift2 { 0%,100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(-50px,30px,0); } }

/* ---------- type helpers ---------- */
.kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ochre);
}
.kicker::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--terracotta);
}
.kicker.center { justify-content: center; }

h1, h2, h3 {
  font-family: var(--font-display);
  line-height: 1.08;
  letter-spacing: -0.02em;
  text-wrap: balance;
}

.section-title {
  font-size: clamp(2rem, 4.6vw, 3.2rem);
  font-weight: 700;
  color: var(--burgundy);
  margin-top: 0.9rem;
  letter-spacing: -0.03em;
}

.gold-rule {
  width: 56px; height: 2px;
  background: var(--ochre);
  border: none;
  margin: 1.4rem 0;
}
.gold-rule.centered { margin-inline: auto; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 1rem 1.9rem;
  border: 1.5px solid transparent;
  border-radius: 999px;
  cursor: pointer;
  transition: transform var(--dur-quick) var(--ease-std),
              background-color var(--dur-base) var(--ease-std),
              color var(--dur-base) var(--ease-std),
              border-color var(--dur-base) var(--ease-std),
              box-shadow var(--dur-base) var(--ease-std);
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn-solid {
  background: var(--btn-bg);
  color: var(--cream);
  box-shadow: 0 12px 28px -12px color-mix(in srgb, var(--btn-bg), transparent 30%);
}
.btn-solid:hover {
  background: color-mix(in oklab, var(--btn-bg), black 12%);
  box-shadow: 0 18px 36px -14px color-mix(in srgb, var(--btn-bg), transparent 20%);
}

.btn-outline {
  background: color-mix(in srgb, var(--cream), transparent 92%);
  color: var(--cream);
  border-color: color-mix(in srgb, var(--cream), transparent 55%);
  backdrop-filter: blur(6px);
}
.btn-outline:hover {
  border-color: var(--cream);
  background: color-mix(in srgb, var(--cream), transparent 82%);
}

.btn-outline-dark {
  background: transparent;
  color: var(--burgundy);
  border-color: color-mix(in srgb, var(--burgundy), transparent 55%);
}
.btn-outline-dark:hover {
  border-color: var(--burgundy);
  background: color-mix(in srgb, var(--burgundy), transparent 93%);
}

/* ---------- header (floating pill) ---------- */
.site-header {
  position: fixed;
  inset: 0.9rem 0 auto 0;
  z-index: 100;
  display: flex;
  flex-direction: column;
  align-items: center;
  pointer-events: none;
  transition: inset var(--dur-base) var(--ease-std);
}
.site-header .nav-pill {
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.4rem;
  width: min(100% - 1.6rem, 1180px);
  height: 3.9rem;
  padding: 0 0.6rem 0 1.4rem;
  border-radius: 999px;
  color: var(--cream);
  border: 1px solid transparent;
  transition: background-color var(--dur-base) var(--ease-std),
              color var(--dur-base) var(--ease-std),
              border-color var(--dur-base) var(--ease-std),
              box-shadow var(--dur-base) var(--ease-std),
              backdrop-filter var(--dur-base) var(--ease-std);
}
.site-header.scrolled .nav-pill {
  background: color-mix(in srgb, var(--cream), transparent 12%);
  color: var(--espresso);
  border-color: color-mix(in srgb, var(--espresso), transparent 90%);
  box-shadow: 0 10px 30px -16px rgba(43, 33, 24, 0.45);
  backdrop-filter: blur(16px) saturate(150%);
}

.brand { display: flex; flex-direction: column; align-items: center; text-decoration: none; line-height: 1; }
.brand-word { font-family: var(--font-wordmark); font-weight: 600; font-size: 1.5rem; letter-spacing: 0.02em; }
/* real OOLIO wordmark — inline SVG, inherits text color via currentColor */
.logo-mark { display: block; height: 1em; width: auto; fill: currentColor; }
/* hero + footer wordmarks are centered within their centered text blocks */
.hero-wordmark .logo-mark { margin-inline: auto; }
.brand-sub {
  font-family: var(--font-display); font-size: 0.5rem; font-weight: 500;
  letter-spacing: 0.42em; text-transform: uppercase; margin-top: 0.26rem; opacity: 0.75;
  text-align: center; text-indent: 0.42em; /* offset trailing letter-spacing for true centering */
}

.main-nav { display: none; gap: 1.9rem; }
.main-nav a {
  position: relative;
  font-family: var(--font-display);
  font-size: 0.72rem; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase;
  text-decoration: none; opacity: 0.85;
  transition: opacity var(--dur-quick) var(--ease-std);
}
.main-nav a::after {
  content: ""; position: absolute; left: 0; bottom: -6px;
  width: 100%; height: 1.5px; background: var(--terracotta);
  transform: scaleX(0); transform-origin: 0 50%;
  transition: transform var(--dur-base) var(--ease-out);
}
.main-nav a:hover { opacity: 1; }
.main-nav a:hover::after { transform: scaleX(1); }

.header-cta { padding: 0.65rem 1.25rem; font-size: 0.68rem; }

/* ---------- hamburger toggle ---------- */
.nav-toggle {
  display: none;
  flex: none;
  width: 2.6rem; height: 2.6rem;
  margin-right: 0.4rem;
  padding: 0;
  background: none; border: none; cursor: pointer;
  flex-direction: column; align-items: center; justify-content: center; gap: 5px;
}
.nav-toggle span {
  display: block; width: 22px; height: 2px; border-radius: 2px;
  background: currentColor;
  transition: transform var(--dur-base) var(--ease-out), opacity var(--dur-quick) var(--ease-std);
}
.site-header.menu-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.site-header.menu-open .nav-toggle span:nth-child(2) { opacity: 0; }
.site-header.menu-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---------- mobile dropdown menu ---------- */
.mobile-menu {
  pointer-events: none;
  width: min(100% - 1.6rem, 1180px);
  margin-top: 0.55rem;
  display: flex; flex-direction: column;
  padding: 0.6rem;
  border-radius: 22px;
  background: color-mix(in srgb, var(--cream), transparent 6%);
  backdrop-filter: blur(18px) saturate(150%);
  border: 1px solid color-mix(in srgb, var(--espresso), transparent 88%);
  box-shadow: 0 18px 50px -20px rgba(43, 33, 24, 0.5);
  opacity: 0; visibility: hidden;
  transform: translateY(-10px) scale(0.98); transform-origin: top center;
  transition: opacity var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out),
              visibility 0s linear var(--dur-base);
}
.site-header.menu-open .mobile-menu {
  pointer-events: auto;
  opacity: 1; visibility: visible;
  transform: none;
  transition: opacity var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out),
              visibility 0s;
}
.mobile-menu a:not(.btn) {
  font-family: var(--font-display);
  font-size: 0.95rem; font-weight: 500;
  letter-spacing: 0.04em; color: var(--espresso);
  text-decoration: none;
  padding: 0.95rem 1rem; border-radius: 14px;
  transition: background-color var(--dur-quick) var(--ease-std), color var(--dur-quick) var(--ease-std);
}
.mobile-menu a:not(.btn):hover,
.mobile-menu a:not(.btn):active { background: color-mix(in srgb, var(--burgundy), transparent 92%); color: var(--burgundy); }
.mobile-menu a + a:not(.btn) { border-top: 1px solid color-mix(in srgb, var(--espresso), transparent 92%); }
.mobile-menu .mobile-cta { margin-top: 0.6rem; width: 100%; }

/* ---------- responsive header switch ---------- */
@media (min-width: 900px) {
  .main-nav { display: flex; }
  .nav-toggle { display: none; }
  .mobile-menu { display: none; }
}
@media (max-width: 899px) {
  .header-cta { display: none; }
  .nav-toggle { display: inline-flex; }
}

/* ---------- hero ---------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--cream);
  overflow: hidden;
  isolation: isolate;
}
.hero-bg {
  position: absolute;
  inset: -18% 0;
  background: url("images/photos/storefront-dusk.webp") center / cover no-repeat;
  z-index: -2;
  will-change: transform;
}
/* hero photo slideshow (parallax on wrapper, Ken Burns zoom on slides) */
.hero-slides {
  position: absolute;
  inset: -18% 0;
  z-index: -2;
  overflow: hidden;
  will-change: transform;
}
.hero-slide {
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  opacity: 0;
  transform: scale(1.04);
  transition: opacity 1.6s var(--ease-out);
  will-change: opacity, transform;
}
.hero-slide.is-active {
  opacity: 1;
  animation: heroZoom 9s var(--ease-out) forwards;
}
@keyframes heroZoom {
  from { transform: scale(1.02); }
  to   { transform: scale(1.14); }
}
.hero::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(to bottom,
      rgb(18 22 12 / calc(var(--hero-overlay) - 0.1)) 0%,
      rgb(18 22 12 / var(--hero-overlay)) 45%,
      rgb(18 22 12 / calc(var(--hero-overlay) + 0.22)) 100%);
  z-index: -1;
}
.hero-inner { padding: 7rem 1.5rem 6rem; max-width: 54rem; }
.hero-label {
  font-family: var(--font-display);
  font-size: clamp(0.68rem, 1.4vw, 0.82rem);
  font-weight: 500; letter-spacing: 0.5em; text-transform: uppercase;
  color: color-mix(in srgb, var(--cream), transparent 12%);
}
.hero-wordmark {
  font-family: var(--font-wordmark);
  font-size: clamp(4.4rem, 16vw, 10.5rem);
  font-weight: 600; letter-spacing: 0.01em;
  margin: 0.8rem 0 0.6rem; color: #FBF4E6;
  line-height: 0.92;
  /* warm lit-sign glow, echoing the storefront sign */
  text-shadow:
    0 0 1px rgba(255, 246, 224, 0.9),
    0 0 22px rgba(247, 228, 184, 0.45),
    0 0 60px rgba(183, 143, 78, 0.35);
}
.hero-subline {
  font-size: clamp(1rem, 2.2vw, 1.3rem);
  letter-spacing: 0.02em;
  color: color-mix(in srgb, var(--cream), transparent 6%);
}
.hero-ctas { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.9rem; margin-top: 2.6rem; }

.scroll-cue {
  position: absolute; bottom: 1.8rem; left: 50%; transform: translateX(-50%);
  z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  font-family: var(--font-display); font-size: 0.6rem; letter-spacing: 0.32em;
  text-transform: uppercase; color: color-mix(in srgb, var(--cream), transparent 35%);
}
.scroll-cue .dot {
  width: 22px; height: 36px; border: 1.5px solid color-mix(in srgb, var(--cream), transparent 55%);
  border-radius: 999px; position: relative;
}
.scroll-cue .dot::after {
  content: ""; position: absolute; top: 7px; left: 50%; transform: translateX(-50%);
  width: 3px; height: 7px; border-radius: 999px; background: var(--cream);
  animation: cue 1.8s var(--ease-out) infinite;
}
@keyframes cue { 0% { opacity: 0; transform: translate(-50%, 0); } 40% { opacity: 1; } 100% { opacity: 0; transform: translate(-50%, 12px); } }

/* hero entrance */
.hero-inner > * { opacity: 0; transform: translateY(26px); animation: heroUp 1s var(--ease-out) forwards; }
.hero-inner > *:nth-child(1) { animation-delay: 0.15s; }
.hero-inner > *:nth-child(2) { animation-delay: 0.28s; }
.hero-inner > *:nth-child(3) { animation-delay: 0.42s; }
.hero-inner > *:nth-child(4) { animation-delay: 0.56s; }
@keyframes heroUp { to { opacity: 1; transform: none; } }

/* ---------- generic section wrap + reveal ---------- */
.block { position: relative; z-index: 1; }
.reveal { opacity: 0; transform: translateY(30px); filter: blur(7px); transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out), filter var(--dur-slow) var(--ease-out); }
.reveal.is-visible { opacity: 1; transform: none; filter: none; }
.stagger > * { opacity: 0; transform: translateY(26px); filter: blur(6px); transition: opacity 0.75s var(--ease-out), transform 0.75s var(--ease-out), filter 0.75s var(--ease-out); }
.stagger.is-visible > * { opacity: 1; transform: none; filter: none; }
.stagger.is-visible > *:nth-child(2) { transition-delay: 0.08s; }
.stagger.is-visible > *:nth-child(3) { transition-delay: 0.16s; }
.stagger.is-visible > *:nth-child(4) { transition-delay: 0.24s; }
.stagger.is-visible > *:nth-child(5) { transition-delay: 0.32s; }
.stagger.is-visible > *:nth-child(6) { transition-delay: 0.40s; }

/* ---------- concept ---------- */
.concept { padding: clamp(5rem, 10vw, 8rem) 0 clamp(2.5rem, 5vw, 4rem); text-align: center; }
.concept .container-narrow > p {
  font-size: clamp(1.1rem, 2vw, 1.32rem);
  color: color-mix(in srgb, var(--espresso), transparent 12%);
}
.concept .container-narrow > p + p { margin-top: 1.2rem; }

/* full-bleed parallax image band */
.image-band {
  position: relative;
  height: clamp(360px, 56vh, 640px);
  margin: clamp(3rem, 6vw, 5.5rem) 0;
  overflow: hidden;
}
.image-band .band-img {
  position: absolute; inset: -18% 0;
  background-size: cover; background-position: center;
  will-change: transform;
}
.image-band::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgb(24 10 8 / 0.45), rgb(24 10 8 / 0.05)); }
.image-band .band-caption {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: clamp(1.5rem, 4vw, 3rem);
  z-index: 1; color: var(--cream);
}
.image-band .band-caption h3 {
  font-size: clamp(1.6rem, 3.6vw, 2.6rem); font-weight: 700; color: #fff; max-width: 18ch;
}
.image-band .band-caption p { margin-top: 0.5rem; color: color-mix(in srgb, var(--cream), transparent 20%); max-width: 42ch; }

/* ---------- pillars ---------- */
.pillars { padding: clamp(4.5rem, 9vw, 7rem) 0; }
.pillars-head { max-width: 36rem; }
.pillar-grid { display: grid; gap: 1.3rem; margin-top: 2.8rem; }
.pillar {
  background: var(--cream-2);
  border: 1px solid color-mix(in srgb, var(--espresso), transparent 90%);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.pillar:hover { transform: translateY(-6px); box-shadow: var(--shadow-lift); }
.pillar-media { position: relative; aspect-ratio: 16 / 11; overflow: hidden; }
.pillar-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease-out); }
.pillar:hover .pillar-media img { transform: scale(1.06); }
.pillar-num {
  position: absolute; top: 0.9rem; left: 0.9rem;
  font-family: var(--font-display); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.3em;
  color: var(--cream); background: color-mix(in srgb, var(--burgundy), transparent 12%);
  padding: 0.35rem 0.7rem; border-radius: 999px; backdrop-filter: blur(4px);
}
.pillar-body { padding: 1.6rem 1.6rem 2rem; }
.pillar-body h3 { font-size: 1.35rem; font-weight: 600; color: var(--burgundy); margin-bottom: 0.6rem; }
.pillar-body p { font-size: 0.98rem; color: color-mix(in srgb, var(--espresso), transparent 22%); }
@media (min-width: 600px) { .pillar-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .pillar-grid { grid-template-columns: repeat(3, 1fr); } }

/* ---------- menu ---------- */
.menu { padding: clamp(4.5rem, 9vw, 7.5rem) 0; text-align: center; }
.menu-tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.4rem; margin: 2.6rem auto 0.5rem; }
.menu-tab {
  appearance: none; background: none; border: none;
  font-family: var(--font-display); font-size: 0.78rem; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: color-mix(in srgb, var(--espresso), transparent 45%);
  padding: 0.6rem 1.1rem; border-radius: 999px; cursor: pointer;
  transition: color var(--dur-quick) var(--ease-std), background-color var(--dur-quick) var(--ease-std);
}
.menu-tab:hover { color: var(--espresso); }
.menu-tab[aria-selected="true"] { color: var(--cream); background: var(--burgundy); }
.menu-panel { max-width: 40rem; margin: 2.4rem auto 0; text-align: left; }
.menu-panel[hidden] { display: none; }
.menu-panel:not([hidden]) { animation: panelIn 0.5s var(--ease-out); }
@keyframes panelIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
.dish { padding: 1.25rem 0; }
.dish + .dish { border-top: 1px solid color-mix(in srgb, var(--espresso), transparent 88%); }
.dish-line { display: flex; align-items: baseline; gap: 0.75rem; }
.dish-name { font-family: var(--font-display); font-weight: 600; font-size: 1.06rem; color: var(--burgundy); }
.dish-leader { flex: 1; border-bottom: 1px dotted color-mix(in srgb, var(--ochre), transparent 35%); transform: translateY(-4px); }
.dish-price { font-family: var(--font-display); font-weight: 600; color: var(--espresso); }
.dish-desc { font-size: 0.93rem; color: color-mix(in srgb, var(--espresso), transparent 30%); margin-top: 0.3rem; max-width: 32rem; }
.menu-download { margin-top: 2.8rem; }

/* ---------- gallery ---------- */
.gallery { padding: clamp(4rem, 9vw, 7rem) 0; }
.gallery-head { text-align: center; margin-bottom: 2.8rem; }
.gallery-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.9rem; }
.gallery-item {
  position: relative; width: 100%; aspect-ratio: 1 / 1;
  overflow: hidden; border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--espresso), transparent 92%);
}
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease-out); }
.gallery-item figcaption {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 1.4rem 1.1rem 1rem;
  font-family: var(--font-display); font-size: 0.78rem; font-weight: 600;
  letter-spacing: 0.04em; color: var(--cream);
  background: linear-gradient(to top, rgb(24 10 8 / 0.72), transparent);
  opacity: 0; transform: translateY(8px);
  transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.gallery-item:hover img { transform: scale(1.07); }
.gallery-item:hover figcaption { opacity: 1; transform: none; }
@media (min-width: 760px) {
  .gallery-grid { grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
  .gallery-item { aspect-ratio: 4 / 5; }
  .gallery-item.tall { grid-row: span 2; aspect-ratio: auto; }
}

/* ---------- location ---------- */
.location { padding: clamp(4rem, 9vw, 7rem) 0; }
.location-grid { display: grid; gap: 2.75rem; margin-top: 2.6rem; }
.map-embed {
  width: 100%; aspect-ratio: 4 / 3; border-radius: var(--radius);
  border: 1px solid color-mix(in srgb, var(--espresso), transparent 85%);
  overflow: hidden; box-shadow: var(--shadow-soft);
}
.map-embed iframe, .map-embed .map-canvas { width: 100%; height: 100%; border: 0; display: block; }
.map-embed .map-canvas { background: #e9e2d4; }
.map-embed .leaflet-container { font-family: var(--font-body); }
.map-link {
  display: inline-flex; align-items: center; gap: 0.4rem;
  margin-top: 0.9rem;
  font-family: var(--font-display); font-size: 0.74rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--burgundy); text-decoration: none;
  border-bottom: 1.5px solid color-mix(in srgb, var(--ochre), transparent 40%);
  padding-bottom: 2px;
  transition: border-color var(--dur-quick) var(--ease-std), color var(--dur-quick) var(--ease-std);
}
.map-link:hover { color: var(--terracotta); border-color: var(--terracotta); }
.map-link::after { content: "↗"; font-size: 0.9em; }
.location-address { font-style: normal; font-size: 1.04rem; }
.location-address strong { font-family: var(--font-display); font-weight: 600; color: var(--burgundy); }
.hours-table { width: 100%; border-collapse: collapse; margin-top: 1.6rem; }
.hours-table th, .hours-table td {
  text-align: left; padding: 0.7rem 0;
  border-bottom: 1px solid color-mix(in srgb, var(--espresso), transparent 88%);
  font-size: 0.97rem; vertical-align: top;
}
.hours-table th { font-family: var(--font-display); font-weight: 600; color: var(--burgundy); padding-right: 1.5rem; white-space: nowrap; }
.hours-table td span { display: block; font-size: 0.85rem; color: color-mix(in srgb, var(--espresso), transparent 40%); }
.location-note { margin-top: 1.7rem; display: grid; gap: 1.1rem; }
.location-note h4 {
  font-family: var(--font-display); font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.24em; text-transform: uppercase; color: var(--ochre); margin-bottom: 0.25rem;
}
.location-note p { font-size: 0.95rem; color: color-mix(in srgb, var(--espresso), transparent 20%); }
@media (min-width: 900px) { .location-grid { grid-template-columns: 1.1fr 1fr; gap: 4rem; align-items: start; } }

/* ---------- reservation (full-bleed) ---------- */
.reserve {
  position: relative;
  text-align: center;
  color: var(--cream);
  padding: clamp(6rem, 13vw, 10rem) 0;
  overflow: hidden;
  isolation: isolate;
}
.reserve-bg {
  position: absolute; inset: -18% 0; z-index: -2;
  background: url("images/photos/storefront-dusk.webp") center / cover no-repeat, var(--burgundy);
  will-change: transform;
}
.reserve::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(to bottom, color-mix(in srgb, var(--burgundy), transparent 18%), color-mix(in srgb, var(--espresso), transparent 22%));
}
.reserve h2 { font-size: clamp(2.2rem, 5.6vw, 3.8rem); font-weight: 700; color: #fff; max-width: 22ch; margin-inline: auto; }
.reserve p { margin: 1.2rem auto 0; max-width: 38rem; color: color-mix(in srgb, var(--cream), transparent 14%); }
.reserve-ctas { display: flex; flex-direction: column; align-items: center; gap: 1.1rem; margin-top: 2.6rem; }
.reserve-phone {
  font-family: var(--font-display); font-size: 0.96rem; font-weight: 500; letter-spacing: 0.06em;
  color: color-mix(in srgb, var(--cream), transparent 10%); text-decoration-color: var(--ochre); text-underline-offset: 5px;
}

/* ---------- footer ---------- */
.site-footer { background: var(--espresso); color: color-mix(in srgb, var(--cream), transparent 25%); padding: 4.5rem 0 2.5rem; font-size: 0.93rem; position: relative; z-index: 1; }
.footer-grid { display: grid; gap: 2.5rem; }
.footer-brand { display: inline-flex; flex-direction: column; align-items: center; }
.footer-brand .brand-word { font-family: var(--font-wordmark); font-weight: 600; color: var(--cream); font-size: 1.7rem; letter-spacing: 0.02em; }
.footer-brand .brand-sub { color: var(--ochre); opacity: 1; }
.footer-col h4 { font-family: var(--font-display); font-size: 0.7rem; font-weight: 600; letter-spacing: 0.26em; text-transform: uppercase; color: var(--ochre); margin-bottom: 0.9rem; }
.footer-col ul { list-style: none; display: grid; gap: 0.45rem; }
.footer-col a { text-decoration: none; transition: color var(--dur-quick) var(--ease-std); }
.footer-col a:hover { color: var(--cream); }
.footer-col address { font-style: normal; }
.lang-switch { display: inline-flex; align-items: center; gap: 0.6rem; font-family: var(--font-display); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.12em; }
.lang-switch .active { color: var(--cream); }
.lang-switch .divider { color: color-mix(in srgb, var(--cream), transparent 65%); }
.lang-switch button { appearance: none; background: none; border: none; font: inherit; letter-spacing: inherit; color: color-mix(in srgb, var(--cream), transparent 50%); cursor: pointer; transition: color var(--dur-quick) var(--ease-std); }
.lang-switch button:hover { color: var(--cream); }
.footer-bottom { margin-top: 3rem; padding-top: 1.5rem; border-top: 1px solid color-mix(in srgb, var(--cream), transparent 88%); display: flex; flex-wrap: wrap; gap: 0.5rem 2rem; justify-content: space-between; font-size: 0.82rem; color: color-mix(in srgb, var(--cream), transparent 50%); }
@media (min-width: 760px) { .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; } }

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; }
  .reveal, .stagger > *, .hero-inner > * { opacity: 1 !important; transform: none !important; filter: none !important; }
  .cursor-glow { display: none !important; }
  .hero-wordmark, .hero-wordmark .logo-mark { animation: none !important; }
  .hero-slide { animation: none !important; transform: none !important; }
  .hero-slide.is-active { opacity: 1 !important; }
}

/* ============================================================
   EXTRA EFFECTS — premium micro-interactions
   ============================================================ */

/* hero content pointer-parallax smoothing */
.hero-inner { transition: transform 0.35s var(--ease-out); }

/* cursor spotlight (desktop pointer only) */
.cursor-glow {
  position: fixed; top: 0; left: 0; z-index: 90;
  width: 460px; height: 460px; margin: -230px 0 0 -230px;
  border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle, color-mix(in srgb, var(--ochre), transparent 70%) 0%, transparent 62%);
  mix-blend-mode: soft-light; opacity: 0;
  transition: opacity 0.4s var(--ease-std);
  will-change: transform; display: none;
}
@media (hover: hover) and (pointer: fine) {
  .cursor-glow { display: block; }
}

/* hero lit-sign breathing + occasional flicker (keeps the heroUp entrance) */
.hero .hero-wordmark { animation: heroUp 1s var(--ease-out) 0.28s forwards; }
/* warm lit-sign glow that gently breathes — drop-shadow works on the SVG mark */
.hero-wordmark .logo-mark {
  filter: drop-shadow(0 0 18px rgba(247,228,184,0.40)) drop-shadow(0 0 48px rgba(183,143,78,0.30));
  animation: signBreathe 5.5s var(--ease-std) 1.8s infinite;
}
@keyframes signBreathe {
  0%, 100% { filter: drop-shadow(0 0 16px rgba(247,228,184,0.40)) drop-shadow(0 0 50px rgba(183,143,78,0.30)); }
  45%      { filter: drop-shadow(0 0 26px rgba(247,228,184,0.60)) drop-shadow(0 0 72px rgba(183,143,78,0.45)); }
  92%      { filter: drop-shadow(0 0 16px rgba(247,228,184,0.40)) drop-shadow(0 0 50px rgba(183,143,78,0.30)); }
  94%      { filter: drop-shadow(0 0 6px rgba(247,228,184,0.18))  drop-shadow(0 0 20px rgba(183,143,78,0.12)); }
  96%      { filter: drop-shadow(0 0 26px rgba(247,228,184,0.60)) drop-shadow(0 0 72px rgba(183,143,78,0.45)); }
}

/* glossy sheen sweep on solid buttons */
.btn-solid { position: relative; overflow: hidden; }
.btn-solid::after {
  content: ""; position: absolute; top: 0; left: -120%;
  width: 70%; height: 100%; pointer-events: none;
  background: linear-gradient(105deg, transparent, rgba(255,255,255,0.38), transparent);
  transform: skewX(-18deg);
  transition: left 0.7s var(--ease-out);
}
.btn-solid:hover::after { left: 130%; }

/* animated gold rule draw-in */
.gold-rule { transform: scaleX(0); transform-origin: 50% 50%; transition: transform 0.9s var(--ease-out) 0.15s; }
.reveal.is-visible .gold-rule, .is-visible.gold-rule { transform: scaleX(1); }

/* kicker dot pulse */
.kicker::before { animation: dotPulse 2.6s var(--ease-std) infinite; }
@keyframes dotPulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--terracotta), transparent 30%); }
  60%      { box-shadow: 0 0 0 6px color-mix(in srgb, var(--terracotta), transparent 100%); }
}

/* pillar cursor spotlight + lift glow */
.pillar { position: relative; }
.pillar::before {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  border-radius: var(--radius);
  background: radial-gradient(220px circle at var(--mx, 50%) var(--my, 0%), color-mix(in srgb, var(--ochre), transparent 78%), transparent 60%);
  opacity: 0; transition: opacity var(--dur-base) var(--ease-std);
}
.pillar:hover::before { opacity: 1; }
.pillar:hover { box-shadow: var(--shadow-lift), 0 0 0 1px color-mix(in srgb, var(--ochre), transparent 60%); }
.pillar-body, .pillar-media { position: relative; z-index: 2; }

/* gallery 3D tilt (transform set inline via JS) + shine */
.gallery-item:hover { box-shadow: var(--shadow-lift); z-index: 3; }
.gallery-item::after {
  content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  border-radius: inherit;
  background: radial-gradient(300px circle at var(--gx, 50%) var(--gy, 50%), rgba(255,255,255,0.22), transparent 55%);
  opacity: 0; transition: opacity var(--dur-base) var(--ease-std);
}
.gallery-item:hover::after { opacity: 1; }

/* map hover lift */
.map-embed { transition: box-shadow var(--dur-base) var(--ease-out); }
.map-embed:hover { box-shadow: var(--shadow-lift); }

/* nav links + footer link subtle slide already exist; add reserve phone glow */
.reserve-phone { transition: color var(--dur-base) var(--ease-std), text-shadow var(--dur-base) var(--ease-std); }
.reserve-phone:hover { color: #fff; text-shadow: 0 0 18px rgba(247,228,184,0.5); }

/* ---------- directional reveal variants (reuse the IntersectionObserver) ---------- */
/* Translate stays within the container's 1.5rem (24px) side margin so a not-yet-
   revealed element never pushes past the viewport (no horizontal overflow). */
.reveal.reveal--left  { transform: translateX(-20px); }
.reveal.reveal--right { transform: translateX(20px); }
.reveal.reveal--scale { transform: scale(0.94); }
/* Explicitly win over the variant transforms once revealed (equal specificity, so
   this must come after and be more specific) — otherwise they'd stay offset. */
.reveal.reveal--left.is-visible,
.reveal.reveal--right.is-visible,
.reveal.reveal--scale.is-visible { transform: none; }
/* Larger, more expressive slide only where the container has room (wide desktop). */
@media (min-width: 1280px) {
  .reveal.reveal--left  { transform: translateX(-40px); }
  .reveal.reveal--right { transform: translateX(40px); }
}

/* ---------- menu: panel switch animation + dish hover ---------- */
.menu-panel:not([hidden]) { animation: panelIn 0.5s var(--ease-out); }
@keyframes panelIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

.dish { transition: transform var(--dur-base) var(--ease-out); }
.dish:hover { transform: translateX(8px); }
.dish-name { transition: color var(--dur-quick) var(--ease-std); }
.dish:hover .dish-name { color: var(--terracotta); }
.dish-leader { transition: border-color var(--dur-base) var(--ease-std); }
.dish:hover .dish-leader { border-bottom-color: color-mix(in srgb, var(--terracotta), transparent 35%); }

/* ---------- footer columns lift slightly on hover ---------- */
.footer-col { transition: transform var(--dur-base) var(--ease-out); }
.footer-col:hover { transform: translateY(-4px); }

/* ============================================================
   MENU PAGE (speisekarte.html)
   ============================================================ */
.menu-hero {
  position: relative; isolation: isolate;
  min-height: 60vh; display: grid; place-items: center; text-align: center;
  color: var(--cream); overflow: hidden;
  padding: 8rem 1.5rem 4rem;
}
.menu-hero .hero-bg,
.menu-hero .hero-slide {
  position: absolute; inset: -18% 0; z-index: -2;
  background: url("images/photos/dining-room.webp") center / cover no-repeat;
  will-change: transform;
}
.menu-hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(to bottom, rgb(18 22 12 / 0.55), rgb(18 22 12 / 0.7));
}
.menu-hero h1 {
  font-family: var(--font-wordmark); font-weight: 600;
  font-size: clamp(2.6rem, 7vw, 5rem); color: #FBF4E6; letter-spacing: 0.01em;
  text-shadow: 0 0 24px rgba(247,228,184,0.35);
}
.menu-hero p { margin-top: 0.8rem; color: color-mix(in srgb, var(--cream), transparent 12%); max-width: 38rem; }
.menu-hero .hero-label { margin-bottom: 0.4rem; }

/* sticky category sub-nav */
.subnav {
  position: sticky; top: 0; z-index: 40;
  display: flex; gap: 0.4rem; justify-content: center; flex-wrap: wrap;
  padding: 0.7rem 1rem;
  background: color-mix(in srgb, var(--cream), transparent 6%);
  backdrop-filter: blur(14px) saturate(150%);
  border-bottom: 1px solid color-mix(in srgb, var(--espresso), transparent 90%);
}
.subnav a {
  font-family: var(--font-display); font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase; text-decoration: none;
  color: color-mix(in srgb, var(--espresso), transparent 35%);
  padding: 0.45rem 0.9rem; border-radius: 999px;
  transition: background-color var(--dur-quick) var(--ease-std), color var(--dur-quick) var(--ease-std);
}
.subnav a:hover { background: color-mix(in srgb, var(--burgundy), transparent 90%); color: var(--burgundy); }

.menu-cat, .lunch, .drinks { scroll-margin-top: 7rem; }
.menu-cat { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.menu-cat + .menu-cat { border-top: 1px solid color-mix(in srgb, var(--espresso), transparent 92%); }
.menu-cat-head { text-align: center; max-width: 44rem; margin: 0 auto clamp(2rem,4vw,3rem); }
.menu-cat-head p.intro { margin-top: 0.8rem; color: color-mix(in srgb, var(--espresso), transparent 25%); }
.price-note { font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ochre); margin-top: 0.6rem; }

/* feature cards with photo */
.feature-grid { display: grid; grid-template-columns: 1fr; gap: 1.2rem; margin-bottom: 2.6rem; }
@media (min-width: 680px) { .feature-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .feature-grid.cols-3 { grid-template-columns: repeat(3, 1fr); } }
.feature-card {
  position: relative; overflow: hidden; border-radius: var(--radius);
  background: var(--cream-2); box-shadow: var(--shadow-soft);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.feature-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lift); }
.feature-card .fc-media { aspect-ratio: 4 / 3; overflow: hidden; }
.feature-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease-out); }
.feature-card:hover img { transform: scale(1.06); }
.fc-body { padding: 1.3rem 1.4rem 1.6rem; }
.fc-head { display: flex; align-items: baseline; gap: 0.75rem; }
.fc-name { font-family: var(--font-display); font-weight: 600; font-size: 1.08rem; color: var(--burgundy); }
.fc-dots { flex: 1; border-bottom: 1px dotted color-mix(in srgb, var(--ochre), transparent 35%); transform: translateY(-4px); }
.fc-price { font-family: var(--font-display); font-weight: 600; color: var(--espresso); }
.fc-desc { margin-top: 0.4rem; font-size: 0.92rem; color: color-mix(in srgb, var(--espresso), transparent 30%); }

/* plain dish list (reuses .dish from homepage) */
.dish-list { max-width: 46rem; margin: 0 auto; }
.dish-list.two-col { max-width: 64rem; }
@media (min-width: 820px) { .dish-list.two-col { columns: 2; column-gap: 3.5rem; } .dish-list.two-col .dish { break-inside: avoid; } }

/* lunch weeks */
.lunch { background: var(--burgundy); color: var(--cream); padding: clamp(4rem,8vw,6.5rem) 0; }
.lunch .section-title, .lunch .menu-cat-head p.intro { color: var(--cream); }
.lunch .menu-cat-head p.intro { color: color-mix(in srgb, var(--cream), transparent 20%); }
.lunch-grid { display: grid; grid-template-columns: 1fr; gap: 1.1rem; }
@media (min-width: 680px) { .lunch-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .lunch-grid { grid-template-columns: repeat(3, 1fr); } }
.lunch-card {
  border: 1px solid color-mix(in srgb, var(--cream), transparent 80%);
  border-radius: var(--radius); padding: 1.7rem 1.6rem 1.9rem;
  transition: transform var(--dur-base) var(--ease-out), background-color var(--dur-base) var(--ease-std);
}
.lunch-card:hover { transform: translateY(-5px); background: color-mix(in srgb, var(--cream), transparent 92%); }
.lunch-card .lc-num { font-family: var(--font-display); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.3em; color: var(--ochre); }
.lunch-card h3 { font-size: 1.25rem; font-weight: 600; margin: 0.9rem 0 0.5rem; }
.lunch-card p { font-size: 0.95rem; color: color-mix(in srgb, var(--cream), transparent 22%); }
.lunch-note { text-align: center; margin-top: 2.4rem; font-size: 0.95rem; color: color-mix(in srgb, var(--cream), transparent 22%); }

/* drinks signature cards (portrait photos) */
.drinks { padding: clamp(4rem,8vw,6.5rem) 0; }
.drinks-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.1rem; }
@media (min-width: 900px) { .drinks-grid { grid-template-columns: repeat(4, 1fr); } }
.drink-card { position: relative; overflow: hidden; border-radius: var(--radius); background: var(--cream-2); box-shadow: var(--shadow-soft);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.drink-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lift); }
.drink-card .dc-media { aspect-ratio: 3 / 4; overflow: hidden; }
.drink-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease-out); }
.drink-card:hover img { transform: scale(1.05); }
.dc-body { padding: 1.1rem 1.2rem 1.4rem; }
.dc-head { display: flex; align-items: baseline; justify-content: space-between; gap: 0.6rem; }
.dc-name { font-family: var(--font-display); font-weight: 600; font-size: 1rem; color: var(--burgundy); }
.dc-price { font-family: var(--font-display); font-weight: 600; color: var(--espresso); }
.dc-desc { margin-top: 0.35rem; font-size: 0.86rem; color: color-mix(in srgb, var(--espresso), transparent 32%); }

/* drinks text columns */
.drinks-lists { display: grid; grid-template-columns: 1fr; gap: 2.4rem; margin-top: 3rem; max-width: 64rem; margin-inline: auto; }
@media (min-width: 760px) { .drinks-lists { grid-template-columns: repeat(2, 1fr); gap: 3.5rem; } }
.drinks-lists h3 { font-family: var(--font-display); font-size: 0.74rem; font-weight: 600; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ochre); margin-bottom: 0.4rem; }

/* ============================================================
   Apple-grade card material + motion (less "AI", more crafted)
   Shared premium material; each card keeps its own hover accent.
   ============================================================ */
.pillar, .feature-card, .drink-card, .lunch-card, .map-embed { border: 1px solid var(--hairline); }
.pillar, .feature-card, .drink-card, .map-embed { box-shadow: var(--shadow-soft), var(--card-highlight); }
.pillar, .feature-card, .drink-card {
  transition: transform 0.55s var(--ease-spring), box-shadow 0.45s var(--ease-out);
}
.pillar:hover {
  transform: translateY(-7px) scale(1.012);
  box-shadow: var(--shadow-lift), var(--card-highlight), 0 0 0 1px color-mix(in srgb, var(--ochre), transparent 55%);
}
.feature-card:hover, .drink-card:hover {
  transform: translateY(-7px) scale(1.012);
  box-shadow: var(--shadow-lift), var(--card-highlight);
}
.lunch-card { transition: transform 0.55s var(--ease-spring), background-color var(--dur-base) var(--ease-std); }
.lunch-card:hover { transform: translateY(-7px) scale(1.012); }
.map-embed { box-shadow: var(--shadow-soft), var(--card-highlight); }
.map-embed:hover { box-shadow: var(--shadow-lift), var(--card-highlight); }
.gallery-item { box-shadow: var(--shadow-soft); transition: box-shadow 0.45s var(--ease-out); }

/* buttons: refined spring + tactile press */
.btn {
  transition: transform 0.4s var(--ease-spring),
              background-color var(--dur-base) var(--ease-std),
              color var(--dur-base) var(--ease-std),
              border-color var(--dur-base) var(--ease-std),
              box-shadow var(--dur-base) var(--ease-std);
}
.btn:hover { transform: translateY(-2px) scale(1.015); }
.btn:active { transform: translateY(0) scale(0.99); }

/* a touch of intentional asymmetry: nudge the candlelit band caption off-grid */
.image-band .band-caption h3 { letter-spacing: -0.02em; }
