/* ==========================================================================
   layout.css · Osteria del Lago
   Page-specific section layouts and responsive grid systems.
   ========================================================================== */

/* --- Global section rhythm --- */
section {
  padding-block: var(--space-2xl);
}

.section-head {
  max-width: 720px;
  margin-bottom: var(--space-xl);
}

.section-head .t-label {
  display: block;
  margin-bottom: 1rem;
}

.section-head .t-h2,
.section-head .t-display {
  margin-bottom: 1rem;
}

.section-head em {
  font-style: italic;
  color: var(--color-forest);
}

/* ==========================================================================
   HOMEPAGE · Hero (scroll-pinned scrollytelling stage)
   ========================================================================== */

/* The section is the scroll track. Base (no-JS / reduced-motion) keeps it
   to one viewport; JS adds .is-interactive to extend it into a pin. */
.hero {
  position: relative;
  min-height: 100dvh;
  padding-block: 0;        /* override the global section padding (no top gap) */
}

.hero__stage {
  position: relative;
  height: 100dvh;
  overflow: hidden;
}

/* Full-bleed video that stays put while the content animates over it */
.hero__video {
  position: absolute;
  inset: 0;
}

.hero__video-media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  /* zoom to fill the stage, cropping rather than stretching */
  object-fit: cover;
  object-position: center;
}

.hero__video-scrim {
  position: absolute;
  inset: 0;
  background: rgba(26, 26, 24, 0.32);
  pointer-events: none;
}

/* Overlay layer holding the centred intro and the slide-in form */
.hero__layer {
  position: absolute;
  inset: 0;
  z-index: 2;
}

.hero__intro {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(90vw, 760px);
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff;
  will-change: transform;
}

/* Generic hero text styles, reused by the Events page hero */
.hero__label {
  display: block;
  margin-bottom: 1.5rem;
}

.hero__title {
  margin-bottom: 1.5rem;
}

.hero__title em {
  font-style: italic;
  color: var(--color-forest);
}

.hero__lead {
  max-width: 480px;
  color: var(--color-ink-muted);
}

.hero__trust {
  margin-top: 1.5rem;
  font-size: 0.875rem;
  color: var(--color-ink-muted);
}

/* Homepage intro overrides: white text over the video */
.hero__intro .hero__title {
  margin-bottom: 0;
  color: #fff;
  text-shadow: 0 2px 30px rgba(0, 0, 0, 0.35);
}

.hero__intro .hero__title em {
  color: #fff;
}

.hero__subtitle {
  margin-top: 1.25rem;
  margin-inline: auto;
  max-width: 48ch;
  color: rgba(255, 255, 255, 0.85);
}

.hero__panel {
  position: absolute;
  top: 50%;
  left: 0;
  width: min(90vw, 420px);
  transform: translateY(-50%);
  padding-left: clamp(1.25rem, 4vw, 3rem);
  will-change: transform, opacity;
}

/* Reservation form panel */
.hero-reserve {
  background: rgba(247, 248, 245, 0.94);
  backdrop-filter: blur(14px) saturate(160%);
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  border: 1px solid var(--color-border);
  border-radius: 4px;
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.hero-reserve__eyebrow {
  display: block;
  margin-bottom: 0.25rem;
}

.hero-reserve__field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.hero-reserve__label {
  font-size: var(--t-label);
  font-weight: 500;
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-ink-muted);
}

.hero-reserve__input,
.hero-reserve__select {
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  border: none;
  background: transparent;
  border-bottom: 1px solid var(--color-border);
  padding: 0.375rem 0;
  color: var(--color-ink);
  width: 100%;
  transition: border-color var(--dur-fast) var(--ease-out-expo);
}

.hero-reserve__input:focus,
.hero-reserve__select:focus {
  outline: none;
  border-bottom-color: var(--color-forest);
}

.hero-reserve__submit {
  margin-top: 0.25rem;
  background: var(--color-forest);
  color: #fff;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 0.9375rem;
  border: none;
  border-radius: 3px;
  cursor: pointer;
  padding: 0.75rem 1.5rem;
  transition:
    background var(--dur-fast) var(--ease-out-expo),
    transform var(--dur-fast) var(--ease-out-expo);
}

.hero-reserve__submit:hover {
  background: var(--color-green);
  transform: translateY(-1px);
}

.hero-reserve__submit:active {
  transform: scale(0.98);
}

.hero-reserve__trust {
  font-size: 0.8125rem;
  color: var(--color-ink-muted);
  line-height: 1.45;
}

/* ---- Interactive (JS, motion allowed) ---- */
.hero.is-interactive {
  height: 250vh;       /* 100vh stage pinned + 150vh of scrub + release */
  min-height: 0;
}

