/* =============================================
   MARI ZANOTTO PROJETOS — STYLES v4
   Curso de Captação · Navy sofisticado + azuis vivos
   ============================================= */

:root {
  /* Backgrounds */
  --bg-darkest: #04091A;
  --bg-dark:    #070F26;
  --bg-navy:    #0A1530;
  --bg-club:    #081A3D;
  --light:      #F4F8FF;
  --light-2:    #EAF1FF;
  --white:      #FFFFFF;

  /* Blues — marca + vida */
  --blue-900: #0B2E73;
  --blue-700: #1551B8;
  --blue-600: #1E6BEE;
  --blue-500: #2E84FF;
  --sky:      #4FB4FF;
  --sky-2:    #7FD0FF;
  --cyan:     #34E2E4;
  --pale:     #BFE0FF;

  /* Text */
  --tx-on-dark:   #EAF1FF;
  --tx-on-dark-2: #A9BEE3;
  --tx-on-dark-3: #6F86B3;
  --tx-on-light:  #0A1B3D;
  --tx-on-light-2:#46587D;

  /* Lines / borders */
  --line-dark:  rgba(120,170,255,0.14);
  --line-light: rgba(20,60,130,0.12);

  /* Gradients */
  --grad-blue: linear-gradient(120deg, var(--blue-600), var(--sky));
  --grad-vivid: linear-gradient(120deg, var(--blue-700) 0%, var(--blue-500) 45%, var(--cyan) 110%);
  --grad-text: linear-gradient(100deg, #FFFFFF 0%, var(--sky-2) 60%, var(--cyan) 100%);

  --radius:    18px;
  --radius-sm: 11px;
  --radius-lg: 26px;
  --radius-xl: 34px;

  --shadow-sm:  0 4px 18px rgba(4,14,40,.10);
  --shadow:     0 14px 44px rgba(6,18,52,.14);
  --shadow-lg:  0 30px 80px rgba(4,12,36,.22);
  --shadow-blue:0 22px 60px rgba(30,107,238,.34);

  --trans: all .32s cubic-bezier(.4,0,.2,1);

  --f-display: 'Fraunces', Georgia, serif;
  --f-body:    'Plus Jakarta Sans', system-ui, sans-serif;
  --f-mono:    'JetBrains Mono', monospace;
}

/* RESET */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100%; }
body {
  font-family:var(--f-body);
  background:var(--bg-darkest);
  color:var(--tx-on-light);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,svg { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; color:inherit; }
::selection { background:var(--blue-500); color:#fff; }
::-webkit-scrollbar { width:9px; }
::-webkit-scrollbar-track { background:var(--bg-darkest); }
::-webkit-scrollbar-thumb { background:var(--blue-700); border-radius:5px; }

/* =============================================
   UTILITIES
   ============================================= */
.container { max-width:1220px; margin:0 auto; padding:0 26px; position:relative; z-index:2; }
.container-narrow { max-width:840px; }
.anchor { scroll-margin-top:84px; }

.kicker {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--f-mono);
  font-size:.74rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:var(--sky-2);
}
.kicker.dark { color:var(--blue-700); }
.kicker-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--cyan); box-shadow:0 0 12px var(--cyan);
  flex-shrink:0;
}
.kicker.dark .kicker-dot { background:var(--blue-600); box-shadow:0 0 10px rgba(30,107,238,.6); }

.sec-title {
  font-family:var(--f-display);
  font-weight:600;
  font-size:clamp(2rem, 4.4vw, 3.3rem);
  line-height:1.08;
  letter-spacing:-.015em;
  color:var(--tx-on-dark);
}
.sec-title.dark { color:var(--tx-on-light); }

.sec-desc {
  font-size:1.06rem; line-height:1.7; color:var(--tx-on-dark-2);
  max-width:680px; margin:18px auto 0;
}
.sec-desc.dark { color:var(--tx-on-light-2); }

.sec-head { margin-bottom:54px; }
.sec-head.center { text-align:center; }
.sec-head.center .kicker { justify-content:center; }
.sec-head .kicker { margin-bottom:16px; }

/* SECTION SHELLS */
.sec { position:relative; padding:108px 0; overflow:hidden; }
.sec-light { background:var(--light); color:var(--tx-on-light); }
.sec-light::before {
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(var(--line-light) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-light) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(circle at 50% 0%, #000 0%, transparent 62%);
          mask-image:radial-gradient(circle at 50% 0%, #000 0%, transparent 62%);
  opacity:.5; z-index:0;
}
.sec-dark { background:var(--bg-dark); color:var(--tx-on-dark); }
.sec-dark::after {
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 80% -10%, rgba(30,107,238,.10), transparent 55%);
  z-index:0;
}

/* =============================================
   BUTTONS
   ============================================= */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--f-body); font-weight:700; font-size:.95rem;
  padding:13px 24px; border-radius:var(--radius-sm);
  transition:var(--trans); white-space:nowrap; line-height:1;
}
.btn-lg { padding:17px 32px; font-size:1.02rem; }
.btn i { font-size:.9em; }

.btn-primary {
  background:var(--grad-vivid); color:#fff;
  box-shadow:var(--shadow-blue);
  background-size:160% 160%; background-position:0% 50%;
}
.btn-primary:hover { transform:translateY(-3px); background-position:100% 50%; box-shadow:0 28px 70px rgba(52,226,228,.34); }

.btn-outline {
  background:rgba(255,255,255,.04); color:var(--tx-on-dark);
  border:1.5px solid var(--line-dark);
  backdrop-filter:blur(6px);
}
.btn-outline:hover { border-color:var(--sky); color:#fff; transform:translateY(-3px); background:rgba(79,180,255,.10); }

.btn-ghost {
  background:transparent; color:var(--tx-on-dark);
  border:1.5px solid var(--line-dark); padding:10px 18px;
}
.btn-ghost:hover { border-color:var(--sky); color:#fff; }

.btn-outline-blue {
  background:#fff; color:var(--blue-700);
  border:1.5px solid rgba(30,107,238,.26);
}
.btn-outline-blue:hover { background:var(--blue-700); color:#fff; border-color:var(--blue-700); transform:translateY(-3px); box-shadow:var(--shadow-blue); }

.pulse { animation:pulse 2.6s ease-in-out infinite; }
@keyframes pulse {
  0%,100% { box-shadow:var(--shadow-blue); }
  50% { box-shadow:0 22px 60px rgba(52,226,228,.5); }
}

/* =============================================
   NAVBAR
   ============================================= */
#navbar {
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  transition:var(--trans);
  padding:14px 0;
  /* leve diferenciação da hero, mesmo sem rolar */
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(10px) saturate(140%);
  border-bottom:1px solid rgba(20,60,130,.06);
}
#navbar.scrolled {
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line-light);
  box-shadow:0 6px 26px rgba(20,60,130,.07);
  padding:10px 0;
}
.nav-inner { max-width:1280px; margin:0 auto; padding:0 26px; display:flex; align-items:center; justify-content:space-between; gap:20px; }

.nav-logo { display:flex; align-items:center; gap:11px; }
.logo-mark {
  width:42px; height:42px; border-radius:11px;
  display:grid; place-items:center;
  font-family:var(--f-display); font-weight:900; font-size:1.05rem; color:#fff;
  background:var(--grad-vivid);
  box-shadow:0 8px 22px rgba(30,107,238,.4);
  letter-spacing:-.02em;
}
.logo-words { display:flex; flex-direction:column; line-height:1.05; }
.logo-main { font-family:var(--f-display); font-weight:600; font-size:1.08rem; color:var(--tx-on-light); }
.logo-sub { font-family:var(--f-mono); font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:var(--blue-600); }

.nav-menu { display:flex; gap:30px; }
.nav-link {
  font-size:.92rem; font-weight:600; color:var(--tx-on-light-2);
  position:relative; padding:5px 0; transition:var(--trans);
}
.nav-link::after {
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px;
  background:var(--grad-blue); border-radius:2px; transition:var(--trans);
}
.nav-link:hover, .nav-link.active { color:var(--tx-on-light); }
.nav-link:hover::after, .nav-link.active::after { width:100%; }

