@media screen and (max-width: 768px) {

    
    /* === ÉLÉMENTS GÉNÉRAUX === */
    
    body {
        overflow-x: hidden;
    }
    
    /* === HEADER - LOGO ET DÉCO === */
    
    /* Masquer le texte décoratif sur mobile */
    .deco {
        display: none !important;
    }
    
    /* Ajuster le logo pour mobile */
    .logo {
        height: 35px;
        top: 20px;
        left: 20px;
    }
    
    /* === NAVIGATION CIRCULAIRE === */
    
    .circle-nav {
        top: 20px;
        left: auto;
        right: 15px;
        transform: none;
        flex-direction: column;
        align-items: flex-end;
        gap: 10px;
        max-width: auto;
    }
    
    .nav-circle {
        width: auto;
        min-width: 70px;
        height: 30px;
        border-radius: 20px;
        padding: 0 12px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .nav-circle:hover {
        width: auto;
        min-width: 90px;
        height: 32px;
    }
    
    .nav-label {
        font-size: 11px;
        opacity: 1 !important;
        position: static;
        transform: none;
        color: #000000 !important;
    }
    
    /* === SECTION ACCUEIL / HERO === */
    
    .section-hero {
        padding: 0;
    }
    
    /* Container de l'image */
    .hero-image-container {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        display: block;
        padding: 0;
        overflow: hidden;
    }
    
    /* Image hero - remplit tout l'écran avec zoom 150% */
    .hero-image {
        position: absolute !important;
        top: 55% !important;
        left: 55% !important;
        width: 150% !important;
        height: 150% !important;
        max-width: none !important;
        max-height: none !important;
        min-width: 150% !important;
        min-height: 150% !important;
        transform: translate(-50%, -50%) !important;
        object-fit: cover !important;
        object-position: center !important;
        margin: 0 !important;
    }
    
    @keyframes heroImageEntry {
        0% {
            opacity: 0;
            filter: blur(20px);
        }
        100% {
            opacity: 1;
            filter: none;
        }
    }
    
    /* Titres hero - superposés verticalement, centrés verticalement et alignés à gauche */
    .hero-title {
        font-size: 40vw !important;
        transform: scaleY(2);
        line-height: 0.9;
        white-space: normal;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
        letter-spacing: -1px;
        position: absolute;
        top: 55%;
        left: 20px;
        transform: translateY(-50%);
        width: calc(100% - 40px);
    }
    
    .hero-title span {
        margin: 0 !important;
        display: block;
    }
    
    .hero-title-foreground {
        font-size: 40vw !important;
        transform: scaleY(2);
        line-height: 0.9;
        white-space: normal;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
        letter-spacing: -1px;
        top: 55%;
        left: 20px;
        bottom: auto;
        transform: translateY(-50%);
        width: calc(100% - 40px);
        z-index: 0;
    }
    
    .hero-title-foreground span {
        margin: 0 !important;
        display: block;
    }
    
    @keyframes slideUpFade {
        0% {
            transform: translateY(-50%) translateX(-150px) scaleY(1);
            opacity: 0;
            filter: blur(10px);
        }
        100% {
            transform: translateY(-50%) translateX(0) scaleY(1.8);
            opacity: 1;
            filter: blur(0px);
        }
    }
    
    /* Flèche de scroll */
    .scroll-arrow {
        bottom: 100px;
        font-size: 18px;
        width: 35px;
        height: 35px;
    }
    
    /* Cercles animés */
    .circle {
        bottom: 15px;
    }
}

/* ============================================
   PETITS TÉLÉPHONES (max-width: 480px)
   ============================================ */

@media screen and (max-width: 480px) {
    
    /* === TEXTES ET TITRES ENCORE PLUS GRANDS === */
    
    .hero-title {
        font-size: 35vw !important;
        transform: scaleY(2);
    }
    
    .hero-title-foreground {
        font-size: 35vw !important;
        transform: scaleY(2);
    }
    
    /* === NAVIGATION === */
    
    .nav-circle {
        min-width: 85px;
        height: 30px;
        padding: 0 12px;
    }
    
    .circle-nav {
        gap: 8px;
        top: 20px;
        right: 15px;
    }
    
    .nav-label {
        font-size: 10px;
        color: #000000 !important;
    }
    
    /* === LOGO === */
    
    .logo {
        height: 30px;
        top: 15px;
        left: 15px;
    }
    
    /* === IMAGE HERO === */
    
    .hero-image {
        /* Pas de limitation supplémentaire - prend déjà tout l'écran */
    }
}

/* ============================================
   TRÈS PETITS ÉCRANS (max-width: 375px)
   ============================================ */

@media screen and (max-width: 375px) {
    
    .hero-title {
        font-size: 30vw !important;
        left: 15px;
    }
    
    .hero-title-foreground {
        font-size: 30vw !important;
        left: 15px;
    }
    
    .nav-circle {
        min-width: 80px;
        height: 28px;
        font-size: 9px;
    }
    
    .circle-nav {
        gap: 6px;
        top: 65px;
        right: 15px;
    }
    
    .nav-label {
        color: #000000 !important;
    }
}

/* ============================================
   MODE PAYSAGE (LANDSCAPE)
   ============================================ */

@media screen and (max-height: 500px) and (orientation: landscape) {
    
    .hero-title {
        font-size: 15vh !important;
    }
    
    .hero-title-foreground {
        font-size: 15vh !important;
    }
    
    .hero-image {
        max-height: 60vh;
    }
    
    .scroll-arrow {
        bottom: 15px;
        width: 30px;
        height: 30px;
        font-size: 14px;
    }
}

/* ============================================
   SECTION À PROPOS - RESPONSIVE
   ============================================ */

@media screen and (max-width: 768px) {
    
    /* === SECTION À PROPOS === */
    /* Surcharge complète du CSS existant */
    
    section#apropos.section {
        min-height: auto !important;
        height: auto !important;
        padding: 60px 20px !important;
        align-items: flex-start !important;
        justify-content: flex-start !important;
    }
    
    section#apropos .content {
        display: block !important;
        width: 100% !important;
    }
    
    section#apropos .qui {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        transform: none !important;
        font-size: 12vw !important;
        margin-bottom: 30px !important;
        text-align: center !important;
        transform: scaleY(2);
    }
    
    /* GRID - Surcharge le flexbox d'apropos.css */
    section#apropos .apropos-container {
        display: grid !important;
        grid-template-columns: 1fr !important;
        grid-template-rows: auto auto !important;
        gap: 40px !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        min-height: auto !important;
        flex-direction: row !important; /* Annule le column du CSS existant */
        position: static !important;
    }
    
    /* Zone de texte - Grid row 1 - SURCHARGE position absolute */
    section#apropos .text-zone {
        position: static !important;
        grid-row: 1 !important;
        grid-column: 1 !important;
        width: 75% !important;
        max-width: 80% !important;
        padding: 0 !important;
        top: auto !important;
        left: auto !important;
        flex: none !important;
        transform: translate(15%)
    }
    
    section#apropos .text-zone p {
        font-size: 1rem !important;
        line-height: 1.6 !important;
        margin-bottom: 20px !important;
        text-align: left !important;
        opacity: 1 !important;
    }
    
    /* Photo container - Grid row 2 - SURCHARGE position absolute/relative */
    section#apropos .photo-container {
        position: static !important;
        grid-row: 2 !important;
        grid-column: 1 !important;
        width: 100% !important;
        height: auto !important;
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        margin: 0 !important;
        right: auto !important;
        bottom: auto !important;
        opacity: 1 !important;
    }
    
    section#apropos .portrait-image {
        position: static !important;
        width: 100% !important;
        max-width: 450px !important;
        height: auto !important;
        border-radius: 15px !important;
        opacity: 1 !important;
        transform: none !important;
        animation: none !important;
    }
    
    /* Bouton CV */
    section#apropos .cv-button-container {
        margin-top: 30px !important;
        text-align: center !important;
        padding: 20px 0 !important;
    }
    
    section#apropos .button-blur {
        padding: 14px 28px !important;
        font-size: 1rem !important;
        width: auto !important;
        display: inline-flex !important;
    }
}