.hero.is-interactive .hero__stage {
  position: sticky;
  top: 0;
}

/* The intro and panel are scrubbed via inline transforms from JS.
   Panel starts hidden until JS sets its progress. */
.hero.is-interactive .hero__panel {
  opacity: 0;
}

/* ---- Static fallback (no JS / reduced motion): readable two-up layout ---- */
.hero:not(.is-interactive) .hero__intro {
  top: 38%;
}

.hero:not(.is-interactive) .hero__panel {
  top: auto;
  bottom: clamp(1.5rem, 5vh, 4rem);
  transform: none;
}

/* ---- Hero on small screens: panel docks to the bottom, centred ---- */
@media (max-width: 900px) {
  .hero.is-interactive {
    height: 210vh;
  }

  .hero__intro {
    width: min(90vw, 560px);
  }

  .hero__panel {
    top: auto;
    bottom: clamp(1.5rem, 6vh, 3rem);
    left: 50%;
    width: min(92vw, 460px);
    padding-left: 0;
    transform: translateX(-50%);
  }

  .hero:not(.is-interactive) .hero__intro {
    top: 32%;
  }
}

/* ==========================================================================
   HOMEPAGE · Marquee section
   ========================================================================== */
.marquee-section {
  padding-block: 0;
}

/* ==========================================================================
   HOMEPAGE · Featured dishes
   ========================================================================== */
.dishes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  border: 1px solid var(--color-border);
}

.dishes-grid .dish-feature {
  padding: 1.5rem;
  background: var(--color-canvas);
  border-top: none;
}

.dishes-grid .dish-feature .dish-feature__divider {
  border-top: 2px solid var(--color-forest);
}

/* re-apply the top accent rule cleanly inside grid cells */
.dishes-grid .dish-feature {
  border-top: 2px solid var(--color-forest);
  display: flex;
  flex-direction: column;
}

/* push the dish image to the bottom so all three align across the row */
.dishes-grid .dish-feature__img {
  margin-top: auto;
}

/* ==========================================================================
   HOMEPAGE · About split
   ========================================================================== */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
}

.about-text .stats-row {
  margin-block: 2rem;
}

.about-media {
  position: relative;
  min-height: 520px;
}

.about-media__back {
  position: absolute;
  top: 0;
  right: 0;
  width: 72%;
  aspect-ratio: 4 / 5;
  transform-origin: center;
  will-change: transform;
}

.about-media__front {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 62%;
  aspect-ratio: 3 / 4;
  border: 6px solid var(--color-canvas);
  transform-origin: center;
  will-change: transform;
}

.about-media__back img,
.about-media__front img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ==========================================================================
   HOMEPAGE · Experience steps
   ========================================================================== */
.experience-section {
  background: var(--color-green-tint);
}

.experience-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.experience-step {
  padding: 0 1.5rem;
  border-right: 1px solid rgba(29, 74, 47, 0.15);
}

.experience-step:first-child {
  padding-left: 0;
}

.experience-step:last-child {
  border-right: none;
  padding-right: 0;
}

.experience-step__ordinal {
  display: block;
  margin-bottom: 1rem;
  color: var(--color-forest);
}

.experience-step__name {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  line-height: 1.2;
  margin-bottom: 0.75rem;
}

.experience-step__desc {
  font-size: 0.875rem;
  color: var(--color-ink-muted);
  line-height: 1.55;
}

/* ==========================================================================
   HOMEPAGE · Gallery section
   ========================================================================== */
.gallery-section {
  padding-block: 0;
}

/* ==========================================================================
   HOMEPAGE · Pull quote section
   ========================================================================== */
.pull-quote-section .pull-quote {
  max-width: 680px;
  margin-inline: auto;
}

/* ==========================================================================
   HOMEPAGE · Testimonials
   ========================================================================== */
.testimonials-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
}

.testimonials-media {
  aspect-ratio: 4 / 5;
  overflow: hidden;
}

.testimonials-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ==========================================================================
   MENU PAGE
   ========================================================================== */
.menu-hero {
  padding-block: calc(var(--space-3xl) + 80px) var(--space-xl);
}

.menu-hero__breadcrumb {
  margin-bottom: 1rem;
}

.menu-hero__lead {
  max-width: 560px;
  color: var(--color-ink-muted);
  margin-top: 1.25rem;
}

.menu-nav {
  position: sticky;
  top: 64px;
  background: rgba(247, 248, 245, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border);
  z-index: 50;
  padding-block: 1rem;
}

