/* ================================================================
   ASE TECHNOLOGIE — style.css v5
   Mobile-first · Dark tech · Vitrine + CTA fort
   Couleurs : #07090F void · #111827 deep · #0EA5E9 blue · #38BDF8 sky
   Typo : Syne (display) + DM Sans (body)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ── RESET ────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',sans-serif;background:#07090F;color:#F1F5F9;line-height:1.65;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}

/* ── TOKENS ─────────────────────────────────────────────── */
:root{
  --c-void:    #07090F;
  --c-deep:    #111827;
  --c-panel:   #0F1929;
  --c-border:  rgba(14,165,233,.16);
  --c-blue:    #0EA5E9;
  --c-sky:     #38BDF8;
  --c-glow:    rgba(56,189,248,.1);
  --c-text:    #F1F5F9;
  --c-muted:   #94A3B8;
  --c-red:     #EF4444;
  --c-gold:    #FBBF24;
  --c-green:   #10B981;
  --ff-d:'Syne',sans-serif;
  --ff-b:'DM Sans',sans-serif;
  --r:10px;--r-lg:18px;--r-xl:24px;
  --transition:.22s ease;
  --shadow-glow:0 0 40px rgba(56,189,248,.15),0 8px 32px rgba(0,0,0,.5);
}

/* ── LAYOUT ────────────────────────────────────────────── */
.container{width:100%;max-width:1160px;margin:0 auto;padding:0 20px}
@media(min-width:768px){.container{padding:0 32px}}
@media(min-width:1200px){.container{padding:0 24px}}

.section{padding:64px 0}
@media(min-width:768px){.section{padding:96px 0}}
.section-sm{padding:40px 0}
@media(min-width:768px){.section-sm{padding:56px 0}}

/* ── TYPOGRAPHY ─────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--ff-d);line-height:1.15;letter-spacing:-.02em}
.h1{font-size:clamp(2rem,6vw,3.8rem);font-weight:800}
.h2{font-size:clamp(1.6rem,4vw,2.6rem);font-weight:700}
.h3{font-size:clamp(1.1rem,2.5vw,1.4rem);font-weight:700}
.label{
  font-family:var(--ff-d);font-size:.68rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--c-sky);
  display:block;margin-bottom:12px
}
.tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--c-sky);background:rgba(56,189,248,.08);
  border:1px solid rgba(56,189,248,.25);padding:5px 13px;border-radius:999px
}
.tag::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--c-sky);animation:blink 2s infinite}
.text-sky{color:var(--c-sky)}
.text-muted{color:var(--c-muted)}
.text-center{text-align:center}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

/* ── GRID BG ────────────────────────────────────────────── */
.bg-grid{
  background-image:
    linear-gradient(rgba(14,165,233,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(14,165,233,.04) 1px,transparent 1px);
  background-size:52px 52px
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 26px;border-radius:var(--r);
  font-family:var(--ff-d);font-weight:700;font-size:.9rem;
  cursor:pointer;border:none;transition:all var(--transition);
  white-space:nowrap;text-align:center;line-height:1
}
.btn svg{width:17px;height:17px;flex-shrink:0}
.btn-primary{
  background:linear-gradient(135deg,var(--c-blue),var(--c-sky));
  color:#fff;box-shadow:0 4px 20px rgba(14,165,233,.3)
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(14,165,233,.45)}
.btn-primary:active{transform:translateY(0)}
.btn-outline{background:transparent;border:1.5px solid var(--c-border);color:var(--c-text)}
.btn-outline:hover{border-color:var(--c-sky);color:var(--c-sky);background:var(--c-glow)}
.btn-tel{
  background:linear-gradient(135deg,#10B981,#059669);
  color:#fff;box-shadow:0 4px 20px rgba(16,185,129,.3);
  font-size:1rem;padding:16px 28px
}
.btn-tel:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(16,185,129,.45)}
.btn-cta{padding:16px 36px;font-size:1rem}
.btn-full{width:100%}

/* ── STICKY CTA MOBILE ──────────────────────────────────── */
#sticky-cta{
  position:fixed;bottom:0;left:0;right:0;z-index:900;
  display:flex;gap:0;
  background:var(--c-deep);border-top:1px solid var(--c-border);
  padding:10px 16px 10px;
  padding-bottom:calc(10px + env(safe-area-inset-bottom));
}
#sticky-cta a{flex:1;text-align:center;font-family:var(--ff-d);font-weight:700;font-size:.82rem;padding:12px 8px;border-radius:var(--r);transition:all var(--transition)}
#sticky-cta .scta-tel{background:linear-gradient(135deg,#10B981,#059669);color:#fff;margin-right:8px}
#sticky-cta .scta-form{background:linear-gradient(135deg,var(--c-blue),var(--c-sky));color:#fff}
@media(min-width:768px){#sticky-cta{display:none}}

/* ── HEADER ─────────────────────────────────────────────── */
#header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:all .3s
}
#header.scrolled{
  background:rgba(7,9,15,.94);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--c-border)
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 0;gap:16px
}
.nav-logo{font-family:var(--ff-d);font-weight:800;font-size:1.15rem;letter-spacing:.02em;flex-shrink:0}
.nav-logo span{color:var(--c-sky)}
.nav-logo small{font-size:.58rem;font-weight:600;color:var(--c-muted);letter-spacing:.1em;text-transform:uppercase;display:block;margin-top:-2px}

