/* ===========================================
   GEDEONWEB — Redesign épuré & moderne
   Palette : vert nature + bleu-gris sombre
   Fonts  : Quicksand (titres) + Montserrat (body)
   =========================================== */

/* --- Fonts (self-hosted) --- */
@font-face {
    font-family: 'Quicksand';
    font-style: normal;
    font-weight: 400 700;
    font-display: swap;
    src: url('/fonts/quicksand-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 300 600;
    font-display: swap;
    src: url('/fonts/montserrat-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{background:none;border:none;cursor:pointer;font:inherit}

/* --- Design Tokens --- */
:root{
    /* Palette du site original */
    --accent:#1a9e82;
    --accent-dark:#0d7a63;
    --accent-glow:rgba(26,158,130,.15);
    --dark:#10151b;
    --dark-2:#1a2332;
    --dark-3:#243549;
    --slate:#3a4f65;
    --muted:#5a6f82;
    --light:#c8d6e0;
    --off-white:#f0f4f7;
    --white:#ffffff;

    /* Fonts */
    --ff-heading:'Quicksand',sans-serif;
    --ff-body:'Montserrat',sans-serif;

    /* Sizes */
    --fs-xs:.85rem;
    --fs-sm:.95rem;
    --fs-base:1.075rem;
    --fs-lg:1.2rem;
    --fs-xl:1.35rem;
    --fs-2xl:1.65rem;
    --fs-3xl:2.25rem;
    --fs-4xl:3rem;
    --fs-5xl:3.75rem;

    /* Misc */
    --radius:12px;
    --radius-lg:20px;
    --ease:cubic-bezier(.4,0,.2,1);
    --dur:.35s;
    --container:1140px;
}

body{
    font-family:var(--ff-body);
    font-size:var(--fs-base);
    font-weight:400;
    line-height:1.7;
    color:var(--slate);
    background:var(--white);
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
}

h1,h2,h3,h4{
    font-family:var(--ff-heading);
    font-weight:700;
    line-height:1.15;
    color:var(--dark);
}

.wrap{
    width:100%;
    max-width:var(--container);
    margin:0 auto;
    padding:0 2rem;
}

/* =========================================
   BUTTONS
   ========================================= */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.5rem;
    font-family:var(--ff-heading);
    font-weight:600;
    font-size:var(--fs-sm);
    letter-spacing:.02em;
    border:2px solid transparent;
    border-radius:50px;
    cursor:pointer;
    transition:all var(--dur) var(--ease);
    text-decoration:none;
    position:relative;
    overflow:hidden;
}
.btn::after{
    content:'';
    position:absolute;
    inset:0;
    background:rgba(255,255,255,.15);
    transform:translateX(-110%);
    transition:transform .4s var(--ease);
    border-radius:inherit;
}
.btn:hover::after{transform:translateX(0)}

.btn--sm{padding:.55rem 1.4rem;font-size:var(--fs-xs)}
.btn--lg{padding:.9rem 2.4rem;font-size:var(--fs-base)}
.btn--xl{padding:1.1rem 3rem;font-size:var(--fs-lg)}
.btn--full{width:100%}

.btn--accent{
    background:var(--accent);
    color:var(--white);
    border-color:var(--accent);
}
.btn--accent:hover{
    background:var(--accent-dark);
    border-color:var(--accent-dark);
    transform:translateY(-2px);
    box-shadow:0 8px 30px rgba(26,158,130,.3);
}

.btn--ghost{
    background:transparent;
    color:var(--white);
    border-color:rgba(255,255,255,.35);
}
.btn--ghost:hover{
    border-color:var(--white);
    background:rgba(255,255,255,.08);
}

.btn--outline{
    background:transparent;
    color:var(--dark);
    border-color:var(--light);
}
.btn--outline:hover{
    border-color:var(--accent);
    color:var(--accent);
    transform:translateY(-2px);
}

.btn--white{
    background:var(--white);
    color:var(--dark);
    border-color:var(--white);
    font-size:var(--fs-lg);
}
.btn--white:hover{
    background:transparent;
    color:var(--white);
    transform:translateY(-2px);
    box-shadow:0 10px 40px rgba(0,0,0,.2);
}

/* =========================================
   HEADER
   ========================================= */
.header{
    position:fixed;
    top:0;left:0;right:0;
    z-index:100;
    transition:all .4s var(--ease);
}
.header::before{
    content:'';
    position:absolute;
    inset:0;
    background:rgba(16,21,27,.6);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    opacity:0;
    transition:opacity .4s var(--ease);
    border-bottom:1px solid rgba(255,255,255,.06);
}
.header--solid::before{opacity:1}

.header__wrap{
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:5rem;
    position:relative;
    z-index:1;
    max-width:100%;
    padding:0 1rem;
}

.logo__img{height:32px;width:auto;transition:opacity var(--dur)}
.logo__img:hover{opacity:.8}

.nav__list{display:flex;gap:0;flex-wrap:nowrap}
.nav__link{
    padding:.5rem .65rem;
    font-family:var(--ff-heading);
    font-size:.9rem;
    font-weight:500;
    white-space:nowrap;
    color:rgba(255,255,255,.7);
    border-radius:50px;
    transition:all var(--dur) var(--ease);
    position:relative;
}
.nav__link::after{
    content:'';
    position:absolute;
    bottom:4px;left:.65rem;right:.65rem;
    height:2px;
    background:var(--accent);
    transform:scaleX(0);
    transform-origin:center;
    transition:transform var(--dur) var(--ease);
    border-radius:2px;
}
.nav__link:hover,.nav__link.active{color:var(--white)}
.nav__link:hover::after,.nav__link.active::after{transform:scaleX(1)}

.header__right{display:flex;align-items:center;gap:1rem}
.header__tel{
    display:flex;
    align-items:center;
    gap:.4rem;
    font-family:var(--ff-heading);
    font-size:.875rem;
    font-weight:600;
    color:rgba(255,255,255,.8);
    transition:color var(--dur);
}
.header__tel:hover{color:var(--accent)}

/* Burger */
.burger{
    display:none;
    width:28px;height:20px;
    position:relative;
    z-index:110;
}
.burger span,
.burger::before,
.burger::after{
    content:'';
    position:absolute;
    left:0;right:0;
    height:2px;
    background:var(--white);
    border-radius:2px;
    transition:all var(--dur) var(--ease);
}
.burger::before{top:0}
.burger span{top:50%;transform:translateY(-50%)}
.burger::after{bottom:0}
.burger.open::before{transform:rotate(45deg) translate(6px,6px)}
.burger.open span{opacity:0}
.burger.open::after{transform:rotate(-45deg) translate(6px,-6px)}

/* =========================================
   HERO
   ========================================= */
.hero{
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
}
.hero__bg{
    position:absolute;
    inset:-20% 0;
    z-index:0;
}
.hero__bg img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
    transform:scale(1.15);
    transition:transform 5s ease-out;
    will-change:transform;
}
.hero.loaded .hero__bg img{
    transform:scale(1);
}
.hero__overlay{
    position:absolute;
    inset:0;
    z-index:1;
    background:
        linear-gradient(180deg, rgba(16,21,27,.88) 0%, rgba(16,21,27,.40) 40%, rgba(16,21,27,.92) 100%),
        linear-gradient(135deg, rgba(26,158,130,.06) 0%, transparent 60%);
}

.hero__wrap{
    position:relative;
    z-index:2;
    text-align:center;
    padding:8rem 2rem 6rem;
    text-shadow:0 2px 20px rgba(0,0,0,.4), 0 0 40px rgba(26,158,130,.15);
}
.hero__wrap::before,
.hero__wrap::after{
    content:'';
    position:absolute;
    border-radius:50%;
    pointer-events:none;
    z-index:-1;
}
.hero__wrap::before{
    width:550px;height:550px;
    top:-10%;left:-15%;
    background:rgba(26,158,130,.55);
    filter:blur(90px);
    animation:glowA 7s ease-in-out infinite;
}
.hero__wrap::after{
    width:450px;height:450px;
    bottom:-5%;right:-10%;
    background:rgba(26,107,138,.45);
    filter:blur(90px);
    animation:glowB 9s ease-in-out infinite 2s;
}
/* Glows supplémentaires via les actions */
.hero__actions::before,
.hero__actions::after{
    content:'';
    position:absolute;
    border-radius:50%;
    pointer-events:none;
    z-index:-1;
}
.hero__actions{position:relative}
.hero__actions::before{
    width:350px;height:350px;
    top:-300px;right:-200px;
    background:rgba(26,158,130,.4);
    filter:blur(80px);
    animation:glowC 11s ease-in-out infinite 1s;
}
.hero__actions::after{
    width:300px;height:300px;
    top:-450px;left:-180px;
    background:rgba(13,122,99,.35);
    filter:blur(80px);
    animation:glowD 13s ease-in-out infinite 4s;
}
@keyframes glowA{
    0%{opacity:.5;transform:translate(0,0) scale(1)}
    25%{opacity:.9;transform:translate(80px,40px) scale(1.2)}
    50%{opacity:.6;transform:translate(120px,-20px) scale(1.05)}
    75%{opacity:.8;transform:translate(-40px,60px) scale(1.15)}
    100%{opacity:.5;transform:translate(0,0) scale(1)}
}
@keyframes glowB{
    0%{opacity:.4;transform:translate(0,0) scale(1)}
    25%{opacity:.8;transform:translate(-70px,-40px) scale(1.2)}
    50%{opacity:.5;transform:translate(-100px,30px) scale(.9)}
    75%{opacity:.7;transform:translate(50px,-50px) scale(1.1)}
    100%{opacity:.4;transform:translate(0,0) scale(1)}
}
@keyframes glowC{
    0%{opacity:.3;transform:translate(0,0) scale(1)}
    33%{opacity:.7;transform:translate(-90px,50px) scale(1.25)}
    66%{opacity:.5;transform:translate(60px,80px) scale(.9)}
    100%{opacity:.3;transform:translate(0,0) scale(1)}
}
@keyframes glowD{
    0%{opacity:.3;transform:translate(0,0) scale(.9)}
    33%{opacity:.6;transform:translate(70px,-40px) scale(1.15)}
    66%{opacity:.4;transform:translate(-50px,-70px) scale(1.05)}
    100%{opacity:.3;transform:translate(0,0) scale(.9)}
}

.hero__tag{
    display:inline-block;
    padding:.4rem 1.4rem;
    font-family:var(--ff-heading);
    font-size:var(--fs-xs);
    font-weight:600;
    letter-spacing:.15em;
    text-transform:uppercase;
    color:var(--accent);
    border:1px solid rgba(26,158,130,.3);
    border-radius:50px;
    margin-bottom:2rem;
}

.hero__title{
    font-size:clamp(var(--fs-3xl), 5vw, var(--fs-5xl));
    color:var(--white);
    margin-bottom:1.5rem;
    letter-spacing:-.02em;
}
.hero__title--accent{
    color:var(--accent);
}
.hero__title--light{
    font-weight:400;
    opacity:.7;
    font-size:.75em;
}

.hero__lead{
    font-size:clamp(var(--fs-base), 1.5vw, var(--fs-lg));
    color:rgba(255,255,255,.75);
    max-width:580px;
    margin:0 auto 2.5rem;
    font-weight:400;
    line-height:1.8;
}

.hero__actions{
    display:flex;
    gap:1rem;
    justify-content:center;
}
.hero__actions .btn--accent{
    background:rgba(26,158,130,.55);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    border:1px solid rgba(26,158,130,.4);
}
.hero__actions .btn--accent:hover{
    background:rgba(26,158,130,.75);
    border-color:rgba(26,158,130,.6);
    flex-wrap:wrap;
}

.hero__arrow{
    position:absolute;
    bottom:2.5rem;
    left:50%;
    transform:translateX(-50%);
    z-index:2;
    color:rgba(255,255,255,.3);
    animation:arrow-bounce 2.5s ease-in-out infinite;
    transition:color var(--dur);
}
.hero__arrow:hover{color:var(--accent)}

@keyframes arrow-bounce{
    0%,100%{transform:translateX(-50%) translateY(0)}
    50%{transform:translateX(-50%) translateY(10px)}
}

/* =========================================
   SECTIONS
   ========================================= */
.section{
    padding:7rem 0;
    position:relative;
}
#offres{
    background:linear-gradient(180deg, var(--white) 0%, var(--off-white) 100%);
}
.section--dark{
    background:var(--dark);
}
.section--dark h2,.section--dark h3,.section--dark h4{
    color:var(--white);
}
.section--subtle{
    background:var(--off-white);
}
.section--cta{
    background:linear-gradient(135deg, var(--dark-2) 0%, var(--dark-3) 100%);
    position:relative;
    overflow:hidden;
}
.section--cta::before{
    content:'';
    position:absolute;
    width:500px;height:500px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(26,158,130,.12) 0%, transparent 70%);
    top:-200px;right:-100px;
    pointer-events:none;
}

