/* Layout containers */
.container {
  width: 100%;
  max-width: var(--container-xl);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

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

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

/* Page Layout grid (main + sidebar) */
.page-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  margin-top: var(--space-8);
  margin-bottom: var(--space-12);
}

@media (min-width: 1024px) {
  .page-layout {
    grid-template-columns: 1fr 320px;
  }
}

.page-layout__main {
  min-width: 0; /* Prevents overflow in grid items */
}

.page-layout__sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.sticky-sidebar {
  position: static;
}

@media (min-width: 1024px) {
  .sticky-sidebar {
    position: sticky;
    top: 90px;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
    padding-right: 4px;
  }
}

/* Grids */
.grid {
  display: grid;
  gap: var(--space-4);
}

.grid--2col { grid-template-columns: 1fr; }
.grid--3col { grid-template-columns: 1fr; }
.grid--4col { grid-template-columns: 1fr; }

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

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

.grid--auto-fill {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

/* Flex utilities */
.flex {
  display: flex;
}

.flex--between { justify-content: space-between; }
.flex--center { justify-content: center; align-items: center; }
.flex--align-center { align-items: center; }
.flex--wrap { flex-wrap: wrap; }
.flex--col { flex-direction: column; }

.flex--gap-sm { gap: var(--space-2); }
.flex--gap-md { gap: var(--space-4); }
.flex--gap-lg { gap: var(--space-8); }

/* Section spacing */
.section {
  padding-top: var(--space-8);
  padding-bottom: var(--space-8);
}

.section--sm {
  padding-top: var(--space-4);
  padding-bottom: var(--space-4);
}

.section--lg {
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
}

.section__title {
  margin-bottom: var(--space-2);
}

.section__subtitle {
  color: var(--text-muted);
  font-size: var(--fs-lg);
  margin-bottom: var(--space-8);
}
