/* ============================================
   Layout - Grid, Containers, Sections
   ============================================ */

/* Container */
.container {
  max-width: var(--container-max-width);
  margin-inline: auto;
  padding-inline: var(--container-padding);
  width: 100%;
}

/* Section base */
section {
  padding-block: var(--section-padding-y);
}

/* Alternating section backgrounds */
.bg-black {
  background-color: var(--color-black);
}

.bg-charcoal {
  background-color: var(--color-charcoal);
}

.bg-midnight {
  background-color: var(--color-midnight);
}

.bg-gray {
  background-color: var(--color-gray);
}

/* Grid layouts */
.grid {
  display: grid;
  gap: var(--space-6);
}

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

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

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

/* Two-column content layout (text + image) */
.split-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}

/* Trust bar grid */
.trust-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
  text-align: center;
}

/* Service cards grid */
.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

/* Destinations tab content grid */
.destinations-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

/* Steps layout */
.steps-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  text-align: center;
}

/* Testimonials track (horizontal scroll) */
.testimonials-track {
  display: flex;
  gap: var(--space-6);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: var(--space-4);
  padding-inline: var(--space-2);
}

.testimonials-track::-webkit-scrollbar {
  display: none;
}

/* Vehicle features grid */
.vehicle-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

/* FAQ container */
.faq-container {
  max-width: 800px;
  margin-inline: auto;
}

/* Contact layout */
.contact-content {
  text-align: center;
  max-width: 600px;
  margin-inline: auto;
}

/* Footer grid */
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  text-align: center;
}

/* ============================================
   Responsive Grids (md: 768px+)
   ============================================ */
@media (min-width: 768px) {
  .grid-2 {
    grid-template-columns: repeat(2, 1fr);
  }

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

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

  .split-layout {
    grid-template-columns: 1fr 1fr;
  }

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

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

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

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

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

  .footer-grid {
    grid-template-columns: repeat(3, 1fr);
    text-align: left;
  }
}

/* ============================================
   Responsive Grids (lg: 1024px+)
   ============================================ */
@media (min-width: 1024px) {
  .grid-3 {
    grid-template-columns: repeat(3, 1fr);
  }

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

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

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