/*
Theme Name: Firenze Ingenierie Expertises
Theme URI: https://firenze-ingenierie.ci
Author: Firenze Ingenierie
Description: Theme professionnel anime - Firenze Ingenierie et Expertises Abidjan CI
Version: 5.0
License: GNU General Public License v2
Text Domain: firenze
Tags: one-page, business, professional, animated
*/

:root{
  --bg:#FFFFFF;--surface:#F5F5F3;--surface2:#EDECEA;
  --rouge:#B5302A;--rouge-dark:#8C2420;--rouge-glow:rgba(181,48,42,.12);--rouge-lite:#D4453E;
  --or:#C4940F;--vert:#27AE60;--bleu:#2471A3;
  --texte:#1B1B1B;--texte-2:#4A4A4A;--texte-dim:#7A7A7A;--texte-muted:#A8A8A8;
  --grid-line:rgba(181,48,42,.04);--grid-line2:rgba(0,0,0,.02);
  --border:rgba(0,0,0,.08);--border-strong:rgba(0,0,0,.12);
  --shadow-sm:0 2px 8px rgba(0,0,0,.04);--shadow-md:0 8px 30px rgba(0,0,0,.07);--shadow-lg:0 20px 60px rgba(0,0,0,.1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}body{font-family:'Source Sans 3',sans-serif;color:var(--texte);background:var(--bg);overflow-x:hidden;line-height:1.7}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}ul{list-style:none}
h1,h2,h3,h4{font-family:'EB Garamond',Georgia,serif;line-height:1.15;font-weight:700}

/* GRAIN */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9990;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.blueprint-bg{position:fixed;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px),linear-gradient(var(--grid-line2) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line2) 1px,transparent 1px);background-size:100px 100px,100px 100px,20px 20px,20px 20px}
#scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--rouge),var(--or));z-index:99999;width:0}

/* LOADER */
#loader{position:fixed;inset:0;z-index:100000;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column}
#loader.done{animation:loaderExit 1s cubic-bezier(.7,0,.2,1) forwards}
@keyframes loaderExit{0%{clip-path:inset(0)}100%{clip-path:inset(0 0 100% 0)}}
.loader-counter{font-family:'EB Garamond',serif;font-size:clamp(4rem,12vw,9rem);font-weight:800;color:var(--rouge);line-height:1;letter-spacing:-.04em}
.loader-label{font-size:.65rem;letter-spacing:.6em;text-transform:uppercase;color:var(--texte-dim);margin-top:1.5rem}
.loader-line{width:120px;height:1px;background:var(--border);margin-top:1rem;position:relative;overflow:hidden}
.loader-line::after{content:'';position:absolute;left:0;top:0;height:100%;width:0;background:var(--rouge);animation:ll 2.5s ease forwards}
@keyframes ll{to{width:100%}}
.loader-corner{position:absolute;width:24px;height:24px;pointer-events:none}
.loader-corner.tl{top:28px;left:28px;border-top:1px solid rgba(181,48,42,.15);border-left:1px solid rgba(181,48,42,.15)}
.loader-corner.tr{top:28px;right:28px;border-top:1px solid rgba(181,48,42,.15);border-right:1px solid rgba(181,48,42,.15)}
.loader-corner.bl{bottom:28px;left:28px;border-bottom:1px solid rgba(181,48,42,.15);border-left:1px solid rgba(181,48,42,.15)}
.loader-corner.br{bottom:28px;right:28px;border-bottom:1px solid rgba(181,48,42,.15);border-right:1px solid rgba(181,48,42,.15)}

