/* ══════════════════════════════════════
   KEMET CONSULTING — CHARTE FUTURISTE
   Navy #1C4A6E · Or #B8965A
══════════════════════════════════════ */
:root{
  --navy:#1C4A6E;--gold:#B8965A;--gold-bright:#D4A96A;
  --cream:#F7F5F0;--white:#fff;--grey:#6B6B6B;
  --terra:#C1440E;--navy-deep:#0F2E45;
  --dark:#060F18;--dark2:#0a1a28;
  --gold-glow:rgba(184,150,90,.35);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:Arial,sans-serif;background:var(--dark);color:#fff;overflow-x:hidden;}
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--dark);}
::-webkit-scrollbar-thumb{background:var(--gold);}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 52px;background:rgba(6,15,24,.82);backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid rgba(184,150,90,.18);transition:background .3s;}
nav.scrolled{background:rgba(6,15,24,.97);}
.nav-brand{display:flex;align-items:center;gap:14px;cursor:pointer;text-decoration:none;}
.nav-logo-k{width:38px;height:38px;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-size:22px;font-weight:bold;color:#fff;position:relative;overflow:hidden;flex-shrink:0;}
.nav-logo-k::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 35%,rgba(255,255,255,.35) 50%,transparent 65%);transform:translateX(-120%);animation:shimmer 3.5s ease-in-out infinite;}
@keyframes shimmer{0%{transform:translateX(-120%)}100%{transform:translateX(220%)}}
.nav-brand-name{font-family:Georgia,serif;font-size:13px;font-weight:bold;letter-spacing:2.5px;text-transform:uppercase;color:#fff;line-height:1.2;}
.nav-brand-sub{font-size:8px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-top:2px;}
.nav-links{display:flex;gap:26px;align-items:center;}
.nav-link{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.45);cursor:pointer;border:none;background:none;font-family:Arial,sans-serif;padding:4px 0;position:relative;transition:color .25s;text-decoration:none;display:inline-block;}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.22,1,.36,1);}
.nav-link:hover{color:var(--gold);}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1);}
.nav-link.active{color:var(--gold);}
.nav-cta{background:transparent;border:1px solid rgba(184,150,90,.5);color:var(--gold);font-size:9px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;padding:9px 22px;cursor:pointer;font-family:Arial,sans-serif;transition:all .3s;position:relative;overflow:hidden;text-decoration:none;display:inline-block;}
.nav-cta::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateX(-101%);transition:transform .3s cubic-bezier(.22,1,.36,1);}
.nav-cta:hover{color:#fff;border-color:var(--gold);}
.nav-cta:hover::before{transform:translateX(0);}
.nav-cta-inner{position:relative;z-index:1;}

/* ── MARQUEE ── */
.marquee-band{background:var(--gold);overflow:hidden;padding:11px 0;}
.marquee-track{display:flex;white-space:nowrap;animation:mscroll 28s linear infinite;}
@keyframes mscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.m-item{font-family:Georgia,serif;font-style:italic;font-size:16px;color:rgba(255,255,255,.85);padding:0 32px;}
.m-dot{color:rgba(255,255,255,.4);font-style:normal;}

/* ── FILET ── */
.filet{display:flex;flex-direction:column;}
.filet-navy{height:5px;background:var(--navy);}
.filet-or{height:2px;background:var(--gold);}

/* ── MINI HERO ── */
.mini-hero{position:relative;height:420px;overflow:hidden;padding-top:68px;}
.mh-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.28);}
.mh-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,15,24,.92) 0%,rgba(28,74,110,.5) 60%,rgba(184,150,90,.08) 100%);}
.mh-grid{position:absolute;inset:0;opacity:.03;background-image:linear-gradient(rgba(184,150,90,1) 1px,transparent 1px),linear-gradient(90deg,rgba(184,150,90,1) 1px,transparent 1px);background-size:60px 60px;}
.mh-content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:0 80px 52px;}
.bc{display:flex;gap:8px;align-items:center;margin-bottom:14px;}
.bc span{font-size:11px;color:rgba(255,255,255,.3);}
.bc .sep{color:var(--gold);}
.bc .cur{color:rgba(255,255,255,.7);font-weight:bold;}
.mh-eyebrow{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-weight:bold;margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.mh-eyebrow::before{content:'';width:22px;height:1px;background:var(--gold);}
.mh-title{font-family:Georgia,serif;font-size:clamp(28px,4.5vw,56px);font-weight:bold;color:#fff;line-height:1.05;letter-spacing:-1px;margin-bottom:10px;}
.mh-title em{font-style:italic;color:var(--gold);}
.mh-sub{font-size:14px;color:rgba(255,255,255,.4);max-width:520px;line-height:1.75;}

/* ── SECTIONS ── */
section{padding:96px 80px;}
.sec-eyebrow{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-weight:bold;margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.sec-eyebrow::before{content:'';width:22px;height:1px;background:var(--gold);}
h2.sec-title{font-family:Georgia,serif;font-size:clamp(24px,3.2vw,42px);font-weight:bold;line-height:1.1;color:#fff;}
.sec-line{width:52px;height:2px;background:var(--gold);margin:14px 0 52px;box-shadow:0 0 12px rgba(184,150,90,.4);}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.22,1,.36,1),transform .75s cubic-bezier(.22,1,.36,1);}
.reveal.show{opacity:1;transform:none;}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* ── CTA BAND ── */
.cta-band{background:linear-gradient(135deg,var(--navy-deep) 0%,rgba(28,74,110,.7) 100%);padding:80px;display:flex;align-items:center;justify-content:space-between;gap:40px;position:relative;overflow:hidden;border-top:1px solid rgba(184,150,90,.15);border-bottom:1px solid rgba(184,150,90,.15);}
.cta-band::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(184,150,90,.025) 0,rgba(184,150,90,.025) 1px,transparent 0,transparent 50%);background-size:18px 18px;}
.cta-band::after{content:'"';position:absolute;right:40px;top:-30px;font-family:Georgia,serif;font-size:280px;font-weight:bold;color:rgba(255,255,255,.03);line-height:1;pointer-events:none;}
.cta-content{position:relative;z-index:1;}
.cta-title{font-family:Georgia,serif;font-size:clamp(20px,3vw,36px);font-weight:bold;color:#fff;margin-bottom:8px;}
.cta-title em{font-style:italic;color:var(--gold);}
.cta-sub{font-size:14px;color:rgba(255,255,255,.4);}
.cta-btn{position:relative;z-index:1;flex-shrink:0;background:var(--gold);color:#fff;font-size:10px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;padding:16px 36px;border:none;cursor:pointer;font-family:Arial,sans-serif;transition:all .3s;text-decoration:none;display:inline-block;overflow:hidden;}
.cta-btn:hover{transform:translateY(-3px);box-shadow:0 14px 44px rgba(184,150,90,.35);}

/* ── FOOTER ── */
footer{background:var(--navy-deep);border-top:1px solid rgba(184,150,90,.12);}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding:52px 80px 40px;}
.footer-name{font-family:Georgia,serif;font-size:15px;font-weight:bold;color:#fff;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:6px;}
.footer-name span{color:var(--gold);}
.footer-tagline{font-family:Georgia,serif;font-style:italic;font-size:12px;color:rgba(255,255,255,.25);margin-bottom:14px;}
.footer-desc{font-size:12px;line-height:1.7;color:rgba(255,255,255,.25);}
.footer-col-title{font-size:9px;font-weight:bold;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.footer-links{display:flex;flex-direction:column;gap:10px;}
.footer-link{font-size:12px;color:rgba(255,255,255,.28);cursor:pointer;transition:color .2s;text-decoration:none;display:block;}
.footer-link:hover{color:var(--gold);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:22px 80px;border-top:1px solid rgba(184,150,90,.1);}
.footer-copy{font-size:11px;color:rgba(255,255,255,.18);}
.footer-slogan{font-family:Georgia,serif;font-style:italic;font-size:11px;color:rgba(255,255,255,.18);}

/* ── BUTTONS ── */
.btn-primary{background:var(--gold);color:#fff;font-size:10px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;padding:15px 34px;border:none;cursor:pointer;font-family:Arial,sans-serif;transition:all .35s;position:relative;overflow:hidden;display:inline-block;text-decoration:none;}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 35%,rgba(255,255,255,.22) 50%,transparent 65%);transform:translateX(-120%);transition:transform .5s;}
.btn-primary:hover::after{transform:translateX(220%);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 48px rgba(184,150,90,.45);}
.btn-outline{background:transparent;color:#fff;font-size:10px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;padding:14px 30px;border:1px solid rgba(255,255,255,.2);cursor:pointer;font-family:Arial,sans-serif;transition:all .3s;text-decoration:none;display:inline-block;}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);}
.btn-gold-outline{background:transparent;color:var(--gold);font-size:10px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;padding:12px 28px;border:1px solid rgba(184,150,90,.4);cursor:pointer;font-family:Arial,sans-serif;transition:all .3s;text-decoration:none;display:inline-block;}
.btn-gold-outline:hover{background:var(--gold);color:#fff;}

/* ── CARDS (shared) ── */
.card-dark{background:rgba(255,255,255,.025);border:1px solid rgba(184,150,90,.1);transition:all .4s;}
.card-dark:hover{border-color:rgba(184,150,90,.35);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 50px rgba(184,150,90,.07);}

/* ── TAG ── */
.tag{background:rgba(184,150,90,.08);border:1px solid rgba(184,150,90,.18);color:var(--gold);font-size:9px;font-weight:bold;letter-spacing:1px;text-transform:uppercase;padding:3px 9px;display:inline-block;}

/* ── GOLD BOX (kemet etymology) ── */
.kemet-box{background:rgba(28,74,110,.2);border:1px solid rgba(184,150,90,.18);padding:26px 30px;position:relative;overflow:hidden;}
.kemet-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent);}
.kemet-box::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(184,150,90,.025) 0,rgba(184,150,90,.025) 1px,transparent 0,transparent 50%);background-size:16px 16px;}
.kb-inner{position:relative;z-index:1;}
.kb-label{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(184,150,90,.55);margin-bottom:8px;}
.kb-word{font-family:Georgia,serif;font-size:26px;font-weight:bold;color:#fff;letter-spacing:5px;margin-bottom:4px;}
.kb-trans{font-family:Georgia,serif;font-style:italic;font-size:14px;color:var(--gold);margin-bottom:10px;}
.kb-desc{font-size:12px;line-height:1.75;color:rgba(255,255,255,.38);}

/* ── SCAN LINE ── */
.scan-line{position:fixed;top:0;left:0;right:0;z-index:9999;height:2px;background:linear-gradient(90deg,transparent,rgba(184,150,90,.55),transparent);animation:scan 9s linear infinite;pointer-events:none;opacity:.35;}
@keyframes scan{0%{top:-2px}100%{top:100vh}}

/* ── SCROLL TOP BTN ── */
.scroll-top{position:fixed;bottom:28px;right:28px;z-index:999;width:44px;height:44px;cursor:pointer;opacity:0;transition:opacity .3s;}
.scroll-top.visible{opacity:1;}
.scroll-top-ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--gold);animation:pulse-ring 2s ease-out infinite;}
.scroll-top-ring:nth-child(2){animation-delay:.65s;opacity:.5;}
.scroll-top-dot{position:absolute;inset:11px;border-radius:50%;background:var(--gold);box-shadow:0 0 14px rgba(184,150,90,.7);}
@keyframes pulse-ring{0%{transform:scale(.85);opacity:.8}100%{transform:scale(1.85);opacity:0}}

/* ── FORM ── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px;}
.form-row.full{grid-template-columns:1fr;}
.form-grp{display:flex;flex-direction:column;gap:6px;}
.form-lbl{font-size:9px;font-weight:bold;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.4);}
.form-inp{background:rgba(255,255,255,.04);border:1px solid rgba(184,150,90,.15);color:#fff;padding:12px 14px;font-family:Arial,sans-serif;font-size:13px;outline:none;width:100%;transition:all .25s;}
.form-inp:focus{border-color:var(--gold);background:rgba(184,150,90,.07);box-shadow:0 0 18px rgba(184,150,90,.1);}
.form-inp::placeholder{color:rgba(255,255,255,.18);}
textarea.form-inp{resize:vertical;min-height:100px;line-height:1.65;}
select.form-inp option{background:var(--dark);}

/* ── STAT BAND ── */
.stats-band{background:var(--gold);padding:52px 80px;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.stat-item{text-align:center;padding:0 20px;border-right:1px solid rgba(6,15,24,.18);}
.stat-item:last-child{border-right:none;}
.stat-number{font-family:Georgia,serif;font-size:52px;font-weight:bold;color:var(--dark);line-height:1;}
.stat-label{font-size:9px;font-weight:bold;letter-spacing:2.5px;text-transform:uppercase;color:rgba(6,15,24,.5);margin-top:8px;}

/* ══ INDEX — HERO ══ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:#060F18;}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(.35) saturate(.7);}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden;}
.hbg-orb{position:absolute;border-radius:50%;filter:blur(80px);animation:orbFloat 12s ease-in-out infinite;}
.hbg-orb-1{width:700px;height:700px;background:radial-gradient(circle,rgba(28,74,110,.55) 0%,transparent 70%);top:-200px;left:-180px;animation-delay:0s;}
.hbg-orb-2{width:500px;height:500px;background:radial-gradient(circle,rgba(184,150,90,.14) 0%,transparent 70%);bottom:-150px;right:-100px;animation-delay:4s;}
.hbg-orb-3{width:350px;height:350px;background:radial-gradient(circle,rgba(28,74,110,.3) 0%,transparent 70%);top:40%;right:25%;animation-delay:7s;}
.hbg-orb-4{width:200px;height:200px;background:radial-gradient(circle,rgba(184,150,90,.1) 0%,transparent 70%);top:20%;right:45%;animation-delay:2s;}
@keyframes orbFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.07)}}
.hbg-beam{position:absolute;height:1px;width:130%;left:-15%;background:linear-gradient(90deg,transparent 0%,rgba(184,150,90,.18) 40%,rgba(184,150,90,.25) 50%,rgba(184,150,90,.18) 60%,transparent 100%);animation:beamSweep 10s ease-in-out infinite;}
.hbg-beam:nth-child(1){top:18%;transform:rotate(-8deg);animation-delay:0s;}
.hbg-beam:nth-child(2){top:45%;transform:rotate(-5deg);animation-delay:3.5s;}
.hbg-beam:nth-child(3){top:72%;transform:rotate(-10deg);animation-delay:7s;}
@keyframes beamSweep{0%,100%{opacity:0;transform:rotate(-8deg) translateX(-20%)}30%,70%{opacity:1}50%{transform:rotate(-8deg) translateX(5%)}}
.hbg-beam:nth-child(2){animation:beamSweep2 12s ease-in-out infinite 3.5s;}
@keyframes beamSweep2{0%,100%{opacity:0;transform:rotate(-5deg) translateX(-20%)}30%,70%{opacity:1}50%{transform:rotate(-5deg) translateX(5%)}}
.hbg-beam:nth-child(3){animation:beamSweep3 9s ease-in-out infinite 7s;}
@keyframes beamSweep3{0%,100%{opacity:0;transform:rotate(-10deg) translateX(-20%)}30%,70%{opacity:1}50%{transform:rotate(-10deg) translateX(5%)}}
.hbg-grid{position:absolute;inset:0;opacity:.028;background-image:linear-gradient(rgba(184,150,90,1) 1px,transparent 1px),linear-gradient(90deg,rgba(184,150,90,1) 1px,transparent 1px);background-size:70px 70px;}
.hbg-flare{position:absolute;width:600px;height:600px;top:50%;left:20%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(28,74,110,.25) 0%,transparent 65%);animation:flarePulse 6s ease-in-out infinite;}
@keyframes flarePulse{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}}
.scroll-hint{position:absolute;bottom:132px;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:opacity .3s;opacity:0;animation:fadeUp .8s ease forwards 1.4s;}
.scroll-hint:hover{opacity:.9 !important;}
.scroll-hint-label{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.45);}
.scroll-mouse{width:22px;height:34px;border:1.5px solid rgba(184,150,90,.5);border-radius:11px;display:flex;justify-content:center;padding-top:5px;}
.scroll-wheel{width:3px;height:7px;background:var(--gold);border-radius:2px;animation:scrollAnim 1.8s ease-in-out infinite;}
@keyframes scrollAnim{0%{transform:translateY(0);opacity:1}80%{transform:translateY(10px);opacity:0}100%{transform:translateY(0);opacity:0}}
#hero-canvas{position:absolute;inset:0;z-index:1;mix-blend-mode:screen;opacity:.6;}
.hero-grid{position:absolute;inset:0;z-index:1;opacity:.022;background-image:linear-gradient(rgba(184,150,90,1) 1px,transparent 1px),linear-gradient(90deg,rgba(184,150,90,1) 1px,transparent 1px);background-size:70px 70px;}
.hero-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(110deg,rgba(6,15,24,.82) 0%,rgba(28,74,110,.4) 55%,rgba(6,15,24,.45) 100%);}
.hero-vignette{position:absolute;inset:0;z-index:2;background:linear-gradient(to right,rgba(6,15,24,.8) 0%,transparent 60%);}
.hero-content{position:relative;z-index:3;padding:0 80px;padding-top:68px;max-width:860px;transition:transform .55s cubic-bezier(.22,1,.36,1);will-change:transform;}
.hero-eyebrow{font-size:9px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);font-weight:bold;margin-bottom:26px;display:flex;align-items:center;gap:14px;opacity:0;animation:fadeUp .8s ease forwards .4s;}
.hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--gold);}
.hero-eyebrow::after{content:'';flex:0 0 6px;height:6px;background:var(--gold);transform:rotate(45deg);}
.hero-title{font-family:Georgia,serif;font-size:clamp(40px,6vw,84px);font-weight:bold;line-height:1.03;letter-spacing:-2px;color:#fff;margin-bottom:28px;opacity:0;animation:fadeUp .8s ease forwards .6s;}
.hero-title em{font-style:italic;color:transparent;-webkit-text-stroke:1.5px var(--gold);filter:drop-shadow(0 0 20px rgba(184,150,90,.5));}
.glitch{position:relative;display:inline-block;}
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;}
.glitch::before{color:var(--gold);animation:glitch1 6s infinite;clip-path:polygon(0 15%,100% 15%,100% 35%,0 35%);opacity:.7;}
.glitch::after{color:rgba(28,74,110,.9);animation:glitch2 6s infinite;clip-path:polygon(0 65%,100% 65%,100% 80%,0 80%);opacity:.7;}
@keyframes glitch1{0%,88%,100%{transform:translate(0)}89%{transform:translate(-4px,1px)}91%{transform:translate(4px,-1px)}93%{transform:translate(-2px,2px)}95%{transform:translate(0)}}
@keyframes glitch2{0%,88%,100%{transform:translate(0)}89%{transform:translate(4px,1px)}91%{transform:translate(-4px,-1px)}93%{transform:translate(2px,-2px)}95%{transform:translate(0)}}
.hero-desc{font-size:15px;line-height:1.85;color:rgba(255,255,255,.5);max-width:500px;margin-bottom:44px;opacity:0;animation:fadeUp .8s ease forwards .8s;}
.hero-btns{display:flex;gap:16px;opacity:0;animation:fadeUp .8s ease forwards 1s;}
.hero-bottom{position:absolute;bottom:0;left:0;right:0;z-index:3;display:grid;grid-template-columns:repeat(4,1fr);background:linear-gradient(to bottom,transparent 0%,rgba(6,15,24,.88) 100%);backdrop-filter:blur(24px) saturate(1.2);-webkit-backdrop-filter:blur(24px) saturate(1.2);}
.hero-bottom::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(184,150,90,.6) 20%,rgba(184,150,90,.9) 50%,rgba(184,150,90,.6) 80%,transparent 100%);box-shadow:0 0 12px rgba(184,150,90,.3);}
.hs{padding:26px 44px;border-right:1px solid rgba(184,150,90,.12);background:none;display:flex;align-items:center;gap:18px;transition:background .35s;position:relative;}
.hs::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.22,1,.36,1);box-shadow:0 0 8px rgba(184,150,90,.5);}
.hs:hover{background:rgba(184,150,90,.06);}
.hs:hover::after{transform:scaleX(1);}
.hs:last-child{border-right:none;}
.hs-num{font-family:Georgia,serif;font-size:32px;font-weight:bold;color:var(--gold);line-height:1;letter-spacing:-1px;filter:drop-shadow(0 0 14px rgba(184,150,90,.5));}
.hs-sep{width:1px;height:34px;background:linear-gradient(to bottom,transparent,rgba(184,150,90,.35),transparent);flex-shrink:0;}
.hs-label{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.35);line-height:1.55;font-weight:600;}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.axes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.axe-card{position:relative;background:rgba(255,255,255,.025);border:1px solid rgba(184,150,90,.1);padding:40px 32px 36px;cursor:pointer;overflow:hidden;transition:all .4s;transform-style:preserve-3d;}
.axe-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(184,150,90,.06),transparent 60%);opacity:0;transition:opacity .4s;}
.axe-card:hover{border-color:rgba(184,150,90,.35);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 50px rgba(184,150,90,.07);transform:translateY(-6px);}
.axe-card:hover::before{opacity:1;}
.axe-num{font-family:Georgia,serif;font-size:52px;font-weight:bold;color:rgba(184,150,90,.08);line-height:1;margin-bottom:18px;}
.axe-icon{width:48px;height:48px;border:1px solid rgba(184,150,90,.3);display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:20px;color:var(--gold);transition:all .3s;}
.axe-card:hover .axe-icon{background:rgba(184,150,90,.1);border-color:var(--gold);}
.axe-title{font-family:Georgia,serif;font-size:19px;font-weight:bold;color:#fff;margin-bottom:10px;line-height:1.3;}
.axe-desc{font-size:12px;line-height:1.88;color:rgba(255,255,255,.38);margin-bottom:22px;}
.axe-line{width:32px;height:1px;background:var(--gold);transition:width .4s;margin-bottom:18px;}
.axe-card:hover .axe-line{width:70px;}
.axe-link{font-size:9px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:var(--gold);text-decoration:none;display:flex;align-items:center;gap:8px;transition:gap .3s;}
.axe-card:hover .axe-link{gap:14px;}
.dakar-band{position:relative;height:360px;overflow:hidden;}
.dakar-band img{width:100%;height:100%;object-fit:cover;filter:brightness(.3);}
.dakar-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(6,15,24,.92) 0%,rgba(28,74,110,.45) 60%,transparent 100%);}
.dakar-content{position:absolute;inset:0;display:flex;align-items:center;padding:0 80px;}
.dakar-title{font-family:Georgia,serif;font-size:clamp(24px,3.5vw,44px);font-weight:bold;color:#fff;line-height:1.1;letter-spacing:-1px;margin-bottom:14px;}
.dakar-title em{font-style:italic;color:var(--gold);}
#door-overlay{position:fixed;inset:0;z-index:99999;display:none;pointer-events:none;}
#door-overlay.active{display:block;pointer-events:all;}
#door-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.door-panel{position:absolute;top:0;bottom:0;width:50%;background:linear-gradient(160deg,#060F18 0%,#0a1a28 60%,#0d2238 100%);z-index:2;transition:transform 1.3s cubic-bezier(.77,0,.175,1);overflow:hidden;}
.door-left{left:0;border-right:1px solid rgba(184,150,90,.4);}
.door-right{right:0;border-left:1px solid rgba(184,150,90,.4);}
.door-left::before,.door-right::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(184,150,90,.04) 50%,transparent);animation:doorShimmer 2.5s ease-in-out infinite;}
@keyframes doorShimmer{0%,100%{opacity:.3}50%{opacity:1}}
.door-left::after{content:'';position:absolute;top:0;right:0;bottom:0;width:80px;background:linear-gradient(to right,transparent,rgba(184,150,90,.12));}
.door-right::after{content:'';position:absolute;top:0;left:0;bottom:0;width:80px;background:linear-gradient(to left,transparent,rgba(184,150,90,.12));}
.door-deco{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;}
.door-logo-k{width:64px;height:64px;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-size:36px;font-weight:bold;color:#fff;box-shadow:0 0 40px rgba(184,150,90,.6);animation:doorPulse 1.5s ease-in-out infinite;}
@keyframes doorPulse{0%,100%{box-shadow:0 0 40px rgba(184,150,90,.6)}50%{box-shadow:0 0 60px rgba(184,150,90,.9),0 0 100px rgba(184,150,90,.3)}}
.door-brand{font-family:Georgia,serif;font-size:14px;font-weight:bold;letter-spacing:3px;text-transform:uppercase;color:#fff;}
.door-brand span{color:var(--gold);}
.door-tagline{font-size:8px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(184,150,90,.6);}
.door-shine{position:absolute;top:0;bottom:0;left:30%;width:40px;background:linear-gradient(to right,transparent,rgba(255,255,255,.04),transparent);animation:doorShineMove 2s ease-in-out infinite;}
@keyframes doorShineMove{0%,100%{opacity:0;transform:skewX(-15deg) translateX(0)}50%{opacity:1;transform:skewX(-15deg) translateX(30px)}}
.door-panel::before{content:'';position:absolute;top:20%;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(184,150,90,.2),transparent);box-shadow:0 200px 0 rgba(184,150,90,.1),0 400px 0 rgba(184,150,90,.08);}
.door-edge{position:absolute;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,transparent,var(--gold) 30%,var(--gold) 70%,transparent);opacity:.7;}
.door-edge-right{right:0;}
.door-edge-left{left:0;}
#door-overlay.door-open .door-left{transform:translateX(-100%);}
#door-overlay.door-open .door-right{transform:translateX(100%);}
#door-overlay.door-fade{animation:overlayFadeOut .5s ease forwards;}
@keyframes overlayFadeOut{to{opacity:0;}}

/* ══ CABINET ══ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.about-img-frame{position:relative;overflow:hidden;aspect-ratio:3/4;}
.about-img-frame img{width:100%;height:100%;object-fit:cover;filter:brightness(.65) saturate(.75);}
.about-img-frame::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,15,24,.9) 0%,transparent 55%);z-index:1;pointer-events:none;}
.corner{position:absolute;z-index:2;width:52px;height:52px;pointer-events:none;}
.corner.tl{top:0;left:0;border-top:2px solid var(--gold);border-left:2px solid var(--gold);}
.corner.br{bottom:0;right:0;border-bottom:2px solid var(--gold);border-right:2px solid var(--gold);}
.about-badge{position:absolute;bottom:24px;left:24px;z-index:3;background:var(--gold);padding:18px 24px;}
.about-badge-num{font-family:Georgia,serif;font-size:32px;font-weight:bold;color:var(--dark);line-height:1;}
.about-badge-label{font-size:9px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:rgba(6,15,24,.6);margin-top:4px;}
.about-text p{font-size:14px;line-height:1.88;color:rgba(255,255,255,.45);margin-bottom:16px;}
.about-text p strong{color:#fff;}
.timeline{margin-top:32px;display:flex;flex-direction:column;gap:0;}
.tl-row{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid rgba(184,150,90,.1);}
.tl-row:last-child{border-bottom:none;}
.tl-yr{font-family:Georgia,serif;font-size:13px;font-weight:bold;color:var(--gold);width:44px;flex-shrink:0;margin-top:2px;}
.tl-event{font-size:12px;font-weight:bold;color:#fff;margin-bottom:2px;}
.tl-detail{font-size:11px;color:rgba(255,255,255,.38);line-height:1.6;}
.mvv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.mvv-card{background:rgba(255,255,255,.03);border:1px solid rgba(184,150,90,.12);padding:32px 26px;transition:all .3s;}
.mvv-card:hover{background:rgba(184,150,90,.06);border-color:rgba(184,150,90,.3);}
.mvv-num{font-size:8px;font-weight:bold;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.mvv-num::after{content:'';flex:1;height:1px;background:rgba(184,150,90,.2);}
.mvv-title{font-family:Georgia,serif;font-size:16px;font-weight:bold;color:#fff;margin-bottom:10px;}
.mvv-text{font-size:12px;line-height:1.8;color:rgba(255,255,255,.42);}
.valeurs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.val-card{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.08);padding:28px 22px;transition:all .3s;position:relative;overflow:hidden;}
.val-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--gold);transition:height .4s;}
.val-card:hover::before{height:100%;}
.val-card:hover{background:rgba(184,150,90,.05);}
.val-icon{margin-bottom:14px;}
.val-title{font-family:Georgia,serif;font-size:15px;font-weight:bold;color:#fff;margin-bottom:8px;}
.val-text{font-size:11px;line-height:1.7;color:rgba(255,255,255,.38);}
.dirigeant{display:grid;grid-template-columns:320px 1fr;gap:2px;margin-bottom:2px;}
.dir-img{position:relative;overflow:hidden;}
.dir-img img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:brightness(.7) grayscale(.1);transition:all .5s;}
.dirigeant:hover .dir-img img{filter:brightness(.82) grayscale(0);}
.dir-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,15,24,.95) 0%,rgba(28,74,110,.35) 50%,transparent 100%);}
.dir-info{position:absolute;bottom:0;left:0;right:0;padding:24px;}
.dir-name{border-left:3px solid var(--gold);padding-left:12px;margin-bottom:6px;}
.dir-name h3{font-family:Georgia,serif;font-size:19px;font-weight:bold;color:#fff;margin-bottom:2px;}
.dir-name span{font-size:9px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:var(--gold);}
.dir-content{background:rgba(255,255,255,.025);border:1px solid rgba(184,150,90,.1);padding:36px 40px;}
.dir-badge{display:inline-block;background:rgba(28,74,110,.5);border:1px solid rgba(184,150,90,.2);color:var(--gold);font-size:9px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;margin-bottom:18px;}
.dir-bio{font-size:13px;line-height:1.88;color:rgba(255,255,255,.45);margin-bottom:22px;}
.dir-bio strong{color:#fff;}
.dir-skills{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px;}
.dir-skill{background:rgba(28,74,110,.2);border-left:3px solid var(--gold);padding:10px 14px;}
.dir-skill-title{font-size:11px;font-weight:bold;color:#fff;margin-bottom:2px;}
.dir-skill-sub{font-size:10px;color:rgba(255,255,255,.38);}
.dir-quote{background:rgba(28,74,110,.3);border-left:3px solid var(--gold);padding:16px 20px;}
.dir-quote p{font-family:Georgia,serif;font-style:italic;font-size:13px;color:rgba(255,255,255,.65);line-height:1.7;}

/* ══ SERVICES ══ */
.svc-block{display:grid;grid-template-columns:280px 1fr;gap:0;margin-bottom:2px;background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.08);transition:border-color .3s;}
.svc-block:hover{border-color:rgba(184,150,90,.25);}
.svc-block.rev{grid-template-columns:1fr 280px;}
.svc-label{background:rgba(28,74,110,.4);padding:32px 28px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;}
.svc-label-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.1;transition:opacity .4s;}
.svc-block:hover .svc-label-img{opacity:.2;}
.svc-label-inner{position:relative;z-index:1;}
.svc-num{font-family:Georgia,serif;font-size:54px;font-weight:bold;color:rgba(184,150,90,.1);line-height:1;}
.svc-name{font-family:Georgia,serif;font-size:17px;font-weight:bold;color:#fff;line-height:1.3;margin-bottom:8px;}
.svc-tag-label{font-size:8px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:var(--gold);}
.svc-content{padding:32px 36px;}
.svc-intro{font-size:13px;line-height:1.9;color:rgba(255,255,255,.45);margin-bottom:22px;border-left:3px solid var(--gold);padding-left:16px;}
.svc-intro strong{color:#fff;}
.prest-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px;}
.prest{background:rgba(255,255,255,.03);padding:11px 14px;display:flex;gap:9px;border:1px solid rgba(184,150,90,.07);transition:border-color .3s;}
.prest:hover{border-color:rgba(184,150,90,.25);}
.prest-dot{width:5px;height:5px;background:var(--gold);flex-shrink:0;margin-top:5px;}
.prest-title{font-size:11px;font-weight:bold;color:#fff;display:block;margin-bottom:2px;}
.prest-sub{font-size:10px;color:rgba(255,255,255,.35);}
.svc-footer{display:flex;justify-content:flex-end;padding-top:14px;border-top:1px solid rgba(184,150,90,.1);}
.outils-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.outil-card{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.1);padding:26px 22px;transition:all .3s;}
.outil-card:hover{background:rgba(184,150,90,.08);border-color:rgba(184,150,90,.3);}
.outil-name{font-family:Georgia,serif;font-size:22px;font-weight:bold;color:var(--gold);margin-bottom:6px;}
.outil-label{font-size:9px;font-weight:bold;letter-spacing:1.5px;text-transform:uppercase;color:#fff;margin-bottom:8px;}
.outil-desc{font-size:11px;line-height:1.7;color:rgba(255,255,255,.38);}
.methodo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;}
.m-card{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.07);padding:28px 20px;position:relative;transition:all .3s;}
.m-card:hover{background:rgba(184,150,90,.05);border-color:rgba(184,150,90,.25);}
.m-card::after{content:'›';position:absolute;right:-12px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:22px;z-index:2;opacity:.5;}
.m-card:last-child::after{display:none;}
.m-num{font-family:Georgia,serif;font-size:40px;font-weight:bold;color:rgba(184,150,90,.07);line-height:1;margin-bottom:10px;}
.m-title{font-family:Georgia,serif;font-size:13px;font-weight:bold;color:#fff;margin-bottom:6px;}
.m-desc{font-size:11px;line-height:1.65;color:rgba(255,255,255,.38);}

/* ══ FORMATIONS ══ */
.catalogue-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.f-card{background:rgba(255,255,255,.025);border:1px solid rgba(184,150,90,.08);overflow:hidden;cursor:pointer;transition:all .4s;position:relative;}
.f-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 40px rgba(184,150,90,.07);border-color:rgba(184,150,90,.3);}
.f-card-img{height:185px;overflow:hidden;}
.f-card-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.65) saturate(.7);transition:all .5s;}
.f-card:hover .f-card-img img{transform:scale(1.05);filter:brightness(.82) saturate(.9);}
.f-accent{height:2px;background:var(--navy);}
.f-card:nth-child(2) .f-accent,.f-card:nth-child(5) .f-accent{background:var(--gold);}
.f-body{padding:24px 22px 28px;}
.f-cat{font-size:9px;font-weight:bold;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.f-title{font-family:Georgia,serif;font-size:16px;font-weight:bold;color:#fff;line-height:1.3;margin-bottom:8px;}
.f-desc{font-size:11px;line-height:1.72;color:rgba(255,255,255,.38);margin-bottom:16px;}
.f-meta{display:flex;gap:16px;padding-top:14px;border-top:1px solid rgba(184,150,90,.1);margin-bottom:14px;}
.f-mi-label{font-size:8px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:rgba(184,150,90,.6);margin-bottom:2px;}
.f-mi-val{font-size:11px;font-weight:bold;color:#fff;}
.f-tags{display:flex;flex-wrap:wrap;gap:5px;}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.proc-card{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.08);padding:28px 22px;text-align:center;transition:all .3s;position:relative;}
.proc-card:hover{background:rgba(184,150,90,.06);border-color:rgba(184,150,90,.25);}
.proc-card::after{content:'→';position:absolute;right:-16px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:18px;opacity:.5;z-index:2;}
.proc-card:last-child::after{display:none;}
.proc-step{font-family:Georgia,serif;font-size:36px;font-weight:bold;color:rgba(184,150,90,.12);line-height:1;margin-bottom:12px;}
.proc-title{font-family:Georgia,serif;font-size:14px;font-weight:bold;color:#fff;margin-bottom:8px;}
.proc-desc{font-size:11px;line-height:1.65;color:rgba(255,255,255,.38);}
.formats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.format-card{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.1);padding:32px 26px;transition:all .3s;}
.format-card:hover{border-color:rgba(184,150,90,.3);background:rgba(184,150,90,.05);}
.format-icon{margin-bottom:14px;color:var(--gold);}
.format-title{font-family:Georgia,serif;font-size:16px;font-weight:bold;color:#fff;margin-bottom:10px;}
.format-desc{font-size:12px;line-height:1.75;color:rgba(255,255,255,.4);}
.format-list{margin-top:12px;display:flex;flex-direction:column;gap:6px;}
.format-item{font-size:11px;color:rgba(255,255,255,.35);display:flex;gap:8px;}
.format-item::before{content:'—';color:var(--gold);flex-shrink:0;}

/* ══ ÉQUIPE ══ */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.t-card{position:relative;overflow:hidden;cursor:pointer;transition:transform .3s;}
.t-card:hover{transform:translateY(-6px);}
.t-card-img{height:280px;overflow:hidden;}
.t-card-img img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(.4) brightness(.65);transition:all .5s;}
.t-card:hover .t-card-img img{filter:grayscale(0) brightness(.82);transform:scale(1.04);}
.t-card-info{background:rgba(6,15,24,.92);padding:24px 20px;border-top:2px solid var(--gold);transition:background .3s;min-height:138px;}
.t-card:hover .t-card-info{background:rgba(28,74,110,.95);}
.t-name{font-family:Georgia,serif;font-size:14px;font-weight:bold;color:#fff;margin-bottom:3px;}
.t-role{font-size:9px;font-weight:bold;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;}
.t-tags{display:flex;flex-wrap:wrap;gap:4px;}
.t-tag{background:rgba(184,150,90,.08);border:1px solid rgba(184,150,90,.1);color:rgba(255,255,255,.4);font-size:9px;padding:2px 8px;}
.eq-vals{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.eq-val{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.08);padding:28px 24px;transition:all .3s;}
.eq-val:hover{border-color:rgba(184,150,90,.25);background:rgba(184,150,90,.04);}
.eq-val-num{font-family:Georgia,serif;font-size:32px;font-weight:bold;color:rgba(184,150,90,.1);line-height:1;margin-bottom:10px;}
.eq-val-title{font-family:Georgia,serif;font-size:15px;font-weight:bold;color:#fff;margin-bottom:8px;}
.eq-val-text{font-size:12px;line-height:1.75;color:rgba(255,255,255,.38);}
.rejoindre-grid{display:grid;grid-template-columns:1fr 360px;gap:2px;}
.rej-content{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.1);padding:48px;}
.rej-content p{font-size:14px;line-height:1.85;color:rgba(255,255,255,.45);margin-bottom:16px;}
.rej-content p strong{color:#fff;}
.rej-avantages{display:flex;flex-direction:column;gap:10px;margin-top:24px;}
.rej-av{display:flex;gap:12px;align-items:flex-start;}
.rej-av-dot{width:5px;height:5px;background:var(--gold);flex-shrink:0;margin-top:6px;}
.rej-av-text{font-size:12px;line-height:1.6;color:rgba(255,255,255,.45);}
.rej-av-text strong{color:#fff;}
.rej-sidebar{background:rgba(28,74,110,.3);border:1px solid rgba(184,150,90,.15);padding:36px 28px;position:relative;overflow:hidden;}
.rej-sidebar::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent);}
.dir-name-row{border-left:3px solid var(--gold);padding-left:14px;margin-bottom:6px;}
.dir-role{font-size:9px;font-weight:bold;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);}
.dir-skill-t{font-size:11px;font-weight:bold;color:#fff;margin-bottom:2px;}
.dir-skill-s{font-size:10px;color:rgba(255,255,255,.35);}

/* ══ ÉTUDES ══ */
.etudes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.etude-card{position:relative;overflow:hidden;cursor:pointer;height:420px;}
.etude-card:hover .ep-img{transform:scale(1.05);filter:brightness(.45);}
.ep-img{width:100%;height:100%;object-fit:cover;filter:brightness(.32);transition:all .5s;display:block;position:absolute;inset:0;}
.ep-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,15,24,.97) 0%,transparent 55%);}
.ep-content{position:absolute;bottom:0;left:0;right:0;padding:28px 26px;}
.ep-num{font-family:Georgia,serif;font-size:60px;font-weight:bold;color:rgba(184,150,90,.12);line-height:1;display:block;margin-bottom:-6px;}
.ep-title{font-family:Georgia,serif;font-size:19px;font-weight:bold;color:#fff;line-height:1.15;margin-bottom:6px;}
.ep-tag{font-size:8px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:block;}
.ep-items{margin-bottom:16px;}
.ep-item{font-size:12px;color:rgba(255,255,255,.45);display:flex;gap:6px;margin-bottom:4px;}
.ep-item::before{content:'—';color:var(--gold);flex-shrink:0;}
.ep-cta{font-size:9px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:var(--gold);text-decoration:none;display:flex;align-items:center;gap:8px;border:none;background:none;cursor:pointer;font-family:Arial,sans-serif;}
.ep-cta:hover{color:#fff;}
.domaines-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.dom-card{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.08);padding:28px 22px;transition:all .3s;}
.dom-card:hover{background:rgba(184,150,90,.06);border-color:rgba(184,150,90,.25);}
.dom-icon{display:flex;align-items:center;margin-bottom:14px;color:var(--gold);}
.dom-title{font-family:Georgia,serif;font-size:14px;font-weight:bold;color:#fff;margin-bottom:8px;}
.dom-list{display:flex;flex-direction:column;gap:5px;}
.dom-item{font-size:11px;color:rgba(255,255,255,.38);display:flex;gap:6px;}
.dom-item::before{content:'·';color:var(--gold);}
.etude-process{display:grid;grid-template-columns:repeat(6,1fr);gap:2px;}
.ep-step{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.07);padding:24px 18px;text-align:center;position:relative;transition:all .3s;}
.ep-step:hover{background:rgba(184,150,90,.05);border-color:rgba(184,150,90,.2);}
.ep-step::after{content:'›';position:absolute;right:-13px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:20px;opacity:.4;}
.ep-step:last-child::after{display:none;}
.ep-step-num{font-family:Georgia,serif;font-size:32px;font-weight:bold;color:rgba(184,150,90,.08);line-height:1;margin-bottom:8px;}
.ep-step-title{font-size:11px;font-weight:bold;color:#fff;margin-bottom:4px;letter-spacing:.5px;}
.ep-step-sub{font-size:10px;color:rgba(255,255,255,.3);line-height:1.55;}
.pk-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;}
.pk-card{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.08);padding:32px 28px;display:flex;gap:16px;transition:border-color .3s;}
.pk-card:hover{border-color:rgba(184,150,90,.25);}
.pk-num{font-family:Georgia,serif;font-size:28px;font-weight:bold;color:rgba(184,150,90,.2);flex-shrink:0;line-height:1;}
.pk-title{font-family:Georgia,serif;font-size:15px;font-weight:bold;color:#fff;margin-bottom:8px;}
.pk-text{font-size:12px;line-height:1.75;color:rgba(255,255,255,.4);}

/* ══ CONTACT ══ */
.contact-grid{display:grid;grid-template-columns:1fr 400px;gap:2px;}
.c-form{background:rgba(255,255,255,.025);border:1px solid rgba(184,150,90,.1);padding:52px;}
.c-info{background:rgba(28,74,110,.2);border:1px solid rgba(184,150,90,.12);padding:48px 36px;position:relative;overflow:hidden;}
.c-info::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent);}
.ci-row{display:flex;gap:14px;margin-bottom:24px;align-items:flex-start;}
.ci-m{width:2px;min-height:40px;background:var(--gold);flex-shrink:0;box-shadow:0 0 6px rgba(184,150,90,.4);}
.ci-label{font-size:8px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:rgba(184,150,90,.6);margin-bottom:4px;}
.ci-val{font-size:14px;font-weight:bold;color:#fff;line-height:1.5;}
.ci-hint{font-size:10px;color:rgba(255,255,255,.3);margin-top:2px;}
.sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:28px;}
.sub-btn{border:1px solid rgba(184,150,90,.15);background:rgba(255,255,255,.03);padding:12px 14px;cursor:pointer;transition:all .2s;display:flex;gap:10px;align-items:flex-start;text-align:left;color:#fff;font-family:Arial,sans-serif;}
.sub-btn:hover{border-color:rgba(184,150,90,.35);background:rgba(184,150,90,.05);}
.sub-btn.sel{border-color:var(--gold);background:rgba(184,150,90,.08);border-left:3px solid var(--gold);}
.sub-ind{width:9px;height:9px;border:1.5px solid rgba(184,150,90,.4);flex-shrink:0;margin-top:3px;transition:all .2s;}
.sub-btn.sel .sub-ind{background:var(--gold);border-color:var(--gold);}
.sub-lbl{font-size:12px;font-weight:bold;color:#fff;display:block;margin-bottom:2px;}
.sub-sub{font-size:10px;color:rgba(255,255,255,.35);}
.eng-box{background:rgba(184,150,90,.07);border:1px solid rgba(184,150,90,.15);padding:20px;margin-top:28px;position:relative;}
.eng-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold);}
.eng-title{font-family:Georgia,serif;font-size:14px;font-weight:bold;color:var(--gold);margin-bottom:14px;}
.eng-item{display:flex;gap:10px;margin-bottom:10px;align-items:flex-start;}
.eng-d{width:5px;height:5px;background:var(--gold);flex-shrink:0;margin-top:5px;}
.eng-text{font-size:12px;line-height:1.6;color:rgba(255,255,255,.45);}
.eng-text strong{color:#fff;}
.map-placeholder{height:320px;background:rgba(28,74,110,.15);border:1px solid rgba(184,150,90,.1);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.map-placeholder::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(184,150,90,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(184,150,90,.05) 1px,transparent 1px);background-size:40px 40px;}
.map-dot{width:14px;height:14px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(184,150,90,.5);animation:ping 2s ease-out infinite;position:relative;z-index:1;}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(184,150,90,.5)}70%{box-shadow:0 0 0 24px rgba(184,150,90,0)}100%{box-shadow:0 0 0 0 rgba(184,150,90,0)}}
.map-label{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);font-size:12px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.4);}
.success-box{text-align:center;padding:60px 32px;display:none;}
.success-box.show{display:block;}
.succ-ring{width:64px;height:64px;border:2px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 0 30px rgba(184,150,90,.3);}
.succ-check{width:20px;height:13px;border-left:2.5px solid var(--gold);border-bottom:2.5px solid var(--gold);transform:rotate(-45deg) translateY(-2px);}
.succ-title{font-family:Georgia,serif;font-size:24px;font-weight:bold;color:#fff;margin-bottom:10px;}
.succ-sub{font-size:13px;line-height:1.7;color:rgba(255,255,255,.4);max-width:360px;margin:0 auto 24px;}

.ci-val a{color:inherit;text-decoration:none;}
.ci-val a:hover{color:var(--gold);}
.scroll-top{border:0;background:transparent;padding:0;}

/* ══ SERVICES — NOUVELLES SECTIONS ══ */

/* Texte intro section */
.sec-intro-text{font-size:14px;line-height:1.85;color:rgba(255,255,255,.4);max-width:620px;margin-bottom:52px;}

/* Strip positionnement */
.pos-strip{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:center;background:var(--navy);padding:32px 80px;}
.pos-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;}
.pos-num{font-family:Georgia,serif;font-size:36px;font-weight:bold;color:var(--gold);line-height:1;letter-spacing:-1px;}
.pos-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.45);line-height:1.5;}
.pos-sep{width:1px;height:52px;background:rgba(184,150,90,.2);margin:0 24px;}

