/**
 * StageBack Admin — Thème sombre aligné sur la marketplace
 * Contraste maximal pour une lisibilité parfaite (WCAG).
 */

:root,
[data-theme="light"],
[data-theme="dark"],
[data-theme="auto"] {
  /* Variables StageBack */
  --sb-dark-bg: #0A0A0A;
  --sb-dark-surface: #121212;
  --sb-dark-card: #1A1A1A;
  --sb-dark-border: #2A2A2A;
  --sb-dark-elevated: #1E1E1E;
  --sb-primary: #5F3FFF;
  --sb-primary-hover: #A78BFA;
  --sb-primary-glow: rgba(95, 63, 255, 0.4);
  --sb-neon-pink: #FF10F0;
  --sb-text: #FFFFFF;
  --sb-text-muted: #E5E5E5;
  --sb-text-dim: #B0B0B0;
  --sb-radius: 12px;
  --sb-radius-sm: 8px;
  --sb-font-sans: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
  --sb-font-display: 'Space Grotesk', sans-serif;
  /* Forcer les variables du thème Django (priorité sur le thème natif) */
  --body-bg: #0A0A0A !important;
  --body-fg: #FFFFFF !important;
  --body-quiet-color: #E5E5E5 !important;
  --header-bg: #1A1A1A !important;
  --header-link-color: #FFFFFF !important;
  --header-color: #FFFFFF !important;
  --breadcrumbs-bg: #0A0A0A !important;
  --breadcrumbs-fg: #E5E5E5 !important;
  --link-fg: #5F3FFF !important;
  --link-hover-color: #A78BFA !important;
  --button-bg: #5F3FFF !important;
  --button-hover-bg: #7C5CFF !important;
  --default-button-bg: #5F3FFF !important;
  --accent: #5F3FFF !important;
}

/* Base & typography — contraste maximal partout */
body,
#container,
main,
#content {
  background: var(--sb-dark-bg) !important;
  color: var(--sb-text) !important;
  font-family: var(--sb-font-sans) !important;
}

/* Tous les textes du header visibles (éviter gris sur noir) */
#header,
#header *,
#user-tools,
#user-tools * {
  color: var(--sb-text) !important;
}
#user-tools a:link,
#user-tools a:visited {
  color: var(--sb-text-muted) !important;
}
#user-tools a:hover {
  color: var(--sb-primary) !important;
}
#user-tools strong {
  color: var(--sb-text) !important;
}

/* Tableau de bord : titres de sections (Api, Authentification...) */
#content-main .module caption,
#content-main .module caption a {
  color: var(--sb-text) !important;
  font-weight: 600 !important;
}
#content-main .module caption a:hover {
  color: var(--sb-primary) !important;
}

/* Lignes des modèles : nom du modèle (th) et cellules (td) toujours lisibles */
#content-main .module table th,
#content-main .module table th a,
#content-main .module table td,
#content-main .module table td a {
  color: var(--sb-text) !important;
  background: transparent !important;
}
#content-main .module table th a:hover,
#content-main .module table td a:hover {
  color: var(--sb-primary) !important;
}

/* Sidebar "Actions récentes" : titres et liste lisibles */
#content-related h2,
#content-related h3,
#content-related li {
  color: var(--sb-text) !important;
}
#content-related a {
  color: var(--sb-primary) !important;
}
#content-related a:hover {
  color: var(--sb-primary-hover) !important;
}
#content-related .module h2,
#content-related .module h3 {
  background: var(--sb-dark-elevated) !important;
  color: var(--sb-text) !important;
}

/* Header */
#header {
  background: linear-gradient(135deg, var(--sb-dark-card) 0%, var(--sb-dark-elevated) 100%) !important;
  border-bottom: 1px solid var(--sb-dark-border) !important;
  padding: 0 24px !important;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3) !important;
}

#branding h1,
#branding h1 a:link,
#branding h1 a:visited {
  color: var(--sb-text) !important;
  font-family: var(--sb-font-display) !important;
  font-weight: 700 !important;
  font-size: 1.35rem !important;
  letter-spacing: -0.02em !important;
}

.admin-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
  padding: 12px 0 !important;
}

.admin-logo .logo-icon {
  color: var(--sb-primary) !important;
  font-size: 1.2rem !important;
  filter: drop-shadow(0 0 8px var(--sb-primary-glow));
}

.admin-logo .logo-text {
  color: var(--sb-text) !important;
}