/* CURSOR */
.cur-ring{width:40px;height:40px;border:1.5px solid var(--rouge);border-radius:50%;position:fixed;pointer-events:none;z-index:99998;transition:transform .2s,opacity .2s,width .3s,height .3s,border-color .3s;opacity:.4}
.cur-ring.hover{width:65px;height:65px;border-color:var(--or);opacity:.2}
.cur-dot{width:5px;height:5px;background:var(--rouge);border-radius:50%;position:fixed;pointer-events:none;z-index:99998}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:9998;padding:14px 48px;display:flex;align-items:center;justify-content:space-between;transition:all .4s}
#nav.scrolled{padding:8px 48px;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}
#nav.hide{transform:translateY(-110%)}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo img{height:42px;width:42px;object-fit:contain}
.nav-logo-text{font-family:'EB Garamond',serif;font-weight:700;font-size:14px;line-height:1.3}
.nav-logo-text span{display:block;font-family:'Source Sans 3',sans-serif;font-weight:400;font-size:10px;letter-spacing:.18em;color:var(--texte-dim);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--texte-dim);padding:8px 14px;border-radius:5px;transition:all .3s;position:relative}
.nav-links a:hover{color:var(--texte)}
.nav-links a::after{content:'';position:absolute;bottom:4px;left:14px;right:14px;height:1px;background:var(--rouge);transform:scaleX(0);transition:transform .4s cubic-bezier(.4,0,.2,1)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{background:var(--rouge)!important;color:#fff!important;border-radius:5px!important;padding:9px 20px!important;font-weight:600!important;box-shadow:0 2px 16px var(--rouge-glow)}
.nav-cta:hover{background:var(--rouge-dark)!important;transform:translateY(-2px)!important}
.nav-cta::after{display:none!important}
.nav-wa{color:var(--vert)!important}
.hamburger{display:none;background:none;border:none;font-size:22px;color:var(--texte);cursor:pointer}
#mob-menu{display:none;position:fixed;inset:0;background:rgba(255,255,255,.98);backdrop-filter:blur(16px);z-index:9997;flex-direction:column;align-items:center;justify-content:center;gap:8px}
#mob-menu.open{display:flex}
#mob-menu a{font-family:'EB Garamond',serif;font-size:1.4rem;font-weight:600;color:var(--texte);padding:12px 30px}
#mob-menu a:hover{color:var(--rouge)}
.mob-close{position:absolute;top:20px;right:24px;background:none;border:none;font-size:28px;cursor:pointer}

/* UTILITAIRES */
.container{max-width:1180px;margin:0 auto;padding:0 40px}
.sec-pad{padding:100px 0;position:relative;z-index:1}
.sec-label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.5em;text-transform:uppercase;color:var(--rouge);display:flex;align-items:center;gap:12px;margin-bottom:1.2rem}
.sec-label::before{content:'';width:28px;height:1px;background:var(--rouge)}
.sec-title{font-family:'EB Garamond',serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:800;line-height:1.1;margin-bottom:.8rem}
.sec-title em{font-style:normal;color:var(--rouge)}
.sec-sub{color:var(--texte-2);font-size:1rem;max-width:520px;line-height:1.85}
.bg-grey{background:var(--surface)}
.bg-dark{background:var(--texte);color:#fff}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;font-family:'Source Sans 3',sans-serif;font-weight:600;font-size:13px;letter-spacing:.05em;border-radius:6px;cursor:pointer;transition:all .4s;border:none;position:relative;overflow:hidden}
.btn-rouge{background:var(--rouge);color:#fff;box-shadow:0 3px 20px var(--rouge-glow)}
.btn-rouge:hover{background:var(--rouge-dark);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--rouge);border:1.5px solid var(--rouge)}
.btn-outline:hover{background:var(--rouge);color:#fff;transform:translateY(-2px)}
.btn-wa{background:var(--vert);color:#fff}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(39,174,96,.2)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}
.btn-lg{padding:16px 34px;font-size:14px}

/* ═══ HERO ═══ */
#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:70px;padding:130px 80px 80px;position:relative;overflow:hidden;background:linear-gradient(135deg,#fff 0%,#fdf3f2 60%,#fde8e6 100%)}
.hero-canvas{position:absolute;inset:0;z-index:0}
.hero-canvas canvas{width:100%;height:100%}
#hero>*:not(.hero-canvas):not(.hero-geo){position:relative;z-index:2}
#hero::before{content:'';position:absolute;top:-200px;right:-200px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(181,48,42,.06),transparent 70%);animation:orbF 12s ease-in-out infinite;pointer-events:none}
@keyframes orbF{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-20px)}}
.hero-overline{display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--rouge);margin-bottom:1.5rem;opacity:0;animation:fadeIn .6s 2.8s forwards}
.hero-dot{width:7px;height:7px;background:var(--rouge);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 8px var(--rouge-glow)}50%{box-shadow:0 0 20px rgba(181,48,42,.25)}}
.hero-title{font-family:'EB Garamond',serif;font-size:clamp(2.6rem,5vw,4.8rem);font-weight:800;line-height:1.05;margin-bottom:1.5rem}
.hero-line{display:block;overflow:hidden;padding-bottom:.06em}
.hero-line-inner{display:block;transform:translateY(108%)}
.hero-title .rouge{color:var(--rouge)}
.hero-title .under{position:relative;display:inline-block}
.hero-title .under::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:4px;background:var(--rouge);opacity:.3;border-radius:2px;animation:underG .6s 3.2s forwards}
@keyframes underG{to{width:100%}}
.hero-sub{font-size:1rem;color:var(--texte-2);max-width:490px;line-height:1.85;margin-bottom:2rem;opacity:0;animation:fadeIn .7s 3.4s forwards}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:3rem;opacity:0;animation:fadeIn .7s 3.6s forwards}
.hero-trust{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--border);opacity:0;animation:fadeIn .7s 3.8s forwards}
.hero-trust-avatars{display:flex}
.hero-trust-avatars span{width:34px;height:34px;border-radius:50%;background:var(--rouge);border:2px solid #fff;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;margin-right:-8px}
.hero-trust strong{display:block;font-weight:700;font-size:13px}
.hero-trust div:last-child{font-size:12px;color:var(--texte-dim)}
.hero-right{position:relative;opacity:0;transform:translateX(40px);animation:fadeInR 1s 2.8s forwards}
@keyframes fadeInR{to{opacity:1;transform:translateX(0)}}
.hero-img{width:100%;border-radius:16px;box-shadow:var(--shadow-lg);aspect-ratio:4/3;object-fit:cover;transition:transform .5s}
.hero-right:hover .hero-img{transform:scale(1.02)}
.hero-card{position:absolute;background:#fff;border-radius:14px;padding:16px 20px;box-shadow:var(--shadow-lg);opacity:0;transform:scale(.8);animation:cardP .6s forwards}
@keyframes cardP{to{opacity:1;transform:scale(1)}}
.hero-card-1{bottom:-20px;left:-24px;animation-delay:3.8s}
.hero-card-2{top:16px;right:-18px;background:var(--rouge);color:#fff;animation-delay:4s;box-shadow:0 8px 28px rgba(181,48,42,.25)}
.hero-card .num{font-family:'EB Garamond',serif;font-weight:800;line-height:1}
.hero-card-1 .num{font-size:1.8rem;color:var(--rouge)}
.hero-card-2 .num{font-size:1.5rem}
.hero-card .lbl{font-size:11px;color:var(--texte-dim);margin-top:3px}
.hero-card-2 .lbl{color:rgba(255,255,255,.75)}
@keyframes fadeIn{to{opacity:1}}

/* Geometric hero */
.hero-geo{position:absolute;pointer-events:none;z-index:1}
.hero-geo svg{opacity:.05}
.hero-geo.spin{animation:geoSpin 60s linear infinite}
@keyframes geoSpin{to{transform:rotate(360deg)}}
.geo-cross{position:absolute;width:24px;height:24px;pointer-events:none;z-index:1}
.geo-cross::before,.geo-cross::after{content:'';position:absolute;background:var(--rouge);opacity:.1}
.geo-cross::before{width:1px;height:100%;left:50%}
.geo-cross::after{height:1px;width:100%;top:50%}
.geo-cross i{position:absolute;width:8px;height:8px;border:1px solid var(--rouge);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.1}
.geo-float{position:absolute;pointer-events:none;z-index:0;opacity:.04}
.geo-float.spin{animation:geoSpin 40s linear infinite}
.geo-float.spin-r{animation:geoSpin 55s linear infinite reverse}
.geo-float.drift{animation:geoDrift 20s ease-in-out infinite}
@keyframes geoDrift{0%,100%{transform:translate(0,0) rotate(0)}50%{transform:translate(10px,-12px) rotate(6deg)}}
.geo-dots{position:absolute;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle,var(--rouge) .5px,transparent .5px);background-size:28px 28px;opacity:.025}
.geo-divider{display:flex;align-items:center;justify-content:center;gap:12px;padding:6px 80px;opacity:.12}
.geo-divider-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--rouge),transparent)}
.geo-divider-d{width:6px;height:6px;background:var(--rouge);transform:rotate(45deg);flex-shrink:0}
.geo-divider-c{width:5px;height:5px;border:1px solid var(--rouge);border-radius:50%;flex-shrink:0}
.geo-measure{position:absolute;display:flex;align-items:center;pointer-events:none;z-index:0;opacity:.06}
.geo-measure span{font-family:'JetBrains Mono',monospace;font-size:7px;color:var(--rouge);letter-spacing:.1em;padding:0 6px;white-space:nowrap}
.geo-measure::before,.geo-measure::after{content:'';flex:1;height:1px;background:var(--rouge)}
.geo-corner{position:absolute;width:14px;height:14px;pointer-events:none;opacity:.06;z-index:1}
.geo-corner.tl{border-top:1px solid var(--rouge);border-left:1px solid var(--rouge)}
.geo-corner.tr{border-top:1px solid var(--rouge);border-right:1px solid var(--rouge)}
.geo-corner.bl{border-bottom:1px solid var(--rouge);border-left:1px solid var(--rouge)}
.geo-corner.br{border-bottom:1px solid var(--rouge);border-right:1px solid var(--rouge)}

