/* ═══════════════════════════════════════════════════════════
   KEYLIO — Serrurier professionnel
   Style : épuré, moderne, blanc & bleu, beaucoup d'espace
═══════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
img,svg{max-width:100%;height:auto;display:block}

:root{
  /* Palette — bleu confiance + neutres clairs */
  --blue:#1D4ED8;          /* bleu principal */
  --blue-600:#2563EB;
  --blue-700:#1E40AF;
  --blue-50:#EFF4FF;
  --blue-100:#DBE6FF;
  --ink:#0F172A;           /* texte foncé */
  --slate:#475569;         /* texte secondaire */
  --slate-400:#94A3B8;
  --line:#E6EAF0;          /* bordures */
  --bg:#FFFFFF;
  --bg-soft:#F7F9FC;       /* sections alternées */
  --bg-soft-2:#F1F5FB;
  --green:#16A34A;
  --amber:#F59E0B;
  --white:#FFFFFF;

  --radius:10px;
  --radius-lg:16px;
  --radius-xl:24px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06);
  --shadow:0 4px 16px rgba(15,23,42,.07);
  --shadow-md:0 12px 32px rgba(15,23,42,.10);
  --shadow-lg:0 24px 64px rgba(15,23,42,.14);
  --shadow-blue:0 12px 32px rgba(29,78,216,.22);

  --maxw:1200px;
  --ease:cubic-bezier(.4,0,.2,1);

  --font-display:'Sora',-apple-system,sans-serif;
  --font-body:'Plus Jakarta Sans',-apple-system,sans-serif;
}

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:16.5px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.12;font-weight:700;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.3rem,5vw,3.9rem);font-weight:800}
h2{font-size:clamp(1.85rem,3.6vw,2.85rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
h4{font-size:1.1rem}
p{color:var(--slate)}
a{color:inherit;text-decoration:none}
strong{font-weight:700;color:var(--ink)}

/* ── LAYOUT ── */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 28px}
.section{padding:96px 0}
.section-soft{background:var(--bg-soft)}
.center{text-align:center}

/* Eyebrow label */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);
  font-size:13px;font-weight:600;letter-spacing:.04em;
  color:var(--blue);text-transform:uppercase;
  background:var(--blue-50);
  padding:6px 14px;border-radius:100px;
  margin-bottom:20px;
}
.eyebrow svg{width:15px;height:15px;fill:var(--blue)}

