@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=DM+Sans:wght@300;400;500;600&display=swap');
:root{--blue:#005697;--blue-dark:#003f70;--blue-light:#0070c4;--gold:#BFB778;--gold-light:#d4ce99;--gold-dark:#a09856;--white:#fff;--off-white:#f7f8fa;--gray-100:#f0f2f5;--gray-200:#e2e6ec;--gray-400:#9aa3b2;--gray-600:#5a6478;--gray-800:#2c3345;--text:#1e2535;--shadow-sm:0 2px 8px rgba(0,86,151,.08);--shadow-md:0 6px 24px rgba(0,86,151,.12);--shadow-lg:0 16px 48px rgba(0,86,151,.16);--radius:12px;--radius-lg:20px;--transition:.3s cubic-bezier(.4,0,.2,1);--font-display:'Playfair Display',Georgia,serif;--font-body:'DM Sans',system-ui,sans-serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--text);background:var(--white);line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.section--alt{background:var(--off-white)}
.section--blue{background:var(--blue);color:var(--white)}
.section--dark{background:var(--gray-800);color:var(--white)}
.badge{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dark);background:rgba(191,183,120,.12);border:1px solid var(--gold-light);padding:4px 14px;border-radius:40px;margin-bottom:16px}
.section-header{max-width:680px;margin-bottom:56px}
.section-header h2{font-family:var(--font-display);font-size:clamp(1.9rem,3.5vw,2.8rem);line-height:1.2;color:var(--blue-dark);margin-bottom:16px}
.section-header p{font-size:1.05rem;color:var(--gray-600)}
.section-header--centered{max-width:700px;margin-left:auto;margin-right:auto;text-align:center}
.section--blue .section-header h2,.section--dark .section-header h2{color:var(--white)}
.section--blue .section-header p,.section--dark .section-header p{color:rgba(255,255,255,.75)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:8px;font-size:.95rem;font-weight:600;transition:var(--transition);white-space:nowrap}
.btn--primary{background:var(--blue);color:var(--white);box-shadow:0 4px 16px rgba(0,86,151,.3)}
.btn--primary:hover{background:var(--blue-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,86,151,.35)}
.btn--gold{background:var(--gold);color:var(--gray-800)}
.btn--gold:hover{background:var(--gold-light);transform:translateY(-2px)}
.btn--outline{border:2px solid var(--blue);color:var(--blue)}
.btn--outline:hover{background:var(--blue);color:var(--white)}
.btn--outline-white{border:2px solid rgba(255,255,255,.6);color:var(--white)}
.btn--outline-white:hover{background:rgba(255,255,255,.15)}
.btn--sm{padding:9px 20px;font-size:.88rem}
.btn--lg{padding:17px 36px;font-size:1.05rem}
.card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition);border:1px solid var(--gray-200)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card__img{width:100%;height:220px;object-fit:cover;background:var(--gray-100)}
.card__body{padding:28px}
.card__tag{font-size:.78rem;font-weight:600;color:var(--gold-dark);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.card__title{font-family:var(--font-display);font-size:1.2rem;margin-bottom:10px;color:var(--blue-dark);line-height:1.3}
.card__text{font-size:.92rem;color:var(--gray-600);margin-bottom:20px}
.card__footer{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-top:1px solid var(--gray-100);font-size:.85rem;color:var(--gray-400)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.header{position:sticky;top:0;z-index:100;background:var(--white);border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.header__logo{display:flex;align-items:center;gap:0}
.header__logo-img{height:48px;width:auto}
.header__logo-text{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--blue);line-height:1.2}
.header__logo-sub{font-size:.68rem;color:var(--gray-400);font-family:var(--font-body);font-weight:400;display:block}
.nav{display:flex;align-items:center;gap:4px}
.nav__item{position:relative}
.nav__link{display:flex;align-items:center;gap:4px;padding:8px 14px;font-size:.9rem;font-weight:500;color:var(--gray-800);border-radius:8px;transition:var(--transition)}
.nav__link:hover,.nav__link.active{color:var(--blue);background:rgba(0,86,151,.06)}
.nav__link svg{width:14px;height:14px;transition:transform .25s}
.nav__item:hover .nav__link svg{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:240px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--gray-200);padding:8px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:var(--transition);z-index:200}
.nav__item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown__link{display:block;padding:10px 14px;font-size:.88rem;color:var(--gray-600);border-radius:8px;transition:var(--transition)}
.dropdown__link:hover{background:rgba(0,86,151,.06);color:var(--blue)}
.header__actions{display:flex;align-items:center;gap:12px}
.header__lang{font-size:.85rem;font-weight:600;color:var(--gray-600);padding:6px 12px;border:1px solid var(--gray-200);border-radius:6px;cursor:pointer;transition:var(--transition)}
.header__lang:hover{border-color:var(--blue);color:var(--blue)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.hamburger span{display:block;width:24px;height:2px;background:var(--blue);border-radius:2px;transition:var(--transition)}
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;background:linear-gradient(135deg,#002b4a 0%,#005697 55%,#0072c6 100%)}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.hero__decor{position:absolute;right:-120px;top:50%;transform:translateY(-50%);width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(191,183,120,.15) 0%,transparent 70%);pointer-events:none}
.hero__content{position:relative;z-index:2;max-width:760px;color:var(--white)}
.hero__badge{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);background:rgba(191,183,120,.15);border:1px solid rgba(191,183,120,.3);padding:6px 16px;border-radius:40px;margin-bottom:28px}
.hero__badge span{width:6px;height:6px;background:var(--gold);border-radius:50%;animation:pulse 2s infinite}
.hero h1{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,4rem);line-height:1.1;margin-bottom:24px;color:var(--white)}
.hero h1 em{color:var(--gold-light);font-style:normal}
.hero__sub{font-size:clamp(1rem,1.8vw,1.15rem);color:rgba(255,255,255,.8);max-width:580px;margin-bottom:40px;line-height:1.7}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.5);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;animation:bounce 2.5s infinite}
.hero__scroll-line{width:1px;height:40px;background:rgba(255,255,255,.3)}
.stats-bar{background:var(--white);border-bottom:1px solid var(--gray-200)}
.stats-bar__inner{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:32px 24px;text-align:center;border-right:1px solid var(--gray-100);transition:var(--transition)}
.stat-item:last-child{border-right:0}
.stat-item:hover{background:rgba(0,86,151,.03)}
.stat-item__num{font-family:var(--font-display);font-size:2.4rem;font-weight:700;color:var(--blue);line-height:1;margin-bottom:6px}
.stat-item__label{font-size:.85rem;color:var(--gray-600)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about__img{width:100%;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(0,86,151,.08),rgba(191,183,120,.15));aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:5rem;color:var(--gray-400)}
.about__badge-float{background:var(--gold);color:var(--gray-800);padding:20px 28px;border-radius:var(--radius);box-shadow:var(--shadow-md);font-weight:700;text-align:center;margin-top:20px;display:inline-block}
.about__badge-float strong{display:block;font-size:2rem;font-family:var(--font-display)}
.about__badge-float span{font-size:.82rem}
.about__values{margin-top:40px;display:flex;flex-direction:column;gap:16px}
.about__value{display:flex;gap:16px;align-items:flex-start}
.about__value-icon{flex-shrink:0;width:44px;height:44px;background:rgba(0,86,151,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.about__value h4{font-size:.95rem;font-weight:600;color:var(--blue-dark);margin-bottom:2px}
.about__value p{font-size:.87rem;color:var(--gray-600)}
.project-card__img{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,var(--blue-dark),var(--blue-light));display:flex;align-items:center;justify-content:center;font-size:2.5rem;border-radius:var(--radius) var(--radius) 0 0;overflow:hidden;min-height:180px}
.project-card__zone{font-size:.72rem;padding:3px 10px;background:rgba(0,86,151,.07);color:var(--blue);border-radius:20px;font-weight:500;display:inline-block;margin:3px 3px 0 0}
.project-card__dates{font-size:.82rem;color:var(--gray-400);margin-bottom:12px}
.network-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:36px;transition:var(--transition);position:relative;overflow:hidden}
.network-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--gold))}
.network-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.network-card__icon{font-size:2.5rem;margin-bottom:20px}
.network-card__title{font-family:var(--font-display);font-size:1.25rem;color:var(--blue-dark);margin-bottom:12px}
.network-card__text{font-size:.9rem;color:var(--gray-600);margin-bottom:24px;line-height:1.7}
.cta-banner{background:linear-gradient(135deg,var(--blue-dark),var(--blue));border-radius:var(--radius-lg);padding:60px;text-align:center;color:var(--white);position:relative;overflow:hidden}
.cta-banner::after{content:'';position:absolute;bottom:-80px;right:-80px;width:300px;height:300px;border-radius:50%;background:rgba(191,183,120,.1)}
.cta-banner h2{font-family:var(--font-display);font-size:2rem;margin-bottom:16px}
.cta-banner p{color:rgba(255,255,255,.75);max-width:500px;margin:0 auto 32px}
.cta-banner__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.team-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);text-align:center;transition:var(--transition)}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.team-card__avatar{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--blue-dark),var(--blue-light));display:flex;align-items:center;justify-content:center;font-size:3rem;color:rgba(255,255,255,.6);max-height:200px}
.team-card__body{padding:24px}
.team-card__name{font-family:var(--font-display);font-size:1.05rem;color:var(--blue-dark);margin-bottom:4px}
.team-card__role{font-size:.85rem;color:var(--gold-dark);font-weight:600}
.form-group{margin-bottom:24px}
.form-label{display:block;font-size:.88rem;font-weight:600;color:var(--gray-800);margin-bottom:8px}
.form-input,.form-select,.form-textarea{width:100%;padding:13px 16px;border:1.5px solid var(--gray-200);border-radius:10px;font-family:var(--font-body);font-size:.95rem;color:var(--text);background:var(--white);transition:var(--transition);outline:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,86,151,.1)}
.form-textarea{resize:vertical;min-height:120px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-hint{font-size:.8rem;color:var(--gray-400);margin-top:4px}
.page-hero{background:linear-gradient(135deg,var(--blue-dark),var(--blue));padding:80px 0 60px;color:var(--white)}
.page-hero__breadcrumb{display:flex;align-items:center;gap:8px;font-size:.82rem;color:rgba(255,255,255,.6);margin-bottom:20px}
.page-hero h1{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);margin-bottom:16px}
.page-hero p{color:rgba(255,255,255,.75);font-size:1.05rem;max-width:580px}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.impact-item{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:32px 24px;text-align:center;transition:var(--transition)}
.impact-item:hover{background:rgba(255,255,255,.12)}
.impact-item__num{font-family:var(--font-display);font-size:2.6rem;font-weight:700;color:var(--gold-light);margin-bottom:8px}
.impact-item__label{font-size:.88rem;color:rgba(255,255,255,.75)}
.footer{background:var(--gray-800);color:var(--white);padding:72px 0 0}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.footer__desc{font-size:.9rem;color:rgba(255,255,255,.55);line-height:1.7;max-width:280px;margin-bottom:24px}
.footer__social{display:flex;gap:12px}
.footer__social a{width:38px;height:38px;background:rgba(255,255,255,.08);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:var(--transition)}
.footer__social a:hover{background:var(--blue);color:var(--white)}
.footer__col h4{font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);margin-bottom:20px}
.footer__links{display:flex;flex-direction:column;gap:10px}
.footer__links a{font-size:.88rem;color:rgba(255,255,255,.55);transition:var(--transition)}
.footer__links a:hover{color:var(--white)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding:24px 0;display:flex;align-items:center;justify-content:space-between;font-size:.82rem;color:rgba(255,255,255,.35)}
.tabs{display:flex;gap:4px;border-bottom:2px solid var(--gray-200);margin-bottom:40px}
.tab-btn{padding:12px 20px;font-size:.9rem;font-weight:600;color:var(--gray-600);border-bottom:2px solid transparent;margin-bottom:-2px;transition:var(--transition)}
.tab-btn.active{color:var(--blue);border-bottom-color:var(--blue)}
.tab-btn:hover{color:var(--blue)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.toast{position:fixed;bottom:32px;right:32px;background:var(--blue-dark);color:var(--white);padding:16px 24px;border-radius:10px;box-shadow:var(--shadow-lg);font-size:.9rem;font-weight:500;z-index:9999;transform:translateY(20px);opacity:0;transition:var(--transition)}
.toast.show{transform:none;opacity:1}
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px}
.filter-btn{padding:8px 18px;border-radius:40px;font-size:.85rem;font-weight:600;border:1.5px solid var(--gray-200);color:var(--gray-600);transition:var(--transition);cursor:pointer;background:var(--white)}
.filter-btn.active,.filter-btn:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}
.pub-card{display:flex;gap:20px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:24px;transition:var(--transition)}
.pub-card:hover{box-shadow:var(--shadow-md)}
.pub-card__icon{flex-shrink:0;width:56px;height:56px;background:rgba(0,86,151,.08);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.8rem}
.pub-card__title{font-family:var(--font-display);font-size:1rem;color:var(--blue-dark);margin-bottom:6px}
.pub-card__meta{font-size:.82rem;color:var(--gray-400);margin-bottom:10px}
.pub-card__text{font-size:.88rem;color:var(--gray-600)}
.timeline{position:relative;padding-left:32px}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gray-200)}
.timeline-item{position:relative;padding-bottom:48px}
.timeline-item::before{content:'';position:absolute;left:-37px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--blue);border:3px solid var(--white);box-shadow:0 0 0 3px var(--blue-light)}
.timeline-item__year{font-size:.8rem;font-weight:700;color:var(--gold-dark);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.timeline-item__title{font-family:var(--font-display);font-size:1.1rem;color:var(--blue-dark);margin-bottom:8px}
.timeline-item__text{font-size:.9rem;color:var(--gray-600)}
.animate-on-scroll{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.animate-on-scroll.visible{opacity:1;transform:none}
.animate-delay-1{transition-delay:.1s}
.animate-delay-2{transition-delay:.2s}
.animate-delay-3{transition-delay:.3s}


/* Partners strip */
.partners-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:20px;align-items:stretch}
.partner-logo{min-height:96px;background:var(--white);border:1px solid var(--gray-200);border-radius:18px;padding:18px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:var(--transition)}
.partner-logo:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.partner-logo__media{width:100%;height:56px;display:flex;align-items:center;justify-content:center}
.partner-logo img{max-width:100%;max-height:56px;object-fit:contain;display:block;filter:none}
.partner-logo__text{text-align:center;font-size:.95rem;font-weight:600;color:var(--blue-dark);line-height:1.35}
@media(max-width:640px){.partners-strip{grid-template-columns:1fr 1fr;gap:14px}.partner-logo{min-height:84px;padding:14px}.partner-logo__media{height:48px}.partner-logo img{max-height:48px}}
@media(max-width:420px){.partners-strip{grid-template-columns:1fr}}

@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@media(max-width:1024px){.grid-3{grid-template-columns:repeat(2,1fr)}.grid-4{grid-template-columns:repeat(2,1fr)}.impact-grid{grid-template-columns:repeat(2,1fr)}.footer__grid{grid-template-columns:1fr 1fr}.about-grid{gap:48px}}
@media(max-width:768px){.container{padding:0 16px}.section{padding:64px 0}.nav{display:none}.hamburger{display:flex}.hero{min-height:80vh}.hero__decor{display:none}.stats-bar__inner{grid-template-columns:1fr 1fr}.about-grid{grid-template-columns:1fr}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.impact-grid{grid-template-columns:1fr 1fr}.footer__grid{grid-template-columns:1fr;gap:32px}.form-grid{grid-template-columns:1fr}.cta-banner{padding:40px 24px}.nav.open{display:flex;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:var(--white);border-top:1px solid var(--gray-200);padding:16px;box-shadow:var(--shadow-md)}.nav.open .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding-left:16px}.nav.open .dropdown[style*='display: block'],.nav.open .dropdown[style*='display:block']{display:block!important}}
.text-blue{color:var(--blue)}.text-gold{color:var(--gold-dark)}.text-muted{color:var(--gray-400)}.fw-bold{font-weight:700}.mt-4{margin-top:32px}.mb-4{margin-bottom:32px}.text-center{text-align:center}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.gap-2{gap:16px}.gap-3{gap:24px}