/* ═══ STATS ═══ */
#stats{background:var(--rouge);display:grid;grid-template-columns:repeat(4,1fr);position:relative;z-index:1}
.stat{text-align:center;color:#fff;padding:40px 20px;position:relative;transition:background .4s}
.stat:hover{background:rgba(0,0,0,.08)}
.stat:not(:last-child)::after{content:'';position:absolute;right:0;top:20%;bottom:20%;width:1px;background:rgba(255,255,255,.15)}
.stat::before{content:'';position:absolute;top:8px;right:8px;width:16px;height:16px;border-top:1px solid rgba(255,255,255,.1);border-right:1px solid rgba(255,255,255,.1)}
.stat-icon{font-size:22px;margin-bottom:8px;opacity:.7}
.stat-num{font-family:'EB Garamond',serif;font-size:clamp(2.2rem,3.5vw,3.2rem);font-weight:800;line-height:1}
.stat-lbl{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.25em;text-transform:uppercase;opacity:.65;margin-top:8px}

/* ═══ ABOUT ═══ */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:70px;align-items:center}
.about-imgs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.about-imgs img{width:100%;height:220px;object-fit:cover;border-radius:12px;border:1px solid var(--border);transition:transform .5s,box-shadow .5s}
.about-imgs img:nth-child(2){margin-top:20px}
.about-imgs img:nth-child(3){margin-top:-20px}
.about-imgs img:hover{transform:scale(1.04);box-shadow:var(--shadow-md)}
.about-text p{font-size:15px;color:var(--texte-2);line-height:1.85;margin-bottom:1rem}
.pills{display:flex;flex-wrap:wrap;gap:10px;margin:1.5rem 0}
.pill{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:50px;font-size:12px;font-weight:600;border:1px solid var(--border);transition:all .3s;cursor:default}
.pill:hover{border-color:var(--rouge);background:rgba(181,48,42,.04);transform:translateY(-2px)}

