@charset "UTF-8";
:root{
  --night:#1A186E;--navy:#2D2A8F;--violet:#7B3FCC;--fuchsia:#E040AB;
  --cyan:#00B4D8;--lav:#EDE9FB;--lav2:#B8A9E0;--lav3:#D4CDF5;
  --off:#F8F7FF;--white:#fff;--text:#111827;--muted:#4B5563;
  --border:#E9E7F7;--green:#059669;--amber:#D97706;--red:#DC2626;
  --grad-main:linear-gradient(135deg,#1A186E,#6B2FBF,#E040AB);
  --grad-warm:linear-gradient(135deg,#9B2FCC 0%,#E040AB 55%,#FF1A8C 100%);
  --grad-night:linear-gradient(140deg,#080621 0%,#120F5E 45%,#2A0B4E 100%);
  --grad-hero:linear-gradient(145deg,#060519 0%,#0E0B50 35%,#1A0D58 65%,#260A4A 100%);
  --grad-card:linear-gradient(135deg,rgba(123,63,204,.05),rgba(224,64,171,.03));
  --grad-border:linear-gradient(135deg,rgba(123,63,204,.5),rgba(224,64,171,.5));
  --grad-text:linear-gradient(135deg,#C084FC,#E040AB);
  --glow-v:0 0 48px rgba(123,63,204,.22);
  --glow-f:0 0 48px rgba(224,64,171,.18);
  --sh-xs:0 1px 4px rgba(17,24,39,.04);
  --sh-sm:0 2px 12px rgba(45,42,143,.06);
  --sh-md:0 8px 32px rgba(45,42,143,.10);
  --sh-lg:0 20px 60px rgba(45,42,143,.14);
  --sh-xl:0 32px 80px rgba(45,42,143,.18);
  --r-xs:6px;--r-sm:10px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-2xl:40px;--r-full:999px;
  --sec:108px;--sec-sm:72px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;overflow-x:clip}
body{font-family:"Plus Jakarta Sans",sans-serif;font-size:16px;line-height:1.7;color:var(--text);background:#fff}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;font-family:inherit;border:none;background:none}
h1,h2,h3,h4{font-family:"Bricolage Grotesque",sans-serif;letter-spacing:-.035em;line-height:1.07}
.wrap{max-width:1120px;margin:0 auto;padding:0 40px}
.s{padding:var(--sec) 0}
.eg{font-style:normal;background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* -- BANNER --------------------------------------- */
.banner{background:var(--grad-main);padding:11px 40px;display:flex;align-items:center;justify-content:center;gap:18px;position:relative;z-index:200}
.banner p{font-size:.77rem;color:rgba(255,255,255,.8);font-weight:500;text-align:center;line-height:1.4}
.banner strong{color:#fff}
.bnr-btn{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:#fff;padding:4px 15px;border-radius:var(--r-full);font-size:.71rem;font-weight:700;white-space:nowrap;transition:.2s}
.bnr-btn:hover{background:rgba(255,255,255,.26)}
.bnr-close{position:absolute;right:18px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.58);font-size:.85rem;padding:6px;line-height:1;transition:.2s}
.bnr-close:hover{color:#fff}

/* -- NAV ------------------------------------------- */

.nav{position:sticky;top:40px;z-index:200;background:#fff;transition:box-shadow .2s}
.nav.scrolled{box-shadow:0 4px 28px rgba(45,42,143,.09)}
.nav-i{max-width:1160px;margin:0 auto;padding:0 44px;height:84px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;padding:6px 0;margin-right:4px;transition:opacity .22s;line-height:0}
.nav-logo:hover{opacity:.82}

.nav-links{display:flex;align-items:center;gap:2px}
.nav-item{position:relative}
.nav-item::after{content:"";position:absolute;left:0;right:0;top:100%;height:14px}
.nav-link{font-size:.82rem;font-weight:600;color:rgba(30,28,80,.80);padding:8px 11px;border-radius:999px;transition:all .18s;cursor:pointer;display:block;letter-spacing:.01em;white-space:nowrap}
.nav-link:hover{color:var(--violet);background:rgba(123,63,204,.07)}
.nav-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.burger{display:none;flex-direction:column;gap:5px;padding:6px}
.burger span{width:20px;height:2px;background:var(--navy);border-radius:2px;display:block;transition:.3s}
.mmenu{position:fixed;inset:0;z-index:500;background:var(--night);display:flex;flex-direction:column;padding:76px 32px 36px;transform:translateX(-100%);transition:.3s cubic-bezier(.4,0,.2,1)}
.mmenu.open{transform:none}
.mmenu a{color:rgba(255,255,255,.72);font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.02rem;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.05);display:block;transition:.2s}
.mmenu a:hover{color:#fff;padding-left:8px}
.mmenu-cta{margin-top:22px;background:var(--grad-warm) !important;color:#fff !important;padding:15px 22px;border-radius:var(--r-lg);font-weight:800;text-align:center;border:none !important}

/* -- TRUSTBAR -------------------------------------- */
.tbar{background:var(--night);padding:13px 40px;border-bottom:1px solid rgba(255,255,255,.04)}
.tbar-i{max-width:1120px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.4);font-size:.71rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase}
.ti-sep{width:1px;height:12px;background:rgba(255,255,255,.07)}

/* -- HERO V3 --------------------------------------- */
.hero{background:var(--grad-hero);padding:96px 40px 92px;position:relative;overflow:hidden;min-height:620px;display:flex;align-items:center}
.hero-orb1{position:absolute;width:860px;height:860px;border-radius:50%;background:radial-gradient(circle,rgba(123,63,204,.16) 0%,transparent 65%);right:-220px;top:-280px;pointer-events:none;animation:ospin 30s linear infinite}
.hero-orb2{position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(224,64,171,.1) 0%,transparent 65%);left:-120px;bottom:-180px;pointer-events:none;animation:ospin 42s linear infinite reverse}
.hero-orb3{position:absolute;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(0,180,216,.08) 0%,transparent 65%);right:32%;top:22%;pointer-events:none}
@keyframes ospin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}
.hero-inner{max-width:1120px;width:100%;margin:0 auto;position:relative;z-index:2;display:grid;grid-template-columns:1fr 440px;gap:64px;align-items:center}
/* Badge pill */
.hero-pill{display:inline-flex;align-items:center;gap:8px;padding:5px 16px 5px 8px;border-radius:var(--r-full);border:1px solid rgba(224,64,171,.22);background:rgba(224,64,171,.06);font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:26px;backdrop-filter:blur(8px)}
.hero-dot{width:8px;height:8px;border-radius:50%;background:var(--fuchsia);box-shadow:0 0 10px var(--fuchsia);animation:blink 2s infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}
.hero h1{font-size:clamp(2.9rem,5.5vw,5rem);font-weight:800;color:#fff;margin-bottom:22px;letter-spacing:-.05em;line-height:.97}
.hero h1 .line2{display:block;background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-desc{font-size:.98rem;color:rgba(255,255,255,.82);line-height:1.88;max-width:490px;margin-bottom:34px}
.hero-desc strong{color:rgba(255,255,255,.9);font-weight:700}
.hero-ctas{display:flex;gap:11px;flex-wrap:wrap;margin-bottom:38px}
.btn-hp{display:inline-flex;align-items:center;gap:9px;background:var(--grad-warm);color:#fff;padding:14px 26px;border-radius:var(--r-md);font-weight:700;font-size:.91rem;transition:all .25s;box-shadow:0 8px 32px rgba(224,64,171,.45);cursor:pointer;border:none;font-family:inherit;letter-spacing:.01em}
.btn-hp:hover{transform:translateY(-2px);box-shadow:0 16px 44px rgba(224,64,171,.42)}
.btn-hs{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);color:rgba(255,255,255,.86);padding:13px 22px;border-radius:var(--r-md);font-weight:600;font-size:.89rem;transition:all .2s;backdrop-filter:blur(8px)}
.btn-hs:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.22)}
.hero-trust{display:flex;gap:18px;flex-wrap:wrap}
.hero-ti{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.3);font-size:.72rem;font-weight:600;letter-spacing:.03em}
/* Founder frame */
.hero-visual{position:relative;display:flex;justify-content:center}
.founder-frame{position:relative;width:350px;height:412px}
.founder-frame::before{content:"";position:absolute;inset:-2px;border-radius:30px;background:var(--grad-border);z-index:0;opacity:.55}
.founder-frame::after{content:"";position:absolute;inset:-28px;border-radius:44px;background:radial-gradient(circle,rgba(123,63,204,.14) 0%,transparent 70%);z-index:-1}
.founder-img-wrap{position:absolute;inset:2px;border-radius:28px;overflow:hidden;background:linear-gradient(145deg,#1a1060,#2a0f50);z-index:1}
.founder-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:brightness(.96) contrast(1.04)}
.founder-img-wrap::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(12,6,60,.5) 0%,transparent 52%);pointer-events:none}
.fbadge-top{position:absolute;top:-14px;right:-22px;background:#fff;border-radius:15px;padding:9px 13px;box-shadow:var(--sh-lg);display:flex;align-items:center;gap:9px;z-index:10}
.fbadge-ico{width:32px;height:32px;border-radius:9px;background:var(--grad-main);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fbadge-txt{font-size:.7rem;font-weight:700;color:var(--night);line-height:1.3}
.fbadge-txt span{display:block;font-size:.63rem;color:var(--muted);font-weight:500;margin-top:1px}
.fbadge-bot{position:absolute;bottom:-14px;left:-22px;background:var(--grad-night);border:1px solid rgba(123,63,204,.2);border-radius:15px;padding:11px 15px;box-shadow:var(--sh-lg);z-index:10;min-width:190px}
.fbadge-bot-title{font-size:.71rem;color:#fff;font-weight:700;margin-bottom:5px;display:flex;align-items:center;gap:5px}
.fbadge-bot-sub{font-size:.63rem;color:rgba(255,255,255,.4);line-height:1.5}
.fbadge-dots{display:flex;gap:4px;margin-top:7px}
.fbadge-dot{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 7px rgba(5,150,105,.5)}
.founder-quali{position:absolute;top:50%;right:-32px;transform:translateY(-50%);background:#fff;border-radius:11px;padding:7px 10px;box-shadow:var(--sh-md);display:flex;align-items:center;gap:7px;z-index:10}
.founder-quali img{width:26px;height:auto;flex-shrink:0}
.founder-quali span{font-size:.6rem;font-weight:700;color:var(--night);line-height:1.3;display:block;max-width:60px}

/* -- TRUST RIBBON ---------------------------------- */
.trust-ribbon{background:var(--off);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:0 40px}
.trust-ribbon-i{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}
.tstat{background:var(--off);padding:22px 26px;display:flex;align-items:center;gap:14px}
.tstat-ico{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tstat-lbl{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:.96rem;color:#1A186E;letter-spacing:-.02em;line-height:1.2}
.tstat-sub{font-size:.74rem;color:#4B5563;margin-top:2px;line-height:1.4}

/* -- SECTION HEADERS ------------------------------- */
.label{font-size:.66rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--violet);margin-bottom:11px;display:flex;align-items:center;gap:8px}
.label::before{content:"";width:18px;height:2px;background:var(--grad-warm);border-radius:1px;flex-shrink:0}
.s-title{font-size:clamp(1.9rem,3.4vw,2.9rem);font-weight:800;color:var(--night);letter-spacing:-.04em;margin-bottom:16px;line-height:1.05}
.s-sub{font-size:.96rem;color:#374151;max-width:540px;line-height:1.85}
.s-header{margin-bottom:52px}

/* -- PERSONAS -------------------------------------- */
.personas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:46px}
.pcard{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:26px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;flex-direction:column}
.pcard-bar{position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-warm);transform:scaleX(0);transform-origin:left;transition:.3s}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--sh-xl);border-color:rgba(123,63,204,.18)}
.pcard:hover .pcard-bar{transform:scaleX(1)}
.pcard-ico{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;flex-shrink:0}
.pcard-name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.05rem;color:var(--night);margin-bottom:7px;letter-spacing:-.03em}
.pcard-desc{font-size:.84rem;color:#374151;line-height:1.72;margin-bottom:14px;flex:1}
.pcard-probs{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.pcard-prob{display:flex;align-items:flex-start;gap:7px;font-size:.8rem;color:var(--text);line-height:1.5}
.pcard-arr{color:var(--violet);font-weight:700;flex-shrink:0}
.pcard-cta{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--lav);color:var(--violet);padding:9px 14px;border-radius:var(--r-md);font-weight:700;font-size:.8rem;transition:all .2s;border:1px solid var(--lav3);margin-top:auto}
.pcard-cta:hover{background:var(--violet);color:#fff;border-color:var(--violet)}

/* -- STORY / ABOUT --------------------------------- */
.story{background:var(--grad-night);position:relative;overflow:hidden}
.story-orb{position:absolute;width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(123,63,204,.09),transparent 70%);right:-180px;top:-200px;pointer-events:none}
.story-orb2{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(224,64,171,.05),transparent 70%);left:-80px;bottom:-80px;pointer-events:none}
.story-i{display:grid;grid-template-columns:420px 1fr;gap:72px;align-items:center;position:relative;z-index:2}
.story-photo{position:relative;border-radius:26px;overflow:hidden}
.story-photo img{width:100%;height:480px;object-fit:cover;object-position:center top;filter:brightness(.91)}
.story-photo::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:3px;background:var(--grad-warm);z-index:3}
.story-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,transparent 52%,rgba(10,7,55,.68));pointer-events:none;z-index:2}
.story-caption{position:absolute;bottom:22px;left:22px;right:22px;z-index:4}
.story-caption-name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.05rem;color:#fff;letter-spacing:-.03em}
.story-caption-role{font-size:.74rem;color:rgba(255,255,255,.5);margin-top:3px}
.story-vals{display:flex;flex-direction:column;gap:9px;margin-top:18px}
.story-val{display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:var(--r-md);padding:12px 15px;transition:.2s}
.story-val:hover{background:rgba(255,255,255,.07);border-color:rgba(123,63,204,.18)}
.story-val-ico{width:32px;height:32px;border-radius:9px;background:var(--grad-warm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.story-val-txt{font-size:.82rem;color:rgba(255,255,255,.72);font-weight:600;line-height:1.35}
.story-val-sub{font-size:.7rem;color:rgba(255,255,255,.52);margin-top:1px}
.story-lbl{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--fuchsia);margin-bottom:14px}
.story-h2{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(2.1rem,3.3vw,2.85rem);font-weight:800;color:#fff;letter-spacing:-.05em;line-height:1.02;margin-bottom:24px}
.story-p{font-size:.95rem;color:rgba(255,255,255,.78);line-height:1.88;margin-bottom:18px}
.story-p strong{color:rgba(255,255,255,.86);font-weight:700}
.story-quote{border-left:3px solid var(--fuchsia);padding:18px 22px;margin:24px 0;background:rgba(224,64,171,.05);border-radius:0 14px 14px 0}
.story-quote-text{font-size:.98rem;color:rgba(255,255,255,.75);font-style:italic;line-height:1.72;margin-bottom:7px}
.story-quote-author{font-size:.7rem;color:rgba(255,255,255,.58);font-weight:600;letter-spacing:.07em;text-transform:uppercase}
.story-ctas{display:flex;gap:11px;flex-wrap:wrap;margin-top:28px}

/* -- DIFFERENTIATEURS ------------------------------ */
.diff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:46px}
.diff-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:26px;transition:all .28s;position:relative;overflow:hidden}
.diff-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-warm);transform:scaleX(0);transition:.28s;transform-origin:left}
.diff-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(123,63,204,.14)}
.diff-card:hover::before{transform:scaleX(1)}
.diff-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.diff-title{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.02rem;color:var(--night);margin-bottom:7px;letter-spacing:-.03em}
.diff-desc{font-size:.84rem;color:var(--muted);line-height:1.72}
.diff-pill{display:inline-flex;align-items:center;gap:4px;margin-top:12px;padding:3px 11px;border-radius:var(--r-full);font-size:.63rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}

/* -- OFFRES ---------------------------------------- */
.offres-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.ocard{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;transition:all .3s;position:relative}
.ocard:hover{transform:translateY(-5px);box-shadow:var(--sh-xl);border-color:rgba(123,63,204,.14)}
.ocard.featured{border-color:rgba(123,63,204,.28);box-shadow:0 0 0 3px rgba(123,63,204,.06)}
.ocard-topbar{height:3px;background:var(--border)}
.ocard.featured .ocard-topbar{background:var(--grad-warm)}
.ocard-badge{position:absolute;top:18px;right:18px;background:var(--grad-warm);color:#fff;padding:3px 11px;border-radius:var(--r-full);font-size:.61rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;z-index:1}
.ocard-head{padding:26px 26px 18px}
.ocard-ico{width:50px;height:50px;border-radius:15px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.ocard-title{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.2rem;color:var(--night);margin-bottom:7px;letter-spacing:-.04em}
.ocard-desc{font-size:.84rem;color:var(--muted);line-height:1.74;margin-bottom:14px}
.ocard-tools{display:flex;flex-wrap:wrap;gap:5px}
.ocard-tool{background:var(--off);border:1px solid var(--border);border-radius:var(--r-full);padding:2px 9px;font-size:.69rem;font-weight:600;color:var(--text)}
.ocard-body{padding:0 26px 26px;flex:1;display:flex;flex-direction:column}
.ocard-sep{height:1px;background:var(--border);margin:18px 0}
.ocard-feats{display:flex;flex-direction:column;gap:9px;flex:1;margin-bottom:20px}
.ocard-feat{display:flex;align-items:flex-start;gap:8px;font-size:.84rem;color:var(--text);line-height:1.55}
.feat-chk{width:17px;height:17px;border-radius:50%;background:rgba(5,150,105,.1);border:1px solid rgba(5,150,105,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.ocard-cta{display:flex;align-items:center;justify-content:center;gap:7px;background:var(--grad-main);color:#fff;padding:12px;border-radius:var(--r-md);font-weight:700;font-size:.85rem;transition:all .2s;cursor:pointer;border:none;font-family:inherit;margin-top:auto;letter-spacing:.01em}
.ocard-cta:hover{opacity:.9;transform:translateY(-1px)}

/* -- SECTORS --------------------------------------- */
.sectors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:46px}
.scard{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;transition:all .26s;display:flex;flex-direction:column}
.scard:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:rgba(123,63,204,.14)}
.scard-ico{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0}
.scard-name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.02rem;color:var(--night);margin-bottom:5px;letter-spacing:-.03em}
.scard-desc{font-size:.83rem;color:var(--muted);line-height:1.7;margin-bottom:14px;flex:1}
.scard-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:14px}
.scard-tag{padding:2px 9px;border-radius:var(--r-full);font-size:.66rem;font-weight:600;color:var(--violet);background:var(--lav);border:1px solid var(--lav3)}
.scard-link{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:700;color:var(--violet);transition:all .2s;margin-top:auto}
.scard-link:hover{gap:9px;color:var(--night)}

/* -- CAS CONCRETS ---------------------------------- */
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:46px}
.case-card{background:var(--off);border:1px solid var(--border);border-radius:var(--r-xl);padding:26px;transition:all .26s;display:flex;flex-direction:column;position:relative;overflow:hidden}
.case-card::before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--grad-warm)}
.case-card:hover{border-color:rgba(123,63,204,.18);box-shadow:var(--sh-md);transform:translateY(-3px)}
.case-sector{display:inline-flex;align-items:center;gap:5px;padding:3px 11px;border-radius:var(--r-full);background:var(--lav);color:var(--violet);font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;border:1px solid var(--lav3)}
.case-situ{font-size:.82rem;color:var(--muted);line-height:1.65;margin-bottom:13px;flex:1}
.case-situ strong{color:var(--text)}
.case-result{display:flex;align-items:flex-start;gap:7px;background:rgba(5,150,105,.06);border:1px solid rgba(5,150,105,.12);border-radius:var(--r-md);padding:11px 13px;margin-top:auto}
.case-result-ico{width:18px;height:18px;border-radius:50%;background:rgba(5,150,105,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.case-result-txt{font-size:.8rem;color:var(--green);font-weight:600;line-height:1.5}
.case-levers{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px}
.case-lever{padding:2px 8px;border-radius:var(--r-full);font-size:.65rem;font-weight:600;color:var(--text);background:#fff;border:1px solid var(--border)}

/* -- METHOD ---------------------------------------- */
.method-2col{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:start}
.msteps{display:flex;flex-direction:column}
.mstep{display:flex;gap:18px;padding-bottom:26px;position:relative}
.mstep::before{content:"";position:absolute;left:20px;top:42px;bottom:0;width:2px;background:linear-gradient(var(--lav3) 0%,transparent 100%)}
.mstep:last-child{padding-bottom:0}
.mstep:last-child::before{display:none}
.mstep-n{width:40px;height:40px;border-radius:50%;background:var(--night);color:#fff;font-family:"Bricolage Grotesque",sans-serif;font-size:.86rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1;position:relative;border:2px solid rgba(123,63,204,.18)}
.mstep.hi .mstep-n{background:var(--grad-warm);border:none;box-shadow:0 4px 14px rgba(224,64,171,.3)}
.mstep-title{font-weight:700;color:var(--text);margin-bottom:3px;font-size:.9rem;letter-spacing:-.01em}
.mstep-desc{font-size:.84rem;color:var(--muted);line-height:1.7}
.mstep-tag{display:inline-block;margin-top:7px;padding:2px 11px;border-radius:var(--r-full);background:var(--lav);color:var(--violet);font-size:.63rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
/* VS Box */
.vs-box{background:var(--grad-night);border-radius:var(--r-xl);padding:32px;position:relative;overflow:hidden;border:1px solid rgba(123,63,204,.09)}
.vs-box::after{content:"MOJO";position:absolute;right:-6px;bottom:-20px;font-family:"Bricolage Grotesque",sans-serif;font-size:6rem;color:rgba(255,255,255,.03);line-height:1;font-weight:800;pointer-events:none;letter-spacing:-.04em}
.vs-lbl{font-size:.6rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--fuchsia);margin-bottom:18px;display:flex;align-items:center;gap:7px}
.vs-lbl::after{content:"";flex:1;height:1px;background:rgba(224,64,171,.18)}
.vs-rows{display:flex;flex-direction:column;gap:7px}
.vs-row{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.mc{padding:10px 12px;border-radius:var(--r-sm);font-size:.77rem;font-weight:500;line-height:1.45}
.mc-bad{background:rgba(255,255,255,.04);color:rgba(255,255,255,.3)}
.mc-bad .mct,.mc-ok .mct{font-size:.57rem;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:2px}
.mc-bad .mct{color:rgba(255,255,255,.16)}
.mc-ok{background:rgba(224,64,171,.07);border:1px solid rgba(224,64,171,.14);color:rgba(255,255,255,.84)}
.mc-ok .mct{color:var(--fuchsia)}
.vs-cta{display:flex;align-items:center;justify-content:center;gap:7px;background:var(--grad-warm);color:#fff;padding:12px;border-radius:var(--r-md);font-weight:700;font-size:.84rem;transition:all .2s;margin-top:22px;box-shadow:0 4px 14px rgba(224,64,171,.22)}
.vs-cta:hover{opacity:.9;transform:translateY(-1px)}

/* -- TEMOIGNAGES ----------------------------------- */
.temos{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.temo{background:var(--off);border:1px solid var(--border);border-radius:var(--r-xl);padding:26px;transition:all .22s;display:flex;flex-direction:column}
.temo:hover{border-color:rgba(123,63,204,.14);box-shadow:var(--sh-sm);transform:translateY(-3px)}
.temo-stars{color:var(--violet);font-size:.84rem;margin-bottom:10px;letter-spacing:2px}
.temo-res{display:inline-flex;align-items:center;gap:5px;background:rgba(5,150,105,.07);border:1px solid rgba(5,150,105,.12);border-radius:var(--r-full);padding:3px 11px;font-size:.68rem;font-weight:700;color:var(--green);margin-bottom:13px}
.temo-text{font-size:.85rem;color:var(--muted);line-height:1.8;font-style:italic;margin-bottom:18px;flex:1}
.temo-author{display:flex;align-items:center;gap:11px;padding-top:14px;border-top:1px solid var(--border);margin-top:auto}
.temo-av{width:38px;height:38px;border-radius:50%;background:var(--grad-main);display:flex;align-items:center;justify-content:center;font-family:"Bricolage Grotesque",sans-serif;font-weight:800;color:#fff;flex-shrink:0;font-size:.8rem}
.temo-name{font-weight:700;color:var(--text);font-size:.84rem}
.temo-role{font-size:.71rem;color:var(--muted)}

/* -- FINANCEMENT ----------------------------------- */
.fin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}
.fin-card{background:var(--off);border:1px solid var(--border);border-radius:var(--r-xl);padding:26px;transition:all .24s}
.fin-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:rgba(123,63,204,.09)}
.fin-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.fin-name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.06rem;color:var(--night);margin-bottom:7px;letter-spacing:-.03em}
.fin-desc{font-size:.84rem;color:var(--muted);line-height:1.7;margin-bottom:12px}
.fin-list{display:flex;flex-direction:column;gap:7px}
.fin-li{display:flex;align-items:flex-start;gap:6px;font-size:.8rem;color:var(--text);line-height:1.5}
.fin-li::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--green);flex-shrink:0;margin-top:7px}
.fin-note{background:rgba(217,119,6,.05);border:1px solid rgba(217,119,6,.14);border-radius:var(--r-md);padding:14px 18px;margin-top:26px;font-size:.81rem;color:var(--text);line-height:1.72}
.fin-note strong{color:var(--amber)}
.fin-cta-row{margin-top:32px;background:var(--grad-night);border-radius:var(--r-xl);padding:36px;display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap}
.fin-cta-row h3{font-family:"Bricolage Grotesque",sans-serif;font-size:1.75rem;color:#fff;margin-bottom:5px;letter-spacing:-.04em}
.fin-cta-row p{color:rgba(255,255,255,.65);font-size:.88rem}

/* -- BLOG ------------------------------------------ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.blog-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;transition:all .28s}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.blog-thumb{height:148px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.blog-cat-pill{position:absolute;top:12px;left:12px;background:rgba(16,13,72,.82);color:var(--lav2);padding:2px 11px;border-radius:var(--r-full);font-size:.63rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;backdrop-filter:blur(6px)}
.blog-body{padding:20px;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;align-items:center;gap:7px;margin-bottom:9px;font-size:.7rem;color:var(--muted)}
.blog-h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:.95rem;color:var(--night);margin-bottom:7px;letter-spacing:-.02em;line-height:1.3}
.blog-excerpt{font-size:.82rem;color:var(--muted);line-height:1.7;flex:1;margin-bottom:14px}
.blog-lnk{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:700;color:var(--violet);transition:all .2s;margin-top:auto}
.blog-lnk:hover{gap:9px}

/* -- FAQ ------------------------------------------- */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 52px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:13px;padding:16px 0;cursor:pointer;font-weight:600;font-size:.88rem;color:var(--text);transition:color .2s;width:100%;background:none;border:none;font-family:inherit;text-align:left;letter-spacing:-.01em}
.faq-q:hover{color:var(--navy)}
.faq-arr{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .28s;color:var(--muted)}
.faq-item.open .faq-arr{transform:rotate(45deg);border-color:var(--violet);background:var(--violet);color:#fff}
.faq-ans{max-height:0;overflow:hidden;transition:max-height .38s ease}
.faq-ans-in{padding-bottom:16px;font-size:.85rem;color:var(--muted);line-height:1.82}

/* -- CTA FINAL ------------------------------------- */
.cta-final{background:var(--grad-night);padding:var(--sec) 40px;text-align:center;position:relative;overflow:hidden}
.cta-final-orb{position:absolute;width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(123,63,204,.08),transparent 65%);left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none}
.cta-final-orb2{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(224,64,171,.06),transparent 65%);right:-80px;bottom:-80px;pointer-events:none}
.cta-pre{font-size:.64rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--lav2);margin-bottom:14px;position:relative;z-index:1}
.cta-final h2{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(2.3rem,4.2vw,4rem);font-weight:800;color:#fff;letter-spacing:-.05em;margin-bottom:13px;position:relative;z-index:1;line-height:.99}
.cta-final-sub{color:rgba(255,255,255,.65);font-size:.96rem;margin:0 auto 40px;max-width:460px;line-height:1.85;position:relative;z-index:1}
.cta-final-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.cfb1{background:var(--grad-warm);color:#fff;padding:16px 30px;border-radius:var(--r-md);font-weight:700;font-size:.93rem;display:flex;align-items:center;gap:8px;transition:all .25s;box-shadow:0 8px 28px rgba(224,64,171,.22)}
.cfb1:hover{opacity:.92;transform:translateY(-2px);box-shadow:0 16px 44px rgba(224,64,171,.34)}
.cfb2{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.84);padding:16px 28px;border-radius:var(--r-md);font-weight:600;font-size:.93rem;display:flex;align-items:center;gap:7px;transition:all .2s;backdrop-filter:blur(8px)}
.cfb2:hover{background:rgba(255,255,255,.12)}
.cta-note{color:rgba(255,255,255,.2);font-size:.71rem;margin-top:20px;position:relative;z-index:1}

/* -- FOOTER V3 ------------------------------------- */
.footer{background:#07061e;color:rgba(255,255,255,.38)}
.footer-strip{background:rgba(123,63,204,.07);border-bottom:1px solid rgba(123,63,204,.09);padding:28px 40px}
.footer-strip-i{max-width:1120px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap}
.footer-strip-h{font-family:"Bricolage Grotesque",sans-serif;font-size:1.35rem;color:#fff;letter-spacing:-.04em;margin-bottom:3px}
.footer-strip-p{font-size:.84rem;color:rgba(255,255,255,.38);line-height:1.5}
.footer-main{max-width:1120px;margin:0 auto;padding:60px 40px 44px;display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:44px;border-bottom:1px solid rgba(255,255,255,.04)}
.footer-brand img{max-width:170px;height:auto;margin-bottom:14px}
.footer-tagline{font-size:.92rem;font-family:"Bricolage Grotesque",sans-serif;color:rgba(255,255,255,.58);font-weight:700;margin-bottom:9px;letter-spacing:-.02em;line-height:1.4}
.footer-desc{font-size:.76rem;color:rgba(255,255,255,.52);line-height:1.84;margin-bottom:16px}
.footer-quali{display:flex;align-items:center;gap:11px;padding:11px 13px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:var(--r-md)}
.footer-quali img{filter:brightness(0) invert(1);opacity:.35;width:42px;height:auto;flex-shrink:0}
.footer-quali p{font-size:.7rem;color:rgba(255,255,255,.52);line-height:1.6}
.footer-quali strong{color:rgba(255,255,255,.78)}
.footer-socials{display:flex;gap:7px;margin-top:16px}
.footer-social{width:32px;height:32px;border-radius:9px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.58);transition:all .2s}
.footer-social:hover{background:rgba(123,63,204,.18);border-color:rgba(123,63,204,.28);color:var(--lav2)}
.footer-col-title{font-weight:700;color:rgba(255,255,255,.65);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-link{font-size:.77rem;color:rgba(255,255,255,.58);transition:all .2s;display:flex;align-items:center;gap:5px}
.footer-link:hover{color:rgba(255,255,255,.76);padding-left:4px}
.footer-cta-btn{background:var(--grad-warm);color:#fff;padding:12px 16px;border-radius:var(--r-md);font-weight:700;font-size:.79rem;display:flex;align-items:center;gap:7px;transition:all .2s;justify-content:center;box-shadow:0 4px 16px rgba(224,64,171,.18);margin-bottom:14px}
.footer-cta-btn:hover{opacity:.9;transform:translateY(-1px)}
.footer-bottom{max-width:1120px;margin:0 auto;padding:22px 40px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom-copy{font-size:.72rem;color:rgba(255,255,255,.22)}
.footer-legal{display:flex;gap:16px;flex-wrap:wrap}
.footer-legal a{font-size:.72rem;color:rgba(255,255,255,.22);transition:.2s}
.footer-legal a:hover{color:rgba(255,255,255,.58)}

/* -- FLOAT BUTTONS --------------------------------- */
.float{position:fixed;bottom:26px;right:26px;z-index:400;display:flex;flex-direction:column;gap:9px;align-items:flex-end}
.fbtn{display:flex;align-items:center;gap:8px;padding:11px 18px;border-radius:var(--r-full);font-weight:700;font-size:.81rem;box-shadow:0 4px 22px rgba(0,0,0,.18);transition:all .22s;white-space:nowrap}
.fbtn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.25)}
.fbtn-wa{background:#25D366;color:#fff}
.fbtn-diag{background:var(--grad-warm);color:#fff;box-shadow:0 4px 22px rgba(224,64,171,.24)}

/* -- INNER PAGES ----------------------------------- */

.page-hero::before{content:"";position:absolute;width:660px;height:660px;border-radius:50%;background:radial-gradient(circle,rgba(123,63,204,.11),transparent 65%);right:-160px;top:-240px;pointer-events:none}
.page-hero::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(224,64,171,.06),transparent 65%);left:8%;bottom:-140px;pointer-events:none}
.page-hero-inner{max-width:640px;position:relative;z-index:2}
.page-eye{display:inline-flex;align-items:center;gap:7px;padding:4px 14px;border-radius:var(--r-full);border:1px solid rgba(255,255,255,.11);background:rgba(255,255,255,.05);font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--lav2);margin-bottom:20px;backdrop-filter:blur(8px)}
.page-hero h1{font-size:clamp(2.3rem,4.2vw,3.8rem);font-weight:800;color:#fff;margin-bottom:16px;letter-spacing:-.05em;line-height:1.02}
.page-hero-sub{font-size:.98rem;color:rgba(255,255,255,.72);line-height:1.84;max-width:540px;margin-bottom:30px}
.page-hero-sub strong{color:rgba(255,255,255,.9)}
.page-ctas{display:flex;gap:11px;flex-wrap:wrap}
.breadcrumb{background:var(--off);border-bottom:1px solid var(--border);padding:10px 0}
.breadcrumb-i{max-width:1120px;margin:0 auto;padding:0 40px;display:flex;align-items:center;gap:5px;font-size:.73rem;color:var(--muted)}
.breadcrumb-i a{color:var(--violet);transition:.2s;font-weight:500}
.breadcrumb-i a:hover{color:var(--navy)}
.bc-sep{color:var(--border)}

/* -- BUTTONS --------------------------------------- */
.btn-primary{display:inline-flex;align-items:center;gap:7px;background:var(--grad-warm);color:#fff;padding:13px 24px;border-radius:var(--r-md);font-weight:700;font-size:.89rem;transition:all .25s;box-shadow:0 6px 22px rgba(224,64,171,.24);cursor:pointer;border:none;font-family:inherit;letter-spacing:.01em}
.btn-primary:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 12px 32px rgba(224,64,171,.34)}
.btn-secondary{display:inline-flex;align-items:center;gap:7px;background:var(--lav);border:1px solid var(--lav3);color:var(--violet);padding:12px 22px;border-radius:var(--r-md);font-weight:700;font-size:.89rem;transition:all .22s;cursor:pointer;font-family:inherit;letter-spacing:.01em}
.btn-secondary:hover{background:var(--lav3);transform:translateY(-1px)}
.btn-dark{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);color:rgba(255,255,255,.86);padding:12px 22px;border-radius:var(--r-md);font-weight:600;font-size:.89rem;transition:all .2s;backdrop-filter:blur(8px)}
.btn-dark:hover{background:rgba(255,255,255,.13)}

/* -- BLOG ARTICLE ---------------------------------- */
.article-wrap{max-width:780px;margin:0 auto;padding:60px 40px}
.article-cat-pill{display:inline-block;background:var(--lav);color:var(--violet);padding:3px 13px;border-radius:var(--r-full);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px;border:1px solid var(--lav3)}
.article-h1{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(2.1rem,3.8vw,2.95rem);font-weight:800;color:var(--night);letter-spacing:-.05em;line-height:1.05;margin-bottom:16px}
.article-meta{display:flex;align-items:center;gap:13px;color:var(--muted);font-size:.77rem;padding-bottom:26px;border-bottom:1px solid var(--border);margin-bottom:34px}
.article-body h2{font-family:"Bricolage Grotesque",sans-serif;font-size:1.58rem;font-weight:800;color:var(--night);letter-spacing:-.04em;margin:40px 0 16px;line-height:1.14}
.article-body p{font-size:.96rem;color:var(--text);line-height:1.85;margin-bottom:20px}
.article-body strong{color:var(--night);font-weight:700}
.article-cta-box{background:var(--lav);border:1px solid var(--lav3);border-radius:var(--r-xl);padding:26px;margin:40px 0;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.article-cta-box h3{font-family:"Bricolage Grotesque",sans-serif;font-size:1.06rem;color:var(--night);margin-bottom:3px;letter-spacing:-.03em}
.article-cta-box p{font-size:.84rem;color:var(--muted)}
.related-sec{padding:44px 0 0;border-top:1px solid var(--border);margin-top:48px}
.related-title{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.28rem;color:var(--night);margin-bottom:22px;letter-spacing:-.03em}

/* -- ANIMATIONS ------------------------------------ */
.reveal{opacity:0;transform:translateY(12px);transition:.45s cubic-bezier(.16,1,.3,1);will-change:transform,opacity}
.reveal.on{opacity:1;transform:none;will-change:auto}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* -- RESPONSIVE ------------------------------------ */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:44px}.hero-visual{display:none}
  .story-i{grid-template-columns:1fr;gap:44px}.story-photo{display:none}
  .diff-grid{grid-template-columns:1fr 1fr}.trust-ribbon-i{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  :root{--sec:68px;--sec-sm:48px}
  .wrap{padding:0 26px}
  .personas-grid,.offres-grid{grid-template-columns:1fr}
  .sectors-grid,.cases-grid{grid-template-columns:1fr 1fr}
  .method-2col{grid-template-columns:1fr}.temos{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr 1fr}.faq-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr 1fr;gap:28px}
  .cta-final-btns{flex-direction:column;align-items:center}
  .cfb1,.cfb2{width:100%;max-width:360px;justify-content:center}
  .fin-cta-row{flex-direction:column}
}
@media(max-width:640px){
  :root{--sec:60px}
  .nav-links,.nav-actions{display:none}.burger{display:flex}
  
  .hero{padding:68px 18px 60px}
  .hero h1{font-size:clamp(2.6rem,9vw,3.8rem)}
  .diff-grid,.sectors-grid,.cases-grid{grid-template-columns:1fr}
  .trust-ribbon-i{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr;padding:44px 18px 32px}
  .footer-strip,.footer-bottom{padding:22px 18px}
  .float .fbtn span{display:none}.fbtn{padding:13px}
  .article-wrap{padding:44px 18px}
  .article-cta-box{flex-direction:column}
  .banner{padding:9px 18px}
}
@media print{.banner,.nav,.float{display:none!important}}

/* === V4+V5 ADDITIONS === */

/* 5 PILIERS */
.pillars-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:48px}
.pillar-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:26px 20px;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}
.pillar-card:hover{transform:translateY(-6px);box-shadow:var(--sh-xl);border-color:rgba(123,63,204,.18)}
.pillar-num{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:2.4rem;letter-spacing:-.06em;background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1;margin-bottom:12px}
.pillar-ico{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0}
.pillar-title{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:.96rem;color:var(--night);letter-spacing:-.03em;margin-bottom:9px;line-height:1.2}
.pillar-desc{font-size:.8rem;color:var(--muted);line-height:1.72;margin-bottom:13px;flex:1}
.pillar-examples{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.pillar-ex{display:flex;align-items:flex-start;gap:6px;font-size:.76rem;color:var(--text);line-height:1.5}
.pillar-ex::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--violet);flex-shrink:0;margin-top:4px}
.pillar-link{display:flex;align-items:center;gap:5px;font-size:.76rem;font-weight:700;color:var(--violet);transition:all .2s;margin-top:auto}
.pillar-link:hover{gap:8px;color:var(--night)}
.pillar-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--grad-warm);transform:scaleX(0);transform-origin:left;transition:.3s}
.pillar-card:hover .pillar-bar{transform:scaleX(1)}

