

:root{
  --g:#8dc63f;--g2:#a8d94e;--gd:#6fa52e;
  --p:#922B8C;--p2:#b03aaa;
  --bg:#080a0c;--bg2:#0f1114;--bg3:#161a1e;--bg4:#1d2126;
  --border:rgba(255,255,255,.06);
  --text:#dde0e4;--muted:#5e6470;--dim:#363b44;
}
/* NAV */
#sitenav{position:fixed;top:0;left:0;right:0;z-index:9000;height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 5vw;background:rgba(8,10,12,.93);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.07)}
#nav-brand img{height:42px;width:auto;max-width:160px;object-fit:contain;display:block;flex-shrink:0}
#nav-desktop{display:flex;align-items:center;gap:2px}
#nav-desktop a{color:#7a7d82;text-decoration:none;font-family:'Rajdhani',sans-serif;font-weight:600;font-size:14px;padding:8px 12px;border-radius:6px;transition:.18s;white-space:nowrap}
#nav-desktop a:hover{color:#fff;background:rgba(255,255,255,.05)}
#nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
#nav-tel{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:13px;color:#dde0e4;text-decoration:none;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:7px 12px;white-space:nowrap;transition:.18s}
#nav-tel:hover{border-color:#8dc63f;color:#8dc63f}
#nav-cta-btn{background:#922B8C;color:#fff;text-decoration:none;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:13px;padding:8px 16px;border-radius:6px;white-space:nowrap}
#nav-cta-btn:hover{background:#b03aaa}

/* Burger label */
#nav-burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;cursor:pointer;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:9px;flex-shrink:0;transition:border-color .2s}
#nav-burger:hover{border-color:#8dc63f}
#nav-burger span{display:block;width:22px;height:2px;background:#dde0e4;border-radius:2px;transition:transform .28s,opacity .28s}

/* Burger animé quand coché */
#nav-toggle:checked ~ #nav-actions #nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
#nav-toggle:checked ~ #nav-actions #nav-burger span:nth-child(2){opacity:0;transform:scaleX(0)}
#nav-toggle:checked ~ #nav-actions #nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Menu mobile : caché par défaut */
#nav-mobile{display:none;position:fixed;top:70px;left:0;right:0;z-index:8999;background:rgba(8,10,12,.98);border-bottom:2px solid #8dc63f;flex-direction:column;padding:6px 0 14px}
#nav-toggle:checked ~ #nav-mobile{display:flex}
#nav-mobile a{color:#dde0e4;text-decoration:none;font-family:'Rajdhani',sans-serif;font-weight:600;font-size:16px;padding:15px 24px;border-bottom:1px solid rgba(255,255,255,.06);transition:.15s}
#nav-mobile a:last-child{border-bottom:none}
#nav-mobile a:hover{color:#8dc63f;background:rgba(141,198,63,.05)}

@media(max-width:960px){
  #nav-desktop,#nav-tel,#nav-cta-btn{display:none}
  #nav-burger{display:flex}
}


body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}

/* HERO */
.hero{min-height:100vh;padding:70px 5vw 0;display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:60px;position:relative;overflow:hidden;background:var(--bg)}
.hero-bg{position:absolute;inset:0;z-index:0}
#net-canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.3}
.hero-glow{position:absolute;width:800px;height:800px;border-radius:50%;top:-200px;right:-150px;background:radial-gradient(circle,rgba(141,198,63,.06) 0%,transparent 65%);pointer-events:none}
.hero-glow2{position:absolute;width:500px;height:500px;border-radius:50%;bottom:-100px;left:-80px;background:radial-gradient(circle,rgba(146,43,140,.06) 0%,transparent 65%);pointer-events:none}

.hero-content{position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(141,198,63,.25);background:rgba(141,198,63,.07);color:var(--g);font-family:'Rajdhani',sans-serif;font-weight:700;font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:6px 14px;border-radius:20px;margin-bottom:28px;animation:fadeUp .5s ease both}
.hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--g);animation:blink 1.5s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

