/* ================================================== */
/* ARQUIVO DE ESTILOS (style.css)                     */
/* Contém todas as regras de CSS para o jogo Genius.  */
/* ================================================== */

/* --- Estilos Globais e Body --- */
body {
  background-image: url('mesa.jpg'); /* Imagem de fundo opcional */
  background-size: cover;
  background-repeat: no-repeat;
  background-color: #333; /* Cor de fundo fallback */
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  margin: 0;
  overflow: hidden; /* Evita barras de rolagem indesejadas */
  font-family: sans-serif; /* Fonte padrão fallback */
}

#game-container {
  display: flex;
  align-items: flex-start; /* Alinha itens no topo */
  justify-content: center;
  width: 100%;
  flex-wrap: wrap; /* Permite que o placar vá para baixo em telas menores */
  gap: 20px; /* Espaço entre o jogo e o placar */
  padding: 10px; /* Espaçamento interno */
  box-sizing: border-box;
}

/* --- Estrutura Principal do Jogo (Círculos) --- */
#outer-circle { /* Base preta principal */
  background: #000000;
  border-radius: 50%;
  height: 500px; /* Tamanho base */
  width: 500px;  /* Tamanho base */
  position: relative;
  border: 10px solid #111111; /* Borda cinza muito escura, quase preta */
  box-shadow: 6px 6px 12px 3px rgba(0, 0, 0, 0.6); /* Sombra externa para destacar */
  flex-shrink: 0; /* Impede que encolha com flexbox */
  overflow: hidden; /* Garante que nada saia dos limites arredondados */
}

#inner-circle { /* Área central cinza */
  position: absolute;
  background: #4d4d4d; /* Cinza médio */
  border-radius: 50%;
  height: 50%;
  width: 50%;
  border-style: solid;
  border-width: 10px; /* Espessura da borda do círculo cinza */
  border-color: #000000; /* Borda preta */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); /* Centraliza perfeitamente */
  box-sizing: border-box;
  box-shadow: inset 3px 3px 8px rgba(0, 0, 0, 0.7),
              inset -2px -2px 5px rgba(255, 255, 255, 0.1);
  z-index: 2; /* Fica acima dos quadrantes coloridos */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

/* --- Quadrantes Coloridos (Botões de Jogo) --- */
.quadrant {
    position: absolute;
    height: 50%;
    width: 50%;
    border-style: solid;
    border-color: #000000; /* Borda preta entre quadrantes */
    border-width: 6px;     /* Borda entre quadrantes mais fina */
    box-sizing: border-box;
    cursor: pointer;
    transition: background-color 0.1s ease-in-out, box-shadow 0.1s ease-in-out, filter 0.1s ease-in-out;
    box-shadow: inset 1px 1px 3px rgba(255, 255, 255, 0.15),
                inset -2px -2px 4px rgba(0, 0, 0, 0.4),
                3px 3px 6px rgba(0, 0, 0, 0.6);
    z-index: 1;
    filter: brightness(0.9);
}
.quadrant:active {
   filter: brightness(1.1);
   box-shadow: inset 1px 1px 4px rgba(0, 0, 0, 0.5);
}
.quadrant.lit { /* Estilo quando o quadrante acende */
   filter: brightness(1.2);
   box-shadow: inset 1px 1px 3px rgba(255, 255, 255, 0.2),
               inset -2px -2px 4px rgba(0, 0, 0, 0.5),
               4px 4px 8px rgba(0, 0, 0, 0.7);
}
/* Cores e Posições dos Quadrantes */
#topleft { top: 0; left: 0; border-radius: 100% 0 0 0; background: darkgreen; }
#topleft.lit { background-color: lightgreen; }
#topright { top: 0; left: 50%; border-radius: 0 100% 0 0; background: darkred; }
#topright.lit { background-color: tomato; }
#bottomleft { top: 50%; left: 0; border-radius: 0 0 0 100%; background: goldenrod; }
#bottomleft.lit { background-color: yellow; }
#bottomright { top: 50%; left: 50%; border-radius: 0 0 100% 0; background: darkblue; }
#bottomright.lit { background-color: lightskyblue; }