/* Desktop nav */
.nav-links{display:none}
@media(min-width:900px){
  .nav-links{
    display:flex;align-items:center;gap:2px;flex:1;justify-content:center
  }
  .nav-links>li>a{
    padding:7px 12px;border-radius:var(--r);
    font-size:.83rem;font-weight:500;color:var(--c-muted);
    transition:all var(--transition);white-space:nowrap
  }
  .nav-links>li>a:hover,.nav-links>li>a.active{color:var(--c-text);background:rgba(255,255,255,.05)}
  .nav-links>li.nav-cctv>a{
    color:var(--c-sky);background:rgba(56,189,248,.07);
    border:1px solid rgba(56,189,248,.2)
  }
  .nav-links>li.nav-cctv>a:hover{background:rgba(56,189,248,.14)}
}
.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-phone{
  display:none;
  font-family:var(--ff-d);font-weight:700;font-size:.82rem;
  padding:8px 14px;border-radius:var(--r);
  background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.25);
  color:#10B981;transition:all var(--transition);white-space:nowrap
}
.nav-phone:hover{background:rgba(16,185,129,.2);border-color:#10B981}
@media(min-width:640px){.nav-phone{display:flex;align-items:center;gap:6px}}
.nav-btn{display:none}
@media(min-width:900px){.nav-btn{display:inline-flex}}
.nav-toggle{
  display:flex;background:none;border:1px solid var(--c-border);
  color:var(--c-text);cursor:pointer;padding:8px;border-radius:var(--r);
  transition:all var(--transition)
}
.nav-toggle:hover{border-color:var(--c-sky);color:var(--c-sky)}
@media(min-width:900px){.nav-toggle{display:none}}

/* Mobile drawer */
.nav-drawer{
  display:none;position:fixed;inset:0;z-index:999;
  background:rgba(7,9,15,.97);backdrop-filter:blur(24px);
  flex-direction:column;padding:80px 24px 32px;overflow-y:auto;
  gap:4px
}
.nav-drawer.open{display:flex}
.nav-drawer>li>a{
  display:block;padding:14px 4px;font-size:1.1rem;font-weight:600;
  color:var(--c-text);border-bottom:1px solid var(--c-border);
  transition:color var(--transition)
}
.nav-drawer>li>a:hover{color:var(--c-sky)}
.nav-drawer .drawer-ctas{display:grid;gap:10px;margin-top:24px}
.drawer-close{
  position:absolute;top:18px;right:20px;background:none;border:none;
  color:var(--c-muted);cursor:pointer;font-size:1.5rem;
  display:flex;align-items:center;gap:8px
}

/* ── HERO ────────────────────────────────────────────────── */
#hero{
  min-height:100svh;display:flex;align-items:center;
  position:relative;overflow:hidden;padding-top:72px;
  padding-bottom:80px /* espace sticky CTA mobile */
}
@media(min-width:768px){#hero{padding-bottom:0}}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 70% 60% at 70% 40%,rgba(14,165,233,.1) 0%,transparent 65%),
    radial-gradient(ellipse 40% 40% at 10% 80%,rgba(56,189,248,.06) 0%,transparent 55%),
    var(--c-void)
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(14,165,233,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(14,165,233,.04) 1px,transparent 1px);
  background-size:56px 56px
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr;gap:48px;
  align-items:center
}
@media(min-width:900px){.hero-inner{grid-template-columns:1fr 1fr;gap:64px}}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(56,189,248,.07);border:1px solid rgba(56,189,248,.25);
  padding:6px 14px;border-radius:999px;
  font-size:.73rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--c-sky);margin-bottom:20px
}
.hero-eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--c-sky);animation:blink 1.5s infinite}
.hero-title{margin-bottom:18px}
.hero-title em{
  font-style:normal;
  background:linear-gradient(90deg,var(--c-blue),var(--c-sky));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent
}
.hero-desc{font-size:1rem;color:var(--c-muted);margin-bottom:32px;line-height:1.75;max-width:500px}
@media(min-width:768px){.hero-desc{font-size:1.05rem}}

