/*
Theme Name:  CTI-CI
Theme URI:   https://cti-ci.com
Description: Thème WordPress sur mesure — Centre de Traitement Informatique de Côte d'Ivoire
Version:     1.0
Author:      Switch Maker SARL
Author URI:  https://switchmaker.net
Text Domain: ctici
*/

/* ═══════════════════════════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --navy:#0c2671;--navy-dark:#06101e;--navy-light:#1A3A8F;
  --electric:#1A7AFF;--ice:#E6F0FF;
  --green:#0F7A4B;--green2:#1DB954;
  --orange:#FF6B1A;--orange2:#FFAA33;
  --white:#fff;--off:#F5F7FF;--text:#1a1a2e;--gray:#6a6a7a;
  --e1:cubic-bezier(.25,.46,.45,.94);
  --e2:cubic-bezier(.76,0,.24,1);
  --e3:cubic-bezier(.34,1.56,.64,1);
  /* alias courts utilisés dans le CSS original */
  --w:#fff;
  --o1:#FF6B1A;--o3:#FFAA33;
  --g2:#1DB954;
  --b1:#0c2671;--b2:#1A3A8F;--b3:#0a1f5c;--b4:#1A7AFF;
  --k2:#080e1c;--k3:rgba(255,255,255,.04);
  /* espacement uniforme */
  --sp:2rem 6%;
  --sp-sm:1.5rem 6%;
  --sp-hd:1.5rem 6% 0;
}

html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;font-size:16px;background:#080e1c;color:#fff;overflow-x:hidden;cursor:auto}
section,.section-padded{padding:var(--sp)}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

/* ═══════════════════════════
   CURSOR
═══════════════════════════ */
#cur{width:8px;height:8px;background:var(--orange);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
#cur-o{width:36px;height:36px;border:1px solid rgba(255,255,255,.3);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s}
.cx #cur{width:52px;height:52px;background:rgba(255,107,26,.15);mix-blend-mode:normal}
.cx #cur-o{opacity:0}

/* ═══════════════════════════
   LOADER
═══════════════════════════ */
#loader{position:fixed;inset:0;z-index:99999;background:var(--navy-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .6s .2s,transform .7s .2s var(--e2)}
#loader.out{opacity:0;pointer-events:none;transform:scaleY(0);transform-origin:top}
.ld-img{width:180px;margin-bottom:0.9rem;mix-blend-mode:lighten;animation:ldPulse 1.5s ease-in-out infinite alternate;filter:drop-shadow(0 0 24px rgba(255,107,26,.2))}
@keyframes ldPulse{from{opacity:.6;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.ld-name{font-family:'Montserrat',sans-serif;font-size:1.8rem;font-weight:900;letter-spacing:.12em;color:#fff}
.ld-name span{color:var(--orange)}
.ld-sub{font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:.4rem}
.ld-bar{width:160px;height:1.5px;background:rgba(255,255,255,.08);margin-top:1rem;overflow:hidden}
.ld-prog{height:100%;background:linear-gradient(90deg,var(--green),var(--orange));animation:ldprog 1.9s var(--e1) forwards}
@keyframes ldprog{from{width:0}to{width:100%}}

/* ═══════════════════════════
   NAV
═══════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:120px;padding:0 6% 0 2%;display:flex;align-items:center;justify-content:space-between;transition:height .4s var(--e1),background .4s,box-shadow .4s}
nav.stuck{height:80px;background:rgba(10,31,92,.97);backdrop-filter:blur(18px);box-shadow:0 1px 0 rgba(255,255,255,.06)}
.nav-logo{display:flex;align-items:center;margin-top:10px}
.nav-logo-png{
  height:126px;width:auto;
  mix-blend-mode:lighten;
  transition:height .4s var(--e1),filter .4s;
  filter:
    drop-shadow(0 0 24px rgba(255,107,26,.5))
    drop-shadow(0 0 50px rgba(15,122,75,.3))
    drop-shadow(0 0 4px rgba(255,255,255,.3))
    brightness(1.08);
  animation:navLogoGlow 4s 2s ease-in-out infinite alternate;
}
@keyframes navLogoGlow{
  from{filter:drop-shadow(0 0 24px rgba(255,107,26,.5)) drop-shadow(0 0 50px rgba(15,122,75,.3)) drop-shadow(0 0 4px rgba(255,255,255,.3)) brightness(1.08)}
  to  {filter:drop-shadow(0 0 40px rgba(255,107,26,.75)) drop-shadow(0 0 80px rgba(26,122,255,.35)) drop-shadow(0 0 7px rgba(255,255,255,.5)) brightness(1.14)}
}
nav.stuck .nav-logo-png{height:82px}
nav.stuck .nav-logo{margin-top:0}

/* ── Nav links ── */
.nav-links{display:flex;gap:.4rem;list-style:none;align-items:center}
.nav-links > li > a,
.nav-links > li > .nav-dropdown-trigger {
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  position:relative;
  padding:.45rem .85rem;
  border-radius:2px;
  transition:color .22s, background .22s;
  display:flex;align-items:center;gap:.35rem;
}
.nav-links > li > a::after,
.nav-links > li > .nav-dropdown-trigger::after { display:none !important }

/* Hover : fond orangé doux + texte blanc */
.nav-links > li > a:hover,
.nav-links > li > .nav-dropdown-trigger:hover,
.nav-links > li.has-dropdown:hover > .nav-dropdown-trigger {
  color:#fff;
  background:rgba(255,107,26,.18);
}
/* Accueil et items simples */
.nav-links > li > a:not(.nav-dropdown-trigger):hover {
  color:#fff;
  background:rgba(255,107,26,.18);
}
.nav-cta{background:var(--orange);padding:.52rem 1.4rem;border-radius:1px;color:#fff !important;font-size:.78rem !important;letter-spacing:.1em !important;transition:background .3s,transform .2s !important}
.nav-cta::after{display:none !important}
.nav-cta:hover{background:#d95800 !important;transform:translateY(-1px)}

/* ═══════════════════════════
   HERO SLIDER
═══════════════════════════ */
#hero{height:100vh;min-height:680px;position:relative;display:flex;align-items:center;overflow:hidden}

/* Piste de slides — glissement horizontal */
.hero-track{
  position:absolute;inset:0;z-index:2;
  display:flex;
  width:100%;height:100%;
  transition:transform .9s var(--e2);
  will-change:transform;
}

.hero-slide{
  position:relative;
  flex:0 0 100%;
  width:100%;height:100%;
  display:flex;align-items:center;
  overflow:hidden;
}

.hero-photo{
  position:absolute;inset:-10%;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  filter:brightness(.95) saturate(1.1) hue-rotate(-2deg);
  will-change:transform;
}

/* Vidéo de fond hero — même comportement que hero-photo */
.hero-video {
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  filter:brightness(.95) saturate(1.1);
  pointer-events:none;
  z-index:0;
}

/* Le dégradé, la grille et les orbes restent communs à tout le hero (pas par slide) */
.hero-grad{
  position:absolute;inset:0;z-index:3;pointer-events:none;
  background:
    linear-gradient(105deg, rgba(10,31,92,.18) 0%, rgba(10,31,92,.08) 40%, transparent 70%),
    linear-gradient(to top, rgba(10,31,92,.22) 0%, transparent 35%);
}

.hero-grid{
  position:absolute;inset:0;z-index:3;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.028) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px);
  background-size:65px 65px;
  animation:gdrift 22s linear infinite;
  mask-image:radial-gradient(ellipse 80% 100% at 30% 50%,black 0%,transparent 100%);
  will-change:transform;
}
@keyframes gdrift{to{transform:translateY(65px)}}

#hero-canvas{position:absolute;inset:0;z-index:3;pointer-events:none;opacity:.55}

.hero-orb-a{
  position:absolute;right:5%;top:50%;transform:translateY(-50%);
  width:min(55vw,640px);height:min(55vw,640px);border-radius:50%;
  background:radial-gradient(circle, rgba(15,122,75,.28) 0%, rgba(26,122,255,.12) 45%, transparent 70%);
  animation:orbA 10s ease-in-out infinite alternate;
  pointer-events:none;z-index:3;
}
@keyframes orbA{
  from{transform:translateY(-50%) scale(1);opacity:.65}
  to{transform:translateY(-53%) scale(1.1);opacity:.9}
}
.hero-orb-b{
  position:absolute;left:-8%;bottom:-15%;
  width:min(40vw,480px);height:min(40vw,480px);border-radius:50%;
  background:radial-gradient(circle, rgba(255,107,26,.15) 0%, transparent 65%);
  animation:orbB 13s ease-in-out infinite alternate;
  pointer-events:none;z-index:3;
}
@keyframes orbB{
  from{transform:scale(1) rotate(0deg);opacity:.4}
  to{transform:scale(1.15) rotate(5deg);opacity:.65}
}

.hero-ring{position:absolute;right:-5%;top:50%;transform:translateY(-50%);width:min(52vw,620px);height:min(52vw,620px);border-radius:50%;border:1px solid rgba(255,255,255,.06);animation:ringSpin 55s linear infinite;pointer-events:none;z-index:3}
.hero-ring2{position:absolute;right:3%;top:50%;transform:translateY(-50%);width:min(34vw,400px);height:min(34vw,400px);border-radius:50%;border:1px solid rgba(255,107,26,.09);animation:ringSpin 32s linear infinite reverse;pointer-events:none;z-index:3}
.hero-ring3{position:absolute;right:10%;top:50%;transform:translateY(-50%);width:min(20vw,230px);height:min(20vw,230px);border-radius:50%;border:1px solid rgba(15,122,75,.14);animation:ringSpin 20s linear infinite;pointer-events:none;z-index:3}
@keyframes ringSpin{to{transform:translateY(-50%) rotate(360deg)}}

/* hero-clip supprimé */

.hero-inner{position:relative;z-index:4;padding:0 6%;width:100%;max-width:100%;transform-origin:center center;will-change:transform,opacity}

.hero-h1{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(2.6rem, 5.5vw, 6rem);
  font-weight:900;line-height:.95;letter-spacing:-.025em;
  white-space:nowrap;
  transform-origin:left center;
  will-change:transform;
}
@media(max-width:900px){.hero-h1{font-size:clamp(2rem,7vw,3.5rem);white-space:normal}}

.h1-orange{color:var(--orange)}
.h1-stroke{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.4);font-size:.88em;letter-spacing:0}

.hl{display:block;overflow:visible}
.hl span{display:inline-block;opacity:0;transform:translateY(110%);will-change:transform}

/* Animation d'entrée du titre — rejouée uniquement sur la slide active */
.hero-slide.active .hl-1 span{animation:lup .9s .42s var(--e2) forwards !important}
.hero-slide.active .hl-2 span{animation:lup .9s .62s var(--e2) forwards !important}
.hero-slide.active .hl-3 span{animation:lup .9s .82s var(--e2) forwards !important}
@keyframes lup{to{opacity:1;transform:translateY(0)}}

.hero-slide.active .hero-h1{animation:titleGlow 5s 2.2s ease-in-out infinite}
@keyframes titleGlow{
  0%,100%{text-shadow:none}
  50%{text-shadow:0 0 80px rgba(255,107,26,.22),0 0 160px rgba(26,122,255,.12)}
}

.hero-tagline{
  max-width:640px;margin-top:0.9rem;
  font-family:'Poppins',sans-serif;
  font-size:clamp(1rem,1.5vw,1.15rem);
  font-weight:300;line-height:1.9;
  color:rgba(255,255,255,.6);letter-spacing:.015em;
  opacity:0;
}
.hero-slide.active .hero-tagline{animation:fadeUp .9s 1.08s var(--e1) forwards}
.hero-tagline strong{color:rgba(255,255,255,.88);font-weight:600}
@media(max-width:700px){.hero-tagline{font-size:.8rem}.br-desk{display:none}}

.hero-btns{margin-top:1rem;display:flex;gap:1.2rem;flex-wrap:wrap;opacity:0}
.hero-slide.active .hero-btns{animation:fadeUp .8s 1.48s var(--e1) forwards}
.btn-fill{display:inline-flex;align-items:center;gap:.6rem;background:var(--orange);color:#fff;padding:.95rem 2.2rem;border-radius:1px;font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s}
.btn-fill::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,.14);transform:skewX(-20deg) translateX(-130%);transition:transform .5s var(--e1)}
.btn-fill:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(255,107,26,.5)}
.btn-fill:hover::before{transform:skewX(-20deg) translateX(130%)}
.btn-fill.g{background:var(--green)}.btn-fill.g:hover{box-shadow:0 10px 32px rgba(15,122,75,.45)}
.btn-out{display:inline-flex;align-items:center;gap:.5rem;border:1px solid rgba(255,255,255,.3);color:rgba(255,255,255,.7);padding:.92rem 1.8rem;border-radius:1px;font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;transition:border-color .3s,color .3s,background .3s}
.btn-out:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.05)}
.arr{display:inline-block;transition:transform .3s var(--e1)}
.btn-fill:hover .arr,.btn-out:hover .arr{transform:translateX(4px)}

.h-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;opacity:0;animation:fadeUp .8s 2s var(--e1) forwards;z-index:5}
.scroll-m{width:22px;height:34px;border:1.5px solid rgba(255,255,255,.22);border-radius:12px;display:flex;justify-content:center;padding-top:6px}
.scroll-d{width:3px;height:7px;background:#fff;border-radius:2px;animation:sd 2s ease-in-out infinite}
@keyframes sd{0%,100%{opacity:1;transform:translateY(0)}50%{opacity:.3;transform:translateY(8px)}}
.scroll-t{font-family:'Montserrat',sans-serif;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.25)}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* Dots de navigation du hero slider */
.hero-dots{
  position:absolute;bottom:2.2rem;right:6%;z-index:5;
  display:flex;align-items:center;gap:.6rem;
}
.hero-dot{
  width:10px;height:10px;border-radius:50%;
  background:rgba(255,255,255,.2);border:1.5px solid rgba(255,255,255,.35);
  cursor:pointer;padding:0;transition:all .3s var(--e1);
}
.hero-dot:hover{background:rgba(255,255,255,.4)}
.hero-dot.active{
  background:var(--orange);border-color:var(--orange);
  width:28px;border-radius:6px;
}
@media(max-width:700px){
  .hero-dots{right:50%;transform:translateX(50%);bottom:1.2rem}
  .h-scroll{display:none}
}

