/* Estilos inspirados na Netflix */

/* Resetador universal - Remove espaçamentos padrão do navegador */
* {
    margin: 0; /* Remove margem padrão de todos os elementos */
    padding: 0; /* Remove preenchimento padrão de todos os elementos */
    box-sizing: border-box; /* Inclui padding e border no cálculo de largura/altura */
}

/* Temas light/dark (CSS custom properties) */
:root {
    --background-color: #000000;
    --text-color: #ffffff;
    --primary-color: #E50914;
    --card-background: #141414;
    --card-border: rgba(255,255,255,0.08);
    --hover-card-border: rgba(255,255,255,0.5);
}

.light-mode {
    --background-color: #f3f3f3;
    --text-color: #111111;
    --primary-color: #e50914;
    --card-background: #ffffff;
    --card-border: rgba(0,0,0,0.08);
    --hover-card-border: rgba(0,0,0,0.4);
}

.dark-mode {
    --background-color: #000000;
    --text-color: #ffffff;
    --primary-color: #E50914;
    --card-background: #141414;
    --card-border: rgba(255,255,255,0.08);
    --hover-card-border: rgba(255,255,255,0.5);
}

/* Estilos do corpo da página */
body {
    background-color: var(--background-color); /* Fundo baseado em tema */
    color: var(--text-color); /* Texto baseado em tema */
    font-family: 'Arial', sans-serif; /* Fonte limpa e moderna */
    display: flex; /* Ativa layout flexível */
    flex-direction: column; /* Organiza elementos em coluna (vertical) */
    min-height: 100vh; /* Ocupa no mínimo a altura total da viewport */
}

/* Estilos do cabeçalho */
header {
    display: flex; /* Ativa layout flexível */
    justify-content: space-between; /* Exibe título e botão em lados opostos */
    align-items: center; /* Centraliza conteúdo verticalmente */
    padding: 20px; /* Espaçamento interno */
    background-color: var(--background-color); /* Fundo baseado no tema */
}

