/* ==========================================================================
   CONFIGURAÇÕES INICIAIS E VARIÁVEIS
   ========================================================================== */

/* Cores do site */
:root {
    --cor-fundo: #f3f4f6;
    --cor-superficie: #e4e9ea;
    --cor-primaria: #2563eb;
    --cor-primaria-hover: #1d4ed8;
    --cor-texto: #1f2937;
    --cor-texto-suave: #6b7280;
    --cor-borda: #becadf;
    --cor-perigo: #dc2626;
    --sombra: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --raio: 10px;
}

/* Cores pro modo escuro - basicamente troca o fundo claro pelo escuro */
body.modo-escuro {
    --cor-fundo: #111827;
    --cor-superficie: #1f2937;
    --cor-texto: #f9fafb;
    --cor-texto-suave: #9ca3af;
    --cor-borda: #374151;
}

/* Reset básico pra zerar as margens que o navegador coloca por padrão */
* { 
    margin: 0;
    padding: 0; 
    box-sizing: border-box; 
    font-family: 'Segoe UI', system-ui, sans-serif; 
}

/* O body agora é um 'flex container' vertical. 
   O min-height: 100vh garante que ele sempre tenha o tamanho da tela,
   fazendo o rodapé ficar no lugar certo mesmo com a lista vazia.
*/
body { 
    background-color: var(--cor-fundo); 
    color: var(--cor-texto); 
    line-height: 1.6; 
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    margin: 0;
    justify-content: flex-start;
}

/* ==========================================================================
   LAYOUT E CONTAINERS
   ========================================================================== */

/* Limita a largura do conteúdo pra não ficar esticado demais em telas grandes */
.container { 
    max-width: 1200px; 
    margin: 0 auto; 
    padding: 0 1.5rem; 
    width: 100%;
}

/* O main funciona como uma mola (flex: 1). Ele ocupa todo o espaço que sobra 
   e empurra o footer lá pra baixo sem bagunçar os elementos internos. 
*/
main {
    flex: 1;
    display: flex;
    flex-direction: column; /* Força os filhos a ficarem um embaixo do outro */
    align-items: stretch;   /* Garante que os elementos ocupem a largura do container */
}

/* Barra de navegação superior */
.navbar { 
    background: var(--cor-superficie); 
    box-shadow: var(--sombra); 
    padding: 1rem 0; 
    margin-bottom: 2rem; 
}

/* Alinha o título de um lado e o painel de controle do outro */
.nav-content { 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    flex-wrap: wrap; 
    gap: 1rem; 
}

/* Agrupa o total de horas e o switch de tema */
.nav-painel { 
    display: flex; 
    gap: 1rem; 
    align-items: center; 
}

/* Barra de ferramentas abaixo do título principal */
.toolbar { 
    display: flex; 
    justify-content: space-between; /* Título de um lado, botões do outro */
    align-items: center; 
    margin-bottom: 2rem; 
    width: 100%;
}

.toolbar .nav-painel {
    display: flex;
    gap: 1rem;
    align-items: center;
}
/* ==========================================================================
   COMPONENTES (BOTÕES, INPUTS E BADGES)
   ========================================================================== */

/* Estilização geral dos botões */
.btn { 
    padding: 0.6rem 1.2rem; 
    border: none; 
    border-radius: 6px; 
    cursor: pointer; 
    font-weight: 600; 
    transition: all 0.2s; 
}

.btn-primario { 
    background: var(--cor-primaria); 
    color: white; 
}

.btn-primario:hover { 
    background: var(--cor-primaria-hover); 
    transform: translateY(-1px); 
}

/* Botão vazado usado para registrar horas */
.btn-outline { 
    background: transparent; 
    border: 1px solid var(--cor-borda); 
    color: var(--cor-texto); 
}

.btn-outline:hover { 
    border-color: var(--cor-primaria); 
    color: var(--cor-primaria); 
}

/* Classe utilitária pra ocupar a largura toda do card */
.w-100 { 
    width: 100%; 
}

/* Campo de busca com cantos arredondados */
#input-busca { 
    padding: 0.5rem 1rem; 
    border: 1px solid var(--cor-borda); 
    border-radius: 20px; 
    outline: none; 
    transition: border-color 0.3s; 
}

#input-busca:focus { 
    border-color: var(--cor-primaria); 
}

