/* ============================================
   Layout Utilities - Containers, Grid, Spacing
   ============================================ */

/* Container */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--spacing-md);
}

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

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

/* Section Spacing */
.section {
  padding: var(--spacing-xl) 0;
}

.section--sm {
  padding: var(--spacing-md) 0;
}

.section--lg {
  padding: calc(var(--spacing-xl) * 1.5) 0;
}

/* Grid Utilities */
.grid {
  display: grid;
  gap: var(--spacing-md);
}

.grid--gap-sm {
  gap: var(--spacing-sm);
}

.grid--gap-lg {
  gap: var(--spacing-lg);
}

/* Flexbox Utilities */
.flex {
  display: flex;
}

.flex--column {
  flex-direction: column;
}

.flex--center {
  align-items: center;
  justify-content: center;
}

.flex--between {
  justify-content: space-between;
}

.flex--wrap {
  flex-wrap: wrap;
}

/* Spacing Utilities */
.mt-sm {
  margin-top: var(--spacing-sm);
}

.mt-md {
  margin-top: var(--spacing-md);
}

.mt-lg {
  margin-top: var(--spacing-lg);
}

.mb-sm {
  margin-bottom: var(--spacing-sm);
}

.mb-md {
  margin-bottom: var(--spacing-md);
}

.mb-lg {
  margin-bottom: var(--spacing-lg);
}

.py-sm {
  padding-top: var(--spacing-sm);
  padding-bottom: var(--spacing-sm);
}

.py-md {
  padding-top: var(--spacing-md);
  padding-bottom: var(--spacing-md);
}

.py-lg {
  padding-top: var(--spacing-lg);
  padding-bottom: var(--spacing-lg);
}

/* Responsive Utilities */
@media (min-width: 768px) {
  .container {
    padding: 0 var(--spacing-lg);
  }
}