/* Hero CTA block */
.hero-cta-block{
  display:flex;flex-direction:column;gap:12px;
  margin-bottom:36px
}
@media(min-width:480px){
  .hero-cta-block{flex-direction:row;flex-wrap:wrap}
}
.hero-trust{
  display:flex;flex-wrap:wrap;gap:12px 20px;align-items:center
}
.trust-item{
  display:flex;align-items:center;gap:7px;
  font-size:.78rem;color:var(--c-muted)
}
.trust-item strong{color:var(--c-text)}

/* CCTV feeds */
.hero-visual{display:none}
@media(min-width:900px){.hero-visual{display:flex;justify-content:center;align-items:center}}
.cam-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  width:100%;max-width:440px
}
.cam-feed{
  aspect-ratio:4/3;border-radius:12px;
  background:var(--c-panel);border:1px solid var(--c-border);
  position:relative;overflow:hidden
}
.cam-feed:first-child{grid-column:1/-1;aspect-ratio:16/9}
.cam-feed::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(56,189,248,.018) 3px,rgba(56,189,248,.018) 4px);
  pointer-events:none;z-index:2
}
.cam-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--c-deep),var(--c-void))}
.cam-scene{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse 50% 40% at 55% 40%,rgba(56,189,248,.05) 0%,transparent 60%)}
.cam-lbl{position:absolute;top:6px;left:8px;z-index:3;font-size:.58rem;font-family:monospace;color:rgba(56,189,248,.7);letter-spacing:.06em}
.cam-rec{position:absolute;top:6px;right:8px;z-index:3;display:flex;align-items:center;gap:4px;font-size:.56rem;font-family:monospace;color:var(--c-red)}
.cam-rec::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--c-red);animation:blink 1s infinite}
.cam-ts{position:absolute;bottom:6px;left:8px;z-index:3;font-size:.54rem;font-family:monospace;color:rgba(255,255,255,.28)}
.cam-c{position:absolute;z-index:4;width:10px;height:10px;border-color:rgba(56,189,248,.45);border-style:solid}
.cam-c.tl{top:4px;left:4px;border-width:2px 0 0 2px}
.cam-c.tr{top:4px;right:4px;border-width:2px 2px 0 0}
.cam-c.bl{bottom:4px;left:4px;border-width:0 0 2px 2px}
.cam-c.br{bottom:4px;right:4px;border-width:0 2px 2px 0}

/* ── STATS BAR ──────────────────────────────────────────── */
#stats{background:var(--c-panel);border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);padding:28px 0}
.stats-row{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--c-border)
}
@media(min-width:640px){.stats-row{grid-template-columns:repeat(4,1fr)}}
.stat-item{
  padding:20px 16px;text-align:center;
  background:var(--c-panel)
}
.stat-val{font-family:var(--ff-d);font-size:1.9rem;font-weight:800;color:var(--c-sky);line-height:1.1;margin-bottom:4px}
.stat-lbl{font-size:.75rem;color:var(--c-muted)}

/* ── SERVICE CARDS ──────────────────────────────────────── */
.services-grid{
  display:grid;grid-template-columns:1fr;gap:16px
}
@media(min-width:640px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services-grid{grid-template-columns:repeat(3,1fr)}}

