/* =============================================
   JOSHUA NKOMBE — FORCE NATIONALE
   Shared Stylesheet
   ============================================= */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}

:root{
  --green:#00BC70;
  --green-dark:#009959;
  --green-pale:#e8f8f1;
  --green-light:#c8edd9;
  --dark:#0f1f16;
  --dark2:#1a3025;
  --white:#ffffff;
  --off:#f5f9f7;
  --gray:#5a7a6a;
  --gray-light:#9ab5a5;
  --text:#1a2e24;
  --font-h:'Cormorant Garamond',Georgia,serif;
  --font-b:'Inter',-apple-system,sans-serif;
  --nav-h:68px;
  --sub-h:46px;
}

html{scroll-behavior:smooth;background:var(--white);}
body{font-family:var(--font-b);color:var(--text);overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img,video{display:block;max-width:100%;}

/* ---- LANGUAGE ---- */
html.lang-fr .lang-en{display:none!important;}
html.lang-en .lang-fr{display:none!important;}
html:not(.lang-en) .lang-en{display:none!important;}

/* ---- HEADER ---- */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  transition:background .35s,box-shadow .35s;
}
.site-header.scrolled{
  background:rgba(255,255,255,.97);
  box-shadow:0 1px 0 rgba(0,0,0,.08),0 4px 24px rgba(0,0,0,.06);
}
.site-header.solid{
  background:rgba(255,255,255,.97);
  box-shadow:0 1px 0 rgba(0,0,0,.08),0 4px 24px rgba(0,0,0,.06);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;height:var(--nav-h);max-width:1600px;margin:0 auto;
}
.menu-btn,.search-btn{
  background:none;border:none;cursor:pointer;
  color:var(--white);display:flex;align-items:center;gap:9px;
  font-family:var(--font-b);font-size:.68rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  transition:color .3s,opacity .2s;opacity:.9;
}
.menu-btn:hover,.search-btn:hover{opacity:1;}
.site-header.scrolled .menu-btn,
.site-header.scrolled .search-btn,
.site-header.solid .menu-btn,
.site-header.solid .search-btn{color:var(--dark);}
.site-header.scrolled .menu-icon span,
.site-header.solid .menu-icon span{background:var(--green);}
.menu-icon{width:22px;height:13px;display:flex;flex-direction:column;justify-content:space-between;}
.menu-icon span{display:block;height:1.5px;background:var(--white);border-radius:2px;transition:background .3s;}
.logo-wrap{text-align:center;line-height:1;cursor:pointer;}
.logo-name{
  font-family:var(--font-h);font-size:1.3rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--white);
  transition:color .3s;
}
.site-header.scrolled .logo-name,
.site-header.solid .logo-name{color:var(--dark);}
.logo-sub{
  font-size:.52rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--green);margin-top:4px;font-weight:600;
}
.header-right{display:flex;align-items:center;gap:20px;}
.lang-sw{
  display:flex;align-items:center;
  background:rgba(255,255,255,.15);border-radius:4px;padding:2px;gap:1px;
  transition:background .3s;
}
.site-header.scrolled .lang-sw,
.site-header.solid .lang-sw{background:rgba(0,188,112,.1);}
.lang-btn{
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.55);font-size:.63rem;font-weight:700;
  letter-spacing:.12em;padding:5px 10px;border-radius:3px;transition:all .2s;
}
.site-header.scrolled .lang-btn,
.site-header.solid .lang-btn{color:var(--gray);}
.lang-btn.active{background:var(--green)!important;color:#fff!important;opacity:1;}

/* ---- SUB-NAV ---- */
.sub-nav{
  position:fixed;top:var(--nav-h);left:0;width:100%;z-index:999;
  background:transparent;
  border-bottom:1px solid rgba(255,255,255,.15);
  overflow-x:auto;scrollbar-width:none;
  transition:background .35s,border-color .35s;
}
.sub-nav.scrolled,.sub-nav.solid{
  background:rgba(255,255,255,.97);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,0,0,.07);
}
.sub-nav::-webkit-scrollbar{display:none;}
.sub-nav-inner{
  display:flex;align-items:center;justify-content:center;padding:0 40px;
  max-width:1600px;margin:0 auto;white-space:nowrap;
}
.sub-nav a{
  font-size:.63rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.7);padding:0 16px;height:var(--sub-h);
  display:flex;align-items:center;
  border-bottom:2px solid transparent;transition:color .2s,border-color .2s;
}
.sub-nav a:hover{color:var(--white);}
.sub-nav a.active{color:var(--green);border-bottom-color:var(--green);}
.sub-nav.scrolled a,.sub-nav.solid a{color:rgba(26,46,36,.5);}
.sub-nav.scrolled a:hover,.sub-nav.solid a:hover{color:var(--dark);}
.sub-nav.scrolled a.active,.sub-nav.solid a.active{color:var(--green);border-bottom-color:var(--green);}

/* ---- HERO FULL (home) ---- */
.hero-full{
  position:relative;width:100%;height:100vh;min-height:640px;
  display:flex;align-items:flex-end;overflow:hidden;
}
.hero-full .hero-bg{position:absolute;inset:0;z-index:0;background:#050e09;}
.hero-full .hero-bg img,
.hero-full .hero-bg video{width:100%;height:100%;object-fit:cover;opacity:.55;}
.hero-full .hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(5,14,9,.97) 0%,rgba(5,14,9,.6) 35%,rgba(5,14,9,.15) 70%,transparent 100%);
}
.hero-full .hero-content{
  position:relative;z-index:2;
  padding:0 72px 88px;max-width:860px;
}

