/* ================================================
   STYLE.CSS — Combined styles for all main pages
   ================================================ */

/* === INDEX / HOMEPAGE === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
:root{
  --black:#0a0a0a;
  --dark:#1d1d1f;
  --mid:#515154;
  --soft:#86868b;
  --border:#d2d2d7;
  --bg:#f5f5f7;
  --white:#ffffff;
  --red:#cc0000;
  --red-soft:#fff0f0;
  --green:#1a7a4a;
  --blue:#0071e3;
  --max:1200px;
}
body{font-family:'Outfit',system-ui,-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;color:var(--dark);background:var(--white);line-height:1.5;overflow-x:hidden;font-size:17px}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(255,255,255,0.85);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(0,0,0,0.08);height:54px;display:flex;align-items:center;padding:0 2rem}
.nav-in{max-width:var(--max);margin:0 auto;width:100%;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none}
.nl-box{width:28px;height:28px;background:var(--black);border-radius:6px;display:flex;align-items:center;justify-content:center}
.nl-box svg{width:16px;height:16px}
.nl-name{font-weight:700;font-size:.95rem;color:var(--black);letter-spacing:-.01em}
.nav-links{display:flex;gap:1.8rem;align-items:center}
.nav-links a{font-size:.88rem;font-weight:500;color:#444;text-decoration:none;transition:color .15s}
.nav-links a:hover{color:#cc0000}
.nav-dropdown{position:relative}
.nav-dropdown-trigger{cursor:pointer}
.nav-dropdown-menu{display:none;position:absolute;top:100%;left:-12px;padding-top:8px;z-index:200}
.nav-dropdown:hover .nav-dropdown-menu{display:block !important;box-shadow:0 8px 24px rgba(0,0,0,.12);border-radius:8px;overflow:hidden}
.nav-dropdown-menu a{display:block;padding:8px 16px;font-size:.82rem;color:#444;white-space:nowrap;background:#fff;border-bottom:1px solid #f0f0f0;text-decoration:none;transition:background .1s}
.nav-dropdown-menu a:first-child{border-radius:8px 8px 0 0}
.nav-dropdown-menu a:last-child{border-radius:0 0 8px 8px;border-bottom:none}
.nav-dropdown-menu a:hover{background:#fef2f2;color:#cc0000}
.nav-r{display:flex;gap:.75rem;align-items:center}
.nav-tel{font-size:.85rem;color:#444;text-decoration:none;font-weight:500}
.nav-btn{background:#cc0000 !important;color:#ffffff !important;text-decoration:none;padding:12px 24px;border-radius:100px;font-size:.85rem;font-weight:700 !important;transition:all .2s;letter-spacing:-.01em;border:2px solid #cc0000 !important;box-shadow:0 4px 20px rgba(204,0,0,0.4)}
.nav-btn:hover{background:#ffffff !important;color:#cc0000 !important;border-color:#cc0000 !important;box-shadow:0 4px 20px rgba(0,0,0,0.15)}

/* HERO */
.hero{min-height:0;display:flex;align-items:center;padding:80px 2rem 60px;background:var(--white);overflow:hidden;position:relative}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--border)}
.hero-in{max-width:var(--max);margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;border-radius:980px;padding:.4rem 1rem;font-size:.95rem;font-weight:500;color:var(--green);background:#edfbf3;border:1px solid #b8e8cc;margin-bottom:1.5rem}
.hb-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(2.8rem,5vw,4.5rem);font-weight:800;line-height:1.05;color:var(--dark);letter-spacing:-.04em;margin-bottom:1.5rem}
.hero h1 strong{color:var(--red);font-weight:800}
.hero-p{font-size:1.25rem;color:var(--mid);line-height:1.6;max-width:480px;margin-bottom:2.5rem;font-weight:400}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.btn-dark{display:inline-flex;align-items:center;gap:.5rem;background:var(--dark);color:white;text-decoration:none;padding:1rem 2rem;border-radius:980px;font-size:1.05rem;font-weight:600;transition:all .2s;letter-spacing:-.01em}
.btn-dark:hover{background:var(--red);transform:scale(1.02)}
.btn-light{display:inline-flex;align-items:center;gap:.5rem;color:var(--blue);text-decoration:none;padding:1rem 2rem;border-radius:980px;font-size:1.05rem;font-weight:600;transition:all .2s;background:var(--bg)}
.btn-light:hover{background:#e8e8ed}
.hero-proof{display:flex;align-items:center;gap:1.2rem}
.stars-row{color:#f0a500;font-size:1.1rem;letter-spacing:.05em}
.proof-txt{font-size:1rem;color:var(--mid);font-weight:400}
.proof-txt b{color:var(--dark);font-weight:700}

/* HERO VISUAL */
.hero-vis{position:relative;display:flex;justify-content:center;align-items:center;height:520px}

/* Phone 3D */
.phone3d{width:200px;height:400px;background:linear-gradient(160deg,#2a2a2a,#111);border-radius:36px;position:absolute;left:50%;top:50%;transform:translate(-50%,-55%) rotate(-8deg);box-shadow:0 60px 100px rgba(0,0,0,.25),0 0 0 1.5px rgba(255,255,255,.08),inset 0 0 0 1px rgba(255,255,255,.05);z-index:2}
.phone3d-scr{position:absolute;inset:8px;background:#050a12;border-radius:29px;overflow:hidden;display:flex;flex-direction:column}
.phone3d-notch{width:90px;height:26px;background:#000;border-radius:0 0 16px 16px;margin:0 auto;flex-shrink:0}
.phone3d-body{flex:1;padding:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem}
.p3-check{width:64px;height:64px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center}
.p3-check svg{width:30px;height:30px}
.p3-label{font-size:10px;font-weight:700;color:white;text-align:center;letter-spacing:.02em}
.p3-sub{font-size:8px;color:rgba(255,255,255,.45);text-align:center}
.p3-card{background:rgba(255,255,255,.08);border-radius:10px;padding:.55rem .7rem;width:100%;margin-top:.3rem}
.p3-row{display:flex;justify-content:space-between;font-size:8px;color:rgba(255,255,255,.5);margin-bottom:.25rem}
.p3-row b{color:white;font-weight:700}
.p3-row.green b{color:#4cd964}

/* Phone 2 cassé */
.phone3d-b{width:170px;height:340px;background:linear-gradient(160deg,#3a1a1a,#1a0808);border-radius:30px;position:absolute;left:15%;top:50%;transform:translateY(-45%) rotate(10deg);box-shadow:0 40px 60px rgba(0,0,0,.2);z-index:1;opacity:.85}
.phone3d-b-scr{position:absolute;inset:7px;background:#1a0505;border-radius:24px;overflow:hidden}
.crack{position:absolute;inset:0}

/* Floating cards */
.fcard{position:absolute;background:white;border-radius:16px;padding:.9rem 1.2rem;box-shadow:0 12px 40px rgba(0,0,0,.12),0 0 0 1px rgba(0,0,0,.06);z-index:10}
.fc-top{animation:fc-float 4s ease-in-out infinite}
.fc-bot{animation:fc-float 4s ease-in-out infinite 2s}
@keyframes fc-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.fc-top{top:8%;right:2%}
.fc-bot{bottom:10%;left:2%}
.fc-label{font-size:.7rem;color:var(--soft);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem;font-weight:600}
.fc-val{font-size:1.05rem;font-weight:700;color:var(--dark)}
.fc-sub{font-size:.72rem;color:var(--soft);margin-top:.1rem}

/* STATS BAND */
.stats-band{background:var(--dark);padding:60px 2rem}
.stats-in{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat-item{text-align:center;padding:2rem 1rem;border-right:1px solid rgba(255,255,255,.08)}
.stat-item:last-child{border-right:none}
.stat-num{font-size:3.5rem;font-weight:800;color:white;display:block;line-height:1;letter-spacing:-.04em;margin-bottom:.4rem}
.stat-num span{color:var(--red);font-size:2rem}
.stat-lbl{font-size:1rem;color:rgba(255,255,255,.4);font-weight:400}

/* SECTION BASE */
.sec{padding:130px 2rem;content-visibility:auto;contain-intrinsic-size:auto 800px}
.sec-in{max-width:var(--max);margin:0 auto}
.sec-eyebrow{font-size:1rem;font-weight:600;color:var(--red);letter-spacing:.02em;margin-bottom:1rem;display:block}
.sec-h{font-size:clamp(2.2rem,4vw,3.2rem);font-weight:800;line-height:1.1;color:var(--dark);letter-spacing:-.03em;margin-bottom:1.2rem}
.sec-h strong{color:var(--red)}
.sec-p{font-size:1.2rem;color:var(--mid);font-weight:400;max-width:560px;line-height:1.6}

/* SERVICES APPLE STYLE */
.srv-wrap{margin-top:5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border-radius:24px;overflow:hidden;border:2px solid var(--border)}
.srv-card{background:white;padding:3rem 2.5rem;position:relative;transition:background .2s;overflow:hidden}
.srv-card:hover{background:#fafafa}
.srv-illo{width:100%;height:160px;margin-bottom:2rem;display:flex;align-items:center;justify-content:center}
.srv-tag{font-size:.82rem;font-weight:600;color:var(--red);letter-spacing:.04em;margin-bottom:.6rem;display:block}
.srv-h{font-size:1.4rem;font-weight:700;color:var(--dark);margin-bottom:.75rem;letter-spacing:-.02em}
.srv-p{font-size:1rem;color:var(--mid);line-height:1.65;margin-bottom:1.5rem;font-weight:400}
.srv-price{font-size:1.1rem;font-weight:700;color:var(--dark)}
.srv-price b{font-size:1.6rem;font-weight:800;letter-spacing:-.02em}
.srv-ul{list-style:none;margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.srv-li{font-size:.95rem;color:var(--mid);display:flex;align-items:center;gap:.6rem}
.srv-li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--red);flex-shrink:0}

/* PROCESS */
.proc-bg{background:var(--bg)}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3rem;margin-top:5rem}
.proc-step{text-align:center}
.proc-illo{width:120px;height:120px;margin:0 auto 2rem;border-radius:28px;display:flex;align-items:center;justify-content:center}
.proc-num{font-size:1.8rem;font-weight:800;color:var(--red);margin-bottom:.5rem;display:block}
.proc-h{font-size:1.1rem;font-weight:700;color:var(--dark);margin-bottom:.6rem}
.proc-p{font-size:.95rem;color:var(--mid);line-height:1.65}

/* ZONES */
.zones-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;margin-top:5rem}
.zone-list{display:flex;flex-direction:column;gap:.75rem}
.zone-row{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;background:var(--bg);border-radius:14px;text-decoration:none;transition:all .2s;border:2px solid transparent}
.zone-row:hover{border-color:var(--dark);background:white;transform:translateX(4px)}
.zr-l{display:flex;align-items:center;gap:.9rem}
.zr-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.zr-name{font-size:1.05rem;font-weight:600;color:var(--dark)}
.zr-sub{font-size:.85rem;color:var(--soft);margin-top:.1rem}
.zr-time{font-size:.85rem;font-weight:700;color:var(--red);background:var(--red-soft);padding:.25rem .75rem;border-radius:980px}
.map-wrap{border-radius:24px;overflow:hidden;background:var(--bg);border:2px solid var(--border)}

/* REVIEWS */
.revs-bg{background:var(--dark)}
.revs-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:4rem;flex-wrap:wrap;gap:2rem}
.rev-big{font-size:5rem;font-weight:800;color:white;line-height:1;letter-spacing:-.04em}
.rev-stars{color:#f0a500;font-size:1.3rem;letter-spacing:.08em;margin-bottom:.4rem}
.rev-cnt{font-size:1rem;color:rgba(255,255,255,.4)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(255,255,255,.08);border-radius:24px;overflow:hidden}
.rev-card{background:#1a1a1a;padding:2.2rem;transition:background .2s}
.rev-card:hover{background:#222}
.rc-head{display:flex;align-items:center;gap:.85rem;margin-bottom:1.3rem}
.rc-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;color:white;flex-shrink:0}
.rc-name{font-size:1rem;font-weight:700;color:white}
.rc-date{font-size:.82rem;color:rgba(255,255,255,.3);margin-top:.1rem}
.rc-stars{color:#f0a500;font-size:.85rem;margin-bottom:.9rem;letter-spacing:.05em}
.rc-txt{font-size:1rem;color:rgba(255,255,255,.6);line-height:1.7;font-style:italic}
.rc-badge{margin-top:1.1rem;font-size:.78rem;color:rgba(255,255,255,.25);display:flex;align-items:center;gap:.4rem}
.rc-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:#4285f4;flex-shrink:0}

/* PRICING */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:5rem}
.pc{background:white;border:2px solid var(--border);border-radius:22px;padding:2.8rem 2.2rem;transition:all .25s;position:relative}
.pc:hover{transform:translateY(-4px);box-shadow:0 24px 60px rgba(0,0,0,.08);border-color:var(--dark)}
.pc.feat{background:var(--dark);border-color:var(--dark)}
.feat-pill{display:inline-block;background:var(--red);color:white;font-size:.75rem;font-weight:700;padding:.22rem .75rem;border-radius:980px;margin-bottom:1.2rem;letter-spacing:.03em}
.pc-type{font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);margin-bottom:.75rem;display:block}
.pc.feat .pc-type{color:rgba(255,255,255,.4)}
.pc-name{font-size:1.5rem;font-weight:800;color:var(--dark);margin-bottom:1.5rem;letter-spacing:-.02em}
.pc.feat .pc-name{color:white}
.pc-price{font-size:3.2rem;font-weight:800;color:var(--dark);line-height:1;letter-spacing:-.04em}
.pc.feat .pc-price{color:white}
.pc-unit{font-size:1rem;color:var(--soft);font-weight:400}
.pc.feat .pc-unit{color:rgba(255,255,255,.4)}
.pc-desc{font-size:.95rem;color:var(--mid);margin:1.2rem 0 1.5rem;line-height:1.6}
.pc.feat .pc-desc{color:rgba(255,255,255,.45)}
.pc-div{height:1px;background:var(--border);margin-bottom:1.5rem}
.pc.feat .pc-div{background:rgba(255,255,255,.1)}
.pc-ul{list-style:none;display:flex;flex-direction:column;gap:.65rem;margin-bottom:2rem}
.pc-li{font-size:.95rem;color:var(--mid);display:flex;align-items:center;gap:.6rem}
.pc.feat .pc-li{color:rgba(255,255,255,.5)}
.pc-li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0}
.pc.feat .pc-li::before{color:#4cd964}
.pc-a{display:flex;align-items:center;justify-content:center;padding:1rem;border-radius:14px;font-size:1rem;font-weight:700;text-decoration:none;transition:all .2s;letter-spacing:-.01em}
.pc-a-dark{background:var(--dark);color:white}
.pc-a-dark:hover{background:var(--red)}
.pc.feat .pc-a-dark{background:white;color:var(--dark)}
.pc.feat .pc-a-dark:hover{background:var(--red);color:white}
.pc-a-out{border:2px solid var(--border);color:var(--dark)}
.pc-a-out:hover{border-color:var(--dark);background:var(--bg)}

/* FAQ */
.faq-bg{background:var(--bg)}
.faq-wrap{max-width:800px;margin:4rem 0 0;display:flex;flex-direction:column;gap:.75rem}
.faq-it{background:white;border-radius:14px;overflow:hidden;border:2px solid transparent;transition:border-color .2s}
.faq-it.open{border-color:var(--dark)}
.faq-q{padding:1.5rem 1.8rem;font-size:1.05rem;font-weight:600;color:var(--dark);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;user-select:none}
.faq-ico{width:26px;height:26px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.9rem;color:var(--dark);transition:all .3s;font-weight:700}
.faq-it.open .faq-ico{background:var(--dark);color:white;transform:rotate(45deg)}
.faq-a{display:none;padding:.25rem 1.8rem 1.5rem;font-size:1rem;color:var(--mid);line-height:1.75;border-top:1px solid var(--border);padding-top:1rem}
.faq-it.open .faq-a{display:block}

/* CTA SECTION */
.cta-sec{padding:130px 2rem}
.cta-box{max-width:var(--max);margin:0 auto;background:var(--dark);border-radius:30px;padding:100px 80px;text-align:center;position:relative;overflow:hidden}
.cta-box::before{content:'';position:absolute;top:-150px;right:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(204,0,0,.15) 0%,transparent 65%)}
.cta-box::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(0,113,227,.08) 0%,transparent 65%)}
.cta-eyebrow{font-size:.95rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1.2rem;display:block}
.cta-h{font-size:clamp(2.2rem,4vw,3.5rem);font-weight:800;color:white;line-height:1.05;letter-spacing:-.04em;margin-bottom:1rem}
.cta-h strong{color:var(--red)}
.cta-p{font-size:1.2rem;color:rgba(255,255,255,.45);margin-bottom:3rem;max-width:520px;margin-left:auto;margin-right:auto;line-height:1.6}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.cta-w{background:white;color:var(--dark);text-decoration:none;padding:1.1rem 2.2rem;border-radius:980px;font-size:1.05rem;font-weight:700;transition:all .2s;letter-spacing:-.01em}
.cta-w:hover{background:var(--red);color:white;transform:scale(1.03)}
.cta-t{border:1.5px solid rgba(255,255,255,.2);color:rgba(255,255,255,.7);text-decoration:none;padding:1.1rem 2.2rem;border-radius:980px;font-size:1.05rem;font-weight:600;transition:all .2s}
.cta-t:hover{border-color:rgba(255,255,255,.5);color:white}
.cta-num{font-size:2rem;font-weight:800;color:rgba(255,255,255,.4);margin-top:2.5rem;position:relative;z-index:1;letter-spacing:-.02em}
.cta-num a{color:rgba(255,255,255,.4);text-decoration:none;transition:color .2s}
.cta-num a:hover{color:white}

/* FOOTER */
footer{background:#080808;padding:50px 2rem 30px}
.ft-in{max-width:var(--max);margin:0 auto}
.ft-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:5rem;margin-bottom:4rem}
.ft-logo{font-size:1.1rem;font-weight:800;color:white;letter-spacing:-.01em;display:block;margin-bottom:.8rem}
.ft-desc{font-size:.95rem;color:rgba(255,255,255,.55);line-height:1.7;max-width:260px}
.ft-addr{margin-top:1.5rem;font-size:.9rem;color:rgba(255,255,255,.5);line-height:1.9}
.ft-addr a{color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s}
.ft-addr a:hover{color:white}
.ft-col-h{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:1.2rem;display:block}
.ft-lnks{display:flex;flex-direction:column;gap:.6rem}
.ft-lnks a{font-size:.9rem;color:rgba(255,255,255,.7) !important;text-decoration:none;transition:color .2s}
.ft-lnks a:hover{color:#cc0000 !important}
.ft-bot{border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.ft-copy{font-size:13px;color:rgba(255,255,255,.45)}
.ft-copy a{color:rgba(255,255,255,.5) !important;text-decoration:none}
.ft-copy a:hover{color:#cc0000 !important}
.ft-rate{font-size:.85rem;color:rgba(255,255,255,.5)}
.seo-bar{background:#060606;padding:1.5rem 2rem;border-top:1px solid rgba(255,255,255,.04)}
.seo-bar-in{max-width:var(--max);margin:0 auto;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.seo-a{font-size:.78rem;color:rgba(255,255,255,.18);text-decoration:none;transition:color .15s}
.seo-a:hover{color:rgba(255,255,255,.5)}
.seo-sep{color:rgba(255,255,255,.08);font-size:.78rem}

/* CALL FIXED */
.call-btn{position:fixed;bottom:2rem;right:2rem;background:var(--dark);color:white;text-decoration:none;padding:.9rem 1.6rem;border-radius:980px;font-size:.9rem;font-weight:700;display:flex;align-items:center;gap:.5rem;z-index:99;box-shadow:0 8px 30px rgba(0,0,0,.22);transition:all .2s;letter-spacing:-.01em}
.call-btn:hover{background:var(--red);transform:translateY(-2px);box-shadow:0 12px 40px rgba(204,0,0,.3)}

/* ANIMATIONS */
.fade{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.fade.in{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero-in,.zones-grid{grid-template-columns:1fr;gap:3rem}
  .hero-vis{display:none}
  .stats-in{grid-template-columns:repeat(2,1fr)}
  .srv-wrap,.rev-grid,.price-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:repeat(2,1fr)}
  .ft-top{grid-template-columns:1fr 1fr;gap:2.5rem}
  .cta-box{padding:60px 40px}
}
@media(max-width:640px){
  .nav-links{display:none}
  body{font-size:16px}
  .sec{padding:90px 1.5rem}
  .stats-in{grid-template-columns:repeat(2,1fr)}
  .stat-num{font-size:2.6rem}
  .ft-top{grid-template-columns:1fr}
  .cta-box{padding:50px 24px}
  .hero{padding:80px 1.5rem 50px}
  .proc-grid{grid-template-columns:1fr}
}

/* === REPARATION CITY PAGES (reparation-cannes, nice, antibes, etc.) === */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'DM Sans',sans-serif;color:#1a1a1a;line-height:1.6}
.hero{background:#111;color:white;padding:3rem 2rem;text-align:center}
.hero h1{font-family:'Fraunces',serif;font-size:2.4rem;font-weight:900;margin-bottom:1rem;color:white}
.hero h1 span{color:#cc0000}
.hero p{font-size:1.1rem;color:rgba(255,255,255,.8);max-width:600px;margin:0 auto 2rem}
.btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-red{background:#cc0000;color:white;padding:1rem 2rem;border-radius:100px;text-decoration:none;font-weight:700;font-size:1rem}
.btn-white{background:white;color:#cc0000;padding:1rem 2rem;border-radius:100px;text-decoration:none;font-weight:700;font-size:1rem}
.section{padding:3rem 2rem;max-width:900px;margin:0 auto}
.section h2{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:900;margin-bottom:1.5rem;color:#111}
.section h2 span{color:#cc0000}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}
.card{background:#f7f7f7;border-radius:16px;padding:1.5rem;text-align:center}
.card h3{font-size:1.1rem;font-weight:700;margin-bottom:.5rem}
.card p{font-size:.9rem;color:#666}
.card .price{font-size:1.5rem;font-weight:900;color:#cc0000;margin:.5rem 0}
.faq{background:#f7f7f7;border-radius:16px;padding:1.5rem;margin-bottom:1rem}
.faq h3{font-weight:700;margin-bottom:.5rem}
.faq p{font-size:.9rem;color:#555}
.cta{background:#cc0000;color:white;padding:3rem 2rem;text-align:center}
.cta h2{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:900;margin-bottom:1rem}
.cta .num{font-size:2rem;font-weight:900;margin:1rem 0}
.stars{color:#ffcc00;font-size:1.2rem;margin:.5rem 0}
footer{background:#111;color:#888;padding:2rem;text-align:center;font-size:.85rem}
footer a{color:#cc0000;text-decoration:none}
@media(max-width:600px){.grid{grid-template-columns:1fr}.hero h1{font-size:1.8rem}}

/* === REPARATION DEVICE PAGES (iphone-cannes, samsung-cannes, depannage) === */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'DM Sans',sans-serif;color:#1a1a1a;line-height:1.7}
.hero{background:#111;color:white;padding:4rem 2rem;text-align:center}
.hero h1{font-family:'Fraunces',serif;font-size:2.6rem;font-weight:900;margin-bottom:1rem}
.hero h1 span{color:#555}
.hero p{font-size:1.1rem;color:rgba(255,255,255,.8);max-width:650px;margin:0 auto 2rem}
.stars{color:#ffcc00;font-size:1.3rem;margin-bottom:1.5rem}
.btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-r{background:#cc0000;color:white;padding:1rem 2rem;border-radius:100px;text-decoration:none;font-weight:700;font-size:1rem}
.btn-w{background:white;color:#cc0000;padding:1rem 2rem;border-radius:100px;text-decoration:none;font-weight:700;font-size:1rem}
.section{max-width:900px;margin:0 auto;padding:3rem 2rem}
.section h2{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:900;margin-bottom:1.5rem;color:#111}
.section h2 span{color:#cc0000}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:2rem}
.card{background:#f7f7f7;border-radius:14px;padding:1.4rem;text-align:center}
.card .icon{font-size:2.2rem;margin-bottom:.6rem}
.card h3{font-size:1rem;font-weight:700;margin-bottom:.4rem}
.card .price{font-size:1.4rem;font-weight:900;color:#cc0000;margin:.4rem 0}
.card p{font-size:.85rem;color:#666}
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:2rem 0}
.step{text-align:center;padding:1rem}
.step-num{width:44px;height:44px;border-radius:50%;background:#cc0000;color:white;font-size:1.2rem;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem}
.step h3{font-size:.9rem;font-weight:700;margin-bottom:.3rem}
.step p{font-size:.82rem;color:#666}
.faq-item{background:#f7f7f7;border-radius:12px;padding:1.2rem;margin-bottom:.85rem}
.faq-item h3{font-weight:700;margin-bottom:.5rem;color:#111}
.faq-item p{font-size:.9rem;color:#555}
.cta{background:#cc0000;padding:3.5rem 2rem;text-align:center}
.cta h2{font-family:'Fraunces',serif;font-size:2rem;font-weight:900;color:white;margin-bottom:.75rem}
.cta p{color:rgba(255,255,255,.85);margin-bottom:1.5rem}
.cta .num{font-size:2.2rem;font-weight:900;color:white;margin:1rem 0}
.zones{background:#f7f7f7;padding:2rem;text-align:center}
.zones-title{font-size:.8rem;color:#888;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:1rem}
.zones-links{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.zones-links a{background:white;border:1px solid #e5e5e5;border-radius:100px;padding:.3rem .85rem;font-size:.8rem;color:#cc0000;text-decoration:none;font-weight:600}
footer{background:#111;color:#888;padding:2rem;text-align:center;font-size:.85rem}
footer a{color:#cc0000;text-decoration:none}
@media(max-width:600px){.grid3,.process{grid-template-columns:1fr}.hero h1{font-size:1.9rem}}

/* === RESERVATION PAGE === */
:root{
  --red:#cc0000;--red2:#e63333;--rl:#fff0f0;--rm:#ffd0d0;
  --dark:#111;--text:#1a1a1a;--mu:#666;--border:#e5e5e5;
  --bg:#f7f7f7;--white:#fff;--gn:#1a7a4a;--gl:#e8f5ee;
  --r:14px;--rs:10px;
  --sh:0 4px 20px rgba(0,0,0,.08);--shl:0 16px 48px rgba(0,0,0,.12);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-size:15px;line-height:1.6;overflow-x:hidden}

/* HEADER */
.hdr{background:var(--dark);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.hdr-logo{display:flex;align-items:center;gap:.65rem;text-decoration:none}
.hdr-icon{width:38px;height:38px;background:var(--red);border-radius:10px;display:flex;align-items:center;justify-content:center}
.hdr-name{font-family:'Fraunces',serif;font-weight:900;font-size:1.1rem;color:white;letter-spacing:.04em}
.hdr-sub{font-size:.65rem;color:rgba(255,255,255,.55)}
.hdr-phone{display:flex;align-items:center;gap:.45rem;background:var(--red);color:white;text-decoration:none;padding:.55rem 1.1rem;border-radius:100px;font-weight:700;font-size:.83rem;transition:all .2s}
.hdr-phone:hover{background:#aa0000}

/* HERO RESERVATION */
.res-hero{background:var(--white);border-bottom:1px solid var(--border);padding:2.5rem 2rem}
.res-hero-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.res-hero h1{font-family:'Fraunces',serif;font-weight:900;font-size:2rem;letter-spacing:-.03em;color:var(--dark);margin-bottom:.4rem}
.res-hero p{font-size:.9rem;color:var(--mu);max-width:460px}
.acompte-badge{background:var(--red);color:white;border-radius:12px;padding:1rem 1.4rem;text-align:center;min-width:180px}
.ab-amount{font-family:'Fraunces',serif;font-size:2.5rem;font-weight:900;display:block;line-height:1}
.ab-label{font-size:.75rem;opacity:.85;display:block;margin-top:.2rem}
.ab-sub{font-size:.68rem;opacity:.65;margin-top:.15rem;display:block}

/* STEPS INDICATOR */
.steps-bar{background:var(--white);border-bottom:1px solid var(--border);padding:.85rem 2rem}
.steps-bar-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:0}
.step-ind{display:flex;align-items:center;gap:.5rem;flex:1}
.step-circle{width:28px;height:28px;border-radius:50%;background:var(--border);color:var(--mu);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;transition:all .3s}
.step-circle.active{background:var(--red);color:white}
.step-circle.done{background:var(--gn);color:white}
.step-label{font-size:.75rem;color:var(--mu);font-weight:500;transition:color .3s}
.step-label.active{color:var(--red);font-weight:700}
.step-label.done{color:var(--gn)}
.step-line{flex:1;height:2px;background:var(--border);margin:0 .5rem;transition:background .3s}
.step-line.done{background:var(--gn)}

/* MAIN */
.main{max-width:900px;margin:2rem auto;padding:0 2rem 6rem}

/* SECTION BOOKING */
.bsec{background:var(--white);border:1px solid var(--border);border-radius:var(--r);margin-bottom:1.5rem;overflow:hidden}
.bsec-head{padding:1.1rem 1.4rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}
.bsec-num{width:28px;height:28px;border-radius:50%;background:var(--red);color:white;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;flex-shrink:0}
.bsec-title{font-family:'Fraunces',serif;font-weight:700;font-size:.95rem;color:var(--dark)}
.bsec-body{padding:1.4rem}

/* SERVICES SELECTION */
.services-list{display:grid;gap:.75rem}
.svc-opt{border:2px solid var(--border);border-radius:var(--rs);padding:1.1rem 1.3rem;cursor:pointer;transition:all .2s;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem}
.svc-opt:hover{border-color:var(--red);background:var(--rl)}
.svc-opt.selected{border-color:var(--red);background:var(--rl)}
.svc-opt input[type="radio"]{display:none}
.svc-radio{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.svc-opt.selected .svc-radio{border-color:var(--red);background:var(--red)}
.svc-opt.selected .svc-radio::after{content:'';width:8px;height:8px;border-radius:50%;background:white}
.svc-info{}
.svc-name{font-weight:600;font-size:.9rem;color:var(--dark);display:block;margin-bottom:.18rem}
.svc-desc{font-size:.78rem;color:var(--mu)}
.svc-price-tag{text-align:right;white-space:nowrap}
.svc-price-main{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:900;color:var(--red);display:block;line-height:1}
.svc-price-sub{font-size:.68rem;color:var(--mu)}
.svc-duration{display:inline-flex;align-items:center;gap:.3rem;background:var(--bg);border-radius:100px;padding:.15rem .5rem;font-size:.68rem;color:var(--mu);margin-top:.3rem}

/* ZONE SELECTION */
.zones-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem}
.zone-opt{border:2px solid var(--border);border-radius:var(--rs);padding:.9rem 1rem;cursor:pointer;transition:all .2s;text-align:center}
.zone-opt:hover{border-color:var(--red);background:var(--rl)}
.zone-opt.selected{border-color:var(--red);background:var(--rl)}
.zone-opt input{display:none}
.zone-name{font-weight:600;font-size:.85rem;color:var(--dark);display:block;margin-bottom:.15rem}
.zone-time{font-size:.72rem;color:var(--mu)}
.zone-extra{font-size:.7rem;color:var(--red);font-weight:600;margin-top:.2rem;display:block}

/* CALENDRIER */
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.cal-nav h3{font-family:'Fraunces',serif;font-weight:700;font-size:1rem;color:var(--dark);text-transform:capitalize}
.cal-btn{background:var(--bg);border:1px solid var(--border);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:all .2s;color:var(--dark)}
.cal-btn:hover{background:var(--red);color:white;border-color:var(--red)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-header-day{text-align:center;font-size:.7rem;font-weight:700;color:var(--mu);padding:.4rem 0;text-transform:uppercase}
.cal-day{text-align:center;padding:.55rem .2rem;border-radius:8px;cursor:pointer;font-size:.85rem;transition:all .2s;border:1.5px solid transparent;position:relative}
.cal-day:hover:not(.disabled):not(.empty){background:var(--rl);border-color:var(--rm)}
.cal-day.today{font-weight:700;color:var(--red)}
.cal-day.selected{background:var(--red);color:white;border-color:var(--red);font-weight:700}
.cal-day.disabled{color:var(--border);cursor:default}
.cal-day.empty{cursor:default}
.cal-day.has-slots::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--gn)}
.cal-day.selected.has-slots::after{background:rgba(255,255,255,.7)}

/* CRÉNEAUX HORAIRES */
.slots-title{font-size:.82rem;font-weight:600;color:var(--dark);margin-bottom:.75rem}
.slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}
.slot{border:1.5px solid var(--border);border-radius:8px;padding:.6rem .4rem;text-align:center;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s;color:var(--text)}
.slot:hover:not(.slot-full){border-color:var(--red);color:var(--red);background:var(--rl)}
.slot.selected{background:var(--red);color:white;border-color:var(--red)}
.slot.slot-full{background:var(--bg);color:var(--border);cursor:default;text-decoration:line-through}
.slot-tag{font-size:.6rem;display:block;margin-top:.1rem;opacity:.7}
.no-slots{text-align:center;padding:1.5rem;color:var(--mu);font-size:.85rem}

/* FORMULAIRE */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.38rem}
.form-group.full{grid-column:1/-1}
.form-label{font-size:.78rem;font-weight:600;color:var(--dark)}
.form-label span{color:var(--red)}
.form-input{padding:.75rem 1rem;border:1.5px solid var(--border);border-radius:var(--rs);font-family:'DM Sans',sans-serif;font-size:.88rem;color:var(--text);transition:border-color .2s;background:var(--white)}
.form-input:focus{outline:none;border-color:var(--red)}
.form-input::placeholder{color:#bbb}
select.form-input{cursor:pointer}
textarea.form-input{resize:vertical;min-height:90px}

/* RÉCAP PAIEMENT */
.recap{background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);padding:1.2rem;margin-bottom:1.2rem}
.recap-title{font-weight:700;font-size:.85rem;color:var(--dark);margin-bottom:.85rem}
.recap-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;padding:.35rem 0;border-bottom:1px solid var(--border)}
.recap-row:last-child{border-bottom:none}
.recap-row.total{font-weight:700;font-size:.95rem;color:var(--dark);margin-top:.25rem}
.recap-row.acompte{color:var(--red);font-weight:700}
.recap-row.reste{color:var(--gn);font-weight:600}
.recap-val{font-family:'Fraunces',serif;font-weight:700}

/* ALERTE PAIEMENT */
.pay-info{background:var(--rl);border:1px solid var(--rm);border-radius:var(--rs);padding:1rem 1.2rem;margin-bottom:1.2rem;font-size:.82rem;line-height:1.6;color:#8b0000}
.pay-info strong{color:var(--red)}

/* MODES PAIEMENT */
.pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;margin-bottom:1.2rem}
.pay-method{border:2px solid var(--border);border-radius:var(--rs);padding:.9rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.65rem}
.pay-method:hover{border-color:var(--red);background:var(--rl)}
.pay-method.selected{border-color:var(--red);background:var(--rl)}
.pay-method input{display:none}
.pay-method-icon{font-size:1.4rem;flex-shrink:0}
.pay-method-name{font-weight:600;font-size:.83rem;color:var(--dark)}
.pay-method-sub{font-size:.7rem;color:var(--mu)}

/* CARD FORM */
.card-form{background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);padding:1.2rem;margin-bottom:1rem}
.card-form-title{font-size:.78rem;font-weight:600;color:var(--dark);margin-bottom:.85rem;display:flex;align-items:center;gap:.5rem}
.card-icons{display:flex;gap:.4rem;margin-left:auto}
.card-icon{background:white;border:1px solid var(--border);border-radius:5px;padding:.2rem .45rem;font-size:.7rem;font-weight:700;color:var(--mu)}
.card-icon.visa{color:#1a1f8e}
.card-icon.mc{color:#eb001b}

.card-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.card-input-wrap{position:relative}
.card-input{width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:var(--rs);font-family:'DM Sans',sans-serif;font-size:.88rem;color:var(--text);transition:border-color .2s;background:white}
.card-input:focus{outline:none;border-color:var(--red)}
.card-input::placeholder{color:#bbb}

/* BOUTONS */
.btn-next{width:100%;background:var(--red);color:white;border:none;border-radius:var(--rs);padding:1rem;font-family:'DM Sans',sans-serif;font-weight:700;font-size:.97rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}
.btn-next:hover{background:#aa0000;transform:translateY(-1px);box-shadow:0 4px 16px rgba(204,0,0,.3)}
.btn-next:disabled{background:var(--border);color:var(--mu);cursor:default;transform:none;box-shadow:none}
.btn-back{background:var(--bg);color:var(--mu);border:1.5px solid var(--border);border-radius:var(--rs);padding:.75rem 1.4rem;font-family:'DM Sans',sans-serif;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s}
.btn-back:hover{border-color:var(--red);color:var(--red)}
.btns-row{display:flex;gap:.75rem;align-items:center;margin-top:.5rem}
.btns-row .btn-next{flex:1}

/* SECURITE */
.secure-badges{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:.85rem;flex-wrap:wrap}
.secure-badge{display:flex;align-items:center;gap:.35rem;font-size:.7rem;color:var(--mu)}
.secure-icon{font-size:.9rem}

/* PANNEAU CONFIRMATION */
.confirm-panel{text-align:center;padding:3rem 2rem}
.confirm-icon{font-size:4rem;margin-bottom:1rem;display:block;animation:pop .4s ease-out}
@keyframes pop{from{transform:scale(0)}to{transform:scale(1)}}
.confirm-title{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:900;color:var(--dark);margin-bottom:.5rem}
.confirm-sub{font-size:.9rem;color:var(--mu);margin-bottom:2rem;line-height:1.6}
.confirm-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;text-align:left;margin-bottom:1.5rem;max-width:480px;margin-left:auto;margin-right:auto}
.confirm-row{display:flex;justify-content:space-between;align-items:flex-start;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.85rem}
.confirm-row:last-child{border-bottom:none}
.confirm-row-label{color:var(--mu);flex-shrink:0;margin-right:1rem}
.confirm-row-val{font-weight:600;color:var(--dark);text-align:right}
.confirm-acompte{background:var(--gl);border:1px solid #b3dcc4;border-radius:var(--rs);padding:1rem;text-align:center;max-width:480px;margin:0 auto 1.5rem}
.ca-amount{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:900;color:var(--gn);display:block}
.ca-label{font-size:.8rem;color:var(--gn);font-weight:600}
.ca-sub{font-size:.72rem;color:var(--mu);margin-top:.2rem}
.confirm-reste{background:var(--rl);border:1px solid var(--rm);border-radius:var(--rs);padding:.9rem;text-align:center;max-width:480px;margin:0 auto 1.5rem;font-size:.82rem;color:#8b0000;line-height:1.5}

/* ERREUR */
.field-error{font-size:.72rem;color:var(--red);margin-top:.2rem}
.input-error{border-color:var(--red)!important}

/* PROGRESS */
.progress-bar{height:4px;background:var(--border);border-radius:100px;overflow:hidden;margin-bottom:0}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--red),var(--red2));border-radius:100px;transition:width .4s ease}

/* NOTICE ANNULATION */
.notice-annul{background:#fffbe6;border:1px solid #f5e166;border-radius:var(--rs);padding:.85rem 1.1rem;font-size:.78rem;color:#7a6a00;line-height:1.55;margin-top:.85rem}
.notice-annul strong{color:#5a5000}

@media(max-width:640px){
  .zones-grid{grid-template-columns:1fr 1fr}
  .slots-grid{grid-template-columns:repeat(3,1fr)}
  .form-grid{grid-template-columns:1fr}
  .pay-methods{grid-template-columns:1fr}
  .card-row{grid-template-columns:1fr}
  .res-hero-inner{flex-direction:column}
  .main{padding:0 1rem 6rem}
  .res-hero{padding:1.5rem 1rem}
  .steps-bar{padding:.75rem 1rem}
  .step-label{display:none}
}

/* === LEGAL PAGES (mentions-legales, politique-confidentialite, cgv, cookies) === */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Outfit',system-ui,sans-serif;color:#1d1d1f;background:#fff;font-size:16px;line-height:1.7}
.nav{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between}
.nav a{text-decoration:none;color:#0a0a0a;font-weight:700}
.nav-back{font-size:.85rem;color:#515154;font-weight:500}
.wrap{max-width:800px;margin:0 auto;padding:3rem 2rem 5rem}
h1{font-size:2rem;font-weight:800;color:#0a0a0a;letter-spacing:-.02em;margin-bottom:.5rem}
.subtitle{font-size:.95rem;color:#86868b;margin-bottom:3rem}
h2{font-size:1.15rem;font-weight:700;color:#0a0a0a;margin:2.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:2px solid #f0f0f0}
h3{font-size:1rem;font-weight:700;color:#0a0a0a;margin:1.5rem 0 .5rem}
p{color:#515154;margin-bottom:.9rem;font-size:.95rem}
table{width:100%;border-collapse:collapse;margin:1rem 0 1.5rem}
th{background:#f5f5f7;padding:.65rem 1rem;text-align:left;font-size:.82rem;font-weight:700;color:#515154;border:1px solid #e0e0e0}
td{padding:.65rem 1rem;font-size:.88rem;color:#515154;border:1px solid #e0e0e0}
.info-box{background:#f5f5f7;border-radius:12px;padding:1.2rem 1.5rem;margin:1rem 0;font-size:.9rem;color:#515154}
.info-box strong{color:#0a0a0a;display:block;margin-bottom:.4rem;font-size:.95rem}
a{color:#0071e3;text-decoration:none}
a:hover{text-decoration:underline}
footer{background:#0a0a0a;padding:2rem;text-align:center;font-size:.82rem;color:rgba(255,255,255,.35)}
footer a{color:rgba(255,255,255,.4);text-decoration:none}

/* Additional legal page styles */
ul{color:#515154;margin:.5rem 0 1rem 1.5rem;font-size:.95rem}
ul li{margin-bottom:.4rem}
.highlight{background:#edfbf3;border-left:3px solid #1a7a4a;padding:.85rem 1.2rem;border-radius:0 10px 10px 0;margin:1rem 0;font-size:.92rem;color:#1d1d1f}
.warning{background:#fff8e0;border-left:3px solid #f0a500;padding:.85rem 1.2rem;border-radius:0 10px 10px 0;margin:1rem 0;font-size:.92rem;color:#1d1d1f}
.droit-badge{display:inline-block;background:#e8f5ff;color:#0071e3;font-size:.78rem;font-weight:700;padding:.2rem .65rem;border-radius:980px;margin:.2rem .2rem .2rem 0}
.pref-btn{background:#0a0a0a;color:white;border:none;padding:.75rem 1.8rem;border-radius:980px;font-size:.95rem;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif;transition:background .2s;margin-right:.75rem}
.pref-btn:hover{background:#cc0000}
.pref-btn.outline{background:transparent;color:#0a0a0a;border:2px solid #d2d2d7}
.pref-btn.outline:hover{border-color:#0a0a0a;background:#f5f5f7}

/* ═══ STICKY MOBILE CONTACT BAR ═══ */
.sticky-contact-bar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 998;
  background: #1a1a1a;
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: 8px 4px;
  padding-bottom: max(8px, env(safe-area-inset-bottom));
}

@media (max-width: 768px) {
  .sticky-contact-bar { display: flex; justify-content: space-around; }
  /* Push WhatsApp button above the bar */
  body > a[href*="wa.me"] { bottom: 80px !important; }
}

.sticky-contact-bar a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  text-decoration: none;
  color: white;
  font-size: 10px;
  font-weight: 600;
  font-family: 'DM Sans', sans-serif;
  padding: 4px 8px;
  border-radius: 8px;
  transition: background 0.2s;
}

.sticky-contact-bar a:hover { background: rgba(255,255,255,0.1); }

.sticky-contact-bar a span.sticky-icon { font-size: 20px; }

.sticky-contact-bar a.sticky-reserve {
  background: #cc0000;
  border-radius: 20px;
  padding: 6px 14px;
}

/* ═══ WHATSAPP PROACTIVE POPUP ═══ */
.wa-popup {
  display: none;
  position: fixed;
  bottom: 90px;
  right: 1.5rem;
  z-index: 997;
  background: white;
  border-radius: 16px;
  padding: 16px 20px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.15);
  max-width: 300px;
  font-family: 'DM Sans', sans-serif;
  animation: waPopIn 0.3s ease-out;
}

.wa-popup.show { display: block; }

.wa-popup-close {
  position: absolute;
  top: 8px;
  right: 12px;
  background: none;
  border: none;
  font-size: 18px;
  cursor: pointer;
  color: #999;
}

.wa-popup p {
  color: #1a1a1a;
  font-size: 14px;
  margin: 0 0 12px;
  line-height: 1.5;
}

.wa-popup a {
  display: inline-block;
  background: #25D366;
  color: white;
  text-decoration: none;
  padding: 10px 20px;
  border-radius: 100px;
  font-weight: 700;
  font-size: 14px;
}

@keyframes waPopIn {
  from { transform: translateY(20px) scale(0.95); opacity: 0; }
  to { transform: translateY(0) scale(1); opacity: 1; }
}

/* ═══ TRUST BADGE ═══ */
.trust-badge-bar {
  background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 100%);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  padding: 10px 20px;
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  color: #ffffff;
  font-weight: 600;
}

.trust-badge-bar span {
  white-space: nowrap;
  color: #ffffff !important;
  background: rgba(255,255,255,0.15) !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 5px 14px;
  border-radius: 100px;
  font-weight: 600;
}

/* ═══ HERO PHONE ANIMATION ═══ */
.anim-phone-wrap {
  position: relative;
  width: 280px;
  height: 560px;
  margin: 0 auto;
}
.anim-iphone {
  position: relative;
  width: 240px;
  height: 500px;
  background: #111;
  border: 3px solid #444;
  border-radius: 44px;
  margin: 30px auto;
  overflow: hidden;
  box-shadow:
    0 50px 100px rgba(0,0,0,0.7),
    0 0 0 1px #333,
    0 0 40px rgba(204,0,0,0.2);
  will-change: transform;
}
.anim-notch {
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 80px; height: 20px;
  background: #000;
  border-radius: 0 0 12px 12px;
  z-index: 10;
}
.anim-screen {
  position: absolute;
  top: 8px; left: 8px; right: 8px; bottom: 8px;
  border-radius: 32px;
  overflow: hidden;
  background: #0a0a0a;
}

/* Scenes */
.anim-scene {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px;
  opacity: 0;
  transition: opacity 0.5s ease;
}
.anim-scene-text {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  text-align: center;
}

/* Scene 1 - Cracked */
.scene-1 { background: linear-gradient(135deg, #1a0505 0%, #0a0a0a 100%); }
.scene-1.active { opacity: 1; animation: phoneShake 0.5s ease-out; }
.anim-cracks {
  position: absolute; inset: 0; width: 100%; height: 100%;
  opacity: 0;
}
.scene-1.active .anim-cracks { animation: cracksAppear 1s 0.3s forwards; }
@keyframes cracksAppear { from { opacity:0; stroke-dasharray:0 1000; } to { opacity:0.8; stroke-dasharray:1000 0; } }
@keyframes phoneShake { 0%{transform:rotate(-5deg) scale(0.95)} 50%{transform:rotate(2deg) scale(1.02)} 100%{transform:rotate(0) scale(1)} }

/* Scene 2 - Technicien */
.scene-2 { background: linear-gradient(135deg, #0a0a1a 0%, #0a0a0a 100%); }
.scene-2.active { opacity: 1; }
.anim-dots { display: flex; gap: 8px; }
.anim-dots span {
  width: 12px; height: 12px;
  background: #cc0000;
  border-radius: 50%;
  animation: dotPulse 1.2s infinite;
}
.anim-dots span:nth-child(2) { animation-delay: 0.2s; }
.anim-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes dotPulse { 0%,100%{transform:scale(0.6);opacity:0.4} 50%{transform:scale(1);opacity:1} }
.anim-countdown {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,0.5);
  margin-top: 8px;
}

/* Scene 3 - Repair */
.scene-3 { background: linear-gradient(135deg, #050a1a 0%, #0a0a0a 100%); }
.scene-3.active { opacity: 1; }
.anim-progress-wrap {
  width: 80%;
  height: 8px;
  background: #222;
  border-radius: 10px;
  overflow: hidden;
}
.anim-progress-bar {
  width: 0%;
  height: 100%;
  background: linear-gradient(90deg, #cc0000, #ff4444);
  border-radius: 10px;
  transition: width 1.8s cubic-bezier(0.25,0.46,0.45,0.94);
}
.scene-3.active .anim-progress-bar { width: 100%; }
.anim-pulse { animation: textPulse 1s infinite; }
@keyframes textPulse { 0%,100%{opacity:1} 50%{opacity:0.5} }
.anim-tools {
  font-size: 24px;
  opacity: 0;
  animation: none;
}
.scene-3.active .anim-tools { animation: toolsIn 0.5s 0.3s forwards; }
@keyframes toolsIn { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

/* Scene 4 - Done */
.scene-4 { background: linear-gradient(135deg, #0a1a0a 0%, #0a0a0a 100%); }
.scene-4.active { opacity: 1; }
.anim-check {
  width: 50px; height: 50px;
  opacity: 0;
}
.scene-4.active .anim-check { animation: checkBounce 0.6s cubic-bezier(0.34,1.56,0.64,1) forwards; }
@keyframes checkBounce { from{opacity:0;transform:scale(0)} to{opacity:1;transform:scale(1)} }
.anim-details {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 8px;
  width: 100%;
}
.anim-detail-row {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 12px;
  color: rgba(255,255,255,0.7);
  text-align: center;
  opacity: 0;
}
.scene-4.active .anim-detail-row { animation: slideRow 0.4s forwards; }
.scene-4.active .anim-detail-row:nth-child(1) { animation-delay: 0.3s; }
.scene-4.active .anim-detail-row:nth-child(2) { animation-delay: 0.5s; }
.scene-4.active .anim-detail-row:nth-child(3) { animation-delay: 0.7s; }
.scene-4.active .anim-detail-row:nth-child(4) { animation-delay: 0.9s; }
@keyframes slideRow { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* Floating badges */
.anim-badge {
  position: absolute;
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px;
  padding: 8px 16px;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: white;
  opacity: 0;
  transition: opacity 0.5s, transform 0.5s cubic-bezier(0.34,1.56,0.64,1);
  white-space: nowrap;
}
.anim-badge-top { top: 0; right: -20px; transform: translateX(20px); }
.anim-badge-bot { bottom: 20px; left: -30px; transform: translateX(-20px); }
.anim-badge-top.visible { opacity: 1; transform: translateX(0); }
.anim-badge-bot.visible { opacity: 1; transform: translateX(0); }

/* Glow */
.anim-glow {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(204,0,0,0.15) 0%, transparent 70%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.8s;
}
.anim-glow.visible { opacity: 1; }

@media (max-width: 768px) {
  .anim-phone-wrap { width: 200px; height: 400px; }
  .anim-iphone { width: 190px; height: 380px; border-radius: 32px; }
  .anim-screen { border-radius: 26px; }
  .anim-notch { width: 80px; height: 22px; border-radius: 0 0 14px 14px; }
  .anim-badge-top { right: -10px; font-size: 11px; padding: 6px 12px; }
  .anim-badge-bot { left: -15px; font-size: 11px; padding: 6px 12px; }
}

/* ═══ PREMIUM IMAGES GLOBAL ═══ */
img { max-width: 100%; height: auto; display: block; }
.img-premium {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.15);
  transition: transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94), box-shadow 0.5s ease;
}
.img-premium:hover {
  transform: scale(1.03);
  box-shadow: 0 30px 80px rgba(0,0,0,0.25);
}

/* ═══ SERVICE VISUAL CARDS — APPLE STYLE ═══ */
.svc-visual {
  position: relative;
  border-radius: 16px 16px 0 0;
  overflow: hidden;
  height: 220px;
  background: #0a0a0a;
}
.svc-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
  filter: brightness(0.85);
}
.svc-visual:hover img {
  transform: scale(1.04);
  filter: brightness(1);
}
.svc-visual::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 50%;
  background: linear-gradient(transparent 50%, rgba(0,0,0,0.7));
  pointer-events: none;
}

/* Process step icons — Apple minimal */
.proc-icon {
  width: 60px;
  height: 60px;
  background: #cc0000;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-bottom: 16px;
}
.proc-icon-num {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 22px;
  height: 22px;
  background: #fff;
  color: #cc0000;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.svc-badge {
  position: absolute;
  top: 16px; right: 16px;
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: white;
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 13px;
  font-weight: 600;
  z-index: 2;
  border: 1px solid rgba(255,255,255,0.2);
}

.srv-card {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform, opacity;
}
.srv-card.visible {
  opacity: 1;
  transform: translateY(0);
}
.srv-card:nth-child(2) { transition-delay: 0.15s; }
.srv-card:nth-child(3) { transition-delay: 0.30s; }

/* ═══ MOBILE INPUT ZOOM FIX ═══ */
@media (max-width: 768px) {
  input, select, textarea { font-size: 16px !important; }
  body { padding-bottom: 70px; }
}

/* ═══ SERVICE CARD ANIMATIONS ═══ */
.svc-anim { transition: transform 0.3s; }
.svc-anim:hover { transform: scale(1.02); }

/* Card 1 - Crack */
.anim-crack-line {
  position:absolute; top:10%; left:20%; width:2px; height:0;
  background:linear-gradient(180deg, #cc0000, #ff4444);
  transform:rotate(25deg); transform-origin:top;
  animation: crackGrow 2s ease-out infinite;
}
.anim-repair-done {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:28px; color:#22c55e; font-weight:900;
  opacity:0; animation: repairShow 3s ease infinite;
}
@keyframes crackGrow { 0%{height:0;opacity:1} 50%{height:80%;opacity:1} 60%{height:80%;opacity:0} 100%{height:0;opacity:0} }
@keyframes repairShow { 0%,55%{opacity:0;transform:scale(0)} 65%{opacity:1;transform:scale(1.2)} 75%{transform:scale(1)} 95%{opacity:1} 100%{opacity:0} }

/* Card 2 - Battery */
.anim-battery-fill {
  position:absolute; bottom:2px; left:2px; right:2px; height:0;
  border-radius:3px;
  animation: batteryCharge 3s ease-in-out infinite;
}
.anim-battery-pct {
  font-family:'DM Sans',sans-serif; font-size:14px; font-weight:700;
  animation: batteryPctAnim 3s ease-in-out infinite;
}
@keyframes batteryCharge { 0%{height:8%;background:#cc0000} 80%{height:95%;background:#22c55e} 100%{height:95%;background:#22c55e} }
@keyframes batteryPctAnim { 0%{color:#cc0000;content:'5%'} 80%{color:#22c55e} 100%{color:#22c55e} }

/* Card 3 - Laptop */
.anim-laptop-screen {
  position:absolute; inset:4px; border-radius:4px;
  animation: laptopFix 3s ease infinite;
}
@keyframes laptopFix { 0%,40%{background:#1a0505} 45%{background:#cc0000} 55%{background:#0a1a0a} 60%,95%{background:#0a1a0a} 100%{background:#1a0505} }
.anim-laptop-screen::after {
  content:'⚠️'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:24px; animation: laptopIcon 3s ease infinite;
}
@keyframes laptopIcon { 0%,40%{content:'⚠️';opacity:1} 50%{opacity:0} 55%{content:'✓';opacity:1;color:#22c55e;font-size:28px} 95%{opacity:1} 100%{opacity:0} }

/* Card 4 - Water */
.anim-water-drops {
  position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 0%, rgba(59,130,246,.3) 100%);
  animation: waterRise 3s ease infinite;
}
@keyframes waterRise { 0%{transform:translateY(100%)} 40%{transform:translateY(20%)} 60%{transform:translateY(20%)} 80%{transform:translateY(100%)} 100%{transform:translateY(100%)} }
.anim-water-saved {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:28px; color:#22c55e; font-weight:900;
  opacity:0; animation: waterSavedShow 3s ease infinite;
}
@keyframes waterSavedShow { 0%,70%{opacity:0;transform:scale(0)} 80%{opacity:1;transform:scale(1.2)} 90%{transform:scale(1)} 95%{opacity:1} 100%{opacity:0} }

/* Card 5 - Senior */
.anim-senior-words {
  font-family:'DM Sans',sans-serif; font-size:14px; color:rgba(255,255,255,.7); font-weight:600;
  text-align:center; height:20px; overflow:hidden;
}
.anim-senior-words::after {
  content:'Simple'; display:block;
  animation: seniorWords 4s ease infinite;
}
@keyframes seniorWords { 0%,20%{content:'Simple'} 25%,45%{content:'Rapide'} 50%,70%{content:'Chez vous'} 75%,95%{content:'Sans jargon ❤️'} }
.anim-senior-icon { animation: seniorBounce 4s ease infinite; }
@keyframes seniorBounce { 0%,100%{transform:scale(1)} 50%{transform:scale(1.1)} }

/* Card 6 - Scan */
.anim-scan-ring {
  width:80px; height:80px; border:3px solid #cc0000; border-radius:50%;
  border-top-color:transparent;
  animation: scanSpin 1.5s linear infinite;
}
.anim-scan-result {
  position:absolute; font-family:'DM Sans',sans-serif; font-size:14px;
  font-weight:700; color:#22c55e;
  animation: scanResult 3s ease infinite;
}
@keyframes scanSpin { to{transform:rotate(360deg)} }
@keyframes scanResult { 0%,60%{opacity:0;transform:scale(0)} 70%{opacity:1;transform:scale(1.1)} 80%{transform:scale(1)} 95%{opacity:1} 100%{opacity:0} }

/* ═══════════════════════════════════════════════════
   MOBILE REFONTE COMPLÈTE — 768px et moins
   ═══════════════════════════════════════════════════ */

/* Hamburger button — modern asymmetric */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  gap: 5px;
  width: 44px;
  height: 44px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 8px;
  border-radius: 12px;
  transition: background 0.2s ease;
}
.hamburger:hover { background: rgba(0,0,0,0.06); }
.ham-line {
  display: block;
  height: 2px;
  background: #0a0a0a;
  border-radius: 2px;
  transition: all 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform-origin: center;
}
.ham-line-1 { width: 24px; }
.ham-line-2 { width: 18px; }
.ham-line-3 { width: 12px; }
.hamburger.open .ham-line-1 { width: 22px; transform: translateY(7px) rotate(45deg); }
.hamburger.open .ham-line-2 { opacity: 0; transform: scaleX(0); }
.hamburger.open .ham-line-3 { width: 22px; transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu overlay */
.mobile-menu {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.6); z-index: 300;
}
.mobile-menu.open { display: block; }
.mobile-menu-inner {
  position: absolute; top: 0; right: 0;
  width: 280px; height: 100%; background: #111;
  padding: 70px 0 24px;
  display: flex; flex-direction: column; gap: 0;
  overflow-y: auto;
  animation: slideMenuIn .25s ease;
}
@keyframes slideMenuIn { from{transform:translateX(100%)} to{transform:translateX(0)} }
.mobile-menu-inner a {
  color: #fff; text-decoration: none;
  font-size: 15px; font-weight: 500;
  padding: 10px 24px; margin: 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
  display: block;
}
.mobile-menu-inner a:active { color: #cc0000; }

@media (max-width: 768px) {
  /* NAV MOBILE */
  .hamburger { display: flex; }
  .nav-links { display: none !important; }
  .nav-tel { display: none; }
  .nav { height: 50px; padding: 0 16px; }
  .nav-btn { padding: 8px 18px !important; font-size: 13px !important; }
  .nl-name { font-size: .85rem; }

  /* HERO MOBILE */
  .hero { padding: 70px 20px 40px !important; text-align: center; }
  .hero-in { grid-template-columns: 1fr !important; gap: 0 !important; }
  .hero-vis { display: none !important; }
  .hero h1 { font-size: 32px !important; line-height: 1.15; }
  .hero-p { font-size: 15px !important; max-width: 100%; }
  .hero-btns { flex-direction: column; gap: 10px; }
  .hero-btns a { width: 100%; text-align: center; justify-content: center; padding: 14px !important; font-size: 16px !important; }
  .hero-badge { font-size: 13px; }
  .hero-proof { justify-content: center; }

  /* TRUST BADGE BAR */
  .trust-badge-bar { gap: 8px; padding: 8px 12px; }
  .trust-badge-bar span { font-size: 11px; padding: 4px 10px; }

  /* SERVICES MOBILE */
  .srv-wrap { grid-template-columns: 1fr !important; }
  .svc-visual { height: 160px; }
  .srv-h { font-size: 18px !important; }
  .srv-price b { font-size: 24px; }
  .srv-card { margin-bottom: 8px; }

  /* PROCESS MOBILE */
  .proc-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .proc-icon { width: 50px; height: 50px; border-radius: 14px; }

  /* ZONES MOBILE */
  .zones-grid { grid-template-columns: 1fr !important; }
  .zone-list { gap: .5rem; }
  .zone-row { padding: 14px 16px; }

  /* PRICING MOBILE */
  .price-grid { grid-template-columns: 1fr !important; gap: 16px; }
  .pc { padding: 24px 20px; }

  /* REVIEWS MOBILE */
  .rev-grid { grid-template-columns: 1fr !important; }

  /* FAQ MOBILE */
  .faq-q { font-size: 15px; padding: 16px 0; }
  .faq-a { font-size: 14px; }

  /* CTA MOBILE */
  .cta-box { padding: 40px 20px !important; }
  .cta-h { font-size: 1.6rem !important; }
  .cta-btns { flex-direction: column; gap: 10px; }
  .cta-w, .cta-t { width: 100%; text-align: center; padding: 14px !important; }

  /* CERTIFICATION SECTION */
  .cert-section { padding: 2rem 1rem; }

  /* FOOTER MOBILE */
  footer { padding: 30px 16px 20px !important; }
  .ft-top { grid-template-columns: 1fr !important; gap: 2rem !important; }
  .ft-bot { flex-direction: column; text-align: center; gap: .5rem; }
  .ft-copy { font-size: 12px; }
  .seo-bar { display: none; }

  /* STICKY BAR MOBILE — refonte */
  .sticky-contact-bar {
    display: flex !important;
    height: 70px;
    background: #000 !important;
    border-top: 2px solid #cc0000 !important;
    padding: 0 !important;
    padding-bottom: env(safe-area-inset-bottom) !important;
  }
  .sticky-contact-bar a {
    width: 25% !important;
    flex: none !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0 !important;
    padding: 8px 0 !important;
    border-radius: 0 !important;
    font-size: 10px !important;
    color: #ffffff !important;
    text-align: center !important;
    white-space: nowrap !important;
    min-height: auto !important;
    line-height: 1.2;
  }
  .sticky-contact-bar a span.sticky-icon {
    font-size: 22px !important;
    display: block !important;
    text-align: center !important;
    margin-bottom: 3px !important;
  }
  .sticky-contact-bar a.sticky-reserve {
    background: #cc0000 !important;
    border-radius: 0 !important;
    padding: 8px 0 !important;
    width: 25% !important;
  }
  body { padding-bottom: 78px !important; }

  /* WhatsApp popup mobile */
  .wa-popup { bottom: 80px !important; right: 12px !important; max-width: 260px; font-size: 13px; }
  .wa-popup p { font-size: 13px; }

  /* WhatsApp floating button above sticky */
  body > a[href*="wa.me"] { bottom: 80px !important; width: 50px !important; height: 50px !important; }

  /* DOUBLE OPTION CARDS */
  .double-option > div { min-width: 100% !important; }

  /* Touch targets */
  a, button, input, select, textarea { min-height: 44px; }
  input, select, textarea { font-size: 16px !important; }

  /* Reduce animations on mobile */
  @media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  }
}
