:root{
  --navy:#0c0145;
  --navy-deep:#06002a;
  --navy-soft:#1a0e6b;
  --yellow:#f7b500;
  --yellow-deep:#e0a300;
  --green:#3aaa35;
  --text:#5c618a;
  --heading:#0c0145;
  --line:#ececf3;
  --bg:#ffffff;
  --bg-soft:#f6f6fb;

  --maxw:1240px;
  --radius:14px;
  --radius-img:22px;
  --shadow:0 22px 55px -25px rgba(12,1,69,.45);
  --shadow-sm:0 10px 30px -16px rgba(12,1,69,.5);
  --ease:cubic-bezier(.22,.61,.36,1);
  --font:"Poppins", system-ui, sans-serif;
  --header-h:86px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-weight:400}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
h1,h2,h3,h4{color:var(--heading);font-weight:700;line-height:1.18;letter-spacing:-.01em}
.section{padding:84px 0;position:relative}

img.img-missing{position:relative;background:repeating-linear-gradient(45deg,#ececf6,#ececf6 12px,#f4f4fb 12px,#f4f4fb 24px)}
img.img-missing::after{content:attr(alt);position:absolute;inset:0;display:grid;place-items:center;color:#a6a6c8;font-size:.8rem;padding:12px;text-align:center}

/* ---------------- Boutons ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:600;font-size:.92rem;
  padding:.78em 1.6em;border-radius:0;border:2px solid transparent;
  transition:transform .3s var(--ease),background .25s,color .25s,border-color .25s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-yellow{background:var(--yellow);color:var(--navy)}
.btn-yellow:hover{background:var(--yellow-deep)}
.btn-yellow-outline{border-color:var(--yellow);color:var(--yellow-deep);background:transparent;font-weight:700}
.btn-yellow-outline:hover{background:var(--yellow);color:var(--navy)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-deep)}
.btn-block{width:100%}

/* =========================================================
   HEADER
   ========================================================= */
.header{position:sticky;top:0;z-index:90;background:#fff;border-bottom:1px solid var(--line);transition:box-shadow .3s}
.header .wrap{max-width:none;padding:0 32px}
.header.scrolled{box-shadow:0 6px 24px -16px rgba(12,1,69,.18)}
.nav{display:flex;align-items:center;gap:18px;height:var(--header-h)}
.brand{display:flex;align-items:center;flex:0 0 auto}
.brand .logo{height:48px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:30px;margin:0 auto;font-size:.95rem;font-weight:500;flex-wrap:nowrap}
.nav-links a{color:var(--navy);padding:6px 2px;position:relative;transition:color .2s;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:3px;background:var(--yellow);
  transform:scaleX(0);transform-origin:center;transition:transform .3s var(--ease);border-radius:2px}
.nav-links a:hover,.nav-links a.active{color:var(--yellow-deep)}
.nav-links a.active::after,.nav-links a:hover::after{transform:scaleX(.6)}
.nav-actions{display:flex;gap:10px;align-items:center;flex:0 0 auto}
.nav-actions .btn{padding:.62em 1.4em;font-size:.9rem}
.burger{display:none;width:44px;height:44px;border-radius:10px}
.burger span{display:block;width:22px;height:2px;background:var(--navy);margin:5px auto;border-radius:2px;transition:.3s}

/* menu mobile */
.mobile-menu{position:fixed;inset:0;z-index:95;background:#fff;color:var(--yellow);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:48px 32px;transform:translateX(100%);transition:transform .4s var(--ease)}
.mobile-menu.open{transform:none}
.mobile-menu a{font-size:1.2rem;font-weight:500;color:var(--yellow);padding:5px 0;text-align:center;letter-spacing:-.005em}
.mobile-menu a[data-open]:first-of-type{margin-top:34px}
.mobile-menu .close{position:absolute;top:18px;right:22px;color:#888;font-size:2.6rem;line-height:1;font-weight:300}

/* =========================================================
   BANDEAUX
   ========================================================= */
.band{padding:28px 0;text-align:center}
.band h2{font-size:clamp(1.4rem,3.4vw,2.1rem);letter-spacing:.04em;margin:0;font-weight:800}
.band-navy{background:var(--navy)}
.band-navy h2{color:#fff}
.band-yellow{background:var(--yellow)}
.band-yellow h2{color:var(--navy)}

/* =========================================================
   HERO — avec image en parallax
   ========================================================= */
.hero{
  position:relative;
  text-align:center;
  padding:140px 0 160px;
  overflow:hidden;
  isolation:isolate;
  min-height:520px;
  display:flex;
  align-items:center;
}
.hero-bg{
  position:absolute;
  inset:-15% 0;
  z-index:-2;
  will-change:transform;
}
.hero-bg img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hero-overlay{
  position:absolute;
  inset:0;
  z-index:-1;
  background:linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.35) 60%, rgba(0,0,0,.55) 100%);
}
.hero-content{position:relative;z-index:1;width:100%}
.hero h1{font-size:clamp(2.7rem,7.5vw,3.8rem);color:var(--yellow);font-weight:700;margin-bottom:22px;letter-spacing:-.005em;line-height:1.05;text-shadow:0 2px 12px rgba(0,0,0,.45)}
.hero p{max-width:70ch;margin:0 auto 38px;color:#fff;font-size:1.05rem;font-weight:400;text-shadow:0 1px 6px rgba(0,0,0,.55)}
.hero-cta{display:flex;gap:14px;justify-content:center;margin-top:38px;flex-wrap:wrap}

/* Adaptations mobile pour le HERO */
@media (max-width: 768px){
  .hero{padding:100px 0 110px;min-height:420px}
  .hero-bg{inset:0}
}
/* Respect des préférences utilisateur (accessibilité) */
@media (prefers-reduced-motion: reduce){
  .hero-bg{transform:none !important}
}

/* mockups */
.frame-tablet{position:relative;max-width:720px;margin:0 auto}
.frame-tablet .device-frame{width:100%;display:block;position:relative;z-index:1;pointer-events:none}
.frame-tablet .screen{position:absolute;top:5.5%;left:4.5%;right:4.5%;bottom:5.5%;z-index:2;overflow:hidden;background:#000}
.frame-tablet .screen img,.frame-tablet .screen video{width:100%;height:100%;object-fit:cover;display:block}
.frame-phone{position:relative;max-width:240px;margin:0 auto}
.frame-phone .device-frame{width:100%;display:block;position:relative;z-index:2;pointer-events:none}
.frame-phone .screen{
  position:absolute;
  top:2.6%;
  left:5%;
  right:5%;
  bottom:2.6%;
  z-index:1;
  overflow:hidden;
  background:#000;
  border-radius:11% / 5.5%;
}
.frame-phone .screen video,
.frame-phone .screen img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:inherit;
}
/* Masquer la chrome native moche du lecteur dans le cadre iPhone */
.frame-phone .screen video::-webkit-media-controls-panel{background:transparent}
.frame-laptop{position:relative;max-width:540px;margin:0 auto}
.frame-laptop .device-frame{width:100%;display:block;position:relative;z-index:1;pointer-events:none}
.frame-laptop .screen{position:absolute;top:5%;left:11%;right:11%;bottom:13%;z-index:2;overflow:hidden;background:#000}
.frame-laptop .screen img,.frame-laptop .screen video{width:100%;height:100%;object-fit:cover;display:block}

/* =========================================================
   VISION
   ========================================================= */
.vision .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.vision .text{text-align:center}
.vision h2{color:var(--yellow);font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:600;margin-bottom:18px}
.vision p{color:var(--navy);font-size:1.02rem;max-width:48ch;margin:0 auto;font-weight:400}

/* =========================================================
   SERVICES
   ========================================================= */
.service{padding:64px 0}
.service .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.service .visual{order:0}
.service .img-card{border-radius:var(--radius-img);overflow:hidden;aspect-ratio:3/4.1;box-shadow:var(--shadow);background:#ececf6}
.service .img-card img{width:100%;height:100%;object-fit:cover}
.service h3{font-size:clamp(1.3rem,2.3vw,1.65rem);font-weight:700;text-align:center;margin-bottom:16px}
.service .desc{color:var(--text);margin-bottom:20px;font-size:.97rem}
.check-list li{position:relative;padding-left:30px;margin-bottom:9px;color:var(--navy);font-size:.95rem}
.check-list li::before{content:"";position:absolute;left:0;top:.35em;width:18px;height:18px;border-radius:50%;background:var(--navy);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:11px}
.cible-bar{background:var(--navy);color:#fff;font-weight:600;font-size:.9rem;padding:7px 16px;border-radius:4px;margin:26px 0 12px;display:inline-block}
.service-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
/* Icônes après le texte des boutons d'action service */
.service-actions .btn::after{content:"";width:18px;height:18px;background-repeat:no-repeat;background-position:center;background-size:contain;flex:0 0 auto}
.service-actions .btn:first-child::after{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230c0145' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M8 14s1.5 2 4 2 4-2 4-2'/%3E%3Cpath d='M9 9h.01'/%3E%3Cpath d='M15 9h.01'/%3E%3C/svg%3E");
}
.service-actions .btn:last-child::after{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230c0145' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M9 12h6m-2-3l3 3-3 3'/%3E%3C/svg%3E");
}

/* =========================================================
   VAGUES
   ========================================================= */
.wave{
  height:160px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1000 407.65' preserveAspectRatio='none'%3E%3Cpath d='M751.32 187.47C613 235 462.72 218.9 318.61 225 200.89 230 48.86 251.53 0 407.65h1000V0c-64.23 92.19-152 154.24-248.68 187.47z' fill='%230c0145' fill-opacity='.25'/%3E%3Cpath d='M777.61 210.75c-123.72 42.52-258.09 28.11-387 33.57-105.24 4.46-241.2 23.68-284.89 163.33H1000V43.1C942.56 125.54 864.09 181 777.61 210.75z' fill='%230c0145'/%3E%3C/svg%3E");
  background-size:100% 100%;
  background-repeat:no-repeat;
  background-position:center bottom;
  line-height:0;
}
.wave-top{transform:scaleY(-1)}
@media(max-width:680px){.wave{height:80px}}

/* =========================================================
   CONTACT
   ========================================================= */
.contact .wrap{display:grid;grid-template-columns:1fr 1.15fr;gap:0;align-items:stretch}
.contact-aside{background:var(--yellow);padding:54px 44px;display:flex;flex-direction:column;justify-content:center;border-radius:6px 0 0 6px}
.contact-aside h2{color:var(--navy);font-size:clamp(1.6rem,3vw,2.15rem);font-weight:700;margin-bottom:24px}
.socials{display:flex;gap:14px;flex-wrap:wrap}
.socials a{color:var(--navy);transition:transform .25s}
.socials a:hover{transform:translateY(-3px)}
.contact-form{background:#fff;padding:44px;border:1px solid var(--line);border-left:0;border-radius:0 6px 6px 0}
.field{margin-bottom:18px}
.field label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text);margin-bottom:7px}
.field input,.field textarea{width:100%;padding:11px 14px;border:1.6px solid var(--navy);border-radius:4px;font-family:inherit;font-size:.95rem;color:var(--navy);background:#fff;transition:box-shadow .2s,border-color .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--yellow);box-shadow:0 0 0 3px rgba(247,181,0,.18)}
.field textarea{resize:vertical;min-height:120px}

/* =========================================================
   PROGRAMMES + PARTENAIRES
   ========================================================= */
.prog-strip{padding:54px 0;text-align:center}
.prog-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:30px;margin-top:36px;padding:0}
.prog-list li{display:flex;flex-direction:column;align-items:center;gap:14px}
.prog-list li img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:8px;box-shadow:var(--shadow-sm)}
.prog-list li span{font-weight:700;color:var(--navy);font-size:1.15rem;text-align:center}
.prog-list li a{display:flex;flex-direction:column;align-items:center;gap:14px;color:inherit;text-decoration:none;transition:transform .3s var(--ease)}
.prog-list li a:hover{transform:translateY(-4px)}
.prog-list li a:hover span{color:var(--yellow-deep)}
.prog-list li a img{transition:box-shadow .3s var(--ease)}
.prog-list li a:hover img{box-shadow:var(--shadow)}
.partners{padding:70px 0;text-align:center}
.partners h2{font-size:clamp(1.5rem,2.9vw,2rem);font-weight:800;letter-spacing:.04em;margin-bottom:40px}
.partner-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:26px;align-items:center}
.partner-grid img{max-height:64px;width:auto;margin:0 auto;object-fit:contain;filter:grayscale(.2)}

/* =========================================================
   NEWSLETTER
   ========================================================= */
.newsletter .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.newsletter{padding-bottom:30px}
.newsletter .visual{position:relative;z-index:2}
.newsletter .visual .frame-phone{margin-bottom:-50px}
.newsletter + .wave{position:relative;z-index:1;margin-top:-80px}
.newsletter .eyebrow{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);display:block;margin-bottom:8px}
.newsletter h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;margin-bottom:16px}
.newsletter p{margin-bottom:24px}
.news-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:500px}
.news-fields input{padding:12px 14px;border:1.6px solid var(--navy);border-radius:4px;font-family:inherit;color:var(--navy)}
.news-fields input:focus{outline:none;border-color:var(--yellow)}
.news-fields .email-row{grid-column:1/-1;display:flex;gap:10px}
.news-fields .email-row input{flex:1}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{padding:60px 0 40px;text-align:center;border-top:1px solid var(--line)}
.footer .brand{justify-content:center;margin-bottom:14px}
.footer .brand .logo{height:120px}
.footer .place{color:var(--navy);font-size:.95rem;letter-spacing:.1em;font-weight:600;margin-bottom:26px}
.footer-links{display:flex;justify-content:center;flex-wrap:wrap;gap:0;margin-bottom:30px}
.footer-links a{color:var(--yellow-deep);font-size:1rem;padding:0 22px;border-right:1px solid var(--line);font-weight:500}
.footer-links a:last-child{border-right:0}
.footer-links a:hover{color:var(--yellow)}
.footer .copy{color:var(--navy);font-size:.92rem}

/* =========================================================
   MODALES
   ========================================================= */
.modal-overlay{position:fixed;inset:0;z-index:120;background:rgba(12,1,69,.55);backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:12px;max-width:440px;width:100%;padding:40px 36px;position:relative;box-shadow:var(--shadow);margin:auto}
.modal h3{text-align:center;font-size:1.65rem;font-weight:700;color:var(--navy);margin-bottom:24px}
.modal .close{position:absolute;top:14px;right:16px;font-size:1.6rem;color:#9a9ab5;line-height:1}
.social-row{display:flex;justify-content:center;gap:12px;margin-bottom:18px}
.social-row .s{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700}
.social-row .g{background:#fff;border:1px solid var(--line);color:#4285f4}
.social-row .f{background:#3b5998}
.social-row .in{background:#0077b5}
.social-row .ap{background:#000}
.modal .sep{text-align:center;color:#9a9ab5;font-size:.85rem;margin:14px 0}
.modal .field label{color:var(--navy);text-transform:none;letter-spacing:0;font-size:.95rem;font-weight:600}
.modal .field input{border:0;border-bottom:1.6px solid var(--line);border-radius:0;padding:8px 2px;color:var(--navy)}
.modal .field input:focus{box-shadow:none;border-bottom-color:var(--yellow)}
.modal .req{color:#e05}
.modal-foot{display:flex;justify-content:space-between;margin-top:20px;font-size:.88rem}
.modal-foot a{color:var(--yellow-deep);font-weight:600}

/* =========================================================
   ANIMATIONS reveal
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
[data-delay="1"]{transition-delay:.1s}[data-delay="2"]{transition-delay:.2s}[data-delay="3"]{transition-delay:.3s}

/* =========================================================
   PAGE PROGRAMMES — hero intro + sections immersives
   ========================================================= */
.prog-hero{padding:90px 0 70px}
.prog-hero .wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}
.prog-hero h1{font-size:clamp(2.3rem,4.6vw,3.3rem);color:var(--navy);font-weight:800;line-height:1.05;margin-bottom:24px;text-transform:uppercase;letter-spacing:.005em}
.prog-hero p{color:var(--text);font-size:1.02rem;margin-bottom:30px;max-width:55ch;text-align:justify}
.prog-hero .img-trio{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.prog-hero .img-trio img{width:100%;aspect-ratio:3/5;object-fit:cover;border-radius:18px;box-shadow:var(--shadow-sm)}
.prog-hero .img-trio img:nth-child(2){transform:translateY(22px)}

/* Section immersive sur fond image (Polyphonies / Crescendo Vert) */
.prog-section{position:relative;padding:90px 0;color:#fff;overflow:hidden}
.prog-section .prog-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;display:block}
.prog-section::after{content:"";position:absolute;inset:0;background:rgba(12,1,69,.78);z-index:1;pointer-events:none}
.prog-section.green::after{background:rgba(18,68,35,.80)}
.prog-section.green .text p{font-size:1.35rem}
.prog-section.green .feature-block .copy{font-size:1.2rem}
.prog-section .wrap{position:relative;z-index:2}
.prog-section .prog-row{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.prog-section .text p{color:rgba(255,255,255,.88);font-size:1rem;margin-bottom:22px;text-align:justify}

/* Feature block (icône cercle + titre + petit texte) */
.feature-block{display:flex;gap:18px;margin-top:24px;align-items:flex-start}
.feature-block .ic{width:48px;height:48px;border-radius:50%;background:#2e7eb5;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.feature-block .ic svg{width:24px;height:24px}
.feature-block h4{color:#fff;font-size:1.05rem;margin-bottom:6px;font-weight:700}
.feature-block .copy{color:rgba(255,255,255,.78);font-size:.92rem;line-height:1.55;text-align:left}
.prog-section.green .feature-block .ic{background:#3aaa35}

/* Galerie empilée à droite : 2 portraits côte à côte + 2 landscapes dessous */
.gallery-stack{display:flex;flex-direction:column;gap:16px}
.gallery-stack .portraits{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gallery-stack img{width:100%;border-radius:18px;box-shadow:0 25px 50px -20px rgba(0,0,0,.5);object-fit:cover;display:block}
.gallery-stack .portraits img{aspect-ratio:3/4.3}
.gallery-stack .landscape{aspect-ratio:16/8}

@media(max-width:900px){
  .prog-hero .wrap,.prog-section .prog-row{grid-template-columns:1fr;gap:36px}
  .prog-hero .img-trio img:nth-child(2){transform:none}
}
@media(max-width:680px){
  .prog-hero{padding:60px 0 50px}
  .prog-section{padding:60px 0}
  .feature-block{gap:14px}
  .feature-block .ic{width:42px;height:42px}
  .feature-block .ic svg{width:20px;height:20px}
}

/* =========================================================
   PAGE PARTENARIATS — hero partenaire + projets communs + bandeau
   ========================================================= */
.partner-hero{padding:80px 0 30px}
.partner-hero .wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:55px;align-items:flex-start}
.partner-hero h1{font-size:clamp(3rem,6vw,4.5rem);color:#6b3a1a;font-weight:800;line-height:1;margin-bottom:28px;letter-spacing:-.01em}
.partner-hero p{color:var(--text);font-size:1rem;margin-bottom:18px;text-align:justify}
.partner-hero .photo{border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}
.partner-hero .photo img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.partner-hero .actions{display:flex;gap:14px;margin-top:22px;flex-wrap:wrap}

.partner-extra{padding:30px 0 70px}
.partner-extra p{color:var(--text);font-size:1rem;max-width:72ch;margin:0 auto;text-align:justify}

.common-projects{padding:30px 0 80px}
.common-projects h2{text-align:center;font-size:clamp(1.7rem,3.2vw,2.3rem);font-weight:800;color:#6b3a1a;margin-bottom:50px;text-transform:uppercase;letter-spacing:.005em}
.projects-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.proj-card{text-align:center}
.proj-card img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:6px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.proj-card h3{font-weight:800;font-size:1.05rem;margin-bottom:6px}
.proj-card.yellow h3{color:var(--yellow-deep)}
.proj-card.green h3{color:var(--green)}
.proj-card.navy h3{color:var(--navy)}
.proj-card p{color:var(--text);font-size:.88rem;line-height:1.4}
.proj-card .yellow-desc{color:var(--yellow-deep);font-weight:500}

.partner-band{padding:0;line-height:0}
.partner-band img{width:100%;max-height:420px;object-fit:cover;display:block}

/* Sous-photo paragraphe (partenariats) */
.partner-hero .below-photo{color:var(--text);font-size:1rem;margin-top:24px;text-align:justify}

/* CTA "Devenez partenaires vous aussi" */
.partner-cta{position:relative;padding:100px 0;color:#fff;overflow:hidden;text-align:center}
.partner-cta .prog-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;display:block}
.partner-cta::after{content:"";position:absolute;inset:0;background:rgba(12,1,69,.62);z-index:1;pointer-events:none}
.partner-cta .wrap{position:relative;z-index:2}
.partner-cta h2{font-size:clamp(1.8rem,3.6vw,2.6rem);color:#fff;font-weight:800;margin-bottom:14px}
.partner-cta p{color:rgba(255,255,255,.92);font-size:1.05rem;margin-bottom:34px}
.partner-cta .btn-yellow-outline{color:#fff;border-color:var(--yellow)}
.partner-cta .btn-yellow-outline:hover{background:var(--yellow);color:var(--navy)}

@media(max-width:900px){
  .partner-hero .wrap{grid-template-columns:1fr;gap:36px}
  .projects-grid{grid-template-columns:repeat(2,1fr);gap:24px}
}
@media(max-width:580px){
  .projects-grid{grid-template-columns:1fr;gap:24px}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1100px){
  .nav-links{gap:22px;font-size:.92rem}
  .nav-actions .btn{padding:.55em 1.2em;font-size:.85rem}
}
@media(max-width:980px){
  .nav-links{display:none}
  .burger{display:block}
  .nav-actions{margin-left:auto}
  .nav-actions .btn{display:none}
}
@media(max-width:900px){
  .vision .wrap,.service .wrap,.contact .wrap,.newsletter .wrap{grid-template-columns:1fr;gap:36px}
  .service .visual{order:-1}
  .contact-aside{border-radius:6px 6px 0 0}
  .contact-form{border-left:1px solid var(--line);border-top:0;border-radius:0 0 6px 6px}
}
@media(max-width:680px){
  .section{padding:60px 0}
  .brand .logo{height:40px}
  .news-fields{grid-template-columns:1fr}
  .news-fields .email-row{flex-direction:column}
  .hero-cta{flex-wrap:wrap;justify-content:center}
  .hero-cta .btn{flex:1;min-width:130px}
}

/* =========================================================
   PAGES LÉGALES (Termes & Conditions, Cookies, Confidentialité)
   ========================================================= */
.legal-hero{padding:60px 0 36px;text-align:center;border-bottom:1px solid var(--line);background:var(--bg-soft)}
.legal-hero h1{font-size:clamp(1.8rem,4vw,2.6rem);color:var(--navy);margin-bottom:10px;font-weight:800}
.legal-hero h1 .sep{color:var(--yellow);margin:0 .25em;font-weight:400}
.legal-meta{color:var(--text);font-size:.9rem;margin-bottom:22px}
.legal-meta .ph{color:var(--yellow-deep);font-weight:600}
.lang-toggle{display:inline-flex;border:2px solid var(--yellow);border-radius:0;overflow:hidden}
.lang-toggle button{padding:.55em 1.4em;font-size:.88rem;font-weight:700;color:var(--yellow-deep);background:transparent;transition:all .2s;letter-spacing:.02em}
.lang-toggle button.active{background:var(--yellow);color:var(--navy)}
.lang-toggle button:hover:not(.active){background:rgba(247,181,0,.12)}

.legal-body{padding:50px 0 80px}
.legal-body .wrap{max-width:920px}
.legal-content .intro{font-size:.98rem;color:var(--navy);margin-bottom:26px;padding:18px 22px;background:var(--bg-soft);border-left:4px solid var(--yellow);border-radius:0 6px 6px 0;line-height:1.65}
.legal-content h2{font-size:1.2rem;color:var(--navy);margin:40px 0 14px;font-weight:700;letter-spacing:-.005em}
.legal-content p{margin-bottom:14px;color:var(--text);font-size:.95rem;line-height:1.72;text-align:justify}
.legal-content ul{padding-left:22px;margin-bottom:14px}
.legal-content li{color:var(--text);font-size:.94rem;line-height:1.7;margin-bottom:8px;list-style:disc;text-align:justify}
.legal-content strong{color:var(--navy);font-weight:600}
.legal-content a{color:var(--yellow-deep);text-decoration:underline;text-underline-offset:2px}
.legal-content a:hover{color:var(--navy)}
.legal-content .ph{color:var(--yellow-deep);font-weight:600;background:rgba(247,181,0,.12);padding:1px 7px;border-radius:3px;font-size:.88em;white-space:nowrap}
.lang-block[hidden]{display:none}

/* Sous-titres (services tiers : Vimeo, Hotjar, etc.) */
.legal-content h3{font-size:1rem;color:var(--navy);margin:28px 0 10px;font-weight:700;letter-spacing:.005em}

/* Tableaux de cookies */
.legal-content .table-wrap{overflow-x:auto;margin:10px 0 24px;border:1px solid var(--line);border-radius:6px}
.legal-content table{width:100%;border-collapse:collapse;font-size:.86rem;min-width:560px;background:#fff}
.legal-content th{text-align:left;padding:10px 14px;background:var(--bg-soft);color:var(--navy);font-weight:700;border-bottom:2px solid var(--yellow);font-size:.82rem;letter-spacing:.01em;white-space:nowrap}
.legal-content td{padding:10px 14px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--text);font-size:.86rem;line-height:1.5}
.legal-content tr:last-child td{border-bottom:0}
.legal-content td code,.legal-content p code{font-family:"SF Mono",Menlo,Consolas,monospace;color:var(--navy);background:rgba(247,181,0,.1);padding:2px 6px;border-radius:3px;font-size:.82em}

@media(max-width:680px){
  .legal-hero{padding:44px 0 28px}
  .legal-body{padding:36px 0 60px}
  .legal-content h2{font-size:1.08rem;margin:32px 0 12px}
  .legal-content p,.legal-content li{font-size:.92rem;text-align:left}
}

/* =========================================================
   PAGES LÉGALES (Termes, Cookies, Confidentialité)
   ========================================================= */
.legal{padding:70px 0 90px}
.legal .wrap{max-width:920px}
.legal .legal-intro{color:var(--text);font-size:1rem;margin-bottom:18px;text-align:justify}
.legal h2{color:var(--navy);font-size:clamp(1.15rem,2vw,1.4rem);font-weight:700;margin:38px 0 14px;letter-spacing:.005em}
.legal p{color:var(--text);font-size:.96rem;margin-bottom:12px;text-align:justify;line-height:1.65}
.legal ul{margin:8px 0 16px 22px}
.legal ul li{color:var(--text);font-size:.96rem;margin-bottom:10px;line-height:1.6;list-style:disc;padding-left:4px}
.legal strong{color:var(--navy);font-weight:600}
.legal a{color:var(--yellow-deep);font-weight:500;text-decoration:underline}
.legal a:hover{color:var(--navy)}

@media(max-width:680px){
  .legal{padding:50px 0 70px}
  .legal h2{margin:30px 0 12px}
}