.hero-title{font-family:'Rajdhani',sans-serif;font-size:clamp(42px,5.2vw,70px);font-weight:700;line-height:1.03;color:#fff;margin-bottom:26px;animation:fadeUp .6s .1s ease both}
.hero-title em{color:var(--g);font-style:normal}
.hero-title span{color:var(--p2)}

.hero-sub{font-size:17px;color:var(--muted);max-width:500px;margin-bottom:44px;line-height:1.75;animation:fadeUp .6s .2s ease both}
.hero-sub b{color:var(--text)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .6s .3s ease both}
.btn-g{display:inline-flex;align-items:center;gap:8px;background:var(--g);color:#080a0c;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;padding:13px 26px;border-radius:8px;text-decoration:none;transition:.2s;box-shadow:0 0 28px rgba(141,198,63,.25)}
.btn-g:hover{background:var(--g2);transform:translateY(-2px);box-shadow:0 0 44px rgba(141,198,63,.4)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.2);font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;padding:11px 24px;border-radius:8px;text-decoration:none;transition:.2s}
.btn-outline:hover{border-color:var(--g);color:var(--g);transform:translateY(-2px)}
.btn-p-pulse{display:inline-flex;align-items:center;gap:8px;background:var(--p);color:#fff;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:15px;padding:11px 22px;border-radius:8px;text-decoration:none;transition:.2s;animation:glowp 2.5s infinite}
.btn-p-pulse:hover{background:var(--p2);transform:translateY(-2px)}
@keyframes glowp{0%,100%{box-shadow:0 0 10px rgba(146,43,140,.25)}50%{box-shadow:0 0 28px rgba(146,43,140,.55)}}

/* Hero visual — dashboard IT */
.hero-visual{position:relative;z-index:2;animation:fadeUp .7s .2s ease both}
.it-dashboard{background:var(--bg3);border:1px solid var(--border);border-radius:18px;padding:0;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.5)}
.dash-top{height:3px;background:linear-gradient(90deg,var(--g),var(--p))}
.dash-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border)}
.dash-dots{display:flex;gap:6px}
.dash-dot{width:10px;height:10px;border-radius:50%}
.dash-title{font-family:'Rajdhani',sans-serif;font-size:12px;color:var(--muted);letter-spacing:1px}
.dash-live{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--g);font-family:'Rajdhani',sans-serif;font-weight:700}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--g);animation:blink 1.5s infinite}