/* ---- HERO INNER PAGES ---- */
.hero-inner{
  position:relative;width:100%;height:58vh;min-height:420px;
  display:flex;align-items:flex-end;overflow:hidden;
  padding-top:calc(var(--nav-h) + var(--sub-h));
}
.hero-inner .hero-bg{position:absolute;inset:0;z-index:0;background:#050e09;}
.hero-inner .hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.45;}
.hero-inner .hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(5,14,9,.92) 0%,rgba(5,14,9,.55) 45%,rgba(5,14,9,.1) 100%);
}
.hero-inner .hero-content{
  position:relative;z-index:2;
  padding:0 72px 64px;max-width:820px;
}

/* ---- HERO SHARED ELEMENTS ---- */
.hero-eyebrow{
  font-size:.62rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;
  color:var(--green);margin-bottom:22px;
  display:flex;align-items:center;gap:14px;
}
.hero-eyebrow::before{content:'';width:36px;height:1px;background:var(--green);}
.hero-title{
  font-family:var(--font-h);
  font-size:clamp(3rem,6vw,5.8rem);
  font-weight:300;line-height:1.04;letter-spacing:.03em;
  color:var(--white);margin-bottom:24px;
}
.hero-title em{color:var(--green);font-style:italic;}
.hero-desc{
  font-size:.95rem;line-height:1.75;
  color:rgba(255,255,255,.65);max-width:560px;margin-bottom:36px;
}
.hero-author-name{
  font-family:var(--font-h);font-size:1.5rem;font-weight:600;
  letter-spacing:.06em;color:var(--white);
}
.hero-author-role{
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--green);font-weight:600;margin-top:5px;
}
.hero-btns{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:36px;}
.hero-scroll-hint{
  position:absolute;bottom:36px;right:72px;z-index:2;
  display:flex;align-items:center;gap:10px;
  font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.35);
}
.hero-scroll-hint::after{content:'';width:36px;height:1px;background:rgba(255,255,255,.2);}

/* ---- BUTTONS ---- */
.btn-green{
  background:var(--green);color:#fff;border:none;cursor:pointer;
  font-family:var(--font-b);font-size:.7rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  padding:15px 36px;transition:background .2s,transform .15s;
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
  display:inline-block;
}
.btn-green:hover{background:var(--green-dark);transform:translateY(-1px);}
.btn-ghost{
  background:none;color:var(--white);border:1px solid rgba(255,255,255,.3);
  cursor:pointer;font-family:var(--font-b);font-size:.7rem;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;padding:14px 34px;
  transition:border-color .2s,color .2s;display:inline-block;
}
.btn-ghost:hover{border-color:var(--green);color:var(--green);}
.btn-dark{
  background:var(--dark);color:#fff;border:none;cursor:pointer;
  font-family:var(--font-b);font-size:.7rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  padding:14px 32px;transition:background .2s;display:inline-block;
}
.btn-dark:hover{background:var(--dark2);}
.btn-outline-green{
  background:none;color:var(--green);border:1.5px solid var(--green);
  cursor:pointer;font-family:var(--font-b);font-size:.68rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;padding:11px 26px;
  transition:background .2s,color .2s;display:inline-block;
}
.btn-outline-green:hover{background:var(--green);color:#fff;}

/* ---- SECTION WRAPPER ---- */
.section-wrap{max-width:1400px;margin:0 auto;padding:0 72px;}
.section-wrap-sm{max-width:960px;margin:0 auto;padding:0 72px;}
.section-tag{
  font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--green);margin-bottom:18px;
  display:flex;align-items:center;gap:12px;
}
.section-tag::before{content:'';width:28px;height:1px;background:var(--green);}

/* ---- QUOTE / STATS SECTION ---- */
.quote-section{
  padding:100px 0;background:var(--white);
}
.quote-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:center;
}
.big-quote{
  font-family:var(--font-h);font-size:clamp(1.9rem,3.2vw,2.9rem);
  font-weight:400;line-height:1.3;color:var(--dark);
  border-left:3px solid var(--green);padding-left:36px;
}
.big-quote em{color:var(--green);font-style:italic;}
.stats-list{display:flex;flex-direction:column;gap:32px;}
.stat-item{display:flex;align-items:flex-start;gap:24px;}
.stat-num{
  font-family:var(--font-h);font-size:3.2rem;font-weight:300;
  color:var(--green);line-height:1;min-width:100px;
}
.stat-label{font-size:.85rem;line-height:1.6;color:var(--gray);}
.stat-label strong{display:block;color:var(--dark);font-weight:600;margin-bottom:4px;font-size:.92rem;}

/* ---- PRIORITY SECTIONS (home) ---- */
.priority-section{
  position:relative;min-height:90vh;
  display:flex;align-items:center;overflow:hidden;
}
.priority-section .bg{position:absolute;inset:0;z-index:0;}
.priority-section .bg img{width:100%;height:100%;object-fit:cover;}
.priority-section .overlay{
  position:absolute;inset:0;z-index:1;
  background:rgba(5,14,9,.72);
}
.priority-section .content{
  position:relative;z-index:2;
  max-width:1400px;margin:0 auto;padding:100px 72px;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.priority-section.reverse .content{direction:rtl;}
.priority-section.reverse .content>*{direction:ltr;}
.priority-num{
  font-family:var(--font-h);font-size:8rem;font-weight:300;
  color:rgba(0,188,112,.12);line-height:1;margin-bottom:-20px;
}
.priority-label{
  font-size:.6rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;
  color:var(--green);margin-bottom:20px;
  display:flex;align-items:center;gap:10px;
}
.priority-label::before{content:'';width:24px;height:1px;background:var(--green);}
.priority-title{
  font-family:var(--font-h);font-size:clamp(2.4rem,4.5vw,4rem);
  font-weight:300;line-height:1.1;color:var(--white);margin-bottom:28px;
}
.priority-title em{color:var(--green);font-style:italic;}
.priority-text{font-size:.93rem;line-height:1.8;color:rgba(255,255,255,.7);margin-bottom:36px;}
.priority-visual{
  position:relative;overflow:hidden;
  aspect-ratio:4/3;
}
.priority-visual img{width:100%;height:100%;object-fit:cover;}
.priority-visual::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,rgba(0,188,112,.15),transparent);
  pointer-events:none;
}