.admin-logo .logo-badge {
  background: linear-gradient(135deg, var(--sb-primary), var(--sb-neon-pink)) !important;
  color: white !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  padding: 2px 8px !important;
  border-radius: 6px !important;
  margin-left: 4px !important;
  letter-spacing: 0.02em !important;
}

#user-tools {
  font-family: var(--sb-font-sans) !important;
  padding: 16px 0 !important;
}

#user-tools a:link,
#user-tools a:visited {
  color: var(--sb-text-muted) !important;
  transition: color 0.2s !important;
}

#user-tools a:hover {
  color: var(--sb-primary) !important;
}

#user-tools strong {
  color: var(--sb-text) !important;
}

/* Main content */
#content {
  padding: 24px !important;
  background: var(--sb-dark-bg) !important;
}

#content h1 {
  font-family: var(--sb-font-display) !important;
  font-weight: 700 !important;
  color: var(--sb-text) !important;
  font-size: 1.75rem !important;
  margin-bottom: 24px !important;
  letter-spacing: -0.02em !important;
}

#content-main {
  background: transparent !important;
}

/* Modules / cards */
.module,
#changelist .results,
.submit-row {
  background: var(--sb-dark-card) !important;
  border: 1px solid var(--sb-dark-border) !important;
  border-radius: var(--sb-radius) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2) !important;
}

.module h2,
.module caption,
.inline-group h2 {
  background: linear-gradient(135deg, var(--sb-dark-elevated), var(--sb-dark-card)) !important;
  color: var(--sb-text) !important;
  font-family: var(--sb-font-display) !important;
  font-weight: 600 !important;
  border-bottom: 1px solid var(--sb-dark-border) !important;
  padding: 14px 20px !important;
  border-radius: var(--sb-radius) var(--sb-radius) 0 0 !important;
}

.module table,
.module th,
.module td,
#changelist table thead th,
#changelist table tbody td {
  border-color: var(--sb-dark-border) !important;
  color: var(--sb-text) !important;
}

.module table tbody tr:hover,
#changelist table tbody tr:hover {
  background: rgba(95, 63, 255, 0.06) !important;
}

#changelist .results {
  overflow: hidden;
  border-radius: var(--sb-radius) !important;
}

#changelist table thead th {
  background: var(--sb-dark-elevated) !important;
  color: var(--sb-text-muted) !important;
  font-weight: 600 !important;
  padding: 14px 16px !important;
  white-space: normal !important;
  min-width: 80px !important;
}
#changelist table thead th a {
  display: inline-block !important;
  max-width: 100% !important;
  word-break: break-word !important;
}

#changelist table tbody td {
  padding: 14px 16px !important;
}

/* Links */
a:link,
a:visited {
  color: var(--sb-primary) !important;
}

a:hover {
  color: var(--sb-primary-hover) !important;
}

/* Buttons */
.button,
input[type="submit"],
input[type="button"],
.submit-row input,
button[type="submit"],
.add-row a {
  background: linear-gradient(135deg, var(--sb-primary), #7C5CFF) !important;
  color: white !important;
  border: none !important;
  border-radius: var(--sb-radius-sm) !important;
  padding: 10px 20px !important;
  font-weight: 600 !important;
  font-family: var(--sb-font-sans) !important;
  box-shadow: 0 4px 14px var(--sb-primary-glow) !important;
  transition: transform 0.15s, box-shadow 0.2s !important;
}

.button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
.submit-row input:hover,
.add-row a:hover {
  background: linear-gradient(135deg, var(--sb-primary-hover), var(--sb-primary)) !important;
  box-shadow: 0 6px 20px var(--sb-primary-glow) !important;
  transform: translateY(-1px);
}

.button.default,
input[type="submit"].default,
.submit-row input.default {
  background: linear-gradient(135deg, var(--sb-primary), var(--sb-neon-pink)) !important;
  box-shadow: 0 4px 16px rgba(255, 16, 240, 0.3) !important;
}

.deletelink-box .deletelink {
  background: rgba(239, 68, 68, 0.15) !important;
  color: #f87171 !important;
  border: 1px solid rgba(239, 68, 68, 0.4) !important;
  border-radius: var(--sb-radius-sm) !important;
}

.deletelink-box .deletelink:hover {
  background: rgba(239, 68, 68, 0.25) !important;
  color: #fca5a5 !important;
}

/* Form inputs */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="url"],
input[type="number"],
input[type="date"],
textarea,
select {
  background: var(--sb-dark-surface) !important;
  border: 1px solid var(--sb-dark-border) !important;
  color: var(--sb-text) !important;
  border-radius: var(--sb-radius-sm) !important;
  padding: 10px 14px !important;
  font-family: var(--sb-font-sans) !important;
}

