@charset "UTF-8";

/* Hero */
/* On force la hauteur du Hero sur page d'accueil à 600px */
.card-alaune--with-background {
  /* Medium and up */
  @media screen and (min-width: 768px) {
    min-height: 600px;
  }
}
/* End Hero */

/*Menu Langue*/
.header__tool .u-popover__title,
.pop-list__link .icon-content__content {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.header__tool .u-popover__title::after,
.pop-list__link .icon-content__content::after {
  content: "";
  display: inline-block;
  width: 22px;
  height: 15px;
  border-radius: 2px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
  flex-shrink: 0;
  vertical-align: middle;
}
.header__tool .u-popover__title::after {
  background: linear-gradient(
    to right,
    #002395 33.3%,
    #ffffff 33.3%,
    #ffffff 66.6%,
    #ed2939 66.6%
  );
}
.header__tool:has(a[href$="/es"]):has(a[href="/"]) .u-popover__title::after,
.header__tool:has(a[href$="/es"]):has(a[href$="-fr"]) .u-popover__title::after {
  background:
    linear-gradient(
      90deg,
      transparent 44%,
      #cf142b 44%,
      #cf142b 56%,
      transparent 56%
    ),
    linear-gradient(
      0deg,
      transparent 40%,
      #cf142b 40%,
      #cf142b 60%,
      transparent 60%
    ),
    linear-gradient(
      90deg,
      transparent 38%,
      #ffffff 38%,
      #ffffff 62%,
      transparent 62%
    ),
    linear-gradient(
      0deg,
      transparent 32%,
      #ffffff 32%,
      #ffffff 68%,
      transparent 68%
    ),
    conic-gradient(
      from 0deg at 50% 50%,
      #00247d 0deg 35deg,
      #ffffff 35deg 45deg,
      #00247d 45deg 135deg,
      #ffffff 135deg 145deg,
      #00247d 145deg 215deg,
      #ffffff 215deg 225deg,
      #00247d 225deg 315deg,
      #ffffff 315deg 325deg,
      #00247d 325deg
    ) !important;
}
.header__tool:has(a[href$="/en"]):has(a[href="/"]) .u-popover__title::after,
.header__tool:has(a[href$="/en"]):has(a[href$="-fr"]) .u-popover__title::after {
  background: linear-gradient(
    to bottom,
    #aa151b 25%,
    #f1bf00 25%,
    #f1bf00 75%,
    #aa151b 75%
  ) !important;
}
a[href="/"] .icon-content__content::after,
a[href$="-fr"] .icon-content__content::after {
  background: linear-gradient(
    to right,
    #002395 33.3%,
    #ffffff 33.3%,
    #ffffff 66.6%,
    #ed2939 66.6%
  ) !important;
}
a[href$="/en"] .icon-content__content::after {
  background:
    linear-gradient(
      90deg,
      transparent 44%,
      #cf142b 44%,
      #cf142b 56%,
      transparent 56%
    ),
    linear-gradient(
      0deg,
      transparent 40%,
      #cf142b 40%,
      #cf142b 60%,
      transparent 60%
    ),
    linear-gradient(
      90deg,
      transparent 38%,
      #ffffff 38%,
      #ffffff 62%,
      transparent 62%
    ),
    linear-gradient(
      0deg,
      transparent 32%,
      #ffffff 32%,
      #ffffff 68%,
      transparent 68%
    ),
    conic-gradient(
      from 0deg at 50% 50%,
      #00247d 0deg 35deg,
      #ffffff 35deg 45deg,
      #00247d 45deg 135deg,
      #ffffff 135deg 145deg,
      #00247d 145deg 215deg,
      #ffffff 215deg 225deg,
      #00247d 225deg 315deg,
      #ffffff 315deg 325deg,
      #00247d 325deg
    ) !important;
}
a[href$="/es"] .icon-content__content::after {
  background: linear-gradient(
    to bottom,
    #aa151b 25%,
    #f1bf00 25%,
    #f1bf00 75%,
    #aa151b 75%
  ) !important;
}
.header__tool:has(.icon-user) .u-popover__title::after {
  content: none !important;
}

/* Footer*/
/* RS*/
.footer .btn-rs img {
  /* fond transparent en Light, blanc pur en Dark */
  background-color: light-dark(transparent, #ffffff);

  /* On arrondit le fond pour créer une pastille */
  border-radius: 50%;

  /* On utilise box-shadow pour agrandir la pastille blanche de 4px */
  box-shadow: 0 0 0 4px light-dark(transparent, #ffffff);

  /* Votre filtre par défaut : les icônes restent grises/noires */
  filter: grayscale(1);

  /* Animation fluide au survol */
  transition: filter 0.2s ease-in-out;
}

.footer .btn-rs img:hover {
  /* Au survol,  vraies couleurs */
  filter: grayscale(0);
}
/* LOGOS PARTENAIRES (ANR, France 2030, HR)*/
.footer .cke-layoutmanager__column--2 img {
  /* MÊME HAUTEUR pour tous les logos */
  /*height: 90px !important;*/
  /* width: auto !important; */
  object-fit: contain;
  background-color: light-dark(transparent, #ffffff);
  /* border-radius: light-dark(0, 50px); */
  padding: light-dark(0, 10px);
  box-shadow: 0 0 0 4px light-dark(transparent, #ffffff);
}
/* End Footer */

/* ==========================================================================
   MOTEUR DE RECHERCHE ET FORMULAIRES FRONT
   ========================================================================== */
/* Positionnement moteur de recherche général */
#panel-search:has(form[role="search"]) {
  top: 40%;
}
h4,
h5,
h6 {
  font-size: var(--size-4);
}

/*moteur de recherhe inclus dans les pages dans un encadre*/
.ul1--include .form-field--expanded {
  margin-bottom: 1.5rem;
}
.ul1--include.universite .button--xl,
.ul1--include.campus .button--xl {
  width: 100%;
}

/* Form saisie front */
#apercu {
  background-color: #5a55ff;
  color: white;
}

#apercu:hover {
  background-color: #757dff;
}

#suppression {
  background-color: #cf3236;
  color: white;
}

#suppression:hover {
  background-color: #ff4334;
}