/* Résultats par service */
.svc-result-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px;}
.svc-result-item{display:flex;align-items:center;gap:7px;font-size:11px;color:rgba(255,255,255,.38);background:rgba(255,255,255,.03);border:1px solid rgba(184,150,90,.1);padding:7px 12px;}
.svc-result-icon{color:var(--gold);display:flex;align-items:center;flex-shrink:0;}

/* Services extra (05 + 06) */
.svc-extra-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:2px;}
.svc-extra-card{display:flex;gap:0;background:rgba(28,74,110,.18);border:1px solid rgba(184,150,90,.12);padding:36px;text-decoration:none;transition:all .35s;position:relative;overflow:hidden;}
.svc-extra-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent);transform:scaleX(0);transform-origin:left;transition:transform .4s;}
.svc-extra-card:hover{border-color:rgba(184,150,90,.35);background:rgba(28,74,110,.28);}
.svc-extra-card:hover::before{transform:scaleX(1);}
.svc-extra-num{font-family:Georgia,serif;font-size:72px;font-weight:bold;color:rgba(184,150,90,.07);line-height:1;flex-shrink:0;margin-right:28px;margin-top:-8px;}
.svc-extra-content{flex:1;}
.svc-extra-tag{font-size:8px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.svc-extra-title{font-family:Georgia,serif;font-size:22px;font-weight:bold;color:#fff;margin-bottom:10px;line-height:1.2;}
.svc-extra-desc{font-size:12px;line-height:1.85;color:rgba(255,255,255,.38);margin-bottom:18px;}
.svc-extra-items{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px;}
.svc-extra-items span{background:rgba(255,255,255,.04);border:1px solid rgba(184,150,90,.12);color:rgba(255,255,255,.45);font-size:10px;padding:3px 10px;letter-spacing:.5px;}
.svc-extra-cta{font-size:9px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:8px;transition:gap .25s;}
.svc-extra-card:hover .svc-extra-cta{gap:14px;}

/* Secteurs d'intervention */
.sectors-section{padding:96px 80px;background:var(--cream);}
.sectors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:0;}
.sector-card{background:#fff;border:1px solid rgba(28,74,110,.1);border-top:3px solid var(--navy);padding:32px 28px;transition:all .3s;cursor:default;position:relative;}
.sector-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s;}
.sector-card:hover{box-shadow:0 12px 40px rgba(28,74,110,.1);transform:translateY(-3px);}
.sector-card:hover::after{transform:scaleX(1);}
.sector-icon{width:48px;height:48px;background:rgba(28,74,110,.06);border:1px solid rgba(28,74,110,.12);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--navy);transition:all .3s;}
.sector-card:hover .sector-icon{background:var(--navy);color:var(--gold);}
.sector-title{font-family:Georgia,serif;font-size:17px;font-weight:bold;color:var(--navy);margin-bottom:8px;}
.sector-desc{font-size:12px;line-height:1.8;color:var(--grey);}

