/* ==========================================================================
   Layout — Container, Grid, Section Utilities
   ========================================================================== */

/* Containers */
.container {
    width: 100%;
    max-width: var(--max-container);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--space-md);
    padding-right: var(--space-md);
}

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

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

/* Grid */
.grid {
    display: grid;
    gap: var(--space-lg);
}

.grid--2 {
    grid-template-columns: repeat(2, 1fr);
}

.grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

.grid--4 {
    grid-template-columns: repeat(4, 1fr);
}

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

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

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

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

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

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

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

/* Sections */
.section {
    padding-top: var(--space-3xl);
    padding-bottom: var(--space-3xl);
}

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

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

.section--white { background-color: var(--color-bg); }
.section--light { background-color: var(--color-bg-light); }
.section--dark {
    background-color: var(--color-bg-dark);
    color: var(--color-text-inverse);
}
.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4 {
    color: var(--color-text-inverse);
}
.section--dark p,
.section--dark li {
    color: rgba(255, 255, 255, 0.85);
}
.section--dark a:not(.btn) {
    color: var(--color-accent-light);
}
.section--dark .section-label {
    color: var(--color-accent);
}
.section--darker {
    background-color: var(--color-bg-darker);
    color: var(--color-text-inverse);
}
.section--darker h1,
.section--darker h2,
.section--darker h3,
.section--darker h4 {
    color: var(--color-text-inverse);
}
.section--darker p,
.section--darker li {
    color: rgba(255, 255, 255, 0.85);
}
.section--darker a:not(.btn) {
    color: var(--color-accent-light);
}
.section--darker .section-label {
    color: var(--color-accent);
}

/* Section header (centered intro text) */
.section-header {
    max-width: var(--max-wide);
    margin-bottom: var(--space-2xl);
}

.section-header--center {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.section-header h2 {
    margin-bottom: var(--space-sm);
}

.section-header p {
    font-size: var(--text-lg);
    color: var(--color-text-light);
    max-width: 640px;
}

.section-header--center p {
    margin-left: auto;
    margin-right: auto;
}

/* Two-column layout (text + image) */
.split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2xl);
    align-items: center;
}

.split--reverse {
    direction: rtl;
}

.split--reverse > * {
    direction: ltr;
}

@media (max-width: 768px) {
    .split,
    .split--reverse {
        grid-template-columns: 1fr;
        direction: ltr;
    }
}

.split__image img {
    border-radius: var(--radius-lg);
    width: 100%;
    object-fit: cover;
}

.split__content h2,
.split__content h3 {
    margin-bottom: var(--space-sm);
}

.split__content p {
    margin-bottom: var(--space-md);
}