#mode_expert {
  background-color: white;
  color: #5a55ff;
  border: 1px solid #c2c2c2;
}

#valider-formulaire .button--success {
  background-color: #00a13d;
  color: white;
  padding: 0.75rem;
}

#valider-formulaire .button--success:hover {
  background-color: #19c154;
}

.ksup-saisie-front .form__fieldset--aligned input.reset {
  background-color: #cf3236;
  color: white;
}

.ksup-saisie-front .form__fieldset--aligned input.reset:hover {
  background-color: #ff4334;
}

#valider-formulaire .button--error,
.ksup-saisie-front .form__fieldset--aligned input.submit,
.ksup-saisie-front input[type="button"].submit {
  background-color: white;
  color: #5a55ff;
  border: 1px solid #c2c2c2;
  padding: 0.75rem;
}

/* End Form saisie front */

/*Formulaire formation*/
/* Search toolbox */
.input input {
  border: 1px solid #c5c4c3;
  border-radius: 4px;
  line-height: 150%;
  padding: 0.5rem 0.5rem;
  width: 100%;
  margin-bottom: 1rem;
}

.option b {
  display: block;
  width: 100%;
  margin-bottom: 1rem;
}

.option input[type="checkbox"] {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
  font: inherit;
  color: #df0100;
  width: 1.15em;
  height: 1.15em;
  border: 0.15em solid #df0100;
  border-radius: 0.15em;
  transform: translateY(-0.075em);
  display: grid;
  margin-right: 0.5rem;
  place-content: center;
}

.option input[type="checkbox"]::before {
  content: "";
  width: 0.65em;
  height: 0.65em;
  clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
  transform: scale(0);
  transform-origin: bottom left;
  transition: 120ms transform ease-in-out;
  box-shadow: inset 1em 1em #df0100;
  background-color: #df0100;
}

.option input[type="checkbox"]:checked::before {
  transform: scale(1);
}