/* ---- NEWS SECTION ---- */
.news-section{padding:100px 0;background:var(--off);}
.news-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:56px;
}
.news-title{
  font-family:var(--font-h);font-size:clamp(2.2rem,3.5vw,3.2rem);
  font-weight:300;color:var(--dark);
}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.news-card{background:var(--white);cursor:pointer;transition:transform .25s,box-shadow .25s;}
.news-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.1);}
.news-card-img{aspect-ratio:16/10;overflow:hidden;}
.news-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.news-card:hover .news-card-img img{transform:scale(1.04);}
.news-card-body{padding:28px;}
.news-cat{
  font-size:.58rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--green);margin-bottom:12px;
}
.news-card-title{
  font-family:var(--font-h);font-size:1.35rem;font-weight:500;
  line-height:1.3;color:var(--dark);margin-bottom:12px;
}
.news-card-excerpt{font-size:.82rem;line-height:1.65;color:var(--gray);}
.news-card-meta{
  padding:0 28px 20px;display:flex;align-items:center;
  justify-content:space-between;border-top:1px solid rgba(0,0,0,.05);
  margin-top:16px;padding-top:16px;
}
.news-date{font-size:.7rem;color:var(--gray-light);letter-spacing:.06em;}
.news-read-more{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green);}

/* ---- NEWSLETTER SECTION ---- */
.sec-eyebrow{
  font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--green);font-weight:700;margin-bottom:12px;display:block;
}
.sec-title{
  font-family:var(--font-h);font-size:clamp(2.1rem,4vw,3.3rem);
  font-weight:400;letter-spacing:.05em;text-transform:uppercase;color:var(--dark);
}
.newsletter{
  padding:100px 72px;background:var(--dark);
}
.nl-inner{max-width:680px;margin:0 auto;text-align:center;}
.nl-inner .sec-eyebrow{display:block;margin-bottom:12px;}
.nl-inner .sec-title{color:var(--white);margin-bottom:16px;}
.nl-sub{font-size:.88rem;color:rgba(255,255,255,.5);margin-bottom:40px;}
.nl-form{display:flex;max-width:500px;margin:0 auto;}
.nl-form input{
  flex:1;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);border-right:none;
  color:var(--white);padding:14px 20px;
  font-family:var(--font-b);font-size:.84rem;outline:none;
  transition:border-color .2s;
}
.nl-form input:focus{border-color:var(--green);}
.nl-form input::placeholder{color:rgba(255,255,255,.28);}
.nl-form button{
  background:var(--green);color:#fff;border:none;cursor:pointer;
  font-family:var(--font-b);font-size:.63rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  padding:14px 28px;white-space:nowrap;transition:background .2s;
}
.nl-form button:hover{background:var(--green-dark);}

/* ---- FOOTER ---- */
.site-footer{
  padding:80px 72px 40px;background:var(--off);
  border-top:1px solid rgba(0,0,0,.07);
}
.ft-grid{
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:56px;
  max-width:1400px;margin:0 auto 60px;
  padding-bottom:60px;border-bottom:1px solid rgba(0,0,0,.07);
}
.ft-logo-name{
  font-family:var(--font-h);font-size:1.1rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--dark);
}
.ft-logo-sub{
  font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--green);font-weight:600;margin-top:4px;margin-bottom:18px;
}
.ft-tagline{font-size:.82rem;line-height:1.75;color:var(--gray);max-width:270px;}
.ft-social{display:flex;gap:10px;margin-top:22px;}
.soc-btn{
  width:34px;height:34px;border:1px solid rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;color:var(--gray);transition:border-color .2s,color .2s;
  cursor:pointer;text-decoration:none;
}
.soc-btn:hover{border-color:var(--green);color:var(--green);}
.ft-col-title{
  font-size:.58rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--green);font-weight:700;margin-bottom:18px;
}
.ft-links{list-style:none;}
.ft-links li+li{margin-top:11px;}
.ft-links a{font-size:.8rem;color:var(--gray);transition:color .2s;}
.ft-links a:hover{color:var(--dark);}
.ft-bottom{
  display:flex;justify-content:space-between;align-items:center;
  max-width:1400px;margin:0 auto;
}
.ft-copy{font-size:.7rem;color:var(--gray-light);letter-spacing:.05em;}
.ft-legal{display:flex;gap:24px;}
.ft-legal a{font-size:.7rem;color:var(--gray-light);transition:color .2s;}
.ft-legal a:hover{color:var(--dark);}

