/* ===== Clínica Evolution — estilos custom (complementa o Tailwind CDN) ===== */

:root {
  --gold: #f2b705;
  --gold-light: #ffd24a;
  --gold-dark: #d99700;
  --black: #0d0d0d;
  --charcoal: #1a1a1a;
  --gray: #333333;
  /* Gradiente metálico dourado (identidade da logo "CE") */
  --gold-metallic: linear-gradient(135deg, #b8860b 0%, #ffd24a 40%, #f2b705 60%, #a9740a 100%);
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 5rem; /* compensa o header fixo ao navegar por âncoras */
}

/* Garante que o utilitário `hidden` do Tailwind vença os componentes custom
   (.btn-gold etc.) definidos depois neste arquivo — senão o CTA "hidden md:inline-flex"
   reaparece no mobile. */
.hidden { display: none !important; }

body {
  font-family: 'Poppins', sans-serif;
}

/* Hero carrossel — slides das quadras, largura total */
.hero-slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  will-change: opacity;
}
.hero-slide.is-active {
  opacity: 1;
}

/* ===== Botões ===== */
.btn-gold {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  color: var(--black);
  background-color: var(--gold);
  border-radius: 9999px;
  transition: transform .2s ease, background-color .2s ease, box-shadow .2s ease;
  box-shadow: 0 4px 14px rgba(255, 215, 0, .25);
}
.btn-gold:hover { background-color: #fff; transform: translateY(-2px); }

.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  color: #fff;
  border: 2px solid rgba(255,255,255,.4);
  border-radius: 9999px;
  transition: all .2s ease;
}
.btn-outline:hover { border-color: var(--gold); color: var(--gold); }

/* ===== Nav links ===== */
.nav-link {
  position: relative;
  color: #e5e5e5;
  transition: color .2s ease;
}
.nav-link:hover { color: var(--gold); }
.nav-link::after {
  content: '';
  position: absolute;
  left: 0; bottom: -6px;
  width: 0; height: 2px;
  background: var(--gold);
  transition: width .25s ease;
}
.nav-link:hover::after { width: 100%; }

.mobile-link {
  display: block;
  padding: .65rem .5rem;
  border-radius: .5rem;
  color: #e5e5e5;
  transition: background-color .2s, color .2s;
}
.mobile-link:hover { background: rgba(255,255,255,.06); color: var(--gold); }

/* ===== Seções ===== */
.section-eyebrow {
  display: inline-block;
  color: var(--gold);
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .15em;
  text-transform: uppercase;
}
.section-title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  line-height: 1.1;
  margin-top: .5rem;
}