/* ═══════════════════════════
   TICKER
═══════════════════════════ */
.ticker{background:var(--orange);overflow:hidden;padding:.75rem 0;position:relative;z-index:2}
.ticker-t{display:inline-flex;white-space:nowrap;animation:tickRun 32s linear infinite}
.ticker-t span{font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:0 2.2rem}
.ticker-t .sep{opacity:.45;padding:0}
@keyframes tickRun{to{transform:translateX(-50%)}}

/* ═══════════════════════════
   STAT BAND
═══════════════════════════ */
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);background:var(--navy-dark)}
.stat-band .sc{padding:1.2rem 1.5rem;text-align:center;border-right:1px solid rgba(255,255,255,.06);position:relative;overflow:hidden;transition:background .4s}
.stat-band .sc:last-child{border-right:0}
.stat-band .sc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--orange),var(--green));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--e2)}
.stat-band .sc:hover{background:rgba(255,255,255,.03)}
.stat-band .sc:hover::after{transform:scaleX(1)}
.sc-n{font-family:'Montserrat',sans-serif;font-size:clamp(2.5rem,4.5vw,3.8rem);font-weight:900;line-height:1;color:#fff}
.sc-sf{font-size:.6em;color:var(--orange);vertical-align:top;margin-top:.2em;display:inline-block}
.sc-l{font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.32);margin-top:.55rem;transition:color .4s}
.stat-band .sc:hover .sc-l{color:rgba(255,255,255,.55)}

/* ═══════════════════════════
   COMPOSANTS COMMUNS
═══════════════════════════ */
/* ══════════════════════════════════════════════════════
   HIÉRARCHIE TYPOGRAPHIQUE — du plus petit au plus grand
   Eyebrow .52 → Tag .58 → Desc/Excerpt .80 → Sous-titre .90 → Titre carte 1.05 → H2 clamp(2.2,4.2vw,3.8)
══════════════════════════════════════════════════════ */

/* Niveau 0 : Eyebrow (catégorie de section) */
.ew{font-family:'Montserrat',sans-serif;font-size:.52rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;display:flex;align-items:center;gap:.7rem;margin-bottom:.8rem}
.ew-o{color:var(--orange)}
.ew-g{color:var(--green2)}
.ew-w{color:rgba(255,255,255,.5)}
.ew-dk{color:var(--green)}

/* Niveau 1 : H2 principal de section */
h2.st{font-family:'Montserrat',sans-serif;font-size:clamp(2.2rem,4.2vw,3.8rem);font-weight:900;line-height:.97;letter-spacing:-.02em;margin-bottom:0}
.st-w{color:#fff}.st-d{color:var(--navy-dark)}.st-o{color:var(--orange)}.st-g{color:var(--green2)}
.sti{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;color:transparent;font-size:.88em;letter-spacing:0}
.sti-w{-webkit-text-stroke:1.5px rgba(255,255,255,.4)}
.sti-d{-webkit-text-stroke:1.5px rgba(2,8,25,.3)}
.btn-navy{background:var(--navy);color:#fff;padding:.88rem 1.8rem;border-radius:1px;font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;transition:background .3s,transform .2s}
.btn-navy:hover{background:var(--navy-light);transform:translateY(-2px)}
.btn-green{background:var(--green);color:#fff;padding:.88rem 1.8rem;border-radius:1px;font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;transition:background .3s,transform .2s}
.btn-green:hover{background:#0a6040;transform:translateY(-2px)}
.btn-secondary{border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.6);padding:.7rem 1.5rem;border-radius:1px;font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;transition:border-color .3s,color .3s}
.btn-secondary:hover{border-color:rgba(255,255,255,.5);color:#fff}
.sr{opacity:0;transform:translateY(32px);transition:opacity .8s var(--e1),transform .8s var(--e1)}
.sr.vis{opacity:1;transform:translateY(0)}

/* ═══════════════════════════
   PARTENAIRES
═══════════════════════════ */
#partners{background:#f8f9fc;padding:4rem 0 3rem;position:relative}
#partners::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--orange),var(--electric),var(--green2))}
.pt-head{text-align:center;margin-bottom:2.8rem;padding:0 5%}
.pt-eyebrow{font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;justify-content:center;gap:.8rem;margin-bottom:.7rem}
.pt-eyebrow::before,.pt-eyebrow::after{content:'';width:24px;height:1px;background:var(--orange)}
.pt-title{font-family:'Montserrat',sans-serif;font-size:clamp(1.8rem,3.5vw,3rem);font-weight:900;line-height:.97;letter-spacing:-.02em;color:var(--navy-dark)}
.pt-title span{color:var(--orange)}
.pt-sub{font-size:.88rem;font-weight:300;color:#6a6a8a;margin-top:.7rem;max-width:480px;margin-inline:auto;line-height:1.7}
.pt-slider-wrap{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%)}
.pt-track{display:flex;align-items:center;width:max-content;gap:10px;padding:10px 0 20px;animation:ptScroll 36s linear infinite;will-change:transform}
.pt-track:hover{animation-play-state:paused}
@keyframes ptScroll{0%{transform:translateX(0)}100%{transform:translateX(calc(-50% - 6px))}}
.pt-card{display:flex;align-items:center;gap:0;height:120px;width:120px;flex-shrink:0;background:#fff;border-radius:18px;border:1.5px solid #e4e7f2;box-shadow:0 3px 16px rgba(12,38,113,.07);overflow:hidden;cursor:pointer;transition:width .52s var(--e2),border-color .3s,box-shadow .3s}
.pt-card:hover{width:380px;border-color:rgba(255,107,26,.4);box-shadow:0 10px 40px rgba(255,107,26,.14)}
.pt-card-logo{width:120px;height:120px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:18px;background:#fff}
.pt-card-logo img{width:100%;height:100%;object-fit:contain;display:block}
.pt-card-logo-txt{font-family:'Montserrat',sans-serif;font-size:.75rem;font-weight:900;color:var(--navy);text-align:center;line-height:1.25}
.pt-card-sep{width:1px;height:60px;flex-shrink:0;background:linear-gradient(to bottom,transparent,#d8ddf0,transparent);opacity:0;transition:opacity .3s .08s}
.pt-card:hover .pt-card-sep{opacity:1}
.pt-card-text{display:flex;flex-direction:column;gap:.28rem;padding:0 1.4rem;min-width:0;overflow:hidden;opacity:0;transform:translateX(-10px);transition:opacity .38s .1s,transform .38s .1s var(--e3)}
.pt-card:hover .pt-card-text{opacity:1;transform:translateX(0)}
.pt-card-tag{font-family:'Montserrat',sans-serif;font-size:.5rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);white-space:nowrap}
.pt-card-name{font-family:'Montserrat',sans-serif;font-size:.95rem;font-weight:800;color:var(--navy-dark);white-space:nowrap;line-height:1.2}
.pt-card-desc{font-size:.75rem;font-weight:300;color:#01010c;line-height:1.45;white-space:normal;max-width:220px}
@media(max-width:600px){.pt-card{height:96px;width:96px}.pt-card:hover{width:280px}.pt-card-logo{width:96px;height:96px;padding:14px}}

/* ═══════════════════════════
   PILIERS
═══════════════════════════ */
#pillars{background:#080e1c;padding:0}
.pillars-header{padding:var(--sp-hd);margin-bottom:30px}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.pill{position:relative;height:520px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:2rem}
.pill-photo{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .8s var(--e1),filter .6s}
.pill:hover .pill-photo{transform:scale(1.07);filter:brightness(.25)}
.pill::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,31,92,.97) 0%,rgba(10,31,92,.6) 50%,rgba(10,31,92,.1) 100%);z-index:1;transition:opacity .5s}
.pill-num{position:absolute;top:2rem;left:2.5rem;z-index:2;font-family:'Montserrat',sans-serif;font-size:.5rem;font-weight:700;letter-spacing:.22em;color:rgba(255,255,255,.35)}
.pill-content{position:relative;z-index:2}
.pill-tag{font-family:'Montserrat',sans-serif;font-size:.56rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--green2);margin-bottom:.8rem}
.pill:nth-child(2) .pill-tag{color:var(--green2)}
.pill:nth-child(3) .pill-tag{color:var(--green2)}
.pill-title{font-family:'Montserrat',sans-serif;font-size:1.15rem;font-weight:800;line-height:1.15;margin-bottom:.7rem;color:#fff}
.pill-desc{font-size:.80rem;font-weight:300;color:rgba(255,255,255,.85);line-height:1.85;max-height:0;overflow:hidden;transition:max-height .5s var(--e1),opacity .5s}
.pill:hover .pill-desc{max-height:120px;opacity:1}
.pill-arrow{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);transition:color .3s,gap .3s}
.pill:hover .pill-arrow{color:var(--g2);gap:.7rem}

/* ═══════════════════════════
   ENCHANT
═══════════════════════════ */
#enchant{display:grid;grid-template-columns:1fr 1fr;min-height:85vh}
.enc-vis{position:relative;overflow:hidden}
.enc-photo{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transition:transform 12s linear}
#enchant:hover .enc-photo{transform:scale(1.04)}
.enc-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,31,92,.88) 0%,rgba(12,80,40,.65) 100%)}
.enc-vis-inner{position:relative;z-index:2;padding:var(--sp);height:100%;display:flex;flex-direction:column;justify-content:flex-end}
.enc-bignum{font-family:'Cormorant Garamond',serif;font-size:14rem;font-weight:700;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.07);position:absolute;bottom:-2rem;left:-1rem;user-select:none;pointer-events:none;animation:numD 14s ease-in-out infinite alternate}
@keyframes numD{from{transform:rotate(-1deg)}to{transform:rotate(1.5deg)}}
.enc-quote{font-family:'Cormorant Garamond',serif;font-size:clamp(1.75rem,2.8vw,2.6rem);font-style:italic;font-weight:400;color:rgba(255,255,255,.9);line-height:1.45;max-width:460px}
.enc-author{margin-top:1.5rem;font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.38)}
.enc-right{background:var(--off);padding:var(--sp);display:flex;flex-direction:column;justify-content:center}
.enc-right .ew-dk{color:var(--green)}.enc-right .ew-dk::before{background:var(--green)}
.enc-right h2.st{color:var(--navy-dark)}
.enc-body{margin-top:1rem;font-size:.95rem;font-weight:300;line-height:1.85;color:#4a4a6a;text-align:left}
.enc-list{margin-top:1.4rem;display:flex;flex-direction:column;gap:0}
.enc-li{display:flex;align-items:flex-start;gap:1.2rem;padding:1rem 0;border-bottom:1px solid rgba(12,38,113,.08);transition:padding-left .3s var(--e1)}
.enc-li:hover{padding-left:.5rem}
.enc-li-line{width:2px;min-height:100%;background:var(--green2);flex-shrink:0;align-self:stretch;opacity:.7;transition:background .3s}
.enc-li-title{font-family:'Montserrat',sans-serif;font-size:1.05rem;font-weight:700;color:var(--navy-dark);margin-bottom:.2rem}
.enc-li-desc{font-size:.80rem;font-weight:300;color:#555;line-height:1.7;text-align:left}
.enc-btns{margin-top:1.4rem;display:flex;gap:1rem}

/* ═══════════════════════════
   SERVICES
═══════════════════════════ */
#services{background:var(--k2);padding:var(--sp)}
.srv-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.2rem;flex-wrap:wrap;gap:1.5rem}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

/* NOTE : .sc dans .srv-grid uniquement — ne pas confondre avec .stat-band .sc */
.srv-grid .sc{
  background:var(--k3);border:1px solid rgba(255,255,255,.06);
  padding:1.5rem 1.6rem;
  position:relative;overflow:hidden;
  transform-style:preserve-3d;perspective:800px;
  opacity:0;transform:translateY(25px);
  transition:opacity .7s var(--e1),transform .7s var(--e1),box-shadow .4s,border-color .4s;
}
.srv-grid .sc.vis{opacity:1;transform:translateY(0)}
.srv-grid .sc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--o1),var(--o1));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--e2)}
.srv-grid .sc:hover::before{transform:scaleX(1)}
.srv-grid .sc:hover{border-color:rgba(255,107,26,.2);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.sc-photo{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .6s var(--e1)}
.srv-grid .sc:hover .sc-photo{opacity:.08}
.sc-bgn{position:absolute;bottom:-.5rem;right:.5rem;font-family:'Montserrat',sans-serif;font-size:7rem;font-weight:900;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.04);line-height:1;pointer-events:none;user-select:none;transition:-webkit-text-stroke .4s}
.srv-grid .sc:hover .sc-bgn{-webkit-text-stroke:1px rgba(255,255,255,.1)}
.sc-inner{position:relative;z-index:1}
.sc-num{font-family:'Montserrat',sans-serif;font-size:.5rem;font-weight:700;letter-spacing:.25em;color:var(--g2);margin-bottom:.9rem;display:flex;align-items:center;gap:.5rem}
.sc-num::before{content:'';width:18px;height:1px;background:var(--g2)}
.sc-title{font-family:'Montserrat',sans-serif;font-size:1.05rem;font-weight:700;color:var(--w);margin-bottom:.6rem;line-height:1.2}
.sc-desc{font-size:.80rem;font-weight:300;color:rgba(255,255,255,.85);line-height:1.78}
.sc-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.2rem;font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.28);transition:color .3s,gap .3s}
.srv-grid .sc:hover .sc-link{color:var(--green2);gap:.7rem}

