/* ==========================================================================
   Responsive — every media query in the project lives here.
   Breakpoints: mobile (<=480px), tablet (<=768px), laptop (<=1024px).
   ========================================================================== */

/* ---- Laptop (<=1024px) ---- */
@media (max-width: 1024px) {
  .container {
    padding-inline: var(--space-xl);
  }

  .hero__inner,
  .menu-hero__inner {
    grid-template-columns: 1fr;
    padding-block: 64px 72px;
    gap: var(--space-2xl);
  }

  /* Hide the decorative hero imagery on tablet & below so the copy leads */
  .hero__visual,
  .menu-hero__visual {
    display: none;
  }

  .site-footer__grid {
    grid-template-columns: 1fr 1fr;
    row-gap: var(--space-2xl);
  }

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

/* ---- Tablet (<=768px) ---- */
@media (max-width: 768px) {
  .container {
    padding-inline: var(--space-lg);
  }

  .section {
    padding-block: var(--space-4xl);
  }

  h1 { font-size: clamp(2.1rem, 8vw, 3rem); }
  h2 { font-size: clamp(1.7rem, 6vw, 2.25rem); }

  /* Nav collapses into a mobile panel anchored below the sticky header.
     Uses position:absolute (not fixed) because the header's backdrop-filter
     creates a containing block for fixed descendants, which would otherwise
     confine "fixed" positioning to the header's own small box. */
  .site-nav {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: var(--z-mobile-menu);
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-lg);
    max-height: calc(100vh - 100%);
    overflow-y: auto;
    background: var(--pure-white);
    box-shadow: var(--shadow-raised);
    padding: var(--space-xl) var(--space-2xl);
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
    transition: opacity var(--transition-base), transform var(--transition-base), visibility var(--transition-base);
  }

  .site-nav.is-open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    visibility: visible;
  }

  .site-nav__list {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-lg);
  }

  .site-nav__list a {
    font-size: 18px;
  }

  .site-nav__cta {
    align-self: flex-start;
  }

  .site-header__toggle {
    display: flex;
  }

  .grid--2,
  .grid--3,
  .steps,
  .reset-highlights {
    grid-template-columns: 1fr;
  }

  .step,
  .reset-highlight {
    border-left: none;
    border-top: 1px solid var(--border);
    padding-left: 0;
  }

  .reset-highlight {
    border-top-color: rgba(255, 255, 255, 0.14);
  }

  .step:first-child,
  .reset-highlight:first-child {
    border-top: none;
  }

  .stats {
    flex-wrap: wrap;
    gap: var(--space-lg);
  }

  .stat {
    border-left: none;
    padding-inline: 0;
  }

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

  .form-card {
    padding: var(--space-2xl) var(--space-lg);
  }

  /* Center-align section content on mobile — FAQ stays left-aligned */
  main > section:not(#faq) {
    text-align: center;
  }

  .hero__content,
  .menu-hero__content,
  .book-section__copy {
    align-items: center;
  }

  .btn-group,
  .trust-row,
  .stats,
  .tag-list,
  .service-card__footer {
    justify-content: center;
  }
}

/* ---- Mobile (<=480px) ---- */
@media (max-width: 480px) {
  .container {
    padding-inline: var(--space-md);
  }

  .hero__title,
  .menu-hero__title {
    font-size: 2.2rem;
  }

  .btn {
    width: 100%;
    justify-content: center;
  }

  .btn-group {
    flex-direction: column;
  }

  .quote-card {
    padding: var(--space-2xl) var(--space-lg);
  }

  .quote-card__text {
    font-size: 26px;
  }
}
