:root{
  --primary:#1e3a8a; --primary-2:#2747a9; --accent:#f59e0b;
  --text:#111827; --muted:#6b7280; --bg:#ffffff; --soft:#f6f8fb;
  --card:#ffffff; --border:#e5e7eb; --shadow:0 8px 25px rgba(0,0,0,.08);
  --radius:14px; --focus:0 0 0 4px rgba(59,130,246,.25);
  --max:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial;
  color:var(--text);background:var(--bg);line-height:1.6}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.bg-soft{background:var(--soft)}
.muted{color:var(--muted)}
code{background:#eef2ff;padding:.15rem .35rem;border-radius:6px}

.skip-link{position:absolute;left:-999px;top:12px;background:#fff;color:var(--primary);padding:.6rem .9rem;border-radius:10px;box-shadow:var(--shadow);z-index:2000}
.skip-link:focus{left:12px;outline:none;box-shadow:var(--focus)}

/* Header */
.header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid var(--border)}
.header-content{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:20px;
  padding:14px 0;
  flex-wrap:nowrap; /* empêche le menu de passer en dessous */
}


/* Brand (texte à gauche) */
.brand{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width: 210px;
}
.logo-title{font-weight:800;color:var(--primary)}
.logo-subtitle{font-size:.92rem;color:var(--muted)}

/* Navigation */
.nav{
  display:flex;
  align-items:center;
  gap:14px;
  margin-left:20px; /* 20px entre logo et menu */
  justify-content:flex-start;
  padding-left:0;
  min-width:0;
}
.nav-menu{display:flex;gap:6px;list-style:none;margin:0;padding:0;align-items:center;flex-wrap:wrap}
.nav-menu a{display:block;padding:.55rem .8rem;border-radius:10px;color:var(--text);text-decoration:none;font-weight:600;font-size:.95rem}
.nav-menu a:hover{background:rgba(30,58,138,.08)}
.nav-menu a.active{background:var(--primary);color:#fff}

.burger{display:none;border:1px solid var(--border);background:#fff;border-radius:12px;padding:10px;cursor:pointer}
.burger span{display:block;width:22px;height:2px;background:var(--primary);margin:5px 0;transition:.25s}

/* Logo à droite */
.header-logo{
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  margin-left:12px;
}
.header-logo img{
  height:56px;
  width:auto;
  display:block;
}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;border-radius:12px;
  padding:.85rem 1.05rem;font-weight:700;border:1px solid transparent;cursor:pointer}
.btn-small{padding:.6rem .85rem;border-radius:10px;font-weight:700}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-2)}
.btn-ghost{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.25)}
.btn-light{background:#fff;color:var(--primary);border-color:rgba(255,255,255,.7)}

a:focus,button:focus,input:focus,select:focus,textarea:focus{outline:none;box-shadow:var(--focus)}

/* Carousel */
.carousel{background:#0b1020}
.carousel-container{position:relative;height:min(560px,70vh);overflow:hidden}
.carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease}
.carousel-slide.active{opacity:1}
.carousel-slide img{width:100%;height:100%;object-fit:cover}
.carousel-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.58),rgba(0,0,0,.2))}
.carousel-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;gap:12px;
  max-width:var(--max);margin:0 auto;padding:0 20px;color:#fff}
.carousel-content h1,.carousel-content h2{margin:0;line-height:1.15;font-size:clamp(1.6rem,3.3vw,3rem)}
.carousel-content p{margin:0;max-width:58ch;font-size:clamp(1rem,1.6vw,1.2rem);color:rgba(255,255,255,.92)}
.carousel-buttons{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}

.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:999px;border:1px solid rgba(255,255,255,.45);
  background:rgba(0,0,0,.25);cursor:pointer}
.carousel-btn:before{content:"";display:block;width:10px;height:10px;border-right:3px solid #fff;border-bottom:3px solid #fff;
  margin:auto;transform:rotate(135deg)}
.carousel-btn.next{right:18px}
.carousel-btn.prev{left:18px}
.carousel-btn.next:before{transform:rotate(-45deg)}
.carousel-btn:hover{background:rgba(0,0,0,.38)}