/* ---- FLOATING BTN ---- */
.float-btn{
  position:fixed;bottom:28px;left:28px;z-index:900;
  display:flex;align-items:center;gap:10px;
  background:var(--green);color:#fff;border:none;cursor:pointer;
  font-family:var(--font-b);font-size:.63rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  padding:13px 22px 13px 18px;border-radius:2px;
  box-shadow:0 8px 32px rgba(0,188,112,.28);
  transition:background .2s,transform .2s,box-shadow .2s;
}
.float-btn:hover{background:var(--green-dark);transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,188,112,.38);}
.float-close{
  background:none;border:none;cursor:pointer;color:rgba(255,255,255,.6);
  font-size:.85rem;margin-left:6px;transition:color .2s;padding:0;
}
.float-close:hover{color:#fff;}

/* ---- ABOUT PAGE ---- */
.bio-section{padding:100px 0;background:var(--white);}
.bio-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;}
.bio-photo{position:relative;}
.bio-photo img{width:100%;object-fit:cover;}
.bio-photo-caption{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent,rgba(5,14,9,.85));
  padding:40px 28px 24px;
}
.bio-photo-name{font-family:var(--font-h);font-size:1.4rem;color:var(--white);font-weight:500;}
.bio-photo-role{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-top:5px;font-weight:600;}
.bio-text h2{
  font-family:var(--font-h);font-size:clamp(2rem,3vw,2.8rem);
  font-weight:300;line-height:1.2;color:var(--dark);margin-bottom:28px;
}
.bio-text h2 em{color:var(--green);font-style:italic;}
.bio-text p{font-size:.93rem;line-height:1.85;color:var(--gray);margin-bottom:20px;}
.bio-text p strong{color:var(--dark);}
.bio-values{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:40px;
}
.value-card{
  padding:28px;border:1px solid var(--green-light);
  background:var(--green-pale);
}
.value-icon{
  width:40px;height:40px;background:var(--green);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.value-icon svg{stroke:white;fill:none;width:20px;height:20px;}
.value-title{font-family:var(--font-h);font-size:1.15rem;color:var(--dark);font-weight:600;margin-bottom:8px;}
.value-text{font-size:.8rem;line-height:1.65;color:var(--gray);}

/* ---- TIMELINE ---- */
.timeline-section{padding:100px 0;background:var(--off);}
.timeline-title{
  font-family:var(--font-h);font-size:clamp(2rem,3vw,2.8rem);
  font-weight:300;color:var(--dark);margin-bottom:60px;
  text-align:center;
}
.timeline{position:relative;max-width:800px;margin:0 auto;}
.timeline::before{
  content:'';position:absolute;left:50%;top:0;bottom:0;
  width:1px;background:var(--green-light);transform:translateX(-50%);
}
.timeline-item{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  align-items:start;margin-bottom:48px;
}
.timeline-item:nth-child(even) .tl-content{order:1;}
.timeline-item:nth-child(even) .tl-year{order:2;text-align:left;}
.tl-year{
  font-family:var(--font-h);font-size:2.8rem;font-weight:300;
  color:var(--green);text-align:right;padding-right:56px;padding-top:4px;
  position:relative;
}
.tl-year::after{
  content:'';position:absolute;right:0;top:16px;
  width:12px;height:12px;background:var(--green);border-radius:50%;
  transform:translateX(50%);
}
.timeline-item:nth-child(even) .tl-year{padding-right:0;padding-left:56px;}
.timeline-item:nth-child(even) .tl-year::after{right:auto;left:0;transform:translateX(-50%);}
.tl-content{padding-left:56px;padding-top:4px;}
.timeline-item:nth-child(even) .tl-content{padding-left:0;padding-right:56px;}
.tl-title{font-family:var(--font-h);font-size:1.2rem;font-weight:600;color:var(--dark);margin-bottom:8px;}
.tl-text{font-size:.82rem;line-height:1.65;color:var(--gray);}

/* ---- VISION PAGE ---- */
.vision-intro{padding:80px 0;background:var(--white);}
.vision-intro-text{
  font-family:var(--font-h);font-size:clamp(1.6rem,2.8vw,2.3rem);
  font-weight:300;line-height:1.4;color:var(--dark);
  max-width:860px;margin:0 auto;text-align:center;
}
.vision-intro-text em{color:var(--green);font-style:italic;}
.vision-pillars{padding:80px 0;background:var(--off);}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--green-light);}
.pillar-card{background:var(--white);padding:48px 36px;}
.pillar-num{
  font-family:var(--font-h);font-size:4rem;font-weight:300;
  color:var(--green-light);line-height:1;margin-bottom:8px;
}
.pillar-title{font-family:var(--font-h);font-size:1.5rem;font-weight:600;color:var(--dark);margin-bottom:16px;}
.pillar-text{font-size:.85rem;line-height:1.75;color:var(--gray);}
.vision-detail{padding:100px 0;}
.vision-detail-item{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:center;margin-bottom:100px;
}
.vision-detail-item:last-child{margin-bottom:0;}
.vision-detail-item.reverse .vd-img{order:2;}
.vision-detail-item.reverse .vd-text{order:1;}
.vd-img{overflow:hidden;}
.vd-img img{width:100%;object-fit:cover;aspect-ratio:4/3;}
.vd-text .section-tag{margin-bottom:16px;}
.vd-title{font-family:var(--font-h);font-size:clamp(2rem,3vw,2.6rem);font-weight:300;color:var(--dark);margin-bottom:20px;}
.vd-title em{color:var(--green);font-style:italic;}
.vd-body{font-size:.9rem;line-height:1.85;color:var(--gray);margin-bottom:28px;}
.vd-points{list-style:none;margin-bottom:32px;}
.vd-points li{
  font-size:.85rem;line-height:1.6;color:var(--gray);
  padding:10px 0;border-bottom:1px solid var(--green-pale);
  display:flex;align-items:flex-start;gap:12px;
}
.vd-points li::before{content:'';width:6px;height:6px;background:var(--green);border-radius:50%;flex-shrink:0;margin-top:6px;}

