Basculer le menu
Changer de menu des préférences
Basculer le menu personnel
Non connecté(e)
Votre adresse IP sera visible au public si vous faites des modifications.

« Modèle:Roadmap/styles.css » : différence entre les versions

De Nefald
Hiob (discussion | contributions)
tags
Hiob (discussion | contributions)
mAucun résumé des modifications
 
(7 versions intermédiaires par le même utilisateur non affichées)
Ligne 2 : Ligne 2 :
   ROADMAP — Design intégré au skin Citizen
   ROADMAP — Design intégré au skin Citizen
   Utilise var() Citizen pour surfaces/textes (dark mode auto)
   Utilise var() Citizen pour surfaces/textes (dark mode auto)
   Couleurs statuts en hex direct (pas de custom properties)
   Couleurs statuts via palette --nefald-* (Citizen.css)
   ============================================================ */
   ============================================================ */
/* --- Variables locales statuts (dérivées de --nefald-*) --- */
:root {
--roadmap-idea-bg:          var(--nefald-neutral-bg);
--roadmap-idea-text:        var(--nefald-neutral-text);
--roadmap-idea-border:      var(--nefald-neutral-border);
--roadmap-planned-bg:        var(--nefald-warning-bg);
--roadmap-planned-text:      var(--nefald-warning-text);
--roadmap-planned-border:    var(--nefald-warning-border);
--roadmap-inprogress-bg:    var(--nefald-info-bg);
--roadmap-inprogress-text:  var(--nefald-info-text);
--roadmap-inprogress-border: var(--nefald-info-border);
--roadmap-done-bg:          var(--nefald-success-bg);
--roadmap-done-text:        var(--nefald-success-text);
--roadmap-done-border:      var(--nefald-success-border);
--roadmap-cancelled-bg:      var(--nefald-danger-bg);
--roadmap-cancelled-text:    var(--nefald-danger-text);
--roadmap-cancelled-border:  var(--nefald-danger-border);
}


