/* ============================================================
   ALSACARD — Section Alsa'Card, Zone d'intervention, Carousels
   ============================================================ */

/* === SECTION ALSA'CARD === */
.alsacard-content {
    background: transparent;
}

.alsacard-subtitle {
    font-size: 1.2rem;
    color: var(--primary);
    margin-top: 1.5rem;
    margin-bottom: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.5px;
}

.alsacard-offre {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 1.5rem;
}

.alsacard-price {
    font-size: 1.3rem;
    color: var(--secondary);
    margin-bottom: 1rem;
    font-weight: 600;
}

.shipping {
    font-size: 0.9rem;
    color: var(--text-muted);
    font-style: italic;
    margin-top: 0.3rem;
}

.alsacard-btn-wrapper {
    display: flex;
    justify-content: center;
    width: 100%;
}

.alsacard-ideal {
    margin: 1.2rem 0 1.5rem;
    font-size: 1rem;
    color: var(--text-dark);
    text-align: center;
}

.alsacard-tags {
    display: inline-block;
    background: #ccd7ff;
    color: #000;
    border-radius: 2rem;
    padding: 0.4rem 1.2rem;
    font-size: 0.95rem;
    margin-top: 0.5rem;
    font-weight: 500;
    letter-spacing: 0.5px;
}

body.light-mode .alsacard-tags {
    background: rgba(109, 141, 255, 0.2);
    color: var(--text-dark);
}

/* --- Cards Alsa'Card --- */
.alsacard-cards {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: center;
    margin-bottom: 2rem;
}

.alsacard-card {
    background: var(--bg-card-transparent);
    backdrop-filter: blur(4px);
    border-radius: 1rem;
    box-shadow: var(--box-shadow);
    padding: 1.2rem 1.1rem 1.1rem;
    min-width: 200px;
    max-width: 270px;
    flex: 1 1 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.alsacard-card:hover {
    box-shadow: var(--box-shadow-lg);
    transform: translateY(-4px) scale(1.03);
    transition:
        box-shadow 0.2s,
        transform 0.2s;
}

body.light-mode .alsacard-card {
    background-color: var(--bg-card-transparent);
}

.alsacard-icon {
    font-size: 2.2rem;
    color: var(--primary);
    margin-bottom: 0.7rem;
    text-align: center;
}

.alsacard-card-content h4 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 0.3rem;
    color: var(--text-dark);
    text-align: center;
}

.alsacard-card-content p {
    font-size: 0.98rem;
    color: var(--text-muted);
    text-align: center;
    margin-bottom: 0;
}

/* === ZONE D'INTERVENTION === */
.coverage-text h3 {
    color: var(--primary);
    font-size: var(--font-size-xl);
    margin-bottom: var(--spacing-lg);
    font-weight: var(--font-weight-bold);
}

.coverage-text p {
    font-size: var(--font-size-lg);
    line-height: 1.8;
    margin-bottom: var(--spacing-xl);
    color: var(--text-dark);
}

.cities-served h4 {
    color: var(--secondary);
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-lg);
    font-weight: var(--font-weight-semibold);
}

.cities-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--spacing-md);
    list-style: none;
}

.cities-list li {
    background-color: var(--bg-dark);
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    border-left: 4px solid var(--primary);
    transition: var(--transition);
    font-size: var(--font-size-base);
}

.cities-list li:hover {
    transform: translateX(5px);
    box-shadow: var(--box-shadow);
    border-left-color: var(--secondary);
}

.cities-list li strong {
    color: var(--primary);
}

body.light-mode .cities-list li {
    background-color: #000;
}
body.light-mode .cities-list li * {
    color: var(--text-dark);
}

.coverage-features {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.feature-card {
    background-color: var(--bg-dark);
    padding: var(--spacing-lg);
    border-radius: var(--border-radius);
    text-align: center;
    transition: var(--transition);
    box-shadow: var(--box-shadow);
}

.feature-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--box-shadow-lg);
}

.feature-card i {
    font-size: var(--font-size-2xl);
    color: var(--primary);
    margin-bottom: var(--spacing-md);
}

