/*
Theme Name: Soserrurier
Theme URI: https://sosserrurierparis.fr
Author: Atelier sur-mesure (Cowork)
Description: Theme WordPress sur-mesure pour SOS Serrurier - artisan serrurier a Paris. Identite artisanale : laiton, encre profonde et papier chaud, typographie a caractere, tarifs transparents. Aucun framework parent.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: soserrurier
*/

/* ============================================================
   FONTS (auto-hebergees - RGPD friendly)
   ============================================================ */
@font-face{font-family:"Fraunces";src:url("assets/fonts/fraunces-latin-500-normal.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("assets/fonts/fraunces-latin-600-normal.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("assets/fonts/fraunces-latin-600-italic.woff2") format("woff2");font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:"Fraunces";src:url("assets/fonts/fraunces-latin-700-normal.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("assets/fonts/hanken-grotesk-latin-400-normal.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("assets/fonts/hanken-grotesk-latin-500-normal.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("assets/fonts/hanken-grotesk-latin-600-normal.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken Grotesk";src:url("assets/fonts/hanken-grotesk-latin-700-normal.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ============================================================
   TOKENS
   ============================================================ */
:root{
  --ink:#16242E; --ink-700:#21333E; --ink-900:#0E1920;
  --paper:#F3ECDE; --paper-2:#FBF7EE; --card:#FCFAF4;
  --brass:#BE8C36; --brass-600:#A1722A; --brass-300:#E6CD96; --brass-050:#F3E7CB;
  --brick:#B23A2E; --brick-700:#8E2C22;
  --steel:#54646D; --muted:#7B7261;
  --line:#E4D9C3; --line-2:#D7C9AC;
  --ok:#2E7D4F;
  --ink-on:#F6EFE0;
  --font-head:"Fraunces",Georgia,"Times New Roman",serif;
  --font-body:"Hanken Grotesk",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --wrap:1180px; --wrap-narrow:880px;
  --gutter:clamp(1rem,4vw,2.5rem);
  --radius:3px; --radius-lg:7px;
  --shadow-sm:0 1px 2px rgba(20,30,38,.06),0 2px 8px rgba(20,30,38,.05);
  --shadow:0 12px 36px rgba(20,30,38,.10),0 3px 10px rgba(20,30,38,.06);
  --shadow-brass:0 14px 40px rgba(120,86,24,.16);
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ============================================================
   BASE / RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:clip}
body{overflow-x:clip}
body{
  margin:0;background-color:var(--paper);color:var(--ink);
  font-family:var(--font-body);font-size:1.0625rem;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
img{max-width:100%;height:auto;display:block}
a{color:var(--brass-600);text-underline-offset:3px;text-decoration-thickness:1px}
a:hover{color:var(--ink)}
strong,b{font-weight:700}
::selection{background:var(--brass-300);color:var(--ink-900)}
:focus-visible{outline:2px solid var(--brass);outline-offset:3px;border-radius:2px}

h1,h2,h3,h4{font-family:var(--font-head);color:var(--ink);font-weight:600;line-height:1.08;margin:0 0 .5em;letter-spacing:-.012em}
h1{font-size:clamp(2.3rem,1.4rem + 3.6vw,3.7rem);font-weight:600}
h2{font-size:clamp(1.8rem,1.2rem + 2.2vw,2.7rem)}
h3{font-size:clamp(1.25rem,1rem + 1vw,1.6rem)}
p{margin:0 0 1.1em}
em,i{font-style:italic}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.wrap--narrow{max-width:var(--wrap-narrow)}
.section{padding-block:clamp(3.2rem,2rem + 5vw,6rem)}
.section--paper2{background:var(--paper-2)}
.section--ink{background:var(--ink);color:var(--ink-on)}
.section--ink h1,.section--ink h2,.section--ink h3{color:#fff}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.7rem 1rem;z-index:1000}
.skip-link:focus{left:8px;top:8px}

/* shared bits */
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-body);font-weight:600;
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-600);margin:0 0 1rem}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--brass);display:inline-block}
.section--ink .eyebrow{color:var(--brass-300)}
.lead{font-size:clamp(1.08rem,1rem + .5vw,1.28rem);color:#3a4750;line-height:1.6}
.section--ink .lead{color:#cdd6da}
.accent-i{font-style:italic;color:var(--brass-600);font-weight:600}
.section--ink .accent-i{color:var(--brass-300)}
.measure{max-width:56ch}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{--bg:var(--ink);--fg:#fff;--bd:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-body);font-weight:600;font-size:1rem;line-height:1;
  padding:.95rem 1.5rem;border:1.5px solid var(--bd);border-radius:var(--radius);
  background:var(--bg);color:var(--fg);text-decoration:none;cursor:pointer;
  transition:transform .15s var(--ease),box-shadow .2s var(--ease),background .2s,color .2s;
  box-shadow:var(--shadow-sm)}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow);color:var(--fg)}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn--brick{--bg:var(--brick);--bd:var(--brick);--fg:#fff}
.btn--brick:hover{--bg:var(--brick-700)}
.btn--brass{--bg:var(--brass);--bd:var(--brass);--fg:#2a1f08}
.btn--brass:hover{--bg:var(--brass-600);--fg:#fff}
.btn--ghost{--bg:transparent;--fg:var(--ink);--bd:var(--line-2)}
.btn--ghost:hover{--bg:var(--ink);--fg:#fff;--bd:var(--ink)}
.section--ink .btn--ghost{--fg:#fff;--bd:rgba(255,255,255,.4)}
.section--ink .btn--ghost:hover{--bg:#fff;--fg:var(--ink)}
.btn--lg{padding:1.1rem 1.9rem;font-size:1.08rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}

/* ============================================================
   TOPBAR + HEADER
   ============================================================ */
.topbar{background:var(--ink-900);color:#c9d2d6;font-size:.84rem;letter-spacing:.01em}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:40px;padding-block:.35rem}
.topbar a{color:#e7ecee;text-decoration:none;font-weight:600}
.topbar a:hover{color:var(--brass-300)}
.topbar-info{display:flex;gap:1.4rem;align-items:center}
.topbar-info span{display:inline-flex;align-items:center;gap:.45rem}
.topbar-info svg{width:15px;height:15px;color:var(--brass-300)}
.topbar .dot-ok{width:8px;height:8px;border-radius:50%;background:#46c07e;box-shadow:0 0 0 3px rgba(70,192,126,.18)}

.site-header{position:sticky;top:0;z-index:90;background:rgba(243,236,222,.92);
  backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .3s,background .3s}
.site-header.is-stuck{box-shadow:0 6px 24px rgba(20,30,38,.10);background:rgba(247,242,232,.97)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:78px}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink)}
.brand__key{width:42px;height:42px;flex:none;display:grid;place-items:center;
  background:var(--ink);border-radius:50%;color:var(--brass-300);box-shadow:inset 0 0 0 2px var(--brass)}
.brand__key svg{width:21px;height:21px}
.brand__name{font-family:var(--font-head);font-weight:600;font-size:1.32rem;line-height:1;letter-spacing:-.01em}
.brand__name b{color:var(--brass-600);font-weight:600}
.brand__tag{display:block;font-family:var(--font-body);font-size:.72rem;letter-spacing:.13em;
  text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:.28rem}

.nav{display:flex;align-items:center;gap:.3rem}
.nav a{font-family:var(--font-body);font-weight:600;font-size:1rem;color:var(--ink);text-decoration:none;
  padding:.55rem .8rem;border-radius:var(--radius);position:relative}
.nav a::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.32rem;height:2px;background:var(--brass);
  transform:scaleX(0);transform-origin:left;transition:transform .22s var(--ease)}
.nav a:hover::after,.nav .current-menu-item>a::after{transform:scaleX(1)}
.nav .current-menu-item>a{color:var(--brass-600)}
.header-actions{display:flex;align-items:center;gap:.8rem}
.header-phone{display:inline-flex;align-items:center;gap:.55rem;text-decoration:none;font-weight:700;color:var(--ink)}
.header-phone .lab{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;display:block;line-height:1}
.header-phone .num{font-size:1.12rem;line-height:1.1}
.header-phone svg{width:34px;height:34px;color:var(--brick)}

.nav-toggle{display:none;align-items:center;justify-content:center;width:46px;height:46px;border:1.5px solid var(--line-2);
  background:var(--paper-2);border-radius:var(--radius);cursor:pointer;color:var(--ink)}
.nav-toggle svg{width:24px;height:24px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:
   radial-gradient(120% 90% at 88% -10%,rgba(190,140,54,.14),transparent 60%),
   linear-gradient(180deg,var(--paper-2),var(--paper));
   border-bottom:1px solid var(--line);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);
  align-items:center;padding-block:clamp(3rem,2rem + 5vw,5.5rem)}
.hero h1{margin-bottom:.55em}
.hero-trust{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin-top:1.7rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.hero-trust li{list-style:none;display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;color:var(--ink-700)}
.hero-trust svg{width:18px;height:18px;color:var(--brass-600);flex:none}
.hero-rating{display:inline-flex;align-items:center;gap:.4rem}
.stars{color:var(--brass);letter-spacing:1px}

/* plaque card */
.plaque{position:relative;background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);padding:1.7rem 1.7rem 1.5rem}
.plaque::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  background:linear-gradient(90deg,var(--brass-600),var(--brass-300),var(--brass-600))}
.plaque h2{font-size:1.15rem;letter-spacing:.02em;margin:.2rem 0 .2rem}
.plaque .plaque-sub{font-size:.85rem;color:var(--muted);margin:0 0 1.1rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.plaque-phone{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink);
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:.85rem 1rem;margin-bottom:.7rem}
.plaque-phone svg{width:30px;height:30px;color:var(--brick);flex:none}
.plaque-phone .num{font-family:var(--font-head);font-weight:600;font-size:1.5rem;line-height:1}
.plaque-phone .lab{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}
.plaque-list{list-style:none;margin:.8rem 0 0;padding:.8rem 0 0;border-top:1px dashed var(--line-2);display:grid;gap:.55rem}
.plaque-list li{display:flex;align-items:center;gap:.6rem;font-size:.95rem;color:var(--ink-700)}
.plaque-list svg{width:17px;height:17px;color:var(--ok);flex:none}
/* wax seal */
.seal{position:absolute;right:-18px;top:-22px;width:96px;height:96px;transform:rotate(-9deg);filter:drop-shadow(0 6px 10px rgba(120,86,24,.25))}
.seal svg{width:100%;height:100%}
@media(max-width:560px){.seal{width:74px;height:74px;right:-6px;top:-14px}}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trustband{background:var(--ink);color:var(--ink-on)}
.trustband .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding-block:0}
.trustband .ti{display:flex;align-items:flex-start;gap:.8rem;padding:1.5rem 1.4rem}
.trustband .ti+.ti{border-left:1px solid rgba(230,205,150,.18)}
.trustband svg{width:26px;height:26px;color:var(--brass-300);flex:none;margin-top:2px}
.trustband b{display:block;font-size:1rem;font-weight:700;color:#fff;margin-bottom:.1rem}
.trustband span{font-size:.86rem;color:#b9c2c6;line-height:1.4}

/* ============================================================
   SERVICES / TARIFS  (menu-style, transparent)
   ============================================================ */
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:2.2rem}
.tarifs{display:grid;grid-template-columns:1fr 1fr;gap:0 3.5rem}
.tarif{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:.4rem 1rem;
  padding:1.15rem 0;border-top:1px solid var(--line)}
.tarif:nth-child(-n+2){border-top:none}
.tarif__ico{grid-row:span 2;width:42px;height:42px;display:grid;place-items:center;align-self:center;
  border:1px solid var(--line-2);border-radius:50%;color:var(--brass-600);background:var(--paper-2)}
.tarif__ico svg{width:21px;height:21px}
.tarif__name{font-family:var(--font-head);font-weight:600;font-size:1.16rem;color:var(--ink)}
.tarif__lead{border-bottom:1px dotted var(--line-2);transform:translateY(-4px);min-width:18px}
.tarif__price{font-family:var(--font-head);font-weight:600;font-size:1rem;color:var(--brass-600);white-space:nowrap}
.tarif__desc{grid-column:2/4;font-size:.92rem;color:var(--steel);margin-top:.1rem}
.tarif-note{margin-top:2rem;display:flex;gap:.8rem;align-items:flex-start;background:var(--brass-050);
  border:1px solid var(--brass-300);border-radius:var(--radius-lg);padding:1rem 1.2rem;font-size:.95rem;color:#5b4a23}
.tarif-note svg{width:22px;height:22px;color:var(--brass-600);flex:none;margin-top:1px}

/* ============================================================
   ENGAGEMENTS
   ============================================================ */
.pledges{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.pledge{background:var(--card);padding:1.6rem 1.5rem}
.pledge__n{display:flex;align-items:center;gap:.7rem;margin-bottom:.6rem}
.pledge__n svg{width:24px;height:24px;color:var(--brass-600)}
.pledge h3{font-size:1.12rem;margin:0}
.pledge p{margin:0;color:var(--steel);font-size:.95rem}

/* ============================================================
   PROCESS
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;counter-reset:s}
.step{position:relative;padding-top:.4rem}
.step__num{font-family:var(--font-head);font-weight:700;font-size:2.6rem;color:var(--brass);line-height:1;
  display:flex;align-items:center;gap:.7rem}
.step__num::after{content:"";flex:1;height:1px;background:var(--line-2)}
.step:last-child .step__num::after{display:none}
.step h3{font-size:1.12rem;margin:.7rem 0 .25rem}
.step p{margin:0;color:#cdd6da;font-size:.94rem}
.section--ink .step p{color:#b4bec3}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews-top{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:1.2rem 1.5rem;box-shadow:var(--shadow-sm)}
.reviews-grade{font-family:var(--font-head);font-weight:700;font-size:2.6rem;color:var(--ink);line-height:1}
.reviews-meta{flex:1;min-width:180px}
.reviews-meta .stars{font-size:1.2rem}
.reviews-meta small{color:var(--muted)}
.gicon{width:22px;height:22px;vertical-align:-5px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.6rem}
.review{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.3rem;box-shadow:var(--shadow-sm)}
.review .stars{font-size:1rem;margin-bottom:.5rem;display:block}
.review p{font-size:.98rem;color:var(--ink-700);margin:0 0 .9rem}
.review cite{font-style:normal;font-weight:700;font-size:.92rem;color:var(--ink)}
.review cite span{display:block;font-weight:500;color:var(--muted);font-size:.82rem}

/* ============================================================
   ZONES
   ============================================================ */
.zones-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
.zone-list{columns:2;column-gap:2rem;list-style:none;margin:1.2rem 0 0;padding:0}
.zone-list li{break-inside:avoid;padding:.4rem 0;border-bottom:1px dotted var(--line-2);display:flex;align-items:center;gap:.5rem;font-weight:500}
.zone-list svg{width:15px;height:15px;color:var(--brass-600)}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{background:
   radial-gradient(100% 140% at 0% 0%,rgba(190,140,54,.22),transparent 55%),var(--ink-900);
   color:#fff;border-radius:var(--radius-lg)}
.cta-band .inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;
  padding:clamp(1.8rem,1rem + 3vw,3rem) clamp(1.5rem,1rem + 3vw,3.2rem)}
.cta-band h2{color:#fff;margin:0 0 .3rem;max-width:22ch}
.cta-band p{margin:0;color:#cdd6da}

/* ============================================================
   PAGE (contenu generique / blocs)
   ============================================================ */
.page-hero{background:linear-gradient(180deg,var(--paper-2),var(--paper));border-bottom:1px solid var(--line)}
.page-hero .wrap{padding-block:clamp(2.4rem,2rem + 3vw,4rem)}
.page-hero .crumbs{font-size:.85rem;color:var(--muted);margin-bottom:.8rem}
.page-hero .crumbs a{color:var(--brass-600);text-decoration:none}
.entry-content{font-size:1.06rem}
.entry-content>*{margin-bottom:1.2rem}
.entry-content h2{margin-top:1.8rem}
.entry-content h3{margin-top:1.4rem}
.entry-content ul,.entry-content ol{padding-left:1.3rem}
.entry-content li{margin-bottom:.4rem}
.entry-content blockquote{border-left:3px solid var(--brass);margin:1.5rem 0;padding:.4rem 0 .4rem 1.3rem;
  font-family:var(--font-head);font-style:italic;font-size:1.2rem;color:var(--ink-700)}
.entry-content a{font-weight:600}
.entry-content img,.entry-content figure{border-radius:var(--radius-lg)}
.entry-content table{width:100%;border-collapse:collapse}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:.6rem .8rem;text-align:left}

/* posts */
.post-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.post-card .pc-body{padding:1.3rem}
.post-card h3{margin:0 0 .4rem}
.post-meta{font-size:.85rem;color:var(--muted)}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink-900);color:#aeb8bd;font-size:.95rem}
.site-footer .wrap{padding-block:clamp(2.6rem,2rem + 3vw,4rem)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2rem}
.site-footer h4{color:#fff;font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:.14em;
  text-transform:uppercase;margin:0 0 1rem}
.site-footer a{color:#cdd6da;text-decoration:none}
.site-footer a:hover{color:var(--brass-300)}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.foot-brand .brand__name{color:#fff;font-size:1.3rem}
.foot-brand .brand__name b{color:var(--brass-300)}
.foot-brand .brand__key{background:#1c2c36;box-shadow:inset 0 0 0 2px var(--brass)}
.foot-blurb{margin:1rem 0 1.1rem;color:#9aa4a9;max-width:34ch}
.foot-rating{display:inline-flex;align-items:center;gap:.6rem;background:#16242e;border:1px solid #283a45;
  border-radius:var(--radius);padding:.6rem .85rem}
.foot-rating .stars{font-size:1.05rem}
.foot-rating b{color:#fff}
.foot-contact li{display:flex;gap:.6rem;align-items:flex-start}
.foot-contact svg{width:17px;height:17px;color:var(--brass-300);flex:none;margin-top:3px}
.foot-pay{display:flex;align-items:center;gap:.6rem;margin-top:1rem;color:#8b969b;font-size:.82rem;flex-wrap:wrap}
.foot-pay span{border:1px solid #2b3d48;border-radius:3px;padding:.25rem .5rem;font-weight:600;color:#c2cbd0}
.footer-bottom{border-top:1px solid #233139;margin-top:2.2rem;padding-top:1.4rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#7e898e}
.footer-bottom a{color:#9aa4a9}

/* ============================================================
   STICKY MOBILE CALL BAR
   ============================================================ */
.callbar{display:none}
@media(max-width:860px){
  .callbar{display:grid;grid-template-columns:1fr 1fr;gap:1px;position:fixed;left:0;right:0;bottom:0;z-index:120;
    background:var(--line-2);box-shadow:0 -4px 16px rgba(0,0,0,.18)}
  .callbar a{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem;
    font-weight:700;text-decoration:none;font-size:1.02rem}
  .callbar .c-phone{background:var(--brick);color:#fff}
  .callbar .c-quote{background:var(--ink);color:#fff}
  .callbar svg{width:19px;height:19px}
  body{padding-bottom:60px}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:2.2rem}
  .plaque{max-width:460px}
  .tarifs{grid-template-columns:1fr;gap:0}
  .tarif:nth-child(2){border-top:1px solid var(--line)}
  .pledges{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:1.8rem 1.4rem}
  .reviews-grid{grid-template-columns:1fr}
  .zones-grid{grid-template-columns:1fr}
  .trustband .wrap{grid-template-columns:1fr 1fr}
  .trustband .ti:nth-child(3){border-left:none}
  .trustband .ti:nth-child(odd){border-left:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .topbar{display:none}
  .nav,.header-phone .lab{display:none}
  .nav-toggle{display:inline-flex}
  .site-header .wrap{min-height:64px}
  .site-nav{position:fixed;top:0;right:0;bottom:0;left:auto;width:min(86vw,340px);background:var(--paper-2);
    height:100vh;height:100dvh;
    transform:translateX(100%);transition:transform .3s var(--ease);z-index:200;
    box-shadow:-20px 0 40px rgba(0,0,0,.15);padding:5rem 1.4rem 2rem;overflow-y:auto}
  .site-nav.is-open{transform:translateX(0)}
  .site-nav .nav{display:flex;flex-direction:column;align-items:stretch;gap:.2rem}
  .site-nav .nav a{padding:.9rem .6rem;border-bottom:1px solid var(--line);border-radius:0;font-size:1.1rem}
  .site-nav .nav a::after{display:none}
  .nav-backdrop{position:fixed;inset:0;background:rgba(14,25,32,.45);opacity:0;visibility:hidden;
    transition:.3s;z-index:150}
  .nav-backdrop.is-open{opacity:1;visibility:visible}
  .nav-close{position:absolute;top:1rem;right:1rem;width:42px;height:42px;border:none;background:none;cursor:pointer;color:var(--ink)}
  .nav-close svg{width:26px;height:26px}
  .nav-cta-mobile{margin-top:1.4rem}
  .nav-cta-mobile .btn{width:100%}
  .pledges{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .zone-list{columns:1}
  .cta-band .inner{flex-direction:column;align-items:flex-start}
}
@media(min-width:761px){.site-nav{display:contents}.nav-close,.nav-backdrop,.nav-cta-mobile{display:none}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}}

/* ============================================================
   FIXES / AFFINAGES
   ============================================================ */
/* Menu : reset liste + sous-menus deroulants */
.nav,.nav ul{list-style:none;margin:0;padding:0}
.nav>li{position:relative}
.nav .sub-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:230px;background:var(--paper-2);
  border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:.4rem;
  display:none;z-index:95}
.nav>li:hover>.sub-menu,.nav>li:focus-within>.sub-menu{display:block}
.nav .sub-menu li{display:block}
.nav .sub-menu a{display:block;padding:.55rem .7rem;border-radius:var(--radius);font-size:.96rem}
.nav .sub-menu a::after{display:none}
.nav .menu-item-has-children>a{padding-right:1.25rem}
.nav .menu-item-has-children>a:before{content:"";position:absolute;right:.55rem;top:50%;width:6px;height:6px;
  border-right:2px solid var(--steel);border-bottom:2px solid var(--steel);transform:translateY(-70%) rotate(45deg)}
/* Topbar : icones contraintes */
.topbar svg{width:15px;height:15px}
.topbar-actions a{display:inline-flex;align-items:center;gap:.45rem}
.topbar-actions svg{color:var(--brass-300)}
/* Plaque : empiler libelle + numero */
.plaque-phone>span{display:flex;flex-direction:column;gap:3px}
/* Wordmark : pas de soulignement */
.brand{text-decoration:none}
.brand:hover{color:var(--ink)}
.entry-content>*:first-child{margin-top:0}

/* ===== Polish mobile ===== */
@media(max-width:760px){
  .tarif{grid-template-columns:auto 1fr}
  .tarif__ico{grid-row:1/4}
  .tarif__name{grid-column:2;grid-row:1}
  .tarif__lead{display:none}
  .tarif__price{grid-column:2;grid-row:2;justify-self:start;margin-top:.15rem}
  .tarif__desc{grid-column:2;grid-row:3}
  .svc-head{gap:1rem}
  .reviews-top{gap:.6rem 1rem}
}
@media(max-width:480px){
  .brand__tag{display:none}
  .brand__name{font-size:1.15rem}
  .brand__key{width:38px;height:38px}
  .brand__key svg{width:19px;height:19px}
  .header-phone .num{font-size:1rem}
  .header-phone svg{width:30px;height:30px}
  .site-header .wrap{gap:.5rem;min-height:60px}
  .hero .wrap{padding-block:2.2rem}
  .btn{padding:.85rem 1.1rem}
  .btn--lg{padding:.95rem 1.15rem;font-size:1rem}
  .hero .btn-row{width:100%}
  .hero .btn-row .btn{flex:1 1 140px}
  .plaque{padding:1.4rem 1.3rem}
  .plaque-phone .num{font-size:1.35rem}
  .section{padding-block:2.8rem}
  .cta-band .inner .btn-row{width:100%}
  .cta-band .inner .btn{flex:1 1 150px}
  .reviews-grade{font-size:2.2rem}
  .trustband .ti{padding:1.2rem 1.1rem}
}

/* ===== Corrections round 2 ===== */
.btn{white-space:nowrap}
.cta-band .btn--ghost{--fg:#fff;--bd:rgba(255,255,255,.45)}
.cta-band .btn--ghost:hover{--bg:#fff;--fg:var(--ink);--bd:#fff}
/* Mobile : pas de backdrop-filter sur l'en-tete (sinon il devient le bloc
   contenant du menu fixe -> le drawer part hors-ecran au scroll). Fond solide. */
@media(max-width:760px){
  .site-header,.site-header.is-stuck{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--paper)}
}
/* Eyebrow hero compact pour tenir sur une ligne sur petits ecrans */
@media(max-width:480px){
  .hero .eyebrow{font-size:.72rem;letter-spacing:.08em}
  .hero .eyebrow::before{display:none}
}

/* ============================================================
   PAGE CONTACT
   ============================================================ */
.contact-urgence{background:var(--ink);color:var(--ink-on)}
.contact-urgence .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem 1.5rem;flex-wrap:wrap;padding-block:1rem}
.contact-urgence>div{display:flex;align-items:center;gap:.6rem;font-size:1.02rem}
.contact-urgence strong{color:#fff}
.contact-urgence svg{width:22px;height:22px;color:var(--brass-300);flex:none}
.contact-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.contact-main h2{margin-bottom:.3rem}
.contact-intro{color:var(--steel);margin-bottom:1.6rem}
.req{color:var(--brick);font-weight:700}
.sos-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.sos-form .field{margin-bottom:1.1rem;display:flex;flex-direction:column;gap:.4rem}
.sos-form label{font-weight:600;font-size:.95rem;color:var(--ink)}
.sos-form input,.sos-form select,.sos-form textarea{font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--card);border:1.5px solid var(--line-2);border-radius:var(--radius);padding:.8rem .9rem;width:100%;
  transition:border-color .15s,box-shadow .15s}
.sos-form textarea{resize:vertical;min-height:130px}
.sos-form input:focus,.sos-form select:focus,.sos-form textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(190,140,54,.18)}
.sos-form [aria-invalid="true"]{border-color:var(--brick);box-shadow:0 0 0 3px rgba(178,58,46,.14)}
.field-error{color:var(--brick);font-size:.86rem;font-weight:600}
.field--check .checkbox{display:flex;align-items:flex-start;gap:.6rem;font-weight:500;color:var(--steel);cursor:pointer}
.field--check input{width:auto;margin-top:.2rem;accent-color:var(--brass-600)}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.form-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.4rem}
.form-hint{color:var(--muted);font-size:.9rem}
.form-notice{display:flex;gap:.7rem;align-items:flex-start;border-radius:var(--radius-lg);padding:1rem 1.2rem;margin-bottom:1.4rem;font-size:.98rem}
.form-notice svg{width:22px;height:22px;flex:none;margin-top:1px}
.form-notice a{font-weight:700}
.form-notice--ok{background:#e8f3ec;border:1px solid #b9dcc6;color:#1d5b38}
.form-notice--ok svg{color:var(--ok)}
.form-notice--err{background:#f7e3e1;border:1px solid #e3b4ae;color:#8e2c22}
.contact-card{background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.6rem 1.5rem;position:relative}
.contact-card::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:linear-gradient(90deg,var(--brass-600),var(--brass-300),var(--brass-600))}
.contact-card h2{font-size:1.2rem;margin-bottom:1rem}
.contact-card .plaque-phone{margin-bottom:1rem}
.contact-list{list-style:none;margin:0 0 1.2rem;padding:0;display:grid;gap:.7rem}
.contact-list li{display:flex;gap:.6rem;align-items:flex-start;color:var(--ink-700)}
.contact-list svg{width:18px;height:18px;color:var(--brass-600);flex:none;margin-top:2px}
.contact-list a{color:var(--ink-700);text-decoration:none}
.contact-list a:hover{color:var(--brass-600)}
.contact-reassure{margin-top:1.4rem;padding:1.4rem 1.5rem;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-lg)}
.contact-reassure h3{font-size:1.05rem;margin-bottom:.7rem}
.contact-reassure ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.contact-reassure li{display:flex;gap:.55rem;align-items:flex-start;font-size:.95rem;color:var(--ink-700)}
.contact-reassure svg{width:17px;height:17px;color:var(--ok);flex:none;margin-top:2px}
@media(max-width:860px){
  .contact-grid{grid-template-columns:1fr}
  .sos-form .form-row{grid-template-columns:1fr}
  .contact-urgence .wrap{flex-direction:column;align-items:flex-start}
}