/* DIAGNOSTIC SECTION */
.diag-section{background:var(--grad-night);position:relative;overflow:hidden}
.diag-orb{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(123,63,204,.12),transparent 70%);right:-100px;top:-150px;pointer-events:none}
.diag-i{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;position:relative;z-index:2}
.diag-lbl{font-size:.63rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--fuchsia);margin-bottom:12px}
.diag-h2{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(1.7rem,2.8vw,2.5rem);font-weight:800;color:#fff;letter-spacing:-.05em;line-height:1.05;margin-bottom:18px}
.diag-sub{font-size:.89rem;color:rgba(255,255,255,.48);line-height:1.82;margin-bottom:26px}
.diag-steps{display:flex;flex-direction:column;gap:0}
.diag-step{display:flex;gap:15px;padding:17px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.diag-step:last-child{border-bottom:none}
.diag-step-n{width:32px;height:32px;border-radius:50%;background:var(--grad-warm);color:#fff;font-family:"Bricolage Grotesque",sans-serif;font-size:.78rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.diag-step-title{font-weight:700;color:#fff;font-size:.88rem;margin-bottom:3px}
.diag-step-desc{font-size:.8rem;color:rgba(255,255,255,.65);line-height:1.6}
.diag-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);padding:30px}
.diag-card-title{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.1rem;color:#fff;margin-bottom:18px;letter-spacing:-.03em}
.diag-gets{display:flex;flex-direction:column;gap:13px;margin-bottom:24px}
.diag-get{display:flex;align-items:flex-start;gap:11px}
.diag-get-ico{width:34px;height:34px;border-radius:9px;background:rgba(123,63,204,.2);border:1px solid rgba(123,63,204,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.diag-get-title{font-weight:700;font-size:.84rem;color:rgba(255,255,255,.86);margin-bottom:2px}
.diag-get-desc{font-size:.76rem;color:rgba(255,255,255,.38);line-height:1.5}
.diag-note{font-size:.72rem;color:rgba(255,255,255,.26);margin-top:12px;text-align:center}

/* PROFILES */
.profiles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:44px}
.profile-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:22px 24px;display:flex;align-items:flex-start;gap:15px;transition:all .25s;position:relative;overflow:hidden;text-decoration:none;color:inherit}
.profile-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-warm);transform:scaleX(0);transform-origin:left;transition:.28s}
.profile-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:rgba(123,63,204,.15)}
.profile-card:hover::before{transform:scaleX(1)}
.profile-ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.profile-name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:.94rem;color:var(--night);margin-bottom:5px;letter-spacing:-.02em;line-height:1.2}
.profile-desc{font-size:.8rem;color:var(--muted);line-height:1.62;margin-bottom:9px}
.profile-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:9px}
.profile-tag{padding:2px 9px;border-radius:var(--r-full);background:var(--lav);color:var(--violet);font-size:.64rem;font-weight:600;border:1px solid var(--lav3);white-space:nowrap}
.profile-link{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:700;color:var(--violet);transition:all .2s}
.profile-link:hover{gap:8px}

