/* -------------------------------------------------
   Another PlastiK — ABOUT
   ------------------------------------------------- */
/* Fonts (toujours en tête) */
@import url('https://api.fontshare.com/v2/css?f[]=cabinet-grotesk@400,500,700&display=swap');

/* ===== VARIABLES ===== */
:root {
  /* Couleurs principales */
  --primary: #1F3D32;
  --primary-light: #2A4F42;
  --primary-dark: #16291F;

  /* Accents */
  --accent: #2C5F6F;
  --accent-light: #3A7A8C;
  --accent-soft: rgba(44, 95, 111, 0.12);
  --olive: #8B9556;

  /* Neutres */
  --bg: #FFFFFF;
  --bg-sand: #F4EBE0;
  --bg-light: #F8FAFC;
  --text: #2A2A2A;
  --text-muted: #6B7280;
  --black: #0A0A0A;
  --white: #FFFFFF;

  /* UI */
  --gray-50: #FAFAFA;
  --gray-100: #F5F5F5;
  --gray-200: #E5E5E5;
  --gray-300: #D4D4D4;
  --gray-400: #A3A3A3;
  --gray-500: #737373;
  --gray-600: #525252;
  --gray-700: #404040;
  --gray-800: #262626;
  --gray-900: #171717;

  --shadow: 0 8px 28px rgba(0,0,0,.08);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.12);

  --container: 1380px;
  --container-narrow: 1280px;
  --gutter: 20px;

  --header-h: 75px;
  --link-h: 44px;

  /* Hero heights */
  --hero-h-desktop: 78vh;
  --hero-h-tablet: 63vh;
  --hero-h-mobile: 50vh;

  /* Ratios de base */
  --media-ar-desktop: 5 / 3.9;    
  --media-ar-tablet:  5 / 3.8;   
  --media-ar-mobile:  5 / 3.3;   

  /* Hauteur exacte de la phase-banner */
  --banner-h: 40px;

  /* Couleur succès (pour progress-fill) */
  --success: #1aa37a;
}

/* =========================
        Base/ Reset
   ========================= */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
/* Fix global overflow + fond blanc parasite */
html, body {
  width:100%;
  max-width:100%;
  overflow-x:hidden;      /* empêche le scroll horizontal */
  background:var(--bg);   /* évite les bandes blanches */
}
body{
  margin:0; font-family:"Cabinet Grotesk",system-ui,sans-serif;
  font-size:17px; line-height:1.75; color:var(--text);
  background:transparent; overflow-x:hidden; -webkit-font-smoothing:antialiased;
  font-weight:400; letter-spacing:-.01em;
  min-height:100vh; display:flex; flex-direction:column;
}
body.menu-open{overflow:hidden}
.container{max-width:var(--container); margin:0 auto; padding:0 var(--gutter);}
.container-narrow{max-width:var(--container-narrow); margin:0 auto; padding:0 var(--gutter);}
.section{padding:60px 0; overflow-x:hidden; padding-left:var(--gutter); padding-right:var(--gutter);}body.has-hero main{margin-top:0;}
main{flex:1 0 auto; padding-top:calc(var(--header-h) + var(--banner-h));}
footer{margin-top:auto;}

/* =========================
        Buttons
   ========================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; text-align:center;
  font-weight:600; font-size:.9rem; letter-spacing:.3px; cursor:pointer; text-decoration:none;
  border-radius:5px; transition:all .25s ease; height:45px; width:180px;
  background:var(--primary); color:#fff; border:2.5px solid var(--primary); box-shadow:none;
}
.btn:hover,.btn:focus{background:#fff;color:var(--primary); border-color:var(--primary); transform:translateY(-1px);}
.btn:active{background:var(--primary); color:#fff; transform:translateY(0);}
.btn.outline{background:transparent;color:var(--primary);border:2.5px solid var(--primary);}
.btn.outline:hover{background:var(--primary);color:#fff;}

/* =========================
   PHASE BANNER
   ========================= */