.menu-nav__list {
  display: flex;
  gap: 1.75rem;
  overflow-x: auto;
  scrollbar-width: none;
}

.menu-nav__list::-webkit-scrollbar {
  display: none;
}

.menu-nav__list a {
  font-size: 0.9375rem;
  color: var(--color-ink-muted);
  white-space: nowrap;
  padding-bottom: 0.35rem;
  border-bottom: 2px solid transparent;
  transition:
    color var(--dur-fast) var(--ease-out-expo),
    border-color var(--dur-fast) var(--ease-out-expo);
}

.menu-nav__list a.active {
  color: var(--color-forest);
  border-bottom-color: var(--color-forest);
}

.menu-section {
  padding-block: var(--space-xl);
  border-bottom: 1px solid var(--color-border);
  scroll-margin-top: 135px;
}

.menu-section:last-of-type {
  border-bottom: none;
}

.menu-section__head {
  margin-bottom: 1.5rem;
}

.menu-section__desc {
  color: var(--color-ink-muted);
  max-width: 560px;
  margin-top: 0.75rem;
}

.chef-note {
  background: var(--color-green-tint);
  border-left: 3px solid var(--color-forest);
  padding: 1.25rem 1.5rem;
  margin-block: 1.5rem;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--t-small);
  line-height: 1.6;
  color: var(--color-ink);
}

.wine-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 3rem;
}

.wine-grid__group h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 400;
  padding-bottom: 0.5rem;
  margin-bottom: 0.5rem;
  border-bottom: 2px solid var(--color-forest);
}

/* ==========================================================================
   RESERVATIONS PAGE
   ========================================================================== */
.reservations-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: start;
}

.reservation-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.field label {
  font-size: var(--t-label);
  font-weight: 500;
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-ink-muted);
}

.field input,
.field select,
.field textarea {
  border: none;
  border-bottom: 1px solid var(--color-border);
  padding: 0.75rem 0;
  font-size: 1rem;
  background: transparent;
  width: 100%;
  font-family: var(--font-sans);
  color: var(--color-ink);
  transition: border-color var(--dur-fast) var(--ease-out-expo);
}

.field textarea {
  resize: vertical;
  line-height: 1.5;
}

.field select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B6B66' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0 center;
  background-size: 18px;
  padding-right: 1.5rem;
  cursor: pointer;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-bottom-color: var(--color-forest);
}

.field.error input,
.field.error select,
.field.error textarea {
  border-bottom-color: var(--color-crimson);
}

.field__error {
  font-size: 0.8125rem;
  color: var(--color-crimson);
  min-height: 0;
  display: none;
}

.field.error .field__error {
  display: block;
}

.form-submit {
  width: 100%;
  justify-content: center;
  margin-top: 2rem;
}

.form-success {
  text-align: center;
  padding: var(--space-2xl) 1.5rem;
}

.form-success__icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 1.5rem;
  color: var(--color-forest);
}

.form-success__title {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  color: var(--color-ink);
  line-height: 1.3;
  max-width: 32ch;
  margin-inline: auto;
}

.reservation-info {
  position: sticky;
  top: 120px;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.reservation-info__img {
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

/* Real images filling their framed containers (cover, no distortion) */
.reservation-info__img img,
.story-aside__img img,
.team-member__img img,
.story-hero__media img,
.story-hero__media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story-hero__video {
  filter: grayscale(0.25);
}

.reservation-info__block h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 400;
  margin-bottom: 0.75rem;
}

.reservation-info__phone {
  font-family: var(--font-mono);
  font-size: 1.125rem;
  color: var(--color-crimson);
}

.faq-section {
  max-width: 760px;
}

/* ==========================================================================
   STORY PAGE
   ========================================================================== */
.story-hero {
  padding-top: 84px;
  padding-bottom: var(--space-2xl);
}

/* Full-bleed video hero: spans the full viewport width */
.story-hero__media {
  position: relative;
  width: 100%;
  height: 78vh;
  min-height: 460px;
  overflow: hidden;
}

.story-hero__media .img-placeholder {
  filter: grayscale(0.4);
}

.story-hero__overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding-block: 0 2.5rem;
  z-index: 2;
}

.story-hero__overlay .t-display {
  color: #fff;
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.4);
}

.story-hero__overlay .t-label {
  color: rgba(255, 255, 255, 0.85);
}

.story-hero__scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(26, 26, 24, 0.55) 0%, rgba(26, 26, 24, 0) 55%);
  z-index: 1;
  pointer-events: none;
}

.story-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: start;
}

/* ==========================================================================
   404 PAGE
   ========================================================================== */