/* --- Título dentro do Círculo Central --- */
#title {
  font-family: 'Press Start 2P', cursive;
  position: absolute;
  top: 30px;
  left: 0;
  width: 100%;
  text-align: center;
  line-height: 1.3;
  pointer-events: none; /* Impede que o texto bloqueie cliques nos botões abaixo */
  z-index: 4; /* Garante que fique acima dos controles se houver sobreposição */
}
.geek-code-title { /* Fonte tradicional */
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-size: 11px;
  color: #f0f0f0;
  letter-spacing: 1px;
  margin-bottom: 6px;
  text-shadow: 1px 1px 1px rgba(0,0,0,0.6);
}
.genius-title { /* Fonte 'Press Start 2P' */
  font-size: 26px;
  color: white;
  text-shadow: 1px 1px 0px #ccc,
               2px 2px 0px #aaa,
               3px 3px 0px #888,
               4px 4px 3px rgba(0,0,0,0.6);
}

/* --- Controles (Power, Start, Contador) --- */
#switches {
  position: relative;
  margin-top: 50px; /* Posição vertical dos botões */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  z-index: 3; /* Fica acima do fundo do inner-circle, mas abaixo do título */
  gap: 15px; /* Espaçamento entre os botões */
}
#switches label {
  display: flex;
  flex-direction: column;
  align-items: center;
}
#switches label span { /* Texto "POWER" - Fonte tradicional */
  font-family: Arial, Helvetica, sans-serif;
  font-size: 0.7em;
  font-weight: bold;
  margin-top: 8px;
  color: #ddd;
  text-align: center;
  line-height: 1;
}
.toggle-button { /* Botão Power */
  width: 40px; height: 40px; border-radius: 50%; background-color: darkred;
  border: 2px solid #ccc; cursor: pointer; box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4);
  transition: all 0.1s ease; pointer-events: auto !important; /* Garante que seja clicável */
}
.toggle-button.active { /* Estilo do botão Power quando ligado */
  background-color: tomato; box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.6), inset 0 0 10px rgba(0, 0, 0, 0.4);
  border: 2px solid #888;
}
.toggle-button:active { /* Estilo do botão Power ao ser clicado */
  box-shadow: inset 2px 2px 5px rgba(0, 0, 0, 0.6); border: 2px solid #888;
}
.button#start { /* Botão Start */
  height: 40px; width: 85px; border-radius: 6px;
  font-family: Arial, Helvetica, sans-serif; /* Fonte tradicional */
  font-size: 0.9em; font-weight: bold; color: #ffffff;
  background-color: #006400; border: 1px solid #004d00;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.5), inset 0px 0px 2px rgba(255, 255, 255, 0.2);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  text-transform: uppercase; letter-spacing: 0.5px; padding: 0 5px; line-height: 1;
  /* Deslocamento vertical para cima (opcional, para alinhar visualmente) */
   transform: translateY(-11px);
}
.button#start:active { /* Estilo do botão Start ao ser clicado (sem transição para resposta imediata) */
  background-color: #008000; box-shadow: inset 1px 1px 3px rgba(0, 0, 0, 0.6);
}
.button#start:disabled { /* Estilo do botão Start quando desabilitado (sem transição) */
    background-color: #555; color: #999; cursor: not-allowed;
    box-shadow: inset 1px 1px 3px rgba(0, 0, 0, 0.4); border-color: #444;
}
#turn { /* Contador de turnos */
  position: absolute; background: #330000; color: red;
  font-family: 'Press Start 2P', cursive; font-size: 12px;
  height: 25px; width: 55px; left: 50%; transform: translateX(-50%);
  bottom: 10px; text-align: center; line-height: 25px; border-radius: 3px;
  border: 1px solid #5c0000; box-shadow: inset 0 0 3px rgba(0,0,0,0.5); z-index: 4; /* Acima de tudo no centro */
}

