/* === AASR - Estilo Premium === */
:root{
  --red:#c40000;
  --red-dark:#7a0000;
  --red-light:#ff3b3b;
  --white:#ffffff;
  --gray:#f5f5f5;
  --black:#1a1a1a;
  --shadow-sm: 0 4px 12px rgba(0,0,0,.08);
  --shadow-md: 0 12px 32px rgba(0,0,0,.12);
  --shadow-lg: 0 24px 60px rgba(196,0,0,.25);
  --radius: 16px;
  --transition: .35s cubic-bezier(.4,0,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',sans-serif;
  color:var(--black);
  background:var(--white);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

.container{width:min(1200px,92%);margin:0 auto}
.container.narrow{width:min(820px,92%)}

/* === PRELOADER === */
.preloader{
  position:fixed;inset:0;background:var(--black);
  display:flex;align-items:center;justify-content:center;
  z-index:9999;transition:opacity .6s ease;
}
.preloader.hide{opacity:0;pointer-events:none}
.loader-circle{
  width:60px;height:60px;border:4px solid rgba(255,255,255,.1);
  border-top-color:var(--red);border-radius:50%;
  animation:spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* === NAVBAR (maior) === */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:22px 0;transition:var(--transition);
  background:transparent;
}
.navbar.scrolled{
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(12px);
  box-shadow:var(--shadow-sm);
  padding:16px 0;
}
.nav-container{display:flex;align-items:center;justify-content:space-between;gap:14px}
.logo{display:flex;align-items:center;gap:14px;font-weight:800;color:var(--white)}
.logo-img{
  width:64px;height:64px;object-fit:cover;
  background:transparent;border-radius:12px;padding:0;
  box-shadow:0 6px 16px rgba(0,0,0,.22);
  image-rendering:auto;
  transform:translateZ(0);
  transition:var(--transition);
  outline:3px solid var(--red-light);
  outline-offset:0px;
}

/* Remove fundo branco da logo (caso o arquivo tenha fundo) */
.logo-img{
  background:transparent !important;
  mix-blend-mode:multiply;
}
.navbar.scrolled .logo-img{width:56px;height:56px}
.logo-text{font-size:26px;letter-spacing:1px}
.brand-mark{font-weight:900;color:#fff;transition:var(--transition)}
.brand-mark .r{color:#fff;transition:var(--transition)}
.navbar.scrolled .brand-mark{color:var(--black)}
.navbar.scrolled .brand-mark .r{color:var(--red)}

.nav-menu{display:flex;align-items:center;gap:26px}
.nav-menu a{
  color:#fff;font-weight:500;font-size:15px;
  position:relative;transition:var(--transition);
}
.navbar.scrolled .nav-menu a{color:var(--black)}
.nav-menu a:not(.btn-cta):hover{color:var(--red-light)}
.navbar.scrolled .nav-menu a:not(.btn-cta):hover{color:var(--red)}
.nav-menu a:not(.btn-cta)::after{
  content:'';position:absolute;left:0;bottom:-6px;width:0;height:2px;
  background:var(--red);transition:var(--transition);
}
.nav-menu a:not(.btn-cta):hover::after{width:100%}
.btn-cta{
  background:linear-gradient(135deg,var(--red),var(--red-light));
  color:#fff !important;padding:10px 20px;border-radius:50px;
  font-weight:600;box-shadow:0 6px 20px rgba(196,0,0,.45);
  transition:var(--transition);display:inline-flex;align-items:center;gap:8px;
}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(196,0,0,.6)}

/* === HAMBURGER === */
.hamburger{
  display:none;background:none;border:none;cursor:pointer;
  width:44px;height:44px;padding:8px;position:relative;z-index:120;
}
.hamburger span{
  display:block;position:absolute;left:8px;right:8px;height:3px;
  background:#fff;border-radius:2px;
  transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .25s ease,background .3s;
}
.hamburger span:nth-child(1){top:13px}
.hamburger span:nth-child(2){top:20px}
.hamburger span:nth-child(3){top:27px}
.navbar.scrolled .hamburger span{background:var(--black)}
.hamburger.open span{background:var(--black)}
.hamburger.open span:nth-child(1){top:20px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){top:20px;transform:rotate(-45deg)}

/* === HERO === */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  color:#fff;overflow:hidden;background:#1a1a1a;
}
.hero-slideshow{position:absolute;inset:0;z-index:0}
.hero-slide{
  position:absolute;inset:0;
  background-size:cover;
  /* Desktop: posiciona melhor pra reduzir corte agressivo */
background-position:50% 35%;
  opacity:0;transform:scale(1.03);
  transition:opacity 1.4s ease, transform 7s ease;
}
.hero-slide.active{opacity:1;transform:scale(1)}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(135deg,rgba(26,26,26,.65) 0%,rgba(122,0,0,.55) 100%),
    radial-gradient(circle at 50% 100%, rgba(0,0,0,.6), transparent 60%);
}
.hero-content{position:relative;z-index:2;text-align:center;max-width:900px;margin:0 auto;display:flex;flex-direction:column;justify-content:center;gap:10px}

.hero-tag{
  display:inline-block;padding:8px 20px;border:1px solid rgba(255,255,255,.3);
  border-radius:50px;font-size:13px;letter-spacing:2px;text-transform:uppercase;
  margin-bottom:18px;backdrop-filter:blur(8px);background:rgba(255,255,255,.08);
}
.hero h1{
  font-size:clamp(2.4rem,6vw,5rem);font-weight:800;line-height:1.05;
  margin-bottom:8px;letter-spacing:-1px;
}
.highlight{
  background:linear-gradient(135deg,var(--red-light),var(--red));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p{font-size:clamp(1rem,1.5vw,1.25rem);max-width:600px;margin:0 auto 2px;opacity:.9;line-height:1.35}
.hero-tradicao{
  margin:0 auto;
  font-size:clamp(.9rem,1.15vw,1.05rem);
  max-width:720px;
  opacity:.92;
  color:#fff;
  letter-spacing:.2px;
}

/* Bordinha/"chip" mais fininha */
.hero-tradicao-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 14px;
  border-radius:50px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(8px);
  margin-top:6px;
  font-size:.88rem;
}

.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:10px}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}




.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 30px;border-radius:50px;font-weight:600;font-size:15px;
  cursor:pointer;border:none;transition:var(--transition);position:relative;overflow:hidden;
}
.btn-primary{
  background:linear-gradient(135deg,var(--red),var(--red-light));
  color:#fff;box-shadow:0 10px 30px rgba(196,0,0,.45);
}
.btn-primary::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  transition:.6s;
}
.btn-primary:hover::before{left:100%}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(196,0,0,.6)}
.btn-lg{padding:18px 36px;font-size:16px}
.btn-spaced{margin-top:24px;padding:16px 34px}
.btn-ghost{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);
  color:#fff;backdrop-filter:blur(8px);
}
.btn-ghost:hover{background:rgba(255,255,255,.2);transform:translateY(-3px)}
.btn-whats{
  background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;
  width:100%;justify-content:center;
  box-shadow:0 8px 22px rgba(37,211,102,.35);
}
.btn-whats:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(37,211,102,.5)}