.header__logo img{height:48px;width:auto;display:block;}
@media(max-width:768px){.header__logo img{height:40px;}}


/* ── MOBILE RESPONSIVE FIXES ─────────────────────────────────── */

/* Pub-cards stack on mobile */
@media(max-width:640px){
  .pub-card{flex-direction:column;gap:12px;padding:18px;}
  .pub-card__icon{font-size:2rem;}
  .pub-card__title{font-size:.95rem;}
}

/* Stat cards grid responsive */
@media(max-width:768px){
  .stat-cards{grid-template-columns:repeat(2,1fr)!important;}
  .stat-card{padding:16px 12px;}
}
@media(max-width:480px){
  .stat-cards{grid-template-columns:1fr 1fr;}
  .stat-card{padding:12px 10px;}
  .stat-num{font-size:1.6rem;}
}

/* Hero CTA buttons stack on mobile */
@media(max-width:480px){
  .hero__actions{flex-direction:column;gap:12px;}
  .hero__actions .btn{width:100%;justify-content:center;text-align:center;}
  .hero h1{font-size:clamp(2rem,8vw,2.8rem);}
  .hero__sub{font-size:.95rem;}
}

/* Header — hide Nous rejoindre on very small screens, keep hamburger */
@media(max-width:400px){
  .header__cta{display:none;}
  .lang-switcher{display:none;}
}