/* ---- NEWS / ACTUALITES PAGE ---- */
.news-page{padding:80px 0;background:var(--white);}
.news-filters{
  display:flex;align-items:center;gap:8px;margin-bottom:52px;flex-wrap:wrap;
}
.filter-btn{
  background:none;border:1.5px solid var(--green-light);
  font-family:var(--font-b);font-size:.65rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  padding:9px 20px;cursor:pointer;color:var(--gray);
  transition:all .2s;
}
.filter-btn.active,.filter-btn:hover{background:var(--green);border-color:var(--green);color:#fff;}
.news-featured{
  display:grid;grid-template-columns:1.5fr 1fr;gap:0;
  margin-bottom:48px;background:var(--dark);
  min-height:420px;cursor:pointer;
  transition:box-shadow .25s;
}
.news-featured:hover{box-shadow:0 16px 48px rgba(0,0,0,.2);}
.news-feat-img{overflow:hidden;}
.news-feat-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s;opacity:.8;}
.news-featured:hover .news-feat-img img{transform:scale(1.03);}
.news-feat-body{padding:48px;display:flex;flex-direction:column;justify-content:flex-end;}
.news-feat-cat{font-size:.58rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:14px;}
.news-feat-title{font-family:var(--font-h);font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:400;color:var(--white);line-height:1.25;margin-bottom:16px;}
.news-feat-excerpt{font-size:.85rem;line-height:1.7;color:rgba(255,255,255,.5);margin-bottom:28px;}
.news-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}

/* ---- BOOKS PAGE ---- */
.books-page{padding:100px 0;background:var(--white);}
.books-intro{
  font-size:.95rem;line-height:1.8;color:var(--gray);
  max-width:680px;margin-bottom:72px;
}
.books-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;}
.book-card{cursor:pointer;}
.book-cover{
  position:relative;overflow:hidden;
  aspect-ratio:2/3;margin-bottom:24px;
  box-shadow:0 8px 32px rgba(0,0,0,.15);
}
.book-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.book-card:hover .book-cover img{transform:scale(1.03);}
.book-cover-overlay{
  position:absolute;inset:0;
  background:rgba(5,14,9,.0);
  transition:background .3s;
  display:flex;align-items:center;justify-content:center;
}
.book-card:hover .book-cover-overlay{background:rgba(5,14,9,.45);}
.book-cover-overlay span{
  color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  opacity:0;transition:opacity .3s;
  border:1px solid rgba(255,255,255,.5);padding:10px 20px;
}
.book-card:hover .book-cover-overlay span{opacity:1;}
.book-year{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--green);font-weight:600;margin-bottom:8px;}
.book-title{font-family:var(--font-h);font-size:1.3rem;font-weight:600;color:var(--dark);margin-bottom:10px;}
.book-synopsis{font-size:.8rem;line-height:1.65;color:var(--gray);}
.book-actions{display:flex;gap:12px;margin-top:16px;}

/* ---- SPEECHES PAGE ---- */
.speeches-page{padding:100px 0;background:var(--white);}
.speech-list{display:flex;flex-direction:column;gap:2px;}
.speech-item{
  display:grid;grid-template-columns:120px 1fr auto;gap:32px;
  align-items:center;padding:32px 40px;background:var(--white);
  border:1px solid rgba(0,0,0,.06);
  transition:background .2s,border-color .2s;cursor:pointer;
}
.speech-item:hover{background:var(--green-pale);border-color:var(--green-light);}
.speech-date{font-family:var(--font-h);font-size:1.6rem;font-weight:300;color:var(--green);text-align:center;line-height:1.1;}
.speech-date span{display:block;font-size:.62rem;font-family:var(--font-b);font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gray-light);margin-top:4px;}
.speech-info .speech-cat{font-size:.58rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:8px;}
.speech-info .speech-title{font-family:var(--font-h);font-size:1.2rem;font-weight:500;color:var(--dark);margin-bottom:6px;}
.speech-info .speech-location{font-size:.78rem;color:var(--gray);}
.speech-arrow{color:var(--green);font-size:1.2rem;}

/* ---- CONTACT PAGE ---- */
.contact-page{padding:100px 0;background:var(--white);}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start;}
.contact-info h2{
  font-family:var(--font-h);font-size:clamp(1.8rem,2.8vw,2.5rem);
  font-weight:300;color:var(--dark);margin-bottom:20px;
}
.contact-info p{font-size:.88rem;line-height:1.8;color:var(--gray);margin-bottom:36px;}
.contact-method{display:flex;align-items:flex-start;gap:18px;margin-bottom:28px;}
.contact-method-icon{
  width:44px;height:44px;background:var(--green-pale);border:1px solid var(--green-light);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-method-icon svg{stroke:var(--green);fill:none;width:18px;height:18px;}
.contact-method-label{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray-light);font-weight:600;margin-bottom:4px;}
.contact-method-value{font-size:.9rem;color:var(--dark);font-weight:500;}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.contact-form .form-group{margin-bottom:20px;}
.contact-form label{
  display:block;font-size:.62rem;font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;color:var(--gray);margin-bottom:8px;
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;padding:14px 18px;
  border:1px solid rgba(0,0,0,.12);background:var(--off);
  font-family:var(--font-b);font-size:.88rem;color:var(--dark);
  outline:none;transition:border-color .2s,background .2s;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{border-color:var(--green);background:var(--white);}
.contact-form textarea{height:140px;resize:vertical;}

/* ---- ARTICLE PAGE ---- */
.article-header{padding:60px 0 48px;border-bottom:1px solid rgba(0,0,0,.07);}
.article-cat{font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:20px;}
.article-title{font-family:var(--font-h);font-size:clamp(2.4rem,4vw,3.8rem);font-weight:300;line-height:1.12;color:var(--dark);margin-bottom:24px;}
.article-meta{display:flex;align-items:center;gap:24px;}
.article-meta-date{font-size:.75rem;color:var(--gray-light);}
.article-meta-author{font-size:.75rem;color:var(--gray);font-weight:500;}
.article-feat-img{
  width:100%;aspect-ratio:16/7;overflow:hidden;margin:48px 0;
}
.article-feat-img img{width:100%;height:100%;object-fit:cover;}
.article-body{max-width:720px;}
.article-body p{font-size:.97rem;line-height:1.9;color:var(--gray);margin-bottom:24px;}
.article-body h3{font-family:var(--font-h);font-size:1.5rem;font-weight:600;color:var(--dark);margin:40px 0 16px;}
.article-body blockquote{
  border-left:3px solid var(--green);padding-left:28px;
  margin:36px 0;
}
.article-body blockquote p{font-family:var(--font-h);font-size:1.3rem;font-weight:400;color:var(--dark);line-height:1.4;}
.related-articles{padding:80px 0;background:var(--off);}
.related-title{font-family:var(--font-h);font-size:2rem;font-weight:300;color:var(--dark);margin-bottom:40px;}

/* ---- UTILITIES ---- */
.text-green{color:var(--green);}
.text-white{color:var(--white);}
.text-dark{color:var(--dark);}
.bg-dark{background:var(--dark);}
.bg-off{background:var(--off);}
.divider{width:48px;height:2px;background:var(--green);margin:24px 0;}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}