/* Selects : hauteur et largeur pour que la sélection soit visible (pas écrasée) */
select {
  min-height: 42px !important;
  min-width: 220px !important;
  max-width: 100% !important;
  appearance: auto !important;
  cursor: pointer !important;
}
select option {
  background: var(--sb-dark-card) !important;
  color: var(--sb-text) !important;
  padding: 8px 12px !important;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--sb-primary) !important;
  box-shadow: 0 0 0 3px var(--sb-primary-glow) !important;
  outline: none !important;
}

input::placeholder,
textarea::placeholder {
  color: var(--sb-text-dim) !important;
}

/* Lignes de formulaire : éviter que label et champ se chevauchent */
#content .form-row,
#content main .form-row,
.form-row {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  gap: 8px 16px !important;
  margin-bottom: 16px !important;
  clear: both !important;
}
#content .form-row label,
#content main .form-row label,
.form-row label {
  min-width: 160px !important;
  padding: 8px 0 !important;
  color: var(--sb-text) !important;
  flex-shrink: 0 !important;
}
#content .form-row input,
#content .form-row select,
#content .form-row textarea,
#content .form-row .related-widget-wrapper,
.form-row input,
.form-row select,
.form-row textarea,
.form-row .related-widget-wrapper {
  flex: 1 1 280px !important;
  min-width: 0 !important;
}

/* Input file (Choisir un fichier) : ne pas le faire rétrécir, garder cliquable */
input[type="file"],
#content input[type="file"],
.form-row input[type="file"] {
  min-width: 220px !important;
  flex: 0 1 auto !important;
  padding: 8px 12px !important;
  cursor: pointer !important;
  background: var(--sb-dark-surface) !important;
  border: 1px solid var(--sb-dark-border) !important;
  color: var(--sb-text) !important;
  border-radius: var(--sb-radius-sm) !important;
}
/* Inline : cellule avec le bouton file */
.inline-related input[type="file"],
.tabular .inline-related input[type="file"] {
  min-width: 200px !important;
}

/* Widget ForeignKey : dropdown + liens (Modifier, Ajouter) pas écrasés */
.related-widget-wrapper {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px 12px !important;
}
.related-widget-wrapper select {
  flex: 1 1 auto !important;
  min-width: 200px !important;
}
.related-widget-wrapper a {
  white-space: nowrap !important;
}

/* Champs date/heure sur une ligne (Date : [input] Heure : [input]) */
.form-row p {
  margin: 0 8px 0 0 !important;
  color: var(--sb-text) !important;
}
.form-row .datetime {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
}

/* Zone principale : ne pas compresser le formulaire */
#content {
  min-width: 0 !important;
}
@media (min-width: 1024px) {
  #content main {
    max-width: 900px !important;
  }
}

/* Layout .aligned (label à gauche, champ à droite) — éviter chevauchement */
#content .aligned label,
main .aligned label {
  width: 160px !important;
  min-width: 160px !important;
  padding: 8px 12px 8px 0 !important;
  color: var(--sb-text) !important;
}
#content .aligned .form-row > div,
main .aligned .form-row > div {
  margin-left: 0 !important;
  overflow: visible !important;
}

/* Champs dans un fieldset : espace et visibilité */
#content fieldset.module,
#content .module form {
  overflow: visible !important;
}
#content fieldset .form-row {
  margin-bottom: 14px !important;
}

/* Sidebar (recent actions, etc.) */
#content-related {
  background: var(--sb-dark-card) !important;
  border: 1px solid var(--sb-dark-border) !important;
  border-radius: var(--sb-radius) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2) !important;
}

#content-related .module h2 {
  border-radius: var(--sb-radius) var(--sb-radius) 0 0 !important;
}

/* Breadcrumbs */
.breadcrumbs {
  background: transparent !important;
  color: var(--sb-text-muted) !important;
  padding: 8px 0 16px !important;
  font-size: 0.9rem !important;
}

.breadcrumbs a {
  color: var(--sb-text-muted) !important;
}

.breadcrumbs a:hover {
  color: var(--sb-primary) !important;
}