/* SITE WEB VS */
.siteweb-split{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:start}
.siteweb-vs{background:var(--off);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
.siteweb-vs-row{display:grid;grid-template-columns:1fr 1fr}
.siteweb-vs-head{padding:13px 18px;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.siteweb-vs-head.bad{background:#FEF2F2;color:#DC2626;border-bottom:1px solid rgba(220,38,38,.1)}
.siteweb-vs-head.good{background:var(--lav);color:var(--violet);border-bottom:1px solid var(--lav3)}
.siteweb-vs-body{padding:16px 18px;display:flex;flex-direction:column;gap:10px}
.siteweb-vs-item{display:flex;align-items:flex-start;gap:7px;font-size:.8rem;line-height:1.5}
.siteweb-vs-item.bad{color:var(--muted)}
.siteweb-vs-item.bad::before{content:"";display:inline-block;width:10px;height:2px;background:#DC2626;border-radius:1px;margin-top:7px;flex-shrink:0}
.siteweb-vs-item.good{color:var(--text)}
.siteweb-vs-item.good::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;margin-top:4px}

/* QUALIOPI FOOTER -- logo officiel couleurs sur fond blanc */
.footer-quali{display:flex;align-items:center;gap:11px;padding:10px 14px;background:#fff;border-radius:var(--r-md)}
.footer-quali img{width:90px;height:auto;flex-shrink:0;filter:none;opacity:1}
.footer-quali p{font-size:.7rem;color:rgba(0,0,0,.55);line-height:1.6}
.footer-quali strong{color:rgba(0,0,0,.72);font-weight:700}

/* STORY */
.story{background:var(--grad-night);position:relative;overflow:hidden}
.story-orb{position:absolute;width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(123,63,204,.09),transparent 70%);right:-180px;top:-200px;pointer-events:none}
.story-orb2{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(224,64,171,.05),transparent 70%);left:-80px;bottom:-80px;pointer-events:none}
.story-i{display:grid;grid-template-columns:420px 1fr;gap:72px;align-items:center;position:relative;z-index:2}
.story-photo{position:relative;border-radius:26px;overflow:hidden}
.story-photo img{width:100%;height:480px;object-fit:cover;object-position:center top;filter:brightness(.91)}
.story-photo::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:3px;background:var(--grad-warm);z-index:3}
.story-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,transparent 52%,rgba(10,7,55,.68));pointer-events:none;z-index:2}
.story-caption{position:absolute;bottom:22px;left:22px;right:22px;z-index:4}
.story-caption-name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.05rem;color:#fff;letter-spacing:-.03em}
.story-caption-role{font-size:.74rem;color:rgba(255,255,255,.5);margin-top:3px}
.story-vals{display:flex;flex-direction:column;gap:9px;margin-top:18px}
.story-val{display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:var(--r-md);padding:12px 15px;transition:.2s}
.story-val:hover{background:rgba(255,255,255,.07)}
.story-val-ico{width:32px;height:32px;border-radius:9px;background:var(--grad-warm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.story-val-txt{font-size:.82rem;color:rgba(255,255,255,.72);font-weight:600;line-height:1.35}
.story-val-sub{font-size:.7rem;color:rgba(255,255,255,.52);margin-top:1px}
.story-lbl{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--fuchsia);margin-bottom:14px}
.story-h2{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(2rem,3.2vw,2.7rem);font-weight:800;color:#fff;letter-spacing:-.05em;line-height:1.02;margin-bottom:22px}
.story-p{font-size:.94rem;color:rgba(255,255,255,.78);line-height:1.88;margin-bottom:18px}
.story-p strong{color:rgba(255,255,255,.86);font-weight:700}
.story-quote{border-left:3px solid var(--fuchsia);padding:16px 20px;margin:22px 0;background:rgba(224,64,171,.05);border-radius:0 14px 14px 0}
.story-quote-text{font-size:.97rem;color:rgba(255,255,255,.74);font-style:italic;line-height:1.72;margin-bottom:7px}
.story-quote-author{font-size:.7rem;color:rgba(255,255,255,.58);font-weight:600;letter-spacing:.07em;text-transform:uppercase}
.story-ctas{display:flex;gap:11px;flex-wrap:wrap;margin-top:26px}

/* MISC */
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.s-sm{padding:72px 0}

/* RESPONSIVE ADDITIONS */
@media(max-width:1200px){.pillars-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){
  .pillars-grid{grid-template-columns:1fr 1fr}
  .diag-i{grid-template-columns:1fr;gap:36px}
  .siteweb-split{grid-template-columns:1fr;gap:44px}
  .profiles-grid{grid-template-columns:1fr 1fr}
  .story-i{grid-template-columns:1fr;gap:44px}
  .story-photo{display:none}
  .s-sm{padding:52px 0}
}
@media(max-width:640px){
  .pillars-grid{grid-template-columns:1fr}
  .profiles-grid{grid-template-columns:1fr}
  .siteweb-vs-row{grid-template-columns:1fr}
  .pillar-num{font-size:1.8rem}
}

/* -- STICKY MOBILE CTA --------------------------- */
.sticky-cta-mobile{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;padding:12px 20px 16px;background:linear-gradient(to top,rgba(255,255,255,1) 80%,rgba(255,255,255,0));padding-bottom:max(16px,env(safe-area-inset-bottom))}
.sticky-cta-mobile a{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--grad-warm);color:#fff;padding:14px 20px;border-radius:var(--r-full);font-weight:800;font-size:.9rem;box-shadow:0 8px 32px rgba(224,64,171,.4);width:100%;letter-spacing:.01em}
@media(max-width:767px){.sticky-cta-mobile{display:block}}

/* -- IMPROVED CONTRAST FIXES --------------------- */
.diff-card p,.ocard-desc,.case-desc,.blog-excerpt,.testi-text{color:#374151 !important}
.fin-name{font-weight:700;color:#111827}
.prog-title{color:#1A186E;font-weight:700}
.faq-q{color:#111827;font-weight:700}
.form-label{color:#111827;font-weight:600}

/* -- LOGO INLINE (HTML+SVG -- polices heritees de la page) ------- */
.nav-logo{display:flex!important;align-items:center;text-decoration:none;gap:0}
.logo-moj{
  font-family:"Bricolage Grotesque","Arial Black",Arial,sans-serif;
  font-weight:900;font-size:32px;color:#1A186E;
  letter-spacing:-.08em;line-height:1;
  transition:color .25s;
  -webkit-font-smoothing:antialiased
}
.logo-disc{
  flex-shrink:0;display:block!important;
  width:36px!important;height:36px!important;margin:0 4px
}
.logo-acad{
  font-family:"Plus Jakarta Sans","Helvetica Neue",Arial,sans-serif;
  font-weight:700;font-size:8px;color:rgba(30,28,80,.48);
  letter-spacing:.26em;text-transform:uppercase;
  align-self:flex-end;padding-bottom:4px;padding-left:6px;
  white-space:nowrap;
  -webkit-font-smoothing:antialiased
}
.nav-logo{
  display:flex!important;align-items:center;text-decoration:none;gap:0;
  padding:8px 0;margin-right:8px;
  transition:opacity .25s
}
.nav-logo:hover { opacity:.82 }
.nav-logo:hover .logo-moj { color:var(--violet) }
/* Footer logo (fond sombre -> texte blanc) */
.footer-brand a{display:flex;align-items:center;text-decoration:none;gap:0}
.logo-moj-f{
  font-family:"Bricolage Grotesque","Arial Black",Arial,sans-serif;
  font-weight:900;font-size:32px;color:#fff;
  letter-spacing:-.08em;line-height:1;
  -webkit-font-smoothing:antialiased
}
.logo-disc-f{
  flex-shrink:0;display:block!important;
  width:36px!important;height:36px!important;margin:0 4px
}
.logo-acad-f{
  font-family:"Plus Jakarta Sans","Helvetica Neue",Arial,sans-serif;
  font-weight:700;font-size:8px;color:rgba(255,255,255,.50);
  letter-spacing:.26em;text-transform:uppercase;
  align-self:flex-end;padding-bottom:4px;padding-left:6px;white-space:nowrap;
  -webkit-font-smoothing:antialiased
}
/* -- END LOGO ----------------------------------------------------- */

/* --------------------------------------------------------------
   FORMATION PAGES -- QUALIOPI COMPONENTS
   -------------------------------------------------------------- */

/* Hero meta pills */
.hero-meta-pills{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 24px}

.hmp-green{background:rgba(5,150,105,.12);border-color:rgba(5,150,105,.25);color:rgba(255,255,255,.8)}

/* Problematiques grid */
.problems-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:40px}
.prob-card{background:rgba(123,63,204,.06);border:1px solid rgba(123,63,204,.12);border-radius:16px;padding:20px;transition:.2s}
.prob-card:hover{border-color:rgba(123,63,204,.3);background:rgba(123,63,204,.1)}
.prob-ico{font-size:1.5rem;margin-bottom:10px}
.prob-txt{font-size:.82rem;color:var(--text);line-height:1.65}
.prob-txt strong{color:var(--heading);display:block;margin-bottom:4px}

/* Objectifs grid */
.obj-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px}
.obj-item{display:flex;gap:16px;align-items:flex-start;background:rgba(255,255,255,.5);border:1px solid rgba(123,63,204,.08);border-radius:16px;padding:20px}
.obj-num{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.1rem;color:rgba(123,63,204,.35);flex-shrink:0;min-width:28px}
.obj-body{font-size:.83rem;color:var(--text);line-height:1.65}
.obj-body strong{color:var(--heading)}

/* Programme modules */
.prog-modules{display:flex;flex-direction:column;gap:16px}
.prog-mod{border:1px solid rgba(123,63,204,.12);border-radius:18px;overflow:hidden}
.prog-mod-head{display:flex;align-items:center;gap:16px;padding:18px 22px;background:rgba(123,63,204,.05);border-bottom:1px solid rgba(123,63,204,.08)}
.prog-mod-num{font-size:.6rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--fuchsia);white-space:nowrap}
.prog-mod-title{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1rem;color:var(--heading);flex:1}
.prog-mod-dur{font-size:.74rem;color:var(--muted);white-space:nowrap;background:rgba(255,255,255,.7);border:1px solid rgba(0,0,0,.06);padding:4px 10px;border-radius:999px}
.prog-mod-body{padding:18px 22px;display:flex;flex-direction:column;gap:12px}
.prog-seq{display:flex;align-items:flex-start;gap:12px;font-size:.83rem;color:var(--text);line-height:1.6}
.prog-seq-dot{width:7px;height:7px;border-radius:50%;background:var(--fuchsia);flex-shrink:0;margin-top:7px}
.prog-tag-row{display:flex;flex-wrap:wrap;gap:7px;margin-top:6px;padding-top:12px;border-top:1px solid rgba(0,0,0,.05)}
.prog-tag{font-size:.69rem;font-weight:700;background:rgba(123,63,204,.08);border:1px solid rgba(123,63,204,.15);color:var(--violet);padding:4px 11px;border-radius:999px}

/* Methodes list */
.meth-list{display:flex;flex-direction:column;gap:14px}
.meth-item{display:flex;align-items:flex-start;gap:12px;font-size:.83rem;color:var(--text);line-height:1.6}
.meth-ico{font-size:1.1rem;flex-shrink:0;margin-top:1px}

/* Eval cards */
.eval-cards{display:flex;flex-direction:column;gap:11px;margin-top:24px}
.eval-card{background:rgba(255,255,255,.6);border:1px solid rgba(123,63,204,.1);border-radius:14px;padding:14px 16px}
.eval-card-head{display:flex;align-items:center;gap:9px;margin-bottom:6px}
.eval-ico{font-size:1.1rem}
.eval-card p{font-size:.78rem;color:var(--text);line-height:1.55;margin:0}

/* Info pratiques grid */
.info-prat-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:40px}
.ip-card{background:rgba(255,255,255,.7);border:1px solid rgba(0,0,0,.07);border-radius:16px;padding:18px}
.ip-card-highlight{background:rgba(123,63,204,.05);border-color:rgba(123,63,204,.2);grid-column:1/-1}
.ip-icon{font-size:1.4rem;margin-bottom:8px}
.ip-label{font-size:.62rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--violet);margin-bottom:7px}
.ip-val{font-size:.82rem;color:var(--text);line-height:1.65}

/* VS table */
.vs-table{border:1px solid rgba(123,63,204,.12);border-radius:18px;overflow:hidden;margin-top:40px}
.vs-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;border-bottom:1px solid rgba(0,0,0,.06)}
.vs-row:last-child{border-bottom:none}
.vs-head{background:rgba(123,63,204,.06)}
.vs-c1,.vs-c2,.vs-c3{padding:13px 16px;font-size:.82rem;color:var(--text)}
.vs-head .vs-c1,.vs-head .vs-c2,.vs-head .vs-c3{font-weight:800;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.vs-c2{border-left:1px solid rgba(0,0,0,.06);color:var(--muted)}
.vs-c3{border-left:1px solid rgba(123,63,204,.1);background:rgba(123,63,204,.03)}
.vs-yes{color:var(--green);font-weight:700;margin-right:4px}
.vs-no{color:#ef4444;font-weight:700;margin-right:4px}

/* CTA final section */
.cta-final-section{background:linear-gradient(160deg,rgba(123,63,204,.06) 0%,rgba(224,64,171,.04) 100%)}

/* Responsive */
@media(max-width:900px){
  .problems-grid{grid-template-columns:1fr 1fr}
  .obj-grid{grid-template-columns:1fr}
  .info-prat-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .problems-grid{grid-template-columns:1fr}
  .info-prat-grid{grid-template-columns:1fr}
  .vs-row{grid-template-columns:1fr}
  .vs-c2,.vs-c3{border-left:none;border-top:1px solid rgba(0,0,0,.05)}
  .vs-c2{display:none}
  .hero-meta-pills{gap:6px}
}
/* -------------------------------------------------------------- */

/* -- PROB-ICO: CSS counter numbered badge (replaces emojis) -------------- */
.problems-grid { counter-reset: prob-counter; }
.prob-card { counter-increment: prob-counter; }
.prob-ico {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(123,63,204,.1);
  border: 1px solid rgba(123,63,204,.18);
  color: var(--violet);
  font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 800;
  font-size: .78rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.prob-ico::after {
  content: counter(prob-counter, decimal-leading-zero);
}

/* -- METH-ICO: SVG container -------------------------------------------- */
.meth-ico {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: rgba(123,63,204,.08);
  border: 1px solid rgba(123,63,204,.14);
  color: var(--violet);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}
.meth-ico svg { stroke: var(--violet); }

/* -- EVAL-ICO: SVG container -------------------------------------------- */
.eval-ico {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: rgba(123,63,204,.08);
  border: 1px solid rgba(123,63,204,.14);
  color: var(--violet);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.eval-ico svg { stroke: var(--violet); }

/* -- IP-ICON: SVG container --------------------------------------------- */
.ip-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(123,63,204,.07);
  border: 1px solid rgba(123,63,204,.12);
  color: var(--violet);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
}
.ip-icon svg { stroke: var(--violet); }

/* -- CONTRAST IMPROVEMENTS: micro-texts, FAQ, labels -------------------- */
/* Increase base text darkness */
:root {
  --text-secondary: rgba(30,28,80,.62);   /* was .5 */
  --text-muted: rgba(30,28,80,.44);       /* was .36 */
}

/* FAQ answer text */
.faq-a p {
  font-size: .86rem;
  color: rgba(30,28,80,.68);
  line-height: 1.75;
}

/* FAQ question */
.faq-q {
  font-size: .92rem;
  color: rgba(30,28,80,.88);
  font-weight: 600;
}

/* Programme module descriptions */
.prog-seq > div {
  font-size: .84rem;
  color: rgba(30,28,80,.72);
  line-height: 1.7;
}

/* Eval card descriptions */
.eval-card p {
  font-size: .80rem;
  color: rgba(30,28,80,.66);
  line-height: 1.6;
}

/* Informations pratiques values */
.ip-val {
  font-size: .83rem;
  color: rgba(30,28,80,.72);
  line-height: 1.7;
}

/* Problématiques card text */
.prob-txt {
  font-size: .83rem;
  color: rgba(30,28,80,.7);
  line-height: 1.65;
}
.prob-txt strong {
  color: rgba(30,28,80,.9);
  display: block;
  margin-bottom: 4px;
  font-size: .86rem;
}

/* Objectifs body text */
.obj-body {
  font-size: .84rem;
  color: rgba(30,28,80,.72);
  line-height: 1.68;
}
.obj-body strong { color: rgba(30,28,80,.92); }

/* Programme tags */
.prog-tag {
  font-size: .70rem;
  font-weight: 700;
  color: var(--violet);
  background: rgba(123,63,204,.09);
  border-color: rgba(123,63,204,.18);
}

/* Méthodes pédagogiques text */
.meth-item > div {
  font-size: .84rem;
  color: rgba(30,28,80,.72);
  line-height: 1.68;
}
.meth-item > div strong { color: rgba(30,28,80,.9); }

/* Footer text legibility */
.footer-desc { color: rgba(255,255,255,.58); }
.footer-link { color: rgba(255,255,255,.52); }
.footer-link:hover { color: rgba(255,255,255,.85); }

/* s-sub (subtitle text in sections) */
.s-sub {
  font-size: .90rem;
  color: rgba(30,28,80,.64);
  line-height: 1.75;
}

/* Page hero subtitle */
.page-hero-sub {
  font-size: .95rem;
  color: rgba(255,255,255,.72);
  line-height: 1.72;
}

/* Hero desc on dark */
.hero-desc {
  color: rgba(255,255,255,.72);
  line-height: 1.78;
}

/* Module body text */
.prog-mod-body { color: rgba(30,28,80,.72); }

/* IP card label */
.ip-label {
  font-size: .63rem;
  font-weight: 800;
  letter-spacing: .16em;
  color: var(--violet);
  margin-bottom: 7px;
}

/* Donya creds - contrast boost */
.donya-creds-role { color: rgba(255,255,255,.56); }
.donya-cred-item { color: rgba(255,255,255,.62); }
.donya-cred-stat { color: rgba(255,255,255,.80); }
.donya-creds-label { color: var(--fuchsia); }

/* -- END CONTRAST & ICON IMPROVEMENTS ----------------------------------- */

/* -- COMPETENCES TAGS -------------------------------------------------- */
.comp-tags { display:flex;flex-wrap:wrap;gap:8px;margin-top:4px }
.comp-tag {
  font-size:.78rem;font-weight:600;
  background:rgba(123,63,204,.07);
  border:1px solid rgba(123,63,204,.18);
  color:var(--violet);
  padding:7px 14px;border-radius:999px;
  transition:.2s;
}
.comp-tag:hover { background:rgba(123,63,204,.14); }

/* -- RESULTATS ATTENDUS ------------------------------------------------- */
.res-attend-list { display:flex;flex-direction:column;gap:12px;margin-top:4px }
.res-attend-item {
  display:flex;align-items:flex-start;gap:10px;
  font-size:.85rem;color:rgba(30,28,80,.78);line-height:1.6;
}
.res-attend-item svg { flex-shrink:0;margin-top:2px }

/* -- OUTILS GRID -------------------------------------------------------- */
.outils-grid {
  display:flex;flex-wrap:wrap;gap:10px;
}
.outil-card {
  background:#fff;border:1px solid rgba(123,63,204,.14);
  border-radius:10px;padding:10px 18px;
  font-size:.82rem;font-weight:700;color:rgba(30,28,80,.78);
  box-shadow:0 1px 4px rgba(0,0,0,.04);
  transition:all .2s;
}
.outil-card:hover {
  border-color:rgba(123,63,204,.35);
  color:var(--violet);
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(123,63,204,.12);
}

/* -- END NEW SECTIONS --------------------------------------------------- */

/* -- CAS PRATIQUES & EXERCICES ------------------------------------------ */
.cas-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 680px) { .cas-grid { grid-template-columns: 1fr; } }

.cas-item {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  background: #fff;
  border: 1px solid rgba(123,63,204,.1);
  border-radius: 14px;
  padding: 22px;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
  transition: .2s;
}
.cas-item:hover {
  border-color: rgba(123,63,204,.22);
  box-shadow: 0 4px 18px rgba(123,63,204,.09);
}
.cas-num {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(123,63,204,.08);
  border: 1px solid rgba(123,63,204,.15);
  color: var(--violet);
  font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 800;
  font-size: .82rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cas-body strong {
  display: block;
  font-size: .88rem;
  font-weight: 700;
  color: rgba(30,28,80,.92);
  margin-bottom: 6px;
}
.cas-body p {
  font-size: .82rem;
  color: rgba(30,28,80,.66);
  line-height: 1.65;
  margin: 0;
}
/* -- END CAS PRATIQUES -------------------------------------------------- */

/* -- PARCOURS FLOW ------------------------------------------------------ */
.parcours-flow {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 720px;
  margin: 0 auto;
}
.parcours-step {
  display: flex;
  gap: 22px;
  align-items: flex-start;
  background: #fff;
  border: 1px solid rgba(123,63,204,.12);
  border-radius: 14px;
  padding: 22px 24px;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.parcours-step-num {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--violet), var(--fuchsia));
  color: #fff;
  font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 900;
  font-size: .82rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.parcours-step-title {
  font-size: .92rem;
  font-weight: 700;
  color: rgba(30,28,80,.92);
  margin-bottom: 6px;
}
.parcours-step-desc {
  font-size: .82rem;
  color: rgba(30,28,80,.66);
  line-height: 1.6;
  margin: 0 0 10px;
}
.parcours-step-link {
  font-size: .78rem;
  font-weight: 700;
  color: var(--violet);
  text-decoration: none;
}
.parcours-step-link:hover { text-decoration: underline; }
.parcours-arrow {
  display: flex;
  justify-content: flex-start;
  padding-left: 56px;
  margin: 4px 0;
}
/* -- END PARCOURS -------------------------------------------------------- */

/* -- FINAL CONTRAST PASS ------------------------------------------------ */
/* Improved readability throughout */
.prog-seq > div { color: rgba(30,28,80,.74); font-size:.845rem; line-height:1.72; }
.prog-seq strong { color: rgba(30,28,80,.92); }
.obj-body { color: rgba(30,28,80,.74); font-size:.85rem; line-height:1.7; }
.obj-body strong { color: rgba(30,28,80,.92); font-weight:700; }
.faq-q { color: rgba(30,28,80,.90); font-size:.92rem; font-weight:600; line-height:1.5; }
.faq-a p { color: rgba(30,28,80,.70); font-size:.86rem; line-height:1.78; }
.cas-body p { color: rgba(30,28,80,.68); font-size:.83rem; }
.cas-body strong { color: rgba(30,28,80,.92); font-size:.88rem; }
.eval-card p { color: rgba(30,28,80,.68); font-size:.81rem; }
.ip-val { color: rgba(30,28,80,.74); font-size:.84rem; }
.ip-label { color: var(--violet); font-size:.63rem; font-weight:800; letter-spacing:.16em; margin-bottom:8px; }
.meth-item > div { color: rgba(30,28,80,.73); font-size:.845rem; line-height:1.7; }
.meth-item strong { color: rgba(30,28,80,.91); }
.s-sub { color: rgba(30,28,80,.66); font-size:.91rem; line-height:1.77; }
.page-hero-sub { color: rgba(255,255,255,.74); font-size:.96rem; line-height:1.74; }
.label { color: var(--violet); font-size:.64rem; font-weight:800; letter-spacing:.2em; text-transform:uppercase; margin-bottom:10px; }
.footer-link { color: rgba(255,255,255,.54); font-size:.82rem; }
.footer-link:hover { color: rgba(255,255,255,.88); }
.footer-desc { color: rgba(255,255,255,.60); font-size:.83rem; line-height:1.72; }
/* placeholder text */
input::placeholder, textarea::placeholder { color: rgba(30,28,80,.38); }
/* nav links */
.nav-link { color: rgba(30,28,80,.78); font-size:.84rem; font-weight:600; }
.parcours-step-desc { color: rgba(30,28,80,.68); font-size:.83rem; }
.res-attend-item { color: rgba(30,28,80,.76); font-size:.86rem; }
.prob-txt { color: rgba(30,28,80,.72); font-size:.84rem; }
.prob-txt strong { color: rgba(30,28,80,.92); font-size:.87rem; }
.prog-mod-title { font-size:.94rem; }
/* -- END CONTRAST ------------------------------------------------------- */

/* -- TESTIMONIALS ------------------------------------------------------- */
.testimonials-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 760px) { .testimonials-grid { grid-template-columns: 1fr; } }

.testi-card {
  background: #fff;
  border: 1px solid rgba(123,63,204,.1);
  border-radius: 16px;
  padding: 26px 24px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: .2s;
}
.testi-card:hover {
  border-color: rgba(123,63,204,.2);
  box-shadow: 0 6px 24px rgba(123,63,204,.08);
}
.testi-quote {
  font-size: .875rem;
  color: rgba(30,28,80,.76);
  line-height: 1.8;
  font-style: italic;
  flex: 1;
}
.testi-author {
  display: flex;
  gap: 12px;
  align-items: center;
}
.testi-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--violet), var(--fuchsia));
  color: #fff;
  font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 800;
  font-size: .94rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.testi-name {
  font-size: .86rem;
  font-weight: 700;
  color: rgba(30,28,80,.90);
}
.testi-role {
  font-size: .76rem;
  color: rgba(30,28,80,.55);
  margin-top: 2px;
}
.testi-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.testi-tags span {
  font-size: .69rem;
  font-weight: 700;
  background: rgba(123,63,204,.07);
  border: 1px solid rgba(123,63,204,.15);
  color: var(--violet);
  padding: 3px 10px;
  border-radius: 999px;
}
/* -- END TESTIMONIALS --------------------------------------------------- */

/* -- FINAL-CONTRAST-V15 ------------------------------------------------- */
/* Strengthen key readability elements */
.faq-q { font-size:.915rem; font-weight:600; color:rgba(30,28,80,.9); padding-right:36px; }
.faq-a p { font-size:.865rem; color:rgba(30,28,80,.71); line-height:1.8; }
.prog-seq { padding:10px 0; border-bottom:1px solid rgba(30,28,80,.04); }
.prog-seq:last-of-type { border-bottom:none; }
.prog-seq > div { font-size:.85rem; color:rgba(30,28,80,.73); line-height:1.73; }
.prog-seq strong { color:rgba(30,28,80,.91); font-weight:700; }
.ip-val { font-size:.845rem; color:rgba(30,28,80,.73); line-height:1.72; }
.ip-val strong { color:rgba(30,28,80,.9); }
.ip-val a { font-weight:600; }
.testi-quote { font-size:.875rem; color:rgba(30,28,80,.75); line-height:1.82; }
.testi-name { font-size:.87rem; font-weight:700; color:rgba(30,28,80,.91); }
.testi-role { font-size:.77rem; color:rgba(30,28,80,.56); }
/* Nav legibility */
.nav-link { font-size:.845rem; font-weight:600; }
/* Footer legibility */
.footer-link { font-size:.82rem; color:rgba(255,255,255,.55); }
.footer-link:hover { color:rgba(255,255,255,.9); }
.footer-bottom-copy { font-size:.78rem; color:rgba(255,255,255,.48); }
.footer-legal a { font-size:.76rem; color:rgba(255,28,80,.44); }
/* Story blocks — dark section, white text required */
.story-p { font-size:.92rem; color:rgba(255,255,255,.78) !important; line-height:1.82; }
.story-p strong { color:rgba(255,255,255,.92) !important; }
.story-val-txt { color:rgba(255,255,255,.82) !important; }
.story-val-sub { color:rgba(255,255,255,.54) !important; }
/* Cas items */
.cas-body strong { color:rgba(30,28,80,.91); font-weight:700; }
.cas-body p { font-size:.83rem; color:rgba(30,28,80,.67); line-height:1.67; }
/* -- END FINAL-CONTRAST-V15 --------------------------------------------- */

/* ═══════════════════════════════════════════════════════════════════════
   MOBILE POLISH — v15c
   ═══════════════════════════════════════════════════════════════════════ */

/* Qualiopi components — mobile */
@media(max-width:767px){
  /* Nav logo on mobile — proper sizing */
  
  .logo-moj { font-size:27px; }
  .logo-disc { width:30px!important; height:30px!important; margin:0 3px; }
  .logo-acad { font-size:7.5px; letter-spacing:.2em; }

  /* Page hero on mobile */
  
  .page-hero h1 { font-size:clamp(1.9rem,7vw,2.6rem); }
  .page-hero-sub { font-size:.88rem; }
  .hero-meta-pills { gap:6px; }
  .hmp { font-size:.72rem; padding:5px 10px; }
  .page-ctas { flex-direction:column; gap:10px; }
  .page-ctas .btn-primary, .page-ctas .btn-dark { width:100%; text-align:center; justify-content:center; }

  /* Problems grid — single column */
  .problems-grid { grid-template-columns:1fr; gap:10px; }
  .prob-card { padding:14px 16px; }

  /* Objectives grid — single column */
  .obj-grid { grid-template-columns:1fr; gap:12px; }
  .obj-item { padding:14px 16px; }

  /* Programme modules */
  .prog-mod-head { flex-direction:column; align-items:flex-start; gap:4px; }
  .prog-mod-dur { margin-left:0; }
  .prog-mod-body { padding:14px 16px; }

  /* Méthodes + Eval — stack vertically */
  section .s > .wrap > div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }

  /* Info pratiques grid — 2 columns max on mobile */
  .info-prat-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .ip-card { padding:14px 14px; }
  .ip-card-highlight { grid-column:1/-1; }

  /* Cas pratiques */
  .cas-grid { grid-template-columns:1fr; gap:12px; }

  /* Testimonials — single column */
  .testimonials-grid { grid-template-columns:1fr; gap:14px; }
  .testi-card { padding:20px 18px; }

  /* Outils grid */
  .outils-grid { gap:8px; }
  .outil-card { padding:8px 14px; font-size:.79rem; }

  /* Comp tags */
  .comp-tag { font-size:.76rem; padding:6px 12px; }

  /* Parcours flow */
  .parcours-flow { max-width:100%; }
  .parcours-step { padding:16px 18px; gap:14px; }
  .parcours-step-num { width:38px; height:38px; font-size:.76rem; }

  /* Section grids inline */
  .s .wrap > div[style*="grid-template-columns:1fr 1fr"],
  .s .wrap > div[style*="grid-template-columns:repeat(3"],
  .s .wrap > div[style*="grid-template-columns:1fr 1.15fr"],
  .s .wrap > div[style*="grid-template-columns:1fr 1fr;"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }

  /* FAQ */
  .faq-list { margin:28px auto 0; }
  .faq-q { font-size:.88rem; }

  /* Sections padding */
  .s { padding:48px 18px; }
  .s-alt { padding:48px 18px; }
  .s-title { font-size:clamp(1.6rem,5.5vw,2.2rem); }

  /* CTA final */
  .cta-final-section .wrap > div[style*="flex"] { flex-direction:column; align-items:center; gap:10px; }
  .cta-final-section .btn-primary, .cta-final-section .btn-dark { width:100%; max-width:340px; text-align:center; justify-content:center; }
}