.phase-banner{
  position:fixed; top:var(--header-h); left:0; right:0; z-index:10000;
  height:var(--banner-h); display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,#2C5F6F 0%,#3A7A8C 100%); color:#fff;
  line-height:1; font-size:.95rem; padding:0; transition:transform .3s,opacity .3s;
}
body.scrolled-nav .phase-banner{transform:translateY(-100%);opacity:0;pointer-events:none;}
.phase-banner a{color:#fff;text-decoration:underline;font-weight:600;text-underline-offset:3px;transition:opacity .2s;}
.phase-banner a:hover{opacity:.85;}

/* =========================
   HEADER
   ========================= */
header.nav{
  position:fixed; top:0; left:0; right:0; z-index:10001; height:var(--header-h);
  width:100%; max-width:100vw; overflow-x:clip; background:var(--bg);
  transition:box-shadow .30s ease; box-shadow:0 2px 8px rgba(0,0,0,.1);
}
body.scrolled-nav header.nav{box-shadow:0 6px 18px rgba(0,0,0,.12);}
header.nav .inner{
  width:100%; max-width:var(--container); margin:0 auto; height:100%;
  padding:0 var(--gutter); display:flex; align-items:center; justify-content:space-between;
}
header.nav .logo{display:flex; align-items:center; height:100%; margin-right:clamp(32px,6vw,128px);transform:translateX(-8px)}
header.nav .logo img{display:block; height:calc(var(--header-h) - 28px); width:auto;}

header.nav .links{
  display:flex; align-items:center; gap:20px; height:100%; position:relative; top:3px;
  margin-left:auto; margin-right:0;
}
header.nav .links a{
  position:relative; display:inline-flex; align-items:center; justify-content:center;
  height:var(--link-h); padding:0 14px; line-height:1; font-weight:600; color:var(--primary); text-decoration:none;
  transition:background .2s ease, color .2s ease, transform .2s ease;
}
header.nav .links a::after{
  content:""; position:absolute; left:0; bottom:-3px; width:0%; height:2px; background:var(--primary); transition:width .25s ease;
}
header.nav .links a:hover::after, header.nav .links a:focus::after{width:100%;}
body.has-hero header.nav{background:var(--bg); box-shadow:0 2px 8px rgba(0,0,0,.1);}
body.has-hero.scrolled-nav header.nav{background:var(--bg)!important; box-shadow:0 6px 18px rgba(0,0,0,.12)!important;}
body.has-hero header.nav .links a{color:var(--primary);}
body.has-hero.scrolled-nav header.nav .links a{color:var(--primary)!important;}

/* =========================
            BURGER
   ========================= */
header.nav .nav-toggle{
  display:none; width:44px; height:44px; background:transparent; border:none; cursor:pointer; z-index:10000;
  align-items:center; justify-content:center;
}
header.nav .nav-toggle span{display:block; width:24px; height:2px; background:var(--primary); transition:transform .25s,opacity .2s,background .25s}
header.nav .nav-toggle span+span{margin-left:-24px; transform:translateY(6px)}
body.menu-open .nav-toggle span:first-child{transform:translateY(0) rotate(45deg)}
body.menu-open .nav-toggle span:last-child{transform:translateY(0) rotate(-45deg)}

/* =========================
         Mobile menu
   ========================= */
.mobile-menu{  position:fixed;  inset:0;  z-index:9998;  display:flex;  flex-direction:column;  align-items:center;  justify-content:center;  gap:22px;
  padding:20px;  background:rgba(31,92,66,.98);  transform:translateY(-100%);  transition:transform .28s ease;
}

body.menu-open .mobile-menu{  transform:none;}
.mobile-menu a{  color:#fff;  font-size:1.3rem;  font-weight:600;  text-decoration:none;}

/* =========================
       Language selector
   ========================= */

/* Vertical separator */
.language-separator{  display:inline-block;  width:1px;  height:26px;  background:var(--primary);  margin:0 8px;}

/* Wrapper */
.language-selector{  position:relative;  display:flex;  align-items:center;  height:var(--link-h);}

/* Toggle button */
.lang-toggle{  display:inline-flex;  align-items:center;  justify-content:center;  gap:6px;
  height:var(--link-h);  padding:0 14px;  background:transparent;  border:none;  color:var(--primary);
  font-weight:600;  font-size:1rem;  font-family:"Cabinet Grotesk",sans-serif;
  cursor:pointer;  transform:translateY(1px);  transition:opacity .25s;}
.lang-toggle:hover{  opacity:.9;}

/* Arrow */
.lang-arrow{  width:10px;  height:10px;  stroke:currentColor;  stroke-width:1.6;  transition:transform .25s;}
.lang-toggle[aria-expanded="true"] .lang-arrow{  transform:rotate(180deg);}

/* Dropdown */
.lang-dropdown{  position:absolute;  top:calc(100% + 8px);  right:0;  min-width:120px;  z-index:1000;  background:var(--bg);box-shadow:0 8px 24px rgba(0,0,0,.15);
  opacity:0;  visibility:hidden;  transform:translateY(-8px);  transition:opacity .25s ease, transform .25s ease;
}
.lang-dropdown[aria-hidden="false"]{  opacity:1;  visibility:visible;  transform:translateY(0);}

/* Language links */
.lang-option{  display:block;  width:100%;  padding:12px 20px;  background:transparent;  border:none;  text-align:left;
  text-decoration:none;  color:var(--primary);  font-weight:600;  font-size:.95rem;  font-family:"Cabinet Grotesk",sans-serif;  cursor:pointer;  transition:background .2s ease;}
.lang-option:hover,
.lang-option:focus{  background:var(--accent-soft);  text-decoration:none;}
.lang-option:focus-visible{  outline:2px solid var(--accent);  outline-offset:2px;}
.lang-option.active,
.lang-option[aria-current="page"]{  background:var(--accent-soft);  color:var(--primary);}

/* =========================
    Mobile language
   ========================= */
.mobile-lang-selector{  display:flex;  flex-direction:column;  gap:12px;  padding-top:24px;
  margin-top:24px;  border-top:1px solid rgba(0,0,0,.12);}
.lang-option-mobile{  background:rgba(255,255,255,.1);  border:1.5px solid rgba(255,255,255,.3);  border-radius:5px;
  color:#fff; padding:14px 20px;  font-weight:600;  font-size:1.1rem;  text-align:center;
  font-family:"Cabinet Grotesk",sans-serif;  cursor:pointer;  transition:background .25s, border-color .25s;}
.lang-option-mobile:hover{  background:rgba(255,255,255,.2);  border-color:rgba(255,255,255,.5);}
.lang-option-mobile.active{  background:#fff;  color:var(--primary);  border-color:#fff;}

/* =========================
   Page Hero
   ========================= */
.page-hero{padding:80px 0 60px; position:relative; color:#fff;}
.page-hero .container{  position:relative;   z-index:1;  max-width:var(--container);  margin:0 auto;  padding:0 var(--gutter);}
.page-hero h1{font-size:clamp(2.4rem,5.4vw,4.6rem);   font-weight:600;   line-height:1.08;   color:#fff;   margin-bottom:16px;   text-transform:uppercase;}
.page-hero .overlay{position:absolute; inset:0; background:rgba(0,0,0,.35); z-index:0;  display:flex; flex-direction:column; align-items:flex-start; justify-content:center;     
  text-align:left; background:rgba(0,0,0,.25);}
.page-hero p{  font-size:1.2rem;   color:#fff;   text-align:justify;}

/* =========================
   ADVISORS
   ========================= */
.advisors-wrapper{background:#fff; padding-top:60px;}
.advisors-section{  background:linear-gradient(180deg,#f8fafc 0%,#edf2f7 100%);  padding:15px 0; border-radius:0; text-align:center; position:relative;}
.advisors-section .container{  max-width:var(--container);  margin:0 auto;  padding:0 var(--gutter);}
.advisor-title{  text-align:center; font-size:1.35rem; font-weight:600; color:var(--text);  margin-bottom:6px; letter-spacing:.05em; transform:translateY(6px);}
.advisor-subtitle{color:var(--text-muted); font-size:1rem; margin-bottom:24px;}
.advisors-grid{  display:grid;  grid-template-columns:repeat(3,minmax(0,1fr));  align-items:center;
  justify-items:center;  gap:40px;  max-width:1000px;  margin:0 auto;}
.advisor-card{  display:flex;  flex-direction:column;  align-items:center;  text-align:center;}
.advisor-logo{  width:260px;  max-width:100%;  aspect-ratio:3 / 1;  display:flex;  align-items:center;
  justify-content:center;  margin-bottom:8px;}

/* Agrandit TunSea et Ecostrafi uniquement */
.advisor-logo--big {  transform: scale(1.67);   transform-origin: center;}
.advisor-logo img{  max-height:100%;  width:100%;  object-fit:contain;}
.advisor-card span{
  font-size:.9rem;
  color:var(--text-muted);
  font-weight:500;
  line-height:1.3;
  display:block;
  margin-top:10px;  
}

/* clones cachés sur desktop / tablette */
.advisor-card--clone{
  display:none;
}

/* =========================
   ORIGIN STORY 
========================= */
.origin-section{ padding:30px 0; position: relative; background: #fff; }
.origin-layout{max-width:1380px; margin:0 auto; padding:0 10px; 
               display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start;}

/* Colonne gauche (titre) */
.origin-left { display: flex; flex-direction: column; align-items: flex-start; max-width:680px; width:100%;           }
.origin-left .section-title {text-align: left; margin-bottom: 16px; max-width: 680px; 
 font-size: clamp(2rem, 3.6vw, 2.8rem); color: var(--primary);
 font-weight: 600; font-family: "Cabinet Grotesk", sans-serif;transform:translateX(6px); } 


/* Colonne droite (texte) */
.origin-right {  display: flex;  align-items: center;max-width:680px; }
.origin-right p{  text-align: justify;  text-align-last: left;  font-size: 1.05rem; 
                line-height: 1.85;  color: var(--text);  letter-spacing: 0.1px;}
/* =========================
       MISSION 
   ========================= */
.mission-section{ padding:30px 0; position: relative;background: #fff;}
.mission-layout{ max-width:1380px; margin:0 auto; padding:0 10px; 
               display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start;}
/* Colonne droite (texte) */
.mission-right { max-width:680px;  width:100%;display: flex; flex-direction: column; align-items: flex-start;}
.mission-right .section-title{
  text-align: right;
  margin-bottom: 16px; 
  font-size: clamp(2rem, 3.6vw, 2.8rem);
  color: var(--primary);
  font-weight: 600;
  font-family: "Cabinet Grotesk", sans-serif;
}

.mission-right p{  text-align: justify;  text-align-last: left;  font-size: 1.05rem;
  line-height: 1.85;  color: var(--text);  letter-spacing: 0.1px;   margin: 0; }

/* Colonne gauche (titre) */
.mission-left { max-width:680px;  width:100%;}
.mission-left .mission-image {
  width: 100%;
  height: 360px;
  margin-top: 20px;
  border-radius: 5px;
  display: block;
  object-fit: cover;
  object-position: center; 
}

/* =========================
       VISION
   ========================= */
.vision-section{  padding:30px 0;  position: relative;  background: #fff;}
.vision-layout{ max-width:1380px; margin:0 auto; padding:0 10px; 
               display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start;}

/* Colonne droite (image) */
.vision-right { display: flex; flex-direction: column; align-items: flex-start;}
.vision-right .vision-image {
  width: 100%;
  height: 360px;
  margin-top: 20px;
  border-radius: 5px;
  display: block;
  object-fit: cover;
  object-position: center; 
}

/* Colonne gauche (texte) */
.vision-left { display: flex; flex-direction: column; align-items: flex-start;}
.vision-left .section-title{
  text-align: left;
  margin-bottom: 16px; 
  font-size: clamp(2rem, 3.6vw, 2.8rem);
  color: var(--primary);
  font-weight: 600;
  font-family: "Cabinet Grotesk", sans-serif;
  transform:translateX(6px); 
}
.vision-left p{
  text-align: justify;
  text-align-last: left;
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--text);
  letter-spacing: 0.1px;
}

/* =========================
   FOUNDERS
   ========================= */
.founders-section{  padding:30px 0;  position:relative;  background:#fff;}
.founders-section .container{  max-width:var(--container);  margin:0 auto;  padding:10px;  box-sizing:border-box;}

/* Layout desktop */
.founder-layout{  display:grid;  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.5fr);  grid-template-rows: auto 1fr;
  column-gap:24px;  row-gap:24px;  align-items:start;  max-width:1380px;  margin:0 auto;}

/* Title aligned with message left padding */
.founder-title{  grid-column:2;  grid-row:1;  text-align:left;  margin:0;  padding-left:10px;   box-sizing:border-box;}
.founder-title h2{  font-size:clamp(2rem, 3.6vw, 2.8rem);  color:var(--primary);  margin:0 0 16px 0;  line-height:1.15;}

/* PHOTO column: force a fixed visual width and center meta/links under image */
.founder-photo{  grid-column:1;  grid-row:2;  width:100%;  max-width:320px;  display:flex;  flex-direction:column;  
               align-items:center;    justify-content:flex-start;  gap:14px;}

/* center the whole block inside column 1 */
.founder-layout > .founder-photo{  justify-self:center;}
.founder-photo img{  display:block;  width:100%;  max-width:320px;  border-radius:5px;  object-fit:cover;}

/* META centered */
.founder-meta{  display:flex;  flex-direction:column;  align-items:center;  text-align:center;  gap:6px;  direction:ltr;}
.founder-name{  font-size:1.15rem;  font-weight:700;  line-height:1.2;  color:var(--text);}
.founder-role{  font-size:.92rem;  font-weight:500;  line-height:1.35;  color:var(--text);  opacity:.95;}

/* LINKS centered */
.founder-links{  display:flex;  gap:12px;  justify-content:center;}
.social-link{  width:40px;  height:40px;  background:var(--bg-light);  border-radius:50%;  display:flex;  align-items:center;
  justify-content:center;  text-decoration:none;  color:var(--primary);  font-weight:700;  transition:all .25s ease;}
.social-link:hover{  background:var(--primary);  color:#fff;  transform:translateY(-2px);}

/* Text column */
.founder-message{  grid-column:2;  grid-row:2;  background:#fff;  border-radius:5px;  padding:0 0 0 10px;  box-sizing:border-box;}
.founder-message p{  font-size:1.05rem;  line-height:1.85;  color:var(--text);  margin:0 0 24px 0;  text-align:justify;  text-align-last:left;}

/* =========================
   JOIN SECTION 
   ========================= */
.join-section{  background: transparent;  padding:48px var(--gutter);   max-width: var(--container);  margin:0 auto;}
.join-card{  background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);  color:#fff;  text-align:center;  
  position:relative;  z-index:1;  max-width:980px;  margin:0 auto;  padding:32px 28px;   border-radius:5px;
  box-shadow:0 16px 36px rgba(0,0,0,.12);overflow:hidden;}
.join-card::before{  content:"";  position:absolute;  top:-40%;  right:-8%;  width:520px;  height:520px;
  background: radial-gradient(circle, rgba(255,255,255,.10) 0%, transparent 70%);  pointer-events:none; z-index:-1;}
.join-content{ max-width:690px; margin:0 auto;}
.join-content h2{  font-size:clamp(2rem,4vw,2.8rem);  margin:0 0 12px;  font-weight:700;  font-family:"Cabinet Grotesk",sans-serif;}
.join-content p{  font-size:1.05rem;  opacity:.95;  margin-bottom:24px;   line-height:1.75;}
.join-actions{  display:flex;  gap:12px;   justify-content:center;  flex-wrap:wrap;}
.join-actions .btn{  background:var(--accent-light);  color:#fff;
  border:none;  border-radius:5px;  font-weight:600;  font-size:14px;  text-decoration:none;
  cursor:pointer;  padding:10px 20px;  transition:transform .25s ease, background .25s ease;
  box-shadow:0 3px 8px rgba(44,95,111,.30);}
.join-actions .btn:hover,.join-actions .btn:focus{background:#fff;color:var(--accent-light);transform:translateY(-1px);}
.join-actions .btn:active{transform:translateY(0);background:#356f83 ;color:#fff;}
.join-actions .btn.outline{background:transparent;color:var(--accent-light);border:2.5px solid var(--accent-light);}
.join-actions .btn.outline:hover{background:#356f83;color:#fff;}

/* =========================
           FOOTER
   ========================= */
footer{background:var(--primary); color:rgba(255,255,255,.95); padding:48px 0 24px}
.footer-grid{display:grid; grid-template-columns:1fr 1fr 1fr; gap:48px; max-width:var(--container); 
             margin:0 auto; padding:0 var(--gutter); margin-bottom:32px;}
.footer-brand{margin-bottom:20px}
.footer-brand h3{color:#fff; font-size:1.3rem; font-weight:600}
.footer-info{display:flex; flex-direction:column; gap:14px; margin-bottom:20px}
.info-item{display:flex; align-items:center; gap:12px}
.info-item svg{width:20px; height:20px; stroke:rgba(255,255,255,.9); fill:none; stroke-width:2; flex-shrink:0}
.info-item span,.info-item a{color:rgba(255,255,255,.95); font-size:.95rem; text-decoration:none; transition:color .2s}
.info-item a:hover{color:#fff}
.footer-social{display:flex; gap:12px}
.footer-social a{
  width:44px; height:44px; background:var(--primary); border-radius:5px; display:flex; align-items:center; justify-content:center;
  transition:all .3s; text-decoration:none; position:relative;
}
.footer-social a:hover{transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.2)}
.footer-social a svg{width:26px; height:26px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%)}
.footer-col h4{color:#fff; font-weight:600; margin-bottom:16px; font-size:1.1rem}
.footer-col a{color:rgba(255,255,255,.85); font-size:.95rem; line-height:1.8; text-decoration:none; display:block; margin-bottom:8px; transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.15); padding-top:24px; text-align:center; font-size:.85rem; color:rgba(255,255,255,.7);
  max-width:var(--container); margin:0 auto; padding-inline:var(--gutter);
}

/* ===== Shared container alignment (desktop defaults) ===== */
.container,.container-narrow,.origin-layout,.mission-layout,.footer-grid,
.vision-layout,.founders-section .container{
  max-width:1380px; margin:0 auto; padding-inline:20px; box-sizing:border-box;
}

/* ===============================
         RESPONSIVE
   =============================== */

/* === Desktop (≥1025px) === */
@media (min-width:1025px){
  header.nav .links{
    display:flex;
    align-items:center;
    flex-wrap:nowrap;
    gap:clamp(14px,1.2vw,28px);
  }
  header.nav .links a{
    white-space:nowrap;
    line-height:1.2;
  }
   .advisor-logo--big {
    transform: scale(1.7);
  }
}

/* ===============================
         TABLETTES (≤1024px)
   =============================== */
@media (max-width:1024px){

  :root{
    --gutter:12px; --stats-inset:var(--gutter);
    --btnR-w:clamp(120px,25vw,180px); --btnR-h:40px; --btnR-fs:.9rem; --btnR-padX:12px;
    --sdg-shift:8%;
  }
  
  /* ===== HEADER NAV ===== */
  header.nav .inner{display:flex; align-items:center; justify-content:space-between}
  header.nav .logo{flex:0 0 auto; margin-right:clamp(12px,2.4vw,28px)}
  header.nav .nav-toggle{display:flex !important; margin-left:auto}
  header.nav .links{display:none !important}

  /* Conteneurs principaux (⚠️ on enlève .join-section ici) */
  .container,
  .container-narrow,
  .origin-layout,
  .mission-layout,
  .vision-layout,
  .page-hero .container,
  .advisors-section .container,
  .founders-section .container,
  header.nav .inner{
    max-width:1024px;
    width:100%;
    margin:0 auto;
    padding-inline:var(--gutter) !important;
    box-sizing:border-box;
  }

  /* Sections pleine largeur (⚠️ on enlève .join-section ici aussi) */
  .section,
  .page-hero,
  .advisors-section,
  .origin-section,
  .mission-section,
  .vision-section{
    padding-inline:0 !important;
  }

  /* Layouts ABOUT / MISSION / VISION en colonne */
  .origin-layout,
  .mission-layout,
  .vision-layout{
    display:flex;
    flex-direction:column;
    gap:32px;
    align-items:stretch;
    width:100%;
    max-width:100%;
  }

  /* Colonnes texte & images : largeur 100 % */
  .origin-left,
  .origin-right,
  .mission-left,
  .mission-right,
  .vision-left,
  .vision-right,
  .founder-message{
    width:100% !important;
    max-width:100% !important;
  }

  /* Images full-width */
  .mission-section .mission-left .mission-image,
  .vision-section .vision-right .vision-image{
    display:block !important;
    margin:12px auto 0 !important;
    width:100% !important;
    max-width:100% !important;
    aspect-ratio:var(--media-ar-tablet);
    max-height:clamp(260px,46vw,420px)!important;
    object-fit:cover !important;
    object-position:center !important;
    border-radius:5px;
  }

  /* Titres un peu réduits */
  .origin-section h2,
  .mission-section h2,
  .vision-section h2,
  .founders-section h2{
    font-size:clamp(1.8rem,3.4vw,2.4rem)!important;
  }

  .origin-section .section-title,
  .mission-section .section-title,
  .vision-section .section-title{
    margin-bottom:12px !important;
  }

  .origin-section p,
  .mission-section p,
  .vision-section p{
    margin-top:0 !important;
    margin-bottom:8px !important;
  }

  .origin-section p:last-child,
  .mission-section p:last-child,
  .vision-section p:last-child{
    margin-bottom:12px !important;
  }

  /* Advisors */
  .advisors-grid{ grid-template-columns:repeat(3,minmax(0,1fr)); gap:30px; max-width:100%; }
  .advisor-logo{ width:min(160px, 22vw); aspect-ratio:3 / 1; }
  .advisor-card span{ font-size:.85rem; white-space:nowrap; }

  .origin-section,
  .mission-section,
  .vision-section{
    padding:48px 0;
  }

  /* HEADER + BURGER */
  header.nav .inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
  }
  header.nav .logo{
    flex:0 0 auto;
    margin-right:clamp(12px,2.4vw,28px);
  }
  header.nav .nav-toggle{
    display:flex !important;
    margin-left:auto;
  }
  header.nav .links{ display:none !important; }
  .mobile-menu a{ white-space:nowrap; word-spacing:.08ch; }
  .mission-right{ order:1; }
  .mission-left { order:2; }

  /* Phase banner plein viewport, centrée */
  .phase-banner,
  .banner,
  header .banner,
  header.nav .banner{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    position:fixed;
    top:var(--header-h);
    left:0;
    right:0;
    width:100% !important;
    max-width:100% !important;
    margin:0 !important;
    padding-left:clamp(8px,2vw,16px) !important;
    padding-right:clamp(8px,2vw,16px) !important;
    box-sizing:border-box !important;
  }

  .phase-banner > .container,
  .banner > .container{
    width:100% !important;
    max-width:100% !important;
    padding:0 !important;
    margin:0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
  }

  .phase-banner * ,
  .banner *{ text-align:center !important; margin:0 !important; }
}

/* =========================================================
   LARGEUR COMMUNE 98% — de 1024px à 641px (PAGE ABOUT)
   ========================================================= */
@media (max-width:1024px) and (min-width:641px){

  .container,
  .container-narrow,
  .page-hero .container,
  .advisors-section .container,
  .origin-layout,
  .mission-layout,
  .vision-layout,
  .founders-section .container,
  .join-section,
  .footer-grid{
    max-width:98% !important;
    margin-inline:auto !important;   /* mêmes marges gauche / droite */
  }
}

/* ===============================
   MOBILE (768px)
   =============================== */
@media (max-width:768px){

  /* 1 colonne + empilement contrôlé */
  .founder-layout{
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto !important; /* title, message, photo */
    row-gap:24px;
    column-gap:0;
    align-items:start;
  }

  /* 1) Titre en haut */
  .founder-title{
    grid-column:1 !important;
    grid-row:1 !important;
    text-align:center !important;
    margin:0 !important;
  }

  /* 2) Message au-dessus de la photo */
  .founder-message{
    grid-column:1 !important;
    grid-row:2 !important;         /* <-- message avant */
    padding:16px 18px !important;  /* comme ton style actuel mobile */
  }

  /* 3) Photo en dessous */
  .founder-photo{
    grid-column:1 !important;
    grid-row:3 !important;         /* <-- photo après */
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:14px;
  }

  .founder-photo img{
    width:75%;
    max-width:260px;
    height:auto;
    display:block;
  }

  .founder-links{ justify-content:center; }
  .founder-message p{ font-size:.98rem; margin:0; }
}
/* ===============================
   MOBILE (≤640px)
   =============================== */
@media (max-width:640px){

  :root{ --gutter:12px; }

  .container,
  .container-narrow,
  .origin-layout,
  .mission-layout,
  .vision-layout,
  .page-hero .container,
  .advisors-section .container,
  .founders-section .container,
  header.nav .inner{
    padding-inline:12px !important;
  }

.section{     padding-inline:0 !important;   }
.page-hero h1{   font-size:clamp(1.8rem,6vw,2.4rem)!important;   text-align:left; }
.page-hero p{    font-size:0.95rem !important;    line-height:1.5;    max-width:90%;    text-align:left;  }

.origin-layout,
.mission-layout,
.vision-layout{
    gap:24px;
  }

.origin-section h2,
.mission-section h2,
.vision-section h2{
    font-size:clamp(1.4rem,4vw,1.8rem)!important;
  }

.origin-section p,
.mission-section p,
.vision-section p{
    margin-bottom:6px !important;
  }

header.nav .links{ display:none !important; }
header.nav .nav-toggle{ display:flex !important; margin-left:auto; }
header.nav .inner{ display:flex; align-items:center; }
header.nav .logo{ margin-right:auto; }

  /* Renfort bannière mobile (plein viewport) */
.banner,header .banner,header.nav .banner{  width:100vw !important; max-width:none !important;
    margin-left:calc(50% - 50vw) !important; margin-right:calc(50% - 50vw) !important;
  }

.mission-section .mission-left .mission-image,
.vision-section .vision-right .vision-image{   aspect-ratio:var(--media-ar-mobile) !important;   max-height:clamp(220px,52vw,360px); }

  /* Advisors en rail */
.advisors-section .container{ overflow:hidden; }
.advisors-grid{ display:flex; align-items:center; gap:50px; width:max-content; animation:advisorsMarquee 20s linear infinite; }
.advisor-card{  flex:0 0 auto;  min-width:120px;  display:flex;  flex-direction:column;
    align-items:center;  gap:12px;  text-align:center;}
.advisor-card--clone{ display:flex; flex-direction: column;  align-items: center;      gap: 12px;     }
.advisor-logo{  width:120px;  max-width:40vw; aspect-ratio:3 / 1; height: 40px;
    margin-bottom:12px;  display:flex; align-items:center;  justify-content:center;}
.advisor-logo img{  width:100%;  height:100%;  object-fit:contain;  }
.advisor-card span{ font-size:.8rem; white-space:nowrap; line-height:1.3; margin-top:0;  padding-top: 0;  }

/* rail infini */
@keyframes advisorsMarquee{  0%{   transform:translateX(0); }  100%{ transform:translateX(-50%); }}

.join-section{   padding:32px var(--gutter) 24px; }
.join-card{   padding:24px 18px;  }
.join-content h2{    font-size:clamp(1.6rem,5vw,2.1rem);   margin-bottom:10px; }
.join-content p{   font-size:0.95rem;   margin-bottom:18px;   line-height:1.6;  }
.join-actions{    gap:10px;   }
.join-actions .btn{   padding:8px 16px;    font-size:13px;  }
   
/* Footer */   
 .footer-grid{grid-template-columns:1fr}       
   }  
   
/* =========================
   UTILITIES
   ========================= */
.animate-on-scroll{ will-change: transform, opacity; }
.highlight{ color: #1aa37a; }
