/* ===== YZM GLOBAL CSS v5 — Mobile-First Premium ===== */

/* A11Y — Skip link & screen reader */
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}
.screen-reader-text:focus,.skip-link:focus{background:#0a1628;clip:auto;-webkit-clip-path:none;clip-path:none;color:#fff;display:block;font-family:'Sora',sans-serif;font-weight:700;font-size:.9rem;height:auto;left:8px;line-height:normal;padding:14px 22px;text-decoration:none;top:8px;width:auto;z-index:100000;border-radius:8px;box-shadow:0 6px 24px rgba(0,0,0,.4)}

/* SVG ICONS — Premium sprite v1.3 */
.ic{display:inline-flex;vertical-align:middle;flex-shrink:0;margin-right:.5em;align-items:center;justify-content:center}
.ic-sm{display:inline-flex;vertical-align:middle;flex-shrink:0;margin-right:.4em;align-items:center;justify-content:center;opacity:.7}
.ic-mob{display:inline-flex;vertical-align:middle;flex-shrink:0;margin-right:.75em;align-items:center;justify-content:center;opacity:.85;transition:opacity .2s}
.arr{display:inline-flex;vertical-align:middle;flex-shrink:0;margin-left:auto;opacity:.5;transition:transform .2s,opacity .2s;align-items:center;justify-content:center}

/* SVG injecté à la place des emojis (filtre PHP yzm_replace_emojis_with_svg) */
.yzm-emoji-svg{display:inline-block;vertical-align:-3px;flex-shrink:0;width:1em;height:1em;color:currentColor;margin:0 .15em}

.yn-mob-links a:hover .arr,.yn-mob-links a:focus .arr{opacity:1;transform:translateX(4px)}
.yn-mob-links a:hover .ic-mob,.yn-mob-links a:focus .ic-mob{opacity:1}
.btn-urg-nav .ic{color:currentColor}
.ft-phone .ic{color:#f97316;margin-right:.5em}
.ft-addr{display:flex;align-items:center;gap:.4em}
.ft-addr .ic-sm{color:#f97316;opacity:1;margin:0}
.ft-col ul li a{display:inline-flex;align-items:center}
.ft-col ul li .ic-sm{color:#f97316;opacity:.8;margin-right:.5em}
.ft-bot span{display:inline-flex;align-items:center;gap:.4em}
.ft-bot .ic-sm{color:#f97316;opacity:.8;margin:0}
.yn-mob-call-ico svg{color:#f97316}
.yn-mob-devis .ic{color:currentColor}
.yn-mob-links .emerg .ic-mob{color:#ef4444;opacity:1}

/* BASE */
*,*::before,*::after{box-sizing:border-box}
html{overflow-x:hidden}
.yp{font-family:'DM Sans',sans-serif;color:#0a1628;background:#fff;line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.yp h1,.yp h2,.yp h3,.yp h4,.yp h5{font-family:'Sora',sans-serif;line-height:1.2;margin:0}
.yp p{margin:0}
.yp ul,.yp ol{margin:0;padding:0;list-style:none}
.yp a{text-decoration:none;color:inherit}
.yp img{max-width:100%;display:block;height:auto}
.yp strong{font-weight:700}

/* ===== NAV DESKTOP ===== */
.yn{position:fixed;top:0;left:0;right:0;z-index:9999;background:#0a1628;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:68px;box-shadow:0 2px 20px rgba(0,0,0,.35)}
.yn-brand{font-family:'Sora',sans-serif;font-weight:800;font-size:1.2rem;color:#fff;letter-spacing:-.3px;text-decoration:none;flex-shrink:0;white-space:nowrap;display:flex;align-items:center;gap:2px}
.yn-brand .b-yzm{color:#fff}
.yn-brand .b-svc{color:#f97316}
.yn-center{display:flex;align-items:center;gap:24px;flex:1;justify-content:center}
.yn-center a{font-family:'Sora',sans-serif;font-weight:600;font-size:.88rem;color:rgba(255,255,255,.72);transition:color .2s;white-space:nowrap;text-decoration:none}
.yn-center a:hover{color:#fff}
.yn-right{display:flex;align-items:center;gap:10px}
.btn-urg-nav{display:inline-flex;align-items:center;gap:7px;background:#f97316;color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:.85rem;padding:10px 18px;border-radius:8px;white-space:nowrap;text-decoration:none;transition:background .2s}
.btn-urg-nav:hover{background:#ea6a0a;color:#fff}
.btn-dv-nav{display:inline-flex;align-items:center;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.2);color:#fff;font-family:'Sora',sans-serif;font-weight:600;font-size:.82rem;padding:9px 14px;border-radius:8px;white-space:nowrap;text-decoration:none;transition:all .2s}
.btn-dv-nav:hover{background:rgba(255,255,255,.18)}

/* HAMBURGER */
.yn-ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;width:40px;height:40px;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}
.yn-ham:hover{background:rgba(255,255,255,.1)}
.yn-ham span{width:22px;height:2px;background:#fff;border-radius:2px;display:block;transition:all .3s;transform-origin:center}
.yn-ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.yn-ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.yn-ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== MOBILE NAV — PLEIN ÉCRAN PREMIUM ===== */
.yn-mob{display:none;position:fixed;inset:0;background:#0a1628;z-index:9997;flex-direction:column;padding-top:68px;overflow-y:auto}
.yn-mob.open{display:flex}

/* Header du menu mobile */
.yn-mob-head{padding:28px 24px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.yn-mob-status{display:flex;align-items:center;gap:8px;font-size:.78rem;color:#86efac;font-family:'Sora',sans-serif;font-weight:700;margin-bottom:20px}
.yn-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:yblink 1.5s infinite;flex-shrink:0;display:inline-block}
@keyframes yblink{0%,100%{opacity:1}50%{opacity:.3}}
.yn-mob-call{display:flex;align-items:center;gap:14px;background:rgba(249,115,22,.15);border:1.5px solid rgba(249,115,22,.35);border-radius:16px;padding:16px 20px;text-decoration:none;transition:background .2s}
.yn-mob-call:hover{background:rgba(249,115,22,.25)}
.yn-mob-call-ico{width:44px;height:44px;background:#f97316;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.yn-mob-call-num{font-family:'Sora',sans-serif;font-weight:800;font-size:1.15rem;color:#fff;display:block;line-height:1.2}
.yn-mob-call-sub{font-size:.75rem;color:rgba(255,255,255,.6);display:block;margin-top:2px}

/* Liens menu mobile */
.yn-mob-links{padding:20px 24px;display:flex;flex-direction:column;gap:4px;flex:1}
.yn-mob-links a{font-family:'Sora',sans-serif;font-weight:600;font-size:1.1rem;color:rgba(255,255,255,.8);padding:14px 0;border-bottom:1px solid rgba(255,255,255,.06);text-decoration:none;display:flex;align-items:center;justify-content:space-between;transition:color .2s}
.yn-mob-links a:hover{color:#fff}
.yn-mob-links a:last-child{border-bottom:none}
.yn-mob-links a .arr{font-size:.9rem;opacity:.4;transition:opacity .2s,transform .2s}
.yn-mob-links a:hover .arr{opacity:.8;transform:translateX(4px)}

/* Devis CTA en bas du menu */
.yn-mob-footer{padding:20px 24px 40px;border-top:1px solid rgba(255,255,255,.08)}
.yn-mob-devis{display:flex;align-items:center;justify-content:center;gap:10px;background:#1a56db;color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;padding:16px;border-radius:14px;text-decoration:none;transition:background .2s}
.yn-mob-devis:hover{background:#1d4ed8;color:#fff}

/* ===== HERO ===== */
.hero{margin-top:68px;background:linear-gradient(135deg,#0a1628 0%,#0d1f3c 55%,#112649 100%);display:flex;align-items:center;position:relative;overflow:hidden;padding:80px 32px}
.hero::before{content:'';position:absolute;top:-100px;right:-100px;width:650px;height:650px;background:radial-gradient(circle,rgba(26,86,219,.22) 0%,transparent 70%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-80px;left:10%;width:400px;height:400px;background:radial-gradient(circle,rgba(249,115,22,.08) 0%,transparent 70%);pointer-events:none}
.hero-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 440px;gap:64px;align-items:center;width:100%;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(249,115,22,.15);border:1px solid rgba(249,115,22,.35);color:#fb923c;font-family:'Sora',sans-serif;font-weight:700;font-size:.75rem;padding:6px 14px;border-radius:20px;margin-bottom:22px;text-transform:uppercase;letter-spacing:.8px}
.hero-pulse{width:8px;height:8px;background:#fb923c;border-radius:50%;animation:yblink 1.5s infinite;flex-shrink:0}
.hero h1{font-size:clamp(2rem,4.5vw,3.6rem);font-weight:800;color:#fff !important;letter-spacing:-1.5px;line-height:1.08;margin-bottom:22px}
.hero h1 em{color:#f97316 !important;font-style:normal}
.hero h1 span{color:#fff !important}
.hero-sub{color:#94a3b8;font-size:1.05rem;line-height:1.75;margin-bottom:36px;max-width:500px}
.hero-stats{display:flex;gap:32px;margin-bottom:38px;flex-wrap:wrap}
.hs{display:flex;flex-direction:column;gap:3px}
.hs strong{font-family:'Sora',sans-serif;font-weight:800;font-size:1.9rem;color:#fff;line-height:1}
.hs span{font-size:.78rem;color:#94a3b8}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}

/* PAGE HERO (pages internes) */
.ph{margin-top:68px;background:linear-gradient(135deg,#0a1628 0%,#0f2447 60%,#1a3a6b 100%);padding:64px 24px;text-align:center;position:relative;overflow:hidden}
.ph::before{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(26,86,219,.18),transparent 70%);pointer-events:none}
.ph-label{display:inline-block;font-family:'Sora',sans-serif;font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;color:#fb923c;margin-bottom:14px;background:rgba(249,115,22,.15);border:1px solid rgba(249,115,22,.4);padding:5px 14px;border-radius:20px}
.ph h1{font-size:clamp(1.7rem,4vw,3rem);font-weight:800;color:#fff !important;letter-spacing:-1px;margin-bottom:16px}
.ph p{color:#94a3b8;font-size:1.05rem;max-width:580px;margin:0 auto;line-height:1.7}
.ph-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:28px}

/* HERO CARD */
.hero-card{background:#fff;border-radius:20px;padding:32px 28px;box-shadow:0 20px 60px rgba(0,0,0,.3);position:relative;z-index:2;width:100%}
.hc-title{font-family:'Sora',sans-serif;font-weight:700;font-size:1.1rem;color:#0a1628;margin-bottom:4px}
.hc-sub{font-size:.85rem;color:#64748b;margin-bottom:20px}
.hc-urgence-link{display:flex;align-items:center;justify-content:space-between;gap:10px;background:linear-gradient(135deg,#fef2f2,#fff7ed);border:1.5px solid #fecaca;border-radius:12px;padding:14px 16px;margin-bottom:22px;text-decoration:none;transition:transform .15s,box-shadow .15s}
.hc-urgence-link:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(220,38,38,.15)}
.hc-urg-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.hc-ico{font-size:1.5rem;flex-shrink:0;line-height:1}
.hc-urg-txt{font-family:'Sora',sans-serif;font-weight:700;font-size:.9rem;color:#991b1b;display:block;line-height:1.2}
.hc-urg-sub{font-size:.75rem;color:#b91c1c;display:block;margin-top:2px}
.hc-btn-red{background:#dc2626;color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:.8rem;padding:9px 14px;border-radius:8px;white-space:nowrap;flex-shrink:0}
.hc-note{text-align:center;font-size:.75rem;color:#64748b;margin-top:12px}
.hero-card .wpcf7{display:block}
.hero-card .wpcf7-form{display:flex;flex-direction:column;gap:0}
.hero-card .wpcf7-form .wpcf7-form-control-wrap{display:block;width:100%;margin-bottom:13px}
.hero-card .wpcf7-form select,.hero-card .wpcf7-form input[type=text],.hero-card .wpcf7-form input[type=tel],.hero-card .wpcf7-form input[type=email]{width:100%;padding:12px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-family:'DM Sans',sans-serif;font-size:.95rem;color:#0a1628;background:#f8fafc;outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none;display:block}
.hero-card .wpcf7-form select{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2364748b'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 10px center;background-size:20px;padding-right:36px}
.hero-card .wpcf7-form select:focus,.hero-card .wpcf7-form input:focus{border-color:#1a56db;background:#fff}
.hero-card .wpcf7-form input[type=submit]{width:100%;padding:14px;background:#1a56db;color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;border:none;border-radius:12px;cursor:pointer;transition:all .2s;margin-top:4px}
.hero-card .wpcf7-form input[type=submit]:hover{background:#1d4ed8;transform:translateY(-1px)}
.hero-card .wpcf7-not-valid-tip{font-size:.75rem;color:#dc2626;margin-top:3px;display:block}
.hero-card .wpcf7-response-output{border-radius:10px;padding:12px 16px;margin-top:12px;font-size:.85rem;font-family:'Sora',sans-serif;font-weight:600;text-align:center;border:none !important}
.hero-card .wpcf7-mail-sent-ok{background:#f0fdf4;color:#16a34a}
.hero-card .wpcf7-mail-sent-ng,.hero-card .wpcf7-validation-errors{background:#fef2f2;color:#dc2626}

/* TRUST BAR */
.tbar{background:#0a1628;border-top:1px solid #1e3a5f;padding:13px 32px}
.tbar-in{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:6px;font-size:.82rem;font-weight:500;color:rgba(255,255,255,.75);white-space:nowrap}

/* SECTIONS */
.yp-s{padding:88px 32px}
.yp-s-alt{background:#f8fafc}
.yp-ct{max-width:1200px;margin:0 auto}
.yp-lbl{display:inline-block;font-family:'Sora',sans-serif;font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:1.8px;color:#1a56db;margin-bottom:12px}
.yp-h2{font-size:clamp(1.7rem,3vw,2.5rem);font-weight:800;color:#0a1628;letter-spacing:-.5px;margin-bottom:14px}
.yp-sub{font-size:1rem;color:#64748b;line-height:1.75;max-width:600px;margin-bottom:52px}

/* BOUTONS */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:#f97316;color:#fff !important;font-family:'Sora',sans-serif;font-weight:700;font-size:1.05rem;padding:17px 32px;border-radius:12px;transition:all .2s;box-shadow:0 4px 24px rgba(249,115,22,.35);text-decoration:none;white-space:nowrap}
.btn-primary:hover{background:#ea6a0a;transform:translateY(-2px)}
.btn-blue{display:inline-flex;align-items:center;gap:10px;background:#1a56db;color:#fff !important;font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;padding:16px 28px;border-radius:12px;transition:all .2s;text-decoration:none;white-space:nowrap}
.btn-blue:hover{background:#1d4ed8;transform:translateY(-2px)}
.btn-call{display:inline-flex;align-items:center;gap:10px;background:#f97316;color:#fff !important;font-family:'Sora',sans-serif;font-weight:700;font-size:1.05rem;padding:16px 28px;border-radius:12px;transition:all .2s;box-shadow:0 4px 24px rgba(249,115,22,.4);white-space:nowrap;text-decoration:none}
.btn-call:hover{background:#ea6a0a;transform:translateY(-2px)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.25);color:#fff !important;font-family:'Sora',sans-serif;font-weight:600;font-size:.98rem;padding:15px 24px;border-radius:12px;transition:all .2s;white-space:nowrap;text-decoration:none}
.btn-ghost:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.4)}

/* URGENCE CARDS */
.urg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}
.uc{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;padding:28px 24px;transition:all .25s;position:relative;overflow:hidden}
.uc::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:#1a56db;transform:scaleX(0);transition:transform .25s;transform-origin:left}
.uc:hover{border-color:#1a56db;transform:translateY(-4px);box-shadow:0 12px 40px rgba(10,22,40,.15)}
.uc:hover::after{transform:scaleX(1)}
.uc.feat{border-color:#f97316;background:linear-gradient(160deg,#fff7ed 0%,#fff 60%)}
.uc.feat::after{background:#f97316;transform:scaleX(1)}
.uc-ico{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:16px}
.uc-ico.or{background:#fff7ed}.uc-ico.bl{background:#eff6ff}.uc-ico.gr{background:#f0fdf4}
.uc h3{font-size:1rem;font-weight:700;color:#0a1628;margin-bottom:8px}
.uc p{font-size:.86rem;color:#64748b;line-height:1.65;margin-bottom:14px}
.uc-lnk{font-family:'Sora',sans-serif;font-weight:700;font-size:.82rem;color:#1a56db;display:inline-flex;align-items:center;gap:6px;transition:gap .2s;text-decoration:none}
.uc:hover .uc-lnk{gap:10px}

/* EMG BANNER */
.emg{background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:20px;padding:36px 40px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.emg-left{flex:1;min-width:260px}
.emg-left h3{font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:6px}
.emg-left p{color:rgba(255,255,255,.85);font-size:.92rem}
.emg-right{display:flex;flex-direction:column;gap:10px;flex-shrink:0}
.btn-emg{display:flex;align-items:center;gap:12px;background:#fff;border-radius:12px;padding:14px 22px;transition:transform .2s;white-space:nowrap;text-decoration:none}
.btn-emg:hover{transform:scale(1.03)}
.emg-num{font-family:'Sora',sans-serif;font-weight:800;font-size:1.1rem;color:#dc2626;display:block}
.emg-sub{font-size:.72rem;color:#64748b;display:block}
.btn-emg2{display:block;text-align:center;padding:12px 22px;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.4);border-radius:12px;color:#fff;font-family:'Sora',sans-serif;font-weight:600;font-size:.88rem;transition:background .2s;text-decoration:none}
.btn-emg2:hover{background:rgba(255,255,255,.25)}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-img-wrap{position:relative}
.about-img{width:100%;height:480px;object-fit:cover;border-radius:20px}
.about-badge{position:absolute;bottom:-20px;right:-20px;background:#f97316;color:#fff;border-radius:20px;padding:20px 24px;text-align:center;box-shadow:0 12px 40px rgba(10,22,40,.2)}
.about-badge strong{font-family:'Sora',sans-serif;font-weight:800;font-size:2rem;display:block;line-height:1;color:#fff}
.about-badge span{font-size:.78rem;opacity:.9;margin-top:2px;display:block;color:#fff}
.about-content p{color:#64748b;font-size:.95rem;line-height:1.8;margin-bottom:16px}
.about-feats{display:flex;flex-direction:column;gap:14px;margin:24px 0 28px}
.af{display:flex;align-items:flex-start;gap:14px}
.af-ico{width:40px;height:40px;background:#f1f5f9;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.af-txt strong{display:block;font-weight:700;font-size:.92rem;color:#0a1628;margin-bottom:2px}
.af-txt span{font-size:.83rem;color:#64748b;display:block}
.assur-strip{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.assur-lbl{font-family:'Sora',sans-serif;font-weight:700;font-size:.78rem;color:#334155;white-space:nowrap}
.assur-logos{display:flex;gap:8px;flex-wrap:wrap}
.alog{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:5px 12px;font-family:'Sora',sans-serif;font-weight:700;font-size:.72rem;color:#334155}

/* PROCESS */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.pc{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;padding:30px 22px;text-align:center;transition:all .25s}
.pc:hover{border-color:#1a56db;box-shadow:0 4px 24px rgba(10,22,40,.10);transform:translateY(-3px)}
.pc-num{width:48px;height:48px;border-radius:50%;background:#1a56db;color:#fff;font-family:'Sora',sans-serif;font-weight:800;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.pc h3{font-size:.95rem;font-weight:700;color:#0a1628;margin-bottom:8px}
.pc p{font-size:.83rem;color:#64748b;line-height:1.6}

/* REALISATIONS */
.real-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rg{border-radius:20px;overflow:hidden;position:relative;background:#f1f5f9;cursor:pointer}
.rg img{width:100%;height:240px;object-fit:cover;transition:transform .4s;display:block}
.rg:hover img{transform:scale(1.06)}
.rg-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.85) 0%,transparent 55%);opacity:0;transition:opacity .3s}
.rg:hover .rg-overlay{opacity:1}
.rg-info{position:absolute;bottom:0;left:0;right:0;padding:20px;opacity:0;transform:translateY(8px);transition:all .3s}
.rg:hover .rg-info{opacity:1;transform:translateY(0)}
.rg-cat{font-family:'Sora',sans-serif;font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:1px;color:#f97316;margin-bottom:4px}
.rg-title{font-family:'Sora',sans-serif;font-weight:700;font-size:.95rem;color:#fff}
.real-cta{text-align:center;margin-top:40px}

/* AVIS */
.avis-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:16px}
.avis-big{font-family:'Sora',sans-serif;font-weight:800;font-size:3.5rem;color:#0a1628;line-height:1}
.avis-stars-big{color:#f59e0b;font-size:1.2rem;letter-spacing:2px}
.avis-count{font-size:.82rem;color:#64748b}
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.av{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;padding:24px;transition:all .25s}
.av:hover{border-color:#1a56db;box-shadow:0 4px 24px rgba(10,22,40,.10)}
.av-stars{color:#f59e0b;font-size:.95rem;margin-bottom:12px;letter-spacing:2px}
.av-txt{font-size:.88rem;color:#334155;line-height:1.65;margin-bottom:16px;font-style:italic}
.av-auth{display:flex;align-items:center;gap:10px}
.av-av{width:36px;height:36px;border-radius:50%;background:#1a56db;display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-weight:700;font-size:.82rem;color:#fff;flex-shrink:0}
.av-name{font-weight:700;font-size:.88rem;color:#0a1628}
.av-date{font-size:.75rem;color:#64748b}
.av-verif{font-size:.72rem;color:#16a34a;font-weight:600;font-family:'Sora',sans-serif;margin-top:3px}

/* ZONES */
.zones-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.zc{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;padding:20px;transition:all .2s}
.zc:hover{border-color:#1a56db;transform:translateY(-2px);box-shadow:0 4px 20px rgba(10,22,40,.10)}
.zc-dept{font-family:'Sora',sans-serif;font-weight:800;font-size:1.4rem;color:#1a56db;line-height:1;margin-bottom:4px}
.zc-name{font-weight:700;font-size:.92rem;color:#0a1628;margin-bottom:8px}
.zc-cities{font-size:.76rem;color:#64748b;line-height:1.65}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.bc{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;overflow:hidden;transition:all .25s;display:flex;flex-direction:column;text-decoration:none}
.bc:hover{border-color:#1a56db;transform:translateY(-4px);box-shadow:0 12px 40px rgba(10,22,40,.15)}
.bc-img{width:100%;height:180px;object-fit:cover;display:block}
.bc-ph{width:100%;height:180px;background:linear-gradient(135deg,#0a1628,#1a3a6b);display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.bc-body{padding:22px;flex:1;display:flex;flex-direction:column}
.bc-tag{display:inline-block;font-family:'Sora',sans-serif;font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:1px;padding:3px 10px;border-radius:20px;margin-bottom:10px;width:fit-content}
.bc-tag.pl{background:#eff6ff;color:#1a56db}.bc-tag.cs{background:#fff7ed;color:#f97316}.bc-tag.rv{background:#f0fdf4;color:#16a34a}
.bc-meta{font-size:.76rem;color:#64748b;margin-bottom:8px}
.bc h3{font-size:.95rem;font-weight:700;color:#0a1628;line-height:1.35;margin-bottom:10px}
.bc p{font-size:.83rem;color:#64748b;line-height:1.65;flex:1;margin-bottom:16px}
.bc-lnk{font-family:'Sora',sans-serif;font-weight:700;font-size:.82rem;color:#1a56db;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.bc:hover .bc-lnk{gap:10px}

/* FINAL CTA */
.fcta{background:linear-gradient(135deg,#0a1628,#0f2447);padding:88px 32px;text-align:center;position:relative;overflow:hidden}
.fcta::before{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:700px;height:700px;background:radial-gradient(circle,rgba(26,86,219,.18),transparent 70%);pointer-events:none}
.fcta h2{font-size:clamp(1.9rem,3.5vw,3rem);font-weight:800;color:#fff;letter-spacing:-.8px;margin-bottom:14px;position:relative}
.fcta p{color:#94a3b8;font-size:1.05rem;max-width:520px;margin:0 auto 40px;line-height:1.75;position:relative}
.fcta-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative}

/* FOOTER */
.ft{background:#060e1c;padding:56px 32px 40px;color:#64748b}
.ft-in{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.ft-brand{font-family:'Sora',sans-serif;font-weight:800;font-size:1.4rem;margin-bottom:12px;display:block;text-decoration:none}
.ft-brand .b-yzm{color:#fff}
.ft-brand .b-svc{color:#f97316}
.ft-desc{font-size:.86rem;line-height:1.75;margin-bottom:20px;max-width:280px}
.ft-phone{display:inline-flex;align-items:center;gap:8px;color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:1.1rem;margin-bottom:16px;text-decoration:none}
.ft-phone:hover{color:#f97316}
.ft-addr{font-size:.8rem;color:#475569;line-height:1.6}
.ft-col h4{font-family:'Sora',sans-serif;font-weight:700;font-size:.82rem;color:#fff;margin-bottom:18px;text-transform:uppercase;letter-spacing:.8px}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;padding:0}
.ft-col ul li a{font-size:.85rem;color:#64748b;transition:color .2s;text-decoration:none}
.ft-col ul li a:hover{color:#fff}
.ft-bot{max-width:1200px;margin:0 auto;padding-top:24px;border-top:1px solid #1e293b;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.78rem}

/* BLOG PAGE */
.bl-grid{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.art-feat{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;overflow:hidden;transition:all .25s;margin-bottom:32px;display:block;text-decoration:none}
.art-feat:hover{border-color:#1a56db;box-shadow:0 12px 40px rgba(10,22,40,.15);transform:translateY(-2px)}
.art-feat-img{width:100%;height:260px;object-fit:cover;display:block}
.art-feat-body{padding:32px}
.art-tag{display:inline-block;font-family:'Sora',sans-serif;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:1px;padding:4px 12px;border-radius:20px;margin-bottom:12px}
.t-plomb{background:#eff6ff;color:#1a56db}.t-conseil{background:#fff7ed;color:#f97316}.t-renov{background:#f0fdf4;color:#16a34a}
.art-meta{display:flex;align-items:center;gap:16px;font-size:.8rem;color:#64748b;margin-bottom:14px;flex-wrap:wrap}
.art-feat h2{font-size:1.4rem;font-weight:700;color:#0a1628;margin-bottom:10px;line-height:1.3}
.art-feat p{font-size:.92rem;color:#64748b;line-height:1.7;margin-bottom:20px}
.art-lire{display:inline-flex;align-items:center;gap:8px;font-family:'Sora',sans-serif;font-weight:700;font-size:.9rem;color:#1a56db;transition:gap .2s}
.art-feat:hover .art-lire{gap:12px}
.arts-list{display:flex;flex-direction:column;gap:20px}
.art-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;overflow:hidden;display:grid;grid-template-columns:180px 1fr;transition:all .25s;text-decoration:none}
.art-card:hover{border-color:#1a56db;box-shadow:0 4px 20px rgba(10,22,40,.10);transform:translateY(-2px)}
.art-card-img{width:180px;height:100%;min-height:140px;object-fit:cover;display:block}
.art-card-ph{width:180px;min-height:140px;background:linear-gradient(135deg,#0a1628,#1a3a6b);display:flex;align-items:center;justify-content:center;font-size:2.5rem;flex-shrink:0}
.art-card-body{padding:22px 24px;display:flex;flex-direction:column;justify-content:space-between;gap:8px}
.art-card h3{font-size:1rem;font-weight:700;color:#0a1628;line-height:1.3}
.art-card p{font-size:.85rem;color:#64748b;line-height:1.6;flex:1}
.bl-side{display:flex;flex-direction:column;gap:20px;position:sticky;top:88px}
.side-box{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;padding:24px}
.side-box h4{font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;color:#0a1628;margin-bottom:16px}
.cats{list-style:none;display:flex;flex-direction:column;gap:8px;padding:0}
.cats li a{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:8px;background:#f8fafc;font-size:.88rem;font-weight:500;color:#334155;transition:all .2s;text-decoration:none}
.cats li a:hover{background:#1a56db;color:#fff}
.urg-side{background:linear-gradient(135deg,#f97316,#ea6a0a);border-radius:20px;padding:28px;color:#fff}
.urg-side h4{font-size:1.1rem;font-weight:800;margin-bottom:10px;color:#fff}
.urg-side p{font-size:.85rem;opacity:.9;margin-bottom:18px;line-height:1.6;color:#fff}
.us-btn{display:flex;align-items:center;gap:12px;background:#fff;border-radius:12px;padding:14px 16px;transition:transform .2s;text-decoration:none}
.us-btn:hover{transform:scale(1.02)}
.us-ico{width:38px;height:38px;background:#f97316;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem}
.us-num{font-family:'Sora',sans-serif;font-weight:800;font-size:1rem;color:#0a1628}
.us-sub{font-size:.72rem;color:#64748b}
.pop-list{display:flex;flex-direction:column;gap:10px}
.pop-item{display:flex;gap:10px;align-items:flex-start;padding:10px;background:#f8fafc;border-radius:8px;transition:background .2s;text-decoration:none}
.pop-item:hover{background:#eff6ff}
.pop-emoji{font-size:1.2rem;flex-shrink:0;margin-top:2px}
.pop-item span{font-size:.82rem;font-weight:500;color:#334155;line-height:1.4}
.cta-box-inner{background:linear-gradient(135deg,#0a1628,#0f2447);border-radius:20px;padding:56px 48px;text-align:center}
.cta-box-inner h2{font-size:1.8rem;font-weight:800;color:#fff;margin-bottom:12px}
.cta-box-inner p{color:#94a3b8;font-size:1rem;line-height:1.7;margin-bottom:28px;max-width:500px;margin-left:auto;margin-right:auto}
.cta-btns-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* DEVIS CF7 */
.devis-grid{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start}
.devis-form-wrap{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;padding:40px;box-shadow:0 12px 40px rgba(10,22,40,.08)}
.devis-form-wrap h2{font-size:1.4rem;font-weight:700;color:#0a1628;margin-bottom:4px}
.devis-form-sub{font-size:.88rem;color:#64748b;margin-bottom:28px;display:block}
.devis-form-wrap .wpcf7-form .wpcf7-form-control-wrap{display:block;width:100%;margin-bottom:16px}
.devis-form-wrap .wpcf7-form input[type=text],.devis-form-wrap .wpcf7-form input[type=tel],.devis-form-wrap .wpcf7-form input[type=email],.devis-form-wrap .wpcf7-form select,.devis-form-wrap .wpcf7-form textarea{width:100%;padding:13px 16px;border:1.5px solid #e2e8f0;border-radius:10px;font-family:'DM Sans',sans-serif;font-size:.95rem;color:#0a1628;background:#f8fafc;outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none}
.devis-form-wrap .wpcf7-form select{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2364748b'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px}
.devis-form-wrap .wpcf7-form textarea{resize:vertical;min-height:120px}
.devis-form-wrap .wpcf7-form input:focus,.devis-form-wrap .wpcf7-form select:focus,.devis-form-wrap .wpcf7-form textarea:focus{border-color:#1a56db;background:#fff}
.devis-form-wrap .wpcf7-form input[type=submit]{width:100%;padding:15px;background:#1a56db;color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;border:none;border-radius:12px;cursor:pointer;transition:all .2s;margin-top:4px}
.devis-form-wrap .wpcf7-form input[type=submit]:hover{background:#1d4ed8;transform:translateY(-1px)}
.devis-form-wrap .wpcf7-not-valid-tip{font-size:.75rem;color:#dc2626;margin-top:3px;display:block}
.devis-form-wrap .wpcf7-response-output{border-radius:10px;padding:14px 18px;margin-top:16px;font-size:.9rem;font-family:'Sora',sans-serif;font-weight:600;text-align:center;border:none !important}
.devis-form-wrap .wpcf7-mail-sent-ok{background:#f0fdf4;color:#16a34a}
.devis-form-wrap .wpcf7-mail-sent-ng,.devis-form-wrap .wpcf7-validation-errors{background:#fef2f2;color:#dc2626}
.devis-form-wrap .wpcf7-list-item{margin:0}
.devis-form-wrap .wpcf7-list-item-label{font-size:.88rem;color:#334155;margin-left:8px}
.devis-aside{display:flex;flex-direction:column;gap:20px;position:sticky;top:88px}
.devis-urg-box{background:linear-gradient(135deg,#f97316,#ea6a0a);border-radius:20px;padding:32px;color:#fff}
.devis-urg-box h3{font-size:1.2rem;font-weight:800;margin-bottom:10px;color:#fff}
.devis-urg-box p{font-size:.88rem;opacity:.9;margin-bottom:20px;line-height:1.6;color:#fff}
.devis-call{display:flex;align-items:center;gap:12px;background:#fff;border-radius:12px;padding:14px 18px;text-decoration:none;transition:transform .2s;margin-bottom:10px}
.devis-call:hover{transform:scale(1.02)}
.devis-call-num{font-family:'Sora',sans-serif;font-weight:800;font-size:1.1rem;color:#0a1628}
.devis-call-sub{font-size:.75rem;color:#64748b}
.devis-call-ico{width:40px;height:40px;background:#f97316;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.2rem}
.devis-info-box{background:#fff;border:1.5px solid #e2e8f0;border-radius:20px;padding:28px}
.devis-info-box h4{font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;color:#0a1628;margin-bottom:16px}
.devis-feats{display:flex;flex-direction:column;gap:12px}
.devis-feat{display:flex;align-items:center;gap:10px;font-size:.88rem;color:#334155}
.devis-feat-ico{width:32px;height:32px;background:#f0fdf4;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.devis-assur{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:16px;padding:20px;text-align:center}
.devis-assur p{font-size:.8rem;color:#64748b;margin-bottom:12px}
.devis-form-wrap .wpcf7-form .fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ARTICLE */
.art-layout{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start}
.art-main{min-width:0}
.art-header{margin-bottom:32px}
.art-header .art-tag{margin-bottom:16px}
.art-header h1{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;color:#0a1628;letter-spacing:-.5px;line-height:1.2;margin-bottom:16px}
.art-header .art-meta{color:#64748b;font-size:.85rem;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.art-header img{width:100%;height:420px;object-fit:cover;border-radius:20px;margin-top:28px}
.art-body{font-size:1rem;color:#334155;line-height:1.85}
.art-body h2{font-family:'Sora',sans-serif;font-size:1.5rem;font-weight:800;color:#0a1628;margin:40px 0 16px;padding-top:8px;border-top:2px solid #f1f5f9}
.art-body h3{font-family:'Sora',sans-serif;font-size:1.15rem;font-weight:700;color:#0a1628;margin:28px 0 12px}
.art-body p{margin-bottom:20px;line-height:1.85}
.art-body ul,.art-body ol{padding-left:24px;margin-bottom:20px;display:block}
.art-body ul li,.art-body ol li{margin-bottom:8px;line-height:1.7}
.art-body strong{color:#0a1628}
.art-body a{color:#1a56db;text-decoration:underline}
.art-body a:hover{color:#1d4ed8}
.art-body img{border-radius:12px;margin:28px 0;width:100%;height:auto}
.art-cta{background:linear-gradient(135deg,#0a1628,#0f2447);border-radius:20px;padding:36px;text-align:center;margin-top:40px}
.art-cta h3{font-size:1.3rem;font-weight:800;color:#fff;margin-bottom:10px}
.art-cta p{color:#94a3b8;font-size:.92rem;margin-bottom:24px;line-height:1.6}
.art-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.art-side{display:flex;flex-direction:column;gap:20px;position:sticky;top:88px}
.art-side-urg{background:linear-gradient(135deg,#f97316,#ea6a0a);border-radius:20px;padding:28px;color:#fff}
.art-side-urg h4{font-size:1.1rem;font-weight:800;margin-bottom:8px;color:#fff}
.art-side-urg p{font-size:.85rem;opacity:.9;margin-bottom:18px;line-height:1.6;color:#fff}
.art-related h4{font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;color:#0a1628;margin-bottom:16px}
.art-related-list{display:flex;flex-direction:column;gap:12px}
.art-related-item{display:flex;gap:12px;align-items:flex-start;text-decoration:none;padding:12px;border-radius:12px;transition:background .2s;background:#f8fafc}
.art-related-item:hover{background:#eff6ff}
.art-related-ph{width:64px;height:64px;border-radius:8px;flex-shrink:0;background:linear-gradient(135deg,#0a1628,#1a3a6b);display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.art-related-txt{font-size:.82rem;font-weight:600;color:#0a1628;line-height:1.35}
.art-related-date{font-size:.72rem;color:#64748b;margin-top:3px}

/* ===== RESPONSIVE 1024px ===== */
@media(max-width:1024px){
.yn{padding:0 24px}
.yn-center{gap:16px}
.hero{padding:64px 24px}
.hero-inner{grid-template-columns:1fr 380px;gap:40px}
.yp-s{padding:72px 24px}
.urg-grid{grid-template-columns:repeat(2,1fr)}
.about-grid{grid-template-columns:1fr;gap:40px}
.about-img{height:360px}
.proc-grid{grid-template-columns:repeat(2,1fr)}
.real-grid{grid-template-columns:repeat(2,1fr)}
.avis-grid{grid-template-columns:1fr 1fr}
.zones-grid{grid-template-columns:repeat(2,1fr)}
.blog-grid{grid-template-columns:repeat(2,1fr)}
.ft-in{grid-template-columns:1fr 1fr 1fr;gap:32px}
.ft-in>div:first-child{grid-column:1/-1}
.devis-grid{grid-template-columns:1fr;gap:32px}
.devis-aside{position:static}
.art-layout{grid-template-columns:1fr;gap:32px}
.art-side{position:static}
.art-header img{height:300px}
.bl-grid{grid-template-columns:1fr}
.bl-side{position:static}
}

/* ===== RESPONSIVE MOBILE 768px ===== */
@media(max-width:768px){
/* NAV MOBILE */
.yn{padding:0 16px;height:60px}
.yn-center{display:none}
.btn-dv-nav{display:none}
.btn-urg-nav{font-size:.78rem;padding:9px 14px;gap:5px}
.yn-ham{display:flex}

/* Menu plein écran */
.yn-mob{padding-top:60px}

/* Hero */
.hero{margin-top:60px;padding:40px 16px 48px}
.hero-inner{grid-template-columns:1fr;gap:0}
.hero-card{display:none}
.hero h1{font-size:clamp(1.8rem,7vw,2.4rem);letter-spacing:-1px;margin-bottom:16px}
.hero-sub{font-size:.95rem;margin-bottom:24px}
.hero-stats{gap:20px;margin-bottom:28px}
.hs strong{font-size:1.6rem}
.hs span{font-size:.72rem}
.hero-ctas{flex-direction:column;gap:12px}
.hero-ctas a{justify-content:center;padding:16px 24px}

/* Page hero */
.ph{padding:44px 16px;margin-top:60px}
.ph h1{font-size:clamp(1.5rem,6vw,2rem);margin-bottom:12px}
.ph p{font-size:.95rem}
.ph-ctas{flex-direction:column;gap:10px}
.ph-ctas a{justify-content:center}

/* Trust bar */
.tbar{padding:10px 16px;overflow-x:auto}
.tbar-in{justify-content:flex-start;gap:12px;flex-wrap:nowrap}
.ti{font-size:.72rem;white-space:nowrap}

/* Sections */
.yp-s{padding:48px 16px}
.yp-h2{font-size:1.4rem}
.yp-sub{font-size:.9rem;margin-bottom:32px}

/* Cards */
.urg-grid{grid-template-columns:1fr;gap:12px}
.emg{padding:24px 20px;flex-direction:column;gap:20px}
.emg-left h3{font-size:1.15rem}
.emg-right{width:100%}
.btn-emg{justify-content:center}
.about-grid{grid-template-columns:1fr;gap:32px}
.about-img{height:240px}
.about-badge{position:static;display:inline-block;margin-top:16px}
.proc-grid{grid-template-columns:1fr;gap:12px}
.real-grid{grid-template-columns:1fr;gap:12px}
.rg img{height:200px}
.avis-header{flex-direction:column;align-items:flex-start;gap:12px}
.avis-grid{grid-template-columns:1fr;gap:12px}
.zones-grid{grid-template-columns:1fr 1fr;gap:10px}
.zc{padding:16px}
.zc-dept{font-size:1.1rem}
.blog-grid{grid-template-columns:1fr;gap:14px}

/* Footer */
.ft{padding:40px 16px 48px}
.ft-in{grid-template-columns:1fr;gap:28px}
.ft-bot{flex-direction:column;text-align:center;gap:8px}

/* CTA final */
.fcta{padding:56px 16px}
.fcta h2{font-size:1.6rem}
.fcta-ctas{flex-direction:column;gap:12px}
.fcta-ctas a{justify-content:center}

/* Devis */
.devis-grid{grid-template-columns:1fr;gap:24px}
.devis-aside{position:static}
.devis-form-wrap{padding:24px 16px}
.devis-form-wrap .wpcf7-form .fg-row{grid-template-columns:1fr}

/* Articles */
.art-layout{grid-template-columns:1fr;gap:24px}
.art-side{position:static}
.art-header img{height:220px;border-radius:14px}
.art-header h1{font-size:1.4rem}
.art-body h2{font-size:1.2rem}
.art-cta{padding:28px 16px}
.art-cta h3{font-size:1.1rem}
.art-cta-btns{flex-direction:column;gap:10px}
.art-cta-btns a{justify-content:center}

/* Blog liste */
.art-card{grid-template-columns:1fr}
.art-card-img,.art-card-ph{width:100%;height:160px;min-height:0}

/* CTA box */
.cta-box-inner{padding:32px 16px}
.cta-box-inner h2{font-size:1.3rem}
.cta-btns-row{flex-direction:column}
.cta-btns-row a{justify-content:center}
}

/* 480px */
@media(max-width:480px){
.hero h1{font-size:1.6rem}
.zones-grid{grid-template-columns:1fr}
.btn-urg-nav{font-size:.75rem;padding:8px 12px}
.yn-brand{font-size:1rem}
}

/* ============================================================
   v1.5 — STICKY CTAs MOBILE (Appeler + WhatsApp)
   ============================================================ */
.yzm-sticky-cta{position:fixed;bottom:12px;left:12px;right:12px;display:none;gap:10px;z-index:9990;pointer-events:none}
.yzm-sticky-call,.yzm-sticky-wa{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 18px;border-radius:14px;font-family:'Sora',sans-serif;font-weight:700;font-size:.95rem;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.25);pointer-events:auto;transition:transform .15s ease,box-shadow .15s ease}
.yzm-sticky-call{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;animation:yzmPulseCall 2.4s ease-in-out infinite}
.yzm-sticky-wa{background:#25D366;color:#fff}
.yzm-sticky-call:active,.yzm-sticky-wa:active{transform:scale(.97);box-shadow:0 4px 12px rgba(0,0,0,.2)}
.yzm-sticky-call svg,.yzm-sticky-wa svg{flex-shrink:0}
.yzm-sticky-label{white-space:nowrap}
@keyframes yzmPulseCall{0%,100%{box-shadow:0 8px 24px rgba(249,115,22,.4)}50%{box-shadow:0 8px 32px rgba(249,115,22,.7)}}
@media(max-width:768px){
.yzm-sticky-cta{display:flex}
body{padding-bottom:80px}
}

/* ============================================================
   v1.5 — CAROUSEL LOGOS ASSURANCES (Section "Ils nous font confiance")
   ============================================================ */
.yzm-trust{padding:64px 20px;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);overflow:hidden}
.yzm-trust-inner{max-width:1280px;margin:0 auto;text-align:center}
.yzm-trust-lbl{display:inline-block;font-family:'Sora',sans-serif;font-size:.78rem;font-weight:700;color:#f97316;letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px}
.yzm-trust h2{font-family:'Sora',sans-serif;font-size:1.9rem;font-weight:800;color:#0a1628;margin:0 0 8px;line-height:1.2}
.yzm-trust-sub{color:#64748b;font-size:1rem;margin:0 0 36px;max-width:680px;margin-left:auto;margin-right:auto}
.yzm-trust-track-wrap{position:relative;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%)}
.yzm-trust-track{display:flex;gap:64px;align-items:center;animation:yzmTrustScroll 32s linear infinite;width:max-content}
.yzm-trust-track:hover{animation-play-state:paused}
.yzm-trust-logo{display:flex;align-items:center;justify-content:center;height:50px;flex-shrink:0;filter:grayscale(100%) brightness(.6);opacity:.7;transition:filter .25s ease,opacity .25s ease}
.yzm-trust-logo:hover{filter:grayscale(0) brightness(1);opacity:1}
.yzm-trust-logo img{max-height:50px;max-width:160px;width:auto;height:auto;object-fit:contain}
.yzm-trust-name{font-family:'Sora',sans-serif;font-weight:700;font-size:.95rem;color:#475569;letter-spacing:.5px;white-space:nowrap}
.yzm-trust-note{margin-top:36px;font-size:.85rem;color:#94a3b8;font-style:italic;max-width:720px;margin-left:auto;margin-right:auto;line-height:1.5}
@keyframes yzmTrustScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:768px){
.yzm-trust{padding:44px 16px}
.yzm-trust h2{font-size:1.4rem}
.yzm-trust-sub{font-size:.9rem;margin-bottom:24px}
.yzm-trust-track{gap:40px;animation-duration:24s}
.yzm-trust-logo{height:36px}
.yzm-trust-logo img{max-height:36px;max-width:110px}
.yzm-trust-note{font-size:.78rem;margin-top:24px}
}

/* ============================================================
   v1.5 — SECTION "TOUS NOS SERVICES" HOMEPAGE (grille premium)
   ============================================================ */
.yzm-services-all{padding:72px 20px;background:#fff}
.yzm-services-inner{max-width:1280px;margin:0 auto}
.yzm-services-head{text-align:center;margin-bottom:48px}
.yzm-services-head .yzm-trust-lbl{color:#3b82f6}
.yzm-services-head h2{font-family:'Sora',sans-serif;font-size:2.1rem;font-weight:800;color:#0a1628;margin:0 0 12px;line-height:1.2}
.yzm-services-head p{color:#475569;font-size:1.05rem;max-width:680px;margin:0 auto;line-height:1.6}
.yzm-services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.yzm-svc-card{position:relative;display:flex;flex-direction:column;padding:28px 24px;background:#fff;border:1px solid #e2e8f0;border-radius:16px;text-decoration:none;color:inherit;transition:all .25s cubic-bezier(.4,0,.2,1);overflow:hidden}
.yzm-svc-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,#f97316,#3b82f6);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.yzm-svc-card:hover{border-color:#cbd5e1;transform:translateY(-4px);box-shadow:0 16px 32px -8px rgba(15,23,42,.12)}
.yzm-svc-card:hover::before{transform:scaleX(1)}
.yzm-svc-card.featured{background:linear-gradient(135deg,#0a1628 0%,#1e293b 100%);color:#fff;border-color:#0a1628}
.yzm-svc-card.featured .yzm-svc-arrow{color:#f97316}
.yzm-svc-card.featured .yzm-svc-cat{color:#fb923c}
.yzm-svc-card.featured p{color:#cbd5e1}
.yzm-svc-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff7ed;color:#f97316;border-radius:12px;margin-bottom:18px;transition:transform .25s ease}
.yzm-svc-card.featured .yzm-svc-icon{background:rgba(249,115,22,.15);color:#fb923c}
.yzm-svc-card:hover .yzm-svc-icon{transform:scale(1.08) rotate(-3deg)}
.yzm-svc-cat{font-family:'Sora',sans-serif;font-size:.7rem;font-weight:700;color:#3b82f6;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.yzm-svc-card h3{font-family:'Sora',sans-serif;font-size:1.15rem;font-weight:700;margin:0 0 10px;line-height:1.3}
.yzm-svc-card p{font-size:.92rem;color:#64748b;margin:0 0 18px;line-height:1.55;flex-grow:1}
.yzm-svc-arrow{display:inline-flex;align-items:center;gap:6px;font-family:'Sora',sans-serif;font-size:.85rem;font-weight:600;color:#0a1628;margin-top:auto}
.yzm-svc-card.featured .yzm-svc-arrow{color:#fb923c}
.yzm-svc-arrow svg{transition:transform .2s ease}
.yzm-svc-card:hover .yzm-svc-arrow svg{transform:translateX(4px)}
.yzm-svc-badge{position:absolute;top:14px;right:14px;background:#ef4444;color:#fff;font-family:'Sora',sans-serif;font-size:.65rem;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.06em;text-transform:uppercase}
@media(max-width:768px){
.yzm-services-all{padding:48px 16px}
.yzm-services-head h2{font-size:1.5rem}
.yzm-services-head p{font-size:.95rem}
.yzm-services-grid{grid-template-columns:1fr;gap:14px}
.yzm-svc-card{padding:22px 20px}
.yzm-svc-card h3{font-size:1.05rem}
.yzm-svc-icon{width:42px;height:42px;margin-bottom:14px}
}

/* ============================================================
   v1.5 — POLISH MOBILE-FIRST (typo, spacing, hero)
   ============================================================ */
@media(max-width:768px){
.hero{padding:36px 16px 28px}
.hero h1{font-size:1.85rem;line-height:1.15;margin-bottom:14px}
.hero-sub{font-size:.95rem;line-height:1.5}
.hero-stats{gap:10px}
.hero-stats .hs{padding:10px 12px}
.hero-stats .hs strong{font-size:1.1rem}
.hero-stats .hs span{font-size:.7rem}
.hero-ctas{flex-direction:column;gap:10px}
.hero-ctas a{width:100%;text-align:center;padding:14px 18px}
.btn-call,.btn-ghost,.btn-primary,.btn-blue{font-size:.95rem;padding:13px 18px}
.yp-h2{font-size:1.55rem;line-height:1.2}
.yp-sub{font-size:.95rem}
.yp-s,.yp-s-alt{padding:48px 16px}
.uc{padding:22px 20px}
.uc h3{font-size:1.05rem}
.fcta h2{font-size:1.6rem;line-height:1.2}
.fcta-ctas{flex-direction:column;gap:10px}
.fcta-ctas a{width:100%;text-align:center}
}
@media(max-width:480px){
.hero h1{font-size:1.55rem}
.hero-stats{grid-template-columns:repeat(2,1fr)}
.yp-h2{font-size:1.35rem}
.uc-ico{width:48px;height:48px;font-size:1.4rem}
}

/* ============================================================
   v1.5 — Tarifs grille (page dépannage plomberie)
   ============================================================ */
.yzm-pricing{margin:40px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.yzm-pricing-card{padding:24px 22px;background:#fff;border:1px solid #e2e8f0;border-radius:16px;position:relative}
.yzm-pricing-card.highlight{border:2px solid #f97316;background:linear-gradient(180deg,#fff7ed 0%,#fff 100%)}
.yzm-pricing-card h4{font-family:'Sora',sans-serif;font-size:1.05rem;font-weight:700;color:#0a1628;margin:0 0 12px}
.yzm-pricing-price{font-family:'Sora',sans-serif;font-size:1.8rem;font-weight:800;color:#f97316;margin-bottom:6px;line-height:1}
.yzm-pricing-price small{font-size:.7rem;color:#64748b;font-weight:500;letter-spacing:.05em;text-transform:uppercase;display:block;margin-top:4px}
.yzm-pricing-list{list-style:none;margin:14px 0 0;padding:0}
.yzm-pricing-list li{font-size:.9rem;color:#475569;padding:6px 0;display:flex;align-items:flex-start;gap:8px;line-height:1.4}
.yzm-pricing-list li::before{content:"✓";color:#10b981;font-weight:800;flex-shrink:0}
.yzm-pricing-badge{position:absolute;top:-10px;right:14px;background:#f97316;color:#fff;font-size:.7rem;font-family:'Sora',sans-serif;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.05em;text-transform:uppercase}

/* ============================================================
   v1.5 — FAQ accordéon (page dépannage)
   ============================================================ */
.yzm-faq{margin:48px 0;max-width:860px;margin-left:auto;margin-right:auto}
.yzm-faq-item{border-bottom:1px solid #e2e8f0}
.yzm-faq-item summary{cursor:pointer;padding:20px 0;font-family:'Sora',sans-serif;font-size:1rem;font-weight:600;color:#0a1628;display:flex;justify-content:space-between;align-items:center;gap:16px;list-style:none}
.yzm-faq-item summary::-webkit-details-marker{display:none}
.yzm-faq-item summary::after{content:"+";font-size:1.5rem;font-weight:400;color:#f97316;transition:transform .2s ease;flex-shrink:0}
.yzm-faq-item[open] summary::after{content:"−"}
.yzm-faq-item summary:hover{color:#f97316}
.yzm-faq-content{padding:0 0 20px;color:#475569;font-size:.95rem;line-height:1.65}
@media(max-width:768px){
.yzm-faq-item summary{font-size:.92rem;padding:16px 0}
.yzm-faq-content{font-size:.88rem}
}

/* ============================================================
   v1.6 — PAGES VILLES : Quartiers, nearby cards, sections villes
   ============================================================ */
.yzm-quartiers{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:24px auto 0;max-width:780px}
.yzm-quartier{display:inline-flex;align-items:center;gap:6px;background:#f1f5f9;color:#0a1628;font-family:'Sora',sans-serif;font-weight:600;font-size:.82rem;padding:8px 14px;border-radius:999px;border:1px solid #e2e8f0;transition:all .2s ease;line-height:1.2}
.yzm-quartier:hover{background:#fff7ed;border-color:#fdba74;color:#9a3412}
.yzm-nearby{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:24px}
.yzm-nearby-card{display:flex;align-items:center;gap:10px;padding:16px 18px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;text-decoration:none;color:#0a1628;font-family:'Sora',sans-serif;font-weight:600;font-size:.92rem;transition:all .2s ease}
.yzm-nearby-card:hover{border-color:#f97316;background:#fff7ed;transform:translateY(-2px);box-shadow:0 8px 20px -8px rgba(249,115,22,.25)}
.yzm-nearby-icon{font-size:1.1rem;flex-shrink:0}
.yzm-nearby-name{flex:1}
.yzm-nearby-arrow{color:#f97316;font-weight:700;transition:transform .2s ease}
.yzm-nearby-card:hover .yzm-nearby-arrow{transform:translateX(4px)}
@media(max-width:768px){
.yzm-quartiers{gap:6px}
.yzm-quartier{font-size:.75rem;padding:6px 11px}
.yzm-nearby{grid-template-columns:1fr;gap:10px}
.yzm-nearby-card{padding:14px 16px;font-size:.88rem}
}

/* ============================================================
   v1.6 — SECTION HOMEPAGE : Réseau des villes (maillage SEO)
   ============================================================ */
.yzm-cities-net{padding:64px 20px;background:linear-gradient(180deg,#f8fafc 0%,#fff 100%)}
.yzm-cities-inner{max-width:1280px;margin:0 auto;text-align:center}
.yzm-cities-net h2{font-family:'Sora',sans-serif;font-size:1.9rem;font-weight:800;color:#0a1628;margin:0 0 12px;line-height:1.2}
.yzm-cities-net .yp-sub{margin-bottom:36px}
.yzm-cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;text-align:left}
.yzm-city-card{display:flex;align-items:center;gap:12px;padding:18px 20px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;text-decoration:none;color:#0a1628;transition:all .2s ease}
.yzm-city-card:hover{border-color:#f97316;background:#fff7ed;transform:translateY(-2px);box-shadow:0 12px 24px -10px rgba(249,115,22,.2)}
.yzm-city-flag{width:36px;height:36px;background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;font-family:'Sora',sans-serif;font-weight:800;font-size:.7rem;display:flex;align-items:center;justify-content:center;border-radius:10px;flex-shrink:0}
.yzm-city-body{flex:1;min-width:0}
.yzm-city-body strong{display:block;font-family:'Sora',sans-serif;font-weight:700;font-size:.95rem;color:#0a1628;line-height:1.25}
.yzm-city-body span{display:block;font-size:.78rem;color:#64748b;margin-top:2px}
.yzm-city-arr{color:#f97316;font-weight:700;flex-shrink:0;transition:transform .2s ease}
.yzm-city-card:hover .yzm-city-arr{transform:translateX(4px)}
@media(max-width:768px){
.yzm-cities-net{padding:44px 16px}
.yzm-cities-net h2{font-size:1.4rem}
.yzm-cities-grid{grid-template-columns:1fr;gap:10px}
.yzm-city-card{padding:14px 16px}
}

/* ============================================================
   v1.6 — GOOGLE REVIEWS PLACEHOLDER (structure prête)
   ============================================================ */
.yzm-greviews{padding:64px 20px;background:#fff}
.yzm-greviews-inner{max-width:1280px;margin:0 auto}
.yzm-greviews-head{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:32px}
.yzm-greviews-head h2{font-family:'Sora',sans-serif;font-size:1.9rem;font-weight:800;color:#0a1628;margin:0;line-height:1.2}
.yzm-greviews-head .yp-lbl{display:block;margin-bottom:8px}
.yzm-greviews-score{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:14px 20px}
.yzm-greviews-logo{width:34px;height:34px;flex-shrink:0;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;color:#4285F4;border:1px solid #e2e8f0}
.yzm-greviews-rating{display:flex;flex-direction:column;line-height:1.1}
.yzm-greviews-num{font-family:'Sora',sans-serif;font-weight:800;font-size:1.4rem;color:#0a1628}
.yzm-greviews-stars{color:#fbbf24;letter-spacing:1px;font-size:1rem}
.yzm-greviews-count{font-size:.78rem;color:#64748b;margin-top:2px}
.yzm-greviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.yzm-grev{padding:24px 22px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;transition:all .2s ease;display:flex;flex-direction:column}
.yzm-grev:hover{border-color:#cbd5e1;box-shadow:0 12px 24px -10px rgba(15,23,42,.12)}
.yzm-grev-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.yzm-grev-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1e40af);color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.yzm-grev-meta{flex:1;min-width:0}
.yzm-grev-name{font-family:'Sora',sans-serif;font-weight:700;font-size:.92rem;color:#0a1628;line-height:1.2}
.yzm-grev-date{font-size:.75rem;color:#64748b;margin-top:2px}
.yzm-grev-stars{color:#fbbf24;font-size:.95rem;letter-spacing:.5px;margin-bottom:8px}
.yzm-grev-text{font-size:.92rem;color:#334155;line-height:1.6;flex-grow:1}
.yzm-grev-src{margin-top:14px;font-size:.72rem;color:#94a3b8;display:flex;align-items:center;gap:6px}
.yzm-grev-src::before{content:"G";display:inline-flex;width:14px;height:14px;border-radius:50%;background:#4285F4;color:#fff;align-items:center;justify-content:center;font-weight:800;font-size:.6rem}
.yzm-greviews-cta{text-align:center;margin-top:32px}
.yzm-greviews-cta a{display:inline-flex;align-items:center;gap:8px;color:#4285F4;font-family:'Sora',sans-serif;font-weight:700;font-size:.92rem;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s ease}
.yzm-greviews-cta a:hover{border-color:#4285F4}
@media(max-width:768px){
.yzm-greviews{padding:44px 16px}
.yzm-greviews-head{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:24px}
.yzm-greviews-head h2{font-size:1.4rem}
.yzm-greviews-grid{grid-template-columns:1fr;gap:12px}
.yzm-grev{padding:20px 18px}
}

/* ============================================================
   v1.6 — POLISH MOBILE & PERF (final pass)
   ============================================================ */
/* Réduit le poids visuel des sections sur petits écrans */
@media(max-width:480px){
.yp-s,.yp-s-alt{padding:36px 14px}
.tbar-in{gap:10px;padding:14px 10px}
.tbar-in .ti{font-size:.72rem}
.uc{padding:18px 16px}
.uc h3{font-size:.98rem;margin-bottom:6px}
.uc p{font-size:.85rem}
.emg{padding:24px 18px;flex-direction:column;text-align:center;gap:16px}
.emg-right{width:100%;flex-direction:column}
.btn-emg,.btn-emg2{width:100%;text-align:center}
.fcta{padding:48px 16px}
.fcta h2{font-size:1.45rem}
.fcta p{font-size:.92rem}
.yzm-pricing{gap:12px;margin:24px 0}
.yzm-pricing-card{padding:18px 16px}
.yzm-pricing-price{font-size:1.5rem}
}

/* Touch targets : min 44x44 px sur mobile pour accessibilité */
@media(max-width:768px){
.yp a,.uc-lnk,.btn-call,.btn-ghost,.btn-blue,.btn-primary,.btn-emg,.btn-emg2{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.yn-mob-links a{min-height:48px}
}

/* CLS prevention : forcer hauteurs sur images et logos */
.yzm-trust-logo,.about-img-wrap img{min-height:0}
.about-img-wrap{aspect-ratio:4/3;overflow:hidden;border-radius:16px;position:relative}
.about-img-wrap img{width:100%;height:100%;object-fit:cover}

/* Lazy loading hint pour images hors viewport */
img[loading="lazy"]{background:#f1f5f9}

/* Reduced motion respect */
@media(prefers-reduced-motion:reduce){
.yzm-trust-track,.yzm-sticky-call,.yn-dot,.hero-pulse{animation:none!important}
*{transition-duration:0.01ms!important}
}

/* Print : cache éléments inutiles */
@media print{
.yzm-sticky-cta,.yn,.yn-mob,.ft,.fcta{display:none!important}
body{padding:0!important}
}

/* ============================================================
   v1.6 — Hero homepage : meilleure lisibilité titres mobile
   ============================================================ */
@media(max-width:768px){
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.hs{padding:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px}
.hs strong{font-size:1.2rem}
.hero-badge{font-size:.7rem;padding:5px 11px}
.hero h1 br{display:none}
.tbar{padding:12px 14px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbar-in{flex-wrap:nowrap;width:max-content;min-width:100%;justify-content:flex-start}
}

/* ============================================================
   v1.7 — SVG premium : adaptation taille selon contexte parent
   ============================================================ */
/* Dans les cartes services premium (homepage), le SVG doit être grand et coloré. */
.uc-ico .yzm-emoji-svg,
.yzm-svc-icon .yzm-emoji-svg{width:26px;height:26px;margin:0;vertical-align:middle}
.uc-ico.or .yzm-emoji-svg{color:#f97316}
.uc-ico.bl .yzm-emoji-svg{color:#3b82f6}
.uc-ico.gr .yzm-emoji-svg{color:#16a34a}
.yzm-svc-icon .yzm-emoji-svg{color:inherit}

/* Hero stats et tbar : icônes inline subtiles */
.tbar-in .ti .yzm-emoji-svg{width:16px;height:16px;color:#f97316;vertical-align:-2px;margin-right:4px}
.hero-card .hc-title .yzm-emoji-svg{width:18px;height:18px;color:#f97316;vertical-align:-3px}
.hero-card .hc-note .yzm-emoji-svg{width:14px;height:14px;color:#64748b;vertical-align:-2px}

/* Process steps : les emojis dans les .pc deviennent plus discrets */
.proc-grid .pc h3 .yzm-emoji-svg{width:18px;height:18px}

/* Badge étoile dans tbar/avis : couleur or */
.tbar-in .ti .yzm-emoji-svg[class*="star"],
.av-stars .yzm-emoji-svg,
.avis-stars-big .yzm-emoji-svg{color:#fbbf24}

/* SVG dans la grille tarifaire : marqueur check vert */
.yzm-pricing-list li .yzm-emoji-svg{width:14px;height:14px;color:#10b981;margin-right:6px}

/* SVG dans .emg-num (header urgence) — grand, orange, propre */
.emg-num .yzm-emoji-svg{width:22px;height:22px;color:#fb923c;vertical-align:-5px;margin-right:4px}

/* Boutons CTA : icônes phone proprement alignées */
.btn-call .yzm-emoji-svg,
.btn-emg .yzm-emoji-svg,
.btn-primary .yzm-emoji-svg{width:18px;height:18px;vertical-align:-3px;margin-right:6px;color:currentColor}

/* Cards services : icônes plus larges et centrées dans le carré orange */
.yzm-svc-card .yzm-svc-icon .yzm-emoji-svg{width:28px;height:28px}
.yzm-svc-card.featured .yzm-svc-icon .yzm-emoji-svg{color:#fb923c}

/* Évite le ratatinement sur très petit mobile */
@media(max-width:480px){
.uc-ico .yzm-emoji-svg,.yzm-svc-icon .yzm-emoji-svg{width:22px;height:22px}
}

/* ============================================================
   v1.7 — Polish mobile premium final
   ============================================================ */

/* === MOBILE PREMIUM (< 768px) — densité réduite, plus aéré === */
@media(max-width:768px){
  /* Sections principales — plus de respiration */
  .yp-s,.yp-s-alt{padding:52px 18px}
  .yp-h2{font-size:1.5rem;line-height:1.25;margin-bottom:10px}
  .yp-sub{font-size:.95rem;margin-bottom:28px;line-height:1.55}
  .yp-lbl{font-size:.7rem;letter-spacing:.12em;margin-bottom:10px;display:inline-block}

  /* Cards (urg-grid) — plus d'air, lecture plus claire */
  .urg-grid{grid-template-columns:1fr;gap:14px;margin-bottom:24px}
  .uc{padding:24px 22px;border-radius:18px}
  .uc h3{font-size:1.08rem;margin-bottom:10px;letter-spacing:-.2px}
  .uc p{font-size:.92rem;line-height:1.6;margin-bottom:14px;color:#475569}
  .uc-ico{width:46px;height:46px;border-radius:11px;margin-bottom:14px}
  .uc-lnk{font-size:.85rem}

  /* Cards services homepage — typographie aérée */
  .yzm-services-grid{gap:14px}
  .yzm-svc-card{padding:24px 22px;border-radius:18px}
  .yzm-svc-card h3{font-size:1.1rem;letter-spacing:-.2px;line-height:1.3;margin-bottom:10px}
  .yzm-svc-card p{font-size:.9rem;line-height:1.6;color:#475569;margin-bottom:16px}
  .yzm-svc-icon{width:46px;height:46px;margin-bottom:14px}
  .yzm-svc-cat{font-size:.66rem;margin-bottom:8px}
  .yzm-svc-arrow{font-size:.85rem}

  /* Section "Tous nos services" home — header */
  .yzm-services-all{padding:52px 18px}
  .yzm-services-head{margin-bottom:30px}
  .yzm-services-head h2{font-size:1.5rem;line-height:1.25}
  .yzm-services-head p{font-size:.92rem;line-height:1.55}

  /* Hero card mobile — formulaire moins serré */
  .hero-card{padding:24px 20px}
  .hc-title{font-size:1rem;line-height:1.3}
  .hc-sub{font-size:.85rem;line-height:1.5;margin-bottom:16px}

  /* About grid — image moins haute, contenu plus lisible */
  .about-content h2{font-size:1.55rem;line-height:1.2;margin-bottom:14px}
  .about-content > p{font-size:.95rem;line-height:1.65;margin-bottom:20px}
  .af{padding:14px 0;gap:14px}
  .af-ico{font-size:1.25rem;width:38px;height:38px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff7ed;border-radius:10px}
  .af-txt strong{font-size:.95rem;display:block;margin-bottom:3px}
  .af-txt span{font-size:.85rem;line-height:1.5;color:#64748b}

  /* Process grid — étapes plus aérées */
  .proc-grid{grid-template-columns:1fr;gap:16px}
  .pc{padding:22px 20px}
  .pc-num{width:34px;height:34px;font-size:1.05rem;margin-bottom:10px}
  .pc h3{font-size:1.05rem;margin-bottom:8px}
  .pc p{font-size:.9rem;line-height:1.55;color:#64748b}

  /* Realisations — grille 1 colonne, images plus belles */
  .real-grid{grid-template-columns:1fr;gap:14px}
  .rg{border-radius:18px;overflow:hidden}
  .rg img{height:220px}
  .rg-info{padding:18px}
  .rg-cat{font-size:.7rem;letter-spacing:.1em}
  .rg-title{font-size:1rem;line-height:1.3}

  /* Avis grid */
  .avis-grid{grid-template-columns:1fr;gap:14px}
  .av{padding:22px 20px;border-radius:18px}
  .av-txt{font-size:.92rem;line-height:1.6;margin:12px 0 16px}
  .av-auth{gap:12px}
  .av-av{width:38px;height:38px;font-size:.85rem;flex-shrink:0}
  .av-name{font-size:.92rem}
  .av-date,.av-verif{font-size:.75rem}

  /* Zones grid — 2 colonnes plus larges */
  .zones-grid{grid-template-columns:1fr 1fr;gap:12px}
  .zc{padding:18px 16px;border-radius:14px}
  .zc-dept{font-size:1.4rem}
  .zc-name{font-size:.85rem;margin:4px 0 2px}
  .zc-cities{font-size:.72rem;line-height:1.4}

  /* Blog grid */
  .blog-grid{grid-template-columns:1fr;gap:16px}
  .bc{border-radius:18px}
  .bc-img,.bc-ph{height:180px}
  .bc-body{padding:20px}
  .bc-body h3{font-size:1.05rem;line-height:1.3;margin:10px 0 8px}
  .bc-body p{font-size:.88rem;line-height:1.55}

  /* CTA finale */
  .fcta{padding:56px 18px}
  .fcta h2{font-size:1.5rem;line-height:1.25;margin-bottom:10px}
  .fcta p{font-size:.95rem;line-height:1.55;margin-bottom:24px}

  /* Avis header (note + étoiles) */
  .avis-header{flex-direction:column;align-items:flex-start;gap:18px;margin-bottom:24px}
  .avis-big{font-size:2.5rem}
  .avis-stars-big{font-size:1.1rem}
  .avis-count{font-size:.85rem}

  /* Boutons CTA — typographie un cran plus grosse */
  .btn-call,.btn-primary,.btn-blue,.btn-ghost,.btn-emg,.btn-emg2{font-size:1rem;padding:14px 22px;border-radius:12px;letter-spacing:-.1px}

  /* Sticky CTAs — anneau de respiration au-dessus */
  body{padding-bottom:84px}
  .yzm-sticky-cta{bottom:14px}
  .yzm-sticky-call,.yzm-sticky-wa{padding:15px 18px;font-size:1rem;border-radius:14px}
}

/* === Petit mobile (< 480px) — densité encore plus optimisée === */
@media(max-width:480px){
  .yp-s,.yp-s-alt{padding:44px 16px}
  .yp-h2{font-size:1.35rem;line-height:1.25}
  .yp-sub{font-size:.9rem;margin-bottom:24px}
  .uc{padding:20px 18px}
  .uc h3{font-size:1.02rem}
  .uc p{font-size:.88rem}
  .yzm-svc-card{padding:20px 18px}
  .yzm-svc-card h3{font-size:1.02rem}
  .yzm-svc-card p{font-size:.86rem}
  .pc{padding:18px 16px}
  .rg img{height:180px}
  .blog-grid .bc-img,.blog-grid .bc-ph{height:160px}
  .fcta{padding:44px 16px}
  .fcta h2{font-size:1.3rem}
  .yzm-cities-net{padding:44px 16px}
  .yzm-city-card{padding:14px 16px}
  .yzm-greviews{padding:44px 16px}
  .yzm-grev{padding:18px 16px}
  .yzm-grev-text{font-size:.88rem;line-height:1.5}
  .zones-grid{grid-template-columns:1fr;gap:10px}
}

/* === Optimisation densité homepage hero stats mobile === */
@media(max-width:768px){
  .hero{padding:48px 18px 36px}
  .hero h1{font-size:2rem;line-height:1.1;letter-spacing:-1px;margin-bottom:16px}
  .hero-sub{font-size:1rem;line-height:1.6;margin-bottom:24px;color:#cbd5e1}
  .hero-badge{font-size:.72rem;padding:6px 13px;margin-bottom:18px}
  .hero-stats{margin-bottom:28px}
  .hero-ctas{margin-top:8px}
}
@media(max-width:480px){
  .hero{padding:36px 16px 28px}
  .hero h1{font-size:1.7rem;letter-spacing:-.5px}
  .hero-sub{font-size:.95rem}
  .hero-stats .hs{padding:10px 8px}
  .hero-stats .hs strong{font-size:1.05rem}
  .hero-stats .hs span{font-size:.66rem;line-height:1.2}
}

/* === Page hero (.ph) interne — proportions mobile === */
@media(max-width:768px){
  .ph{padding:56px 20px 44px}
  .ph h1{font-size:1.85rem;line-height:1.15;letter-spacing:-.5px}
  .ph p{font-size:.98rem;line-height:1.6;color:#cbd5e1}
  .ph-label{font-size:.72rem;padding:5px 13px}
  .ph-ctas{gap:10px;margin-top:24px;flex-direction:column;align-items:stretch}
  .ph-ctas a{width:100%;text-align:center;padding:14px 20px}
}

/* === tbar (badge bar sous hero) — scroll horizontal premium === */
@media(max-width:768px){
  .tbar{padding:14px 0;background:linear-gradient(180deg,#fff,#f8fafc)}
  .tbar-in{padding:0 16px;gap:12px;display:flex;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .tbar-in::-webkit-scrollbar{display:none}
  .tbar-in .ti{font-size:.78rem;padding:8px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:999px;white-space:nowrap;flex-shrink:0;font-family:'Sora',sans-serif;font-weight:600;color:#334155}
}

/* === Header mobile (menu hamburger) — espacement optimisé === */
@media(max-width:768px){
  .yn{padding:0 18px;height:62px}
  .yn-center{display:none}
  .yn-ham{display:flex}
  .yn-right .btn-urg-nav{font-size:.78rem;padding:8px 12px;gap:5px}
  .hero{margin-top:62px}
  .ph{margin-top:62px}
}

/* === Section emergency (.emg) — refonte mobile premium === */
@media(max-width:768px){
  .emg{flex-direction:column;align-items:stretch;gap:18px;padding:24px 22px;border-radius:18px;text-align:center}
  .emg-left h3{font-size:1.2rem;margin-bottom:6px}
  .emg-left p{font-size:.92rem;line-height:1.55}
  .emg-right{flex-direction:column;gap:10px;width:100%}
  .btn-emg,.btn-emg2{width:100%;padding:14px 18px}
  .emg-num{font-size:1rem}
  .emg-sub{font-size:.78rem}
}

/* === Footer mobile premium === */
@media(max-width:768px){
  .ft{padding:48px 20px 32px}
  .ft-in{grid-template-columns:1fr;gap:32px}
  .ft-col h4{font-size:.95rem;margin-bottom:14px}
  .ft-col ul li{margin-bottom:8px}
  .ft-col ul li a{font-size:.9rem}
  .ft-bot{flex-direction:column;align-items:flex-start;gap:8px;padding-top:24px;font-size:.78rem;text-align:left}
}

/* === Grille tarifaire (.yzm-pricing) mobile === */
@media(max-width:768px){
  .yzm-pricing{grid-template-columns:1fr;gap:14px;margin:28px 0}
  .yzm-pricing-card{padding:22px 20px;border-radius:16px}
  .yzm-pricing-card h4{font-size:1.05rem;margin-bottom:10px}
  .yzm-pricing-price{font-size:1.6rem}
  .yzm-pricing-price small{font-size:.65rem}
  .yzm-pricing-list li{font-size:.88rem;padding:5px 0}
}

/* ============================================================
   v1.8 — PAGE BLOG /nos-articles/ : refonte mobile premium éditoriale
   Inspiré Medium / Linear / Stripe blog
   ============================================================ */

/* === DESKTOP : raffinements légers === */
.art-feat h2{font-size:1.6rem;letter-spacing:-.5px}
.art-feat-body{padding:36px}
.art-feat-img{height:300px}
.art-card{transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.art-card h3{font-size:1.08rem;line-height:1.35;letter-spacing:-.2px}
.art-card p{font-size:.88rem;line-height:1.65;color:#475569}
.art-card .art-meta{font-size:.75rem;color:#94a3b8;display:flex;gap:14px;align-items:center}
.art-card .art-meta span{display:inline-flex;align-items:center;gap:5px}
.art-card-body{padding:24px 26px;gap:10px}
.arts-list{gap:24px}

/* === TABLETTE (< 1024px) : passage progressif === */
@media(max-width:1024px){
  .bl-grid{grid-template-columns:1fr 280px;gap:36px}
  .art-feat-img{height:240px}
  .art-feat-body{padding:28px}
  .art-feat h2{font-size:1.4rem}
  .art-card{grid-template-columns:140px 1fr}
  .art-card-img,.art-card-ph{width:140px;min-height:130px}
  .art-card-body{padding:18px 20px}
}

/* === MOBILE PREMIUM ÉDITORIAL (< 768px) === */
@media(max-width:768px){
  /* Layout général */
  .bl-grid{grid-template-columns:1fr;gap:40px}
  .bl-side{position:static;gap:24px}

  /* Article à la une — vraie carte hero éditoriale */
  .art-feat{margin-bottom:24px;border-radius:22px}
  .art-feat-img{height:220px}
  .art-feat-body{padding:24px 22px 28px}
  .art-feat-body .art-tag{font-size:.7rem;padding:5px 11px;letter-spacing:.08em;margin-bottom:14px}
  .art-feat-body .art-meta{margin:0 0 14px;font-size:.78rem;gap:12px;color:#94a3b8;display:flex;flex-wrap:wrap}
  .art-feat-body .art-meta span{display:inline-flex;align-items:center;gap:4px}
  .art-feat h2{font-size:1.4rem;line-height:1.25;letter-spacing:-.4px;margin-bottom:12px;color:#0a1628;font-weight:800}
  .art-feat p{font-size:.95rem;line-height:1.65;color:#475569;margin-bottom:16px}
  .art-feat .art-lire{font-size:.88rem;color:#1a56db;display:inline-flex;align-items:center;gap:6px;font-family:'Sora',sans-serif;font-weight:700}

  /* Cards articles — layout vertical premium */
  .arts-list{gap:20px}
  .art-card{grid-template-columns:1fr;border-radius:20px;overflow:hidden}
  .art-card-img,.art-card-ph{width:100%;height:200px;min-height:0}
  .art-card-ph{font-size:3rem;background:linear-gradient(135deg,#0a1628,#1a3a6b)}
  .art-card-body{padding:24px 22px 26px;gap:12px}
  .art-card-body > div{display:flex;flex-direction:column;gap:10px}
  .art-card .art-tag{font-size:.66rem;padding:4px 10px;letter-spacing:.08em;align-self:flex-start;margin-bottom:0}
  .art-card .art-meta{font-size:.75rem;color:#94a3b8;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:0}
  .art-card .art-meta span{display:inline-flex;align-items:center;gap:4px}
  .art-card h3{font-size:1.15rem;line-height:1.3;color:#0a1628;letter-spacing:-.2px;font-weight:700;margin:0}
  .art-card p{font-size:.92rem;line-height:1.65;color:#475569;margin:0}
  .art-card .art-lire{font-size:.85rem;color:#1a56db;display:inline-flex;align-items:center;gap:6px;font-family:'Sora',sans-serif;font-weight:700;align-self:flex-start;margin-top:4px}

  /* yp-lbl entre sections blog : plus de respiration */
  .bl-grid > div > .yp-lbl{margin-top:8px;margin-bottom:14px;display:inline-block}
  .bl-grid > div > .yp-h2{margin-bottom:24px;font-size:1.45rem;line-height:1.25;letter-spacing:-.3px}

  /* Sidebar mobile : devient une vraie zone secondaire */
  .bl-side{margin-top:16px}
  .urg-side{padding:26px 24px;border-radius:20px}
  .urg-side h4{font-size:1.15rem;margin-bottom:10px}
  .urg-side p{font-size:.92rem;line-height:1.55;margin-bottom:18px}
  .side-box{padding:22px;border-radius:18px}
  .side-box h4{font-size:1rem;margin-bottom:14px}

  /* Catégories sidebar mobile */
  .cats li a{padding:12px 16px;font-size:.92rem;min-height:44px}

  /* Articles populaires sidebar mobile */
  .pop-list{gap:8px}
  .pop-item{padding:12px 14px;display:flex;align-items:center;gap:10px;font-size:.88rem;line-height:1.4;border-radius:10px;background:#f8fafc;transition:background .2s ease;text-decoration:none;color:#334155;min-height:44px}
  .pop-item:hover{background:#fff7ed;color:#9a3412}
  .pop-emoji{font-size:1.05rem;flex-shrink:0}

  /* Newsletter box mobile */
  .nl-box{padding:24px;border-radius:18px}
  .nl-box h4{font-size:1.02rem;margin-bottom:8px}
  .nl-box p{font-size:.88rem;line-height:1.55;margin-bottom:14px}
  .nl-btn{padding:12px 18px;font-size:.92rem;min-height:44px;width:100%}
}

/* === Très petit mobile (< 480px) — encore plus aéré === */
@media(max-width:480px){
  .art-feat-img{height:180px}
  .art-feat-body{padding:22px 20px 26px}
  .art-feat h2{font-size:1.25rem}
  .art-feat p{font-size:.92rem}
  .art-card-img,.art-card-ph{height:180px}
  .art-card-body{padding:22px 20px}
  .art-card h3{font-size:1.08rem}
  .art-card p{font-size:.88rem}
  .arts-list{gap:18px}
  .urg-side{padding:22px 20px}
  .side-box{padding:20px}
}

/* ============================================================
   v1.8 — PAGES ARTICLES INDIVIDUELS : meilleure lisibilité mobile
   ============================================================ */
@media(max-width:768px){
  .art-layout{grid-template-columns:1fr;gap:28px}
  .art-side{position:static}
  .art-header h1{font-size:1.7rem;line-height:1.2;letter-spacing:-.4px;margin-bottom:14px;color:#0a1628;font-weight:800}
  .art-header img{height:240px;border-radius:16px;margin-top:20px}
  .art-meta{font-size:.78rem;color:#94a3b8;gap:14px;flex-wrap:wrap}
  .art-tag{font-size:.7rem;padding:5px 11px;letter-spacing:.08em;margin-bottom:14px;display:inline-block}

  /* Corps article : typographie premium */
  .art-body{font-size:1rem;line-height:1.75;color:#1f2937}
  .art-body p{margin-bottom:20px;font-size:1rem;line-height:1.75}
  .art-body h2{font-size:1.4rem;line-height:1.3;letter-spacing:-.3px;margin:36px 0 14px;color:#0a1628;font-weight:800}
  .art-body h3{font-size:1.15rem;line-height:1.35;margin:28px 0 12px;color:#0a1628;font-weight:700}
  .art-body ul,.art-body ol{margin:0 0 24px;padding-left:24px}
  .art-body li{font-size:1rem;line-height:1.75;margin-bottom:8px;color:#334155}
  .art-body strong{color:#0a1628;font-weight:700}
  .art-body a{color:#1a56db;text-decoration:underline;text-underline-offset:3px}

  /* Article CTA en bas */
  .art-cta{padding:28px 24px;border-radius:20px;margin-top:36px}
  .art-cta h3{font-size:1.25rem;line-height:1.3;margin-bottom:10px}
  .art-cta p{font-size:.95rem;line-height:1.55;margin-bottom:20px}
  .art-cta-btns{flex-direction:column;gap:10px}
  .art-cta-btns a{width:100%;text-align:center;padding:14px 20px}

  /* Sidebar article mobile */
  .art-side-urg{padding:24px 22px;border-radius:18px}
  .art-side-urg h4{font-size:1.1rem;margin-bottom:8px}
  .art-related-item{padding:12px 14px;gap:12px;min-height:48px;display:flex;align-items:center;font-size:.88rem}
  .art-related-ph{font-size:1.2rem;width:34px;height:34px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff7ed;border-radius:10px}
}
@media(max-width:480px){
  .art-header h1{font-size:1.5rem}
  .art-header img{height:200px}
  .art-body{font-size:.95rem}
  .art-body p{font-size:.95rem}
  .art-body h2{font-size:1.25rem}
  .art-body h3{font-size:1.08rem}
}

/* ============================================================
   v1.8 — Logos trust : structure encore plus premium
   ============================================================ */
/* Animation un peu plus lente et fluide pour rendu premium */
@keyframes yzm-trust-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.yzm-trust-track{animation:yzm-trust-scroll 42s linear infinite}
.yzm-trust-track-wrap{position:relative;overflow:hidden}
/* Fade edges plus marqués */
.yzm-trust-track-wrap::before,
.yzm-trust-track-wrap::after{content:'';position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.yzm-trust-track-wrap::before{left:0;background:linear-gradient(to right,#fff 30%,rgba(255,255,255,0))}
.yzm-trust-track-wrap::after{right:0;background:linear-gradient(to left,#fff 30%,rgba(255,255,255,0))}
.yzm-trust:hover .yzm-trust-track{animation-play-state:paused}

@media(max-width:768px){
  .yzm-trust{padding:48px 16px}
  .yzm-trust h2{font-size:1.5rem;line-height:1.25}
  .yzm-trust-sub{font-size:.92rem;line-height:1.55}
  .yzm-trust-track{animation-duration:32s}
  .yzm-trust-track-wrap::before,.yzm-trust-track-wrap::after{width:50px}
  .yzm-trust-logo{padding:0 22px}
  .yzm-trust-name{font-size:.88rem}
  .yzm-trust-note{font-size:.78rem;line-height:1.55;margin-top:24px;padding:0 4px}
}

/* ============================================================
   v1.8 — Google Reviews : raffinements premium
   ============================================================ */
.yzm-greviews-score{box-shadow:0 4px 16px rgba(15,23,42,.06)}
.yzm-grev{transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.yzm-grev:hover{transform:translateY(-2px)}

@media(max-width:768px){
  .yzm-greviews-head h2{line-height:1.25}
  .yzm-greviews-score{padding:12px 18px;gap:12px;align-self:flex-start}
  .yzm-greviews-num{font-size:1.25rem}
  .yzm-greviews-stars{font-size:.95rem}
  .yzm-greviews-count{font-size:.72rem}
}

/* ============================================================
   v1.8 — Cities net (section villes proches) : animation entrée
   ============================================================ */
.yzm-cities-grid > .yzm-city-card{opacity:0;animation:yzm-fade-in .35s ease-out forwards}
.yzm-cities-grid > .yzm-city-card:nth-child(1){animation-delay:.02s}
.yzm-cities-grid > .yzm-city-card:nth-child(2){animation-delay:.06s}
.yzm-cities-grid > .yzm-city-card:nth-child(3){animation-delay:.10s}
.yzm-cities-grid > .yzm-city-card:nth-child(4){animation-delay:.14s}
.yzm-cities-grid > .yzm-city-card:nth-child(5){animation-delay:.18s}
.yzm-cities-grid > .yzm-city-card:nth-child(6){animation-delay:.22s}
.yzm-cities-grid > .yzm-city-card:nth-child(7){animation-delay:.26s}
.yzm-cities-grid > .yzm-city-card:nth-child(8){animation-delay:.30s}
.yzm-cities-grid > .yzm-city-card:nth-child(n+9){animation-delay:.34s}
@keyframes yzm-fade-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){
  .yzm-cities-grid > .yzm-city-card{animation:none;opacity:1}
}

/* ============================================================
   v1.8 — Polish micro homepage : densité réduite, respirations
   ============================================================ */
/* Section "Tous nos services" : titre plus impactant */
.yzm-services-head h2{font-weight:800;letter-spacing:-.5px}
@media(min-width:1024px){
  .yzm-services-head h2{font-size:2.2rem;line-height:1.15}
  .yzm-services-head p{font-size:1.05rem;line-height:1.55;color:#475569;max-width:680px;margin:14px auto 0}
}

/* About-grid : alignement vertical impeccable */
.about-img-wrap{align-self:start}
.about-content{align-self:center}

/* Hero stats : harmonisation desktop */
@media(min-width:1024px){
  .hero-stats{gap:14px}
  .hs{padding:14px 16px}
}

/* ============================================================
   v1.8 — Cleanup final : suppression doublons & micro-optims
   ============================================================ */
/* Smooth scroll global premium */
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
}

/* Focus visible accessibilité (anneau orange propre) */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
summary:focus-visible{
  outline:2px solid #f97316;
  outline-offset:3px;
  border-radius:6px;
}

/* Selection text : orange brand */
::selection{background:#fed7aa;color:#7c2d12}

/* Scrollbars premium (desktop) */
@media(min-width:1024px){
  ::-webkit-scrollbar{width:10px;height:10px}
  ::-webkit-scrollbar-track{background:#f8fafc}
  ::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:5px}
  ::-webkit-scrollbar-thumb:hover{background:#94a3b8}
}

/* ============================================================
   v1.9 — POLISH BLOG : encore plus éditorial mobile
   ============================================================ */
@media(max-width:768px){
  /* Article à la une : respiration renforcée */
  .art-feat{margin-bottom:32px}
  .art-feat-body{padding:26px 22px 30px}
  .art-feat-body .art-tag{margin-bottom:16px}
  .art-feat-body .art-meta{margin:0 0 18px;line-height:1.4}
  .art-feat h2{margin-bottom:14px;line-height:1.22}
  .art-feat p{margin-bottom:18px;line-height:1.7;color:#475569}

  /* Cards articles : encore plus de respiration */
  .arts-list{gap:22px}
  .art-card-body{padding:26px 22px 28px;gap:14px}
  .art-card-body > div{gap:12px}
  .art-card h3{font-size:1.18rem;line-height:1.28}
  .art-card p{line-height:1.7;color:#475569}
  .art-card .art-meta{gap:14px;line-height:1.4}
  .art-card .art-lire{margin-top:6px;font-size:.88rem;letter-spacing:.1px}

  /* yp-lbl entre sections : plus de marge */
  .bl-grid > div > .yp-lbl{margin-top:14px;margin-bottom:16px}
  .bl-grid > div > .yp-h2{margin-bottom:28px}

  /* Sidebar : box plus distinctes */
  .bl-side{gap:18px}
  .side-box,.urg-side,.nl-box{margin:0}
}

@media(max-width:480px){
  .arts-list{gap:18px}
  .art-card-body{padding:22px 20px 24px}
  .art-card h3{font-size:1.1rem;line-height:1.3}
  .art-feat-body{padding:22px 20px 26px}
  .art-feat h2{font-size:1.3rem;line-height:1.22}
  .art-feat p{font-size:.92rem;line-height:1.65}
}

/* ============================================================
   v1.9 — AUDIT TABLETTE (768px → 1024px) : optimisations dédiées
   ============================================================ */
@media(min-width:769px) and (max-width:1024px){
  /* Sections : padding équilibré */
  .yp-s,.yp-s-alt{padding:64px 32px}
  .yp-h2{font-size:1.75rem;line-height:1.2}
  .yp-sub{font-size:1rem;margin-bottom:32px;max-width:680px;margin-left:auto;margin-right:auto}

  /* Hero tablette : équilibre */
  .hero{padding:64px 36px 56px}
  .hero-inner{gap:48px}
  .hero h1{font-size:2.4rem;line-height:1.1;letter-spacing:-1px}
  .hero-sub{font-size:1.05rem;line-height:1.6}
  .hero-stats{grid-template-columns:repeat(4,1fr);gap:12px}
  .hs{padding:14px 12px}
  .hs strong{font-size:1.25rem}
  .hs span{font-size:.75rem}

  /* Cards services : 2 colonnes équilibrées */
  .urg-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .uc{padding:24px}
  .uc h3{font-size:1.05rem}
  .uc p{font-size:.9rem}

  /* Section "Tous nos services" tablette : 3 colonnes lisibles */
  .yzm-services-grid{grid-template-columns:repeat(3,1fr);gap:18px}
  .yzm-svc-card{padding:24px 22px}
  .yzm-svc-card h3{font-size:1.05rem;line-height:1.3}
  .yzm-svc-card p{font-size:.9rem}

  /* About grid tablette : 2 colonnes équilibrées */
  .about-grid{grid-template-columns:1.1fr 1fr;gap:36px}
  .about-content h2{font-size:1.65rem;line-height:1.2}
  .about-content > p{font-size:.98rem;line-height:1.65}

  /* Process steps tablette : 4 colonnes 2x2 */
  .proc-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .pc{padding:24px}

  /* Réalisations tablette : 2 colonnes */
  .real-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .rg img{height:220px}

  /* Avis tablette : 2 colonnes */
  .avis-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .av{padding:24px}

  /* Zones tablette : 4 colonnes en 2x4 */
  .zones-grid{grid-template-columns:repeat(4,1fr);gap:14px}
  .zc{padding:18px 14px}
  .zc-dept{font-size:1.45rem}
  .zc-name{font-size:.9rem}
  .zc-cities{font-size:.74rem}

  /* Blog grid tablette : 2 colonnes propres */
  .blog-grid{grid-template-columns:repeat(2,1fr);gap:20px}

  /* Cards villes (yzm-cities-grid) tablette : 3 colonnes */
  .yzm-cities-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .yzm-city-card{padding:16px 18px}
  .yzm-city-body strong{font-size:.92rem}
  .yzm-city-body span{font-size:.76rem}

  /* Google Reviews tablette : 2 colonnes */
  .yzm-greviews-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .yzm-grev{padding:22px}

  /* Page Blog (/nos-articles/) tablette : sidebar 260px */
  .bl-grid{grid-template-columns:1fr 260px;gap:32px}
  .art-feat-img{height:260px}
  .art-feat-body{padding:30px}
  .art-card{grid-template-columns:160px 1fr}
  .art-card-img,.art-card-ph{width:160px;min-height:140px}
  .art-card-body{padding:20px 22px}

  /* Article individuel tablette : largeur lecture optimale */
  .art-layout{grid-template-columns:1fr 280px;gap:36px}
  .art-header h1{font-size:1.95rem;line-height:1.18}
  .art-header img{height:340px}
  .art-body{font-size:1rem;line-height:1.75}
  .art-body p{font-size:1rem;line-height:1.75}
  .art-body h2{font-size:1.5rem;margin:36px 0 14px}
  .art-body h3{font-size:1.2rem;margin:28px 0 12px}

  /* Devis tablette : aside en bas */
  .devis-grid{grid-template-columns:1fr;gap:32px}
  .devis-aside{display:grid;grid-template-columns:1fr 1fr;gap:18px}
  .devis-aside .devis-urg-box{grid-column:1/-1}

  /* Pricing tablette : 3 colonnes */
  .yzm-pricing{grid-template-columns:repeat(3,1fr);gap:18px}
  .yzm-pricing-card{padding:24px 22px}
  .yzm-pricing-price{font-size:1.65rem}

  /* FAQ tablette : padding confort */
  .yzm-faq-item summary{font-size:1rem;padding:18px 0}
  .yzm-faq-content{font-size:.95rem;line-height:1.7;padding:0 0 20px}

  /* CTA finale tablette */
  .fcta{padding:72px 36px}
  .fcta h2{font-size:1.85rem;line-height:1.2}

  /* Footer tablette : 3 colonnes */
  .ft-in{grid-template-columns:repeat(3,1fr);gap:36px}
  .ft-in > div:first-child{grid-column:1/-1}

  /* Page hero (.ph) tablette */
  .ph{padding:80px 36px 56px}
  .ph h1{font-size:2.1rem;line-height:1.15}
  .ph p{font-size:1.05rem;line-height:1.55}

  /* tbar tablette : visible sans scroll */
  .tbar{padding:14px 0}
  .tbar-in{padding:0 36px;flex-wrap:wrap;gap:10px;justify-content:center;width:auto}
  .tbar-in .ti{font-size:.8rem;padding:8px 14px}

  /* Quartiers chips tablette */
  .yzm-quartiers{gap:8px}
  .yzm-quartier{font-size:.82rem;padding:8px 14px}

  /* Nearby cities tablette : 3 colonnes */
  .yzm-nearby{grid-template-columns:repeat(3,1fr);gap:14px}
  .yzm-nearby-card{padding:14px 16px}

  /* Hero card formulaire tablette : largeur contrôlée */
  .hero-card{padding:26px 24px}
  .hc-title{font-size:1.05rem}
  .hc-sub{font-size:.9rem}

  /* Section emergency (.emg) tablette */
  .emg{padding:28px 26px;gap:24px;border-radius:20px}
  .emg-left h3{font-size:1.3rem}
  .emg-left p{font-size:.95rem;line-height:1.55}
  .emg-right{flex-direction:column;gap:10px;align-items:stretch;min-width:260px}
}

/* ============================================================
   v1.9 — Logos trust : préparation vrais SVG monochrome
   ============================================================ */
/* Quand on remplacera les <span> par des <img>, ces règles s'appliqueront */
.yzm-trust-track img{
  max-height:42px;
  max-width:140px;
  width:auto;
  height:auto;
  object-fit:contain;
  filter:grayscale(100%) brightness(.65) contrast(.9);
  opacity:.7;
  transition:filter .35s ease,opacity .35s ease;
}
.yzm-trust-track img:hover{
  filter:grayscale(0) brightness(1) contrast(1);
  opacity:1;
}
@media(min-width:769px) and (max-width:1024px){
  .yzm-trust-track img{max-height:38px;max-width:130px}
}
@media(max-width:768px){
  .yzm-trust-track img{max-height:32px;max-width:110px}
}

/* ============================================================
   v1.9 — Mentions légales / page sobre
   ============================================================ */
.yzm-mentions{padding:80px 32px;max-width:780px;margin:0 auto}
.yzm-mentions h1{font-family:'Sora',sans-serif;font-weight:800;font-size:2rem;letter-spacing:-.5px;color:#0a1628;margin:0 0 28px;line-height:1.2}
.yzm-mentions h2{font-family:'Sora',sans-serif;font-weight:700;font-size:1.2rem;color:#0a1628;margin:32px 0 12px;letter-spacing:-.2px}
.yzm-mentions p{font-size:1rem;line-height:1.75;color:#334155;margin:0 0 12px}
.yzm-mentions ul{margin:0 0 16px;padding-left:22px}
.yzm-mentions li{font-size:1rem;line-height:1.75;color:#334155;margin-bottom:6px}
.yzm-mentions strong{color:#0a1628;font-weight:700}
.yzm-mentions a{color:#1a56db;text-decoration:underline;text-underline-offset:3px}
@media(max-width:768px){
  .yzm-mentions{padding:56px 18px}
  .yzm-mentions h1{font-size:1.65rem}
  .yzm-mentions h2{font-size:1.12rem;margin:26px 0 10px}
  .yzm-mentions p,.yzm-mentions li{font-size:.95rem;line-height:1.7}
}

/* ============================================================
   v1.9 — Bloc humain intro pages villes (E-E-A-T)
   ============================================================ */
.yzm-human-intro{max-width:780px;margin:0 auto 32px;text-align:left}
.yzm-human-intro p{font-size:1rem;line-height:1.75;color:#334155;margin:0 0 14px}
.yzm-human-intro p:last-child{margin-bottom:0}
.yzm-human-intro strong{color:#0a1628;font-weight:700}
.yzm-human-intro em{color:#475569;font-style:italic}

@media(min-width:769px) and (max-width:1024px){
  .yzm-human-intro p{font-size:.98rem;line-height:1.7}
}

@media(max-width:768px){
  .yzm-human-intro{margin-bottom:24px}
  .yzm-human-intro p{font-size:.95rem;line-height:1.7;margin-bottom:12px}
}
@media(max-width:480px){
  .yzm-human-intro p{font-size:.92rem;line-height:1.65}
}

/* ============================================================
   v1.10 — TICKER tbar premium (scroll auto + swipe manuel)
   Sur toutes les pages contenant .tbar > .tbar-in > .ti
   ============================================================ */

/* Wrap propre, plus de risque d'overflow horizontal sur le viewport */
.tbar{
  background:linear-gradient(180deg,#fff,#f8fafc);
  border-top:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
  padding:14px 0;
  position:relative;
  overflow:hidden;
}

/* Fade edges premium */
.tbar::before,
.tbar::after{
  content:'';
  position:absolute;
  top:0;bottom:0;
  width:60px;
  z-index:2;
  pointer-events:none;
}
.tbar::before{
  left:0;
  background:linear-gradient(to right, #f8fafc 20%, rgba(248,250,252,0));
}
.tbar::after{
  right:0;
  background:linear-gradient(to left, #f8fafc 20%, rgba(248,250,252,0));
}

/* Scroll horizontal natif (swipe tactile compatible) */
.tbar-in{
  display:flex;
  flex-wrap:nowrap;
  gap:14px;
  width:max-content;
  padding:0 32px;
  /* L'animation ne s'applique QUE si .yzm-ticker-on est ajouté par le JS,
     pour éviter tout flash de contenu non animé si JS lent */
  animation:yzm-ticker 32s linear infinite;
  animation-play-state:running;
  will-change:transform;
}
.tbar-in:hover{animation-play-state:paused}

/* Sur swipe tactile : pause auto pendant 4s puis reprise */
.tbar-in.yzm-paused{animation-play-state:paused}

/* Sur prefers-reduced-motion : pas d'animation, scroll manuel uniquement */
@media (prefers-reduced-motion:reduce){
  .tbar-in{animation:none;width:auto;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .tbar-in::-webkit-scrollbar{display:none}
}

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

/* Badges modernes ticker */
.tbar-in .ti{
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex-shrink:0;
  white-space:nowrap;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:999px;
  padding:8px 16px;
  font-family:'Sora',sans-serif;
  font-weight:600;
  font-size:.82rem;
  color:#334155;
  line-height:1.2;
  box-shadow:0 1px 2px rgba(15,23,42,.03);
}

/* Mobile : animation plus rapide */
@media (max-width:768px){
  .tbar{padding:12px 0}
  .tbar::before,.tbar::after{width:36px}
  .tbar-in{animation-duration:26s;gap:10px;padding:0 16px}
  .tbar-in .ti{font-size:.78rem;padding:7px 13px}
}

/* ============================================================
   v1.10 — RÉALISATIONS Avant/Après premium
   Mini slider non destructif : <img src=après> + data-before=avant
   Le JS ajoute .yzm-ba (before/after) + crée la 2e image.
   ============================================================ */

/* Wrapper image — la card .rg reste exactement comme avant */
.rg.yzm-ba{position:relative}
.rg.yzm-ba .rg-imgs{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
  display:block;
  z-index:1;
}
.rg.yzm-ba .rg-overlay,
.rg.yzm-ba .rg-info{z-index:2}
.rg.yzm-ba .rg-ba-label,
.rg.yzm-ba .rg-ba-dots{z-index:3}
.rg.yzm-ba .rg-imgs img,
.rg.yzm-ba .rg-imgs .rg-ba-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:opacity .8s cubic-bezier(.4,0,.2,1);
  opacity:1;
}
.rg.yzm-ba .rg-imgs .rg-ba-img.is-before{opacity:0}
.rg.yzm-ba .rg-imgs.show-before .rg-ba-img.is-before{opacity:1}
.rg.yzm-ba .rg-imgs.show-before .rg-ba-img.is-after{opacity:0}

/* Sauvegarde de la height de l'image originale (le wrapper la force) */
.rg.yzm-ba .rg-imgs{height:240px;background:#0a1628}

/* Label "Avant / Après" — discret en haut à gauche */
.rg.yzm-ba .rg-ba-label{
  position:absolute;
  top:14px;
  left:14px;
  z-index:3;
  background:rgba(10,22,40,.78);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  color:#fff;
  font-family:'Sora',sans-serif;
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:6px 12px;
  border-radius:999px;
  pointer-events:none;
  transition:opacity .25s ease, transform .35s ease;
}
.rg.yzm-ba .rg-ba-label::before{
  content:"";
  display:inline-block;
  width:5px;height:5px;
  background:#f97316;
  border-radius:50%;
  margin-right:7px;
  vertical-align:middle;
  animation:yzm-ba-dot 1.6s ease-in-out infinite;
}
.rg.yzm-ba .rg-imgs.show-before ~ .rg-ba-label,
.rg.yzm-ba .rg-imgs.show-before .rg-ba-label{
  /* style label "Avant" */
}
@keyframes yzm-ba-dot{
  0%,100%{opacity:.4}
  50%{opacity:1}
}

/* Dots indicateurs (swipe manuel) */
.rg.yzm-ba .rg-ba-dots{
  position:absolute;
  bottom:14px;
  right:14px;
  z-index:3;
  display:flex;
  gap:5px;
  pointer-events:none;
}
.rg.yzm-ba .rg-ba-dots span{
  width:6px;height:6px;
  border-radius:50%;
  background:rgba(255,255,255,.45);
  transition:background .25s ease,transform .25s ease;
}
.rg.yzm-ba .rg-ba-dots span.active{
  background:#fff;
  transform:scale(1.3);
}

/* Sur hover, overlay+info plus visibles ; on garde le comportement existant */
.rg.yzm-ba:hover .rg-imgs img,
.rg.yzm-ba:hover .rg-imgs .rg-ba-img{transform:scale(1.04)}

/* Tablette : hauteur cohérente */
@media (min-width:769px) and (max-width:1024px){
  .rg.yzm-ba .rg-imgs{height:220px}
}
/* Mobile */
@media (max-width:768px){
  .rg.yzm-ba .rg-imgs{height:220px}
  .rg.yzm-ba .rg-ba-label{font-size:.66rem;padding:5px 11px;top:12px;left:12px}
  .rg.yzm-ba .rg-ba-dots{bottom:12px;right:12px}
}
@media (max-width:480px){
  .rg.yzm-ba .rg-imgs{height:200px}
}

/* prefers-reduced-motion : pas d'animation auto */
@media (prefers-reduced-motion:reduce){
  .rg.yzm-ba .rg-imgs img,
  .rg.yzm-ba .rg-imgs .rg-ba-img{transition:none}
  .rg.yzm-ba .rg-ba-label::before{animation:none}
}

/* ============================================================
   v1.10 — BLOG /nos-articles/ : refonte mobile éditoriale finale
   On override TOUTES les règles précédentes pour un rendu Medium-style propre
   ============================================================ */

/* === Section title bl-section-title (remplace l'inline margin-bottom:28px) === */
.bl-section-title{margin-top:48px;margin-bottom:32px}
@media (max-width:768px){
  .bl-section-title{margin-top:40px;margin-bottom:24px}
}

/* === DESKTOP raffinements (sans casser ce qui marche) === */
@media (min-width:1025px){
  .arts-list{gap:28px}
  .art-card{
    grid-template-columns:200px 1fr;
    gap:0;
    border-radius:18px;
    overflow:hidden;
    background:#fff;
    border:1px solid #e2e8f0;
    transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease;
  }
  .art-card:hover{
    border-color:#cbd5e1;
    transform:translateY(-2px);
    box-shadow:0 16px 30px -16px rgba(15,23,42,.18);
  }
  .art-card-img,.art-card-ph{
    width:200px;
    height:100%;
    min-height:200px;
    object-fit:cover;
  }
  .art-card-ph{
    background:linear-gradient(135deg,#0a1628,#1a3a6b);
    color:#fff;
    font-size:2.6rem;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .art-card-body{
    padding:26px 30px;
    display:flex;
    flex-direction:column;
    gap:12px;
  }
  .art-card-body > div{display:flex;flex-direction:column;gap:10px}
  .art-card .art-tag{
    align-self:flex-start;
    margin-bottom:0;
  }
  .art-card .art-meta{
    margin-bottom:0;
    font-size:.78rem;
    color:#94a3b8;
    display:flex;
    gap:14px;
    flex-wrap:wrap;
  }
  .art-card h3{
    font-size:1.18rem;
    line-height:1.32;
    letter-spacing:-.2px;
    color:#0a1628;
    margin:0;
    font-weight:700;
  }
  .art-card p{
    font-size:.92rem;
    line-height:1.65;
    color:#475569;
    margin:0;
  }
  .art-card .art-lire{
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    font-size:.85rem;
    align-self:flex-start;
    margin-top:6px;
  }

  /* Article à la une desktop */
  .art-feat{
    border-radius:24px;
    overflow:hidden;
    background:#fff;
    border:1px solid #e2e8f0;
    display:block;
    text-decoration:none;
    color:inherit;
    transition:border-color .25s ease,box-shadow .25s ease;
  }
  .art-feat:hover{
    border-color:#cbd5e1;
    box-shadow:0 24px 40px -20px rgba(15,23,42,.18);
  }
  .art-feat-img{height:340px}
  .art-feat-body{padding:38px}
  .art-feat-body .art-tag{margin-bottom:16px;display:inline-block}
  .art-feat-body .art-meta{margin-bottom:16px;font-size:.85rem;color:#94a3b8;display:flex;gap:16px;flex-wrap:wrap}
  .art-feat h2{
    font-size:1.7rem;
    line-height:1.2;
    letter-spacing:-.5px;
    color:#0a1628;
    font-weight:800;
    margin:0 0 14px;
  }
  .art-feat p{
    font-size:1.05rem;
    line-height:1.7;
    color:#475569;
    margin-bottom:18px;
  }
  .art-feat .art-lire{
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    font-size:.95rem;
  }
}

/* === TABLETTE (769-1024px) : 2 colonnes contenu compact === */
@media (min-width:769px) and (max-width:1024px){
  .arts-list{gap:22px}
  .art-card{
    grid-template-columns:170px 1fr;
    gap:0;
    border-radius:18px;
    overflow:hidden;
    background:#fff;
    border:1px solid #e2e8f0;
    transition:all .25s ease;
  }
  .art-card:hover{
    border-color:#cbd5e1;
    transform:translateY(-2px);
    box-shadow:0 16px 30px -16px rgba(15,23,42,.18);
  }
  .art-card-img,.art-card-ph{
    width:170px;
    height:100%;
    min-height:180px;
    object-fit:cover;
  }
  .art-card-ph{
    background:linear-gradient(135deg,#0a1628,#1a3a6b);
    color:#fff;
    font-size:2.2rem;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .art-card-body{padding:22px 24px;gap:12px;display:flex;flex-direction:column}
  .art-card-body > div{display:flex;flex-direction:column;gap:10px}
  .art-card h3{font-size:1.08rem;line-height:1.3;margin:0}
  .art-card p{font-size:.9rem;line-height:1.6;margin:0}
  .art-card .art-tag,.art-card .art-meta{margin-bottom:0}
  .art-feat-img{height:280px}
  .art-feat-body{padding:32px}
  .art-feat h2{font-size:1.5rem;line-height:1.22;margin-bottom:12px}
  .art-feat p{font-size:1rem;line-height:1.65}
}

/* === MOBILE PREMIUM ÉDITORIAL (≤ 768px) : refonte complète Medium-style === */
@media (max-width:768px){
  /* Layout général : pleine largeur sidebar dessous */
  .bl-grid{
    display:flex !important;
    flex-direction:column !important;
    gap:48px !important;
  }
  .bl-side{position:static;gap:20px;display:flex;flex-direction:column}

  /* === Article à la une === */
  .art-feat{
    display:block;
    border-radius:24px;
    overflow:hidden;
    background:#fff;
    border:1px solid #e2e8f0;
    text-decoration:none;
    color:inherit;
    margin:0 0 36px;
    box-shadow:0 1px 2px rgba(15,23,42,.04);
  }
  .art-feat-img{
    width:100%;
    height:240px;
    object-fit:cover;
    display:block;
    margin:0;
  }
  .art-feat-body{
    padding:24px 22px 28px;
    display:flex;
    flex-direction:column;
    gap:0;
  }
  .art-feat-body .art-tag{
    display:inline-block;
    align-self:flex-start;
    font-size:.7rem;
    padding:5px 11px;
    letter-spacing:.08em;
    margin:0 0 14px;
  }
  .art-feat-body .art-meta{
    font-size:.78rem;
    color:#94a3b8;
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin:0 0 14px;
    line-height:1.4;
  }
  .art-feat h2{
    font-size:1.42rem;
    line-height:1.22;
    letter-spacing:-.4px;
    color:#0a1628;
    font-weight:800;
    margin:0 0 14px;
  }
  .art-feat p{
    font-size:.98rem;
    line-height:1.7;
    color:#475569;
    margin:0 0 18px;
  }
  .art-feat .art-lire{
    font-size:.92rem;
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    align-self:flex-start;
  }

  /* === Liste articles : refonte totale pleine largeur === */
  .arts-list{
    display:flex !important;
    flex-direction:column !important;
    gap:28px !important;
  }
  .art-card{
    display:flex !important;
    flex-direction:column !important;
    grid-template-columns:none !important;
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:22px;
    overflow:hidden;
    text-decoration:none;
    color:inherit;
    transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
    box-shadow:0 1px 2px rgba(15,23,42,.04);
  }
  .art-card:active{transform:scale(.985)}
  .art-card-img,.art-card-ph{
    width:100% !important;
    height:220px !important;
    min-height:0 !important;
    object-fit:cover;
    display:block;
    margin:0 !important;
  }
  .art-card-ph{
    background:linear-gradient(135deg,#0a1628,#1a3a6b);
    color:#fff;
    font-size:3rem;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .art-card-body{
    padding:24px 22px 26px !important;
    display:flex !important;
    flex-direction:column !important;
    gap:14px !important;
  }
  .art-card-body > div{
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
  }
  .art-card .art-tag{
    align-self:flex-start;
    font-size:.66rem;
    padding:4px 10px;
    letter-spacing:.08em;
    margin:0 !important;
  }
  .art-card .art-meta{
    font-size:.75rem;
    color:#94a3b8;
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    line-height:1.4;
    margin:0 !important;
  }
  .art-card h3{
    font-size:1.2rem;
    line-height:1.28;
    letter-spacing:-.2px;
    color:#0a1628;
    font-weight:700;
    margin:0;
  }
  .art-card p{
    font-size:.96rem;
    line-height:1.7;
    color:#475569;
    margin:0;
  }
  .art-card .art-lire{
    font-size:.88rem;
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    align-self:flex-start;
    margin-top:4px;
  }

  /* === Sidebar mobile premium === */
  .bl-side{margin-top:24px}
  .urg-side{
    padding:28px 24px;
    border-radius:22px;
  }
  .urg-side h4{font-size:1.18rem;margin-bottom:10px;line-height:1.3}
  .urg-side p{font-size:.95rem;line-height:1.6;margin-bottom:18px}

  .side-box,.nl-box{padding:24px 22px;border-radius:20px}
  .side-box h4,.nl-box h4{font-size:1.05rem;margin-bottom:14px}

  /* Catégories et populaires : touch targets confort */
  .cats li a{
    padding:14px 18px;
    font-size:.95rem;
    min-height:48px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    border-radius:12px;
    transition:background .2s ease;
  }
  .pop-list{gap:8px}
  .pop-item{
    padding:14px 16px;
    display:flex;
    align-items:center;
    gap:12px;
    font-size:.92rem;
    line-height:1.4;
    border-radius:12px;
    background:#f8fafc;
    text-decoration:none;
    color:#334155;
    min-height:48px;
    transition:background .2s ease,color .2s ease;
  }
  .pop-emoji{font-size:1.1rem;flex-shrink:0}

  .nl-btn{padding:14px 18px;font-size:.95rem;min-height:48px;width:100%;border-radius:12px}

  /* === CTA fin blog mobile === */
  .cta-box-inner{padding:32px 24px;text-align:center;border-radius:22px}
  .cta-box-inner h2{font-size:1.4rem;line-height:1.25;margin-bottom:12px}
  .cta-box-inner p{font-size:.95rem;line-height:1.6;margin-bottom:22px}
  .cta-btns-row{flex-direction:column;gap:10px}
  .cta-btns-row a{width:100%;text-align:center;padding:14px 20px}
}

/* === PETIT MOBILE (≤ 480px) === */
@media (max-width:480px){
  .art-feat-img{height:200px}
  .art-feat-body{padding:22px 20px 26px}
  .art-feat h2{font-size:1.28rem;line-height:1.22}
  .art-feat p{font-size:.94rem;line-height:1.68}

  .arts-list{gap:24px !important}
  .art-card-img,.art-card-ph{height:200px !important}
  .art-card-body{padding:22px 20px 24px !important}
  .art-card h3{font-size:1.12rem;line-height:1.3}
  .art-card p{font-size:.92rem;line-height:1.68}

  .urg-side{padding:24px 20px}
  .side-box,.nl-box{padding:22px 20px}
}

/* ============================================================
   v1.11 — Messages CF7 premium responsive
   ============================================================ */

/* Conteneur de message après submit — large, lisible, mobile-first */
.wpcf7-response-output{
  margin:20px 0 0 !important;
  padding:18px 22px !important;
  border:1px solid !important;
  border-radius:14px !important;
  font-family:'Sora',sans-serif;
  font-weight:600;
  font-size:.95rem;
  line-height:1.55;
  letter-spacing:-.1px;
  display:flex;
  align-items:flex-start;
  gap:12px;
  animation:yzm-msg-in .35s cubic-bezier(.4,0,.2,1);
}

/* Succès — vert */
.wpcf7 form.sent .wpcf7-response-output{
  background:#ecfdf5 !important;
  border-color:#a7f3d0 !important;
  color:#065f46 !important;
}

/* Erreur d'envoi / failed — orange/rouge */
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output{
  background:#fef2f2 !important;
  border-color:#fecaca !important;
  color:#991b1b !important;
}

/* Validation invalide — orange */
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output{
  background:#fff7ed !important;
  border-color:#fed7aa !important;
  color:#9a3412 !important;
}

/* Spam — gris */
.wpcf7 form.spam .wpcf7-response-output{
  background:#f8fafc !important;
  border-color:#e2e8f0 !important;
  color:#475569 !important;
}

/* Champs avec erreur de validation */
.wpcf7-not-valid{
  border-color:#dc2626 !important;
  background:#fef2f2 !important;
}
.wpcf7-not-valid-tip{
  color:#dc2626 !important;
  font-size:.82rem !important;
  margin-top:4px !important;
  font-weight:600;
  font-family:'Sora',sans-serif;
}

/* Spinner pendant envoi */
.wpcf7-spinner{
  display:inline-block !important;
  width:18px !important;
  height:18px !important;
  margin:0 0 0 12px !important;
  vertical-align:middle;
}

/* Animation entrée */
@keyframes yzm-msg-in{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:none}
}
@media (prefers-reduced-motion:reduce){
  .wpcf7-response-output{animation:none !important}
}

/* Mobile — encore plus aéré */
@media (max-width:768px){
  .wpcf7-response-output{
    padding:18px 18px !important;
    font-size:.92rem !important;
    border-radius:14px !important;
    line-height:1.6 !important;
  }
}

/* ============================================================
   v1.11 — BLOG /nos-articles/ : ARTICLE À LA UNE refonte définitive
   Structure full-width responsive premium type Medium/Vercel
   ============================================================ */

/* === RESET propre du featured article === */
.art-feat{
  display:block;
  text-decoration:none;
  color:inherit;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:24px;
  overflow:hidden;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
  margin-bottom:36px;
}
.art-feat:hover{
  border-color:#cbd5e1;
  box-shadow:0 24px 40px -20px rgba(15,23,42,.18);
}

.art-feat-img{
  width:100%;
  display:block;
  object-fit:cover;
  margin:0;
  border-radius:0;
}

/* === DESKTOP (≥1025px) — image hero impactante === */
@media (min-width:1025px){
  .art-feat-img{height:380px}
  .art-feat-body{padding:42px 44px 46px}
  .art-feat-body .art-tag{
    display:inline-block;
    margin:0 0 18px;
    font-size:.72rem;
    padding:5px 13px;
    letter-spacing:.08em;
  }
  .art-feat-body .art-meta{
    margin:0 0 18px;
    font-size:.85rem;
    color:#94a3b8;
    display:flex;
    gap:16px;
    flex-wrap:wrap;
    line-height:1.4;
  }
  .art-feat h2{
    font-size:1.9rem;
    line-height:1.18;
    letter-spacing:-.6px;
    color:#0a1628;
    font-weight:800;
    margin:0 0 16px;
    max-width:680px;
  }
  .art-feat p{
    font-size:1.08rem;
    line-height:1.7;
    color:#475569;
    margin:0 0 22px;
    max-width:680px;
  }
  .art-feat .art-lire{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    font-size:.98rem;
    transition:gap .25s ease;
  }
  .art-feat:hover .art-lire{gap:12px}
}

/* === TABLETTE (769-1024px) === */
@media (min-width:769px) and (max-width:1024px){
  .art-feat{margin-bottom:32px;border-radius:22px}
  .art-feat-img{height:300px}
  .art-feat-body{padding:36px 36px 40px}
  .art-feat-body .art-tag{
    display:inline-block;
    margin:0 0 16px;
    font-size:.7rem;
    padding:5px 12px;
  }
  .art-feat-body .art-meta{
    margin:0 0 16px;
    font-size:.82rem;
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    color:#94a3b8;
    line-height:1.4;
  }
  .art-feat h2{
    font-size:1.6rem;
    line-height:1.2;
    letter-spacing:-.45px;
    color:#0a1628;
    font-weight:800;
    margin:0 0 14px;
  }
  .art-feat p{
    font-size:1.02rem;
    line-height:1.68;
    color:#475569;
    margin:0 0 20px;
  }
  .art-feat .art-lire{
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    font-size:.94rem;
  }
}

/* === GRAND MOBILE (481-768px) === */
@media (min-width:481px) and (max-width:768px){
  .art-feat{margin-bottom:32px;border-radius:22px}
  .art-feat-img{height:300px}
  .art-feat-body{padding:32px 28px 34px}
  .art-feat-body .art-tag{
    display:inline-block !important;
    margin:0 0 16px !important;
    font-size:.7rem;
    padding:5px 12px;
    letter-spacing:.08em;
  }
  .art-feat-body .art-meta{
    margin:0 0 16px !important;
    font-size:.8rem;
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    color:#94a3b8;
    line-height:1.4;
  }
  .art-feat h2{
    font-size:1.55rem;
    line-height:1.22;
    letter-spacing:-.4px;
    color:#0a1628;
    font-weight:800;
    margin:0 0 14px;
  }
  .art-feat p{
    font-size:1rem;
    line-height:1.7;
    color:#475569;
    margin:0 0 20px;
  }
  .art-feat .art-lire{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    font-size:.92rem;
  }
}

/* === PETIT MOBILE (≤480px) — proportions optimisées === */
@media (max-width:480px){
  .art-feat{
    margin-bottom:28px;
    border-radius:20px;
  }
  .art-feat-img{
    height:220px;
    width:100%;
    object-fit:cover;
  }
  .art-feat-body{
    padding:26px 22px 30px;
  }
  .art-feat-body .art-tag{
    display:inline-block !important;
    margin:0 0 14px !important;
    font-size:.68rem;
    padding:4px 11px;
    letter-spacing:.08em;
  }
  .art-feat-body .art-meta{
    margin:0 0 14px !important;
    font-size:.76rem;
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    color:#94a3b8;
    line-height:1.4;
  }
  .art-feat h2{
    font-size:1.35rem;
    line-height:1.22;
    letter-spacing:-.4px;
    color:#0a1628;
    font-weight:800;
    margin:0 0 12px;
  }
  .art-feat p{
    font-size:.96rem;
    line-height:1.68;
    color:#475569;
    margin:0 0 18px;
  }
  .art-feat .art-lire{
    display:inline-flex;
    align-items:center;
    gap:6px;
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    font-size:.88rem;
  }
}

/* === Très petit mobile (≤360px) === */
@media (max-width:360px){
  .art-feat-img{height:200px}
  .art-feat-body{padding:24px 20px 28px}
  .art-feat h2{font-size:1.28rem}
  .art-feat p{font-size:.94rem}
}

/* ============================================================
   v1.11 — BLOG : Tous les articles — refonte liste premium définitive
   ============================================================ */

/* DESKTOP (≥1025px) — liste premium avec image gauche, contenu droite */
@media (min-width:1025px){
  .arts-list{
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
  }
  .art-card{
    display:grid !important;
    grid-template-columns:240px 1fr !important;
    gap:0 !important;
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:20px;
    overflow:hidden;
    text-decoration:none;
    color:inherit;
    transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
    box-shadow:0 1px 2px rgba(15,23,42,.04);
  }
  .art-card:hover{
    border-color:#cbd5e1;
    transform:translateY(-2px);
    box-shadow:0 16px 30px -16px rgba(15,23,42,.18);
  }
  .art-card-img,
  .art-card-ph{
    width:240px !important;
    height:100% !important;
    min-height:200px !important;
    object-fit:cover;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .art-card-ph{
    background:linear-gradient(135deg,#0a1628,#1a3a6b);
    color:#fff;
    font-size:3rem;
  }
  .art-card-body{
    padding:28px 32px !important;
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
    justify-content:center;
  }
  .art-card-body > div{
    display:flex !important;
    flex-direction:column !important;
    gap:10px !important;
  }
  .art-card .art-tag{
    align-self:flex-start;
    margin:0 !important;
    font-size:.7rem;
    padding:4px 11px;
    letter-spacing:.08em;
  }
  .art-card .art-meta{
    margin:0 !important;
    font-size:.78rem;
    color:#94a3b8;
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    line-height:1.4;
  }
  .art-card h3{
    font-size:1.2rem;
    line-height:1.32;
    letter-spacing:-.25px;
    color:#0a1628;
    font-weight:700;
    margin:0;
  }
  .art-card p{
    font-size:.95rem;
    line-height:1.66;
    color:#475569;
    margin:0;
  }
  .art-card .art-lire{
    align-self:flex-start;
    color:#1a56db;
    font-family:'Sora',sans-serif;
    font-weight:700;
    font-size:.88rem;
    margin-top:6px;
    transition:gap .25s ease;
    display:inline-flex;
    align-items:center;
    gap:6px;
  }
  .art-card:hover .art-lire{gap:10px}
}

/* TABLETTE (769-1024px) — image plus petite, contenu plus large */
@media (min-width:769px) and (max-width:1024px){
  .arts-list{
    display:flex !important;
    flex-direction:column !important;
    gap:22px !important;
  }
  .art-card{
    display:grid !important;
    grid-template-columns:200px 1fr !important;
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:20px;
    overflow:hidden;
    text-decoration:none;
    color:inherit;
    transition:all .25s ease;
    box-shadow:0 1px 2px rgba(15,23,42,.04);
  }
  .art-card:hover{
    border-color:#cbd5e1;
    transform:translateY(-2px);
    box-shadow:0 16px 30px -16px rgba(15,23,42,.18);
  }
  .art-card-img,
  .art-card-ph{
    width:200px !important;
    height:100% !important;
    min-height:200px !important;
    object-fit:cover;
  }
  .art-card-ph{
    background:linear-gradient(135deg,#0a1628,#1a3a6b);
    color:#fff;
    font-size:2.5rem;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .art-card-body{
    padding:24px 28px !important;
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
    justify-content:center;
  }
  .art-card-body > div{
    display:flex !important;
    flex-direction:column !important;
    gap:10px !important;
  }
  .art-card .art-tag{margin:0 !important;font-size:.7rem;padding:4px 11px;align-self:flex-start}
  .art-card .art-meta{margin:0 !important;font-size:.78rem;display:flex;gap:14px;flex-wrap:wrap;color:#94a3b8;line-height:1.4}
  .art-card h3{font-size:1.12rem;line-height:1.32;color:#0a1628;font-weight:700;letter-spacing:-.2px;margin:0}
  .art-card p{font-size:.92rem;line-height:1.62;color:#475569;margin:0}
  .art-card .art-lire{margin-top:4px;color:#1a56db;font-family:'Sora',sans-serif;font-weight:700;font-size:.86rem;align-self:flex-start}
}

/* ============================================================
   v1.11.3 — Fix article à la une : ratio image/texte
   Mobile et tablette : image trop haute, texte trop serré.
   Réduit les hauteurs d'image et booste la respiration.
   ============================================================ */

/* TABLETTE (769-1024px) — image moins dominante */
@media (min-width:769px) and (max-width:1024px){
  .art-feat-img{height:240px}
  .art-feat-body{padding:32px 36px 36px}
  .art-feat-body .art-tag{margin:0 0 18px}
  .art-feat-body .art-meta{margin:0 0 18px;line-height:1.5}
  .art-feat h2{font-size:1.55rem;line-height:1.22;margin:0 0 16px}
  .art-feat p{font-size:1.02rem;line-height:1.72;margin:0 0 20px}
}

/* GRAND MOBILE (481-768px) — image bien contenue, texte qui respire */
@media (min-width:481px) and (max-width:768px){
  .art-feat-img{height:200px}
  .art-feat-body{padding:28px 26px 32px}
  .art-feat-body .art-tag{margin:0 0 18px !important}
  .art-feat-body .art-meta{margin:0 0 18px !important;line-height:1.5}
  .art-feat h2{font-size:1.4rem;line-height:1.25;margin:0 0 16px}
  .art-feat p{font-size:.98rem;line-height:1.75;margin:0 0 20px}
  .art-feat .art-lire{font-size:.92rem;margin-top:4px}
}

/* PETIT MOBILE (≤480px) — proportions resserrées */
@media (max-width:480px){
  .art-feat-img{height:180px}
  .art-feat-body{padding:24px 22px 28px}
  .art-feat-body .art-tag{margin:0 0 16px !important}
  .art-feat-body .art-meta{margin:0 0 16px !important;line-height:1.5}
  .art-feat h2{font-size:1.28rem;line-height:1.28;margin:0 0 14px}
  .art-feat p{font-size:.94rem;line-height:1.72;margin:0 0 18px}
}

/* TRÈS PETIT MOBILE (≤360px) */
@media (max-width:360px){
  .art-feat-img{height:160px}
  .art-feat-body{padding:22px 20px 26px}
  .art-feat h2{font-size:1.22rem;line-height:1.28}
  .art-feat p{font-size:.92rem;line-height:1.7}
}

/* ============================================================
   v1.11.4 — Article à la une : refonte responsive structurelle
   v1.11.3 réduisait les hauteurs, mais l'image dominait toujours
   en LARGEUR (100% de la carte). Solution propre :
   - Sidebar blog passe dessous dès tablette → libère la largeur
   - Layout HORIZONTAL image-gauche / texte-droite à partir de 600px
   - Vertical conservé sur smartphones (≤599px)
   ============================================================ */

/* Sidebar blog passe dessous dès tablette pour la respiration */
@media (max-width:1024px){
  .bl-grid{
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
  .bl-side{ position: static !important; }
}

/* HORIZONTAL — Grand mobile + Tablette portrait (600-799px) */
@media (min-width:600px) and (max-width:799px){
  .art-feat{
    display: grid !important;
    grid-template-columns: 240px 1fr !important;
    gap: 0 !important;
    align-items: stretch;
  }
  .art-feat-img{
    width: 100% !important;
    height: 100% !important;
    min-height: 220px;
    object-fit: cover;
    border-radius: 0;
    margin: 0;
  }
  .art-feat-body{
    padding: 26px 30px !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0;
  }
  .art-feat-body .art-tag{ margin: 0 0 12px !important; align-self: flex-start }
  .art-feat-body .art-meta{ margin: 0 0 12px !important; line-height: 1.45 }
  .art-feat h2{ font-size: 1.32rem !important; line-height: 1.25; margin: 0 0 12px !important }
  .art-feat p{ font-size: .96rem !important; line-height: 1.68; margin: 0 0 14px !important }
  .art-feat .art-lire{ font-size: .9rem !important }
}

/* HORIZONTAL — Tablette large + paysage (800-1024px) */
@media (min-width:800px) and (max-width:1024px){
  .art-feat{
    display: grid !important;
    grid-template-columns: 320px 1fr !important;
    gap: 0 !important;
    align-items: stretch;
  }
  .art-feat-img{
    width: 100% !important;
    height: 100% !important;
    min-height: 280px;
    object-fit: cover;
    border-radius: 0;
    margin: 0;
  }
  .art-feat-body{
    padding: 34px 38px !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0;
  }
  .art-feat-body .art-tag{ margin: 0 0 14px !important; align-self: flex-start }
  .art-feat-body .art-meta{ margin: 0 0 14px !important; line-height: 1.5 }
  .art-feat h2{ font-size: 1.55rem !important; line-height: 1.22; margin: 0 0 14px !important }
  .art-feat p{ font-size: 1.02rem !important; line-height: 1.72; margin: 0 0 18px !important }
  .art-feat .art-lire{ font-size: .96rem !important }
}

/* VERTICAL — Smartphones (≤599px) — image bien contenue */
@media (max-width:599px){
  .art-feat{ display: block !important }
  .art-feat-img{
    width: 100% !important;
    height: 200px !important;
    object-fit: cover;
    border-radius: 0;
  }
  .art-feat-body{ padding: 24px 22px 28px !important }
  .art-feat-body .art-tag{ margin: 0 0 14px !important }
  .art-feat-body .art-meta{ margin: 0 0 14px !important; line-height: 1.5 }
  .art-feat h2{ font-size: 1.28rem !important; line-height: 1.28; margin: 0 0 12px !important }
  .art-feat p{ font-size: .94rem !important; line-height: 1.72; margin: 0 0 16px !important }
}

@media (max-width:480px){
  .art-feat-img{ height: 180px !important }
}

@media (max-width:360px){
  .art-feat-img{ height: 160px !important }
  .art-feat-body{ padding: 22px 20px 26px !important }
}
