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 */
}

/* --- 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; 
    } 
}

.tarifs-container { max-width: 900px; margin: 0 auto; padding: 20px; flex-grow: 1; }
.page-title { text-align: center; color: #0056b3; border-bottom: 2px solid #ccc; padding-bottom: 10px; margin-top: 0; margin-bottom: 30px;}

.pricing-info { background-color: transparent; border-radius: 4px; font-size: 0.95em; }

/* CARTES DE PRIX (Remplacent les accordéons) */
.pricing-card { margin: 0 auto 30px auto; border: 1px solid #ddd; border-radius: 8px; background: #fff; box-shadow: 0 4px 10px rgba(0,0,0,0.05); overflow: hidden;}
.pricing-title { margin: 0; padding: 15px 20px; background: #f8f9fa; color: #05037b; border-bottom: 1px solid #ddd; font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; }
.pricing-content { padding: 25px; }

.sub-title { margin-top: 0; color: #333; font-size: 1.1em; margin-bottom: 15px;}
.inner-title { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #1a2a6c; border-bottom: 1px solid #d35400; padding-bottom: 8px; margin-bottom: 20px;}

/* ELEMENTS DES TABLEAUX */
.dtf-table { width: 100%; border-collapse: collapse; margin-bottom: 15px; background-color: #fff; }
.dtf-table th, .dtf-table td { border: 1px solid #ddd; padding: 12px 10px; text-align: left; }
.dtf-table th { background-color: #007bff; color: white; font-weight: 600; }
.dtf-table td:last-child { font-weight: bold; color: #07511c; text-align: right; background-color: #d4edda; }    

.remise-helper { text-align: center; margin-bottom: 15px; font-weight: bold; color: #555;}
.remise-text-table { width: 100%; max-width: 450px; margin: 0 auto; border-collapse: collapse; }
.remise-text-table td { padding: 6px 0; border: none; background: transparent; text-align: left; border-bottom: 1px solid #f1f1f1;}
.remise-text-table td:last-child { text-align: right; color: #555; font-weight: bold; }

/* SEPARATEURS ET ALERTES */
.dashed-divider { margin: 25px 0; border: 0; border-top: 1px dashed #ccc; }
.solid-divider { margin: 25px 0; border: 0; border-top: 1px solid #d35400; }
.warning-list { list-style: none; padding-left: 0; line-height: 1.6; margin-bottom: 25px;}
.warning-list li { margin-bottom: 8px; }
.text-danger { color: #dc3545; }
.text-success { color: #28a745; font-weight: bold;}

.info-box { border-left: 4px solid #28a745; padding: 12px 15px; margin: 15px 0 0 0; background-color: #f1f8f1; }
.info-box p { margin: 0; font-size: 0.95rem; color: #333; font-style: italic;}

.delivery-info { margin-top: 30px; margin-bottom: 10px; border-left: 4px solid #007bff; padding: 15px; background-color: #f8f9fa; border-radius: 4px;}
.delivery-info strong { display: block; font-size: 1.1em; color: #0056b3; margin-bottom: 10px;}
.delivery-info ul { list-style: none; padding-left: 0; margin: 0; }
.delivery-info li { margin-bottom: 8px; font-size: 0.95em;}

/* APPEL A L'ACTION */
.cta-section { text-align: center; margin-top: 40px; padding: 30px; background: #e2e8f0; border-radius: 12px; }
.cta-section p { font-size: 1.1rem; color: #333; margin-bottom: 15px; font-weight: 600;}
.btn-primary { display: inline-block; padding: 12px 30px; background: #ff7b00; color: white; text-decoration: none; font-weight: bold; border-radius: 50px; text-transform: uppercase; transition: 0.3s; }
.btn-primary:hover { background: #00c2ff; transform: scale(1.05); }

/* 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; } }