/* ============================================
   NOVIABOT SETUP — STYLE GLASS
   Header / footer inchangés (DA), contenu en glass
   ============================================ */

/* --- Scrollbar globale glass --- */
body.setup-glass-page::-webkit-scrollbar,
body.setup-glass-page *::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
body.setup-glass-page::-webkit-scrollbar-track,
body.setup-glass-page *::-webkit-scrollbar-track {
  background: rgba(35,19,77,0.5);
  border-radius: 10px;
}
body.setup-glass-page::-webkit-scrollbar-thumb,
body.setup-glass-page *::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(185,120,247,0.4), rgba(24,231,255,0.35));
  border-radius: 10px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
body.setup-glass-page::-webkit-scrollbar-thumb:hover,
body.setup-glass-page *::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(185,120,247,0.6), rgba(24,231,255,0.55));
  background-clip: padding-box;
}
body.setup-glass-page::-webkit-scrollbar-corner,
body.setup-glass-page *::-webkit-scrollbar-corner {
  background: transparent;
}
/* Firefox scrollbar */
body.setup-glass-page {
  scrollbar-width: thin;
  scrollbar-color: rgba(185,120,247,0.4) rgba(35,19,77,0.5);
}
body.setup-glass-page * {
  scrollbar-width: thin;
  scrollbar-color: rgba(185,120,247,0.4) rgba(35,19,77,0.5);
}

/* --- Body + fond animé --- */
body.setup-glass-page {
  background: #23134d;
  color: #e8eaff;
  font-family: 'Segoe UI', sans-serif;
  padding: 0;
  min-height: 100vh;
  position: relative;
  display: flex;
  flex-direction: column;
}

body.setup-glass-page::before {
  content: '';
  position: fixed;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background:
    radial-gradient(circle at 20% 30%, rgba(185,120,247,0.15), transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(24,231,255,0.15), transparent 40%);
  animation: glass-float 20s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}

@keyframes glass-float {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  50% { transform: translate(30px, -30px) rotate(5deg); }
}

/* --- Zone principale : toute la largeur (entre header et footer) --- */
body.setup-glass-page .glass-wrap {
  flex: 1;
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 32px 28px 60px;
  box-sizing: border-box;
}

.glass-container {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

/* --- En-tête titre : sans glass, texte seul --- */
.glass-header {
  background: transparent;
  border: none;
  padding: 32px 0 28px;
  margin-bottom: 24px;
  text-align: center;
}

.glass-header-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
}

.glass-header-logo {
  width: 96px;
  height: 96px;
  object-fit: contain;
  flex-shrink: 0;
}

.glass-header h1 {
  font-size: 68px;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-align: left;
  margin: 0;
}