/* ═══ SERVICES ═══ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:2rem}
.svc-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:all .5s;display:flex;flex-direction:column;position:relative}
.svc-card:hover{border-color:var(--rouge);transform:translateY(-10px);box-shadow:var(--shadow-lg)}
.svc-card-head{padding:32px 28px 20px;border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.svc-card-head::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--rouge);transform:scaleX(0);transition:transform .5s;transform-origin:left}
.svc-card:hover .svc-card-head::before{transform:scaleX(1)}
.svc-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:16px;transition:transform .5s}
.svc-card:hover .svc-icon{transform:scale(1.1) rotate(-5deg)}
.svc-card h3{font-family:'EB Garamond',serif;font-size:1.2rem;margin-bottom:8px}
.svc-card-head p{font-size:13px;color:var(--texte-dim);line-height:1.7}
.svc-card-body{padding:20px 28px;flex:1}
.svc-card-body li{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px;color:var(--texte-2);border-bottom:1px solid var(--border)}
.svc-card-body li:last-child{border-bottom:none}
.svc-card-body .ck{width:20px;height:20px;min-width:20px;background:rgba(181,48,42,.07);border-radius:5px;display:flex;align-items:center;justify-content:center;color:var(--rouge);font-size:9px}
.svc-card-foot{padding:16px 28px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.svc-tag{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--texte-muted)}
.svc-arr{color:var(--rouge);font-size:13px;transition:transform .3s}
.svc-card:hover .svc-arr{transform:translateX(6px)}
/* Corner marks on cards */
.svc-card::after{content:'';position:absolute;top:8px;right:8px;width:12px;height:12px;border-top:1px solid var(--rouge);border-right:1px solid var(--rouge);opacity:.06;pointer-events:none}

