/* Utilities — Standard Bearer Co. */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
  box-sizing: border-box;
  min-width: 0;
}

.container--narrow { max-width: 880px; }
.container--prose  { max-width: 680px; }

/* vertical rhythm */
.stack > * + * { margin-top: var(--sp-4); }
.stack-sm > * + * { margin-top: var(--sp-2); }
.stack-lg > * + * { margin-top: var(--sp-6); }

/* horizontal flex with gap */
.cluster { display: flex; flex-wrap: wrap; gap: var(--sp-4); align-items: center; }
.cluster--tight { gap: var(--sp-2); }
.cluster--between { justify-content: space-between; }

/* simple grid */
.grid-2, .grid-3, .grid-4 { display: grid; gap: var(--sp-6); }
@media (min-width: 768px) {
  .grid-2 { grid-template-columns: 1fr 1fr; }
  .grid-3 { grid-template-columns: repeat(3, 1fr); }
  .grid-4 { grid-template-columns: repeat(4, 1fr); }
}

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

/* skip link */
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--c-navy); color: var(--c-cream);
  padding: var(--sp-3) var(--sp-4);
  z-index: 100;
}
.skip-link:focus { left: var(--sp-4); top: var(--sp-4); }

/* alignment */
.text-center { text-align: center; }
.text-right  { text-align: right; }
.center-x { margin-left: auto; margin-right: auto; }

/* space helpers (use sparingly — prefer .stack) */
.mt-0 { margin-top: 0 !important; }
.mb-0 { margin-bottom: 0 !important; }
.mt-6 { margin-top: var(--sp-6); }
.mb-6 { margin-bottom: var(--sp-6); }

/* divider with star (heritage motif) */
.rule-star {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  text-align: center;
  color: var(--c-navy);
  margin: var(--sp-6) 0;
}
.rule-star::before, .rule-star::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--c-navy);
}
.rule-star__icon {
  font-size: 14px;
  color: var(--c-red);
  line-height: 1;
}

/* responsive show/hide */
.hide-md { display: initial; }
.show-md { display: none; }
@media (min-width: 768px) {
  .hide-md { display: none; }
  .show-md { display: initial; }
}

/* aspect ratios */
.ratio-4-5 { aspect-ratio: 4 / 5; }
.ratio-1-1 { aspect-ratio: 1 / 1; }
.ratio-16-9 { aspect-ratio: 16 / 9; }

/* badge */
.badge {
  display: inline-block;
  font-family: var(--ff-ui);
  font-size: var(--fs-caption);
  font-weight: 600;
  letter-spacing: var(--ls-ui);
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  background: var(--c-cream-soft);
  color: var(--c-navy);
}
.badge--accent { background: var(--c-red); color: var(--c-white); }
.badge--bronze { background: var(--c-bronze); color: var(--c-white); }

/* quiet motion respect */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}
