/* ============================================
   NOURIMOI Vitrine - Responsive Design
   Mobile-first media queries
   ============================================ */

/* --- Tablet (max 1024px) --- */
@media (max-width: 1024px) {
    .hero-inner {
        grid-template-columns: 1fr;
        text-align: center;
        gap: var(--space-lg);
    }

    .hero-content {
        max-width: 100%;
    }

    .hero-buttons {
        justify-content: center;
    }

    .hero-stats {
        justify-content: center;
    }

    .hero-visual {
        max-width: 350px;
        margin: 0 auto;
    }

    .floating-element {
        font-size: 0.78rem;
        padding: 0.6rem 0.9rem;
    }

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

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

    .about-grid {
        grid-template-columns: 1fr;
        gap: var(--space-lg);
    }

    .about-image {
        order: -1;
        max-width: 500px;
        margin: 0 auto;
    }

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

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

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

    .steps-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-lg);
    }

    .step-card:not(:last-child)::after {
        display: none;
    }

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

    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-lg);
    }
}

/* --- Navigation compacte (max 1100px) --- */
@media (max-width: 1100px) {
    /* Navigation mobile */
    .navbar-menu {
        position: fixed;
        top: 0;
        right: -100%;
        width: 80%;
        max-width: 320px;
        height: 100vh;
        background: var(--cream);
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        padding: 100px var(--space-lg) var(--space-lg);
        gap: 0.3rem;
        transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: -10px 0 40px rgba(0,0,0,0.1);
        z-index: 999;
        border-left: 3px solid var(--beige-dark);
        white-space: normal;
    }

    .navbar-menu.open {
        right: 0;
    }

    .navbar-menu a {
        width: 100%;
        padding: 0.8rem 1rem;
        font-size: 1.05rem;
        border-radius: var(--radius-sm);
    }

    .navbar-cta {
        margin-left: 0;
        margin-top: var(--space-sm);
        width: 100%;
        gap: 0.65rem;
    }

    .navbar-cta .btn {
        width: 100%;
        justify-content: center;
    }

    .hamburger {
        display: flex;
    }

    /* Overlay quand menu ouvert */
    .menu-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0,0,0,0.3);
        z-index: 998;
    }

    .menu-overlay.active {
        display: block;
    }
}

/* --- Mobile Large (max 768px) --- */
@media (max-width: 768px) {
    html {
        font-size: 15px;
    }

    .section {
        padding: var(--space-xl) 0;
    }

    .navbar-logo .logo-image {
        height: 70px;
        width: auto;
        max-width: 200px;
    }

    /* Hero */
    .hero {
        min-height: auto;
        padding-top: calc(78px + var(--space-lg));
        padding-bottom: var(--space-xl);
    }

    .hero-visual {
        max-width: 280px;
    }

    .hero-visual .visual-main .visual-emoji {
        font-size: 5rem;
    }

    .hero-stats {
        gap: var(--space-md);
    }

    .hero-stat .stat-number {
        font-size: 1.6rem;
    }

    /* Grilles */
    .services-grid {
        grid-template-columns: 1fr;
    }

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

    .team-grid {
        grid-template-columns: 1fr;
        max-width: 400px;
        margin: 0 auto;
    }

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

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

    .steps-grid {
        grid-template-columns: 1fr;
        max-width: 350px;
        margin: 0 auto;
    }

    .values-list {
        grid-template-columns: 1fr;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: var(--space-lg);
    }

    .footer-bottom {
        flex-direction: column;
        text-align: center;
    }

    .form-row {
        grid-template-columns: 1fr;
    }

    .features-inline {
        gap: 0.5rem;
    }

    .feature-tag {
        font-size: 0.8rem;
        padding: 0.4rem 1rem;
    }
}

/* --- Mobile Small (max 480px) --- */
@media (max-width: 480px) {
    html {
        font-size: 14px;
    }

    .container {
        padding: 0 var(--space-sm);
    }

    .navbar-logo .logo-image {
        height: 60px;
        width: auto;
        max-width: 175px;
    }

    .hero-buttons {
        flex-direction: column;
        width: 100%;
    }

    .hero-buttons .btn {
        width: 100%;
        justify-content: center;
    }

    .hero-stats {
        flex-wrap: wrap;
        gap: var(--space-sm);
    }

    .impact-grid {
        grid-template-columns: 1fr;
        max-width: 300px;
        margin: 0 auto;
    }

    .partners-grid {
        grid-template-columns: 1fr;
        max-width: 300px;
        margin: 0 auto;
    }

    .service-card {
        padding: var(--space-md);
    }

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

    .btn-lg {
        padding: 0.9rem 2rem;
        font-size: 1rem;
    }

    .about-image .image-badge {
        position: relative;
        bottom: auto;
        right: auto;
        margin-top: var(--space-sm);
        text-align: center;
    }

    .scroll-top {
        bottom: 20px;
        right: 20px;
        width: 42px;
        height: 42px;
    }
}

/* --- Print --- */
@media print {
    .navbar,
    .scroll-top,
    .cta-section {
        display: none;
    }

    body {
        background: white;
        color: black;
    }

    .hero {
        min-height: auto;
        padding-top: 0;
    }
}
