/* =================================================================
   LAYOUT — Grilles, split-layouts, structures de page
   ================================================================= */

/* ----- Split Layout (Philosophie, etc.) ----- */

.split-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s-gap-lg);
    align-items: center;
}

/* ----- Section Header ----- */

.section-header {
    max-width: 700px;
    margin: 0 auto clamp(3rem, 6vw, 5rem);
    text-align: center;
}

.section-header .display-text {
    margin-top: 0;
}

.section-header p {
    margin-top: 1.25rem;
    font-size: var(--fs-lead);
}

/* ----- Service Grid ----- */

.service-list {
    display: flex;
    gap: var(--s-gap-sm);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    /* Break out of container */
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    padding-left: max(var(--s-gap-sm), calc(50vw - 1600px / 2));
    padding-right: max(var(--s-gap-sm), calc(50vw - 1600px / 2));
}

.service-list::-webkit-scrollbar {
    display: none;
}

.service-card {
    min-width: 280px;
    flex: 0 0 280px;
    scroll-snap-align: center;
}

/* ----- Footer Grid ----- */

.footer-top {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--s-gap-md);
    margin-bottom: var(--s-gap-lg);
}

/* ----- Instagram Grid ----- */

.insta-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--s-gap-xxs);
}

/* ----- Desktop overrides (min-width: 768px) ----- */

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

    .footer-top {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: var(--s-gap-lg);
    }
}

/* ----- Desktop overrides (min-width: 1024px) ----- */

@media (min-width: 1024px) {
    .split-layout {
        grid-template-columns: 1fr 1fr;
        gap: var(--s-gap-lg);
    }

    .service-card {
        min-width: 0;
        flex: 1;
    }
}

/* ----- Large Desktop overrides (min-width: 1200px) ----- */
@media (min-width: 1200px) {
    .split-layout {
        gap: var(--s-gap-xl);
    }
}