/* =========================================
   MAINTENANCE WP
   ========================================= */
.section--maintenance{
    position:relative;
    overflow:hidden;
    text-align:center;
    padding:4rem 0;
}
.maintenance__bg{
    position:absolute;
    inset:0;
    z-index:0;
}
.maintenance__bg img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.maintenance__overlay{
    position:absolute;
    inset:0;
    z-index:1;
    background:linear-gradient(135deg, rgba(13,122,99,.88) 0%, rgba(26,107,138,.85) 50%, rgba(26,82,118,.9) 100%);
}
.section--maintenance::before{
    content:'';
    position:absolute;
    width:600px;height:600px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(255,255,255,.06) 0%, transparent 70%);
    top:-250px;left:-150px;
    pointer-events:none;
}
.section--maintenance::after{
    content:'';
    position:absolute;
    width:400px;height:400px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(26,158,130,.15) 0%, transparent 70%);
    bottom:-150px;right:-100px;
    pointer-events:none;
}
.maintenance__content{
    position:relative;
    z-index:1;
    max-width:900px;
    margin:0 auto;
}
.maintenance__icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:72px;height:72px;
    border-radius:50%;
    background:rgba(255,255,255,.1);
    color:var(--white);
    margin-bottom:1.5rem;
}
.maintenance__title{
    font-family:var(--ff-heading);
    font-size:clamp(var(--fs-2xl), 3vw, var(--fs-3xl));
    color:var(--white);
    margin-bottom:1.25rem;
}
.maintenance__text{
    font-size:var(--fs-base);
    color:rgba(255,255,255,.75);
    line-height:1.8;
    margin-bottom:1.5rem;
}
.maintenance__text strong{color:var(--white)}
.maintenance__list{
    list-style:none;
    display:inline-grid;
    grid-template-columns:1fr 1fr;
    gap:.6rem 2rem;
    text-align:left;
    margin-bottom:2.5rem;
    font-size:var(--fs-sm);
    color:rgba(255,255,255,.8);
}
.maintenance__list li::before{
    content:'✓ ';
    color:var(--white);
    font-weight:700;
}
@media(max-width:600px){
    .maintenance__list{grid-template-columns:1fr}
}