/* Carte full-width */
.sc-full{
  grid-column:span 3;
  display:block;  /* même structure que .sc normal, pas de grid */
  padding:0;
  background:linear-gradient(135deg,var(--b1) 0%,var(--b2) 60%,var(--b3) 100%);
  border-color:rgba(26,122,255,.15);
}
.sc-full::before{background:linear-gradient(90deg,rgba(255,255,255,.08),rgba(255,255,255,.02))}
.sc-full .sc-inner{padding:1.6rem}
.sc-full .sc-title,.sc-full .sc-link{color:var(--w)}
.sc-full .sc-desc{color:rgba(255,255,255,.75)}
.sc-full .sc-link{color:rgba(255,255,255,.3)}
.sc-full:hover .sc-link{color:var(--green2)}
/* Image en fond très subtil sur toute la carte (comme .sc-photo sur les autres) */
.sc-full-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;
  transition:opacity .6s var(--e1);
  pointer-events:none;
}
.sc-full:hover .sc-full-img{opacity:.08}

/* ═══════════════════════════
   BLOG / ACTUALITÉS
═══════════════════════════ */
#blog{background:#060c1a;padding:var(--sp)}
.blog-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.4rem}
.blog-header-left{}
.blog-nav{display:flex;align-items:center;gap:.8rem}
.blog-arrow{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,color .2s,border-color .2s;
}
.blog-arrow:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.blog-nav-counter{
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.1em;color:rgba(255,255,255,.4);
  min-width:36px;text-align:center;
}
.blog-slider-wrap{overflow:hidden}
.blog-slider{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-footer{display:flex;justify-content:center;margin-top:2rem}
.blog-see-all{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--orange);border:1px solid rgba(255,107,26,.35);
  padding:.65rem 1.6rem;transition:background .2s,color .2s,border-color .2s;
}
.blog-see-all:hover{background:var(--orange);color:#fff;border-color:var(--orange)}
.bc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);overflow:hidden;transition:transform .3s,border-color .3s}
.bc:hover{transform:translateY(-5px);border-color:rgba(255,107,26,.25)}
.bc-img{height:200px;background-size:cover !important;background-position:center !important;transition:transform .6s var(--e1)}
.bc:hover .bc-img{transform:scale(1.05)}
.bc-body{padding:1.2rem}
.bc-tag{font-family:'Montserrat',sans-serif;font-size:.52rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--orange);display:inline-block;margin-bottom:.7rem}
.bc-title{font-family:'Montserrat',sans-serif;font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.5rem;line-height:1.3}
.bc-excerpt{font-size:.80rem;font-weight:300;color:rgba(255,255,255,.75);line-height:1.75;margin-bottom:1rem}
.bc-link{font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(216, 135, 13, 0.856);display:flex;align-items:center;gap:.4rem;transition:color .3s,gap .3s}
.bc:hover .bc-link{color:var(--green2);gap:.7rem}

/* ═══════════════════════════
   MISSION
═══════════════════════════ */
#mission{display:grid;grid-template-columns:1fr 1fr;min-height:80vh}
.ms-photo{position:relative;overflow:hidden}
.ms-photo-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transition:transform 12s linear}
#mission:hover .ms-photo-bg{transform:scale(1.04)}
.ms-photo-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,31,92,.92) 0%,rgba(12,38,113,.75) 50%,rgba(15,80,40,.6) 100%)}
.ms-photo-inner{position:relative;z-index:2;padding:var(--sp);height:100%;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.ms-ci-map-wrap{width:100%;display:flex;justify-content:center;margin-bottom:1rem}
.ms-ci-frame{position:relative;width:100%;max-width:360px;border-radius:4px;overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.08), 0 24px 60px rgba(0,0,0,.5);animation:mapLift 10s ease-in-out infinite alternate}
@keyframes mapLift{from{transform:translateY(0) scale(1)}to{transform:translateY(-6px) scale(1.01)}}
.ms-ci-frame-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(10,31,92,.6) 0%, transparent 40%),linear-gradient(to bottom, rgba(10,31,92,.3) 0%, transparent 30%);pointer-events:none}
.ms-abidjan-dot{position:absolute;bottom:14%;right:18%;display:flex;align-items:center;gap:.5rem;z-index:2}
.ms-abidjan-pulse{width:12px;height:12px;border-radius:50%;background:var(--orange);flex-shrink:0;box-shadow:0 0 0 0 rgba(255,107,26,.6);animation:abPulse 2s ease-in-out infinite}
@keyframes abPulse{0%{box-shadow:0 0 0 0 rgba(255,107,26,.7)}70%{box-shadow:0 0 0 14px rgba(255,107,26,0)}100%{box-shadow:0 0 0 0 rgba(255,107,26,0)}}
.ms-abidjan-label{font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.9);line-height:1.2}
.ms-abidjan-label small{font-size:.55rem;font-weight:400;opacity:.7;display:block}
.ms-bignum{font-family:'Cormorant Garamond',serif;font-size:clamp(8rem,14vw,13rem);font-weight:700;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.06);position:absolute;bottom:-2rem;left:-1rem;user-select:none;pointer-events:none}
.ms-content{background:var(--off);padding:var(--sp);display:flex;flex-direction:column;justify-content:center}
.ms-content .ew-dk{color:var(--green)}.ms-content .ew-dk::before{background:var(--green)}
.ms-content h2.st{color:var(--navy-dark)}
.ms-bq{margin-top:1rem;border-left:3px solid var(--green);background:#fff;padding:1rem 1.4rem;box-shadow:0 4px 24px rgba(12,38,113,.07)}
.ms-bq p{font-size:1.05rem;font-weight:400;line-height:1.9;color:#4a4a6a;font-style:italic}
.ms-bq2{margin-top:1rem;border-left:3px solid var(--orange);background:#fff;padding:1.2rem 1.8rem;box-shadow:0 4px 24px rgba(12,38,113,.07)}
.ms-bq2-lbl{font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);margin-bottom:.35rem}
.ms-bq2 p{font-size:1rem;color:#444;line-height:1.85}
.ms-vals{margin-top:0.9rem;display:grid;grid-template-columns:1fr 1fr;gap:.6rem 1.5rem}
.ms-v{display:flex;align-items:center;gap:.6rem;font-family:'Montserrat',sans-serif;font-size:.85rem;font-weight:700;color:var(--navy-dark)}
.ms-v::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--orange);flex-shrink:0}
.ms-btns{margin-top:1rem;display:flex;gap:1rem}

/* ═══════════════════════════
   CIBLES
═══════════════════════════ */
#cibles{background:#080e1c;padding:var(--sp)}
.cib-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.05);margin-top:1.2rem}
.cib{background:var(--navy-dark);padding:1.5rem 1.8rem;position:relative;overflow:hidden;opacity:0;transform:translateY(20px);transition:opacity .6s var(--e1),transform .6s var(--e1),background .4s}
.cib.vis{opacity:1;transform:translateY(0)}
.cib-photo{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .6s var(--e1)}
.cib:hover .cib-photo{opacity:.12}
.cib::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--e2)}
.cib:hover::after{transform:scaleX(1)}
.cib-inner{position:relative;z-index:1}
.cib-who{font-family:'Montserrat',sans-serif;font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:.3rem}
.cib-need{font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--green2);margin-bottom:.8rem}
.cib:nth-child(2) .cib-need{color:var(--green2)}
.cib:nth-child(3) .cib-need,.cib:nth-child(6) .cib-need{color:var(--green2)}
.cib-msg{font-size:1rem;font-weight:300;color:rgba(255,255,255,.963);line-height:1.9}

/* ═══════════════════════════
   PROCESSUS
═══════════════════════════ */
#process{background:var(--off);padding:var(--sp)}
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:1.2rem;position:relative}
.proc::before{content:'';position:absolute;top:28px;left:12%;right:12%;height:1px;background:linear-gradient(90deg,transparent,rgba(12,38,113,.15) 20%,rgba(12,38,113,.15) 80%,transparent)}
.ps{padding:0 1.5rem;text-align:center;opacity:0;transform:translateY(20px);transition:opacity .7s var(--e1),transform .7s var(--e1)}
.ps.vis{opacity:1;transform:translateY(0)}
.ps-dot{width:56px;height:56px;border-radius:50%;border:1.5px solid rgba(12,38,113,.15);background:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 4px 20px rgba(12,38,113,.08);transition:background .4s,border-color .4s,transform .4s var(--e3)}
.ps:hover .ps-dot{background:var(--navy);border-color:var(--navy);transform:scale(1.12)}
.ps-dot-n{font-family:'Montserrat',sans-serif;font-size:.75rem;font-weight:900;color:var(--navy);transition:color .4s}
.ps:hover .ps-dot-n{color:#fff}
.ps-title{font-family:'Montserrat',sans-serif;font-size:1.12rem;font-weight:700;color:var(--navy-dark);margin-bottom:.6rem}
.ps-desc{font-size:1rem;font-weight:300;color:#100202;line-height:1.82}
.ps:nth-child(2){transition-delay:.1s}.ps:nth-child(3){transition-delay:.2s}.ps:nth-child(4){transition-delay:.3s}

/* ═══════════════════════════
   ROADMAP
═══════════════════════════ */
#roadmap{background:#fff;padding:var(--sp)}
.rmap{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:rgba(12,38,113,.08);margin-top:1.2rem;border:1px solid rgba(12,38,113,.08)}
.rm{background:#fff;padding:1.2rem 1.4rem;position:relative;overflow:hidden;opacity:0;transform:translateY(18px);transition:opacity .6s var(--e1),transform .6s var(--e1),background .4s}
.rm.vis{opacity:1;transform:translateY(0)}
.rm:hover{background:var(--off)}
.rm::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--e2)}
.rm:hover::before{transform:scaleX(1)}
.rm-p{font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--orange);margin-bottom:.7rem}
.rm-t{font-family:'Montserrat',sans-serif;font-size:1.05rem;font-weight:700;color:var(--navy-dark);margin-bottom:.6rem;line-height:1.3}
.rm-b{font-size:.96rem;font-weight:300;color:#080202;line-height:1.8}
.rm:nth-child(2){transition-delay:.07s}.rm:nth-child(3){transition-delay:.14s}.rm:nth-child(4){transition-delay:.21s}.rm:nth-child(5){transition-delay:.28s}

/* ═══════════════════════════
   VALEURS
═══════════════════════════ */
#valeurs{position:relative;padding:var(--sp);overflow:hidden}
.val-photo-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;filter:brightness(.12) saturate(1.1)}
.val-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,31,92,.97) 0%,rgba(10,50,30,.9) 100%)}
.val-inner{position:relative;z-index:2}
.val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.05);margin-top:1rem}
.vc{background:rgba(5,10,22,.7);padding:1.5rem 1.6rem;backdrop-filter:blur(4px);opacity:0;transform:translateY(20px);transition:opacity .6s var(--e1),transform .6s var(--e1),background .4s,border-left .4s;border-left:2px solid transparent}
.vc.vis{opacity:1;transform:translateY(0)}
.vc:hover{background:rgba(255,255,255,.04);border-left-color:var(--orange)}
.vc:nth-child(2):hover{border-left-color:var(--green2)}
.vc:nth-child(3):hover,.vc:nth-child(6):hover{border-left-color:var(--electric)}
.vc-title{font-family:'Montserrat',sans-serif;font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:.6rem}
.vc-desc{font-size:1rem;font-weight:300;color:rgba(255,255,255,.958);line-height:1.9}
.vc:nth-child(2){transition-delay:.08s}.vc:nth-child(3){transition-delay:.16s}.vc:nth-child(4){transition-delay:.1s}.vc:nth-child(5){transition-delay:.18s}.vc:nth-child(6){transition-delay:.26s}