/* Very small screens */
@media(max-width:420px){
  .info-prat-grid { grid-template-columns:1fr; }
  .logo-moj { font-size:24px; }
  .logo-disc { width:27px!important; height:27px!important; }
}
/* ═══════════════════════════════════════════════════════════════════════ */

/* ─── CONTRAST FINAL v15c ─────────────────────────────────────────────── */
/* Stronger hierarchy for paragraph text */
p, li { color: rgba(30,28,80,.73); }
.s-sub, .page-hero-sub { color: rgba(30,28,80,.67); }

/* Ensure nav links are dark enough */
.nav > .nav-i .nav-links .nav-link { color: rgba(30,28,80,.80); }

/* FAQ stronger */
.faq-q { color: rgba(30,28,80,.91); font-weight:600; }
.faq-a { color: rgba(30,28,80,.71); }

/* Footer bottom */
.footer-legal a { color: rgba(255,255,255,.50); font-size:.77rem; }
.footer-legal a:hover { color: rgba(255,255,255,.85); }
.footer-bottom-copy { color: rgba(255,255,255,.46); font-size:.77rem; }

/* IP card values */
.ip-val { color: rgba(30,28,80,.74); }
.ip-label { color: var(--violet); opacity:.9; }

/* Prog module description */
.prog-mod-title { color: rgba(30,28,80,.92); font-size:.935rem; font-weight:700; }
.prog-mod-num { font-size:.72rem; }
.prog-mod-dur { color: rgba(30,28,80,.54); font-size:.78rem; }

/* Story blocks */
.parcours-step-title { color: rgba(30,28,80,.92); }
.parcours-step-desc { color: rgba(30,28,80,.68); font-size:.83rem; }

/* Cas clients cards */
.cas-num { font-size:.82rem; }
/* ─── END CONTRAST v15c ──────────────────────────────────────────────── */

/* -- STATS STRIP -------------------------------------------------------- */
.stats-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  background: #fff;
  border: 1px solid rgba(123,63,204,.1);
  border-radius: 16px;
  padding: 20px 32px;
  box-shadow: 0 2px 16px rgba(0,0,0,.05);
  flex-wrap: wrap;
}
.stat-item {
  text-align: center;
  padding: 8px 28px;
  flex: 1;
  min-width: 110px;
}
.stat-val {
  font-family: "Bricolage Grotesque", sans-serif;
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--violet);
  letter-spacing: -.04em;
  line-height: 1.1;
  margin-bottom: 4px;
}
.stat-lbl {
  font-size: .72rem;
  font-weight: 600;
  color: rgba(30,28,80,.56);
  text-transform: uppercase;
  letter-spacing: .1em;
  white-space: nowrap;
}
.stat-sep {
  width: 1px;
  height: 36px;
  background: rgba(123,63,204,.12);
  flex-shrink: 0;
}
@media(max-width:640px){
  .stats-strip { flex-direction:column; padding:18px 24px; gap:16px; }
  .stat-sep { width:40px; height:1px; }
  .stat-item { padding:0; }
}
/* -- END STATS STRIP ---------------------------------------------------- */

/* -- RICH TESTIMONIALS -------------------------------------------------- */
.testi-card-rich {
  background: #fff;
  border: 1px solid rgba(123,63,204,.1);
  border-radius: 18px;
  padding: 28px 26px;
  box-shadow: 0 2px 14px rgba(0,0,0,.05);
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  overflow: hidden;
  transition: .2s;
}
.testi-card-rich::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px; height: 100%;
  background: linear-gradient(180deg, var(--violet), var(--fuchsia));
  border-radius: 2px 0 0 2px;
}
.testi-card-rich:hover {
  border-color: rgba(123,63,204,.22);
  box-shadow: 0 8px 28px rgba(123,63,204,.1);
}
.testi-result-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(16,185,129,.09);
  border: 1px solid rgba(16,185,129,.2);
  color: #059669;
  font-size: .72rem;
  font-weight: 800;
  padding: 4px 12px;
  border-radius: 999px;
  letter-spacing: .04em;
  width: fit-content;
}
.testi-result-badge svg { flex-shrink:0; }
.testi-quote-rich {
  font-size: .875rem;
  color: rgba(30,28,80,.76);
  line-height: 1.82;
  font-style: italic;
  border-left: none;
}
.testi-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 14px;
  border-top: 1px solid rgba(30,28,80,.06);
}
.testi-avatar-rich {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--violet), var(--fuchsia));
  color: #fff;
  font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 900;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.testi-name-rich { font-size:.87rem; font-weight:700; color:rgba(30,28,80,.91); }
.testi-role-rich { font-size:.76rem; color:rgba(30,28,80,.55); margin-top:2px; }
.testi-formation { font-size:.7rem; font-weight:700; color:var(--violet); margin-top:4px; }
@media(max-width:640px){
  .testi-card-rich { padding:20px 18px; }
}
/* -- END RICH TESTIMONIALS ---------------------------------------------- */

/* ═══════════════════════════════════════════════════════════════════════
   OFFICIAL LOGO IMAGE — Header & Footer
   ═══════════════════════════════════════════════════════════════════════ */

/* Header logo image */
.nav-logo {
  display: flex !important;
  align-items: center;
  text-decoration: none;
  padding: 4px 0;
  margin-right: 12px;
  flex-shrink: 0;
  transition: opacity .22s;
}
.nav-logo:hover { opacity: .82; }


/* Footer logo image */
.footer-logo-link {
  display: inline-block;
  text-decoration: none;
  transition: opacity .2s;
}
.footer-logo-link:hover { opacity: .8; }
.logo-img-footer {
  height: 52px;
  width: auto;
  display: block;
  max-width: 200px;
  object-fit: contain;
}

/* Nav height — accommodates larger logo */


/* Kill old text logo CSS to avoid conflicts */
.logo-moj, .logo-disc, .logo-acad,
.logo-moj-f, .logo-disc-f, .logo-acad-f {
  display: none !important;
}

/* Mobile: smaller logo */
@media(max-width:767px){
  
  .logo-img-footer { height: 42px; }
  
}


/* ═══════════════════════════════════════════════════════════════════════ */

/* ─── HEADER BUG FIX ─────────────────────────────────────────────────── */
/* Sticky nav is now 76px — ensure content starts below it */
/* Index hero: add top padding if it overlaps */
/* Page hero on formation pages */
/* Ensure nav stays above all content */


/* Fix: ensure nav-logo doesn't get cut by overflow:hidden on nav */


/* Mobile hero fix */
@media(max-width:640px){
  }
/* ─────────────────────────────────────────────────────────────────────── */

/* ═══════════════════════════════════════════════════════════════════════
   HEADER HOMEPAGE BUG FIX + FINAL POLISH
   ═══════════════════════════════════════════════════════════════════════ */

/* Ensure sticky nav doesn't overlap content */


/* Fix: hero on homepage must start below nav */
/* Fix: page-hero consistent top spacing */
/* Fix mobile nav height with new logo */


/* Nav logo alignment — vertically center the image */


/* Footer logo alignment */
.footer-brand { 
  display: flex; 
  align-items: flex-start;
}

/* Ensure tbar + nav stack cleanly */
.tbar { position: relative; z-index: 201; }
.banner { z-index: 202; }

/* ─── CONTRAST IMPROVEMENTS v15d ─────────────────────────────────────── */
/* Slightly stronger body text */
body { color: rgba(30,28,80,.80); }
p { color: rgba(30,28,80,.74); }

/* Stronger FAQ */
.faq-q { 
  font-size: .92rem;
  font-weight: 600;
  color: rgba(30,28,80,.92) !important;
  text-align: left;
  padding: 18px 40px 18px 0;
  line-height: 1.5;
}
.faq-a p { 
  font-size: .875rem;
  color: rgba(30,28,80,.72) !important;
  line-height: 1.80;
}

/* Stronger labels everywhere */
.label { 
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .2em;
  color: var(--violet);
  opacity: 1;
  display: block;
  margin-bottom: 10px;
}

/* Stronger prog-seq */
.prog-seq > div { 
  color: rgba(30,28,80,.76) !important;
  font-size: .855rem;
  line-height: 1.74;
}
.prog-seq strong { color: rgba(30,28,80,.93) !important; }

/* Footer bottom improved */
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 18px 44px;
}
.footer-bottom-copy { 
  font-size: .78rem;
  color: rgba(255,255,255,.50);
}
.footer-legal a { 
  font-size: .77rem;
  color: rgba(255,255,255,.52);
  transition: color .2s;
}
.footer-legal a:hover { color: rgba(255,255,255,.88); }

/* IP card values stronger */
.ip-val { 
  font-size: .86rem;
  color: rgba(30,28,80,.76) !important;
  line-height: 1.73;
}
.ip-label {
  font-size: .64rem;
  letter-spacing: .18em;
  opacity: 1 !important;
  color: var(--violet) !important;
  font-weight: 800;
}