@media screen and (max-width: 480px) {
    
    section#apropos.section {
        padding: 50px 15px !important;
    }
    
    section#apropos .qui {
        font-size: 10vw !important;
        margin-bottom: 25px !important;
        position: relative !important;
        top: auto !important;
        left: auto !important;
        transform: none !important;
        transform: scaleY(2);
        opacity: 1;
    }
    
    section#apropos .apropos-container {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 30px !important;
        padding: 0 !important;
        position: static !important;
    }
    
    section#apropos .text-zone {
        position: static !important;
        grid-row: 1 !important;
        width: 100% !important;
        top: auto !important;
        left: auto !important;
    }
    
    section#apropos .photo-container {
        position: static !important;
        grid-row: 2 !important;
        width: 100% !important;
        height: auto !important;
        right: auto !important;
        bottom: auto !important;
    }
    
    section#apropos .text-zone p {
        font-size: 0.95rem !important;
        margin-bottom: 18px !important;
        opacity: 1 !important;
    }
    
    section#apropos .portrait-image {
        max-width: 100% !important;
        position: static !important;
        opacity: 1 !important;
        transform: none !important;
    }
    
    section#apropos .button-blur {
        padding: 12px 24px !important;
        font-size: 0.9rem !important;
    }
}

@media screen and (max-width: 375px) {
    
    section#apropos {
        padding: 40px 15px !important;
    }
    
    section#apropos .qui {
        font-size: 1.8rem !important;
    }
    
    section#apropos .apropos-container {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 30px !important;
    }
    
    section#apropos .text-zone {
        grid-row: 1 !important;
        width: 100% !important;
    }
    
    section#apropos .photo-container {
        grid-row: 2 !important;
        width: 100% !important;
    }
    
    section#apropos .text-zone p {
        font-size: 0.9rem !important;
        margin-bottom: 16px !important;
    }
}