/* ═══════════════════════════
   SCROLL REVEAL TEXT
═══════════════════════════ */
#reveal-sec{padding:var(--sp);background:var(--navy-dark);border-top:1px solid rgba(255,255,255,.05)}
.big-rv{font-family:'Montserrat',sans-serif;font-size:clamp(1.8rem,4vw,4rem);font-weight:900;line-height:1.12;text-align:center;color:#fff}
.rv-w{display:inline-block;margin:0 .15em;opacity:.09;transition:opacity .55s var(--e1),color .55s}
.rv-w.lit{opacity:1}
.rv-w.c-o{color:var(--orange)}.rv-w.c-g{color:var(--green2)}

/* ═══════════════════════════
   CONTACT
═══════════════════════════ */
#contact{background:var(--navy-dark)}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;min-height:480px}
.ct-info{background:rgba(255,255,255,.02);padding:var(--sp);display:flex;flex-direction:column;justify-content:center}
.ct-info h2{font-family:'Montserrat',sans-serif;font-size:clamp(1.8rem,3vw,2.8rem);font-weight:900;color:#fff;letter-spacing:-.02em;line-height:1.05;margin-bottom:1rem}
.ct-info h2 span{color:var(--orange)}
.ct-rows{display:flex;flex-direction:column;gap:1.2rem}
.ct-row{display:flex;align-items:flex-start;gap:.9rem}
.ct-bar{width:18px;height:1.5px;background:var(--orange);flex-shrink:0;margin-top:.6rem}
.ct-lbl{font-family:'Montserrat',sans-serif;font-size:.5rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--orange);margin-bottom:.2rem}
.ct-val{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.6}
.ct-socials{display:flex;gap:.7rem;margin-top:1rem}
.ct-socials-inline{display:flex;gap:.7rem;margin-top:.5rem}
.cs{width:40px;height:40px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;transition:transform .25s,box-shadow .25s;flex-shrink:0}
.cs:hover{transform:translateY(-3px)}
.cs.li{background:#0077b5;box-shadow:0 4px 14px rgba(0,119,181,.4)}
.cs.li:hover{box-shadow:0 8px 22px rgba(0,119,181,.6)}
.cs.tw{background:#000;box-shadow:0 4px 14px rgba(0,0,0,.35)}
.cs.tw:hover{box-shadow:0 8px 22px rgba(0,0,0,.55)}
.cs.fb{background:#1877f2;box-shadow:0 4px 14px rgba(24,119,242,.4)}
.cs.fb:hover{box-shadow:0 8px 22px rgba(24,119,242,.6)}
.cs.yt{background:#ff0000;box-shadow:0 4px 14px rgba(255,0,0,.4)}
.cs.yt:hover{box-shadow:0 8px 22px rgba(255,0,0,.6)}
.cs.wa{background:#25d366;box-shadow:0 4px 14px rgba(37,211,102,.4)}
.cs.wa:hover{box-shadow:0 8px 22px rgba(37,211,102,.6)}
.ct-map{position:relative;overflow:hidden;min-height:420px}
.ct-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:invert(.9) hue-rotate(180deg) saturate(.7) brightness(.75)}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}.ct-map{min-height:300px}}

/* ═══════════════════════════
   FOOTER
═══════════════════════════ */
footer{background:linear-gradient(175deg,#03080f 0%,#060e1f 100%);border-top:1px solid rgba(255,255,255,.06);position:relative}
.ft-inner{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:0;padding:3rem 4% 2.8rem 2%;border-bottom:1px solid rgba(255,255,255,.06)}
.ft-col{padding:0 2.2rem;border-right:1px solid rgba(255,255,255,.05)}
.ft-col:first-child{padding-left:0}
.ft-col:last-child{padding-right:0;border-right:none}
.ft-col-brand{display:flex;align-items:flex-start;padding-right:2.5rem}
.ft-brand-row{display:flex;align-items:center;gap:2rem;width:100%}
.ft-logo{width:400px;height:auto;flex-shrink:0;mix-blend-mode:normal;display:block;margin-left:-10px}
.ft-brand-row .ft-contact-list{border-left:1px solid rgba(255,255,255,.07);padding-left:2rem}
.ft-col-title{font-family:'Montserrat',sans-serif;font-size:.54rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.985);margin-bottom:1.3rem;padding-bottom:.55rem;border-bottom:1px solid rgba(255,255,255,.05)}
.ft-contact-list{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.ft-contact-list li{display:flex;align-items:center;gap:.6rem}
.ft-contact-list a,.ft-contact-list span{font-size:.8rem;color:rgba(255,255,255,.3);transition:color .22s}
.ft-contact-list a:hover{color:var(--orange)}
.ft-list{list-style:none;display:flex;flex-direction:column;gap:.65rem}
.ft-list a{font-size:.82rem;font-weight:300;color:rgba(255,255,255,.959);transition:color .2s,padding-left .2s;display:block}
.ft-list a:hover{color:#fff;padding-left:.4rem}
.ft-voir-plus{color:var(--orange) !important;font-weight:600 !important;font-size:.75rem !important;letter-spacing:.04em}
.ft-socials{display:flex;gap:.7rem;margin-top:1.2rem;margin-bottom:1.4rem}
.ft-soc{width:40px;height:40px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;transition:transform .25s,box-shadow .25s;flex-shrink:0}
.ft-soc:hover{transform:translateY(-3px)}
.ft-soc.li{background:#0077b5;box-shadow:0 4px 14px rgba(0,119,181,.4)}
.ft-soc.li:hover{box-shadow:0 8px 22px rgba(0,119,181,.6)}
.ft-soc.tw{background:#000;box-shadow:0 4px 14px rgba(0,0,0,.35)}
.ft-soc.tw:hover{box-shadow:0 8px 22px rgba(0,0,0,.55)}
.ft-soc.fb{background:#1877f2;box-shadow:0 4px 14px rgba(24,119,242,.4)}
.ft-soc.fb:hover{box-shadow:0 8px 22px rgba(24,119,242,.6)}
.ft-soc.yt{background:#ff0000;box-shadow:0 4px 14px rgba(255,0,0,.4)}
.ft-soc.yt:hover{box-shadow:0 8px 22px rgba(255,0,0,.6)}
.ft-soc.wa{background:#25d366;box-shadow:0 4px 14px rgba(37,211,102,.4)}
.ft-soc.wa:hover{box-shadow:0 8px 22px rgba(37,211,102,.6)}
.fsoc{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;color:rgba(255,255,255,.9);transition:all .25s var(--e1);text-decoration:none}
.fsoc:hover{transform:translateY(-2px)}
.fsoc.li:hover{background:#0077b5;border-color:#0077b5;color:#fff;box-shadow:0 4px 12px rgba(0,119,181,.3)}
.fsoc.tw:hover{background:#111;border-color:#444;color:#fff}
.fsoc.fb:hover{background:#1877f2;border-color:#1877f2;color:#fff;box-shadow:0 4px 12px rgba(24,119,242,.3)}
.fsoc.yt:hover{background:#f00;border-color:#f00;color:#fff;box-shadow:0 4px 12px rgba(255,0,0,.3)}
.ft-tagline{font-size:.76rem;font-weight:300;color:rgba(255,255,255,.921);line-height:1.8}
.ft-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.8rem;padding:.95rem 6%;background:rgba(0,0,0,.22)}
.ft-copy{font-family:'Montserrat',sans-serif;font-size:.58rem;color:rgba(255,255,255,.91)}
.ft-legal-links{display:flex;gap:1.3rem}
.ft-legal-links a{font-family:'Montserrat',sans-serif;font-size:.58rem;color:rgba(255,255,255,.874);transition:color .2s}
.ft-legal-links a:hover{color:rgba(255,255,255,.5)}

/* ═══════════════════════════
   RESPONSIVE
═══════════════════════════ */
@media(max-width:1100px){
  .pillars-grid{grid-template-columns:1fr}.pill{height:420px}
  #enchant,#mission{grid-template-columns:1fr}.enc-vis{min-height:400px}
  .srv-grid{grid-template-columns:1fr 1fr}
  .sc-full{grid-column:span 2}
  .cib-grid,.val-grid{grid-template-columns:repeat(2,1fr)}
  .rmap{grid-template-columns:repeat(2,1fr)}
  .proc{grid-template-columns:repeat(2,1fr);gap:3rem}.proc::before{display:none}
  .ft-inner{grid-template-columns:1fr 1fr;row-gap:2rem}
  .ft-col-brand{grid-column:span 2;border-right:none;padding-right:0;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:2rem}
  .ft-col:nth-child(3){border-right:none;padding-right:0}
  .ft-col:nth-child(4){padding-left:0}
}
@media(max-width:768px){
  .nav-links{display:none}
  .stat-band{grid-template-columns:repeat(2,1fr)}
  .cib-grid,.val-grid{grid-template-columns:1fr}
  .rmap{grid-template-columns:1fr}
  .srv-grid{grid-template-columns:1fr}
  .sc-full{grid-column:span 1;grid-template-columns:1fr}
  .blog-slider{grid-template-columns:1fr}
  .proc{grid-template-columns:1fr}
  .ft-inner{grid-template-columns:1fr;row-gap:1.8rem}
  .ft-col-brand{grid-column:span 1;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:1.8rem}
  .ft-brand-row{flex-direction:column;align-items:flex-start;gap:1.2rem}
  .ft-brand-row .ft-contact-list{border-left:none;padding-left:0}
  .ft-col{padding:0;border-right:none;padding-top:1.5rem}
  .ft-bar{flex-direction:column;align-items:flex-start}
}


/* ═══════════════════════════════════════════════════════════════
   MENU DÉROULANT — SERVICES
═══════════════════════════════════════════════════════════════ */

.nav-links li.has-dropdown { position:relative }

.nav-dropdown-trigger { display:flex;align-items:center;gap:.4rem;cursor:pointer }

.nav-arrow {
  font-size:.6rem;transition:transform .3s var(--e1);display:inline-block;
  margin-top:1px;
}

.nav-links li.has-dropdown:hover .nav-arrow { transform:rotate(180deg) }

.nav-dropdown {
  position:absolute;top:calc(100% + 1rem);left:50%;transform:translateX(-50%);
  min-width:280px;
  background:rgba(10,31,92,.97);
  backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:2px;
  padding:.6rem 0;
  list-style:none;
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateX(-50%) translateY(8px);
  transition:opacity .3s var(--e1),transform .3s var(--e1),visibility .3s;
  z-index:9999;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
}

.nav-links li.has-dropdown:hover .nav-dropdown {
  opacity:1;visibility:visible;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}

.nav-dropdown::before {
  content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);
  width:10px;height:10px;background:rgba(10,31,92,.97);
  border-left:1px solid rgba(255,255,255,.08);
  border-top:1px solid rgba(255,255,255,.08);
  transform:translateX(-50%) rotate(45deg);
}

.nav-dropdown-item {
  display:block;padding:.65rem 1.4rem;
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:600;
  letter-spacing:.06em;color:rgba(255,255,255,.7);
  transition:color .2s,background .2s,padding-left .2s;
  border-left:2px solid transparent;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.nav-dropdown-item:hover {
  color:#fff;background:rgba(255,255,255,.05);
  padding-left:1.8rem;border-left-color:var(--orange);
}

/* ═══════════════════════════════════════════════════════════════
   PAGE HERO — commun à toutes les pages internes
═══════════════════════════════════════════════════════════════ */

.page-hero {
  position:relative;min-height:380px;
  display:flex;align-items:center;
  padding:8rem 6% 4rem;
  overflow:hidden;
}

.page-hero-bg {
}
/* ═══════════════════════════════════════════════════════════════
   VARIABLES PAGES INTERNES
   Palette sobre, institutionnelle — contraste avec la homepage dark
═══════════════════════════════════════════════════════════════ */

:root {
  --ip-bg:       #ffffff;        /* fond principal pages internes */
  --ip-bg2:      #f7f8fc;        /* fond alternatif très clair */
  --ip-bg3:      #eef0f8;        /* fond accent */
  --ip-text:     #1a1a2e;        /* texte principal */
  --ip-text2:    #4a4a6a;        /* texte secondaire */
  --ip-text3:    #8a8aaa;        /* texte tertiaire */
  --ip-border:   rgba(12,38,113,.1); /* bordure légère */
  --ip-navy:     #0c2671;        /* bleu institutionnel */
  --ip-orange:   #FF6B1A;        /* accent orange — utilisé avec parcimonie */
  --ip-green:    #0F7A4B;        /* accent vert */
  --ip-shadow:   0 4px 24px rgba(12,38,113,.08);
  --ip-shadow2:  0 12px 40px rgba(12,38,113,.12);
}

/* ═══════════════════════════════════════════════════════════════
   MEGA-MENU NAV
═══════════════════════════════════════════════════════════════ */

.nav-actions {
  display:flex;align-items:center;gap:.4rem;flex-shrink:0;
}

.nav-btn-adhesion {
  display:inline-flex;align-items:center;gap:.3rem;
  background:var(--orange);color:#fff;
  padding:.38rem .7rem;
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  transition:background .3s,transform .2s;white-space:nowrap;
}
.nav-btn-adhesion:hover { background:#d95800;transform:translateY(-1px) }

.nav-btn-contact {
  display:inline-flex;align-items:center;
  border:1px solid rgba(255,255,255,.28);color:rgba(255,255,255,.7);
  padding:.36rem .7rem;
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  transition:all .3s;white-space:nowrap;
}
.nav-btn-contact:hover { border-color:#fff;color:#fff }

.nav-btn-espace {
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  border:1px solid rgba(255,255,255,.15);font-size:.9rem;
  color:rgba(255,255,255,.4);transition:all .3s;
}
.nav-btn-espace:hover { border-color:var(--orange);color:var(--orange) }

/* Dropdown trigger */
.nav-arrow {
  font-size:.6rem;display:inline-block;
  transition:transform .3s var(--e1);margin-top:1px;
}
.has-dropdown:hover .nav-arrow { transform:rotate(180deg) }

/* Mega-menu conteneur */
.nav-mega {
  position:absolute;top:calc(100% + 6px);left:50%;
  transform:translateX(-50%) translateY(4px);
  min-width:520px;
  background:#fff;
  border-top:3px solid var(--orange);
  box-shadow:0 20px 60px rgba(12,38,113,.14);
  display:flex;gap:0;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .28s var(--e1),transform .28s var(--e1),visibility .28s;
  z-index:9999;
}
/* Pont transparent entre le lien et le mega pour maintenir le hover */
.has-dropdown::after {
  content:'';
  position:absolute;
  bottom:-6px;left:0;right:0;
  height:6px;
  background:transparent;
  display:block;
}
.has-dropdown:hover .nav-mega {
  opacity:1;visibility:visible;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}

/* Forcer la couleur des liens à l'intérieur du mega-menu */
.nav-mega a,
.nav-mega .nav-mega-item,
.nav-mega .nav-mega-label,
.nav-mega .nav-mega-desc {
  color:var(--ip-text2);
}
.nav-mega a:hover,
.nav-mega .nav-mega-item:hover {
  color:var(--ip-orange) !important;
}
.nav-mega .nav-mega-label { color:var(--ip-text3) }
.nav-mega .nav-mega-btn,
.nav-mega .nav-mega-btn:hover { color:#fff !important }
.nav-mega a::after,
.nav-mega a:hover::after { display:none !important; width:0 !important }

.nav-mega-col {
  padding:1.4rem 1.6rem;min-width:210px;
  border-right:1px solid rgba(12,38,113,.06);
}
.nav-mega-col:last-child { border-right:none }

.nav-mega-label {
  font-family:'Montserrat',sans-serif;font-size:.52rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--ip-text3);
  margin-bottom:.8rem;padding-bottom:.45rem;
  border-bottom:1px solid var(--ip-border);
  display:block;
}

/* Tous les items du sous-menu — même gabarit */
.nav-mega-item {
  display:block;
  padding:.38rem .6rem;
  margin-left:-.6rem; /* compense le padding pour aligner le bord gauche du texte */
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:600;
  color:var(--ip-text2);letter-spacing:.02em;line-height:1.4;
  transition:color .18s, background .18s, padding-left .18s;
  border-left:2px solid transparent;
}
.nav-mega-item:hover {
  color:var(--ip-orange);
  padding-left:1rem;
  border-left-color:var(--ip-orange);
  background:rgba(255,107,26,.04);
}

.nav-mega-cta {
  background:var(--ip-bg2);min-width:260px;max-width:280px;
  display:flex;flex-direction:column;justify-content:center;gap:.5rem;padding:1.4rem 1.6rem;
}
.nav-mega-desc {
  font-size:.74rem;font-weight:300;color:var(--ip-text3);
  line-height:1.7;margin-bottom:.2rem;
}

/* Tous les boutons CTA du mega — une seule ligne, jamais deux */
.nav-mega-btn {
  display:flex;align-items:center;justify-content:center;
  background:var(--orange);color:#fff !important;
  padding:.52rem .9rem;
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  transition:background .22s;
  width:100%;box-sizing:border-box;
  text-align:center;
  white-space:nowrap;
}
.nav-mega-btn:hover { background:#d95800 !important }

/* Services mega */
.nav-mega-services { min-width:680px;flex-direction:column }
.nav-mega-services-grid {
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;border-bottom:1px solid var(--ip-border);
}
.nav-service-card {
  display:flex;align-items:flex-start;gap:.6rem;
  padding:.9rem 1rem;
  border-right:1px solid var(--ip-border);
  transition:background .2s;
  color:var(--ip-text);
}
.nav-service-card::after { display:none !important }
.nav-service-card:last-child { border-right:none }
.nav-service-card:hover { background:var(--ip-bg2) }
.nav-service-icone { font-size:1.3rem;flex-shrink:0;margin-top:2px }
.nav-service-num {
  display:block;font-family:'Montserrat',sans-serif;font-size:.5rem;
  font-weight:700;letter-spacing:.18em;color:var(--ip-orange);margin-bottom:.2rem;
}
.nav-service-name {
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;
  color:var(--ip-text);line-height:1.25;
}
.nav-mega-services-foot {
  display:flex;align-items:center;justify-content:space-between;
  padding:.8rem 1.2rem;
}
.nav-mega-services-all {
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:600;
  color:var(--ip-text3);transition:color .2s;
}
.nav-mega-services-all:hover { color:var(--ip-orange) }
.nav-mega-services-all span { margin-left:.3rem }

/* Hamburger */
.nav-hamburger {
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:.4rem;
}
.nav-hamburger span {
  display:block;width:24px;height:2px;background:rgba(255,255,255,.7);
  transition:all .3s var(--e1);
}
.nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg) }
.nav-hamburger.open span:nth-child(2) { opacity:0 }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg) }

/* Mobile nav */
.nav-mobile-overlay {
  position:fixed;inset:0;background:rgba(0,0,0,.55);
  z-index:990;opacity:0;pointer-events:none;transition:opacity .3s;
}
.nav-mobile-overlay.open { opacity:1;pointer-events:all }

.nav-mobile {
  position:fixed;top:0;right:-320px;width:300px;height:100vh;
  background:#fff;z-index:991;
  padding:5rem 1.5rem 2rem;overflow-y:auto;
  transition:right .4s var(--e2);
  display:flex;flex-direction:column;gap:0;
}
.nav-mobile.open { right:0 }

.nav-mobile-close {
  position:absolute;top:1.2rem;right:1.2rem;
  background:none;border:none;color:var(--ip-text3);
  font-size:1.2rem;cursor:pointer;transition:color .2s;
}
.nav-mobile-close:hover { color:var(--ip-navy) }

.nav-mobile-links { list-style:none;display:flex;flex-direction:column }
.nav-mobile-links > li > a {
  display:block;padding:.85rem 0;
  font-family:'Montserrat',sans-serif;font-size:.8rem;font-weight:700;
  letter-spacing:.06em;color:var(--ip-text);
  border-bottom:1px solid var(--ip-border);
  transition:color .2s,padding-left .2s;
}
.nav-mobile-links > li > a:hover { color:var(--ip-orange);padding-left:.4rem }

.nav-mobile-group { }
.nav-mobile-toggle {
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 0;background:none;border:none;border-bottom:1px solid var(--ip-border);
  font-family:'Montserrat',sans-serif;font-size:.8rem;font-weight:700;
  letter-spacing:.06em;color:var(--ip-text);cursor:pointer;
  transition:color .2s;
}
.nav-mobile-toggle:hover { color:var(--ip-orange) }
.nav-mobile-toggle span { font-size:1rem;font-weight:400;transition:transform .3s }
.nav-mobile-toggle.open span { transform:rotate(45deg) }

.nav-mobile-sub {
  list-style:none;display:none;
  padding:.4rem 0 .4rem .8rem;
  border-bottom:1px solid var(--ip-border);
}
.nav-mobile-sub.open { display:block }
.nav-mobile-sub li a {
  display:block;padding:.42rem 0;
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:600;
  color:var(--ip-text2);transition:color .2s;
}
.nav-mobile-sub li a:hover { color:var(--ip-orange) }

.nav-mobile-actions {
  margin-top:1.5rem;display:flex;flex-direction:column;gap:.7rem;
}
.nav-mobile-actions .nav-btn-adhesion,
.nav-mobile-actions .nav-btn-contact {
  justify-content:center;width:100%;
}
.nav-mobile-actions .nav-btn-contact {
  border-color:var(--ip-navy);color:var(--ip-navy);
}
.nav-mobile-actions .nav-btn-contact:hover {
  background:var(--ip-navy);color:#fff;
}


/* ═══════════════════════════════════════════════════════════════
   PAGE BANDEAU — sobre, compact
   Remplace l'ancien .inner-hero plein écran par un bandeau propre
═══════════════════════════════════════════════════════════════ */

.page-band {
  background:var(--ip-navy);
  padding:7.5rem 6% 2.8rem;
  position:relative;overflow:hidden;
}
/* Couche photo de fond — activée si --page-band-bg est défini */
.page-band-photo {
  position:absolute;inset:0;
  background-image:var(--page-band-bg, none);
  background-size:cover;background-position:center;
  filter:brightness(.32) saturate(1.3);
  transition:transform 14s linear;
}
.page-band:hover .page-band-photo { transform:scale(1.04) }
/* Overlay dégradé navy par-dessus la photo */
.page-band-photo-ov {
  position:absolute;inset:0;
  background:
    linear-gradient(105deg, rgba(10,31,92,.92) 0%, rgba(10,31,92,.7) 45%, rgba(10,31,92,.3) 100%),
    linear-gradient(to top, rgba(6,16,30,.85) 0%, transparent 50%);
}
.page-band::before {
  content:'';position:absolute;inset:0;z-index:1;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 70% 100% at 30% 50%,black,transparent);
}
.page-band::after {
  content:'';position:absolute;right:-5%;top:50%;z-index:1;
  transform:translateY(-50%);
  width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,107,26,.18) 0%,transparent 70%);
  pointer-events:none;
}
.page-band-inner { position:relative;z-index:2;max-width:780px }

.page-band-eyebrow {
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--orange);
  display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem;
}
.page-band-eyebrow::before {
  content:'';width:22px;height:1.5px;background:var(--orange);flex-shrink:0;
}

.page-band-title {
  font-family:'Montserrat',sans-serif;
  font-size:clamp(2rem,4.5vw,3.8rem);
  font-weight:900;line-height:.97;letter-spacing:-.025em;
  color:#fff;margin-bottom:1rem;
}
.page-band-title span { color:var(--orange) }

.page-band-sub {
  font-size:clamp(.88rem,1.3vw,1rem);font-weight:300;
  color:rgba(255,255,255,.58);line-height:1.9;max-width:600px;
}

/* Fil d'Ariane intégré dans le band */
.page-band-breadcrumb {
  margin-top:1.5rem;display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
}
.page-band-breadcrumb a     { color:rgba(255,255,255,.35);transition:color .2s }
.page-band-breadcrumb a:hover { color:rgba(255,255,255,.7) }
.page-band-breadcrumb span  { color:rgba(255,255,255,.6) }
.page-band-breadcrumb .sep  { color:rgba(255,255,255,.2) }


/* ═══════════════════════════════════════════════════════════════
   LAYOUT PAGES INTERNES
   Structure principale : fond blanc, sections alternées
═══════════════════════════════════════════════════════════════ */

.ip-body { background:var(--ip-bg) }

/* Section standard */
.ip-section {
  padding:4rem 6%;
  background:var(--ip-bg);
}
.ip-section.alt  { background:var(--ip-bg2) }
.ip-section.dark { background:var(--ip-navy);color:#fff }
.ip-section.navy-light { background:#eef1f8 }

/* ═══════════════════════════
   MISSION SECTION — style calqué sur la homepage #mission
═══════════════════════════ */
.ip-mission-split {
  display:grid;grid-template-columns:1fr 1fr;min-height:80vh;
}

/* Colonne gauche — visuel */
.ip-ms-visual {
  position:relative;overflow:hidden;
}
.ip-ms-photo {
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 12s linear;
}
.ip-ms-photo--default {
  background-color:var(--ip-navy);
  background-image:
    radial-gradient(ellipse 80% 80% at 30% 50%, rgba(26,122,255,.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 70% 80%, rgba(15,122,75,.15) 0%, transparent 55%),
    linear-gradient(135deg, #06101e 0%, #0c2671 50%, #0a1f5c 100%);
}
.ip-mission-split:hover .ip-ms-photo { transform:scale(1.04) }
.ip-ms-overlay {
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(10,31,92,.92) 0%,rgba(12,38,113,.75) 50%,rgba(15,80,40,.6) 100%);
}
.ip-ms-visual-inner {
  position:relative;z-index:2;
  padding:var(--sp);height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
}
.ip-ms-bignum {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(8rem,14vw,13rem);font-weight:700;line-height:1;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.06);
  position:absolute;bottom:-2rem;left:-1rem;
  user-select:none;pointer-events:none;
}
.ip-ms-badge {
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin-bottom:1rem;
}
.ip-ms-badge-dot {
  width:8px;height:8px;border-radius:50%;background:var(--green2);flex-shrink:0;
  box-shadow:0 0 0 0 rgba(29,185,84,.6);
  animation:abPulse 2s ease-in-out infinite;
}
.ip-ms-quote {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.4rem,2.2vw,2rem);
  font-style:italic;font-weight:400;
  color:rgba(255,255,255,.88);line-height:1.55;
  max-width:420px;margin:0 0 .9rem;
  border:none;padding:0;
}
.ip-ms-quote-source {
  font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.3);
}

/* Colonne droite — contenu */
.ip-ms-content {
  background:var(--ip-bg2);
  padding:var(--sp);
  display:flex;flex-direction:column;justify-content:center;
  gap:0;
}
.ip-ms-content .ip-eyebrow { margin-bottom:.6rem }
.ip-ms-content .ip-title   { margin-bottom:1.4rem }

.ip-ms-block {
  border-left:3px solid transparent;
  background:#fff;
  padding:1.1rem 1.4rem;
  box-shadow:var(--ip-shadow);
  margin-bottom:.9rem;
}
.ip-ms-block--green  { border-left-color:var(--ip-green) }
.ip-ms-block--orange { border-left-color:var(--ip-orange) }
.ip-ms-block--navy   { border-left-color:var(--ip-navy) }

.ip-ms-block-lbl {
  font-family:'Montserrat',sans-serif;font-size:.52rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;margin-bottom:.4rem;
}
.ip-ms-block--green  .ip-ms-block-lbl { color:var(--ip-green) }
.ip-ms-block--orange .ip-ms-block-lbl { color:var(--ip-orange) }
.ip-ms-block--navy   .ip-ms-block-lbl { color:var(--ip-navy) }

.ip-ms-block-text {
  font-size:.92rem;font-weight:300;color:var(--ip-text2);line-height:1.85;
}

.ip-ms-vals-wrap {
  background:#fff;padding:1.1rem 1.4rem;
  box-shadow:var(--ip-shadow);margin-bottom:.9rem;
}
.ip-ms-vals-title {
  font-family:'Montserrat',sans-serif;font-size:.52rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--ip-navy);margin-bottom:.75rem;
}
.ip-ms-vals {
  display:grid;grid-template-columns:1fr 1fr;gap:.45rem .8rem;
}
.ip-ms-val {
  display:flex;align-items:center;gap:.55rem;
  font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:700;
  color:var(--ip-navy);
}
.ip-ms-val-dot {
  width:6px;height:6px;border-radius:50%;
  background:var(--ip-orange);flex-shrink:0;
}

@media(max-width:900px) {
  .ip-mission-split { grid-template-columns:1fr;min-height:auto }
  .ip-ms-visual { min-height:340px }
}
@media(max-width:600px) {
  .ip-ms-visual { min-height:260px }
}

/* Titre de section */
.ip-eyebrow {
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--ip-orange);
  display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem;
}
.ip-eyebrow::before { content:'';width:20px;height:1.5px;background:var(--ip-orange);flex-shrink:0}
.ip-eyebrow.green   { color:var(--ip-green) }
.ip-eyebrow.green::before { background:var(--ip-green) }

.ip-title {
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:900;line-height:1;letter-spacing:-.02em;
  color:var(--ip-navy);margin-bottom:0;
}
.ip-title.light { color:#fff }
.ip-title span  { color:var(--ip-orange) }
.ip-title span.g { color:var(--ip-green) }

.ip-intro {
  font-size:1rem;font-weight:300;color:var(--ip-text2);
  line-height:1.9;max-width:680px;margin-top:1rem;
}

/* Lead 2 colonnes */
.ip-lead {
  display:grid;grid-template-columns:1.2fr 1fr;gap:4rem;
  align-items:center;padding:4rem 6%;background:var(--ip-bg);
}
.ip-lead.rev { direction:rtl }
.ip-lead.rev > * { direction:ltr }
.ip-lead-text { display:flex;flex-direction:column;gap:.8rem }
.ip-lead-visual {
  position:relative;
  border-left:4px solid var(--ip-orange);
  padding:2.5rem 2rem;
  background:var(--ip-bg2);
}
.ip-lead-visual.green { border-left-color:var(--ip-green) }

.ip-lead-quote {
  font-family:'Cormorant Garamond',serif;font-size:clamp(1.2rem,2vw,1.55rem);
  font-style:italic;color:var(--ip-navy);line-height:1.55;
  margin-bottom:1rem;
}
.ip-lead-quote-author {
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;color:var(--ip-text3);
}

/* Liste de points */
.ip-points { display:flex;flex-direction:column;gap:1.1rem;margin-top:1rem }
.ip-point {
  display:flex;align-items:flex-start;gap:1rem;
  padding:1rem 1.2rem;background:var(--ip-bg);
  border-left:2px solid var(--ip-orange);
  transition:border-color .3s,background .3s;
}
.ip-point:hover { background:var(--ip-bg2);border-left-color:var(--ip-navy) }
.ip-point-title {
  font-family:'Montserrat',sans-serif;font-size:.88rem;font-weight:700;
  color:var(--ip-navy);margin-bottom:.3rem;
}
.ip-point-desc { font-size:.85rem;font-weight:300;color:var(--ip-text2);line-height:1.7 }

/* Grille de cartes */
.ip-grid {
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5rem;margin-top:2rem;
}
.ip-grid.cols-4 { grid-template-columns:repeat(4,1fr) }
.ip-grid.cols-2 { grid-template-columns:repeat(2,1fr) }

.ip-card {
  background:var(--ip-bg);border:1px solid var(--ip-border);
  padding:1.8rem;
  transition:box-shadow .3s,transform .3s,border-color .3s;
  position:relative;
}
.ip-card::before {
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--ip-orange);
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--e2);
}
.ip-card:hover {
  box-shadow:var(--ip-shadow2);
  transform:translateY(-3px);
  border-color:rgba(255,107,26,.25);
}
.ip-card:hover::before { transform:scaleX(1) }

.ip-card-num {
  font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;
  letter-spacing:.22em;color:var(--ip-orange);margin-bottom:.7rem;
  display:flex;align-items:center;gap:.4rem;
}
.ip-card-num::before { content:'';width:14px;height:1px;background:var(--ip-orange) }

.ip-card-title {
  font-family:'Montserrat',sans-serif;font-size:1rem;font-weight:700;
  color:var(--ip-navy);line-height:1.25;margin-bottom:.6rem;
}
.ip-card-desc {
  font-size:.85rem;font-weight:300;color:var(--ip-text2);line-height:1.8;
}
.ip-card-link {
  display:inline-flex;align-items:center;gap:.4rem;margin-top:1.2rem;
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ip-orange);
  transition:gap .3s;
}
.ip-card-link:hover { gap:.7rem }

/* Carte sur fond sombre */
.ip-card.dark-card {
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.08);
}
.ip-card.dark-card::before { background:var(--orange) }
.ip-card.dark-card .ip-card-title { color:#fff }
.ip-card.dark-card .ip-card-desc  { color:rgba(255,255,255,.55) }
.ip-card.dark-card .ip-card-link  { color:rgba(255,255,255,.5) }
.ip-card.dark-card:hover .ip-card-link { color:var(--orange) }
.ip-card.dark-card:hover { border-color:rgba(255,107,26,.2) }

/* Stat band sobre */
.ip-stats {
  display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--ip-navy);
}
.ip-stat {
  padding:2rem 1.5rem;text-align:center;
  border-right:1px solid rgba(255,255,255,.08);
  transition:background .3s;
}
.ip-stat:last-child { border-right:none }
.ip-stat:hover { background:rgba(255,255,255,.04) }
.ip-stat-val {
  font-family:'Montserrat',sans-serif;
  font-size:clamp(2rem,4vw,3rem);font-weight:900;
  color:#fff;line-height:1;margin-bottom:.5rem;
}
.ip-stat-val span { font-size:.6em;color:var(--orange) }
.ip-stat-lbl {
  font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);
}

/* Processus en ligne sobre */
.ip-steps {
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;position:relative;margin-top:2.5rem;
}
.ip-steps::before {
  content:'';position:absolute;top:22px;left:8%;right:8%;height:1px;
  background:var(--ip-border);z-index:0;
}
.ip-step { text-align:center;padding:0 1.2rem;position:relative;z-index:1 }
.ip-step-dot {
  width:44px;height:44px;border-radius:50%;
  border:2px solid var(--ip-border);background:var(--ip-bg);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.2rem;
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;
  color:var(--ip-navy);
  transition:all .3s var(--e1);
}
.ip-step:hover .ip-step-dot {
  background:var(--ip-navy);border-color:var(--ip-navy);color:#fff;
}
.ip-step-title {
  font-family:'Montserrat',sans-serif;font-size:.88rem;font-weight:700;
  color:var(--ip-navy);margin-bottom:.5rem;
}
.ip-step-desc {
  font-size:.78rem;font-weight:300;color:var(--ip-text2);line-height:1.7;
}

/* Roadmap sobre */
.ip-roadmap {
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:0;margin-top:2rem;
  border:1px solid var(--ip-border);
}
.ip-rm {
  padding:1.4rem 1.2rem;border-right:1px solid var(--ip-border);
  position:relative;overflow:hidden;
  transition:background .3s;
}
.ip-rm:last-child { border-right:none }
.ip-rm:hover { background:var(--ip-bg2) }
.ip-rm::before {
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--ip-orange);
  transform:scaleX(0);transform-origin:left;transition:transform .45s var(--e2);
}
.ip-rm:hover::before { transform:scaleX(1) }
.ip-rm-p {
  font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;color:var(--ip-orange);
  margin-bottom:.6rem;
}
.ip-rm-t {
  font-family:'Montserrat',sans-serif;font-size:.9rem;font-weight:700;
  color:var(--ip-navy);line-height:1.3;margin-bottom:.5rem;
}
.ip-rm-b { font-size:.8rem;font-weight:300;color:var(--ip-text2);line-height:1.7 }

/* FAQ sobre */
.ip-faq { max-width:780px;margin-top:2rem }
.ip-faq-item {
  border-bottom:1px solid var(--ip-border);
}
.ip-faq-item:first-child { border-top:1px solid var(--ip-border) }
.ip-faq-q {
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.1rem 0;background:none;border:none;cursor:pointer;text-align:left;
  font-family:'Montserrat',sans-serif;font-size:.9rem;font-weight:700;
  color:var(--ip-navy);transition:color .2s;
}
.ip-faq-q:hover { color:var(--ip-orange) }
.ip-faq-icon {
  flex-shrink:0;width:22px;height:22px;border-radius:50%;
  border:1.5px solid var(--ip-border);
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;color:var(--ip-orange);font-weight:400;
  transition:all .3s;
}
.ip-faq-a {
  display:none;padding:.2rem 0 1.2rem;
  font-size:.9rem;font-weight:300;color:var(--ip-text2);line-height:1.9;
}

/* CTA section sobre */
.ip-cta {
  background:var(--ip-navy);
  padding:3.5rem 6%;text-align:center;
  position:relative;overflow:hidden;
}
.ip-cta::before {
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:48px 48px;
}
.ip-cta-inner { position:relative;z-index:2;max-width:600px;margin:0 auto }
.ip-cta-title {
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.5rem,3vw,2.2rem);font-weight:900;
  color:#fff;line-height:1.05;letter-spacing:-.02em;margin-bottom:.8rem;
}
.ip-cta-title span { color:var(--orange) }
.ip-cta-sub {
  font-size:.95rem;font-weight:300;color:rgba(255,255,255,.55);
  margin-bottom:1.8rem;line-height:1.8;
}
.ip-cta-btns { display:flex;justify-content:center;gap:1rem;flex-wrap:wrap }

/* Boutons sobre pages internes */
.ip-btn-primary {
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--orange);color:#fff;
  padding:.75rem 1.8rem;
  font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  transition:background .3s,transform .2s;
}
.ip-btn-primary:hover { background:#d95800;transform:translateY(-2px) }

.ip-btn-secondary {
  display:inline-flex;align-items:center;gap:.5rem;
  border:1.5px solid var(--ip-navy);color:var(--ip-navy);
  padding:.73rem 1.6rem;
  font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  transition:all .3s;
}
.ip-btn-secondary:hover { background:var(--ip-navy);color:#fff }

.ip-btn-ghost {
  display:inline-flex;align-items:center;gap:.5rem;
  border:1.5px solid rgba(255,255,255,.25);color:rgba(255,255,255,.7);
  padding:.73rem 1.6rem;
  font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  transition:all .3s;
}
.ip-btn-ghost:hover { border-color:#fff;color:#fff }

/* Tableau comparatif */
.ip-table-wrap { overflow-x:auto;margin-top:2rem }
.ip-table {
  width:100%;border-collapse:collapse;
  font-size:.85rem;
}
.ip-table th {
  background:var(--ip-navy);color:#fff;
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.9rem 1.2rem;text-align:left;
}
.ip-table td {
  padding:.85rem 1.2rem;border-bottom:1px solid var(--ip-border);
  color:var(--ip-text2);font-weight:300;vertical-align:top;
}
.ip-table tr:hover td { background:var(--ip-bg2) }
.ip-table .check { color:var(--ip-green);font-weight:700 }
.ip-table .cross  { color:var(--ip-text3) }

/* Formulaire sobre */
.ip-form { display:flex;flex-direction:column;gap:1.2rem }
.ip-form-row { display:grid;grid-template-columns:1fr 1fr;gap:1.2rem }
.ip-form-group { display:flex;flex-direction:column;gap:.4rem }
.ip-label {
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ip-text3);
}
.ip-input {
  background:var(--ip-bg2);border:1.5px solid var(--ip-border);
  color:var(--ip-text);
  padding:.8rem 1rem;
  font-family:'Poppins',sans-serif;font-size:.88rem;font-weight:300;
  outline:none;transition:border-color .3s,background .3s;
  -webkit-appearance:none;
}
.ip-input::placeholder { color:var(--ip-text3) }
.ip-input:focus { border-color:var(--ip-navy);background:#fff }
.ip-input.error { border-color:var(--ip-orange) }
.ip-textarea { resize:vertical;min-height:130px }

.ip-req { color:var(--ip-orange) }

.ip-feedback {
  padding:.85rem 1.1rem;font-size:.82rem;font-weight:600;margin-bottom:1rem;
}
.ip-feedback.success {
  background:rgba(15,122,75,.08);border:1px solid rgba(15,122,75,.25);
  color:var(--ip-green);
}
.ip-feedback.error {
  background:rgba(255,107,26,.08);border:1px solid rgba(255,107,26,.25);
  color:#c04a00;
}

/* Archive Blog */
.ip-archive { background:var(--ip-bg);padding:3rem 6% }

.ip-archive-filters {
  display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem;
}
.ip-filter {
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.42rem .95rem;border:1.5px solid var(--ip-border);
  color:var(--ip-text3);background:transparent;cursor:pointer;
  transition:all .25s;
}
.ip-filter:hover,
.ip-filter.active {
  background:var(--ip-navy);border-color:var(--ip-navy);color:#fff;
}

.ip-blog-grid {
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
}
.ip-article {
  background:#fff;border:1px solid var(--ip-border);overflow:hidden;
  transition:box-shadow .3s,transform .3s;
}
.ip-article:hover { box-shadow:var(--ip-shadow2);transform:translateY(-4px) }
.ip-article-img {
  height:200px;background-size:cover !important;
  background-position:center !important;overflow:hidden;
}
.ip-article-img-inner {
  height:100%;background-size:cover;background-position:center;
  transition:transform .5s var(--e1);
}
.ip-article:hover .ip-article-img-inner { transform:scale(1.05) }
.ip-article-body { padding:1.4rem }
.ip-article-meta {
  display:flex;align-items:center;gap:.7rem;margin-bottom:.7rem;
}
.ip-article-cat {
  font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ip-orange);
}
.ip-article-date {
  font-family:'Montserrat',sans-serif;font-size:.6rem;color:var(--ip-text3);
}
.ip-article-title {
  font-family:'Montserrat',sans-serif;font-size:1rem;font-weight:700;
  color:var(--ip-navy);line-height:1.3;margin-bottom:.6rem;
}
.ip-article-title a { color:inherit;transition:color .2s }
.ip-article-title a:hover { color:var(--ip-orange) }
.ip-article-excerpt {
  font-size:.85rem;font-weight:300;color:var(--ip-text2);line-height:1.8;
  margin-bottom:1rem;
}
.ip-article-link {
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--ip-orange);display:flex;align-items:center;gap:.4rem;
  transition:gap .3s;
}
.ip-article-link:hover { gap:.7rem }

/* Pagination */
.ip-pagination { display:flex;justify-content:center;gap:.5rem;margin-top:3rem }
.ip-pagination a,
.ip-pagination span {
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;
  font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;
  border:1.5px solid var(--ip-border);color:var(--ip-text3);
  transition:all .25s;
}
.ip-pagination a:hover,
.ip-pagination span.current {
  background:var(--ip-navy);border-color:var(--ip-navy);color:#fff;
}
.ip-pagination .prev,
.ip-pagination .next { width:auto;padding:0 .9rem }

/* Article single */
.ip-single { background:var(--ip-bg);padding:3rem 6% }
.ip-single-layout { display:grid;grid-template-columns:1fr 300px;gap:3rem;align-items:flex-start;margin-top:1.5rem }
.ip-single-content { }
.ip-single-nav {
  display:grid;grid-template-columns:1fr 1fr;gap:1rem;
  margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--ip-border);
}
.ip-single-nav-item {
  padding:.9rem 1rem;border:1.5px solid var(--ip-border);
  transition:border-color .3s,background .3s;display:flex;flex-direction:column;gap:.35rem;
}
.ip-single-nav-item:hover { border-color:var(--ip-navy);background:var(--ip-bg2) }
.ip-single-nav-item.next { text-align:right }
.ip-single-nav-dir {
  font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ip-orange);
}
.ip-single-nav-ttl {
  font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:700;
  color:var(--ip-navy);line-height:1.3;
}