/* Pourquoi Kemet */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;}
.why-card{background:rgba(255,255,255,.025);border:1px solid rgba(184,150,90,.1);padding:40px 36px;transition:all .3s;position:relative;overflow:hidden;}
.why-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .4s;}
.why-card:hover{border-color:rgba(184,150,90,.3);background:rgba(255,255,255,.04);}
.why-card:hover::before{transform:scaleY(1);}
.why-icon{width:44px;height:44px;border:1px solid rgba(184,150,90,.3);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:18px;transition:all .3s;}
.why-card:hover .why-icon{background:rgba(184,150,90,.1);}
.why-title{font-family:Georgia,serif;font-size:19px;font-weight:bold;color:#fff;margin-bottom:12px;}
.why-desc{font-size:13px;line-height:1.85;color:rgba(255,255,255,.42);}

/* Méthodo sur fond clair */
.m-card-light{background:#fff;border:1px solid rgba(28,74,110,.1);}
.m-card-light:hover{background:rgba(28,74,110,.04);border-color:rgba(28,74,110,.2);}
.m-card-light::after{color:var(--navy);opacity:.3;}

/* ══ CABINET — icônes valeurs et MVV ══ */
.val-card .val-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid rgba(184,150,90,.25);margin-bottom:16px;color:var(--gold);}
.mvv-icon{display:flex;align-items:center;margin-bottom:12px;color:var(--gold);}

/* ══ PREMIUM FX — cursor, scroll progress, 3D ══ */

/* Scroll progress bar */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--navy),var(--gold));z-index:9999;pointer-events:none;transition:width .08s linear;}