.glass-header .nov { color: #b978f7; }
.glass-header .ia { color: #18e7ff; }
.glass-header .bot { color: #b978f7; }

.glass-header .subtitle {
  color: #a7b2d9;
  margin-top: 8px;
  font-size: 22px;
  font-weight: 500;
  text-align: left;
}

/* --- Grille 2 colonnes (PC1 / PC2, puis Écrans / Caméra, Audio / Périphériques) --- */
.glass-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 24px;
}

@media (max-width: 900px) {
  .glass-grid {
    grid-template-columns: 1fr;
  }
}

/* --- Carte glass --- */
.glass-card {
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 24px;
  padding: 35px;
  transition: all 0.4s ease;
  /* Forcer la promotion GPU pour éviter les disparitions au scroll (Chrome/Edge) */
  will-change: transform;
  transform: translateZ(0);
}

.glass-card:hover {
  background: rgba(255,255,255,0.05);
  border-color: rgba(24,231,255,0.25);
  transform: translateY(-3px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
}

.card-title {
  font-size: 26px;
  color: #fff;
  font-weight: 800;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.card-icon {
  width: 36px;
  height: 36px;
  object-fit: contain;
  flex-shrink: 0;
}

.glass-card .card-desc {
  color: #a7b2d9;
  font-size: 16px;
  margin-bottom: 20px;
  margin-top: 0;
}

/* --- Champ (label + input) --- */
.glass-card .field {
  margin-bottom: 0;
}

.glass-card .field label {
  display: block;
  color: #d9e6ff;
  font-weight: 600;
  margin-bottom: 10px;
  font-size: 18px;
}

.glass-card .field input {
  width: 100%;
  padding: 16px;
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.15);
  color: #e8eaff;
  border-radius: 14px;
  font-size: 18px;
  transition: all 0.3s;
  box-sizing: border-box;
}

.glass-card .field input::placeholder {
  color: rgba(167, 178, 217, 0.8);
}

.glass-card .field input:focus {
  outline: none;
  background: rgba(255,255,255,0.08);
  border-color: #18e7ff;
  box-shadow: 0 0 0 4px rgba(24,231,255,0.1);
}

/* --- Ligne avec label + bouton + AJOUTER (Écrans, Micro, etc.) — même largeur que les lignes ajoutées --- */
.glass-card .field-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 0;
  margin-top: 0;
}

.glass-card .field-row label {
  margin-bottom: 0;
  flex-shrink: 0;
  width: 220px;
  min-width: 220px;
  color: #d9e6ff;
  font-weight: 600;
  font-size: 18px;
  order: 0;
  cursor: pointer;
  transition: color 0.15s ease;
}
.glass-card .field-row label:hover {
  color: #fff;
}

.glass-card .field-row .btn-add {
  flex-shrink: 0;
  order: 2;
}

.glass-card .field-row::before {
  content: '';
  flex: 1;
  min-width: 0;
  order: 1;
}

/* Espacement entre champs (PC1/PC2), sans ligne --- */
.glass-card .field + .field {
  padding-top: 16px;
  margin-top: 0;
}

/* Lignes ajoutées par + Ajouter — grille stricte : même largeur partout --- */
.glass-list {
  margin-top: 0;
}

.glass-added-row {
  display: grid;
  grid-template-columns: 220px 1fr;
  align-items: center;
  gap: 0 12px;
  padding: 14px 0;
  margin-top: 0;
}

.glass-added-row label {
  grid-column: 1;
  margin: 0;
  color: #d9e6ff;
  font-weight: 600;
  font-size: 16px;
  min-width: 0;
}

.glass-added-row-inner {
  grid-column: 2;
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.glass-added-row-inner .input-with-badge {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.glass-added-row-inner .input-with-badge input {
  flex: 1;
  min-width: 0;
}

.glass-added-row-inner input {
  flex: 1;
  min-width: 0;
  box-sizing: border-box;
}

.glass-added-row input {
  min-width: 0;
  padding: 16px;
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.15);
  color: #e8eaff;
  border-radius: 14px;
  font-size: 15px;
  transition: all 0.3s;
  box-sizing: border-box;
}

.glass-added-row input::placeholder {
  color: rgba(167, 178, 217, 0.8);
}

.glass-added-row input:focus {
  outline: none;
  background: rgba(255,255,255,0.08);
  border-color: #18e7ff;
  box-shadow: 0 0 0 4px rgba(24,231,255,0.1);
}

.glass-added-row .btn-remove {
  flex-shrink: 0;
  width: 36px;
  min-width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  background: rgba(239,68,68,0.15);
  color: #e8eaff;
  border-radius: 10px;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  transition: background 0.2s, color 0.2s;
}

.glass-added-row .btn-remove:hover {
  background: rgba(239,68,68,0.3);
  color: #fff;
}

/* Liste d’autocomplétion — style glass (seule liste affichée, plus de datalist natif) */
.custom-datalist-dropdown {
  display: none;
  position: fixed;
  z-index: 9999;
  max-height: 280px;
  overflow-y: auto;
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 14px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.35), 0 0 0 1px rgba(24,231,255,0.08);
  padding: 8px 0;
  margin-top: 4px;
}

/* Scrollbar glass pour le dropdown d'autocomplétion */
.custom-datalist-dropdown::-webkit-scrollbar {
  width: 6px;
}
.custom-datalist-dropdown::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.02);
  border-radius: 10px;
}
.custom-datalist-dropdown::-webkit-scrollbar-thumb {
  background: rgba(185,120,247,0.35);
  border-radius: 10px;
}
.custom-datalist-dropdown::-webkit-scrollbar-thumb:hover {
  background: rgba(24,231,255,0.5);
}

.custom-datalist-dropdown.active {
  display: block;
}

.custom-datalist-dropdown.custom-datalist-above {
  margin-top: 0;
  margin-bottom: 4px;
}