/* Sidebar */
.ip-sidebar { display:flex;flex-direction:column;gap:1.2rem;position:sticky;top:100px }
.ip-sidebar-widget { background:var(--ip-bg2);padding:1.4rem;border:1px solid var(--ip-border) }
.ip-sidebar-title {
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ip-navy);
  margin-bottom:1.1rem;padding-bottom:.6rem;border-bottom:1px solid var(--ip-border);
}
.ip-sidebar-post {
  display:flex;align-items:center;gap:.8rem;padding:.6rem 0;
  border-bottom:1px solid var(--ip-border);transition:opacity .2s;
}
.ip-sidebar-post:last-child { border-bottom:none }
.ip-sidebar-post:hover { opacity:.75 }
.ip-sidebar-post-img {
  width:50px;height:50px;flex-shrink:0;
  background-size:cover;background-position:center;
}
.ip-sidebar-post-title {
  font-family:'Montserrat',sans-serif;font-size:.75rem;font-weight:700;
  color:var(--ip-navy);line-height:1.25;
}
.ip-sidebar-post-date { font-size:.62rem;color:var(--ip-text3);margin-top:.2rem }
.ip-sidebar-service-link {
  display:flex;align-items:center;gap:.5rem;padding:.5rem 0;
  border-bottom:1px solid var(--ip-border);
  font-family:'Montserrat',sans-serif;font-size:.76rem;font-weight:600;
  color:var(--ip-text2);transition:color .2s,padding-left .2s;
  border-left:2px solid transparent;padding-left:.4rem;
}
.ip-sidebar-service-link:last-child { border-bottom:none }
.ip-sidebar-service-link:hover,
.ip-sidebar-service-link.active { color:var(--ip-orange);border-left-color:var(--ip-orange);padding-left:.8rem }
.ip-sidebar-service-num { font-size:.6rem;color:var(--ip-green);font-weight:700;flex-shrink:0 }

