/* Reset básico - Remove margens e preenchimentos padrão de todos os elementos e define box-sizing para border-box */
* {
    margin: 0;
    /* Remove margem externa */
    padding: 0;
    /* Remove preenchimento interno */
    box-sizing: border-box;
    /* Inclui bordas e preenchimento na largura/altura total */
}

/* Corpo da página - Define estilos globais para o body */
body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    /* Define a família de fontes, priorizando Helvetica Neue */
    background-color: #000;
    /* Define o fundo como preto */
    color: #fff;
    /* Define a cor do texto como branco */
    height: 100vh;
    /* Define a altura como 100% da altura da viewport */
    display: flex;
    /* Usa flexbox para layout */
    flex-direction: column;
    /* Organiza os filhos em coluna */
    justify-content: center;
    /* Centraliza verticalmente */
    align-items: center;
    /* Centraliza horizontalmente */
    overflow: hidden;
    /* Esconde qualquer conteúdo que exceda o limite */
}

/* Header - Estilos para o cabeçalho *//*
  O elemento <header> agrupa o título e botão de troca de tema.
  text-align:center mantém o conteúdo centralizado na tela.
*/header {
    text-align: center;
    /* Centraliza o texto */
    margin-bottom: 50px;
    /* Adiciona margem inferior de 50px */
}

header h1 {
    font-size: 3rem;
    /* Define o tamanho da fonte como 3rem (48px) */
    font-weight: 300;
    /* Define o peso da fonte como leve (300) */
    letter-spacing: 0.1em;
    /* Adiciona espaçamento entre letras de 0.1em */
}

/* Main - Estilos para o conteúdo principal */
/*
  O <main> define a área principal do app.
  largura responsiva com max-width evita estender demais.
*/
main {
    width: 100%;
    /* Define a largura como 100% do pai */
    max-width: 1200px;
    /* Limita a largura máxima a 1200px */
    padding: 0 20px;
    /* Adiciona preenchimento lateral de 20px */
}

/* Light mode */
/*
  Esta classe é aplicada dinamicamente pelo JS quando o usuário escolhe tema claro.
  - Ajusta cores de fundo/texto para visual claro.
  - Modifica botão para ficar legível em fundo claro.
*/
body.light-mode {
    background-color: #f4f4f4;
    color: #111;
}

body.light-mode .profile img {
    border-color: transparent;
}

body.light-mode header h1,
body.light-mode .profile figcaption {
    color: #fff;
    /* Mantém os nomes dos perfis brancos mesmo no modo claro */
}

body.light-mode button#theme-toggle {
    background-color: #111;
    color: #fff;
}

/* Estilo do botão de alternância de tema (sempre presente) */
button#theme-toggle {
    position: fixed;
    top: 16px;
    right: 16px;
    padding: 8px 14px;
    border: 1px solid #fff;
    background-color: rgba(0, 0, 0, 0.4);
    color: #fff;
    border-radius: 6px;
    cursor: pointer;
    font-size: 1.2rem;
    line-height: 1;
    z-index: 999;
}

body.light-mode button#theme-toggle {
    background-color: rgba(255, 255, 255, 0.8);
    color: #111;
}

/* Ajusta borda para contraste em modo claro */
body.light-mode button#theme-toggle {
    border: 1px solid #111;
}

/* Estilo do rodapé fixo */
.page-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    color: #fff;
    text-align: center;
    padding: 8px 0;
    font-size: 0.9rem;
    z-index: 900;
}

body.light-mode .page-footer {
    background-color: rgba(255, 255, 255, 0.8);
    color: #111;
}
.profiles ul {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 30px;
    list-style: none;
    padding: 0;
    margin: 0 auto;
    width: 100%;
    max-width: 900px;
}

.profiles ul li {
    list-style: none;
    padding: 0;
    margin: 0;
}

.profile {
    text-align: center;
    /* Centraliza o texto */
    cursor: pointer;
    /* Muda o cursor para pointer ao passar o mouse */
    transition: transform 0.3s ease;
    /* Adiciona transição suave para transformações */
}
/* Perfil individual - Estilos para cada perfil */
.profile {
    text-align: center;
    /* Centraliza o texto */
    cursor: pointer;
    /* Muda o cursor para pointer ao passar o mouse */
    transition: transform 0.3s ease;
    /* Adiciona transição suave para transformações */
}

.profile:hover {
    transform: scale(1.1);
    /* Aumenta o tamanho em 10% ao passar o mouse */
}

.perfil {
    text-decoration: none;
    /* Remove o underline dos links dos perfis */
}

.profile figure {
    margin: 0;
    /* Remove margem */
}

