/* PASO - SHARED CSS
   Base styles partagés par toutes les pages du site.
   Inclut : tokens, typo, layout, nav, boutons, badges, cards,
   .paso-proof, et le bloc CASE STUDY (.case-*) pour les pages cas-*.html.
   ============================================================ */

:root {
  --navy:       #13173e; --navy-mid:   #42487a; --navy-light: #7e85b7;
  --amber:      #dd8f18; --amber-light:#f5c56a; --amber-dark: #b8720f;
  --amber-100:  #f9e4b2; --amber-900:  #7a4a08;
  --white:      #ffffff;
  --gray-50:    #f8f9fb; --gray-100:   #f0f2f7; --gray-200:   #dde1ec;
  --gray-400:   #9199b8; --gray-600:   #5a6380; --gray-800:   #2d3356;
  --black:      #0a0c1e; --success:    #1a7a5e; --error:      #c23a4f;
  --font:'Inter',sans-serif;
  --radius-md:8px; --radius-lg:12px; --radius-xl:16px; --radius-pill:100px;
  --btn-radius:8px 8px 16px 8px;
  --shadow-sm:0 1px 3px rgba(19,23,62,.08);
  --shadow-md:0 4px 16px rgba(19,23,62,.10);
  --shadow-lg:0 8px 32px rgba(19,23,62,.14);
  --shadow-amber:0 4px 16px rgba(221,143,24,.28);
  --nav-h:88px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;overflow-x:clip;}
body{font-family:var(--font);color:var(--navy);background:#fafbfc;line-height:1.6;overflow-x:hidden;overflow-x:clip;position:relative;width:100%;max-width:100vw;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;}
[id]{scroll-margin-top:var(--nav-h);}
button{font-family:var(--font);cursor:pointer;border:none;background:none;}

.container{max-width:1320px;margin:0 auto;padding:0 clamp(24px,4.5vw,72px);}
section{padding:clamp(72px,9vw,120px) 0;}
.section-dark{background:var(--navy);color:white;}
.section-gray{background:var(--gray-50);}

/* TYPO */
.display{font-size:clamp(42px,5vw,64px);font-weight:800;letter-spacing:-2px;line-height:1.05;}
h1{font-size:clamp(36px,4vw,52px);font-weight:800;letter-spacing:-1.2px;line-height:1.08;color:var(--navy);}
h2{font-size:clamp(28px,2.8vw,36px);font-weight:700;letter-spacing:-.5px;line-height:1.15;color:var(--navy);}
h3{font-size:22px;font-weight:700;color:var(--navy);}
.text-amber{color:var(--amber);}
.amber-dot{color:var(--amber);}
.section-dark h1,.section-dark h2,.section-dark h3{color:white;}

/* LOGO */
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.logo-img{height:40px;width:auto;display:block;}

/* PASO LOGO PATTERN (Inter 800, -0.025em tracking, amber dot accent) */
.logo-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;
  border-radius:11px;
  background:var(--navy);color:#FAFBFC;
  font-family:'Inter',sans-serif;font-weight:800;font-size:22px;line-height:1;
  letter-spacing:-0.025em;
  text-decoration:none;flex-shrink:0;
  transition:background 220ms ease,color 220ms ease,border-color 220ms ease;
  border:1px solid transparent;
}
.logo-mark .logo-dot{color:var(--amber);transition:color 220ms ease;margin-left:-1px;}
/* En nav-dark : P navy sur carre blanc. On epaissit le contour du P
   pour compenser l illusion d irradiation (texte clair sur fond sombre
   parait visuellement plus epais qu un texte sombre sur fond clair). */
#navbar.nav-dark .logo-mark{
  background:#FAFBFC;color:var(--navy);
  -webkit-text-stroke:0.5px var(--navy);
}
#navbar.nav-dark .logo-mark .logo-dot{color:var(--amber);-webkit-text-stroke:0.5px var(--amber);}
#navbar.nav-dark .logo-wordmark{color:white;}
#navbar.nav-dark .logo-wordmark .logo-dot{color:var(--amber);}

.logo-wordmark{
  font-family:'Inter',sans-serif;font-weight:800;font-size:22px;line-height:1;
  letter-spacing:-0.025em;
  text-decoration:none;
  display:inline-flex;align-items:baseline;
  color:var(--navy);white-space:nowrap;
}
.logo-wordmark .logo-dot{color:var(--amber);}
footer .logo-wordmark,.section-dark .logo-wordmark{color:white;}
/* Wordmark dans la nav : visible en initial, masqué quand .scrolled */
.logo-wordmark-nav{
  font-size:20px;
  max-width:200px;opacity:1;overflow:hidden;
  transition:opacity 250ms ease,max-width 350ms ease,margin-left 350ms ease;
}
#navbar.scrolled .logo-wordmark-nav{
  opacity:0;max-width:0;margin-left:-10px;
}

/* SECTION LABEL */
.section-label{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.section-label::after{content:'';flex:1;height:1px;background:var(--gray-200);max-width:80px;}
.section-dark .section-label::after{background:rgba(255,255,255,.1);}
.label-center{justify-content:center;}
.label-center::after,.label-center::before{display:none;}

/* BOUTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--btn-radius);font-size:14px;font-weight:600;white-space:nowrap;transition:transform 200ms ease,background 200ms ease,box-shadow 200ms ease;cursor:pointer;border:none;text-decoration:none;}
.btn:hover{transform:translateY(-1px);}
.btn:active{transform:translateY(0);}
.btn-lg{padding:16px 32px;font-size:16px;}
.btn-sm{padding:9px 18px;font-size:12px;}
.btn-primary{background:var(--navy);color:white;}
.btn-primary:hover{background:#1e2451;box-shadow:var(--shadow-md);}
.btn-amber{background:var(--amber);color:#FAFBFC;box-shadow:0 4px 16px rgba(221,143,24,.28);}
.btn-amber:hover{background:var(--amber);color:#FAFBFC;box-shadow:0 6px 22px rgba(221,143,24,.4);}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--navy);}
.btn-outline:hover{background:rgba(19,23,62,.05);}
.btn-outline-light{background:transparent;color:white;border:1.5px solid rgba(255,255,255,.25);}
.btn-outline-light:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.5);}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;letter-spacing:.04em;}
.badge-amber{background:rgba(221,143,24,.12);color:var(--amber-dark);}

/* CARDS */
.card{background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:32px;transition:border-color 250ms cubic-bezier(.22,1,.36,1),transform 250ms cubic-bezier(.22,1,.36,1),box-shadow 250ms cubic-bezier(.22,1,.36,1);}
.card:hover{border-color:rgba(221,143,24,.3);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.card-dark{background:var(--navy);color:white;border-color:transparent;}
.card-dark:hover{border-color:rgba(221,143,24,.4);}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media(max-width:900px){.grid-3{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.grid-2,.grid-3{grid-template-columns:1fr;}}

/* NAV FLOTTANTE */
#navbar{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 12px;pointer-events:none;}
.logo-sticky{display:none;pointer-events:all;align-items:center;justify-content:center;text-decoration:none;position:absolute;top:50%;left:max(40px,calc(50vw - 632px));transform:translateY(-50%);z-index:2;}
#navbar.scrolled .logo-sticky{display:inline-flex;}
.nav-inner{max-width:1320px;margin:0 auto;padding:0 28px;height:64px;display:flex;align-items:center;gap:0;position:relative;background:transparent;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);border-radius:16px;border:1px solid transparent;box-shadow:none;pointer-events:all;transition:box-shadow 350ms ease,background 350ms ease,border-color 350ms ease,backdrop-filter 350ms ease,-webkit-backdrop-filter 350ms ease,height 350ms ease,margin-left 350ms ease,max-width 350ms ease;isolation:isolate;}
#navbar.scrolled .nav-inner{height:56px;background:rgba(255,255,255,.72);backdrop-filter:blur(72px);-webkit-backdrop-filter:blur(72px);border-color:rgba(255,255,255,.4);box-shadow:0 4px 28px rgba(19,23,62,.10),0 0 0 1px rgba(19,23,62,.05);margin-left:max(87px,calc(50vw - 585px));margin-right:max(0px,calc(50vw - 672px));max-width:none;}
#navbar.scrolled .nav-logo-wrap{display:none;}
#navbar.scrolled .nav-links{margin-left:auto;}
#navbar.nav-dark .nav-inner{background:rgba(19,23,62,.72);border-color:rgba(255,255,255,.08);box-shadow:0 2px 20px rgba(0,0,0,.25),0 0 0 1px rgba(255,255,255,.04);}
#navbar.nav-dark .nav-link{color:rgba(255,255,255,.55);}
#navbar.nav-dark .nav-link:hover,#navbar.nav-dark .nav-link.active{color:white;}
#navbar.nav-dark .nav-link::after{background:var(--amber);}
#navbar.nav-dark .btn-primary{background:white;color:var(--navy);}
#navbar.nav-dark .btn-primary:hover{background:rgba(255,255,255,.88);}
#navbar.nav-dark .nav-hamburger{color:white;}
#navbar .logo-img{transition:opacity 200ms ease;}
#navbar .logo-dark-img{position:absolute;top:0;left:0;opacity:0;pointer-events:none;transition:opacity 200ms ease;}
#navbar.nav-dark .logo-light-img{opacity:0;}
#navbar.nav-dark .logo-dark-img{opacity:1;}
.nav-logo-wrap{margin-right:auto;flex-shrink:0;}
.nav-links{display:flex;align-items:center;gap:28px;margin-right:28px;}
.nav-link{font-size:14px;font-weight:500;color:var(--gray-600);position:relative;padding-bottom:2px;transition:color 200ms ease;}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--amber);transition:width 250ms ease;}
.nav-link:hover,.nav-link.active{color:var(--navy);}
.nav-link:hover::after,.nav-link.active::after{width:100%;}
.nav-cta{margin-left:0;gap:6px;}
.nav-cta-arrow{flex-shrink:0;transition:transform 220ms ease;}
.nav-cta:hover .nav-cta-arrow{transform:translateX(3px);}

