:root {
    --zones-hero-gradient: linear-gradient(135deg, rgba(3, 3, 105, 0.95), rgba(3, 3, 105, 0.65));
}

.body--zones {
    background: var(--color-surface);
}

.page-hero--zones {
    position: relative;
    background: url("../../assets/images/about/entreprise.png") center/cover no-repeat;
    color: var(--color-base-00);
}

.page-hero--zones::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--zones-hero-gradient);
    z-index: 0;
}

.page-hero--zones .page-hero__container {
    position: relative;
    z-index: 1;
}

.page-hero--zones .page-hero__content h1 {
    color: var(--color-base-00);
    font-size: clamp(2rem, 3.2vw, 2.6rem);
}

.zones-hero__title {
    color: var(--color-primary);
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    font-weight: 600;
}

.page-hero--zones .page-hero__content p {
    color: rgba(255, 255, 255, 0.88);
}

.page-hero--zones .bullet-list {
    list-style: none;
    padding: 0;
    margin: 1.6rem 0 0;
    display: grid;
    gap: 0.8rem;
    color: rgba(255, 255, 255, 0.86);
}

.page-hero--zones .bullet-list li::before {
    content: "";
    display: inline-block;
    width: 0.9rem;
    height: 0.9rem;
    margin-right: 0.8rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.75);
}

.page-hero--zones .page-hero__media {
    background: rgba(255, 255, 255, 0.95);
    border-radius: 2rem;
    display: grid;
    gap: 1.4rem;
}

.zones-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.4rem;
}

.zones-columns ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.8rem;
    color: var(--color-base-80);
    font-size: clamp(1rem, 1.5vw, 1.2rem);
}

.zones-columns li {
    display: flex;
    align-items: center;
}

.zones-columns li::before {
    content: "";
    display: inline-block;
    width: 0.9rem;
    height: 0.9rem;
    margin-right: 0.8rem;
    border-radius: 999px;
    background: var(--color-primary);
}

.coverage-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: clamp(1.8rem, 3vw, 2.4rem);
    margin-top: clamp(2rem, 3vw, 3rem);
}

.coverage-card {
    display: grid;
    gap: 1.4rem;
    padding: clamp(2.4rem, 3vw, 3rem);
}

.coverage-card h3 {
    font-size: clamp(1.35rem, 2.3vw, 1.6rem);
    font-weight: 600;
    color: var(--color-primary);
}

.checklist {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.8rem;
    font-size: clamp(0.95rem, 1.4vw, 1.1rem);
    color: var(--color-base-80);
}

.checklist li::before {
    content: "";
    display: inline-block;
    width: 1rem;
    height: 1rem;
    margin-right: 0.75rem;
    border-radius: 999px;
    background: var(--color-primary);
}

.services-summary {
    gap: clamp(1.6rem, 3vw, 2.4rem);
}

.services-summary .card--accent {
    display: grid;
    gap: 1.2rem;
}

.services-summary .btn-link {
    color: var(--color-primary);
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
    font-size: clamp(1rem, 1.4vw, 1.2rem);
}

.services-summary .btn-link::after {
    content: "→";
    font-size: 1.4rem;
    transition: transform 0.2s ease;
}

.services-summary .btn-link:hover::after {
    transform: translateX(0.4rem);
}

.process-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.6rem, 3vw, 2.4rem);
}

.process-card {
    position: relative;
    padding: clamp(2.4rem, 3vw, 3rem);
    display: grid;
    gap: 1.2rem;
    border: 1px solid rgba(3, 3, 105, 0.12);
    border-radius: 2rem;
    background: var(--color-base-00);
}

.process-step {
    position: absolute;
    top: 2rem;
    right: 2.4rem;
    font-size: 1.2rem;
    letter-spacing: 0.28rem;
    text-transform: uppercase;
    color: var(--color-primary);
    font-weight: 600;
}

.page-hero--zones .btn-outline {
    color: var(--color-base-00);
    border-color: rgba(255, 255, 255, 0.72);
}

.page-hero--zones .btn-outline:hover {
    border-color: var(--color-base-00);
}

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

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

@media (max-width: 768px) {
    .page-hero--zones {
        background-position: center;
    }

    .coverage-grid {
        grid-template-columns: 1fr;
    }

    .process-grid {
        grid-template-columns: 1fr;
    }
}