/* Badge que mostra o total de horas estudadas no topo */
.stats-badge { 
    background: #afc4df; 
    color: #1e40af; 
    padding: 0.5rem 1rem; 
    border-radius: 20px; 
    font-weight: 500; 
    font-size: 0.9rem; 
}

/* ==========================================================================
   GRID E CARDS DE DISCIPLINAS
   ========================================================================== */

/* Organiza os cards em grade que se ajusta sozinha conforme o tamanho da tela */
.grade-cards { 
    display: grid; 
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); 
    gap: 1.5rem; 
}

/* Estilo de cada card de matéria */
.card { 
    background: var(--cor-superficie); 
    border-radius: var(--raio); 
    padding: 1.5rem; 
    box-shadow: var(--sombra); 
    display: flex; 
    flex-direction: column; 
    position: relative; 
    overflow: hidden; 
}

/* Barrinha de progresso que fica no topo do card */
.card-indicador { 
    position: absolute; 
    top: 0; 
    left: 0; 
    height: 4px; 
    background: var(--cor-primaria); 
    transition: width 0.5s ease; 
}

/* Alinha a tag da área e os botões de ação (editar/excluir) */
.card-cabecalho { 
    display: flex; 
    justify-content: space-between; 
    align-items: flex-start; 
    margin-bottom: 1rem; 
    margin-top: 0.5rem; 
}

/* Etiqueta pequena com o nome da área (Exatas, Humanas, etc) */
.tag-area { 
    font-size: 0.75rem; 
    font-weight: bold; 
    text-transform: uppercase; 
    background: var(--cor-fundo); 
    padding: 0.3rem 0.6rem; 
    border-radius: 4px; 
    color: var(--cor-texto-suave); 
}

/* Estilo dos ícones de editar e excluir dentro do card */
.acoes-card button { 
    background: none; 
    border: none; 
    font-size: 1.1rem; 
    cursor: pointer; 
    margin-left: 0.5rem; 
    color: var(--cor-texto-suave); 
    transition: color 0.2s; 
}

.acoes-card .btn-editar:hover { color: var(--cor-primaria); }
.acoes-card .btn-excluir:hover { color: var(--cor-perigo); }

/* Informações de texto dentro do card */
.card-info h3 { font-size: 1.25rem; margin-bottom: 0.2rem; }
.card-info p { color: var(--cor-texto-suave); font-size: 0.9rem; margin-bottom: 1rem; }

/* Texto que mostra as horas e a porcentagem embaixo */
.progresso-texto { 
    display: flex; 
    justify-content: space-between; 
    font-size: 0.85rem; 
    margin-bottom: 1.5rem; 
    font-weight: 500; 
}

/* ==========================================================================
   MODAL (FORMULÁRIO DE CADASTRO)
   ========================================================================== */

/* A janela que abre por cima pra cadastrar/editar */
dialog { 
    margin: auto; 
    border: none; 
    border-radius: var(--raio); 
    padding: 2rem; 
    width: 90%; 
    max-width: 500px; 
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.2); 
    background: var(--cor-superficie);
    color: var(--cor-texto);
}

/* Escurece o fundo quando o modal tá aberto */
dialog::backdrop { 
    background: rgba(0,0,0,0.5); 
    backdrop-filter: blur(3px); 
}

.modal-cabecalho { 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    margin-bottom: 1.5rem; 
}

/* Botão de X pra fechar o modal */
.btn-fechar { 
    background: none; 
    border: none; 
    font-size: 1.8rem; 
    cursor: pointer; 
    color: var(--cor-texto-suave); 
}

/* Organização dos labels e campos do formulário */
.grupo-input { 
    display: flex; 
    flex-direction: column; 
    gap: 0.4rem; 
    margin-bottom: 1rem; 
}

.linha-inputs { 
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: 1rem; 
}

label { font-size: 0.9rem; font-weight: 500; }

input, select { 
    padding: 0.6rem; 
    border: 1px solid var(--cor-borda); 
    border-radius: 6px; 
    outline: none; 
    background: var(--cor-superficie);
    color: var(--cor-texto);
}

input:focus, select:focus { 
    border-color: var(--cor-primaria); 
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1); 
}

/* Diz para o modal usar a animação suave toda vez que for aberto */
dialog[open] { 
    animation: fadeIn 0.4s ease-out forwards; 
}