.hero-scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  width:24px;height:40px;border:2px solid rgba(255,255,255,.5);border-radius:20px;
  z-index:2;
}
.hero-scroll span{
  display:block;width:4px;height:8px;background:#fff;border-radius:2px;
  margin:6px auto;animation:scroll 1.6s ease-in-out infinite;
}
@keyframes scroll{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(12px);opacity:0}}

/* === SECTIONS === */
.section{padding:100px 0;position:relative}
.bg-dark{background:linear-gradient(135deg,var(--black) 0%,#2a2a2a 100%);color:#fff}
.bg-soft{background:var(--gray)}

.section-head{text-align:center;max-width:720px;margin:0 auto 60px}
.eyebrow{
  display:inline-block;color:var(--red);font-weight:600;font-size:13px;
  letter-spacing:3px;text-transform:uppercase;margin-bottom:14px;
}
.eyebrow.light{color:var(--red-light)}
.section-head h2{
  font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.15;
  margin-bottom:16px;letter-spacing:-1px;
}
.section-head h2.white{color:#fff}
.section-head p{color:#666;font-size:17px}
.section-head p.white-soft{color:rgba(255,255,255,.7)}

/* About */
.about-text{max-width:820px;margin:0 auto 50px;text-align:center;color:#555;font-size:16px}
.about-text p{margin-bottom:16px}

/* Club photos head */
.club-photos-head{text-align:center;margin:30px auto 24px;max-width:720px}
.club-photos-head h3{font-size:clamp(1.5rem,2.6vw,2rem);font-weight:800;letter-spacing:-.5px}

/* === CARDS === */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}
.card{
  background:#fff;padding:36px 24px;border-radius:var(--radius);
  text-align:center;box-shadow:var(--shadow-sm);transition:var(--transition);
  border:1px solid rgba(0,0,0,.04);
}
.card.glass{background:rgba(255,255,255,.7);backdrop-filter:blur(10px)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:rgba(196,0,0,.2)}
.card i{font-size:36px;color:var(--red);margin-bottom:18px;display:inline-block;transition:var(--transition)}
.card:hover i{transform:scale(1.15) rotate(-5deg)}
.card h3{font-size:18px;margin-bottom:8px;font-weight:700}
.card p{color:#666;font-size:14px}

/* === PLANS === */
.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px;align-items:stretch}
.plan{
  background:#fff;color:var(--black);padding:40px 32px;
  border-radius:24px;position:relative;transition:var(--transition);
  box-shadow:var(--shadow-md);display:flex;flex-direction:column;
}
.plan-top{flex:1 1 auto;margin-bottom:24px}
.plan:hover{transform:translateY(-12px) scale(1.02);box-shadow:var(--shadow-lg)}
.plan.featured{background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;transform:scale(1.05)}
.plan.featured:hover{transform:translateY(-12px) scale(1.07)}
.badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--red-light);color:#fff;padding:6px 16px;border-radius:50px;
  font-size:12px;font-weight:600;letter-spacing:1px;
}
.plan h3{font-size:20px;margin-bottom:16px;font-weight:700}
.plan .price{font-size:36px;font-weight:800;letter-spacing:-1px}
.plan .installment{opacity:.7;margin-bottom:24px;font-size:14px}
.plan ul{margin-bottom:8px}
.plan ul li{padding:8px 0;display:flex;align-items:center;gap:10px;font-size:14px}
.plan ul li i{color:#25d366}
.plan.featured ul li i{color:#fff}
.plan .btn-whats{margin-top:auto}

/* === TABLES === */
.table-wrap{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.modern-table{width:100%;border-collapse:collapse;background:#fff}
.modern-table thead{background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff}
.modern-table th,.modern-table td{padding:14px 18px;text-align:left;font-size:15px}
.modern-table tbody tr{border-bottom:1px solid #f0f0f0;transition:var(--transition)}
.modern-table tbody tr:hover{background:#fff5f5}
.modern-table tbody tr:last-child{border:none}
.info-box{
  margin:22px auto 0;max-width:520px;background:#fff;border-left:4px solid var(--red);
  padding:14px 18px;border-radius:10px;box-shadow:var(--shadow-sm);
  display:flex;align-items:center;gap:12px;font-size:14px;color:#444;
}
.info-box i{color:var(--red);font-size:18px}

/* === CARROSSEL === */
.carousel{position:relative;width:100%;overflow:hidden;margin-top:40px;height:380px}
.carousel-track{display:flex;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);will-change:transform}
/* garante que o conteúdo do carrossel fique acima do background */
.carousel{z-index:1}
.carousel-track{gap:16px}

.slide{
  flex:0 0 auto;height:100%;background-size:cover;background-position:center;
  position:relative;display:flex;align-items:center;justify-content:center;
  margin:0;border-radius:var(--radius);overflow:hidden;
}


.slide::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(26,26,26,.7),rgba(196,0,0,.5));
}

/* === Vantagens: fundo branco (sem imagem) === */
#vantagens .slide{
  background:#fff;
}
#vantagens .slide::before{
  display:none;
}
#vantagens .slide-inner{
  color:var(--black);
}
#vantagens .slide-inner i{
  color:var(--red);
}
/* remover cor branca aplicada ao slide geral */
#vantagens .slide-inner{
  color:var(--black) !important;
}
#vantagens .slide-inner p{
  color:#666;
  opacity:1;
}

/* Garante leitura: cria “reserva” lateral para as setas não encobrir texto */
#vantagens.carousel{
  padding:0 90px;
  height:auto;
  min-height:380px;
}
#vantagens .carousel-track{align-items:stretch}
#vantagens .slide{
  margin:0 6px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:var(--shadow-sm);
  height:auto;
  min-height:360px;
  padding:32px 26px;
  display:flex;align-items:center;justify-content:center;
  box-sizing:border-box;
}
#vantagens .slide-inner{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:100%;height:100%;text-align:center;gap:10px;
}
/* Uniformiza a “caixa do ícone” em todos os slides (com ou sem .vant-icon) */
#vantagens .slide-inner > i,
#vantagens .vant-icon{
  width:84px;height:84px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 10px;
  font-size:46px;
  color:var(--red);
}
#vantagens .slide-inner h3{
  font-size:17px;line-height:1.3;
  text-align:center;
  word-break:break-word;
}
#vantagens .slide-inner p{
  font-size:14px;line-height:1.5;margin-top:4px;
  text-align:center;
}

