/*
Theme Name: Marciano Serrurier
Theme URI: https://marciano-serrurier.fr
Author: Groupe Marciano
Description: Theme sur-mesure pour Marciano Serrurier — serrurerie & depannage 24/7, Paris & Ile-de-France. Bleu confiance + accent orange.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: marciano-serrurier
*/

:root{
--primary:#2E3A48;--primary-dark:#1F2733;--azur:#5C6B7A;--bg-light:#ECEFF3;
--accent:#F36C21;--accent-dark:#D2540E;
--white:#fff;--text:#334155;--text-strong:#1F2733;--muted:#64748B;--border:#E2E8F0;--bg-subtle:#F8FAFC;
--success:#16A34A;--star:#F5A623;
--font-h:'Poppins',system-ui,sans-serif;--font-b:'Inter',system-ui,sans-serif;
--r-sm:6px;--r-md:10px;--r-lg:16px;--r-full:999px;
--sh-sm:0 1px 3px rgba(20,28,36,.08),0 1px 2px rgba(20,28,36,.04);
--sh-md:0 6px 20px rgba(20,28,36,.12);
--focus:0 0 0 3px rgba(243,108,33,.4);--t:160ms ease;
--maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-b);color:var(--text);line-height:1.6;background:var(--white);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-h);color:var(--text-strong);line-height:1.2}
h1{font-size:clamp(2rem,5vw,2.75rem);font-weight:700;letter-spacing:-.02em}
h2{font-size:clamp(1.5rem,4vw,2rem);font-weight:600;letter-spacing:-.01em}
h3{font-size:1.3rem;font-weight:600}
h4{font-size:1.1rem;font-weight:600}
p{margin:.4em 0}
a{color:var(--primary);text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
section{scroll-margin-top:120px}
.btn{font-family:var(--font-h);font-weight:600;font-size:1rem;border-radius:var(--r-md);cursor:pointer;display:inline-flex;align-items:center;gap:8px;border:none;transition:var(--t);text-align:center;justify-content:center}
.btn svg{width:18px;height:18px}
.btn-primary{color:#fff;background:var(--accent);padding:14px 24px;box-shadow:var(--sh-sm)}
.btn-primary:hover{background:var(--accent-dark);box-shadow:var(--sh-md);transform:translateY(-1px)}
.btn-secondary{color:var(--primary);background:transparent;border:2px solid var(--primary);padding:12px 22px}
.btn-secondary:hover{background:var(--primary);color:#fff}
.btn-phone{color:#fff;background:var(--primary-dark);padding:13px 20px}
.btn-phone:hover{background:#06182B}
.btn-ghost{color:#fff;background:rgba(255,255,255,.12);padding:13px 20px}
.btn-ghost:hover{background:rgba(255,255,255,.22)}
.btn-lg{padding:18px 30px;font-size:1.12rem}
.badge{display:inline-flex;align-items:center;gap:6px;font-weight:500;font-size:.85rem;color:var(--text-strong);background:var(--bg-light);padding:6px 12px;border-radius:var(--r-full)}
.badge svg{width:16px;height:16px;color:var(--primary)}
.stars{color:var(--star);letter-spacing:1px;font-size:.95rem}

/* proto bar */
.proto{position:sticky;top:0;z-index:100;background:#06182B;color:#cbd5e1;border-bottom:2px solid var(--accent)}
.proto .wrap{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:8px 20px}
.proto .lbl{font-family:var(--font-h);font-weight:700;color:#fff;font-size:.8rem;letter-spacing:.08em;background:var(--accent);padding:3px 8px;border-radius:4px}
.proto .tabs{display:flex;gap:4px;flex-wrap:wrap}
.proto .tab{font-family:var(--font-b);font-weight:500;font-size:.82rem;color:#cbd5e1;background:transparent;border:1px solid rgba(255,255,255,.18);padding:6px 12px;border-radius:var(--r-full);cursor:pointer;transition:var(--t)}
.proto .tab:hover{color:#fff;border-color:rgba(255,255,255,.5)}
.proto .tab.active{background:#fff;color:#06182B;border-color:#fff;font-weight:600}

/* header */
.header{position:sticky;top:42px;z-index:40;background:var(--primary-dark);box-shadow:var(--sh-sm)}
.header .wrap{display:flex;align-items:center;gap:22px;padding:12px 20px;position:relative}
.burger{display:none;background:none;border:none;color:#fff;padding:9px;cursor:pointer;border-radius:8px}
.burger svg{width:26px;height:26px;display:block}
.logo{display:flex;align-items:center;gap:10px;line-height:1.05;text-decoration:none}
.logo-mark{width:36px;height:36px;border-radius:9px;background:rgba(243,108,33,.18);display:flex;align-items:center;justify-content:center;flex:none}
.logo-mark svg{width:20px;height:20px;color:var(--accent)}
.logo-txt{display:flex;flex-direction:column}
.logo b{font-family:var(--font-h);font-weight:700;color:#fff;font-size:1.15rem;letter-spacing:-.01em}
.logo span{font-size:.68rem;color:#9AA7B4;letter-spacing:.14em;text-transform:uppercase}
.nav{display:flex;gap:4px;margin-right:auto;margin-left:8px}
.nav a{font-weight:500;color:#E2E8F0;font-size:.92rem;padding:10px 12px;border-radius:6px;white-space:nowrap;text-decoration:none}
.nav a:hover{color:#fff;background:rgba(255,255,255,.07)}
.header-cta{display:flex;align-items:center;gap:10px}
.btn-call{background:var(--accent);color:#fff;padding:12px 18px;white-space:nowrap;font-variant-numeric:tabular-nums}
.btn-call:hover{background:var(--accent-dark)}
.btn-call .num{font-weight:600;font-family:var(--font-h)}
.header-cta .btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.22);padding:11px 18px}
.header-cta .btn-ghost:hover{background:rgba(255,255,255,.22)}
.header a:focus-visible,.header button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.dot{width:9px;height:9px;border-radius:50%;background:#34d399;box-shadow:0 0 0 3px rgba(52,211,153,.35);animation:p 1.6s infinite;flex:none}
@keyframes p{50%{box-shadow:0 0 0 6px rgba(52,211,153,0)}}

/* reassurance */
.reassure{background:var(--bg-light);border-bottom:1px solid var(--border)}
.reassure .wrap{display:flex;justify-content:space-between;gap:10px;padding:10px 20px;flex-wrap:wrap}
.reassure .it{display:flex;align-items:center;gap:8px;font-size:.86rem;font-weight:500;color:var(--text-strong)}
.reassure .it svg{width:18px;height:18px;color:var(--primary);flex:none}

/* pages */
.page{display:none}
.page.active{display:block}

/* hero */
.hero{background:linear-gradient(135deg,#1F2733 0%,#2E3A48 100%);color:#fff;position:relative;overflow:hidden}
.hero:before{content:"";position:absolute;right:-80px;top:-80px;width:420px;height:420px;background:radial-gradient(circle,rgba(243,108,33,.35),transparent 70%)}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:30px;padding:54px 20px;align-items:center}
.hero h1{color:#fff;margin-bottom:12px}
.hero .sub{font-size:1.12rem;color:#C7D0DA;max-width:560px;margin-bottom:22px}
.hero .acts{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.hero .meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;color:#C7D0DA;font-size:.9rem}
.hero .meta b{color:#fff}
.hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:var(--r-lg);padding:22px;backdrop-filter:blur(4px)}
.hero-card h3{color:#fff;margin-bottom:6px}
.hero-card .num{font-family:var(--font-h);font-weight:700;font-size:1.8rem;color:#fff;margin:6px 0}
.hero-card .mini{font-size:.82rem;color:#cbd5e1}
.hero.urg{background:linear-gradient(135deg,#7c1d0a 0%,#b3420f 60%,#1F2733 100%)}
.hero.urg:before{background:radial-gradient(circle,rgba(243,108,33,.4),transparent 70%)}

/* generic section */
.sec{padding:54px 0}
.sec.alt{background:var(--bg-subtle)}
.sec h2{margin-bottom:8px}
.lead{color:var(--muted);max-width:680px;margin-bottom:26px}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.grid{display:grid;gap:18px}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;transition:var(--t)}
.card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:transparent}
.card .ic{width:46px;height:46px;border-radius:var(--r-md);background:var(--bg-light);color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.card .ic svg{width:24px;height:24px}
.card .price{color:var(--accent);font-weight:600;font-size:.85rem;margin-top:8px}
.card h3{font-size:1.12rem;margin-bottom:4px}
.card p{font-size:.92rem;color:var(--muted)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:s}
.step{position:relative;padding:20px;background:#fff;border:1px solid var(--border);border-radius:var(--r-lg)}
.step .n{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--font-h);font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.step h4{margin-bottom:4px}.step p{font-size:.9rem;color:var(--muted)}

/* trust band */
.band{background:var(--primary-dark);color:#fff;padding:40px 0}
.band .wrap{display:flex;justify-content:space-around;gap:20px;flex-wrap:wrap;text-align:center}
.band .num{font-family:var(--font-h);font-weight:700;font-size:2.1rem;color:#fff}
.band .lab{color:#cbd5e1;font-size:.9rem}

/* list check */
.checks{list-style:none;display:grid;gap:10px}
.checks li{display:flex;gap:10px;align-items:flex-start}
.checks svg{width:20px;height:20px;color:var(--success);flex:none;margin-top:2px}

/* reviews */
.rev{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}
.rev .top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.rev .av{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem}
.rev .au{font-weight:600;color:var(--text-strong);font-size:.9rem}
.rev .lo{font-size:.76rem;color:var(--muted)}
.rev p{font-size:.92rem;color:var(--text)}
.gnote{display:flex;align-items:center;gap:14px;background:var(--bg-light);border-radius:var(--r-lg);padding:18px 22px;flex-wrap:wrap}
.gnote .big{font-family:var(--font-h);font-weight:700;font-size:2.4rem;color:var(--text-strong)}

/* tarifs table */
.ttable{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.ttable th,.ttable td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border);font-size:.95rem}
.ttable th{background:var(--primary-dark);color:#fff;font-family:var(--font-h);font-weight:600}
.ttable td:last-child{color:var(--accent);font-weight:600;font-family:var(--font-h);white-space:nowrap}
.ttable tr:last-child td{border-bottom:none}

/* simulator */
.sim{background:#fff;border:2px solid var(--bg-light);border-radius:var(--r-lg);padding:26px;box-shadow:var(--sh-sm)}
.sim .prog{display:flex;gap:6px;margin-bottom:18px}
.sim .prog span{flex:1;height:5px;border-radius:3px;background:var(--border)}
.sim .prog span.on{background:var(--accent)}
.sim h3{margin-bottom:14px}
.simgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.opt{border:1px solid var(--border);border-radius:var(--r-md);padding:14px;text-align:center;cursor:pointer;font-weight:500;font-size:.9rem;color:var(--text-strong);background:#fff;transition:var(--t)}
.opt:hover{border-color:var(--azur);background:var(--bg-light)}
.opt.sel{border-color:var(--accent);background:#fff5ef;box-shadow:0 0 0 2px rgba(243,108,33,.25)}
.opt svg{width:24px;height:24px;color:var(--primary);display:block;margin:0 auto 6px}
.sim-actions{display:flex;justify-content:space-between;margin-top:18px;gap:10px}
.result{text-align:center;padding:10px}
.result .est{font-family:var(--font-h);font-weight:700;font-size:2.4rem;color:var(--accent)}
.result .br{color:var(--text-strong);font-weight:600;font-size:1.1rem;margin-top:4px}
.result .dis{font-size:.84rem;color:var(--muted);margin:12px auto;max-width:420px;background:var(--bg-light);padding:10px 14px;border-radius:var(--r-md)}

/* faq */
.faq{max-width:780px}
.qa{border-bottom:1px solid var(--border)}
.qa button{width:100%;text-align:left;background:none;border:none;padding:16px 0;font-family:var(--font-h);font-weight:600;font-size:1.02rem;color:var(--text-strong);cursor:pointer;display:flex;justify-content:space-between;gap:12px;align-items:center}
.qa button svg{width:20px;height:20px;color:var(--primary);transition:var(--t);flex:none}
.qa.open button svg{transform:rotate(180deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--text)}
.qa.open .ans{max-height:340px}
.qa .ans p{padding:0 0 16px}

/* form */
.formwrap{display:grid;grid-template-columns:1fr .9fr;gap:30px;align-items:start}
.formcard{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;box-shadow:var(--sh-sm)}
.field-l{display:block;font-weight:500;font-size:.85rem;margin-bottom:6px;color:var(--text)}
.field{width:100%;height:48px;padding:0 14px;font-family:var(--font-b);font-size:1rem;color:var(--text-strong);background:#fff;border:1px solid var(--border);border-radius:var(--r-sm);transition:var(--t)}
textarea.field{height:auto;min-height:90px;padding:12px 14px}
.field:focus{outline:none;border-color:var(--azur);box-shadow:var(--focus)}
.fg{margin-bottom:14px}
.microcopy{font-size:.82rem;color:var(--muted);margin-top:10px;display:flex;align-items:center;gap:6px;justify-content:center}
.microcopy svg{width:15px;height:15px;color:var(--success)}
.side-call{background:var(--primary-dark);color:#fff;border-radius:var(--r-lg);padding:26px}
.side-call h3{color:#fff}.side-call .num{font-family:var(--font-h);font-weight:700;font-size:1.9rem;margin:8px 0;color:#fff}

/* cta band */
.ctaband{background:linear-gradient(135deg,#2E3A48,#5C6B7A);color:#fff;border-radius:var(--r-lg);padding:36px;text-align:center}
.ctaband h2{color:#fff}.ctaband p{color:#C7D0DA;margin-bottom:18px}
.ctaband .acts{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* footer */
.footer{background:var(--primary-dark);color:#cbd5e1;padding:54px 0 24px;font-size:.9rem}
.footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:26px}
.footer h4{color:#fff;margin-bottom:12px;font-size:1rem}
.footer a{color:#cbd5e1;display:block;padding:3px 0}
.footer a:hover{color:#fff}
.footer .legal{margin-top:30px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);color:#94A3B8;font-size:.78rem;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* callbar mobile */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;gap:8px;padding:10px 12px;background:#fff;border-top:1px solid var(--border);box-shadow:0 -4px 16px rgba(20,28,36,.12)}
.callbar .btn{flex:1}

/* responsive */
@media(max-width:920px){
.hero .wrap{grid-template-columns:1fr}
.g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(2,1fr)}
.steps{grid-template-columns:repeat(2,1fr)}
.formwrap{grid-template-columns:1fr}
.footer .cols{grid-template-columns:1fr 1fr}
.burger{display:inline-flex}
.nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;margin:0;background:var(--primary-dark);padding:8px 16px 16px;box-shadow:var(--sh-md);border-top:1px solid rgba(255,255,255,.08)}
.nav.open{display:flex}
.nav a{padding:14px 8px;font-size:1rem;border-bottom:1px solid rgba(255,255,255,.07);border-radius:0}
.header-cta .devis-btn{display:none}
}
@media(max-width:600px){
.g4,.g3,.g2,.simgrid{grid-template-columns:1fr}
.band .wrap{gap:24px}
.callbar{display:flex}
.header{top:0}
.header .wrap{gap:12px}
.btn-call{padding:11px 14px;min-height:44px}
.btn-call .num{display:none}
.logo b{font-size:1.05rem}
.proto{position:static}
body{padding-bottom:76px}
.reassure .wrap{justify-content:flex-start}
}


/* ===== Overrides theme WordPress (pas de proto-bar) ===== */
.proto{display:none!important}
.page{display:block!important}
.header{top:0}
.admin-bar .header{top:32px}
@media(max-width:782px){.admin-bar .header{top:46px}}


/* ===== Bandeau cookies RGPD ===== */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;background:#1F2733;color:#E2E8F0;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:16px 18px;display:none;box-shadow:0 12px 34px rgba(0,0,0,.32);max-width:780px;margin:0 auto}
.cookie.show{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.cookie p{font-size:.86rem;margin:0;flex:1;min-width:230px;color:#E2E8F0}
.cookie a{color:#9AA7B4}
.cookie .cbtns{display:flex;gap:8px}
.cookie button{font-family:var(--font-h);font-weight:600;font-size:.85rem;border:none;border-radius:8px;padding:10px 16px;cursor:pointer}
.cookie .acc{background:var(--accent);color:#fff}
.cookie .acc:hover{background:var(--accent-dark)}
.cookie .ref{background:rgba(255,255,255,.14);color:#fff}
@media(max-width:600px){.cookie{bottom:84px;left:10px;right:10px}}