/* Custom cursor */
.cursor-dot{position:fixed;width:6px;height:6px;background:var(--gold);pointer-events:none;z-index:99999;transform:translate(-50%,-50%);box-shadow:0 0 10px rgba(184,150,90,.8);}
.cursor-ring{position:fixed;width:30px;height:30px;border:1px solid rgba(184,150,90,.55);pointer-events:none;z-index:99998;transform:translate(-50%,-50%);transition:width .35s,height .35s,border-color .35s,background .35s;}
.cursor-ring.hovering{width:52px;height:52px;border-color:var(--gold);background:rgba(184,150,90,.06);}
.cursor-dot,.cursor-ring{display:none;}
@media(pointer:fine){.cursor-dot,.cursor-ring{display:block;}}

/* Hero floating geometry */
.hero-shape{position:absolute;pointer-events:none;z-index:3;will-change:transform;transition:transform .7s cubic-bezier(.22,1,.36,1);}
.hshape-diamond{width:130px;height:130px;border:1px solid rgba(184,150,90,.2);top:22%;right:10%;animation:hsDrift 9s ease-in-out infinite;}
.hshape-ring{width:260px;height:260px;border:1px solid rgba(28,74,110,.5);border-radius:50%;top:30%;right:5%;animation:hsDrift 14s ease-in-out infinite reverse;opacity:.3;}
.hshape-vline{width:1px;height:90px;background:linear-gradient(transparent,rgba(184,150,90,.5),transparent);top:18%;right:22%;animation:hsLine 7s ease-in-out infinite;}
.hshape-dot{width:5px;height:5px;background:var(--gold);top:18%;right:22.3%;animation:hsDot 4s ease-in-out infinite;box-shadow:0 0 12px rgba(184,150,90,.9);}
@keyframes hsDrift{0%,100%{transform:rotate(45deg) translateY(0)}50%{transform:rotate(48deg) translateY(-20px)}}
@keyframes hsLine{0%,100%{opacity:.5;transform:translateY(0)}50%{opacity:1;transform:translateY(-14px)}}
@keyframes hsDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.5)}}