/* Garante altura igual (os cards com textos maiores não “puxam” o tamanho) */
#vantagens .slide-inner{min-height:100%;}
#vantagens .slide-inner > *{flex:0 0 auto}

/* Padroniza dimensões do ícone (sobrescreve .vant-icon 90x90) */
#vantagens .slide-inner > i,
#vantagens .vant-icon{
  width:84px !important;
  height:84px !important;
  margin:0 auto 10px !important;
  background:transparent !important;
  border:none !important;
}

#vantagens .slide-inner .vant-icon{margin-top:0}

/* Ícones específicos */
.vant-icon{
  width:90px;height:90px;

  border-radius:26px;
  /* Removido “bordado vermelho” (fundo + borda) */
  background:transparent;
  border:none;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;
}
#vantagens .vant-icon i{
  font-size:46px;
  color:var(--red);
}

#vantagens .vant-icon.vant-icon-chart{
  background:transparent;
  border-color:transparent;
}


.slide-inner{position:relative;z-index:2;color:#fff;text-align:center;padding:0 20px}
.slide-inner i{font-size:54px;margin-bottom:14px;color:var(--red-light)}
.slide-inner h3{font-size:22px;font-weight:700}
.slide-inner p{font-size:14px;opacity:.9;margin-top:6px}
.car-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.95);border:none;width:50px;height:50px;
  border-radius:50%;cursor:pointer;font-size:18px;color:var(--red);
  box-shadow:var(--shadow-md);
  transition:var(--transition);
  z-index:50;
}

.car-btn:hover{background:var(--red);color:#fff;transform:translateY(-50%) scale(1.1)}
.car-btn.prev{left:20px}
.car-btn.next{right:20px}

/* Setas do carrossel de Vantagens no desktop ficam mais afastadas */
#vantagens .car-btn.prev{left:14px}
#vantagens .car-btn.next{right:14px}

/* === Botão "Ver mais modalidades" === */
.modalidades-toggle{
  display:flex;justify-content:center;margin-top:28px;
}
#accordion .acc-item.is-hidden{display:none}

/* Club carousel */
.club-carousel{height:340px;margin-top:30px}
.club-carousel .carousel-track{
  justify-content:flex-start;
}

.club-slide{background-position:center}
.club-slide::before{display:none}


/* Toggle button + collapsible */
.toggle-table{display:inline-flex;margin:0 auto 24px;justify-content:center}
.section .container > .toggle-table,
.section .container.narrow > .toggle-table{display:flex;margin-left:auto;margin-right:auto}
.collapsible[hidden]{display:none !important}

/* === Botão “Ver todas as modalidades” (fonte vermelha) === */
#toggleModalidades{
  color:var(--red);
}
#toggleModalidades i{
  color:var(--red);
}


/* === SÓCIO CTA === */
.socio-cta{padding:60px 0}
.socio-cta-inner{
  display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
}
.socio-cta-inner h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-top:6px}
.socio-cta-inner p{margin-top:8px}