/* ═══ WHY ═══ */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.why-mosaic{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:12px}
.why-mosaic .img1{grid-row:span 2;border-radius:12px;overflow:hidden}
.why-mosaic .img1 img{width:100%;height:400px;object-fit:cover}
.why-mosaic .img2 img,.why-mosaic .img3 img{width:100%;height:194px;object-fit:cover}
.why-mosaic .img2,.why-mosaic .img3{border-radius:12px;overflow:hidden}
.why-mosaic img{transition:transform .5s;border:1px solid var(--border)}
.why-mosaic div:hover img{transform:scale(1.05)}
.why-feats{display:flex;flex-direction:column;gap:18px;margin-top:1.5rem}
.why-feat{display:flex;gap:16px;padding:16px;border-radius:10px;transition:all .4s}
.why-feat:hover{background:var(--surface);transform:translateX(6px)}
.why-feat-ic{width:48px;height:48px;min-width:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .4s}
.why-feat:hover .why-feat-ic{background:var(--rouge)!important;color:#fff!important;transform:rotate(-5deg)}
.why-feat h4{font-family:'EB Garamond',serif;font-size:1rem;margin-bottom:4px}
.why-feat p{font-size:13px;color:var(--texte-dim);line-height:1.7}

/* ═══ IMPACT ═══ */
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:2rem}
.impact-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:32px 20px;text-align:center;transition:all .5s;position:relative;overflow:hidden}
.impact-card:hover{border-color:var(--rouge);transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.impact-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,var(--rouge-glow),transparent 70%);opacity:0;transition:opacity .5s}
.impact-card:hover::after{opacity:.5}
.impact-ic{font-size:2rem;margin-bottom:.6rem;position:relative;z-index:1}
.impact-num{font-family:'EB Garamond',serif;font-size:2.8rem;font-weight:800;line-height:1;margin-bottom:.3rem;position:relative;z-index:1}
.impact-lbl{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--texte-muted);position:relative;z-index:1}

