/* ════════════════════════════════════════════
   Softlor Ingénierie — main.css v1.0
════════════════════════════════════════════ */

:root{
  --navy:#0A1628;
  --navy2:#112240;
  --blue:#1565C0;
  --blue2:#1E88E5;
  --accent:#F5A623;
  --accent2:#E8960E;
  --white:#FFFFFF;
  --off:#F4F7FB;
  --g100:#EBF0F8;
  --g200:#C8D6EA;
  --g500:#7A90AD;
  --g700:#3D5470;
  --text:#0D1F35;
  --muted:#5A748F;
  --font:'Outfit',sans-serif;
  --mono:'JetBrains Mono',monospace;
  --r1:8px;--r2:16px;--r3:24px;
  --s1:0 2px 8px rgba(10,22,40,.07);
  --s2:0 8px 32px rgba(10,22,40,.12);
  --s3:0 20px 60px rgba(10,22,40,.16);
  --tr:.22s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--text);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;display:block}

.sl-container{max-width:1160px;margin-inline:auto;padding-inline:24px}
.sl-tag{display:inline-block;font-family:var(--mono);font-size:.72rem;letter-spacing:.09em;text-transform:uppercase;color:var(--accent2);background:rgba(245,166,35,.12);border-radius:4px;padding:4px 11px;margin-bottom:.9rem}
.sl-title{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:700;line-height:1.2;color:var(--navy)}
.sl-sub{font-size:1rem;color:var(--muted);margin-top:.55rem;max-width:580px}
.sl-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--r2);font-family:var(--font);font-weight:600;font-size:.92rem;cursor:pointer;border:none;transition:var(--tr)}
.sl-btn-gold{background:var(--accent);color:var(--navy)}
.sl-btn-gold:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:var(--s2)}
.sl-btn-ghost{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.35)}
.sl-btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.sl-btn-navy{background:var(--navy);color:var(--white)}
.sl-btn-navy:hover{background:var(--blue);transform:translateY(-2px);box-shadow:var(--s2)}
.sl-btn-wa{background:#25D366;color:var(--white)}
.sl-btn-wa:hover{background:#1da851;transform:translateY(-2px);box-shadow:var(--s2)}

/* ── NAVBAR ── */
#sl-nb{position:sticky;top:0;z-index:100;background:rgba(10,22,40,.97);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.07)}
.sl-ni{display:flex;align-items:center;justify-content:space-between;height:68px}
.sl-logo{display:flex;align-items:center;gap:12px}
.sl-logo img{height:46px;width:auto}
.sl-logo-txt{font-weight:700;font-size:1.05rem;color:var(--white);line-height:1.15}
.sl-logo-txt span{display:block;font-size:.68rem;font-weight:400;color:var(--g500);letter-spacing:.05em}
.sl-nl{display:flex;align-items:center;gap:28px}
.sl-nl a{color:rgba(255,255,255,.7);font-size:.88rem;font-weight:500;transition:var(--tr)}
.sl-nl a:hover,.sl-nl a.active{color:var(--accent)}
.sl-hbg{display:none;background:none;border:none;cursor:pointer;color:var(--white);font-size:26px}
.sl-mm{display:none;flex-direction:column;background:var(--navy2);padding:14px 24px 22px;gap:4px;border-top:1px solid rgba(255,255,255,.07)}
.sl-mm a{color:rgba(255,255,255,.8);font-size:.95rem;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.sl-mm a:last-child{border-bottom:none}
.sl-mm.open{display:flex}
@media(max-width:860px){.sl-nl,.sl-nc{display:none}.sl-hbg{display:block}}

/* ── HERO ── */
#sl-hero{background:linear-gradient(150deg,var(--navy) 0%,var(--navy2) 55%,#163A6E 100%);padding:104px 0 84px;position:relative;overflow:hidden}
#sl-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 72% 45%,rgba(245,166,35,.09) 0%,transparent 55%),radial-gradient(ellipse at 18% 85%,rgba(21,101,192,.16) 0%,transparent 50%)}
.sl-hg{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.sl-heyebrow{font-family:var(--mono);font-size:.73rem;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);margin-bottom:1.2rem;display:flex;align-items:center;gap:8px}
.sl-heyebrow::before{content:'';display:inline-block;width:28px;height:2px;background:var(--accent)}
.sl-htitle{font-size:clamp(2rem,4.5vw,3.5rem);font-weight:700;line-height:1.12;color:var(--white)}
.sl-htitle em{font-style:normal;color:var(--accent)}
.sl-hdesc{margin-top:1.3rem;font-size:1.02rem;color:rgba(255,255,255,.65);max-width:470px;line-height:1.75}
.sl-hacts{margin-top:2rem;display:flex;gap:12px;flex-wrap:wrap}
.sl-hstats{display:flex;gap:36px;margin-top:2.8rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}
.sl-stat strong{display:block;font-size:1.7rem;font-weight:700;color:var(--white);line-height:1}
.sl-stat span{font-size:.78rem;color:var(--g500);margin-top:3px;display:block}
.sl-hv{display:flex;flex-direction:column;gap:13px}
.sl-hc{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);padding:18px 20px;display:flex;align-items:center;gap:15px;backdrop-filter:blur(6px);transition:var(--tr);animation:slfu .6s ease both}
.sl-hc:nth-child(2){animation-delay:.09s}.sl-hc:nth-child(3){animation-delay:.18s}.sl-hc:nth-child(4){animation-delay:.27s}.sl-hc:nth-child(5){animation-delay:.36s}
@keyframes slfu{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.sl-hc:hover{background:rgba(255,255,255,.10);border-color:rgba(245,166,35,.3)}
.sl-hc-ic{width:44px;height:44px;min-width:44px;background:rgba(245,166,35,.14);border-radius:10px;display:flex;align-items:center;justify-content:center}
.sl-hc-ic i{font-size:22px;color:var(--accent)}
.sl-hc-t strong{display:block;color:var(--white);font-size:.9rem;font-weight:600}
.sl-hc-t span{font-size:.78rem;color:var(--g500)}
@media(max-width:860px){.sl-hg{grid-template-columns:1fr;gap:44px}.sl-hv{display:grid;grid-template-columns:1fr 1fr;gap:11px}.sl-hstats{gap:22px}}
@media(max-width:520px){.sl-hv{grid-template-columns:1fr}}

/* ── QUICK NAV ── */
#sl-qn{background:var(--off);border-bottom:1px solid var(--g200);padding:13px 0;overflow-x:auto}
.sl-qi{display:flex;gap:10px;align-items:center;white-space:nowrap}
.sl-qb{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--g700);background:var(--white);border:1px solid var(--g200);border-radius:20px;padding:6px 15px;transition:var(--tr);cursor:pointer}
.sl-qb:hover{border-color:var(--accent);color:var(--accent2);background:rgba(245,166,35,.06)}
.sl-qb i{font-size:15px}

/* ── SERVICES ── */
#sl-services{padding:100px 0}
.sl-shd{text-align:center;margin-bottom:60px}
.sl-shd .sl-sub{margin-inline:auto;text-align:center}
.sl-sg{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:22px}
.sl-sc{background:var(--white);border:1px solid var(--g100);border-radius:var(--r3);padding:34px;transition:var(--tr);position:relative;overflow:hidden}
.sl-sc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--blue2));transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.sl-sc:hover{box-shadow:var(--s2);transform:translateY(-4px)}
.sl-sc:hover::before{transform:scaleX(1)}
.sl-sc:hover .sl-sc-ic{background:var(--accent);border-color:var(--accent)}
.sl-sc:hover .sl-sc-ic i{color:var(--navy)}
.sl-sc-ic{width:56px;height:56px;background:var(--g100);border:1.5px solid var(--g200);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:var(--tr)}
.sl-sc-ic i{font-size:28px;color:var(--blue);transition:var(--tr)}
.sl-sc-tit{font-size:1.12rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.sl-sc-des{font-size:.88rem;color:var(--muted);line-height:1.7}
.sl-sc-ul{margin-top:16px;display:flex;flex-direction:column;gap:7px}
.sl-sc-ul li{font-size:.83rem;color:var(--muted);display:flex;align-items:flex-start;gap:9px}
.sl-sc-ul li::before{content:'';display:block;width:6px;height:6px;min-width:6px;background:var(--accent);border-radius:50%;margin-top:7px}

/* ── WHY ── */
#sl-why{background:var(--navy);padding:100px 0;position:relative;overflow:hidden}
#sl-why::after{content:'';position:absolute;top:-60px;right:-80px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(245,166,35,.07) 0%,transparent 70%);pointer-events:none}
.sl-wg{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}
.sl-wc .sl-title{color:var(--white)}
.sl-wc .sl-sub{color:rgba(255,255,255,.55)}
.sl-wpts{margin-top:2.2rem;display:flex;flex-direction:column;gap:22px}
.sl-wpt{display:flex;gap:16px;align-items:flex-start}
.sl-wp-ic{width:42px;height:42px;min-width:42px;background:rgba(245,166,35,.13);border-radius:10px;display:flex;align-items:center;justify-content:center}
.sl-wp-ic i{font-size:21px;color:var(--accent)}
.sl-wp-t strong{display:block;color:var(--white);font-weight:600;font-size:.95rem}
.sl-wp-t span{font-size:.85rem;color:rgba(255,255,255,.5)}
.sl-wv{display:flex;flex-direction:column;gap:16px}
.sl-tc{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.09);border-radius:var(--r2);padding:26px}
.sl-ts{color:#FFB830;font-size:.95rem;margin-bottom:12px}
.sl-tt{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.65}
.sl-ta{display:flex;align-items:center;gap:10px;margin-top:18px}
.sl-tav{width:38px;height:38px;border-radius:50%;background:rgba(245,166,35,.2);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--accent)}
.sl-tn strong{display:block;color:var(--white);font-size:.85rem}
.sl-tn span{font-size:.76rem;color:var(--g500)}
@media(max-width:860px){.sl-wg{grid-template-columns:1fr;gap:44px}}

