/* =============================================================
   ADOUCISSEUR — "Avant / Après" comparateur + bénéfices + CTA
   Scoped under #adc. Reuses tokens from adoucisseur.css.
   ============================================================= */
#adc .adc-cmp{ padding-top:64px; }
#adc .adc-cmp__head{ text-align:center; max-width:760px; margin:0 auto 34px; }
#adc .adc-cmp__head h2{ font-size:clamp(26px,3.6vw,40px); margin-bottom:16px; }
#adc .adc-cmp__hl{ color:var(--adc-blue); }
#adc .adc-cmp__badge{ display:inline-flex; align-items:center; gap:9px; font-weight:600; font-size:15px;
                      color:var(--adc-navy); background:#fff; border:1px solid var(--adc-line);
                      padding:9px 18px; border-radius:999px; box-shadow:var(--adc-shadow); }
#adc .adc-cmp__badge svg{ width:20px; height:20px; color:var(--adc-blue); flex:none; }
#adc .adc-cmp__badge b{ color:var(--adc-blue); white-space:nowrap; }

/* ---- comparateur avant/après : carrousel auto ---- */
#adc .adc-cmp__carousel{ position:relative; max-width:860px; margin:0 auto 44px; aspect-ratio:16/9;
                         border-radius:22px; overflow:hidden; box-shadow:0 26px 60px rgba(8,26,68,.18);
                         background:#e7eef7; }
#adc .adc-cmp__track{ display:flex; height:100%; will-change:transform;
                      transition:transform .6s cubic-bezier(.5,.05,.2,1); }
#adc .adc-cmp__slide{ position:relative; flex:0 0 100%; min-width:100%; height:100%; }
#adc .adc-cmp__slider{ position:relative; width:100%; height:100%; overflow:hidden;
                       user-select:none; touch-action:none; }
#adc .adc-cmp__pane{ position:absolute; inset:0; }
#adc .adc-cmp__pane img{ width:100%; height:100%; object-fit:cover; display:block; pointer-events:none; }
#adc .adc-cmp__pane--after{ z-index:1; }
/* the "before" pane is clipped to the handle position */
#adc .adc-cmp__pane--before{ z-index:2; clip-path:inset(0 calc(100% - var(--pos)) 0 0); }
/* placeholder-only tint so the two sides differ until real photos are added */
#adc .adc-cmp__pane--before img{ filter:sepia(.55) saturate(.7) contrast(1.08) brightness(.82); }

#adc .adc-cmp__tag{ position:absolute; top:14px; display:inline-flex; align-items:center; gap:6px; z-index:3;
                    font-weight:800; font-size:12.5px; letter-spacing:.03em; color:#fff; padding:6px 12px; border-radius:999px; }
#adc .adc-cmp__tag svg{ width:15px; height:15px; }
#adc .adc-cmp__tag--before{ left:14px; background:var(--adc-red); }
#adc .adc-cmp__tag--after{ right:14px; background:var(--adc-green); }

#adc .adc-cmp__note{ position:absolute; bottom:14px; z-index:3; display:flex; align-items:center; gap:10px;
                     background:rgba(255,255,255,.94); border-radius:13px; padding:10px 13px; box-shadow:0 10px 24px rgba(8,26,68,.16);
                     max-width:44%; }
#adc .adc-cmp__note--before{ left:14px; }
#adc .adc-cmp__note--after{ right:14px; }
#adc .adc-cmp__note-ic{ flex:none; width:32px; height:32px; border-radius:50%; display:grid; place-items:center; }
#adc .adc-cmp__note-ic svg{ width:18px; height:18px; }
#adc .adc-cmp__note-ic--bad{ background:rgba(228,0,20,.12); color:var(--adc-red); }
#adc .adc-cmp__note-ic--ok{ background:rgba(11,181,116,.14); color:var(--adc-green); }
#adc .adc-cmp__note-tx strong{ display:block; font-family:var(--adc-display); font-size:13.5px; color:var(--adc-navy); line-height:1.15; }
#adc .adc-cmp__note-tx small{ font-size:12px; color:var(--adc-navy-soft); }

/* divider handle */
#adc .adc-cmp__handle{ position:absolute; top:0; bottom:0; left:var(--pos); width:3px; transform:translateX(-50%);
                       background:#fff; z-index:4; pointer-events:none; box-shadow:0 0 0 1px rgba(8,26,68,.08); }
#adc .adc-cmp__handle svg{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
                           width:26px; height:26px; padding:9px; box-sizing:content-box; color:var(--adc-blue);
                           background:#fff; border-radius:50%; box-shadow:0 8px 20px rgba(8,26,68,.28); }
/* invisible range input drives --pos (drag anywhere) */
#adc .adc-cmp__range{ position:absolute; inset:0; width:100%; height:100%; margin:0; z-index:5; cursor:ew-resize;
                      -webkit-appearance:none; appearance:none; background:transparent; }
