/* ============================================
   LAYOUT — containers, grid utilities
   ============================================ */

/* ---- Container ---- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* ---- Main content offset for sticky header ---- */
.main-content {
  padding-top: var(--header-h);
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .main-content {
    padding-top: var(--header-h-md);
  }
}

/* ---- Generic grid helpers ---- */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-6); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-6); }

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

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

@media (max-width: 480px) {
  .grid-4, .grid-3, .grid-2 { grid-template-columns: 1fr; }
}

/* ---- Surface card ---- */
.card {
  background: var(--surface);
  border: 1px solid var(--border-gold);
  border-radius: var(--radius-xl);
  padding: var(--sp-6);
  box-shadow: var(--shadow-md);
}

/* ---- Section spacing ---- */
.section { padding-block: var(--sp-16); }
.section--sm { padding-block: var(--sp-8); }

/* ---- Page hero strip ---- */
.page-hero {
  background: transparent;
  padding-block: var(--sp-12);
  text-align: center;
}
.page-hero--sm { padding-block: var(--sp-8); }

.page-hero__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--gold);
  margin-bottom: var(--sp-3);
}

.page-hero__sub {
  color: var(--text-muted);
  font-size: var(--text-md);
  max-width: 60ch;
  margin-inline: auto;
}

/* ---- Sticky bottom CTA (mobile) ---- */
.sticky-cta {
  position: fixed;
  bottom: calc(60px + env(safe-area-inset-bottom));
  left: 0;
  right: 0;
  padding: var(--sp-3) var(--sp-4);
  background: linear-gradient(to top, var(--bg) 60%, transparent);
  z-index: var(--z-raised);
}

@media (min-width: 768px) {
  .sticky-cta { display: none; }
}