/* ============================================
   SECTION PROJETS - RESPONSIVE
   ============================================ */

@media screen and (max-width: 768px) {
    
    /* === SECTION PROJETS === */
    
    section#projets.section-projets {
        flex-direction: column !important;
        padding: 60px 20px !important;
        justify-content: flex-start !important;
        align-items: flex-start !important;
    }
    
    /* Masquer complètement l'image de fond TV */
    section#projets .background-tv {
        display: none !important;
    }
    
    section#projets .tv-image {
        display: none !important;
    }
    
    section#projets .tv-screen {
        display: none !important;
    }
    
    /* Titre "Mes Réalisations" - Grand et centré */
    section#projets .projets-titre {
        position: relative !important;
        top: auto !important;
        left: -3% !important;
        transform: scaleY(2) !important;
        font-size: 12vw !important;
        text-align: center !important;
        width: 100% !important;
        margin-bottom: 40px !important;
        z-index: 10 !important;
    }
    
    /* Table section - Prend toute la largeur */
    section#projets .table-section {
        position: relative !important;
        width: 100% !important;
        margin-top: 0 !important;
        padding: 0 !important;
        background: transparent !important;
        min-height: auto !important;
        opacity: 1 !important;
        transform: none !important;
    }
    
    section#projets .table-header {
        margin-bottom: 30px !important;
        opacity: 1 !important;
        transform: none !important;
    }
    
    section#projets .table-header h2 {
        display: none !important;
    }
    
    section#projets .subtitle {
        font-size: 0.9rem !important;
        padding: 20px !important;
    }
    
    /* En-têtes de tableau - masquer sur mobile */
    section#projets .table-headers {
        display: none !important;
    }
    
    /* Lignes de projet - Layout vertical */
    section#projets .project-row {
        display: flex !important;
        flex-direction: column !important;
        gap: 15px !important;
        padding: 20px !important;
        margin-bottom: 15px !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border-radius: 10px !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        opacity: 1 !important;
        transform: none !important;
    }
    
    section#projets .project-row.expanded {
        background: rgba(255, 255, 255, 0.1) !important;
        padding: 25px 20px !important;
    }
    
    section#projets .cell {
        width: 100% !important;
    }
    
    section#projets .project-name {
        font-size: 1.1rem !important;
        margin-bottom: 10px !important;
        text-align: left !important;
    }
    
    section#projets .project-desc-short {
        font-size: 0.95rem !important;
        line-height: 1.5 !important;
    }
    
    section#projets .project-desc-long {
        font-size: 0.9rem !important;
        line-height: 1.6 !important;
    }
    
    section#projets .project-duration {
        font-size: 0.85rem !important;
        text-align: left !important;
        color: rgba(255, 255, 255, 0.7) !important;
        justify-content: flex-start !important;
    }
    
    section#projets .project-button {
        width: 100% !important;
        justify-content: center !important;
        padding: 12px 20px !important;
        font-size: 0.9rem !important;
    }
}

