/* =========================
   Another PlastiK — GLOBAL
   ========================= */
/* Font (primary) */
@import url('https://api.fontshare.com/v2/css?f[]=cabinet-grotesk@400,500,700&display=swap');

/* =========================
   Variables
   ========================= */
:root{
  /* Brand */
  --primary:#1F3D32;
  --primary-light:#2A4F42;
  --primary-dark:#16291F;

  --accent:#2C5F6F;
  --accent-light:#3A7A8C;
  --accent-soft:rgba(44,95,111,.12);

  /* Neutrals */
  --bg:#FFFFFF;
  --bg-sand:#F4EBE0;
  --bg-light:#F8FAFC;

  --text:#2A2A2A;
  --text-muted:#6B7280;

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

  /* Layout */
  --container:1380px;
  --container-narrow:980px;
  --gutter:20px;

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

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

  /* Media ratios */
  --media-ar-desktop:5/3.9;
  --media-ar-tablet:5/3.8;
  --media-ar-mobile:5/3.3;

  /* SDG */
  --sdg-gap:16px;
  --sdg-shift:8%;
}

/* =========================
        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{
  min-height:100vh; display:flex; flex-direction:column;
  margin:0; font-family:"Cabinet Grotesk",system-ui,sans-serif;
  font-size:17px; line-height:1.75; font-weight:400; letter-spacing:-.01em;
  color:var(--text); background:transparent; overflow-x:hidden; -webkit-font-smoothing:antialiased;
}
body.menu-open{overflow:hidden}
main{flex:1 0 auto; padding-top:calc(var(--header-h) + var(--banner-h));}
footer{margin-top:auto;}

.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-inline:var(--gutter);}

/* =========================
            Buttons
   ========================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; text-align:center;
  height:45px; width:180px; padding:0 16px; gap:8px; cursor:pointer; text-decoration:none;
  font-weight:600; font-size:.9rem; letter-spacing:.3px; border-radius:5px;
  color:#fff; background:var(--primary); border:2.5px solid var(--primary);
  box-shadow:none; transition:all .25s ease;
}
.btn:hover,.btn:focus{background:#fff;color:var(--primary);transform:translateY(-1px);}
.btn:active{transform:translateY(0);background:var(--primary);color:#fff;}
.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 / Nav
   ========================= */
header.nav{  position:fixed; inset:0 0 auto 0; height:var(--header-h); z-index:10001;  width:100%; max-width:100vw; 
  overflow-x:clip; background:var(--bg);  box-shadow:0 2px 8px rgba(0,0,0,.1); transition:box-shadow .3s;}
body.scrolled-nav header.nav{box-shadow:0 6px 18px rgba(0,0,0,.12);}
header.nav .inner{  height:100%; max-width:var(--container); margin:0 auto; 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;}

/* Desktop links */
header.nav .links{  display:flex; align-items:center; gap:20px; height:100%; position:relative; top:3px; margin-left:auto;}
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:color .2s,transform .2s;
}
header.nav .links a::after{  content:""; position:absolute; left:0; bottom:-3px; width:0; 
   height:2px; background:var(--primary); transition:width .25s;}
header.nav .links a:hover::after, header.nav .links a:focus::after{width:100%;}

/* 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 header.nav .nav-toggle span:first-child{transform:translateY(0) rotate(45deg)}
body.menu-open header.nav .nav-toggle span:last-child{transform:translateY(0) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{  position:fixed;  inset:0;  z-index:10002;  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;}

/* =========================
   HERO
   ========================= */
.hero{position:relative; width:100%; min-height:560px; height:var(--hero-h-desktop); overflow:hidden;}
.hero-video{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; object-fit:cover; object-position:center center;}
.hero-overlay{
  position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; align-items:flex-start; justify-content:center;
  text-align:left; padding:0; background:rgba(0,0,0,.25);
}
.hero-container{  width:100%;  max-width:var(--container);
  margin:0 auto;  padding-inline:var(--gutter);
}
.hero-title{
  color:#fff; font-weight:600; font-size:clamp(2.4rem,5.4vw,4.6rem); line-height:1.08; margin:0 0 8px; 
   max-width:1000px; text-wrap:balance;}
.hero-title span{display:block; white-space:nowrap; letter-spacing:-.2px;}
.hero-cta{position:relative; display:flex; flex-wrap:wrap; gap:20px; justify-content:center; z-index:2; margin-top:12px;}
.hero-hint{text-align:center; font-size:.95rem; color:var(--text-muted); font-weight:500; margin:7px 0 30px; letter-spacing:.2px;}