.section-head{max-width:640px;margin-bottom:56px}
.section-head.center{margin-left:auto;margin-right:auto}
.section-head h2{margin-bottom:16px}
.section-head p{font-size:1.1rem}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-display);
  font-size:15px;font-weight:600;
  padding:15px 28px;border-radius:var(--radius);
  border:1.5px solid transparent;cursor:pointer;
  transition:all .25s var(--ease);white-space:nowrap;
  line-height:1;
}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn-primary{background:var(--blue);color:#fff;box-shadow:var(--shadow-blue)}
.btn-primary:hover{background:var(--blue-700);transform:translateY(-2px);box-shadow:0 16px 40px rgba(29,78,216,.3)}
.btn-primary svg{fill:#fff}
.btn-light{background:#fff;color:var(--blue);border-color:var(--line)}
.btn-light:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-light svg{fill:var(--blue)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.5)}
.btn-ghost svg{fill:#fff}
.btn-white{background:#fff;color:var(--blue)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-white svg{fill:var(--blue)}
.btn-lg{padding:17px 34px;font-size:16px}
.btn-block{width:100%}

/* ═══════════ TOPBAR ═══════════ */
.topbar{background:var(--ink);color:#fff;font-size:13.5px}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:42px}
.topbar-left{display:flex;align-items:center;gap:22px;color:rgba(255,255,255,.7)}
.topbar-item{display:flex;align-items:center;gap:7px}
.topbar-item svg{width:14px;height:14px;fill:var(--blue-100)}
.topbar-live{display:flex;align-items:center;gap:7px;color:#fff;font-weight:500}
.live-dot{width:7px;height:7px;border-radius:50%;background:#4ADE80;box-shadow:0 0 0 0 rgba(74,222,128,.6);animation:ping 2s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(74,222,128,.5)}70%{box-shadow:0 0 0 6px rgba(74,222,128,0)}100%{box-shadow:0 0 0 0 rgba(74,222,128,0)}}
.topbar-phone{color:#fff;font-weight:600;display:flex;align-items:center;gap:7px}
.topbar-phone svg{width:14px;height:14px;fill:#4ADE80}

/* ═══════════ HEADER / NAV ═══════════ */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
.header.scrolled{border-color:var(--line);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-size:1.5rem;font-weight:800;letter-spacing:-.03em;color:var(--ink)}
.brand-logo{width:40px;height:40px;flex-shrink:0}
.brand b{color:var(--blue);font-weight:800}
.nav-menu{display:flex;align-items:center;gap:4px;list-style:none}
.nav-menu>li{position:relative}
.nav-menu>li>a{display:flex;align-items:center;gap:5px;padding:10px 15px;font-size:15px;font-weight:500;color:var(--slate);border-radius:8px;transition:all .2s}
.nav-menu>li>a:hover,.nav-menu>li.current>a{color:var(--blue);background:var(--blue-50)}
.nav-menu .caret{width:14px;height:14px;fill:currentColor;opacity:.6;transition:transform .2s}
.nav-menu>li:hover .caret{transform:rotate(180deg)}

/* Dropdown */
.dropdown{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:10px;opacity:0;pointer-events:none;transition:all .22s var(--ease);z-index:200}
.nav-menu>li:hover .dropdown{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.dropdown.mega{display:grid;grid-template-columns:1fr 1fr;gap:4px;width:520px}
.dropdown.single{width:240px}
.drop-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:10px;transition:background .15s}
.drop-item:hover{background:var(--bg-soft)}
.drop-ico{width:38px;height:38px;border-radius:9px;background:var(--blue-50);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.drop-ico svg{width:19px;height:19px;fill:var(--blue)}
.drop-txt b{display:block;font-family:var(--font-display);font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.3}
.drop-txt span{font-size:12.5px;color:var(--slate-400)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-phone{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--blue);padding:10px 16px;border-radius:8px;transition:background .2s}
.nav-phone:hover{background:var(--blue-50)}
.nav-phone svg{width:17px;height:17px;fill:var(--blue)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ═══════════ HERO ═══════════ */
.hero{position:relative;padding:80px 0 96px;overflow:hidden;background:linear-gradient(180deg,#fff 0%,var(--blue-50) 100%)}
.hero-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-deco .blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}
.hero-deco .b1{width:480px;height:480px;background:radial-gradient(circle,rgba(37,99,235,.25),transparent 70%);top:-160px;right:-120px}
.hero-deco .b2{width:360px;height:360px;background:radial-gradient(circle,rgba(74,222,128,.12),transparent 70%);bottom:-120px;left:-100px}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 30%,transparent 75%);opacity:.5;pointer-events:none}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);padding:8px 16px;border-radius:100px;font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:26px}
.hero-badge .stars{color:var(--amber);letter-spacing:1px}
.hero-badge .sep{width:1px;height:14px;background:var(--line)}
.hero h1{margin-bottom:22px}
.hero h1 .hl{color:var(--blue);position:relative;white-space:nowrap}
.hero h1 .hl::after{content:'';position:absolute;left:0;right:0;bottom:4px;height:10px;background:var(--blue-100);z-index:-1;border-radius:3px}
.hero-lead{font-size:1.2rem;color:var(--slate);margin-bottom:34px;max-width:520px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}
.hero-trust{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:500;color:var(--slate)}
.hero-trust-item svg{width:20px;height:20px;fill:var(--green);flex-shrink:0}

/* Hero card */
.hero-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}
.hero-card-top{background:var(--ink);padding:22px 26px;display:flex;align-items:center;justify-content:space-between}
.hero-card-top h3{color:#fff;font-size:1.15rem}
.hero-card-top .tag{display:flex;align-items:center;gap:7px;background:rgba(74,222,128,.15);color:#4ADE80;font-size:12px;font-weight:600;padding:5px 11px;border-radius:100px}
.hero-card-body{padding:26px}
.field{margin-bottom:15px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:7px}
.field input,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;font-family:var(--font-body);font-size:15px;color:var(--ink);background:var(--bg-soft);transition:all .2s;appearance:none}
.field input:focus,.field select:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px var(--blue-50)}
.field input::placeholder{color:var(--slate-400)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hero-card-note{font-size:12.5px;color:var(--slate-400);text-align:center;margin-top:14px;display:flex;align-items:center;justify-content:center;gap:6px}
.hero-card-note svg{width:14px;height:14px;fill:var(--green)}

/* ═══════════ LOGOS / TRUST STRIP ═══════════ */
.trust-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.trust-strip .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-top:30px;padding-bottom:30px}
.trust-stat{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;min-width:130px}
.trust-stat .num{font-family:var(--font-display);font-size:2.2rem;font-weight:800;color:var(--blue);line-height:1}
.trust-stat .lbl{font-size:13.5px;color:var(--slate);margin-top:6px}
.trust-divider{width:1px;height:46px;background:var(--line)}

/* ═══════════ SERVICES ═══════════ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;transition:all .3s var(--ease);position:relative;overflow:hidden}
.service-card:hover{border-color:var(--blue-100);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.service-ico{width:56px;height:56px;border-radius:14px;background:var(--blue-50);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:all .3s}
.service-card:hover .service-ico{background:var(--blue);transform:rotate(-6deg)}
.service-ico svg{width:28px;height:28px;fill:var(--blue);transition:fill .3s}
.service-card:hover .service-ico svg{fill:#fff}
.service-card h3{margin-bottom:11px}
.service-card p{font-size:15px;margin-bottom:20px}
.service-link{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-size:14.5px;font-weight:600;color:var(--blue);transition:gap .2s}
.service-link svg{width:16px;height:16px;fill:var(--blue);transition:transform .2s}
.service-card:hover .service-link{gap:11px}

/* ═══════════ HOW / STEPS ═══════════ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;counter-reset:step}
.step{position:relative;padding-top:8px}
.step-num{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--blue);background:var(--blue-50);width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.step h4{margin-bottom:9px}
.step p{font-size:14.5px}
.step:not(:last-child)::after{content:'';position:absolute;top:29px;left:54px;right:-14px;height:2px;background:linear-gradient(90deg,var(--blue-100),transparent);z-index:-1}

/* ═══════════ WHY / FEATURES (split) ═══════════ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.split-visual{position:relative}
.visual-card{background:linear-gradient(160deg,var(--blue-700),var(--blue));border-radius:var(--radius-xl);padding:48px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.visual-card::before{content:'';position:absolute;top:-60px;right:-60px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.08)}
.visual-card::after{content:'';position:absolute;bottom:-80px;left:-40px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.05)}
.visual-card .vc-ico{width:72px;height:72px;border-radius:18px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;margin-bottom:28px;position:relative}
.visual-card .vc-ico svg{width:36px;height:36px;fill:#fff}
.visual-card h3{color:#fff;font-size:1.7rem;margin-bottom:14px;position:relative}
.visual-card p{color:rgba(255,255,255,.82);position:relative;margin-bottom:28px}
.vc-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px;position:relative}
.vc-stat{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:18px}
.vc-stat .n{font-family:var(--font-display);font-size:1.8rem;font-weight:800;line-height:1}
.vc-stat .l{font-size:12.5px;color:rgba(255,255,255,.7);margin-top:5px}
.feature-list{display:flex;flex-direction:column;gap:8px}
.feature{display:flex;gap:18px;padding:20px;border-radius:14px;transition:background .2s}
.feature:hover{background:var(--bg-soft)}
.feature-ico{width:48px;height:48px;border-radius:12px;background:var(--blue-50);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feature-ico svg{width:24px;height:24px;fill:var(--blue)}
.feature-txt h4{margin-bottom:5px}
.feature-txt p{font-size:14.5px}

/* ═══════════ ZONES (home) ═══════════ */
.zones-list{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.zone-tile{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;transition:all .25s var(--ease)}
.zone-tile:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-2px)}
.zone-tile-name{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:15px}
.zone-tile-name svg{width:17px;height:17px;fill:var(--blue)}
.zone-tile-time{font-size:12px;font-weight:600;color:var(--green);background:rgba(22,163,74,.1);padding:3px 9px;border-radius:100px}

/* ═══════════ TESTIMONIALS ═══════════ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;display:flex;flex-direction:column}
.testi-stars{color:var(--amber);font-size:16px;letter-spacing:2px;margin-bottom:16px}
.testi-quote{font-size:15.5px;color:var(--ink);line-height:1.7;flex:1;margin-bottom:22px}
.testi-author{display:flex;align-items:center;gap:13px;padding-top:20px;border-top:1px solid var(--line)}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:16px;flex-shrink:0}
.testi-name{font-family:var(--font-display);font-weight:600;font-size:14.5px}
.testi-loc{font-size:13px;color:var(--slate-400)}

/* ═══════════ CTA BAND ═══════════ */
.cta-band{background:var(--ink);border-radius:var(--radius-xl);padding:64px 56px;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-100px;right:-60px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.4),transparent 70%);filter:blur(40px)}
.cta-band-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap}
.cta-band h2{color:#fff;margin-bottom:12px}
.cta-band p{color:rgba(255,255,255,.7);font-size:1.1rem;max-width:480px}
.cta-band-actions{display:flex;flex-direction:column;gap:12px;min-width:260px}
.cta-phone{display:flex;align-items:center;gap:15px;color:#fff}
.cta-phone-ico{width:56px;height:56px;border-radius:16px;background:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 0 8px rgba(37,99,235,.15)}
.cta-phone-ico svg{width:26px;height:26px;fill:#fff}
.cta-phone .num{font-family:var(--font-display);font-size:1.55rem;font-weight:800;line-height:1}
.cta-phone .sub{font-size:13px;color:rgba(255,255,255,.55);margin-top:3px}

/* ═══════════ FAQ ═══════════ */
.faq-list{max-width:820px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;background:#fff;transition:box-shadow .2s,border-color .2s}
.faq-item.open{border-color:var(--blue-100);box-shadow:var(--shadow)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 26px;cursor:pointer;font-family:var(--font-display);font-weight:600;font-size:16.5px;color:var(--ink)}
.faq-q .plus{width:26px;height:26px;border-radius:50%;background:var(--blue-50);color:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px;line-height:1;transition:all .25s}
.faq-item.open .plus{background:var(--blue);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a-inner{padding:0 26px 24px;color:var(--slate);font-size:15.5px;line-height:1.75}

/* ═══════════ FOOTER ═══════════ */
.footer{background:var(--ink);color:#fff;padding:72px 0 0}
.footer-top{display:grid;grid-template-columns:2.2fr 1fr 1fr 1.3fr;gap:48px;padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-size:1.45rem;font-weight:800;color:#fff;margin-bottom:18px}
.footer-brand b{color:#60A5FA}
.footer-about{color:rgba(255,255,255,.55);font-size:14.5px;line-height:1.75;margin-bottom:24px;max-width:300px}
.footer-phone{display:inline-flex;align-items:center;gap:12px;background:rgba(37,99,235,.15);border:1px solid rgba(37,99,235,.3);border-radius:12px;padding:14px 18px;transition:background .2s}
.footer-phone:hover{background:rgba(37,99,235,.25)}
.footer-phone svg{width:18px;height:18px;fill:#60A5FA}
.footer-phone b{display:block;color:#fff;font-family:var(--font-display);font-size:15px}
.footer-phone span{display:block;color:rgba(255,255,255,.5);font-size:12px;margin-top:1px}
.footer-col h5{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:18px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer-links a{color:rgba(255,255,255,.6);font-size:14.5px;transition:color .2s}
.footer-links a:hover{color:#60A5FA}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:24px 0;font-size:13px;color:rgba(255,255,255,.4)}
.footer-bottom a{color:rgba(255,255,255,.4)}
.footer-bottom a:hover{color:#60A5FA}

/* ═══════════ FLOATING ═══════════ */
.fab{position:fixed;right:22px;bottom:22px;z-index:90;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.fab-btn{display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:100px;font-family:var(--font-display);font-weight:700;font-size:14.5px;box-shadow:var(--shadow-md);transition:all .25s var(--ease)}
.fab-btn svg{width:20px;height:20px}
.fab-btn:hover{transform:translateY(-3px) scale(1.02)}
.fab-call{background:var(--blue);color:#fff}
.fab-call svg{fill:#fff}
.fab-wa{background:#25D366;color:#fff}
.fab-wa svg{fill:#fff}

/* ═══════════ INNER PAGE HERO ═══════════ */
.page-hero{background:linear-gradient(180deg,var(--ink),#152540);color:#fff;padding:56px 0 64px;position:relative;overflow:hidden}
.page-hero-deco{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:52px 52px;mask-image:radial-gradient(ellipse 70% 80% at 70% 30%,#000,transparent);pointer-events:none}
.page-hero-glow{position:absolute;top:-120px;right:-80px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.4),transparent 70%);filter:blur(50px);pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:760px}
.crumb{display:flex;align-items:center;gap:8px;font-size:13.5px;color:rgba(255,255,255,.5);margin-bottom:22px;flex-wrap:wrap}
.crumb a{color:rgba(255,255,255,.65);transition:color .2s}
.crumb a:hover{color:#60A5FA}
.crumb svg{width:13px;height:13px;fill:rgba(255,255,255,.3)}
.crumb .cur{color:#60A5FA}
.page-hero .eyebrow{background:rgba(37,99,235,.2);color:#93B4FF}
.page-hero h1{color:#fff;margin-bottom:18px}
.page-hero p{color:rgba(255,255,255,.7);font-size:1.15rem;margin-bottom:30px;max-width:600px}
.page-hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* Inner content blocks */
.prose{max-width:760px}
.prose h2{margin:0 0 18px}
.prose h3{margin:36px 0 14px}
.prose p{font-size:16.5px;margin-bottom:18px;line-height:1.8}
.prose ul{margin:0 0 22px;padding-left:0;list-style:none}
.prose ul li{position:relative;padding-left:32px;margin-bottom:12px;color:var(--slate);font-size:16px}
.prose ul li::before{content:'';position:absolute;left:0;top:3px;width:20px;height:20px;background:var(--blue-50);border-radius:50%}
.prose ul li::after{content:'';position:absolute;left:6px;top:9px;width:7px;height:4px;border-left:2px solid var(--blue);border-bottom:2px solid var(--blue);transform:rotate(-45deg)}

/* Info cards row */
.info-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:8px 0}
.info-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px}
.info-card .ic-ico{width:48px;height:48px;border-radius:12px;background:var(--blue-50);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.info-card .ic-ico svg{width:24px;height:24px;fill:var(--blue)}
.info-card h4{margin-bottom:8px}
.info-card p{font-size:14.5px}

/* Two-col content (service detail) */
.detail-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:start}
.detail-aside{position:sticky;top:100px}
.aside-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow)}
.aside-card.dark{background:var(--ink);color:#fff;border:none}
.aside-card.dark h4{color:#fff;margin-bottom:6px}
.aside-card.dark p{color:rgba(255,255,255,.6);font-size:14px;margin-bottom:18px}
.aside-price{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}
.aside-feats{list-style:none;display:flex;flex-direction:column;gap:12px;margin:20px 0}
.aside-feats li{display:flex;align-items:center;gap:11px;font-size:14.5px}
.aside-feats svg{width:18px;height:18px;fill:#4ADE80;flex-shrink:0}

/* Zone specifics */
.zone-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:40px 0}
.zone-stat{text-align:center;padding:26px 18px;background:#fff;border:1px solid var(--line);border-radius:14px}
.zone-stat .n{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--blue);line-height:1}
.zone-stat .l{font-size:13px;color:var(--slate);margin-top:7px}
.communes{display:flex;flex-wrap:wrap;gap:10px}
.commune{background:#fff;border:1px solid var(--line);border-radius:100px;padding:9px 18px;font-size:14px;font-weight:500;color:var(--ink)}

/* Related */
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.related-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;transition:all .25s var(--ease)}
.related-card:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-3px)}
.related-ico{width:42px;height:42px;border-radius:11px;background:var(--blue-50);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.related-ico svg{width:21px;height:21px;fill:var(--blue)}
.related-card b{display:block;font-family:var(--font-display);font-size:15px;font-weight:600;margin-bottom:4px}
.related-card span{font-size:13px;color:var(--slate-400)}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ═══════════ RESPONSIVE ═══════════ */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:48px;max-width:560px;margin:0 auto}
  .split{grid-template-columns:1fr;gap:48px}
  .detail-grid{grid-template-columns:1fr;gap:40px}
  .detail-aside{position:static}
  .steps{grid-template-columns:1fr 1fr;gap:32px}
  .step:not(:last-child)::after{display:none}
  .services-grid{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr}
  .zones-list{grid-template-columns:1fr 1fr}
  .related-grid{grid-template-columns:1fr 1fr}
  .zone-stats{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
  .info-row{grid-template-columns:1fr}
}
@media(max-width:768px){
  .section{padding:64px 0}
  .nav-menu,.nav-phone{display:none}
  .burger{display:flex}
  .topbar-left{gap:14px}
  .topbar-item.hide-sm{display:none}
  .hero{padding:56px 0 64px}
  .hero-lead{font-size:1.1rem}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}
  .trust-strip .wrap{gap:20px}
  .trust-divider{display:none}
  .trust-stat{min-width:42%}
  .cta-band{padding:44px 28px}
  .cta-band-inner{flex-direction:column;align-items:flex-start}
  .cta-band-actions{width:100%}
  .visual-card{padding:36px}
  .page-hero-actions{flex-direction:column}
  .page-hero-actions .btn{width:100%}
}
@media(max-width:520px){
  .wrap,.wrap-narrow{padding:0 20px}
  .services-grid,.steps,.zones-list,.related-grid,.zone-stats{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .vc-stats{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:30px}
  .trust-stat{min-width:100%}
  .fab-btn span{display:none}
  .fab-btn{padding:15px;border-radius:50%}
  .footer-bottom{flex-direction:column;text-align:center}
}