/* Stat number glow */
@keyframes statGlow{0%,100%{text-shadow:0 0 20px rgba(184,150,90,.15)}50%{text-shadow:0 0 50px rgba(184,150,90,.55),0 0 90px rgba(184,150,90,.15)}}
.stat-number{animation:statGlow 4s ease-in-out infinite;}

/* Pillar card slide */
.pillar-card:hover{transform:translateX(10px);border-color:rgba(184,150,90,.3);background:rgba(184,150,90,.04);}

/* Sector pill pop */
.sector-pill:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(28,74,110,.2);}

/* ══ INDEX — approche ══ */
.approche-section{background:var(--dark);border-top:1px solid rgba(184,150,90,.08);}
.approche-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.approche-manifesto{font-family:Georgia,serif;font-size:clamp(20px,2.5vw,30px);line-height:1.4;color:#fff;letter-spacing:-.3px;margin-top:24px;}
.approche-manifesto em{font-style:italic;color:var(--gold);}
.approche-signature{display:flex;align-items:center;gap:16px;margin-top:32px;}
.approche-sig-line{width:32px;height:1px;background:var(--gold);flex-shrink:0;}
.approche-sig-text{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.3);}
.approche-pillars{display:flex;flex-direction:column;gap:2px;margin-top:8px;}
.pillar-card{background:rgba(255,255,255,.025);border:1px solid rgba(184,150,90,.08);padding:22px 24px;display:flex;gap:16px;align-items:flex-start;transition:border-color .3s;}
.pillar-card:hover{border-color:rgba(184,150,90,.3);background:rgba(184,150,90,.03);}
.pillar-icon{color:var(--gold);flex-shrink:0;margin-top:2px;}
.pillar-title{font-family:Georgia,serif;font-size:14px;font-weight:bold;color:#fff;margin-bottom:5px;}
.pillar-desc{font-size:11px;color:rgba(255,255,255,.38);line-height:1.65;}

/* ══ INDEX — secteurs strip ══ */
.sectors-strip-band{background:var(--cream);padding:52px 80px;border-top:3px solid var(--navy);}
.sectors-strip-label{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(28,74,110,.45);margin-bottom:24px;display:flex;align-items:center;gap:16px;}
.sectors-strip-label::after{content:'';flex:1;height:1px;background:rgba(28,74,110,.12);}
.sectors-pills{display:flex;flex-wrap:wrap;gap:8px;}
.sector-pill{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(28,74,110,.1);border-top:2px solid var(--navy);padding:11px 18px;font-size:11px;font-weight:600;letter-spacing:.3px;color:var(--dark);transition:all .25s;cursor:default;}
.sector-pill:hover{border-top-color:var(--gold);background:var(--navy);color:#fff;}
.sector-pill svg{color:var(--navy);flex-shrink:0;transition:color .25s;}
.sector-pill:hover svg{color:var(--gold);}

/* ══════════════════════════════════════════════════════
   PAGE TRANSITIONS v4 — transitions.js
   Portal zoom · clip-path circle épuré
   Cercle seul — pas de logo, pas d'anneaux
══════════════════════════════════════════════════════ */

.pt-overlay{
  position:fixed;inset:0;z-index:999999;
  pointer-events:none;overflow:hidden;
  clip-path:circle(0% at 50% 50%);
  /* transition pilotée par JS */
}

/* Fond du cercle — dégradé radial pour la profondeur */
.pt-void{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 70% at 50% 50%,#0d1928 0%,var(--dark) 65%);
}

/* ── Bordure or sur le cercle en mouvement ──
   Astuce : pseudo-element en border-radius:50%, même
   taille que le viewport diagonal, centré, zoomé avec
   clip-path du parent → seul l'arc avant est visible.    */
.pt-void::after{
  content:'';
  position:absolute;
  width:200vmax;height:200vmax;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  border-radius:50%;
  border:2px solid rgba(184,150,90,.55);
  box-shadow:0 0 22px rgba(184,150,90,.35),inset 0 0 22px rgba(184,150,90,.18);
  pointer-events:none;
}

/* ── STATE: ENTERING (cercle s'étend) ── */
.pt-overlay.pt-entering{pointer-events:all;}

/* ── STATE: LEAVING (cercle se rétracte) ── */
.pt-overlay.pt-leaving{pointer-events:none;}

/* ══════════════════════════════════════════════════════
   STUDIO-GRADE FX — studio.js
   Inspired by studionamma.com signature animations
══════════════════════════════════════════════════════ */

/* ── MASKED TEXT LINE REVEAL ── */
.k-line-mask{overflow:hidden;display:block;}
.k-line-inner{display:block;transform:translateY(105%);transition:transform 1.1s cubic-bezier(0.16,1,0.3,1);}
.k-line-inner.k-line-in{transform:translateY(0);}

/* ── IMAGE WIPE REVEAL ── */
.k-wipe{position:relative;overflow:hidden;}
.k-wipe::after{content:'';position:absolute;inset:0;background:var(--dark);z-index:3;transform-origin:top;transform:scaleY(1);transition:transform 1.15s cubic-bezier(0.77,0,0.18,1);}
.k-wipe.k-wipe-in::after{transform:scaleY(0);}
.k-wipe > img,.k-wipe > video{transform:scale(1.08);transition:transform 1.5s cubic-bezier(0.77,0,0.18,1);}
.k-wipe.k-wipe-in > img,.k-wipe.k-wipe-in > video{transform:scale(1);}

/* ── STAGGERED GRID REVEAL ── */
.k-grid-hidden{opacity:0;transform:translateY(36px) scale(0.97);transition:opacity .42s ease,transform .42s cubic-bezier(0.16,1,0.3,1);}
.k-grid-visible{opacity:1;transform:none;}

/* ── OVERSIZED DECO TYPOGRAPHY ── */
.k-deco-word{position:absolute;font-family:Georgia,serif;font-size:clamp(80px,14vw,220px);font-weight:bold;color:transparent;-webkit-text-stroke:1px rgba(184,150,90,.055);letter-spacing:-5px;pointer-events:none;user-select:none;white-space:nowrap;top:50%;right:-2%;transform:translateY(-50%);z-index:0;line-height:1;}
.k-deco-left{right:auto;left:-3%;}
.sectors-strip-band .k-deco-word{-webkit-text-stroke:1px rgba(28,74,110,.08);font-size:clamp(60px,12vw,180px);}

/* ── SECTION PROGRESS LINE ── */
.k-section-line{position:absolute;top:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--navy));opacity:0;transition:width 1.4s cubic-bezier(0.16,1,0.3,1),opacity .3s;}
.k-section-line.k-section-line-in{width:100%;opacity:.35;}