.nav-actions { display:flex; align-items:center; gap:12px; }
.btn-area { box-shadow:0 10px 26px rgba(30,107,238,.28); }
.nav-menu-cta { display:none; }

.nav-toggle { display:none; flex-direction:column; gap:5px; padding:8px; }
.nav-toggle span { width:24px; height:2px; background:var(--tx-on-light); border-radius:2px; transition:var(--trans); }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =============================================
   HERO
   ============================================= */
#hero {
  position:relative; min-height:100vh; display:flex; align-items:center;
  padding:132px 0 72px;
  background:
    radial-gradient(1000px 720px at 82% 4%, rgba(46,132,255,.13), transparent 58%),
    radial-gradient(820px 600px at -6% 98%, rgba(52,226,228,.10), transparent 60%),
    linear-gradient(180deg, #FFFFFF 0%, #EBF2FF 100%);
  overflow:hidden;
}
#canvas { display:none; }
#hero .hero-aurora { opacity:.5; }
#hero .hero-grid-tex {
  background-image:
    linear-gradient(rgba(20,60,130,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(20,60,130,.045) 1px, transparent 1px);
}

.hero-aurora { position:absolute; border-radius:50%; filter:blur(90px); z-index:0; pointer-events:none; }
.hero-aurora.a1 { width:560px; height:560px; top:-160px; right:-100px; background:radial-gradient(circle, rgba(30,107,238,.5), transparent 70%); animation:floaty 14s ease-in-out infinite; }
.hero-aurora.a2 { width:480px; height:480px; bottom:-180px; left:-120px; background:radial-gradient(circle, rgba(52,226,228,.26), transparent 70%); animation:floaty 18s ease-in-out infinite reverse; }
.hero-aurora.a3 { width:600px; height:600px; top:-200px; left:40%; background:radial-gradient(circle, rgba(46,132,255,.18), transparent 70%); }
@keyframes floaty { 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(30px,40px); } }