.section__head{
    text-align:center;
    margin-bottom:4rem;
}
.section__label{
    display:inline-block;
    font-family:var(--ff-heading);
    font-size:var(--fs-xs);
    font-weight:700;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:var(--accent);
    margin-bottom:.75rem;
}
.section__label--light{color:var(--accent)}
.section__title{
    font-size:clamp(var(--fs-2xl), 3.5vw, var(--fs-4xl));
    margin-bottom:.75rem;
    letter-spacing:-.02em;
}
.section__title--white{color:var(--white)}
.section__intro{
    font-size:var(--fs-lg);
    color:var(--muted);
    max-width:500px;
    margin:0 auto;
    font-weight:300;
}

/* =========================================
   CARDS (Prestations)
   ========================================= */
.cards{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.5rem;
}

.card{
    position:relative;
    padding:2.5rem 2rem 2rem;
    background:var(--white);
    border:1px solid var(--off-white);
    border-radius:var(--radius-lg);
    transition:all var(--dur) var(--ease);
    overflow:hidden;
}
.card::before{
    content:'';
    position:absolute;
    top:0;left:0;
    width:100%;height:3px;
    background:linear-gradient(90deg, var(--accent), var(--accent-dark));
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .5s var(--ease);
}
.card:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 60px rgba(16,21,27,.08);
    border-color:transparent;
}
.card:hover::before{transform:scaleX(1)}

