/* ============================================
   THE MERCENARY CHEF — Layouts & Responsive
   ============================================ */

/* ---- Container ---- */
.container {
  width: min(92%, var(--cn-max-width));
  margin-inline: auto;
  padding-inline: var(--cn-space-md);
}

.container--narrow {
  width: min(92%, var(--cn-max-width-narrow));
}

/* ---- Section Base ---- */
.section {
  position: relative;
  padding-block: var(--cn-section-py);
  overflow: hidden;
}

.section--dark {
  background-color: var(--cn-black);
}

.section--darkalt {
  background-color: var(--cn-dark);
}

.section--cream {
  background-color: var(--cn-cream);
  color: var(--cn-black);
}

.section--compact {
  padding-block: calc(var(--cn-section-py) * 0.5);
}

.section--cta {
  background: linear-gradient(
    160deg,
    var(--cn-black) 0%,
    #14100a 40%,
    #1a1508 70%,
    var(--cn-black) 100%
  );
}

.section__title {
  margin-top: var(--cn-space-lg);
  margin-bottom: var(--cn-space-lg);
  max-width: 800px;
}

.section__title--dark {
  color: var(--cn-black);
}

.section__subtitle {
  font-family: var(--cn-font-body);
  font-size: var(--cn-text-body);
  font-weight: 400;
  line-height: 1.7;
  max-width: 650px;
  margin-bottom: var(--cn-space-3xl);
  opacity: 0.85;
}

.section__subtitle--dark {
  color: var(--cn-black);
}

.section__cta {
  text-align: center;
  margin-top: var(--cn-space-3xl);
}

/* ---- Header ---- */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--cn-z-header);
  height: var(--cn-header-height);
  transition: background-color var(--cn-transition-fast),
              box-shadow var(--cn-transition-fast);
}

.site-header.header-scrolled {
  background: rgba(12, 12, 12, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 1px 0 rgba(196, 163, 90, 0.1);
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--cn-header-height);
}

.header__nav {
  display: none;
}

.header__nav-list {
  display: flex;
  gap: var(--cn-space-xl);
  align-items: center;
}

/* ---- HERO ---- */
.hero {
  min-height: 100svh;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding-top: calc(var(--cn-header-height) + var(--cn-space-xl));
  background:
    radial-gradient(ellipse at 50% 30%, rgba(107, 29, 42, 0.06) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 80%, rgba(26, 23, 20, 0.4) 0%, transparent 50%),
    var(--cn-black);
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(12, 12, 12, 0.3) 0%, rgba(12, 12, 12, 0.8) 100%);
  pointer-events: none;
}

.hero__content {
  position: relative;
  z-index: var(--cn-z-base);
  max-width: 900px;
}

.hero__subtitle {
  font-size: var(--cn-text-body);
  max-width: 600px;
  margin-inline: auto;
  margin-top: var(--cn-space-lg);
  margin-bottom: var(--cn-space-2xl);
  opacity: 0.85;
  line-height: 1.8;
}

.hero__ctas {
  display: flex;
  flex-direction: column;
  gap: var(--cn-space-md);
  align-items: center;
}

.hero__scroll-indicator {
  position: absolute;
  bottom: var(--cn-space-xl);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cn-space-xs);
  opacity: 0.4;
}

/* ---- Credentials / Metrics Bar ---- */
.metrics-bar {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--cn-space-lg);
  text-align: center;
}

/* ---- Services Overview Grid ---- */
.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-xl);
  margin-top: var(--cn-space-xl);
}

/* ---- About ---- */
.about-body {
  margin-bottom: var(--cn-space-2xl);
  line-height: 1.8;
}

.scripture-callout {
  margin-top: var(--cn-space-xl);
  padding-left: var(--cn-space-lg);
  border-left: 3px solid var(--cn-gold);
}

.mission-scripture {
  color: var(--cn-gold-muted);
  font-size: var(--cn-text-body);
}

.credentials-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--cn-space-lg);
  margin-top: var(--cn-space-2xl);
}

/* ---- Service Detail ---- */
.service-detail-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-xl);
  margin-top: var(--cn-space-xl);
}

.feature-list {
  display: flex;
  flex-direction: column;
  gap: var(--cn-space-sm);
}

.feature-list li {
  padding-left: var(--cn-space-lg);
  position: relative;
  line-height: 1.7;
}

.feature-list li::before {
  content: '\2713';
  position: absolute;
  left: 0;
  color: var(--cn-gold);
  font-weight: 700;
}

/* ---- Tiers Grid ---- */
.tiers-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-xl);
  margin-top: var(--cn-space-xl);
}

.pricing-note {
  margin-top: var(--cn-space-xl);
  text-align: center;
  font-size: var(--cn-text-small);
  opacity: 0.6;
}

/* ---- Classes Grid ---- */
.classes-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-lg);
  margin-top: var(--cn-space-xl);
}

/* ---- Mission / Youth ---- */
.mission-body {
  line-height: 1.8;
  margin-bottom: var(--cn-space-2xl);
}