.theme-toggle {
    background: transparent;
    border: 2px solid var(--text-color);
    color: var(--text-color);
    font-size: 0.9rem;
    border-radius: 999px;
    padding: 8px 14px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.theme-toggle:hover,
.theme-toggle:focus {
    opacity: 0.8;
    outline: none;
}

/* Estilos do título do cabeçalho */
header h1 {
    font-size: 3.0rem; /* Tamanho grande e destacado */
    color: var(--primary-color); /* Vermelho Netflix - cor signature da marca */
    font-weight: bold; /* Texto em negrito para maior impacto */
}

/* Estilos da área principal */
main {
    flex: 1; /* Ocupa todo espaço vertical disponível */
    display: flex; /* Ativa layout flexível */
    flex-direction: column; /* Organiza elementos em coluna */
    align-items: center; /* Centraliza horizontalmente */
    justify-content: center; /* Centraliza verticalmente */
    padding: 40px 20px; /* Espaçamento interno (topo/baixo e lados) */
}

/* Estilos do subtítulo principal */
main h2 {
    font-size: 2.0rem; /* Tamanho de subtítulo */
    margin-bottom: 50px; /* Espaço abaixo do título antes dos perfis */
    text-align: center; /* Centraliza o texto */
}

/* Estilos do container de perfis */
.profiles {
    display: flex; /* Ativa layout flexível */
    flex-wrap: wrap; /* Permite que itens quebrem para próxima linha */
    justify-content: center; /* Centraliza itens horizontalmente */
    gap: 20px; /* Espaçamento entre itens */
    max-width: 800px; /* Limita a largura máxima do container */
    list-style: none; /* Remove marcadores padrão de lista */
}

/* Estilos de cada perfil */
.profile {
    display: flex; /* Ativa layout flexível */
    flex-direction: column; /* Organiza elementos em coluna */
    align-items: center; /* Centraliza os itens horizontalmente */
    cursor: pointer; /* Muda cursor para indicar que é clicável */
    transition: transform 0.3s ease, border-color 0.3s ease, background-color 0.3s ease;
    background: transparent;
    border: none;
    border-radius: 14px;
    padding: 10px;
}

.profile a {
    text-decoration: none; /* Remove sublinhado dos links */
    color: inherit; /* Herda a cor do texto */
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
}

.profile:hover {
    transform: scale(1.1);
    border-color: none;
}

/* Efeito ao passar o mouse no perfil */
.profile:hover {
    transform: scale(1.1); /* Aumenta o tamanho em 10% */
}

/* Estilos da imagem do perfil */
.profile img {
    width: 180px; /* Largura da imagem do perfil */
    height: 180px; /* Altura da imagem do perfil */
    border-radius: 12px; /* Cantos levemente arredondados */
    object-fit: cover; /* Preenchimento proporcionado da imagem */
    border: 3px solid transparent; /* Borda invisível (preparação para hover) */
    transition: border-color 0.3s ease; /* Animação suave na mudança de cor da borda */
}

/* Efeito ao passar o mouse na imagem */
.profile img:hover {
    border: 3px solid #fff; /* Adiciona uma borda branca ao passar o mouse */
}

/* Estilos do nome do perfil */
.profile p {
    margin-top: 15px; /* Espaço acima do texto do nome */
    font-size: 1.0rem; /* Tamanho padrão de texto */
    text-align: center; /* Centraliza o texto */
}

/* ========================================
   RESPONSIVIDADE - ABORDAGEM MOBILE FIRST
   ======================================== */

/* MOBILE - Extra pequeno (até 360px) */
@media (max-width: 360px) {
    header {
        padding: 15px 10px;
    }

    header h1 {
        font-size: 1.8rem;
    }

    main {
        padding: 20px 10px;
    }

    main h2 {
        font-size: 1rem;
        margin-bottom: 30px;
    }

    .profiles {
        gap: 25px;
        max-width: 100%;
    }

    .profile img {
        width: 80px;
        height: 80px;
    }

    .profile p {
        font-size: 0.85rem;
        margin-top: 10px;
    }
}

/* MOBILE - Pequeno (361px a 480px) */
@media (min-width: 361px) and (max-width: 480px) {
    header {
        padding: 15px 10px;
    }

    header h1 {
        font-size: 2rem;
    }

    main {
        padding: 25px 15px;
    }

    main h2 {
        font-size: 1.2rem;
        margin-bottom: 35px;
    }

    .profiles {
        gap: 25px;
        max-width: 100%;
    }

    .profile img {
        width: 100px;
        height: 100px;
    }

    .profile p {
        font-size: 0.9rem;
        margin-top: 12px;
    }
}

/* MOBILE - Médio (481px a 600px) */
@media (min-width: 481px) and (max-width: 600px) {
    header {
        padding: 20px 15px;
    }

    header h1 {
        font-size: 2.2rem;
    }

    main {

        padding: 30px 15px;
    }

    main h2 {
        font-size: 1.4rem;
        margin-bottom: 40px;
    }

    .profiles {
        gap: 30px;
        max-width: 500px;
    }

    .profile img {
        width: 110px;
        height: 110px;
    }

    .profile p {
        font-size: 0.95rem;
        margin-top: 12px;
    }
}

/* TABLET - Pequeno (601px a 768px) */
@media (min-width: 601px) and (max-width: 768px) {
    header {
        padding: 25px 20px;
    }

    header h1 {
        font-size: 2.5rem;
    }

    main {
        padding: 40px 20px;
    }

    main h2 {
        font-size: 1.6rem;
        margin-bottom: 45px;
    }

    .profiles {
        gap: 25px;
        max-width: 600px;
    }

    .profile img {
        width: 140px;
        height: 140px;
    }

    .profile p {
        font-size: 1rem;
        margin-top: 12px;
    }

    /* Grid de 2 colunas para tablets pequenos */
    .profiles {
        max-width: 100%;
        justify-content: space-around;
    }
}

/* TABLET - Grande (769px a 1024px) */
@media (min-width: 769px) and (max-width: 1024px) {
    header {
        padding: 30px 25px;
    }

    header h1 {
        font-size: 2.7rem;
    }

    main {
        padding: 50px 30px;
    }

    main h2 {
        font-size: 1.8rem;
        margin-bottom: 50px;
    }

    .profiles {
        gap: 30px;
        max-width: 750px;
    }

    .profile img {
        width: 160px;
        height: 160px;
    }

    .profile p {
        font-size: 1.05rem;
        margin-top: 15px;
    }

    .profile:hover {
        transform: scale(1.08);
    }
}

/* DESKTOP - Padrão (1025px em diante) */
@media (min-width: 1025px) {
    header {
        padding: 30px;
    }

    header h1 {
        font-size: 3rem;
    }

    main {
        padding: 60px 40px;
    }

    main h2 {
        font-size: 2rem;
        margin-bottom: 60px;
    }

    .profiles {
        gap: 30px;
        max-width: 900px;
    }

    .profile img {
        width: 180px;
        height: 180px;
    }

    .profile p {
        font-size: 1.1rem;
        margin-top: 15px;
    }

    .profile:hover {
        transform: scale(1.12);
    }
}

/* DESKTOP - Grande (1441px em diante) */
@media (min-width: 1441px) {
    main {
        padding: 80px 50px;
    }

    main h2 {
        font-size: 2.2rem;
        margin-bottom: 70px;
    }

    .profiles {
        gap: 25px;
        max-width: 1000px;
    }

    .profile img {
        width: 200px;
        height: 200px;
    }

    .profile p {
        font-size: 1.15rem;
    }
}

/* ========================================
   OTIMIZAÇÕES PARA DIFERENTES CONTEXTOS
   ======================================== */

/* Ajustes para modo paisagem em dispositivos móveis */
@media (max-height: 600px) and (orientation: landscape) {
    header {
        padding: 10px 20px;
    }

    header h1 {
        font-size: 1.8rem;
    }

    main {
        padding: 20px;
    }

    main h2 {
        margin-bottom: 20px;
    }

    .profiles {
        gap: 15px;
    }

    .profile img {
        width: 100px;
        height: 100px;
    }

    .profile p {
        margin-top: 8px;
        font-size: 0.85rem;
    }
}

/* Dispositivos com toque (remove :hover em mobile) */
@media (hover: none) and (pointer: coarse) {
    .profile:hover {
        transform: none;
    }

    .profile img:hover {
        border: 3px solid transparent;
    }

    /* Efeito ao clicar em dispositivos táteis */
    .profile:active {
        transform: scale(0.95);
    }

    .profile:active img {
        border: 3px solid #E50914;
    }
}

/* Suporte para telas com alta densidade de pixels (Retina) */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    body {
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }
}
