/* ════════════════════════════════════════════════════════════════════
   LAYOUT — containers, sections, grid utilities
   ──────────────────────────────────────────────────────────────────── */

.container {
  max-width: var(--container-base);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.container--narrow { max-width: var(--container-narrow); }
.container--wide   { max-width: var(--container-wide); }
.container--bleed  { max-width: none; padding: 0 var(--gutter); }

@media (max-width: 720px) {
  .container,
  .container--narrow,
  .container--wide,
  .container--bleed { padding: 0 var(--gutter-mobile); }
}

/* Sections */
section { position: relative; }

.section {
  padding: var(--s-16) var(--gutter);
}
.section--lg { padding: var(--s-20) var(--gutter); }
.section--xl { padding: 180px var(--gutter); }
.section--sm { padding: 96px var(--gutter); }

.section--bone   { background: var(--bone); }
.section--bone-2 { background: var(--bone-2); }
.section--cloud  { background: var(--cloud); }
.section--navy   { background: var(--navy); color: var(--bone); }

.section--bordered {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.section__inner {
  max-width: var(--container-wide);
  margin: 0 auto;
  position: relative;
}
.section__inner--narrow { max-width: var(--container-narrow); }
.section__inner--base   { max-width: var(--container-base); }

@media (max-width: 720px) {
  .section { padding: 80px var(--gutter-mobile); }
  .section--lg, .section--xl { padding: 96px var(--gutter-mobile); }
}

/* Grid helpers */
.grid { display: grid; gap: var(--s-3); }
.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--auto-280 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid--auto-260 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.grid--auto-360 { grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)); }

.gap-1 { gap: 8px; }
.gap-2 { gap: 16px; }
.gap-3 { gap: 24px; }
.gap-4 { gap: 32px; }
.gap-5 { gap: 40px; }
.gap-6 { gap: 48px; }
.gap-8 { gap: 64px; }
.gap-10 { gap: 80px; }

@media (max-width: 1024px) {
  .grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); }
  .stack-md { grid-template-columns: 1fr; gap: 48px; }
}
@media (max-width: 720px) {
  .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
}

/* Flex helpers */
.row { display: flex; align-items: center; gap: var(--s-2); }
.row--between { justify-content: space-between; }
.row--end { align-items: flex-end; }
.row--wrap { flex-wrap: wrap; }
.col { display: flex; flex-direction: column; }

/* Section header — eyebrow + title + body, used everywhere */
.section-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: end;
  margin-bottom: 72px;
}
.section-head--center { grid-template-columns: 1fr; max-width: 880px; margin-left: auto; margin-right: auto; text-align: center; }
.section-head--single { grid-template-columns: 1fr; }

@media (max-width: 1024px) {
  .section-head { grid-template-columns: 1fr; gap: 32px; margin-bottom: 56px; }
}

.section-head__title {
  font-size: var(--t-h2-lg);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 0.96;
  margin: 0;
  color: var(--navy);
  text-wrap: balance;
  max-width: 900px;
}
.section--navy .section-head__title { color: var(--bone); }

.section-head__lede {
  font-size: 18px;
  line-height: 1.6;
  color: var(--ink-2);
  margin: 0;
  max-width: 500px;
}
.section--navy .section-head__lede { color: rgba(250,250,248,0.7); }

/* Pill-tag header eyebrow ("● label") */
.tag-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 32px;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--cloud);
  border: 1px solid var(--border);
}
.tag-pill__dot {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--verdigris);
  flex-shrink: 0;
}
.tag-pill__text {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 500;
}
.section--navy .tag-pill {
  background: rgba(250,250,248,0.05);
  border-color: rgba(250,250,248,0.12);
}
.section--navy .tag-pill__text { color: rgba(250,250,248,0.78); }