/* ============ TABLET ============ */

/* ---- MOBILE DRAWER ---- */
.drawer-overlay{
  position:fixed;inset:0;z-index:1100;
  background:rgba(5,14,9,.6);backdrop-filter:blur(4px);
  opacity:0;visibility:hidden;display:none;
  transition:opacity .4s ease,visibility .4s ease;
}
.drawer-overlay.open{opacity:1;visibility:visible;display:block;}

.mobile-drawer{
  position:fixed;top:0;left:0;width:340px;max-width:88vw;height:100vh;height:100dvh;
  z-index:1200;
  background:var(--dark);
  transform:translateX(-100%);
  transition:transform .45s cubic-bezier(.4,0,.2,1);
  display:none;flex-direction:column;
  overflow-y:auto;
}
.mobile-drawer.open{transform:translateX(0);display:flex;}

.drawer-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:28px 28px 20px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.drawer-brand{display:flex;flex-direction:column;gap:2px;}
.drawer-logo{
  font-family:var(--font-h);font-size:1.15rem;font-weight:600;
  color:#fff;letter-spacing:.18em;text-transform:uppercase;
}
.drawer-sub{
  font-family:var(--font-b);font-size:.6rem;font-weight:400;
  color:var(--green);letter-spacing:.28em;text-transform:uppercase;
}
.drawer-close{
  background:none;border:none;color:rgba(255,255,255,.5);
  cursor:pointer;padding:8px;transition:color .2s;
}
.drawer-close:hover{color:#fff;}
.drawer-close svg{width:20px;height:20px;}

.drawer-links{
  flex:1;padding:24px 0;display:flex;flex-direction:column;
}
.drawer-links a{
  display:flex;align-items:center;gap:14px;
  padding:14px 28px;
  font-family:var(--font-b);font-size:.8rem;font-weight:400;
  color:rgba(255,255,255,.7);
  text-decoration:none;text-transform:uppercase;
  letter-spacing:.18em;
  border-left:3px solid transparent;
  transition:all .25s ease;
  cursor:pointer;
}
.drawer-links a:hover{
  color:#fff;
  background:rgba(255,255,255,.04);
  border-left-color:var(--green);
}
.drawer-links a.active{
  color:var(--green);
  border-left-color:var(--green);
}
.drawer-num{
  font-family:var(--font-b);font-size:.65rem;font-weight:300;
  color:rgba(255,255,255,.25);letter-spacing:.05em;
  min-width:18px;
}

.drawer-footer{
  padding:20px 28px 32px;
  border-top:1px solid rgba(255,255,255,.08);
}
.drawer-lang{display:flex;gap:8px;}
.drawer-lang .lang-btn{
  flex:1;padding:10px 16px;
  font-family:var(--font-b);font-size:.7rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,.15);
  border-radius:4px;
  background:transparent;color:rgba(255,255,255,.6);
  cursor:pointer;
  transition:all .25s ease;
}
.drawer-lang .lang-btn:hover{
  border-color:var(--green);color:#fff;
}
.drawer-lang .lang-btn.active{
  background:var(--green);color:#fff;
  border-color:var(--green);
}

/* Hamburger animation */
body.drawer-open .menu-icon span:nth-child(1){
  transform:rotate(45deg) translate(5px,5px);
}
body.drawer-open .menu-icon span:nth-child(2){opacity:0;}
body.drawer-open .menu-icon span:nth-child(3){
  transform:rotate(-45deg) translate(5px,-5px);
}
@media(max-width:900px){
  .section-wrap,.section-wrap-sm{padding:0 24px;}
  .hero-full .hero-content,.hero-inner .hero-content{padding:0 24px 56px;}
  .quote-grid,.bio-grid,.contact-grid{grid-template-columns:1fr;}
  .news-grid,.news-page-grid,.books-grid{grid-template-columns:1fr 1fr;}
  .pillars-grid{grid-template-columns:1fr;}
  .priority-section .content{grid-template-columns:1fr;padding:60px 24px;}
  .ft-grid{grid-template-columns:1fr 1fr;gap:36px;}
  .newsletter{padding:64px 28px;}
  .site-footer{padding:56px 28px 32px;}
  .ft-bottom{flex-direction:column;gap:14px;text-align:center;}
  .vision-detail-item{grid-template-columns:1fr;}
  .speech-item{grid-template-columns:80px 1fr auto;padding:24px;}
  .quote-grid{gap:48px;}
  .bio-grid{gap:40px;}
  .hero-full{min-height:520px;}
  .hero-inner{min-height:340px;height:50vh;}
  .hero-title{margin-bottom:18px;}
  .hero-desc{margin-bottom:28px;}
  .big-quote{padding-left:24px;font-size:clamp(1.5rem,2.8vw,2.4rem);}
  .stat-num{font-size:2.4rem;}
  .timeline-item{grid-template-columns:1fr;gap:8px;margin-bottom:36px;}
  .timeline::before{left:16px;}
  .tl-year{text-align:left!important;padding-left:44px!important;padding-right:0!important;font-size:2rem;}
  .tl-year::after{right:auto!important;left:10px!important;transform:translateX(0)!important;width:10px;height:10px;top:14px;}
  .tl-content{padding-left:44px!important;padding-right:0!important;order:2!important;}
  .timeline-item:nth-child(even) .tl-year{order:1!important;}
  .timeline-item:nth-child(even) .tl-content{order:2!important;}
  .bio-values{grid-template-columns:1fr 1fr;gap:16px;}
  .value-card{padding:20px;}
}

