:root{--black:#111;--dark:#1b1b1b;--orange:#ff6600;--yellow:#FFD000;--light:#f4f4f4;--white:#fff;--text:#333;--muted:#666;--shadow:0 8px 25px rgba(0,0,0,.12);--radius:16px}*{margin:0;padding:0;box-sizing:border-box;font-family:Arial,Helvetica,sans-serif}html{scroll-behavior:smooth}body{background:var(--light);color:var(--text);line-height:1.6}img{max-width:100%;height:auto;display:block}.skip-link{position:absolute;left:-999px;top:10px;background:var(--yellow);color:var(--black);padding:10px;z-index:9999}.skip-link:focus{left:10px}.site-header{background:rgba(17,17,17,.96);color:white;padding:14px 5%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;position:sticky;top:0;z-index:1000;box-shadow:0 4px 20px rgba(0,0,0,.25);backdrop-filter:blur(8px)}.logo{display:flex;align-items:center;gap:15px}.logo-img{height:60px;width:auto;object-fit:contain;background:white;border-radius:10px;padding:4px}.logo-text{display:flex;flex-direction:column;line-height:1.2}.logo-text span{color:var(--yellow);font-size:14px}nav a{color:white;text-decoration:none;margin-left:20px;font-weight:bold;position:relative}nav a:hover,nav a.active{color:var(--yellow)}.header-call{background:var(--orange);color:white;padding:12px 18px;border-radius:999px;text-decoration:none;font-weight:bold}.menu-toggle{display:none;background:var(--yellow);color:var(--black);border:0;padding:10px 14px;border-radius:8px;font-weight:bold}.hero{background:var(--yellow);padding:80px 20px;text-align:center}.hero-premium{position:relative;min-height:720px;display:flex;align-items:center;justify-content:center;background:url('../images/hero.webp') center/cover no-repeat;color:white;overflow:hidden}.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.58),rgba(0,0,0,.25))}.hero-content{position:relative;z-index:2;width:min(1100px,90%);text-align:left}.badge{display:inline-block;background:var(--yellow);color:var(--black);padding:8px 14px;border-radius:999px;font-weight:bold;margin-bottom:20px}.hero h1,.hero h2{font-size:clamp(38px,6vw,78px);line-height:1.05;margin-bottom:20px;max-width:900px}.hero p{font-size:20px;margin-bottom:30px}.hero-text{max-width:720px;color:#f1f1f1}.hero-actions{display:flex;gap:15px;flex-wrap:wrap}.hero-trust{display:flex;gap:18px;flex-wrap:wrap;margin-top:25px;font-weight:bold}.btn{display:inline-block;background:var(--black);color:white;padding:15px 35px;border-radius:8px;text-decoration:none;font-size:18px;font-weight:bold;border:0;cursor:pointer}.btn:hover{background:#444}.btn-orange{background:var(--orange)}.btn-orange:hover{background:#d95300}.btn-dark{background:var(--black)}section{padding:70px 10%}.section-title{text-align:center;max-width:850px;margin:0 auto 30px}.section-title h2,section h2{font-size:clamp(28px,4vw,44px);color:var(--black);margin-bottom:12px}.subtitle{color:var(--orange);text-transform:uppercase;font-weight:bold;letter-spacing:1px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:30px}.card{background:white;padding:28px;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.05)}.card h3,.card h2{margin-bottom:10px;color:var(--black)}.card:hover{transform:translateY(-4px)}.emergency-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--black);padding:0}.emergency-strip div{background:var(--black);color:white;text-align:center;padding:25px 15px}.emergency-strip strong{display:block;color:var(--yellow);font-size:30px}.dark-section{background:var(--black);color:white}.dark-section h2,.light h2{color:white}.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}.gallery-item{border:0;background:transparent;cursor:pointer;overflow:hidden;border-radius:var(--radius)}.gallery-item img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:.4s}.gallery-item:hover img{transform:scale(1.06)}.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px}.lightbox img{max-height:85vh;border-radius:12px}.reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.review{background:white;padding:25px;border-radius:var(--radius);box-shadow:var(--shadow)}.review strong{color:var(--orange);font-size:22px}.review span{color:var(--muted);font-size:14px}.split{display:grid;grid-template-columns:1fr 1fr;gap:30px;background:white}.chips{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}.chips span{background:var(--light);border:1px solid #ddd;padding:10px 14px;border-radius:999px;font-weight:bold}.faq{max-width:900px;margin:auto}.faq-question{width:100%;background:white;color:var(--black);border:1px solid #ddd;padding:18px;text-align:left;font-weight:bold;font-size:18px;cursor:pointer;margin-top:10px;border-radius:10px}.faq-answer{display:none;background:white;padding:0 18px 18px;border-radius:0 0 10px 10px}.faq-answer.open{display:block}.page-hero{background:linear-gradient(135deg,var(--black),#333);color:white;text-align:center}.page-hero h1{font-size:clamp(34px,5vw,62px)}.page-hero p{font-size:20px;color:#eee}table{width:100%;border-collapse:collapse;margin-top:20px;background:white;box-shadow:var(--shadow);border-radius:var(--radius);overflow:hidden}th{background:var(--black);color:white;padding:15px;text-align:left}td{padding:15px;border-bottom:1px solid #ddd}.notice{color:var(--muted);margin-top:15px}.cta{text-align:center;background:var(--yellow)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:35px}.contact-form{background:white;padding:25px;border-radius:var(--radius);box-shadow:var(--shadow);display:grid;gap:14px}.contact-form label{display:grid;gap:6px;font-weight:bold}input,textarea{padding:14px;border:1px solid #ccc;border-radius:8px;font-size:16px}input:focus,textarea:focus,button:focus,a:focus{outline:3px solid var(--yellow);outline-offset:2px}.map iframe{width:100%;height:350px;border:0;border-radius:var(--radius);margin-top:20px}.legal{max-width:900px;margin:auto;background:white;border-radius:var(--radius)}footer{background:var(--black);color:white;text-align:left;padding:45px 8% 25px;margin-top:0}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:30px}.footer-logo{height:80px;background:white;border-radius:10px;margin-bottom:15px}footer a{display:block;color:white;text-decoration:none;margin:8px 0}footer a:hover{color:var(--yellow)}.copyright{text-align:center;margin-top:25px;color:#ccc}.floating-call{display:none;position:fixed;left:15px;right:15px;bottom:15px;background:var(--orange);color:white;text-align:center;padding:16px;border-radius:999px;text-decoration:none;font-weight:bold;z-index:2000;box-shadow:0 8px 25px rgba(0,0,0,.3)}.floating-whatsapp{position:fixed;right:18px;bottom:24px;background:#25d366;color:white;text-decoration:none;padding:13px 16px;border-radius:999px;font-weight:bold;z-index:1900}

/* ============================================================
FORMULAIRE PHP - Messages de retour et champ anti-spam
============================================================ */

.hidden-field{
    display:none!important;
}

.form-feedback{
    margin:10px 0 15px;
}

.success-message,
.error-message{
    display:none;
    padding:12px 14px;
    border-radius:8px;
    font-weight:bold;
}

.success-message{
    background:#e8f8ee;
    color:#126b33;
    border:1px solid #9ad8ae;
}

.error-message{
    background:#fdecec;
    color:#9d1c1c;
    border:1px solid #f2a6a6;
}

body.form-success .success-message{
    display:block;
}

body.form-error .error-message{
    display:block;
}


/* ============================================================
V2 AGENCE WEB PREMIUM - Formulaire AJAX, upload et messages
============================================================ */

.premium-form{
    border:1px solid rgba(255,102,0,.25);
    box-shadow:0 20px 45px rgba(0,0,0,.16);
    position:relative;
    overflow:hidden;
}

.premium-form::before{
    content:"";
    position:absolute;
    inset:0 0 auto 0;
    height:5px;
    background:linear-gradient(90deg,#FFD000,#ff6600,#111);
}

.field-help{
    color:#666;
    font-size:13px;
    font-weight:normal;
}

.ajax-feedback{
    display:none;
    padding:13px 15px;
    border-radius:10px;
    font-weight:bold;
}

.ajax-feedback.loading,
.ajax-feedback.success,
.ajax-feedback.error{
    display:block;
}

.ajax-feedback.loading{
    background:#fff8dc;
    color:#6f5700;
    border:1px solid #f0d46b;
}

.ajax-feedback.success{
    background:#e8f8ee;
    color:#126b33;
    border:1px solid #9ad8ae;
}

.ajax-feedback.error{
    background:#fdecec;
    color:#9d1c1c;
    border:1px solid #f2a6a6;
}

button:disabled{
    opacity:.65;
    cursor:not-allowed;
}

input[type="file"]{
    background:#fafafa;
}

.g-recaptcha{
    margin:8px 0;
    overflow:hidden;
}

/* ============================================================
V3 - Page Devis et suppression bloc assurances
============================================================ */
select{padding:14px;border:1px solid #ccc;border-radius:8px;font-size:16px;background:white}
.single-split{grid-template-columns:1fr;text-align:center}
.single-split .chips{justify-content:center}
.quote-info{margin-top:20px}
.quote-info ul{padding-left:20px;margin-top:10px}

/* ============================================================
V4 - Avis Google
============================================================ */
.reviews-section{background:#f4f4f4}.google-review-box{background:#111;color:white;border-radius:18px;padding:28px;display:flex;align-items:center;justify-content:space-between;gap:25px;box-shadow:0 15px 35px rgba(0,0,0,.18);margin-bottom:30px}.google-review-box strong{color:#FFD000;font-size:28px}.google-review-box h2,.google-review-box h3{color:white;margin:8px 0}.review-notice{text-align:center;margin-top:20px}.review-help{background:white;max-width:900px;margin:auto;border-radius:18px}.review-help ol{padding-left:22px;margin-top:15px}.review-help code{background:#f4f4f4;padding:3px 6px;border-radius:6px}@media(max-width:700px){.google-review-box{flex-direction:column;text-align:center}}

/* ============================================================
V5 - Zone Avis Google complete
============================================================ */

.google-reviews-zone{
    background:#f4f4f4;
}

.google-reviews-layout{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:25px;
    align-items:stretch;
}

.google-map-card{
    background:white;
    padding:12px;
    border-radius:20px;
    box-shadow:0 15px 35px rgba(0,0,0,.14);
}

.google-map-card iframe{
    width:100%;
    min-height:460px;
    border:0;
    border-radius:16px;
}

.google-review-panel{
    background:#111;
    color:white;
    padding:30px;
    border-radius:20px;
    box-shadow:0 15px 35px rgba(0,0,0,.18);
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    gap:20px;
}

.google-score{
    display:flex;
    gap:15px;
    align-items:center;
}

.google-logo{
    width:52px;
    height:52px;
    border-radius:50%;
    background:white;
    color:#4285F4;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:bold;
    font-size:30px;
}

.google-score strong{
    display:block;
    font-size:24px;
}

.google-score p,
.review-intro{
    color:#eee;
}

.stars{
    color:#FFD000;
    font-size:34px;
    letter-spacing:3px;
}

.google-actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
}

.google-mini-reviews{
    display:grid;
    gap:12px;
}

.google-mini-reviews article{
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
    border-radius:14px;
    padding:15px;
}

.google-mini-reviews strong{
    color:#FFD000;
}

.google-mini-reviews span{
    color:#ccc;
    font-size:13px;
}

.google-setup-note{
    background:white;
    border-left:5px solid #ff6600;
    padding:20px;
    border-radius:14px;
    box-shadow:0 8px 25px rgba(0,0,0,.08);
    margin-top:25px;
}

.google-setup-note code{
    background:#f4f4f4;
    padding:3px 6px;
    border-radius:6px;
}

/* V6 - Carrousel galerie et lightbox premium */
.index-support{background:white}
.gallery-carousel-section{overflow:hidden}
.carousel{position:relative;display:flex;align-items:center;gap:15px}
.carousel-track{display:flex;gap:18px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;padding:10px 4px 25px;scrollbar-width:thin}
.carousel-slide{min-width:320px;scroll-snap-align:start;position:relative;background:#111;border-radius:18px;overflow:hidden;box-shadow:0 12px 30px rgba(0,0,0,.25)}
.carousel-slide img{width:100%;aspect-ratio:4/3;object-fit:cover}
.carousel-slide span{position:absolute;left:0;right:0;bottom:0;padding:18px;color:white;font-weight:bold;font-size:18px;background:linear-gradient(transparent,rgba(0,0,0,.88));text-align:left}
.carousel-btn{flex:0 0 auto;width:48px;height:48px;border:0;border-radius:50%;background:#FFD000;color:#111;font-size:34px;font-weight:bold;cursor:pointer;box-shadow:0 8px 22px rgba(0,0,0,.25)}
.lightbox{position:fixed;inset:0;z-index:5000;display:flex;align-items:center;justify-content:center;padding:25px;overflow:hidden}
.lightbox::before{content:"";position:absolute;inset:-30px;background:var(--lightbox-bg) center/cover no-repeat;filter:blur(25px) brightness(.45);transform:scale(1.08)}
.lightbox-content{position:relative;z-index:2;max-width:min(1000px,92vw);background:rgba(17,17,17,.88);color:white;border-radius:22px;overflow:hidden;box-shadow:0 25px 80px rgba(0,0,0,.5)}
.lightbox-content img{width:100%;max-height:70vh;object-fit:cover}
.lightbox-text{padding:22px}.lightbox-text h3{color:#FFD000;font-size:28px;margin-bottom:8px}
.lightbox-close{position:absolute;z-index:3;top:18px;right:18px;width:44px;height:44px;border:0;border-radius:50%;background:#FFD000;color:#111;font-size:26px;font-weight:bold;cursor:pointer}

/* ============================================================
V7 - Contact sans formulaire
============================================================ */

.contact-without-form{
    align-items:stretch;
}

.contact-card-main{
    background:white;
    padding:30px;
    border-radius:18px;
    box-shadow:0 15px 35px rgba(0,0,0,.12);
}

.contact-actions{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin:25px 0;
}

.contact-info-list{
    display:grid;
    gap:10px;
    margin-top:20px;
}

.emergency-contact-box{
    margin-top:25px;
    background:#111;
    color:white;
}

.emergency-contact-box h3{
    color:#FFD000;
}

.contact-map-large iframe{
    min-height:520px;
}


/* ============================================================
V8 - Alignement services 2 lignes de 3
============================================================ */

.cards{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:25px;
    align-items:stretch;
}

.cards .card{
    height:100%;
}

/* Tablette */
@media(max-width:900px){
    .cards{
        grid-template-columns:repeat(2,1fr);
    }
}

/* Mobile */
@media(max-width:700px){
    .cards{
        grid-template-columns:1fr;
    }
}


/* ============================================================
V9 - Finition premium
============================================================ */

.section-title{
    text-align:center;
    max-width:900px;
    margin:0 auto 40px;
}

.section-title h2{
    margin-bottom:15px;
}

.cards{
    align-items:stretch;
}

.card{
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    text-align:center;
    transition:transform .25s ease, box-shadow .25s ease;
}

.card:hover{
    transform:translateY(-5px);
}

.card h3{
    min-height:58px;
    display:flex;
    align-items:center;
    justify-content:center;
}

.card p{
    flex:1;
}

.contact-info-list p,
.quote-info li{
    line-height:1.8;
}

.btn{
    font-weight:700;
}

.subtitle{
    letter-spacing:1px;
    text-transform:uppercase;
}


/* V10 - Carrousel automatique */
.carousel-track{
    scroll-behavior:smooth;
}

.lightbox-text{
    text-align:center;
}

.lightbox-text p{
    font-size:18px;
    line-height:1.8;
}


/* ============================================================
V11 PRODUCTION - Carrousel final
============================================================ */

.gallery-carousel-section{
    position:relative;
}

.carousel{
    max-width:1280px;
    margin:0 auto;
}

.carousel-track{
    scroll-behavior:smooth;
    -webkit-overflow-scrolling:touch;
    padding-bottom:30px;
}

.carousel-track::-webkit-scrollbar{
    height:8px;
}

.carousel-track::-webkit-scrollbar-track{
    background:rgba(255,255,255,.12);
    border-radius:999px;
}

.carousel-track::-webkit-scrollbar-thumb{
    background:#FFD000;
    border-radius:999px;
}

.carousel-btn{
    position:relative;
    z-index:5;
    transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
}

.carousel-btn:hover{
    background:#ff6600;
    color:white;
    transform:scale(1.08);
}

.carousel-btn:active{
    transform:scale(.96);
}

.carousel-slide{
    cursor:pointer;
}

.carousel-slide::after{
    content:"Cliquer pour agrandir";
    position:absolute;
    top:14px;
    right:14px;
    background:rgba(0,0,0,.72);
    color:white;
    font-size:13px;
    font-weight:bold;
    padding:7px 10px;
    border-radius:999px;
    opacity:0;
    transition:opacity .25s ease;
}

.carousel-slide:hover::after{
    opacity:1;
}

body.lightbox-open{
    overflow:hidden;
}

.lightbox-close{
    line-height:1;
}


/* ============================================================
V12 - Finition esthétique et carrousel propre
============================================================ */

/* Titres plus propres */
.section-title{
    max-width:920px;
    margin-left:auto;
    margin-right:auto;
    text-align:center;
}

.section-title p{
    max-width:760px;
    margin-left:auto;
    margin-right:auto;
}

/* Cartes : meilleur alignement du texte */
.cards{
    align-items:stretch;
}

.card{
    min-height:220px;
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    justify-content:flex-start;
}

.card h2,
.card h3{
    width:100%;
    min-height:54px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    line-height:1.25;
}

.card p{
    margin-top:8px;
    text-align:center;
}

/* Carrousel : affichage plus premium */
.gallery-carousel-section .section-title{
    margin-bottom:34px;
}

.carousel{
    max-width:1320px;
    margin:0 auto;
    display:grid;
    grid-template-columns:56px minmax(0,1fr) 56px;
    align-items:center;
    gap:18px;
}

.carousel-track{
    display:flex;
    gap:22px;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    scroll-behavior:smooth;
    padding:8px 4px 32px;
    -webkit-overflow-scrolling:touch;
}

.carousel-slide{
    min-width:360px;
    max-width:360px;
    min-height:290px;
    border-radius:22px;
    scroll-snap-align:start;
    box-shadow:0 18px 45px rgba(0,0,0,.32);
}

.carousel-slide img{
    height:260px;
    width:100%;
    object-fit:cover;
}

.carousel-slide span{
    min-height:72px;
    display:flex;
    align-items:flex-end;
    justify-content:flex-start;
    padding:22px;
    line-height:1.25;
}

.carousel-btn{
    width:56px;
    height:56px;
    display:flex;
    align-items:center;
    justify-content:center;
    line-height:1;
    font-size:38px;
}

/* Lightbox : texte plus lisible */
.lightbox-content{
    max-width:min(1050px,92vw);
}

.lightbox-text{
    text-align:center;
    padding:26px 32px 30px;
}

.lightbox-text h3{
    margin-bottom:10px;
    line-height:1.2;
}

.lightbox-text p{
    max-width:760px;
    margin:0 auto;
    font-size:18px;
    line-height:1.7;
}

/* Devis et contact : meilleure lisibilité */
.contact-card-main,
.contact-form,
.google-review-panel,
.google-map-card{
    line-height:1.7;
}

.contact-actions{
    justify-content:flex-start;
}

.notice{
    line-height:1.7;
}

@media(max-width:900px){
    .carousel{
        grid-template-columns:1fr;
    }

    .carousel-btn{
        display:none;
    }

    .carousel-slide{
        min-width:78vw;
        max-width:78vw;
    }
}

@media(max-width:700px){
    .card{
        min-height:auto;
    }

    .card h2,
    .card h3{
        min-height:auto;
    }

    .carousel-slide{
        min-width:84vw;
        max-width:84vw;
    }

    .carousel-slide img{
        height:220px;
    }
}


/* ============================================================
V13 - Bloc Informations utiles plus esthétique
============================================================ */

.quote-info-left{
    text-align:left;
    align-items:stretch;
}

.quote-info-left h3{
    justify-content:flex-start;
    text-align:left;
    min-height:auto;
    margin-bottom:18px;
}

.quote-checklist{
    display:grid;
    gap:13px;
}

.quote-check-item{
    display:grid;
    grid-template-columns:34px 1fr;
    align-items:center;
    gap:12px;
    background:#f7f7f7;
    border:1px solid #e7e7e7;
    border-radius:12px;
    padding:12px 14px;
}

.quote-check-item span{
    width:34px;
    height:34px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#FFD000;
    color:#111;
    border-radius:50%;
    font-weight:900;
    box-shadow:0 4px 12px rgba(0,0,0,.12);
}

.quote-check-item p{
    margin:0;
    text-align:left;
    font-weight:600;
    color:#222;
    line-height:1.35;
}

/* ============================================================
V14 PRODUCTION PREMIUM - Finitions discrètes
============================================================ */
body{text-rendering:optimizeLegibility}
.section-title h2,.page-hero h1{text-wrap:balance}
.section-title p,.page-hero p,.hero-text,.card p,.review p,.notice,.quote-check-item p{text-wrap:pretty}
.hero-actions .btn,.contact-actions .btn{min-width:220px;text-align:center}
.quote-check-item{transition:transform .2s ease,box-shadow .2s ease}
.quote-check-item:hover{transform:translateX(3px);box-shadow:0 6px 18px rgba(0,0,0,.08)}
input,textarea,select{transition:border-color .2s ease,box-shadow .2s ease}
input:focus,textarea:focus,select:focus{border-color:#ff6600;box-shadow:0 0 0 4px rgba(255,102,0,.14)}


/* ============================================================
V15 - Titre Contact
============================================================ */

.contact-card-main h2{
    text-wrap:balance;
}


/* ============================================================
V16 - Titre contact sur une ligne
============================================================ */

.contact-title-nowrap{
    display:inline-block;
    white-space:nowrap;
    font-size:clamp(1.45rem, 2.15vw, 2.15rem);
    line-height:1.15;
}

@media(max-width:700px){
    .contact-title-nowrap{
        white-space:normal;
        font-size:clamp(1.55rem, 7vw, 2rem);
    }
}


/* ============================================================
V17 - Mobile premium
============================================================ */

/* Boutons plus confortables au tactile */
.btn,
.header-call{
    min-height:54px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
}

/* Menu mobile plus propre */
.menu-toggle{
    cursor:pointer;
}

@media(max-width:900px){
    .site-header{
        position:sticky;
        top:0;
    }

    #menu-principal{
        width:100%;
        background:#111;
        border-radius:14px;
        padding:10px;
        box-shadow:0 15px 35px rgba(0,0,0,.25);
    }

    #menu-principal a{
        border-bottom:1px solid rgba(255,255,255,.08);
    }

    #menu-principal a:last-child{
        border-bottom:0;
    }
}

/* Hero mobile plus lisible */
@media(max-width:700px){
    .hero-premium{
        min-height:690px;
        padding-top:70px;
        padding-bottom:90px;
    }

    .hero h1{
        font-size:clamp(2rem, 9vw, 2.7rem);
        line-height:1.08;
    }

    .hero-text{
        font-size:1.05rem;
        line-height:1.65;
    }

    .hero-actions{
        display:grid;
        grid-template-columns:1fr;
        gap:12px;
        width:100%;
    }

    .hero-actions .btn{
        width:100%;
    }
}

/* Bouton téléphone flottant renforcé */
.floating-call{
    display:none;
}

@media(max-width:900px){
    .floating-call{
        display:flex;
        align-items:center;
        justify-content:center;
        left:14px;
        right:14px;
        bottom:14px;
        min-height:58px;
        font-size:18px;
        border-radius:999px;
        background:#ff6600;
        color:#fff;
        box-shadow:0 14px 35px rgba(0,0,0,.35);
    }

    body{
        padding-bottom:86px;
    }
}

/* Carrousel mobile plus agréable */
@media(max-width:700px){
    .carousel-track{
        gap:16px;
        padding-bottom:24px;
    }

    .carousel-slide{
        min-width:84vw;
        max-width:84vw;
    }

    .carousel-slide span{
        font-size:17px;
        min-height:64px;
    }
}

/* Zone contact/devis plus propre sur tablette */
@media(max-width:900px){
    .contact-grid{
        gap:24px;
    }

    .contact-card-main,
    .contact-form{
        padding:24px;
    }
}


/* V17 - titres responsive */
.mobile-title{
    display:none;
}

@media(max-width:700px){
    .desktop-title{
        display:none;
    }

    .mobile-title{
        display:inline;
    }
}

/* V18 - Production publication */
.map-link-wrapper{margin-top:14px;text-align:center}.map-open-link{min-width:220px}@media(max-width:700px){.map-open-link{width:100%}}

/* ============================================================
V19 - Avis Google final
============================================================ */

.google-review-panel{
    justify-content:center;
}

.google-actions{
    margin-top:10px;
}

.google-reviews-zone .section-title p{
    max-width:820px;
}

/* V20 - Production finale */
.footer-availability{color:#FFD000;font-weight:800;margin-top:4px}
.services-grid-final .card{text-align:center;justify-content:flex-start}
.services-grid-final .card h3{min-height:70px;line-height:1.25}
.services-grid-final .card p{line-height:1.7}
.legal-premium{background:white}
.legal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.legal-card{background:#f7f7f7;border:1px solid #e7e7e7;border-radius:16px;padding:24px;box-shadow:0 8px 22px rgba(0,0,0,.06)}
.legal-card h3{color:#111;margin-bottom:12px}.legal-card p{margin-bottom:8px;line-height:1.65}.legal-card a{color:#111;font-weight:700}
@media(max-width:800px){.legal-grid{grid-template-columns:1fr}}


/* ============================================================
V21 - Services esthétiques avec icônes
============================================================ */

.services-premium-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:26px;
}

.service-card-premium{
    position:relative;
    overflow:hidden;
    padding:34px 28px;
    text-align:center;
    border:1px solid rgba(0,0,0,.06);
    background:linear-gradient(180deg,#ffffff 0%,#fafafa 100%);
}

.service-card-premium::before{
    content:"";
    position:absolute;
    inset:0 0 auto 0;
    height:5px;
    background:linear-gradient(90deg,#FFD000,#ff6600);
}

.service-icon{
    width:72px;
    height:72px;
    margin:0 auto 18px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:20px;
    background:#111;
    color:#FFD000;
    font-size:34px;
    box-shadow:0 12px 28px rgba(0,0,0,.18);
}

.service-card-premium h3{
    min-height:76px;
    display:flex;
    align-items:center;
    justify-content:center;
    margin-bottom:14px;
    color:#111;
    line-height:1.22;
    text-align:center;
}

.service-card-premium p{
    color:#444;
    line-height:1.75;
    text-align:center;
}

.service-card-premium:hover{
    transform:translateY(-6px);
    box-shadow:0 18px 42px rgba(0,0,0,.14);
}

@media(max-width:1000px){
    .services-premium-grid{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}

@media(max-width:700px){
    .services-premium-grid{
        grid-template-columns:1fr;
    }

    .service-card-premium h3{
        min-height:auto;
    }
}

/* ============================================================
V22 - Thème jaune / noir basé sur le nouveau visuel
============================================================ */

:root{
    --black:#050505;
    --dark:#0d0d0d;
    --orange:#f5a400;
    --yellow:#FFD000;
    --gold:#ffc400;
    --light:#0a0a0a;
    --white:#ffffff;
    --text:#f7f7f7;
    --muted:#d6d6d6;
    --shadow:0 14px 40px rgba(0,0,0,.35);
}

body{
    background:#050505;
    color:#f5f5f5;
}

.site-header{
    background:rgba(0,0,0,.96);
    border-bottom:1px solid rgba(255,208,0,.35);
}

.logo-img{
    height:76px;
    background:transparent;
    border-radius:8px;
    padding:0;
    object-fit:contain;
}

.logo-text strong{
    color:#FFD000;
}

nav a.active,
nav a:hover{
    color:#FFD000;
}

.header-call,
.btn-orange{
    background:linear-gradient(135deg,#FFD000,#f5a400);
    color:#050505;
    box-shadow:0 8px 22px rgba(255,208,0,.28);
}

.btn-orange:hover{
    background:#ffffff;
    color:#050505;
}

.btn-dark{
    background:#050505;
    border:1px solid #FFD000;
    color:#FFD000;
}

.hero-premium{
    background:
        linear-gradient(90deg, rgba(0,0,0,.96) 0%, rgba(0,0,0,.76) 40%, rgba(0,0,0,.22) 100%),
        url('../images/hero.webp') center right/cover no-repeat;
    min-height:760px;
}

.hero-overlay{
    display:none;
}

.badge{
    background:#FFD000;
    color:#050505;
}

.hero h1,
.hero h2{
    color:#ffffff;
    text-transform:uppercase;
    letter-spacing:.5px;
    text-shadow:0 8px 20px rgba(0,0,0,.65);
}

.hero-text{
    color:#ffffff;
    font-weight:600;
}

.hero-trust span{
    background:rgba(255,208,0,.11);
    border:1px solid rgba(255,208,0,.28);
    padding:8px 12px;
    border-radius:999px;
    color:#fff;
}

.emergency-strip{
    border-top:1px solid #FFD000;
    border-bottom:1px solid #FFD000;
}

.emergency-strip div{
    background:#090909;
}

.emergency-strip strong{
    color:#FFD000;
}

section{
    background:#050505;
}

.index-support,
.split,
.reviews-section,
.google-reviews-zone,
.legal-premium{
    background:#0a0a0a;
}

.section-title h2,
section h2,
.card h2,
.card h3{
    color:#ffffff;
}

.subtitle{
    color:#FFD000;
}

.card,
.review,
.contact-card-main,
.contact-form,
.legal-card,
.google-map-card{
    background:linear-gradient(180deg,#171717,#0b0b0b);
    color:#ffffff;
    border:1px solid rgba(255,208,0,.22);
    box-shadow:0 14px 36px rgba(0,0,0,.35);
}

.card p,
.review p,
.notice,
.contact-info-list p,
.legal-card p{
    color:#eeeeee;
}

.card:hover,
.service-card-premium:hover{
    border-color:#FFD000;
}

.service-card-premium{
    background:linear-gradient(180deg,#141414 0%,#070707 100%);
    border:1px solid rgba(255,208,0,.28);
}

.service-card-premium::before{
    background:linear-gradient(90deg,#FFD000,#f5a400,#ffffff);
}

.service-icon{
    background:#FFD000;
    color:#050505;
}

.service-card-premium h3{
    color:#ffffff;
}

.service-card-premium p{
    color:#ededed;
}

.dark-section{
    background:#050505;
    border-top:1px solid rgba(255,208,0,.25);
    border-bottom:1px solid rgba(255,208,0,.25);
}

.carousel-slide{
    border:1px solid rgba(255,208,0,.3);
}

.carousel-slide span{
    color:#ffffff;
}

.carousel-btn{
    background:#FFD000;
    color:#050505;
}

.page-hero{
    background:
        linear-gradient(90deg, rgba(0,0,0,.92), rgba(0,0,0,.65)),
        url('../images/hero.webp') center/cover no-repeat;
    color:white;
    border-bottom:1px solid #FFD000;
}

input,
textarea,
select{
    background:#111;
    color:#fff;
    border:1px solid rgba(255,208,0,.28);
}

input::placeholder,
textarea::placeholder{
    color:#cfcfcf;
}

.quote-check-item{
    background:#111;
    border:1px solid rgba(255,208,0,.22);
}

.quote-check-item p{
    color:#ffffff;
}

.quote-check-item span{
    background:#FFD000;
    color:#050505;
}

.chips span{
    background:#111;
    color:#fff;
    border:1px solid rgba(255,208,0,.32);
}

footer{
    background:#000;
    border-top:2px solid #FFD000;
}

.footer-logo{
    background:transparent;
    height:88px;
    border-radius:8px;
}

.footer-availability,
footer a:hover{
    color:#FFD000;
}

.floating-call{
    background:linear-gradient(135deg,#FFD000,#f5a400);
    color:#050505;
}

.floating-whatsapp{
    background:#25d366;
    color:#050505;
}

.google-review-panel{
    background:linear-gradient(180deg,#151515,#050505);
    border:1px solid rgba(255,208,0,.28);
}

.google-logo{
    background:#FFD000;
    color:#050505;
}

.stars{
    color:#FFD000;
}

@media(max-width:700px){
    .hero-premium{
        background:
            linear-gradient(180deg, rgba(0,0,0,.95), rgba(0,0,0,.72)),
            url('../images/hero.webp') center/cover no-repeat;
    }

    .logo-img{
        height:64px;
    }
}


/* ============================================================
V23 - Alignement titre hero accueil
============================================================ */

.hero-title-main,
.hero-title-sub{
    display:block;
}

.hero-title-main{
    color:#ffffff;
}

.hero-title-sub{
    color:#FFD000;
    margin-top:10px;
    font-size:clamp(2.1rem, 5vw, 4.6rem);
    line-height:1;
}

@media(max-width:700px){
    .hero-title-sub{
        font-size:clamp(2rem, 10vw, 3rem);
        margin-top:8px;
    }
}


/* ============================================================
V24 - Politique de confidentialité + contact
============================================================ */

.privacy-premium{
    background:#0a0a0a;
}

.privacy-note{
    margin-top:28px;
    background:linear-gradient(180deg,#171717,#0b0b0b);
    border:1px solid rgba(255,208,0,.24);
    border-radius:16px;
    padding:24px;
    box-shadow:0 10px 28px rgba(0,0,0,.22);
}

.privacy-note h3{
    color:#FFD000;
    margin-bottom:10px;
}

.privacy-note p,
.privacy-note a{
    color:#ffffff;
}

.contact-white-link{
    color:#ffffff!important;
    font-weight:800;
    text-decoration:none;
}

.contact-white-link:hover{
    color:#FFD000!important;
    text-decoration:underline;
}

.contact-info-list a{
    color:#ffffff!important;
}

.contact-info-list a:hover{
    color:#FFD000!important;
}

/* ============================================================
V25 - Pages légales premium + correction liens contact
============================================================ */

.legal-hero{
    border-bottom:2px solid #FFD000;
}

.legal-page-premium{
    background:#050505;
}

.legal-intro-card{
    max-width:980px;
    margin:0 auto 34px;
    text-align:center;
    background:linear-gradient(180deg,#171717,#0b0b0b);
    border:1px solid rgba(255,208,0,.26);
    border-radius:22px;
    padding:34px;
    box-shadow:0 18px 42px rgba(0,0,0,.32);
}

.legal-intro-card h2{
    color:#ffffff;
    margin:8px 0 12px;
}

.legal-intro-card p{
    color:#eeeeee;
    line-height:1.75;
}

.legal-premium-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:24px;
}

.legal-premium-card{
    position:relative;
    background:linear-gradient(180deg,#151515,#070707);
    border:1px solid rgba(255,208,0,.25);
    border-radius:20px;
    padding:28px;
    color:#ffffff;
    box-shadow:0 14px 34px rgba(0,0,0,.32);
    overflow:hidden;
}

.legal-premium-card::before{
    content:"";
    position:absolute;
    inset:0 0 auto 0;
    height:4px;
    background:linear-gradient(90deg,#FFD000,#f5a400,#ffffff);
}

.legal-icon{
    width:58px;
    height:58px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#FFD000;
    color:#050505;
    border-radius:18px;
    font-size:28px;
    margin-bottom:16px;
    box-shadow:0 10px 24px rgba(255,208,0,.22);
}

.legal-premium-card h3{
    color:#FFD000;
    margin-bottom:14px;
    font-size:1.35rem;
}

.legal-premium-card p,
.legal-premium-card li{
    color:#f2f2f2;
    line-height:1.75;
}

.legal-premium-card ul{
    list-style:none;
    padding:0;
    margin:0;
}

.legal-premium-card li{
    padding:8px 0;
    border-bottom:1px solid rgba(255,255,255,.08);
}

.legal-premium-card li:last-child{
    border-bottom:0;
}

.legal-premium-card a,
.contact-card-main a,
.contact-info-list a{
    color:#ffffff!important;
    font-weight:800;
    text-decoration:none;
}

.legal-premium-card a:hover,
.contact-card-main a:hover,
.contact-info-list a:hover{
    color:#FFD000!important;
    text-decoration:underline;
}

.legal-highlight{
    border-color:#FFD000;
}

footer a,
footer p,
footer li,
footer span{
    color:#ffffff;
}

footer h3{
    color:#FFD000;
}

.footer-availability{
    color:#FFD000!important;
}

@media(max-width:850px){
    .legal-premium-grid{
        grid-template-columns:1fr;
    }

    .legal-intro-card{
        padding:26px;
    }
}

/* ============================================================
V28 - FAQ premium noir / jaune
============================================================ */

.faq{
    max-width:980px;
    margin:0 auto;
    display:grid;
    gap:14px;
}

.faq-question{
    width:100%;
    background:linear-gradient(180deg,#171717,#090909);
    color:#ffffff;
    border:1px solid rgba(255,208,0,.35);
    padding:20px 22px;
    text-align:left;
    font-weight:800;
    font-size:18px;
    cursor:pointer;
    margin-top:0;
    border-radius:14px;
    box-shadow:0 10px 28px rgba(0,0,0,.28);
    position:relative;
    padding-right:58px;
    transition:transform .2s ease, border-color .2s ease, background .2s ease;
}

.faq-question::after{
    content:"+";
    position:absolute;
    right:18px;
    top:50%;
    transform:translateY(-50%);
    width:32px;
    height:32px;
    border-radius:50%;
    background:#FFD000;
    color:#050505;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:24px;
    font-weight:900;
    line-height:1;
}

.faq-question:hover{
    transform:translateY(-2px);
    border-color:#FFD000;
    background:linear-gradient(180deg,#202020,#0d0d0d);
}

.faq-question.is-open::after{
    content:"−";
}

.faq-answer{
    display:none;
    background:rgba(255,208,0,.08);
    color:#ffffff;
    border:1px solid rgba(255,208,0,.22);
    border-top:0;
    padding:18px 22px 20px;
    border-radius:0 0 14px 14px;
    margin-top:-14px;
    box-shadow:0 12px 28px rgba(0,0,0,.18);
}

.faq-answer.open{
    display:block;
}

.faq-answer p{
    color:#f4f4f4;
    line-height:1.7;
    margin:0;
}

@media(max-width:700px){
    .faq-question{
        font-size:16px;
        padding:17px 56px 17px 18px;
    }

    .faq-answer{
        padding:16px 18px 18px;
    }
}

/* ============================================================
V30 - Derniers ajustements publication
============================================================ */

.logo-img{
    max-width:230px;
    height:76px;
    object-fit:contain;
}

.hero-premium{
    background:
        linear-gradient(90deg, rgba(0,0,0,.96) 0%, rgba(0,0,0,.74) 42%, rgba(0,0,0,.20) 100%),
        url('../images/hero.webp') center right/cover no-repeat;
}

@media(max-width:700px){
    .logo-img{
        max-width:210px;
        height:64px;
    }

    .hero-premium{
        background:
            linear-gradient(180deg, rgba(0,0,0,.95), rgba(0,0,0,.72)),
            url('../images/hero.webp') center/cover no-repeat;
    }
}

/* ============================================================
V31 - Publication weekend : finition contact / confiance
============================================================ */

.pro-info-panel{
    background:linear-gradient(180deg,#171717,#090909);
    border:1px solid rgba(255,208,0,.28);
    border-radius:20px;
    padding:24px;
    margin-bottom:20px;
    box-shadow:0 14px 34px rgba(0,0,0,.28);
}

.pro-info-item{
    display:grid;
    grid-template-columns:44px 1fr;
    gap:14px;
    align-items:start;
    padding:14px 0;
    border-bottom:1px solid rgba(255,255,255,.08);
}

.pro-info-item:last-of-type{
    border-bottom:0;
}

.pro-info-item span{
    width:44px;
    height:44px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#FFD000;
    color:#050505;
    border-radius:14px;
    font-size:22px;
}

.pro-info-item strong{
    color:#FFD000;
    display:block;
    margin-bottom:4px;
}

.pro-info-item p,
.pro-info-item a{
    color:#ffffff!important;
    margin:0;
    text-decoration:none;
    font-weight:700;
}

.pro-info-actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:18px;
}

.why-choose-final{
    background:#050505;
    border-top:1px solid rgba(255,208,0,.18);
    border-bottom:1px solid rgba(255,208,0,.18);
}

.why-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:18px;
}

.why-grid article{
    background:linear-gradient(180deg,#171717,#090909);
    border:1px solid rgba(255,208,0,.24);
    border-radius:18px;
    padding:24px;
    text-align:center;
    box-shadow:0 12px 28px rgba(0,0,0,.24);
}

.why-grid span{
    width:58px;
    height:58px;
    margin:0 auto 14px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#FFD000;
    color:#050505;
    border-radius:18px;
    font-size:28px;
}

.why-grid h3{
    color:#ffffff;
    margin-bottom:10px;
}

.why-grid p{
    color:#eeeeee;
    line-height:1.6;
}

@media(max-width:1000px){
    .why-grid{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}

@media(max-width:700px){
    .why-grid{
        grid-template-columns:1fr;
    }

    .pro-info-actions .btn{
        width:100%;
    }
}

/* ============================================================
V32 - Bloc contact premium final
============================================================ */

.contact-premium-panel{
    background:linear-gradient(180deg,#171717,#0b0b0b);
    border:1px solid rgba(255,208,0,.45);
    border-radius:24px;
    padding:34px;
    box-shadow:0 18px 44px rgba(0,0,0,.35);
}

.contact-premium-item{
    display:grid;
    grid-template-columns:92px 1fr;
    align-items:center;
    gap:24px;
    padding:4px 0;
}

.contact-premium-icon{
    width:78px;
    height:78px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#FFD000;
    color:#050505;
    border-radius:22px;
    font-size:32px;
    box-shadow:0 12px 26px rgba(255,208,0,.20);
}

.contact-premium-text h3{
    color:#FFD000;
    font-size:clamp(1.35rem,2vw,1.85rem);
    margin:0 0 10px;
    line-height:1.15;
}

.contact-premium-text p{
    color:#ffffff;
    font-size:clamp(1.18rem,1.8vw,1.55rem);
    font-weight:900;
    line-height:1.25;
    margin:0;
}

.contact-premium-text a{
    color:#ffffff!important;
    text-decoration:none;
}

.contact-premium-text a:hover{
    color:#FFD000!important;
}

.contact-premium-separator{
    height:1px;
    background:rgba(255,255,255,.14);
    margin:28px 0;
}

.contact-premium-actions{
    margin-top:32px;
    display:flex;
    flex-wrap:wrap;
    gap:14px;
}

.contact-premium-actions .btn{
    min-width:220px;
}

@media(max-width:900px){
    .contact-premium-panel{
        padding:28px;
    }
}

@media(max-width:700px){
    .contact-premium-item{
        grid-template-columns:72px 1fr;
        gap:16px;
    }

    .contact-premium-icon{
        width:64px;
        height:64px;
        border-radius:18px;
        font-size:26px;
    }

    .contact-premium-text p{
        font-size:1.08rem;
    }

    .contact-premium-actions .btn{
        width:100%;
    }
}

/* V33 - Contact Ultimate Publication */
.contact-ultimate-hero{text-align:center}.contact-hero-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-top:24px}
.contact-ultimate-layout{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:28px;align-items:stretch}
.contact-ultimate-card,.contact-ultimate-map{background:linear-gradient(180deg,#171717,#0b0b0b);border:1px solid rgba(255,208,0,.45);border-radius:24px;padding:34px;box-shadow:0 18px 44px rgba(0,0,0,.35)}
.contact-ultimate-map{padding:14px}.contact-ultimate-map iframe{width:100%;height:100%;min-height:610px;border:0;border-radius:18px}
.contact-ultimate-item{display:grid;grid-template-columns:88px 1fr;gap:24px;align-items:center}.contact-ultimate-icon{width:78px;height:78px;display:flex;align-items:center;justify-content:center;background:#FFD000;color:#050505;border-radius:22px;font-size:32px;box-shadow:0 12px 26px rgba(255,208,0,.20)}
.contact-ultimate-item h2{color:#FFD000;margin:0 0 8px;font-size:clamp(1.35rem,2vw,1.85rem);line-height:1.15}.contact-ultimate-item p,.contact-ultimate-item a{color:#fff!important;font-size:clamp(1.1rem,1.7vw,1.45rem);font-weight:900;line-height:1.35;text-decoration:none;margin:0}.contact-ultimate-item a:hover{color:#FFD000!important}.contact-ultimate-separator{height:1px;background:rgba(255,255,255,.14);margin:28px 0}
.contact-ultimate-actions{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}.contact-why,.service-zones,.contact-faq-section{background:#050505;border-top:1px solid rgba(255,208,0,.18)}
.contact-why-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.contact-why-grid article{background:linear-gradient(180deg,#171717,#090909);border:1px solid rgba(255,208,0,.24);border-radius:18px;padding:24px;text-align:center;box-shadow:0 12px 28px rgba(0,0,0,.24)}
.contact-why-grid span{width:58px;height:58px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;background:#FFD000;color:#050505;border-radius:18px;font-size:28px}.contact-why-grid h3{color:#fff;margin-bottom:10px;line-height:1.25}.contact-why-grid p{color:#eee;line-height:1.6}
.zone-badges{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;max-width:1050px;margin:0 auto}.zone-badges span{background:linear-gradient(180deg,#171717,#0b0b0b);border:1px solid rgba(255,208,0,.32);color:#fff;border-radius:999px;padding:12px 18px;font-weight:800;box-shadow:0 8px 18px rgba(0,0,0,.20)}
@media(max-width:1050px){.contact-ultimate-layout{grid-template-columns:1fr}.contact-ultimate-map iframe{min-height:420px}.contact-why-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:700px){.contact-hero-actions,.contact-ultimate-actions{grid-template-columns:1fr;display:grid}.contact-hero-actions .btn,.contact-ultimate-actions .btn{width:100%}.contact-ultimate-card{padding:26px}.contact-ultimate-item{grid-template-columns:70px 1fr;gap:16px}.contact-ultimate-icon{width:62px;height:62px;border-radius:18px;font-size:25px}.contact-why-grid{grid-template-columns:1fr}}

/* ============================================================
V34 - Contact carte premium sans dépassement email
============================================================ */

.contact-ultimate-card{
    padding:30px;
    display:grid;
    gap:16px;
}

.contact-ultimate-item{
    background:rgba(255,255,255,.035);
    border:1px solid rgba(255,208,0,.24);
    border-radius:18px;
    padding:18px;
    transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.contact-ultimate-item:hover{
    transform:translateY(-2px);
    border-color:rgba(255,208,0,.55);
    box-shadow:0 10px 26px rgba(0,0,0,.22);
}

.contact-ultimate-separator{
    display:none;
}

.contact-ultimate-item p,
.contact-ultimate-item a{
    overflow-wrap:anywhere;
    word-break:break-word;
}

.contact-ultimate-actions{
    margin-top:10px;
}

@media(max-width:700px){
    .contact-ultimate-card{
        padding:22px;
    }

    .contact-ultimate-item{
        grid-template-columns:58px 1fr;
        padding:16px;
    }

    .contact-ultimate-icon{
        width:54px;
        height:54px;
        font-size:23px;
        border-radius:16px;
    }

    .contact-ultimate-item h2{
        font-size:1.18rem;
    }

    .contact-ultimate-item p,
    .contact-ultimate-item a{
        font-size:.98rem;
    }
}


/* ============================================================
V36 - Logo agrandi
============================================================ */

.logo-img{
    max-width: 320px !important;
    height: 110px !important;
    object-fit: contain;
}

@media(max-width:700px){
    .logo-img{
        max-width: 260px !important;
        height: 88px !important;
    }
}


/* ============================================================
V37 - Logo beaucoup plus gros et plus esthétique
============================================================ */

.site-header .logo{
    flex: 0 0 auto;
}

.site-header .logo-img{
    max-width: 420px !important;
    width: 100%;
    height: 145px !important;
    object-fit: contain;
    display: block;
}

.site-header{
    gap: 24px;
}

@media (max-width: 1100px){
    .site-header .logo-img{
        max-width: 360px !important;
        height: 125px !important;
    }
}

@media (max-width: 700px){
    .site-header .logo{
        width: 100%;
        justify-content: center;
    }

    .site-header .logo-img{
        max-width: 300px !important;
        height: 105px !important;
    }
}


/* ============================================================
V38 - Logo footer agrandi
============================================================ */

footer .footer-logo,
.site-footer .footer-logo{
    max-width: 340px !important;
    width: 100%;
    height: 130px !important;
    object-fit: contain;
    display: block;
}

footer .footer-brand,
.site-footer .footer-brand{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
}

@media (max-width: 700px){
    footer .footer-logo,
    .site-footer .footer-logo{
        max-width: 280px !important;
        height: 110px !important;
    }
}


/* ============================================================
V40 - Footer élégant sans logo
============================================================ */

footer .footer-logo,
.site-footer .footer-logo{
    display:none !important;
}

.footer-grid{
    align-items:start;
    gap:28px;
}

.footer-grid > div:first-child{
    min-width:0;
}

.footer-brand-minimal{
    position:relative;
    padding-left:20px;
    max-width:420px;
}

.footer-brand-minimal::before{
    content:"";
    position:absolute;
    left:0;
    top:4px;
    bottom:4px;
    width:4px;
    border-radius:999px;
    background:linear-gradient(180deg,#FFD000,#f5a400);
}

.footer-brand-name{
    color:#ffffff;
    font-size:1.55rem;
    line-height:1.15;
    margin:0 0 8px;
    letter-spacing:.2px;
}

.footer-brand-tagline{
    color:#FFD000;
    font-size:.98rem;
    font-weight:800;
    margin:0 0 10px;
}

.footer-brand-desc{
    color:#e9e9e9;
    line-height:1.75;
    margin:0;
}

footer h3,
.site-footer h3{
    color:#FFD000;
    margin-bottom:12px;
}

footer a,
footer p,
footer strong,
.site-footer a,
.site-footer p,
.site-footer strong{
    color:#ffffff;
}

footer a:hover,
.site-footer a:hover{
    color:#FFD000;
}

.copyright{
    margin-top:28px;
    padding-top:20px;
    border-top:1px solid rgba(255,255,255,.10);
    color:#dcdcdc;
}

@media(max-width:700px){
    .footer-brand-minimal{
        padding-left:16px;
        max-width:none;
    }

    .footer-brand-name{
        font-size:1.35rem;
    }
}