/* DROPDOWN NAV - MEGA MENU */
.nav-link-with-dropdown{position:static;}
.nav-link-with-dropdown > .nav-link{cursor:pointer;display:inline-flex;align-items:center;gap:4px;}
.nav-link-chevron{display:inline-block;font-size:8px;transition:transform 200ms ease;line-height:1;margin-top:2px;}
.nav-link-with-dropdown:hover .nav-link-chevron,.nav-link-with-dropdown:focus-within .nav-link-chevron{transform:rotate(180deg);}

.nav-megamenu{
  position:absolute;
  top:calc(100% + 18px);
  left:50%;
  transform:translate(-50%,-8px);
  opacity:0;visibility:hidden;
  transition:opacity 220ms ease,visibility 220ms ease,transform 220ms ease;
  width:min(1100px,calc(100vw - 64px));
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid var(--gray-200);
  border-radius:20px;
  box-shadow:0 24px 64px rgba(19,23,62,.16),0 8px 16px rgba(19,23,62,.06);
  padding:32px;
  z-index:300;
}
.nav-link-with-dropdown:hover .nav-megamenu,
.nav-link-with-dropdown:focus-within .nav-megamenu{
  opacity:1;visibility:visible;transform:translate(-50%,0);
}
.nav-link-with-dropdown.mega-force-closed .nav-megamenu{
  opacity:0 !important;visibility:hidden !important;transform:translate(-50%,-8px) !important;
}
.nav-megamenu::before{
  content:'';position:absolute;top:-18px;left:0;right:0;height:18px;
}
.nav-megamenu-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;
  gap:12px;
  margin-bottom:20px;
}
.nav-megamenu-card{
  display:flex;flex-direction:column;gap:8px;
  padding:18px;
  border-radius:14px;
  border:1px solid var(--gray-200);
  background:white;
  transition:border-color 200ms ease,background 200ms ease,transform 200ms ease;
  position:relative;
  overflow:hidden;
}
.nav-megamenu-card:hover{
  border-color:rgba(221,143,24,.4);
  background:#fffaf0;
  transform:translateY(-2px);
}
.nav-megamenu-card-featured{
  background:linear-gradient(135deg,var(--navy) 0%,#1a1f5a 100%);
  border-color:transparent;
  color:white;
}
.nav-megamenu-card-featured::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 100% 0%,rgba(221,143,24,.18) 0%,transparent 60%);
  pointer-events:none;
}
.nav-megamenu-card-featured:hover{
  border-color:rgba(221,143,24,.5);
  background:linear-gradient(135deg,var(--navy) 0%,#1a1f5a 100%);
}
.nav-megamenu-card-featured *{position:relative;}
.nav-megamenu-icon{
  width:36px;height:36px;
  border-radius:10px;
  background:rgba(221,143,24,.1);
  color:var(--amber);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:4px;
  transition:background 200ms ease;
}
.nav-megamenu-card:hover .nav-megamenu-icon{
  background:rgba(221,143,24,.18);
}
.nav-megamenu-card-featured .nav-megamenu-icon{
  background:rgba(221,143,24,.18);
}
.nav-megamenu-tag{
  font-size:10px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--amber);
}
.nav-megamenu-card-featured .nav-megamenu-tag{color:var(--amber-light);}
.nav-megamenu-name{
  font-size:15px;font-weight:700;
  color:var(--navy);letter-spacing:-.2px;line-height:1.2;
}
.nav-megamenu-card-featured .nav-megamenu-name{color:white;}
.nav-megamenu-desc{
  font-size:12px;color:var(--gray-600);line-height:1.5;
  margin-top:auto;
}
.nav-megamenu-card-featured .nav-megamenu-desc{color:rgba(255,255,255,.65);}
.nav-megamenu-arrow{
  position:absolute;top:18px;right:18px;
  color:var(--gray-400);
  opacity:0;transform:translateX(-4px);
  transition:opacity 200ms ease,transform 200ms ease,color 200ms ease;
}
.nav-megamenu-card:hover .nav-megamenu-arrow{
  opacity:1;transform:translateX(0);color:var(--amber);
}
.nav-megamenu-card-featured .nav-megamenu-arrow{
  color:rgba(255,255,255,.4);opacity:1;
}
.nav-megamenu-card-featured:hover .nav-megamenu-arrow{
  color:var(--amber-light);transform:translateX(2px);
}

.nav-megamenu-footer{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
  padding:18px 18px 4px;
  border-top:1px solid var(--gray-200);
  flex-wrap:wrap;
}
.nav-megamenu-footer-label{
  font-size:11px;font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;color:var(--gray-600);
  display:flex;align-items:center;gap:10px;
}
.nav-megamenu-footer-label::after{
  content:'';width:24px;height:1px;background:var(--gray-200);
}
.nav-megamenu-footer-links{
  display:flex;gap:8px;flex-wrap:wrap;
}
.nav-megamenu-footer-link{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;
  background:var(--gray-50);
  border:1px solid var(--gray-200);
  border-radius:8px 8px 16px 8px;
  font-size:12px;font-weight:600;color:var(--navy);
  transition:border-color 200ms ease,background 200ms ease,color 200ms ease;
}
.nav-megamenu-footer-link:hover{
  border-color:rgba(221,143,24,.4);
  background:#fffaf0;
  color:var(--amber-dark);
}
.nav-megamenu-footer-link svg{flex-shrink:0;transition:transform 200ms ease;}
.nav-megamenu-footer-link:hover svg{transform:translateX(2px);}

#navbar.nav-dark .nav-megamenu{background:rgba(255,255,255,.98);border-color:var(--gray-200);}

