html { background-color: #1a2436 !important; scroll-behavior: smooth; margin: 0; padding: 0; }
body { max-width: 100%; overflow-x: hidden; width: 100%; margin: 0; padding: 0; display: flex; flex-direction: column; min-height: 100vh; font-family: 'Poppins', sans-serif; background-color: #f4f4f9; }

/* HEADER UNIQUE */
.site-header { position: sticky !important; top: 15px !important; z-index: 9999 !important; background: linear-gradient(90deg, #ff7b00, #00c2ff) !important; color: #fff !important; box-shadow: 0 6px 20px rgba(0,0,0,0.15) !important; width: calc(100% - 30px) !important; max-width: 1200px !important; margin: 15px auto 40px auto !important; border-radius: 16px !important; padding: 0 !important; border: none !important; box-sizing: border-box !important; }
.hero { display: flex !important; align-items: center !important; justify-content: space-between !important; padding: 10px 20px !important; background: transparent !important; box-sizing: border-box !important; min-height: 80px !important; }
.brand-group { display: flex !important; align-items: center !important; gap: 14px !important; text-decoration: none !important; }
.brand-group img.logo { width: 60px !important; height: 60px !important; border-radius: 10px !important; background: #fff !important; padding: 2px !important; box-shadow: 0 2px 5px rgba(0,0,0,0.1) !important; margin: 0 !important; border: none !important; box-sizing: border-box !important; }
h1.logo-title { font-size: clamp(16px, 2vw, 20px) !important; font-weight: 700 !important; margin: 0 !important; color: #fff !important; text-align: left !important; border: none !important; padding: 0 !important; line-height: 1.2 !important; }
.hero-text .sub { font-size: 0.85rem !important; opacity: 0.95 !important; margin: 4px 0 0 !important; color: #fff !important; border: none !important; padding: 0 !important; line-height: 1.2 !important; }
.nav-links { display: flex !important; gap: 10px !important; align-items: center !important; flex-wrap: wrap !important; justify-content: center !important; margin: 0 !important; padding: 0 !important; }
.nav-links a { background-color: #ffffff !important; color: #007bff !important; padding: 8px 16px !important; border-radius: 8px !important; text-decoration: none !important; font-weight: 700 !important; font-size: 0.90rem !important; text-transform: uppercase !important; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1) !important; transition: all 0.3s ease !important; text-align: center !important; box-sizing: border-box !important; border: none !important; }
.nav-links a:hover { background-color: #05037b !important; color: #ffffff !important; transform: translateY(-2px) !important; box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15) !important; }

/* --- STYLE DU BOUTON BURGER --- */
.burger-menu {
    display: none; /* Caché sur PC */
    background: transparent;
    border: none;
    color: #ffffff;
    font-size: 1.8rem;
    cursor: pointer;
    padding: 5px 10px;
    margin-left: auto; /* Pousse le bouton à droite */
}

/* --- ADAPTATION ULTRA-COMPACTE POUR LES TÉLÉPHONES --- */
@media (max-width: 768px) {
    .site-header { width: calc(100% - 14px) !important; margin: 5px auto 15px auto !important; top: 5px !important; }
    
    /* La barre du haut garde le logo à gauche et le burger à droite */
    .hero { 
        flex-direction: row !important; 
        flex-wrap: wrap !important; 
        padding: 10px 15px !important; 
    }
    
    .brand-group img.logo { width: 40px !important; height: 40px !important; }
    h1.logo-title { font-size: 1.1rem !important; }
    .hero-text .sub { display: none !important; } 

    /* On affiche le bouton burger */
    .burger-menu { display: block !important; }

    /* On cache les liens par défaut et on les met en colonne */
    .nav-links { 
        display: none !important; /* Caché par défaut */
        width: 100% !important; 
        flex-direction: column !important; 
        gap: 8px !important; 
        padding-top: 15px !important;
        margin-top: 10px !important;
        border-top: 1px solid rgba(255,255,255,0.2);
    }

    /* La classe 'open' est ajoutée par le Javascript quand on clique sur le burger */
    .nav-links.open { 
        display: flex !important; 
    }

    .nav-links a { 
        width: 100% !important; 
        font-size: 0.85rem !important; 
        padding: 10px !important; 
    }

    /* Ajustement de la boîte principale du formulaire sur mobile */
    .catalogue-request-block { 
        padding: 15px !important; 
        margin: 15px 5px !important; 
    }
}

/* FORMULAIRE DEVIS */
.catalogue-request-block { margin: 30px auto; padding: 30px; background-color: #ffffff; border-radius: 12px; border: 1px solid #dde1ea; box-shadow: 0 4px 15px rgba(0,0,0,0.05); }
.catalogue-request-block h2 { margin-top: 0; margin-bottom: 10px; color: #1a2436; }
.catalogue-request-block p.helper { margin-top: 0; margin-bottom: 25px; font-size: 1rem; color: #555; }
.catalogue-form-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); column-gap: 16px; row-gap: 15px; margin-bottom: 20px; }
@media (max-width: 900px) { .catalogue-form-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 600px) { .catalogue-form-grid { grid-template-columns: 1fr; } }
.catalogue-form-grid > div { min-width: 0; width: 100%; }
.catalogue-request-block label { font-size: 0.9rem; font-weight: 600; margin-bottom: 6px; display: block; color: #333;}
.catalogue-request-block select, .catalogue-request-block input, .catalogue-request-block textarea { width: 100%; padding: 10px; border-radius: 6px; border: 1px solid #cbd0dd; font-size: 1rem; box-sizing: border-box; font-family: 'Poppins', sans-serif;}
.catalogue-request-block select:focus, .catalogue-request-block input:focus, .catalogue-request-block textarea:focus {outline: none; border-color:#007bff; box-shadow: 0 0 0 2px rgba(0,123,255,0.1);}
.catalogue-request-block textarea { min-height: 100px; resize: vertical; }

.catalogue-request-block .btn-row { margin-top: 15px; margin-bottom: 25px; display: flex; gap: 15px; flex-wrap: wrap; }
.catalogue-request-block .btn-primary, .catalogue-request-block .btn-secondary { border: none; border-radius: 6px; padding: 12px 24px; font-size: 1rem; cursor: pointer; font-weight: 600; transition: 0.3s; }
.catalogue-request-block .btn-primary { background-color: #007bff; color: #ffffff; }
.catalogue-request-block .btn-primary:hover { background-color: #0056b3; }
.catalogue-request-block .btn-primary:disabled, .catalogue-request-block .btn-secondary:disabled { opacity: 0.6; cursor: not-allowed; }
.catalogue-request-block .btn-secondary { background-color: #f4f4f9; color: #333333; border: 1px solid #ccd1dd; }
.catalogue-request-block .btn-secondary:hover { background-color: #e2e8f0; }

/* --- RESPONSIVITÉ DU TABLEAU DE DEVIS --- */
.table-responsive {
    width: 100%;
    overflow-x: auto; /* Active le scroll horizontal automatique */
    -webkit-overflow-scrolling: touch; /* Rend le défilement fluide sur iPhone */
    margin-bottom: 25px;
}

/* On force le tableau à garder une taille raisonnable pour qu'il soit lisible */
.catalogue-recap-table {
    width: 100%; 
    min-width: 800px; /* On augmente un peu la largeur minimale pour donner de la place à la colonne Impression */
    border-collapse: collapse; 
    margin-bottom: 0 !important; 
    font-size: 0.95rem; 
    table-layout: fixed; /* Force le navigateur à respecter nos largeurs de colonnes */
}

/* On donne des tailles précises aux colonnes pour éviter qu'elles ne s'écrasent */
.catalogue-recap-table th:nth-child(1), .catalogue-recap-table td:nth-child(1) { width: 5%; } /* # */
.catalogue-recap-table th:nth-child(2), .catalogue-recap-table td:nth-child(2) { width: 25%; } /* Article */
.catalogue-recap-table th:nth-child(3), .catalogue-recap-table td:nth-child(3) { width: 12%; } /* Couleur */
.catalogue-recap-table th:nth-child(4), .catalogue-recap-table td:nth-child(4) { width: 8%; }  /* Taille */
.catalogue-recap-table th:nth-child(5), .catalogue-recap-table td:nth-child(5) { width: 30%; } /* Impression (Prend le plus de place) */
.catalogue-recap-table th:nth-child(6), .catalogue-recap-table td:nth-child(6) { width: 5%; }  /* Qté */
.catalogue-recap-table th:nth-child(7), .catalogue-recap-table td:nth-child(7) { width: 15%; } /* Livraison */

.catalogue-recap-table th, .catalogue-recap-table td { 
    border: 1px solid #dde1ea; 
    padding: 10px; 
    text-align: left; 
    word-wrap: break-word; /* Force le texte trop long à passer à la ligne s'il n'a pas le choix */
}
.catalogue-recap-table th { background-color: #f1f3f9; color: #1a2436; }
.catalogue-recap-empty { font-size: 1rem; color: #777; margin-bottom: 25px; font-style: italic; }

.catalogue-recap-table { width: 100%; border-collapse: collapse; margin-bottom: 25px; font-size: 0.95rem; }
.catalogue-recap-table th, .catalogue-recap-table td { border: 1px solid #dde1ea; padding: 10px; text-align: left; }
.catalogue-recap-table th { background-color: #f1f3f9; color: #1a2436; }
.catalogue-recap-empty { font-size: 1rem; color: #777; margin-bottom: 25px; font-style: italic; }

.catalogue-request-block .client-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 15px; margin-top: 15px; margin-bottom: 15px; }
@media (max-width: 700px) { .catalogue-request-block .client-grid { grid-template-columns: 1fr; } }
.catalogue-request-block .status-message { font-size: 1rem; margin-top: 15px; text-align:center; font-weight: bold;}
.catalogue-request-block .status-success { color: #1a7f37; }
.catalogue-request-block .status-error { color: #c62828; }

.catalogue-form-grid .field-delivery { margin-left: 0; }
.catalogue-two-cols { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 15px; margin-bottom: 15px; }
.catalogue-one-col { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr; margin-bottom: 15px; }

/* FOOTER */
.site-footer { background-color: #1a2436 !important; color: #ffffff !important; padding: 40px 20px 20px 20px !important; margin-top: 60px !important; font-family: 'Poppins', sans-serif !important; }
.footer-container { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 30px; text-align: center; }
.footer-logo { width: 100px; border-radius: 8px; margin-bottom: 10px; }
.site-footer h4 { color: #ff7b00; margin-bottom: 15px; text-transform: uppercase; font-size: 1rem; }
.site-footer a { color: #fff; text-decoration: none; transition: color 0.3s; }
.site-footer a:hover { color: #00c2ff; }
.social-links { display: flex; justify-content: center; gap: 10px; }
.fb-btn, .msn-btn { padding: 8px 15px; border-radius: 5px; font-weight: bold; font-size: 0.9rem; }
.fb-btn { background-color: #1877f2; }
.msn-btn { background-color: #0084ff; }
.footer-bottom { margin-top: 40px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,0.1); font-size: 0.8rem; opacity: 0.7; text-align: center; }
.footer-nav ul { list-style: none; padding: 0; margin: 0; }
.footer-nav ul li { margin-bottom: 10px; }

@media (max-width: 768px) { .footer-container { grid-template-columns: 1fr; gap: 40px; } .site-footer { padding: 30px 15px 15px 15px !important; } }

/* --- TRANSFORMATION DU TABLEAU EN CARTES COMPACTES SUR MOBILE --- */
@media (max-width: 768px) {
    /* On annule la largeur forcée */
    .catalogue-recap-table { min-width: 0 !important; border: none; }
    .catalogue-recap-table thead { display: none; }
    
    .catalogue-recap-table tbody,
    .catalogue-recap-table tr { display: block; width: 100%; box-sizing: border-box; }

    /* Carte plus compacte */
    .catalogue-recap-table tr {
        margin-bottom: 12px; /* Espace réduit entre les cartes */
        border: 1px solid #007bff; /* Bordure plus fine */
        border-radius: 6px;
        padding: 10px 15px; /* Espaces internes réduits */
        background: #ffffff;
        box-shadow: 0 2px 5px rgba(0,0,0,0.08);
    }

    /* Design de base : Label à gauche, Valeur à droite */
    .catalogue-recap-table td {
        display: flex;
        flex-direction: row; /* Sur la même ligne */
        justify-content: space-between; /* Écarte le titre et la valeur */
        align-items: flex-start;
        width: 100% !important;
        border: none;
        border-bottom: 1px solid #f1f3f9;
        padding: 5px 0; /* Padding vertical très réduit */
        text-align: right;
        font-size: 0.85rem; /* Police légèrement plus petite */
        box-sizing: border-box;
    }

    /* Exception : L'article et l'impression (textes longs) restent empilés */
    .catalogue-recap-table td:nth-child(2),
    .catalogue-recap-table td:nth-child(5) {
        flex-direction: column;
        text-align: left;
    }

    /* La dernière ligne (Bouton supprimer) */
    .catalogue-recap-table td:last-child {
        border-bottom: none;
        justify-content: center;
        padding-top: 10px;
        padding-bottom: 0;
    }

    /* --- Titres des colonnes générés automatiquement --- */
    .catalogue-recap-table td::before { 
        font-weight: bold; 
        color: #555; 
        margin-right: 10px; 
        flex-shrink: 0; /* Empêche le titre de s'écraser */
    }
    
    .catalogue-recap-table td:nth-child(1)::before { content: "Ligne #"; color: #007bff; }
    .catalogue-recap-table td:nth-child(2)::before { content: "Article :"; margin-bottom: 2px; }
    .catalogue-recap-table td:nth-child(3)::before { content: "Couleur :"; }
    .catalogue-recap-table td:nth-child(4)::before { content: "Taille :"; }
    .catalogue-recap-table td:nth-child(5)::before { content: "Impression :"; margin-bottom: 2px; }
    .catalogue-recap-table td:nth-child(6)::before { content: "Quantité :"; }
    .catalogue-recap-table td:nth-child(7)::before { content: "Livraison :"; }
}