/* --- Variáveis de Cores Baseadas na Logo --- */
        :root {
            --azul-claro: #8CE0FA;
            --azul-escuro: #2D82B5;
            --preto-chumbo: #1A1A1A;
            --branco: #FFFFFF;
            --laranja-destaque: #FFA500;
            --verde-destaque: #28A745;
            --cinza-fundo: #F4F7F6;
        }

        /* --- Reset Básico --- */
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        }

        /* --- Configurações Globais da Página --- */
        html {
            scroll-behavior: smooth; /* Faz a tela deslizar suavemente em vez de "pular" direto */
            scroll-padding-top: 80px; /* Cria uma margem de segurança no topo do tamanho do seu menu */
        }

        body {
            background-color: var(--cinza-fundo);
            color: var(--preto-chumbo);
            line-height: 1.6;
        }

        /* --- Navegação e Menu Fixo --- */
        header {
            background-color: var(--preto-chumbo);
            color: var(--branco);
            padding: 1rem 5%;
            display: flex;
            justify-content: space-between;
            align-items: center;
            position: sticky; /* Faz o menu acompanhar a rolagem */
            top: 0; /* Prende o menu no topo da tela */
            z-index: 1000; /* Garante que o menu passe por cima de tudo */
            box-shadow: 0 2px 10px rgba(0,0,0,0.5); /* Adiciona uma sombra elegante */
        }

        @font-face {
            font-family: 'Sportsball';
            src: url('fonts/Sportsball.ttf') format('truetype'),
                 url('fonts/Sportsball.woff') format('woff');
            font-weight: normal;
            font-style: normal;
        }

        .logo {
            font-size: 100%;
            font-weight: bold;
            color: var(--branco);
            text-transform: uppercase;
            text-align: center;
            font-family: 'Sportsball', sans-serif;
        }
        
        .header-brand {
            display: flex;
            align-items: center;
            gap: 10px;
        }

        /* Esconde o ícone de menu no computador */
        .menu-toggle {
            display: none;
            font-size: 2rem;
            cursor: pointer;
            color: var(--azul-claro);
            user-select: none;
        }

        nav ul {
            list-style: none;
            display: flex;
            gap: 2rem;
        }

        nav a {
            color: var(--branco);
            text-decoration: none;
            font-weight: 500;
            transition: color 0.3s ease;
        }

        nav a:hover {
            color: var(--azul-claro);
        }

        /* --- Responsividade (Para Celulares e Tablets) --- */
        @media (max-width: 768px) {
            .menu-toggle {
                display: block; /* Mostra o ícone de menu no celular */
            }

            /* Configura o menu para virar uma lista vertical no celular */
            nav {
                display: none; /* Esconde o menu inicialmente no celular */
                position: absolute;
                top: 100%;
                left: 0;
                width: 100%;
                background-color: var(--preto-chumbo);
                box-shadow: 0 4px 6px rgba(0,0,0,0.3);
            }

            /* Classe que o JavaScript vai adicionar para mostrar o menu */
            nav.ativo {
                display: block; 
            }

            nav ul {
                flex-direction: column;
                gap: 0;
            }

            nav ul li {
                text-align: center;
                border-top: 1px solid rgba(255,255,255,0.1); /* Linha divisória entre os links */
            }

            nav ul li a {
                display: block;
                padding: 1.5rem; /* Aumenta a área de clique para o dedo */
            }

            /* Ajustes para o layout não quebrar no mobile */
            .sobre-container {
                flex-direction: column; /* Coloca a foto embaixo do texto no celular */
                text-align: center;
            }

            .hero h1 {
                font-size: 2.2rem; /* Diminui o título principal */
            }
        }

        /* --- Seção Hero (Destaque Inicial) --- */
        .hero {
            background: linear-gradient(135deg, var(--azul-claro) 0%, var(--azul-escuro) 100%);
            color: var(--preto-chumbo);
            text-align: center;
            padding: 5rem 1rem;
        }

        .hero h1 {
            font-size: 3rem;
            margin-bottom: 1rem;
            color: var(--branco);
        }

        .btn-agendar {
            display: inline-block;
            background-color: var(--verde-destaque);
            color: var(--branco);
            padding: 10px 25px;
            border-radius: 5px;
            text-decoration: none;
            font-weight: bold;
            margin-top: 1.5rem;
            transition: transform 0.2s ease;
        }

        .btn-agendar:hover {
            transform: scale(1.05);
        }

        /* --- Seção de Modalidades --- */
        .modalidades-container {
            padding: 4rem 5%;
            text-align: center;
        }

        .modalidades-grid {
            display: flex;
            justify-content: center;
            gap: 2rem;
            margin-top: 2rem;
            flex-wrap: wrap;
        }

        .card {
            background-color: var(--branco);
            border: 2px solid var(--preto-chumbo);
            border-radius: 10px;
            padding: 2rem;
            width: 300px;
            box-shadow: 0 4px 6px rgba(0,0,0,0.1);
        }

        .card h3 {
            color: var(--azul-escuro);
            margin-bottom: 1rem;
        }

        .modalidades-imagem {
            width: 100%;
            height: 250px;
            object-fit: cover;
            border-radius: 5px;
            margin-bottom: 1rem;
        }

        /* --- Seção de Turmas e Horários --- */
        .turmas-container {
            padding: 4rem 5%;
            background-color: var(--branco);
            text-align: center;
        }

        .turmas-container h2 {
            color: var(--azul-escuro);
            font-size: 2.5rem;
            margin-bottom: 0.5rem;
        }

        /* --- Wrapper das Tabelas --- */
        .tabelas-wrapper {
            display: flex;
            flex-wrap: wrap;
            gap: 2rem;
            justify-content: center;
            align-items: flex-start; /* Mágica 1: Impede que a tabela menor estique para baixo */
            margin-top: 3rem;
        }

        /* --- Container Individual de cada Tabela --- */
        .tabela-horarios {
            flex: 1;
            min-width: 320px;
            max-width: 800px; /* Mágica 2: Aumenta a largura máxima permitida no PC */
            background-color: var(--cinza-fundo);
            border-radius: 10px;
            overflow-x: auto; /* Adiciona barra de rolagem lateral no celular, se a tabela ficar muito larga */
            box-shadow: 0 4px 10px rgba(0,0,0,0.08);
        }

        .tabela-header {
            padding: 1.5rem;
            color: var(--branco);
        }

        .tabela-header.natacao {
            background-color: var(--azul-escuro);
        }

        .tabela-header.volei {
            background-color: var(--preto-chumbo);
        }

        .tabela-horarios table {
            width: 100%;
            border-collapse: collapse;
            text-align: left;
        }

        /* --- Células da Tabela --- */
        .tabela-horarios th, .tabela-horarios td {
            padding: 1rem;
            border-bottom: 1px solid #ddd;
            white-space: nowrap; /* Mágica 3: Força o texto de cada coluna a ficar em uma única linha */
        }

        .tabela-horarios th {
            background-color: #e9ecef;
            font-weight: 600;
            color: var(--preto-chumbo);
        }

        .tabela-horarios tbody tr:hover {
            background-color: rgba(140, 224, 250, 0.2); 
            transition: background-color 0.3s ease;
        }

        /* --- Footer / Localização --- */
        footer {
            background-color: var(--preto-chumbo);
            color: var(--branco);
            text-align: center;
            padding: 2rem 5%;
            margin-top: 2rem;
        }

        /* --- Seção de Agendamento --- */
        .agendamento-container {
            padding: 4rem 5%;
            background: linear-gradient(135deg, var(--azul-claro) 0%, var(--azul-escuro) 100%);
            text-align: center;
            color: var(--branco);
        }

        .agendamento-container h2 {
            font-size: 2.5rem;
            margin-bottom: 1rem;
        }

        .form-whatsapp {
            max-width: 500px;
            margin: 2rem auto 0;
            display: flex;
            flex-direction: column;
            gap: 1.2rem;
            background-color: var(--branco);
            padding: 2.5rem;
            border-radius: 10px;
            box-shadow: 0 8px 15px rgba(0,0,0,0.2);
        }

        .form-whatsapp input, 
        .form-whatsapp select {
            padding: 12px;
            border: 1px solid #ccc;
            border-radius: 5px;
            font-size: 1rem;
            color: var(--preto-chumbo);
            width: 100%;
        }

        .form-whatsapp input:focus, 
        .form-whatsapp select:focus {
            outline: none;
            border-color: var(--azul-escuro);
        }

        .form-whatsapp button {
            cursor: pointer;
            border: none;
            font-size: 1.1rem;
            width: 100%;
            margin-top: 0.5rem;
        }

        /* --- Mapa de Localização --- */
        .mapa-container {
            margin: 2rem auto 0;
            max-width: 800px; /* Mantém um tamanho bonito em monitores grandes */
            height: 350px;
            border-radius: 10px;
            overflow: hidden;
            box-shadow: 0 4px 8px rgba(0,0,0,0.3);
            border: 2px solid var(--azul-escuro);
        }
        
        .mapa-container iframe {
            width: 100%;
            height: 100%;
            border: 0;
        }
        /* --- Seção Sobre Nós --- */
        .sobre-container {
            padding: 4rem 5%;
            background-color: var(--branco);
            display: flex;
            align-items: center;
            gap: 3rem;
            flex-wrap: wrap;
        }

        .sobre-texto {
            flex: 1;
            min-width: 320px;
        }

        .sobre-texto h2 {
            color: var(--azul-escuro);
            font-size: 2.5rem;
            margin-bottom: 1rem;
        }

        .sobre-texto p {
            margin-bottom: 1rem;
            text-align: justify;
            font-size: 1.05rem;
        }

        /* --- Carrossel Unificado (PC e Mobile Sobre Nós) --- */
        .sobre-imagem {
            flex: 1;
            min-width: 320px;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .carrossel-container {
            position: relative;
            width: 100%;
            max-width: 450px;
            border-radius: 15px;
            overflow: hidden;
            box-shadow: 0 8px 15px rgba(0,0,0,0.1);
        }

        .carrossel-track {
            display: flex;
            overflow-x: auto;
            scroll-snap-type: x mandatory;
            scroll-behavior: smooth;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: none; 
            -ms-overflow-style: none; 
        }

        .carrossel-track::-webkit-scrollbar {
            display: none; 
        }

        .carrossel-track img {
            flex: 0 0 100%;
            width: 100%;
            aspect-ratio: 1 / 1;
            object-fit: cover; 
            scroll-snap-align: center;
        }

        /* --- ESTÉTICA UNIFICADA DOS BOTÕES (Sobre Nós e Avaliações) --- */
        .carrossel-container, .carrossel-avaliacoes-wrapper {
            position: relative; /* Mantém os botões presos dentro dos seus respetivos blocos */
        }

        .btn-carrossel {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            background-color: rgba(0, 0, 0, 0.3); /* Fundo Translúcido Fantasma */
            color: var(--branco);
            border: none;
            width: 45px;
            height: 45px;
            border-radius: 50%;
            font-size: 1.2rem;
            cursor: pointer;
            z-index: 10;
            display: flex;
            align-items: center;
            justify-content: center;
            box-shadow: 0 4px 6px rgba(0,0,0,0.1);
            transition: all 0.3s ease;
        }

        .btn-carrossel:hover {
            background-color: var(--azul-escuro); /* Fica azul apenas ao passar o rato */
            transform: translateY(-50%) scale(1.1);
            box-shadow: 0 4px 10px rgba(0,0,0,0.3);
        }

        .btn-carrossel.prev { left: 10px; }
        .btn-carrossel.next { right: 10px; }

        @media (max-width: 768px) {
            .btn-carrossel {
                width: 35px;
                height: 35px;
                font-size: 1rem;
            }
        }

        /* --- Seção de Avaliações Google --- */
        .avaliacoes-container {
            padding: 4rem 5%;
            background-color: var(--cinza-fundo);
            text-align: center;
        }

        .avaliacoes-container h2 {
            color: var(--azul-escuro);
            font-size: 2.5rem;
            margin-bottom: 0.5rem;
        }

        .carrossel-avaliacoes-wrapper {
            max-width: 1200px;
            margin: 2.5rem auto;
            padding: 0 60px;
        }

        .avaliacoes-grid {
            display: flex;
            gap: 1.5rem;
            margin: 0;
            overflow-x: auto;
            padding-bottom: 1rem;
            scroll-snap-type: x mandatory;
            scrollbar-width: none; 
            -ms-overflow-style: none;
        }

        .avaliacoes-grid::-webkit-scrollbar {
            display: none;
        }

        @media (max-width: 768px) {
            .carrossel-avaliacoes-wrapper { padding: 0; }
            .carrossel-avaliacoes-wrapper .btn-carrossel { display: none; }
        }

        .avaliacao-card {
            background: var(--branco);
            border-radius: 10px;
            padding: 1.8rem;
            min-width: 320px;
            max-width: 350px;
            text-align: left;
            box-shadow: 0 4px 10px rgba(0,0,0,0.06);
            border: 1px solid #eaeaea;
            scroll-snap-align: center;
            flex: 0 0 auto;
            display: flex;
            flex-direction: column;
        }

        .avaliacao-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            margin-bottom: 0.8rem;
        }

        .avaliador-info {
            display: flex;
            flex-direction: column;
        }

        .avaliador-nome { font-weight: bold; color: var(--preto-chumbo); font-size: 1.05rem; }
        .avaliador-data { font-size: 0.85rem; color: #777; margin-top: 2px; }
        
        .estrelas {
            color: #fbbc04;
            font-size: 1.3rem;
            margin-bottom: 1rem;
            letter-spacing: 2px;
        }

        .avaliacao-texto { font-size: 0.95rem; color: #555; line-height: 1.6; font-style: italic; }

        .btn-ver-mais-google {
            display: inline-block;
            background-color: var(--azul-escuro);
            color: var(--branco);
            padding: 12px 30px;
            border-radius: 5px;
            text-decoration: none;
            font-weight: bold;
            margin-top: 1.5rem;
            font-size: 1.1rem;
            transition: transform 0.3s ease, background-color 0.3s ease;
            box-shadow: 0 4px 6px rgba(0,0,0,0.1);
        }

        .btn-ver-mais-google:hover {
            background-color: var(--preto-chumbo);
            transform: scale(1.05);
        }

        /* --- Imagens dos Cards de Modalidades --- */
        .modalidades-imagem {
            width: 100%; max-width: 220px; height: auto;
            margin: 1rem auto; display: block; border-radius: 10px;
            image-rendering: -webkit-optimize-contrast; 
            image-rendering: crisp-edges;
            object-fit: contain; 
        }

        /* --- Ajuste da Tabela para Celulares --- */
        @media (max-width: 768px) {
            .tabela-horarios th, .tabela-horarios td {
                white-space: normal; padding: 0.6rem 0.3rem; font-size: 0.85rem; text-align: center; word-wrap: break-word;
            }
            .tabela-horarios { overflow-x: hidden; }
            .tabela-horarios table { table-layout: fixed; }
        }

        /* --- Botão Flutuante WhatsApp --- */
        .whatsapp-float {
            position: fixed; width: 60px; height: 60px; bottom: 30px; right: 30px;
            background-color: #25d366; border-radius: 50px; box-shadow: 2px 4px 10px rgba(0,0,0,0.3);
            z-index: 1000; display: flex; justify-content: center; align-items: center;
            transition: transform 0.3s ease, box-shadow 0.3s ease; overflow: hidden;
        }

        .whatsapp-float:hover { transform: scale(1.1); box-shadow: 3px 6px 15px rgba(0,0,0,0.4); }
        .whatsapp-float img { width: 60%; height: auto; display: block; }

        @media (max-width: 768px) {
            .whatsapp-float { bottom: 20px; right: 20px; width: 55px; height: 55px; }
        }