/* Service card vitrine */
.svc-card{
  background:var(--c-panel);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:28px 24px;
  display:flex;flex-direction:column;gap:14px;
  transition:all var(--transition);position:relative;overflow:hidden;
  text-decoration:none;color:inherit
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c-blue),var(--c-sky));
  transform:scaleX(0);transform-origin:left;transition:transform .3s
}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card:hover{
  border-color:rgba(56,189,248,.3);transform:translateY(-4px);
  box-shadow:var(--shadow-glow)
}
.svc-icon{font-size:2.2rem;line-height:1}
.svc-card h3{font-size:1.05rem}
.svc-card p{font-size:.84rem;color:var(--c-muted);line-height:1.65;flex:1}
.svc-list{display:grid;gap:6px}
.svc-list li{
  font-size:.79rem;color:var(--c-muted);
  display:flex;align-items:flex-start;gap:7px
}
.svc-list li::before{content:'✓';color:var(--c-sky);font-size:.72rem;flex-shrink:0;margin-top:.15em}
.svc-link{
  display:flex;align-items:center;gap:6px;margin-top:auto;
  font-family:var(--ff-d);font-size:.8rem;font-weight:700;color:var(--c-sky);
  transition:gap var(--transition)
}
.svc-card:hover .svc-link{gap:10px}

/* Card featured (full-width ou highlight) */
.svc-card-featured{
  background:linear-gradient(135deg,rgba(14,165,233,.1),rgba(56,189,248,.05));
  border-color:rgba(56,189,248,.25)
}
.svc-card-featured::before{transform:scaleX(1)}

/* ── SECTION COPRO FOCUS ────────────────────────────────── */
.copro-section{
  display:grid;grid-template-columns:1fr;gap:48px;align-items:start
}
@media(min-width:900px){.copro-section{grid-template-columns:1.1fr 1fr;gap:64px}}

.zone-cards{display:grid;gap:12px;margin-top:28px}
@media(min-width:640px){.zone-cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.zone-cards{grid-template-columns:1fr}}

.zone-card{
  display:flex;align-items:center;gap:14px;
  background:rgba(255,255,255,.03);border:1px solid var(--c-border);
  border-radius:var(--r);padding:14px 16px;
  transition:all var(--transition)
}
.zone-card:hover{border-color:rgba(56,189,248,.35);background:rgba(56,189,248,.05)}
.zone-card-ico{
  width:40px;height:40px;border-radius:9px;flex-shrink:0;font-size:1.2rem;
  background:rgba(56,189,248,.1);border:1px solid rgba(56,189,248,.18);
  display:flex;align-items:center;justify-content:center
}
.zone-card h4{font-size:.88rem;margin-bottom:2px}
.zone-card p{font-size:.76rem;color:var(--c-muted);line-height:1.4}

/* ── CTA BOX ────────────────────────────────────────────── */
.cta-box{
  background:linear-gradient(135deg,rgba(14,165,233,.1),rgba(56,189,248,.05));
  border:1px solid rgba(56,189,248,.2);border-radius:var(--r-lg);
  padding:28px 24px;text-align:center
}
.cta-box strong{font-size:1.2rem;font-family:var(--ff-d);display:block;margin-bottom:6px}
.cta-box p{font-size:.84rem;color:var(--c-muted);margin-bottom:18px;line-height:1.6}
.cta-box-btns{display:flex;flex-direction:column;gap:10px}
@media(min-width:480px){.cta-box-btns{flex-direction:row;justify-content:center}}

/* ── FEAT LIST ──────────────────────────────────────────── */
.feat-list{display:grid;gap:18px}
.feat-item{
  padding-left:16px;border-left:2px solid rgba(56,189,248,.2);
  transition:border-color var(--transition)
}
.feat-item:hover{border-left-color:var(--c-sky)}
.feat-item h4{font-size:.95rem;margin-bottom:5px}
.feat-item p{font-size:.82rem;color:var(--c-muted);line-height:1.6}