.option .form-control {
  display: flex;
  flex-direction: row;
  align-items: center;
}

input[type="checkbox"]::before {
  transform-origin: bottom left;
  clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

.option > div {
  margin-bottom: 1rem;
}

.formulaire_redacteur .input {
  margin-bottom: 1rem;
}

form.formulaire_redacteur > * {
  --field-gap: initial;
}

#content input[type="submit"] {
  background: #5a55ff;
}

#content input[type="submit"] {
  background: #df0100;
  padding: 0.5rem 1rem;
  border: 1px solid #df0100;
  color: white;
}

#content input[type="submit"]#valider:hover,
#content input[type="submit"]:hover {
  background: #800000;
  border-color: #800000;
  cursor: pointer;
}

/* Small only */
@media screen and (max-width: 768px) {
  .input b {
    line-height: 2.5rem;
  }

  .option b {
    display: initial;
    width: initial;
  }
}
/* End Search toolbox */

/* Key words */
.ChampSaisie {
  border: 1px solid #c5c4c3;
  border-radius: 4px;
  line-height: 150%;
  padding: 0.5rem 0.5rem;
  width: 100%;
}
/* End Key words */

/* Fixed Main Menu-navigation positioning */
.header {
  anchor-name: --menu-nav;
}
.date-publication {
  font-size: var(--size-4);
}

header .l-content .desktop .menu__popup {
  position: absolute;
  position-anchor: --menu-nav;
  position-area: bottom;
}

header .l-content .desktop .menu__popup {
  margin-block-start: initial;
}
/* End Fixed Main Menu-Navigation positioning */

/* Admin tool */
.header__tool .pop-list .pop-list__item a {
  padding: 0.5rem 1rem 0.5rem 0.5rem;
}

.u-mis-auto .header__tool .pop-list .pop-list__item a .icon-content {
  font-size: 0.85rem;
}

.u-mis-auto .header__tool .pop-list .pop-list__item a .icon-content svg {
  height: 1.5rem;
}

#menu .menu-grid .menu-grid {
  display: none;
}

/* Focus */
.header .header__tool button:focus,
.menu__item:has(> :popover-open) > .menu__link:focus,
.menu__link:focus {
  outline: none;
  box-shadow: none;
}
.menu__item:has(> :popover-open) > .menu__link {
  box-shadow: none;
}
.menu__link--current {
    --menu-link-stroke: transparent transparent var(--color3-60) transparent;
}
/* Focus clavier */
.header .header__tool button:focus-visible,
.menu__item:has(> :popover-open) > .menu__link:focus-visible,
.menu__link:focus-visible {
  outline: 2px solid;
  outline-offset: 2px;
  outline-color: #df0100 !important;
  outline-color: -webkit-focus-ring-color;
  outline-color: -moz-focusring;
  box-shadow: none;
}
/* End Admin tool*/
/** PAGE ACCUEIL **/
/* ==========================================================================
   CHARTE GRAPHIQUE : ACCUEIL (templateULyon1) - CORRECTIONS DARK MODE & RGAA
   ========================================================================== */

/* 1. Règle dynamique et globale (Déverrouillage color-scheme) */
.main--ficheaccueil
  .l-grid[data-layout="templateULyon1"]
  .l-cell--has-background-color {
  color-scheme: inherit !important;
  background-color: light-dark(
    var(--background-light),
    var(--background-dark)
  ) !important;
}