/* === TWO COL === */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.two-col.reverse > div:first-child{order:2}
.feature-list li{
  padding:14px 0;display:flex;align-items:center;gap:14px;font-size:16px;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.feature-list.dark li{border-color:rgba(0,0,0,.08)}
.feature-list li i{
  width:40px;height:40px;background:rgba(196,0,0,.15);color:var(--red-light);
  display:flex;align-items:center;justify-content:center;border-radius:10px;
}
.feature-list.dark li i{background:rgba(196,0,0,.1);color:var(--red)}

/* === CTA CARD (Não Sócio) === */
.nao-socio-visual{display:flex;justify-content:center}
.cta-card{
  position:relative;width:100%;max-width:460px;
  padding:50px 36px 44px;border-radius:28px;text-align:center;color:#fff;
  background:linear-gradient(150deg,#1a1a1a 0%,#5a0000 55%,var(--red) 100%);
  box-shadow:0 30px 70px rgba(196,0,0,.35);overflow:hidden;
  isolation:isolate;
}
.cta-card-bg{
  position:absolute;inset:-40%;
  background:
    radial-gradient(circle at 20% 20%,rgba(255,255,255,.18),transparent 40%),
    radial-gradient(circle at 80% 80%,rgba(255,59,59,.4),transparent 45%);
  animation:spin 22s linear infinite;z-index:0;
}
.cta-shield{
  width:78px;height:78px;border-radius:22px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;font-size:34px;
  margin:0 auto 18px;backdrop-filter:blur(6px);position:relative;z-index:2;
  box-shadow:0 10px 26px rgba(0,0,0,.3);
}
.cta-eyebrow{
  position:relative;z-index:2;display:inline-block;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  background:rgba(255,255,255,.15);padding:5px 14px;border-radius:20px;
  margin-bottom:14px;font-weight:600;
}
.cta-title{
  position:relative;z-index:2;
  font-size:clamp(1.5rem,2.8vw,2rem);font-weight:800;line-height:1.15;
  letter-spacing:-.5px;margin-bottom:22px;color:#fff;
}
.cta-title .highlight{
  background:linear-gradient(135deg,#fff,#ffd5d5);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cta-mini{position:relative;z-index:2;margin-bottom:26px;display:inline-block;text-align:left}
.cta-mini li{
  padding:6px 0;display:flex;align-items:center;gap:10px;font-size:14px;opacity:.95;
}
.cta-mini li i{
  width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.18);
  display:inline-flex;align-items:center;justify-content:center;font-size:10px;
}
.cta-card .btn-primary{position:relative;z-index:2}
.cta-floats{position:absolute;inset:0;pointer-events:none;z-index:1}
.cta-float{
  position:absolute;
  width:50px;
  height:50px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:20px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(6px);
  box-shadow: 0 14px 40px rgba(0,0,0,.18);
  animation:floatUp 6.5s ease-in-out infinite;
}
.cta-float i{filter: drop-shadow(0 6px 10px rgba(0,0,0,.25));}
.cta-float.f1{top:16%;left:-10px;animation-delay:0s}
.cta-float.f2{top:8%;right:-12px;animation-delay:1.4s}
.cta-float.f3{bottom:18%;left:-14px;animation-delay:2.6s}
.cta-float.f4{bottom:10%;right:-8px;animation-delay:.8s}
.cta-float.f5{top:30%;right:-16px;animation-delay:2.1s}
.cta-float.f6{bottom:26%;left:8%;animation-delay:1.9s}
.cta-float.f7{top:46%;left:-16px;animation-delay:3.2s}
.cta-float.f8{bottom:10%;right:12%;animation-delay:2.8s}
@keyframes floatUp{
  0%,100%{transform:translateY(0) translateX(0) rotate(-6deg) scale(1)}
  50%{transform:translateY(-16px) translateX(6px) rotate(6deg) scale(1.03)}
}

@media (max-width:768px){
  .cta-float{width:44px;height:44px;font-size:18px;border-radius:16px;}
  .cta-float.f5{display:none}
  .cta-float.f6{display:none}
  .cta-float.f7{display:none}
  .cta-float.f8{display:none}
}


/* === APP SECTION === */
.app-section{background:linear-gradient(135deg,#fff5f5 0%,#fff 100%)}
.app-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.app-grid .muted{color:#666;margin:14px 0 30px;font-size:16px}
.store-buttons{display:flex;gap:16px;flex-wrap:wrap}
.store-btn{
  display:inline-flex;align-items:center;gap:14px;
  background:var(--black);color:#fff;padding:14px 22px;border-radius:14px;
  transition:var(--transition);box-shadow:var(--shadow-md);
}
.store-btn:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);background:var(--red)}
.store-btn i{font-size:32px}
.store-btn small{display:block;font-size:11px;opacity:.8;line-height:1}
.store-btn strong{display:block;font-size:17px;line-height:1.2;margin-top:2px}
.app-visual{display:flex;justify-content:center}

/* Phone */
.phone-frame{
  position:relative;width:240px;height:480px;
  background:linear-gradient(160deg,#1a1a1a 0%,#2a2a2a 100%);
  border-radius:42px;padding:14px;
  box-shadow:
    0 30px 80px rgba(196,0,0,.28),
    0 0 0 3px #0a0a0a,
    inset 0 0 0 2px rgba(255,255,255,.05);
  animation:phoneFloat 4s ease-in-out infinite;
}
@keyframes phoneFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.phone-notch{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:90px;height:22px;background:#0a0a0a;border-radius:0 0 14px 14px;z-index:2;
}
.phone-screen{
  width:100%;height:100%;
  background:linear-gradient(160deg,#fff 0%,#fff5f5 100%);
  border-radius:30px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;padding:30px;
  box-shadow:inset 0 0 30px rgba(196,0,0,.08);
}
/* Logo transparente — mix-blend para eliminar o quadrado branco */
.phone-logo{
  width:140px;height:140px;object-fit:contain;
  background:#fff;
  border-radius:24px;
  padding:10px;
  filter:drop-shadow(0 8px 18px rgba(196,0,0,.25));
}
.phone-brand{font-weight:900;font-size:22px;letter-spacing:2px;color:var(--red);}
.phone-screen small{color:#888;font-size:12px;letter-spacing:2px;text-transform:uppercase}

/* === ACCORDION === */
.accordion{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.acc-item{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition)}
.acc-item.open{box-shadow:var(--shadow-lg);grid-column:1/-1}
.acc-thumb{
  width:100%;height:140px;background-size:cover;background-position:center;
  position:relative;
}
.acc-thumb::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.45));
}
.acc-head{padding:18px 22px;display:flex;align-items:center;gap:16px;cursor:pointer;background:#fff;transition:var(--transition)}
.acc-head:hover{background:#fff5f5}
.acc-num{
  width:42px;height:42px;border-radius:10px;
  background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;
  font-size:18px;flex-shrink:0;
}
.acc-title{flex:1;font-weight:600;font-size:16px}
.acc-icon{
  width:32px;height:32px;border-radius:50%;background:var(--red);color:#fff;
  display:flex;align-items:center;justify-content:center;transition:var(--transition);
}
.acc-item.open .acc-icon{transform:rotate(45deg);background:var(--red-dark)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .5s ease}
.acc-item.open .acc-body{max-height:2000px}
.acc-content{padding:0 22px 22px}
.acc-info p{margin-bottom:8px;font-size:14px;color:#444}
.acc-info strong{color:var(--black)}
.acc-info .prof{margin:6px 0 14px;font-size:14px;color:var(--red);font-weight:600}
.acc-table{width:100%;border-collapse:collapse;margin:8px 0 14px;font-size:14px}
.acc-table th,.acc-table td{padding:8px 12px;text-align:left;border-bottom:1px solid #f0f0f0}
.acc-table th{background:#fff5f5;color:var(--red);font-weight:600;font-size:13px}
.acc-obs{
  background:#fff5f5;border-left:3px solid var(--red);padding:10px 14px;
  border-radius:8px;font-size:13px;color:#555;margin-top:10px;
}

/* === CONTATO === */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.contact-grid.two-items{grid-template-columns:repeat(2,minmax(0,1fr));max-width:760px;margin:0 auto}
.contact-item{
  background:rgba(255,255,255,.05);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.1);padding:36px 28px;border-radius:var(--radius);
  text-align:center;transition:var(--transition);
}
.contact-item:hover{transform:translateY(-6px);background:rgba(255,255,255,.08);border-color:var(--red)}
.contact-item i{font-size:32px;color:var(--red-light);margin-bottom:16px}
.contact-item h4{margin-bottom:8px;font-size:18px}
.contact-item p{opacity:.8;font-size:15px}

/* === MAPA === */
.map-section{height:420px;width:100%}
.map-section iframe{width:100%;height:100%;border:none;display:block;filter:grayscale(.2)}

/* === FOOTER === */
.footer{background:var(--black);color:#fff;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1.6fr;gap:40px;padding-bottom:40px}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.brand-mark-footer{font-size:28px;font-weight:900;letter-spacing:1px;color:#fff;margin:0}
.brand-mark-footer::after{
  content:'';display:block;width:46px;height:3px;background:var(--red);margin-top:8px;border-radius:2px;
}
.footer .mt{margin-top:8px;opacity:.7;font-size:14px;max-width:320px;margin-bottom:18px}
.footer h5{margin-bottom:18px;font-size:16px;font-weight:600;color:#fff}
.footer h6{margin:18px 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--red-light);font-weight:700}
.footer a{display:block;padding:6px 0;opacity:.75;transition:var(--transition);font-size:14px}
.footer a:hover{opacity:1;color:var(--red-light);transform:translateX(4px)}

/* Board groups */
.board-sub{font-size:13px;opacity:.7;margin-bottom:14px}
.board-group{border-top:1px solid rgba(255,255,255,.08)}
.board-group:last-of-type{border-bottom:1px solid rgba(255,255,255,.08)}
.board-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;background:none;border:none;color:#fff;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:600;text-align:left;
  transition:color .25s;
}
.board-toggle:hover{color:var(--red-light)}
.board-toggle i{transition:transform .35s ease;color:var(--red-light);font-size:12px}
.board-toggle[aria-expanded="true"] i{transform:rotate(180deg)}
.board-list{max-height:0;overflow:hidden;transition:max-height .5s ease}
.board-list.open{max-height:1000px}
.board-list ul{padding:4px 0 16px}
.board-list ul li{font-size:13px;opacity:.85;padding:4px 0;line-height:1.5}
.board-list ul li strong{color:#fff;font-weight:600;opacity:1}
.board-obs{margin-top:14px;font-size:12px;opacity:.6;line-height:1.5}

.socials{display:flex;gap:12px;margin-top:6px}
.socials a{
  width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex !important;align-items:center;justify-content:center;padding:0;opacity:1;
}
.socials a:hover{background:var(--red);transform:translateY(-3px)}
.footer-legal{
  border-top:1px solid rgba(255,255,255,.08);
  padding:24px 0 8px;
  font-size:12.5px;opacity:.7;line-height:1.55;
}
.footer-legal h6{margin:0 0 8px;font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--red-light);font-weight:700}
.footer-legal p{margin:4px 0}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:24px 0;text-align:center;
  font-size:13px;opacity:.75;
}
.credits{display:inline-block;margin-top:6px;font-size:12px;opacity:.7}
.credits strong{color:var(--red-light);font-weight:600}

/* === FLOATING === */
.float-whats{
  position:fixed;bottom:24px;right:24px;width:62px;height:62px;
  background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:30px;box-shadow:0 12px 30px rgba(37,211,102,.5);z-index:90;
  animation:pulse 2s infinite;transition:var(--transition);
}
.float-whats:hover{transform:scale(1.1)}
@keyframes pulse{
  0%{box-shadow:0 12px 30px rgba(37,211,102,.5),0 0 0 0 rgba(37,211,102,.6)}
  70%{box-shadow:0 12px 30px rgba(37,211,102,.5),0 0 0 20px rgba(37,211,102,0)}
  100%{box-shadow:0 12px 30px rgba(37,211,102,.5),0 0 0 0 rgba(37,211,102,0)}
}
.back-top{
  position:fixed;bottom:100px;right:30px;width:46px;height:46px;
  background:var(--red);color:#fff;border:none;border-radius:50%;cursor:pointer;
  box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:var(--transition);
  z-index:89;
}
.back-top.show{opacity:1;pointer-events:auto}
.back-top:hover{background:var(--red-dark);transform:translateY(-4px)}

/* === REVEAL === */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}
.reveal.active{opacity:1;transform:translateY(0)}

/* === BACKDROP do menu mobile === */
.nav-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  opacity:0;pointer-events:none;transition:opacity .35s ease;z-index:99;
}
.nav-backdrop.show{opacity:1;pointer-events:auto}

/* === RESPONSIVE === */
@media (max-width:980px){
  .two-col{grid-template-columns:1fr;gap:40px}
  .two-col.reverse > div:first-child{order:0}
  .footer-grid{grid-template-columns:1fr;text-align:left}
  .footer .mt{margin-left:0}
  .app-grid{grid-template-columns:1fr;text-align:center}
  .store-buttons{justify-content:center}
  .socio-cta-inner{flex-direction:column;text-align:center}
}



@media (max-width:768px){
  /* mobile: mantém recorte mais seguro */
  .hero-slide{background-position:center;transform:scale(1.05)}

  /* mobile: logo do header */
  .logo-img{background:transparent !important;padding:0 !important;box-shadow:none;object-fit:cover !important;outline-offset:-2px !important;}


  .hamburger{display:block}

  /* Vantagens: ajusta setas + reserva lateral */
  #vantagens.carousel{
    padding:0 44px;
    height:auto;
    min-height:300px;
    overflow:hidden;
  }
  #vantagens .carousel-track{
    align-items:stretch;
    /* NÃO usar justify-content:center aqui — quebra o translateX do slider */
  }
  #vantagens .slide{
    margin:0 4px;
    padding:28px 16px;
    display:flex;align-items:center;justify-content:center;
    min-height:280px;
    border:1px solid rgba(0,0,0,.06);
    border-radius:var(--radius);
    background:#fff;
    box-shadow:var(--shadow-sm);
    box-sizing:border-box;
  }
  #vantagens .slide-inner{
    padding:0 4px;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    width:100%;
    text-align:center;
  }
  #vantagens .slide-inner i{font-size:40px;margin-bottom:10px;}
  #vantagens .slide-inner h3{font-size:16px;line-height:1.25;}
  #vantagens .slide-inner p{font-size:13px;line-height:1.4;margin-top:6px;}

  #vantagens .vant-icon{width:64px;height:64px;margin-bottom:8px;}
  #vantagens .vant-icon i{font-size:38px;}
  #vantagens .car-btn{width:40px;height:40px;font-size:14px;}
  #vantagens .car-btn.prev{left:4px;}
  #vantagens .car-btn.next{right:4px;}


  .logo-text{font-size:20px}
.logo-img{
    width:52px;height:52px;
    background:transparent;
    padding:0;
    border-radius:14px;
    box-shadow:0 6px 16px rgba(0,0,0,.18);
  }
  .navbar{padding:14px 0}
  .navbar.scrolled{padding:12px 0}
  .nav-menu{
    position:fixed;top:0;right:-100%;width:82%;max-width:320px;height:100vh;
    background:#fff;flex-direction:column;justify-content:center;gap:22px;
    transition:right .4s cubic-bezier(.4,0,.2,1);
    box-shadow:-20px 0 40px rgba(0,0,0,.2);
    padding:80px 30px 30px;align-items:flex-start;
    overflow-y:auto;
  }
  .nav-menu.open{right:0}
  .nav-menu a{color:var(--black) !important;font-size:17px;width:100%}
  .nav-menu .btn-cta{color:#fff !important;width:auto;margin-top:8px}
  .section{padding:70px 0}
  .carousel{height:280px}
  .club-carousel{height:260px}
  .plan.featured{transform:none}
  .plan.featured:hover{transform:translateY(-8px)}
  .modern-table th,.modern-table td{padding:10px 12px;font-size:13px}

  .phone-frame{width:200px;height:400px}
  .phone-logo{width:120px;height:120px}
  .float-whats{width:54px;height:54px;font-size:26px;bottom:18px;right:18px}
  .back-top{bottom:84px;right:22px;width:42px;height:42px}
  .acc-content{padding:0 18px 18px}
  .acc-table th,.acc-table td{padding:6px 8px;font-size:12.5px}
  .contact-grid.two-items{grid-template-columns:1fr}
  .acc-thumb{height:120px}
  .hero-photos{grid-template-columns:repeat(3,1fr);gap:12px;max-width:520px;margin-top:36px}
  .hero-photo.hide-mobile{display:none}
  .club-carousel{height:260px}
}
@media (max-width:480px){
  /* Compactação do HERO (mobile) */
  .hero{min-height:86vh}

  /* Vantagens: telas menores */
  #vantagens.carousel{padding:0 34px;min-height:270px;}
  #vantagens .slide{margin:0 4px;padding:20px 12px;min-height:240px;}

  #vantagens .slide-inner h3{font-size:16px;}
  #vantagens .slide-inner p{font-size:13px;}
  #vantagens .slide-inner i{font-size:34px;}
  #vantagens .car-btn{width:36px;height:36px;font-size:13px;}

  #vantagens .car-btn.prev{left:4px;}
  #vantagens .car-btn.next{right:4px;}

  .hero-content{gap:8px;max-width:860px;padding:0 6px}
  .hero h1{font-size:1.95rem;line-height:1.08;margin-bottom:0}
  .hero p{font-size:.97rem;margin-bottom:18px}
  .hero-tradicao{font-size:.92rem;margin-bottom:0}
  .hero-tradicao-chip{margin-top:2px;padding:6px 12px;font-size:.84rem}
  .hero-cta{margin-top:6px}
  .hero-buttons{gap:10px}

  .btn{padding:12px 20px;font-size:14px}

  .hero-overlay{
    background:
      linear-gradient(180deg,rgba(26,26,26,.55) 0%,rgba(58,0,0,.7) 100%),
      radial-gradient(circle at 50% 100%, rgba(0,0,0,.5), transparent 60%);
  }
  .hero-scroll{display:none}

  .section{padding:56px 0}
  .section-head{margin-bottom:36px}
  .section-head h2{font-size:1.7rem}
  .plan{padding:30px 22px}
  .plan .price{font-size:30px}
  .footer{padding:40px 0 0}
  .contact-item{padding:26px 18px}
  .cta-card{padding:38px 22px 32px}
  .map-section{height:300px}

  /* Club photos (Nosso Espaço): altura menor e slides centralizados */
  .carousel,.club-carousel{height:220px}
  .club-carousel{height:220px;margin-top:22px}
  .club-carousel .carousel-track{align-items:center}
  .club-carousel .slide{margin:0 6px}
  .club-carousel .club-slide{background-position:center;}

  .car-btn{width:42px;height:42px;font-size:15px}
  .modern-table th,.modern-table td{padding:9px 10px;font-size:12.5px}
  .info-box{font-size:13px;padding:12px 14px}
}


/* === CENTRALIZAÇÃO VISUAL GLOBAL (mais consistente) === */
section{position:relative}
.footer,.footer-legal,.footer-bottom{width:100%}
.map-section{display:flex;justify-content:center}
.map-section iframe{max-width:1200px}

/* mantém containers centralizados */
.container,
.container.narrow,
.container.nav-container,
.container.hero-content,
.container.two-col,
.container.app-grid,
.container.footer-grid,
.container.socio-cta-inner{
  margin-left:auto !important;
  margin-right:auto !important;
}
body,html{max-width:100%;overflow-x:hidden}


/* =====================================================================
   === PREMIUM PATCH — Mobile, 3D, hover, hamburguer, animações ===
   ===================================================================== */

/* ---- Transições reutilizáveis ---- */
:root{
  --ease-elastic: cubic-bezier(.34,1.56,.64,1);
  --ease-smooth: cubic-bezier(.22,1,.36,1);
}

/* ===== HAMBURGUER ESTILIZADO ===== */
.hamburger{
  border-radius:14px;
  transition: background .35s ease, box-shadow .35s ease, transform .35s var(--ease-elastic);
}
.hamburger:hover{ transform:scale(1.08); }
.hamburger.open{
  background:linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,245,245,.95));
  box-shadow:
    0 8px 26px rgba(196,0,0,.45),
    0 0 0 4px rgba(196,0,0,.18),
    inset 0 0 0 1px rgba(196,0,0,.25);
  transform: rotate(180deg) scale(1.05);
}
.hamburger.open span{
  background: linear-gradient(90deg, var(--red), var(--red-light)) !important;
  height:3.5px; border-radius:3px;
  box-shadow: 0 0 10px rgba(196,0,0,.55);
}
.hamburger.open span:nth-child(1){ top:18px; }
.hamburger.open span:nth-child(3){ top:18px; }
@keyframes hamburgerPulse{
  0%,100%{ box-shadow: 0 8px 26px rgba(196,0,0,.45), 0 0 0 4px rgba(196,0,0,.18); }
  50%   { box-shadow: 0 8px 30px rgba(196,0,0,.55), 0 0 0 9px rgba(196,0,0,.06); }
}
.hamburger.open{ animation: hamburgerPulse 1.8s ease-in-out infinite; }