.mission-qualifier {
  background: var(--cn-black);
  color: var(--cn-cream);
  padding: var(--cn-space-xl) var(--cn-space-2xl);
  border-radius: var(--cn-border-radius-lg);
  border-left: 4px solid var(--cn-gold);
  margin-top: var(--cn-space-xl);
}

.mission-qualifier__title {
  font-size: var(--cn-text-h4);
  margin-bottom: var(--cn-space-md);
  color: var(--cn-gold);
}

.mission-qualifier__list {
  display: flex;
  flex-direction: column;
  gap: var(--cn-space-sm);
}

.mission-qualifier__list li {
  padding-left: var(--cn-space-lg);
  position: relative;
  line-height: 1.6;
}

.mission-qualifier__list li::before {
  content: '\2713';
  position: absolute;
  left: 0;
  color: var(--cn-gold);
  font-weight: 700;
}

.youth-cta-text {
  margin-bottom: var(--cn-space-lg);
  opacity: 0.85;
}

/* ---- Experience ---- */
.experience-grid {
  display: flex;
  flex-direction: column;
  gap: var(--cn-space-xl);
  margin-top: var(--cn-space-xl);
}

.mentorship-callout {
  margin-top: var(--cn-space-3xl);
  padding: var(--cn-space-xl);
  border-left: 4px solid var(--cn-gold);
}

.mentorship-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-lg);
  margin-top: var(--cn-space-lg);
}

/* ---- Testimonials ---- */
.testimonials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-xl);
}

/* ---- FAQ ---- */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--cn-space-sm);
  margin-top: var(--cn-space-xl);
}

/* ---- Footer ---- */
.site-footer {
  background: #050505;
  padding-block: var(--cn-space-3xl) var(--cn-space-xl);
  border-top: 1px solid rgba(196, 163, 90, 0.15);
}

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

.footer__tagline {
  margin-top: var(--cn-space-sm);
  font-size: var(--cn-text-small);
  opacity: 0.6;
  max-width: 350px;
  line-height: 1.6;
}

.footer__nav-title {
  font-family: var(--cn-font-body);
  font-size: var(--cn-text-label);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--cn-gold);
  margin-bottom: var(--cn-space-md);
}

.footer__nav-list {
  display: flex;
  flex-direction: column;
  gap: var(--cn-space-xs);
}

.footer__nav-list a {
  font-size: var(--cn-text-small);
  opacity: 0.6;
  transition: opacity var(--cn-transition-fast), color var(--cn-transition-fast);
}

.footer__nav-list a:hover {
  opacity: 1;
  color: var(--cn-gold);
}

.footer__social {
  display: flex;
  gap: var(--cn-space-md);
  margin-bottom: var(--cn-space-md);
}

.footer__email {
  font-size: var(--cn-text-small);
  opacity: 0.6;
  transition: opacity var(--cn-transition-fast), color var(--cn-transition-fast);
}

.footer__email:hover {
  opacity: 1;
  color: var(--cn-gold);
}

.footer__phone {
  margin-top: var(--cn-space-xs);
}

.footer__bottom {
  grid-column: 1 / -1;
  padding-top: var(--cn-space-xl);
  border-top: 1px solid rgba(196, 163, 90, 0.1);
  font-size: var(--cn-text-small);
  opacity: 0.4;
}

.footer__scripture {
  margin-top: var(--cn-space-xs);
}

/* ---- Mobile Sticky CTA ---- */
.mobile-cta-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--cn-z-mobile-cta);
  background: var(--cn-gold);
  padding: var(--cn-space-sm) var(--cn-space-md);
  padding-bottom: calc(var(--cn-space-sm) + env(safe-area-inset-bottom, 0px));
  text-align: center;
  transform: translateY(100%);
  transition: transform var(--cn-transition-base);
}

.mobile-cta-bar.visible {
  transform: translateY(0);
}

section[id] {
  scroll-margin-top: var(--cn-header-height);
}

/* =============================================
   RESPONSIVE (Mobile-First)
   ============================================= */
@media (min-width: 30em) {
  .hero__ctas {
    flex-direction: row;
    justify-content: center;
  }
  .booking-form__options {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 48em) {
  .metrics-bar {
    grid-template-columns: repeat(4, 1fr);
  }
  .services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .service-detail-grid {
    grid-template-columns: 2fr 1fr;
  }
  .tiers-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .classes-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .credentials-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  .mentorship-grid {
    grid-template-columns: 1fr 1fr;
  }
  .testimonials-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .testimonials-grid .testimonial:last-child {
    grid-column: 1 / -1;
    max-width: 600px;
    justify-self: center;
  }
  .footer__inner {
    grid-template-columns: 2fr 1fr 1fr;
  }
  .mobile-cta-bar {
    display: none;
  }
  .booking-form__fields {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 64em) {
  .header__nav {
    display: block;
  }
  .hamburger {
    display: none;
  }
  .services-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  .testimonials-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .testimonials-grid .testimonial:last-child {
    grid-column: auto;
    max-width: none;
  }
}

@media (min-width: 80em) {
  .container {
    padding-inline: var(--cn-space-xl);
  }
}