.card__number{
    font-family:var(--ff-heading);
    font-size:var(--fs-4xl);
    font-weight:700;
    color:var(--off-white);
    line-height:1;
    margin-bottom:.75rem;
    display:block;
    transition:color var(--dur) var(--ease);
}
.card:hover .card__number{color:var(--accent-glow)}

.card__title{
    font-size:var(--fs-lg);
    margin-bottom:.75rem;
}
.card__text{
    font-size:var(--fs-sm);
    color:var(--muted);
    line-height:1.75;
}
.card__line{
    width:40px;height:2px;
    background:var(--accent);
    margin-top:1.5rem;
    border-radius:2px;
    transition:width var(--dur) var(--ease);
}
.card:hover .card__line{width:80px}

.card__link{
    display:inline-flex;
    align-items:center;
    margin-top:1.25rem;
    font-family:var(--ff-heading);
    font-size:var(--fs-sm);
    font-weight:600;
    color:var(--accent);
    transition:gap var(--dur) var(--ease), color var(--dur) var(--ease);
    gap:.3rem;
}
.card__link::after{
    content:'→';
    transition:transform var(--dur) var(--ease);
}
.card:hover .card__link{color:var(--accent-dark)}
.card:hover .card__link::after{transform:translateX(4px)}

/* =========================================
   FAQ
   ========================================= */
.faq{
    max-width:750px;
    margin:0 auto 4rem;
}
.faq__item{
    border-bottom:1px solid rgba(255,255,255,.08);
}
.faq__item:first-child{
    border-top:1px solid rgba(255,255,255,.08);
}
.faq__q{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:1rem;
    padding:1.5rem 0;
    cursor:pointer;
    font-family:var(--ff-heading);
    font-size:var(--fs-base);
    font-weight:600;
    color:rgba(255,255,255,.85);
    list-style:none;
    transition:color var(--dur);
}
.faq__q::-webkit-details-marker{display:none}
.faq__q:hover{color:var(--accent)}

.faq__icon{
    width:24px;height:24px;
    flex-shrink:0;
    position:relative;
    border:1.5px solid rgba(255,255,255,.2);
    border-radius:50%;
    transition:all var(--dur) var(--ease);
}
.faq__icon::before,
.faq__icon::after{
    content:'';
    position:absolute;
    background:rgba(255,255,255,.6);
    border-radius:2px;
    transition:all var(--dur) var(--ease);
}
.faq__icon::before{
    width:10px;height:1.5px;
    top:50%;left:50%;
    transform:translate(-50%,-50%);
}
.faq__icon::after{
    width:1.5px;height:10px;
    top:50%;left:50%;
    transform:translate(-50%,-50%);
}
.faq__item[open] .faq__icon{
    border-color:var(--accent);
    transform:rotate(45deg);
}
.faq__item[open] .faq__icon::before,
.faq__item[open] .faq__icon::after{
    background:var(--accent);
}

.faq__a{
    color:rgba(255,255,255,.7);
    font-size:var(--fs-sm);
    line-height:1.8;
    font-weight:400;
    max-height:0;
    overflow:hidden;
    opacity:0;
    padding-bottom:0;
    transition:max-height .5s var(--ease), opacity .35s var(--ease), padding-bottom .5s var(--ease);
}

/* =========================================
   ATOUTS (Les Plus)
   ========================================= */
