.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--spacing-margin-desktop);
}

.section-margin {
  margin-top: 80px;
  margin-bottom: 80px;
}

/* Bento Grid */
.bento-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--spacing-gutter);
}

.col-12 { grid-column: span 12; }
.col-8 { grid-column: span 8; }
.col-6 { grid-column: span 6; }
.col-4 { grid-column: span 4; }
.col-3 { grid-column: span 3; }

/* Flex utilities */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.gap-1 { gap: var(--spacing-unit); }
.gap-2 { gap: calc(var(--spacing-unit) * 2); }
.gap-3 { gap: calc(var(--spacing-unit) * 3); }

@media (max-width: 1199px) {
  .bento-grid {
    grid-template-columns: repeat(8, 1fr);
  }
  .col-8 { grid-column: span 8; }
  .col-4 { grid-column: span 4; }
  .col-6 { grid-column: span 8; } /* stacks on tablet */
}

@media (max-width: 767px) {
  .container {
    padding: 0 var(--spacing-margin-mobile);
  }
  .section-margin {
    margin-top: 40px;
    margin-bottom: 40px;
  }
  .bento-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
  }
  .col-12, .col-8, .col-6, .col-4, .col-3 {
    grid-column: span 4;
  }
}
