/* =============================================================
   ADOUCISSEUR — Banner slider (3 themed slides)
   Scoped under #adc. Reuses tokens from adoucisseur.css.
   ============================================================= */
#adc .ban{
    position:relative; isolation:isolate;
    --ban-accent:#2274a5; --ban-accent-2:#2b8cc0;
    --ban-ink:#0f2a44; --ban-sub:#51627a;
    background:#f4f7fd;   /* plain background behind the tabs (under the banner) */
}
/* themes — only the stage (the banner area) is themed, tabs stay on plain bg */
#adc .ban.t1{ --ban-accent:#2274a5; --ban-accent-2:#2b8cc0; }
#adc .ban.t2{ --ban-accent:#e40014; --ban-accent-2:#ff3b4e; --ban-ink:#fff; --ban-sub:#c9d2e0; }
#adc .ban.t3{ --ban-accent:#15a35a; --ban-accent-2:#22c06d; }
#adc .ban.t1 .ban__stage{ background:radial-gradient(80% 120% at 88% -10%,#dcebf8 0,#eef5fb 60%); }
#adc .ban.t2 .ban__stage{ background:radial-gradient(90% 120% at 75% 0%,#1c2330 0,#070a10 70%); }
#adc .ban.t3 .ban__stage{ background:radial-gradient(80% 120% at 88% -10%,#e2f4ea 0,#eef7f2 60%); }

#adc .ban__stage{ position:relative; padding:140px 60px 0px; overflow:hidden; transition:background .5s ease; }
#adc .ban__inner{ max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1.02fr .98fr; gap:20px; align-items:center; min-height:470px; }

/* LEFT content (stacked slides, cross-fade) */
#adc .ban__content{ display:grid; }
#adc .ban__slide{ grid-area:1/1; opacity:0; visibility:hidden; transform:translateY(12px);
                  transition:opacity .45s ease, transform .45s ease, visibility .45s; pointer-events:none; }
#adc .ban__slide.is-active{ opacity:1; visibility:visible; transform:none; pointer-events:auto; }

#adc .ban__offer{ display:inline-flex; align-items:center; gap:14px; margin-bottom:22px; }
#adc .ban__offer-box{ display:flex; flex-direction:column; background:rgba(34,116,165,.08); border:1px solid rgba(34,116,165,.18);
                      border-radius:14px; padding:10px 16px; }
#adc .ban.t2 .ban__offer-box{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.18); }
#adc .ban__offer-small{ font-size:12px; color:var(--ban-sub); }
#adc .ban__offer-big{ font-family:var(--adc-display); font-weight:800; font-size:24px; color:var(--ban-accent); }
#adc .ban__offer-tag{ background:#e40014; color:#fff; font-weight:800; font-size:12px; letter-spacing:.04em;
                      padding:7px 12px; border-radius:8px; align-self:center; }

#adc .ban__title{ font-family:var(--adc-display); font-weight:900; color:var(--ban-ink);
                  font-size:clamp(34px,4.6vw,58px); line-height:1.02; letter-spacing:-.015em; margin:0 0 18px; }
#adc .ban__title .ban-hl{ color:var(--ban-accent); }
#adc .ban__lead{ font-size:18px; color:var(--ban-sub); max-width:480px; margin:0 0 26px; }

#adc .ban__cta{ display:flex; flex-wrap:wrap; gap:14px; }
#adc .ban__btn{ display:inline-flex; align-items:center; gap:10px; font-family:var(--adc-sans); font-weight:700;
                font-size:16px; padding:15px 26px; border-radius:14px; border:2px solid transparent; cursor:pointer;
                transition:transform .15s ease, box-shadow .2s ease; }
#adc .ban__btn svg{ width:19px; height:19px; }
#adc .ban__btn--accent{ color:#fff; background:var(--ban-accent); box-shadow:0 14px 30px -8px var(--ban-accent); }
#adc .ban__btn--accent:hover{ transform:translateY(-2px); }
#adc .ban__btn--light{ color:var(--ban-ink); background:#fff; border-color:#e2e8f0; box-shadow:0 8px 22px rgba(8,26,68,.08); }
#adc .ban.t2 .ban__btn--light{ color:#0f2a44; }
#adc .ban__btn--light:hover{ transform:translateY(-2px); }