.atouts__grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.25rem;
}
.atout{
    display:flex;
    gap:1rem;
    padding:1.5rem;
    border:1px solid rgba(255,255,255,.12);
    border-radius:var(--radius);
    transition:all var(--dur) var(--ease);
}
.atout:hover{
    background:rgba(255,255,255,.06);
    border-color:rgba(26,158,130,.3);
}
.atout__icon{
    flex-shrink:0;
    width:44px;height:44px;
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--accent);
    background:rgba(26,158,130,.15);
    border-radius:10px;
}
.atout__name{
    font-size:var(--fs-base);
    margin-bottom:.25rem;
    color:var(--white);
}
.atout__text{
    font-size:var(--fs-sm);
    color:rgba(255,255,255,.7);
    line-height:1.7;
    font-weight:400;
}

/* =========================================
   PRICING
   ========================================= */
.pricing{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.75rem;
    align-items:stretch;
}
.pricing__card{
    position:relative;
    padding:2rem 1.75rem;
    background:var(--white);
    border:1px solid var(--off-white);
    border-radius:var(--radius-lg);
    transition:all var(--dur) var(--ease);
    text-align:center;
    display:flex;
    flex-direction:column;
}
.pricing__card .btn{margin-top:auto}
.pricing__card:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 60px rgba(16,21,27,.08);
}
.pricing__card--featured{
    border:2px solid var(--accent);
    box-shadow:0 0 0 4px var(--accent-glow);
}

.pricing__badge{
    position:absolute;
    top:-12px;left:50%;
    transform:translateX(-50%);
    padding:.3rem 1.2rem;
    background:var(--accent);
    color:var(--white);
    font-family:var(--ff-heading);
    font-size:var(--fs-xs);
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    border-radius:50px;
}

.pricing__name{
    font-size:var(--fs-xl);
    margin-bottom:1rem;
    padding-top:.5rem;
}
.pricing__price{
    font-family:var(--ff-heading);
    font-size:var(--fs-4xl);
    font-weight:700;
    color:var(--dark);
    margin-bottom:.25rem;
}
.pricing__price sup{
    font-size:var(--fs-xl);
    vertical-align:super;
}
.pricing__price small{
    font-size:var(--fs-sm);
    font-weight:400;
    color:var(--muted);
    margin-left:.15rem;
}
.pricing__old{
    font-size:var(--fs-sm);
    color:var(--muted);
    text-decoration:line-through;
    margin-bottom:1rem;
}
.pricing__sub{
    font-size:var(--fs-sm);
    color:var(--accent);
    font-weight:500;
    margin-top:-.15rem;
    margin-bottom:1rem;
}
.pricing__list{
    text-align:left;
    margin-bottom:1.5rem;
    display:flex;
    flex-direction:column;
    gap:.5rem;
}
.pricing__list li{
    font-size:var(--fs-sm);
    color:var(--slate);
    padding-left:1.5rem;
    position:relative;
    line-height:1.5;
}
.pricing__list li::before{
    content:'';
    position:absolute;
    left:0;top:.35em;
    width:12px;height:12px;
    border-radius:50%;
    border:2px solid var(--accent);
    background:transparent;
    transition:background var(--dur);
}
.pricing__card:hover .pricing__list li::before{
    background:var(--accent);
}
.pricing__extra{
    font-size:var(--fs-xs);
    color:var(--muted);
    margin-bottom:1rem;
    font-style:italic;
}
.pricing__note{
    text-align:center;
    margin-top:2.5rem;
    font-size:var(--fs-sm);
    color:var(--muted);
    max-width:600px;
    margin-left:auto;
    margin-right:auto;
}

/* =========================================
   MARQUEE (Clients)
   ========================================= */
.marquee{
    overflow:hidden;
    padding:2rem 0;
    max-width:100vw;
    mask-image:linear-gradient(to right, transparent, black 4%, black 96%, transparent);
    -webkit-mask-image:linear-gradient(to right, transparent, black 4%, black 96%, transparent);
}
.marquee__track{
    display:flex;
    align-items:center;
    gap:5rem;
    animation:scroll 80s linear infinite;
    width:max-content;
}
.marquee__track img{
    height:45px;
    width:auto;
    object-fit:contain;
    filter:grayscale(1) opacity(.45);
    transition:all .4s var(--ease);
}
.marquee__track img:hover{
    filter:grayscale(0) opacity(1);
    transform:scale(1.1);
}

@keyframes scroll{
    0%{transform:translateX(0)}
    100%{transform:translateX(-50%)}
}

/* =========================================
   TESTIMONIAL CAROUSEL
   ========================================= */
