/* ============================================================
   THEME: MAGICAL MIRROR — Detrás del Espejo Encantado
   Overrides style.css with antique/mystical/violet aesthetic.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&display=swap');

:root {
  --mirror-violet: #7b2d8e;
  --mirror-deep: #2a0a3a;
  --mirror-dark: #14061f;
  --mirror-void: #0a0210;
  --mirror-gold: #c9a84c;
  --mirror-gold-light: #e8d48b;
  --mirror-glow: #a855f7;
  --mirror-amber: #d4a056;
  --mirror-rose: #c44a7c;
  --mirror-crystal: rgba(200, 160, 255, 0.15);
  --mirror-crystal-bright: rgba(200, 160, 255, 0.3);
  --mirror-frame: #3a1a4e;
  --mirror-panel: rgba(20, 6, 31, 0.92);

  --font-display: 'Cinzel', serif;
  --font-body: 'Cormorant Garamond', serif;

  --bg-body: var(--mirror-void);
}

/* ── 1. BODY — deep void with violet mist ── */
body {
  background: var(--mirror-void) !important;
  font-family: var(--font-body) !important;
}

/* ── 2. INTRO SPLASH ── */
.intro-titulo {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
  text-shadow: 0 0 20px rgba(201, 168, 76, 0.5), 0 0 60px rgba(201, 168, 76, 0.2) !important;
  letter-spacing: 8px;
}
.intro-sub {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: rgba(201, 168, 76, 0.6) !important;
}

/* ── 3. HOME SCREEN — replace neon/tech with magical ambient ── */
.home-screen::before {
  background:
    radial-gradient(ellipse 70% 50% at 30% 40%, rgba(123, 45, 142, 0.15) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 70% 60%, rgba(201, 168, 76, 0.06) 0%, transparent 50%),
    radial-gradient(ellipse 40% 50% at 50% 20%, rgba(168, 85, 247, 0.08) 0%, transparent 50%) !important;
  animation: magical-mist 20s ease-in-out infinite alternate !important;
}

.home-screen::after {
  display: none !important;
}

.grid-bg, .scanlines, .crt-overlay {
  display: none !important;
}

@keyframes magical-mist {
  0% { opacity: 0.6; transform: scale(1); }
  100% { opacity: 1; transform: scale(1.08); }
}

/* ── 4. HOME TITLES ── */
.home-screen h1 {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
  text-shadow: 0 0 30px rgba(201, 168, 76, 0.3), 0 4px 20px rgba(0, 0, 0, 0.5) !important;
  letter-spacing: 6px !important;
}
.home-screen .subtitulo {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: rgba(201, 168, 76, 0.5) !important;
}

/* ── 5. ORNATE CARD — reusable decorative container ── */
.ornate-card {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.95), rgba(20, 6, 31, 0.98)) !important;
  border: 2px solid var(--mirror-gold) !important;
  border-radius: 4px !important;
  box-shadow:
    0 0 40px rgba(123, 45, 142, 0.2),
    0 0 80px rgba(201, 168, 76, 0.05),
    inset 0 0 60px rgba(168, 85, 247, 0.05) !important;
  position: relative;
}
.ornate-card::before {
  content: '';
  position: absolute;
  top: -3px; left: -3px;
  right: -3px; bottom: -3px;
  border: 1px solid rgba(201, 168, 76, 0.2);
  border-radius: 6px;
  pointer-events: none;
}
.ornate-card::after {
  content: '✦';
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  font-size: 18px;
  color: var(--mirror-gold);
  text-shadow: 0 0 15px rgba(201, 168, 76, 0.5);
  background: var(--mirror-void);
  padding: 0 12px;
}

/* ── 6. WELCOME SCREEN — ornate mirror ── */
.welcome-screen {
  background: radial-gradient(ellipse at center, rgba(42, 10, 58, 0.6) 0%, var(--mirror-void) 70%) !important;
}