.error-page {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-block: calc(var(--space-3xl) + 80px) var(--space-2xl);
}

.error-page__code {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-crimson);
  margin-bottom: 1.25rem;
}

.error-page__title {
  max-width: 16ch;
  margin-bottom: 1.25rem;
}

.error-page__title em {
  font-style: italic;
  color: var(--color-forest);
}

.error-page__lead {
  max-width: 48ch;
  color: var(--color-ink-muted);
  margin-bottom: 2.5rem;
}

.error-page__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

.story-prose p {
  margin-bottom: 1.5rem;
  color: var(--color-ink);
  line-height: var(--lh-body);
}

.story-prose p:first-child::first-letter {
  font-family: var(--font-serif);
  font-size: 3.25rem;
  line-height: 0.8;
  float: left;
  padding-right: 0.5rem;
  padding-top: 0.4rem;
  color: var(--color-forest);
}

.story-aside {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  position: sticky;
  top: 120px;
}

.story-aside__img {
  aspect-ratio: 4 / 5;
}

.beliefs-section {
  background: var(--color-green-tint);
}

.beliefs-list {
  display: grid;
  gap: 0;
  max-width: 760px;
}

.beliefs-list li {
  font-family: var(--font-serif);
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  line-height: 1.35;
  padding: 1.25rem 0;
  border-bottom: 1px solid rgba(29, 74, 47, 0.15);
  color: var(--color-ink);
}

.beliefs-list li:last-child {
  border-bottom: none;
}

.team-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
}

.team-member {
  border-top: 2px solid var(--color-forest);
  padding-top: 1.5rem;
}

.team-member__img {
  aspect-ratio: 4 / 5;
  margin-bottom: 1.5rem;
}

.team-member__name {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 400;
}

.team-member__role {
  font-size: var(--t-label);
  font-weight: 500;
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-forest);
  margin-top: 0.35rem;
  margin-bottom: 1rem;
  display: block;
}

.team-member__bio {
  color: var(--color-ink-muted);
  line-height: var(--lh-body);
}

/* ==========================================================================
   EVENTS PAGE
   ========================================================================== */
.events-hero {
  padding-block: var(--space-3xl) 0;
  min-height: 90dvh;
}

.events-hero__grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: var(--col-gap);
  align-items: stretch;
}

.events-hero__media {
  position: relative;
  overflow: hidden;
}

.events-hero__media .img-placeholder,
.events-hero__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.events-hero__text {
  padding-top: calc(var(--space-3xl) + 80px);
  padding-bottom: var(--space-2xl);
  max-width: 560px;
}

.events-hero__text .hero__title {
  margin-bottom: 1.75rem;
}

.events-hero__text .hero__lead {
  margin-bottom: 2.5rem;
}

.events-hero__text .btn-row {
  gap: 1rem;
}

.events-intro {
  max-width: 760px;
}

.events-intro p {
  font-size: var(--t-large);
  line-height: 1.55;
  color: var(--color-ink-muted);
}

.event-feature {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
  margin-bottom: var(--space-2xl);
}

.event-feature:last-child {
  margin-bottom: 0;
}

.event-feature:nth-child(even) {
  direction: rtl;
}

.event-feature:nth-child(even) > * {
  direction: ltr;
}

.event-feature__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.event-feature__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.event-feature__text .t-h3 {
  margin-block: 1rem;
}

.event-feature__text p {
  color: var(--color-ink-muted);
  line-height: var(--lh-body);
  margin-bottom: 1.5rem;
}

.events-packages {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  border: 1px solid var(--color-border);
}

.package {
  padding: 2rem 1.75rem;
  border-right: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
}

.package:last-child {
  border-right: none;
}

.package__name {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 400;
}

.package__guests {
  font-size: var(--t-label);
  font-weight: 500;
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-ink-muted);
  margin-top: 0.5rem;
}

.package__price {
  font-family: var(--font-mono);
  font-size: 1.125rem;
  color: var(--color-crimson);
  font-weight: 500;
  margin-block: 1.25rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--color-border);
}

.package__includes {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 2rem;
  flex: 1;
}

.package__includes li {
  font-size: 0.9375rem;
  color: var(--color-ink-muted);
  line-height: 1.45;
  padding-left: 1.5rem;
  position: relative;
}

.package__includes li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-forest);
}

.events-form-section .reservation-form {
  max-width: 760px;
}

/* ==========================================================================
   LEGAL PAGES (Privacy, Cookies)
   ========================================================================== */
.legal-section {
  padding-block: 0 var(--space-2xl);
}

.legal-content {
  max-width: 720px;
}