/* RIGHT media */
#adc .ban__media{ position:relative; align-self:stretch; min-height:470px; }
#adc .ban__glow{ position:absolute; inset:6% 4% 8% 6%; border-radius:50%;
                 background:radial-gradient(closest-side, rgba(255,255,255,.7), rgba(255,255,255,0)); opacity:0; transition:opacity .5s; }
#adc .ban.t2 .ban__glow{ opacity:.55; background:radial-gradient(closest-side, rgba(120,170,220,.45), rgba(120,170,220,0)); }
#adc .ban__persons{ position:absolute; inset:0; z-index:2; }
#adc .ban__person{ position:absolute; left:20%; bottom:0; transform:translateX(-50%); height:104%; width:auto; max-width:none; object-fit:contain;
                   filter:drop-shadow(0 24px 26px rgba(8,26,68,.22));
                   opacity:0; visibility:hidden; transition:opacity .45s ease, visibility .45s; }
#adc .ban__person.is-active{ opacity:1; visibility:visible; }

/* floating feature-card panel */
#adc .ban__cards{ position:absolute; right:0; bottom:26px; width:300px; max-width:46%; display:grid; z-index:3; }
#adc .ban__cardset{ grid-area:1/1; display:flex; flex-direction:column; gap:8px;
                    background:rgba(255,255,255,.92); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
                    border-radius:18px; padding:16px; box-shadow:0 22px 50px rgba(8,26,68,.18);
                    opacity:0; visibility:hidden; transform:translateY(10px);
                    transition:opacity .4s ease, transform .4s ease, visibility .4s; pointer-events:none; }
#adc .ban__cardset.is-active{ opacity:1; visibility:visible; transform:none; pointer-events:auto; }
#adc .ban__card{ display:flex; align-items:flex-start; gap:11px; padding:6px 4px; }
#adc .ban__card-ic{ flex:none; width:38px; height:38px; border-radius:11px; display:grid; place-items:center;
                    background:rgba(34,116,165,.1); color:var(--ban-accent); }
#adc .ban__card-ic svg{ width:20px; height:20px; }
#adc .ban__card-tx strong{ display:block; font-family:var(--adc-display); font-size:15px; color:#0f2a44; }
#adc .ban__card-tx small{ font-size:12.5px; color:#5b6780; line-height:1.35; display:block; }

/* nav arrows */
#adc .ban__nav{ position:absolute; top:50%; transform:translateY(-50%); z-index:6; width:46px; height:46px; border-radius:50%;
                background:#fff; border:1px solid #e2e8f0; box-shadow:0 8px 22px rgba(8,26,68,.14); color:#0f2a44; outline: none;
                display:grid; place-items:center; cursor:pointer; transition:transform .15s, background .2s, color .2s; }
#adc .ban__nav:hover{ background:var(--ban-accent); color:#fff; border-color:var(--ban-accent); }
#adc .ban__nav svg{ width:22px; height:22px; }
#adc .ban__nav--prev{ left:14px; } #adc .ban__nav--next{ right:14px; }
#adc .ban.t2 .ban__nav{ background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.25); color:#fff; }

/* dots */
#adc .ban__dots{ position:absolute; left:50%; transform:translateX(-50%); bottom:10px; display:flex; gap:8px; z-index:5; }
#adc .ban__dot{ width:9px; height:9px; border-radius:50%; border:none; background:rgba(34,116,165,.28); cursor:pointer; transition:width .25s, background .25s; padding:0; }
#adc .ban__dot.is-active{ width:26px; border-radius:6px; background:var(--ban-accent); }
#adc .ban.t2 .ban__dot{ background:rgba(255,255,255,.35); } #adc .ban.t2 .ban__dot.is-active{ background:#fff; }

/* bottom tabs */
#adc .ban__tabs{ position:relative; max-width:1200px; margin:0 auto; padding:30px 26px 30px;
                 display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
#adc .ban__tab{ text-align:left; background:#fff; border:1px solid #e6edf5; border-radius:14px; padding:16px 18px; cursor:pointer;
                box-shadow:0 8px 22px rgba(8,26,68,.06); transition:transform .15s, box-shadow .2s, background .25s; }