/* Article detail grid on mobile */
@media(max-width:768px){
  .article-layout-grid{grid-template-columns:1fr!important;}
  .article-sidebar{display:none;}
}

/* Forms on mobile */
@media(max-width:640px){
  .form-grid-3{grid-template-columns:1fr!important;}
  .form-group{margin-bottom:12px;}
}

/* Project cards gap on mobile */
@media(max-width:768px){
  .project-card{padding:20px 16px;}
  .grid-3.projects-grid{grid-template-columns:1fr;}
}

/* Footer mobile */
@media(max-width:480px){
  .footer__grid{grid-template-columns:1fr;}
  .footer__social{justify-content:flex-start;}
}

/* Page hero mobile */
@media(max-width:640px){
  .page-hero{padding:40px 0 32px;}
  .page-hero h1{font-size:clamp(1.6rem,6vw,2rem);}
  .page-hero__breadcrumb{font-size:.75rem;}
}

/* Network cards on mobile */
@media(max-width:640px){
  .network-card{padding:20px 16px;}
}

/* Dropdown arrow on mobile */
@media(max-width:768px){
  .nav__item:hover>.dropdown,.nav__item:focus-within>.dropdown{display:block;}
}


/* Mobile navigation UX improvements */
body.menu-open{overflow:hidden;}
@media(max-width:768px){
  .header{position:sticky;top:0;z-index:1000;}
  .header__inner{min-height:72px;}
  .nav.open{max-height:calc(100vh - 72px);overflow-y:auto;border-radius:0 0 18px 18px;}
  .nav__item{border-bottom:1px solid var(--gray-200);}
  .nav__item:last-child{border-bottom:none;}
  .nav__link{display:flex;align-items:center;justify-content:space-between;padding:14px 4px;}
  .dropdown{display:none;padding:6px 0 12px 12px;}
  .nav__item.is-open>.dropdown{display:block;}
  .dropdown__link{padding:11px 12px;border-radius:10px;}
  .header__actions{gap:10px;}
  .header__lang,.header__actions .btn{display:none;}
  .hamburger{display:flex;}
}
@media(max-width:640px){
  .page-hero{padding-top:28px;}
  .contact-grid,.about-grid,[style*='grid-template-columns: 1.2fr .8fr'],[style*='grid-template-columns:1.2fr .8fr'],[style*='grid-template-columns: 1fr 1fr'],[style*='grid-template-columns:1fr 1fr']{grid-template-columns:1fr !important;}
  .form-input,.form-select,.form-textarea{font-size:16px;}
  .toast{left:16px;right:16px;bottom:16px;}
}