.feature-card h4 {
    color: var(--primary);
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-sm);
    font-weight: var(--font-weight-bold);
}

.feature-card p {
    color: var(--text-dark);
    font-size: var(--font-size-sm);
    line-height: 1.6;
}

body.light-mode .feature-card {
    background-color: #000;
}
body.light-mode .feature-card * {
    color: var(--text-dark);
}

/* === CAROUSELS MOBILE / DESKTOP === */

/* Desktop : grilles visibles, carousels cachés */
.alsacard-carousel {
    display: none;
}

.desktop-only {
    display: initial;
}
.skills-grid.desktop-only {
    display: grid;
}
.projects-grid.desktop-only {
    display: grid;
}
.contact-links.desktop-only {
    display: flex;
}
.alsacard-cards.desktop-only {
    display: flex;
}

.mobile-carousel {
    display: none;
}

/* Mobile */
@media (max-width: 768px) {
    /* Masquer les éléments desktop */
    .desktop-only {
        display: none !important;
    }
    .alsacard-cards {
        display: none;
    }

    /* Carousel générique */
    .mobile-carousel {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: none;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        margin: 0 -1.5rem;
        padding: 0 1.5rem 1rem;
        gap: var(--spacing-md);
        cursor: grab;
    }

    .mobile-carousel.grabbing {
        cursor: grabbing;
        user-select: none;
    }
    .mobile-carousel::-webkit-scrollbar {
        display: none;
    }

    .mobile-carousel-item {
        flex: 0 0 100%;
        scroll-snap-align: center;
    }

    /* Carousel Alsa'Card */
    .alsacard-carousel {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        margin: 0 -1.5rem;
        padding: 1rem 1.5rem;
        gap: 1rem;
    }

    .alsacard-carousel::-webkit-scrollbar {
        display: none;
    }

    .alsacard-carousel-item {
        flex: 0 0 85%;
        scroll-snap-align: center;
        min-width: 220px;
        max-width: 270px;
    }

    .alsacard-carousel .alsacard-card {
        box-shadow: var(--box-shadow-md);
    }

    /* Tailles spécifiques des carousels */
    .skills-carousel .skill-card {
        flex: 0 0 320px;
        margin-bottom: var(--spacing-md);
    }
    .projects-carousel .project-card {
        flex: 0 0 280px;
        height: 380px;
        padding-bottom: 10px;
    }
    .contact-carousel .contact-link {
        flex: 0 0 250px;
        margin-block: var(--spacing-md);
    }

    /* Indicateur de défilement */
    .section::after {
        content: "";
        display: none;
        width: 50px;
        height: 4px;
        background-color: var(--primary);
        margin: var(--spacing-lg) auto 0;
        border-radius: 2px;
        opacity: 0.7;
    }

    .section.has-carousel::after {
        display: block;
        animation: pulse-scroll 2s infinite;
    }

    @keyframes pulse-scroll {
        0%,
        100% {
            opacity: 0.4;
            width: 30px;
        }
        50% {
            opacity: 0.8;
            width: 50px;
        }
    }

    /* Responsive coverage */
    .cities-list {
        grid-template-columns: 1fr;
    }
    .coverage-features {
        flex-direction: column;
    }
    .feature-card {
        max-width: none;
    }
}

@media (max-width: 480px) {
    .skills-carousel .skill-card {
        flex: 0 0 280px;
    }
    .projects-carousel .project-card {
        flex: 0 0 260px;
        height: 350px;
    }
    .contact-carousel .contact-link {
        flex: 0 0 280px;
        height: 150px;
    }
}

/* Coverage tablette */
@media (max-width: 992px) {
    .coverage-content {
        grid-template-columns: 1fr;
        gap: var(--spacing-2xl);
    }

    .cities-list {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    }

    .coverage-features {
        flex-direction: row;
        justify-content: space-around;
    }

    .feature-card {
        flex: 1;
        max-width: 200px;
    }
}

/* Coverage mobile */
@media (max-width: 768px) {
    .coverage-features {
        flex-direction: column;
        justify-content: flex-start;
    }

    .feature-card {
        max-width: 100%;
    }
}