/* Messages */
.messagelist li {
  background: var(--sb-dark-card) !important;
  border: 1px solid var(--sb-dark-border) !important;
  border-radius: var(--sb-radius-sm) !important;
  color: var(--sb-text) !important;
}

.messagelist li.success {
  border-left: 4px solid #22c55e !important;
}

.messagelist li.warning {
  border-left: 4px solid #eab308 !important;
}

.messagelist li.error {
  border-left: 4px solid #ef4444 !important;
}

/* Login page */
.login {
  background: var(--sb-dark-bg) !important;
}

.login #container {
  background: var(--sb-dark-card) !important;
  border: 1px solid var(--sb-dark-border) !important;
  border-radius: var(--sb-radius) !important;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5), 0 0 0 1px var(--sb-dark-border) !important;
  padding: 40px !important;
}

.login h1 {
  color: var(--sb-text) !important;
  font-family: var(--sb-font-display) !important;
}

.login label,
.login p,
.login .errornote {
  color: var(--sb-text) !important;
}

.login form input[type="text"],
.login form input[type="password"] {
  background: var(--sb-dark-surface) !important;
  border: 1px solid var(--sb-dark-border) !important;
  color: var(--sb-text) !important;
}

.login .submit-row {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Toute table dans l’admin : texte lisible (tableau de bord + listes) */
#content .module table caption,
#content .module table th,
#content .module table td,
#content .module table caption a,
#content .module table th a,
#content .module table td a {
  color: var(--sb-text) !important;
}
#content .module table caption a:hover,
#content .module table th a:hover,
#content .module table td a:hover {
  color: var(--sb-primary) !important;
}

/* Dashboard tables */
#content-main .module table {
  border-radius: var(--sb-radius-sm) !important;
}

#content-main .module table th a {
  color: var(--sb-text) !important;
  font-weight: 600 !important;
}

#content-main .module table th a:hover {
  color: var(--sb-primary) !important;
}

/* Pagination */
.pagination a,
.pagination span {
  background: var(--sb-dark-surface) !important;
  border-color: var(--sb-dark-border) !important;
  color: var(--sb-text-muted) !important;
  border-radius: 6px !important;
}

.pagination a:hover {
  background: var(--sb-primary) !important;
  border-color: var(--sb-primary) !important;
  color: white !important;
}

.pagination .this-page {
  background: var(--sb-primary) !important;
  color: white !important;
  border-color: var(--sb-primary) !important;
}

/* Filter sidebar in changelist */
#changelist-filter {
  background: var(--sb-dark-card) !important;
  border: 1px solid var(--sb-dark-border) !important;
  border-radius: var(--sb-radius) !important;
}

#changelist-filter h2 {
  background: var(--sb-dark-elevated) !important;
  color: var(--sb-text) !important;
  border-bottom: 1px solid var(--sb-dark-border) !important;
}

#changelist-filter h3,
#changelist-filter li {
  color: var(--sb-text-muted) !important;
}

#changelist-filter a {
  color: var(--sb-text-muted) !important;
}

#changelist-filter a:hover,
#changelist-filter li.selected a {
  color: var(--sb-primary) !important;
}

/* Thème forcé sombre (aligné marketplace) */
[data-theme],
html {
  color-scheme: dark;
}

/* Bouton "Changer de thème" Django 5 — discret ou masqué */
#toggle-theme,
button[title*="thème"],
button[title*="theme"] {
  background: var(--sb-dark-surface) !important;
  border: 1px solid var(--sb-dark-border) !important;
  color: var(--sb-text-muted) !important;
  border-radius: var(--sb-radius-sm) !important;
}
#toggle-theme:hover,
button[title*="thème"]:hover,
button[title*="theme"]:hover {
  color: var(--sb-primary) !important;
  border-color: var(--sb-primary) !important;
}

/* Small tweaks for inline forms */
.inline-group {
  border-radius: var(--sb-radius) !important;
  overflow: visible !important;
  border: 1px solid var(--sb-dark-border) !important;
}
/* Cellules d’inline : ne pas cacher l’input file */
.inline-group td input[type="file"],
.inline-group .form-row input[type="file"] {
  min-width: 200px !important;
  width: auto !important;
  cursor: pointer !important;
}

.inline-group .tabular tr.odd {
  background: rgba(255, 255, 255, 0.02) !important;
}

.errorlist {
  color: #f87171 !important;
}

.help {
  color: var(--sb-text-dim) !important;
}