/* Faz o fundo escuro aparecer suavemente, em vez de piscar na tela */
dialog[open]::backdrop {
    animation: escurecerFundo 0.4s ease-out forwards;
}

/* animação só pro fundo escuro não usar o movimento de subidinha do fadeIn */
@keyframes escurecerFundo {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* ==========================================================================
   ESTADOS VAZIOS E ANIMAÇÕES
   ========================================================================== */

/* Mensagem que aparece quando não tem nada cadastrado */
.estado-vazio { 
    text-align: center; 
    padding: 5rem 0; 
    color: var(--cor-texto-suave); 
    display: flex;
    flex-direction: column;
    align-items: center; /* Centraliza o ícone e o texto horizontalmente */
    justify-content: center;
    width: 100%;
}

.icone-vazio { 
    font-size: 4rem; 
    margin-bottom: 1rem; 
    opacity: 0.5; 
}

/* Classe pra sumir com elementos via JavaScript */
.escondido { display: none !important; }

/* Animação suave pros cards aparecerem na tela */
@keyframes fadeIn { 
    from { opacity: 0; transform: translateY(600px); } 
    to { opacity: 1; transform: translateY(0); } 
}

/* Animação suave de modais e cards */
.animacao-entrada {
    animation: fadeIn 0.8s ease-out forwards; 
}

/* ==========================================================================
   SWITCH DE TEMA (MODO ESCURO)
   ========================================================================== */

/* Container do interruptor */
.switch-tema { 
    position: relative; 
    display: inline-block; 
    width: 60px; 
    height: 30px; 
    margin-left: 10px; 
}

.switch-tema input { opacity: 0; width: 0; height: 0; }

/* O fundo do switch */
.slider-tema { 
    position: absolute; 
    cursor: pointer; 
    top: 0; left: 0; right: 0; bottom: 0; 
    background-color: #cbd5e1; 
    transition: .4s; 
    border-radius: 30px; 
}

/* A bolinha branca que desliza */
.slider-tema:before { 
    position: absolute; 
    content: ""; 
    height: 22px; width: 22px; 
    left: 4px; bottom: 4px; 
    background-color: white; 
    transition: .4s; 
    border-radius: 50%; 
    z-index: 2; 
    box-shadow: 0 2px 4px rgba(0,0,0,0.2); 
}

.switch-tema input:checked + .slider-tema { background-color: var(--cor-primaria); }
.switch-tema input:checked + .slider-tema:before { transform: translateX(30px); }

/* Posicionamento dos emojis de Sol e Lua */
.switch-tema .icone { 
    position: absolute; 
    top: 50%; 
    transform: translateY(-50%); 
    font-size: 14px; 
    z-index: 1; 
    user-select: none; 
}

.switch-tema .sol { right: 8px; }
.switch-tema .lua { left: 8px; }

/* ==========================================================================
   RODAPÉ (FOOTER)
   ========================================================================== */

/* Configuração do rodapé de identificação. 
   O 'margin-top: 2rem' dá um respiro pros cards não colarem nele.
*/
.rodape-autor { 
    text-align: center; 
    padding: 1.5rem 1rem; 
    margin-top: 2rem; 
    color: var(--cor-texto-suave); 
    border-top: 1px solid var(--cor-borda); 
    font-size: 0.85rem; 
    font-weight: 500;
    background: var(--cor-superficie);
}

/* ==========================================================================
   RESPONSIVIDADE
   ========================================================================== */

@media (max-width: 768px) {
    /* Centraliza os elementos do cabeçalho */
    .nav-content {
        justify-content: center;
        text-align: center;
    }

    /* Muda a toolbar de linha pra coluna */
    .toolbar {
        flex-direction: column;
        align-items: stretch; /* Faz os elementos esticarem até as bordas */
        gap: 1rem;
        text-align: center;
    }

    /* Faz a barra de busca e o botão empilharem e ocuparem 100% da tela */
    .toolbar .nav-painel {
        flex-direction: column;
        width: 100%;
    }

    /* Ajusta o tamanho dos inputs e botões para ficarem melhores para o toque */
    .toolbar #input-busca,
    .toolbar .btn {
        width: 100%;
    }

    /* Reduz um pouco as margens do estado vazio para caber melhor na tela */
    .estado-vazio {
        padding: 3rem 1rem;
    }
}