/* ── WHY GRID ───────────────────────────────────────────── */
.why-grid{
  display:grid;grid-template-columns:1fr;gap:16px
}
@media(min-width:640px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.why-grid{grid-template-columns:repeat(3,1fr)}}
.why-item{
  background:rgba(255,255,255,.025);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:24px;display:flex;gap:16px
}
.why-n{
  font-family:var(--ff-d);font-size:1.8rem;font-weight:800;
  color:rgba(56,189,248,.15);line-height:1;flex-shrink:0;width:40px
}
.why-item h4{font-size:.92rem;margin-bottom:6px}
.why-item p{font-size:.81rem;color:var(--c-muted);line-height:1.6}

/* ── AVIS ───────────────────────────────────────────────── */
.avis-grid{
  display:grid;grid-template-columns:1fr;gap:16px
}
@media(min-width:640px){.avis-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.avis-grid{grid-template-columns:repeat(3,1fr)}}
.avis-card{
  background:var(--c-panel);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:20px;display:flex;flex-direction:column;gap:10px
}
.avis-head{display:flex;align-items:center;gap:9px}
.avis-av{
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--c-blue),var(--c-sky));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-d);font-weight:700;font-size:.8rem;color:#fff
}
.avis-name{font-weight:600;font-size:.85rem}
.avis-date{font-size:.7rem;color:var(--c-muted)}
.stars{color:var(--c-gold);font-size:.95rem;letter-spacing:2px}
.avis-text{font-size:.82rem;color:var(--c-muted);line-height:1.65;flex:1}
.avis-badge{
  align-self:flex-start;font-size:.64rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--c-sky);
  background:rgba(56,189,248,.07);border:1px solid rgba(56,189,248,.18);
  padding:3px 9px;border-radius:999px
}

/* ── STEPS ──────────────────────────────────────────────── */
.steps{
  display:grid;grid-template-columns:1fr;gap:16px;
  counter-reset:steps
}
@media(min-width:640px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{
  background:var(--c-void);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:24px;
  transition:all var(--transition);counter-increment:steps;
  position:relative;overflow:hidden
}
.step::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--c-blue),var(--c-sky));
  transform:scaleX(0);transform-origin:left;transition:transform .3s
}
.step:hover::after{transform:scaleX(1)}
.step:hover{border-color:rgba(14,165,233,.3)}
.step-n{
  font-family:var(--ff-d);font-size:2rem;font-weight:800;
  color:rgba(56,189,248,.16);line-height:1;margin-bottom:12px
}
.step h4{font-size:.92rem;margin-bottom:8px}
.step p{font-size:.8rem;color:var(--c-muted);line-height:1.6}

/* ── ZONES ──────────────────────────────────────────────── */
.zones-grid{
  display:grid;grid-template-columns:1fr;gap:40px;align-items:center
}
@media(min-width:900px){.zones-grid{grid-template-columns:1fr 1fr;gap:60px}}
.zone-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.zone-chip{
  padding:6px 14px;border-radius:var(--r);
  background:rgba(14,165,233,.07);border:1px solid rgba(14,165,233,.18);
  font-size:.78rem;color:var(--c-muted);transition:all var(--transition)
}
.zone-chip:hover{border-color:var(--c-sky);color:var(--c-sky)}
.map-visual{
  aspect-ratio:1;background:var(--c-void);border:1px solid var(--c-border);
  border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;max-width:380px;margin:0 auto
}
@media(min-width:900px){.map-visual{max-width:none;margin:0}}
.map-ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(56,189,248,.13);
  animation:ring 4s ease-out infinite
}
.map-ring:nth-child(1){width:48%;height:48%;animation-delay:0s}
.map-ring:nth-child(2){width:68%;height:68%;animation-delay:1.3s}
.map-ring:nth-child(3){width:90%;height:90%;animation-delay:2.6s}
.map-dot{
  width:10px;height:10px;border-radius:50%;background:var(--c-sky);
  position:absolute;box-shadow:0 0 14px var(--c-sky),0 0 28px rgba(56,189,248,.4)
}
.map-label{
  position:absolute;bottom:16px;font-size:.65rem;
  font-family:monospace;color:var(--c-muted);letter-spacing:.08em;text-align:center;line-height:1.5
}
@keyframes ring{0%{opacity:.6;transform:scale(.9)}100%{opacity:0;transform:scale(1.06)}}

