
/* ======= NEXTU CARDS (v1.4.0) — version consolidée ======= */

/* Scope + police (Arial partout) */
.nextu *{
  box-sizing: border-box !important;
  font-family: Arial, Helvetica, sans-serif !important;
}
.nextu{
  --primary:#122C40;
  --blue:#122C40;   /* on met le bouton sur la même teinte */
  --chip:#0f172a;
  --muted:#6b7280;
}

/* Filtres */
.nextu .nu-filters{
  display:flex !important;
  gap:16px !important;
  align-items:flex-end !important;
  margin:0 0 20px 0 !important;
  flex-wrap:wrap !important;
}
.nextu .nu-field label{
  display:block !important;
  font-size:12px !important;
  color:var(--muted) !important;
  margin-bottom:6px !important;
}
.nextu .nu-field select{
  padding:10px 12px !important;
  border:1px solid #e5e7eb !important;
  border-radius:10px !important;
  min-width:180px !important;
}

/* Grille des cartes */
.nextu .nu-cards{
  display:grid !important;
  gap:24px !important;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr)) !important;
}

/* Carte */
.nextu .nu-card{
  display:flex !important;
  flex-direction:column !important;
  text-decoration:none !important;
  color:inherit !important;
  background:#fff !important;
  border:1px solid #e5e7eb !important;
  border-radius:16px !important;
  overflow:hidden !important;
  box-shadow:0 1px 2px rgba(16,24,40,.04) !important;
}

/* Bandeau haut : couleur fixe + pas d’écart, image masquée */
.nextu .nu-media{
  position:relative !important;
  height:160px !important;
  background:#122C40 !important;
  margin:0 !important;
  padding:0 !important;
  display:block !important;
}
.nextu .nu-media img{ display:none !important; }

/* Badge date */
.nextu .nu-badge-date{
  position:absolute !important;
  top:12px !important;
  left:12px !important;
  background:#fff !important;
  border-radius:10px !important;
  padding:6px 8px !important;
  text-align:center !important;
  box-shadow:0 1px 3px rgba(0,0,0,.15) !important;
}
.nextu .nu-badge-date .d{ font-weight:800 !important; font-size:18px !important; line-height:1 !important; }
.nextu .nu-badge-date .m{ font-size:10px !important; letter-spacing:.08em !important; }

/* Pastilles */
.nextu .nu-chip{
  position:absolute !important;
  color:#fff !important;
  background:rgba(0,0,0,.35) !important;
  padding:6px 10px !important;
  border-radius:9999px !important;
  font-weight:700 !important;
  display:flex !important;
  gap:6px !important;
  align-items:center !important;
}
/* Pastille ville — MASQUÉE */
.nextu .nu-chip-campus{ display:none !important; }
/* Pastille type — même couleur que le bandeau */
.nextu .nu-chip-type{ bottom:12px !important; left:12px !important; background:#122C40 !important; }

/* Corps de carte */
.nextu .nu-body{
  padding:16px 18px !important;
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
}
.nextu .nu-title{
  margin:0 !important;
  font-size:22px !important;
  font-weight:600 !important;
  color:#111827 !important;
}
.nextu .nu-meta{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
  display:grid !important;
  gap:6px !important;
  color:#374151 !important;
}
.nextu .nu-meta i{ margin-right:6px !important; }

/* Bouton : #122C40, une seule ligne */
.nextu .nu-btn{
  margin-top:auto !important;
  display:inline-block !important;      /* pas full width */
  background:#122C40 !important;
  color:#fff !important;
  border:1px solid #122C40 !important;
  border-radius:10px !important;
  padding:12px 16px !important;
  font-weight:800 !important;
  white-space:nowrap !important;        /* pas de retour à la ligne */
}

/* (optionnel) si le texte du bouton déborde : réduire légèrement */
@media (max-width: 380px){
  .nextu .nu-btn{ font-size:14px !important; }
}

/* ======= SECTION PAGES FILLE (ancienne n-page) ======= */
/* Ces règles sont restreintes au contexte .nextu.n-page pour éviter toute collision avec les cartes de la page mère. */

.nextu.n-page{ width:100% !important; max-width:none !important; }

.nextu .nu-hero{
  background:var(--primary) !important;
  color:#fff !important;
  padding:48px 0 !important;
  position:relative !important;
  margin-left:calc(50% - 50vw) !important;
  margin-right:calc(50% - 50vw) !important;
  padding-left:calc(50vw - 50%) !important;
  padding-right:calc(50vw - 50%) !important;
  width:100vw !important;
}
.nextu .nu-hero .nu-container{ text-align:center !important; }
.nextu .nu-hero .ic i{ font-size:32px !important; }
.nextu .nu-hero h1{ margin:8px 0 0 0 !important; font-weight:600 !important; }

.nextu .nu-container{ max-width:1120px !important; margin:0 auto !important; padding:0 24px !important; }
.nextu .nu-pad{ padding:48px 0 !important; }
.nextu .nu-cols{ display:grid !important; grid-template-columns:1fr !important; gap:24px !important; }
@media(min-width:1000px){ .nextu .nu-cols{ grid-template-columns:1fr 1fr !important; } }

/* La carte interne des pages fille est scindée pour ne pas impacter les cartes de la page mère */
.nextu.n-page .nu-card{
  background:#fff !important;
  border:1px solid #e5e7eb !important;
  border-radius:16px !important;
  padding:24px !important;
  box-shadow:0 1px 2px rgba(16,24,40,.04) !important;
}

.nextu .nu-h2{
  margin:0 0 12px 0 !important;
  font-size:24px !important;
  font-weight:400 !important;
  color:#122C40 !important;
}
.nextu .nu-kpis{ display:grid !important; grid-template-columns:1fr 1fr !important; gap:12px !important; }
.nextu .nu-kpis .it{
  background:#f3f4f6 !important;
  border-radius:12px !important;
  padding:14px !important;
  display:flex !important;
  gap:10px !important;
  align-items:center !important;
}
.nextu .nu-kpis .k{ font-size:12px !important; color:#6b7280 !important; }
.nextu .nu-kpis .v{ font-weight:700 !important; }
.nextu .nu-program{ display:grid !important; gap:12px !important; }
.nextu .nu-program .row{
  display:flex !important;
  gap:12px !important;
  padding:12px !important;
  border:1px solid #eef2f7 !important;
  border-radius:12px !important;
  background:#f9fafb !important;
}
.nextu .nu-program .row .t{ font-weight:700 !important; }
.nextu .nu-addr{ margin-top:16px !important; color:#374151 !important; }
