/* ==========================================================
   GAME! — Slate Mono Light Theme
   neon.css — Monochrome total sur fond gris clair
   ========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@500;600;700&family=Orbitron:wght@500;700&display=swap');

/* ----------------------------------------------------------
   VARIABLES
   ---------------------------------------------------------- */
:root {
  /* Fonds gris clairs */
  --bg-body:        #f2f2f2;
  --bg-surface:     #e8e8e8;
  --bg-card:        #ffffff;
  --bg-card-hover:  #fafafa;
  --bg-header:      #eeeeee;
  --border-color:   #cccccc;
  --border-subtle:  #dddddd;

  /* Accents mono — noirs, gris et blanc uniquement */
  --accent-primary:  #111111;
  --accent-primary2: #000000;
  --accent-mid:      #555555;
  --accent-mid2:     #333333;
  --accent-light:    #888888;
  --accent-light2:   #aaaaaa;
  --accent-teal:     #336655;
  --accent-rose:     #884444;

  /* Texte */
  --text-primary:   #111111;
  --text-secondary: #555555;
  --text-muted:     #aaaaaa;
  --text-link:      #222222;
  --text-link-hover:#000000;

  /* Navbar — noir total */
  --navbar-bg:      #111111;
  --navbar-border:  #222222;

  /* Glow — absent en mono */
  --glow-primary:   none;
  --glow-mid:       none;

  /* Typographie */
  --font-body:      'Rajdhani', sans-serif;
  --font-display:   'Orbitron', monospace;

  /* Alias compat */
  --neon-blue:      var(--accent-mid);
  --neon-purple:    var(--accent-primary);
  --bg-color:       var(--bg-body);
  --dark-text:      var(--text-primary);
  --btn-neon:       var(--accent-primary);
  --btn-neon-hover: var(--accent-primary2);
}

/* ----------------------------------------------------------
   BASE
   ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: 0.95rem;
  background-color: var(--bg-body);
  color: var(--text-primary);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

/* Pas de gradient — mono pur */
body::before { display: none; }

.container, .container-fluid, nav, .modal { position: relative; z-index: 1; }

/* ----------------------------------------------------------
   TYPOGRAPHIE
   ---------------------------------------------------------- */
h1, h2, h3, h4, h5 {
  font-family: var(--font-body);
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: 0.01em;
}
h1 { font-size: 1.6rem; }
h5 { font-size: 1rem; font-weight: 600; }
h6 {
  font-size: 0.875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
}
a { color: var(--text-link); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--text-link-hover); text-decoration: underline; }

/* ----------------------------------------------------------
   NAVBAR — noir total
   ---------------------------------------------------------- */
.navbar {
  background-color: var(--navbar-bg) !important;
  border-bottom: 1px solid var(--navbar-border);
  padding: 0.6rem 1.2rem;
  position: sticky;
  top: 0;
  z-index: 1030;
}

.navbar-brand {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: #ffffff !important;
  letter-spacing: 0.12em;
  text-shadow: none;
  transition: opacity 0.2s;
}
.navbar-brand:hover {
  color: #ffffff !important;
  opacity: 0.75;
}

.navbar-dark .navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.88rem;
  font-weight: 600;
  padding: 0.45rem 0.85rem;
  border-radius: 6px;
  transition: color 0.2s, background-color 0.2s;
}
.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link.active {
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.1);
}

.navbar-toggler { border-color: rgba(255,255,255,0.3); }
.navbar-toggler-icon { filter: invert(0.8); }

.bg-neon { background-color: var(--navbar-bg) !important; }
.bg-neon-hidden { background-color: rgba(0, 0, 0, 0.04) !important; }
.container.mt-4 { padding-top: 1.5rem !important; }

/* ----------------------------------------------------------
   CARDS
   ---------------------------------------------------------- */