.welcome-card {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.92), rgba(20, 6, 31, 0.96)) !important;
  border: 2px solid var(--mirror-gold) !important;
  border-radius: 4px !important;
  box-shadow:
    0 0 80px rgba(123, 45, 142, 0.2),
    0 0 160px rgba(201, 168, 76, 0.05),
    inset 0 0 80px rgba(168, 85, 247, 0.03) !important;
  position: relative;
  padding: 50px 40px !important;
}
.welcome-card::before {
  content: '';
  position: absolute;
  top: 4px; left: 4px;
  right: 4px; bottom: 4px;
  border: 1px solid rgba(201, 168, 76, 0.15);
  border-radius: 2px;
  pointer-events: none;
}
.welcome-card::after {
  content: '';
  position: absolute;
  top: -2px; left: -2px;
  right: -2px; bottom: -2px;
  border: 1px solid rgba(123, 45, 142, 0.3);
  border-radius: 6px;
  pointer-events: none;
}

/* Corner ornaments */
.welcome-card .corner {
  position: absolute;
  width: 30px; height: 30px;
  border-color: var(--mirror-gold);
  border-style: solid;
  border-width: 0;
  opacity: 0.4;
  pointer-events: none;
}
.welcome-card .corner-tl {
  top: 8px; left: 8px;
  border-top-width: 1px;
  border-left-width: 1px;
}
.welcome-card .corner-tr {
  top: 8px; right: 8px;
  border-top-width: 1px;
  border-right-width: 1px;
}
.welcome-card .corner-bl {
  bottom: 8px; left: 8px;
  border-bottom-width: 1px;
  border-left-width: 1px;
}
.welcome-card .corner-br {
  bottom: 8px; right: 8px;
  border-bottom-width: 1px;
  border-right-width: 1px;
}

.welcome-icono {
  width: 80px !important;
  height: 80px !important;
  border: 2px solid var(--mirror-gold) !important;
  border-radius: 50% !important;
  background: radial-gradient(circle at 40% 35%, rgba(168, 85, 247, 0.2), rgba(42, 10, 58, 0.5)) !important;
  box-shadow:
    0 0 40px rgba(168, 85, 247, 0.2),
    inset 0 0 40px rgba(201, 168, 76, 0.05) !important;
}
.welcome-icono::before {
  content: '🪞';
  font-size: 36px;
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}

.welcome-titulo-principal {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
  text-shadow: 0 0 30px rgba(201, 168, 76, 0.3) !important;
  letter-spacing: 4px !important;
  font-size: 1.1rem !important;
}

.welcome-sub {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: rgba(201, 168, 76, 0.5) !important;
}

.welcome-input {
  background: rgba(42, 10, 58, 0.4) !important;
  border: 1px solid rgba(201, 168, 76, 0.3) !important;
  border-radius: 2px !important;
  color: var(--mirror-gold-light) !important;
  font-family: var(--font-display) !important;
  letter-spacing: 4px !important;
  text-align: center !important;
  transition: all 0.4s ease !important;
}
.welcome-input:focus {
  border-color: var(--mirror-gold) !important;
  box-shadow: 0 0 30px rgba(201, 168, 76, 0.15), inset 0 0 20px rgba(168, 85, 247, 0.05) !important;
  outline: none !important;
}
.welcome-input::placeholder {
  color: rgba(201, 168, 76, 0.2) !important;
  letter-spacing: 3px;
  font-size: 0.75rem;
}

.welcome-btn {
  font-family: var(--font-display) !important;
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.1), rgba(123, 45, 142, 0.15)) !important;
  border: 1.5px solid var(--mirror-gold) !important;
  border-radius: 2px !important;
  color: var(--mirror-gold-light) !important;
  letter-spacing: 4px !important;
  text-shadow: 0 0 15px rgba(201, 168, 76, 0.3) !important;
  box-shadow: 0 0 30px rgba(201, 168, 76, 0.1), 0 4px 20px rgba(0, 0, 0, 0.3) !important;
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
.welcome-btn:hover {
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.2), rgba(123, 45, 142, 0.25)) !important;
  box-shadow: 0 0 60px rgba(201, 168, 76, 0.2), 0 6px 30px rgba(0, 0, 0, 0.4) !important;
  transform: translateY(-2px) !important;
}

.welcome-error {
  color: #d44a7c !important;
  font-family: var(--font-body) !important;
  font-style: italic;
  text-shadow: 0 0 20px rgba(212, 74, 124, 0.3) !important;
}