/* ===== PLANOS — hover 3D + animação em TODOS os cards (preço/título) ===== */
.plan{
  perspective: 1000px;
  transition: transform .5s var(--ease-smooth), box-shadow .5s ease;
  overflow:hidden;
  isolation:isolate;
}
.plan h3, .plan .price, .plan .installment, .plan ul li{
  transition: transform .45s var(--ease-elastic), color .35s ease, text-shadow .35s ease, letter-spacing .35s ease;
  will-change: transform;
}
.plan:hover h3{
  transform: translateY(-4px) translateZ(30px);
  color: var(--red);
  letter-spacing:.3px;
}
.plan.featured:hover h3{ color:#fff; text-shadow: 0 6px 24px rgba(255,255,255,.35); }
.plan:hover .price{
  transform: translateY(-6px) scale(1.08) translateZ(40px);
  text-shadow: 0 14px 30px rgba(196,0,0,.35);
  background: linear-gradient(135deg, var(--red), var(--red-light));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.plan.featured:hover .price{
  background: linear-gradient(135deg, #fff, #ffd5d5);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 14px 30px rgba(255,255,255,.4);
}
.plan:hover .installment{ transform: translateY(-3px) translateZ(20px); opacity:1; }
.plan:hover ul li{ transform: translateX(4px) translateZ(15px); }
.plan:hover ul li:nth-child(2){ transition-delay:.05s; }
.plan:hover ul li:nth-child(3){ transition-delay:.1s; }

/* gloss que segue o mouse (via --mx/--my no JS) */
.tilt-3d{ position:relative; }
.tilt-3d::after{
  content:''; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(420px circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.18), transparent 45%);
  opacity:0; transition: opacity .4s ease;
  border-radius:inherit; z-index:1;
}
.tilt-3d:hover::after{ opacity:1; }
.plan > *{ position:relative; z-index:2; }

/* sobrescreve o transform anterior (do tilt) — featured não fica mais maior estática */
.plan.featured{ transform:none; }
.plan:hover{ box-shadow: 0 30px 80px rgba(196,0,0,.35); }

/* badge animado */
.plan .badge{
  animation: badgeFloat 2.6s ease-in-out infinite;
  box-shadow: 0 8px 22px rgba(196,0,0,.45);
}
@keyframes badgeFloat{
  0%,100%{ transform: translateX(-50%) translateY(0); }
  50%   { transform: translateX(-50%) translateY(-6px); }
}

/* ===== CARDS / CONTATO — preparo 3D ===== */
.card, .contact-item, .store-btn, .cta-card, #vantagens .slide{
  transform-style: preserve-3d;
  perspective: 900px;
}
.card{ transition: transform .55s var(--ease-smooth), box-shadow .55s ease, border-color .35s ease; }

/* ===== HERO — slide com leve flutuação Ken-Burns ===== */
.hero-slide.active{
  animation: kenburns 9s ease-out forwards;
}
@keyframes kenburns{
  0%   { transform: scale(1.06); }
  100% { transform: scale(1.12); }
}

/* highlight com gradiente animado */
.highlight{
  background-size: 200% 200%;
  animation: gradientShift 6s ease infinite;
}
@keyframes gradientShift{
  0%,100%{ background-position:0% 50%; }
  50%   { background-position:100% 50%; }
}

/* h1 do hero — sutil flutuação 3D */
.hero h1{
  text-shadow: 0 10px 40px rgba(0,0,0,.45);
  transform-style: preserve-3d;
}

/* ===== Botão CTA com brilho rotativo ===== */
.btn-cta{ position:relative; overflow:hidden; }
.btn-cta::after{
  content:''; position:absolute; inset:-2px;
  background: conic-gradient(from 0deg, transparent 0 70%, rgba(255,255,255,.6) 80%, transparent 90%);
  animation: rotateGlow 4s linear infinite;
  opacity:.0; transition: opacity .3s;
  z-index:0;
}
.btn-cta:hover::after{ opacity:.7; }
.btn-cta > *{ position:relative; z-index:1; }
@keyframes rotateGlow{ to{ transform: rotate(1turn); } }

/* float-whats com micro-shake periódico */
@keyframes wiggle{
  0%,92%,100%{ transform: rotate(0); }
  94%{ transform: rotate(-10deg); }
  96%{ transform: rotate(10deg); }
  98%{ transform: rotate(-6deg); }
}
.float-whats{ animation: pulse 2s infinite, wiggle 6s ease-in-out infinite; }

/* ===== Phone — tilt 3D contínuo ===== */
.phone-frame{
  animation: phoneFloat 4s ease-in-out infinite, phoneTilt 9s ease-in-out infinite;
  transform-style: preserve-3d;
}
@keyframes phoneTilt{
  0%,100%{ transform: rotateY(-6deg) rotateX(4deg); }
  50%   { transform: rotateY(6deg)  rotateX(-3deg); }
}

/* ===== Reveal — slide com leve 3D ===== */
.reveal{ transform: translateY(40px) rotateX(8deg); transform-origin: 50% 100%; }
.reveal.active{ transform: translateY(0) rotateX(0); }

/* ===========================================================
   ============== MOBILE — VERSIONAMENTO COMPLETO ============
   =========================================================== */
@media (max-width: 768px){
  /* HERO compacto */
  .hero{ min-height: 92vh; }
  .hero-content{ gap:6px !important; padding:0 14px; }
  .hero h1{ font-size: clamp(1.85rem, 7.5vw, 2.6rem) !important; line-height:1.05; margin-bottom:2px; }
  .hero p{ font-size: .95rem; line-height:1.3; margin: 2px auto 4px; max-width: 92%; }
  .hero-tradicao{ font-size:.84rem; margin-top:2px; }
  .hero-tradicao-chip{ margin-top:4px !important; padding:5px 12px; }
  .hero-cta{ gap:10px !important; margin-top:10px !important; }
  .hero-cta .btn{ padding:11px 18px; font-size:13.5px; }

  /* CARROSSEL — centralização real no mobile (both) */
  .carousel{ padding: 0 !important; overflow:hidden; }
  .carousel-track{ gap: 0 !important; }
  .carousel .slide{ margin: 0 !important; }
  /* Botões de seta sobrepostos com leve offset interno */
  .car-btn{ width:42px; height:42px; }
  .car-btn.prev{ left: 10px !important; }
  .car-btn.next{ right: 10px !important; }

  /* Vantagens: zera padding lateral e usa slide cheio.
     Ajuste: reduz altura/tamanho pra caber melhor e não ser encoberto pelas setas no mobile.
  */
  #vantagens.carousel{ padding: 0 56px !important; min-height: 260px; }
  #vantagens .slide{
    margin: 0 !important;
    border-radius: var(--radius);
    background: #fff;
    border: 1px solid rgba(0,0,0,.06);
    box-shadow: var(--shadow-sm);
    padding: 22px 16px;
    min-height: 230px;
  }
  #vantagens .slide-inner h3{ font-size:15px; }
  #vantagens .slide-inner p{ font-size:12.5px; line-height:1.38; }
  #vantagens .vant-icon{ width:56px; height:56px; margin-bottom:6px; }
  #vantagens .vant-icon i{ font-size:32px; }
  #vantagens .car-btn{ width:36px; height:36px; font-size:13px; }
  #vantagens .car-btn.prev{ left: 6px !important; }
  #vantagens .car-btn.next{ right: 6px !important; }

  /* Club (Nosso Espaço): também 100% no mobile */
  .club-carousel{ height: 260px; }
  .club-carousel .slide{ border-radius: var(--radius); }

  /* Container central perfeito */
  .container{ width: min(1200px, 94%); }

  /* Hamburguer mais visível */
  .hamburger{ background: rgba(0,0,0,.18); backdrop-filter: blur(6px); }
  .navbar.scrolled .hamburger{ background: rgba(196,0,0,.08); }
  .hamburger span{ height:3px; border-radius:3px; }

  /* Reduz parallax */
  .hero-slideshow{ transition: transform .8s ease; }
}