/* Eval card text */
.eval-card p {
  font-size: .82rem;
  color: rgba(30,28,80,.70) !important;
  line-height: 1.65;
}

/* Meth item text */
.meth-item > div {
  font-size: .86rem;
  color: rgba(30,28,80,.75) !important;
  line-height: 1.70;
}

/* S-sub text */
.s-sub { color: rgba(30,28,80,.68) !important; }

/* Drop menu text */
.nav-link { color: rgba(30,28,80,.82) !important; }

/* ═══════════════════════════════════════════════════════════════════════ */


/* ═══════════════════════════════════════════════════════════════════════
   NAV DÉFINITIF — Source of truth pour tous les états
   ═══════════════════════════════════════════════════════════════════════ */
.nav {
  position: sticky;
  top: 0;
  z-index: 200;
  background: rgba(255,255,255,.93);
  backdrop-filter: blur(28px) saturate(1.6);
  -webkit-backdrop-filter: blur(28px) saturate(1.6);
  border-bottom: 1px solid rgba(123,63,204,.08);
  transition: box-shadow .3s;
  will-change: transform;
}
.nav.scrolled { box-shadow: 0 4px 28px rgba(45,42,143,.08); }
.nav-i {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 44px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  overflow: visible;
}
.nav-logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
  padding: 5px 0;
  margin-right: 6px;
  transition: opacity .22s;
  line-height: 0;
}
.nav-logo:hover { opacity: .82; }

.nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
  flex: 1;
}
.nav-link {
  font-size: .82rem;
  font-weight: 600;
  color: rgba(30,28,80,.80);
  padding: 8px 11px;
  border-radius: 999px;
  transition: all .18s;
  cursor: pointer;
  display: block;
  letter-spacing: .01em;
  white-space: nowrap;
}
.nav-link:hover {
  color: var(--violet);
  background: rgba(123,63,204,.07);
}
.nav-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0;
}

/* Mobile nav */
@media(max-width:900px) {
  .nav-i { padding: 0 28px; }
}
@media(max-width:640px) {
  .nav-i { height: 62px; padding: 0 16px; }
  
  .nav-links, .nav-actions { display: none; }
  .burger { display: flex; }
}
@media(max-width:420px) {
  .nav-i { height: 56px; padding: 0 14px; }
  
}
/* ═══════════════════════════════════════════════════════════════════════ */



/* ─── PAGE HERO — DÉFINITIF ─────────────────────────────────────── */
.page-hero {
  background: var(--grad-hero);
  padding: 64px 40px 56px;
  position: relative;
  overflow: hidden;
}
html { scroll-padding-top: 80px; }
@media(max-width:640px){
  .page-hero { padding: 60px 18px 40px; }
  html { scroll-padding-top: 66px; }
}
/* ─────────────────────────────────────────────────────────────────── */

/* ─── CONTRAST SWEEP FINAL ─────────────────────────────────────────── */
/* Body text baseline */
body { color: rgba(30,28,80,.82); }

/* Section subtitles */
.s-sub { 
  font-size: .91rem !important; 
  color: rgba(30,28,80,.68) !important; 
  line-height: 1.77;
}

/* FAQ high contrast */
.faq-q { 
  color: rgba(30,28,80,.92); 
  font-size: .915rem; 
  font-weight: 600; 
  line-height: 1.52;
  padding: 18px 38px 18px 0;
}
.faq-a p { 
  color: rgba(30,28,80,.72); 
  font-size: .875rem; 
  line-height: 1.8; 
}

/* Programme modules */
.prog-seq > div { color: rgba(30,28,80,.76); font-size: .855rem; }
.prog-seq strong { color: rgba(30,28,80,.93); }

/* Objectives */
.obj-body { color: rgba(30,28,80,.75); font-size: .86rem; }
.obj-body strong { color: rgba(30,28,80,.93); }

/* Problem cards */
.prob-txt { color: rgba(30,28,80,.72); font-size: .84rem; }
.prob-txt strong { color: rgba(30,28,80,.92); }

/* Info pratiques */
.ip-val { color: rgba(30,28,80,.76); font-size: .855rem; }
.ip-label { color: var(--violet); font-weight: 800; font-size: .64rem; letter-spacing: .18em; }

/* Testimonials */
.testi-quote, .testi-quote-rich { color: rgba(30,28,80,.76); line-height: 1.82; }

/* Footer */
.footer-link { color: rgba(255,255,255,.55); }
.footer-link:hover { color: rgba(255,255,255,.90); }
.footer-bottom-copy { color: rgba(255,255,255,.48); }
.footer-legal a { color: rgba(255,255,255,.50); font-size: .77rem; }
.footer-legal a:hover { color: rgba(255,255,255,.88); }

/* Drop menu links */

/* Meth items */
.meth-item > div { color: rgba(30,28,80,.74); font-size: .855rem; }
.meth-item strong { color: rgba(30,28,80,.92); }

/* Eval cards */
.eval-card p { color: rgba(30,28,80,.70); font-size: .825rem; }

/* Cas pratiques */
.cas-body p { color: rgba(30,28,80,.68); font-size: .835rem; }
.cas-body strong { color: rgba(30,28,80,.92); }

/* Témoignages name/role */
.testi-name, .testi-name-rich { color: rgba(30,28,80,.92); }
.testi-role, .testi-role-rich { color: rgba(30,28,80,.56); }

/* Formation tags */
.testi-formation { color: var(--violet); font-size: .7rem; font-weight: 700; }

/* Outils cards */
.outil-card { color: rgba(30,28,80,.78); font-weight: 700; }

/* Stats */
.stat-lbl { color: rgba(30,28,80,.58); }

/* Hero meta pills text */
.hmp { color: rgba(30,28,80,.76); }
/* ─────────────────────────────────────────────────────────────────── */

/* ─── PILIER PAGES — MODULE CARDS ───────────────────────────────────── */
.modules-pilier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media(max-width:900px){ .modules-pilier-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){ .modules-pilier-grid { grid-template-columns:1fr; } }

.module-card {
  background: #fff;
  border: 1px solid rgba(123,63,204,.11);
  border-radius: 16px;
  padding: 22px 20px;
  box-shadow: 0 2px 10px rgba(0,0,0,.04);
  transition: all .2s;
  display: flex;
  flex-direction: column;
}
.module-card:hover {
  border-color: rgba(123,63,204,.25);
  box-shadow: 0 6px 24px rgba(123,63,204,.09);
  transform: translateY(-2px);
}
/* ─────────────────────────────────────────────────────────────────── */

/* ─── MMENU SIMPLIFIED ──────────────────────────────────────────────── */
.mmenu-section { padding: 12px 16px 4px; }
.mmenu-label {
  font-size: .64rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--violet);
  margin-bottom: 8px;
  padding: 0 0 4px;
  border-bottom: 1px solid rgba(123,63,204,.1);
}
#mmenu a {
  display: block;
  padding: 8px 4px;
  font-size: .86rem;
  font-weight: 500;
  color: rgba(30,28,80,.80);
  text-decoration: none;
  border-bottom: 1px solid rgba(30,28,80,.05);
}
#mmenu a:hover { color: var(--violet); }
/* ─────────────────────────────────────────────────────────────────── */

/* ═══════════════════════════════════════════════════════════════════════
   PILIERS INDEX — 4 Business Pillar Cards
   ═══════════════════════════════════════════════════════════════════════ */
.piliers-index-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media(max-width:680px){ .piliers-index-grid { grid-template-columns:1fr; } }

.pilier-card {
  background: #fff;
  border: 1px solid rgba(123,63,204,.12);
  border-radius: 20px;
  padding: 28px 26px;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
  transition: all .22s;
  position: relative;
  overflow: hidden;
}
.pilier-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--violet), var(--fuchsia));
  opacity: 0;
  transition: opacity .22s;
}
.pilier-card:hover {
  border-color: rgba(123,63,204,.26);
  box-shadow: 0 8px 32px rgba(123,63,204,.12);
  transform: translateY(-3px);
}
.pilier-card:hover::before { opacity: 1; }
.pilier-card-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: .78rem;
  font-weight: 700;
  color: var(--violet);
  background: rgba(123,63,204,.08);
  border: 1.5px solid rgba(123,63,204,.18);
  padding: 8px 16px;
  border-radius: 999px;
  margin-top: 4px;
  transition: all .22s;
  align-self: flex-start;
  letter-spacing: .01em;
}
.pilier-card:hover .pilier-card-link {
  background: linear-gradient(135deg, #7B3FCC, #E040AB);
  border-color: transparent;
  color: #fff;
}

.pilier-card-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: rgba(123,63,204,.07);
  border: 1px solid rgba(123,63,204,.14);
  display: flex;
  align-items: center;
  justify-content: center;
}
.pilier-card-num {
  font-family: "Bricolage Grotesque", sans-serif;
  font-size: .72rem;
  font-weight: 800;
  color: rgba(123,63,204,.5);
  letter-spacing: .1em;
}
.pilier-card-title {
  font-size: 1.02rem;
  font-weight: 700;
  color: rgba(30,28,80,.92);
  line-height: 1.4;
  margin: 0;
}
.pilier-card-desc {
  font-size: .83rem;
  color: rgba(30,28,80,.66);
  line-height: 1.68;
  margin: 0;
  flex: 1;
}
.pilier-card-modules {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.pilier-card-modules span {
  font-size: .7rem;
  font-weight: 700;
  background: rgba(123,63,204,.07);
  border: 1px solid rgba(123,63,204,.14);
  color: var(--violet);
  padding: 3px 10px;
  border-radius: 999px;
}
.pilier-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: .78rem;
  font-weight: 700;
  color: var(--violet);
  background: rgba(123,63,204,.08);
  border: 1.5px solid rgba(123,63,204,.18);
  padding: 8px 16px;
  border-radius: 999px;
  margin-top: 6px;
  transition: all .22s;
  align-self: flex-start;
  letter-spacing: .01em;
}
.pilier-card:hover .pilier-card-cta {
  background: linear-gradient(135deg, #7B3FCC, #E040AB);
  border-color: transparent;
  color: #fff;
  transform: translateX(3px);
}

/* ─── ETAPE CARDS — Comment ça marche ─────────────────────────────── */
.etape-card {
  background: #fff;
  border: 1px solid rgba(123,63,204,.1);
  border-radius: 16px;
  padding: 24px 20px;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.etape-num {
  font-family: "Bricolage Grotesque", sans-serif;
  font-size: 2rem;
  font-weight: 900;
  color: rgba(123,63,204,.15);
  line-height: 1;
  margin-bottom: 12px;
  letter-spacing: -.04em;
}
.etape-title {
  font-size: .92rem;
  font-weight: 700;
  color: rgba(30,28,80,.92);
  margin: 0 0 10px;
  line-height: 1.4;
}
.etape-desc {
  font-size: .82rem;
  color: rgba(30,28,80,.68);
  line-height: 1.7;
  margin: 0;
}
@media(max-width:900px){
  .etape-card { padding:20px 18px; }
}
@media(max-width:680px){
  section .wrap > div[style*="repeat(4,1fr)"] {
    grid-template-columns: repeat(2,1fr) !important;
  }
}
@media(max-width:480px){
  section .wrap > div[style*="repeat(4,1fr)"] {
    grid-template-columns: 1fr !important;
  }
}
/* ═══════════════════════════════════════════════════════════════════════ */

/* ─── MMENU — slide-in overlay ─────────────────────────────────────── */
#mmenu {
  display: block;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: #fff;
  z-index: 500;
  overflow-y: auto;
  padding-top: 68px;
  transform: translateX(-100%);
  transition: transform .28s cubic-bezier(.16,1,.3,1);
  visibility: hidden;
  pointer-events: none;
}
#mmenu.open {
  transform: translateX(0);
  visibility: visible;
  pointer-events: auto;
}
/* Show only on mobile */
@media(min-width:641px) {
  #mmenu { display: none !important; }
}
/* ────────────────────────────────────────────────────────────────────── */

/* ═══════════════════════════════════════════════════════════════════
   TOPBAR — 3-column layout with search
   ═══════════════════════════════════════════════════════════════════ */