/* Informações — lista de itens */
.info-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}
.info-row-icon {
  flex: 0 0 auto;
  font-size: 1.5rem;
  width: 3rem; height: 3rem;
  display: flex; align-items: center; justify-content: center;
  border-radius: 9999px;
  background: rgba(242,183,5,.12);
  border: 1px solid rgba(242,183,5,.3);
  color: var(--gold);
}
.info-row-label {
  color: var(--gold);
  font-weight: 600;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.info-row-value {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 1.15rem;
  color: #fff;
  margin-top: .15rem;
}

/* Texto com gradiente metálico dourado (identidade da logo) */
.text-metallic {
  background: var(--gold-metallic);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ===== Carrossel de treinadores (cards compactos, 4 por vez) ===== */
.coach-carousel {
  position: relative;
  padding: 0 4.5rem;
}
.coach-viewport {
  overflow: hidden;
  padding: 6px 0; /* respiro para o hover (translateY) não ser cortado */
}
.coach-track {
  display: flex;
  gap: 1rem;
  transition: transform .55s cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}
/* 4 cards por vez (considera o gap de 1rem entre eles) */
.coach-slide {
  flex: 0 0 calc((100% - 3rem) / 4);
  max-width: calc((100% - 3rem) / 4);
  background: linear-gradient(160deg, #1c1c1c 0%, #0d0d0d 100%);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 1rem;
  overflow: hidden;
  transition: transform .25s ease, border-color .25s ease;
}
.coach-slide:hover { transform: translateY(-4px); border-color: var(--gold); }

/* Foto enquadrada: foco no rosto/torso, esconde braços cortados nas bordas */
.coach-photo {
  position: relative;
  aspect-ratio: 4 / 5;
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(242,183,5,.16) 0%, rgba(13,13,13,0) 60%),
    #141414;
  overflow: hidden;
}
.coach-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}
/* Alan Gomes: desloca para a direita (parte apagada do troféu na borda) */
.coach-photo--right img { object-position: top right; }
/* leve fade na base para integrar a foto ao card */
.coach-photo::after {
  content: '';
  position: absolute;
  inset: auto 0 0 0;
  height: 35%;
  background: linear-gradient(to top, #0d0d0d 0%, rgba(13,13,13,0) 100%);
}
.coach-info {
  padding: .9rem 1rem 1.1rem;
  text-align: center;
}
.coach-name {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  line-height: 1.05;
  font-size: 1.05rem;
  color: #fff;
}
.coach-cat {
  margin-top: .15rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  color: #cfcfcf;
  font-size: .8rem;
}
.coach-club {
  margin-top: .1rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--gold);
  font-size: .95rem;
  letter-spacing: .02em;
}

/* Setas — maiores, afastadas dos cards, sem mudança no hover */
.coach-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 3.5rem; height: 3.5rem;
  display: flex; align-items: center; justify-content: center;
  border-radius: 9999px;
  background: rgba(0,0,0,.6);
  color: var(--gold);
  border: 1px solid rgba(242,183,5,.4);
  cursor: pointer;
  transition: background-color .2s, color .2s, transform .2s;
}
.coach-arrow:hover { background: var(--gold); color: #0d0d0d; transform: translateY(-50%) scale(1.08); }
.coach-arrow svg { width: 1.9rem; height: 1.9rem; }
.coach-prev { left: 0; }
.coach-next { right: 0; }

/* Dots */
.coach-dots {
  display: flex;
  justify-content: center;
  gap: .4rem;
  margin-top: 1.5rem;
}
.coach-dots button {
  width: .5rem; height: .5rem;
  border-radius: 9999px;
  background: rgba(255,255,255,.3);
  transition: background-color .2s, width .2s;
}
.coach-dots button.active {
  background: var(--gold);
  width: 1.4rem;
}

/* Carrossel de staff (preparadores/captadores) */
/* Mobile (≤767px): 1 card por vez, looping */
.coach-carousel--staff {
  max-width: 24rem;
  margin-left: auto;
  margin-right: auto;
}
.coach-carousel--staff .coach-track { gap: 0; }
.coach-carousel--staff .coach-slide {
  flex: 0 0 100%;
  max-width: 100%;
}

/* Desktop (≥768px): sem carrossel — os 2 cards lado a lado, centralizados */
@media (min-width: 768px) {
  .coach-carousel--staff {
    max-width: none;
    padding: 0; /* remove espaço reservado para as setas */
  }
  .coach-carousel--staff .coach-track {
    gap: 1.5rem;
    justify-content: center;
    transform: none !important;
  }
  .coach-carousel--staff .coach-slide {
    flex: 0 0 16rem;
    max-width: 16rem;
  }
  .coach-carousel--staff .coach-arrow,
  .coach-carousel--staff .coach-dots {
    display: none;
  }
}

/* Responsivo: 2 por vez no tablet, 1 no mobile */
@media (max-width: 900px) {
  .coach-slide { flex-basis: calc((100% - 1rem) / 2); max-width: calc((100% - 1rem) / 2); }
}
@media (max-width: 560px) {
  .coach-carousel { padding: 0 2rem; }
  .coach-slide { flex-basis: 100%; max-width: 100%; }
}

/* ===== Contador regressivo (seção de inscrição, fundo dourado) ===== */
.countdown-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 4.25rem;
  padding: .65rem .5rem;
  background: var(--black);
  color: #fff;
  border-radius: .85rem;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
.countdown-num {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 1.9rem;
  line-height: 1;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}
.countdown-label {
  margin-top: .25rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: .65rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #cfcfcf;
}
#countdown.is-over .countdown-num { color: var(--gold-light); }

/* Diferenciais */
.diff-card {
  position: relative;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 1rem;
  padding: 2rem;
  overflow: hidden;
  transition: transform .25s ease, border-color .25s ease;
}
.diff-card:hover { transform: translateY(-4px); border-color: var(--gold); }
.diff-number {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 3rem;
  color: rgba(255,215,0,.18);
  line-height: 1;
}
.diff-title { font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 1.15rem; margin-top: .5rem; }
.diff-text { color: #9ca3af; margin-top: .5rem; }

/* Footer */
.footer-title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  color: #fff;
  margin-bottom: 1rem;
}
.social-icon {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 2.5rem; height: 2.5rem;
  border-radius: 9999px;
  background: rgba(255,255,255,.08);
  color: #fff;
  transition: background-color .2s, color .2s, transform .2s;
}
.social-icon:hover { background: var(--gold); color: var(--black); transform: translateY(-2px); }

/* ===== Scroll reveal ===== */
[data-reveal] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .7s ease, transform .7s ease;
}
[data-reveal].revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Acessibilidade: foco visível */
a:focus-visible, button:focus-visible {
  outline: 3px solid var(--gold);
  outline-offset: 3px;
  border-radius: 4px;
}

/* Respeitar preferências de movimento reduzido */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  [data-reveal] { opacity: 1; transform: none; transition: none; }
  .hero-slide { transition: none; }
}