/* ═══ PROCESS ═══ */
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.method-line{position:absolute;top:44px;left:calc(12.5% + 38px);right:calc(12.5% + 38px);height:1px;background:rgba(255,255,255,.1)}
.method-step{text-align:center;padding:0 20px}
.step-circle{width:88px;height:88px;border-radius:50%;background:var(--rouge);margin:0 auto 24px;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative;z-index:1;box-shadow:0 0 30px rgba(181,48,42,.3);transition:transform .5s}
.step-circle::after{content:'';position:absolute;inset:-6px;border:1px dashed rgba(255,255,255,.12);border-radius:50%;animation:geoSpin 20s linear infinite}
.method-step:hover .step-circle{transform:scale(1.12)}
.step-circle .n{font-family:'EB Garamond',serif;font-size:1.7rem;font-weight:800;color:#fff;line-height:1}
.step-circle i{font-size:11px;color:rgba(255,255,255,.5)}
.method-step h4{font-family:'EB Garamond',serif;font-size:1rem;margin-bottom:.4rem}
.method-step p{font-size:12px;color:rgba(255,255,255,.45);line-height:1.7}
.method-tag{display:inline-block;margin-top:10px;padding:4px 14px;border-radius:20px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.55);font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.12em}

/* ═══ EQUIPEMENTS ═══ */
.equip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:2rem}
.equip-card{border-radius:12px;overflow:hidden;position:relative;cursor:pointer;border:1px solid var(--border)}
.equip-card img{width:100%;height:240px;object-fit:cover;transition:transform .5s}
.equip-card:hover img{transform:scale(1.08)}
.equip-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.72),transparent 55%);padding:20px;display:flex;flex-direction:column;justify-content:flex-end;transition:opacity .4s}
.equip-badge{display:inline-flex;align-items:center;gap:5px;background:var(--rouge);color:#fff;padding:4px 12px;border-radius:20px;font-size:10px;font-weight:700;margin-bottom:6px;width:fit-content}
.equip-overlay h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:3px;font-family:'Source Sans 3',sans-serif}
.equip-overlay p{font-size:12px;color:rgba(255,255,255,.7);line-height:1.6}

/* ═══ TEMOIGNAGES ═══ */
.temo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:2rem}
.temo-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:30px;transition:all .5s;position:relative}
.temo-card:hover{border-color:rgba(181,48,42,.2);transform:translateY(-6px);box-shadow:var(--shadow-md)}
.temo-card::before{content:'"';position:absolute;top:14px;right:22px;font-family:'EB Garamond',serif;font-size:4rem;color:var(--rouge);opacity:.07;line-height:1}
.temo-stars{display:flex;gap:3px;margin-bottom:.6rem}
.temo-stars i{color:var(--or);font-size:12px}
.temo-card blockquote{font-family:'EB Garamond',serif;font-size:14px;color:var(--texte-2);line-height:1.8;font-style:italic;margin-bottom:1.3rem}
.temo-author{display:flex;align-items:center;gap:12px}
.temo-avatar{width:40px;height:40px;border-radius:50%;background:var(--rouge);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}
.temo-name{font-family:'EB Garamond',serif;font-size:14px;font-weight:700}
.temo-role{font-size:10px;color:var(--texte-muted);margin-top:2px}