/* ── 7. BUTTONS — ornate, mysterious ── */
.btn-img, .btn-back, .destino-btn, .ruleta-btn,
.verdad-btn-v, .verdad-btn-m, .caja-btn, .prefieres-btn {
  font-family: var(--font-display) !important;
  letter-spacing: 3px !important;
}
.destino-btn {
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.08), rgba(123, 45, 142, 0.1)) !important;
  border: 1.5px solid var(--mirror-gold) !important;
  border-radius: 2px !important;
  color: var(--mirror-gold-light) !important;
  text-shadow: 0 0 15px rgba(201, 168, 76, 0.2) !important;
  box-shadow: 0 0 30px rgba(201, 168, 76, 0.08) !important;
}
.destino-btn:hover {
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.15), rgba(123, 45, 142, 0.2)) !important;
  box-shadow: 0 0 50px rgba(201, 168, 76, 0.15) !important;
  transform: translateY(-3px) !important;
}
.destino-btn:disabled {
  opacity: 0.3 !important;
}

/* ── 8. GAMES HUB — cards ── */
.destino-titulo {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
  text-shadow: 0 0 30px rgba(201, 168, 76, 0.2) !important;
}
.destino-sub {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: rgba(201, 168, 76, 0.4) !important;
}

.destino-card {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.85), rgba(20, 6, 31, 0.9)) !important;
  border: 1.5px solid rgba(201, 168, 76, 0.2) !important;
  border-radius: 4px !important;
  box-shadow: 0 0 30px rgba(123, 45, 142, 0.1) !important;
  position: relative;
  overflow: hidden;
}
.destino-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  right: 0; bottom: 0;
  border: 1px solid rgba(201, 168, 76, 0.06);
  border-radius: 4px;
  pointer-events: none;
}
.destino-card:hover {
  border-color: rgba(201, 168, 76, 0.4) !important;
  box-shadow: 0 0 50px rgba(123, 45, 142, 0.2), 0 0 80px rgba(201, 168, 76, 0.05) !important;
  transform: translateY(-4px) !important;
}
.destino-card .card-icono {
  filter: drop-shadow(0 0 10px rgba(201, 168, 76, 0.2));
}
.destino-card .card-nombre {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold-light) !important;
}
.destino-card .card-desc {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: rgba(201, 168, 76, 0.5) !important;
}

/* ── 9. GAME VIEWS — containers ── */
.game-view {
  background: radial-gradient(ellipse at center, rgba(42, 10, 58, 0.3), var(--mirror-void) 80%) !important;
}

.btn-back-game {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
  border: 1px solid rgba(201, 168, 76, 0.3) !important;
  background: rgba(42, 10, 58, 0.4) !important;
  border-radius: 2px !important;
  letter-spacing: 2px !important;
}

/* ── 10. PROFILE OVERLAY ── */
.profile-card, .ranking-card {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.96), rgba(20, 6, 31, 0.98)) !important;
  border: 2px solid var(--mirror-gold) !important;
  border-radius: 4px !important;
  box-shadow: 0 0 80px rgba(123, 45, 142, 0.2), 0 0 160px rgba(201, 168, 76, 0.03) !important;
}
.profile-nombre {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold-light) !important;
}
.profile-nivel-badge {
  font-family: var(--font-display) !important;
  font-size: 0.65rem !important;
}
.profile-stat-label {
  font-family: var(--font-display) !important;
  font-size: 0.6rem !important;
  color: rgba(201, 168, 76, 0.5) !important;
}
.profile-stat-val {
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  color: var(--mirror-gold-light) !important;
}
.profile-historial-titulo {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
}
.profile-historial-item {
  font-family: var(--font-body) !important;
  color: rgba(201, 168, 76, 0.6) !important;
}

/* ── 11. RANKING OVERLAY ── */
.ranking-titulo {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
}
.ranking-nombre {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold-light) !important;
}
.ranking-nivel {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: rgba(201, 168, 76, 0.5) !important;
}
.ranking-puntos {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
}