.card {
  background-color: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  color: var(--text-primary);
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
.card:hover {
  border-color: #999999;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  transform: translateY(-2px);
}

.card-header {
  background-color: var(--bg-header) !important;
  border-bottom: 1px solid var(--border-color);
  padding: 0.75rem 1.1rem;
  border-radius: 8px 8px 0 0 !important;
}
.card-header h5, .card-header h6 { margin-bottom: 0; }
.card-body { padding: 1.1rem; }
.shadow-sm { box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important; }

/* Cards colorées — mono uniquement */
.card.text-white.bg-primary { background-color: rgba(0, 0, 0, 0.06) !important;   border-color: rgba(0, 0, 0, 0.2) !important;   color: var(--text-primary) !important; }
.card.text-white.bg-success  { background-color: rgba(51, 102, 85, 0.08) !important; border-color: rgba(51, 102, 85, 0.22) !important; color: var(--text-primary) !important; }
.card.text-white.bg-warning  { background-color: rgba(85, 85, 85, 0.08) !important;  border-color: rgba(85, 85, 85, 0.22) !important;  color: var(--text-primary) !important; }
.card.text-white.bg-info     { background-color: rgba(51, 51, 51, 0.06) !important;  border-color: rgba(51, 51, 51, 0.18) !important;  color: var(--text-primary) !important; }
.card.text-white.bg-neon     { background-color: var(--bg-surface) !important; border-color: var(--border-color) !important; color: var(--text-primary) !important; }

.card.text-white.bg-primary .card-header,
.card.text-white.bg-success .card-header,
.card.text-white.bg-warning .card-header,
.card.text-white.bg-info .card-header {
  background-color: rgba(255,255,255,0.6) !important;
  border-bottom-color: rgba(0,0,0,0.1) !important;
  color: var(--text-secondary);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.card.text-white.bg-primary h5.card-title { color: var(--accent-primary); font-size: 1.4rem; }
.card.text-white.bg-success h5.card-title  { color: var(--accent-teal);   font-size: 1.4rem; }
.card.text-white.bg-warning h5.card-title  { color: var(--accent-mid);    font-size: 1.4rem; }
.card.text-white.bg-info h5.card-title     { color: var(--accent-mid2);   font-size: 1.4rem; }

/* ----------------------------------------------------------
   TABLEAUX
   ---------------------------------------------------------- */
.table { color: var(--text-primary); border-color: var(--border-color); margin-bottom: 0; }
.table thead th {
  background-color: var(--bg-header);
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-color);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  padding: 0.7rem 0.85rem;
}
.table tbody tr { border-color: var(--border-subtle); transition: background-color 0.15s; }
.table-striped > tbody > tr:nth-of-type(odd) > * { background-color: rgba(0, 0, 0, 0.025); color: var(--text-primary); }
.table-hover > tbody > tr:hover > * { background-color: rgba(0, 0, 0, 0.05); color: var(--text-primary); }
.table tbody td { padding: 0.7rem 0.85rem; vertical-align: middle; border-color: var(--border-subtle); font-size: 0.9rem; }
.thead-light { background-color: var(--bg-header); }

/* ----------------------------------------------------------
   BADGES
   ---------------------------------------------------------- */
.badge { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.04em; border-radius: 4px; padding: 0.3em 0.55em; }
.badge.bg-primary   { background-color: rgba(0, 0, 0, 0.08) !important;    color: #111111 !important;          border: 1px solid rgba(0, 0, 0, 0.25); }
.badge.bg-secondary { background-color: rgba(85, 85, 85, 0.1) !important;   color: var(--accent-mid) !important; border: 1px solid rgba(85, 85, 85, 0.25); }
.badge.bg-success   { background-color: rgba(51, 102, 85, 0.1) !important;  color: var(--accent-teal) !important; border: 1px solid rgba(51, 102, 85, 0.25); }
.badge.bg-warning, .badge.bg-warning.text-dark { background-color: rgba(102, 102, 102, 0.1) !important; color: #444444 !important; border: 1px solid rgba(102, 102, 102, 0.25); }
.badge.bg-info, .badge.bg-info.text-dark       { background-color: rgba(51, 51, 51, 0.08) !important;  color: #333333 !important; border: 1px solid rgba(51, 51, 51, 0.22); }
.badge.bg-danger    { background-color: rgba(136, 68, 68, 0.1) !important;  color: var(--accent-rose) !important; border: 1px solid rgba(136, 68, 68, 0.25); }
.badge.bg-light.text-dark { background-color: rgba(0,0,0,0.04) !important; color: var(--text-secondary) !important; border: 1px solid var(--border-color); }
.badge.rounded-pill { border-radius: 50px; }

/* ----------------------------------------------------------
   BOUTONS
   ---------------------------------------------------------- */
.btn {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.875rem;
  border-radius: 6px;
  padding: 0.45rem 1rem;
  transition: all 0.2s;
  letter-spacing: 0.04em;
  border: none;
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 4px 10px rgba(0,0,0,0.15); }
.btn:active { transform: translateY(0); }

.btn-primary { background-color: var(--accent-primary); color: #ffffff; }
.btn-primary:hover { background-color: var(--accent-primary2); color: #ffffff; }

.btn-outline-primary { background-color: transparent; border: 1px solid rgba(0, 0, 0, 0.5); color: var(--accent-primary); }
.btn-outline-primary:hover { background-color: rgba(0, 0, 0, 0.06); border-color: #000000; }

.btn-secondary { background-color: rgba(85, 85, 85, 0.1); color: var(--text-secondary); border: 1px solid var(--border-color); }
.btn-secondary:hover { background-color: rgba(85, 85, 85, 0.18); color: var(--text-primary); }

.btn-outline-secondary { background-color: transparent; border: 1px solid var(--border-color); color: var(--text-secondary); }
.btn-outline-secondary:hover { background-color: rgba(0, 0, 0, 0.05); color: var(--text-primary); border-color: #999999; }

.btn-outline-warning { background-color: transparent; border: 1px solid rgba(85, 85, 85, 0.4); color: var(--accent-mid); }
.btn-outline-warning:hover { background-color: rgba(85, 85, 85, 0.08); }

.btn-danger { background-color: rgba(136, 68, 68, 0.1); color: var(--accent-rose); border: 1px solid rgba(136, 68, 68, 0.3); }
.btn-danger:hover { background-color: rgba(136, 68, 68, 0.18); }

.btn-warning { background-color: rgba(85, 85, 85, 0.1); color: var(--accent-mid); border: 1px solid rgba(85, 85, 85, 0.3); }
.btn-warning:hover { background-color: rgba(85, 85, 85, 0.18); color: var(--accent-mid2); }

.btn.bg-success, .btn-success { background-color: rgba(51, 102, 85, 0.12) !important; color: var(--accent-teal) !important; border: 1px solid rgba(51, 102, 85, 0.3) !important; }
.btn.bg-success:hover, .btn-success:hover { background-color: rgba(51, 102, 85, 0.2) !important; }

.btn.bg-info { background-color: rgba(51, 51, 51, 0.08) !important; color: var(--accent-mid2) !important; border: 1px solid rgba(51, 51, 51, 0.22) !important; }
.btn.bg-info:hover { background-color: rgba(51, 51, 51, 0.15) !important; }

.btn-outline-sync {
  background-color: transparent;
  border: 1px solid var(--border-color);
  color: var(--text-secondary);
  transition: all 0.2s;
}
.btn-outline-sync:hover { background-color: rgba(0, 0, 0, 0.05); color: var(--text-primary); border-color: #999999; }

.btn-custom-letter {
  color: var(--text-secondary);
  background-color: transparent;
  border: 1px solid var(--border-color);
  padding: 0.25rem 0.55rem;
  font-size: 0.8rem;
  font-weight: 700;
  border-radius: 4px;
}
.btn-custom-letter.active {
  color: #ffffff;
  background-color: var(--accent-primary);
  border-color: var(--accent-primary);
}
.btn-custom-letter:not(.active):hover {
  color: var(--text-primary);
  background-color: rgba(0, 0, 0, 0.06);
  border-color: #888888;
}

.btn-custom-letter2 { color: var(--text-secondary); background-color: transparent; border: 1px solid var(--border-color); padding: 0.25rem 0.55rem; font-size: 0.8rem; }
.btn-custom-letter2.active { color: var(--text-primary); background-color: var(--bg-surface); border-color: #888888; }
.btn-custom-letter2:not(.active):hover { color: var(--text-primary); background-color: rgba(0, 0, 0, 0.04); }

.btn-group .btn { border-radius: 4px !important; }
.btn-group > .btn:not(:last-child) { margin-right: 2px; }
.btn-sm { font-size: 0.78rem; padding: 0.3rem 0.65rem; }

/* ----------------------------------------------------------
   FORMULAIRES
   ---------------------------------------------------------- */
.form-control, .form-select {
  background-color: var(--bg-card);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
  border-radius: 6px;
  font-size: 0.9rem;
  padding: 0.5rem 0.85rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.form-control:focus, .form-select:focus {
  background-color: var(--bg-card);
  border-color: #444444;
  color: var(--text-primary);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.1);
  outline: none;
}
.form-control::placeholder { color: var(--text-muted); }
.form-control:disabled, .form-select:disabled { background-color: var(--bg-surface); color: var(--text-muted); border-color: var(--border-subtle); opacity: 0.7; }
.form-control-lg, .form-select-lg { font-size: 1rem; padding: 0.65rem 1rem; }
.form-label { font-size: 0.82rem; font-weight: 700; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 0.35rem; }
.form-check-input { background-color: var(--bg-card); border-color: var(--border-color); }
.form-check-input:checked { background-color: var(--accent-primary); border-color: var(--accent-primary); }
.form-check-label { color: var(--text-primary); font-size: 0.9rem; }

/* ----------------------------------------------------------
   ALERTES
   ---------------------------------------------------------- */
.alert { border-radius: 6px; font-size: 0.9rem; border-width: 1px; }
.alert-success { background-color: rgba(51, 102, 85, 0.08);  border-color: rgba(51, 102, 85, 0.25);  color: var(--accent-teal); }
.alert-danger  { background-color: rgba(136, 68, 68, 0.08);  border-color: rgba(136, 68, 68, 0.25);  color: var(--accent-rose); }
.alert-warning { background-color: rgba(85, 85, 85, 0.08);   border-color: rgba(85, 85, 85, 0.22);   color: var(--accent-mid); }
.alert-info    { background-color: rgba(0, 0, 0, 0.05);      border-color: rgba(0, 0, 0, 0.15);      color: var(--accent-mid2); }
.alert-link    { color: inherit; font-weight: 700; text-decoration: underline; }
.btn-close { filter: none; opacity: 0.5; }

/* ----------------------------------------------------------
   PAGINATION
   ---------------------------------------------------------- */
.pagination .page-link { background-color: var(--bg-card); border-color: var(--border-color); color: var(--text-secondary); font-size: 0.85rem; padding: 0.35rem 0.75rem; }
.pagination .page-link:hover { background-color: rgba(0, 0, 0, 0.06); border-color: #888888; color: var(--text-primary); }
.pagination .page-item.disabled .page-link { background-color: var(--bg-surface); border-color: var(--border-subtle); color: var(--text-muted); }

/* ----------------------------------------------------------
   PROGRESS BAR
   ---------------------------------------------------------- */
.progress { background-color: var(--bg-surface); border-radius: 50px; border: 1px solid var(--border-color); }
.progress-bar { background-color: var(--accent-primary); transition: width 0.4s ease; }
.progress-bar.bg-success { background-color: var(--accent-teal) !important; }
.progress-bar.bg-danger  { background-color: var(--accent-rose) !important; }

/* ----------------------------------------------------------
   MODALS
   ---------------------------------------------------------- */
.modal-content { background-color: var(--bg-card); border: 1px solid var(--border-color); border-radius: 10px; color: var(--text-primary); box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15); }
.modal-header { border-bottom: 1px solid var(--border-color); padding: 1rem 1.25rem; }
.modal-header.bg-primary { background-color: rgba(0, 0, 0, 0.06) !important; }
.modal-header.bg-light   { background-color: var(--bg-header) !important; }
.modal-footer { border-top: 1px solid var(--border-color); }
.modal-title { font-size: 1rem; font-weight: 700; }
.modal-backdrop { background-color: rgba(0, 0, 0, 0.55); }

#searchOverlay { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); backdrop-filter: blur(4px); z-index: 1050; }
#searchOverlay .modal-content.bg-search { background-color: var(--bg-card); border-color: #555555; box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2); }
#searchOverlay .bg-search { background-color: var(--bg-card) !important; }
#searchOverlay.show { display: block; }
#searchOverlay .form-control { background-color: var(--bg-surface); color: var(--text-primary); border-color: var(--border-color); }
#updateModal .modal-header.bg-primary { background-color: #222222 !important; color: #fff !important; }

/* ----------------------------------------------------------
   IMAGES & GRILLE JEUX
   ---------------------------------------------------------- */
.img-fluid { max-height: 200px; object-fit: contain; }
.card.shadow-sm img.img-fluid { border-radius: 5px; }
.row-cols-2 .card, .row-cols-sm-3 .card, .row-cols-md-4 .card, .row-cols-lg-5 .card {
  background-color: var(--bg-card); border-color: var(--border-color);
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s; cursor: pointer;
}
.row-cols-2 .card:hover, .row-cols-sm-3 .card:hover, .row-cols-md-4 .card:hover, .row-cols-lg-5 .card:hover {
  border-color: #555555; transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}
.d-flex.align-items-center.justify-content-center.bg-light { background-color: var(--bg-surface) !important; border-radius: 5px; }

/* ----------------------------------------------------------
   SUPPORTS
   ---------------------------------------------------------- */
.btn-outline-primary.w-100 { text-align: center; padding: 0.85rem 0.5rem; display: flex; flex-direction: column; align-items: center; gap: 0.3rem; }
.btn-outline-primary.w-100 i.bi.bi-controller { font-size: 1.6rem; }
.btn-outline-primary.w-100 small.text-muted { color: var(--text-muted) !important; font-size: 0.78rem; }

/* ----------------------------------------------------------
   UTILITAIRES
   ---------------------------------------------------------- */
.text-muted     { color: var(--text-muted) !important; }
.text-secondary { color: var(--text-secondary) !important; }
.text-primary   { color: var(--accent-primary) !important; }
.text-success   { color: var(--accent-teal) !important; }
.text-warning   { color: var(--accent-mid) !important; }
.text-danger    { color: var(--accent-rose) !important; }
.text-info      { color: var(--accent-mid2) !important; }
.fw-bold        { font-weight: 700; }
.text-decoration-none { text-decoration: none !important; }

.bg-primary   { background-color: var(--accent-primary) !important; }
.bg-secondary { background-color: rgba(85, 85, 85, 0.1) !important; }
.bg-success   { background-color: rgba(51, 102, 85, 0.1) !important; }
.bg-warning   { background-color: rgba(85, 85, 85, 0.08) !important; }
.bg-info      { background-color: rgba(51, 51, 51, 0.06) !important; }
.bg-danger    { background-color: rgba(136, 68, 68, 0.1) !important; }
.bg-light     { background-color: var(--bg-surface) !important; }
.bg-dark      { background-color: #111111 !important; }

/* ----------------------------------------------------------
   NEON CUSTOM — compat anciens composants
   ---------------------------------------------------------- */
.bg-neon-games    { background-color: rgba(0, 0, 0, 0.06) !important; }
.bg-neon-livraison{ background-color: rgba(51, 102, 85, 0.08) !important; }
.bg-neon-pdf      { background-color: rgba(136, 68, 68, 0.08) !important; }
.bg-neon-zip      { background-color: rgba(85, 85, 85, 0.08) !important; }

/* ----------------------------------------------------------
   DIVERS
   ---------------------------------------------------------- */
.col-lg-2-12 { flex: 0 0 auto; width: 12%; }
.list-group-item { background-color: var(--bg-card); border-color: var(--border-color); color: var(--text-primary); font-size: 0.9rem; }
.list-group-item:hover { background-color: var(--bg-card-hover); }
.etat-container { font-size: 0.875rem; gap: 4px; }
.etat-container .badge { padding: 0.2em 0.45em; font-weight: 600; }
.card-body .mb-3 i.bi { color: var(--text-muted); width: 1.1em; }
.card.mb-3 .card-header.text-success { color: var(--accent-teal) !important; background-color: transparent !important; }
.card.mb-3 h4.text-success { color: var(--accent-teal) !important; }
canvas { background: transparent !important; }

#dropZone { border: 2px dashed var(--border-color); border-radius: 6px; cursor: pointer; transition: all 0.3s; background-color: var(--bg-surface); }
#dropZone.border-primary { border-color: #555555; background-color: rgba(0, 0, 0, 0.03); }

/* ----------------------------------------------------------
   SCROLLBAR
   ---------------------------------------------------------- */
::-webkit-scrollbar { width: 7px; height: 7px; }
::-webkit-scrollbar-track { background: var(--bg-surface); }
::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #888888; }

/* ----------------------------------------------------------
   RESPONSIVE
   ---------------------------------------------------------- */
@media (max-width: 991.98px) {
  .navbar-collapse { background-color: #111111; border-top: 1px solid #222222; margin-top: 0.5rem; padding: 0.5rem; border-radius: 6px; }
  .navbar-nav.ms-auto { margin-left: 0 !important; width: 100%; }
  .navbar-nav .nav-link { padding: 0.5rem 1rem; }
}
@media (max-width: 767.98px) {
  h1 { font-size: 1.25rem; }
  .card-body { padding: 0.85rem; }
  .btn-group .btn-custom-letter { padding: 0.2rem 0.4rem; font-size: 0.72rem; }
}
