:root {
  --red: #C82020;
  --gold: #D4B26A;
  --dark: #151515;
  --gray: #5C5C5C;
  --soft: #F4F4F4;
}

* {
  box-sizing: border-box;
}

body {
  font-family: "Poppins", sans-serif;
  background: #ffffff;
  color: var(--dark);
  scroll-behavior: smooth;
}

/* ============================
   NAVBAR PREMIUM
============================ */
.navbar {
  background: rgba(255, 255, 255, 0.85);
  padding: 0.9rem 0.75rem;
  backdrop-filter: blur(12px);     /* efeito vidro fosco */
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 4px 22px rgba(0,0,0,0.04);
  position: sticky;
  top: 0;
  z-index: 1000;
  transition: all 0.25s ease;
}

/* Efeito ao rolar — navbar mais sólida */
.navbar.scrolled {
  background: rgba(255, 255, 255, 0.96);
  padding: 0.55rem 0.75rem;
  box-shadow: 0 8px 30px rgba(0,0,0,0.08);
}

/* Logo */
.navbar-brand img {
  height: 64px;
  transition: 0.25s;
}

.navbar.scrolled .navbar-brand img {
  height: 58px;
}

/* Links */
.nav-link {
  font-weight: 500;
  margin-left: 1rem;
  color: var(--dark);
  font-size: 0.95rem;
  padding: 0.5rem 0.2rem;
  transition: 0.25s ease;
}

.nav-link:hover {
  color: var(--red);
  transform: translateY(-2px);   /* efeito suave */
}

.nav-link:active {
  transform: scale(0.96);
  color: var(--red);
}

/* Link ativo */
.nav-link.active {
  color: var(--red);
  position: relative;
}

.nav-link.active::after {
  content: "";
  width: 6px;
  height: 6px;
  background: var(--red);
  border-radius: 50%;
  position: absolute;
  bottom: -4px;
  left: 50%;
  transform: translateX(-50%);
}

/* BOTÃO WHATS — PADRÃO */
.btn-nav-whats {
  background: var(--red);
  color: #fff !important;
  padding: 0.4rem 1.1rem;
  border-radius: 999px;
  font-weight: 600;
  margin-left: 1rem;
  font-size: 0.85rem;
  border: 2px solid var(--red); /* IMPORTANTE */
  box-shadow: 0 12px 28px rgba(200, 32, 32, 0.35);
  text-decoration: none !important;
  transition: .25s ease;
}

/* HOVER – APENAS LEVE ESCURECIDA */
.btn-nav-whats:hover {
  background: #a21818;
  color: #fff !important;
}

/* ACTIVE / SELECTED / FOCUS – FUNDO BRANCO E TEXTO VERMELHO */
.btn-nav-whats:active,
.btn-nav-whats:focus,
.btn-nav-whats.selected {
  background: #fff !important;
  color: var(--red) !important;
  border-color: var(--red) !important;
  transform: scale(0.96);
  box-shadow: 0 6px 14px rgba(200, 32, 32, 0.20);
  outline: none !important;
}


/* ============================
   HERO
============================ */

.hero {
  width: 100%;
  display: flex;
  align-items: center;
}



.hero h1 {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

.hero h1 span {
  color: var(--gold);
}

.hero p {
  font-size: 1.1rem;
  max-width: 540px;
  opacity: 0.96;
  margin-top: 0.6rem;
}

.btn-hero-main {
  background: var(--red);
  color: #fff;
  padding: 0.9rem 2.4rem;
  border-radius: 999px;
  font-weight: 600;
  margin-right: 12px;
  box-shadow: 0 18px 40px rgba(200, 32, 32, 0.4);
  border: none;
  font-size: 1rem;
  text-decoration: none !important;

}

.btn-hero-main:hover {
  background: #9d1515;
  color: #fff;
  text-decoration: none !important;

}

.btn-hero-ghost {
  border: 2px solid #fff;
  padding: 0.9rem 2.4rem;
  border-radius: 999px;
  color: #fff;
  font-weight: 600;
  background: transparent;
  font-size: 1rem;
      text-decoration: none !important;
}

/* ============================
   SECTION TITLES
============================ */
.section-tag {
  color: var(--red);
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-size: 0.85rem;
}

.section-title {
  font-weight: 700;
  font-size: 2.1rem;
}

.section-sub {
  color: var(--gray);
  max-width: 640px;
  margin: 0.5rem auto 0;
  font-size: 0.98rem;
}

/* ============================
   QUEM SOMOS
============================ */
.about-text {
  color: var(--gray);
  font-size: 1.02rem;
  line-height: 1.7;
}

.about-box {
  background: #ffffff;
  border-radius: 18px;
  padding: 1.8rem;
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08);
  border-left: 5px solid var(--gold);
  margin-top: 1.5rem;
}

.about-img-wrapper {
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.16);
}

.about-img-wrapper img {
  width: 100%;
  height: 380px;
  object-fit: cover;
}