/* ── PRODUITS ── */
#sl-produits{padding:100px 0;background:var(--off)}
.sl-pg{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:20px}
.sl-pc{background:var(--white);border:1px solid var(--g100);border-radius:var(--r2);overflow:hidden;transition:var(--tr)}
.sl-pc:hover{box-shadow:var(--s2);transform:translateY(-4px)}
.sl-pi{height:138px;background:var(--g100);display:flex;align-items:center;justify-content:center}
.sl-pi i{font-size:54px;color:var(--blue2)}
.sl-pb{padding:18px 20px}
.sl-pn{font-weight:700;color:var(--navy);font-size:.93rem;margin-bottom:6px}
.sl-pd{font-size:.82rem;color:var(--muted);line-height:1.6}
.sl-pbg{display:inline-block;margin-top:10px;font-size:.7rem;font-weight:600;color:var(--accent2);background:rgba(245,166,35,.12);border-radius:4px;padding:3px 8px}

/* ── LIENS ── */
#sl-liens{padding:80px 0}
.sl-lhd{text-align:center;margin-bottom:48px}
.sl-lhd .sl-sub{margin-inline:auto;text-align:center}
.sl-lg{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px}
.sl-lc{background:var(--white);border:1px solid var(--g200);border-radius:var(--r2);padding:20px 22px;display:flex;align-items:center;gap:14px;transition:var(--tr)}
.sl-lc:hover{border-color:var(--accent);box-shadow:var(--s1);transform:translateX(3px)}
.sl-lc:hover .sl-lci{background:var(--accent);border-color:transparent}
.sl-lc:hover .sl-lci i{color:var(--navy)}
.sl-lci{width:42px;height:42px;min-width:42px;background:var(--g100);border:1px solid var(--g200);border-radius:10px;display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.sl-lci i{font-size:20px;color:var(--blue);transition:var(--tr)}
.sl-lct strong{display:block;font-size:.88rem;font-weight:600;color:var(--navy)}
.sl-lct span{font-size:.76rem;color:var(--muted)}
.sl-la{margin-left:auto;color:var(--g500);font-size:16px;transition:var(--tr)}
.sl-lc:hover .sl-la{color:var(--accent2)}
.sl-disabled{opacity:.5;cursor:default}
.sl-disabled:hover{transform:none;border-color:var(--g200);box-shadow:none}

/* ── CONTACT ── */
#sl-contact{padding:100px 0;background:var(--off)}
.sl-cg{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.sl-cb-blk{display:flex;align-items:flex-start;gap:16px;background:var(--white);border:1px solid var(--g200);border-radius:var(--r1);padding:18px 20px}
.sl-cbi{width:42px;height:42px;min-width:42px;background:rgba(21,101,192,.1);border-radius:8px;display:flex;align-items:center;justify-content:center}
.sl-cbi i{font-size:21px;color:var(--blue)}
.sl-cbl{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.sl-cbv{font-size:.93rem;font-weight:600;color:var(--navy);line-height:1.55}
.sl-cbv a{color:var(--blue);transition:var(--tr)}
.sl-cbv a:hover{color:var(--accent2)}
.sl-cf{background:var(--white);border:1px solid var(--g200);border-radius:var(--r3);padding:38px;box-shadow:var(--s1)}
.sl-cf-tit{font-size:1.22rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.sl-cf-note{font-size:.82rem;color:var(--muted);margin-bottom:20px;display:flex;align-items:center;gap:6px}
.sl-cf-note i{color:#25D366;font-size:17px}
.sl-fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sl-fg{margin-bottom:14px}
.sl-fg label{display:block;font-size:.8rem;font-weight:600;color:var(--g700);margin-bottom:6px}
.sl-fg input,.sl-fg textarea,.sl-fg select{width:100%;padding:10px 14px;border:1px solid var(--g200);border-radius:var(--r1);font-family:var(--font);font-size:.88rem;color:var(--text);background:var(--off);outline:none;transition:var(--tr)}
.sl-fg input:focus,.sl-fg textarea:focus,.sl-fg select:focus{border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px rgba(21,101,192,.1)}
.sl-fg textarea{resize:vertical;min-height:110px}
.sl-fsub{width:100%;background:#25D366;color:var(--white);padding:13px;border-radius:var(--r2);font-size:.93rem;font-weight:600;border:none;cursor:pointer;transition:var(--tr);display:flex;align-items:center;justify-content:center;gap:8px}
.sl-fsub:hover{background:#1da851}
.sl-wa-note{font-size:.78rem;color:var(--muted);text-align:center;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:6px}
@media(max-width:860px){.sl-cg{grid-template-columns:1fr;gap:44px}.sl-fr{grid-template-columns:1fr}}

/* ── CTA ── */
#sl-cta{background:linear-gradient(135deg,var(--blue) 0%,var(--navy) 100%);padding:76px 0;text-align:center}
.sl-cta-tit{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700;color:var(--white)}
.sl-cta-sub{margin-top:.75rem;color:rgba(255,255,255,.6);font-size:.98rem}
.sl-cta-acts{margin-top:2rem;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── FOOTER ── */
footer.sl-footer{background:var(--navy);color:rgba(255,255,255,.5);padding:68px 0 32px}
.sl-fg-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:52px}
.sl-fb p{font-size:.86rem;line-height:1.7;max-width:290px;margin-top:14px}
.sl-fc h4{font-size:.82rem;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:.09em;margin-bottom:16px}
.sl-fc ul{display:flex;flex-direction:column;gap:9px}
.sl-fc ul li a{font-size:.86rem;color:rgba(255,255,255,.5);transition:var(--tr)}
.sl-fc ul li a:hover{color:var(--accent)}
.sl-fbot{border-top:1px solid rgba(255,255,255,.07);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:.8rem}
.sl-fbot a{color:rgba(255,255,255,.35);transition:var(--tr)}
.sl-fbot a:hover{color:var(--accent)}
@media(max-width:860px){.sl-fg-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.sl-fg-grid{grid-template-columns:1fr}}

/* ── TOAST ── */
#sl-toast{position:fixed;bottom:24px;right:24px;background:var(--navy2);color:var(--white);padding:14px 20px;border-radius:var(--r2);font-size:.88rem;border-left:4px solid #25D366;box-shadow:var(--s3);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:999;display:flex;align-items:center;gap:10px}
#sl-toast.show{opacity:1}

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

/* ── HORAIRES TABLE ── */
.sl-horaires{width:100%;border-collapse:collapse;font-size:.88rem}
.sl-horaires tr:not(:last-child){border-bottom:1px solid var(--g200)}
.sl-horaires td{padding:6px 0;color:var(--navy);font-weight:500}
.sl-horaires td:last-child{color:var(--muted);text-align:right}
.sl-horaires .closed td{color:var(--muted)}
