/* ============================================
   CRUSADE X WARRIOR — 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 Bar (Metrics) ---- */
.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 / Mission ---- */
.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 Grid ---- */
.service-detail-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-xl);
  margin-top: var(--cn-space-xl);
}

/* ---- Feature List ---- */
.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 (Catering) ---- */
.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 Qualifier (Youth) ---- */
.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;
}

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

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

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

/* ---- Mentorship ---- */
.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 Bar ---- */
.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);
}

/* Scroll margin for sticky header */
section[id] {
  scroll-margin-top: var(--cn-header-height);
}

/* ---- Problem Grid (Section 2) ---- */
.problem-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-2xl);
  margin-top: var(--cn-space-2xl);
  margin-bottom: var(--cn-space-2xl);
}

.problem-bridge {
  text-align: center;
  font-size: var(--cn-text-body);
  line-height: 1.8;
  max-width: 700px;
  margin-inline: auto;
  margin-top: var(--cn-space-xl);
  opacity: 0.9;
}

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

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

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

.business-differentiator {
  margin-top: var(--cn-space-2xl);
  padding: var(--cn-space-xl) var(--cn-space-2xl);
  border-left: 4px solid var(--cn-gold);
  font-size: var(--cn-text-body);
  line-height: 1.8;
  opacity: 0.9;
}

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

/* ---- CTA Actions Grid (Section 9) ---- */
.cta-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cn-space-xl);
  margin-top: var(--cn-space-2xl);
}

/* ---- Header Logo Text ---- */
.header__logo-text {
  font-family: var(--cn-font-body);
  font-weight: 700;
  font-size: var(--cn-text-small);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

/* ---- Footer Connect ---- */
.footer__connect {
  display: flex;
  flex-direction: column;
}

/* =============================================
   RESPONSIVE BREAKPOINTS (Mobile-First)
   ============================================= */

/* ---- 480px: Larger phones ---- */
@media (min-width: 30em) {
  .hero__ctas {
    flex-direction: row;
    justify-content: center;
  }

  .booking-form__options {
    grid-template-columns: 1fr 1fr;
  }
}

/* ---- 768px: Tablets ---- */
@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;
  }

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

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

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

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

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

/* ---- 1024px: Desktop ---- */
@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;
  }

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

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

/* ---- 1280px: Large desktop ---- */
@media (min-width: 80em) {
  .container {
    padding-inline: var(--cn-space-xl);
  }
}
