/* --- Global font and resets --- */
:root{
  --accent-easy:  #00E0FF;
  --accent-hard:  #FF0050;
  --accent-main:  var(--accent-easy);
}

body {
  margin: 0;
  padding: 0;
  background: #13092B; /* deep purple arcade bg */
  color: #fff;
  font-family: 'Press Start 2P', sans-serif;
  display: flex; justify-content: center; align-items: flex-start;
  padding-top: 2vh;
}

body.easyMode{ --accent-main: var(--accent-easy); }
body.hardMode{ --accent-main: var(--accent-hard); }

/* utility */
.hidden{ display:none !important; }

/* --- Welcome Screen --- */
#welcomeScreen {
  position: fixed; inset: 0;
  background: #13092B;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 22px;
  z-index: 2000;
}
#welcomeLogo { width: clamp(280px, 30vw, 400px); height: auto; image-rendering: pixelated; }
#welcomeScreen input {
  padding: 14px 18px; width: 220px;
  font-family: 'Press Start 2P', sans-serif;
  font-size: .8rem; text-align: center;
  border: 2px solid #00E0FF; background: #000; color: #fff; outline: none;
}
#startBtn {
  padding: 16px 32px;
  font-size: 1rem; letter-spacing: 1px;
  background: #00E0FF; color: #000; border: none; cursor: pointer;
}
#startBtn:disabled { opacity: .35; cursor: not-allowed; }
#welcomeScreen h3 { margin: 10px 0 0 0; font-size: 1rem; color: #FFD700; }
#leaderboard { list-style: none; padding: 0; margin: 0; width: 220px; text-align: left; font-size: .8rem; color: #fff; }
#leaderboard li { margin: 2px 0; display: flex; justify-content: space-between; }
.modalBtn { display: inline-block; margin: 0 8px; padding: 14px 22px; background: #00E0FF; color: #000; border: none; cursor: pointer; }
.modalBtn:hover { background: #00a8d9; }

/* --- Game Layout --- */
#gameUI {
  display: flex; flex-direction: column;
  align-items: center;
  width: 100%;
  padding-bottom: 8vh;
}

/* ───── LOGO centrado y más compacto ───── */
#logo {
  display: block;
  margin: 0 auto 12px;
  width: 35%;
  max-width: 200px;
  height: auto;
  image-rendering: pixelated;
}

/* ───── Tablero y panel redimensionados ───── */
#gameContainer { display: flex; gap: clamp(1rem,4vw,4rem); max-width: 1000px; margin: 0 auto; justify-content: center; align-items: flex-start; }
#gameCanvas {
  background: #C0C0C0;
  border: 4px solid #00E0FF;
  box-shadow: 0 0 12px #00e0ff55;
  /* Escala basada en ALTURA: el tablero nunca superará el 70 % de la ventana
     y conserva proporción 10×20 (1/2). El ancho se deriva de la altura */
  height: 70vh;
  max-height: 70vh;
  aspect-ratio: 1 / 2;
  width: auto;
  image-rendering: pixelated;
}
#sidePanel {
  background: #BDBDBD;
  border: 3px solid #808080;
  padding: 18px;
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  gap: 15px;
  width: clamp(220px, 22vw, 32vh);
}
#sidePanel p { color: #000; margin: 5px 0; font-size: .8rem; }

/* --- Modal & Game Over --- */
#modalOverlay { position: fixed; inset: 0; display: flex; justify-content: center; align-items: center; background: rgba(0,0,0,.6); visibility: hidden; opacity: 0; transition: .25s; z-index: 1000; }
#modalOverlay.visible { visibility: visible; opacity: 1; }
#modalBox { background: #222; color: #fff; padding: 30px 40px; border-radius: 8px; font-size: 1.2rem; text-align: center; min-width: 260px; }
#game-over { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: #222; color: #fff; padding: 24px 32px; text-align: center; border-radius: 4px; display: none; }

/* --- Responsive overrides are now located in styles-mobile.css */

#startEasyBtn,
#startHardBtn {
  padding: 16px 28px;
  font-size: 1rem;
  letter-spacing: 1px;
  font-family: 'Press Start 2P', sans-serif;
  border: 3px solid #fff;
  text-shadow: 0 0 4px #fff;
  cursor: pointer;
}

#startEasyBtn {
  background: #00E0FF;
  color: #000;
  box-shadow: 0 0 10px #00E0FF, 0 0 20px #00E0FF;
}
#startHardBtn {
  background: #FF0050;
  color: #000;
  box-shadow: 0 0 10px #FF0050, 0 0 20px #FF0050;
}

#startEasyBtn:hover { background: #00a8d9; }
#startHardBtn:hover { background: #FF4078; }

#startEasyBtn:disabled,
#startHardBtn:disabled { opacity: .35; box-shadow: none; cursor: not-allowed; }

#modeLabel {
  font-size: .9rem;
  font-weight: bold;
  text-align: center;
  text-shadow: 0 0 4px rgba(0,0,0,.5);
  margin: 0;
  color: var(--accent-main) !important;
}

/* Contenedor principal para ambos leaderboards */
.leaderboards-container {
  display: flex;
  gap: 30px;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap; /* Para que se adapte en pantallas medianas */
}

