/* ============================================================
   LAYOUT — Container, Grid, Section Patterns
   ============================================================ */

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

.container--narrow {
  max-width: var(--max-w-narrow);
}

.container--wide {
  max-width: var(--max-w-wide);
}

/* ── Sections ── */
.section {
  padding: var(--sp-8) 0;
}

.section--sm  { padding: var(--sp-5) 0; }
.section--lg  { padding: var(--sp-9) 0; }
.section--hero { padding: 0; }

/* ── Section Header ── */
.section-header {
  text-align: center;
  margin-bottom: var(--sp-6);
}

.section-header h2 {
  margin-top: var(--sp-1);
}

.section-header p {
  margin: var(--sp-2) auto 0;
  color: var(--charcoal-mid);
}

/* ── Grid utilities ── */
.grid {
  display: grid;
  gap: var(--sp-4);
}

.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--5 { grid-template-columns: repeat(5, 1fr); }
.grid--auto { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

/* ── Flex utilities ── */
.flex        { display: flex; }
.flex-col    { flex-direction: column; }
.flex-center { align-items: center; justify-content: center; }
.flex-between{ align-items: center; justify-content: space-between; }
.flex-wrap   { flex-wrap: wrap; }
.gap-1  { gap: var(--sp-1); }
.gap-2  { gap: var(--sp-2); }
.gap-3  { gap: var(--sp-3); }
.gap-4  { gap: var(--sp-4); }

/* ── Split layouts ── */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
  align-items: center;
}

.split--wide-left  { grid-template-columns: 3fr 2fr; }
.split--wide-right { grid-template-columns: 2fr 3fr; }

/* ── Background sections ── */
.bg-navy   { background: var(--navy); }
.bg-cream  { background: var(--cream); }
.bg-sage   { background: var(--sage); }
.bg-dark   { background: var(--navy-deep); }
.bg-white  { background: var(--white); }

.bg-gradient-navy {
  background: linear-gradient(135deg, var(--navy-deep) 0%, var(--navy) 50%, var(--navy-mid) 100%);
}

.bg-gradient-sage {
  background: linear-gradient(135deg, var(--sage) 0%, var(--sage-light) 100%);
}

.bg-gradient-cream {
  background: linear-gradient(180deg, var(--cream) 0%, var(--cream-dark) 100%);
}

/* ── Hero Layouts ── */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__content {
  position: relative;
  z-index: var(--z-raised);
  width: 100%;
}

/* ── Page hero (inner pages) ── */
.page-hero {
  min-height: 60vh;
  display: flex;
  align-items: flex-end;
  padding-bottom: var(--sp-7);
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--navy-deep) 0%, var(--navy) 100%);
}

.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 60% 100%, rgba(107,142,127,0.15) 0%, transparent 70%);
  pointer-events: none;
}

.page-hero__content {
  position: relative;
  z-index: var(--z-raised);
  padding-top: calc(var(--nav-h) + var(--sp-6));
}

/* ── Spacing utilities ── */
.mt-1 { margin-top: var(--sp-1); }
.mt-2 { margin-top: var(--sp-2); }
.mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }
.mt-5 { margin-top: var(--sp-5); }
.mt-6 { margin-top: var(--sp-6); }
.mb-1 { margin-bottom: var(--sp-1); }
.mb-2 { margin-bottom: var(--sp-2); }
.mb-3 { margin-bottom: var(--sp-3); }
.mb-4 { margin-bottom: var(--sp-4); }
.mb-5 { margin-bottom: var(--sp-5); }
.mb-6 { margin-bottom: var(--sp-6); }

/* ── Visually hidden (accessibility) ── */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