.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);padding:0}
.dash-cell{background:var(--bg2);padding:16px 18px}
.dc-label{font-size:11px;color:var(--muted);letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}
.dc-val{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:26px;line-height:1}
.dc-val.g{color:var(--g)}
.dc-val.p{color:var(--p2)}
.dc-val.w{color:#fff}
.dc-sub{font-size:11px;color:var(--muted);margin-top:4px}
.dc-bar{height:4px;background:rgba(255,255,255,.06);border-radius:2px;margin-top:8px;overflow:hidden}
.dc-fill{height:100%;border-radius:2px;background:var(--g);animation:grow 1.5s ease}
.dc-fill.p{background:var(--p)}
@keyframes grow{from{width:0!important}}

.dash-alerts{padding:12px 18px;border-top:1px solid var(--border)}
.alert-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.alert-row:last-child{border-bottom:none}
.alert-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.alert-dot.ok{background:var(--g)}
.alert-dot.warn{background:#f59e0b}
.alert-dot.info{background:var(--p)}
.alert-text{font-size:12px;color:var(--muted);flex:1}
.alert-time{font-size:10px;color:var(--dim);font-family:'Rajdhani',sans-serif}

.hero-float{position:absolute;top:-16px;right:-16px;background:var(--bg4);border:1px solid rgba(141,198,63,.3);border-radius:12px;padding:12px 16px;box-shadow:0 8px 24px rgba(0,0,0,.4);animation:float 3s ease-in-out infinite;text-align:center;z-index:5}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-float strong{display:block;font-family:'Rajdhani',sans-serif;font-size:30px;font-weight:700;color:var(--g);line-height:1}
.hero-float small{font-size:10px;color:var(--muted);letter-spacing:1px}

/* STATS */
.stats-bar{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr)}
.stat{padding:28px 16px;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-ico{font-size:24px;margin-bottom:6px;display:block}
.stat-n{font-family:'Rajdhani',sans-serif;font-size:36px;font-weight:700;color:var(--g);line-height:1}
.stat-n.p{color:var(--p2)}
.stat-l{font-size:11px;color:var(--muted);margin-top:4px;letter-spacing:.3px}

/* OFFRES PHARES */
.offers{background:var(--bg);padding:100px 5vw}
.section-eyebrow{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--g);margin-bottom:12px}
.section-h{font-family:'Rajdhani',sans-serif;font-size:clamp(30px,3.8vw,48px);font-weight:700;color:#fff;line-height:1.08;margin-bottom:16px}
.section-h span{color:var(--p2)}
.section-p{font-size:16px;color:var(--muted);line-height:1.75}

.offers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.offer-card{background:var(--bg2);border:1px solid var(--border);border-radius:18px;padding:32px 28px;position:relative;overflow:hidden;transition:.3s;cursor:default}
.offer-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--g);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.offer-card.purple-card::before{background:var(--p)}
.offer-card:hover{border-color:rgba(141,198,63,.25);transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.3)}
.offer-card.purple-card:hover{border-color:rgba(146,43,140,.25)}
.offer-card:hover::before{transform:scaleX(1)}
.offer-card.featured{border-color:rgba(141,198,63,.3);background:linear-gradient(135deg,rgba(141,198,63,.06),var(--bg2))}
.offer-badge{display:inline-block;font-family:'Rajdhani',sans-serif;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:3px 10px;border-radius:4px;margin-bottom:16px}
.badge-g{background:rgba(141,198,63,.12);color:var(--g);border:1px solid rgba(141,198,63,.3)}
.badge-p{background:rgba(146,43,140,.12);color:var(--p2);border:1px solid rgba(146,43,140,.3)}
.badge-star{background:rgba(245,158,11,.12);color:#f59e0b;border:1px solid rgba(245,158,11,.3)}
.offer-icon{font-size:36px;margin-bottom:16px;display:block}
.offer-card h3{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:20px;color:#fff;margin-bottom:10px}
.offer-card p{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:20px}
.offer-features{display:flex;flex-direction:column;gap:8px}
.off-feat{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text)}
.off-feat::before{content:'✓';color:var(--g);font-weight:700;font-size:11px;width:16px;text-align:center;flex-shrink:0}
.offer-card.purple-card .off-feat::before{color:var(--p2)}

/* SUPERVISION PHARE */
.supervision{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:100px 5vw}
.supervision-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.sup-features{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.sup-feat{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;background:var(--bg3);border-radius:10px;border:1px solid var(--border);transition:.2s}
.sup-feat:hover{border-color:rgba(141,198,63,.3)}
.sup-feat-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.sup-feat-title{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:15px;color:#fff;margin-bottom:3px}
.sup-feat-desc{font-size:13px;color:var(--muted);line-height:1.55}
.sup-dash{background:var(--bg3);border:1px solid var(--border);border-radius:20px;overflow:hidden}
.sup-dash-top{height:3px;background:linear-gradient(90deg,var(--g),var(--p))}
.sup-dash-inner{padding:28px}
.sup-dash h3{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;color:var(--g);margin-bottom:4px}
.sup-dash p{font-size:12px;color:var(--muted);margin-bottom:22px}
.metric{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.metric:last-child{border-bottom:none}
.metric-l{font-size:13px;color:var(--muted);min-width:150px}
.metric-bar{flex:1;margin:0 12px;height:4px;background:rgba(255,255,255,.05);border-radius:2px;overflow:hidden}
.metric-f{height:100%;border-radius:2px;background:var(--g);animation:grow 1.5s ease}
.metric-f.p{background:var(--p)}
.metric-v{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:14px;color:#fff;min-width:34px;text-align:right}

/* PHOTO BAND */
.photo-band{display:grid;grid-template-columns:repeat(5,1fr);height:220px}
.pb-cell{position:relative;overflow:hidden}
.pb-cell img{width:100%;height:100%;object-fit:cover;filter:brightness(.5) saturate(.7);transition:.4s}
.pb-cell:hover img{filter:brightness(.8) saturate(1);transform:scale(1.06)}
.pb-info{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.75));padding:14px 12px 10px}
.pb-info small{display:block;font-size:10px;letter-spacing:2px;color:var(--g);font-weight:700;font-family:'Rajdhani',sans-serif;margin-bottom:2px}
.pb-info span{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:14px;color:white}

/* PROCESS */
.process{background:var(--bg);padding:100px 5vw}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:56px;position:relative}
.process-steps::before{content:'';position:absolute;top:31px;left:12%;right:12%;height:1px;background:linear-gradient(90deg,transparent,var(--border),var(--border),transparent)}
.step{text-align:center;padding:0 14px;position:relative;z-index:2}
.step-num{width:62px;height:62px;border-radius:50%;background:var(--bg3);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:20px;color:var(--g);transition:.3s}
.step:hover .step-num{border-color:var(--g);background:rgba(141,198,63,.08);box-shadow:0 0 20px rgba(141,198,63,.2)}
.step-ico{font-size:22px;margin-bottom:8px}
.step h4{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;color:#fff;margin-bottom:7px}
.step p{font-size:13px;color:var(--muted);line-height:1.65}

/* TELECOM SECTION — en support */
.telecom{background:var(--bg2);border-top:1px solid var(--border);padding:100px 5vw}
.telecom-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.telecom-services{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px}
.tsvc{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:18px 16px;transition:.2s}
.tsvc:hover{border-color:rgba(141,198,63,.25)}
.tsvc-icon{font-size:22px;margin-bottom:8px;display:block}
.tsvc h4{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:15px;color:#fff;margin-bottom:5px}
.tsvc p{font-size:12px;color:var(--muted);line-height:1.55}
.telecom-photo{border-radius:20px;overflow:hidden;position:relative}
.telecom-photo img{width:100%;height:380px;object-fit:cover;filter:brightness(.6) saturate(.8)}
.telecom-photo-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(141,198,63,.1),rgba(146,43,140,.07))}

/* TESTIMONIALS */
.testimony{background:var(--bg);border-top:1px solid var(--border);padding:100px 5vw}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.test-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:28px 24px;position:relative;transition:.3s}
.test-card:hover{border-color:rgba(141,198,63,.25);transform:translateY(-4px)}
.test-card::before{content:'"';position:absolute;top:16px;right:20px;font-size:56px;font-family:Georgia,serif;color:rgba(141,198,63,.12);line-height:1}
.test-stars{color:var(--g);font-size:13px;margin-bottom:12px;letter-spacing:2px}
.test-text{font-size:14px;color:var(--text);line-height:1.75;margin-bottom:18px;font-style:italic}
.test-author{display:flex;align-items:center;gap:10px}
.test-avatar{width:38px;height:38px;border-radius:50%;background:var(--bg3);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px}
.test-name{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:14px;color:#fff}
.test-role{font-size:11px;color:var(--muted)}

/* TERRITOIRE */
.territory{background:var(--bg2);border-top:1px solid var(--border);padding:100px 5vw}
.territory-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.badge{display:inline-flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:8px 14px;font-family:'Rajdhani',sans-serif;font-weight:600;font-size:13px;color:var(--text);transition:.2s}
.badge:hover{border-color:var(--g);color:var(--g)}
.bdot{width:6px;height:6px;border-radius:50%;background:var(--g)}
.bdot.p{background:var(--p)}
.territory-viz{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:28px 24px;text-align:center}
.france-map-full{width:100%;max-width:300px;display:block;margin:0 auto}
.territory-stats{display:flex;align-items:center;justify-content:center;gap:0;margin-top:18px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.ts-item{flex:1;padding:14px 10px;text-align:center}
.ts-val{display:block;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:26px;color:var(--g);line-height:1}
.ts-val small{font-size:15px}
.ts-label{display:block;font-size:10px;color:var(--muted);margin-top:3px;line-height:1.4}
.ts-sep{width:1px;background:var(--border);align-self:stretch}

/* FAQ */
.faq{background:var(--bg);border-top:1px solid var(--border);padding:100px 5vw}
.faq-inner{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border);padding:18px 0}
.faq-q{font-family:'Rajdhani',sans-serif;font-size:17px;font-weight:700;color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq-q:hover{color:var(--g)}
.faq-chevron{font-size:20px;color:var(--g);flex-shrink:0;transition:transform .2s}
.faq-a{display:none;padding-top:12px;font-size:15px;color:var(--muted);line-height:1.75}
.faq-a b{color:var(--text)}

/* CONTACT */
.contact{background:var(--bg2);border-top:1px solid var(--border);padding:100px 5vw}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.cd{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;background:var(--bg3);border-radius:12px;border:1px solid var(--border);border-left:3px solid var(--g);margin-bottom:12px}
.cd.p{border-left-color:var(--p)}
.cd-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.cd-lbl{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:4px}
.cd-val{font-family:'Rajdhani',sans-serif;font-weight:600;font-size:16px;color:var(--text)}
.cd-val a{color:var(--p2);text-decoration:none}
.cd-val a:hover{color:var(--g)}
.remote-cta{margin-top:22px;background:rgba(146,43,140,.12);border:1px solid rgba(146,43,140,.3);border-radius:14px;padding:26px 22px;text-align:center}
.remote-cta h3{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:18px;color:#fff;margin-bottom:7px}
.remote-cta p{font-size:13px;color:var(--muted);margin-bottom:18px}
.btn-remote{display:inline-flex;align-items:center;gap:9px;background:var(--p);color:#fff;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;padding:12px 22px;border-radius:8px;text-decoration:none;transition:.2s;animation:glowp 2.5s infinite}
.btn-remote:hover{background:var(--p2);transform:translateY(-2px)}
.cform{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:36px 32px}
.cform h3{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:22px;color:#fff;margin-bottom:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{margin-bottom:15px}
.fg label{display:block;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:6px}
.fg input,.fg textarea,.fg select{width:100%;padding:11px 14px;border:1px solid var(--border);background:var(--bg2);border-radius:8px;font-size:14px;color:var(--text);font-family:'DM Sans',sans-serif;outline:none;transition:.2s}
.fg input::placeholder,.fg textarea::placeholder{color:var(--dim)}
.fg select{color:var(--muted)}
.fg select option{background:var(--bg2)}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(141,198,63,.08)}
.fg textarea{height:110px;resize:vertical}
.btn-submit{width:100%;padding:13px;background:var(--g);color:#080a0c;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:17px;border:none;border-radius:8px;cursor:pointer;letter-spacing:.5px;transition:.2s;box-shadow:0 0 24px rgba(141,198,63,.2)}
.btn-submit:hover{background:var(--g2);transform:translateY(-1px)}
.fsuccess{display:none;text-align:center;padding:48px 20px}
.fsuccess .ok{font-size:46px;margin-bottom:14px}
.fsuccess h4{font-family:'Rajdhani',sans-serif;font-size:24px;color:var(--g);margin-bottom:8px}
.fsuccess p{color:var(--muted)}

/* FOOTER */
footer{background:#040506;border-top:1px solid var(--border);padding:48px 5vw 28px}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:32px;padding-bottom:32px;border-bottom:1px solid var(--border)}
.footer-brand img{height:36px;max-width:150px;object-fit:contain;display:block;margin-bottom:12px}
.footer-brand p{font-size:13px;color:var(--muted);max-width:220px;line-height:1.6}
.footer-col h4{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--text);margin-bottom:12px}
.footer-col a{display:block;font-size:13px;color:var(--muted);text-decoration:none;margin-bottom:7px;transition:color .2s}
.footer-col a:hover{color:var(--g)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding-top:22px;font-size:12px;color:var(--dim)}

/* ANIMS */

/* ── PARTENAIRES ── */
.partners{
  background:var(--bg2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:32px 5vw;
}
.partners-label{
  text-align:center;
  font-family:'Rajdhani',sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:24px;
}
.partners-logos{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:16px;
}
.partner-badge{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 20px;
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:10px;
  text-decoration:none;
  transition:.2s;
  min-width:160px;
  justify-content:center;
}
.partner-badge:hover{
  border-color:rgba(141,198,63,.35);
  background:rgba(141,198,63,.05);
  transform:translateY(-2px);
}
.partner-logo{
  width:28px;
  height:28px;
  object-fit:contain;
  display:block;
  opacity:.7;
  transition:.2s;
}
.partner-badge:hover .partner-logo{
  opacity:1;
}
.partner-name{
  font-family:'Rajdhani',sans-serif;
  font-weight:700;
  font-size:15px;
  color:var(--muted);
  letter-spacing:.5px;
  transition:.2s;
}
.partner-badge:hover .partner-name{color:#fff}
@media(max-width:600px){
  .partners-logos{gap:10px}
  .partner-badge{min-width:140px;padding:10px 14px}
}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:1;transform:none}
.reveal.visible{opacity:1;transform:none}

@media(max-width:960px){
  .hero{grid-template-columns:1fr;padding-top:100px}
  .hero-visual{display:none}
  .supervision-inner,.telecom-inner,.territory-inner,.contact-inner{grid-template-columns:1fr;gap:40px}
  .offers-grid,.test-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr 1fr;gap:32px}
  .process-steps::before{display:none}
  .stats-bar{grid-template-columns:repeat(3,1fr)}
  .photo-band{grid-template-columns:repeat(3,1fr);height:auto}
  .pb-cell{height:160px}
  .telecom-services{grid-template-columns:1fr}
  nav 
  .form-row{grid-template-columns:1fr}
}