@media screen and (max-width: 480px) {
    
    section#projets.section-projets {
        padding: 50px 15px !important;
    }
    
    section#projets .projets-titre {
        font-size: 10vw !important;
        margin-bottom: 35px !important;
    }
    
    section#projets .subtitle {
        font-size: 0.85rem !important;
        padding: 18px !important;
    }
    
    section#projets .project-row {
        padding: 18px !important;
        margin-bottom: 12px !important;
    }
    
    section#projets .project-name {
        font-size: 1rem !important;
    }
    
    section#projets .project-desc-short,
    section#projets .project-desc-long {
        font-size: 0.88rem !important;
    }
}

@media screen and (max-width: 375px) {
    
    section#projets .projets-titre {
        font-size: 15vw !important;
        margin-bottom: 30px !important;
    }
    
    section#projets .project-row {
        padding: 15px !important;
    }
}

/* ============================================
   SECTION CONTACT - RESPONSIVE
   ============================================ */

@media screen and (max-width: 768px) {

    section#contact {
        display: grid !important;
        grid-template-columns: 1fr !important;
        grid-template-rows: auto auto auto !important;
        width: 100% !important;
        overflow: hidden !important;
        padding: 40px 20px !important;
        box-sizing: border-box !important;
        position: relative !important;
        min-height: auto !important;
        height: auto !important;
    }

    section#contact .contact-particles {
        grid-row: 1 !important;
        position: relative !important;
        inset: auto !important;
        transform: none !important;
        font-size: 18vw !important;
        text-align: center !important;
        line-height: 1.1 !important;
        letter-spacing: -2px !important;
        width: 100% !important;
        overflow: hidden !important;
        margin-bottom: 20px !important;
        pointer-events: none !important;
    }

    section#contact .contact-particles p {
        margin: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        line-height: 1.1 !important;
        transform: none !important;
    }

    section#contact .contact-particles p span {
        display: block !important;
        transform: none !important;
        line-height: 1.1 !important;
    }

    section#contact .contact-main-container {
        grid-row: 2 !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        grid-template-rows: auto auto !important;
        gap: 20px !important;
        width: 100% !important;
        position: relative !important;
        overflow: hidden !important;
    }

    /* MASQUER COMPLÈTEMENT LE LOGO 3D SUR MOBILE */
    section#contact .contact-logo-3d {
        display: none !important;
        visibility: hidden !important;
        pointer-events: none !important;
        height: 0 !important;
        width: 0 !important;
        overflow: hidden !important;
    }

    section#contact .contact-info-container {
        grid-row: 1 !important;
        position: relative !important;
        inset: auto !important;
        transform: none !important;
        opacity: 1 !important;
        width: 100% !important;
        max-width: 100% !important;
        transition: none !important;
        box-sizing: border-box !important;
    }

    section#contact .contact-info-container.active {
        transform: none !important;
        opacity: 1 !important;
    }

    section#contact .contact-form-container {
        grid-row: 2 !important;
        position: relative !important;
        inset: auto !important;
        transform: none !important;
        opacity: 1 !important;
        width: 100% !important;
        max-width: 100% !important;
        transition: none !important;
        box-sizing: border-box !important;
    }

    section#contact .contact-form-container.active {
        transform: none !important;
        opacity: 1 !important;
    }

    section#contact .social-links {
        flex-direction: column !important;
        gap: 8px !important;
        width: 100% !important;
    }

    section#contact .social-link {
        width: 100% !important;
        box-sizing: border-box !important;
    }

    section#contact .submit-button {
        width: 100% !important;
    }

    section#contact .contact-footer {
        grid-row: 3 !important;
        position: relative !important;
        inset: auto !important;
        transform: none !important;
        text-align: center !important;
        width: 100% !important;
        margin-top: 20px !important;
    }
}