#adc .ban__tab strong{ display:block; font-family:var(--adc-display); font-size:16px; color:#0f2a44; }
#adc .ban__tab span{ font-size:13px; color:#8a97a8; }
#adc .ban__tab:hover{ transform:translateY(-2px); }
#adc .ban__tab.is-active{ background:var(--ban-accent); border-color:var(--ban-accent); box-shadow:0 16px 30px -10px var(--ban-accent); }
#adc .ban__tab.is-active strong{ color:#fff; }
#adc .ban__tab.is-active span{ color:rgba(255,255,255,.85); }

/* floating ACTIF pill above the active tab */
#adc .ban__pill{ position:absolute; top:0; left:16.66%; transform:translate(-50%,calc(-100% - 8px));
                 background:#fff; color:var(--ban-accent); font-weight:800; font-size:11px; letter-spacing:.05em;
                 padding:7px 12px; border-radius:999px; box-shadow:0 8px 20px rgba(8,26,68,.16); white-space:nowrap;
                 transition:left .35s cubic-bezier(.4,0,.2,1), top .35s cubic-bezier(.4,0,.2,1), color .3s; border:1px solid #eef2f7; z-index:4; }
#adc .ban__pill i{ position:absolute; left:50%; bottom:-5px; transform:translateX(-50%) rotate(45deg);
                   width:10px; height:10px; background:#fff; border-right:1px solid #eef2f7; border-bottom:1px solid #eef2f7; }

/* MOBILE/TABLET block: feature cards + CTA shown under the banner (hidden on desktop) */
#adc .ban__mobile{ display:none; max-width:1200px; margin:0 auto; padding:22px 26px 20px; }
#adc .ban__mset{ display:none; }
#adc .ban__mset.is-active{ display:block; }
#adc .ban__mcards{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
#adc .ban__mcard{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:9px; padding:4px; }
#adc .ban__mcard .ban__card-ic{ width:48px; height:48px; border-radius:50%; background:rgba(0,0,0,.04); color:var(--ban-accent); }
#adc .ban__mcard .ban__card-ic svg{ width:22px; height:22px; }
#adc .ban__mcard .ban__card-tx strong{ font-family:var(--adc-display); font-size:15px; color:#0f2a44; display:block; }
#adc .ban__mcard .ban__card-tx small{ font-size:12.5px; color:#5b6780; line-height:1.4; display:block; }
#adc .ban__mcta{ display:flex; flex-direction:column; gap:12px; margin-top:20px; }
#adc .ban__mcta .ban__btn{ width:100%; justify-content:center; }
#adc .ban__mcta .ban__btn--light{ color:var(--ban-accent); border-color:var(--ban-accent); background:#fff; }

/* responsive — keep the text-left / person-right layout on tablet & mobile (per reference) */
@media (max-width:1320px){
    #adc .ban__nav {
        top: unset;
        bottom: 20%;
        opacity: 0.75;
    }
    #adc .ban__nav--next {
        right: 7px;
    }
    #adc .ban__nav--prev {
        left: 7px;
    }
}
@media (max-width: 1100px) {
    #adc .ban__cards { display: none; }                 /* floating cards hidden */
    #adc .ban__person{ left:auto; right:6%; transform:none; height:104%; }
    #adc .ban__stage{ padding:120px 60px 0; }
    #adc .ban__mobile{ display:block; }                 /* show cards + CTA under the banner */
    #adc .ban__slide .ban__cta{ display:none; }         /* hide the in-banner buttons */
    #adc .ban__offer {
        display: none;
    }
    #adc .ban__inner {
        align-items: start;
    }
}

/* this page only: hide the header "Nous contacter" button (frees the header's right side) */
.adoucisseur-page .mobile-header-btn{ display:none !important; }
/* …and keep the bar's height (the hidden button was its only sized content) */
.adoucisseur-page .header-navigation .logo-box{ min-height:58px; }

/* promo bandeau — overlaid INSIDE the header strip (≤1100px : the theme keeps the
   mobile-style header up to that width). Absolute (no page push), sits in the empty
   area right of the logo (logo ends ~137px). pointer-events:none so it can never block
   header interactions. Hidden on desktop (>1100px). */