.ip-sidebar-cta {
  background:var(--ip-navy);padding:1.4rem;
}
.ip-sidebar-cta-title {
  font-family:'Montserrat',sans-serif;font-size:.92rem;font-weight:800;
  color:#fff;margin-bottom:.4rem;
}
.ip-sidebar-cta p {
  font-size:.78rem;font-weight:300;color:rgba(255,255,255,.55);
  margin-bottom:1rem;line-height:1.6;
}

.ip-back-link {
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--ip-orange);transition:gap .3s;margin-bottom:.5rem;
}
.ip-back-link:hover { gap:.7rem }

/* Tags article */
.ip-tags { display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--ip-border) }
.ip-tag {
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.32rem .85rem;background:var(--ip-bg2);color:var(--ip-navy);
  border:1.5px solid var(--ip-border);transition:all .2s;
}
.ip-tag:hover { background:var(--ip-navy);border-color:var(--ip-navy);color:#fff }

/* Wysiwyg */
.ip-wysiwyg {
  font-size:.95rem;font-weight:300;color:var(--ip-text2);line-height:1.95;
}
.ip-wysiwyg h2 {
  font-family:'Montserrat',sans-serif;font-size:1.4rem;font-weight:800;
  color:var(--ip-navy);margin:2rem 0 .8rem;
}
.ip-wysiwyg h3 {
  font-family:'Montserrat',sans-serif;font-size:1.1rem;font-weight:700;
  color:var(--ip-navy);margin:1.5rem 0 .5rem;
}
.ip-wysiwyg p { margin-bottom:1.1rem }
.ip-wysiwyg ul,
.ip-wysiwyg ol { padding-left:1.4rem;margin-bottom:1.1rem }
.ip-wysiwyg li { margin-bottom:.4rem }
.ip-wysiwyg strong { color:var(--ip-navy);font-weight:700 }
.ip-wysiwyg a { color:var(--ip-orange);text-decoration:underline }
.ip-wysiwyg blockquote {
  border-left:3px solid var(--ip-orange);
  padding:.9rem 1.4rem;background:var(--ip-bg2);
  margin:1.5rem 0;font-style:italic;color:var(--ip-text2);
}
.ip-wysiwyg img { max-width:100%;margin:1.5rem 0 }

/* Documents */
.ip-doc-tabs {
  display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;margin-bottom:1.5rem;
}
.ip-doc-tab {
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.42rem 1.1rem;border:1.5px solid var(--ip-border);
  background:#fff;color:var(--ip-navy);cursor:pointer;
  transition:all .25s;display:flex;align-items:center;gap:.4rem;
}
.ip-doc-tab:hover,
.ip-doc-tab.active { background:var(--ip-navy);border-color:var(--ip-navy);color:#fff }
.ip-doc-tab-count {
  background:var(--ip-orange);color:#fff;
  border-radius:10px;padding:.08rem .42rem;font-size:.55rem;
}

.ip-doc-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem }
.ip-doc-card {
  background:#fff;border:1px solid var(--ip-border);border-top:3px solid var(--ip-orange);
  padding:1.3rem;display:flex;flex-direction:column;gap:.5rem;
  transition:box-shadow .3s,transform .3s;
}
.ip-doc-card:hover { box-shadow:var(--ip-shadow);transform:translateY(-2px) }
.ip-doc-icon { font-size:1.6rem }
.ip-doc-cat {
  font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ip-orange);
}
.ip-doc-title {
  font-family:'Montserrat',sans-serif;font-size:.9rem;font-weight:700;
  color:var(--ip-navy);line-height:1.25;
}
.ip-doc-desc { font-size:.8rem;font-weight:300;color:var(--ip-text2);line-height:1.65;flex:1 }
.ip-doc-date { font-size:.65rem;color:var(--ip-text3) }
.ip-doc-dl {
  display:inline-flex;align-items:center;gap:.35rem;margin-top:.4rem;
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--ip-orange);transition:gap .3s;
}
.ip-doc-dl:hover { gap:.6rem }