/* ============================
   YOUTUBE
============================ */


.yt-card {
  border-radius: 16px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: #000;
  box-shadow: 0 18px 40px rgba(0,0,0,0.15);
  transition: .3s ease;
}

.yt-thumb {
  width: 100%;
  height: 220px;
  object-fit: cover;
  transition: .3s ease;
}

.yt-card:hover .yt-thumb {
  transform: scale(1.05);
  opacity: .85;
}

.yt-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: .3s ease;
}

.yt-card:hover .yt-overlay {
  opacity: 1;
}

.yt-play {
  font-size: 3rem;
  color: var(--gold);
  text-shadow: 0 4px 10px rgba(0,0,0,0.5);
}

@media (max-width: 768px) {
  .yt-thumb { height: 180px; }
}




/* ============================
   MODALIDADES
============================ */
.modalidades {
  background: var(--soft);
}

.mod-card {
  height: 260px;
  background-size: cover;
  background-position: center;
  border-radius: 20px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: 1.4rem;
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.15);
  transform: translateY(0);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border 0.3s ease;
  border: 2px solid transparent;
}

.mod-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.15));
  transition: background 0.3s ease;
}

.mod-card span {
  position: relative;
  z-index: 2;
  color: #fff;
  font-weight: 600;
  font-size: 1.2rem;
}

.mod-card:hover {
  transform: translateY(-6px) scale(1.03);

  box-shadow: 0 24px 55px rgba(0, 0, 0, 0.25);
  border-color: var(--gold);
}

.mod-card:hover::after {
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.2));
}

/* ============================
   ESTRUTURA
============================ */
.estrutura-box {
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.15);
  background: #FFF;
}

.estrutura-box img {
  width: 100%;
  height: 430px;
  object-fit: cover;
  opacity: 0.92;
}

.estrutura-box-inner {
  padding: 2rem 2.5rem;
  background: #ffffff;
}

/* ============================
   EQUIPE
============================ */
.team-large,
.team-small {
  background: #ffffff;
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.15);
  border: 3px solid var(--gold);
}

.team-large img {
  width: 100%;
  height: 340px;
  object-fit: cover;
}

.team-large-body {
  padding: 1.6rem 1.8rem 1.8rem;
}

.team-large-body h3 {
  font-weight: 700;
  margin-bottom: 0.3rem;
}

.team-large-body span {
  color: var(--red);
  font-weight: 600;
  font-size: 0.94rem;
}

.team-large-body p {
  color: var(--gray);
  margin-top: 0.7rem;
  font-size: 0.95rem;
}

.team-small img {
  width: 100%;
  height: 180px;
  object-fit: cover;
}

.team-small-body {
  padding: 1rem 1rem 1.4rem;
  text-align: center;
}

.team-small-body h5 {
  font-weight: 700;
  margin-top: 0.8rem;
  margin-bottom: 0.2rem;
}

.team-small-body span {
  color: var(--red);
  font-weight: 600;
  font-size: 0.92rem;
}

.team-small-body p {
  color: var(--gray);
  font-size: 0.9rem;
  margin-top: 0.4rem;
}

/* ============================
   DIFERENCIAIS
============================ */
.diff-card {
  background: #ffffff;
  border-radius: 18px;
  padding: 1.8rem 1.5rem;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.10);
  text-align: center;
  height: 100%;
}

.diff-icon {
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(212, 178, 106, 0.16);
  color: var(--red);
  margin-bottom: 0.8rem;
  font-size: 1.2rem;
}

.diff-card h5 {
  font-weight: 700;
  font-size: 1.05rem;
  margin-bottom: 0.4rem;
}

.diff-card p {
  color: var(--gray);
  font-size: 0.9rem;
}

/* ============================
   ATLETAS DESTAQUE
============================ */
.atl-card {
  height: 300px;
  border-radius: 20px;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.18);
  display: flex;
  align-items: flex-end;
  padding: 1.4rem;
  color: #fff;
}

.atl-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.2));
}

.atl-content {
  position: relative;
  z-index: 2;
}

.atl-name {
  font-weight: 700;
  font-size: 1.1rem;
}

.atl-role {
  font-size: 0.9rem;
  opacity: 0.9;
}

/* ============================
   FORMULÁRIO
============================ */
.form-card {
  background: #ffffff;
  border-radius: 24px;
  padding: 2.4rem 2.3rem;
  box-shadow: 0 25px 55px rgba(0, 0, 0, 0.12);
  border: 1px solid rgba(0, 0, 0, 0.05);
}

.form-card .form-control,
.form-card .form-select {
  border-radius: 14px;
  padding: 0.75rem;
  font-size: 0.95rem;
}

.form-card button {
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: 50px;
  padding: 0.95rem;
  font-weight: 600;
  font-size: 1.02rem;
  box-shadow: 0 15px 35px rgba(200, 32, 32, 0.28);
}

.form-card button:hover {
  background: #9d1515;
  color: #fff;
}