/* --- Placar (Scoreboard) --- */
#scoreboard {
  background-color: rgba(30, 30, 30, 0.85); border-radius: 8px; padding: 15px 20px;
  box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.5); font-family: 'Press Start 2P', cursive;
  color: #00ff00; width: 220px; flex-shrink: 0; border: 1px solid #003300;
  align-self: center; /* Centraliza verticalmente em relação ao container flex */
  margin-top: 20px; /* Espaço acima em telas maiores */
  margin-bottom: 20px; /* Espaço abaixo em telas maiores */
  box-sizing: border-box;
  max-height: 480px; /* Limita altura para evitar que fique muito grande */
  overflow-y: auto; /* Adiciona barra de rolagem se necessário */
}
#scoreboard h2 {
  font-size: 0.9em; margin-top: 0; margin-bottom: 15px; text-align: center;
  color: #33ff33; text-transform: uppercase; letter-spacing: 1px;
}
#scoreboard ol {
  padding-left: 0; list-style-position: inside; /* Marcadores dentro da caixa */
  margin-bottom: 0; font-size: 0.75em;
}
#scoreboard li {
  margin-bottom: 8px; border-bottom: 1px dashed #005000; padding-bottom: 5px;
}
 #scoreboard li:last-child { border-bottom: none; margin-bottom: 0; }

/* --- Media Queries (Responsividade) --- */
@media (max-width: 800px) {
     /* Ajusta layout para telas médias/tablets */
     #game-container {
        align-items: center; /* Centraliza itens verticalmente */
        padding-top: 20px; /* Espaço no topo */
        padding-bottom: 20px; /* Espaço abaixo */
        height: auto; /* Altura automática */
        min-height: 100vh; /* Garante que ocupe a tela toda */
     }
     #scoreboard {
        width: 80%; /* Largura relativa */
        max-width: 300px; /* Largura máxima */
        margin-top: 0; /* Remove margem superior extra */
        align-self: initial; /* Reset do alinhamento vertical */
        max-height: 200px; /* Altura máxima menor */
     }
}
@media (max-width: 540px) {
    /* Ajustes para telas menores (smartphones) */
    #outer-circle {
        border-width: 8px;
        width: 85vw; /* Largura baseada na viewport */
        height: 85vw; /* Altura baseada na viewport */
        max-width: 400px; /* Limite máximo */
        max-height: 400px; /* Limite máximo */
    }
    #inner-circle { border-width: 8px; }
    .quadrant { border-width: 5px; } /* Borda quadrante mais fina */
    #title { top: 20px; }
    .geek-code-title { font-size: 10px; margin-bottom: 4px;}
    .genius-title { font-size: 20px; }
    #switches {
        margin-top: 100px; /* Ajusta posição vertical dos controles */
        transform: scale(0.9); /* Reduz um pouco o tamanho dos controles */
        gap: 10px; /* Reduz espaço entre botões */
    }
    #switches label span { font-size: 0.6em; margin-top: 5px; }
    .button#start {
        font-size: 0.8em;
        width: 75px;
        /* transform: translateY(-8px); */ /* Ajuste opcional do deslocamento vertical */
    }
    #turn {
        bottom: 8px; font-size: 10px; width: 50px; height: 20px; line-height: 20px;
    }
    #scoreboard { padding: 10px 15px; max-height: 180px; }
    #scoreboard h2 { font-size: 0.8em; margin-bottom: 10px;}
    #scoreboard ol { font-size: 0.7em; }
    #scoreboard li { margin-bottom: 6px; padding-bottom: 4px;}
}
@media (max-width: 400px) {
    /* Ajustes finos para telas muito pequenas */
    #outer-circle { width: 90vw; height: 90vw; border-width: 6px;}
    #inner-circle { border-width: 6px; }
    .quadrant { border-width: 4px; } /* Borda quadrante mais fina */
    #title { top: 15px; }
    .geek-code-title { font-size: 9px; }
    .genius-title { font-size: 18px; }
    #switches {
        margin-top: 90px; /* Ajusta posição vertical */
        transform: scale(0.85); /* Reduz mais os controles */
    }
    #turn { font-size: 9px; width: 45px; height: 18px; line-height: 18px; }
    #scoreboard { width: 90%; max-height: 150px; }
}