.leaderboard-section {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.leaderboard-section h3 {
  margin: 10px 0 8px 0;
  font-size: 1rem;
  color: #FFD700;
  text-shadow: 0 0 8px #FFD700;
  text-align: center;
}

.leaderboard {
  list-style: none;
  padding: 15px;
  margin: 0;
  width: 280px;
  text-align: left;
  font-size: .8rem;
  color: #fff;
  border: 2px solid var(--accent-main);
  border-radius: 6px;
  background: rgba(0, 224, 255, 0.05);
  box-shadow: 0 0 8px rgba(0, 224, 255, 0.3);
  transition: box-shadow 0.3s ease;
}

.leaderboard:hover {
  box-shadow: 0 0 15px var(--accent-main);
}

/* También los títulos con glow */
#welcomeScreen h3 {
  margin: 10px 0 5px 0;
  font-size: 1rem;
  color: #FFD700;
  text-shadow: 0 0 8px #FFD700; /* ← Glow dorado */
}

.leaderboard li { margin: 2px 0; display: flex; justify-content: space-between; }

/* Large desktop screens */
@media (min-width: 1400px) {
  #gameCanvas { width: min(40vw, 32vh); }
}

.startButtons{
  display:flex;
  gap:14px;
}

.modalText{ margin-bottom:18px; display:block; }

.share-button {
  margin-top: 20px;
  background: transparent;
  border: 2px solid var(--accent-main);
  color: var(--accent-main);
  padding: 10px 20px;
  font-family: 'Press Start 2P', sans-serif;
  font-size: 0.8rem;
  cursor: pointer;
  text-shadow: 0 0 6px var(--accent-main);
  transition: all 0.2s ease-in-out;
}
.share-button:hover {
  background: var(--accent-main);
  color: #13092B;
  box-shadow: 0 0 12px var(--accent-main);
}

.arcadeBtn{
  padding: 16px 28px;
  font-size: 1rem;
  letter-spacing: 1px;
  font-family: 'Press Start 2P', sans-serif;
  border: 3px solid #fff;
  text-shadow: 0 0 4px #fff;
  cursor: pointer;
  transition: filter .2s;
}
.arcadeBtn:hover{ filter: brightness(1.1); }

/* Botones principales reutilizan arcadeBtn + color */
#startEasyBtn{ background: var(--accent-easy); color:#000; box-shadow:0 0 10px var(--accent-easy); }
#startHardBtn{ background: var(--accent-hard); color:#000; box-shadow:0 0 10px var(--accent-hard); }

/* Modal buttons share same look */
.modalBtn{ background: var(--accent-main); color:#000; }

/* Game container spacing */
#gameContainer{ gap:clamp(1rem,4vw,4rem); }

.gameOverBox{
  position:fixed; top:50%; left:50%; transform:translate(-50%,-50%);
  background:#222; color:#fff; padding:24px 32px; text-align:center; border-radius:4px;
  z-index:1500; font-size:1.2rem;
}

#startEasyBtn:disabled,
#startHardBtn:disabled { opacity:.35; box-shadow:none; cursor:not-allowed; }

/* --- Responsive overrides for small desktop screens (formerly in styles-mobile.css) --- */

@media (max-width: 768px) {
  #gameContainer { flex-direction: column; gap: 4vh; align-items: center; }
  #sidePanel     { width: 90vw; flex-direction: row; gap: 4vw; align-items: flex-start; }
  #sidePanel p   { font-size: .65rem; }
  #gameCanvas    { width: 95vw; }
}

@media (max-width: 480px) {
  #gameCanvas { width: 94vw; }
  #sidePanel  { flex-wrap: wrap; }
  #nextCanvas { max-width: 60px; }
}

@media (max-width: 350px) {
  #nextCanvas { max-width: 50px; }
}

@media (max-height: 700px){
  #gameCanvas{ height: 60vh; }
}

/* --- Responsive overrides below --- */

#topScore{ color:#FFD700; } 

/* Responsive: volver a vertical en pantallas pequeñas */
@media (max-width: 768px) {
  .leaderboards-container {
    flex-direction: column;
    gap: 20px;
  }
} 

.version-info {
  margin-top: 15px;
  font-family: 'Press Start 2P', sans-serif;
  font-size: 0.6rem;
  color: rgba(255, 255, 255, 0.6);
  text-align: center;
  letter-spacing: 1px;
} 

.support-buttons {
  display: flex;
  gap: 15px;
  justify-content: center;
  align-items: center; /* ← Esto centra verticalmente */
  flex-wrap: wrap;
}

/* Asegurar que el enlace de Ko-fi tenga el mismo comportamiento */
.support-buttons a {
  display: inline-flex;
  align-items: center;
  vertical-align: middle;
}

/* Ajustar el botón SHARE si es necesario */
.share-button {
  margin-top: 0;
  margin-bottom: 0;
  vertical-align: middle;
}

/* Responsive: vertical en pantallas pequeñas */
@media (max-width: 480px) {
  .support-buttons {
    flex-direction: column;
    gap: 10px;
    align-items: center; /* ← Centrar horizontalmente cuando son verticales */
  }
} 

#kofiframe {
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

/* Responsive: vertical en pantallas medianas */
@media (max-width: 768px) {
  .support-buttons {
    flex-direction: column;
    align-items: center;
    gap: 15px;
  }
  
  #kofiframe {
    width: 90%;
    max-width: 350px;
    height: 450px;
  }
} 

#lives {
  display: inline-flex;
  align-items: center;
  margin-left: 6px;
}
#lives img {
  vertical-align: middle;
}