/* ─────────────────────────────────────────────────────────────────────────────
   SIP GLOBAL — Layout
───────────────────────────────────────────────────────────────────────────── */

.container {
  width    : 100%;
  max-width: var(--max-width);
  margin   : 0 auto;
  padding  : 0 var(--space-lg);
}

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

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

/* Sections */
.section {
  padding: var(--space-2xl) 0;
}

.section--navy {
  background: var(--color-navy);
  color     : var(--color-white);
}

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

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

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

/* Flex utilities */
.flex         { display: flex; }
.flex-col     { flex-direction: column; }
.flex-wrap    { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.justify-center { justify-content: center; }
.justify-between{ justify-content: space-between; }
.gap-sm       { gap: var(--space-sm); }
.gap-md       { gap: var(--space-md); }
.gap-lg       { gap: var(--space-lg); }
.gap-xl       { gap: var(--space-xl); }

/* Grid */
.grid-2 {
  display              : grid;
  grid-template-columns: 1fr 1fr;
  gap                  : var(--space-lg);
}

.grid-3 {
  display              : grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap                  : var(--space-lg);
}

/* Page offset for fixed nav — use on pages without a hero */
.page-body {
  padding-top: var(--nav-height);
}

/* Consistent section top padding when directly below nav */
.section--top {
  padding-top: calc(var(--nav-height) + var(--space-2xl));
}

/* Full viewport hero */
.vh-full {
  min-height: 100vh;
  display   : flex;
  flex-direction: column;
  justify-content: center;
}