/* --- Conteneur principal --- */
/* --- Conteneur principal --- */
.roadmap-container {
.roadmap-container {
  width: 100%;
width: 100%;
  max-width: none;
max-width: none;
  margin: 1.5em 0;
margin: 1.5em 0;
  border-radius: 12px;
border-radius: 12px;
  overflow: hidden;
overflow: hidden;
  border: 1px solid rgba(0,0,0,0.08);
border: 1px solid var(--border-color-base);
  background: var(--color-surface-1, #f8f9fa);
background: var(--color-surface-1);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}
}


/* --- Header --- */
/* --- Header --- */
.roadmap-header {
.roadmap-header {
  background: var(--color-surface-2, #eaecf0);
background: var(--color-surface-2);
  padding: 1.4em 1.5em 1.2em;
padding: 1.4em 1.5em 1.2em;
  border-bottom: 1px solid rgba(0,0,0,0.08);
border-bottom: 1px solid var(--border-color-base);
}
}


.roadmap-header-title {
.roadmap-header-title {
  font-size: 1.4em;
font-size: 1.4em;
  font-weight: 700;
font-weight: 700;
  color: var(--color-emphasized, #1a1a2e);
color: var(--color-emphasized);
  margin: 0;
margin: 0;
  line-height: 1.3;
line-height: 1.3;
}
}


.roadmap-subtitle {
.roadmap-subtitle {
  font-size: 0.85em;
font-size: 0.85em;
  color: var(--color-subtle, #72777d);
color: var(--color-subtle);
  margin-top: 0.3em;
margin-top: 0.3em;
}
}


/* --- Statistiques conteneur --- */
/* --- Statistiques conteneur --- */
.roadmap-stats {
.roadmap-stats {
  display: flex;
display: flex;
  flex-wrap: wrap;
flex-wrap: wrap;
  gap: 0.6em;
gap: 0.6em;
  padding: 1em 1.5em;
padding: 1em 1.5em;
  background: var(--color-surface-0, #ffffff);
background: var(--color-surface-0);
  border-bottom: 1px solid rgba(0,0,0,0.08);
border-bottom: 1px solid var(--border-color-base);
}
}


/* --- Stat box de base --- */
/* --- Stat box de base --- */
.roadmap-stat {
.roadmap-stat {
  display: flex;
display: flex;
  flex-direction: column;
flex-direction: column;
  align-items: center;
align-items: center;
  min-width: 65px;
min-width: 65px;
  padding: 0.5em 0.8em;
padding: 0.5em 0.8em;
  border-radius: 8px;
border-radius: 8px;
  border: 1px solid rgba(0,0,0,0.08);
border: 1px solid var(--border-color-base);
  transition: background 0.15s ease, transform 0.15s ease;
transition: background 0.15s ease, transform 0.15s ease;
}
}


.roadmap-stat:hover {
.roadmap-stat:hover {
  transform: translateY(-1px);
transform: translateY(-1px);
}
}


.roadmap-stat-count {
.roadmap-stat-count {
  font-size: 1.3em;
font-size: 1.3em;
  font-weight: 700;
font-weight: 700;
  line-height: 1;
line-height: 1;
}
}


.roadmap-stat-label {
.roadmap-stat-label {
  font-size: 0.7em;
font-size: 0.7em;
  color: var(--color-subtle, #72777d);
color: var(--color-subtle);
  text-transform: uppercase;
text-transform: uppercase;
  letter-spacing: 0.03em;
letter-spacing: 0.03em;
  margin-top: 0.2em;
margin-top: 0.2em;
}
 
/* --- Couleurs stat par statut --- */
 
.roadmap-stat-idea {
background: var(--roadmap-idea-bg);
border-color: var(--roadmap-idea-border);
}
.roadmap-stat-idea .roadmap-stat-count {
color: var(--roadmap-idea-text);
}
}


/* --- Couleurs par statut : stats --- */
.roadmap-stat-planned {
.roadmap-stat-done {
background: var(--roadmap-planned-bg);
  background: #e8f5e9;
border-color: var(--roadmap-planned-border);
  border-color: #a5d6a7;
}
}
.roadmap-stat-done .roadmap-stat-count {
.roadmap-stat-planned .roadmap-stat-count {
  color: #2e7d32;
color: var(--roadmap-planned-text);
}
}
.roadmap-stat-inprogress {
.roadmap-stat-inprogress {
  background: #fff8e1;
background: var(--roadmap-inprogress-bg);
  border-color: #ffe082;
border-color: var(--roadmap-inprogress-border);
}
}
.roadmap-stat-inprogress .roadmap-stat-count {
.roadmap-stat-inprogress .roadmap-stat-count {
  color: #f57f17;
color: var(--roadmap-inprogress-text);
}
}
.roadmap-stat-planned {
 
  background: #e3ecfa;
.roadmap-stat-done {
  border-color: #90b4e8;
background: var(--roadmap-done-bg);
border-color: var(--roadmap-done-border);
}
}
.roadmap-stat-planned .roadmap-stat-count {
.roadmap-stat-done .roadmap-stat-count {
  color: #1a56a8;
color: var(--roadmap-done-text);
}
.roadmap-stat-idea {
  background: #f3e5f5;
  border-color: #ce93d8;
}
.roadmap-stat-idea .roadmap-stat-count {
  color: #7b1fa2;
}
}
.roadmap-stat-cancelled {
.roadmap-stat-cancelled {
  background: #fce8e8;
background: var(--roadmap-cancelled-bg);
  border-color: #ef9a9a;
border-color: var(--roadmap-cancelled-border);
}
}
.roadmap-stat-cancelled .roadmap-stat-count {
.roadmap-stat-cancelled .roadmap-stat-count {
  color: #c62828;
color: var(--roadmap-cancelled-text);
}
}


/* --- Barre de progression --- */
/* --- Barre de progression --- */
.roadmap-progress-wrap {
.roadmap-progress-wrap {
  padding: 0.8em 1.5em 1em;
padding: 0.8em 1.5em 1em;
  background: var(--color-surface-0, #ffffff);
background: var(--color-surface-0);
  border-bottom: 1px solid rgba(0,0,0,0.08);
border-bottom: 1px solid var(--border-color-base);
}
}


.roadmap-progress-label {
.roadmap-progress-label {
  font-size: 0.82em;
font-size: 0.82em;
  color: var(--color-subtle, #72777d);
color: var(--color-subtle);
  margin-bottom: 0.5em;
margin-bottom: 0.5em;
}
}


.roadmap-progress-bar {
.roadmap-progress-bar {
  width: 100%;
width: 100%;
  height: 10px;
height: 10px;
  background: var(--color-surface-3, #ddd);
background: var(--color-surface-3);
  border-radius: 99px;
border-radius: 99px;
  overflow: hidden;
overflow: hidden;
}
}


.roadmap-progress-fill {
.roadmap-progress-fill {
  height: 100%;
height: 100%;
  background: #3366cc;
background: var(--color-progressive);
  border-radius: 99px;
border-radius: 99px;
  transition: width 0.6s ease;
transition: width 0.6s ease;
}
}


/* --- Sections --- */
/* --- Sections --- */
.roadmap-section {
.roadmap-section {
  border-top: 1px solid rgba(0,0,0,0.06);
border-top: 1px solid var(--border-color-base);
}
}


.roadmap-section-title {
.roadmap-section-title {
  font-size: 0.82em;
font-size: 0.82em;
  font-weight: 700;
font-weight: 700;
  text-transform: uppercase;
text-transform: uppercase;
  letter-spacing: 0.06em;
letter-spacing: 0.06em;
  color: var(--color-subtle, #72777d);
color: var(--color-subtle);
  padding: 0.8em 1.5em 0.4em;
padding: 0.8em 1.5em 0.4em;
  background: var(--color-surface-2, #eaecf0);
background: var(--color-surface-2);
}
}


/* --- Items --- */
/* --- Items --- */
.roadmap-item {
.roadmap-item {
  display: flex;
display: flex;
  align-items: flex-start;
align-items: flex-start;
  gap: 0.7em;
gap: 0.7em;
  padding: 0.7em 1.5em;
padding: 0.7em 1.5em;
  border-bottom: 1px solid rgba(0,0,0,0.04);
border-bottom: 1px solid var(--border-color-base);
  transition: background 0.12s ease;
transition: background 0.12s ease;
}
}


.roadmap-item:hover {
.roadmap-item:hover {
  background: var(--color-surface-2, rgba(0,0,0,0.02));
background: var(--color-surface-2);
}
}


/* --- Bordure gauche par statut --- */
/* --- Bordure gauche par statut --- */
.roadmap-item.roadmap-done {
 
  border-left: 3px solid #2e7d32;
.roadmap-item.roadmap-idea      { border-left: 3px solid var(--roadmap-idea-border); }
}
.roadmap-item.roadmap-planned    { border-left: 3px solid var(--roadmap-planned-border); }
.roadmap-item.roadmap-inprogress {
.roadmap-item.roadmap-inprogress { border-left: 3px solid var(--roadmap-inprogress-border); }
  border-left: 3px solid #f57f17;
.roadmap-item.roadmap-done      { border-left: 3px solid var(--roadmap-done-border); }
}
.roadmap-item.roadmap-cancelled { border-left: 3px solid var(--roadmap-cancelled-border); }
.roadmap-item.roadmap-planned {
  border-left: 3px solid #1a56a8;
}
.roadmap-item.roadmap-idea {
  border-left: 3px solid #7b1fa2;
}
.roadmap-item.roadmap-cancelled {
  border-left: 3px solid #c62828;
}


.roadmap-item-content {
.roadmap-item-content {
  flex: 1;
flex: 1;
  min-width: 0;
min-width: 0;
}
}


.roadmap-item-title {
.roadmap-item-title {
  font-weight: 600;
font-weight: 600;
  color: var(--color-emphasized, #1a1a2e);
color: var(--color-emphasized);
  font-size: 0.92em;
font-size: 0.92em;
  line-height: 1.4;
line-height: 1.4;
}
}


.roadmap-item-title a {
.roadmap-item-title a {
  color: var(--color-link, #3366cc);
color: var(--color-link);
  text-decoration: none;
text-decoration: none;
}
}


.roadmap-item-title a:hover {
.roadmap-item-title a:hover {
  text-decoration: underline;
text-decoration: underline;
}
}


.roadmap-item-desc {
.roadmap-item-desc {
  font-size: 0.82em;
font-size: 0.82em;
  color: var(--color-subtle, #72777d);
color: var(--color-subtle);
  margin-top: 0.15em;
margin-top: 0.15em;
  line-height: 1.45;
line-height: 1.45;
}
}


/* --- Badges --- */
/* --- Badges --- */
.roadmap-badge {
.roadmap-badge {
  display: inline-flex;
display: inline-flex;
  align-items: center;
align-items: center;
  justify-content: center;
justify-content: center;
  width: 22px;
width: 22px;
  height: 22px;
height: 22px;
  min-width: 22px;
min-width: 22px;
  border-radius: 50%;
border-radius: 50%;
  font-size: 0.72em;
font-size: 0.72em;
  font-weight: 700;
font-weight: 700;
  flex-shrink: 0;
flex-shrink: 0;
  margin-top: 2px;
margin-top: 2px;
}
}


.roadmap-badge-done {
.roadmap-badge-idea      { background: var(--roadmap-idea-border);       color: var(--color-surface-0); }
  background: #2e7d32;
.roadmap-badge-planned    { background: var(--roadmap-planned-border);   color: var(--color-surface-0); }
  color: #ffffff;
.roadmap-badge-inprogress { background: var(--roadmap-inprogress-border); color: var(--color-surface-0); }
}
.roadmap-badge-done      { background: var(--roadmap-done-border);       color: var(--color-surface-0); }
.roadmap-badge-inprogress {
.roadmap-badge-cancelled { background: var(--roadmap-cancelled-border); color: var(--color-surface-0); }
  background: #f57f17;
 
  color: #ffffff;
/* =====================================================
}
  TAGS — Roadmap
.roadmap-badge-planned {
  ===================================================== */
  background: #1a56a8;
  color: #ffffff;
}
.roadmap-badge-idea {
  background: #7b1fa2;
  color: #ffffff;
}
.roadmap-badge-cancelled {
  background: #c62828;
  color: #ffffff;
}


/* --- Tags --- */
.roadmap-tags {
.roadmap-tags {
  display: flex;
display: flex;
  flex-wrap: wrap;
flex-wrap: wrap;
  gap: 0.3em;
gap: 0.3em;
  margin-top: 0.3em;
margin-top: 0.3em;
}
}
/* Base tag */


.roadmap-tag {
.roadmap-tag {
  font-size: 0.7em;
font-size: 0.7em;
  font-weight: 600;
font-weight: 600;
  padding: 0.15em 0.55em;
padding: 0.15em 0.55em;
  border-radius: 99px;
border-radius: 8px;
  white-space: nowrap;
white-space: nowrap;
  background: var(--color-surface-3, #ddd);
background: var(--color-surface-3);
  color: var(--color-subtle, #555);
color: var(--color-subtle);
}
}


.roadmap-tag-gameplay {
/* --- Général --- */
  background: #e0f2e9;
  color: #1b6e33;
}
.roadmap-tag-technique {
  background: #e0e8f5;
  color: #2a4d8e;
}
.roadmap-tag-contenu {
  background: #fdf0e0;
  color: #7a5220;
}
.roadmap-tag-interface {
  background: #fce8e8;
  color: #8e2a2a;
}
.roadmap-tag-event {
  background: #f0e0f5;
  color: #5e2a7a;
}
.roadmap-tag-wiki {
  background: #e0f5f0;
  color: #1a6e55;
}
.roadmap-tag-discord {
  background: #e8e0f5;
  color: #3a2a7a;
}


.roadmap-tag-economie {
.roadmap-tag-gameplay  { background: var(--nefald-success-bg);  color: var(--nefald-success-text); }
   background: #fce4ec;
.roadmap-tag-contenu   { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }
  color: #880e4f;
.roadmap-tag-event    { background: var(--nefald-neutral-bg);  color: var(--nefald-neutral-text); }
}
.roadmap-tag-interface { background: var(--nefald-neutral-bg);  color: var(--nefald-neutral-text); }


.roadmap-tag-quetes {
/* --- Monde & Exploration --- */
  background: #e8d5f5;
  color: #6a1b9a;
}


.roadmap-tag-build {
.roadmap-tag-monde      { background: var(--nefald-info-bg); color: var(--nefald-info-text); }
  background: #fff3e0;
.roadmap-tag-spawn      { background: var(--nefald-info-bg); color: var(--nefald-info-text); }
   color: #e65100;
.roadmap-tag-build       { background: var(--nefald-info-bg); color: var(--nefald-info-text); }
}
.roadmap-tag-exploration { background: var(--nefald-info-bg); color: var(--nefald-info-text); }
.roadmap-tag-transport   { background: var(--nefald-info-bg); color: var(--nefald-info-text); }


.roadmap-tag-bestiaire {
/* --- Gameplay & Combat --- */
  background: #fff9c4;
  color: #f57f17;
}


.roadmap-tag-roleplay {
.roadmap-tag-combat    { background: var(--nefald-danger-bg);  color: var(--nefald-danger-text); }
  background: #e0f7fa;
.roadmap-tag-quetes    { background: var(--nefald-danger-bg);  color: var(--nefald-danger-text); }
  color: #00695c;
.roadmap-tag-metier    { background: var(--nefald-danger-bg);  color: var(--nefald-danger-text); }
}
.roadmap-tag-magie    { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }
.roadmap-tag-bestiaire { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-roleplay  { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }
.roadmap-tag-economie  { background: var(--nefald-success-bg); color: var(--nefald-success-text); }


.roadmap-tag-moderation {
/* --- Technique & Administration --- */
  background: #e8f5e9;
  color: #2e7d32;
}


.roadmap-tag-admin {
.roadmap-tag-technique  { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
  background: #fce4ec;
.roadmap-tag-plugin      { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
  color: #ad1457;
.roadmap-tag-config      { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
}
.roadmap-tag-performance { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
.roadmap-tag-securite    { background: var(--nefald-danger-bg);  color: var(--nefald-danger-text); }
.roadmap-tag-permissions { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }
.roadmap-tag-sauvegarde  { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
.roadmap-tag-dev        { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-admin      { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-moderation  { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }


.roadmap-tag-communication {
/* --- Communication & Documentation --- */
  background: #f1f8e9;
  color: #558b2f;
}


.roadmap-tag-dev {
.roadmap-tag-communication { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
  background: #ede7f6;
.roadmap-tag-discord      { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
  color: #4527a0;
.roadmap-tag-wiki          { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
}


/* --- Date --- */
/* --- Date --- */
.roadmap-date {
.roadmap-date {
  flex-shrink: 0;
flex-shrink: 0;
  font-size: 0.72em;
font-size: 0.72em;
  color: var(--color-subtle, #72777d);
color: var(--color-subtle);
  padding: 0.2em 0.6em;
padding: 0.2em 0.6em;
  background: var(--color-surface-2, #eaecf0);
background: var(--color-surface-2);
  border-radius: 6px;
border-radius: 6px;
  margin-top: 2px;
margin-top: 2px;
  white-space: nowrap;
white-space: nowrap;
}
}


/* --- Légende --- */
/* --- Légende --- */
.roadmap-legend {
.roadmap-legend {
  display: flex;
display: flex;
  flex-wrap: wrap;
flex-wrap: wrap;
  gap: 1em;
gap: 1em;
  padding: 0.8em 1.5em;
padding: 0.8em 1.5em;
  background: var(--color-surface-2, #eaecf0);
background: var(--color-surface-2);
  border-top: 1px solid rgba(0,0,0,0.08);
border-top: 1px solid var(--border-color-base);
  font-size: 0.78em;
font-size: 0.78em;
  color: var(--color-subtle, #72777d);
color: var(--color-subtle);
}
}


.roadmap-legend-item {
.roadmap-legend-item {
  display: inline-flex;
display: inline-flex;
  align-items: center;
align-items: center;
  gap: 0.4em;
gap: 0.4em;
}
}


.roadmap-legend-item .roadmap-badge {
.roadmap-legend-item .roadmap-badge {
  width: 16px;
width: 16px;
  height: 16px;
height: 16px;
  min-width: 16px;
min-width: 16px;
  font-size: 0.6em;
font-size: 0.6em;
}
}


/* --- Responsive --- */
/* --- Responsive --- */
@media (max-width: 640px) {
@media (max-width: 640px) {
  .roadmap-stats {
.roadmap-stats         { padding: 0.8em 1em; gap: 0.4em; }
    padding: 0.8em 1em;
.roadmap-stat           { min-width: 55px; padding: 0.4em 0.6em; }
    gap: 0.4em;
.roadmap-item           { padding: 0.6em 1em; }
  }
.roadmap-date           { display: none; }
  .roadmap-stat {
.roadmap-header         { padding: 1em; }
    min-width: 55px;
.roadmap-section-title { padding: 0.6em 1em; }
    padding: 0.4em 0.6em;
.roadmap-progress-wrap { padding: 0.6em 1em 0.8em; }
  }
  .roadmap-item {
    padding: 0.6em 1em;
  }
  .roadmap-date {
    display: none;
  }
  .roadmap-header {
    padding: 1em;
  }
  .roadmap-section-title {
    padding: 0.6em 1em;
  }
  .roadmap-progress-wrap {
    padding: 0.6em 1em 0.8em;
  }
}
}

Dernière version du 2 mars 2026 à 20:17

/* ============================================================
   ROADMAP — Design intégré au skin Citizen
   Utilise var() Citizen pour surfaces/textes (dark mode auto)
   Couleurs statuts via palette --nefald-* (Citizen.css)
   ============================================================ */

/* --- Variables locales statuts (dérivées de --nefald-*) --- */

:root {
--roadmap-idea-bg:           var(--nefald-neutral-bg);
--roadmap-idea-text:         var(--nefald-neutral-text);
--roadmap-idea-border:       var(--nefald-neutral-border);

--roadmap-planned-bg:        var(--nefald-warning-bg);
--roadmap-planned-text:      var(--nefald-warning-text);
--roadmap-planned-border:    var(--nefald-warning-border);

--roadmap-inprogress-bg:     var(--nefald-info-bg);
--roadmap-inprogress-text:   var(--nefald-info-text);
--roadmap-inprogress-border: var(--nefald-info-border);

--roadmap-done-bg:           var(--nefald-success-bg);
--roadmap-done-text:         var(--nefald-success-text);
--roadmap-done-border:       var(--nefald-success-border);

--roadmap-cancelled-bg:      var(--nefald-danger-bg);
--roadmap-cancelled-text:    var(--nefald-danger-text);
--roadmap-cancelled-border:  var(--nefald-danger-border);
}

/* --- Conteneur principal --- */

.roadmap-container {
width: 100%;
max-width: none;
margin: 1.5em 0;
border-radius: 12px;
overflow: hidden;
border: 1px solid var(--border-color-base);
background: var(--color-surface-1);
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

/* --- Header --- */

.roadmap-header {
background: var(--color-surface-2);
padding: 1.4em 1.5em 1.2em;
border-bottom: 1px solid var(--border-color-base);
}

.roadmap-header-title {
font-size: 1.4em;
font-weight: 700;
color: var(--color-emphasized);
margin: 0;
line-height: 1.3;
}

.roadmap-subtitle {
font-size: 0.85em;
color: var(--color-subtle);
margin-top: 0.3em;
}

/* --- Statistiques conteneur --- */

.roadmap-stats {
display: flex;
flex-wrap: wrap;
gap: 0.6em;
padding: 1em 1.5em;
background: var(--color-surface-0);
border-bottom: 1px solid var(--border-color-base);
}

/* --- Stat box de base --- */

.roadmap-stat {
display: flex;
flex-direction: column;
align-items: center;
min-width: 65px;
padding: 0.5em 0.8em;
border-radius: 8px;
border: 1px solid var(--border-color-base);
transition: background 0.15s ease, transform 0.15s ease;
}

.roadmap-stat:hover {
transform: translateY(-1px);
}

.roadmap-stat-count {
font-size: 1.3em;
font-weight: 700;
line-height: 1;
}

.roadmap-stat-label {
font-size: 0.7em;
color: var(--color-subtle);
text-transform: uppercase;
letter-spacing: 0.03em;
margin-top: 0.2em;
}

/* --- Couleurs stat par statut --- */

.roadmap-stat-idea {
background: var(--roadmap-idea-bg);
border-color: var(--roadmap-idea-border);
}
.roadmap-stat-idea .roadmap-stat-count {
color: var(--roadmap-idea-text);
}

.roadmap-stat-planned {
background: var(--roadmap-planned-bg);
border-color: var(--roadmap-planned-border);
}
.roadmap-stat-planned .roadmap-stat-count {
color: var(--roadmap-planned-text);
}

.roadmap-stat-inprogress {
background: var(--roadmap-inprogress-bg);
border-color: var(--roadmap-inprogress-border);
}
.roadmap-stat-inprogress .roadmap-stat-count {
color: var(--roadmap-inprogress-text);
}

.roadmap-stat-done {
background: var(--roadmap-done-bg);
border-color: var(--roadmap-done-border);
}
.roadmap-stat-done .roadmap-stat-count {
color: var(--roadmap-done-text);
}

.roadmap-stat-cancelled {
background: var(--roadmap-cancelled-bg);
border-color: var(--roadmap-cancelled-border);
}
.roadmap-stat-cancelled .roadmap-stat-count {
color: var(--roadmap-cancelled-text);
}

/* --- Barre de progression --- */

.roadmap-progress-wrap {
padding: 0.8em 1.5em 1em;
background: var(--color-surface-0);
border-bottom: 1px solid var(--border-color-base);
}

.roadmap-progress-label {
font-size: 0.82em;
color: var(--color-subtle);
margin-bottom: 0.5em;
}

.roadmap-progress-bar {
width: 100%;
height: 10px;
background: var(--color-surface-3);
border-radius: 99px;
overflow: hidden;
}

.roadmap-progress-fill {
height: 100%;
background: var(--color-progressive);
border-radius: 99px;
transition: width 0.6s ease;
}

/* --- Sections --- */

.roadmap-section {
border-top: 1px solid var(--border-color-base);
}

.roadmap-section-title {
font-size: 0.82em;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--color-subtle);
padding: 0.8em 1.5em 0.4em;
background: var(--color-surface-2);
}

/* --- Items --- */

.roadmap-item {
display: flex;
align-items: flex-start;
gap: 0.7em;
padding: 0.7em 1.5em;
border-bottom: 1px solid var(--border-color-base);
transition: background 0.12s ease;
}

.roadmap-item:hover {
background: var(--color-surface-2);
}

/* --- Bordure gauche par statut --- */

.roadmap-item.roadmap-idea       { border-left: 3px solid var(--roadmap-idea-border); }
.roadmap-item.roadmap-planned    { border-left: 3px solid var(--roadmap-planned-border); }
.roadmap-item.roadmap-inprogress { border-left: 3px solid var(--roadmap-inprogress-border); }
.roadmap-item.roadmap-done       { border-left: 3px solid var(--roadmap-done-border); }
.roadmap-item.roadmap-cancelled  { border-left: 3px solid var(--roadmap-cancelled-border); }

.roadmap-item-content {
flex: 1;
min-width: 0;
}

.roadmap-item-title {
font-weight: 600;
color: var(--color-emphasized);
font-size: 0.92em;
line-height: 1.4;
}

.roadmap-item-title a {
color: var(--color-link);
text-decoration: none;
}

.roadmap-item-title a:hover {
text-decoration: underline;
}

.roadmap-item-desc {
font-size: 0.82em;
color: var(--color-subtle);
margin-top: 0.15em;
line-height: 1.45;
}

/* --- Badges --- */

.roadmap-badge {
display: inline-flex;
align-items: center;
justify-content: center;
width: 22px;
height: 22px;
min-width: 22px;
border-radius: 50%;
font-size: 0.72em;
font-weight: 700;
flex-shrink: 0;
margin-top: 2px;
}

.roadmap-badge-idea       { background: var(--roadmap-idea-border);       color: var(--color-surface-0); }
.roadmap-badge-planned    { background: var(--roadmap-planned-border);    color: var(--color-surface-0); }
.roadmap-badge-inprogress { background: var(--roadmap-inprogress-border); color: var(--color-surface-0); }
.roadmap-badge-done       { background: var(--roadmap-done-border);       color: var(--color-surface-0); }
.roadmap-badge-cancelled  { background: var(--roadmap-cancelled-border);  color: var(--color-surface-0); }

/* =====================================================
   TAGS — Roadmap
   ===================================================== */

.roadmap-tags {
display: flex;
flex-wrap: wrap;
gap: 0.3em;
margin-top: 0.3em;
}

/* Base tag */

.roadmap-tag {
font-size: 0.7em;
font-weight: 600;
padding: 0.15em 0.55em;
border-radius: 8px;
white-space: nowrap;
background: var(--color-surface-3);
color: var(--color-subtle);
}

/* --- Général --- */

.roadmap-tag-gameplay  { background: var(--nefald-success-bg);  color: var(--nefald-success-text); }
.roadmap-tag-contenu   { background: var(--nefald-neutral-bg);  color: var(--nefald-neutral-text); }
.roadmap-tag-event     { background: var(--nefald-neutral-bg);  color: var(--nefald-neutral-text); }
.roadmap-tag-interface { background: var(--nefald-neutral-bg);  color: var(--nefald-neutral-text); }

/* --- Monde & Exploration --- */

.roadmap-tag-monde       { background: var(--nefald-info-bg); color: var(--nefald-info-text); }
.roadmap-tag-spawn       { background: var(--nefald-info-bg); color: var(--nefald-info-text); }
.roadmap-tag-build       { background: var(--nefald-info-bg); color: var(--nefald-info-text); }
.roadmap-tag-exploration { background: var(--nefald-info-bg); color: var(--nefald-info-text); }
.roadmap-tag-transport   { background: var(--nefald-info-bg); color: var(--nefald-info-text); }

/* --- Gameplay & Combat --- */

.roadmap-tag-combat    { background: var(--nefald-danger-bg);  color: var(--nefald-danger-text); }
.roadmap-tag-quetes    { background: var(--nefald-danger-bg);  color: var(--nefald-danger-text); }
.roadmap-tag-metier    { background: var(--nefald-danger-bg);  color: var(--nefald-danger-text); }
.roadmap-tag-magie     { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }
.roadmap-tag-bestiaire { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-roleplay  { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }
.roadmap-tag-economie  { background: var(--nefald-success-bg); color: var(--nefald-success-text); }

/* --- Technique & Administration --- */

.roadmap-tag-technique   { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-plugin      { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-config      { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-performance { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
.roadmap-tag-securite    { background: var(--nefald-danger-bg);  color: var(--nefald-danger-text); }
.roadmap-tag-permissions { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }
.roadmap-tag-sauvegarde  { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
.roadmap-tag-dev         { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-admin       { background: var(--nefald-warning-bg); color: var(--nefald-warning-text); }
.roadmap-tag-moderation  { background: var(--nefald-neutral-bg); color: var(--nefald-neutral-text); }

/* --- Communication & Documentation --- */

.roadmap-tag-communication { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
.roadmap-tag-discord       { background: var(--nefald-success-bg); color: var(--nefald-success-text); }
.roadmap-tag-wiki          { background: var(--nefald-success-bg); color: var(--nefald-success-text); }

/* --- Date --- */

.roadmap-date {
flex-shrink: 0;
font-size: 0.72em;
color: var(--color-subtle);
padding: 0.2em 0.6em;
background: var(--color-surface-2);
border-radius: 6px;
margin-top: 2px;
white-space: nowrap;
}

/* --- Légende --- */

.roadmap-legend {
display: flex;
flex-wrap: wrap;
gap: 1em;
padding: 0.8em 1.5em;
background: var(--color-surface-2);
border-top: 1px solid var(--border-color-base);
font-size: 0.78em;
color: var(--color-subtle);
}

.roadmap-legend-item {
display: inline-flex;
align-items: center;
gap: 0.4em;
}

.roadmap-legend-item .roadmap-badge {
width: 16px;
height: 16px;
min-width: 16px;
font-size: 0.6em;
}

/* --- Responsive --- */

@media (max-width: 640px) {
.roadmap-stats          { padding: 0.8em 1em; gap: 0.4em; }
.roadmap-stat           { min-width: 55px; padding: 0.4em 0.6em; }
.roadmap-item           { padding: 0.6em 1em; }
.roadmap-date           { display: none; }
.roadmap-header         { padding: 1em; }
.roadmap-section-title  { padding: 0.6em 1em; }
.roadmap-progress-wrap  { padding: 0.6em 1em 0.8em; }
}
Les témoins (''cookies'') nous aident à fournir nos services. En utilisant nos services, vous acceptez notre utilisation de témoins.