.testimonial-carousel{
    max-width:650px;
    margin:4rem auto 0;
    position:relative;
}
.testimonial-carousel__track{
    overflow:hidden;
    position:relative;
}
.testimonial{
    text-align:center;
    padding:3rem 2.5rem;
    background:var(--white);
    border-radius:var(--radius-lg);
    border:1px solid var(--light);
    position:relative;
    display:none;
    animation:testimonialFade .5s var(--ease);
}
.testimonial.active{
    display:block;
}
@keyframes testimonialFade{
    from{opacity:0;transform:translateY(10px)}
    to{opacity:1;transform:translateY(0)}
}
.testimonial::before{
    content:'\201C';
    position:absolute;
    top:-30px;left:1.5rem;
    font-size:12rem;
    font-family:Georgia,serif;
    color:var(--accent);
    line-height:1;
    opacity:.12;
    pointer-events:none;
}
.testimonial__stars{
    color:#e8a838;
    font-size:var(--fs-lg);
    letter-spacing:4px;
    margin-bottom:1rem;
}
.testimonial__quote{
    font-size:var(--fs-base);
    color:var(--slate);
    line-height:1.8;
    font-weight:300;
    font-style:italic;
    margin-bottom:1.5rem;
}
.testimonial__cite{
    font-family:var(--ff-heading);
    font-style:normal;
    font-weight:600;
    font-size:var(--fs-sm);
    color:var(--dark);
}
.testimonial__cite span{
    color:var(--muted);
    font-weight:400;
}
/* Nav */
.testimonial-carousel__nav{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:1rem;
    margin-top:1.5rem;
}
.testimonial-carousel__btn{
    width:40px;height:40px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:var(--white);
    border:1px solid var(--light);
    color:var(--slate);
    transition:all .3s var(--ease);
    cursor:pointer;
}
.testimonial-carousel__btn:hover{
    background:var(--accent);
    color:var(--white);
    border-color:var(--accent);
}
.testimonial-carousel__dots{
    display:flex;
    gap:.4rem;
}
.testimonial-carousel__dot{
    width:8px;height:8px;
    border-radius:50%;
    background:var(--light);
    border:none;
    cursor:pointer;
    transition:all .3s var(--ease);
    padding:0;
}
.testimonial-carousel__dot.active{
    background:var(--accent);
    transform:scale(1.3);
}

/* =========================================
   CONTACT POPUP
   ========================================= */
.contact-popup{
    position:fixed;
    inset:0;
    z-index:9999;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    pointer-events:none;
    visibility:hidden;
}
.contact-popup.open{
    pointer-events:auto;
    visibility:visible;
}
.contact-popup__backdrop{
    position:absolute;
    inset:0;
    background:rgba(16,21,27,.6);
    opacity:0;
    transition:opacity .4s var(--ease);
}
.contact-popup.open .contact-popup__backdrop{
    opacity:1;
}
.contact-popup__panel{
    position:relative;
    width:100%;
    max-width:520px;
    height:100vh;
    background:var(--white);
    overflow-y:auto;
    padding:2.5rem;
    transform:translateX(100%);
    transition:transform .45s var(--ease);
    box-shadow:-10px 0 40px rgba(0,0,0,.15);
}
.contact-popup.open .contact-popup__panel{
    transform:translateX(0);
}
.contact-popup__close{
    position:absolute;
    top:1.25rem;right:1.25rem;
    width:36px;height:36px;
    display:flex;align-items:center;justify-content:center;
    border-radius:50%;
    color:var(--muted);
    transition:all .3s var(--ease);
    cursor:pointer;
    background:none;
    border:none;
}
.contact-popup__close:hover{
    color:var(--dark);
    background:var(--off-white);
}
.contact-popup__header{
    margin-bottom:2rem;
}
.contact-popup__title{
    font-family:var(--ff-heading);
    font-size:var(--fs-3xl);
    color:var(--dark);
    margin-bottom:.5rem;
}
.contact-popup__lead{
    font-size:var(--fs-sm);
    color:var(--muted);
}

/* Form */
.contact-form__row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:1rem;
}
.contact-form__field{
    margin-bottom:1.25rem;
}
.contact-form__field label{
    display:block;
    font-family:var(--ff-heading);
    font-size:var(--fs-sm);
    font-weight:600;
    color:var(--dark);
    margin-bottom:.4rem;
}
.contact-form__field input,
.contact-form__field select,
.contact-form__field textarea{
    width:100%;
    padding:.75rem 1rem;
    font-family:var(--ff-body);
    font-size:var(--fs-sm);
    color:var(--dark);
    background:var(--off-white);
    border:1px solid var(--light);
    border-radius:var(--radius);
    transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
    outline:none;
    resize:vertical;
}
.contact-form__field input:focus,
.contact-form__field select:focus,
.contact-form__field textarea:focus{
    border-color:var(--accent);
    box-shadow:0 0 0 3px var(--accent-glow);
}
.contact-form__field select{
    cursor:pointer;
    appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237b8fa3' stroke-width='2' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 1rem center;
    padding-right:2.5rem;
}
.contact-form__footer{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:1rem;
    margin-top:.5rem;
}
.contact-form__info{
    display:flex;
    align-items:center;
    gap:.4rem;
    font-size:.75rem;
    color:var(--muted);
}

/* Success */
.contact-popup__success{
    text-align:center;
    padding:3rem 1rem;
}
.contact-popup__success-icon{
    color:var(--accent);
    margin-bottom:1.5rem;
}
.contact-popup__success h3{
    font-family:var(--ff-heading);
    font-size:var(--fs-2xl);
    color:var(--dark);
    margin-bottom:.75rem;
}
.contact-popup__success p{
    color:var(--muted);
    margin-bottom:2rem;
    line-height:1.7;
}