/* =========================
      Recognition Bar
   ========================= */
.recognition-bar{padding:15px 0; background:linear-gradient(180deg,#f8fafc 0%,#edf2f7 100%);}
.recognition-title{text-align:center; font-size:1.35rem; font-weight:600; color:var(--text); margin-bottom:6px; letter-spacing:.05em; transform:translateY(6px);}
.recognition-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:60px; text-align:center; max-width:680px; margin:0 auto;}
.recognition-item{display:flex; flex-direction:column; align-items:center; gap:4px;}
.recognition-logo{height:100px; display:flex; align-items:center; justify-content:center; margin-bottom:4px;}
.recognition-logo img{max-height:100%; max-width:220px; width:auto; height:auto; object-fit:contain;}
.recognition-item span{font-size:.9rem; color:var(--text-muted); font-weight:500; line-height:1.3;}

/* =========================
   Discover More/ Problem
   ========================= */
.crisis-section{background:#fff; padding:30px 0; position:relative;}
.crisis-layout{max-width:1380px; margin:0 auto; padding-left:0 !important; padding-right:0 !important;
               display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center;}
.crisis-col.text{order:1;  display:flex; flex-direction:column; justify-content:center; align-self:stretch; max-width:680px;}
.crisis-col.cards{order:2;}
.crisis-header{text-align:left; margin-bottom:0; max-width:680px;}
.crisis-header h2{font-size:clamp(2rem,3.6vw,2.8rem); color:var(--primary); font-weight:600; margin:0 0 6px;}
.crisis-text{text-align:justify; text-align-last:left; font-size:1.05rem; line-height:1.85; color:var(--text); letter-spacing:.1px; }
.crisis-text p{margin:0 0 6px;}
.stats-grid{  display:grid; grid-template-columns:repeat(2,minmax(200px,1fr)); padding-left:0 !important;padding-right:0 !important; 
   gap:20px; max-width:680px; align-items:stretch; margin-left:auto;
}
.stat-card{ background: linear-gradient(180deg,#f8fafc 0%,#edf2f7 100%); padding:20px 18px; text-align:center; 
   transition:transform .3s, box-shadow 0.3s ease; position:relative; border-radius:5px;}
.stat-number{font-size:clamp(1.8rem,3.6vw,2.8rem); font-weight:500; color:var(--primary); line-height:1.1; margin-bottom:10px; display:block;}
.stat-label{font-size:.95rem; color:var(--text); font-weight:500; line-height:1.6; display:block; margin-top:6px;}
.stat-card small{position:absolute; bottom:8px; left:16px; font-size:.68rem; color:var(--text-muted); letter-spacing:.3px;}
.stat-card:nth-child(1), .stat-card:nth-child(2){aspect-ratio:1/1; display:flex; flex-direction:column; justify-content:center;}
.stat-card:nth-child(3){grid-column:1/-1; aspect-ratio:auto; min-height:140px;}
.stats-nav{display:none; gap:12px; justify-content:center; align-items:center; margin-top:18px;}
.stat-source{  position:absolute;  bottom:8px;  left:16px;  font-size:.68rem;  letter-spacing:.3px;}
.stat-source a{  color:var(--text-muted);  text-decoration:none;  cursor:pointer;  transition:color .2s ease, opacity .2s ease;}
/* Hover discret, pas de reveal */
.stat-source a:hover{  color:var(--accent);  opacity:.85;}

.stats-scrollbar{ display:none;}

/* =========================
         How it works 
   ========================= */
.how-section{padding:30px 0; background:var(--bg); position:relative; overflow-x:clip}
.how-layout{  max-width:1380px; margin:0 auto; padding-left:0 !important; padding-right:0 !important; 
              display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center;}

/* CARROUSEL (style identique à Solution) */
.how-carousel{ order:1;  position:relative;  overflow:hidden;  width:100%;  max-width:680px;
  aspect-ratio:var(--media-ar-desktop);  max-height:475px;   border-radius:5px;}
.how-carousel .track{display:flex; height:100%; transition:transform .6s ease}
.how-carousel .slide{min-width:100%; height:100%; position:relative}
.how-carousel img{width:100%; height:100%; display:block; object-fit:cover}
.how-carousel .nav{  position:absolute; bottom:16px; left:50%; z-index:5; width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; background:#1F3D32; color:#fff; 
  border:none; cursor:pointer; transition:transform .25s, opacity .25s;
}
.how-carousel .nav.prev{transform:translateX(calc(-50% - 28px))}
.how-carousel .nav.next{transform:translateX(calc(-50% + 28px))}
.how-carousel .nav.prev:hover{transform:translateX(calc(-50% - 28px)) scale(1.05)}
.how-carousel .nav.next:hover{transform:translateX(calc(-50% + 28px)) scale(1.05)}

/* CONTENU */
.how-content{order:2; text-align:left; max-width:680px; display:flex; flex-direction:column;
          justify-content:center;   align-self:stretch;    margin-bottom:0;     }
.how-header h2{font-size:clamp(2rem,3.6vw,2.8rem); color:var(--primary); font-weight:600; margin:0 0 6px;}
.how-story{font-size:1.05rem; line-height:1.85; color:var(--text); letter-spacing:.1px; text-align:justify; text-align-last:left; margin:0 0 8px;  }
.how-story p{margin:0 0 6px;}
/* CTA (équivalent “rythme” = texte puis action) */
.how-content .btn{  align-self:flex-start;  margin-top:12px;}

/* =========================
          Solution
   ========================= */
.solution{background:#fff; padding:30px 0; position:relative; overflow-x:clip;}
.solution-split{max-width:1380px; margin:0 auto; padding-left:0 !important; padding-right:0 !important; 
                display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:40px; align-items:center;}
.solution-gallery{  order:2;  position:relative;  overflow:hidden;  width:100%;
  max-width:680px; aspect-ratio:var(--media-ar-desktop);  max-height:475px;   
  border-radius:5px;  justify-self:end;}
.solution-gallery .track{display:flex; height:100%; transition:transform .6s ease;}
.solution-gallery .slide{min-width:100%; height:100%; position:relative;}
.solution-gallery img{width:100%; height:100%; display:block; object-fit:cover;}
.solution-gallery .nav{
  position:absolute; bottom:16px; left:50%; z-index:5; width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; background:#1F3D32; color:#fff; border:none; cursor:pointer; transition:transform .25s, opacity .25s;
}
.solution-gallery .nav.prev{transform:translateX(calc(-50% - 28px));}
.solution-gallery .nav.next{transform:translateX(calc(-50% + 28px));}
.solution-gallery .nav.prev:hover{transform:translateX(calc(-50% - 28px)) scale(1.05);}
.solution-gallery .nav.next:hover{transform:translateX(calc(-50% + 28px)) scale(1.05);}
.solution-copy{order:1; text-align:left; max-width:680px; display:flex; flex-direction:column;
          justify-content:center;   align-self:stretch;    margin-bottom:0;     }
.solution-copy h2{font-size:clamp(2rem,3.6vw,2.8rem); color:var(--primary); margin:0 0 6px; font-weight:600;}
.solution-copy p{font-size:1.05rem; line-height:1.85; color:var(--text); letter-spacing:.1px; text-align:justify; text-align-last:left; margin:0 0 8px;  }
.solution-bullets{list-style:none; padding:0; margin:0}
.solution-bullets li{position:relative; padding-left:28px; margin-bottom:6px; color:var(--text); font-weight:400; font-size:1.05rem; line-height:1.85; }
.solution-bullets li::before{content:""; position:absolute; left:0; top:.55em; width:6px; height:6px; background:var(--primary);}
.solution-copy .btn{ align-self:flex-start;   margin:12px 0 0;}

/* =========================
         Planet First
   ========================= */
.planet-first { background:#fff; padding:30px 0; position:relative; }
.planet-first-split{  display:grid; grid-template-columns:1fr 1fr; gap:40px;  max-width:1380px; 
                    margin:0 auto; align-items:center; padding-left:0 !important; padding-right:0 !important;}
.sdg-column{ position:relative; max-width:680px; width:100%; aspect-ratio: var(--media-ar-desktop);
  border-radius:5px; background:#fff; overflow:hidden;
}
.sdg-icons{  display:grid; grid-template-columns:repeat(3, 1fr); grid-template-rows:repeat(3, 1fr);
  gap:var(--sdg-gap); margin:0; padding: 0; width:100%; height:100%;
  box-sizing:border-box;  transform: translateY(var(--sdg-shift)); }
.sdg-icons li{  align-self: stretch; justify-self: stretch; display: flex; width: 100%; height: 100%;}
.sdg-icons img{  width: 100%; height: 100%;  object-fit: cover;  border-radius: 5px;  transition: transform .2s ease, box-shadow .2s ease;}
.text-column{max-width:680px; justify-self:end; display:flex; flex-direction:column; justify-content:center;  align-self:stretch;      }
.text-column h2{color:var(--primary); font-size:clamp(2rem,3.6vw,2.8rem); font-weight:600; margin:0 0 6px}
.lead-text{text-align:justify; text-align-last:left; font-size:1.05rem; line-height:1.85; color:var(--text); letter-spacing:.1px; margin:0 0 8px;}
.text-column .cta-wrap{ align-self:flex-start;  margin:12px 0 0;}

/* =========================
   CTA Section
   ========================= */
.cta-section{  background: transparent;  padding: 48px var(--gutter);    max-width: var(--container);   margin: 0 auto;   }
.cta-section .container-narrow{  position: relative;  z-index: 1;  max-width: 980px;    margin: 0 auto;
  padding: 32px 28px;  background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
  color: #fff; border-radius: 5px;  box-shadow: 0 16px 36px rgba(0,0,0,.12);  overflow: hidden;  text-align: center;}
.cta-section .container-narrow::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;  }
.cta-section h2{  font-size:clamp(2.2rem,3.8vw,3.1rem);  font-weight:700;  margin:0 0 12px;}
.cta-section .container-narrow > p{  font-size:1.05rem;  margin:0 0 24px;  opacity:.95;}
.waitlist-form{  display:flex;  gap:12px;  max-width:640px;  margin:0 auto 14px;  flex-wrap:wrap;  justify-content:center;}
.waitlist-form input{  flex:1;  min-width:230px;  padding:10px 14px;  border:none;  border-radius:5px;
  font-size:14px;  font-family:"Cabinet Grotesk",sans-serif; box-shadow:0 1px 4px rgba(0,0,0,.10);}
.waitlist-form button{  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);}
.waitlist-form button:hover,.waitlist-form button:focus{background:#fff;color:var(--accent-light);transform:translateY(-1px);}
.waitlist-form button:active{transform:translateY(0);background:#356f83 ;color:#fff;}
.waitlist-form button.outline{background:transparent;color:var(--accent-light);border:2.5px solid var(--accent-light);}
.waitlist-form button.outline:hover{background:#356f83;color:#fff;}

.form-success{  display:none;  background:rgba(72,187,120,.18);  border:2px solid rgba(72,187,120,.45);  color:#fff;  padding:14px 18px;
  border-radius:5px;  margin-top:14px;  font-weight:600;  animation:slideIn .5s ease;}
.form-success.show{display:block;}

.social-proof{  font-size:.9rem;  opacity:.85;  margin-top:8px;}
.trust-badges{  display:flex;  gap:12px;  justify-content:center;  flex-wrap:wrap;  margin-top:20px;}
.trust-badge{  background:rgba(255,255,255,.16);  backdrop-filter:blur(8px);  padding:8px 14px;
  border-radius:5px;  font-size:.85rem;  font-weight:600;  transition:transform .25s, background .25s;}
.trust-badge:hover{  background:rgba(255,255,255,.22);  transform:translateY(-2px);}


/* =========================
           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}
.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);
}

/* =========================
   Desktop Shared Alignment
   ========================= */
.container,.container-narrow,.crisis-layout,.how-layout,.solution-split,.planet-first-split,.footer-grid{
  max-width:1380px; margin:0 auto; padding-inline:20px; box-sizing:border-box;
}

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

/* =========================================================
   TABLETTES / ≤1024px
   ========================================================= */
@media (max-width:1024px){
  :root{
    --gutter:12px; --btnR-w:clamp(120px,25vw,180px); 
     --btnR-h:40px; --btnR-fs:.9rem; --btnR-padX:12px;
    --sdg-shift:8%;
  }

  .section,.crisis-section,.how-section,.solution,.planet-first{padding-inline:0}

  .crisis-layout,.how-layout,.solution-split,.planet-first-split{
    display:flex; flex-direction:column; gap:16px; align-items:stretch;
  }

  .crisis-header h2,
  .how-header h2,
  .solution-copy h2,
  .planet-header h2,
  .text-column h2{
    font-size:clamp(1.8rem,3.4vw,2.4rem)!important;
  }

  /* --- Header --- */
  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}

  /* --- Hero & CTA --- */
  .hero{height:var(--hero-h-tablet); min-height:480px}
 
   /* hero-container garde padding-inline:var(--gutter) */
  .hero-title{font-size:clamp(1.6rem,5vw,2.4rem)}
  .hero-cta .btn,
  .solution .btn,
  .planet-first .btn,
  .cta-wrap .btn{
    width:var(--btnR-w)!important; 
    height:var(--btnR-h)!important; 
    font-size:var(--btnR-fs)!important; 
    padding:0 var(--btnR-padX)!important; 
    border-width:2px;
  }
  .hero-cta{gap:12px}

  /* --- Stats : carrousel horizontal + barre custom --- */
  .crisis-section .container{padding-inline:var(--gutter) !important; }
  .crisis-col.text{ order:1; max-width:100% !important; width:100% !important;
    padding-inline:var(--gutter) !important; box-sizing:border-box; }
  .crisis-col.cards{  order:2;    display:flex;    flex-direction:column;    align-items:center;
    width:100%;  padding-inline:var(--gutter);  box-sizing:border-box;}

  .stats-grid{   display:flex !important;   flex-wrap:nowrap !important;  overflow-x:auto !important;   overflow-y:hidden !important;
    gap:16px !important;  width:100% !important;  padding:0 !important;  margin:0 !important; scroll-snap-type:x mandatory !important; 
    scroll-padding:0 !important;  -webkit-overflow-scrolling:touch !important;   scrollbar-width:none; }
  
 .stats-grid::-webkit-scrollbar{   display:none; }

 .stat-card{   flex:0 0 100% !important;   max-width:100% !important;   scroll-snap-align:center !important;
    scroll-snap-stop:always !important;   height:clamp(200px,45vw,280px) !important;   margin:0 !important;
    display:flex !important;    flex-direction:column !important;    justify-content:center !important;
    align-items:center !important;    gap:8px !important;    padding:24px 20px !important;
    border-radius:5px !important;    background:var(--bg-light) !important; }

  /* --- Barre carrousel custom, toujours visible --- */
  .stats-scrollbar{ display:block;  position:relative;  width:100%;    max-width:680px;  
    margin:10px auto 0;  height:8px;  box-sizing:border-box;    border-radius:0;  }
  .stats-scrollbar::before{   content:"";   position:absolute;   inset:0;   border-radius:0;   background:#E5E7EB; }
  .stats-scrollbar-thumb{
    position:absolute;
    inset-block:0;
    left:0;
    height:8px;
    border-radius:0;
    background:#9CA3AF;
    width:40%;
    transform:none;
    transition:left .2s linear, width .2s ease-out;
  }
 
  /* --- HOW --- */
  .how-content{   order:1 !important;    display:grid !important;    grid-template-columns:1fr !important;
    justify-items:start !important;    align-content:start !important;    row-gap:6px !important;
    width:100% !important;   max-width:100% !important; }
  .how-header,
  .how-header h2,
  .how-sub{  text-align:left !important;   margin:0 !important;   max-width:100% !important;   text-align:justify !important; }

  /* Image HOW : même ratio & hauteur que Solution */
  .step-title-text{font-size:1rem;}
  .step-number{width:36px; height:36px; font-size:1rem;}

  /* --- SOLUTION --- */
  .solution-copy{
    order:1 !important;
    text-align:left !important;
    margin:0 !important;
    max-width:100% !important;
    width:100% !important;
  }
  .solution-copy p,
  .solution-copy .lead-paragraph{
    max-width:100% !important;   width:100% !important;   word-break:normal;
    overflow-wrap:anywhere;   font-size:inherit !important;   line-height:inherit !important; }

  /* Image HOW : même ordre que sur desktop */
  .how-carousel{  order:2 !important;}

  /* Image SOLUTION : même ordre, rien de spécial ici */
  .solution-gallery{ order:2 !important; }

  /* HOW + SOLUTION : mêmes dimensions + mêmes marges */
  .how-carousel,
  .solution-gallery{
    width:100% !important;
    max-width:92% !important;   
    margin-inline:auto !important;
    aspect-ratio:var(--media-ar-tablet) !important;
    max-height:clamp(260px,46vw,420px);
    overflow:hidden;
    border-radius:5px;
  }

  /* --- PLANET FIRST / SDG --- */
  .planet-header{text-align:left}
  .text-column{
    text-align:left !important; order:-1;
    max-width:100% !important; width:100% !important; margin:0 auto !important;
  }
  .lead-text{max-width:100% !important; width:100% !important; font-size:inherit !important; line-height:inherit !important;}

  .sdg-column{margin-inline:auto !important;}
  .sdg-icons{margin-inline:auto !important;}
  .sdg-icons li{flex:unset !important;}
   
  /* --- Phase Banner — plein viewport, bien 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
   ========================================================= */
@media (max-width:1024px) and (min-width:641px){

  .container,
  .container-narrow,
  .hero-container {
    max-width:98% !important;
    margin-inline:auto !important;
  }
}

/* =========================================================
               Tablets étroites (≤768px)
   ========================================================= */
@media (max-width:768px){
  :root{ --sdg-shift:10%; }
}

/* =========================================================
   MOBILE / ≤640px
   ========================================================= */
@media (max-width:640px){
  :root{
    --btnM-w:clamp(110px,40vw,170px);
    --btnM-h:40px;
    --btnM-fs:.88rem;
    --btnM-padX:10px;
  }

  /* Layout paddings */
  .container,
  .container-narrow,
  .crisis-layout,
  .how-layout,
  .solution-split,
  .planet-first-split{
    padding-inline:10px;
  }

  .section,
  .crisis-section,
  .how-section,
  .solution,
  .planet-first{
    padding-inline:0;
  }

  .how-layout{gap:12px;}

  /* Typography */
  .hero-title{
    font-size:clamp(1.5rem,5.5vw,2.2rem);
    line-height:1.15;
  }

  .crisis-header h2,
  .how-header h2,
  .solution-copy h2,
  .planet-header h2,
  .text-column h2{
    font-size:clamp(1.4rem,4vw,1.8rem) !important;
  }

  /* HOW steps UI */
  .step-header{padding:14px 16px; gap:12px;}
  .step-number{width:32px; height:32px; font-size:.95rem;}
  .step-title-text{font-size:.95rem;}
  .step-content.active{padding:0 16px 16px;}
  .step-content p{font-size:1rem;}

  /* Carousels: HOW + SOLUTION — same size on mobile */
  .how-carousel,
  .solution-gallery{
    width:100% !important;
    max-width:92% !important;
    margin-inline:auto !important;

    aspect-ratio:var(--media-ar-mobile) !important;
    max-height:clamp(220px,52vw,360px) !important;

    overflow:hidden;
    border-radius:5px;
  }

  /* Safety: ensure slides/images fill the box */
  .how-carousel .track,
  .how-carousel .slide,
  .solution-gallery .track,
  .solution-gallery .slide{
    height:100%;
  }

  .how-carousel img,
  .solution-gallery img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
  }

  /* Header mobile */
  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;}

  /* Controlled hero video height */
  .hero{
    height:65vh !important;
    min-height:360px !important;
    max-height:420px !important;
  }

  /* CTA buttons mobile */
  .hero-cta{
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
    gap:6px;
  }

  .hero-cta .btn,
  .solution .btn,
  .planet-first .btn,
  .cta-wrap .btn{
    width:var(--btnM-w) !important;
    height:var(--btnM-h) !important;
    font-size:var(--btnM-fs) !important;
    padding:0 var(--btnM-padX) !important;
  }

  /* Banner full 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;
  }

  /* Recognition */
  .recognition-grid{
    grid-template-columns:repeat(2,1fr);
    gap:20px !important;
    max-width:100% !important;
  }
  .recognition-logo{height:80px;}
  .recognition-logo img{
    max-width:140px !important;
    height:auto;
    object-fit:contain;
  }

  /* Planet-First + SDG */
  .text-column,
  .lead-text{
    max-width:100% !important;
    width:100% !important;
  }
  .sdg-column,
  .sdg-icons{
    margin-inline:auto !important;
  }
  .sdg-icons li{flex:unset !important;}

  /* CTA section */
  .cta-section{padding:32px var(--gutter);}
  .cta-section .container-narrow{padding:24px 18px;}
  .waitlist-form input{min-width:200px; padding:8px 12px; font-size:13px;}
  .waitlist-form button{padding:8px 16px; font-size:13px;}
  .social-proof{font-size:.85rem; margin-top:6px;}
  .trust-badges{gap:10px; margin-top:16px;}
  .trust-badge{padding:6px 12px; font-size:.8rem;}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;}
}

/* =========================
   UTILITIES
   ========================= */
.animate-on-scroll{ will-change: transform, opacity; }