/* Mega menu Ressources - grid 4 colonnes avec premier card featured plus large */
.nav-megamenu-grid-resources{grid-template-columns:1.4fr 1fr 1fr 1fr;}
.nav-megamenu-card-soon{opacity:.62;cursor:default;}
.nav-megamenu-card-soon:hover{transform:none;border-color:var(--gray-200);background:white;}
.nav-megamenu-card-soon .nav-megamenu-arrow{display:none;}
.nav-megamenu-soon{position:absolute;top:14px;right:14px;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-400);background:var(--gray-100);padding:3px 8px;border-radius:100px;}

/* Featured card variant : mint green (utilisé sur Acquisition et performance dans le mega menu Ressources) */
.nav-megamenu-card-mint::before{
  background:radial-gradient(ellipse at 100% 0%,rgba(125,217,171,.18) 0%,transparent 60%) !important;
}
.nav-megamenu-card-mint:hover{
  border-color:rgba(125,217,171,.5) !important;
}
.nav-megamenu-card-mint .nav-megamenu-icon{
  background:rgba(125,217,171,.18) !important;
  color:#7DD9AB !important;
}
.nav-megamenu-card-mint .nav-megamenu-tag{color:#7DD9AB !important;}
.nav-megamenu-card-mint:hover .nav-megamenu-arrow{
  color:#7DD9AB !important;
}

@media(max-width:1180px){
  .nav-megamenu-grid{grid-template-columns:repeat(3,1fr);}
  .nav-megamenu-card-featured{grid-column:span 3;}
  .nav-megamenu-grid-resources{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:900px){.nav-megamenu{display:none;}}

/* Mobile menu sous-liens */
.mobile-menu-sub{
  padding-left:20px !important;
  font-size:14px !important;
  color:rgba(255,255,255,.5) !important;
  border-bottom:1px solid rgba(255,255,255,.04) !important;
}
.mobile-menu-sub::before{
  content:'· ';
  color:var(--amber);
  margin-right:6px;
}
.mobile-menu-group-label{
  font-size:10px !important;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.3) !important;
  padding:20px 0 8px !important;
  border-bottom:none !important;
  pointer-events:none;
}
.mobile-menu-soon{
  display:inline-block;
  margin-left:8px;
  font-size:9px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.45);
  background:rgba(255,255,255,.08);
  padding:2px 7px;
  border-radius:100px;
  vertical-align:middle;
}
.mobile-menu-group{
  display:flex !important;
  align-items:center;
  justify-content:space-between;
  width:100%;
  font-family:var(--font);
  font-size:16px !important;
  font-weight:500 !important;
  color:rgba(255,255,255,.65) !important;
  padding:16px 0 !important;
  border-bottom:1px solid rgba(255,255,255,.07) !important;
  background:none;
  border-left:none;border-right:none;border-top:none;
  text-align:left;
  cursor:pointer;
  transition:color 200ms;
}
.mobile-menu-group:hover{color:white !important;}
.mobile-menu-chevron{transition:transform 250ms cubic-bezier(.22,1,.36,1);flex-shrink:0;}
.mobile-menu-group[aria-expanded="true"] .mobile-menu-chevron{transform:rotate(180deg);}
.mobile-menu-group-items{display:block !important;width:100% !important;}
.mobile-menu-group-items[hidden]{display:none !important;}
.mobile-menu-group-items > a{display:block !important;width:100% !important;}
.nav-hamburger{display:none;margin-left:auto;}
.nav-cal-btn{display:none;width:40px;height:40px;border-radius:10px;background:transparent;border:none;color:var(--navy);align-items:center;justify-content:center;flex-shrink:0;transition:background 200ms,color 200ms;}
.nav-cal-btn:hover{background:rgba(19,23,62,.06);}
#navbar.nav-dark .nav-cal-btn{color:white;}
:focus-visible{outline:2px solid var(--amber);outline-offset:3px;border-radius:4px;}
.skip-link{position:absolute;top:-100%;left:0;background:var(--amber);color:white;padding:8px 16px;z-index:9999;}
.skip-link:focus{top:0;}

/* MOBILE MENU */
.mobile-menu{position:fixed;inset:0;z-index:200;background:rgba(19,23,62,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:0;padding:0 28px;opacity:0;pointer-events:none;transition:opacity 300ms;}
.mobile-menu.open{opacity:1;pointer-events:all;}
.mobile-menu a{font-size:16px;font-weight:500;color:rgba(255,255,255,.65);padding:16px 0;border-bottom:1px solid rgba(255,255,255,.07);width:100%;transition:color 200ms;}
.mobile-menu a:last-of-type{border-bottom:none;}
.mobile-menu a:hover{color:white;}
.mobile-menu-cta{margin-top:24px;background:var(--amber) !important;color:white !important;font-weight:600 !important;font-size:15px !important;border-radius:8px 8px 16px 8px !important;padding:16px 24px !important;text-align:center;border-bottom:none !important;}
.mobile-close{position:absolute;top:24px;right:24px;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);color:white;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;}

/* REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 500ms cubic-bezier(.22,1,.36,1),transform 500ms cubic-bezier(.22,1,.36,1);}
.reveal.visible{opacity:1;transform:translateY(0);}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .reveal.visible{transition:none;}
  html{scroll-behavior:auto;}
}

/* FOOTER */
footer{background:var(--black);color:rgba(255,255,255,.55);padding:80px 0 32px;position:relative;overflow:hidden;}
.footer-grid-bg{position:absolute;inset:0;pointer-events:none;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:5px 5px;}
footer .container{position:relative;z-index:1;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px;}
.footer-brand p{font-size:14px;line-height:1.7;color:rgba(255,255,255,.55);margin:16px 0;max-width:280px;}
.footer-domain{font-size:13px;color:var(--amber) !important;font-weight:600;letter-spacing:.02em;}
.footer-col-title{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:18px;}
.footer-col-links{display:flex;flex-direction:column;gap:12px;}
.footer-col-links a{font-size:14px;color:rgba(255,255,255,.65);transition:color 200ms;}
.footer-col-links a:hover{color:white;}
.footer-contact-links{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;}
.footer-contact-links a{font-size:14px;color:rgba(255,255,255,.65);transition:color 200ms;}
.footer-contact-links a:hover{color:white;}
.footer-bottom{padding-top:32px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:12px;color:rgba(255,255,255,.4);}
.footer-legal{display:flex;gap:24px;}
.footer-legal a{transition:color 200ms;}
.footer-legal a:hover{color:rgba(255,255,255,.7);}
.logo-dark img{filter:invert(1);}