.custom-datalist-option {
  padding: 12px 16px;
  color: #e8eaff;
  font-size: 15px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}

.custom-datalist-option:hover,
.custom-datalist-option:focus {
  background: rgba(24,231,255,0.12);
  color: #fff;
}

/* --- Boutons --- */
.btn-glass {
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  padding: 14px 28px;
  cursor: pointer;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: 12px;
  font-size: 14px;
  transition: all 0.3s;
}

.btn-glass:hover {
  background: rgba(24,231,255,0.1);
  border-color: #18e7ff;
  color: #18e7ff;
  transform: translateY(-2px);
}

/* + Ajouter : texte seul, SANS cadre/bulle/fond --- */
.btn-glass.btn-add,
button.btn-glass.btn-add {
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  color: #fff !important;
  padding: 10px 14px !important;
  border-radius: 0 !important;
}

.btn-glass.btn-add:hover,
.btn-glass.btn-add:focus,
button.btn-glass.btn-add:hover,
button.btn-glass.btn-add:focus {
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  color: #18e7ff !important;
  transform: translateY(-1px);
}

/* Bouton Récap : seul le badge rouge visible, texte au survol, SANS cadre/bulle --- */
.glass-recap-btn,
button.glass-recap-btn {
  position: fixed;
  bottom: 100px;
  right: 30px;
  z-index: 50;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  color: #fff;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 !important;
  min-width: 0;
  transition: color 0.2s, transform 0.2s;
}
/* Supprimer tout cadre / pseudo-élément autour du récap --- */
.glass-recap-btn::before,
.glass-recap-btn::after {
  display: none !important;
  content: none !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}

.glass-recap-btn:hover,
.glass-recap-btn:focus,
.glass-recap-btn:focus-visible {
  outline: none !important;
  color: #18e7ff;
  transform: translateY(-2px);
}

/* Texte "Récapitulatif" : caché par défaut, visible au survol --- */
.glass-recap-btn .recap-label {
  max-width: 0;
  overflow: hidden;
  opacity: 0;
  white-space: nowrap;
  transition: max-width 0.25s ease, opacity 0.2s ease;
}

.glass-recap-btn:hover .recap-label {
  max-width: 180px;
  opacity: 1;
}

/* Badge rouge (chiffre 0, 1, 2…) toujours visible, sans cadre ni ombre --- */
.glass-recap-btn .recap-count {
  background: #ff3b6b;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  min-width: 22px;
  height: 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

/* ============================================================ */
/* Modales couleur & variante : masquées par défaut, overlay     */
/* fixe au centre (évite le "soucis en bas de page")            */
/* ============================================================ */
.color-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  box-sizing: border-box;
}

.color-modal.active {
  display: flex;
}

.color-modal-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(10px);
}

.color-modal-panel {
  position: relative;
  z-index: 1;
  background: linear-gradient(135deg, rgba(26,11,46,0.98), rgba(14,14,35,0.98));
  border: 1px solid rgba(24,231,255,0.3);
  border-radius: 16px;
  padding: 32px;
  max-width: 500px;
  width: 90%;
  max-height: 85vh;
  overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  animation: glassModalIn 0.3s ease;
}

@keyframes glassModalIn {
  from { opacity: 0; transform: translateY(-30px) scale(0.95); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.color-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 10px;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #fff;
  font-size: 30px;
  line-height: 1;
  padding: 0;
  transition: background 0.2s, color 0.2s, transform 0.25s ease;
}

.color-modal-close:hover {
  background: rgba(255,255,255,0.2);
  transform: rotate(90deg) scale(1.08);
}

.color-modal-title {
  font-size: 22px;
  font-weight: 700;
  color: #18e7ff;
  margin: 0 0 8px 0;
}

.color-modal-product {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  margin: 0 0 20px 0;
}

.color-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}

button.color-option,
.color-option {
  background: rgba(255,255,255,0.05);
  border: 2px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 14px;
  cursor: pointer;
  transition: all 0.2s;
  text-align: center;
  outline: none;
  font-family: inherit;
  -webkit-appearance: none;
  appearance: none;
}

button.color-option:hover,
.color-option:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(24,231,255,0.5);
}

button.color-option:active,
.color-option:active {
  background: rgba(24,231,255,0.25);
  border-color: #18e7ff;
  transform: scale(0.96);
}