/* ── PAGE HERO ──────────────────────────────────────────── */
.page-hero{
  padding:96px 0 56px;
  background:radial-gradient(ellipse 60% 50% at 70% 30%,rgba(14,165,233,.09) 0%,transparent 60%),var(--c-void);
  border-bottom:1px solid var(--c-border);position:relative
}
.page-hero-bg{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(14,165,233,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(14,165,233,.03) 1px,transparent 1px);
  background-size:56px 56px
}
.page-hero .container{position:relative;z-index:1}
.breadcrumb{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px;
  font-size:.74rem;color:var(--c-muted);margin-bottom:20px
}
.breadcrumb a{color:var(--c-muted);transition:color var(--transition)}
.breadcrumb a:hover{color:var(--c-sky)}
.breadcrumb .sep{color:rgba(255,255,255,.2)}

/* ── CTA FINAL ──────────────────────────────────────────── */
#cta-final{
  background:linear-gradient(135deg,rgba(14,165,233,.12),rgba(56,189,248,.06));
  border-top:1px solid rgba(14,165,233,.18);
  border-bottom:1px solid rgba(14,165,233,.18);
  position:relative;overflow:hidden
}
#cta-final::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(56,189,248,.05) 0%,transparent 65%);
  pointer-events:none
}
.cta-final-inner{text-align:center;position:relative;z-index:1}
.cta-final-inner h2{margin-bottom:14px}
.cta-final-inner>p{font-size:.95rem;color:var(--c-muted);max-width:460px;margin:0 auto 32px;line-height:1.7}
.cta-btns{display:flex;flex-direction:column;gap:12px;align-items:center}
@media(min-width:480px){.cta-btns{flex-direction:row;justify-content:center}}

/* ── FORMULAIRE CONTACT ─────────────────────────────────── */
.contact-layout{
  display:grid;grid-template-columns:1fr;gap:40px;align-items:start
}
@media(min-width:900px){.contact-layout{grid-template-columns:1fr 1.5fr;gap:56px}}
.contact-info-cards{display:grid;gap:12px}
.cinfo{
  background:var(--c-panel);border:1px solid var(--c-border);
  border-radius:var(--r);padding:16px 18px;
  display:flex;align-items:center;gap:14px
}
.cinfo-ico{font-size:1.4rem;flex-shrink:0}
.cinfo h4{font-size:.85rem;margin-bottom:2px}
.cinfo p,.cinfo a{font-size:.8rem;color:var(--c-muted)}
.cinfo a{color:var(--c-sky);font-weight:600}

/* Form */
.frow{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}
@media(min-width:480px){.frow.two{grid-template-columns:1fr 1fr}}
.flabel{display:block;font-size:.78rem;font-weight:500;color:var(--c-muted);margin-bottom:6px}
.finput,.fselect,.ftextarea{
  width:100%;padding:13px 15px;
  background:var(--c-panel);border:1.5px solid var(--c-border);
  border-radius:var(--r);color:var(--c-text);
  font-family:var(--ff-b);font-size:.88rem;outline:none;
  transition:border-color var(--transition),box-shadow var(--transition);
  -webkit-appearance:none
}
.finput:focus,.fselect:focus,.ftextarea:focus{
  border-color:rgba(56,189,248,.5);
  box-shadow:0 0 0 3px rgba(56,189,248,.08)
}
.ftextarea{resize:vertical;min-height:110px}
.fselect{cursor:pointer}
.form-note{font-size:.72rem;color:var(--c-muted);margin-top:8px;text-align:center}

/* Alerts */
.alert{padding:13px 16px;border-radius:var(--r);font-size:.84rem;display:flex;align-items:flex-start;gap:8px;margin-bottom:18px;line-height:1.5}
.alert-ok{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:#10B981}
.alert-err{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--c-red)}