#adc .adc-cmp__range:focus-visible{ outline:3px solid var(--adc-blue); outline-offset:3px; }
#adc .adc-cmp__range::-webkit-slider-runnable-track{ -webkit-appearance:none; background:transparent; border:none; }
#adc .adc-cmp__range::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:44px; height:44px; border-radius:50%; border:none; background:transparent; box-shadow:none; cursor:ew-resize; }
#adc .adc-cmp__range::-moz-range-thumb{ width:44px; height:44px; border:none; background:transparent; cursor:ew-resize; }
#adc .adc-cmp__range::-moz-range-track{ background:transparent; border:none; }

/* centered equipment label per pair */
#adc .adc-cmp__label{ position:absolute; top:14px; left:50%; transform:translateX(-50%); z-index:99;
                      display:inline-flex; align-items:center; max-width:60%; white-space:nowrap;
                      font-family:var(--adc-display); font-weight:800; font-size:12.5px; letter-spacing:.02em;
                      color:var(--adc-navy); background:rgba(255,255,255,.94); padding:6px 14px; border-radius:999px;
                      box-shadow:0 8px 20px rgba(8,26,68,.16); pointer-events:none; }

/* prev / next arrows */
#adc .adc-cmp__nav{ position:absolute; top:50%; transform:translateY(-50%); z-index:6; width:42px; height:42px; outline: none;
                    display:grid; place-items:center; border:none; border-radius:50%; cursor:pointer;
                    background:rgba(255,255,255,.92); color:var(--adc-navy); box-shadow:0 10px 24px rgba(8,26,68,.22);
                    transition:background .15s ease, transform .15s ease; }
#adc .adc-cmp__nav:hover{ background:#fff; transform:translateY(-50%) scale(1.06); color:var(--adc-blue); }
#adc .adc-cmp__nav:focus-visible{ outline:3px solid var(--adc-blue); outline-offset:2px; }
#adc .adc-cmp__nav svg{ width:20px; height:20px; }
#adc .adc-cmp__nav--prev{ left:14px; }
#adc .adc-cmp__nav--next{ right:14px; }

/* dots */
#adc .adc-cmp__dots{ position:absolute; left:50%; bottom:14px; transform:translateX(-50%); z-index:6;
                     display:flex; gap:8px; padding:7px 11px; border-radius:999px; background:rgba(8,26,68,.34);
                     backdrop-filter:blur(4px); }
#adc .adc-cmp__dot{ width:9px; height:9px; padding:0; border:none; border-radius:50%; cursor:pointer;
                    background:rgba(255,255,255,.5); transition:background .2s ease, transform .2s ease; }
#adc .adc-cmp__dot:hover{ background:rgba(255,255,255,.8); }
#adc .adc-cmp__dot.is-active{ background:#fff; transform:scale(1.25); }
#adc .adc-cmp__dot:focus-visible{ outline:2px solid #fff; outline-offset:2px; }

/* ---- bénéfices (4 cartes) ---- */
#adc .adc-cmp__feats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:34px; }
#adc .adc-cmp__feat{ display:flex; align-items:flex-start; gap:13px; background:#fff; border:1px solid var(--adc-line);
                     border-radius:16px; padding:18px; box-shadow:var(--adc-shadow); }
#adc .adc-cmp__feat-ic{ flex:none; width:42px; height:42px; border-radius:12px; display:grid; place-items:center;
                        background:rgba(34,116,165,.1); color:var(--adc-blue); }
#adc .adc-cmp__feat-ic svg{ width:22px; height:22px; }
#adc .adc-cmp__feat-tx strong{ display:block; font-family:var(--adc-display); font-size:15.5px; color:var(--adc-navy); margin-bottom:3px; }
#adc .adc-cmp__feat-tx small{ font-size:13px; color:var(--adc-navy-soft); line-height:1.4; }

/* ---- bandeau CTA ---- */
#adc .adc-cmp__cta{ display:flex; align-items:center; justify-content:center; gap:12px; text-align:center;
                    background:linear-gradient(120deg,var(--adc-blue),#1b7fc0); color:#fff; font-family:var(--adc-display);
                    font-weight:800; font-size:clamp(15px,2vw,19px); padding:22px 28px; border-radius:18px;
                    box-shadow:0 20px 44px -12px var(--adc-blue); transition:transform .15s ease, box-shadow .2s ease; }
#adc .adc-cmp__cta:hover{ transform:translateY(-2px); box-shadow:0 26px 50px -12px var(--adc-blue); }
#adc .adc-cmp__cta-ic{ font-size:20px; }

