/* === Layout System === */

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

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

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

.container--full {
  max-width: none;
  padding: 0;
}

/* Section spacing */
.section {
  padding: var(--space-3xl) 0;
  position: relative;
  overflow: hidden;
}

.section--sm   { padding: var(--space-2xl) 0; }
.section--lg   { padding: var(--space-4xl) 0; }
.section--flush { padding: 0; }

/* Backgrounds */
.bg-cream      { background-color: var(--cream); }
.bg-warm-white { background-color: var(--warm-white); }
.bg-sand       { background-color: var(--sand); }
.bg-green      { background-color: var(--brand-green); color: var(--text-on-green); }
.bg-green-dark { background-color: var(--brand-green-dark); color: var(--text-on-green); }
.bg-off-white  { background-color: var(--off-white); }

/* Grid system */
.grid {
  display: grid;
  gap: var(--space-lg);
}

.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-editorial {
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  align-items: center;
}

.grid-editorial--reverse > *:first-child {
  order: 2;
}
.grid-editorial--reverse > *:last-child {
  order: 1;
}

/* 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; }
.items-end { align-items: flex-end; }
.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); }

/* Spacing utilities */
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }
.mb-2xl { margin-bottom: var(--space-2xl); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }

/* Text alignment */
.text-center { text-align: center; }

/* Image containers */
.img-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.img-rounded {
  border-radius: var(--radius-md);
  overflow: hidden;
}

.aspect-16-9 { aspect-ratio: 16 / 9; }
.aspect-4-3 { aspect-ratio: 4 / 3; }
.aspect-3-2 { aspect-ratio: 3 / 2; }
.aspect-1-1 { aspect-ratio: 1 / 1; }

/* Dividers */
.divider {
  width: 60px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent-gold), transparent);
  border: none;
  margin: var(--space-lg) 0;
}

.divider--center {
  margin-left: auto;
  margin-right: auto;
}

/* Editorial text link button */
.btn--editorial {
  background: none;
  border: none;
  padding: 0;
  color: var(--cta-warm);
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  position: relative;
  cursor: pointer;
  transition: color var(--duration-normal) var(--ease-premium);
}
.btn--editorial::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--accent-gold);
  transition: width var(--duration-normal) var(--ease-premium);
}
.btn--editorial:hover::after {
  width: 100%;
}
.btn--editorial:hover {
  color: var(--accent-gold);
}

/* Responsive */
@media (max-width: 1024px) {
  .grid-2, .grid-editorial { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-editorial--reverse > *:first-child { order: unset; }
  .grid-editorial--reverse > *:last-child { order: unset; }
}

@media (max-width: 640px) {
  .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .section { padding: var(--space-2xl) 0; }
  .section--lg { padding: var(--space-3xl) 0; }
}