/* Responsive */
@media(max-width:580px){
    .contact-popup__panel{
        max-width:100%;
        padding:2rem 1.5rem;
    }
    .contact-form__row{
        grid-template-columns:1fr;
    }
    .contact-form__footer{
        flex-direction:column;
        align-items:stretch;
    }
}

/* =========================================
   CONTACT
   ========================================= */
.contact{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:4rem;
}
.contact__left{max-width:550px}
.contact__portrait{
    width:100px;height:100px;
    border-radius:50%;
    object-fit:cover;
    border:3px solid var(--accent);
    box-shadow:0 4px 20px rgba(26,158,130,.3);
    margin-bottom:10px;
}
.contact__lead{
    font-size:var(--fs-lg);
    color:rgba(255,255,255,.8);
    margin-bottom:2rem;
    font-weight:400;
    line-height:1.8;
}
.contact__phone{
    display:inline-flex;
    align-items:center;
    gap:.6rem;
    font-family:var(--ff-heading);
    font-size:var(--fs-xl);
    font-weight:600;
    color:var(--white);
    margin-bottom:2rem;
    transition:color var(--dur);
}
.contact__phone:hover{color:var(--accent)}

.contact__socials{display:flex;gap:.75rem}
.contact__socials a{
    width:42px;height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(255,255,255,.12);
    border-radius:50%;
    color:rgba(255,255,255,.6);
    transition:all var(--dur) var(--ease);
}
.contact__socials a:hover{
    border-color:var(--accent);
    color:var(--accent);
    transform:translateY(-2px);
}

/* =========================================
   FOOTER
   ========================================= */
.footer{
    background:var(--dark);
    color:rgba(255,255,255,.85);
    padding-top:4rem;
    border-top:1px solid rgba(255,255,255,.06);
}
.footer__wrap{
    display:grid;
    grid-template-columns:1.8fr 1fr 1fr;
    gap:3rem;
    padding-bottom:3rem;
}
.footer__logo{height:28px;width:auto;margin-bottom:1.25rem;opacity:.85}
.footer__col p{font-size:var(--fs-sm);line-height:1.75;margin-bottom:.5rem;color:rgba(255,255,255,.75)}
.footer__motto{color:var(--accent);opacity:.8;margin-top:.5rem}

.footer__title{
    font-family:var(--ff-heading);
    font-size:var(--fs-xs);
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.15em;
    color:rgba(255,255,255,.5);
    margin-bottom:1.25rem;
}
.footer__col ul{display:flex;flex-direction:column;gap:.5rem}
.footer__col ul a{
    font-size:var(--fs-sm);
    color:rgba(255,255,255,.8);
    transition:color var(--dur);
}
.footer__col ul a:hover{color:var(--accent)}

.footer__phone{
    font-family:var(--ff-heading);
    font-weight:600;
    color:var(--white) !important;
    margin-bottom:.5rem;
}
.footer__phone:hover{color:var(--accent) !important}
.footer__social{display:flex;gap:.6rem;margin-top:1rem}
.footer__social a{
    width:34px;height:34px;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(255,255,255,.2);
    border-radius:50%;
    color:rgba(255,255,255,.7);
    transition:all var(--dur) var(--ease);
}
.footer__social a:hover{
    border-color:var(--accent);
    color:var(--accent);
}

.footer__bar{
    border-top:1px solid rgba(255,255,255,.1);
    padding:1.25rem 0;
}
.footer__bar p{
    text-align:center;
    font-size:var(--fs-xs);
    color:rgba(255,255,255,.55);
}
.footer__bar a{transition:color var(--dur)}
.footer__bar a:hover{color:rgba(255,255,255,.7)}

/* =========================================
   REVEAL ANIMATIONS
   ========================================= */
[data-reveal]{
    opacity:0;
    transform:translateY(30px);
    transition:opacity .8s var(--ease), transform .8s var(--ease);
}
[data-reveal][data-delay="1"]{transition-delay:.15s}
[data-reveal][data-delay="2"]{transition-delay:.3s}
[data-reveal][data-delay="3"]{transition-delay:.45s}
[data-reveal].is-visible{
    opacity:1;
    transform:translateY(0);
}

/* =========================================
   WHATSAPP CHAT WIDGET
   ========================================= */
.wa{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9998}

/* Bouton principal */
.wa__btn{
    width:56px;height:56px;
    border-radius:50%;
    background:#25D366;
    display:flex;
    align-items:center;
    justify-content:center;
    box-shadow:0 4px 15px rgba(37,211,102,.4);
    transition:all .35s var(--ease);
    cursor:pointer;
    border:none;
    position:relative;
}
.wa__btn:hover{transform:scale(1.1);box-shadow:0 6px 25px rgba(37,211,102,.5)}
.wa__icon-close{display:none}
.wa--open .wa__icon-wa{display:none}
.wa--open .wa__icon-close{display:block}