/* ══════════════════════════════════════
   PREMIUM ANIM FX — anim.js support
══════════════════════════════════════ */

/* ── METEORS ── */
.k-meteor{position:absolute;height:1.5px;background:linear-gradient(90deg,rgba(184,150,90,.95) 0%,rgba(255,255,255,.7) 45%,transparent 100%);transform:rotate(-38deg);transform-origin:left center;animation:kMeteor linear infinite;pointer-events:none;z-index:2;border-radius:0;}
@keyframes kMeteor{0%{opacity:0;transform:rotate(-38deg) translateX(-80px);}8%{opacity:1;}80%{opacity:.85;}100%{opacity:0;transform:rotate(-38deg) translateX(700px);}}

/* ── CARD SPOTLIGHT ── */
.k-spot{position:relative;}
.k-spot::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at var(--kx,50%) var(--ky,50%),rgba(184,150,90,.14) 0%,transparent 55%);z-index:0;border-radius:inherit;}

/* ── SPARKLES ── */
.k-sparkle{position:absolute;width:5px;height:5px;background:var(--gold);pointer-events:none;border-radius:50%;animation:kSpark .75s ease-out forwards;z-index:10;}
@keyframes kSpark{0%{opacity:1;transform:scale(0) translate(0,0);}35%{opacity:1;transform:scale(1.8) translate(var(--tx,20px),var(--ty,-20px));}100%{opacity:0;transform:scale(0) translate(calc(var(--tx,20px)*1.6),calc(var(--ty,-20px)*1.6));}}