@media (max-width: 480px){
  .hero{ min-height: 84vh; }
  .hero-content{ gap:4px !important; }
  .hero h1{ font-size: 1.85rem !important; letter-spacing:-.5px; }
  .hero p{ font-size: .9rem; margin: 0 auto 2px; }
  .hero-tradicao-chip{ font-size:.78rem; padding:4px 10px; margin-top:3px !important; }
  .hero-cta{ margin-top:8px !important; gap:8px !important; }
  .hero-cta .btn{ padding:10px 16px; font-size:13px; }

  /* Hero overlay um pouco mais escuro para legibilidade */
  .hero-overlay{
    background:
      linear-gradient(180deg, rgba(20,20,20,.6) 0%, rgba(60,0,0,.78) 100%),
      radial-gradient(circle at 50% 100%, rgba(0,0,0,.55), transparent 60%);
  }

  /* Plans no mobile: hover 3D continua mas tap effect visível */
  .plan:active{ transform: scale(.985); }
  .plan:active .price{ transform: scale(1.06); }
}

/* Em telas com mouse, plano featured não fica mais escalado de origem (corrige hover) */
@media (hover: hover){
  .plan.featured{ transform: none; }
}

/* ===========================================================
   ============== MOBILE TAP ANIMATIONS (touch) ==============
   Espelha os efeitos de :hover quando o usuário toca o card.
   =========================================================== */