/* RESPONSIVE NAV */
@media (max-width:900px){
  .nav-links,.nav-cta{display:none;}
  .nav-hamburger{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;}
  .nav-hamburger:hover{background:rgba(19,23,62,.06);}
  .nav-cal-btn{display:flex;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .footer-brand{grid-column:1 / -1;}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
}

/* PAGE HERO COMMUN */
.page-hero{padding-top:calc(var(--nav-h) + 60px);padding-bottom:80px;background:#fafbfc;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:300px;background:linear-gradient(to bottom,rgba(250,251,252,0) 0%,#fafbfc 35%,white 100%);pointer-events:none;z-index:0;}
.page-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:200px;background:linear-gradient(to bottom,#fafbfc 0%,transparent 100%);pointer-events:none;z-index:1;}
.page-hero-grid-bg{position:absolute;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(19,23,62,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(19,23,62,.032) 1px,transparent 1px);background-size:5px 5px;mask-image:linear-gradient(to bottom,black 0%,black 60%,transparent 95%);-webkit-mask-image:linear-gradient(to bottom,black 0%,black 60%,transparent 95%);}
.page-hero .container{position:relative;z-index:2;}
.page-hero-inner{max-width:820px;}
.page-hero-badge{margin-bottom:24px;}
.page-hero-pillars{font-size:12px;font-weight:500;letter-spacing:.04em;color:var(--gray-600);margin-bottom:28px;}
.page-hero-pillars .sep{color:var(--gray-400);margin:0 6px;}
.page-hero-pillars .active{color:var(--navy);font-weight:700;}
.page-hero-title{margin-bottom:24px;}
.page-hero-tagline{font-size:clamp(18px,1.6vw,22px);font-weight:600;color:var(--navy);line-height:1.4;letter-spacing:-.2px;margin-bottom:24px;font-style:italic;}
.page-hero-tagline .text-amber{font-style:italic;}
.page-hero-sub{font-size:17px;line-height:1.7;color:var(--gray-600);margin-bottom:36px;max-width:680px;}
.page-hero-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:32px;}
.page-hero-actions .btn-lg{padding:13px 24px;font-size:14.5px;}
.page-hero-actions .btn-outline{background:#fafbfc;} .page-hero-actions .btn-outline:hover{background:#f1f2f7;}
/* Variante 2-colonnes : contenu + visuel */
.page-hero-grid{display:grid;grid-template-columns:minmax(380px,1fr) minmax(520px,1.1fr);gap:48px;align-items:center;}
.page-hero-content{min-width:0;}
.page-hero-visual{position:relative;width:100%;display:flex;justify-content:center;align-items:center;min-width:0;}
@media(max-width:1024px){.page-hero-grid{grid-template-columns:1fr;gap:40px;}}
@media(max-width:768px){.page-hero-visual{display:none;}}

/* PASO PROOF PILL */
.paso-proof{display:inline-flex;align-items:center;gap:14px;padding:8px 16px 8px 8px;background:#ffffff;border:1px solid var(--gray-200);border-radius:100px;font-family:var(--font);box-shadow:0 1px 3px rgba(19,23,62,.04);}
.paso-proof__avatars{display:inline-flex;align-items:center;}
.paso-avatar{text-decoration:none;display:inline-flex;align-items:center;border-radius:999px;padding:2px;background:transparent;margin-left:-16px;transition:background-color .35s cubic-bezier(.4,0,.2,1),margin-left .5s cubic-bezier(.4,0,.2,1),box-shadow .35s cubic-bezier(.4,0,.2,1);cursor:pointer;}
.paso-avatar:first-child{margin-left:0;}
.paso-avatar:hover{background:#f3f4f7;margin-left:0;}
.paso-avatar:hover + .paso-avatar{margin-left:6px;}
.paso-avatar__disc{flex-shrink:0;width:30px;height:30px;border-radius:999px;border:2px solid #fff;display:inline-flex;align-items:center;justify-content:center;transition:transform .35s cubic-bezier(.4,0,.2,1);}
.paso-avatar__disc svg{width:16px;height:16px;}
.paso-avatar:hover .paso-avatar__disc{transform:scale(1.08);}
.paso-proof__info{position:relative;font-size:13px;line-height:1.2;white-space:nowrap;font-variant-numeric:tabular-nums;}
.paso-proof__stats,.paso-proof__hover{transition:opacity .25s cubic-bezier(.4,0,.2,1);}
.paso-proof__stats{color:var(--gray-600);font-weight:500;}
.paso-proof__hover{position:absolute;inset:0;display:inline-flex;align-items:center;opacity:0;pointer-events:none;}
.paso-proof.is-hovering .paso-proof__stats{opacity:0;}
.paso-proof.is-hovering .paso-proof__hover{opacity:1;}
.paso-proof__brand{font-weight:600;color:var(--navy);letter-spacing:-.005em;}
.paso-proof__cta{color:var(--amber);font-weight:600;margin-left:10px;}
.paso-proof__strong{color:var(--navy);font-weight:600;}
.paso-proof__muted{color:var(--gray-400);}
.paso-proof__sep{color:var(--gray-400);margin:0 8px;opacity:.6;}
@media(prefers-reduced-motion:reduce){.paso-avatar,.paso-avatar__disc,.paso-proof__stats,.paso-proof__hover{transition:none;}}
@media (max-width:600px){
  .paso-proof{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:20px;max-width:100%;}
  .paso-proof__info{white-space:normal;line-height:1.4;font-size:12.5px;}
  .paso-proof__hover{position:static;opacity:1;display:none;}
  .paso-proof__sep{margin:0 6px;}
}

/* BREADCRUMB */
.breadcrumb{font-size:12px;color:var(--gray-400);margin-bottom:32px;letter-spacing:.04em;}
.breadcrumb a{color:var(--gray-400);transition:color 200ms;}
.breadcrumb a:hover{color:var(--navy);}
.breadcrumb-sep{margin:0 8px;color:var(--gray-200);}
.breadcrumb-current{color:var(--navy);font-weight:500;}

/* SECTIONS COMMUNES PAGES PILIERS */
.pillar-section-header{max-width:760px;margin-bottom:56px;}
.pillar-section-header h2{margin-bottom:16px;letter-spacing:-1.5px;font-weight:800;line-height:1.1;}
.pillar-section-header p:not(.section-label){font-size:17px;color:var(--gray-600);line-height:1.65;}
.section-dark .pillar-section-header p:not(.section-label){color:rgba(255,255,255,.6);}

/* POUR QUI */
.target-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.target-card{background:white;border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:28px;transition:border-color 250ms,transform 250ms;}
.target-card:hover{border-color:rgba(221,143,24,.3);transform:translateY(-2px);}
.target-card-icon{width:40px;height:40px;border-radius:10px;background:rgba(221,143,24,.1);display:flex;align-items:center;justify-content:center;color:var(--amber);margin-bottom:16px;}
.target-card-title{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:8px;letter-spacing:-.2px;}
.target-card-desc{font-size:14px;color:var(--gray-600);line-height:1.6;}
@media(max-width:900px){.target-grid{grid-template-columns:1fr;}}

/* APPROCHE - liste avec numéros */
.approach-list{display:flex;flex-direction:column;gap:0;}
.approach-row{display:grid;grid-template-columns:64px 1fr 1.5fr;gap:32px;padding:32px 0;border-bottom:1px solid var(--gray-100);align-items:start;}
.approach-row:first-child{border-top:1px solid var(--gray-100);}
.approach-row-num{font-size:36px;font-weight:900;color:var(--gray-100);letter-spacing:-1.5px;line-height:1;user-select:none;transition:color 300ms;}
.approach-row:hover .approach-row-num{color:rgba(221,143,24,.25);}
.approach-row-title{font-size:18px;font-weight:700;color:var(--navy);line-height:1.3;letter-spacing:-.2px;padding-right:16px;}
.approach-row-desc{font-size:15px;color:var(--gray-600);line-height:1.7;}
@media(max-width:768px){.approach-row{grid-template-columns:48px 1fr;gap:16px;}.approach-row-desc{grid-column:2;margin-top:8px;}}

/* LIVRABLES (cards sombres) */
.deliverable-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.deliverable-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-xl);padding:28px;display:flex;flex-direction:column;gap:14px;transition:border-color 250ms,transform 250ms,background 250ms;}
.deliverable-card:hover{border-color:rgba(221,143,24,.35);background:rgba(255,255,255,.06);transform:translateY(-3px);}
.deliverable-card-icon{width:44px;height:44px;border-radius:12px;background:rgba(221,143,24,.12);border:1px solid rgba(221,143,24,.2);display:flex;align-items:center;justify-content:center;color:var(--amber);flex-shrink:0;}
.deliverable-card-title{font-size:18px;font-weight:700;color:white;letter-spacing:-.2px;}
.deliverable-card-desc{font-size:14px;color:rgba(255,255,255,.58);line-height:1.65;}
.deliverable-card-tag{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-top:auto;padding-top:14px;border-top:1px solid rgba(255,255,255,.06);}
@media(max-width:900px){.deliverable-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.deliverable-grid{grid-template-columns:1fr;}}

/* TARIFICATION LOGIQUE (sans prix exacts) */
.pricing-logic{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:40px;}
.pricing-logic h3{font-size:20px;margin-bottom:20px;color:var(--navy);}
.pricing-logic-list{display:flex;flex-direction:column;gap:14px;margin-bottom:24px;}
.pricing-logic-item{display:flex;gap:14px;align-items:flex-start;}
.pricing-logic-item-dot{width:20px;height:20px;border-radius:6px;background:rgba(221,143,24,.1);display:flex;align-items:center;justify-content:center;color:var(--amber);flex-shrink:0;margin-top:1px;}
.pricing-logic-item-text{font-size:15px;color:var(--gray-600);line-height:1.65;}
.pricing-logic-item-text strong{color:var(--navy);font-weight:600;}
.pricing-logic-note{font-size:13px;color:var(--gray-400);line-height:1.6;padding-top:20px;border-top:1px solid var(--gray-200);font-style:italic;}

/* FAQ INTERACTIVE - 2 colonnes (questions sidebar + answer panel) */
.faq-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:20px;overflow:hidden;border:1px solid var(--gray-200);box-shadow:var(--shadow-md);}
.faq-questions{background:white;padding:12px;}
.faq-q-item{display:flex;align-items:flex-start;gap:16px;padding:22px 20px;border-radius:12px;cursor:pointer;transition:background 200ms ease;position:relative;}
.faq-q-item:hover{background:var(--gray-50);}
.faq-q-item.active{background:var(--navy);}
.faq-q-num{font-size:11px;font-weight:800;color:var(--gray-400);letter-spacing:.06em;margin-top:3px;flex-shrink:0;width:22px;}
.faq-q-item.active .faq-q-num{color:var(--amber);}
.faq-q-text{font-size:14px;font-weight:600;color:var(--navy);line-height:1.55;}
.faq-q-item.active .faq-q-text{color:white;}
.faq-q-arrow{margin-left:auto;flex-shrink:0;color:var(--gray-400);margin-top:3px;transition:color 200ms,transform 200ms;}
.faq-q-item.active .faq-q-arrow{color:var(--amber);transform:translateX(2px);}
.faq-answer-panel{background:var(--navy);padding:48px 44px;position:relative;display:flex;flex-direction:column;justify-content:flex-start;}
.faq-answer-panel::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 90% 10%,rgba(221,143,24,.12) 0%,transparent 55%);pointer-events:none;}
.faq-answer-slot{display:none;position:relative;}
.faq-answer-slot.active{display:block;}
.faq-ans-num{font-size:72px;font-weight:900;color:rgba(255,255,255,.04);line-height:1;letter-spacing:-4px;margin-bottom:-20px;display:block;}
.faq-ans-q{font-size:17px;font-weight:700;color:white;line-height:1.45;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1);}
.faq-ans-text{font-size:15px;color:rgba(255,255,255,.6);line-height:1.8;}
.faq-ans-text strong{color:white;font-weight:600;}
.faq-ans-cta{margin-top:32px;}
.faq-ans-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:rgba(221,143,24,.15);border-radius:100px;font-size:10px;font-weight:700;color:var(--amber);letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;}
@keyframes fadeSlot{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.faq-answer-slot.active{animation:fadeSlot 250ms ease;}
@media (max-width:1024px){
  .faq-layout{grid-template-columns:1fr;}
  .faq-questions{border-bottom:1px solid var(--gray-200);}
  .faq-answer-panel{padding:32px 28px;min-height:auto;}
}

/* CTA FINAL */
.page-cta{padding:clamp(72px,9vw,120px) 0;background:var(--navy);color:white;text-align:center;position:relative;overflow:hidden;}
.page-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(221,143,24,.15) 0%,transparent 55%);pointer-events:none;}
.page-cta-inner{position:relative;max-width:680px;margin:0 auto;padding:0 clamp(24px,4.5vw,72px);}
.page-cta h2{color:white;margin-bottom:18px;}
.page-cta p{font-size:17px;color:rgba(255,255,255,.65);margin-bottom:32px;line-height:1.65;}
.page-cta-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;}
.page-cta-reassurance{margin-top:24px;display:flex;align-items:center;justify-content:center;gap:14px;font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.03em;flex-wrap:wrap;}
.page-cta-dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.3);}

