/* components/layout.css — Container, grid, flex, and spacing utilities. */

/* ── Containers ── */

.container {
  max-width: var(--layout-max-width);
  margin: 0 auto;
  padding: 0 var(--space-5);
}

.container-fluid {
  width: 100%;
  padding: 0 var(--space-5);
}

.main-container {
  min-height: calc(100vh - 140px);
  padding: var(--space-5) 0;
}

/* ── CSS Grid ── */

.grid {
  display: grid;
  gap: var(--space-5);
}

.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-auto {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.grid-responsive {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

/* ── Flex utilities ── */

.d-flex               { display: flex; }
.flex-column          { flex-direction: column; }
.flex-row             { flex-direction: row; }
.flex-wrap            { flex-wrap: wrap; }
.flex-1               { flex: 1; }

.justify-content-center  { justify-content: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-around  { justify-content: space-around; }
.align-items-center      { align-items: center; }
.align-items-start       { align-items: flex-start; }
.align-items-end         { align-items: flex-end; }

/* ── Spacing ── */

.m-0 { margin: 0; }
.m-1 { margin: var(--space-1); }
.m-2 { margin: var(--space-2); }
.m-3 { margin: var(--space-4); }
.m-4 { margin: var(--space-6); }
.m-5 { margin: var(--space-12); }

.p-0 { padding: 0; }
.p-1 { padding: var(--space-1); }
.p-2 { padding: var(--space-2); }
.p-3 { padding: var(--space-4); }
.p-4 { padding: var(--space-6); }
.p-5 { padding: var(--space-12); }

.mt-3 { margin-top: var(--space-4); }
.mb-3 { margin-bottom: var(--space-4); }
.ml-3 { margin-left: var(--space-4); }
.mr-3 { margin-right: var(--space-4); }

.pt-3 { padding-top: var(--space-4); }
.pb-3 { padding-bottom: var(--space-4); }
.pl-3 { padding-left: var(--space-4); }
.pr-3 { padding-right: var(--space-4); }

/* ── Text utilities ── */

.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }

.text-primary   { color: var(--color-primary); }
.text-secondary { color: var(--color-accent); }
.text-success   { color: var(--color-success); }
.text-danger    { color: var(--color-error); }
.text-warning   { color: var(--color-warning); }
.text-info      { color: var(--color-info); }
.text-muted     { color: var(--text-muted); }

.font-weight-normal { font-weight: var(--weight-normal); }
.font-weight-bold   { font-weight: var(--weight-semibold); }

/* ── Mobile ── */

@media (max-width: 768px) {
  .container {
    padding: 0 var(--space-3);
  }

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

  .main-container {
    padding: var(--space-2) 0;
  }
}

@media (max-width: 480px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
}