.color-option.selected {
  background: rgba(24,231,255,0.2);
  border-color: #18e7ff;
}

/* Les enfants ne captent pas les clics → tout va au bouton parent */
.color-option > * {
  pointer-events: none;
}

.color-dot {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  margin: 0 auto 8px;
  border: 2px solid rgba(255,255,255,0.3);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.color-name {
  font-size: 13px;
  font-weight: 600;
  color: #fff;
}

.color-modal-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.color-modal-actions .btn {
  min-width: 100px;
}

/* Liste variantes (modal "Choisir la variante") */
.variant-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 50vh;
  overflow-y: auto;
  margin-bottom: 20px;
}

button.variant-option,
.variant-option {
  text-align: left;
  padding: 14px 18px;
  background: rgba(255,255,255,0.04);
  border: 2px solid transparent;
  border-radius: 12px;
  outline: none;
  font-family: inherit;
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  cursor: pointer;
  transition: all 0.2s ease;
  color: #e8eaff;
  font-size: 1rem;
}

.variant-option:hover {
  background: rgba(255,255,255,0.08);
  border-color: #18e7ff;
}

/* Les enfants ne captent pas les clics */
.variant-option > *,
.console-toggle > * {
  pointer-events: none;
}

/* Console toggle multi-select : état sélectionné */
.console-toggle.selected {
  background: rgba(24,231,255,0.15);
  border-color: #18e7ff;
  box-shadow: 0 0 12px rgba(24,231,255,0.2);
}
.console-toggle.selected::after {
  content: '✓';
  float: right;
  font-size: 18px;
  color: #18e7ff;
  font-weight: 900;
}

/* ========== Modale Récapitulatif (style glass premium) ========== */
body.recap-modal-open {
  overflow: hidden;
}

.recap-modal.glass-recap-modal {
  position: fixed;
  inset: 0;
  z-index: 10001;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  box-sizing: border-box;
  min-height: 100vh;
  min-height: 100dvh;
}

.recap-modal.glass-recap-modal.active {
  display: flex;
}

.recap-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  pointer-events: auto;
}

.recap-modal.glass-recap-modal .recap-modal-content {
  position: relative;
  z-index: 1;
  margin: auto;
  display: flex;
  flex-direction: column;
  background: linear-gradient(135deg, rgba(35,19,77,0.95) 0%, rgba(26,11,46,0.95) 50%, rgba(18,12,32,0.95) 100%);
  backdrop-filter: blur(40px);
  -webkit-backdrop-filter: blur(40px);
  border: 1px solid rgba(185,120,247,0.2);
  border-radius: 24px;
  padding: 0;
  max-width: 720px;
  width: 100%;
  max-height: 90vh;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,0.7), 0 0 0 1px rgba(24,231,255,0.1) inset, 0 0 60px rgba(185,120,247,0.15);
  animation: glassModalIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.recap-modal-header {
  position: relative;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 32px 32px 24px;
  background: linear-gradient(135deg, rgba(185,120,247,0.08) 0%, rgba(24,231,255,0.05) 100%);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.recap-modal-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, #b978f7 20%, #18e7ff 50%, #b978f7 80%, transparent 100%);
  opacity: 0.6;
}

.recap-modal-header .color-modal-close {
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
  flex-shrink: 0;
  margin-left: 0;
  width: 48px;
  height: 48px;
  font-size: 30px;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  outline: none;
  color: rgba(255,255,255,0.5);
  cursor: pointer;
  transition: color 0.2s, transform 0.25s ease;
  padding: 0;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.recap-modal-header .color-modal-close:hover {
  background: transparent !important;
  color: #18e7ff;
  transform: translateY(-50%) rotate(90deg) scale(1.08);
}

.recap-modal-header-content {
  flex: 1;
  text-align: center;
}

.recap-modal-title {
  font-size: 26px;
  font-weight: 900;
  color: #fff;
  margin: 0 0 8px 0;
  letter-spacing: -0.02em;
}

.recap-modal-subtitle {
  font-size: 14px;
  font-weight: 500;
  color: rgba(255,255,255,0.6);
  margin: 0;
  line-height: 1.5;
}

.recap-modal-body {
  flex: 1;
  min-height: 0;
  padding: 24px 32px;
  overflow-y: auto;
  overflow-x: hidden;
}

.recap-modal-body::-webkit-scrollbar {
  width: 6px;
}

.recap-modal-body::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.02);
  border-radius: 10px;
}

