/* ================================================================
   LAYOUT.CSS
   12-column grid, containers, section spacing.
   Mobile-first: base styles target mobile, min-width scales up.
   ================================================================ */

/* --- Container --- */

.container {
  width: 100%;
  padding-inline: var(--grid-margin);
  margin-inline: auto;
  max-width: 1440px;
}

.container-narrow {
  width: 100%;
  padding-inline: var(--grid-margin);
  margin-inline: auto;
  max-width: 960px;
}

/* --- 12-column grid --- */

.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--grid-gutter);
}

/* Mobile: all columns span full width by default */

[class^="col-"],
[class*=" col-"] {
  grid-column: span 12;
}

/* Explicit full-width helper */

.col-full {
  grid-column: 1 / -1;
}

/* --- Tablet breakpoint (min 768px) --- */

@media (min-width: 768px) {
  .col-md-1  { grid-column: span 1; }
  .col-md-2  { grid-column: span 2; }
  .col-md-3  { grid-column: span 3; }
  .col-md-4  { grid-column: span 4; }
  .col-md-5  { grid-column: span 5; }
  .col-md-6  { grid-column: span 6; }
  .col-md-7  { grid-column: span 7; }
  .col-md-8  { grid-column: span 8; }
  .col-md-9  { grid-column: span 9; }
  .col-md-10 { grid-column: span 10; }
  .col-md-11 { grid-column: span 11; }
  .col-md-12 { grid-column: span 12; }
}

/* --- Desktop breakpoint (min 1024px) --- */

@media (min-width: 1024px) {
  .col-1  { grid-column: span 1; }
  .col-2  { grid-column: span 2; }
  .col-3  { grid-column: span 3; }
  .col-4  { grid-column: span 4; }
  .col-5  { grid-column: span 5; }
  .col-6  { grid-column: span 6; }
  .col-7  { grid-column: span 7; }
  .col-8  { grid-column: span 8; }
  .col-9  { grid-column: span 9; }
  .col-10 { grid-column: span 10; }
  .col-11 { grid-column: span 11; }
  .col-12 { grid-column: span 12; }
}

/* --- Section spacing --- */

.section {
  padding-block: var(--section-block);
}

.section-sm {
  padding-block: var(--space-12);
}

.section-md {
  padding-block: var(--space-20);
}

/* --- Background modifiers --- */

.bg-white { background-color: var(--color-bg); }
.bg-slate { background-color: var(--color-slate); }
.bg-dark  { background-color: var(--color-dark-section); }

/* --- 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-2  { gap: var(--space-2); }
.gap-3  { gap: var(--space-3); }
.gap-4  { gap: var(--space-4); }
.gap-6  { gap: var(--space-6); }
.gap-8  { gap: var(--space-8); }

/* --- Stack (vertical rhythm) --- */

.stack > * + * {
  margin-top: var(--space-4);
}

.stack-sm > * + * {
  margin-top: var(--space-2);
}

.stack-lg > * + * {
  margin-top: var(--space-8);
}

/* Default page wrapper. Constrains generic and
   WooCommerce shortcode pages within the grid. */
.page-main {
    padding-block: var(--section-block);
}

.page-content {
    max-width: 1240px; /* content column ceiling, sits inside grid margin */
    margin-inline: auto;
    padding-inline: var(--grid-margin);
}

.page-title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: var(--text-4xl);
    color: var(--color-ink);
    margin-bottom: var(--space-8);
}