/* Médiathèque */
.ip-media-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem }
.ip-media-card { background:var(--ip-bg2);border:1px solid var(--ip-border);overflow:hidden;transition:box-shadow .3s }
.ip-media-card:hover { box-shadow:var(--ip-shadow2) }
.ip-media-video { position:relative;padding-top:56.25%;background:#000 }
.ip-media-video iframe { position:absolute;inset:0;width:100%;height:100%;border:none }
.ip-media-photo { height:200px;overflow:hidden;position:relative }
.ip-media-photo img { width:100%;height:100%;object-fit:cover;transition:transform .5s var(--e1) }
.ip-media-card:hover .ip-media-photo img { transform:scale(1.05) }
.ip-media-body { padding:1rem 1.2rem }
.ip-media-badge {
  font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ip-orange);margin-bottom:.3rem;
}
.ip-media-title {
  font-family:'Montserrat',sans-serif;font-size:.85rem;font-weight:700;
  color:var(--ip-navy);
}
.ip-media-desc { font-size:.78rem;font-weight:300;color:var(--ip-text2);margin-top:.3rem }

/* Glossaire sobre */
.ip-glossaire { display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2rem }
.ip-glossaire-item {
  background:#fff;border:1px solid var(--ip-border);
  padding:1.4rem;border-top:3px solid var(--ip-orange);
  transition:box-shadow .3s;
}
.ip-glossaire-item:nth-child(4n+2) { border-top-color:var(--ip-green) }
.ip-glossaire-item:nth-child(4n+3) { border-top-color:var(--ip-navy) }
.ip-glossaire-item:nth-child(4n+4) { border-top-color:var(--ip-text3) }
.ip-glossaire-item:hover { box-shadow:var(--ip-shadow) }
.ip-glossaire-sigle {
  font-family:'Montserrat',sans-serif;font-size:1.2rem;font-weight:900;
  color:var(--ip-navy);margin-bottom:.2rem;
}
.ip-glossaire-terme {
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ip-orange);
  margin-bottom:.5rem;
}
.ip-glossaire-def { font-size:.78rem;font-weight:300;color:var(--ip-text2);line-height:1.7 }

