/* ==========================================================================
   Les Officiers — Responsive (mobile-first → desktop)
   Breakpoints : 375px (base), 768px (tablette), 1024px (desktop), 1440px (large)
   ========================================================================== */

/* --- TABLETTE (768px+) --- */
@media (min-width: 768px) {
  section {
    padding: var(--space-4xl) 0;
  }

  .hero__title {
    font-size: var(--fs-4xl);
  }

  .hero__subtitle {
    font-size: var(--fs-lg);
  }

  .salles__grid {
    grid-template-columns: repeat(3, 1fr);
  }

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

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

  .privatisation__content {
    grid-template-columns: 1fr 1fr;
    align-items: center;
  }

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

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

  .footer__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .footer__bottom {
    flex-direction: row;
    justify-content: space-between;
  }

  .section-header__title {
    font-size: var(--fs-3xl);
  }

  .reservation-cta__title {
    font-size: var(--fs-3xl);
  }

  .page-header {
    padding: calc(var(--nav-height) + var(--space-3xl)) 0 var(--space-3xl);
  }

  .page-header__title {
    font-size: var(--fs-3xl);
  }
}

/* --- DESKTOP (1024px+) --- */
@media (min-width: 1024px) {
  .nav {
    height: var(--nav-height);
  }

  .nav__links {
    display: flex;
    flex-direction: row;
    position: absolute;
    right: var(--space-md);
    width: auto;
    height: auto;
    background: none;
    gap: var(--space-lg);
  }

  .nav__links a {
    font-size: var(--fs-sm);
    letter-spacing: 0.05em;
    text-transform: uppercase;
  }

  .nav__burger {
    display: none;
  }

  .nav__cta {
    display: inline-block;
    padding: 10px 24px;
    background: var(--color-secondary);
    color: var(--color-primary);
    font-size: var(--fs-xs);
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border-radius: var(--border-radius);
    transition: background var(--transition-fast);
  }

  .nav__cta:hover {
    background: var(--color-accent);
  }

  .mobile-cta {
    display: none;
  }

  .galerie__grid {
    grid-template-columns: repeat(3, 1fr);
  }

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

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

/* --- LARGE DESKTOP (1440px+) --- */
@media (min-width: 1440px) {
  .container {
    padding: 0 var(--space-xl);
  }

  .hero__title {
    font-size: 4rem;
  }

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