/* RELATED PILLARS (footer-like links to other terrains) */
/* CTA CALLOUT BLOC (encart navy avec texte + bouton, reutilisable) */
.sim-cta-block{background:var(--navy);border-radius:var(--radius-xl);padding:40px;display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:48px;}
.sim-cta-text p{font-size:18px;font-weight:700;color:white;margin-bottom:6px;}
.sim-cta-text span{font-size:14px;color:rgba(255,255,255,.55);line-height:1.5;}
@media(max-width:768px){.sim-cta-block{flex-direction:column;padding:32px;text-align:center;}}

.related-pillars{background:var(--gray-50);padding:64px 0;}
.related-pillars-header{margin-bottom:32px;}
.related-pillars-label{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-bottom:8px;}
.related-pillars-title{font-size:22px;font-weight:700;color:var(--navy);letter-spacing:-.3px;}
.related-pillars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.related-pillar-card{background:white;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px;transition:border-color 250ms,transform 250ms;}
.related-pillar-card:hover{border-color:rgba(221,143,24,.4);transform:translateY(-2px);}
.related-pillar-tag{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-bottom:6px;}
.related-pillar-name{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:6px;letter-spacing:-.2px;}
.related-pillar-desc{font-size:13px;color:var(--gray-600);line-height:1.5;}
@media(max-width:900px){.related-pillars-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:500px){.related-pillars-grid{grid-template-columns:1fr;}}

/* ============================================================
   CASE STUDY (pages cas-*.html) - styles partages
   ============================================================ */
/* Case study specific */
.case-header{background:var(--navy);color:white;padding:calc(var(--nav-h) + 60px) 0 80px;position:relative;overflow:hidden;}
.case-header::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(221,143,24,.12) 0%,transparent 60%);pointer-events:none;}
.case-header-grid-bg{position:absolute;inset:0;pointer-events:none;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:5px 5px;}
.case-header .container{position:relative;z-index:2;}
.case-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);}
.case-meta span{padding:4px 12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:100px;}
.case-meta span.amber{color:var(--amber);border-color:rgba(221,143,24,.3);background:rgba(221,143,24,.08);}
.case-header h1{color:white;font-size:clamp(36px,4.2vw,56px);font-weight:800;letter-spacing:-1.5px;line-height:1.08;margin-bottom:18px;}
.case-header h1 em{color:var(--amber);font-style:normal;}
.case-intro{font-size:18px;line-height:1.7;color:rgba(255,255,255,.7);max-width:780px;margin-bottom:24px;}
.case-disclaimer{padding:16px 20px;background:rgba(221,143,24,.06);border:1px solid rgba(221,143,24,.15);border-radius:var(--radius-md);font-size:13px;color:rgba(255,255,255,.6);line-height:1.6;max-width:780px;}
.case-disclaimer strong{color:var(--amber);}

.case-section{padding:64px 0;}
.case-section-header{max-width:760px;margin-bottom:32px;}
.case-section-header h2{margin-bottom:14px;letter-spacing:-1.5px;font-weight:800;line-height:1.1;}
.case-section-header p:not(.section-label){font-size:17px;color:var(--gray-600);line-height:1.65;}
.case-body{max-width:780px;}
.case-body p{font-size:16px;color:var(--gray-800);line-height:1.75;margin-bottom:18px;}
.case-body p strong{color:var(--navy);font-weight:600;}
.case-body p em{color:var(--gray-600);}

.case-pullquote{padding:32px;background:var(--gray-50);border-left:3px solid var(--amber);margin:32px 0;font-size:18px;line-height:1.6;color:var(--navy);font-style:italic;}
.case-pullquote::before{content:'\201C';font-size:48px;color:var(--amber);line-height:0;vertical-align:-18px;margin-right:8px;font-family:serif;}