.carousel-dots{position:absolute;left:0;right:0;bottom:16px;display:flex;justify-content:center;gap:10px}
.dot{width:12px;height:12px;border-radius:999px;border:1px solid rgba(255,255,255,.75);background:rgba(255,255,255,.3);cursor:pointer}
.dot.active{background:#fff;transform:scale(1.15)}

/* Layout */
.grid-2{display:grid;grid-template-columns:1.25fr .75fr;gap:22px;align-items:start}
.info-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:12px}
.stat{background:var(--soft);border:1px solid var(--border);border-radius:14px;padding:14px}
.stat-num{font-weight:900;font-size:1.6rem;color:var(--primary)}
.stat-label{color:var(--muted);font-weight:700}

.cards{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;margin-top:18px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);text-decoration:none;color:inherit}
.card img{width:100%;height:150px;object-fit:cover}
.card-body{padding:14px 14px 16px}
.card h3{margin:0 0 6px;font-size:1.05rem}
.card p{margin:0;color:var(--muted)}

.section-head{display:flex;align-items:center;justify-content:space-between;gap:14px}

/* News */
.news-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:16px}
.news-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.news-card img{width:100%;height:160px;object-fit:cover}

.news-media{position:relative;width:100%;height:160px;overflow:hidden;background:#000}
.news-media iframe{position:absolute;top:0;left:0;width:100%;height:100%}
.news-media.article-media{height:360px;border-radius:var(--radius);margin:12px 0 16px;box-shadow:var(--shadow)}
@media (max-width: 640px){
  .news-media.article-media{height:220px}
}
.news-card-content{padding:14px 14px 16px}
.news-card h3{margin:0 0 6px;font-size:1.05rem}
.news-date{margin:0 0 10px;color:var(--muted);font-weight:700;font-size:.9rem}
.news-excerpt{margin:0 0 12px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.skeleton{padding:18px;border:1px dashed var(--border);border-radius:var(--radius);color:var(--muted)}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:18px}
.cta-band h2{margin:0;color:#fff}
.cta-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Page hero */
.page-hero{position:relative;height:280px;overflow:hidden}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.6),rgba(0,0,0,.25))}
.page-hero-content{position:relative;color:#fff;padding-top:92px}
.page-hero-content h1{margin:0;font-size:clamp(1.8rem,3vw,2.7rem)}
.page-hero-content p{margin:.35rem 0 0;color:rgba(255,255,255,.92)}

/* Prose */
.prose{max-width:860px}
.prose h2{margin-top:0}
.prose h2:not(:first-child){margin-top:28px}
.prose ul,.prose ol{padding-left:1.2rem}

/* Audio list */
.audio-list{display:flex;flex-direction:column;gap:14px}
.audio-item{display:grid;grid-template-columns:160px 1fr;gap:16px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.audio-item img{width:100%;height:100%;object-fit:cover}
.audio-item > div{padding:14px}
.audio-item audio{width:100%;margin-top:10px}

/* Platforms */
.platforms{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.platform{display:block;text-decoration:none;color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-2));
  border-radius:var(--radius);padding:22px;border:1px solid rgba(255,255,255,.18);box-shadow:var(--shadow)}
.platform h2{margin:0 0 6px;color:#fff}
.platform p{margin:0 0 16px;color:rgba(255,255,255,.9)}

/* Forms */
.form-panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
label{font-weight:800}
input,select,textarea{border:1px solid var(--border);border-radius:12px;padding:12px;font:inherit}

.map-box{border:1px solid var(--border);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);overflow:hidden}
.map-placeholder{padding:18px}

/* Footer */
.footer{background:#0b1020;color:#cbd5e1;padding:46px 0 20px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:18px}
.footer h3{margin:0 0 10px;color:#fff}
.footer a{color:#cbd5e1;text-decoration:none}
.footer a:hover{color:#fff}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin:6px 0}
.social-links{display:flex;gap:10px;flex-wrap:wrap}
.social-links a{border:1px solid rgba(203,213,225,.25);padding:.4rem .6rem;border-radius:12px}
.footer-bottom{border-top:1px solid rgba(203,213,225,.15);margin-top:18px;padding-top:14px;text-align:center}

/* Responsive */
@media (max-width: 1100px){
  .cards{grid-template-columns:repeat(3,minmax(0,1fr))}
  .news-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 900px){
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .platforms{grid-template-columns:1fr}
}
@media (max-width: 1100px){
  .burger{display:block}
  .nav{position:relative}
  .nav-menu{position:absolute;right:0;top:56px;min-width:280px;max-width:92vw;background:#fff;border:1px solid var(--border);
    border-radius:16px;box-shadow:var(--shadow);padding:8px;display:none;flex-direction:column}
  .nav-menu.active{display:flex}
  .nav-menu a{padding:.75rem .9rem}


/* Mobile sous-menus */
.submenu-toggle{display:block}
.has-submenu > a{padding-right:2.6rem}
.submenu{position:static;display:none;min-width:unset;border:none;box-shadow:none;padding:0;margin:0}
.has-submenu.open > .submenu{display:block}
.submenu a{padding:.6rem .9rem;border-top:1px solid rgba(0,0,0,.06)}
  .cta-band-inner{flex-direction:column;align-items:flex-start}

  .header-content{align-items:center}
  .header-logo img{height:44px}
}
@media (max-width: 560px){
  .cards{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .audio-item{grid-template-columns:1fr}
  .page-hero-content{padding-top:78px}
}

/* Logo + Nom à gauche */

.brand-block{
  display:flex;
  align-items:center;
  gap:14px;
  order:0;
  margin-left:0;
  min-width: 300px;
}



.header-logo-img{
  height:70px;      /* Taille du logo */
  width:auto;
  display:block;
}

.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}

/* Mobile */
@media (max-width: 820px){

  .nav{ padding-left:12px; }
.header-logo-img{
    height:55px;
  }

  .brand-block{
    gap:10px;
  }

}

/* ===== Sous-menus (dropdown) ===== */
.nav-menu li{ position:relative; }

/* Espace "tampon" pour éviter que le sous-menu disparaisse quand on passe du lien au sous-menu */
.has-submenu{ padding-bottom:10px; }
.has-submenu::after{
  content:"";
  position:absolute;
  left:0;
  top:100%;
  width:100%;
  height:10px;   /* zone de transition */
}

/* Lien parent + bouton (mobile) */
.has-submenu > a{ padding-right: 2.2rem; }
.submenu-toggle{
  display:none;
  position:absolute;
  right:0.3rem;
  top:50%;
  transform:translateY(-50%);
  width:2rem;
  height:2rem;
  border:none;
  background:transparent;
  cursor:pointer;
}
.submenu-toggle::before{
  content:"▾";
  display:block;
  font-size:1rem;
  line-height:2rem;
}

/* Dropdown desktop */
.submenu{
  display:none;
  position:absolute;
  left:0;
  top:100%;
  min-width: 260px;
  padding:.5rem 0;
  margin:0;
  list-style:none;
  background: var(--primary);            /* fond comme les onglets (état actif/hover) */
  border:1px solid rgba(255,255,255,.14);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
  z-index: 60;
}
.submenu a{
  display:block;
  padding:.6rem 1rem;
  white-space:nowrap;
  font-size:.92rem;
  font-weight:600;
  color:#fff;                             /* écriture blanche */
}
.submenu li + li a{border-top:1px solid rgba(255,255,255,.12)}
.submenu a:hover,
.submenu a:focus{ background: rgba(255,255,255,.12); }

/* Reste affiché si on va vers le sous-menu */
.has-submenu:hover > .submenu,
.has-submenu:focus-within > .submenu{ display:block; }

/* Mobile */
@media (max-width: 900px){
  .has-submenu{ padding-bottom:0; }
  .has-submenu::after{ display:none; }

  .submenu{
    position:static;
    box-shadow:none;
    margin:0;
    padding:0 0 .6rem;
    border:none;
    background: transparent;
  }
  .submenu a{
    padding:.55rem .9rem .55rem 1.8rem;
    color: var(--text);
    border-top:1px solid rgba(0,0,0,.06);
  }
  .submenu a:hover,
  .submenu a:focus{ background: rgba(30,58,138,.10); }

  .submenu-toggle{ display:block; }
  .has-submenu.open > .submenu{ display:block; }
  .has-submenu.open > .submenu-toggle::before{ content:"▴"; }
}
.submenu a{ padding:.55rem .9rem .55rem 1.8rem; }
  .submenu-toggle{ display:block; }
  .has-submenu.open > .submenu{ display:block; }
  .has-submenu.open > .submenu-toggle::before{ content:"▴"; }
}

/* Séparateur vertical entre le logo et le nom */
.brand-text{
  border-left: 2px solid rgba(0,0,0,.18);
  padding-left: 12px;
  margin-left: 12px;
}


/* ===== Embeds (YouTube / iframes) ===== */
.ratio{position:relative;width:100%;overflow:hidden;border-radius:var(--radius);background:#000;}
.ratio-16x9{padding-top:56.25%;}
.ratio iframe{position:absolute;inset:0;width:100%;height:100%;}

/* ===== Callout ===== */
.callout{padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);background:rgba(0,0,0,.03);}

.brand-sep{
  width:2px;
  height:56px;
  background:var(--primary);
  opacity:1;
  display:block;
  flex:0 0 auto;
}




/* Header title layout */
.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}

.logo-line1,
.logo-line2{
  font-size:1.2rem;
  font-weight:700;
}

.logo-line3{
  font-size:0.95rem;
  font-weight:500;
  opacity:0.9;
}


/* ===== Menu en 2 lignes (5 + 5 onglets) ===== */
.nav-menu.two-rows{
  display:grid;
  grid-template-columns: repeat(5, max-content); /* 5 onglets par ligne */
  grid-auto-rows:auto;
  column-gap:18px;
  row-gap:10px;
  justify-content:start;   /* aligné à gauche */
  align-items:center;
}


/* Responsive header wrap */
@media (max-width: 1100px){
  .header-content{ flex-wrap:wrap; }
  .nav{ margin-left:0; width:100%; }
}





/* ===== Onglets sous forme de cartes colorées (couleurs fortes) ===== */

.nav-menu > li > a{
  padding:11px 20px;
  border-radius:12px;
  font-weight:600;
  color:#fff;
  transition:all 0.25s ease;
  box-shadow:0 3px 6px rgba(0,0,0,0.18);
}

/* Couleurs affirmées */
.nav-menu > li:nth-child(1)  > a{ background:#1e3fa3; } /* Accueil */
.nav-menu > li:nth-child(2)  > a{ background:#0b7d6e; } /* Etablissement */
.nav-menu > li:nth-child(3)  > a{ background:#d97706; } /* Scolarité */
.nav-menu > li:nth-child(4)  > a{ background:#7c3aed; } /* Vie scolaire */
.nav-menu > li:nth-child(5)  > a{ background:#0284c7; } /* Familles */

.nav-menu > li:nth-child(6)  > a{ background:#059669; } /* Clairef'Media */
.nav-menu > li:nth-child(7)  > a{ background:#be123c; } /* Actualités */
.nav-menu > li:nth-child(8)  > a{ background:#2563eb; } /* Numérique */
.nav-menu > li:nth-child(9)  > a{ background:#4d7c0f; } /* Clairefolios */
.nav-menu > li:nth-child(10) > a{ background:#374151; } /* Contact */

/* Hover */
.nav-menu > li > a:hover{
  transform:translateY(-3px);
  box-shadow:0 6px 14px rgba(0,0,0,0.25);
  filter:brightness(1.1);
}

/* Actif */
.nav-menu > li > a.active,
.nav-menu > li > a[aria-current="page"]{
  background:var(--primary);
  color:#fff;
  box-shadow:0 6px 16px rgba(0,0,0,0.3);
}


/* Supprimer les flèches des sous-menus */
.nav-menu li.has-submenu > a::after,
.nav-menu li > a::after{
  display:none !important;
  content:none !important;
}


/* ===== Menu en MAJUSCULES et centré ===== */
.nav-menu > li > a{
  text-transform:uppercase;
  text-align:center;
  justify-content:center;
}


/* Suppression définitive des flèches dropdown */
.nav-menu li > a::after,
.nav-menu li > a::before,
.nav-menu li.has-submenu > a::after,
.nav-menu li.has-submenu > a::before{
  content:none !important;
  display:none !important;
}




@media (max-width: 820px){
  .nav-menu > li > a{
    font-size:0.8rem;
  }
}


/* ===== Taille de police du menu ajustée (plus petite) ===== */
.nav-menu > li > a{
  font-size:0.78rem; /* plus fin et harmonisé */
  letter-spacing:0.6px;
}

@media (max-width: 820px){
  .nav-menu > li > a{
    font-size:0.72rem;
  }
}