/* ── BORDER BEAM ── */
.k-beam{position:absolute;inset:-1px;overflow:hidden;pointer-events:none;z-index:0;}
.k-beam::after{content:'';position:absolute;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(184,150,90,.6),transparent);top:0;left:-70%;animation:kBeam 3.5s ease-in-out infinite;opacity:0;}
.axe-card:hover .k-beam::after{opacity:1;}
@keyframes kBeam{0%{left:-70%;}100%{left:170%;}}

/* ── KINETIC SECTION LINES ── */
.k-kinetic-line{background:linear-gradient(90deg,var(--gold),var(--navy),var(--gold));background-size:200% 100%;animation:kLineShift 4s linear infinite;}
@keyframes kLineShift{0%{background-position:0% 50%;}100%{background-position:200% 50%;}}

/* ── AURORA ── */
.k-aurora{position:absolute;inset:0;z-index:0;pointer-events:none;background:
  radial-gradient(ellipse 80% 60% at 10% 50%,rgba(28,74,110,.55) 0%,transparent 60%),
  radial-gradient(ellipse 60% 80% at 90% 20%,rgba(184,150,90,.12) 0%,transparent 60%),
  radial-gradient(ellipse 100% 40% at 50% 90%,rgba(6,15,24,.9) 0%,transparent 100%);
animation:kAuroraShift 14s ease-in-out infinite alternate;}
@keyframes kAuroraShift{0%{opacity:.7;filter:hue-rotate(0deg);}50%{opacity:1;filter:hue-rotate(15deg);}100%{opacity:.8;filter:hue-rotate(-10deg);}}

/* ── GLOW COUNTER ── */
.k-count-glow{animation:kCountGlow 2s ease-in-out infinite;}
@keyframes kCountGlow{0%,100%{filter:drop-shadow(0 0 6px rgba(184,150,90,.2));}50%{filter:drop-shadow(0 0 22px rgba(184,150,90,.7));}}

/* dakar desc */
.dakar-desc{font-size:14px;color:rgba(255,255,255,.45);max-width:460px;line-height:1.75;margin-top:12px;}

/* ══ ÉQUIPE — profils rejoindre ══ */
.rej-profile-card{background:rgba(255,255,255,.03);border:1px solid rgba(184,150,90,.1);padding:14px;}
.rej-profile-card-title{font-family:Georgia,serif;font-size:13px;font-weight:bold;color:#fff;margin-bottom:4px;}
.rej-profile-card-sub{font-size:11px;color:rgba(255,255,255,.38);}

/* ══ CONTACT — FAQ ══ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;}
.faq-card{background:rgba(255,255,255,.02);border:1px solid rgba(184,150,90,.08);padding:28px 26px;transition:border-color .3s;}
.faq-card:hover{border-color:rgba(184,150,90,.25);}
.faq-q{font-family:Georgia,serif;font-size:15px;font-weight:bold;color:#fff;margin-bottom:10px;}
.faq-a{font-size:12px;line-height:1.75;color:rgba(255,255,255,.4);}

/* ══ FORMATIONS — garanties ══ */
.garanties-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.gar-card{background:rgba(255,255,255,.03);border:1px solid rgba(184,150,90,.1);padding:36px 28px;transition:all .3s;}
.gar-card:hover{border-color:rgba(184,150,90,.3);background:rgba(184,150,90,.04);}
.gar-icon{width:48px;height:48px;border:1px solid rgba(184,150,90,.25);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:18px;}
.gar-title{font-family:Georgia,serif;font-size:18px;font-weight:bold;color:#fff;margin-bottom:10px;}
.gar-desc{font-size:12px;line-height:1.8;color:rgba(255,255,255,.4);}

/* ══════════════════════════════════════════════════════
   3D ANIMATIONS — fx3d.js
══════════════════════════════════════════════════════ */

/* ── FLIP CARD ── */
.fc-card{
  perspective:1200px;
  overflow:visible !important;
  background:transparent !important;
  border:none !important;
  padding:0 !important;
  position:relative;
  cursor:pointer;
}
.fc-inner{
  position:relative;
  width:100%;height:100%;
  transform-style:preserve-3d;
  transition:transform .8s cubic-bezier(0.23,1,0.32,1);
}
.fc-card.fc-flipped .fc-inner{transform:rotateY(180deg);}

.fc-front,.fc-back{
  position:absolute;inset:0;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
.fc-front{
  background:rgba(255,255,255,.025);
  border:1px solid rgba(184,150,90,.1);
  padding:40px 32px 36px;
  overflow:hidden;
  transition:border-color .4s,box-shadow .4s;
}
.fc-card:hover .fc-front{
  border-color:rgba(184,150,90,.3);
  box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 50px rgba(184,150,90,.07);
}
.fc-back{
  transform:rotateY(180deg);
  background:linear-gradient(145deg,var(--navy-deep) 0%,#0d1f30 100%);
  border:1px solid rgba(184,150,90,.4);
  padding:36px 28px;
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  overflow:hidden;
  position:relative;
}
.fc-back-glow{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 40%,rgba(184,150,90,.12) 0%,transparent 65%);
  pointer-events:none;
}
.fc-back-num{
  font-family:Georgia,serif;font-size:52px;font-weight:bold;
  color:rgba(184,150,90,.08);line-height:1;margin-bottom:10px;
}
.fc-back-icon{
  width:44px;height:44px;border:1px solid rgba(184,150,90,.35);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);margin-bottom:18px;
}
.fc-back-title{
  font-family:Georgia,serif;font-size:17px;font-weight:bold;
  color:#fff;margin-bottom:10px;line-height:1.2;
}
.fc-back-sep{width:36px;height:1px;background:var(--gold);margin:12px 0;box-shadow:0 0 8px rgba(184,150,90,.4);}
.fc-back-desc{font-size:12px;line-height:1.85;color:rgba(255,255,255,.45);margin-bottom:24px;flex:1;}
.fc-back-cta{
  font-size:9px;font-weight:bold;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold);text-decoration:none;
  border-bottom:1px solid rgba(184,150,90,.35);padding-bottom:3px;
  transition:letter-spacing .3s,border-color .3s;
}
.fc-back-cta:hover{letter-spacing:3px;border-color:var(--gold);}
.fc-back-corner{
  position:absolute;bottom:0;right:0;
  width:40px;height:40px;
  border-top:1px solid rgba(184,150,90,.25);
  border-left:1px solid rgba(184,150,90,.25);
}
.fc-hint{
  position:absolute;top:12px;right:14px;
  font-size:16px;color:rgba(184,150,90,.4);
  transition:color .3s,transform .4s;
  z-index:5;pointer-events:none;
}
.fc-card:hover .fc-hint{color:rgba(184,150,90,.8);transform:rotate(180deg);}
.fc-card.fc-flipped .fc-hint{opacity:0;}

/* ── FAQ 3D HINGE ── */
.faq-q{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.faq-icon{
  flex-shrink:0;width:22px;height:22px;
  border:1px solid rgba(184,150,90,.3);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);font-size:16px;font-weight:300;
  transition:transform .4s cubic-bezier(.23,1,.32,1),background .3s,border-color .3s;
  margin-top:1px;
}
.faq-card.faq-open .faq-icon{
  transform:rotate(45deg);
  background:rgba(184,150,90,.1);border-color:var(--gold);
}
.faq-card{cursor:pointer;transition:border-color .3s,background .3s;}
.faq-card.faq-open{border-color:rgba(184,150,90,.3);background:rgba(184,150,90,.03);}
.faq-a-hidden{
  perspective:600px;
  transform-origin:top center;
}
.faq-a{
  transition:
    max-height .65s cubic-bezier(.16,1,.3,1),
    transform .65s cubic-bezier(.16,1,.3,1),
    opacity .45s ease;
  transform:perspective(600px) rotateX(-14deg);
  opacity:0;
  transform-origin:top center;
  padding-top:0 !important;
  margin-top:0;
}
.faq-card.faq-open .faq-a{
  transform:perspective(600px) rotateX(0deg);
  opacity:1;
  padding-top:16px !important;
}

/* ── THREE.JS HERO CANVAS ── */
#hero-three{
  position:absolute;inset:0;
  width:100%;height:100%;
  z-index:2;
  pointer-events:none;
  opacity:0;
  transition:opacity 2.2s ease 0.6s;
}
#hero-three.h3-visible{opacity:1;}
@media(max-width:768px){#hero-three{display:none!important;}}

/* ── HERO 3D CARD ── */
.hero-3d-card{
  position:absolute;
  right:8%;top:50%;
  width:clamp(200px,22vw,300px);
  transform:perspective(900px) rotateY(-28deg) rotateX(6deg) translateY(-50%);
  transition:transform .6s cubic-bezier(.23,1,.32,1);
  z-index:4;
  animation:heroCardFloat 7s ease-in-out infinite;
  pointer-events:none;
}
@media(max-width:980px){.hero-3d-card{display:none;}}
@keyframes heroCardFloat{
  0%,100%{transform:perspective(900px) rotateY(-28deg) rotateX(6deg) translateY(-50%);}
  50%{transform:perspective(900px) rotateY(-22deg) rotateX(3deg) translateY(calc(-50% - 14px));}
}
.h3c-inner{
  background:linear-gradient(145deg,rgba(28,74,110,.85) 0%,rgba(6,15,24,.95) 100%);
  border:1px solid rgba(184,150,90,.35);
  padding:22px 20px 18px;
  position:relative;overflow:hidden;
}
.h3c-inner::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(184,150,90,.06),transparent 55%);
}
.h3c-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.h3c-k{
  width:32px;height:32px;background:var(--gold);
  font-family:Georgia,serif;font-size:18px;font-weight:bold;color:#fff;
  display:flex;align-items:center;justify-content:center;
}
.h3c-badge{font-size:7px;letter-spacing:2px;text-transform:uppercase;color:rgba(184,150,90,.6);}
.h3c-divider{height:1px;background:rgba(184,150,90,.15);margin:10px 0;}
.h3c-row{display:flex;align-items:center;gap:8px;padding:5px 0;}
.h3c-dot{width:4px;height:4px;background:var(--gold);flex-shrink:0;}
.h3c-label{font-size:10px;color:rgba(255,255,255,.5);letter-spacing:.3px;}
.h3c-bottom{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:rgba(184,150,90,.45);margin-top:4px;}
.h3c-shadow{
  position:absolute;bottom:-18px;left:12px;right:12px;height:20px;
  background:rgba(0,0,0,.5);filter:blur(12px);transform:scaleY(.6);
  z-index:-1;
}
.h3c-reflection{
  position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);
  animation:h3cSheen 5s ease-in-out infinite 2s;
  pointer-events:none;
}
@keyframes h3cSheen{0%,100%{left:-60%;}50%{left:120%;}}