/* ============ MOBILE ============ */
@media(max-width:600px){
  :root{--nav-h:56px;--sub-h:40px;}
  
  /* -- Header mobile -- */
  .header-inner{padding:0 16px;justify-content:center;position:relative;}
  .menu-btn{position:absolute;left:16px;top:50%;transform:translateY(-50%);}
  .menu-btn > span:not(.menu-icon){display:none;}
  .logo-wrap{text-align:center;}
  .logo-name{font-size:1rem;letter-spacing:.15em;}
  .logo-sub{font-size:.42rem;letter-spacing:.22em;}
  .header-right{display:none!important;}
  .sub-nav{display:none!important;}


  /* -- Hero full (homepage) -- */
  .hero-full{min-height:480px;height:85vh;padding-top:var(--nav-h);}
  .hero-full .hero-content,.hero-inner .hero-content{padding:0 20px 44px;max-width:100%;}
  .hero-title{font-size:clamp(2rem,8vw,3.2rem);margin-bottom:14px;}
  .hero-eyebrow{font-size:.52rem;letter-spacing:.18em;margin-bottom:14px;}
  .hero-eyebrow::before{width:24px;}
  .hero-desc{font-size:.85rem;line-height:1.65;margin-bottom:24px;}
  .hero-author-name{font-size:1.2rem;}
  .hero-btns{flex-direction:column;gap:12px;align-items:stretch;}
  .hero-btns .btn-green,.hero-btns .btn-ghost{width:100%;text-align:center;justify-content:center;}

  /* -- Hero inner (sub-pages) -- */
  .hero-inner{min-height:280px;height:45vh;}

  /* -- Sections general -- */
  .section-wrap,.section-wrap-sm{padding:0 20px;}
  .section-tag{font-size:.52rem;margin-bottom:14px;}
  .section-tag::before{width:20px;}
  
  /* -- Quote section -- */
  .quote-section{padding:60px 0;}
  .quote-grid{gap:32px;}
  .big-quote{font-size:clamp(1.3rem,5vw,1.8rem);padding-left:20px;border-left-width:2px;}
  .stat-item{gap:16px;}
  .stat-num{font-size:2rem;}
  .stat-label{font-size:.72rem;}
  .stat-text{font-size:.78rem;}

  /* -- News / Books grids -- */
  .news-grid,.news-page-grid,.books-grid{grid-template-columns:1fr;}
  .news-section{padding:80px 0;}
  .news-card-body{padding:24px 20px;}

  /* -- Pillars -- */
  .pillars-section{padding:60px 0;}
  .pillar-card{padding:32px 24px;}

  /* -- Bio section (A propos) -- */
  .bio-section{padding:60px 0;}
  .bio-grid{gap:28px;}
  .bio-text h2{font-size:clamp(1.6rem,5vw,2.2rem);margin-bottom:20px;}
  .bio-text p{font-size:.87rem;line-height:1.75;}
  .bio-values{grid-template-columns:1fr;gap:12px;margin-top:28px;}
  .value-card{padding:18px;}
  .bio-photo-caption{padding:28px 20px 18px;}

  /* -- Timeline -- */
  .timeline-section{padding:60px 0;}
  .timeline-title{font-size:clamp(1.6rem,5vw,2.2rem);margin-bottom:40px;}
  .timeline-item{margin-bottom:28px;}
  .tl-year{font-size:1.6rem;}
  .tl-title{font-size:1.05rem;}
  .tl-text{font-size:.78rem;}

  /* -- CTA section -- */
  .cta-section{padding:60px 0;}
  .cta-title{font-size:clamp(1.6rem,5vw,2.4rem);}
  .cta-desc{font-size:.85rem;}

  /* -- Contact -- */
  .contact-grid{gap:32px;}
  .contact-info-item{gap:16px;}

  /* -- Vision page -- */
  .vision-detail-item{gap:24px;padding:40px 0;}
  .vision-detail-text h3{font-size:1.3rem;}

  /* -- Speeches page -- */
  .speech-item{grid-template-columns:1fr;gap:12px;padding:20px;}
  .speech-date{font-size:.75rem;}

  /* -- Priority section -- */
  .priority-section{padding:60px 0;}
  .priority-section .content{padding:40px 20px;}
  .priority-section h2{font-size:clamp(1.5rem,5vw,2rem);}

  /* -- Footer -- */
  .footer-inner{grid-template-columns:1fr;gap:32px;}
  .footer{padding:48px 0 24px;}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center;padding-top:24px;}

  /* -- Buttons -- */
  .btn{font-size:.7rem;padding:14px 28px;}
  .btn-outline{padding:12px 24px;}

  /* -- Download pages (Master Plan) -- */
  .wp-block-group{padding-left:20px!important;padding-right:20px!important;}

  /* -- Hero btns mobile -- */
  .hero-btns{flex-direction:column;gap:12px;align-items:stretch;margin-top:24px;}
  .hero-btns .btn-green,.hero-btns .btn-ghost{width:100%;text-align:center;justify-content:center;padding:16px 24px;}
  
  /* -- Section headings -- */
  .section-title{font-size:clamp(1.6rem,5vw,2.2rem);}
  .section-subtitle{font-size:.85rem;}
  
  /* -- News cards -- */
  .news-card img{height:200px;}
  .news-title{font-size:1rem;}
  
  /* -- Book cards -- */
  .book-card{padding:20px;}
  
  /* -- Lang switcher -- */
  .lang-sw{gap:4px;}
  
  /* -- Scroll indicator -- */
  .scroll-down{display:none;}
  
  /* -- WP Block content (download pages) -- */
  .entry-content .wp-block-group{padding-left:16px!important;padding-right:16px!important;}
  .entry-content img{max-width:280px!important;height:auto!important;}

  /* Newsletter + Footer mobile */
  .newsletter{padding:48px 20px;}
  .nl-form{flex-direction:column;}
  .nl-form input{border-right:1px solid rgba(255,255,255,.14);border-bottom:none;}
  .ft-grid{grid-template-columns:1fr;gap:32px;}
  .site-footer{padding:48px 20px 28px;}
  .ft-bottom{flex-direction:column;gap:12px;text-align:center;}
}