/* ═══ PARTNERS ═══ */
.partners{padding:44px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.partners-label{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:var(--texte-muted);white-space:nowrap}
.partner{display:flex;align-items:center;gap:7px;padding:9px 16px;border:1px solid var(--border);border-radius:6px;font-size:12px;font-weight:600;color:var(--texte-dim);transition:all .3s;background:var(--bg)}
.partner:hover{border-color:var(--rouge);color:var(--rouge);transform:translateY(-2px)}
.partner i{color:var(--rouge);font-size:14px}

/* ═══ CTA ═══ */
#cta{background:var(--rouge);position:relative;overflow:hidden;padding:80px 0}
#cta::before{content:'';position:absolute;top:-50%;right:-20%;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 60%);animation:orbF 15s ease-in-out infinite}
.cta-inner{text-align:center;position:relative;z-index:1}
.cta-inner h2{font-family:'EB Garamond',serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;color:#fff;margin-bottom:.8rem}
.cta-inner p{color:rgba(255,255,255,.6);font-size:1rem;max-width:480px;margin:0 auto 2rem}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ═══ FOOTER ═══ */
footer{background:var(--texte);color:#fff;padding:60px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:40px}
.footer-brand img{height:50px;filter:brightness(0) invert(1);margin-bottom:14px}
.footer-brand p{color:rgba(255,255,255,.35);font-size:13px;line-height:1.8;max-width:250px}
.footer-col h5{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:1.2rem}
.footer-col a{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.5);font-size:13px;margin-bottom:9px;transition:all .3s}
.footer-col a:hover{color:var(--rouge-lite);transform:translateX(4px)}
.footer-col a i{font-size:12px;color:rgba(181,48,42,.5);width:16px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:20px;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-size:11px;color:rgba(255,255,255,.2);font-family:'JetBrains Mono',monospace}
.footer-socials{display:flex;gap:8px}
.footer-socials a{width:36px;height:36px;border-radius:6px;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);font-size:14px;transition:all .3s}
.footer-socials a:hover{background:var(--rouge);border-color:var(--rouge);color:#fff;transform:translateY(-2px)}

/* WA */
#wa-float{position:fixed;bottom:28px;right:28px;z-index:9995;width:54px;height:54px;background:var(--vert);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;box-shadow:0 4px 20px rgba(39,174,96,.3);animation:waF 3s ease-in-out infinite}
#wa-float:hover{animation:none;transform:scale(1.1)}
@keyframes waF{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

/* REVEAL */
.rv{opacity:0;transform:translateY(45px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1)}
.rv.vis{opacity:1;transform:translateY(0)}
.rv-l{opacity:0;transform:translateX(-45px);transition:opacity .8s ease,transform .8s ease}
.rv-l.vis{opacity:1;transform:translateX(0)}
.rv-r{opacity:0;transform:translateX(45px);transition:opacity .8s ease,transform .8s ease}
.rv-r.vis{opacity:1;transform:translateX(0)}
.stg>.rv:nth-child(1){transition-delay:0s}.stg>.rv:nth-child(2){transition-delay:.1s}.stg>.rv:nth-child(3){transition-delay:.2s}
.stg>.rv:nth-child(4){transition-delay:.3s}.stg>.rv:nth-child(5){transition-delay:.35s}.stg>.rv:nth-child(6){transition-delay:.4s}

/* ═══ RÉALISATIONS GALLERY ═══ */
.real-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto;gap:16px;margin-top:2rem}
.real-card{border-radius:12px;overflow:hidden;position:relative;cursor:pointer;border:1px solid var(--border);aspect-ratio:16/10}
.real-card.tall{grid-row:span 2;aspect-ratio:auto}
.real-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.real-card:hover img{transform:scale(1.08)}
.real-card .overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(27,27,27,.8) 0%,rgba(27,27,27,.15) 40%,transparent 70%);display:flex;flex-direction:column;justify-content:flex-end;padding:22px;opacity:0;transition:opacity .5s}
.real-card:hover .overlay{opacity:1}
.real-card .overlay .cat{display:inline-flex;align-items:center;gap:5px;background:var(--rouge);color:#fff;padding:4px 12px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.05em;margin-bottom:8px;width:fit-content}
.real-card .overlay h4{font-family:'EB Garamond',serif;font-size:1rem;color:#fff;font-weight:700;margin-bottom:3px}
.real-card .overlay p{font-size:11px;color:rgba(255,255,255,.65);line-height:1.5}

/* ═══ FAQ ═══ */
.faq-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:50px;align-items:start;margin-top:2rem}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .3s}
.faq-item.open{border-color:var(--rouge)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;cursor:pointer;gap:14px;user-select:none;transition:background .3s}
.faq-q:hover{background:rgba(181,48,42,.02)}
.faq-q span{font-family:'EB Garamond',serif;font-size:15px;font-weight:600;line-height:1.4}
.faq-toggle{width:32px;height:32px;min-width:32px;border-radius:8px;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--texte-dim);transition:all .3s}
.faq-item.open .faq-toggle{background:var(--rouge);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease;padding:0 22px}
.faq-item.open .faq-a{max-height:400px;padding:0 22px 20px}
.faq-a p{font-size:14px;color:var(--texte-2);line-height:1.8}
.faq-sidebar{position:sticky;top:90px}
.faq-cta-card{background:var(--rouge);border-radius:16px;padding:32px;color:#fff;text-align:center;margin-bottom:20px}
.faq-cta-card h3{font-family:'EB Garamond',serif;font-size:1.2rem;margin-bottom:8px}
.faq-cta-card p{font-size:13px;opacity:.75;line-height:1.7;margin-bottom:20px}
.faq-contact-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:24px;box-shadow:var(--shadow-sm);margin-bottom:20px}
.faq-contact-card h4{font-family:'EB Garamond',serif;font-size:1rem;margin-bottom:16px}
.faq-cc-item{display:flex;gap:12px;align-items:center;margin-bottom:12px}
.faq-cc-item:last-child{margin-bottom:0}
.faq-cc-ic{width:36px;height:36px;min-width:36px;border-radius:8px;background:rgba(181,48,42,.06);color:var(--rouge);display:flex;align-items:center;justify-content:center;font-size:15px}
.faq-cc-item p{font-size:13px;font-weight:600;line-height:1.4}
.faq-bottom-bar{margin-top:24px;padding:20px;background:var(--surface);border-radius:12px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.faq-bottom-bar .emoji{font-size:2rem}
.faq-bottom-bar h4{font-family:'EB Garamond',serif;font-size:1rem;margin-bottom:2px}
.faq-bottom-bar p{font-size:13px;color:var(--texte-dim)}

/* RESPONSIVE */
@media(max-width:1024px){.container{padding:0 32px}#hero{padding:110px 40px 70px}}
@media(max-width:768px){
  .nav-links{display:none}.hamburger{display:block}#nav{padding:12px 20px}.container{padding:0 20px}
  #hero{grid-template-columns:1fr;padding:110px 20px 60px;text-align:center}
  .hero-btns{justify-content:center}.hero-right{display:none}.hero-trust{justify-content:center}
  #stats{grid-template-columns:1fr 1fr}.stat:nth-child(2)::after{display:none}
  .about-grid,.why-grid{grid-template-columns:1fr;gap:32px}
  .svc-grid,.equip-grid,.temo-grid{grid-template-columns:1fr}
  .real-grid{grid-template-columns:1fr 1fr}.real-card.tall{grid-row:auto;aspect-ratio:16/10}
  .faq-grid{grid-template-columns:1fr}
  .faq-sidebar{position:static}
  .why-mosaic{display:none}.impact-grid{grid-template-columns:1fr 1fr}
  .method-grid{grid-template-columns:1fr 1fr;gap:28px}.method-line{display:none}
  .partners{padding:28px 20px;gap:8px}
  .footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .cur-ring,.cur-dot,.geo-float,.geo-cross,.geo-dots,.geo-measure,.geo-corner{display:none!important}
  .geo-divider{padding:6px 20px}
}
@media(max-width:480px){#stats{grid-template-columns:1fr}.stat::after{display:none!important}.method-grid{grid-template-columns:1fr}.real-grid{grid-template-columns:1fr}.real-card.tall{grid-row:auto;aspect-ratio:16/10}}