.hero-grid-tex {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(120,170,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,170,255,.06) 1px, transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(circle at 50% 40%, #000, transparent 75%);
          mask-image:radial-gradient(circle at 50% 40%, #000, transparent 75%);
}
.hero-grid-tex.soft { opacity:.6; }

.hero-inner { z-index:3; }
.hero-grid { display:grid; grid-template-columns:1.06fr .94fr; gap:46px; align-items:center; }

.hero-left .kicker { margin-bottom:22px; }
.hero-headline {
  font-family:var(--f-display);
  font-weight:600;
  font-size:clamp(1.90rem, 3.8vw, 3.0rem);
  line-height:1.1; letter-spacing:-.015em; color:var(--tx-on-light);
  margin-bottom:22px;
}
.hero-headline .hl {
  background:linear-gradient(100deg, var(--blue-700), var(--blue-500) 58%, var(--cyan));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  font-style:italic; font-weight:700;
}
.hero-sub {
  font-size:1.12rem; line-height:1.68; color:var(--tx-on-light-2);
  max-width:560px; margin-bottom:26px;
}
.hero-bullets {
  display:grid; grid-template-columns:1fr 1fr; gap:11px 20px; margin-bottom:34px; max-width:540px;
}
.hero-bullets li { display:flex; align-items:center; gap:10px; font-size:.92rem; color:var(--tx-on-light); font-weight:600; }
.hero-bullets i { color:var(--blue-600); font-size:1rem; }

.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:38px; }

.hero-trust { display:flex; flex-direction:column; gap:12px; }
.ht-label { font-family:var(--f-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--tx-on-light-2); }
.ht-pills { display:flex; flex-wrap:wrap; gap:9px; }
.ht-pill {
  font-size:.8rem; font-weight:600; color:var(--tx-on-light-2);
  padding:6px 13px; border-radius:30px;
  border:1px solid var(--line-light); background:#fff;
  box-shadow:var(--shadow-sm);
}

/* HERO RIGHT — foto emoldurada + cards (estilo profissional, fundo claro) */
.hero-right { position:relative; }
.hero-photo { position:relative; width:100%; max-width:510px; margin:0 auto; aspect-ratio:1 / 1.04; }
.hp-rings {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:130%; aspect-ratio:1; z-index:0;
  background:repeating-radial-gradient(circle at center, transparent 0 43px, rgba(20,70,150,.07) 43px 44px);
  -webkit-mask-image:radial-gradient(circle, #000 20%, transparent 68%);
          mask-image:radial-gradient(circle, #000 20%, transparent 68%);
}
.hp-panel {
  position:absolute; inset:3% 7% 0; z-index:1;
  border-radius:24px 24px 18px 18px;
  background:linear-gradient(180deg, #E8F1FF 0%, #D6E6FF 100%);
  box-shadow:0 38px 70px rgba(20,60,130,.18), inset 0 0 0 7px rgba(255,255,255,.6);
  display:flex; align-items:flex-end; justify-content:center; overflow:hidden;
}
.hp-img { width:100%; max-width:none; filter:drop-shadow(0 12px 20px rgba(20,60,130,.16)); }

.stat-card {
  position:absolute; z-index:4;
  background:#fff; border:1px solid rgba(20,60,130,.07);
  border-radius:16px; padding:14px 18px; min-width:112px;
  display:flex; flex-direction:column; gap:3px; text-align:center;
  box-shadow:0 22px 46px rgba(20,60,130,.16);
  opacity:0; will-change:transform;
  /* fade-in (opacity) + float perpétuo (transform) — propriedades distintas, sem conflito */
  animation: scAppear .6s ease-out forwards, scFloat 4s ease-in-out infinite;
}
.stat-card .sc-num { font-family:var(--f-display); font-weight:700; font-size:1.8rem; line-height:1; color:var(--blue-600); }
.stat-card .sc-lbl { font-family:var(--f-mono); font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; color:var(--tx-on-light-2); line-height:1.32; }
.sc-tl { top:7%;  left:-8%;  animation-delay:.20s, .20s; }
.sc-tr { top:22%; right:-9%; animation-delay:.45s, 1.5s; }
.sc-bl { bottom:18%; left:-8%; animation-delay:.32s, .9s; }
.sc-br { bottom:2%; right:-7%; animation-delay:.58s, 2.1s; }
.sc-br.featured { padding:18px 24px; }
.sc-br.featured .sc-num { font-size:2.1rem; color:var(--blue-700); }

@keyframes scAppear { from { opacity:0; } to { opacity:1; } }
@keyframes scFloat  { 0%, 100% { transform:translateY(0); } 50% { transform:translateY(-13px); } }

.hero-metrics-mobile { display:none; }

.hero-scroll { position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:5; }
.mouse { display:block; width:24px; height:38px; border:2px solid rgba(20,60,130,.28); border-radius:14px; position:relative; }
.wheel { position:absolute; top:7px; left:50%; transform:translateX(-50%); width:4px; height:7px; background:var(--blue-600); border-radius:3px; animation:wheel 1.6s ease-in-out infinite; }
@keyframes wheel { 0%{ opacity:0; transform:translate(-50%,0);} 40%{opacity:1;} 100%{ opacity:0; transform:translate(-50%,12px);} }

/* =============================================
   MARQUEE
   ============================================= */
.marquee-strip {
  background:var(--bg-darkest);
  border-top:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
  padding:20px 0; overflow:hidden; position:relative; z-index:2;
}
.marquee-track { display:flex; align-items:center; gap:34px; width:max-content; animation:marquee 38s linear infinite; }
.marquee-track span { font-family:var(--f-display); font-style:italic; font-weight:500; font-size:1.25rem; color:var(--tx-on-dark-2); white-space:nowrap; }
.marquee-track i { color:var(--cyan); font-style:normal; font-size:.7rem; }
@keyframes marquee { from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* =============================================
   PARA QUEM É
   ============================================= */
.audience-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.aud-card {
  background:var(--white); border:1px solid var(--line-light);
  border-radius:var(--radius); padding:32px 26px;
  box-shadow:var(--shadow-sm); transition:var(--trans);
  position:relative; overflow:hidden;
}
.aud-card::before {
  content:""; position:absolute; top:0; left:0; width:100%; height:3px;
  background:var(--grad-blue); transform:scaleX(0); transform-origin:left; transition:var(--trans);
}
.aud-card:hover { transform:translateY(-7px); box-shadow:var(--shadow); border-color:transparent; }
.aud-card:hover::before { transform:scaleX(1); }
.aud-ico {
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  font-size:1.4rem; color:var(--blue-600); margin-bottom:18px;
  background:linear-gradient(135deg, rgba(30,107,238,.12), rgba(52,226,228,.10));
}
.aud-card h3 { font-family:var(--f-display); font-weight:600; font-size:1.16rem; line-height:1.2; margin-bottom:10px; color:var(--tx-on-light); }
.aud-card p { font-size:.93rem; color:var(--tx-on-light-2); line-height:1.6; }

/* =============================================
   PROBLEMA
   ============================================= */
.pain-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; max-width:920px; margin:0 auto; }
.pain-card {
  display:flex; align-items:flex-start; gap:16px;
  background:rgba(13,27,60,.5); border:1px solid var(--line-dark);
  border-radius:var(--radius); padding:24px 26px;
  backdrop-filter:blur(6px); transition:var(--trans);
}
.pain-card:hover { border-color:rgba(127,208,255,.3); transform:translateY(-4px); }
.pain-x {
  flex-shrink:0; width:34px; height:34px; border-radius:9px; display:grid; place-items:center;
  background:rgba(255,90,110,.12); color:#FF7A8A; font-size:1rem;
}
.pain-card p { font-size:1rem; color:var(--tx-on-dark); line-height:1.55; }
.pain-turn {
  text-align:center; max-width:760px; margin:46px auto 0;
  font-family:var(--f-display); font-size:1.4rem; line-height:1.45; color:var(--tx-on-dark);
  font-weight:400;
}
.pain-turn strong { color:#fff; font-weight:600; }

/* =============================================
   O QUE APRENDE
   ============================================= */
.learn-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.learn-card {
  background:var(--white); border:1px solid var(--line-light);
  border-radius:var(--radius); padding:30px 28px;
  box-shadow:var(--shadow-sm); transition:var(--trans); position:relative; overflow:hidden;
}
.learn-card:hover { transform:translateY(-7px); box-shadow:var(--shadow); }
.learn-n {
  font-family:var(--f-mono); font-weight:700; font-size:.95rem; color:var(--blue-600);
  display:inline-block; padding:5px 11px; border-radius:8px;
  background:rgba(30,107,238,.08); margin-bottom:16px;
}
.learn-card h3 { font-family:var(--f-display); font-weight:600; font-size:1.24rem; margin-bottom:10px; color:var(--tx-on-light); }
.learn-card p { font-size:.95rem; color:var(--tx-on-light-2); line-height:1.62; }

/* =============================================
   ENCONTROS AO VIVO
   ============================================= */
.live-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.live-content .kicker { margin-bottom:16px; }
.live-content .sec-title { margin-bottom:20px; }
.live-lead { font-size:1.1rem; line-height:1.66; color:var(--tx-on-dark-2); margin-bottom:24px; }
.live-lead strong { color:#fff; }
.live-list { display:flex; flex-direction:column; gap:13px; margin-bottom:32px; }
.live-list li { display:flex; align-items:flex-start; gap:12px; font-size:1rem; color:var(--tx-on-dark); }
.live-list i { color:var(--cyan); margin-top:4px; font-size:.95rem; }

.live-call { position:relative; }
.lc-glow { position:absolute; inset:-8% -4%; z-index:0; border-radius:40px;
  background:radial-gradient(circle at 60% 40%, rgba(46,132,255,.35), rgba(52,226,228,.14) 55%, transparent 75%); filter:blur(44px); }
.lc-window {
  position:relative; z-index:1; background:rgba(8,16,40,.9);
  border:1px solid var(--line-dark); border-radius:18px; padding:14px;
  box-shadow:var(--shadow-lg); backdrop-filter:blur(8px);
  animation:pwFloat 7s ease-in-out infinite;
}
.lc-bar { display:flex; align-items:center; gap:10px; margin-bottom:12px; padding:0 4px; }
.lc-live { display:inline-flex; align-items:center; gap:7px; font-family:var(--f-mono); font-size:.66rem; font-weight:700; letter-spacing:.08em; color:#FF6B7E; background:rgba(255,90,110,.14); padding:5px 10px; border-radius:20px; }
.lc-dot { width:7px; height:7px; border-radius:50%; background:#FF4D63; animation:lcDot 1.3s ease-in-out infinite; }
@keyframes lcDot { 0%,100%{ opacity:1; transform:scale(1);} 50%{ opacity:.35; transform:scale(.65);} }
.lc-bartitle { font-size:.82rem; color:var(--tx-on-dark-2); font-weight:600; flex:1; }
.lc-time { font-family:var(--f-mono); font-size:.72rem; color:var(--tx-on-dark-3); display:inline-flex; align-items:center; gap:6px; }

.lc-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.lc-tile { position:relative; aspect-ratio:16/11; border-radius:12px; overflow:hidden; background:linear-gradient(135deg,#0E2350,#13315f); display:grid; place-items:center; border:1px solid rgba(127,208,255,.12); }
.lc-host img { width:100%; height:100%; object-fit:cover; }
.lc-ring { position:absolute; inset:0; border-radius:12px; border:2.5px solid var(--cyan); opacity:0; animation:lcRing 2.4s ease-out infinite; pointer-events:none; }
@keyframes lcRing { 0%{ opacity:.9; transform:scale(.985);} 100%{ opacity:0; transform:scale(1);} }
.lc-av { width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-family:var(--f-display); font-weight:700; font-size:1.05rem; color:#fff; }
.av-a { background:linear-gradient(135deg,#2E84FF,#34E2E4); }
.av-b { background:linear-gradient(135deg,#7C5CFC,#4FB4FF); }
.av-c { background:linear-gradient(135deg,#46587D,#6F86B3); }
.lc-name { position:absolute; bottom:7px; left:7px; display:inline-flex; align-items:center; gap:5px; font-size:.64rem; font-weight:600; color:#fff; background:rgba(4,9,26,.62); backdrop-filter:blur(4px); padding:3px 7px; border-radius:6px; }
.lc-name i { color:var(--cyan); font-size:.58rem; }
.lc-name-muted i { color:#FF6B7E; }

.lc-controls { display:flex; justify-content:center; gap:9px; margin-top:12px; }
.lc-ctrl { width:34px; height:34px; border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.08); color:#fff; font-size:.76rem; border:1px solid var(--line-dark); }
.lc-ctrl-hand { color:#FFD166; animation:lcHand 2.8s ease-in-out infinite; }
@keyframes lcHand { 0%,84%,100%{ transform:translateY(0) rotate(0);} 89%{ transform:translateY(-3px) rotate(-13deg);} 94%{ transform:translateY(-3px) rotate(13deg);} }
.lc-ctrl-leave { background:#E5484D; border-color:transparent; }

.lc-chat { position:absolute; left:5%; bottom:21%; z-index:3; max-width:72%; font-size:.76rem; color:#fff; background:rgba(8,16,40,.94); border:1px solid var(--line-dark); border-radius:10px 10px 10px 2px; padding:8px 12px; box-shadow:var(--shadow); animation:lcChat 6.5s ease-in-out infinite; }
.lc-chat b { color:var(--sky); margin-right:5px; }
@keyframes lcChat { 0%,6%{ opacity:0; transform:translateY(12px);} 14%,70%{ opacity:1; transform:translateY(0);} 80%,100%{ opacity:0; transform:translateY(-6px);} }

.lc-reaction { position:absolute; right:16%; bottom:32%; z-index:3; font-size:1.5rem; opacity:0; animation:lcReact 5.4s ease-in-out infinite; }
@keyframes lcReact { 0%,44%{ opacity:0; transform:translateY(20px) scale(.6);} 54%{ opacity:1; transform:translateY(0) scale(1);} 72%{ opacity:1;} 100%{ opacity:0; transform:translateY(-42px) scale(1);} }

.lc-badge { position:absolute; z-index:4; bottom:-14px; right:18px; display:inline-flex; align-items:center; gap:8px; background:#fff; color:var(--blue-700); font-size:.78rem; font-weight:700; padding:9px 15px; border-radius:30px; box-shadow:var(--shadow-lg); }
.lc-badge i { color:#4285F4; }

@media (max-width:900px){
  .live-grid { grid-template-columns:1fr; gap:40px; }
  .live-call { max-width:460px; width:100%; margin:0 auto; }
}

/* =============================================
   PLATAFORMA DE ESTUDOS
   ============================================= */
.sec-platform {
  background:
    radial-gradient(900px 520px at 50% -12%, rgba(46,132,255,.12), transparent 60%),
    linear-gradient(180deg, #E9F1FF 0%, #F6F9FF 55%, #FFFFFF 100%);
  color:var(--tx-on-light);
}
.platform-stage { position:relative; max-width:1000px; margin:0 auto; }
.ps-glow {
  position:absolute; inset:-4% 5% 6%; z-index:0; border-radius:40px;
  background:radial-gradient(circle at 50% 42%, rgba(46,132,255,.30), rgba(52,226,228,.12) 55%, transparent 75%);
  filter:blur(42px);
}

/* JANELA */
.platform-window {
  position:relative; z-index:2; background:#fff;
  border:1px solid rgba(20,60,130,.10); border-radius:18px; overflow:hidden;
  box-shadow:0 44px 96px rgba(12,40,95,.30), 0 6px 20px rgba(12,40,95,.12);
  animation:pwFloat 7s ease-in-out infinite;
}
@keyframes pwFloat { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-9px); } }

.pw-topbar { display:flex; align-items:center; justify-content:space-between; padding:11px 18px; background:linear-gradient(90deg, #1E6BEE, #2E84FF); }
.pw-brand { display:flex; align-items:center; gap:10px; color:#fff; font-weight:700; font-size:.95rem; }
.pw-logo { width:26px; height:26px; border-radius:7px; display:grid; place-items:center; background:rgba(255,255,255,.22); font-family:var(--f-display); font-weight:900; font-size:.7rem; }
.pw-bell { position:relative; color:#fff; font-size:1.05rem; }
.pw-ping { position:absolute; top:-2px; right:-3px; width:8px; height:8px; border-radius:50%; background:#34E2E4; animation:pwPing 1.8s ease-out infinite; }
@keyframes pwPing { 0%{ box-shadow:0 0 0 0 rgba(52,226,228,.6);} 70%{ box-shadow:0 0 0 7px rgba(52,226,228,0);} 100%{ box-shadow:0 0 0 0 rgba(52,226,228,0);} }

.pw-body { display:grid; grid-template-columns:152px 1fr; }
.pw-sidebar { background:linear-gradient(180deg, #1E6BEE, #1551B8); padding:16px 12px; color:#fff; }
.pw-user { display:flex; align-items:center; gap:9px; padding-bottom:13px; margin-bottom:10px; border-bottom:1px solid rgba(255,255,255,.18); font-weight:600; font-size:.84rem; }
.pw-avatar { width:28px; height:28px; border-radius:50%; background:rgba(255,255,255,.22); display:grid; place-items:center; font-size:.72rem; }
.pw-nav { display:flex; flex-direction:column; gap:3px; }
.pw-navitem { display:flex; align-items:center; gap:9px; padding:8px 10px; border-radius:8px; font-size:.79rem; color:rgba(255,255,255,.85); transition:var(--trans); cursor:pointer; }
.pw-navitem i { width:15px; font-size:.78rem; opacity:.9; }
.pw-navitem:hover { background:rgba(255,255,255,.14); color:#fff; }
.pw-navitem.active { background:#fff; color:var(--blue-700); font-weight:700; box-shadow:0 4px 12px rgba(0,0,0,.12); }
.pw-navlabel { font-family:var(--f-mono); font-size:.56rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.55); margin:15px 0 8px 10px; }

.pw-main { background:#F4F8FF; padding:16px; min-width:0; }
.pw-toolbar { display:flex; gap:10px; margin-bottom:14px; flex-wrap:wrap; }
.pw-select { display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid rgba(20,60,130,.14); border-radius:8px; padding:7px 12px; font-size:.75rem; color:var(--tx-on-light-2); font-weight:600; }
.pw-select i { font-size:.58rem; opacity:.6; }
.pw-content { display:grid; grid-template-columns:.85fr 1.25fr; gap:14px; }

.pw-lessons { display:flex; flex-direction:column; gap:8px; }
.pw-lesson { display:flex; align-items:center; gap:10px; background:#fff; border:1px solid rgba(20,60,130,.10); border-radius:10px; padding:8px; transition:var(--trans); cursor:pointer; }
.pw-lesson:hover { border-color:rgba(46,132,255,.5); transform:translateX(3px); box-shadow:0 6px 16px rgba(20,60,130,.10); }
.pw-thumb { flex-shrink:0; width:44px; height:33px; border-radius:6px; background:linear-gradient(135deg, #1E6BEE, #34E2E4); display:grid; place-items:center; color:#fff; font-size:.68rem; }
.pw-ltxt { display:flex; flex-direction:column; min-width:0; }
.pw-ltxt b { font-size:.78rem; color:var(--tx-on-light); font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pw-ltxt i { font-family:var(--f-mono); font-size:.62rem; color:var(--tx-on-light-2); font-style:normal; }
.pw-lesson.is-playing { background:linear-gradient(135deg, rgba(46,132,255,.10), rgba(52,226,228,.08)); border-color:rgba(46,132,255,.55); }
.pw-lesson.is-playing .pw-thumb { background:#0B2150; }
.pw-mini-eq { width:18px; height:14px; }
.pw-mini-eq rect { fill:#34E2E4; transform-box:fill-box; transform-origin:bottom; animation:eqBounce .9s ease-in-out infinite; }
.pw-mini-eq .b2 { animation-delay:.2s; } .pw-mini-eq .b3 { animation-delay:.4s; }

.pw-player { background:#000; border-radius:10px; overflow:hidden; box-shadow:0 12px 28px rgba(0,0,0,.28); align-self:start; }
.pw-screen { display:block; width:100%; height:auto; }
.pw-screen-kicker { fill:#7FD0FF; font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; font-weight:700; }
.pw-screen-title { fill:#fff; font-family:var(--f-display); font-weight:700; font-size:26px; opacity:.94; }
.pw-screen-sweep { animation:pwSweep 3.8s ease-in-out infinite; }
@keyframes pwSweep { 0%{ transform:translateX(0);} 100%{ transform:translateX(720px);} }
.pw-pulse { transform-box:fill-box; transform-origin:center; animation:pwPulse 2.4s ease-out infinite; }
.pw-pulse2 { animation-delay:1.2s; }
@keyframes pwPulse { 0%{ transform:scale(.55); opacity:.85;} 100%{ transform:scale(1.55); opacity:0;} }
.pw-eq rect { transform-box:fill-box; transform-origin:bottom; animation:eqBounce 1.1s ease-in-out infinite; }
.pw-eq .e2{animation-delay:.12s}.pw-eq .e3{animation-delay:.24s}.pw-eq .e4{animation-delay:.36s}.pw-eq .e5{animation-delay:.46s}.pw-eq .e6{animation-delay:.30s}.pw-eq .e7{animation-delay:.16s}.pw-eq .e8{animation-delay:.06s}
@keyframes eqBounce { 0%,100%{ transform:scaleY(.28);} 50%{ transform:scaleY(1);} }

.pw-controls { display:flex; align-items:center; gap:10px; padding:9px 13px; background:#0A1426; color:#fff; }
.pw-ctrl-play { width:26px; height:26px; border-radius:50%; background:#2E84FF; display:grid; place-items:center; font-size:.62rem; flex-shrink:0; }
.pw-progress { flex:1; height:5px; border-radius:3px; background:rgba(255,255,255,.18); overflow:hidden; }
.pw-progress-fill { display:block; height:100%; width:34%; border-radius:3px; background:linear-gradient(90deg,#2E84FF,#34E2E4); animation:pwProg 9s linear infinite; }
@keyframes pwProg { 0%{ width:8%;} 100%{ width:96%;} }
.pw-time { font-family:var(--f-mono); font-size:.67rem; color:rgba(255,255,255,.8); }
.pw-controls > i { font-size:.76rem; color:rgba(255,255,255,.7); }

.pw-cursor { position:absolute; width:22px; height:22px; z-index:6; pointer-events:none; filter:drop-shadow(0 3px 5px rgba(0,0,0,.3)); animation:pwCursor 7.5s ease-in-out infinite; }
@keyframes pwCursor {
  0%   { left:62%; top:72%; opacity:0; transform:scale(1); }
  10%  { opacity:1; }
  36%  { left:43%; top:52%; transform:scale(1); }
  43%  { transform:scale(.82); }
  50%  { transform:scale(1); }
  74%  { left:23%; top:44%; opacity:1; }
  90%  { left:23%; top:44%; opacity:0; }
  100% { opacity:0; }
}

.ps-badge { position:absolute; z-index:5; display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid rgba(20,60,130,.08); border-radius:30px; padding:9px 15px; font-size:.8rem; font-weight:700; color:var(--blue-700); box-shadow:0 16px 38px rgba(20,60,130,.16); }
.ps-badge i { color:var(--blue-600); }
.ps-b1 { top:7%; left:-3%; animation:pwFloat 6s ease-in-out infinite; }
.ps-b2 { bottom:16%; right:-3%; animation:pwFloat 6.6s ease-in-out .7s infinite; }

.platform-features { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:56px; }
.pfeat { background:#fff; border:1px solid var(--line-light); border-radius:var(--radius); padding:24px 22px; box-shadow:var(--shadow-sm); transition:var(--trans); }
.pfeat:hover { transform:translateY(-6px); box-shadow:var(--shadow); }
.pfeat-ico { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; font-size:1.12rem; color:#fff; background:var(--grad-vivid); margin-bottom:14px; }
.pfeat h4 { font-family:var(--f-display); font-weight:600; font-size:1.04rem; color:var(--tx-on-light); margin-bottom:7px; line-height:1.2; }
.pfeat p { font-size:.88rem; color:var(--tx-on-light-2); line-height:1.55; }

@media (max-width:980px){
  .platform-features { grid-template-columns:repeat(2,1fr); }
  .ps-badge { display:none; }
}
@media (max-width:760px){
  .pw-sidebar, .pw-cursor { display:none; }
  .pw-body { grid-template-columns:1fr; }
  .pw-content { grid-template-columns:1fr; }
  .pw-lessons { order:2; }
  .pw-player { order:1; }
  .platform-features { grid-template-columns:1fr; }
}
@media (prefers-reduced-motion: reduce){
  .platform-window, .ps-b1, .ps-b2, .pw-cursor, .pw-screen-sweep, .pw-pulse, .pw-progress-fill, .pw-eq rect, .pw-mini-eq rect, .pw-ping { animation:none !important; }
}

/* =============================================
   AUTORIDADE
   ============================================= */
.auth-grid { display:grid; grid-template-columns:.9fr 1.1fr; gap:60px; align-items:center; margin-bottom:84px; }

.auth-photo-frame { position:relative; max-width:420px; }
.auth-photo-glow {
  position:absolute; inset:-20px; z-index:0; border-radius:30px;
  background:radial-gradient(circle at 30% 30%, rgba(52,226,228,.3), rgba(30,107,238,.18) 55%, transparent 75%);
  filter:blur(18px);
}
.auth-photo {
  position:relative; z-index:1; width:100%; border-radius:var(--radius-lg);
  border:1px solid var(--line-dark); box-shadow:var(--shadow-lg);
}
.auth-badge {
  position:absolute; z-index:2; bottom:-18px; right:-14px;
  display:flex; align-items:center; gap:12px;
  background:rgba(10,21,48,.86); backdrop-filter:blur(14px);
  border:1px solid var(--line-dark); border-radius:14px; padding:14px 18px;
  box-shadow:var(--shadow-lg);
}
.auth-badge i { color:var(--cyan); font-size:1.5rem; }
.auth-badge strong { display:block; font-size:1rem; color:#fff; font-weight:700; }
.auth-badge span { font-size:.76rem; color:var(--tx-on-dark-2); }

.auth-content-col .kicker { margin-bottom:14px; }
.auth-content-col .sec-title { margin-bottom:6px; }
.auth-role { font-family:var(--f-mono); font-size:.82rem; letter-spacing:.04em; color:var(--sky); margin-bottom:22px; }
.auth-lead { font-size:1.12rem; line-height:1.6; color:var(--tx-on-dark); margin-bottom:16px; }
.auth-lead strong { color:#fff; }
.auth-text { font-size:1rem; line-height:1.7; color:var(--tx-on-dark-2); margin-bottom:30px; }

.auth-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.as-item {
  text-align:center; padding:18px 8px; border-radius:14px;
  background:rgba(255,255,255,.03); border:1px solid var(--line-dark);
}
.as-n { display:block; font-family:var(--f-display); font-weight:700; font-size:1.7rem; line-height:1;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.as-l { font-size:.74rem; color:var(--tx-on-dark-2); margin-top:6px; }

/* Proof */
.proof-head { text-align:center; margin-bottom:38px; }
.proof-head .kicker { justify-content:center; margin-bottom:12px; }
.proof-title { font-family:var(--f-display); font-weight:600; font-size:1.9rem; color:#fff; }

.proof-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-bottom:84px; }
.proof-card {
  background:rgba(10,21,48,.55); border:1px solid var(--line-dark);
  border-radius:var(--radius); overflow:hidden; transition:var(--trans); backdrop-filter:blur(6px);
}
.proof-card:hover { transform:translateY(-7px); border-color:rgba(127,208,255,.3); box-shadow:var(--shadow-lg); }
.proof-img { position:relative; height:180px; overflow:hidden; }
.proof-img img { width:100%; height:100%; object-fit:cover; transition:var(--trans); }
.proof-card:hover .proof-img img { transform:scale(1.06); }
.proof-tag {
  position:absolute; top:12px; right:12px; z-index:2;
  font-size:.72rem; font-weight:700; color:#fff;
  padding:5px 11px; border-radius:20px; display:inline-flex; align-items:center; gap:6px;
  background:rgba(4,9,26,.7); backdrop-filter:blur(8px); border:1px solid var(--line-dark);
}
.proof-tag.ok i { color:#34E2A8; font-size:.5rem; }
.proof-body { padding:22px 22px 24px; }
.proof-min { font-family:var(--f-mono); font-size:.72rem; color:var(--sky); display:inline-flex; align-items:center; gap:7px; margin-bottom:10px; }
.proof-body h4 { font-family:var(--f-display); font-weight:600; font-size:1.16rem; line-height:1.25; color:#fff; margin-bottom:9px; }
.proof-body p { font-size:.9rem; color:var(--tx-on-dark-2); line-height:1.55; margin-bottom:14px; }
.proof-loc { font-size:.8rem; color:var(--tx-on-dark-3); display:inline-flex; align-items:center; gap:7px; }
.proof-loc i { color:var(--sky); }

/* Map */
.map-block { display:grid; grid-template-columns:1.3fr 1fr; gap:40px; align-items:center; }
.map-canvas-wrap {
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid var(--line-dark); background:var(--bg-darkest);
  box-shadow:var(--shadow-lg); min-height:360px;
}
#brazil-map { width:100%; }
#brazil-map svg { width:100%; height:auto; display:block; }

.map-popup {
  position:absolute; z-index:10; width:268px; pointer-events:none;
  background:rgba(8,16,40,.94); backdrop-filter:blur(16px);
  border:1px solid var(--line-dark); border-radius:14px; padding:16px 18px;
  box-shadow:var(--shadow-lg);
  opacity:0; transform:translateY(8px) scale(.97); transition:opacity .2s, transform .2s;
}
.map-popup.visible { opacity:1; transform:translateY(0) scale(1); }
.popup-city-name { display:block; font-family:var(--f-display); font-weight:600; font-size:1.05rem; color:#fff; margin-bottom:6px; }
.popup-status-row { font-size:.82rem; font-weight:700; margin-bottom:10px; }
.popup-detail-row { display:flex; align-items:flex-start; gap:9px; font-size:.82rem; color:var(--tx-on-dark-2); margin-top:6px; }
.popup-detail-row i { color:var(--sky); margin-top:3px; font-size:.75rem; }

.map-side .kicker { margin-bottom:14px; }
.map-side-title { font-family:var(--f-display); font-weight:600; font-size:1.7rem; color:#fff; margin-bottom:12px; }
.map-side-desc { font-size:.98rem; color:var(--tx-on-dark-2); line-height:1.6; margin-bottom:22px; }
.map-city-list { display:flex; flex-direction:column; gap:8px; max-height:280px; overflow-y:auto; padding-right:6px; }
.map-city-item {
  display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:11px;
  background:rgba(255,255,255,.03); border:1px solid var(--line-dark); cursor:pointer; transition:var(--trans);
}
.map-city-item:hover { background:rgba(46,132,255,.10); border-color:rgba(127,208,255,.3); transform:translateX(4px); }
.map-city-pin { width:30px; height:30px; border-radius:8px; display:grid; place-items:center; background:rgba(46,132,255,.16); color:var(--sky); font-size:.85rem; flex-shrink:0; }
.map-city-info { flex:1; min-width:0; }
.map-city-name-text { font-size:.9rem; font-weight:600; color:#fff; }
.map-city-status { font-size:.74rem; color:var(--tx-on-dark-2); display:flex; align-items:center; gap:6px; }
.mci-status { width:7px; height:7px; border-radius:50%; }
.mci-status.blue { background:var(--sky); box-shadow:0 0 7px var(--sky); }
.mci-status.cyan { background:var(--cyan); box-shadow:0 0 7px var(--cyan); }
.map-city-uf-badge { font-family:var(--f-mono); font-size:.68rem; font-weight:700; color:var(--sky); padding:3px 8px; border-radius:6px; background:rgba(46,132,255,.12); }
.map-city-more { font-size:.8rem; color:var(--tx-on-dark-3); margin-top:14px; font-style:italic; }

/* =============================================
   PLANOS
   ============================================= */
.plans-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch; }
.plan-card {
  display:flex; flex-direction:column;
  background:var(--white); border:1px solid var(--line-light);
  border-radius:var(--radius-lg); padding:34px 30px;
  box-shadow:var(--shadow-sm); transition:var(--trans); position:relative;
}
.plan-card:hover { transform:translateY(-8px); box-shadow:var(--shadow); }
.plan-card.featured {
  background:linear-gradient(180deg, #0A1530, #0C1C40);
  border:1px solid rgba(127,208,255,.34);
  box-shadow:var(--shadow-blue);
  transform:scale(1.03);
}
.plan-card.featured:hover { transform:scale(1.03) translateY(-8px); }

.plan-flag {
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  font-family:var(--f-mono); font-size:.72rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  color:#04091A; background:var(--grad-blue); padding:7px 18px; border-radius:30px;
  box-shadow:0 8px 22px rgba(52,226,228,.4); white-space:nowrap;
}
.plan-for { font-size:.84rem; font-weight:600; color:var(--blue-600); line-height:1.3; display:block; margin-bottom:14px; min-height:36px; }
.featured .plan-for { color:var(--sky-2); }
.plan-level { font-family:var(--f-mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--tx-on-light-2); }
.featured .plan-level { color:var(--tx-on-dark-2); }
.plan-name { font-family:var(--f-display); font-weight:700; font-size:1.55rem; line-height:1.1; margin:6px 0 8px; color:var(--tx-on-light); }
.featured .plan-name { color:#fff; }
.plan-sub { font-size:.92rem; color:var(--tx-on-light-2); line-height:1.5; margin-bottom:22px; min-height:42px; }
.featured .plan-sub { color:var(--tx-on-dark-2); }

.plan-benefits { display:flex; flex-direction:column; gap:11px; padding:22px 0; border-top:1px solid var(--line-light); margin-bottom:6px; flex:1; }
.featured .plan-benefits { border-top-color:var(--line-dark); }
.plan-benefits li { position:relative; padding-left:28px; font-size:.9rem; line-height:1.45; color:var(--tx-on-light); }
.featured .plan-benefits li { color:var(--tx-on-dark); }
.plan-benefits li::before {
  content:"\f00c"; font-family:"Font Awesome 6 Free"; font-weight:900;
  position:absolute; left:0; top:1px; font-size:.7rem; color:#fff;
  width:17px; height:17px; border-radius:50%; display:grid; place-items:center;
  background:var(--grad-blue);
}

.plan-price { padding:18px 0 22px; }
.pp-main { display:flex; align-items:flex-end; gap:3px; line-height:1; }
.pp-rs { font-size:1.05rem; font-weight:700; color:var(--tx-on-light-2); margin-bottom:7px; }
.featured .pp-rs { color:var(--tx-on-dark-2); }
.pp-val { font-family:var(--f-display); font-weight:700; font-size:2.7rem; color:var(--tx-on-light); }
.featured .pp-val { color:#fff; }
.pp-per { font-size:1rem; color:var(--tx-on-light-2); margin-bottom:7px; font-weight:600; }
.featured .pp-per { color:var(--tx-on-dark-2); }
.pp-note { display:block; font-size:.82rem; color:var(--tx-on-light-2); margin-top:8px; }
.featured .pp-note { color:var(--sky-2); }

.btn-plan {
  width:100%; padding:15px; border-radius:12px;
  background:rgba(30,107,238,.08); color:var(--blue-700); font-weight:700;
  border:1.5px solid rgba(30,107,238,.25);
}
.btn-plan:hover { background:var(--blue-700); color:#fff; transform:translateY(-2px); border-color:var(--blue-700); }
.btn-plan-hot { background:var(--grad-vivid); color:#fff; border:none; box-shadow:var(--shadow-blue); }
.btn-plan-hot:hover { color:#fff; box-shadow:0 26px 64px rgba(52,226,228,.4); }

.plans-guarantee {
  display:flex; align-items:center; justify-content:center; gap:11px;
  margin-top:40px; font-size:.95rem; color:var(--tx-on-light-2);
}
.plans-guarantee i { color:var(--blue-600); font-size:1.1rem; }

/* dropdown comparativo dos planos */
.plans-diff {
  max-width:1000px; margin:26px auto 0;
  background:#fff; border:1px solid var(--line-light); border-radius:18px;
  box-shadow:var(--shadow-sm); overflow:hidden; transition:var(--trans);
}
.plans-diff[open] { box-shadow:var(--shadow); border-color:rgba(30,107,238,.22); }
.plans-diff summary {
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:18px 26px; cursor:pointer; list-style:none;
  font-family:var(--f-display); font-weight:600; font-size:1.1rem; color:var(--tx-on-light);
  transition:var(--trans);
}
.plans-diff summary:hover { background:#F7FAFF; }
.plans-diff summary::-webkit-details-marker { display:none; }
.pd-sum-label { display:inline-flex; align-items:center; gap:13px; }
.summary-ico { width:34px; height:34px; border-radius:10px; display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(30,107,238,.14), rgba(52,226,228,.12)); color:var(--blue-600); font-size:.9rem; }
.pd-chevron { color:var(--blue-600); font-size:.95rem; transition:transform .35s; }
.plans-diff[open] .pd-chevron { transform:rotate(180deg); }

.pd-body { padding:8px 22px 24px; }
.plans-diff[open] .pd-body { animation:pdOpen .4s ease; }
@keyframes pdOpen { from { opacity:0; transform:translateY(-10px); } to { opacity:1; transform:translateY(0); } }

.pd-legend { display:flex; flex-wrap:wrap; gap:8px 20px; justify-content:center; margin:4px 0 18px; font-size:.78rem; color:var(--tx-on-light-2); font-weight:500; }
.pd-legend span { display:inline-flex; align-items:center; gap:7px; }
.pd-legend i { font-size:.72rem; }
.l-yes { color:#16A34A; } .l-part { color:#D9870A; } .l-no { color:#9AA7BD; } .l-info { color:var(--blue-600); }

.pd-hint { display:none; align-items:center; justify-content:center; gap:8px; font-size:.78rem; color:var(--blue-600); margin-bottom:12px; font-weight:600; }
.pd-scroll { overflow-x:auto; padding:2px; }

.diff-table { width:100%; border-collapse:separate; border-spacing:0; min-width:660px; }

/* corner + headers */
.dt-corner {
  text-align:left; vertical-align:bottom; padding:0 16px 16px;
  font-family:var(--f-mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--tx-on-light-2); font-weight:700;
  position:sticky; left:0; z-index:3; background:#fff;
}
.dt-plan { vertical-align:bottom; text-align:center; padding:16px 16px 16px; border-bottom:2px solid var(--line-light); }
.dt-name { display:block; font-family:var(--f-display); font-weight:700; font-size:1.05rem; color:var(--tx-on-light); line-height:1.16; }
.dt-tier { display:block; font-family:var(--f-mono); font-size:.62rem; letter-spacing:.03em; text-transform:uppercase; color:var(--tx-on-light-2); margin-top:6px; }
.dt-flag { display:inline-flex; align-items:center; gap:5px; font-family:var(--f-mono); font-size:.58rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:#06203f; background:var(--grad-blue); padding:4px 10px; border-radius:20px; margin-bottom:9px; }
.dt-flag i { font-size:.6rem; }

/* coluna em destaque — faixa contínua */
.dt-hot { background:rgba(46,132,255,.06); box-shadow:inset 1px 0 0 rgba(46,132,255,.22), inset -1px 0 0 rgba(46,132,255,.22); }
.diff-table thead th.dt-hot { background:linear-gradient(180deg, rgba(46,132,255,.16), rgba(46,132,255,.06)); border-bottom:2px solid var(--blue-500); border-radius:14px 14px 0 0; box-shadow:inset 1px 0 0 rgba(46,132,255,.22), inset -1px 0 0 rgba(46,132,255,.22), inset 0 3px 0 var(--blue-500); }
.dt-hot .dt-name { color:var(--blue-700); }

/* body */
.diff-table tbody th {
  position:sticky; left:0; z-index:2;
  text-align:left; font-weight:600; color:var(--tx-on-light);
  padding:14px 16px; background:#fff; font-size:.85rem; white-space:nowrap;
  border-top:1px solid var(--line-light);
}
.diff-table tbody td { text-align:center; padding:14px 16px; font-size:.85rem; color:var(--tx-on-light); border-top:1px solid var(--line-light); }
.diff-table tbody tr:nth-child(even) th,
.diff-table tbody tr:nth-child(even) td:not(.dt-hot) { background:#F7FAFF; }

/* indicadores */
.di { display:inline-flex; align-items:center; gap:9px; text-align:left; }
.di > i { flex-shrink:0; width:20px; height:20px; border-radius:50%; display:grid; place-items:center; font-size:.62rem; }
.di-yes > i { background:rgba(34,197,94,.15); color:#16A34A; }
.di-no { color:var(--tx-on-light-2); }
.di-no > i { background:rgba(150,163,189,.16); color:#9AA7BD; }
.di-part > i { background:rgba(244,160,40,.18); color:#D9870A; }
.di-info { color:var(--tx-on-light-2); }
.di-info > i { background:rgba(46,132,255,.13); color:var(--blue-600); }
.di-plain { color:var(--tx-on-light-2); font-weight:500; }

/* rodapé de preço */
.diff-table tfoot th {
  position:sticky; left:0; z-index:2; text-align:left; background:#fff;
  padding:18px 16px; font-family:var(--f-mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--tx-on-light-2); font-weight:700; border-top:2px solid var(--line-light);
}
.diff-table tfoot td { text-align:center; padding:18px 16px; border-top:2px solid var(--line-light); }
.diff-table tfoot td.dt-hot { border-radius:0 0 14px 14px; box-shadow:inset 1px 0 0 rgba(46,132,255,.22), inset -1px 0 0 rgba(46,132,255,.22), inset 0 -1px 0 rgba(46,132,255,.22); }
.dt-price { font-family:var(--f-display); font-weight:800; font-size:1.14rem; color:var(--tx-on-light); line-height:1.1; }
.dt-price small { display:block; font-family:var(--f-body); font-weight:500; font-size:.68rem; color:var(--tx-on-light-2); margin-top:3px; letter-spacing:0; text-transform:none; }
.dt-hot .dt-price { color:var(--blue-700); }

@media (max-width:680px){
  .pd-hint { display:flex; }
  .plans-diff summary { font-size:1rem; padding:16px 18px; }
  .pd-body { padding:8px 14px 18px; }
  .diff-table tbody th, .dt-corner, .diff-table tfoot th { box-shadow:8px 0 14px -10px rgba(20,60,130,.22); }
}

/* =============================================
   CLUBE
   ============================================= */
.sec-club { background:linear-gradient(135deg, #061233 0%, #0A1E4C 55%, #062A4A 100%); padding:100px 0; }
.club-glow {
  position:absolute; top:-30%; right:-5%; width:600px; height:600px; z-index:0; pointer-events:none;
  background:radial-gradient(circle, rgba(52,226,228,.22), transparent 65%); filter:blur(60px);
}
.club-card {
  display:grid; grid-template-columns:1.5fr 1fr; gap:46px; align-items:center;
  background:rgba(5,12,32,.5); border:1px solid rgba(127,208,255,.22);
  border-radius:var(--radius-xl); padding:48px 50px; backdrop-filter:blur(10px);
  box-shadow:var(--shadow-lg);
}
.club-left .kicker { margin-bottom:16px; }
.club-title { font-family:var(--f-display); font-weight:700; font-size:clamp(1.8rem,3.4vw,2.6rem); color:#fff; margin-bottom:16px; line-height:1.08; }
.club-lead { font-size:1.08rem; line-height:1.62; color:var(--tx-on-dark-2); margin-bottom:24px; }
.club-lead strong { color:#fff; }
.club-benefits { display:grid; grid-template-columns:1fr 1fr; gap:12px 22px; margin-bottom:22px; }
.club-benefits li { display:flex; align-items:flex-start; gap:10px; font-size:.93rem; color:var(--tx-on-dark); line-height:1.4; }
.club-benefits i { color:var(--cyan); margin-top:3px; font-size:.9rem; }
.club-note { font-size:.86rem; color:var(--tx-on-dark-3); font-style:italic; }

.club-price-box {
  background:rgba(255,255,255,.04); border:1px solid rgba(127,208,255,.26);
  border-radius:var(--radius-lg); padding:32px 28px; text-align:center;
}
.cpb-label { font-family:var(--f-mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--sky); }
.cpb-price { display:flex; align-items:flex-end; justify-content:center; gap:3px; margin:10px 0 22px; line-height:1; }
.cpb-rs { font-size:1.1rem; font-weight:700; color:var(--tx-on-dark-2); margin-bottom:8px; }
.cpb-val { font-family:var(--f-display); font-weight:700; font-size:3.4rem; color:#fff; }
.cpb-per { font-size:1.1rem; color:var(--tx-on-dark-2); margin-bottom:9px; font-weight:600; }
.btn-club { width:100%; background:var(--grad-vivid); color:#fff; padding:15px; border-radius:12px; box-shadow:var(--shadow-blue); }
.btn-club:hover { transform:translateY(-3px); box-shadow:0 26px 64px rgba(52,226,228,.42); }
.club-talk { display:inline-flex; align-items:center; gap:8px; margin-top:16px; font-size:.86rem; color:var(--tx-on-dark-2); font-weight:600; }
.club-talk:hover { color:var(--cyan); }

/* =============================================
   FAQ
   ============================================= */
.faq-list { display:flex; flex-direction:column; gap:13px; }
.faq-item {
  background:var(--white); border:1px solid var(--line-light);
  border-radius:14px; overflow:hidden; transition:var(--trans);
}
.faq-item[open] { border-color:rgba(30,107,238,.3); box-shadow:var(--shadow-sm); }
.faq-item summary {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:21px 24px; cursor:pointer; list-style:none;
  font-family:var(--f-display); font-weight:600; font-size:1.08rem; color:var(--tx-on-light);
}
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary i { color:var(--blue-600); font-size:.9rem; transition:var(--trans); flex-shrink:0; }
.faq-item[open] summary i { transform:rotate(45deg); }
.faq-a { padding:0 24px 22px; }
.faq-a p { font-size:.96rem; color:var(--tx-on-light-2); line-height:1.65; }

.faq-cta { text-align:center; margin-top:42px; }
.faq-cta p { font-size:1rem; color:var(--tx-on-light-2); margin-bottom:14px; }
.faq-cta .btn-outline { color:var(--blue-700); border-color:rgba(30,107,238,.3); background:rgba(30,107,238,.05); }
.faq-cta .btn-outline:hover { background:var(--blue-700); color:#fff; border-color:var(--blue-700); }

/* =============================================
   CTA FINAL
   ============================================= */
.final-cta { text-align:center; }
.final-inner { max-width:760px; margin:0 auto; }
.final-inner h2 { font-family:var(--f-display); font-weight:600; font-size:clamp(2rem,4.4vw,3.2rem); color:#fff; line-height:1.1; margin-bottom:18px; letter-spacing:-.02em; }
.final-inner p { font-size:1.14rem; color:var(--tx-on-dark-2); margin-bottom:34px; line-height:1.6; }
.final-ctas { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* =============================================
   FOOTER
   ============================================= */
#contato { background:var(--bg-darkest); color:var(--tx-on-dark); padding:72px 0 30px; position:relative; z-index:2; border-top:1px solid var(--line-dark); }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1.3fr; gap:46px; margin-bottom:46px; }
.footer-brand .nav-logo { margin-bottom:18px; }
.footer-brand p { font-size:.95rem; color:var(--tx-on-dark-2); line-height:1.65; max-width:340px; margin-bottom:20px; }
.f-social { display:flex; gap:11px; }
.f-social a { width:40px; height:40px; border-radius:11px; display:grid; place-items:center; background:rgba(255,255,255,.04); border:1px solid var(--line-dark); color:var(--tx-on-dark-2); transition:var(--trans); }
.f-social a:hover { background:var(--grad-vivid); color:#fff; transform:translateY(-3px); border-color:transparent; }
.footer-col h5 { font-family:var(--f-mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--sky); margin-bottom:18px; }
.footer-col ul { display:flex; flex-direction:column; gap:11px; }
.footer-col ul a { font-size:.93rem; color:var(--tx-on-dark-2); transition:var(--trans); }
.footer-col ul a:hover { color:#fff; padding-left:4px; }
.f-citem { font-size:.9rem; color:var(--tx-on-dark-2); display:flex; align-items:center; gap:10px; margin-bottom:11px; }
.f-citem i { color:var(--sky); width:16px; }
.f-cnpj { font-family:var(--f-mono); font-size:.78rem; color:var(--tx-on-dark-3); margin-top:14px; }
.footer-bottom { border-top:1px solid var(--line-dark); padding-top:24px; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.footer-bottom p { font-size:.82rem; color:var(--tx-on-dark-3); }

/* Floats */
.wa-float {
  position:fixed; bottom:26px; right:26px; z-index:900;
  width:58px; height:58px; border-radius:50%; display:grid; place-items:center;
  background:#25D366; color:#fff; font-size:1.6rem;
  box-shadow:0 10px 30px rgba(37,211,102,.45); transition:var(--trans);
  animation:waPulse 2.6s ease-in-out infinite;
}
.wa-float:hover { transform:scale(1.1); }
@keyframes waPulse { 0%,100%{ box-shadow:0 10px 30px rgba(37,211,102,.45);} 50%{ box-shadow:0 10px 40px rgba(37,211,102,.7);} }

#backTop {
  position:fixed; bottom:96px; right:30px; z-index:899;
  width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
  background:rgba(10,21,48,.8); backdrop-filter:blur(8px); border:1px solid var(--line-dark);
  color:#fff; opacity:0; pointer-events:none; transform:translateY(12px); transition:var(--trans);
}
#backTop.visible { opacity:1; pointer-events:auto; transform:translateY(0); }
#backTop:hover { background:var(--blue-700); }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width:1080px){
  .audience-grid { grid-template-columns:1fr 1fr; }
  .learn-grid { grid-template-columns:1fr 1fr; }
  .proof-grid { grid-template-columns:1fr 1fr; }
  .auth-grid { grid-template-columns:1fr; gap:46px; }
  .auth-photo-frame { max-width:380px; margin:0 auto; }
  .map-block { grid-template-columns:1fr; gap:30px; }
  .club-card { grid-template-columns:1fr; gap:32px; }
}

@media (max-width:920px){
  .nav-menu, .nav-inscrever { display:none; }
  .nav-toggle { display:flex; }
  .btn-area { padding:11px 16px; font-size:.88rem; }
  .nav-menu {
    position:fixed; top:0; right:-100%; width:82%; max-width:340px; height:100vh;
    flex-direction:column; gap:6px; padding:92px 26px 28px;
    background:rgba(255,255,255,.98); backdrop-filter:blur(20px);
    border-left:1px solid var(--line-light); box-shadow:-20px 0 60px rgba(20,60,130,.12);
    transition:right .4s cubic-bezier(.4,0,.2,1); z-index:998;
  }
  .nav-menu.open { right:0; display:flex; }
  .nav-menu li { width:100%; }
  .nav-link { display:block; padding:14px 0; font-size:1.05rem; border-bottom:1px solid var(--line-light); }
  .nav-menu-cta { display:block; margin-top:18px; }
  .nav-menu-cta .btn { width:100%; justify-content:center; }

  .hero-grid { grid-template-columns:1fr; gap:42px; text-align:center; }
  .hero-left .kicker, .hero-trust { justify-content:center; align-items:center; }
  .hero-bullets { max-width:420px; margin-left:auto; margin-right:auto; }
  .hero-sub { margin-left:auto; margin-right:auto; }
  .hero-ctas, .ht-pills { justify-content:center; }
  .hero-photo { display:none; }
  .hero-metrics-mobile {
    display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:6px; max-width:480px; margin-left:auto; margin-right:auto;
  }
  .hmm { padding:16px 6px; border-radius:14px; background:#fff; border:1px solid var(--line-light); box-shadow:var(--shadow-sm); }
  .hmm-n { display:block; font-family:var(--f-display); font-weight:700; font-size:1.5rem; color:var(--blue-600); }
  .hmm-l { font-size:.68rem; color:var(--tx-on-light-2); }
}

@media (max-width:680px){
  .sec { padding:74px 0; }
  .container { padding:0 18px; }
  .audience-grid, .learn-grid, .proof-grid, .plans-grid, .pain-grid, .club-benefits, .auth-stats { grid-template-columns:1fr; }
  .auth-stats, .hero-metrics-mobile { grid-template-columns:repeat(2,1fr); }
  .plan-card.featured { transform:scale(1); }
  .plan-card.featured:hover { transform:translateY(-8px); }
  .club-card { padding:34px 24px; }
  .club-benefits { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:34px; }
  .footer-bottom { flex-direction:column; }
  .plan-for, .plan-sub { min-height:0; }
  .hero-headline { font-size:2.2rem; }
  .pain-turn { font-size:1.15rem; }
  .wa-float { width:52px; height:52px; font-size:1.4rem; bottom:18px; right:18px; }
  #backTop { bottom:80px; right:20px; }
}

/* anim base states (set by GSAP, fallback visible) */
.no-js .anim-up, .no-js .anim-fade-left, .no-js .anim-fade-right { opacity:1 !important; }