.profile img {
    width: 150px;
    /* Define a largura como 150px */
    height: 150px;
    /* Define a altura como 150px */
    border-radius: 10px;
    /* Arredonda os cantos da borda em 10px */
    object-fit: cover;
    /* Corta a imagem para cobrir o espaço sem distorcer */
    border: 3px solid transparent;
    /* Adiciona borda transparente de 3px */
    transition: border-color 0.3s ease;
    /* Adiciona transição suave para a cor da borda */
}

.profile:hover img {
    border-color: #fff;
    /* Muda a cor da borda para branco ao passar o mouse */
}

.profile figcaption {
    margin-top: 10px;
    /* Adiciona margem superior de 10px */
    font-size: 1.2rem;
    /* Define o tamanho da fonte como 1.2rem (19.2px) */
    font-weight: 400;
    /* Define o peso da fonte como normal (400) */
    color: #fff;
    /* Define a cor do texto como branca */
}

/* Botão Gerenciar Perfis - Estilo para o botão abaixo dos perfis */
#gerenciar-perfis {
    display: block;
    /* Faz o botão ocupar uma linha própria */
    margin: 40px auto 0;
    /* Centraliza horizontalmente e adiciona margem superior maior para espaçamento */
    padding: 12px 24px;
    /* Adiciona preenchimento interno */
    background-color: rgba(255, 255, 255, 0.1);
    /* Fundo semi-transparente */
    color: #fff;
    /* Cor do texto branca */
    border: 1px solid #fff;
    /* Borda branca */
    border-radius: 6px;
    /* Cantos arredondados */
    font-size: 1rem;
    /* Tamanho da fonte */
    cursor: pointer;
    /* Cursor de ponteiro */
    transition: background-color 0.3s ease, transform 0.3s ease;
    /* Transições suaves */
    text-decoration: none;
    /* Remove qualquer decoração de texto, embora botões não tenham underline */
}

#gerenciar-perfis:hover {
    background-color: rgba(255, 255, 255, 0.2);
    /* Fundo mais claro ao passar o mouse */
    transform: scale(1.05);
    /* Leve aumento ao passar o mouse */
}

body.light-mode #gerenciar-perfis {
    background-color: rgba(0, 0, 0, 0.1);
    /* Fundo escuro no modo claro */
    color: #111;
    /* Texto escuro */
    border-color: #111;
    /* Borda escura */
}

body.light-mode #gerenciar-perfis:hover {
    background-color: rgba(0, 0, 0, 0.2);
    /* Fundo mais escuro ao passar o mouse no modo claro */
}

/* Responsividade - Estilos para tablets (médio) */
@media (max-width: 1024px) {
    main {
        padding: 0 15px;
    }

    .profiles {
        gap: 25px;
    }

    .profile img {
        width: 140px;
        height: 140px;
    }

    header h1 {
        font-size: 2.5rem;
    }
}

/* Responsividade - Estilos para smartphones (pequeno) */
@media (max-width: 768px) {
    header {
        margin-top: 25px;
        margin-bottom: 35px;
    }

    header h1 {
        font-size: 2rem;
        /* Reduz o tamanho da fonte para 2rem em telas menores */
    }

    .profiles {
        display: block;
        width: 100%;
    }

    .profiles ul {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        justify-items: center;
        gap: 20px;
        width: 100%;
        padding: 0;
        margin: 0 auto;
    }

    .profiles ul li.profile {
        width: 100%;
        max-width: 180px;
    }

    .profile img {
        width: 120px;
        /* Reduz a largura para 120px em telas menores */
        height: 120px;
        /* Reduz a altura para 120px em telas menores */
    }

    .profile figcaption {
        font-size: 1rem;
    }

    #gerenciar-perfis {
        margin: 25px auto 0;
        padding: 10px 20px;
        font-size: 0.9rem;
    }

/* Tela maior que 900px: perfis em linha horizontal */
@media (min-width: 901px) {
    .profiles ul {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 30px;
    }
    .profiles {
        display: flex;
    }
}
/* Responsividade - Estilos para celulares pequenos e retrato */
@media (max-width: 480px) {
    body {
        justify-content: center;
        padding-top: 15px;
    }

    main {
        max-width: 100%;
        padding: 0 8px;
    }

    header {
        margin-top: 10px;
        margin-bottom: 20px;
    }

    .profiles {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        justify-items: center;
        gap: 15px;
    }

    .profile img {
        width: 100px;
        height: 100px;
    }

    .profile figcaption {
        font-size: 0.95rem;
    }

    #gerenciar-perfis {
        margin: 20px auto 0;
        padding: 8px 16px;
        font-size: 0.8rem;
    }

    header h1 {
        font-size: 1.5rem;
    }
}