/* ── 12. ADMIN PANEL ── */
.admin-card {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.96), rgba(20, 6, 31, 0.98)) !important;
  border: 2px solid var(--mirror-gold) !important;
  border-radius: 4px !important;
  box-shadow: 0 0 80px rgba(123, 45, 142, 0.2) !important;
}
.admin-titulo {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
}
.admin-input {
  background: rgba(42, 10, 58, 0.4) !important;
  border: 1px solid rgba(201, 168, 76, 0.2) !important;
  border-radius: 2px !important;
  color: var(--mirror-gold-light) !important;
  font-family: var(--font-body) !important;
}
.admin-input:focus {
  border-color: var(--mirror-gold) !important;
  box-shadow: 0 0 20px rgba(201, 168, 76, 0.1) !important;
  outline: none !important;
}
.admin-btn {
  font-family: var(--font-display) !important;
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.1), rgba(123, 45, 142, 0.15)) !important;
  border: 1px solid var(--mirror-gold) !important;
  border-radius: 2px !important;
  color: var(--mirror-gold-light) !important;
  letter-spacing: 2px !important;
}
.admin-btn:hover {
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.2), rgba(123, 45, 142, 0.25)) !important;
}
.admin-guest-item {
  border-bottom: 1px solid rgba(201, 168, 76, 0.08) !important;
}
.admin-guest-nombre {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold-light) !important;
}
.admin-guest-codigo {
  font-family: var(--font-body) !important;
  color: rgba(201, 168, 76, 0.4) !important;
}
.admin-col-titulo {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
}

/* ── 13. GAME: ROMPE EL ESPEJO ── */
.espejo-container {
  background: transparent !important;
}
.fragmento {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.85), rgba(20, 6, 31, 0.9)) !important;
  border: 1.5px solid rgba(201, 168, 76, 0.15) !important;
  border-radius: 2px !important;
  box-shadow: 0 0 20px rgba(123, 45, 142, 0.1), inset 0 0 20px rgba(168, 85, 247, 0.03) !important;
}
.fragmento.revelado {
  border-color: var(--mirror-gold) !important;
  box-shadow: 0 0 40px rgba(201, 168, 76, 0.1), inset 0 0 30px rgba(168, 85, 247, 0.05) !important;
}
.frag-num {
  font-family: var(--font-display) !important;
  color: rgba(201, 168, 76, 0.3) !important;
}
.frag-texto {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: var(--mirror-gold-light) !important;
}

/* ── 14. GAME: RULETA ── */
.ruleta-stage-beam {
  background: radial-gradient(ellipse at 50% 30%, rgba(123, 45, 142, 0.04) 0%, transparent 50%) !important;
}
.ruleta-outer-ring {
  border-color: rgba(201, 168, 76, 0.12) !important;
  box-shadow: 0 0 30px rgba(123, 45, 142, 0.08), inset 0 0 30px rgba(168, 85, 247, 0.03) !important;
}
.ruleta-container.girando .ruleta-outer-ring {
  border-color: rgba(201, 168, 76, 0.3) !important;
  box-shadow: 0 0 60px rgba(123, 45, 142, 0.2), inset 0 0 60px rgba(168, 85, 247, 0.08) !important;
}
.ruleta-resultado {
  background: rgba(20, 6, 31, 0.95) !important;
  border-color: var(--mirror-gold) !important;
  box-shadow: 0 0 100px rgba(123, 45, 142, 0.2), 0 0 200px rgba(201, 168, 76, 0.05) !important;
}
.ruleta-resultado p {
  font-family: var(--font-body) !important;
}
.ruleta-resultado .categoria {
  font-family: var(--font-display) !important;
}

/* ── 15. GAME: VERDAD O MENTIRA ── */
.verdad-card {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.9), rgba(20, 6, 31, 0.95)) !important;
  border: 2px solid rgba(201, 168, 76, 0.2) !important;
  border-radius: 4px !important;
  box-shadow: 0 0 40px rgba(123, 45, 142, 0.1), inset 0 0 40px rgba(168, 85, 247, 0.02) !important;
}
.verdad-card .categoria {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
}
.verdad-card .afirmacion {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: var(--mirror-gold-light) !important;
}
.verdad-btn-v, .verdad-btn-m {
  font-family: var(--font-display) !important;
  border-radius: 2px !important;
  border: 1.5px solid rgba(201, 168, 76, 0.3) !important;
  color: var(--mirror-gold-light) !important;
  background: rgba(42, 10, 58, 0.4) !important;
}
.verdad-btn-v:hover, .verdad-btn-m:hover {
  border-color: var(--mirror-gold) !important;
  box-shadow: 0 0 30px rgba(201, 168, 76, 0.1) !important;
}

