/* Cyberpunk theme (default)
   Ce fichier est servi via /theme/cyberpunk.css.
   Il fournit des variables + une base de style pour les pages qui s'appuient sur les thèmes.
*/

:root{
  --x-bg0:#020617;
  --x-bg1:#0f172a;
  --x-bg2:#000000;

  --x-text:#e5e7eb;
  --x-muted:rgba(148,163,184,.90);

  --x-cyan:#38bdf8;
  --x-pink:#ec4899;
  --x-green:#10b981;

  --x-accent: var(--x-cyan);

  --x-glass: rgba(2,6,23,.55);
  --x-glass2: rgba(15,23,42,.82);

  --x-border: rgba(56,189,248,.28);
  --x-border2: rgba(236,72,153,.18);

  --x-shadow: 0 18px 60px rgba(0,0,0,.55);
  --x-shadow2: 0 10px 28px rgba(0,0,0,.38);
  --x-link: var(--x-cyan);
  --x-linkHover: #ffffff;
}
/* --------- Mode clair / sombre ---------
   - Automatique: suit le réglage du système (prefers-color-scheme)
   - Manuel: documentElement.dataset.mode = "light" | "dark"
*/

:root[data-mode="dark"]{
  /* forcer le mode sombre même si le système est en clair */
  --x-bg0:#020617;
  --x-bg1:#0f172a;
  --x-bg2:#000000;

  --x-text:#e5e7eb;
  --x-muted:rgba(148,163,184,.90);

  --x-glass: rgba(2,6,23,.55);
  --x-glass2: rgba(15,23,42,.82);

  --x-border: rgba(56,189,248,.28);
  --x-border2: rgba(236,72,153,.18);

  --x-shadow: 0 18px 60px rgba(0,0,0,.55);
  --x-shadow2: 0 10px 28px rgba(0,0,0,.38);

  --x-link: var(--x-cyan);
  --x-linkHover: #ffffff;
}

html, body{ height:auto; min-height:100%; }

body{
  margin:0;
  color: var(--x-text) !important;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  min-height: 100vh;
  min-height: 100svh;
  min-height: 100dvh;
  background:
    radial-gradient(circle at 20% 0, rgba(56,189,248,0.16), transparent 55%),
    radial-gradient(circle at 82% 10%, rgba(236,72,153,0.14), transparent 60%),
    radial-gradient(circle at 60% 92%, rgba(16,185,129,0.10), transparent 65%),
    linear-gradient(180deg, var(--x-bg1), var(--x-bg0) 48%, var(--x-bg2)) !important;
}

/* Surfaces (containers) */
.shell, .table, .game-card, .age-gate, body > .card{
  position:relative;
  z-index:1;
  background:
    radial-gradient(circle at 18% 0, rgba(56,189,248,0.22), rgba(15,23,42,0.98)),
    radial-gradient(circle at 82% 100%, rgba(236,72,153,0.18), rgba(15,23,42,0.98)) !important;
  border: 1px solid var(--x-border) !important;
  box-shadow: var(--x-shadow) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Boutons */
.btn{
  display:inline-block;
  text-decoration:none;
  color: var(--x-text) !important;
  border: 1px solid var(--x-border) !important;
  background: var(--x-glass);
  padding: 10px 14px;
  border-radius: 14px;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.btn:hover{
  transform: translateY(-1px);
  background: rgba(15,23,42,.88);
  border-color: rgba(56,189,248,.50);
}

/* Tables */
table{
  width:100%;
  border-collapse: collapse;
}
th, td{
  padding: 10px 10px;
  border-bottom: 1px solid rgba(148,163,184,0.18);
  font-size: .92rem;
}
th{
  text-align:left;
  color: rgba(148,163,184,.95);
  font-weight: 700;
}

/* Links (theme) */
a{ color: var(--x-link) !important; }
a:hover{ color: var(--x-linkHover) !important; text-decoration: underline; text-underline-offset: 3px; }

/* Bouton mode jour/nuit */
.mode-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 40px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid var(--x-border) !important;
  background: var(--x-glass);
  color: var(--x-text) !important;
  cursor: pointer;
  padding: 0;
  line-height: 1;
  transition: transform .12s ease, filter .12s ease, background .12s ease, border-color .12s ease;
}
.mode-toggle:hover{
  transform: translateY(-1px);
  filter: brightness(1.06);
  background: var(--x-glass2);
  border-color: rgba(56,189,248,.50);
}
.mode-toggle:active{ transform: translateY(0); }
.mode-toggle:focus-visible{
  outline: 2px solid rgba(56,189,248,.65);
  outline-offset: 3px;
}

/* =========================================================
   CONTRASTE MODE JOUR (et zones globales)
   - Corrige la barre utilisateur (Connecté / Solde / menu)
   - Harmonise liens et textes "muted" via variables du thème
   ========================================================= */
a{ color: var(--x-link) !important; }
a:hover{ color: var(--x-linkHover) !important; text-decoration: none !important; }

.muted, .subtitle, .hint, .sub, .note, .label, .k{
  color: var(--x-muted) !important;
}

/* Barre utilisateur : applique seulement en mode jour pour garder le rendu nuit original */

/* Formulaires : améliore lisibilité en mode jour */

/* Home – boutons "Jouer" (Cyberpunk) */
.btn-primary.btn-play{
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  /* Style néon */
  color: #ffffff !important;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: none;
  text-decoration: underline !important;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;

  border: 1px solid transparent;
  background:
    linear-gradient(180deg, rgba(2,6,23,.60), rgba(2,6,23,.25)) padding-box,
    linear-gradient(90deg, var(--x-cyan), var(--x-pink)) border-box;

  box-shadow:
    0 14px 34px rgba(56,189,248,.20),
    0 0 26px rgba(236,72,153,.16);

  text-shadow:
    0 0 14px rgba(56,189,248,.45),
    0 0 8px rgba(236,72,153,.25);

  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease;
}

.btn-primary.btn-play:hover{
  transform: translateY(-1px);
  filter: brightness(1.12);
  color: #ffffff !important;
  text-decoration: none !important;
  box-shadow:
    0 16px 40px rgba(56,189,248,.26),
    0 0 34px rgba(236,72,153,.22);
}

/* Petit reflet animé */
.btn-primary.btn-play::before{
  content:"";
  position:absolute;
  top:-70%;
  left:-40%;
  width: 60%;
  height: 240%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
  transform: rotate(20deg);
  opacity: .55;
  animation: cpShine 3.8s linear infinite;
}

@keyframes cpShine{
  0%{ left:-60%; }
  100%{ left:140%; }
}

@media (prefers-reduced-motion: reduce){
  .btn-primary.btn-play::before{ animation:none; }
}