@media (hover: none){
  /* Plano - replica todos os efeitos de hover */
  .plan.is-tapped{
    transform: translateY(-12px) scale(1.02);
    box-shadow: 0 30px 80px rgba(196,0,0,.35);
  }
  .plan.featured.is-tapped{ transform: translateY(-12px) scale(1.07); }
  .plan.is-tapped h3{
    transform: translateY(-4px) translateZ(30px);
    color: var(--red);
    letter-spacing:.3px;
  }
  .plan.featured.is-tapped h3{ color:#fff; text-shadow: 0 6px 24px rgba(255,255,255,.35); }
  .plan.is-tapped .price{
    transform: translateY(-6px) scale(1.08) translateZ(40px);
    text-shadow: 0 14px 30px rgba(196,0,0,.35);
    background: linear-gradient(135deg, var(--red), var(--red-light));
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .plan.featured.is-tapped .price{
    background: linear-gradient(135deg, #fff, #ffd5d5);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 14px 30px rgba(255,255,255,.4);
  }
  .plan.is-tapped .installment{ transform: translateY(-3px) translateZ(20px); opacity:1; }
  .plan.is-tapped ul li{ transform: translateX(4px) translateZ(15px); }
  .plan.is-tapped ul li:nth-child(2){ transition-delay:.05s; }
  .plan.is-tapped ul li:nth-child(3){ transition-delay:.1s; }

  /* Gloss radial segue o toque */
  .tilt-3d.is-tapped::after{ opacity:1; }

  /* Cards genéricos */
  .card.is-tapped{
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(196,0,0,.2);
  }
  .card.is-tapped i{ transform: scale(1.15) rotate(-5deg); }

  /* Contact items */
  .contact-item.is-tapped{
    transform: translateY(-6px);
    background: rgba(255,255,255,.08);
    border-color: var(--red);
  }

  /* Store buttons */
  .store-btn.is-tapped{
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    background: var(--red);
  }

  /* Transição mais suave ao soltar */
  .plan, .card, .contact-item, .store-btn{
    -webkit-tap-highlight-color: transparent;
  }
}


/* ===== iOS Safari: evita auto-ajuste de fonte que causava tamanhos diferentes nos cards de Vantagens no iPhone ===== */
html{
  -webkit-text-size-adjust:100%;
  -moz-text-size-adjust:100%;
  text-size-adjust:100%;
}
#vantagens .slide-inner h3,
#vantagens .slide-inner p{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}

/* ===== Redes sociais na NAVBAR ===== */
.nav-socials{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-left:4px;
}
.nav-socials a{
  width:36px;height:36px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;background:rgba(255,255,255,.14);
  font-size:15px;
  transition:var(--transition);
}
.nav-socials a:hover{
  transform:translateY(-2px);
  background:var(--red);
  color:#fff;
}
.navbar.scrolled .nav-socials a{
  color:var(--red);
  background:rgba(196,0,0,.08);
}
.navbar.scrolled .nav-socials a:hover{
  background:var(--red);
  color:#fff;
}
/* Em telas intermediárias esconde da navbar para não ficar apertado (continua no menu mobile) */
@media (max-width:1100px) and (min-width:981px){
  .nav-socials{display:none;}
}

/* ===== Redes sociais dentro do menu mobile ===== */
@media (max-width:980px){
  .nav-socials{
    display:flex !important;
    width:100%;
    justify-content:flex-start;
    gap:14px;
    margin:18px 0 0;
    padding-top:18px;
    border-top:1px solid rgba(0,0,0,.08);
  }
  .nav-socials a{
    width:44px;height:44px;
    color:var(--red) !important;
    background:rgba(196,0,0,.08) !important;
    font-size:18px;
  }
  .nav-socials a:hover{
    color:#fff !important;
    background:var(--red) !important;
  }
}

/* ===== QR Code (Beach Tennis) ===== */
.acc-qr{
  margin-top:16px;
  padding:18px;
  border:2px dashed var(--red);
  border-radius:14px;
  background:#fff5f5;
  text-align:center;
}
.acc-qr > strong{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--red);
  font-size:14px;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.acc-qr-box{
  width:200px;
  height:200px;
  margin:14px auto;
  background:#fff;
  border:1px solid #eee;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#bbb;
  font-size:12px;
  text-align:center;
  padding:8px;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.acc-qr-box img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.acc-qr p{
  font-size:13px;
  color:#555;
  margin:6px 0 0;
}

/* ===== Múltiplos botões de WhatsApp (Futevôlei) ===== */
.acc-whats-group{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:14px;
}
.acc-whats-group .btn-whats{
  width:100%;
}

/* === Carrossel "Nossas Áreas" (mesmo tamanho dos cards de Vantagens) === */
#areas-carousel.carousel{
  padding:0 90px;
  height:auto;
  min-height:380px;
}
#areas-carousel .carousel-track{align-items:stretch}
#areas-carousel .slide{
  margin:0 6px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:var(--shadow-sm);
  height:auto;
  min-height:360px;
  padding:32px 26px;
  display:flex;align-items:center;justify-content:center;
  box-sizing:border-box;
  border-radius:var(--radius);
}
#areas-carousel .slide::before{display:none}
#areas-carousel .slide-inner{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:100%;min-height:100%;text-align:center;gap:10px;
  color:var(--black);padding:0 8px;
}
#areas-carousel .slide-inner > *{flex:0 0 auto}
#areas-carousel .slide-inner > i{
  width:84px;height:84px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 10px;
  font-size:46px;color:var(--red);
}
#areas-carousel .slide-inner h3{
  font-size:17px;font-weight:700;color:var(--black);line-height:1.3;
  text-align:center;word-break:break-word;
}
#areas-carousel .slide-inner p{
  font-size:14px;color:#666;line-height:1.5;margin-top:4px;opacity:1;
  text-align:center;
}
#areas-carousel .car-btn.prev{left:14px}
#areas-carousel .car-btn.next{right:14px}

@media(max-width:768px){
  #areas-carousel.carousel{padding:0 56px;min-height:270px;}
  #areas-carousel .slide{min-height:240px;padding:20px 12px;margin:0 4px;}
  #areas-carousel .slide-inner > i{width:64px;height:64px;font-size:38px;margin-bottom:8px;}
  #areas-carousel .slide-inner h3{font-size:16px;line-height:1.25;}
  #areas-carousel .slide-inner p{font-size:13px;line-height:1.4;margin-top:6px;}
  #areas-carousel .car-btn{width:40px;height:40px;font-size:14px;}
  #areas-carousel .car-btn.prev{left:4px;}
  #areas-carousel .car-btn.next{right:4px;}
}
