/* ============================================
   LAYOUT — Grid, Container, Sections
   ============================================ */

/* === CONTAINER === */
.container {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 var(--container-padding-x);
}

.container--narrow {
  max-width: 720px;
}

.container--medium {
  max-width: 880px;
}

.container--wide {
  max-width: 1200px;
}

/* === MAIN CONTENT === */
main {
  position: relative;
  z-index: var(--z-content);
}

/* === SECTION === */
.section {
  padding: var(--section-padding-y-mobile) 0;
  background: rgba(13, 94, 49, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  position: relative;
  z-index: var(--z-content);
}

@media (min-width: 900px) {
  .section {
    padding: var(--section-padding-y) 0;
  }
}

.section--small {
  padding: var(--space-12) 0;
  background: rgba(13, 94, 49, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  position: relative;
  z-index: var(--z-content);
}

@media (min-width: 900px) {
  .section--small {
    padding: var(--space-16) 0;
  }
}

/* === HERO === */
.hero {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: calc(80px + var(--space-12)) var(--container-padding-x) var(--space-8);
  background: transparent;
}

.hero--full {
  min-height: 85vh;
}

.hero__content {
  max-width: 700px;
}

.hero__overline {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-gold);
  margin-bottom: var(--space-4);
}

.hero__title {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-white);
  margin-bottom: var(--space-6);
}

@media (min-width: 900px) {
  .hero__title {
    font-size: var(--text-6xl);
  }
}

.hero__subtitle {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.85);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-8);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.hero .lead {
  color: rgba(255, 255, 255, 0.8);
}

.hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
}

.hero__scroll {
  margin-top: var(--space-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-gold);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  animation: float 3s ease-in-out infinite;
}

.hero__scroll svg {
  width: 20px;
  height: 20px;
}

/* === GRIDS === */

.grid {
  display: grid;
  gap: var(--card-gap);
}

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

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

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

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

@media (min-width: 600px) {
  .grid--2 { grid-template-columns: repeat(2, 1fr); }
  .grid--3 { grid-template-columns: repeat(2, 1fr); }
  .grid--4 { grid-template-columns: repeat(2, 1fr); }
  .grid--5 { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 900px) {
  .grid--3 { grid-template-columns: repeat(3, 1fr); }
  .grid--4 { grid-template-columns: repeat(3, 1fr); }
  .grid--5 { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1200px) {
  .grid--4 { grid-template-columns: repeat(4, 1fr); }
  .grid--5 { grid-template-columns: repeat(5, 1fr); }
}

/* === SECTION TEXT ON GREEN BG === */
.section > .container > h1,
.section > .container > h2,
.section > .container > h3,
.section > .container > h4,
.section .section-header__title {
  color: var(--color-white);
}

.section .section-divider {
  background: var(--color-gold-light);
}

/* === SECTION HEADER === */
.section-header {
  text-align: center;
  margin-bottom: var(--space-12);
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.section-header__divider {
  margin-bottom: var(--space-6);
}

.section-header__title {
  margin-bottom: var(--space-4);
}

.section-header__subtitle {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  color: rgba(var(--color-ice-rgb), 0.8);
  line-height: var(--leading-normal);
}

/* === TEXT ALIGNMENT UTILITIES === */
.text-center { text-align: center; }
.text-left { text-align: left; }

/* === SPACER === */
.spacer-sm { height: var(--space-8); }
.spacer-md { height: var(--space-12); }
.spacer-lg { height: var(--space-16); }

/* Padding top for pages (below fixed header) */
.page-content {
  padding-top: 80px;
}