.case-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:40px 0;}
.case-stat{padding:24px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);text-align:center;}
.case-stat-val{font-size:32px;font-weight:800;color:var(--navy);letter-spacing:-1px;line-height:1;margin-bottom:6px;}
.case-stat-val.amber{color:var(--amber);}
.case-stat-lbl{font-size:12px;font-weight:600;color:var(--gray-600);letter-spacing:.04em;text-transform:uppercase;}
@media(max-width:768px){.case-stats-row{grid-template-columns:1fr;}}

.lessons-list{display:flex;flex-direction:column;gap:0;}
.lesson-row{display:grid;grid-template-columns:48px 1fr;gap:24px;padding:24px 0;border-top:1px solid var(--gray-100);align-items:flex-start;}
.lesson-row:last-child{border-bottom:1px solid var(--gray-100);}
.lesson-num{font-size:18px;font-weight:800;color:var(--amber);letter-spacing:-.3px;}
.lesson-title{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:6px;letter-spacing:-.2px;}
.lesson-desc{font-size:15px;color:var(--gray-600);line-height:1.7;}

/* Note de transparence en tooltip discret declenche au survol/clic */
.case-disclaimer{padding:14px 0 0;border-top:1px solid rgba(255,255,255,.08);margin-top:8px;font-size:12px;color:rgba(255,255,255,.45);line-height:1.6;max-width:780px;}
.amber-dot{color:var(--amber);}
.case-disclaimer-toggle{margin-top:18px;max-width:780px;}
.case-disclaimer-toggle summary{display:inline-flex;align-items:center;gap:6px;cursor:pointer;list-style:none;font-size:12px;font-weight:500;color:rgba(255,255,255,.5);letter-spacing:.02em;padding:6px 10px;border:1px solid rgba(255,255,255,.12);border-radius:100px;background:rgba(255,255,255,.03);transition:all .2s ease;}
.case-disclaimer-toggle summary::-webkit-details-marker{display:none;}
.case-disclaimer-toggle summary:hover{color:rgba(255,255,255,.75);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.06);}
.case-disclaimer-toggle summary::before{content:'i';display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.15);color:white;font-size:9px;font-weight:700;font-style:italic;font-family:Georgia,serif;}
.case-disclaimer-toggle[open] summary{color:rgba(255,255,255,.75);}
.case-disclaimer-content{margin-top:12px;padding:14px 16px;background:rgba(255,255,255,.04);border-left:2px solid rgba(221,143,24,.4);border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:12px;color:rgba(255,255,255,.6);line-height:1.6;}
.case-disclaimer-content strong{color:rgba(221,143,24,.85);}

/* ============================================================
   RESSOURCES - hub principal et pages categories
   ============================================================ */

/* Hero ressources, plus leger que page-hero */
.ressources-hero{padding-top:calc(var(--nav-h) + 60px);padding-bottom:60px;background:#fafbfc;position:relative;overflow:hidden;}
.ressources-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:200px;background:linear-gradient(to bottom,rgba(221,143,24,.04) 0%,transparent 100%);pointer-events:none;}
.ressources-hero-grid-bg{position:absolute;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(19,23,62,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(19,23,62,.032) 1px,transparent 1px);background-size:5px 5px;mask-image:linear-gradient(to bottom,black 0%,black 60%,transparent 95%);-webkit-mask-image:linear-gradient(to bottom,black 0%,black 60%,transparent 95%);}
.ressources-hero .container{position:relative;z-index:2;}
.ressources-hero-inner{max-width:820px;}
.ressources-hero h1{margin-bottom:20px;letter-spacing:-1.5px;}
.ressources-hero-sub{font-size:17px;line-height:1.7;color:var(--gray-600);margin-bottom:28px;max-width:720px;}
.ressources-hero-stats{display:flex;flex-wrap:wrap;gap:24px;align-items:center;font-size:13px;color:var(--gray-600);}
.ressources-hero-stat{display:inline-flex;align-items:center;gap:8px;}
.ressources-hero-stat strong{color:var(--navy);font-weight:700;font-size:15px;}
.ressources-hero-stat-dot{width:3px;height:3px;border-radius:50%;background:var(--gray-400);}

/* Grille categories */
.ressources-cats{padding:64px 0;background:white;}
.ressources-cats-header{margin-bottom:48px;max-width:760px;}
.ressources-cats-header h2,.ressources-featured-header h2,.ressources-articles-header-text h2{margin-bottom:16px;letter-spacing:-1.5px;font-weight:800;line-height:1.1;}
.ressources-cats-header p:not(.section-label),.ressources-featured-header p:not(.section-label),.ressources-articles-header-text p:not(.section-label){font-size:18px;color:var(--gray-600);line-height:1.65;}
.ressources-cats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.ressources-cat-card{display:flex;flex-direction:column;gap:12px;padding:28px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-xl);transition:border-color 250ms cubic-bezier(.22,1,.36,1),transform 250ms cubic-bezier(.22,1,.36,1),box-shadow 250ms cubic-bezier(.22,1,.36,1);position:relative;}
.ressources-cat-card:hover{border-color:rgba(221,143,24,.35);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.ressources-cat-card-icon{width:44px;height:44px;border-radius:12px;background:rgba(221,143,24,.12);color:var(--amber);display:flex;align-items:center;justify-content:center;margin-bottom:4px;}
.ressources-cat-card-name{font-size:19px;font-weight:800;color:var(--navy);letter-spacing:-.4px;line-height:1.2;}
.ressources-cat-card-desc{font-size:13.5px;color:var(--gray-600);line-height:1.6;margin-bottom:auto;}
.ressources-cat-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:14px;border-top:1px solid var(--gray-200);font-size:11.5px;color:var(--gray-400);letter-spacing:.04em;}
.ressources-cat-card-meta strong{color:var(--navy);font-weight:700;}
.ressources-cat-card-arrow{color:var(--gray-400);transition:color 200ms ease,transform 200ms ease;flex-shrink:0;}
.ressources-cat-card:hover .ressources-cat-card-arrow{color:var(--amber);transform:translateX(3px);}
@media(max-width:1100px){.ressources-cats-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.ressources-cats-grid{grid-template-columns:1fr;}}

/* Featured article - bandeau editorial full-width */
.ressources-featured{padding:64px 0;background:var(--gray-50);}
.ressources-featured-header{margin-bottom:40px;max-width:760px;}
.ressources-featured-card{display:flex;flex-direction:column;gap:18px;background:linear-gradient(135deg,var(--navy) 0%,#1e2451 100%);color:white;padding:clamp(40px,5vw,64px) clamp(28px,4vw,56px);border-radius:var(--radius-xl);position:relative;overflow:hidden;text-decoration:none;transition:transform 250ms cubic-bezier(.22,1,.36,1),box-shadow 250ms cubic-bezier(.22,1,.36,1);}
.ressources-featured-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 95% 5%,rgba(221,143,24,.22) 0%,transparent 55%);pointer-events:none;}
.ressources-featured-card::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:6px 6px;pointer-events:none;mask-image:linear-gradient(to bottom,black 0%,transparent 80%);-webkit-mask-image:linear-gradient(to bottom,black 0%,transparent 80%);}
.ressources-featured-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.ressources-featured-card > *{position:relative;z-index:1;}
.ressources-featured-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);}
.ressources-featured-meta-cat{color:var(--amber);padding:5px 12px;background:rgba(221,143,24,.15);border:1px solid rgba(221,143,24,.3);border-radius:100px;}
.ressources-featured-meta-dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.35);}
.ressources-featured-title{font-size:clamp(28px,3.5vw,44px);font-weight:800;color:white;letter-spacing:-1.2px;line-height:1.1;max-width:820px;margin:4px 0 0;}
.ressources-featured-dek{font-size:17px;color:rgba(255,255,255,.7);line-height:1.65;max-width:720px;}
.ressources-featured-cta{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;font-weight:700;color:var(--amber);margin-top:12px;transition:gap 200ms ease;letter-spacing:-.1px;}
.ressources-featured-card:hover .ressources-featured-cta{gap:14px;}