/* Hide sub-nav on scroll down, show on scroll up */
.sub-nav {
  transition: transform 0.35s ease, opacity 0.35s ease;
}
.sub-nav.nav-hidden {
  transform: translateY(calc(-100% - 68px)) !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Header turns white when white section overlaps */
.site-header {
  transition: background 0.4s ease, box-shadow 0.4s ease;
}
.site-header.header-light {
  background: rgba(255, 255, 255, 0.97) !important;
  box-shadow: 0 1px 12px rgba(0,0,0,0.08);
}
.site-header:not(.header-light) {
  background: transparent !important;
  box-shadow: none !important;
}


/* ===== WHITE HOUSE STYLE HEADER ===== */
/* Force white text/icons over hero (before white section reaches header) */
.site-header:not(.header-light) .logo-name { color: #fff !important; }
.site-header:not(.header-light) .menu-btn { color: #fff !important; }
.site-header:not(.header-light) .search-btn { color: #fff !important; }
#siteHeader:not(.header-light) #menuBtn .menu-icon span { background: #fff !important; }
.site-header:not(.header-light) .lang-btn { color: #fff !important; }
.site-header:not(.header-light) .lang-sw { background: rgba(255,255,255,0.15) !important; }
.site-header:not(.header-light) .logo-subtitle { color: rgba(255,255,255,0.7) !important; }

/* Horizontal line below header (always visible, like White House) */
#siteHeader::after {
  display: none !important;
  content: none !important;
}
/* header-light after removed */

/* Logo shrinks on scroll (like White House) */
.site-header .logo-name {
  transition: color 0.4s ease;
}
.site-header .logo-wrap {
  transition: transform 0.35s ease;
  transform-origin: center center;
  will-change: transform;
}
.site-header.logo-shrunk .logo-wrap {
  transform: scale(0.93) !important;
}

/* Header text turns dark ONLY when header-light (white bg) */
.site-header.header-light .logo-name { color: var(--dark) !important; }
.site-header.header-light .menu-btn { color: var(--dark) !important; }
.site-header.header-light .search-btn { color: var(--dark) !important; }
#siteHeader.header-light #menuBtn .menu-icon span { background: var(--dark) !important; }
.site-header.header-light .lang-btn { color: var(--dark) !important; }


/* Sub-nav follows header state via sibling selector */
#siteHeader:not(.header-light) ~ #subNav {
  background: transparent !important;
  backdrop-filter: none !important;
  border-bottom-color: rgba(255,255,255,0.15) !important;
  box-shadow: none !important;
}
#siteHeader.header-light ~ #subNav {
  background: rgba(255,255,255,0.97) !important;
  backdrop-filter: blur(12px) !important;
  border-bottom-color: rgba(0,0,0,0.07) !important;
}

/* Sub-nav links color follows header state */
#siteHeader:not(.header-light) ~ #subNav a {
  color: rgba(255,255,255,0.7) !important;
}
#siteHeader:not(.header-light) ~ #subNav a.active {
  color: var(--green) !important;
}
#siteHeader.header-light ~ #subNav a {
  color: var(--dark) !important;
}
#siteHeader.header-light ~ #subNav a.active {
  color: var(--green) !important;
}


/* Fix newsletter form inputs visibility per language */
html.lang-en .nl-form input.lang-en {
  display: block !important;
}
html.lang-en .nl-form input.lang-fr {
  display: none !important;
}
html.lang-fr .nl-form input.lang-fr,
html:not(.lang-en) .nl-form input.lang-fr {
  display: block !important;
}
html.lang-fr .nl-form input.lang-en,
html:not(.lang-en) .nl-form input.lang-en {
  display: none !important;
}

/* ===== Livres page - Responsive ===== */
.books-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}

@media (max-width: 768px) {
  .section-wrap { padding: 40px 20px !important; }
  .books-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .books-intro { margin-bottom: 40px !important; }
  .books-intro h2 { font-size: 24px !important; }
  .book-cover { height: 300px !important; }
  .book-card > div:last-child { padding: 24px !important; }
  .book-title { font-size: 20px !important; }
  .book-desc { font-size: 14px !important; }
}

@media (max-width: 480px) {
  .section-wrap { padding: 32px 16px !important; }
  .books-grid { gap: 24px !important; }
  .book-cover { height: 250px !important; }
}