.legal-content h2 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: var(--t-h3);
  line-height: 1.2;
  margin-top: 2.75rem;
  margin-bottom: 0.75rem;
}

.legal-content h2:first-child {
  margin-top: 0;
}

.legal-content p {
  color: var(--color-ink-muted);
  line-height: var(--lh-body);
  margin-bottom: 1rem;
}

.legal-content ul {
  list-style: disc;
  padding-left: 1.25rem;
  margin-bottom: 1rem;
}

.legal-content li {
  color: var(--color-ink-muted);
  line-height: var(--lh-body);
  margin-bottom: 0.5rem;
}

.legal-content a {
  color: var(--color-forest);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.legal-content strong {
  color: var(--color-ink);
  font-weight: 500;
}

.legal-meta {
  margin-top: 1.25rem;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
  .about-grid,
  .testimonials-grid,
  .story-content,
  .reservations-grid,
  .events-hero__grid {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  .events-hero {
    min-height: auto;
  }

  .events-hero__grid {
    direction: ltr;
  }

  .events-hero__media {
    aspect-ratio: 16 / 9;
    order: 2;
  }

  .events-hero__text {
    padding-top: calc(var(--space-3xl) + 40px);
    padding-bottom: 0;
    order: 1;
    max-width: 100%;
  }

  .events-hero__media .img-placeholder {
    position: relative;
  }

  .about-media {
    min-height: 440px;
  }

  .reservation-info,
  .story-aside {
    position: static;
  }

  .story-aside {
    flex-direction: column-reverse;
  }
}

@media (max-width: 768px) {
  /* Trim the oversized top clearance under the fixed nav on mobile */
  .events-hero {
    padding-block: calc(var(--space-xl) + 32px) 0;
  }

  .events-hero__text {
    padding-top: 0;
  }

  .menu-hero {
    padding-block: calc(var(--space-xl) + 32px) var(--space-lg);
  }

  .story-hero {
    padding-top: calc(var(--space-xl) + 32px);
  }

  .dishes-grid {
    grid-template-columns: 1fr;
    border: none;
    gap: 0;
  }

  .dishes-grid .dish-feature {
    border-top: 2px solid var(--color-forest);
    padding-inline: 0;
    margin-bottom: 2.5rem;
  }

  .stats-row {
    grid-template-columns: repeat(2, 1fr);
  }

  .stat-item {
    border-right: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
  }

  .stat-item:nth-child(2n) {
    border-right: none;
  }

  .stat-item:nth-last-child(-n+2) {
    border-bottom: none;
  }

  .experience-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem 0;
  }

  .experience-step {
    padding: 0 1.25rem;
  }

  .experience-step:nth-child(2n) {
    border-right: none;
    padding-right: 0;
  }

  .experience-step:nth-child(2n + 1) {
    padding-left: 0;
  }

  .wine-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .reservation-form .form-row {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .team-grid {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  .event-feature {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }

  .event-feature:nth-child(even) {
    direction: ltr;
  }

  .event-feature__media {
    order: -1;
  }

  .events-packages {
    grid-template-columns: 1fr;
    border: none;
    gap: 0;
  }

  .package {
    border-right: none;
    border-bottom: 1px solid var(--color-border);
  }

  .package:last-child {
    border-bottom: none;
  }

  .gallery-strip {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }

  .gallery-strip .img-placeholder:first-child,
  .gallery-strip img:first-child {
    grid-row: auto;
    grid-column: 1 / 3;
    aspect-ratio: 3 / 4;
  }

  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }

  .footer__brand {
    grid-column: 1 / 3;
  }
}

@media (max-width: 480px) {
  .stats-row {
    grid-template-columns: 1fr;
  }

  .stat-item {
    border-right: none;
    border-bottom: 1px solid var(--color-border);
  }

  .stat-item:last-child {
    border-bottom: none;
  }

  .experience-grid {
    grid-template-columns: 1fr;
  }

  .experience-step {
    border-right: none;
    border-bottom: 1px solid rgba(29, 74, 47, 0.15);
    padding: 1.5rem 0;
  }

  .experience-step:last-child {
    border-bottom: none;
  }

  .gallery-strip {
    grid-template-columns: 1fr;
  }

  .gallery-strip .img-placeholder:first-child,
  .gallery-strip img:first-child {
    grid-column: auto;
  }

  .footer__grid {
    grid-template-columns: 1fr;
  }

  .footer__brand {
    grid-column: auto;
  }

  .newsletter__form {
    flex-direction: column;
    gap: 0.75rem;
  }

  .newsletter__input {
    border-radius: 3px;
  }

  .newsletter__submit {
    border-radius: 3px;
  }
}