/* 2. Titre des sections */
.main--ficheaccueil
  .l-grid[data-layout="templateULyon1"]
  .l-cell--has-background-color
  .card-toolbox__title {
  /* Contraste maximal assuré */
  color: light-dark(var(--color-light, #000000), var(--color-dark, #ffffff));
}

/* 3. Carte Agenda (.event-card) */
.main--ficheaccueil .l-grid[data-layout="templateULyon1"] .event-card {
  background-color: transparent;
}

.main--ficheaccueil .l-grid[data-layout="templateULyon1"] .event-card__body {
  /* Fond de base : Gris très clair vs Gris très sombre */
  background-color: light-dark(#f4f4f4, #222222);
  color: light-dark(#333333, #f0f0f0);
  transition: background-color 0.2s ease;
}

/* ACCESSIBILITÉ : État de survol et de focus au clavier */
.main--ficheaccueil
  .l-grid[data-layout="templateULyon1"]
  .event-card:hover
  .event-card__body,
.main--ficheaccueil
  .l-grid[data-layout="templateULyon1"]
  .event-card:focus-visible
  .event-card__body {
  /* Assombrit légèrement en mode clair, Éclaircit légèrement en mode sombre */
  background-color: light-dark(#e8e8e8, #333333);
}

.main--ficheaccueil .l-grid[data-layout="templateULyon1"] .event-card__title {
  color: light-dark(#000000, #ffffff);
}

.main--ficheaccueil .l-grid[data-layout="templateULyon1"] .event-card__type {
  color: light-dark(#555555, #cccccc);
}

/**GRANDS PROJETS - PAGE DETAILS**/
/* ==========================================================================
   CHARTE GRAPHIQUE : GRANDS PROJETS DETAILS (Lyon 1)
   Scope : .main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"]
   ========================================================================== */

/* 1. CONFIGURATION DE LA GRILLE & CONTENEUR */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 30px;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
  box-sizing: border-box;
  align-items: stretch;
  font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: light-dark(#333333, #f0f0f0);
  line-height: 1.6;
  background-color: transparent;
}

.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .l-cell {
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  min-width: 0;
  min-height: 0;
  grid-column-start: calc(var(--cell-column) + 1);
  grid-column-end: span var(--cell-column-span);
  grid-row-start: calc(var(--cell-row) + 1);
  border-radius: 4px;
  transition: all 0.3s ease;
}

@media (max-width: 991px) {
  .main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] {
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
  .main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .l-cell {
    width: 100%;
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
  }
}

/* 2. GESTION DES BACKGROUNDS PAR LIGNE */
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 0"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 1"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 2"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 3"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 5"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 6"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 7"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 8"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 9"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 10"] {
  background-color: transparent;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 1;"] {
  font-size: 2.8rem;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 3"] {
  max-width: 48rem;
  text-align: center;
  margin: auto;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 4"] {
  background-color: light-dark(var(--color3-20), #222222);
  font-size: 2rem;
  color: light-dark(var(--neutral-90), #ffffff);
  padding: 20px;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 5"] {
  max-width: 48rem;
  text-align: center;
  margin: auto;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 7"] {
  align-items: center;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 11"],
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 12"] {
  background-color: transparent !important;
  padding: 20px;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 13"] {
  background-color: light-dark(#f4f4f4, #1a1a1a);
  padding: 0;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 14"] {
  background-color: light-dark(#333333, #0a0a0a);
  color: #ffffff;
  padding: 20px;
}

/* 3. COULEURS & LIENS */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] a {
  color: var(--color1-60);
  text-decoration: none;
  font-weight: 700;
  transition: color 0.2s ease;
}

.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] a:hover {
  text-decoration: underline;
}

/* MISE À JOUR : Les boutons pa-button se calquent sur les variables de K-Sup */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .pa-button,
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .pa-button-reverse {
  --button-content: var(--white, #ffffff);
  --button-fill: var(--color1-60);
  --icon-foreground: var(--white, #ffffff);

  display: inline-block;
  padding: 10px 25px;
  border: none;
  background-color: var(--button-fill);
  color: var(--button-content) !important;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.9rem;
  border-radius: 4px;
  text-align: center;
  text-decoration: none !important;
  line-height: 1.2;
  margin-top: 15px;
  cursor: pointer;
  width: fit-content;
  transition: all 0.3s ease;
}

.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .pa-button:hover,
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .pa-button-reverse:hover {
  --button-content: var(--color1-10);
  --button-fill: var(--color1-80);
  --icon-foreground: var(--white, #ffffff);

  background-color: var(--button-fill);
  color: var(--button-content) !important;
  transform: translateY(-2px); /* Léger effet de soulèvement conservé */
}

/* 4. COMPOSANT : CHIFFRES CLÉS */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .chiffre_cle_carte {
  background-color: light-dark(#000000, #222222);
  color: #ffffff;
  padding: 30px 20px;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-align: center;
  border-radius: 4px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .chiffre_cle_carte:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 4"]
  .chiffre_cle_carte {
  background-color: transparent;
  box-shadow: none;
  color: inherit;
  padding: 10px;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 4"]
  .chiffre_cle_unique__chiffre_cle,
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 4"]
  .chiffre_cle_unique___chiffre_cle_secondaire {
  color: inherit;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .Picto__container
  img.Picto {
  height: 60px;
  width: auto;
  margin-bottom: 20px;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .chiffre_cle_unique__chiffre_cle {
  font-family: Bitter, serif;
  font-weight: 700;
  color: #ffffff;
  margin: 0 0 10px 0;
  line-height: 1;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .l-cell[style*="--cell-row: 4"]
  .chiffre_cle_unique__chiffre_cle {
  color: light-dark(var(--neutral-90), #ffffff);
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .chiffre_cle_unique___chiffre_cle_secondaire {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.9);
  margin: 0;
  line-height: 1.4;
}

/* 5. COMPOSANT : PHOTOS */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .Photo__container {
  height: 100%;
  width: 100%;
  overflow: hidden;
  position: relative;
  border-radius: 4px;
}

.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .Photo__actu {
  width: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  min-height: 350px;
}

/* 6. COMPOSANT : LISTE ACTUALITÉS */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] ul.liste-actualites {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  padding: 0;
  list-style: none;
  margin: 0;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  li.avec_vignette_enligne {
  display: flex;
  flex-direction: column;
  width: 100%;
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

@media (max-width: 768px) {
  .main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] ul.liste-actualites {
    grid-template-columns: 1fr;
  }
}

.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .vignette_deco3 {
  order: 1;
  width: 100%;
  margin-bottom: 20px;
}

.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .vignette_deco3 img {
  width: 100%;
  height: 15.625rem;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .vignette_deco2 {
  order: 2;
  flex-grow: 1;
  margin-bottom: 15px;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .vignette_deco2
  strong
  a {
  font-family: Bitter, serif;
  font-size: 1.4rem;
  color: var(--color1-60);
  display: block;
  margin-bottom: 10px;
  line-height: 1.3;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .container_td
  .thematique {
  font-weight: 800;
  text-transform: uppercase;
  font-size: 0.85rem;
  color: light-dark(var(--neutral-90), #cccccc);
  margin-bottom: 5px;
}

.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .resume {
  color: light-dark(#333333, #eeeeee);
  font-size: 0.95rem;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  a.lirelasuite.lien_interne {
  order: 3;
  margin-top: auto;
  align-self: flex-start;
  background-color: transparent;
  color: var(--color1-60) !important;
  padding: 0;
  font-weight: 700;
  font-size: 1rem;
  text-transform: none;
  border: none;
  display: inline-block;
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  a.lirelasuite.lien_interne:hover {
  background-color: transparent;
  text-decoration: underline;
  transform: none;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  a.lirelasuite.lien_interne::after {
  content: " >";
  font-size: 0.9em;
  margin-left: 3px;
}

/* 7. AUTRES COMPOSANTS */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .damier_text {
  padding: 40px;
  height: 100%;
  flex-direction: column;
  justify-content: center;
  border: 1px solid light-dark(#e1e1e1, #444444);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}

.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .damier_text_logo__container {
  margin-bottom: 25px;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .damier_text__logo {
  max-height: 80px;
  width: auto;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .damier_text___titre {
  font-family: Bitter, serif, sans-serif;
  font-size: 2.2rem;
  color: light-dark(var(--neutral-90), #ffffff);
  font-weight: 700;
  margin-bottom: 15px;
  line-height: 1.2;
  text-transform: uppercase;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .damier_text___sousTitre {
  font-size: 1.1rem;
  color: light-dark(var(--neutral-90), #cccccc);
  margin-bottom: 25px;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .damier_text___hashTag {
  font-size: 0.95rem;
  color: light-dark(var(--neutral-90), #cccccc);
  margin-bottom: 30px;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .wrapper___hashTag {
  margin-right: 15px;
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 800;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .hashtag {
  color: var(--color1-60);
  font-weight: 800;
  margin-right: 3px;
}

/* Toolbox */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .toolboxCard_wrapper {
  margin-bottom: 8px;
  width: 100%;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .toolbox__titre {
  font-family: Bitter, serif;
  font-size: 2rem;
  color: light-dark(var(--neutral-90), #ffffff);
  margin-bottom: 25px;
  padding-left: 20px;
  text-align: center;
  text-transform: uppercase;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .card.toolboxCard {
  padding: 35px;
  background-color: light-dark(#ffffff, transparent);
  color: light-dark(#333333, #f0f0f0);
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .card.toolboxCard:empty,
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .card.toolboxCard:not(:has(*)) {
  display: none;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .toolbox__contenu p,
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .toolbox__contenu li {
  color: light-dark(#333333, #f0f0f0);
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .toolbox__contenu p {
  margin-bottom: 1.2rem;
  text-align: justify;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .toolbox__contenu h3 {
  color: var(--color1-60);
  font-size: 1.4rem;
  margin-top: 2rem;
  margin-bottom: 1rem;
  font-weight: 700;
  font-family: Bitter, serif;
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .toolbox__contenu
  span[style*="background"] {
  background-color: transparent !important;
  color: inherit !important;
}

/* Partenaires */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .partenairesCard {
  background-color: transparent;
  padding: 10px;
  text-align: center;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .partenaires__titre {
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
  color: light-dark(#666666, #cccccc);
  margin-bottom: 25px;
  display: inline-block;
  border-bottom: 2px solid light-dark(#dddddd, #444444);
  padding-bottom: 10px;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .partenaires__liste {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 40px;
  padding: 0;
  list-style: none;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .partenaire__image {
  max-height: 70px;
  max-width: 180px;
  width: auto;
  filter: grayscale(100%);
  opacity: 0.6;
  transition: all 0.3s ease;
  background-color: light-dark(transparent, rgba(255, 255, 255, 0.85));
  padding: light-dark(0, 8px);
  border-radius: light-dark(0, 4px);
}
.main--ficheaccueil
  .l-grid[data-layout="GRANDSPROJETS"]
  .partenaire__image:hover {
  filter: grayscale(0%);
  opacity: 1;
}

/* Contact */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .contact {
  background-color: transparent;
  padding: 50px;
  text-align: center;
  border-top: 4px solid var(--color1-60);
  margin-top: 0;
  width: 100%;
  box-sizing: border-box;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .contact___titre {
  font-family: Bitter, serif;
  font-size: 1.8rem;
  color: light-dark(var(--neutral-90), #ffffff);
  margin-bottom: 25px;
  text-transform: uppercase;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .contact__sousTitre {
  font-size: 1.2rem;
  font-weight: 700;
  color: light-dark(var(--neutral-90), #cccccc);
  margin-bottom: 15px;
  text-transform: uppercase;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .contact__mail,
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .contact__tel {
  font-size: 1.2rem;
  color: light-dark(#333333, #ffffff);
  font-weight: 600;
  margin: 5px 0;
}

/* Réseaux Sociaux */
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .card.reseauxCard {
  background-color: transparent;
  color: var(--neutral-10);
  padding: 10px;
  text-align: center;
  width: 100%;
  box-sizing: border-box;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .reseaux__titre {
  font-size: 1.1rem;
  text-transform: uppercase;
  color: #f0f0f0;
  margin-bottom: 20px;
  letter-spacing: 1px;
  border-bottom: 1px solid #555;
  display: inline-block;
  padding-bottom: 5px;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .reseaux__liste {
  display: flex;
  justify-content: center;
  gap: 25px;
  list-style: none;
  padding: 0;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .reseau__image {
  width: 45px;
  height: 45px;
  transition: transform 0.2s;
  display: block;
}
.main--ficheaccueil .l-grid[data-layout="GRANDSPROJETS"] .reseau__image:hover {
  transform: scale(1.15);
  opacity: 0.8;
}

/**GRANDS PROJETS - HUB GLOBAL**/
/* ==========================================================================
   CHARTE GRAPHIQUE : HUB GRANDS PROJETS
   Layout : .main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"]
   ========================================================================== */

/* 1. CONTENEUR PRINCIPAL (1200px max) */
.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 30px;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 15px;
  box-sizing: border-box;
  font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
  background-color: transparent;
}

/* Cellules de la grille */
.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .l-cell {
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  min-width: 0;
  grid-column-start: calc(var(--cell-column) + 1);
  grid-column-end: span var(--cell-column-span);
  grid-row-start: calc(var(--cell-row) + 1);
  margin-bottom: 20px;
}

/* Responsive Mobile (< 992px) */
@media (max-width: 991px) {
  .main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] {
    display: flex;
    flex-direction: column;
  }
  .main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .l-cell {
    width: 100%;
    grid-column: 1 / -1 !important;
  }
}

/* 2. EN-TÊTE DE PAGE (Intro texte) */
.main--ficheaccueil
  .l-grid[data-layout="HUBGRANDSPROJETS"]
  .toolboxCard_wrapper {
  text-align: center;
  margin-bottom: 40px;
  width: 100%;
}

/* Titre Principal */
.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .toolbox__titre {
  font-family: Bitter, serif;
  font-size: 2.5rem;
  font-weight: 800;
  color: light-dark(#000000, #ffffff);
  margin-bottom: 20px;
  text-transform: none;
  line-height: 1.2;
  border: none;
  padding: 0;
}

/* Texte d'intro */
.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .toolbox__contenu {
  font-size: 1.1rem;
  line-height: 1.6;
  color: light-dark(var(--neutral-90), #f0f0f0);
  max-width: 900px;
  margin: 0 auto;
}

/* Suppression du style "carte" par défaut pour l'intro */
.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .card.toolboxCard {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}

/* 3. CARTES PROJETS (.actualite) */
.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .actualite {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: transparent;
  border: none;
  align-items: flex-start;
}

/* Image (Vignette) */
.main--ficheaccueil
  .l-grid[data-layout="HUBGRANDSPROJETS"]
  .actualite__vignette {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 20px;
  margin-bottom: 25px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
}

/* Titre du projet */
.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .actualite__titre {
  font-family: Bitter, serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color1-60);
  margin: 0 0 10px 0;
  line-height: 1.2;
}

/* Sous-titre */
.main--ficheaccueil
  .l-grid[data-layout="HUBGRANDSPROJETS"]
  .actualite__sousTitre {
  font-size: 1rem;
  font-weight: 700;
  color: light-dark(var(--neutral-90), #cccccc);
  margin: 0 0 15px 0;
  line-height: 1.4;
}

/* Résumé */
.main--ficheaccueil
  .l-grid[data-layout="HUBGRANDSPROJETS"]
  .actualite__resumeLight {
  font-size: 1rem;
  line-height: 1.5;
  color: light-dark(var(--neutral-90), #eeeeee);
  margin-bottom: 20px;
  flex-grow: 1;
}

/* Tags / Mots clés */
.main--ficheaccueil
  .l-grid[data-layout="HUBGRANDSPROJETS"]
  .actualite__motsClesLight {
  margin-bottom: 20px;
  line-height: 1.8;
}

.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .hashtag_hub {
  display: inline-block;
  background-color: light-dark(#f2f2f2, #333333);
  color: light-dark(#000000, #ffffff);
  font-size: 0.9rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 4px;
  margin-right: 5px;
  margin-bottom: 5px;
}

/* Bouton "Voir le projet" */
.main--ficheaccueil .l-grid[data-layout="HUBGRANDSPROJETS"] .actualite__lien {
  --button-content: var(--white);
  --button-fill: var(--color1-60);
  --icon-foreground: var(--white);

  display: inline-block;
  padding: 10px 20px;
  border: none;
  background-color: var(--button-fill);
  color: var(--button-content);
  font-weight: 700;
  text-decoration: none;
  border-radius: 4px;
  margin-top: auto;
  transition: all 0.3s ease;
  font-size: 0.9rem;
}

.main--ficheaccueil
  .l-grid[data-layout="HUBGRANDSPROJETS"]
  .actualite__lien:hover {
  --button-content: var(--color1-10);
  --button-fill: var(--color1-80);
  --icon-foreground: var(--white);

  background-color: var(--button-fill);
  color: var(--button-content);
}

/*FICHE ANNUAIRE - PLUGIN HAL */
/* Spécialisation et réinitialisation de la zone */
.zone-hal {
  --hal-primary: light-dark(#df0100, #ff4d4d);
  --hal-bg-box: light-dark(#ffffff, #000000);
  --hal-bg-cite: light-dark(#f8f9fa, #2d1a1a);
  --hal-text-main: light-dark(#1a1a1a, #efefef);
  --hal-text-muted: light-dark(#666666, #ffffff);
  --hal-border: light-dark(#e0e0e0, #441111);

  font-family:
    system-ui,
    -apple-system,
    sans-serif;
  color: var(--hal-text-main);
}

/*TEMPORAIRE A INTEGRER DANS LES SCSS*/

/* Liste des documents */
.zone-hal .u-list-naked {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Carte de publication */
.zone-hal .box--primary {
  background-color: var(--hal-bg-box);
  border: 1px solid var(--hal-border);
  border-radius: 8px;
  padding: 1.5rem;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.zone-hal .box--primary:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Titre de la publication */
.zone-hal .title_hal {
  margin: 0;
  color: var(--hal-primary);
  font-size: 1.25rem;
  line-height: 1.4;
  text-decoration: none;
}

.zone-hal .u-text-decoration-none:hover .title_hal {
  text-decoration: underline;
}

/* Auteurs */
.zone-hal .text-weight--700 {
  font-size: 0.9rem;
  color: var(--hal-text-main);
}

/* Bloc Citation (Refonte complète) */
.zone-hal cite {
  display: block;
  position: relative;
  padding: 1rem 1rem 1rem 3rem;
  background-color: var(--hal-bg-cite);
  border-left: 4px solid var(--hal-primary);
  border-radius: 4px;
  font-style: normal;
  font-size: 0.875rem;
  color: var(--hal-text-muted);
  background-repeat: no-repeat;
  background-position: 0.75rem 1rem;
  background-size: 1.5rem;
}

/* Badges (Cartouches) */
.zone-hal .cartouche {
  display: inline-flex;
  padding: 0.25rem 0.75rem;
  background: var(--hal-bg-cite);
  border: 1px solid var(--hal-border);
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  width: fit-content;
}

/* Comité de lecture */
.zone-hal .k-dl {
  display: flex;
  gap: 0.5rem;
  font-size: 0.85rem;
  margin: 0;
}

.zone-hal .k-dt {
  color: var(--hal-text-muted);
}

.zone-hal .k-dd {
  font-weight: 600;
  color: var(--hal-primary);
}

/* Bouton */
.zone-hal .button--primary {
  align-self: flex-start;
  background-color: var(--hal-primary);
  color: white !important;
  padding: 0.6rem 1.2rem;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  border: none;
  cursor: pointer;
}

.zone-hal .button--primary:hover {
  filter: brightness(1.1);
}
.box--expand:not(:has(#tabpanel-publications > *:not(h2))):not(
    :has(#tabpanel-activities > *:not(h2))
  ) {
  display: none !important;
}
.box--expand:has(.tabs__panel > *:not(h2)) {
  display: block !important;
}
/*FICHE ANNUAIRE - PLUGIN HAL*/

blockquote,
cite,
q {
  background-position: right 2rem top 1rem;
}

/*Fix Gap Grille dans les pagelibres*/
.main--pagelibre .u-g-lg {
  gap: 0;
}
.main--actualite :not(.rich-content) figure.image {
    justify-self: center;
}