.recap-modal-body::-webkit-scrollbar-thumb {
  background: rgba(24,231,255,0.3);
  border-radius: 10px;
}

.recap-modal-body::-webkit-scrollbar-thumb:hover {
  background: rgba(24,231,255,0.5);
}

.recap-modal-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.recap-modal-list li {
  padding: 14px 18px;
  margin-bottom: 10px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: all 0.25s ease;
  position: relative;
  overflow: hidden;
}

.recap-modal-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, #b978f7 0%, #18e7ff 100%);
  opacity: 0;
  transition: opacity 0.25s;
}

.recap-modal-list li:hover {
  background: rgba(255,255,255,0.04);
  border-color: rgba(24,231,255,0.2);
  transform: translateX(4px);
}

.recap-modal-list li:hover::before {
  opacity: 1;
}

.recap-modal-list li strong {
  color: rgba(255,255,255,0.7);
  font-size: 17px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  display: flex;
  align-items: center;
  gap: 10px;
}

.recap-modal-list li strong::before {
  content: '';
  width: 12px;
  height: 12px;
  background: #18e7ff;
  border-radius: 50%;
  box-shadow: 0 0 12px rgba(24,231,255,0.7);
}

.recap-item-content {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}

.recap-modal-list li .recap-label {
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  flex-shrink: 0;
}

.recap-modal-list li .recap-value {
  color: rgba(255,255,255,0.85);
  font-size: 14px;
  font-weight: 400;
  flex: 1;
  text-align: right;
  line-height: 1.4;
}

.recap-empty-modal {
  text-align: center;
  padding: 48px 24px;
  color: rgba(255,255,255,0.4);
}

.recap-empty-modal p {
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
}

.recap-empty-modal::before {
  content: '📋';
  display: block;
  font-size: 48px;
  margin-bottom: 16px;
  opacity: 0.3;
}

.recap-modal-actions.recap-actions-row {
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  justify-content: center;
  padding: 24px 32px;
  background: rgba(0,0,0,0.2);
  border-top: 1px solid rgba(255,255,255,0.08);
}

.recap-modal-actions .btn-recap-link,
.recap-modal-actions .btn-glass.btn-recap-link,
.color-modal-actions .btn-recap-link,
.color-modal-actions .btn-glass.btn-recap-link {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  padding: 12px 20px !important;
  color: #fff !important;
  font-weight: 800;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  min-width: 0;
  border-radius: 0;
  cursor: pointer;
  transition: color 0.2s, transform 0.2s;
  -webkit-appearance: none;
  appearance: none;
}

.recap-modal-actions .btn-recap-link:hover,
.recap-modal-actions .btn-glass.btn-recap-link:hover,
.recap-modal-actions .btn-recap-link:focus,
.recap-modal-actions .btn-glass.btn-recap-link:focus,
.recap-modal-actions .btn-recap-link:active,
.recap-modal-actions .btn-glass.btn-recap-link:active,
.color-modal-actions .btn-recap-link:hover,
.color-modal-actions .btn-glass.btn-recap-link:hover,
.color-modal-actions .btn-recap-link:focus,
.color-modal-actions .btn-glass.btn-recap-link:focus,
.color-modal-actions .btn-recap-link:active,
.color-modal-actions .btn-glass.btn-recap-link:active {
  color: #18e7ff !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  transform: translateY(-2px);
}

@media (max-width: 640px) {
  .recap-modal.glass-recap-modal .recap-modal-content {
    max-width: 100%;
    border-radius: 20px;
  }
  .recap-modal-header {
    padding: 24px 20px 20px;
  }
  .recap-modal-body {
    padding: 20px;
  }
  .recap-modal-title {
    font-size: 22px;
  }
  .recap-modal-actions.recap-actions-row {
    padding: 20px;
  }
}

/* ── Header lock quand la modale welcome est ouverte ── */
#main-header.header-locked nav a,
#main-header.header-locked .logo-zone,
#main-header.header-locked .twitch-center {
  pointer-events: none;
  opacity: 0.45;
  cursor: default;
  user-select: none;
}
#main-header.header-locked .lang-dropdown {
  pointer-events: auto;
  opacity: 1;
}