/* Articles listing */
.ressources-articles{padding:64px 0;background:white;}
.ressources-articles-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:32px;gap:24px;flex-wrap:wrap;}
.ressources-articles-header-text h2{letter-spacing:-1px;margin-bottom:8px;}
.ressources-articles-header-text p{font-size:15px;color:var(--gray-600);line-height:1.65;}
.ressources-articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.ressources-article-card{display:flex;flex-direction:column;gap:12px;padding:24px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-xl);transition:border-color 250ms,transform 250ms,box-shadow 250ms;position:relative;text-decoration:none;}
.ressources-article-card:hover{border-color:rgba(221,143,24,.35);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.ressources-article-card-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-400);margin-bottom:4px;}
.ressources-article-card-cat{color:var(--amber);}
.ressources-article-card-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--gray-400);}
.ressources-article-card-title{font-size:17px;font-weight:800;color:var(--navy);letter-spacing:-.4px;line-height:1.3;margin:0;}
.ressources-article-card-dek{font-size:13.5px;color:var(--gray-600);line-height:1.6;margin-bottom:auto;}
.ressources-article-card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:14px;border-top:1px solid var(--gray-200);font-size:12px;color:var(--gray-600);}
.ressources-article-card-arrow{color:var(--gray-400);transition:color 200ms ease,transform 200ms ease;flex-shrink:0;}
.ressources-article-card:hover .ressources-article-card-arrow{color:var(--amber);transform:translateX(3px);}
.ressources-article-card.is-empty{opacity:.5;cursor:default;pointer-events:none;}
.ressources-article-card-soon{font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-400);background:white;border:1px solid var(--gray-200);padding:3px 8px;border-radius:100px;}
@media(max-width:900px){.ressources-articles-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.ressources-articles-grid{grid-template-columns:1fr;}}

/* Newsletter inline block */
.ressources-newsletter{background:var(--navy);color:white;padding:48px;border-radius:var(--radius-xl);margin:48px 0 0;position:relative;overflow:hidden;}
.ressources-newsletter::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 90% 20%,rgba(221,143,24,.18) 0%,transparent 60%);pointer-events:none;}
.ressources-newsletter-inner{position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:center;}
.ressources-newsletter-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-bottom:14px;padding:5px 12px;background:rgba(221,143,24,.12);border:1px solid rgba(221,143,24,.25);border-radius:100px;}
.ressources-newsletter-title{font-size:clamp(22px,2.2vw,28px);font-weight:800;letter-spacing:-.6px;line-height:1.2;margin-bottom:12px;color:white;}
.ressources-newsletter-desc{font-size:15px;color:rgba(255,255,255,.7);line-height:1.65;max-width:480px;}
.ressources-newsletter-cta-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:12px;}
.ressources-newsletter-cta{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;background:var(--amber);color:#FAFBFC;font-size:14px;font-weight:700;border-radius:var(--btn-radius);text-decoration:none;transition:transform 200ms ease,box-shadow 200ms ease;}
.ressources-newsletter-cta:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(221,143,24,.4);}
.ressources-newsletter-note{font-size:12px;color:rgba(255,255,255,.45);}
@media(max-width:900px){.ressources-newsletter{padding:40px 32px;}.ressources-newsletter-inner{grid-template-columns:1fr;gap:20px;}}

/* Autres categories block - pages categorie */
.ressources-other-cats{background:var(--gray-50);padding:56px 0;border-top:1px solid var(--gray-200);}
.ressources-other-cats-header{margin-bottom:24px;display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:16px;}
.ressources-other-cats-label{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);}
.ressources-other-cats-title{font-size:20px;font-weight:700;color:var(--navy);letter-spacing:-.3px;}
.ressources-other-cats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.ressources-other-cat-pill{display:flex;align-items:center;gap:14px;padding:18px 22px;background:white;border:1px solid var(--gray-200);border-radius:var(--radius-lg);transition:border-color 200ms,transform 200ms,box-shadow 200ms;text-decoration:none;}
.ressources-other-cat-pill:hover{border-color:rgba(221,143,24,.35);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.ressources-other-cat-pill-icon{width:36px;height:36px;border-radius:10px;background:rgba(221,143,24,.1);color:var(--amber);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ressources-other-cat-pill-text{flex:1;min-width:0;}
.ressources-other-cat-pill-name{font-size:14px;font-weight:700;color:var(--navy);letter-spacing:-.2px;line-height:1.2;margin-bottom:2px;}
.ressources-other-cat-pill-meta{font-size:11.5px;color:var(--gray-400);letter-spacing:.04em;}
.ressources-other-cat-pill-arrow{color:var(--gray-400);flex-shrink:0;transition:color 200ms,transform 200ms;}
.ressources-other-cat-pill:hover .ressources-other-cat-pill-arrow{color:var(--amber);transform:translateX(2px);}
@media(max-width:900px){.ressources-other-cats-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.ressources-other-cats-grid{grid-template-columns:1fr;}}

/* ============================================================
   ARTICLE PAGE - hero, prose, TOC, FAQ, sources, related
   ============================================================ */

/* Hero article */
.article-hero{padding-top:calc(var(--nav-h) + 40px);padding-bottom:48px;background:#fafbfc;position:relative;overflow:hidden;}
.article-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:200px;background:linear-gradient(to bottom,rgba(221,143,24,.04) 0%,transparent 100%);pointer-events:none;}
.article-hero-grid-bg{position:absolute;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(19,23,62,.028) 1px,transparent 1px),linear-gradient(90deg,rgba(19,23,62,.028) 1px,transparent 1px);background-size:5px 5px;mask-image:linear-gradient(to bottom,black 0%,black 60%,transparent 95%);-webkit-mask-image:linear-gradient(to bottom,black 0%,black 60%,transparent 95%);}
.article-hero .container{position:relative;z-index:2;}
.article-hero-inner{max-width:820px;}
.article-hero-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:24px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-400);}
.article-hero-meta-cat{color:var(--amber);padding:5px 12px;background:rgba(221,143,24,.08);border:1px solid rgba(221,143,24,.2);border-radius:100px;}
.article-hero-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--gray-400);}
.article-hero h1{font-size:clamp(30px,3.4vw,46px);margin-bottom:24px;letter-spacing:-1.4px;line-height:1.1;}
.article-hero-dek{font-size:18px;line-height:1.65;color:var(--gray-600);margin-bottom:28px;max-width:780px;}
.article-hero-author{display:flex;align-items:center;gap:12px;padding-top:24px;border-top:1px solid var(--gray-200);}
.article-hero-author-mark{width:36px;height:36px;border-radius:10px;background:var(--navy);color:#FAFBFC;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;letter-spacing:-.025em;flex-shrink:0;}
.article-hero-author-mark .dot{color:var(--amber);margin-left:-1px;}
.article-hero-author-info{font-size:13px;color:var(--gray-600);line-height:1.4;}
.article-hero-author-info strong{color:var(--navy);font-weight:700;display:block;}

/* Body layout TOC + content */
.article-body{padding:48px 0 64px;background:white;}
.article-body-grid{display:grid;grid-template-columns:220px minmax(0,1fr);gap:56px;align-items:start;}
.article-toc{position:sticky;top:calc(var(--nav-h) + 16px);max-height:calc(100vh - var(--nav-h) - 48px);overflow-y:auto;padding:8px 0 24px;}
.article-toc-label{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-bottom:14px;}
.article-toc-list{display:flex;flex-direction:column;gap:2px;list-style:none;padding:0;margin:0;}
.article-toc-list li::before{display:none;}
.article-toc-link{font-size:13px;color:var(--gray-600);text-decoration:none;line-height:1.4;padding:7px 0 7px 14px;display:block;border-left:2px solid transparent;margin-left:-14px;transition:color 200ms,border-color 200ms,background 200ms;}
.article-toc-link:hover{color:var(--navy);border-left-color:var(--gray-200);}
.article-toc-link.is-active{color:var(--navy);font-weight:700;border-left-color:var(--amber);}
@media(max-width:900px){.article-body-grid{grid-template-columns:1fr;gap:24px;}.article-toc{position:static;max-height:none;padding:20px 24px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);}.article-toc-label{margin-bottom:10px;}}

