
:root{
  --blue:#173a7a;
  --blue-2:#234f9e;
  --gold:#d7b44a;
  --ink:#172235;
  --muted:#647089;
  --bg:#f7f8fb;
  --card:#ffffff;
  --line:#e5e9f2;
  --radius:24px;
  --shadow:0 18px 40px rgba(23,58,122,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Segoe UI",Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55}
body::before{content:"";position:fixed;inset:0 auto auto 0;width:100%;height:6px;background:linear-gradient(90deg,#173a7a 0 25%, #ffffff 25% 50%, #16984c 50% 75%, #f0d74f 75% 87%, #c2272d 87% 100%);z-index:100}
img{max-width:100%;height:auto;display:block}
.container{width:min(1180px, calc(100% - 48px));margin:0 auto}
.site-header{position:sticky;top:0;z-index:99;backdrop-filter:blur(16px);background:rgba(255,255,255,.94);border-bottom:1px solid rgba(229,233,242,.85)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:84px;gap:24px}
.brand{display:flex;align-items:center;gap:16px;min-width:0}
.brand img{width:68px;height:58px;object-fit:contain}
.brand-text small{display:block;color:var(--muted);font-size:13px;letter-spacing:.08em;text-transform:uppercase}
.brand-text strong{display:block;font-size:24px;line-height:1.1;color:var(--blue)}
.menu{display:flex;gap:24px;flex-wrap:wrap;justify-content:flex-end}
.menu a{text-decoration:none;color:var(--ink);font-weight:600;font-size:15px}
.menu a:hover{color:var(--blue-2)}

.hero{padding:64px 0 36px;background:radial-gradient(circle at top right, rgba(215,180,74,.14), transparent 32%),linear-gradient(180deg, #f9fbff 0%, #eef3fb 100%)}
.hero-grid{display:grid;grid-template-columns:1.03fr .97fr;gap:34px;align-items:center}
.kicker{display:inline-flex;align-items:center;gap:10px;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);font-weight:700}
.kicker::before{content:"";width:34px;height:2px;background:var(--gold)}
h1{font-family:Georgia,"Times New Roman",serif;font-size:58px;line-height:1.03;margin:16px 0 18px;color:#0f2551;max-width:11ch}
.hero-copy p.lead{max-width:620px;font-size:20px;color:#34425e;margin:0 0 18px}
.hero-copy p.sublead{margin:0 0 28px;color:#55627b;font-size:15px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;text-decoration:none;font-weight:700;transition:.2s ease}
.btn-primary{background:var(--blue);color:white;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--blue-2)}
.btn-secondary{border:1px solid #cfd7e7;color:var(--blue);background:#fff}
.facts{display:flex;gap:32px;flex-wrap:wrap;padding-top:6px}
.fact strong{display:block;font-size:26px;color:var(--blue)}
.fact span{font-size:14px;color:var(--muted)}

section{padding:34px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:22px}
.section-head .eyebrow{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:10px}
.section-head h2{margin:0;font-family:Georgia,"Times New Roman",serif;font-size:40px;color:#102656}
.section-head p{margin:0;max-width:540px;color:var(--muted)}

.card,.media-card,.about article,.mini-card,.president-copy,.contact-card,.contact-visual{background:var(--card);border:1px solid var(--line);border-radius:24px;box-shadow:0 12px 24px rgba(19,29,58,.04)}
.media-card{padding:18px}
.media-card img{border-radius:18px}
.caption{margin:12px 0 0;color:var(--muted);font-size:14px;text-align:center}
.about{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.about article{padding:26px 24px}
.about article b{display:inline-flex;width:44px;height:44px;border-radius:50%;align-items:center;justify-content:center;background:#eef3fb;color:var(--blue);font-size:20px;margin-bottom:16px}
.about h3{margin:0 0 10px;font-size:24px;color:#12295d}
.about p{margin:0;color:#55627b}

.president{display:grid;grid-template-columns:.92fr 1.08fr;gap:28px;align-items:start}
.president-copy{padding:34px 34px 30px}
.president-copy .quote-mark{font-family:Georgia,serif;font-size:64px;color:var(--gold);line-height:.8}
.president-copy h3{margin:10px 0 14px;font-family:Georgia,serif;font-size:36px;line-height:1.1;color:#102656}
.president-copy p{color:#4f5e79;font-size:18px}
.signature{margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}
.signature strong{display:block;font-size:20px;color:var(--blue)}
.signature span{color:var(--muted)}

.interview-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}
.interview-copy{padding:28px}
.interview-copy h3{margin:0 0 12px;font-family:Georgia,serif;font-size:32px;color:#102656;text-align:center;}
.interview-copy p{margin:0;color:#5a677f;font-size:18px; text-align:justify;text-justify:inter-word;max-width:100%;}
.video-thumb-clean{display:flex;justify-content:center;}
.video-thumb-clean img{border-radius:24px;display:block;margin:0 auto;max-width:100%;height:auto;}
.video-cta{display:inline-flex;margin-top:18px;color:var(--blue);font-weight:700;text-decoration:none}
.video-cta:hover{text-decoration:underline}

.news-grid{display:grid;grid-template-columns:1fr;gap:22px}
.news-note{padding:24px 24px 22px}
.news-note p{margin:10px 0 0;color:#5a677f;font-size:18px}
.news-card{background:var(--card);border:1px solid var(--line);border-radius:30px;overflow:hidden;box-shadow:var(--shadow);color:var(--ink)}
.news-card img{width:100%}
.news-card .content{padding:26px 28px 30px}
.news-card .tag{display:inline-flex;align-items:center;gap:8px;background:#eef3fb;color:var(--blue);padding:9px 14px;border-radius:999px;font-weight:700;font-size:13px}
.news-card h3{font-family:Georgia,serif;font-size:38px;line-height:1.08;margin:16px 0 12px;color:#102656}
.news-card p{max-width:none;margin:0;color:#4f5e79;font-size:18px}
.news-side{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.mini-card{padding:24px 24px 22px}
.mini-card .mini-title{font-size:14px;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);font-weight:700}
.mini-card h4{margin:8px 0 10px;font-size:24px;color:#12295d}
.mini-card p{margin:0;color:#5a677f}

.partners-wrap{background:linear-gradient(180deg,#102656 0%, #173a7a 100%);color:#fff;border-radius:34px;padding:36px;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center;box-shadow:var(--shadow)}
.partners-wrap h2{color:#fff}
.partner-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.partner{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);min-height:108px;border-radius:18px;display:grid;place-items:center;font-weight:700;color:rgba(255,255,255,.9);text-align:center;padding:10px}

.contact{display:grid;grid-template-columns:1.05fr .95fr;gap:22px;align-items:start}
.contact-card{padding:32px}
.contact-card p{font-size:18px;color:#50607b}
.contact-list{display:grid;gap:16px;margin-top:24px}
.contact-item strong{display:block;color:var(--blue);font-size:15px;text-transform:uppercase;letter-spacing:.08em}
.contact-item span{color:#1f2b43;font-size:18px}
.contact-visual{padding:18px}
.contact-visual img{border-radius:22px}

.site-footer{margin-top:34px;padding:28px 0 36px;background:#fff;border-top:1px solid var(--line)}
.footer-grid{display:flex;justify-content:space-between;gap:24px;align-items:center;flex-wrap:wrap}
.footer-brand{display:flex;align-items:center;gap:14px}
.footer-brand img{width:56px;height:48px;object-fit:contain}
.footer-brand strong{display:block;color:var(--blue);font-size:18px}
.footer-brand span{display:block;color:var(--muted);font-size:14px}
.footer-links{display:flex;gap:20px;flex-wrap:wrap;color:var(--muted)}
.footer-links a{color:inherit;text-decoration:none}
.notice{padding:18px 0 0;color:var(--muted);font-size:13px}

@media (max-width:980px){
  .hero-grid,.president,.interview-grid,.partners-wrap,.contact,.news-side{grid-template-columns:1fr}
  h1{font-size:46px;max-width:none}
  .about{grid-template-columns:1fr}
  .partner-row{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .container{width:min(1180px, calc(100% - 28px))}
  .menu{display:none}
  .partner-row{grid-template-columns:1fr}
  .section-head{display:block}
  .section-head p{margin-top:10px}
}


/* Anchor offset fix for sticky header */
main section[id], .hero[id], section[id]{scroll-margin-top:110px;}

/* Menu one-line fix */
.navbar, .menu, .nav{
  display:flex;
  flex-wrap:nowrap;
  justify-content:flex-start;
  gap:16px;
}
.menu a{
  white-space:nowrap;
  font-size:0.95rem;
}

/* Section title and intro alignment improvements */
.section-head{
  align-items:flex-start;
}
.section-head > div{
  flex:0 0 auto;
}
.section-head h2{
  white-space:nowrap;
}
.section-head p{
  margin-top:2.6em;
  text-align:justify;
  text-justify:inter-word;
}

/* Force section intro below title */
.section-head{
  display:block;
}
.section-head h2{
  display:block;
  margin-bottom:10px;
  white-space:nowrap;
}
.section-head p{
  display:block;
  margin-top:0;
  text-align:justify;
}

/* Hero title full-width + section intro full line */
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:start;
}
.hero-copy{
  grid-column:1 / -1;
}
.hero-copy h1{
  max-width:none;
  width:100%;
  white-space:normal;
  margin-right:0;
}
.hero-copy .lead,
.hero-copy .sublead,
.hero-copy .hero-actions,
.hero-copy .facts{
  max-width:100%;
}
.hero .media-card{
  grid-column:2;
  margin-top:-40px;
}

.section-head{
  display:block;
}
.section-head > div{
  width:100%;
}
.section-head h2{
  display:block;
  margin-bottom:10px;
}
.section-head p{
  display:block;
  margin-top:0;
  max-width:none;
  width:100%;
  text-align:justify;
  text-justify:inter-word;
}

/* Hero alignment + responsive titles + fact text wrapping */
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:start;
}
.hero-copy{
  grid-column:1;
}
.hero-copy h1{
  max-width:none;
  width:100%;
  white-space:normal;
  text-align:left;
}
.hero .media-card{
  grid-column:2;
  margin-top:168px;
}
.facts{
  display:flex;
  gap:32px;
  flex-wrap:wrap;
  align-items:flex-start;
}
.fact{
  flex:1 1 180px;
  min-width:180px;
}
.fact span{
  display:block;
  text-align:left;
  white-space:normal;
  line-height:1.4;
}
@media (max-width: 980px){
  .hero-grid{
    grid-template-columns:1fr;
  }
  .hero-copy,
  .hero .media-card{
    grid-column:1;
  }
  .hero .media-card{
    margin-top:0;
  }
  .hero-copy h1{
    white-space:normal;
  }
}



/* Hero layout refinement */
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.08fr) minmax(320px, .92fr);
  gap:34px;
  align-items:start;
}
.hero-copy{
  display:contents;
}
.hero-grid .kicker{
  grid-column:1 / -1;
  grid-row:1;
}
.hero-grid h1{
  grid-column:1 / -1;
  grid-row:2;
  max-width:none;
  width:100%;
  white-space:normal;
  text-align:left;
  margin-right:0;
}
.hero-grid .lead{
  grid-column:1;
  grid-row:3;
  max-width:none;
}
.hero-grid .sublead{
  grid-column:1;
  grid-row:4;
  max-width:none;
}
.hero-grid .hero-actions{
  grid-column:1;
  grid-row:5;
  max-width:none;
}
.hero-grid .facts{
  grid-column:1;
  grid-row:6;
  max-width:none;
  display:flex;
  gap:32px;
  flex-wrap:wrap;
  align-items:flex-start;
}
.hero-grid .media-card{
  grid-column:2;
  grid-row:3 / span 4;
  align-self:start;
  margin-top:0;
}
.fact{
  flex:1 1 180px;
  min-width:180px;
}
.fact strong{
  text-align:left;
}
.fact span{
  display:block;
  text-align:left;
  white-space:normal;
  line-height:1.4;
}

/* Remove decorative opening quote before Mot du Président */
.president-copy .quote-mark{
  display:none;
}

@media (max-width: 980px){
  .hero-grid{
    grid-template-columns:1fr;
    gap:24px;
  }
  .hero-copy{
    display:block;
  }
  .hero-grid .kicker,
  .hero-grid h1,
  .hero-grid .lead,
  .hero-grid .sublead,
  .hero-grid .hero-actions,
  .hero-grid .facts,
  .hero-grid .media-card{
    grid-column:auto;
    grid-row:auto;
  }
  .hero-grid .media-card{
    margin-top:0;
  }
  .hero-grid h1{
    white-space:normal;
  }
}




/* Responsive menu and section-title wrapping */
.nav{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
}
.brand{
  flex:0 1 420px;
  min-width:260px;
}
.menu{
  flex:1 1 auto;
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  align-items:center;
  gap:14px 18px;
  min-width:0;
  margin-left:20px;
}
.menu a{
  white-space:nowrap;
}

.section-head h2{
  white-space:normal !important;
  overflow-wrap:anywhere;
  word-break:normal;
}

@media (max-width: 1100px){
  .nav{
    align-items:flex-start;
  }
  .menu{
    justify-content:flex-start;
    margin-left:12px;
    max-width:calc(100% - 300px);
  }
}

@media (max-width: 900px){
  .nav{
    flex-direction:column;
    align-items:flex-start;
  }
  .brand{
    flex:0 0 auto;
    max-width:100%;
  }
  .menu{
    width:100%;
    max-width:100%;
    margin-left:0;
    justify-content:flex-start;
    gap:10px 16px;
  }
}

@media (max-width: 640px){
  .menu{
    gap:8px 12px;
  }
  .menu a{
    font-size:14px;
  }
  .section-head h2{
    font-size:32px;
    line-height:1.15;
  }
}