/* Tooltip */
.wa__tooltip{
    position:absolute;
    right:70px;
    white-space:nowrap;
    background:var(--dark);
    color:var(--white);
    font-family:var(--ff-body);
    font-size:.8rem;
    padding:.5rem 1rem;
    border-radius:8px;
    opacity:0;
    transform:translateX(10px);
    transition:all .3s var(--ease);
    pointer-events:none;
}
.wa__tooltip::after{
    content:'';
    position:absolute;
    top:50%;right:-6px;
    transform:translateY(-50%);
    border:6px solid transparent;
    border-left-color:var(--dark);
}
.wa__btn:hover .wa__tooltip{opacity:1;transform:translateX(0)}
.wa--open .wa__tooltip{display:none}

/* Popup */
.wa__popup{
    position:absolute;
    bottom:70px;right:0;
    width:340px;
    border-radius:16px;
    overflow:hidden;
    box-shadow:0 10px 40px rgba(0,0,0,.2);
    opacity:0;
    transform:translateY(20px) scale(.95);
    pointer-events:none;
    transition:all .3s var(--ease);
}
.wa--open .wa__popup{
    opacity:1;
    transform:translateY(0) scale(1);
    pointer-events:auto;
}

/* Header */
.wa__header{
    background:#075E54;
    padding:1rem 1.25rem;
    display:flex;
    align-items:center;
    gap:.75rem;
}
.wa__avatar{
    width:40px;height:40px;
    border-radius:50%;
    object-fit:cover;
    border:2px solid rgba(255,255,255,.3);
}
.wa__name{
    font-family:var(--ff-heading);
    font-size:.9rem;
    font-weight:600;
    color:#fff;
}
.wa__status{
    font-size:.7rem;
    color:rgba(255,255,255,.6);
}

/* Body */
.wa__body{
    background:#ECE5DD;
    padding:1.25rem;
    min-height:80px;
}
.wa__bubble{
    background:#fff;
    padding:.6rem 1rem;
    border-radius:0 10px 10px 10px;
    font-size:.85rem;
    color:#333;
    line-height:1.5;
    max-width:85%;
    box-shadow:0 1px 2px rgba(0,0,0,.1);
    font-family:var(--ff-body);
}

/* Footer */
.wa__footer{
    background:#f0f0f0;
    padding:.6rem;
    display:flex;
    gap:.5rem;
}
.wa__input{
    flex:1;
    border:none;
    border-radius:20px;
    padding:.6rem 1rem;
    font-family:var(--ff-body);
    font-size:.85rem;
    outline:none;
    background:#fff;
}
.wa__send{
    width:40px;height:40px;
    border-radius:50%;
    background:#25D366;
    border:none;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    transition:background .2s;
    flex-shrink:0;
}
.wa__send:hover{background:#1da851}

@media(max-width:480px){
    .wa{bottom:1rem;right:1rem}
    .wa__btn{width:48px;height:48px}
    .wa__tooltip{display:none}
    .wa__popup{width:calc(100vw - 2rem);right:-0.5rem}
}

/* =========================================
   RESPONSIVE
   ========================================= */

/* Tablet landscape */
@media(max-width:1024px){
    .cards{grid-template-columns:repeat(2,1fr)}
    .atouts__grid{grid-template-columns:repeat(2,1fr)}
    .pricing{grid-template-columns:repeat(2,1fr)}
    .footer__wrap{grid-template-columns:1fr 1fr}
    .footer__col--about{grid-column:span 2}
}

/* Tablet portrait */
@media(max-width:768px){
    .section{padding:5rem 0}

    .nav{
        position:fixed;
        inset:0;
        background:rgba(16,21,27,.97);
        backdrop-filter:blur(20px);
        display:flex;
        align-items:center;
        justify-content:center;
        opacity:0;
        visibility:hidden;
        transition:all .4s var(--ease);
        z-index:100;
    }
    .nav.open{
        opacity:1;
        visibility:visible;
    }
    .nav__list{
        flex-direction:column;
        align-items:center;
        gap:.5rem;
    }
    .nav__link{
        font-size:var(--fs-xl);
        padding:.75rem 1.5rem;
    }
    .burger{display:block}
    .header__tel span,.header__right .btn--sm{display:none}
    .header__tel{font-size:0}
    .header__tel svg{width:22px;height:22px}

    .hero__wrap{padding:7rem 1.5rem 5rem}

    .cards{grid-template-columns:1fr;max-width:480px;margin:0 auto}
    .atouts__grid{grid-template-columns:1fr}
    .pricing{grid-template-columns:1fr;max-width:400px;margin:0 auto}

    .contact{flex-direction:column;text-align:center}
    .contact__portrait{margin:0 auto}
    .contact__socials{justify-content:center}
    .contact__right{width:100%}
    .contact__right .btn{width:100%}

    .footer__wrap{grid-template-columns:1fr;gap:2rem}
    .footer__col--about{grid-column:auto}
}

/* Mobile */
@media(max-width:480px){
    .wrap{padding:0 1.25rem}
    .hero__title{font-size:var(--fs-2xl)}
    .hero__actions{flex-direction:column}
    .hero__actions .btn{width:100%}
    .section__title{font-size:var(--fs-2xl)}
    .card{padding:2rem 1.5rem}
    .testimonial{padding:2rem 1.5rem}
}