/* ── 16. GAME: CAJA MISTERIOSA ── */
.caja-container {
  background: transparent !important;
}
.caja-item {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.85), rgba(20, 6, 31, 0.9)) !important;
  border: 2px solid rgba(201, 168, 76, 0.2) !important;
  border-radius: 4px !important;
  box-shadow: 0 0 30px rgba(123, 45, 142, 0.1) !important;
}
.caja-item.abriendo {
  border-color: var(--mirror-gold) !important;
  box-shadow: 0 0 60px rgba(201, 168, 76, 0.15) !important;
}

/* ── 17. GAME: QUÉ PREFIERES ── */
.prefieres-container {
  background: transparent !important;
}
.prefieres-panel {
  background: linear-gradient(135deg, rgba(42, 10, 58, 0.85), rgba(20, 6, 31, 0.9)) !important;
  border: 2px solid rgba(201, 168, 76, 0.2) !important;
  border-radius: 4px !important;
  box-shadow: 0 0 30px rgba(123, 45, 142, 0.1) !important;
}
.prefieres-panel.seleccionado {
  border-color: var(--mirror-gold) !important;
  box-shadow: 0 0 50px rgba(201, 168, 76, 0.1) !important;
}

/* ── 18. DECORATIVE ORNAMENTS ── */

/* Crystal shard decorative element */
.crystal-shard {
  position: absolute;
  pointer-events: none;
  width: 4px;
  background: linear-gradient(to bottom, rgba(200, 160, 255, 0.4), transparent);
  clip-path: polygon(50% 0%, 100% 100%, 0% 100%);
  opacity: 0.3;
  animation: crystal-float 6s ease-in-out infinite;
}
@keyframes crystal-float {
  0%, 100% { opacity: 0.2; transform: translateY(0) rotate(0deg); }
  50% { opacity: 0.5; transform: translateY(-10px) rotate(5deg); }
}

/* Mirror reflection overlay */
.mirror-reflect {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: linear-gradient(135deg,
    rgba(255, 255, 255, 0.02) 0%,
    rgba(200, 160, 255, 0.03) 30%,
    rgba(201, 168, 76, 0.02) 60%,
    transparent 100%
  );
  pointer-events: none;
  animation: mirror-shimmer 8s ease-in-out infinite;
}
@keyframes mirror-shimmer {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

/* Decorative diamond */
.ornate-diamond {
  display: inline-block;
  width: 8px; height: 8px;
  background: var(--mirror-gold);
  transform: rotate(45deg);
  opacity: 0.3;
  box-shadow: 0 0 10px rgba(201, 168, 76, 0.3);
  margin: 0 8px;
}

/* ── 19. FULLSCREEN BUTTON ── */
#btnFullscreen {
  font-family: var(--font-display) !important;
  font-size: 0.55rem !important;
  color: rgba(201, 168, 76, 0.2) !important;
  border: 1px solid rgba(201, 168, 76, 0.08) !important;
  background: rgba(42, 10, 58, 0.2) !important;
  border-radius: 2px !important;
}

/* ── 20. SCROLLBAR ── */
::-webkit-scrollbar-track {
  background: var(--mirror-void) !important;
}
::-webkit-scrollbar-thumb {
  background: rgba(201, 168, 76, 0.15) !important;
  border-radius: 2px !important;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(201, 168, 76, 0.25) !important;
}

/* ── 21. DIMENSION / PORTAL ── */
.dim-titulo {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
}
.dim-descripcion {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: rgba(201, 168, 76, 0.5) !important;
}
.portal-titulo {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold) !important;
}

/* ── 22. WELCOME BIENVENIDA OVERLAY ── */
.welcome-bienvenido {
  background: rgba(20, 6, 31, 0.95) !important;
  border: 2px solid var(--mirror-gold) !important;
  border-radius: 4px !important;
  box-shadow: 0 0 80px rgba(123, 45, 142, 0.3), 0 0 160px rgba(201, 168, 76, 0.05) !important;
}
.welcome-bienvenido-texto {
  font-family: var(--font-display) !important;
  color: var(--mirror-gold-light) !important;
}
.welcome-bienvenido-sub {
  font-family: var(--font-body) !important;
  font-style: italic;
  color: rgba(201, 168, 76, 0.5) !important;
}