/* V12 mobile/form layout fixes */
.contact-layout,.form-page-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.35fr);gap:56px;align-items:start}
.form-card-body{padding:40px}
.contact-info-panel,.contact-form-panel,.form-panel{min-width:0}
.contact-list{display:flex;flex-direction:column;gap:20px;margin-bottom:40px}
.contact-item{display:flex;gap:16px;align-items:flex-start}
.contact-item__icon{width:48px;height:48px;background:rgba(0,86,151,.08);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.quick-links-card{background:var(--off-white);border-radius:var(--radius);padding:24px;border:1px solid var(--gray-200)}
.form-shell-narrow{max-width:700px;margin:0 auto}
.menu-scroll-lock{overflow:hidden}
@media (max-width: 1024px){
  .contact-layout,.form-page-shell,[style*="grid-template-columns:1fr 1.6fr"],[style*="grid-template-columns: 1fr 1.6fr"],[style*="grid-template-columns:2fr 1fr"],[style*="grid-template-columns: 2fr 1fr"],[style*="grid-template-columns:1fr 300px"],[style*="grid-template-columns: 1fr 300px"]{grid-template-columns:1fr!important;gap:32px!important}
}
@media (max-width: 768px){
  .contact-layout,.form-page-shell,.form-shell-narrow,[style*="grid-template-columns:1fr 1fr"],[style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important;gap:24px!important}
  .form-card-body,.card__body[style*="padding:40px"]{padding:24px!important}
  .contact-item{gap:12px}
  .contact-item__icon{width:42px;height:42px;font-size:1.1rem;border-radius:10px}
  .quick-links-card{padding:18px}
  .section-header{margin-bottom:28px}
  .grid-2,.grid-3,.grid-4,.impact-grid,.about-grid{gap:20px}
  .btn{width:100%;justify-content:center}
}
@media (max-width: 480px){
  .container{padding:0 14px}
  .page-hero{padding:26px 0 24px}
  .page-hero h1{font-size:1.7rem;line-height:1.15}
  .page-hero p{font-size:.95rem}
  .contact-layout,.form-page-shell{gap:20px!important}
  .form-card-body,.card__body[style*="padding:40px"]{padding:18px!important}
  .contact-item__icon{width:38px;height:38px;font-size:1rem}
  .contact-item a,[data-contact]{overflow-wrap:anywhere;word-break:break-word}
  .quick-links-card .btn{font-size:.9rem;padding:12px 14px}
}


/* V13 cache/mobile hardening */
html,body{max-width:100%;overflow-x:hidden;}
img,svg,iframe,video,canvas{max-width:100%;height:auto;}
.contact-layout > *, .form-page-shell > *, .contact-form-panel, .contact-info-panel, .card, .card__body{min-width:0;}
.form-input,.form-select,.form-textarea{width:100%;max-width:100%;}
.page-hero__content,.container{min-width:0;}

@media (max-width: 768px){
  .page-hero{padding-top:96px;}
  .page-hero__content{padding:0 4px;}
  .contact-layout,.form-page-shell{display:grid;grid-template-columns:1fr !important;gap:20px !important;}
  .contact-info-panel,.contact-form-panel,.form-panel{width:100%;max-width:100%;overflow:hidden;}
  .contact-list{gap:16px;margin-bottom:28px;}
  .quick-links-card,.form-card-body{padding:20px !important;}
  .btn{white-space:normal;}
}

@media (max-width: 480px){
  .container{padding:0 14px;}
  .page-hero{padding-top:88px;}
  .card,.quick-links-card,.contact-info-panel,.contact-form-panel{border-radius:18px;}
  .contact-item{align-items:flex-start;}
  .contact-item__icon{margin-top:2px;}
}

@media(max-width:768px){
  .nav__link[data-has-dropdown]{gap:10px;}
  .nav__link[data-has-dropdown] svg{margin-left:auto;flex:0 0 auto;}
  .nav__item.is-open>.nav__link svg{transform:rotate(180deg);}
}


/* V15 mobile UX fine */
.nav__toggle{appearance:none;border:0;background:none;width:100%;text-align:left;font-family:inherit;}
.dropdown__link--overview{font-weight:700;color:var(--blue);}
@media (max-width: 768px){
  .header__inner{height:72px;}
  .nav.open{position:fixed;top:72px;left:0;right:0;bottom:0;max-height:none;height:calc(100vh - 72px);padding:18px 20px 28px;background:rgba(255,255,255,.98);backdrop-filter:blur(10px);overflow-y:auto;overscroll-behavior:contain;}
  .nav__item{padding:2px 0;}
  .nav__link, .nav__toggle{font-size:1.1rem;padding:16px 4px;min-height:52px;}
  .nav__toggle span{display:inline-block;}
  .nav__item.is-open > .nav__toggle{color:var(--blue);}
  .dropdown{padding:4px 0 14px 10px;margin-top:-2px;}
  .dropdown__link{font-size:1rem;padding:12px 14px;}
  .nav__item.is-open > .nav__toggle svg{transform:rotate(180deg);}
  .footer__bottom{flex-direction:column;align-items:flex-start;gap:10px;}
  .footer__bottom > div{display:flex;flex-wrap:wrap;gap:12px;}
  .tabs{overflow:auto;scroll-snap-type:x proximity;padding-bottom:4px;}
  .tab-btn{white-space:nowrap;scroll-snap-align:start;}
}
@media (max-width: 640px){
  .section{padding:52px 0;}
  .section-header{margin-bottom:24px;}
  .section-header h2{font-size:2rem;}
  .hero{min-height:74vh;padding:24px 0 16px;}
  .hero__content{padding:20px 0 40px;}
  .hero__badge{margin-bottom:18px;}
  .hero__sub{margin-bottom:24px;}
  .stats-bar__inner{grid-template-columns:1fr;}
  .stat-item{padding:22px 16px;border-right:0;border-bottom:1px solid var(--gray-100);}
  .stat-item:last-child{border-bottom:0;}
  .card__body{padding:22px;}
  .card__footer{padding:14px 22px;gap:12px;align-items:flex-start;flex-direction:column;}
  .pub-card{padding:18px;}
  .timeline{padding-left:24px;}
  .timeline-item::before{left:-29px;}
  .page-hero__breadcrumb{flex-wrap:wrap;}
  table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
}
@media (max-width: 480px){
  .header__logo img{height:36px!important;}
  .nav.open{padding:14px 16px 24px;}
  .nav__link,.nav__toggle{font-size:1rem;padding:14px 2px;min-height:48px;}
  .dropdown{padding-left:4px;}
  .dropdown__link{font-size:.96rem;padding:11px 12px;}
  .hero h1{font-size:1.95rem;}
  .section-header h2{font-size:1.75rem;}
  .partner-logo{min-height:86px;padding:12px;}
  .partner-logo__media{height:44px;}
  .partner-logo img{max-height:44px;}
  .contact-list{gap:14px;}
  .form-input,.form-select,.form-textarea{padding:12px 14px;}
  .btn{min-height:46px;}
}

/* V16 finition pro */
.nav-backdrop{position:fixed;inset:72px 0 0 0;background:rgba(4,20,37,.22);opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:998;border:0;padding:0;appearance:none}
.nav-backdrop.is-visible{opacity:1;pointer-events:auto}
.partner-logo{flex-direction:column;gap:12px;justify-content:center;text-align:center;min-height:132px;padding:20px 18px;background:linear-gradient(180deg,#fff 0%,#fbfcfe 100%)}
.partner-logo__media{height:64px}
.partner-logo img{max-height:60px}
.partner-logo__name,.partner-logo__text{text-align:center;font-size:.94rem;font-weight:600;color:var(--blue-dark);line-height:1.35}
.partner-logo__placeholder{width:56px;height:56px;border-radius:16px;background:rgba(0,86,151,.08);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--blue);letter-spacing:.04em}
@media (max-width: 768px){
  .nav.open{width:min(100%,420px);left:auto;right:0;bottom:0;border-radius:24px 0 0 0;box-shadow:-8px 0 32px rgba(4,20,37,.12)}
  .nav__item{padding:4px 0}
  .nav__toggle,.nav__link{border-radius:14px}
  .nav__item.is-open>.nav__toggle{background:rgba(0,86,151,.06)}
  .dropdown{padding:6px 0 8px 6px}
  .dropdown__link{background:#fff}
  .partners-strip{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
  .partner-logo{min-height:124px;padding:16px}
}
@media (max-width: 480px){
  .nav-backdrop{inset:72px 0 0 0}
  .nav.open{width:100%;border-radius:20px 20px 0 0;top:72px;height:calc(100vh - 72px)}
  .partners-strip{grid-template-columns:1fr 1fr;gap:12px}
  .partner-logo{min-height:116px;padding:14px 12px;border-radius:16px}
  .partner-logo__media{height:52px}
  .partner-logo img{max-height:48px}
  .partner-logo__name,.partner-logo__text{font-size:.88rem}
}


/* V17 mobile ciblée */
@media (max-width: 768px){
  #valeurs .grid-3{align-items:start;}
  #valeurs .card{height:auto !important; min-height:0 !important; align-self:start; display:block;}
  #valeurs .card__body{height:auto !important; min-height:0 !important;}
  #valeurs .card__text{margin-bottom:0;}
  #valeurs .grid-3 > .card:last-child{grid-column:auto !important;}
  .nav__toggle{touch-action:manipulation;}
  .nav__item:hover > .dropdown, .nav__item:focus-within > .dropdown{display:none;}
  .nav__item.is-open > .dropdown,
  .nav__item.is-open:hover > .dropdown,
  .nav__item.is-open:focus-within > .dropdown{display:block;}
}
@media (max-width: 640px){
  #valeurs .grid-3{grid-template-columns:1fr !important; gap:18px !important;}
  #valeurs .card{border-radius:20px;}
  #valeurs .card__body{padding:20px !important;}
  #valeurs .card__title{font-size:1.7rem; line-height:1.2; margin-bottom:12px;}
  #valeurs .card [style*="font-size:2rem"]{font-size:2.1rem !important; margin-bottom:10px !important;}
}
@media (max-width: 480px){
  #valeurs .card__body{padding:18px !important;}
  #valeurs .card__title{font-size:1.45rem;}
  #valeurs .card__text{font-size:0.95rem; line-height:1.65;}
}


/* V20 mobile header SVG */
.header__mobile-brand{display:none;flex:1;min-width:0;align-items:center;justify-content:center;padding:0 8px;}
.header__mobile-brand-img{display:block;width:100%;max-width:360px;height:auto;max-height:56px;object-fit:contain;}
@media (max-width: 768px){
  .header__inner{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;}
  .header__logo{min-width:0;}
  .header__logo img{height:38px !important;max-width:none !important;}
  .header__mobile-brand{display:flex;}
  .header__actions{justify-content:flex-end;}
  .header__actions .hamburger{margin-left:0;}
}
@media (max-width: 480px){
  .header__inner{gap:8px;}
  .header__logo img{height:34px !important;}
  .header__mobile-brand{padding:0 2px;}
  .header__mobile-brand-img{max-width:300px;max-height:48px;}
}
@media (max-width: 390px){
  .header__mobile-brand-img{max-width:270px;max-height:44px;}
}
@media (min-width: 769px){
  .header__mobile-brand{display:none !important;}
}