.ban__promo{ display:none; }
@media (max-width:1100px){
    /* width:auto (shrink to content) + aligned right — no full-width red bar.
       max-width keeps it clear of the logo (ends ~137px) / burger when stuck. */
    .ban__promo{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:5px 10px;
                 position:absolute; z-index:101; top:29px; transform:translateY(-50%);
                 right:14px; width:auto; max-width:calc(100% - 165px); pointer-events:none;
                 background:#e40014; color:#fff; font-weight:700; font-size:12.5px; line-height:1.25; text-align:center;
                 padding:7px 12px; border-radius:8px; box-shadow:0 6px 16px rgba(228,0,20,.3);
                 transition:opacity .2s ease; }
    .ban__promo-tag{ background:#fff; color:#e40014; font-weight:800; font-size:10.5px; letter-spacing:.03em;
                     padding:3px 9px; border-radius:6px; white-space:nowrap; }
    .ban__promo-txt b{ font-weight:800; }
    .ban__promo del{ opacity:.75; font-weight:600; }
    /* sticky header active (theme's cloned .stricky-fixed bar, z-index:1001) :
       pin the pill over the clone — still auto width, right-aligned */
    .ban__promo.is-stuck{ position:fixed; top:29px; z-index:1002; max-width:calc(100% - 70px); }
}
@media (max-width:600px){
    .ban__promo{ right:10px; max-width:calc(100% - 158px); font-size:11px; gap:4px 8px; padding:8px 13px; }
    .ban__promo.is-stuck{ max-width:calc(100% - 62px); }
    .ban__promo-extra{ display:none; }   /* drop "— sans engagement" on small phones */
}
@media (max-width:400px){
    .ban__promo{ right:8px; max-width:calc(100% - 140px); font-size:10.5px; padding:8px 25px; }
    .ban__promo.is-stuck{ max-width:calc(100% - 56px); }
    .ban__promo-tag{ font-size:9.5px; padding:2px 7px; }
}
@media (max-width:900px){
    #adc .ban__inner{ grid-template-columns:1.1fr .9fr; min-height:380px; gap:12px; }
    #adc .ban__media{ min-height:380px; }
    #adc .ban__person{ left:auto; right:-2%; transform:none; height:90%; }
    #adc .ban__stage{ padding:120px 50px 0px; }
    #adc .ban__title{ font-size:clamp(28px,5.4vw,42px); }
    #adc .ban__lead{ font-size:16px; }
    #adc .ban__nav{ width:38px; height:38px; }
    #adc .ban__nav--prev{ left:6px; } #adc .ban__nav--next{ right:6px; }
    #adc .ban__nav svg{ width:18px; height:18px; }
}
@media (max-width:600px){
    #adc .ban__stage {padding: 120px 30px 0px;}
    #adc .ban__inner{ grid-template-columns:1.3fr .7fr; min-height:400px; gap:8px; }
    #adc .ban__media{ min-height:300px; }
    #adc .ban__tabsbar{ display:none; }
    /* person fits its own column on phones -> never overlaps the text */
    #adc .ban__person{ left:auto; right:-75px; bottom:-100px; transform:none; height:auto; width:300px;
                       filter:drop-shadow(0 14px 16px rgba(8,26,68,.2)); }
    #adc .ban__title{ font-size:clamp(22px,6.2vw,30px); }
    #adc .ban__lead{ font-size:13.5px; margin-bottom:14px; }
    #adc .ban__offer{ margin-bottom:12px; }
    #adc .ban__offer-box{ padding:6px 11px; } #adc .ban__offer-big{ font-size:17px; }
    #adc .ban__cta{ gap:8px; flex-wrap:wrap; }
    #adc .ban__btn{ padding:11px 14px; font-size:13px; border-radius:11px; }
    #adc .ban__btn svg{ width:16px; height:16px; }
    #adc .ban__tabs{ grid-template-columns:1fr; gap:10px; padding:22px 18px; }
    #adc .ban__pill{ display:none; }                   /* stacked tabs -> no single anchor */
    /* cards become readable rows on phones */
    #adc .ban__mobile{ padding:18px 18px 4px; }
    #adc .ban__mcards{ grid-template-columns:1fr; gap:10px; }
    #adc .ban__mcard{ flex-direction:row; align-items:flex-start; text-align:left; gap:12px; }
    #adc .ban__mcard .ban__card-ic{ width:42px; height:42px; flex:none; }
}
@media (max-width:575px){
    #adc .ban__stage {padding: 65px 30px 0px;}
}
@media (max-width:400px){
    #adc .ban__stage {
        padding: 65px 25px 0px;
    }
    #adc .ban__nav {
        top: unset;
        bottom: 10%;
        opacity: 0.75;
    }
    #adc .ban__person{ right:-100px; }
}