/* ============================
   FOOTER
============================ */
/* =========================================================
   FOOTER CTETA — PREMIUM
========================================================= */
.footer-cteta {
  background: #c82020;
  color: #ffffff;
  padding: 2.0rem 0 2rem;
  text-align: center;
  position: relative;
  margin-top: 4rem;
}

/* Linha dourada superior sutil */
.footer-cteta::before {
  content: "";
  width: 90px;
  height: 3px;
  background: var(--gold);
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 40px;
}

.footer-brand {
  font-size: 1.15rem;
  font-weight: 600;
  margin-bottom: 1rem;
}

/* ÍCONES SOCIAIS */
.footer-social a {
  color: #ffffff;
  margin: 0 10px;
  font-size: 1.4rem;
  transition: .3s ease;
}

.footer-social a:hover {
  color: var(--gold);
}

/* COPYRIGHT */
.footer-copy {
  margin-top: 1.4rem;
  font-size: 0.92rem;
  opacity: 0.9;
}

.footer-copy a {
  color: var(--gold);
  font-weight: 600;
  text-decoration: none;
}

.footer-copy a:hover {
  color: #ffffff;
}


/* ===============================
   RESPONSIVIDADE MOBILE CTETA v4.4
================================*/

/* Max-width 991px (tablets e celulares grandes) */
@media (max-width: 991px) {

  /* NAVBAR */
  .navbar-brand img {
    height: 48px !important;
  }
  .btn-nav-whats {
    padding: 0.35rem 1rem;
    font-size: 0.8rem;
    margin-left: 0.5rem;
  }
  .nav-link {
    margin-left: 0;
    padding: 0.6rem 0;
    font-size: 1rem;
  }


  /* QUEM SOMOS */
  .about-text {
    font-size: 0.95rem;
    text-align: justify;
  }
  .about-img-wrapper img {
    height: 260px !important;
  }

  /* MODALIDADES */
  .mod-card {
    height: 180px !important;
    padding: 1rem !important;
    background-position: center;
  }
  .mod-card span {
    font-size: 1rem !important;
  }
  .mod-card:hover {
    transform: scale(1.02) !important;
  }

  /* ESTRUTURA */
  .estrutura-box img {
    height: 240px !important;
  }
  .estrutura-box-inner {
    padding: 1.4rem !important;
  }

  .estr-item {
    text-align: center;
  }



  /* DIFERENCIAIS */
  .diff-card {
    padding: 1.4rem !important;
  }

  /* ATLETAS */
  .atl-card {
    height: 230px !important;
  }
  .atl-name {
    font-size: 1.05rem !important;
  }

  /* FORMULÁRIO */
  .form-card {
    padding: 1.6rem !important;
  }
  .form-card .form-control,
  .form-card .form-select {
    font-size: 0.9rem !important;
    padding: 0.65rem !important;
  }
  .btn-submit {
    padding: 0.85rem !important;
    font-size: 1rem !important;
  }

  /* FOOTER */
  footer {
    padding: 1.8rem 0 !important;
  }
}

/* ===============================
   FIX — EQUIPE ESTOURANDO NO MOBILE
================================*/
@media (max-width: 991px) {

  /* CARD MAIOR (THALYTA) */
  .team-large {
    border-radius: 16px !important;
    overflow: hidden !important;
  }

  .team-large img {
    width: 100% !important;
    height: auto !important;         /* IMPORTANTE */
    aspect-ratio: 4/3 !important;     /* Mantém proporção */
    object-fit: cover !important;
    display: block;
  }

  /* CARDS PEQUENOS */
  .team-small {
    border-radius: 16px !important;
    overflow: hidden !important;
  }

  .team-small img {
    width: 100% !important;
    height: auto !important;         /* IMPORTANTE */
    aspect-ratio: 4/3 !important;     /* Mantém padronizado */
    object-fit: cover !important;
    display: block;
  }
}

@media (max-width: 768px) {
  .hero {
    background-position: center top;
    background-size: cover;
    background-attachment: scroll; /* FIXA CORRETAMENTE EM CELULAR */
    height: 55vh;
    min-height: 380px;
  }
}


/* ===============================
   FIX — HERO QUEBRANDO BOTÕES NO MOBILE
================================*/
@media (max-width: 991px) {

  /* HERO alinhado no mobile */
  .hero {
    text-align: center !important;
    padding: 80px 0 60px !important;
  }



  .hero .container {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  /* Título menor e mais responsivo */
  .hero h1 {
    font-size: 2rem !important;
    line-height: 1.25 !important;
  }

  /* Texto fluindo corretamente */
  .hero p {
    max-width: 95%;
    font-size: 1rem !important;
    margin-bottom: 1.2rem;
  }

  /* BOTÕES: corrigindo 100% */
  .btn-hero-main,
  .btn-hero-ghost {
    width: 100% !important;
    margin: 0 0 10px 0 !important;
    display: block !important;
  }
}

