:root{
  --paper:#ECE7DC;--surface:#F8F5EF;--card:#FFFFFF;
  --ink:#15130D;--steel:#221F17;--muted:#6B6557;
  --brass:#9F6A16;--brass2:#C7973F;
  --green:#2E6B43;
  --danger:#9A3B2A;
  --line:#15130D1A;--line2:#15130D33;--r:2px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:"Hanken Grotesk",system-ui,sans-serif;font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
main{overflow-x:hidden}
.grecaptcha-badge{visibility:hidden!important}
a{color:inherit;text-decoration:none}
.mono{font-family:"JetBrains Mono",monospace}
.disp{font-family:"Big Shoulders Display","Arial Narrow",sans-serif;font-weight:800;line-height:.9;letter-spacing:-.005em;text-transform:uppercase}
.eyebrow{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);font-weight:500}

body>header{position:sticky;top:0;z-index:60;border-bottom:1px solid var(--line)}
/* Le flou est porté par un pseudo-élément en fond, et NON par le header lui-même :
   un backdrop-filter sur le header clipperait les sous-menus déroulants (absolute)
   qui débordent sous le header. On évite aussi le z-index négatif sur ::before
   (combo z-index:-1 + backdrop-filter buggé : le header devenait transparent et le
   contenu défilait visuellement par-dessus le header sticky). Le contenu .nav passe
   au-dessus du fond flou via un z-index positif. */