.tb2{background:#09081f;height:48px;display:flex;align-items:center;position:sticky;top:0;z-index:210;border-bottom:1px solid rgba(123,63,204,.14)}
.tb2-i{max-width:1200px;margin:0 auto;padding:0 40px;width:100%;display:grid;grid-template-columns:220px 1fr auto;align-items:center;gap:20px}
.tb2-search{position:relative;display:flex;align-items:center}
.tb2-search-icon{position:absolute;left:10px;color:rgba(255,255,255,.48);pointer-events:none;flex-shrink:0}
.tb2-search-input{width:100%;height:26px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);border-radius:6px;padding:0 10px 0 30px;font-family:"Plus Jakarta Sans",sans-serif;font-size:.68rem;color:rgba(255,255,255,.88);outline:none;transition:all .18s}
.tb2-search-input::placeholder{color:rgba(255,255,255,.42)}
.tb2-search-input:focus{background:rgba(255,255,255,.13);border-color:rgba(224,64,171,.6);color:#fff}
.tb2-search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:10px;box-shadow:0 8px 32px rgba(30,28,80,.14);border:1px solid rgba(123,63,204,.1);overflow:hidden;display:none;z-index:9999;min-width:280px}
.tb2-search-results.visible{display:block}
.tb2-sr-item{display:flex;flex-direction:column;padding:10px 14px;text-decoration:none;border-bottom:1px solid rgba(30,28,80,.06);transition:background .12s}
.tb2-sr-item:last-child{border-bottom:none}
.tb2-sr-item:hover{background:rgba(123,63,204,.05)}
.tb2-sr-title{font-size:.82rem;font-weight:700;color:rgba(30,28,80,.88);line-height:1.3}
.tb2-sr-sub{font-size:.72rem;color:rgba(30,28,80,.48);margin-top:2px}
.tb2-center{text-align:center}
.tb2-claim{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;color:rgba(255,255,255,.72);white-space:nowrap}
.tb2-claim strong{color:rgba(255,255,255,.84);font-weight:700}
.tb2-claim-dot{width:6px;height:6px;border-radius:50%;background:#E040AB;flex-shrink:0;animation:pulse-dot 2.4s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.tb2-right{display:flex;align-items:center;gap:0}
.tb2-sep{width:1px;height:12px;background:rgba(255,255,255,.1);margin:0 12px;flex-shrink:0}
.tb2-a{display:flex;align-items:center;gap:5px;font-size:.68rem;font-weight:600;color:rgba(255,255,255,.48);text-decoration:none;white-space:nowrap;transition:color .14s}
.tb2-a:hover{color:rgba(255,255,255,.86)}


@media(max-width:640px){.tb2{height:38px}.tb2-i{grid-template-columns:auto 1fr auto;gap:0;padding:0 16px}.tb2-search{display:none}.tb2-center{text-align:left;padding:0 12px}.tb2-claim{font-size:.65rem;gap:6px}.tb2-right .tb2-tel,.tb2-right .tb2-wa,.tb2-right .tb2-sep{display:none}}

/* ═══════════════════════════════════════════════════════════════════
   NAV STICKY
   ═══════════════════════════════════════════════════════════════════ */
.nav{position:sticky;top:40px;z-index:200;background:#fff;transition:box-shadow .2s}
.nav.scrolled{box-shadow:0 4px 28px rgba(45,42,143,.09)}

/* ═══════════════════════════════════════════════════════════════════
   DROPDOWN — editorial, no grid
   ═══════════════════════════════════════════════════════════════════ */
.drop{position:absolute;top:calc(100% + 8px);left:50%;background:#fff;border-radius:14px;box-shadow:0 12px 48px rgba(30,28,80,.12),0 2px 8px rgba(30,28,80,.06);border:1px solid rgba(30,28,80,.07);padding:10px 0;min-width:220px;opacity:0;visibility:hidden;pointer-events:none;transform:translateX(-50%) translateY(-6px);transition:opacity .2s,transform .2s cubic-bezier(.16,1,.3,1),visibility .2s;z-index:800}
.nav-item:hover .drop,.nav-item:focus-within .drop{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.drop-lbl{display:block;font-size:.6rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:rgba(30,28,80,.32);padding:6px 20px 10px;border-bottom:1px solid rgba(30,28,80,.05);margin-bottom:4px}
.drop a{display:flex;align-items:center;gap:10px;padding:9px 20px;font-size:.84rem;font-weight:500;color:rgba(30,28,80,.78);text-decoration:none;transition:all .12s;position:relative}
.drop a::before{content:'';position:absolute;left:10px;top:50%;transform:translateY(-50%);width:2px;height:0;background:var(--violet);border-radius:2px;transition:height .18s}
.drop a:hover{color:var(--violet);background:rgba(123,63,204,.04);padding-left:24px}
.drop a:hover::before{height:18px}
.drop a svg{flex-shrink:0;opacity:.5;transition:opacity .12s}
.drop a:hover svg{opacity:1}
.drop-sep{height:1px;background:rgba(30,28,80,.06);margin:6px 0}
.nav-item:first-child .drop{min-width:260px}

/* ═══════════════════════════════════════════════════════════════════
   MOBILE MENU — single definitive block
   ═══════════════════════════════════════════════════════════════════ */
#mmenu{position:fixed!important;inset:0;z-index:9000;background:#F9F8FC;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;display:flex!important;flex-direction:column;padding:0;transform:translateX(-100%);transition:transform .28s cubic-bezier(.16,1,.3,1);visibility:hidden;pointer-events:none}
#mmenu.open{transform:translateX(0)!important;visibility:visible!important;pointer-events:auto!important}
@media(min-width:641px){#mmenu{display:none!important}}
.mm-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;background:#F9F8FC;position:sticky;top:0;z-index:10;flex-shrink:0}
.mm-logo-link{display:block;line-height:0;text-decoration:none}
.mm-logo-img{height:26px!important;width:auto!important;display:block!important}
.mm-close{width:30px;height:30px;border-radius:50%;background:rgba(30,28,80,.07);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(30,28,80,.5);transition:all .14s;flex-shrink:0;-webkit-tap-highlight-color:transparent;position:relative;z-index:11}
.mm-close:active{transform:scale(.9);background:rgba(30,28,80,.12)}
.mm-guide{padding:2px 24px 16px}
.mm-guide-q{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(30,28,80,.32);margin:0}
.mm-nav{flex:1}
.mm-group{padding:0 24px}
.mm-group-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 0;background:none;border:none;border-bottom:1px solid rgba(30,28,80,.06);font-family:"Bricolage Grotesque",sans-serif;font-size:1.05rem;font-weight:700;color:rgba(30,28,80,.86);cursor:pointer;text-align:left;letter-spacing:-.02em;-webkit-tap-highlight-color:transparent;transition:color .14s}
.mm-group.is-open .mm-group-trigger{border-color:transparent}
.mm-chevron{flex-shrink:0;color:rgba(30,28,80,.22);transition:transform .22s cubic-bezier(.16,1,.3,1)}
.mm-group.is-open .mm-chevron{transform:rotate(180deg)}
.mm-group-body{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.16,1,.3,1)}
.mm-group.is-open .mm-group-body{max-height:800px}
.mm-sub-link{display:flex;align-items:center;gap:13px;padding:10px 0;text-decoration:none;-webkit-tap-highlight-color:transparent}
.mm-sub-link:active{opacity:.7}
.mm-sub-icon{width:30px;height:30px;border-radius:8px;background:rgba(30,28,80,.05);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:rgba(30,28,80,.45)}
.mm-sub-link strong{display:block;font-size:.88rem;font-weight:600;color:rgba(30,28,80,.82);line-height:1.25;letter-spacing:-.01em}
.mm-sub-link small{display:block;font-size:.7rem;color:rgba(30,28,80,.36);margin-top:1px;font-style:normal;line-height:1.3}
.mm-diag-block{margin:18px 24px;padding:18px 20px;background:#fff;border-radius:14px;border:1px solid rgba(123,63,204,.12);box-shadow:0 2px 10px rgba(30,28,80,.06);display:block!important;visibility:visible!important;opacity:1!important}
.mm-diag-eyebrow{font-size:.62rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--violet);margin:0 0 6px}
.mm-diag-body{font-size:.86rem;color:rgba(30,28,80,.62);line-height:1.58;margin:0 0 14px}
.mm-diag-cta{display:inline-flex!important;align-items:center!important;gap:7px!important;background:#0f0d2a!important;border-radius:999px!important;padding:9px 15px!important;text-decoration:none!important;letter-spacing:-.01em!important;-webkit-tap-highlight-color:transparent}
.mm-diag-cta,.mm-diag-cta span,.mm-diag-cta *{color:#fff!important;font-family:"Bricolage Grotesque",sans-serif;font-size:.82rem;font-weight:700}
.mm-diag-cta svg{color:#E040AB!important;flex-shrink:0}
.mm-footer{padding:12px 24px;padding-bottom:max(16px,env(safe-area-inset-bottom));border-top:1px solid rgba(30,28,80,.06);margin-top:auto;flex-shrink:0}
.mm-contact-row{display:flex;gap:10px}
.mm-contact-pill{display:inline-flex;align-items:center;gap:7px;flex:1;padding:9px 14px;border-radius:10px;background:rgba(30,28,80,.05);text-decoration:none;font-size:.82rem;font-weight:600;color:rgba(30,28,80,.62);-webkit-tap-highlight-color:transparent;white-space:nowrap;transition:background .14s}
.mm-contact-pill:active{background:rgba(30,28,80,.10)}
.mm-contact-pill svg{flex-shrink:0;color:rgba(30,28,80,.42)}
.mm-contact-pill--wa{color:#16a34a!important;background:rgba(37,211,102,.08)!important}
.mm-contact-pill--wa svg{color:#16a34a!important}
.mm-contact-item{display:none!important}

/* ═══════════════════════════════════════════════════════════════════
   STICKY MOBILE CTA — clean dark pill
   ═══════════════════════════════════════════════════════════════════ */
.sticky-cta-mobile{display:none!important;position:fixed!important;bottom:0!important;left:0!important;right:0!important;z-index:300!important;padding:10px 16px!important;padding-bottom:max(14px,env(safe-area-inset-bottom))!important;background:rgba(255,255,255,.96)!important;backdrop-filter:blur(10px)!important;-webkit-backdrop-filter:blur(10px)!important;border-top:1px solid rgba(30,28,80,.08)!important}
@media(max-width:767px){.sticky-cta-mobile{display:block!important}.float,.wa-float,a.fbtn,.fbtn-wa{display:none!important}}
.sticky-cta-btn{display:block;text-decoration:none;-webkit-tap-highlight-color:transparent}
.sticky-cta-inner{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:12px!important;background:#0f0d2a!important;border-radius:12px!important;padding:12px 18px!important}
.sticky-cta-btn:active .sticky-cta-inner{opacity:.86}
.sticky-cta-text{display:flex;flex-direction:column;gap:1px}
.sticky-cta-text strong{font-size:.88rem;font-weight:800;font-family:"Bricolage Grotesque",sans-serif;color:#fff!important;line-height:1.2;white-space:nowrap}
.sticky-cta-hint{font-size:.66rem;color:rgba(255,255,255,.42)!important;white-space:nowrap}
.sticky-cta-inner svg{color:#E040AB!important;flex-shrink:0}
.sticky-cta-mobile > a:not(.sticky-cta-btn){display:none!important}

/* ═══════════════════════════════════════════════════════════════════
   MOBILE SEARCH OVERLAY
   ═══════════════════════════════════════════════════════════════════ */
.mob-search-trigger{display:none;align-items:center;justify-content:center;width:36px;height:36px;color:rgba(30,28,80,.6);cursor:pointer;border:none;background:none;margin-right:4px}
@media(max-width:640px){.mob-search-trigger{display:flex}}
.mob-search-overlay{display:none;position:fixed;inset:0;background:rgba(9,8,31,.92);z-index:8000;align-items:flex-start;justify-content:center;padding-top:80px}
.mob-search-overlay.visible{display:flex}
.mob-search-box{width:90%;max-width:480px;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 24px 64px rgba(30,28,80,.24)}
.mob-search-inner{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid rgba(30,28,80,.07)}
.mob-search-inner svg{flex-shrink:0;color:rgba(30,28,80,.4)}
.mob-search-inp{flex:1;border:none;outline:none;font-family:"Plus Jakarta Sans",sans-serif;font-size:.94rem;color:rgba(30,28,80,.88);background:none}
.mob-search-inp::placeholder{color:rgba(30,28,80,.35)}
.mob-search-close{width:28px;height:28px;border-radius:50%;background:rgba(30,28,80,.06);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:rgba(30,28,80,.55);flex-shrink:0}
.mob-search-results-list{padding:8px 0;max-height:320px;overflow-y:auto}
.mob-sr-item{display:flex;flex-direction:column;padding:12px 20px;text-decoration:none;border-bottom:1px solid rgba(30,28,80,.05);transition:background .12s}
.mob-sr-item:hover{background:rgba(123,63,204,.05)}
.mob-sr-item strong{font-size:.88rem;font-weight:700;color:rgba(30,28,80,.88)}
.mob-sr-item small{font-size:.74rem;color:rgba(30,28,80,.45);margin-top:2px}

/* ═══════════════════════════════════════════════════════════════════
   GLOBAL MOBILE OVERRIDES — safe for sticky
   ═══════════════════════════════════════════════════════════════════ */
@media(max-width:640px){
  img,svg,video,iframe{max-width:100%!important;height:auto!important}
  [style*="grid-template-columns:repeat(3,1fr)"].reveal{grid-template-columns:1fr 1fr!important}
  [style*="grid-template-columns:repeat(4,1fr)"].reveal{grid-template-columns:1fr 1fr!important}
  [style*="grid-template-columns:1fr 2fr"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:1fr 1fr;gap:40px"]{grid-template-columns:1fr!important;gap:24px!important}
}

/* ═══════════════════════════════════════════════════════════════════
   MEGA MENU — Parcours métiers
   ═══════════════════════════════════════════════════════════════════ */
.nav-item--mega { position: static; }

.mega-drop {
  position: absolute;
  top: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 16px 56px rgba(30,28,80,.18), 0 2px 8px rgba(30,28,80,.08);
  border: 1px solid rgba(30,28,80,.07);
  display: grid;
  grid-template-columns: 260px 220px;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s, transform .2s cubic-bezier(.16,1,.3,1), visibility .2s;
  z-index: 9000;
  width: 480px;
}
.nav-item--mega:hover .mega-drop,
.nav-item--mega:focus-within .mega-drop {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* Left col: sector links */
.mega-col { padding: 16px 0 12px; }
.mega-col .drop-lbl { padding: 4px 20px 10px; }

.mega-link {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 8px 20px;
  text-decoration: none;
  transition: background .12s;
  position: relative;
}
.mega-link::before {
  content: '';
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
  height: 0;
  background: var(--violet);
  border-radius: 2px;
  transition: height .18s;
}
.mega-link:hover { background: rgba(123,63,204,.04); }
.mega-link:hover::before { height: 20px; }
.mega-link-icon {
  width: 28px; height: 28px;
  border-radius: 7px;
  background: rgba(30,28,80,.05);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: rgba(30,28,80,.45);
  transition: all .14s;
}
.mega-link:hover .mega-link-icon {
  background: rgba(123,63,204,.1);
  color: var(--violet);
}
.mega-link strong {
  display: block;
  font-size: .84rem;
  font-weight: 600;
  color: rgba(30,28,80,.82);
  line-height: 1.25;
}
.mega-link small {
  display: block;
  font-size: .7rem;
  color: rgba(30,28,80,.38);
  margin-top: 1px;
  font-style: normal;
}
.mega-link--all {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 8px 12px 4px;
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(123,63,204,.06);
  font-size: .78rem;
  font-weight: 700;
  color: var(--violet);
  border: 1px solid rgba(123,63,204,.12);
}
.mega-link--all::before { display: none; }
.mega-link--all:hover { background: rgba(123,63,204,.1); }

/* Right col: featured article */
.mega-featured {
  background: #F9F8FC;
  border-left: 1px solid rgba(30,28,80,.06);
  padding: 16px 16px 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.mega-featured .drop-lbl { padding: 0 0 8px; }

.mega-article {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(30,28,80,.07);
  background: #fff;
  transition: box-shadow .18s;
  flex: 1;
}
.mega-article:hover { box-shadow: 0 4px 20px rgba(30,28,80,.1); }

.mega-article-img {
  position: relative;
  height: 80px;
  background: linear-gradient(135deg, #130f58, #2A0B4E);
  display: flex;
  align-items: center;
  justify-content: center;
}
.mega-article-img-bg {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: .4;
}
.mega-article-tag {
  position: absolute;
  top: 8px;
  left: 8px;
  font-size: .6rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #E040AB;
  background: rgba(224,64,171,.15);
  border: 1px solid rgba(224,64,171,.25);
  padding: 3px 8px;
  border-radius: 999px;
}
.mega-article-body { padding: 12px 12px 10px; }
.mega-article-title {
  font-size: .78rem;
  font-weight: 700;
  color: rgba(30,28,80,.84);
  line-height: 1.42;
  margin: 0 0 5px;
}
.mega-article-meta {
  font-size: .66rem;
  color: rgba(30,28,80,.38);
  margin: 0 0 8px;
}
.mega-article-cta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .72rem;
  font-weight: 700;
  color: var(--violet);
}

.mega-diag-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 13px;
  background: #0f0d2a;
  border-radius: 10px;
  text-decoration: none;
  transition: opacity .15s;
  flex-shrink: 0;
}
.mega-diag-cta:hover { opacity: .88; }
.mega-diag-cta strong {
  display: block;
  font-size: .78rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.25;
}
.mega-diag-cta span {
  display: block;
  font-size: .67rem;
  color: rgba(255,255,255,.42);
  margin-top: 1px;
}
.mega-diag-cta svg { color: #E040AB; flex-shrink: 0; }

/* ── Hero form select — better contrast ──────────────────────────── */
.hfp-select {
  appearance: none !important;
  -webkit-appearance: none !important;
  background: rgba(255,255,255,.12) !important;
  border: 1.5px solid rgba(255,255,255,.28) !important;
  border-radius: 11px !important;
  padding: 13px 44px 13px 15px !important;
  font-size: .86rem !important;
  color: rgba(255,255,255,.88) !important;
  width: 100% !important;
  cursor: pointer !important;
  outline: none !important;
  transition: all .2s !important;
}
.hfp-select:focus {
  border-color: rgba(224,64,171,.8) !important;
  background: rgba(255,255,255,.16) !important;
  box-shadow: 0 0 0 3px rgba(224,64,171,.15) !important;
}
.hfp-select option {
  background: #140e48 !important;
  color: #fff !important;
  font-size: .86rem !important;
  padding: 10px !important;
}

/* ── Disponibilités badge — new color (teal/emerald) ───────────────── */
.hero-scarcity,
[class*="scarcity"],
[class*="disponib"] {
  background: rgba(16,185,129,.1) !important;
  border-color: rgba(16,185,129,.25) !important;
  color: #34D399 !important;
}
.hero-scarcity span,
[class*="scarcity"] span { color: #34D399 !important; }

/* ═══════════════════════════════════════════════════════════════════
   SOLUTIONS MEGA MENU — case client card
   ═══════════════════════════════════════════════════════════════════ */
.mega-drop--solutions { width: 500px; grid-template-columns: 270px 230px; }
.mega-caseclient {
  background: linear-gradient(135deg,#130f58,#2A0B4E);
  border-radius: 14px;
  padding: 18px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.mega-caseclient-header { display: flex; align-items: center; gap: 12px; }
.mega-caseclient-logo {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.mega-caseclient-name { font-size: .86rem; font-weight: 800; color: #fff; font-family: "Bricolage Grotesque",sans-serif; }
.mega-caseclient-sector { font-size: .68rem; color: rgba(255,255,255,.42); margin-top: 1px; }
.mega-caseclient-quote { font-size: .78rem; color: rgba(255,255,255,.65); line-height: 1.6; font-style: italic; }
.mega-caseclient-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.mega-caseclient-stat strong { display: block; font-size: 1.2rem; font-weight: 800; color: #fff; font-family: "Bricolage Grotesque",sans-serif; letter-spacing: -.04em; }
.mega-caseclient-stat span { font-size: .66rem; color: rgba(255,255,255,.45); }
.mega-caseclient-tag { font-size: .62rem; font-weight: 700; color: #E040AB; letter-spacing: .1em; text-transform: uppercase; }

/* ═══════════════════════════════════════════════════════════════════
   CUSTOM SELECT — modern hero form
   ═══════════════════════════════════════════════════════════════════ */
.hfp-cselect { position: relative; width: 100%; }
.hfp-cselect-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  background: rgba(255,255,255,.12);
  border: 1.5px solid rgba(255,255,255,.28);
  border-radius: 11px;
  padding: 13px 15px;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: .86rem;
  color: rgba(255,255,255,.55);
  cursor: pointer;
  text-align: left;
  outline: none;
  transition: all .2s;
  -webkit-tap-highlight-color: transparent;
}
.hfp-cselect-btn:hover, .hfp-cselect.is-open .hfp-cselect-btn {
  border-color: rgba(224,64,171,.7);
  background: rgba(255,255,255,.16);
}
.hfp-cselect.is-selected .hfp-cselect-btn { color: #fff; }
.hfp-cselect-arrow {
  flex-shrink: 0;
  color: rgba(255,255,255,.4);
  transition: transform .22s cubic-bezier(.16,1,.3,1);
}
.hfp-cselect.is-open .hfp-cselect-arrow { transform: rotate(180deg); color: #E040AB; }

.hfp-cselect-drop {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 0; right: 0;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 -8px 32px rgba(30,28,80,.16);
  border: 1px solid rgba(30,28,80,.08);
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: all .22s cubic-bezier(.16,1,.3,1);
  z-index: 100;
}
.hfp-cselect.is-open .hfp-cselect-drop {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.hfp-cselect-opt {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 12px 16px;
  font-size: .86rem;
  font-weight: 500;
  color: rgba(30,28,80,.78);
  cursor: pointer;
  transition: background .12s;
  border-bottom: 1px solid rgba(30,28,80,.05);
}
.hfp-cselect-opt:last-child { border-bottom: none; }
.hfp-cselect-opt:hover { background: rgba(123,63,204,.06); color: var(--violet); }
.hfp-cselect-opt svg { flex-shrink: 0; color: rgba(30,28,80,.35); transition: color .12s; }
.hfp-cselect-opt:hover svg { color: var(--violet); }

/* ═══════════════════════════════════════════════════════════════════
   BLOG CARDS — fix gradients and add images
   ═══════════════════════════════════════════════════════════════════ */
.blog-thumb {
  height: 160px;
  display: flex;
  align-items: flex-end;
  padding: 12px 14px;
  position: relative;
  overflow: hidden;
}
.blog-thumb::before {
  content: '';
  position: absolute;
  inset: 0;
  background: inherit;
  background-size: cover;
  background-position: center;
  transition: transform .4s ease;
}
.blog-card:hover .blog-thumb::before { transform: scale(1.04); }
.blog-thumb > * { position: relative; z-index: 2; }

/* Fix blog grid layout */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
@media(max-width:900px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:600px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-card {
  background: #fff;
  border: 1px solid rgba(30,28,80,.08);
  border-radius: 18px;
  overflow: hidden;
  transition: all .22s;
  display: flex;
  flex-direction: column;
}
.blog-card:hover {
  box-shadow: 0 8px 32px rgba(30,28,80,.1);
  transform: translateY(-3px);
  border-color: rgba(123,63,204,.15);
}

/* ═══════════════════════════════════════════════════════════════════
   MEGA MENU — left offset fix for Solutions (starts near left)
   ═══════════════════════════════════════════════════════════════════ */
.nav-links .nav-item:first-child .mega-drop--solutions { transform: translateX(-10%) translateY(-6px); }
.nav-links .nav-item:first-child:hover .mega-drop--solutions,
.nav-links .nav-item:first-child:focus-within .mega-drop--solutions { transform: translateX(-10%) translateY(0); }

/* ╔═══════════════════════════════════════════════════════════════════╗
   ║  BLOG FIX v54 — definitive grid + card styles                   ║
   ╚═══════════════════════════════════════════════════════════════════╝ */
.blog-grid {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 20px !important;
}
@media(max-width:900px){ .blog-grid { grid-template-columns: 1fr 1fr !important; } }
@media(max-width:600px){ .blog-grid { grid-template-columns: 1fr !important; } }

.blog-card {
  background: #fff !important;
  border: 1px solid rgba(30,28,80,.09) !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  transition: all .22s !important;
  box-shadow: none !important;
}
.blog-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 32px rgba(30,28,80,.1) !important;
  border-color: rgba(123,63,204,.14) !important;
}
.blog-thumb {
  height: 160px !important;
  display: flex !important;
  align-items: flex-end !important;
  padding: 14px 16px !important;
  position: relative !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}
.blog-body { padding: 20px !important; flex: 1 !important; display: flex !important; flex-direction: column !important; gap: 10px !important; }
.blog-h3 { font-size: .96rem !important; font-weight: 800 !important; color: rgba(30,28,80,.88) !important; line-height: 1.35 !important; margin: 0 !important; }
.blog-desc { font-size: .79rem !important; color: rgba(30,28,80,.52) !important; line-height: 1.6 !important; flex: 1 !important; }
.blog-cta { display: inline-flex !important; align-items: center !important; gap: 5px !important; font-size: .76rem !important; font-weight: 700 !important; color: var(--violet) !important; margin-top: auto !important; }
.blog-cat-pill { font-size: .62rem !important; font-weight: 800 !important; letter-spacing: .12em !important; text-transform: uppercase !important; color: rgba(255,255,255,.9) !important; background: rgba(255,255,255,.15) !important; border: 1px solid rgba(255,255,255,.25) !important; padding: 3px 10px !important; border-radius: 999px !important; }

/* ─── Article pages: continuous clean white background ─── */
body.article-page section.s { background: #fff !important; }
body.article-page section.s-alt { background: #F9F8FC !important; }
/* Remove excess top/bottom padding between article content sections */  
body.article-page .s { padding-top: 40px !important; padding-bottom: 40px !important; }
body.article-page .s-alt { padding-top: 40px !important; padding-bottom: 40px !important; }
body.article-page .s:first-of-type, body.article-page .page-hero { padding: 0 !important; }

/* ╔═══════════════════════════════════════════════════════════════════╗
   ║  BLOG v55 — blog-card-premium + blog-grid-new                   ║
   ╚═══════════════════════════════════════════════════════════════════╝ */

/* Featured 2-col articles (text cards) */
.blog-grid-new {
  display: grid !important;
  grid-template-columns: repeat(2,1fr) !important;
  gap: 24px !important;
  margin-bottom: 48px !important;
}
@media(max-width:640px) { .blog-grid-new { grid-template-columns: 1fr !important; } }

.blog-card-premium {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 24px 22px;
  background: #fff;
  border: 1px solid rgba(30,28,80,.08);
  border-radius: 16px;
  text-decoration: none;
  transition: all .2s;
  position: relative;
}
.blog-card-premium::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, #7B3FCC, #E040AB);
  border-radius: 16px 16px 0 0;
  opacity: 0;
  transition: opacity .2s;
}
.blog-card-premium:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(30,28,80,.09);
  border-color: rgba(123,63,204,.14);
}
.blog-card-premium:hover::before { opacity: 1; }

.bcp-tag {
  font-size: .64rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--violet);
  margin-bottom: 4px;
}
.bcp-title {
  font-family: "Bricolage Grotesque", sans-serif;
  font-size: .98rem;
  font-weight: 800;
  color: rgba(30,28,80,.88);
  line-height: 1.35;
  margin: 0;
}
.bcp-desc {
  font-size: .79rem;
  color: rgba(30,28,80,.52);
  line-height: 1.62;
  margin: 0;
  flex: 1;
}
.bcp-cta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .76rem;
  font-weight: 700;
  color: var(--violet);
  margin-top: 4px;
}

/* ╔═══════════════════════════════════════════════════════════════════╗
   ║  CAS PRATIQUES — premium visual redesign v56                    ║
   ╚═══════════════════════════════════════════════════════════════════╝ */
.cas-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 20px !important;
  margin-top: 36px;
}
@media(max-width:680px) { .cas-grid { grid-template-columns: 1fr !important; } }

.cas-item {
  background: #fff !important;
  border: 1px solid rgba(30,28,80,.08) !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  padding: 0 !important;
  gap: 0 !important;
  flex-direction: column !important;
  box-shadow: 0 2px 16px rgba(30,28,80,.06) !important;
  display: flex !important;
  transition: all .22s !important;
}
.cas-item:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(30,28,80,.1) !important;
  border-color: rgba(123,63,204,.14) !important;
}

.cas-head {
  background: linear-gradient(135deg, #0f0d2a, #2A0B4E) !important;
  padding: 18px 20px !important;
  font-family: "Bricolage Grotesque", sans-serif !important;
  font-weight: 800 !important;
  font-size: .94rem !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
.cas-head::before {
  content: '';
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #E040AB;
  flex-shrink: 0;
}

.cas-body {
  padding: 16px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

.cas-before {
  padding: 12px 14px !important;
  background: #FEF2F2 !important;
  border-radius: 10px !important;
}
.cas-after {
  padding: 12px 14px !important;
  background: #F0FDF4 !important;
  border-radius: 10px !important;
}

.cas-lbl {
  display: block !important;
  font-size: .66rem !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  margin-bottom: 5px !important;
}
.cas-before .cas-lbl { color: #DC2626 !important; }
.cas-after .cas-lbl { color: #10B981 !important; }

.cas-before p { font-size: .83rem !important; color: rgba(30,28,80,.68) !important; line-height: 1.58 !important; margin: 0 !important; }
.cas-after p { font-size: .83rem !important; color: rgba(30,28,80,.82) !important; line-height: 1.58 !important; margin: 0 !important; font-weight: 500 !important; }

/* ╔═══════════════════════════════════════════════════════════════════╗
   ║  BLOG CARDS v57 — pill top-left, clean thumb                   ║
   ╚═══════════════════════════════════════════════════════════════════╝ */
.blog-thumb {
  height: 160px !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: flex-start !important;
  padding: 14px 16px !important;
  flex-shrink: 0 !important;
}
.blog-thumb svg { display: none !important; }

.blog-cat-pill {
  position: relative !important;
  z-index: 2 !important;
  font-size: .62rem !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: #fff !important;
  background: rgba(255,255,255,.18) !important;
  border: 1px solid rgba(255,255,255,.32) !important;
  padding: 4px 12px !important;
  border-radius: 999px !important;
  backdrop-filter: blur(4px) !important;
  align-self: flex-start !important;
}

/* ── btn-hp: primary CTA (calendly) ─────────────────────────────── */
.btn-hp {
  background: linear-gradient(135deg,#9B2FCC,#E040AB,#FF1A8C) !important;
  color: #fff !important;
  box-shadow: 0 8px 32px rgba(224,64,171,.45) !important;
}
/* ── btn-hs: secondary CTA — ghost dark ─────────────────────────── */
.btn-hs {
  background: rgba(255,255,255,.08) !important;
  border: 1.5px solid rgba(255,255,255,.22) !important;
  color: rgba(255,255,255,.82) !important;
  box-shadow: none !important;
}
.btn-hs:hover {
  background: rgba(255,255,255,.14) !important;
  color: #fff !important;
}

/* WhatsApp float bubble tooltip */
.float-wa-bubble {
  position: absolute;
  right: calc(100% + 10px);
  bottom: 8px;
  background: #fff;
  border-radius: 12px 12px 2px 12px;
  padding: 9px 13px;
  box-shadow: 0 4px 16px rgba(30,28,80,.15);
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  opacity: 0;
  transform: translateX(8px);
  transition: all .22s cubic-bezier(.16,1,.3,1);
  pointer-events: none;
  font-size: .78rem;
  color: rgba(30,28,80,.7);
  line-height: 1.4;
  min-width: 160px;
}
.float-wa-bubble svg { flex-shrink: 0; }
.float:hover .float-wa-bubble {
  opacity: 1;
  transform: translateX(0);
}

/* ── Logo nav — new high-res PNG ──────────────────────────────────── */


.mm-logo-img { height: 30px !important; width: auto !important; display: block !important; }



/* ── Hero: "Échanger sur mon projet" — dark navy, clearly secondary ── */
.btn-hp {
  background: #0f0d2a !important;
  color: #fff !important;
  border: 1.5px solid rgba(255,255,255,.22) !important;
  box-shadow: 0 4px 18px rgba(30,28,80,.4) !important;
}
.btn-hp:hover {
  background: #1a1654 !important;
  border-color: rgba(255,255,255,.35) !important;
}
/* ── Hero form submit — keep pink gradient (primary action) ─────────── */
.hfp-btn {
  background: linear-gradient(135deg,#9B2FCC,#E040AB,#FF1A8C) !important;
  color: #fff !important;
  box-shadow: 0 6px 28px rgba(224,64,171,.5) !important;
}

/* ── btn-hp: "Échanger sur mon projet" — matches "Vérifier mon financement" style ── */
.btn-hp {
  background: rgba(255,255,255,.08) !important;
  color: rgba(255,255,255,.88) !important;
  border: 1.5px solid rgba(255,255,255,.22) !important;
  box-shadow: none !important;
  font-weight: 600 !important;
  padding: 13px 24px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  transition: all .18s !important;
  text-decoration: none !important;
  font-size: .9rem !important;
}
.btn-hp:hover {
  background: rgba(255,255,255,.15) !important;
  color: #fff !important;
  border-color: rgba(255,255,255,.36) !important;
}


/* ── Logo: bigger for readability ──────────────────────────────────── */

.nav-logo { padding: 4px 0 !important; }


.mm-logo-img { height: 36px !important; width: auto !important; }


/* ── Mobile sticky — 2 pills, ultra simple ────────────────────────── */
.sticky-cta-mobile {
  display: none !important;
  position: fixed !important;
  bottom: 0 !important; left: 0 !important; right: 0 !important;
  z-index: 300 !important;
  padding: 10px 16px !important;
  padding-bottom: max(12px, env(safe-area-inset-bottom)) !important;
  background: rgba(255,255,255,.97) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  border-top: 1px solid rgba(30,28,80,.08) !important;
  display: none !important;
  gap: 10px !important;
}
@media(max-width:767px) {
  .sticky-cta-mobile { display: flex !important; }
  .float, .wa-float, .fbtn-wa { display: none !important; }
}
.sticky-tel-btn {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: rgba(30,28,80,.06);
  border: 1.5px solid rgba(30,28,80,.14);
  color: rgba(30,28,80,.82);
  font-size: .88rem; font-weight: 700;
  padding: 13px 10px;
  border-radius: 12px;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
}
.sticky-cal-btn {
  flex: 1.4;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg,#9B2FCC,#E040AB);
  color: #fff;
  font-size: .88rem; font-weight: 700;
  padding: 13px 10px;
  border-radius: 12px;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
}
/* Kill old sticky sub-elements */
.sticky-cta-btn, .sticky-cta-inner, .sticky-cta-text { display: none !important; }


/* ── Topbar phone (replaces search) ───────────────────────────────── */
.tb2-phone {
  display: flex;
  align-items: center;
  gap: 7px;
  color: rgba(255,255,255,.46);
}
.tb2-phone svg { flex-shrink: 0; }
.tb2-phone-link {
  font-size: .68rem;
  font-weight: 600;
  color: rgba(255,255,255,.68);
  text-decoration: none;
  letter-spacing: .03em;
  transition: color .14s;
}
.tb2-phone-link:hover { color: #fff; }
/* Hide search-related elements */
.tb2-search, #tb2-search, .tb2-search-results,
.mob-search-trigger, .mob-search-overlay { display: none !important; }

/* ╔═══════════════════════════════════════════════════════════════════╗
   ║  LOGO FINAL — 56px desktop, 40px tablet, 34px mobile            ║
   ╚═══════════════════════════════════════════════════════════════════╝ */



.mm-logo-img { height: 38px !important; width: auto !important; }

/* ╔═══════════════════════════════════════════════════════════════════╗
   ║  v63 FINAL — logo, topbar responsive, sticky single CTA         ║
   ╚═══════════════════════════════════════════════════════════════════╝ */

/* 1. Logo — big and readable */

.nav-logo { padding: 2px 0 !important; }


.mm-logo-img { height: 40px !important; width: auto !important; }

/* 2. Topbar left area */
.tb2-left-area { display: flex; align-items: center; }

/* Desktop: show search, hide mob-contacts */
.tb2-search-desktop { display: flex !important; }
.tb2-mob-contacts { display: none !important; }

/* Mobile: hide search, show tel+WA */
@media(max-width:640px) {
  .tb2-search-desktop { display: none !important; }
  .tb2-mob-contacts { display: flex !important; align-items: center; gap: 0; }
  .tb2-mob-tel {
    display: flex; align-items: center; gap: 5px;
    font-size: .68rem; font-weight: 600; color: rgba(255,255,255,.72);
    text-decoration: none; white-space: nowrap;
  }
  .tb2-mob-tel svg { flex-shrink:0; color: rgba(255,255,255,.5); }
  .tb2-mob-sep { width:1px; height:10px; background:rgba(255,255,255,.15); margin:0 8px; flex-shrink:0; }
  .tb2-mob-wa {
    display: flex; align-items: center; gap: 5px;
    font-size: .68rem; font-weight: 600; color: rgba(74,222,128,.85);
    text-decoration: none; white-space: nowrap;
  }
  .tb2-mob-wa svg { flex-shrink:0; }
}

/* 3. Single sticky CTA — full-width pill */
.sticky-cta-mobile {
  display: none !important;
  position: fixed !important;
  bottom: 0 !important; left: 0 !important; right: 0 !important;
  z-index: 300 !important;
  padding: 10px 16px !important;
  padding-bottom: max(14px, env(safe-area-inset-bottom)) !important;
  background: rgba(255,255,255,.96) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  border-top: 1px solid rgba(30,28,80,.07) !important;
}
@media(max-width:767px) {
  .sticky-cta-mobile { display: block !important; }
  .float, .fbtn-wa { display: none !important; }
}
.sticky-diag-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 9px !important;
  width: 100% !important;
  background: linear-gradient(135deg,#9B2FCC,#E040AB) !important;
  color: #fff !important;
  font-family: "Bricolage Grotesque",sans-serif !important;
  font-size: .92rem !important;
  font-weight: 700 !important;
  padding: 14px !important;
  border-radius: 14px !important;
  text-decoration: none !important;
  box-shadow: 0 4px 20px rgba(224,64,171,.38) !important;
  -webkit-tap-highlight-color: transparent !important;
}
.sticky-diag-btn:active { opacity: .88 !important; }

/* Kill old sticky sub-elements */
.sticky-tel-btn, .sticky-cal-btn,
.sticky-cta-btn, .sticky-cta-inner,
.sticky-cta-text, .sticky-cta-hint { display: none !important; }

/* Hide phone in tb2-right on mobile (avoid duplication) */
@media(max-width:640px) {
  .tb2-right .tb2-tel,
  .tb2-right .tb2-wa,
  .tb2-right .tb2-sep { display: none !important; }
  .tb2-center { display: none !important; }
}

/* ╔═══════════════════════════════════════════════════════════════════╗
   ║  v64 MOBILE FINAL — logo, topbar, sticky CTA                   ║
   ╚═══════════════════════════════════════════════════════════════════╝ */

/* ── Logo: desktop large, mobile reasonable ─────────────────────────── */

.nav-logo { padding: 4px 0 !important; }

/* ── Mobile nav: 40px topbar + 64px nav = logo fills nicely ─────────── */
@media (max-width: 767px) {
  
  .nav-logo { padding: 2px 0 !important; }
  .nav-i { height: 60px !important; padding: 0 16px !important; }
}
@media (max-width: 480px) {
  
}

/* ── Topbar grid: phone left / claim center / wa right on mobile ─────── */
@media (max-width: 640px) {
  .tb2-i {
    grid-template-columns: auto 1fr auto !important;
    gap: 0 !important;
    padding: 0 14px !important;
  }
  /* Show mob contacts in left slot */
  .tb2-search-desktop { display: none !important; }
  .tb2-mob-contacts   { display: flex !important; align-items: center !important; gap: 0 !important; }
  /* Hide claim text on mobile */
  .tb2-center { display: none !important; }
  /* Right: keep WA, hide phone (already shown left) */
  .tb2-right 
  .tb2-right .tb2-sep { display: none !important; }
  .tb2-right .tb2-wa  { display: flex !important; }
}

/* mob-contacts styles */
.tb2-mob-contacts { display: none; }
.tb2-mob-tel {
  display: flex; align-items: center; gap: 5px;
  font-size: .68rem; font-weight: 600; color: rgba(255,255,255,.78);
  text-decoration: none; white-space: nowrap;
  letter-spacing: .02em;
}
.tb2-mob-tel svg { flex-shrink: 0; color: rgba(255,255,255,.5); }
.tb2-mob-sep {
  width: 1px; height: 10px; background: rgba(255,255,255,.15);
  margin: 0 8px; flex-shrink: 0; display: inline-block;
}
.tb2-mob-wa {
  display: flex; align-items: center; gap: 5px;
  font-size: .68rem; font-weight: 600;
  color: rgba(74,222,128,.9); text-decoration: none; white-space: nowrap;
}

/* ── Sticky bottom CTA — mobile only ────────────────────────────────── */
.sticky-cta-mobile {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 400;
  padding: 10px 16px;
  padding-bottom: max(12px, env(safe-area-inset-bottom));
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-top: 1px solid rgba(30,28,80,.08);
}
@media (max-width: 767px) {
  .sticky-cta-mobile { display: block !important; }
  .float, .fbtn-wa, a.fbtn { display: none !important; }
}
.sticky-diag-btn {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  background: linear-gradient(135deg, #9B2FCC, #E040AB) !important;
  color: #fff !important;
  font-family: "Bricolage Grotesque", sans-serif !important;
  font-size: .92rem !important;
  font-weight: 700 !important;
  padding: 15px 20px !important;
  border-radius: 14px !important;
  text-decoration: none !important;
  letter-spacing: -.01em !important;
  box-shadow: 0 4px 18px rgba(224,64,171,.4) !important;
  -webkit-tap-highlight-color: transparent !important;
}
.sticky-diag-btn:active { opacity: .85 !important; }

/* Kill all old sticky sub-elements */
.sticky-tel-btn, .sticky-cal-btn,
.sticky-cta-btn, .sticky-cta-inner,
.sticky-cta-text, .sticky-cta-hint { display: none !important; }

/* ╔═══════════════════════════════════════════════════════════════════╗
   ║  HERO V2 — Premium immersive, aspirational                      ║
   ╚═══════════════════════════════════════════════════════════════════╝ */

/* ── Base layer ──────────────────────────────────────────────────────── */
.hero-v2 {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: 0;
}

/* Multi-layer background: deep indigo gradient with subtle mesh */
.hero-v2-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 120% 80% at 65% 40%, rgba(123,63,204,.18) 0%, transparent 60%),
    radial-gradient(ellipse 80% 60% at 10% 80%, rgba(224,64,171,.10) 0%, transparent 55%),
    linear-gradient(160deg, #04031a 0%, #080629 35%, #0f0842 65%, #08061e 100%);
  z-index: 0;
}

/* Subtle grid overlay */
.hero-v2-grid {
  position: absolute;
  inset: 0;
  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: 64px 64px;
  z-index: 1;
  mask-image: radial-gradient(ellipse 90% 90% at 50% 50%, black 40%, transparent 100%);
}

/* Atmospheric glows */
.hero-v2-glow1 {
  position: absolute;
  top: -20%;
  right: 5%;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(123,63,204,.22) 0%, transparent 65%);
  z-index: 1;
  pointer-events: none;
  animation: hero-glow-pulse 6s ease-in-out infinite;
}
.hero-v2-glow2 {
  position: absolute;
  bottom: -10%;
  left: -5%;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(224,64,171,.12) 0%, transparent 65%);
  z-index: 1;
  pointer-events: none;
  animation: hero-glow-pulse 8s ease-in-out infinite reverse;
}
@keyframes hero-glow-pulse {
  0%, 100% { opacity: .7; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.08); }
}

/* ── Layout ──────────────────────────────────────────────────────────── */
.hero-v2-inner {
  position: relative;
  z-index: 10;
  display: grid;
  grid-template-columns: 1fr 480px;
  gap: 56px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 100px 44px 80px;
  width: 100%;
}

/* ── Left column — copy ──────────────────────────────────────────────── */
.hero-v2-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 6px 16px;
  font-size: .68rem;
  font-weight: 700;
  color: rgba(255,255,255,.58);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 24px;
}
.hero-v2-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #E040AB;
  flex-shrink: 0;
  animation: pulse-dot 2.4s ease-in-out infinite;
}

.hero-v2-h1 {
  font-family: "Bricolage Grotesque", sans-serif;
  font-size: clamp(2.8rem, 5vw, 4.2rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.07em;
  line-height: 1.0;
  margin-bottom: 20px;
}
.hero-v2-em--DISABLED {
  display: block;
  font-style: normal;
  background: linear-gradient(135deg, #C084FC 0%, #E040AB 40%, #FF6B6B 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  position: relative;
}
/* Subtle underline on em */
.hero-v2-em::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 60%;
  height: 2px;
  background: linear-gradient(90deg, rgba(224,64,171,.6), transparent);
  border-radius: 2px;
}

.hero-v2-position {
  font-size: .96rem;
  color: rgba(255,255,255,.52);
  line-height: 1.65;
  margin-bottom: 18px;
  font-style: italic;
}
.hero-v2-position strong { color: rgba(255,255,255,.82); font-style: normal; font-weight: 700; }

.hero-v2-desc {
  font-size: .92rem;
  color: rgba(255,255,255,.55);
  line-height: 1.78;
  margin-bottom: 36px;
  max-width: 520px;
}

/* ── CTAs ────────────────────────────────────────────────────────────── */
.hero-v2-ctas {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}

.hero-v2-cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: linear-gradient(135deg, #9B2FCC, #E040AB, #FF1A8C);
  color: #fff;
  padding: 15px 28px;
  border-radius: 999px;
  font-weight: 700;
  font-size: .92rem;
  text-decoration: none;
  box-shadow: 0 8px 36px rgba(224,64,171,.50), 0 2px 8px rgba(224,64,171,.25);
  transition: all .22s;
  letter-spacing: -.01em;
  position: relative;
  overflow: hidden;
}
.hero-v2-cta-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.1);
  opacity: 0;
  transition: opacity .18s;
}
.hero-v2-cta-primary:hover::before { opacity: 1; }
.hero-v2-cta-primary:hover { box-shadow: 0 12px 44px rgba(224,64,171,.6), 0 4px 12px rgba(224,64,171,.3); transform: translateY(-1px); }
.hero-v2-cta-arrow { margin-left: 2px; flex-shrink: 0; }

.hero-v2-cta-secondary {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(255,255,255,.07);
  border: 1.5px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.72);
  padding: 15px 24px;
  border-radius: 999px;
  font-weight: 600;
  font-size: .88rem;
  text-decoration: none;
  transition: all .18s;
}
.hero-v2-cta-secondary:hover { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.28); }

/* ── Trust signals ───────────────────────────────────────────────────── */
.hero-v2-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 18px;
}
.hero-v2-ti {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .74rem;
  color: rgba(255,255,255,.38);
  font-weight: 500;
}
.hero-v2-ti svg { flex-shrink: 0; color: rgba(123,63,204,.65); }

/* ── Right column — diagnostic card ─────────────────────────────────── */
.hero-v2-right { position: relative; }

/* Floating result chips */
.hero-v2-chip {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 7px;
  background: rgba(16,185,129,.12);
  border: 1px solid rgba(16,185,129,.3);
  border-radius: 999px;
  padding: 7px 14px;
  font-size: .7rem;
  font-weight: 700;
  color: #34D399;
  white-space: nowrap;
  backdrop-filter: blur(8px);
  z-index: 2;
  box-shadow: 0 4px 16px rgba(16,185,129,.15);
  animation: chip-float 4s ease-in-out infinite;
}
.chip-a { top: -18px; right: 20px; animation-delay: 0s; }
.chip-b { bottom: 60px; left: -20px; animation-delay: 2s; }
@keyframes chip-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* Card redesign */
.hfp-card-v2 {
  background: rgba(255,255,255,.06) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 22px !important;
  padding: 28px !important;
  box-shadow: 0 24px 64px rgba(0,0,0,.3), 0 2px 0 rgba(255,255,255,.08) inset !important;
}
.hfp-v2-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 20px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.hfp-v2-ico {
  width: 42px; height: 42px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(123,63,204,.6), rgba(224,64,171,.6));
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(123,63,204,.4);
}
.hfp-v2-title {
  font-family: "Bricolage Grotesque", sans-serif;
  font-weight: 800;
  font-size: 1rem;
  color: #fff;
  line-height: 1.25;
  margin-bottom: 4px;
}
.hfp-v2-sub {
  font-size: .78rem;
  color: rgba(255,255,255,.46);
  line-height: 1.5;
}
.hfp-v2-benefits {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
}
.hfp-v2-b {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: .81rem;
  color: rgba(255,255,255,.7);
  line-height: 1.4;
}
.hfp-v2-b svg { flex-shrink: 0; }

/* Form inputs on dark bg */
.hfp-card-v2 .hfp-input {
  background: rgba(255,255,255,.09) !important;
  border: 1.5px solid rgba(255,255,255,.16) !important;
  color: #fff !important;
}
.hfp-card-v2 .hfp-input::placeholder { color: rgba(255,255,255,.4) !important; }
.hfp-card-v2 .hfp-input:focus {
  border-color: rgba(224,64,171,.7) !important;
  background: rgba(255,255,255,.13) !important;
  box-shadow: 0 0 0 3px rgba(224,64,171,.15) !important;
}

/* Submit button — ultra premium */
.hfp-v2-btn {
  background: linear-gradient(135deg, #9B2FCC, #E040AB, #FF1A8C) !important;
  box-shadow: 0 6px 28px rgba(224,64,171,.5) !important;
  font-size: .92rem !important;
  font-weight: 700 !important;
  letter-spacing: -.01em !important;
  transition: all .2s !important;
}
.hfp-v2-btn:hover { box-shadow: 0 10px 36px rgba(224,64,171,.65) !important; transform: translateY(-1px) !important; }

/* ── Responsive ──────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .hero-v2-inner { grid-template-columns: 1fr 420px; gap: 40px; padding: 80px 32px; }
  .hero-v2-h1 { font-size: clamp(2.4rem, 4.5vw, 3.4rem); }
}
@media (max-width: 768px) {
  .hero-v2-inner { grid-template-columns: 1fr; gap: 40px; padding: 80px 20px 120px; }
  .hero-v2-h1 { font-size: clamp(2.4rem, 8vw, 3rem); }
  .chip-a { top: -14px; right: 10px; font-size: .66rem; }
  .chip-b { display: none; }
  .hero-v2-ctas { flex-direction: column; align-items: flex-start; }
  .hero-v2-cta-primary, .hero-v2-cta-secondary { width: 100%; justify-content: center; }
}
@media (max-width: 480px) {
  .hero-v2-inner { padding: 72px 16px 120px; }
}

/* ── Hero v2: micro-statement ─────────────────────────────────────── */
.hero-v2-microstat {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.hero-v2-microstat span {
  font-size: .86rem;
  font-weight: 700;
  color: rgba(255,255,255,.72);
}
.hero-v2-micro-sep {
  width: 4px !important;
  height: 4px !important;
  border-radius: 50%;
  background: rgba(224,64,171,.6);
  flex-shrink: 0;
}

/* ── Nav: Notre méthode link ──────────────────────────────────────── */
.nav-methode-link {
  font-weight: 700 !important;
  color: var(--violet) !important;
  position: relative;
}
.nav-methode-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--violet);
  border-radius: 2px;
  transform: scaleX(0);
  transition: transform .2s;
  transform-origin: left;
}
.nav-methode-link:hover::after { transform: scaleX(1); }

/* Hide Profils from main nav (kept in mobile mmenu) */
.nav-profils-hidden { display: none !important; }

/* ── chip-b: lower position, no overlap ────────────────────────── */
.chip-b {
  bottom: -28px !important;
  left: 16px !important;
  animation-delay: 2s;
}

/* ── Footer logo — mobile resize ─────────────────────────────────── */
.footer-logo-img {
  height: 40px;
  width: auto;
  max-width: 180px;
  object-fit: contain;
  display: block;
}
@media (max-width: 640px) {
  .footer-logo-img { height: 32px !important; max-width: 140px !important; }
  .footer-logo { margin-bottom: 16px; }
}

/* ── Anti-spam honeypot — masqué pour les humains ────────────────── */
#hp_website, [name="website"], [name="_t"] {
  position: absolute !important;
  left: -9999px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  tabindex: -1 !important;
}

* ── Topbar: lien simulateur discret ──────────────────────────────── */
.tb2-sim-link {
  font-size: .63rem;
  font-weight: 600;
  color: rgba(255,255,255,.36);
  text-decoration: none;
  letter-spacing: .04em;
  margin-left: 14px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  transition: all .16s;
  white-space: nowrap;
}

@media (max-width: 640px) { .tb2-sim-link { display: none !important; } }

/* ══ FLAT PREMIUM — suppression effets grid/quadrillé ═════════════
   Remplacement par fonds propres sans texture SaaS
   ═══════════════════════════════════════════════════════════════ */
.hero-v2-grid,
.meth-hero-grid,
.sim-hero-grid,
.hero-grid,
.hero-orb1,
.hero-orb2,
.hero-orb3 {
  display: none !important;
}
/* Sections dark sans grid-pattern inline */
[style*="background-image:linear-gradient(rgba(255,255,255,.02) 1px"],
[style*="background-image: linear-gradient(rgba(255,255,255,.02)"],
[style*="background-size:64px 64px"],
[style*="background-size: 64px 64px"] {
  background-image: none !important;
  background-size: unset !important;
}
/* Remplacer le fond hero par version sans grid */
.hero-v2 {
  background:
    radial-gradient(ellipse 110% 70% at 65% 35%, rgba(123,63,204,.16) 0%, transparent 58%),
    radial-gradient(ellipse 70% 55% at 8% 82%, rgba(224,64,171,.09) 0%, transparent 55%),
    linear-gradient(160deg, #04031a 0%, #080629 38%, #0d0740 68%, #07061e 100%) !important;
}
.sim-hero {
  background:
    radial-gradient(ellipse 110% 70% at 70% 38%, rgba(123,63,204,.16) 0%, transparent 58%),
    radial-gradient(ellipse 65% 52% at 5% 82%, rgba(224,64,171,.1) 0%, transparent 55%),
    linear-gradient(160deg, #04031a 0%, #080629 38%, #0d0740 68%, #07061e 100%) !important;
}

/* ── Logo Qualiopi officiel — proportions respectées ──────────────── */
.footer-quali img {
  height: auto !important;
  width: auto !important;
  max-width: 110px !important;
  max-height: 60px !important;
  object-fit: contain !important;
  image-rendering: -webkit-optimize-contrast;
}

/* ── Topbar: "Simuler mes droits" CTA ────────────────────────────── */
.tb2-sim-link { display: none !important; } /* remove old */
.tb2-sim-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .68rem;
  font-weight: 700;
  color: rgba(255,255,255,.55);
  text-decoration: none;
  letter-spacing: .02em;
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  transition: all .18s;
  white-space: nowrap;
}
.tb2-sim-cta svg { flex-shrink: 0; }
.tb2-sim-cta:hover {
  color: rgba(255,255,255,.82);
  border-color: rgba(255,255,255,.26);
  background: rgba(255,255,255,.05);
}
/* Remove old tb2-claim */
.tb2-claim { display: none !important; }
.tb2-claim-dot { display: none !important; }
@media(max-width:640px) { .tb2-sim-cta { display: none !important; } }

/* ── Topbar height bump — adjust nav sticky top ─────────────────── */
.nav { position: sticky; top: 48px !important; }

/* ══ LOGO HEADER — v115 FINAL (62px desktop) ══════════════════════ */

@media (max-width: 900px)  {  }
@media (max-width: 767px)  {  }
.mm-logo-img { height: 40px !important; width: auto !important; }

/* ══ HERO CTA — v77 ═══════════════════════════════════════════════════
   1 seul CTA dominant + ghost link programme discret
   ═══════════════════════════════════════════════════════════════════ */
.page-ctas {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  margin-top: 36px;
}
.hero-prog-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .8rem;
  font-weight: 600;
  color: rgba(255,255,255,.42);
  text-decoration: none;
  letter-spacing: .03em;
  padding: 2px 0;
  border-bottom: 1px solid rgba(255,255,255,.14);
  transition: color .18s, border-color .18s;
}
.hero-prog-link svg { flex-shrink: 0; opacity: .5; transition: opacity .18s; }
.hero-prog-link:hover { color: rgba(255,255,255,.72); border-bottom-color: rgba(255,255,255,.3); }
.hero-prog-link:hover svg { opacity: .85; }
@media(max-width:640px) {
  .page-ctas { align-items: stretch; }
  .btn-primary { text-align: center; justify-content: center; }
}



/* Force "commence ici." back to white (override hero-v2-em gradient) */


* Override old blog-grid to use new card correctly */
.blog-grid 

/* ── Blog grid responsive ─────────────────────────────────────────── */
@media(max-width:900px) {
  .blog-grid[style*="repeat(3,1fr)"] { grid-template-columns: repeat(2,1fr) !important; }
}
@media(max-width:580px) {
  .blog-grid[style*="repeat(3,1fr)"] { grid-template-columns: 1fr !important; }
}

/* ── Homepage H1: "formation" = gradient, rest = white ────────────────────
   "trans" stays white (inherited from .hero-v2-h1 { color:#fff })
   "formation" gets the pink gradient
   "commence ici." stays white (no .hero-v2-em override)
   ─────────────────────────────────────────────────────────────────────── */
.hero-v2-formation-word {
  background: linear-gradient(135deg, #C084FC 0%, #E040AB 40%, #FF6B6B 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline;
}

/* ══ LOGO HEADER — +20% v77 ═══════════════════════════════════════════════
   Desktop 74px · Tablet 62px · Mobile 46px · MMenu 48px
   ═══════════════════════════════════════════════════════════════════════ */
.logo-img-header {
  height: 74px !important;
  width: auto !important;
  max-width: 300px !important;
  object-fit: contain !important;
  display: block !important;
}
@media (max-width: 900px)  { .logo-img-header { height: 62px !important; } }
@media (max-width: 767px)  { .logo-img-header { height: 46px !important; max-width: 190px !important; } }
.mm-logo-img { height: 48px !important; width: auto !important; }

/* ══ BLOG CARD UNIFIÉ v77 — premium card avec pill ════════════════════════
   Structure: fond blanc · bordure subtile · pill catégorie · hover lift
   ═══════════════════════════════════════════════════════════════════════ */

.blog-card-u {
  background: #ffffff;
  border: 1.5px solid rgba(30,28,80,.1);
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .2s, box-shadow .2s, transform .2s;
  height: 100%;
}
.blog-card-u:hover {
  border-color: rgba(123,63,204,.3);
  box-shadow: 0 8px 28px rgba(123,63,204,.12);
  transform: translateY(-3px);
}
.blog-card-u-link {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px 22px 20px;
  text-decoration: none;
  height: 100%;
  box-sizing: border-box;
}
.blog-cat-u {
  display: inline-flex;
  align-items: center;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 4px 12px;
  border: 1.5px solid;
  width: fit-content;
  line-height: 1.2;
  flex-shrink: 0;
}
.blog-h3-u {
  font-family: "Bricolage Grotesque", "Plus Jakarta Sans", sans-serif;
  font-size: .96rem;
  font-weight: 800;
  color: rgba(30,28,80,.92);
  line-height: 1.35;
  letter-spacing: -.02em;
  margin: 0;
}
.blog-exc-u {
  font-size: .82rem;
  color: rgba(30,28,80,.54);
  line-height: 1.65;
  margin: 0;
  flex: 1;
}
.blog-cta-u {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .8rem;
  font-weight: 700;
  color: var(--violet, #7B3FCC);
  margin-top: 2px;
  flex-shrink: 0;
}

/* Blog grid layout */
.blog-grid {
  align-items: stretch;
}

/* Responsive blog grid */
@media(max-width:960px) {
  .blog-grid[style*="repeat(3,1fr)"] { grid-template-columns: repeat(2,1fr) !important; }
}
@media(max-width:580px) {
  .blog-grid[style*="repeat(3,1fr)"] { grid-template-columns: 1fr !important; }
}

/* ══ NAV CTA BUTTON — "Réserver mon diagnostic" ════════════════════════════
   Gradient pill · visible on all pages in the top navigation bar
   ═══════════════════════════════════════════════════════════════════════ */
.btn-nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: linear-gradient(135deg, #9B2FCC 0%, #E040AB 60%, #FF1A8C 100%);
  color: #fff !important;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .01em;
  padding: 10px 20px;
  border-radius: 999px;
  text-decoration: none;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(224,64,171,.35);
  transition: box-shadow .18s, transform .18s, opacity .18s;
  -webkit-text-fill-color: #fff !important;
}
.btn-nav-cta:hover {
  box-shadow: 0 6px 24px rgba(224,64,171,.55);
  transform: translateY(-1px);
  opacity: .95;
}
.btn-nav-cta svg {
  flex-shrink: 0;
  stroke: #fff;
}
@media (max-width: 900px) {
  .btn-nav-cta { display: none; }
}

/* ── homepage H1: "commence ici." = blanc ───────────────────────────────
   gradient only on span.hero-v2-formation-word ("formation")
   ─────────────────────────────────────────────────────────────────────── */
.hero-v2-em {
  display: block;
  font-style: normal;
  color: #fff !important;
  background: none !important;
  -webkit-text-fill-color: #fff !important;
  background-clip: unset !important;
  -webkit-background-clip: unset !important;
}


/* ── Hero meta pills — contraste amélioré ───────────────────────────────── */
.hmp {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.88);
  padding: 6px 13px;
  border-radius: 999px;
  font-size: .74rem;
  font-weight: 600;
}


/* ── Article blog — sections serrées, pas de grands vides ──────────────── */
.article-page .s,
.article-page .s.s-alt {
  padding: 48px 0 !important;
}
.article-page .s:first-of-type {
  padding-top: 40px !important;
}
/* Ensure reveal works — opacity:0 until .on is added */
body:not(.js-ready) .reveal {
  opacity: 1 !important;
  transform: none !important;
}

/* ══ BUTTON CENTERING — global ═════════════════════════════════════════════
   Ensure CTA buttons are centered in their containers
   ═══════════════════════════════════════════════════════════════════════ */

/* cta-final-section — already has text-align:center, ensure btn aligns */
.cta-final-section .btn-primary,
.cta-final-section .s-ctas {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cta-final-section > .wrap,
.s.s-alt.cta-final-section > .wrap {
  text-align: center;
}
/* All sections with text-align:center — center their btns */
[style*="text-align:center"] .btn-primary,
[style*="text-align: center"] .btn-primary {
  margin-left: auto;
  margin-right: auto;
}
/* Page-ctas flex column — center on mobile */
.page-ctas {
  align-items: flex-start;
}
@media(max-width:640px) {
  .page-ctas { align-items: center; }
}
/* Blog CTA final section */
.blog-grid + section .btn-primary { margin: 0 auto; }

/* ── Topbar hover — inverted ─────────────────────────────────────── */



.tb2-tel:hover { color: #fff; }

/* ── Center buttons in centered-layout sections ─────────────────── */
.s-ctas { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; }
/* When page-ctas is inside a centered hero */
.cta-final-section .page-ctas,
[style*="text-align:center"] .page-ctas {
  align-items: center;
}
/* Blog CTA final section */
.s.s-alt.cta-final-section .wrap { text-align: center; }
.s.s-alt.cta-final-section .wrap > * { margin-left: auto; margin-right: auto; }
.s.s-alt.cta-final-section .reveal { display: flex; flex-direction: column; align-items: center; gap: 12px; }

/* ══ PERFORMANCE MOBILE — chirurgical ══════════════════════════════════════
   Réduit le coût GPU sur mobile sans dégrader la DA premium
   S'active uniquement sur écrans < 768px
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ── Reveal: plus léger sur mobile ─────────────────────────────────── */
  .reveal {
    transform: translateY(8px) !important;
    transition: .36s cubic-bezier(.16,1,.3,1) !important;
  }

  /* ── Backdrop-filter: réduit (coûteux sur mobile) ──────────────────── */
  .nav,
  .prog-btn-back,
  .prog-return-bar,
  .mm-panel,
  .bf-dropdown-menu {
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
  }

  /* ── Box-shadows: allégées ──────────────────────────────────────────── */
  .card,
  .blog-card-u,
  .sector-card,
  .faq-item {
    box-shadow: 0 2px 10px rgba(30,28,80,.06) !important;
  }

  /* ── Hero gradient: simplifié (moins de layers) ─────────────────────── */
  .hero-v2 {
    background: linear-gradient(160deg,#060519 0%,#120F5E 60%,#260A4A 100%) !important;
  }
  .page-hero {
    background: linear-gradient(150deg,#060519 0%,#0E0B50 50%,#1A0D58 100%) !important;
  }

  /* ── Orbs décoratifs: désactivés sur mobile ─────────────────────────── */
  .cta-final-orb,
  .cta-final-orb2,
  .hero-v2-orb,
  [class*="-orb"] {
    display: none !important;
  }

  /* ── Transitions: réduites ──────────────────────────────────────────── */
  * {
    transition-duration: max(var(--t-dur, 0ms), 200ms) !important;
  }
  .mega-drop,
  .drop {
    transition: none !important;
  }

  /* ── will-change: libéré après animation ────────────────────────────── */
  .reveal.on {
    will-change: auto !important;
  }

  /* ── Blog featured card: hauteur réduite ─────────────────────────────── */
  .bcf-thumb {
    min-height: 200px !important;
  }

  /* ── Images: optimisées ─────────────────────────────────────────────── */
  img {
    content-visibility: auto;
  }

  /* ── Gradient text: accéléré ────────────────────────────────────────── */
  .eg, .hero-v2-formation-word, .hero-v2-em, [class*="gradient-text"] {
    -webkit-background-clip: text !important;
    background-clip: text !important;
  }
}

/* ── prefers-reduced-motion: respect system preference ─────────────────── */
@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  * {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}

/* ══ CLS PREVENTION — réserve l'espace avant chargement ════════════════════ */
/* Logo header: espace réservé */
.logo-img-header {
  aspect-ratio: 220 / 93;
  height: 74px;
  width: auto;
  max-width: 300px;
  display: block;
  object-fit: contain;
}
/* Footer logo */
.logo-img-footer {
  aspect-ratio: 180 / 76;
  height: 52px;
  width: auto;
  max-width: 200px;
}
/* Blog card thumbs */
.bc-thumb {
  aspect-ratio: 16 / 3.5;
  height: 80px;
  contain: layout style;
}
/* Blog featured thumb */
.bcf-thumb {
  contain: layout style;
}

/* ══ HERO BLOG FILTERS — pills inside dark hero ═════════════════════════ */
.hero-blog-filters { position: relative; z-index: 10; }
.hbf-pill {
  font-family: inherit;
  font-size: .76rem;
  font-weight: 600;
  color: rgba(255,255,255,.62);
  background: rgba(255,255,255,.08);
  border: 1.5px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 7px 16px;
  cursor: pointer;
  transition: all .18s;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.hbf-pill:hover {
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.28);
  color: #fff;
}
.hbf-pill.active {
  background: rgba(255,255,255,.95);
  border-color: transparent;
  color: rgba(30,28,80,.88);
  font-weight: 700;
}
.hbf-pill--dropdown { gap: 6px; }

/* Hero dropdown */
.hbf-dropdown { position: relative; display: inline-block; }
.hbf-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  background: #fff;
  border: 1.5px solid rgba(30,28,80,.08);
  border-radius: 14px;
  padding: 6px;
  min-width: 190px;
  box-shadow: 0 8px 32px rgba(30,28,80,.2);
  z-index: 400;
}
.hbf-dropdown.open .hbf-dropdown-menu { display: block; }
.hbf-dropdown.open .hbf-pill--dropdown {
  background: rgba(255,255,255,.95);
  border-color: transparent;
  color: rgba(30,28,80,.88);
}
.hbf-dropdown-item {
  display: block; width: 100%; text-align: left;
  padding: 9px 14px; border: none; border-radius: 9px;
  background: transparent;
  font-family: inherit; font-size: .8rem; font-weight: 600;
  color: rgba(30,28,80,.7); cursor: pointer; transition: all .14s;
}
.hbf-dropdown-item:hover { background: rgba(123,63,204,.06); color: var(--violet,#7B3FCC); }
.hbf-dropdown-item.active { background: rgba(123,63,204,.08); color: var(--violet,#7B3FCC); font-weight: 700; }

/* ── Blog card — NO thumbnail gradient, pill only ──────────────────────── */
.blog-card-u-link {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 22px 22px 18px;
  text-decoration: none;
  height: 100%;
  box-sizing: border-box;
}
.blog-cat-u {
  display: inline-flex;
  align-items: center;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 4px 12px;
  border: 1.5px solid;
  width: fit-content;
  line-height: 1.2;
  flex-shrink: 0;
}

/* Remove bc-thumb entirely for clean cards */
.bc-thumb { display: none !important; }
.bc-body { padding: 0 !important; display: flex; flex-direction: column; gap: 8px; flex: 1; }

/* ══ TOPBAR — rollover premium ═══════════════════════════════════════════
   Inversion propre sur hover : fond coloré, texte inversé
   ══════════════════════════════════════════════════════════════════════ */

/* TEL */
.tb2-tel {
  letter-spacing: .02em;
  color: rgba(255,255,255,.62);
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid transparent;
  transition: color .16s, background .16s, border-color .16s;
}
.tb2-tel:hover {
  color: #fff;
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.18);
}

/* WA / Échanger avec un expert */
.tb2-wa {
  color: #4ade80 !important;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(74,222,128,.25);
  transition: color .16s, background .16s, border-color .16s;
}
.tb2-wa:hover {
  background: #25D366 !important;
  color: #fff !important;
  border-color: #25D366 !important;
}

/* Simulateur link — inversion sur hover */
.tb2-sim-link:hover {
  background: rgba(255,255,255,.12) !important;
  color: rgba(255,255,255,.9) !important;
  border-color: rgba(255,255,255,.22) !important;
}