/* ============================ RESPONSIVE ============================ */
@media (max-width:900px){
    #adc .adc-cmp__feats{ grid-template-columns:repeat(2,1fr); gap:14px; }
    #adc .adc-cmp__carousel{ aspect-ratio:4/3; }
    #adc .adc-cmp__note{ max-width:48%; padding:8px 11px; }
    #adc .adc-cmp__note-tx small{ display:none; }
    #adc .adc-cmp__nav{ width:36px; height:36px; }
    #adc .adc-cmp__nav svg{ width:17px; height:17px; }
    /* nudge the arrows toward the edges to free the image view */
    #adc .adc-cmp__nav--prev{ left:8px; }
    #adc .adc-cmp__nav--next{ right:8px; }
}
@media (max-width:560px){
    #adc .adc-cmp{ padding-top:44px; }
    #adc .adc-cmp__feats{ grid-template-columns:1fr; }
    #adc .adc-cmp__carousel{ aspect-ratio:4/3; border-radius:16px; }
    #adc .adc-cmp__note{ max-width:none; left:10px !important; right:10px !important; bottom:52px; }
    #adc .adc-cmp__note--after{ display:none; }   /* keep one note on very small screens */
    #adc .adc-cmp__tag{ font-size:11px; padding:5px 9px; }
    #adc .adc-cmp__tag svg{ width:13px; height:13px; }
    /* drop the equipment label BELOW the AVANT/APRÈS tags so they never overlap */
    #adc .adc-cmp__label{ top:48px; font-size:11px; max-width:82%; padding:5px 11px; }
    #adc .adc-cmp__nav{ width:30px; height:30px; }
    #adc .adc-cmp__nav--prev{ left:4px; }
    #adc .adc-cmp__nav--next{ right:4px; }
    /* badge: flow as normal text (inline-flex squeezed it into broken columns) */
    #adc .adc-cmp__badge{ display:inline-block; font-size:13px; padding:9px 16px; line-height:1.5; text-align:center; }
    #adc .adc-cmp__badge svg{ display:inline-block; width:16px; height:16px; vertical-align:-3px; margin-right:5px; }
    #adc .adc-cmp__cta{ padding:18px 20px; }
}

/* =============================================================
   NOS PRESTATIONS (services) — cards + CTA
   ============================================================= */
#adc .adc-srv__head{ text-align:center; margin-bottom:42px; }
#adc .adc-srv__head h2{ font-size:clamp(26px,3.6vw,40px); margin-bottom:14px; }
#adc .adc-srv__rule{ display:block; width:60px; height:4px; border-radius:2px; background:var(--adc-blue); margin:0 auto 16px; }
#adc .adc-srv__head p{ font-size:17px; color:var(--adc-navy-soft); margin:0; }

#adc .adc-srv__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-bottom:38px; }
#adc .adc-srv__card{ background:#fff; border:1px solid var(--adc-line); border-radius:18px; overflow:hidden;
                     box-shadow:var(--adc-shadow); display:flex; flex-direction:column;
                     transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
#adc .adc-srv__card:hover{ transform:translateY(-5px); box-shadow:0 22px 50px rgba(8,26,68,.14); border-color:#cfdcf6; }
/* show the étape posters in FULL (no crop) — the card grows to the image's natural height */
#adc .adc-srv__media{ position:relative; background:linear-gradient(160deg,#f4f8ff,#e9f1ff); }
#adc .adc-srv__media picture{ display:block; }
#adc .adc-srv__media img{ width:100%; height:auto; display:block; }
#adc .adc-srv__spark{ position:absolute; top:12px; right:12px; width:34px; height:34px; border-radius:50%;
                      background:#fff; box-shadow:0 6px 16px rgba(8,26,68,.14); display:grid; place-items:center; color:var(--adc-blue); }
#adc .adc-srv__spark svg{ width:18px; height:18px; }
#adc .adc-srv__body{ padding:20px 20px 18px; display:flex; flex-direction:column; flex:1; }
#adc .adc-srv__title{ font-size:19px; margin:0 0 8px; }
#adc .adc-srv__desc{ font-size:14.5px; color:var(--adc-navy-soft); margin:0 0 18px; flex:1; }
#adc .adc-srv__foot{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
#adc .adc-srv__more{ display:inline-flex; align-items:center; gap:6px; color:var(--adc-blue); font-weight:700; font-size:14px; }
#adc .adc-srv__more svg{ width:16px; height:16px; transition:transform .15s ease; }
#adc .adc-srv__more:hover svg{ transform:translateX(3px); }
#adc .adc-srv__tag{ font-size:11px; font-weight:800; letter-spacing:.05em; color:var(--adc-navy-soft);
                    background:var(--adc-bg); border:1px solid var(--adc-line); padding:5px 10px; border-radius:999px; }

#adc .adc-srv__cta-wrap{ text-align:center; }
#adc .adc-srv__cta{ display:inline-flex; align-items:center; gap:10px; background:linear-gradient(120deg,var(--adc-blue),#1b7fc0);
                    color:#fff; font-weight:700; font-size:16px; padding:16px 32px; border-radius:999px;
                    box-shadow:0 18px 40px -12px var(--adc-blue); transition:transform .15s ease; }
#adc .adc-srv__cta:hover{ transform:translateY(-2px); }
#adc .adc-srv__cta svg{ width:18px; height:18px; }

@media (max-width:900px){
    #adc .adc-srv__grid{ grid-template-columns:repeat(2,1fr); gap:16px; }
}
@media (max-width:560px){
    #adc .adc-srv__grid{ grid-template-columns:1fr; }
    #adc .adc-srv__cta{ width:100%; justify-content:center; }
}