body>header::before{content:"";position:absolute;inset:0;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(8px)}
.nav{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{font-family:"Big Shoulders Display";font-weight:900;text-transform:uppercase;letter-spacing:.02em;font-size:22px;display:flex;align-items:center;gap:0}
.brand .mk{width:34px;height:34px;display:block;object-fit:contain;margin:0 5px}
.brand .b{color:var(--brass)}
/* « Serrurier 41 » devient un <h1> sur l'accueil : on neutralise les défauts du h1
   pour qu'il garde strictement l'apparence du texte-logo. */
.brand .bn{font:inherit;letter-spacing:inherit;margin:0;display:inline}
/* Navigation principale (menu WordPress) */
.navtoggle{display:none;background:none;border:1px solid var(--line2);border-radius:var(--r);font-size:20px;line-height:1;padding:5px 11px;cursor:pointer;color:var(--ink)}
.nlinks .menu{list-style:none;margin:0;padding:0;display:flex;gap:20px;align-items:center}
.nlinks .menu li{position:relative}
.nlinks .menu a{color:var(--muted);font-size:14px;font-weight:600;text-decoration:none;display:block;padding:6px 0;white-space:nowrap}
.nlinks .menu a:hover{color:var(--ink)}
.nlinks .menu .menu-item-has-children>a::after{content:' \25BE';color:var(--brass);font-size:11px}
.nlinks .menu .sub-menu{position:absolute;top:100%;left:0;min-width:215px;list-style:none;margin:0;padding:8px;background:var(--surface);border:1px solid var(--line2);border-radius:var(--r);box-shadow:0 14px 34px #00000018;display:none;z-index:80}
.nlinks .menu li:hover>.sub-menu,.nlinks .menu li:focus-within>.sub-menu{display:block}
.nlinks .menu .sub-menu a{padding:9px 12px;font-size:13.5px;color:var(--steel)}
.nlinks .menu .sub-menu a:hover{color:var(--brass)}
/* Sous-sous-menu (niveau 3) : s'ouvre en flyout sur le côté droit, collé au parent
   (pas de gap, sinon le survol se perd en passant vers le flyout). */
.nlinks .menu .sub-menu .sub-menu{top:-9px;left:100%}
.nlinks .menu .sub-menu .menu-item-has-children>a::after{content:' \25B8';float:right;color:var(--brass);font-size:11px;margin-left:10px}
/* Pont invisible : maintient le survol entre « Outils » et son flyout latéral. */
.nlinks .menu .sub-menu .menu-item-has-children::after{content:"";position:absolute;top:0;right:-12px;width:12px;height:100%}
.call{display:inline-flex;flex-direction:column;align-items:center;gap:1px;background:var(--ink);color:var(--paper);padding:7px 17px;border-radius:4px;font-weight:700;font-size:14px;transition:.15s;line-height:1.15}
.call:hover{background:var(--brass);color:#fff}
.call .call-num{display:flex;align-items:center;gap:8px}
.call .ph{font-family:"JetBrains Mono"}
.call .call-hours{font-size:10.5px;font-weight:500;opacity:.82;font-family:inherit;letter-spacing:.01em}

/* hero */
.hero{padding:60px 0 30px;position:relative}
.hgrid{display:grid;grid-template-columns:1.25fr .9fr;gap:50px;align-items:center}
.hero .htitle{margin:14px 0 0;font-size:clamp(50px,7.6vw,104px)}
.hero .htitle em{font-style:normal;color:var(--brass)}
.hero .sub{max-width:34ch;margin:20px 0 0;font-size:19px;color:var(--steel)}
.hero .sub b{font-weight:700}
.stats{display:flex;gap:34px;margin-top:26px;flex-wrap:wrap}
.stat .v{font-family:"Big Shoulders Display";font-weight:800;font-size:42px;line-height:.9}
.stat .v em{font-style:normal;color:var(--brass)}
.stat .l{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.cta{display:flex;flex-wrap:wrap;gap:13px;margin-top:30px}
.bp{display:inline-flex;align-items:center;gap:9px;background:var(--brass);color:#fff;padding:15px 24px;border-radius:var(--r);font-weight:700;font-size:16px;box-shadow:4px 4px 0 var(--ink);transition:.12s}
.bp:hover{transform:translate(-1px,-1px);box-shadow:6px 6px 0 var(--ink)}
.bg{display:inline-flex;align-items:center;gap:8px;padding:15px 22px;border:1px solid var(--line2);border-radius:var(--r);font-weight:600;color:var(--steel)}
.bg:hover{border-color:var(--ink)}
.hphoto{position:relative}
.hphoto .fr{border:1px solid var(--ink);border-radius:var(--r);overflow:hidden;aspect-ratio:4/5;background:#ccc}
.hphoto img{width:100%;height:100%;object-fit:cover;display:block}
.hphoto .tag{position:absolute;left:-1px;bottom:20px;background:var(--ink);color:var(--paper);padding:9px 13px;font-family:"JetBrains Mono";font-size:11.5px;letter-spacing:.04em}
.hphoto .tag b{color:var(--brass2)}
.hphoto .stamp{position:absolute;top:-16px;right:-12px;z-index:3;width:104px;height:104px;border-radius:50%;background:var(--paper);border:1px solid var(--ink);display:grid;place-items:center;text-align:center;transform:rotate(7deg)}
.hphoto .stamp b{font-family:"Big Shoulders Display";font-weight:800;font-size:12px;line-height:1;text-transform:uppercase}
.hphoto .stamp .big{display:block;font-size:34px;color:var(--brass);letter-spacing:-1px}

.facts{border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);background:var(--ink);color:var(--paper);margin-top:46px}
.facts .row{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px 22px;padding:15px 28px;max-width:1200px;margin:0 auto;font-family:"JetBrains Mono";font-size:12px;letter-spacing:.04em;text-transform:uppercase}
.facts .row span{display:flex;align-items:center;gap:8px}
.facts .row span::before{content:"";width:6px;height:6px;background:var(--brass2);transform:rotate(45deg)}

section{padding:80px 0}
.shead{display:flex;align-items:baseline;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:36px}
.shead h2{margin:6px 0 0;font-size:clamp(32px,4.6vw,58px)}
.shead p{color:var(--muted);max-width:36ch;margin:0}

/* outil prix */
.tool{background:var(--steel);color:var(--paper)}
.tool .eyebrow{color:var(--brass2)}.tool h2{color:var(--paper)}.tool .shead p{color:#CFC9BB}
.toolbox{display:grid;grid-template-columns:1fr;gap:0;background:var(--paper);color:var(--ink);border-radius:var(--r);overflow:hidden;box-shadow:10px 10px 0 #00000045}
.toolbox .left{padding:38px 36px}
.toolbox .left h3{font-family:"Big Shoulders Display";font-weight:800;font-size:28px;text-transform:uppercase;margin:0 0 6px}
.toolbox .left p{color:var(--muted);font-size:14.5px;margin:0 0 22px}
.field{display:flex;gap:8px;margin-bottom:10px}
.field input{flex:1;padding:14px;border:1px solid var(--line2);border-radius:var(--r);font-size:15px;background:#fff;font-family:inherit}
.field .gps{background:var(--green);color:#fff;border:none;border-radius:var(--r);padding:0 14px;font-size:13px;font-weight:600;cursor:pointer}
.field .gps:hover{filter:brightness(1.08)}
.tool-go{width:100%;margin-top:6px;background:var(--brass);color:#fff;border:none;padding:15px;border-radius:var(--r);font-weight:700;font-size:15px;cursor:pointer;box-shadow:3px 3px 0 var(--ink)}
.toolbox .right{background:var(--ink);color:var(--paper);padding:34px 32px}
.exlbl{font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass2);border:1px solid #ffffff2e;display:inline-block;padding:3px 8px;border-radius:99px;margin-bottom:16px}
.resrow{display:flex;justify-content:space-between;align-items:baseline;padding:11px 0;border-bottom:1px solid #ffffff1f;font-size:14.5px}
.resrow span:last-child{font-family:"JetBrains Mono";font-weight:700}
.restot{display:flex;justify-content:space-between;align-items:baseline;margin-top:16px;padding-top:14px;border-top:2px solid var(--brass2)}
.restot .lab{font-weight:700}
.restot .val{font-family:"Big Shoulders Display";font-weight:800;font-size:40px;color:var(--brass2);line-height:.8}
.note-mono{font-family:"JetBrains Mono";font-size:11.5px;color:#CFC9BB;margin-top:14px;line-height:1.5}

/* VS — l'arme anti-arnaque */
.vs{background:var(--paper)}
.vsgrid{display:grid;grid-template-columns:1fr 1fr;gap:78px;position:relative}
.vsbadge{position:absolute;top:50%;left:50%;margin:-31px 0 0 -31px;width:62px;height:62px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:"Big Shoulders Display";font-weight:800;font-size:22px;z-index:2;border:3px solid var(--paper)}
.col{border:1px solid var(--line2);border-radius:var(--r);padding:32px 30px;background:var(--card)}
.col.them{background:#1c1a14;color:#d8d2c4;border-color:#000}
.col h3{font-family:"Big Shoulders Display";font-weight:800;text-transform:uppercase;font-size:24px;margin:0 0 18px;letter-spacing:.01em}
.col.them h3{color:#fff}.col.us h3{color:var(--brass)}
.col ul{list-style:none;margin:0;padding:0}
.col li{display:flex;gap:12px;padding:11px 0;font-size:15px;border-bottom:1px solid var(--line)}
.col.them li{border-color:#ffffff14}
.col li:last-child{border-bottom:0}
.col li .ic{flex:none;width:20px;font-weight:800}
.them li .ic{color:var(--danger)}
.us li .ic{color:var(--green)}

/* tarifs honnêtes */
.plate{background:var(--surface);border:1px solid var(--line2);border-radius:var(--r);padding:38px 42px;box-shadow:8px 8px 0 var(--ink);position:relative}
.plate::before{content:"TARIFS · ANNONCÉS AVANT";position:absolute;top:0;left:42px;transform:translateY(-50%);background:var(--brass);color:#fff;font-family:"JetBrains Mono";font-size:11px;letter-spacing:.16em;padding:6px 12px}
.prow{display:flex;align-items:baseline;gap:10px;padding:16px 0;border-bottom:1px solid var(--line)}
.prow:last-child{border-bottom:0}
.prow .nm{font-weight:600;font-size:17.5px}
.prow .ds{color:var(--muted);font-size:13px;margin-top:2px}
.prow .dots{flex:1;border-bottom:1.5px dotted var(--line2);transform:translateY(-5px);min-width:24px}
.prow .pr{font-family:"JetBrains Mono";font-weight:700;font-size:18px;white-space:nowrap}
.prow .pr .f{color:var(--muted);font-size:11px;font-weight:400;margin-right:4px}
.platefoot{margin-top:22px;padding-top:20px;border-top:1px solid var(--line2);font-size:14.5px;color:var(--steel)}
.platefoot b{color:var(--ink)}

/* services */
.svc{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line2)}
.svc .it{padding:28px 26px 28px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:50px 1fr;gap:16px}
.svc .it:nth-child(odd){padding-right:44px;border-right:1px solid var(--line)}
.svc .it:nth-child(even){padding-left:44px}
.svc .n{font-family:"Big Shoulders Display";font-weight:800;font-size:28px;color:var(--brass)}
.svc h3{margin:1px 0 5px;font-size:19px}
.svc p{margin:0;color:var(--muted);font-size:14.5px}

/* preuve */
.proof{background:var(--surface)}
.gbar{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--line2);border-radius:var(--r);padding:14px 20px;margin-bottom:26px}
.gbar .g{font-family:"Big Shoulders Display";font-weight:800;font-size:30px}
.gbar .g .b{color:#4285F4}.gbar .g .r{color:var(--danger)}.gbar .g .y{color:#F4B400}.gbar .g .gr{color:var(--green)}
.gbar .st{color:var(--brass2);letter-spacing:2px}
.gbar b{font-weight:800}
.gbar a{margin-left:auto;font-family:"JetBrains Mono";font-size:12px;color:var(--brass);border:1px solid var(--line2);padding:8px 12px;border-radius:var(--r);white-space:nowrap}
.gbar>span{white-space:nowrap}
@media(max-width:600px){.gbar{flex-wrap:wrap;gap:8px 14px;padding:14px 16px}.gbar .g{font-size:26px}.gbar a{margin-left:0;width:100%;box-sizing:border-box;text-align:center;margin-top:4px}}
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.rev .st{color:var(--brass2);letter-spacing:3px;font-size:14px}
.rev p{font-size:15px;line-height:1.6}
.rev .who{display:flex;align-items:center;gap:11px;border-top:1px solid var(--line);padding-top:13px;margin-top:4px}
.rev .av{width:38px;height:38px;border-radius:50%;background:var(--steel);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;overflow:hidden;flex:none}
.rev .av img{width:100%;height:100%;object-fit:cover;display:block}
.rev .nm a{color:inherit;text-decoration:none;border-bottom:1px solid var(--brass)}
.rev .nm a:hover{color:var(--brass)}
.rev .s41-rt{display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}
.rev .s41-rt.open{-webkit-line-clamp:unset;display:block;overflow:visible}
.s41-rt-more{background:none;border:none;color:var(--brass);font-weight:700;cursor:pointer;padding:2px 0 0;font-family:inherit;font-size:14px}
.s41-rt-more:hover{text-decoration:underline}
.s41-hidden{display:none!important}
.s41-more-wrap{text-align:center;margin-top:28px}
.s41-more{cursor:pointer;font-family:inherit;font-size:15px}
.rev .who .nm{font-weight:700;font-size:14.5px}
.rev .who .lo{font-family:"JetBrains Mono";font-size:11px;color:var(--muted)}

/* dispo honnête */
.dispo{background:var(--ink);color:var(--paper)}
.dispo .box{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center}
.dispo .hh{font-family:"Big Shoulders Display";font-weight:800;font-size:clamp(40px,6vw,76px);color:var(--brass2);line-height:.85;text-transform:uppercase}
.dispo p{margin:0;color:#D6D0C2;font-size:17px;max-width:52ch}
.dispo p b{color:#fff}

/* zone */
.zone .villes{display:flex;flex-wrap:wrap;gap:10px}
.vbtn{padding:9px 16px;background:var(--card);border:1px solid var(--line2);border-radius:99px;font-size:14px;color:var(--steel);font-weight:500}
.vbtn.main{background:var(--ink);color:var(--paper);border-color:var(--ink);font-weight:700}
.vbtn.base{background:var(--brass);color:#fff;border-color:var(--brass);font-weight:700}
a.vbtn{text-decoration:none;display:inline-block}
/* Boutons Gutenberg (ex : « Zones d'intervention » sur Tarifs) -> style chip ville cohérent */
.wp-block-button__link{background:var(--card);color:var(--steel);border:1px solid var(--line2);border-radius:99px;padding:9px 18px;font-size:14px;font-weight:600;text-decoration:none;box-shadow:none;transition:transform .2s ease,border-color .2s ease,color .2s ease}
.wp-block-button__link:hover{background:var(--card);border-color:var(--brass);color:var(--brass);transform:translateY(-2px)}
/* Dans .entry-content les liens sont soulignés : on l'annule pour les boutons (look chip) */
.entry-content a.wp-block-button__link{color:var(--steel);text-decoration:none}
.entry-content a.wp-block-button__link:hover{color:var(--brass);text-decoration:none}
.shead p a{color:var(--brass);text-decoration:underline;text-underline-offset:3px;font-weight:700}
.shead p a:hover{color:var(--ink)}

/* ===== Page Contact ===== */
.contact-sec{padding:60px 0}
.contact-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:28px;align-items:start;margin-top:18px}
.cform{background:var(--surface);border:1px solid var(--line2);border-radius:var(--r);padding:30px}
.cform .wpcf7-form p{margin:0 0 16px}
.cform label{display:block;font-weight:600;color:var(--ink);font-size:14px;margin-bottom:18px}
.cform input[type=text],.cform input[type=tel],.cform input[type=email],.cform select,.cform textarea{width:100%;margin-top:7px;padding:12px 14px;font:inherit;font-size:15px;color:var(--ink);background:var(--paper);border:1px solid var(--line2);border-radius:10px;box-sizing:border-box}
.cform textarea{min-height:130px;resize:vertical}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px #9f6a1626}
.cform .wpcf7-list-item{display:inline-block;margin:6px 18px 6px 0}
.cform .wpcf7-acceptance{font-weight:400;font-size:13px;color:var(--steel)}
.cform input[type=file]{margin-top:7px;font-size:13px}
.cform .wpcf7-submit{margin-top:6px;background:var(--brass);color:#fff;border:0;border-radius:99px;padding:14px 32px;font-weight:700;font-size:16px;cursor:pointer;transition:transform .2s ease,background .2s ease}
.cform .wpcf7-submit:hover{transform:translateY(-2px);background:#855810}
.cform .wpcf7-spinner{margin:14px auto 0;display:block}
.cinfo{background:var(--surface);border:1px solid var(--line2);color:var(--ink);border-radius:var(--r);padding:26px}
.cphone{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--brass);color:#fff;text-decoration:none;font-weight:800;font-size:20px;padding:14px;border-radius:12px}
.cphone:hover{background:#855810}
.cnote{font-size:13px;color:var(--steel);margin:10px 0 22px;text-align:center}
.cinfo .ctitle{font-family:"Big Shoulders Display",sans-serif;color:var(--ink);font-size:20px;margin:0 0 12px}
.cmono{font-size:12px;color:var(--steel);margin-top:14px}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}.contact-sec{padding:40px 0}}
.znote{margin-top:18px;font-family:"JetBrains Mono";font-size:12px;color:var(--muted)}

/* cta */
.final{background:var(--brass);color:#fff;text-align:center}
.final h2{font-size:clamp(40px,6vw,82px);margin:0 0 10px;color:#fff}
.final p{color:#fff;opacity:.92;max-width:46ch;margin:0 auto 28px}
.final .bp{background:var(--ink);box-shadow:5px 5px 0 #00000040}
.final .bp:hover{box-shadow:7px 7px 0 #00000040}

footer{background:var(--ink);color:#cfc9bd;padding:54px 0 0;font-size:13.5px;border-top:1px solid #ffffff14}
.fgrid{display:grid;grid-template-columns:1.1fr 1fr 1.2fr;gap:40px}
footer b{color:var(--paper);font-weight:600}
footer .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;color:#9a9488}
.fcol .ftitle{font-family:"Big Shoulders Display",sans-serif;font-weight:700;font-size:19px;color:var(--paper);margin:0 0 14px;letter-spacing:.01em}
.fcol p{margin:0 0 10px;line-height:1.5}
.fcol a{color:#e8e2d6;text-decoration:none}
.fcol a:hover{color:var(--brass)}
.fpay{font-size:12.5px;color:#9a9488}
.fpay-img{display:block;margin-top:8px;width:auto;max-width:190px;height:auto;border-radius:4px}
.frev .fstars{color:var(--brass);letter-spacing:1px}
.grev{display:inline-flex;align-items:center;gap:12px;background:#ffffff0d;border:1px solid #ffffff20;border-radius:12px;padding:11px 16px;margin-top:4px;text-decoration:none}
.grev:hover{border-color:var(--brass);background:#ffffff14}
.grev-g{flex:none;display:flex}
.grev-txt{display:flex;flex-direction:column;line-height:1.25}
.grev-name{font-weight:700;color:var(--paper);font-size:13.5px}
.grev-rate{display:flex;align-items:center;gap:7px;margin:1px 0}
.grev-num{font-size:18px;font-weight:800;color:#f5b50a}
.grev-stars{color:#f5b50a;letter-spacing:1px;font-size:14px}
.grev-sub{font-size:12px;color:#9a9488}
.fpartners{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.fpartners img{width:100%;height:52px;padding:6px 10px;border-radius:8px;object-fit:contain;background:#fff;box-shadow:0 1px 0 #00000030}
.fbottom{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-top:42px;padding-top:18px;border-top:1px solid #ffffff14;font-size:12.5px;color:#8b857a}
.flegal{display:flex;gap:20px}
.flegal a{color:#cfc9bd;text-decoration:underline;text-underline-offset:2px}
.flegal a:hover{color:var(--brass)}
.frecaptcha{margin-top:14px;padding-bottom:30px;font-size:11px;line-height:1.5;color:#6f6a60}
.frecaptcha a{color:#8b857a;text-decoration:underline}
@media(max-width:760px){.fgrid{grid-template-columns:1fr;gap:30px}.fbottom{flex-direction:column;align-items:flex-start}}

.reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.4,0,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:900px){
  .hgrid{grid-template-columns:1fr;gap:30px}.hphoto{order:-1;max-width:340px}
  .toolbox{grid-template-columns:1fr}.toolbox .left{padding:24px 16px}.toolbox .right{padding:24px 16px}.vsgrid{display:flex;flex-direction:column;gap:16px}
  .serrurier41-calculator{padding:10px!important}
  #resultats-calcul>div,.serrurier41-calculator [style*="padding: 15px"],.serrurier41-calculator [style*="padding:15px"]{padding:12px!important}
  .vsbadge{position:static;order:2;margin:-4px auto;top:auto;left:auto}
  .col.them{order:1}
  .col.us{order:3}
  .svc{grid-template-columns:1fr}.svc .it:nth-child(odd){padding-right:0;border-right:0}.svc .it:nth-child(even){padding-left:0}
  .revs{grid-template-columns:1fr}.dispo .box{grid-template-columns:1fr;gap:14px}
  .nav{flex-wrap:wrap;height:auto;padding:10px 0}
  .navtoggle{display:block;order:3}
  .nav .call{order:2;margin-left:auto;margin-right:10px}
  #site-nav.nlinks{order:4;flex-basis:100%;display:none}
  #site-nav.nlinks.open{display:block}
  .nlinks .menu{flex-direction:column;align-items:stretch;gap:0;padding:8px 0;margin-top:8px;border-top:1px solid var(--line)}
  .nlinks .menu a{padding:13px 4px;border-bottom:1px solid var(--line)}
  .nlinks .menu .menu-item-has-children>a::after{content:''}
  .nlinks .menu .sub-menu{position:static;display:block;border:none;box-shadow:none;padding:0 0 6px 16px;background:transparent;min-width:0}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}.bp:hover{transform:none}}

/* ============================================================
   AJOUTS THÈME — pages internes (.entry-content) & calculateur injecté
   ============================================================ */

/* Contenu éditorial des pages internes (pages villes, mentions, etc.) */
.entry-content{font-size:17px;line-height:1.7;color:var(--ink)}
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4{font-family:"Big Shoulders Display",sans-serif;font-weight:800;text-transform:uppercase;line-height:.95;letter-spacing:-.005em;color:var(--ink);margin:1.6em 0 .5em}
.entry-content h1{font-size:clamp(34px,5vw,58px)}
.entry-content h2{font-size:clamp(28px,4vw,44px);color:var(--brass)}
.entry-content h3{font-size:clamp(22px,3vw,30px)}
.entry-content h4{font-size:21px}
.entry-content p{margin:0 0 1.1em}
.entry-content a{color:var(--brass);text-decoration:underline;text-underline-offset:2px}
.entry-content a:hover{color:var(--ink)}
/* Classe « bordered » (héritée de l'ancien thème) : notes encadrées (Main d'œuvre, etc.) */
.bordered{border:1px solid var(--line2);border-radius:var(--r);padding:16px 20px;background:#fff;margin:0 0 14px}
/* Services : on encadre la COLONNE entière (titre+desc+prix = carte), pas juste le titre */
.entry-content .wp-block-column:has(> .bordered){border:1px solid var(--line2);border-radius:var(--r);padding:22px 24px;background:#fff}
.entry-content .wp-block-column:has(> .bordered) > .bordered{border:0;background:none;padding:0;margin:0 0 12px}
.entry-content strong,.entry-content b{font-weight:700}
.entry-content ul,.entry-content ol{margin:0 0 1.2em;padding-left:1.4em}
.entry-content li{margin:0 0 .5em}
.entry-content ul{list-style:none;padding-left:0}
.entry-content ul li{position:relative;padding-left:1.5em}
.entry-content ul li::before{content:"";position:absolute;left:.2em;top:.6em;width:7px;height:7px;background:var(--brass2);transform:rotate(45deg)}
.entry-content ol{list-style:decimal}
.entry-content ol li{padding-left:.3em}
.entry-content blockquote{margin:1.4em 0;padding:14px 22px;border-left:3px solid var(--brass);background:var(--surface);color:var(--steel);font-style:italic}
.entry-content img{max-width:100%;height:auto;display:block;border-radius:var(--r);margin:1.2em 0}
.entry-content figure{margin:1.4em 0}
.entry-content figure img{margin:0}
.entry-content figcaption{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--muted);margin-top:8px}
/* Images de bloc (photos/illustrations) : taille maîtrisée, centrées, cadre
   éditorial cohérent avec les photos du thème (au lieu de la pleine largeur brute). */
.entry-content .wp-block-image:not(.alignwide):not(.alignfull):not(.alignleft):not(.alignright){width:fit-content;max-width:min(100%,560px);margin-inline:auto}
.entry-content .wp-block-image img{border:1px solid var(--ink);box-shadow:6px 6px 0 var(--ink)}
.entry-content .wp-block-image figcaption{text-align:center}
.entry-content hr{border:0;border-top:1px solid var(--line2);margin:2em 0}
.entry-content code{font-family:"JetBrains Mono",monospace;font-size:.9em;background:var(--surface);padding:2px 6px;border-radius:var(--r)}
.entry-content table{width:100%;border-collapse:collapse;margin:1.4em 0;font-size:15px}
.entry-content table th,
.entry-content table td{border:1px solid var(--line2);padding:10px 14px;text-align:left}
.entry-content table th{background:var(--ink);color:var(--paper);font-family:"Big Shoulders Display",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.02em}
.entry-content table tr:nth-child(even) td{background:var(--surface)}

/* Wrap des pages internes : un peu d'air vertical */
main.wrap{padding-top:56px;padding-bottom:80px}

/* Titre de page (display, taille domptée pour les titres longs) */
.page-title{font-size:clamp(29px,4.2vw,52px);line-height:.96;margin:0;color:var(--ink)}

/* En-tête de page unifié (pages génériques, articles) */
.page-header{margin:0 0 36px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.page-header .s41-breadcrumb{margin-bottom:16px}

/* Hero des pages villes : texte + photo encadrée */
.ville-hero{display:grid;grid-template-columns:1.08fr .92fr;gap:50px;align-items:center;margin:0 0 52px;padding-bottom:40px;border-bottom:1px solid var(--line)}
.ville-hero .vh-text{min-width:0}
.ville-hero .s41-breadcrumb{margin-bottom:18px}
.ville-hero .eyebrow{display:block;margin-bottom:13px}
.ville-hero .page-title{margin-bottom:0}
.ville-hero .vh-photo{margin:0}
.ville-hero .vh-photo .fr{display:block;border:1px solid var(--ink);border-radius:var(--r);overflow:hidden;box-shadow:7px 7px 0 var(--ink);background:#ddd}
.ville-hero .vh-photo img{width:100%;height:auto;display:block}
.ville-hero .vh-cap{font-family:"JetBrains Mono",monospace;font-size:11.5px;letter-spacing:.02em;color:var(--muted);margin-top:14px;text-align:center}
@media(max-width:820px){
  .ville-hero{grid-template-columns:1fr;gap:30px;padding-bottom:34px;margin-bottom:40px}
  .ville-hero .vh-photo{max-width:460px}
}

/* Calculateur injecté via [distance_calculator] dans la section #prix.
   Les classes générées par le shortcode sont inconnues : on cible
   génériquement les champs du formulaire pour qu'ils héritent du design. */
.serrurier41-calculator form{margin:0}
.serrurier41-calculator form input[type=text],
.serrurier41-calculator form input[type=search],
.serrurier41-calculator form input[type=tel],
.serrurier41-calculator form input[type=number],
.serrurier41-calculator form input:not([type]),
.serrurier41-calculator form select{
  width:100%;
  padding:14px;
  border:1px solid var(--line2);
  border-radius:var(--r);
  font-size:15px;
  background:#fff;
  color:var(--ink);
  font-family:inherit;
  margin-bottom:10px;
}
.serrurier41-calculator form input::placeholder{color:var(--muted)}
.serrurier41-calculator form input[type=submit]{
  width:100%;
  background:var(--brass);
  color:#fff;
  border:none;
  padding:15px;
  border-radius:var(--r);
  font-weight:700;
  font-size:15px;
  font-family:inherit;
  cursor:pointer;
  box-shadow:3px 3px 0 var(--ink);
  transition:.12s;
}
.serrurier41-calculator form button:hover,
.serrurier41-calculator form input[type=submit]:hover{filter:brightness(1.06)}
/* Boutons secondaires éventuels (GPS, etc.) restent verts si la classe existe */
.serrurier41-calculator form .gps,
.serrurier41-calculator form button.gps{background:var(--green);box-shadow:none;width:auto;padding:0 14px}
/* Bouton GPS : largeur auto (sinon il écrase le champ adresse) */
.serrurier41-calculator form #geolocate-btn{width:auto;flex:0 0 auto}
/* Titre du shortcode masqué sur la home (doublon avec « Calculez en 10 secondes ») */
#prix .serrurier41-calculator h2{display:none}
/* Résultats / texte du calculateur dans le panneau sombre */
#prix .toolbox .left{color:var(--ink)}
/* Calculateur en panneau crème PARTOUT (Tarifs, villes) — cohérent avec la home */
.serrurier41-calculator{background:var(--surface);border:1px solid var(--line2);border-radius:var(--r);padding:26px 28px;margin:20px 0}
/* Sur la home il est déjà dans .toolbox -> pas de double cadre */
#prix .serrurier41-calculator{background:none;border:0;border-radius:0;padding:0;margin:0}
/* Les tableaux du calculateur ont leurs couleurs en INLINE (laiton sur les <tr>).
   On neutralise le style générique .entry-content table (en-tête noir + lignes paires
   crème) qui les écrasait sur Tarifs/villes -> le laiton inline réapparait. */
.s41-ptable th,.s41-ptable td{background:transparent !important}

/* ===== ANIMATIONS — CSS natif, perf-friendly ===== */
@view-transition{navigation:auto}

@keyframes s41-rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes s41-fade{from{opacity:0}to{opacity:1}}
@keyframes s41-stamp{from{opacity:0;transform:rotate(-14deg) scale(.55)}to{opacity:1;transform:rotate(7deg) scale(1)}}

/* Entrée du hero orchestrée (au chargement) */
.hero .eyebrow{animation:s41-rise .7s .05s both}
/* L'eyebrow du hero porte le H1 sur l'accueil : on neutralise les défauts du h1
   (taille/marges) pour garder strictement l'apparence de l'eyebrow. */
.hero h1.eyebrow{margin:0;font-size:12px}
.hero .htitle{animation:s41-rise .8s .16s both}
.hero .sub{animation:s41-rise .7s .34s both}
.hero .stats{animation:s41-rise .7s .46s both}
.hero .cta{animation:s41-rise .7s .58s both}
.hphoto .fr{animation:s41-fade 1s .4s both}
.hphoto .tag{animation:s41-rise .6s .9s both}
.hphoto .stamp{animation:s41-stamp .7s 1s both}

/* Reveal directionnel — le duel VS se confronte */
.reveal-l,.reveal-r,.reveal-pop{opacity:0;transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1)}
.reveal-l{transform:translateX(-40px)}
.reveal-r{transform:translateX(40px)}
.reveal-pop{transform:scale(.55)}
.reveal-l.in,.reveal-r.in,.reveal-pop.in{opacity:1;transform:none}
.vsbadge.reveal-pop{transition-delay:.2s;transition-timing-function:cubic-bezier(.34,1.56,.64,1)}

/* Micro-interactions (sans casser le reveal) */
.svc .it{transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1),background-color .25s ease}
.svc .it:hover{background-color:var(--surface)}
.svc .n{transition:transform .25s ease}
.svc .it:hover .n{transform:translateX(3px)}
.rev{transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1),box-shadow .25s ease}
.rev:hover{box-shadow:0 14px 30px #00000014}
.vbtn{transition:transform .2s ease,border-color .2s ease,color .2s ease}
.vbtn:hover{transform:translateY(-2px);border-color:var(--brass);color:var(--brass)}

@media(prefers-reduced-motion:reduce){
  .hero .eyebrow,.hero .htitle,.hero .sub,.hero .stats,.hero .cta,.hphoto .fr,.hphoto .tag,.hphoto .stamp{animation:none!important}
  .reveal-l,.reveal-r,.reveal-pop{opacity:1!important;transform:none!important;transition:none!important}
}

/* Fil d'Ariane */
.s41-breadcrumb{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.02em;color:var(--muted);margin:0 0 18px;display:flex;flex-wrap:wrap;align-items:center;gap:7px;line-height:1.4}
.s41-breadcrumb a{color:var(--muted);text-decoration:none;transition:color .15s}
.s41-breadcrumb a:hover{color:var(--brass)}
.s41-breadcrumb .sep{color:var(--line2)}
.s41-breadcrumb .current{color:var(--ink);font-weight:600}

/* Listes d'articles (archives, catégories, blog, recherche) */
.archive-desc{margin-top:14px;color:var(--muted);max-width:62ch}
.blog-layout{display:grid;grid-template-columns:1fr 290px;gap:50px;align-items:start}
.blog-main{min-width:0}
/* Colonne latérale blog */
.blog-side{position:sticky;top:88px;display:flex;flex-direction:column;gap:30px}
.bs-title{font-family:"Big Shoulders Display",sans-serif;font-weight:800;text-transform:uppercase;font-size:18px;letter-spacing:.02em;margin:0 0 12px;color:var(--ink);padding-bottom:8px;border-bottom:2px solid var(--brass)}
.bs-search{display:flex;border:1px solid var(--line2);border-radius:var(--r);overflow:hidden;background:#fff}
.bs-search input{flex:1;min-width:0;border:0;padding:11px 14px;font-family:inherit;font-size:14px;background:transparent}
.bs-search input:focus{outline:none}
.bs-search button{border:0;background:var(--brass);color:#fff;padding:0 16px;cursor:pointer;font-size:16px;font-weight:700}
.bs-search button:hover{background:var(--ink)}
.bs-list{list-style:none;margin:0;padding:0;font-size:14.5px}
.bs-list li{padding:8px 0;border-bottom:1px solid var(--line)}
.bs-list li:last-child{border-bottom:0}
.bs-list a{color:var(--steel);text-decoration:none;transition:color .15s}
.bs-list a:hover{color:var(--brass)}
.bs-list .children{padding-left:14px;margin-top:8px;border-top:1px solid var(--line)}
@media(max-width:900px){
  .blog-layout{grid-template-columns:1fr;gap:30px}
  .blog-side{position:static;flex-direction:row;flex-wrap:wrap;gap:24px 36px}
  .blog-side .bs-block{flex:1;min-width:210px}
}
.post-list{display:flex;flex-direction:column;gap:0;margin:0 0 44px}
.post-card{display:grid;grid-template-columns:300px 1fr;gap:30px;align-items:center;padding:28px 0;border-bottom:1px solid var(--line)}
.post-card:first-child{padding-top:4px}
.post-card:last-child{border-bottom:0}
.pc-thumb{display:block;border:1px solid var(--ink);border-radius:var(--r);overflow:hidden;box-shadow:5px 5px 0 var(--ink);aspect-ratio:16/11;background:#ddd}
.pc-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.pc-title{font-family:"Big Shoulders Display",sans-serif;font-weight:800;text-transform:uppercase;font-size:clamp(21px,2.3vw,29px);line-height:.98;margin:0 0 9px}
.pc-title a{color:var(--ink);text-decoration:none}
.pc-title a:hover{color:var(--brass)}
.pc-excerpt{color:var(--steel);font-size:15px;margin:0 0 12px}
.pc-excerpt p{margin:0 0 5px}
.pc-excerpt p:last-child{margin:0}
.pc-excerpt .more-link{display:none}
.pc-excerpt h2,.pc-excerpt h3{display:none}
.pc-more{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:13px;font-weight:600;color:var(--brass);text-decoration:none}
.pc-more:hover{text-decoration:underline}
.pagination{display:flex;gap:8px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;min-width:42px;justify-content:center;padding:9px 13px;border:1px solid var(--line2);border-radius:var(--r);font-family:"JetBrains Mono",monospace;font-size:14px;color:var(--steel);text-decoration:none}
.pagination .page-numbers.current{background:var(--brass);color:#fff;border-color:var(--brass)}
.pagination a.page-numbers:hover{border-color:var(--ink);color:var(--ink)}
@media(max-width:680px){
  .post-card{grid-template-columns:1fr;gap:14px}
  .pc-thumb{aspect-ratio:16/9}
}

/* Embeds responsive (vidéos YouTube, etc.) — le thème ne charge pas le CSS
   de wp-block-library, on fournit l'aspect-ratio nous-mêmes. */
.entry-content .wp-block-embed{margin:1.6em auto;max-width:760px}
.entry-content .wp-block-embed.alignwide,.entry-content .wp-block-embed.alignfull{max-width:none}
.wp-block-embed__wrapper{position:relative}
.wp-has-aspect-ratio .wp-block-embed__wrapper::before{content:"";display:block}
.wp-embed-aspect-16-9 .wp-block-embed__wrapper::before{padding-top:56.25%}
.wp-embed-aspect-4-3 .wp-block-embed__wrapper::before{padding-top:75%}
.wp-embed-aspect-1-1 .wp-block-embed__wrapper::before{padding-top:100%}
.wp-embed-aspect-21-9 .wp-block-embed__wrapper::before{padding-top:42.85%}
.wp-has-aspect-ratio .wp-block-embed__wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* Menu mobile ouvert : verrouiller le scroll de la page (sinon l'arrière-plan
   défile sous le doigt) + rendre le menu scrollable s'il dépasse l'écran. */
html.menu-open{overflow:hidden}
@media(max-width:900px){
  #site-nav.nlinks.open{max-height:calc(100dvh - 64px);overflow-y:auto;overscroll-behavior:contain}
}
