/* ============================================
   STMP LOCATION — Responsive Styles
   Mobile-First Breakpoints
   ============================================ */

/* ---- Tablet & Below (max-width: 1024px) ---- */
@media (max-width: 1024px) {
    :root {
        --text-6xl: 2.75rem;
        --text-5xl: 2.25rem;
        --text-4xl: 2rem;
    }

    .hero-content {
        grid-template-columns: 1fr;
        text-align: center;
        gap: var(--space-2xl);
    }

    .hero-text {
        order: 1;
    }

    .hero-visual {
        order: 2;
    }

    .hero-description {
        margin: 0 auto var(--space-2xl);
    }

    .hero-actions {
        justify-content: center;
        flex-wrap: wrap;
    }

    .hero-stats {
        justify-content: center;
    }

    .hero-floating-card-1 {
        left: 10px;
        bottom: -10px;
    }

    .hero-floating-card-2 {
        right: 10px;
    }

    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .categories-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .category-card.featured {
        grid-column: span 2;
        grid-row: span 1;
    }

    .products-carousel {
        grid-template-columns: repeat(2, 1fr);
    }

    .agencies-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-main {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-2xl);
    }

    .footer-brand {
        grid-column: span 2;
        padding-right: 0;
    }
}

/* ---- Mobile Large (max-width: 768px) ---- */
@media (max-width: 768px) {
    :root {
        --text-6xl: 2.25rem;
        --text-5xl: 2rem;
        --text-4xl: 1.75rem;
        --text-3xl: 1.5rem;
        --header-height: 70px;
    }

    .section {
        padding: var(--space-3xl) 0;
    }

    .container {
        padding: 0 var(--space-lg);
    }

    /* --- Header Mobile --- */

    /* Logo : taille réduite sur mobile */
    .header-logo img {
        height: 38px;
    }

    /* Bouton devis compact */
    .btn-devis {
        padding: 8px 14px;
        font-size: var(--text-xs);
        white-space: nowrap;
    }

    /* Afficher le bouton hamburger */
    .mobile-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        border-radius: var(--radius-md);
        background: var(--color-light-gray);
        flex-shrink: 0;
    }

    .mobile-toggle span {
        width: 20px;
        height: 2px;
    }

    /* Cacher le téléphone dans le header (visible dans le nav mobile) */
    .header-phone {
        display: none;
    }

    /* Overlay sombre derrière le menu */
    .mobile-overlay {
        display: none;
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 998;
        backdrop-filter: blur(2px);
    }

    .mobile-overlay.active {
        display: block;
    }

    /* Panneau de navigation latéral */
    .header-nav {
        position: fixed;
        top: 0;
        right: -100%;
        width: 82%;
        max-width: 320px;
        height: 100vh;
        background: var(--color-white);
        flex-direction: column;
        align-items: stretch;
        padding: 0;
        box-shadow: -8px 0 40px rgba(0, 0, 0, 0.15);
        transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1);
        gap: 0;
        overflow-y: auto;
        z-index: 999;
    }

    .header-nav.open {
        right: 0;
    }

    /* En-tête du panneau nav avec logo STMP */
    .header-nav::before {
        content: 'STMP Location';
        display: block;
        padding: var(--space-xl) var(--space-xl) var(--space-lg);
        font-family: var(--font-display);
        font-size: var(--text-xl);
        font-weight: 800;
        color: var(--color-secondary);
        border-bottom: 2px solid var(--color-primary);
        background: var(--color-off-white);
        margin-bottom: var(--space-sm);
    }

    /* Liens de navigation dans le panneau */
    .nav-link {
        width: 100%;
        display: flex;
        align-items: center;
        padding: 16px var(--space-xl);
        font-size: var(--text-base);
        font-weight: 500;
        border-bottom: 1px solid var(--color-light-gray);
        color: var(--color-text);
        min-height: 54px;
        transition: background var(--transition-fast), color var(--transition-fast);
    }

    .nav-link:hover,
    .nav-link.active {
        background: rgba(200, 16, 46, 0.05);
        color: var(--color-primary);
        padding-left: calc(var(--space-xl) + 4px);
    }

    .nav-link::after {
        display: none;
    }

    /* Bouton devis dans le panneau nav mobile */
    .header-nav::after {
        content: '';
        display: block;
        flex: 1;
    }

    /* Téléphone en bas du panneau nav */
    .header-nav .nav-phone-mobile {
        display: flex;
        align-items: center;
        gap: var(--space-sm);
        padding: var(--space-lg) var(--space-xl);
        background: var(--color-light-gray);
        color: var(--color-secondary);
        font-weight: 600;
        margin-top: auto;
        border-top: 1px solid var(--color-gray);
    }

    /* Hero Mobile */
    .hero {
        min-height: auto;
        padding: calc(var(--header-height) + var(--space-xl)) 0 var(--space-3xl);
    }

    .hero-content {
        gap: var(--space-2xl);
    }

    .hero-image-container {
        max-width: 100%;
    }

    /* Hide floating cards on mobile to avoid overlap */
    .hero-floating-card {
        display: none;
    }

    .hero-stats {
        flex-wrap: wrap;
        gap: var(--space-xl);
        justify-content: flex-start;
    }

    .hero-stat {
        text-align: left;
        min-width: 100px;
    }

    /* Services */
    .services-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-lg);
    }

    /* Categories */
    .categories-grid {
        grid-template-columns: 1fr;
    }

    .category-card.featured {
        grid-column: span 1;
    }

    .category-card {
        aspect-ratio: 16/9;
    }

    /* Products */
    .products-carousel {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-lg);
    }

    /* CTA */
    .cta-banner-actions {
        flex-direction: column;
    }

    /* Agencies */
    .agencies-grid {
        grid-template-columns: 1fr;
    }

    /* Footer */
    .footer-main {
        grid-template-columns: 1fr;
        gap: var(--space-2xl);
    }

    .footer-brand {
        grid-column: span 1;
    }

    .footer-bottom {
        flex-direction: column;
        gap: var(--space-md);
        text-align: center;
    }
}