/* Contact page sobre */
.ip-contact-grid { display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:flex-start }
.ip-contact-info { }
.ip-contact-map { overflow:hidden;border:1px solid var(--ip-border);margin-top:1.5rem }
.ip-contact-map iframe { width:100%;height:320px;border:none;display:block }
.ip-maps-open {
  display:flex;align-items:center;gap:.5rem;
  padding:.65rem 1rem;
  background:var(--ip-bg2);border-top:1px solid var(--ip-border);
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.08em;color:var(--ip-navy);
  transition:background .2s,color .2s;
}
.ip-maps-open:hover { background:var(--ip-navy);color:#fff }
.ip-maps-open svg { flex-shrink:0 }

.ip-contact-rows { display:flex;flex-direction:column;gap:1.2rem;margin-top:1.5rem }
.ip-contact-row { display:flex;align-items:flex-start;gap:.9rem }
.ip-contact-bar { width:3px;height:auto;background:var(--ip-orange);flex-shrink:0;min-height:36px }
.ip-contact-lbl {
  font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;color:var(--ip-orange);margin-bottom:.2rem;
}
.ip-contact-val { font-size:.88rem;color:var(--ip-text2);line-height:1.65 }
.ip-contact-val a { color:var(--ip-navy);transition:color .2s }
.ip-contact-val a:hover { color:var(--ip-orange) }

.ip-socials { display:flex;gap:.6rem;margin-top:1.2rem }
.ip-social {
  width:38px;height:38px;border-radius:50%;border:none;
  display:flex;align-items:center;justify-content:center;
  transition:transform .25s,box-shadow .25s;flex-shrink:0;
}
.ip-social:hover { transform:translateY(-2px) }
.ip-social.li { background:#0077b5;box-shadow:0 3px 10px rgba(0,119,181,.35) }
.ip-social.li:hover { box-shadow:0 6px 18px rgba(0,119,181,.55) }
.ip-social.tw { background:#000;box-shadow:0 3px 10px rgba(0,0,0,.3) }
.ip-social.tw:hover { box-shadow:0 6px 18px rgba(0,0,0,.5) }
.ip-social.fb { background:#1877f2;box-shadow:0 3px 10px rgba(24,119,242,.35) }
.ip-social.fb:hover { box-shadow:0 6px 18px rgba(24,119,242,.55) }
.ip-social.yt { background:#f00;box-shadow:0 3px 10px rgba(255,0,0,.35) }
.ip-social.yt:hover { box-shadow:0 6px 18px rgba(255,0,0,.55) }
.ip-social.wa { background:#25d366;box-shadow:0 3px 10px rgba(37,211,102,.35) }
.ip-social.wa:hover { box-shadow:0 6px 18px rgba(37,211,102,.55) }

/* Service single sobre */
.ip-service-hero {
  background:var(--ip-navy);padding:8rem 6% 3rem;position:relative;overflow:hidden;
}
.ip-service-hero::before {
  content:'';position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.25) saturate(1.1);
  will-change:transform;
}
.ip-service-hero-inner { position:relative;z-index:2;max-width:760px }
.ip-service-num {
  font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;
  letter-spacing:.22em;color:var(--green2);margin-bottom:.6rem;
}
.ip-service-icone { font-size:2.5rem;margin-bottom:.8rem }
.ip-service-title {
  font-family:'Montserrat',sans-serif;font-size:clamp(2rem,4vw,3.5rem);
  font-weight:900;line-height:.97;letter-spacing:-.02em;color:#fff;margin-bottom:.8rem;
}
.ip-service-desc {
  font-size:1rem;font-weight:300;color:rgba(255,255,255,.6);
  max-width:560px;line-height:1.85;margin-bottom:1.5rem;
}
.ip-service-points {
  background:rgba(255,255,255,.05);border-left:3px solid var(--orange);
  padding:1.2rem 1.5rem;margin-bottom:1.5rem;
}
.ip-service-points-title {
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);
  margin-bottom:.8rem;
}
.ip-service-points ul { list-style:none;display:flex;flex-direction:column;gap:.5rem }
.ip-service-points li {
  display:flex;align-items:flex-start;gap:.6rem;
  font-size:.88rem;color:rgba(255,255,255,.75);
}
.ip-service-points li::before {
  content:'';width:5px;height:5px;border-radius:50%;
  background:var(--orange);flex-shrink:0;margin-top:.45rem;
}
.ip-service-bottom-cta {
  padding:2rem;background:var(--ip-bg2);border-left:3px solid var(--ip-navy);
  margin-top:2rem;
}
.ip-service-bottom-cta h3 {
  font-family:'Montserrat',sans-serif;font-size:1rem;font-weight:700;
  color:var(--ip-navy);margin-bottom:.4rem;
}
.ip-service-bottom-cta p {
  font-size:.85rem;font-weight:300;color:var(--ip-text2);margin-bottom:1.1rem;line-height:1.7;
}

/* Navigation interne */
.ip-inner-nav {
  background:#fff;border-bottom:1px solid var(--ip-border);
  padding:.6rem 6%;position:sticky;top:80px;z-index:100;
}
.ip-inner-nav-links {
  display:flex;gap:0;overflow-x:auto;
}
.ip-inner-nav-link {
  font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.55rem 1.1rem;color:var(--ip-text3);white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color .2s,border-color .2s;
}
.ip-inner-nav-link:hover,
.ip-inner-nav-link.active {
  color:var(--ip-navy);border-bottom-color:var(--ip-orange);
}

/* Membre équipe sobre */
.ip-team-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2rem }
.ip-team-card { background:#fff;border:1px solid var(--ip-border);overflow:hidden;transition:box-shadow .3s,transform .3s }
.ip-team-card:hover { box-shadow:var(--ip-shadow2);transform:translateY(-3px) }
.ip-team-photo { height:240px;overflow:hidden }
.ip-team-photo img { width:100%;height:100%;object-fit:cover;transition:transform .5s var(--e1) }
.ip-team-card:hover .ip-team-photo img { transform:scale(1.04) }
.ip-team-photo-placeholder {
  height:100%;background:var(--ip-bg3);
  display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-size:3rem;font-weight:900;color:var(--ip-border);
}
.ip-team-body { padding:1.2rem }
.ip-team-name {
  font-family:'Montserrat',sans-serif;font-size:.92rem;font-weight:700;color:var(--ip-navy);
}
.ip-team-poste {
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ip-orange);margin:.25rem 0 .6rem;
}
.ip-team-bio { font-size:.78rem;font-weight:300;color:var(--ip-text2);line-height:1.65 }
.ip-team-linkedin {
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  border:1.5px solid var(--ip-border);font-size:.72rem;font-weight:700;
  color:var(--ip-text3);margin-top:.6rem;transition:all .2s;
}
.ip-team-linkedin:hover { background:#0077b5;border-color:#0077b5;color:#fff }

/* Partenaire card sobre */
.ip-partner-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2rem }
.ip-partner-card {
  background:#fff;border:1px solid var(--ip-border);
  padding:1.5rem;display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:.7rem;transition:box-shadow .3s,transform .3s;
}
.ip-partner-card:hover { box-shadow:var(--ip-shadow);transform:translateY(-2px) }
.ip-partner-logo { height:56px;display:flex;align-items:center;justify-content:center }
.ip-partner-logo img { max-height:52px;max-width:120px;object-fit:contain }
.ip-partner-logo-txt {
  font-family:'Montserrat',sans-serif;font-size:.8rem;font-weight:900;
  color:var(--ip-navy);
}
.ip-partner-cat {
  font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;color:var(--ip-orange);
}
.ip-partner-name {
  font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:700;color:var(--ip-navy);
}
.ip-partner-desc { font-size:.75rem;font-weight:300;color:var(--ip-text2);line-height:1.55 }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — pages internes
═══════════════════════════════════════════════════════════════ */

@media(max-width:1200px) {
  .nav-actions { gap:.4rem }
  .nav-btn-adhesion,.nav-btn-contact { font-size:.6rem;padding:.44rem .8rem }
  .nav-mega-services-grid { grid-template-columns:repeat(3,1fr) }
  .ip-lead { grid-template-columns:1fr }
  .ip-contact-grid { grid-template-columns:1fr }
  .ip-single-layout { grid-template-columns:1fr }
  .ip-sidebar { position:static }
  .ip-team-grid { grid-template-columns:repeat(2,1fr) }
  .ip-partner-grid { grid-template-columns:repeat(3,1fr) }
  .ip-glossaire { grid-template-columns:repeat(2,1fr) }
  .ip-roadmap { grid-template-columns:repeat(3,1fr) }
  .ip-steps { grid-template-columns:repeat(2,1fr) }
  .ip-steps::before { display:none }
}

@media(max-width:900px) {
  .nav-actions .nav-btn-support { display:none }
  .ip-grid.cols-4 { grid-template-columns:repeat(2,1fr) }
  .ip-grid { grid-template-columns:repeat(2,1fr) }
  .ip-stats { grid-template-columns:repeat(2,1fr) }
  .ip-blog-grid { grid-template-columns:repeat(2,1fr) }
  .ip-doc-grid { grid-template-columns:repeat(2,1fr) }
  .ip-media-grid { grid-template-columns:repeat(2,1fr) }
}

@media(max-width:768px) {
  .nav-links { display:none }
  .nav-actions { display:none }
  .nav-hamburger { display:flex }

  .page-band { padding:6.5rem 6% 2rem }
  .page-band-title { font-size:clamp(1.8rem,7vw,2.8rem) }

  .ip-section { padding:2.5rem 6% }
  .ip-grid,.ip-grid.cols-4 { grid-template-columns:1fr }
  .ip-stats { grid-template-columns:repeat(2,1fr) }
  .ip-steps { grid-template-columns:1fr }
  .ip-roadmap { grid-template-columns:1fr }
  .ip-form-row { grid-template-columns:1fr }
  .ip-blog-grid { grid-template-columns:1fr }
  .ip-doc-grid { grid-template-columns:1fr }
  .ip-media-grid { grid-template-columns:1fr }
  .ip-team-grid { grid-template-columns:1fr }
  .ip-partner-grid { grid-template-columns:repeat(2,1fr) }
  .ip-glossaire { grid-template-columns:1fr }
  .ip-single-nav { grid-template-columns:1fr }
  .nav-mega { min-width:calc(100vw - 2rem);left:0;transform:translateX(-1rem) }
  .has-dropdown:hover .nav-mega { transform:translateX(-1rem) translateY(0) }
  .nav-mega-services-grid { grid-template-columns:repeat(2,1fr) }
}
/* ═══════════════════════════════════════════════════════════
   FLASH INFO MODALE
═══════════════════════════════════════════════════════════ */
.fi-overlay {
  position:fixed;inset:0;z-index:99999;
  display:flex;align-items:center;justify-content:center;
  background:rgba(6,16,30,.72);
  backdrop-filter:blur(4px);
  padding:1.5rem;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
}
.fi-overlay.fi-in  { opacity:1;pointer-events:all }
.fi-overlay.fi-out { opacity:0;pointer-events:none }

.fi-modal {
  background:#fff;
  max-width:580px;width:100%;
  max-height:85vh;overflow-y:auto;
  border-top:4px solid var(--orange);
  box-shadow:0 32px 80px rgba(6,16,30,.35);
  transform:translateY(24px) scale(.97);
  transition:transform .35s cubic-bezier(.22,1,.36,1);
  border-radius:2px;
}
.fi-overlay.fi-in .fi-modal { transform:translateY(0) scale(1) }

.fi-modal--alerte { border-top-color:#f59e0b }
.fi-modal--urgent { border-top-color:#ef4444 }
.fi-modal--info   { border-top-color:var(--ip-navy,#0a1f5c) }

.fi-modal-header {
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.4rem .7rem;
  border-bottom:1px solid rgba(12,38,113,.07);
}
.fi-badge {
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--ip-text3,#8a8aaa);
}
.fi-close {
  background:none;border:none;cursor:pointer;
  font-size:1.1rem;color:var(--ip-text3,#8a8aaa);
  padding:.2rem .4rem;transition:color .2s;line-height:1;
}
.fi-close:hover { color:var(--ip-navy,#0a1f5c) }

.fi-modal-body { padding:1.4rem 1.8rem 1rem }
.fi-titre {
  font-family:'Montserrat',sans-serif;font-size:1.25rem;font-weight:800;
  color:var(--ip-navy,#0a1f5c);margin:0 0 .3rem;line-height:1.3;
}
.fi-date {
  font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--ip-text3,#8a8aaa);margin-bottom:1rem;
}
.fi-resume {
  font-size:.95rem;font-weight:500;color:var(--ip-text,#1a1a2e);
  line-height:1.7;margin-bottom:.9rem;
}
.fi-contenu {
  font-size:.88rem;color:var(--ip-text2,#4a4a6a);
  line-height:1.8;border-top:1px solid rgba(12,38,113,.07);
  padding-top:.9rem;margin-top:.5rem;
}
.fi-btn {
  display:inline-flex;align-items:center;gap:.4rem;
  margin-top:1.1rem;
  background:var(--orange);color:#fff;
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.65rem 1.4rem;transition:opacity .2s;
}
.fi-btn:hover { opacity:.88;color:#fff }

.fi-modal-footer {
  padding:.9rem 1.8rem 1.2rem;
  border-top:1px solid rgba(12,38,113,.07);
  text-align:right;
}
.fi-dismiss {
  background:none;border:1px solid rgba(12,38,113,.15);cursor:pointer;
  font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--ip-text3,#8a8aaa);padding:.5rem 1.1rem;
  transition:all .2s;
}
.fi-dismiss:hover { background:var(--ip-bg2);color:var(--ip-navy) }

@media(max-width:600px) {
  .fi-modal-body { padding:1.2rem 1.2rem .8rem }
  .fi-modal-footer { padding:.8rem 1.2rem 1rem }
  .fi-titre { font-size:1.05rem }
}

/* ═══════════════════════════════════════════════════════════
   PAGE RÉALISATIONS
═══════════════════════════════════════════════════════════ */
.ip-rl-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.4rem;
  margin-top:2rem;
}
.ip-rl-card {
  background:#fff;
  box-shadow:var(--ip-shadow);
  border-top:3px solid var(--ip-green);
  display:flex;flex-direction:column;
  overflow:hidden;
  transition:transform .25s var(--e1),box-shadow .25s;
}
.ip-rl-card:hover {
  transform:translateY(-4px);
  box-shadow:0 12px 36px rgba(12,38,113,.12);
}
.ip-rl-img {
  height:180px;
  background-size:cover;background-position:center;
  flex-shrink:0;
}
.ip-rl-body { padding:1.4rem 1.5rem;display:flex;flex-direction:column;gap:.6rem;flex:1 }

.ip-rl-header {
  display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;
}
.ip-rl-num {
  font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:900;
  color:var(--ip-navy);opacity:.25;
}
.ip-rl-annee {
  font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--ip-text3);
}
.ip-rl-badge {
  font-family:'Montserrat',sans-serif;font-size:.5rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--ip-green);
  border:1px solid var(--ip-green);
  padding:.15rem .5rem;margin-left:auto;
}
.ip-rl-titre {
  font-family:'Montserrat',sans-serif;font-size:.92rem;font-weight:700;
  color:var(--ip-navy);line-height:1.4;
}
.ip-rl-impact {
  display:flex;align-items:center;gap:.5rem;
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;
  color:var(--ip-green);
}
.ip-rl-impact-icon {
  width:18px;height:18px;border-radius:50%;
  background:var(--ip-green);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;flex-shrink:0;
}
.ip-rl-desc { font-size:.85rem;color:var(--ip-text2);line-height:1.75 }

@media(max-width:1100px){ .ip-rl-grid{ grid-template-columns:repeat(2,1fr) } }
@media(max-width:650px) { .ip-rl-grid{ grid-template-columns:1fr } }

/* ═══════════════════════════════════════════════════════════
   BOUTON RECHERCHE NAV
═══════════════════════════════════════════════════════════ */
.nav-btn-search {
  background:none;border:none;cursor:pointer;
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.65);
  transition:color .2s, background .2s;
  flex-shrink:0;
}
.nav-btn-search:hover {
  color:#fff;
  background:rgba(255,255,255,.08);
}

/* ═══════════════════════════════════════════════════════════
   SEARCH OVERLAY
═══════════════════════════════════════════════════════════ */
.search-overlay {
  position:fixed;inset:0;z-index:99998;
  background:rgba(6,16,30,.88);
  backdrop-filter:blur(14px);
  display:flex;align-items:flex-start;justify-content:center;
  padding:120px 1.5rem 2rem;
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
}
.search-overlay.active { opacity:1;pointer-events:all }

.search-overlay-inner {
  width:100%;max-width:680px;
  transform:translateY(-16px);
  transition:transform .35s cubic-bezier(.22,1,.36,1);
}
.search-overlay.active .search-overlay-inner { transform:translateY(0) }

.search-close {
  position:fixed;top:1.4rem;right:1.8rem;
  background:rgba(255,255,255,.08);border:none;cursor:pointer;
  color:rgba(255,255,255,.6);font-size:1.1rem;
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.search-close:hover { background:rgba(255,255,255,.16);color:#fff }

.search-label {
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.35);margin-bottom:1rem;
}

.search-form {
  display:flex;align-items:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.15);
  border-bottom:2px solid var(--orange);
  transition:border-color .2s;
}
.search-form:focus-within { border-color:rgba(255,255,255,.3);border-bottom-color:var(--orange) }

.search-input {
  flex:1;background:none;border:none;outline:none;
  font-family:'Montserrat',sans-serif;font-size:1.4rem;font-weight:300;
  color:#fff;padding:1rem 1.2rem;
  caret-color:var(--orange);
}
.search-input::placeholder { color:rgba(255,255,255,.25) }

.search-submit {
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.4);padding:.8rem 1.2rem;
  transition:color .2s;display:flex;align-items:center;
}
.search-submit:hover { color:var(--orange) }

/* Résultats */
.search-results { margin-top:1rem }

.search-loading, .search-empty {
  font-family:'Montserrat',sans-serif;font-size:.78rem;
  color:rgba(255,255,255,.4);padding:.8rem 0;
  font-style:italic;
}
.search-empty strong { color:rgba(255,255,255,.7);font-style:normal }

.search-result-list {
  list-style:none;
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}
.search-result-item { border-bottom:1px solid rgba(255,255,255,.06) }
.search-result-item:last-child { border-bottom:none }

.search-result-link {
  display:flex;flex-direction:column;gap:.2rem;
  padding:.85rem 1.1rem;
  transition:background .2s;
}
.search-result-link:hover { background:rgba(255,255,255,.06) }

.search-result-type {
  font-family:'Montserrat',sans-serif;font-size:.5rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--orange);
}
.search-result-title {
  font-family:'Montserrat',sans-serif;font-size:.88rem;font-weight:600;
  color:#fff;line-height:1.3;
}
.search-result-excerpt {
  font-size:.75rem;color:rgba(255,255,255,.45);line-height:1.5;
}

.search-all-results {
  display:block;margin-top:.8rem;
  font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.06em;color:var(--orange);
  text-align:right;transition:opacity .2s;
}
.search-all-results:hover { opacity:.75;color:var(--orange) }

.search-hint {
  margin-top:1.2rem;
  font-family:'Montserrat',sans-serif;font-size:.58rem;
  color:rgba(255,255,255,.2);text-align:center;
}
.search-hint kbd {
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  border-radius:3px;padding:.1rem .35rem;font-size:.6rem;
  font-family:monospace;color:rgba(255,255,255,.4);
}

@media(max-width:600px) {
  .search-overlay { padding:80px 1rem 2rem }
  .search-input { font-size:1.1rem }
}