/* ── FAQ ────────────────────────────────────────────────── */
.faq-list{display:grid;gap:8px;max-width:760px;margin:0 auto}
.faq-item{border:1px solid var(--c-border);border-radius:var(--r);overflow:hidden;transition:border-color var(--transition)}
.faq-item:hover{border-color:rgba(56,189,248,.25)}
.faq-q{
  width:100%;padding:16px 18px;background:var(--c-panel);border:none;
  color:var(--c-text);text-align:left;font-family:var(--ff-b);font-size:.86rem;font-weight:500;
  cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;
  transition:background var(--transition)
}
.faq-q:hover{background:rgba(14,165,233,.06)}
.faq-q.open{color:var(--c-sky)}
.faq-arr{font-size:1.2rem;color:var(--c-sky);flex-shrink:0;transition:transform .25s}
.faq-q.open .faq-arr{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;background:var(--c-void)}
.faq-a.open{max-height:300px}
.faq-a p{font-size:.83rem;color:var(--c-muted);line-height:1.75;padding:0 18px 16px}

/* ── FOOTER ─────────────────────────────────────────────── */
#footer{
  background:var(--c-panel);border-top:1px solid var(--c-border);
  padding:56px 0 28px;
  padding-bottom:calc(28px + 80px); /* espace sticky mobile */
}
@media(min-width:768px){#footer{padding-bottom:36px}}
.footer-grid{
  display:grid;grid-template-columns:1fr;gap:36px;margin-bottom:40px
}
@media(min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand h3{font-family:var(--ff-d);font-size:1.15rem;font-weight:800;margin-bottom:10px}
.footer-brand h3 span{color:var(--c-sky)}
.footer-brand small{display:block;font-size:.65rem;font-weight:600;color:var(--c-muted);letter-spacing:.1em;text-transform:uppercase;margin-top:-4px;margin-bottom:12px}
.footer-brand p{font-size:.8rem;color:var(--c-muted);line-height:1.7;margin-bottom:16px}
.f-contacts{display:grid;gap:8px}
.f-contact{display:flex;align-items:center;gap:7px;font-size:.79rem;color:var(--c-muted);transition:color var(--transition)}
.f-contact:hover{color:var(--c-sky)}
.footer-col h4{font-family:var(--ff-d);font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-text);margin-bottom:14px}
.footer-col ul{display:grid;gap:8px}
.footer-col ul li a{font-size:.79rem;color:var(--c-muted);transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--c-sky)}
.footer-bottom{
  padding-top:20px;border-top:1px solid var(--c-border);
  display:flex;flex-direction:column;gap:8px;align-items:flex-start
}
@media(min-width:640px){.footer-bottom{flex-direction:row;align-items:center;justify-content:space-between}}
.footer-bottom p{font-size:.73rem;color:var(--c-muted)}
.footer-bottom a:hover{color:var(--c-sky)}

/* ── MENTIONS LÉGALES ───────────────────────────────────── */
.legal-wrap{max-width:700px}
.legal-block{padding:24px 0;border-bottom:1px solid var(--c-border)}
.legal-block:last-child{border-bottom:none}
.legal-block h2{font-family:var(--ff-d);font-size:1.05rem;margin-bottom:12px;color:var(--c-sky)}
.legal-block p{font-size:.86rem;color:var(--c-muted);line-height:1.75;margin-bottom:10px}
.legal-block p:last-child{margin-bottom:0}
.legal-block a{color:var(--c-sky)}

/* ── FADE-UP ────────────────────────────────────────────── */
.fu{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.fu.vis{opacity:1;transform:translateY(0)}

/* ── UTILITY SECTION BACKGROUND ────────────────────────── */
.bg-panel{background:var(--c-panel);border-top:1px solid var(--c-border)}
.bg-deep{background:var(--c-deep)}

/* ── SERVICES HOMEPAGE RESPONSIVE ─────────────────────── */
@media(max-width:768px){
  /* Ligne 1 : 2 grandes cartes → 1 colonne */
  .svc-row-2{grid-template-columns:1fr !important}
  /* Ligne 2 : 3 cartes → 1 colonne */
  .svc-row-3{grid-template-columns:1fr !important}
  /* Événementiel → colonnes → lignes */
  .svc-events{grid-template-columns:1fr !important;text-align:center}
  .svc-events-btns{flex-direction:column !important;align-items:stretch !important}
}
@media(max-width:640px){
  .why-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .avis-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .zones-grid{grid-template-columns:1fr}
  .copro-section{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-cta-block,.cta-btns{flex-direction:column}
  .ph-badges{grid-template-columns:1fr 1fr}
  .intro-stats{grid-template-columns:1fr 1fr}
}