/* ---- Mobile Small (max-width: 480px) ---- */
@media (max-width: 480px) {
    :root {
        --text-6xl: 1.875rem;
        --text-5xl: 1.75rem;
        --text-4xl: 1.5rem;
        --text-3xl: 1.25rem;
    }

    .container {
        padding: 0 var(--space-md);
    }

    .services-grid {
        grid-template-columns: 1fr;
    }

    .products-carousel {
        grid-template-columns: 1fr;
    }

    .hero-actions {
        flex-direction: column;
        width: 100%;
    }

    .hero-actions .btn {
        width: 100%;
    }

    .btn-lg {
        padding: 16px 32px;
        font-size: var(--text-base);
    }

    .cta-banner-content h2 {
        font-size: var(--text-2xl);
    }
}

/* ---- Large Desktop (min-width: 1440px) ---- */
@media (min-width: 1440px) {
    :root {
        --max-width: 1380px;
    }
}

/* --- Éléments visibles uniquement dans le menu mobile --- */
.nav-phone-mobile,
.nav-mobile-cta {
    display: none;
}

/* Ces éléments s'affichent dans le panneau nav mobile (via JS .open) */
@media (max-width: 768px) {
    .nav-phone-mobile {
        display: flex;
        align-items: center;
        gap: var(--space-sm);
        padding: var(--space-lg) var(--space-xl);
        background: var(--color-light-gray);
        color: var(--color-secondary);
        font-weight: 600;
        font-size: var(--text-sm);
        border-top: 1px solid var(--color-gray);
        margin-top: var(--space-lg);
    }

    .nav-mobile-cta {
        display: block;
        padding: var(--space-lg) var(--space-xl);
        border-top: 1px solid var(--color-gray);
    }
}