/**
 * Layout CSS - Containers, Grid, Structure
 *
 * @package Dix
 * @since 1.0.0
 */

/* ==========================================================================
   SITE STRUCTURE
   ========================================================================== */

.site {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.site-content {
    flex: 1;
}

/* ==========================================================================
   CONTAINERS
   ========================================================================== */

.container {
    width: 100%;
    max-width: var(--container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
}

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

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

.container--full {
    max-width: none;
}

/* Header/Footer containers */
.header-container,
.footer-container {
    width: 100%;
    max-width: var(--container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
}

/* ==========================================================================
   GRID SYSTEM (CSS Grid)
   ========================================================================== */

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

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

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

/* Gap variations */
.grid--gap-sm {
    gap: var(--spacing-4);
}

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

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

/* ==========================================================================
   FLEX UTILITIES
   ========================================================================== */

.flex {
    display: flex;
}

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

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

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

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

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

.flex--start {
    justify-content: flex-start;
}

.flex--end {
    justify-content: flex-end;
}

.flex--align-start {
    align-items: flex-start;
}

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

.flex--align-end {
    align-items: flex-end;
}

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

.flex--gap-md {
    gap: var(--spacing-4);
}

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

/* ==========================================================================
   SECTIONS
   ========================================================================== */

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

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

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

.section--no-top {
    padding-top: 0;
}

.section--no-bottom {
    padding-bottom: 0;
}

.section--bg-secondary {
    background-color: var(--color-bg-secondary);
}

.section--bg-dark {
    background-color: var(--color-bg-dark);
    color: var(--color-text-inverse);
}

.section__header {
    text-align: center;
    margin-bottom: var(--spacing-12);
}

.section__title {
    margin-bottom: var(--spacing-4);
}

.section__subtitle {
    color: var(--color-text-secondary);
    font-size: var(--font-size-lg);
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

/* ==========================================================================
   RESPONSIVE GRID
   ========================================================================== */

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

    .section {
        padding-top: var(--spacing-12);
        padding-bottom: var(--spacing-12);
    }

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

@media (max-width: 768px) {
    :root {
        --container-padding: var(--spacing-4);
    }

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

    .section {
        padding-top: var(--spacing-10);
        padding-bottom: var(--spacing-10);
    }

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

    .section__header {
        margin-bottom: var(--spacing-8);
    }
}

/* ==========================================================================
   SPACING UTILITIES
   ========================================================================== */

.mt-0 { margin-top: 0; }
.mt-4 { margin-top: var(--spacing-4); }
.mt-6 { margin-top: var(--spacing-6); }
.mt-8 { margin-top: var(--spacing-8); }
.mt-12 { margin-top: var(--spacing-12); }

.mb-0 { margin-bottom: 0; }
.mb-4 { margin-bottom: var(--spacing-4); }
.mb-6 { margin-bottom: var(--spacing-6); }
.mb-8 { margin-bottom: var(--spacing-8); }
.mb-12 { margin-bottom: var(--spacing-12); }

.pt-0 { padding-top: 0; }
.pt-4 { padding-top: var(--spacing-4); }
.pt-6 { padding-top: var(--spacing-6); }
.pt-8 { padding-top: var(--spacing-8); }

.pb-0 { padding-bottom: 0; }
.pb-4 { padding-bottom: var(--spacing-4); }
.pb-6 { padding-bottom: var(--spacing-6); }
.pb-8 { padding-bottom: var(--spacing-8); }

/* ==========================================================================
   TEXT ALIGNMENT
   ========================================================================== */

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

/* ==========================================================================
   DISPLAY UTILITIES
   ========================================================================== */

.hidden {
    display: none !important;
}

@media (max-width: 768px) {
    .hidden-mobile {
        display: none !important;
    }
}

@media (min-width: 769px) {
    .hidden-desktop {
        display: none !important;
    }
}