/* ── PERSPECTIVE OPEN (sections) ── */
.persp-hidden{
  opacity:0;
  transform:perspective(800px) rotateX(-35deg) translateY(30px);
  transform-origin:top center;
  transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1);
}
.persp-open{opacity:1;transform:none;}

/* ── DEEP TILT Z-LAYERS ── */
.ms-prest-card,.pillar-card{transform-style:preserve-3d;}

/* ── 3D COUNTER ── */
.count-3d{
  display:inline-block;
  transform-style:preserve-3d;
  transition:transform .4s cubic-bezier(.23,1,.32,1);
}
.count-3d:hover{transform:perspective(300px) rotateX(-10deg) scale(1.08);}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important;}
  .hero-video,.ms-hero-video{display:none;}
}

@media (max-width: 980px){
  nav{height:auto;min-height:68px;padding:14px 24px;align-items:flex-start;gap:14px;flex-direction:column;}
  .nav-links{width:100%;display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;}
  .nav-link,.nav-cta{white-space:nowrap;}
  .hero-content,.mh-content,.dakar-content{padding-left:32px;padding-right:32px;}
  section{padding:64px 32px;}
  .hero-bottom,.stats-grid,.axes-grid,.mvv-grid,.valeurs-grid,.outils-grid,.catalogue-grid,.process-grid,.formats-grid,.team-grid,.eq-vals,.etudes-grid,.domaines-grid,.etude-process,.pk-grid{grid-template-columns:1fr 1fr;}
  .about-grid,.dirigeant,.svc-block,.svc-block.rev,.rejoindre-grid,.contact-grid{grid-template-columns:1fr;}
  .svc-block.rev .svc-label{order:-1;}
  .footer-top{grid-template-columns:1fr 1fr;padding:44px 32px 32px;}
  .footer-bottom{padding:22px 32px;gap:10px;flex-wrap:wrap;}
  .cta-band{padding:56px 32px;align-items:flex-start;flex-direction:column;}
  .pos-strip{grid-template-columns:1fr 1fr;gap:28px;padding:32px;}
  .pos-sep{display:none;}
  .svc-extra-grid{grid-template-columns:1fr;}
  .sectors-section{padding:64px 32px;}
  .sectors-grid,.why-grid{grid-template-columns:1fr 1fr;}
  .garanties-grid{grid-template-columns:1fr 1fr;}
  .faq-grid{grid-template-columns:1fr;}
  .approche-grid{grid-template-columns:1fr;gap:44px;}
  .sectors-strip-band{padding:44px 32px;}
}

@media (max-width: 640px){
  nav{padding:12px 18px;}
  .nav-brand-name{font-size:11px;letter-spacing:1.8px;}
  .nav-brand-sub{font-size:7px;}
  .hero{min-height:760px;align-items:flex-start;}
  .hero-content{padding:130px 22px 0;}
  .hero-title{font-size:clamp(34px,12vw,48px);letter-spacing:0;}
  .hero-desc{font-size:14px;margin-bottom:28px;}
  .hero-btns{flex-direction:column;align-items:flex-start;}
  .hero-bottom{grid-template-columns:1fr;position:relative;margin-top:40px;}
  .hs{padding:18px 22px;border-right:0;border-bottom:1px solid rgba(184,150,90,.12);}
  .scroll-hint{display:none;}
  .mini-hero{height:390px;}
  .mh-content{padding:0 22px 36px;}
  .mh-title{font-size:32px;letter-spacing:0;}
  section{padding:52px 22px;}
  .stats-band{padding:36px 22px;}
  .stats-grid,.axes-grid,.mvv-grid,.valeurs-grid,.outils-grid,.methodo-grid,.catalogue-grid,.process-grid,.formats-grid,.team-grid,.eq-vals,.etudes-grid,.domaines-grid,.etude-process,.pk-grid,.prest-grid,.sub-grid,.sectors-grid,.why-grid{grid-template-columns:1fr;}
  .pos-strip{grid-template-columns:1fr 1fr;padding:24px 22px;}
  .svc-extra-card{flex-direction:column;}
  .svc-extra-num{font-size:48px;margin-right:0;margin-bottom:8px;}
  .svc-result-row{flex-direction:column;}
  .garanties-grid{grid-template-columns:1fr;}
  .sectors-section{padding:52px 22px;}
  .sectors-strip-band{padding:36px 22px;}
  .approche-manifesto{font-size:22px;}
  .stat-item{border-right:0;border-bottom:1px solid rgba(6,15,24,.18);padding:18px 0;}
  .stat-item:last-child{border-bottom:0;}
  .c-form,.c-info,.rej-content,.rej-sidebar{padding:28px 22px;}
  .form-row{grid-template-columns:1fr;}
  .dakar-band{height:300px;}
  .map-label{width:90%;text-align:center;}
  .footer-top{grid-template-columns:1fr;padding:40px 22px 28px;}
  .footer-bottom{padding:20px 22px;}
}

/* ══════════════════════════════════════════════════════════════
   LOGO 3D — logo3d.js
══════════════════════════════════════════════════════════════ */
.logo3d-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:20px;
}
.logo3d-wrap canvas{
  border-radius:4px;
  box-shadow:
    0 0 40px rgba(184,150,90,.18),
    0 0 80px rgba(184,150,90,.06),
    0 24px 60px rgba(0,0,0,.55);
  transition:box-shadow .4s ease;
}
.logo3d-wrap canvas:hover{
  box-shadow:
    0 0 60px rgba(184,150,90,.32),
    0 0 120px rgba(184,150,90,.12),
    0 28px 70px rgba(0,0,0,.6);
}
.logo3d-text{
  text-align:center;
  pointer-events:none;
  user-select:none;
}
.logo3d-name{
  font-family:Georgia,serif;
  font-size:14px;
  font-weight:bold;
  letter-spacing:4px;
  text-transform:uppercase;
  color:#fff;
}
.logo3d-name span{ color:var(--gold); }
.logo3d-sub{
  font-size:8px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(184,150,90,.55);
  margin-top:5px;
}

/* Section showcase sur cabinet.html */
.logo3d-showcase{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:32px;
  padding:80px 40px;
  background:radial-gradient(ellipse at 50% 50%, rgba(28,74,110,.15) 0%, transparent 70%);
  position:relative;
}
.logo3d-showcase::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 0%,rgba(184,150,90,.03) 50%,transparent 100%);
  pointer-events:none;
}

@media(max-width:640px){
  .logo3d-showcase{ padding:50px 20px; }
}

/* ══════════════════════════════════════════════
   PERFORMANCE MODE — production
   Keeps the visual identity while removing costly ambient motion.
══════════════════════════════════════════════ */
.scan-line,
.hero-shape,
.scroll-progress,
.cursor-dot,
.cursor-ring,
#hero-three,
#p3d-canvas,
#scroll3d-canvas,
#door-overlay{display:none!important;}

.glitch::before,
.glitch::after{display:none!important;}

.hbg-orb,
.hbg-beam,
.hbg-flare,
.nav-logo-k::after,
.scroll-wheel,
.scroll-top-ring{animation:none!important;}

.hero-video{display:none!important;}

section,
.stats-band,
.dakar-band,
.cta-band{content-visibility:auto;contain-intrinsic-size:1px 700px;}

/* ══════════════════════════════════════════════
   PREMIUM 3D LAYER — premium3d.js
══════════════════════════════════════════════ */

/* ── 1. HOLOGRAPHIC FOIL ── */
.k-holo { position:relative; } /* déjà positionné sur les cards */
.k-holo::after {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:8;
  border-radius:inherit;
  opacity:0;
  transition:opacity .28s ease;
  background:conic-gradient(
    from var(--ha,90deg) at var(--hx,50%) var(--hy,50%),
    rgba(255,80,80, .10),
    rgba(255,210,50,.13),
    rgba(60,255,140,.10),
    rgba(50,140,255,.12),
    rgba(200,60,255,.10),
    rgba(255,80,80, .10)
  );
  mix-blend-mode:screen;
}
.k-holo.k-holo-on::after { opacity:1; }

/* ── 3. DEPTH TITLE WORDS ── */
.k-dw {
  display:inline-block;
  will-change:transform;
}

/* ── 4. GLOBAL SPOTLIGHT ── */
#k-gspot {
  position:fixed;
  width:520px;
  height:520px;
  border-radius:50%;
  pointer-events:none;
  z-index:999;
  transform:translate(-50%,-50%);
  opacity:0;
  transition:opacity .55s ease;
  background:radial-gradient(
    circle,
    rgba(184,150,90,.07) 0%,
    rgba(184,150,90,.04) 30%,
    rgba(28,74,110,.025) 52%,
    transparent 68%
  );
  mix-blend-mode:screen;
  will-change:left,top;
}

/* ── 5. CLICK RIPPLE ── */
.k-ripple {
  position:fixed;
  width:8px;
  height:8px;
  border-radius:50%;
  border:1.5px solid rgba(184,150,90,.72);
  pointer-events:none;
  z-index:99998;
  transform:translate(-50%,-50%) scale(0);
  animation:kRipple .75s cubic-bezier(0.22,1,0.36,1) forwards;
}
@keyframes kRipple {
  0%   { transform:translate(-50%,-50%) scale(0);  opacity:.9; }
  65%  { transform:translate(-50%,-50%) scale(50); opacity:.3; }
  100% { transform:translate(-50%,-50%) scale(68); opacity:0;  }
}