/* TL;DR encart */
.article-tldr{padding:28px 32px;background:var(--gray-50);border:1px solid var(--gray-200);border-left:3px solid var(--amber);border-radius:0 var(--radius-lg) var(--radius-lg) 0;margin:0 0 40px;}
.article-tldr-label{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-bottom:14px;}
.article-tldr-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.article-tldr-list li{font-size:14.5px;color:var(--gray-800);line-height:1.6;padding-left:20px;position:relative;}
.article-tldr-list li::before{content:'';position:absolute;left:0;top:10px;width:10px;height:2px;background:var(--amber);}

/* Prose body */
.article-content{max-width:760px;}
.article-prose{font-size:16.5px;line-height:1.75;color:var(--gray-800);}
.article-prose > * + *{margin-top:18px;}
.article-prose h2{font-size:clamp(24px,2.4vw,32px);font-weight:800;color:var(--navy);letter-spacing:-.8px;line-height:1.2;margin-top:56px;margin-bottom:18px;scroll-margin-top:calc(var(--nav-h) + 24px);}
.article-prose h2:first-child{margin-top:0;}
.article-prose h3{font-size:19px;font-weight:700;color:var(--navy);letter-spacing:-.3px;line-height:1.3;margin-top:32px;margin-bottom:10px;scroll-margin-top:calc(var(--nav-h) + 24px);}
.article-prose h3 + p{margin-top:10px;}
.article-prose p strong{color:var(--navy);font-weight:600;}
.article-prose p em{color:var(--navy);font-style:italic;}
.article-prose ul,.article-prose ol{padding:0;}
.article-prose ul{list-style:none;}
.article-prose ul > li{padding-left:24px;position:relative;}
.article-prose ul > li::before{content:'';position:absolute;left:0;top:13px;width:10px;height:2px;background:var(--amber);}
.article-prose ol{padding-left:24px;}
.article-prose ol > li{padding-left:6px;}
.article-prose ul li + li,.article-prose ol li + li{margin-top:8px;}
.article-prose ul li > strong:first-child,.article-prose ol li > strong:first-child{color:var(--navy);}

/* Tables */
.article-prose-table-wrap{overflow-x:auto;margin:28px 0;border-radius:var(--radius-lg);border:1px solid var(--gray-200);background:white;}
.article-prose table{width:100%;border-collapse:collapse;font-size:14px;background:white;margin:0;}
.article-prose table thead th{background:var(--gray-50);color:var(--navy);font-weight:700;text-align:left;padding:14px 18px;border-bottom:1px solid var(--gray-200);font-size:12.5px;letter-spacing:.02em;text-transform:uppercase;}
.article-prose table tbody td{padding:14px 18px;border-bottom:1px solid var(--gray-100);color:var(--gray-800);font-size:14px;line-height:1.55;}
.article-prose table tbody td:first-child{font-weight:600;color:var(--navy);}
.article-prose table tbody tr:last-child td{border-bottom:none;}
.article-prose table tbody tr:hover{background:var(--gray-50);}

/* Pullquote */
.article-prose blockquote{padding:24px 28px;background:var(--gray-50);border-left:3px solid var(--amber);border-radius:0 var(--radius-lg) var(--radius-lg) 0;margin:32px 0;font-size:17px;line-height:1.65;color:var(--navy);}
.article-prose blockquote p{margin:0;}
.article-prose blockquote em,.article-prose blockquote strong{color:var(--navy);}

/* Hero quote (after H1 dek) */
.article-hero-quote{padding:20px 24px;background:rgba(221,143,24,.06);border-left:3px solid var(--amber);border-radius:0 var(--radius-lg) var(--radius-lg) 0;margin:24px 0 0;font-size:17px;font-weight:500;line-height:1.6;color:var(--navy);max-width:780px;}
.article-hero-quote p{margin:0;}

/* Inline CTA */
.article-inline-cta{padding:32px;background:var(--navy);color:white;border-radius:var(--radius-xl);margin:48px 0;position:relative;overflow:hidden;}
.article-inline-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 90% 20%,rgba(221,143,24,.2) 0%,transparent 60%);pointer-events:none;}
.article-inline-cta-inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.article-inline-cta-text{flex:1;min-width:260px;}
.article-inline-cta-label{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-bottom:10px;padding:4px 10px;background:rgba(221,143,24,.15);border:1px solid rgba(221,143,24,.25);border-radius:100px;}
.article-inline-cta-title{font-size:19px;font-weight:800;color:white;letter-spacing:-.4px;line-height:1.3;margin-bottom:6px;}
.article-inline-cta-desc{font-size:14px;color:rgba(255,255,255,.65);line-height:1.55;}
.article-inline-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 22px;background:var(--amber);color:#FAFBFC;font-size:14px;font-weight:700;border-radius:var(--btn-radius);text-decoration:none;flex-shrink:0;transition:transform 200ms,box-shadow 200ms;}
.article-inline-cta-btn:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(221,143,24,.4);}

/* Article footer (share + meta) */
.article-foot{margin-top:56px;padding:32px 0;border-top:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.article-foot-meta{font-size:13px;color:var(--gray-600);}
.article-foot-share{display:flex;align-items:center;gap:10px;}
.article-foot-share-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-400);}
.article-foot-share-btn{width:36px;height:36px;border-radius:10px;background:var(--gray-50);border:1px solid var(--gray-200);color:var(--gray-600);display:inline-flex;align-items:center;justify-content:center;transition:all 200ms;text-decoration:none;}
.article-foot-share-btn:hover{background:white;border-color:rgba(221,143,24,.4);color:var(--amber);}

/* Article FAQ - reuse .faq-layout */
.article-faq{padding:64px 0;background:var(--gray-50);}
.article-faq-header{margin-bottom:32px;max-width:720px;}
.article-faq-header h2{margin-bottom:12px;letter-spacing:-1px;}
.article-faq-header p{font-size:15px;color:var(--gray-600);line-height:1.65;}

/* Sources */
.article-sources{padding:48px 0;background:white;border-top:1px solid var(--gray-200);}
.article-sources-label{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-bottom:10px;}
.article-sources h2{font-size:22px;font-weight:800;color:var(--navy);letter-spacing:-.6px;margin-bottom:24px;}
.article-sources-list{display:flex;flex-direction:column;gap:10px;list-style:none;padding:0;}
.article-sources-list li{font-size:14px;color:var(--gray-600);line-height:1.5;padding-left:0;}
.article-sources-list li::before{display:none;}
.article-sources-list a{color:var(--navy);text-decoration:underline;text-decoration-color:rgba(221,143,24,.4);text-underline-offset:3px;transition:text-decoration-color 200ms,color 200ms;}
.article-sources-list a:hover{color:var(--amber);text-decoration-color:var(--amber);}

/* Figure / SVG inline dans l'article */
.article-figure{margin:32px 0;padding:24px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);}
.article-figure svg{display:block;width:100%;height:auto;max-width:100%;}
.article-figure figcaption{margin-top:14px;padding-top:14px;border-top:1px solid var(--gray-200);font-size:12.5px;color:var(--gray-600);line-height:1.55;font-style:italic;}
.article-figure figcaption strong{color:var(--navy);font-weight:600;font-style:normal;}

/* Related articles */
.article-related{padding:64px 0;background:var(--gray-50);}
.article-related-header{margin-bottom:24px;}
.article-related-header h2{font-size:24px;font-weight:800;letter-spacing:-.6px;color:var(--navy);}
.article-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media(max-width:900px){.article-related-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.article-related-grid{grid-template-columns:1fr;}}
