/* ============================================================
   O SNIPER - Página do Curso (Método Sniper em Prospecção)
   Design System claro: branco/cinza alternados, texto preto, verde + azul.
   ============================================================ */

:root {
  --white:#ffffff; --gray-bg:#f3f5f8; --gray-card:#ffffff; --gray-soft:#f7f9fb;
  --border:#e5e9ef; --border-strong:#d8dee7;
  --ink:#14181f; --ink-2:#3a414d; --ink-3:#6b7280;
  --green:#00B863; --green-dark:#009a53; --green-soft:#e6f7ef; --green-line:rgba(0,184,99,0.30);
  --blue:#2f6fe0; --blue-dark:#2560c6; --blue-soft:#e8f0fe; --blue-line:rgba(47,111,224,0.28);
  --red:#e05260; --red-soft:#fdecee; --amber:#f59e0b;
  --font-display:'Plus Jakarta Sans',sans-serif; --font-body:'DM Sans',sans-serif;
}

*,*::before,*::after{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ font-family:var(--font-body); background:var(--white); color:var(--ink-2); overflow-x:hidden; -webkit-font-smoothing:antialiased; }

/* ---------- NAVBAR ---------- */
.navbar{ position:fixed; top:0; left:0; right:0; z-index:1000; height:68px; display:flex; align-items:center; justify-content:space-between; padding:0 40px; background:rgba(255,255,255,0.86); backdrop-filter:blur(20px); border-bottom:1px solid var(--border); }
.nav-logo{ font-family:var(--font-display); font-size:21px; font-weight:900; color:var(--ink); text-decoration:none; letter-spacing:-0.5px; }
.nav-logo span{ color:var(--green); }
.nav-links{ display:flex; gap:28px; list-style:none; align-items:center; }
.nav-links a{ font-size:13px; font-weight:600; color:var(--ink-3); text-decoration:none; transition:color 0.2s; }
.nav-links a:hover{ color:var(--ink); }
.nav-cta{ display:inline-flex; align-items:center; padding:10px 20px; background:var(--green); color:#fff !important; border-radius:8px; font-weight:700 !important; font-size:12px !important; letter-spacing:0.03em; transition:all 0.25s !important; font-family:var(--font-display); text-decoration:none; }
.nav-cta:hover{ background:var(--green-dark) !important; transform:translateY(-1px); box-shadow:0 6px 18px rgba(0,184,99,0.28); }
.mobile-toggle{ display:none; background:none; border:none; cursor:pointer; width:26px; height:18px; position:relative; }
.mobile-toggle span{ display:block; width:100%; height:2px; background:var(--ink); border-radius:2px; position:absolute; left:0; transition:all 0.3s; }
.mobile-toggle span:nth-child(1){ top:0; } .mobile-toggle span:nth-child(2){ top:8px; } .mobile-toggle span:nth-child(3){ top:16px; }

/* ---------- BASE SEÇÕES ---------- */
section{ padding:96px 60px; position:relative; }
.bg-white{ background:var(--white); }
.bg-gray{ background:var(--gray-bg); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.section-label{ font-size:11px; font-weight:800; color:var(--blue); letter-spacing:0.16em; text-transform:uppercase; margin-bottom:12px; }
.section-title{ font-family:var(--font-display); font-size:clamp(27px,3.8vw,44px); font-weight:800; color:var(--ink); letter-spacing:-0.03em; line-height:1.14; margin-bottom:16px; }
.section-title em{ font-style:normal; color:var(--green); }
.section-desc{ font-size:16.5px; color:var(--ink-3); line-height:1.7; max-width:680px; }

/* ---------- BOTÃO ---------- */
.btn-primary{ display:inline-flex; align-items:center; gap:10px; padding:18px 44px; background:var(--green); color:#fff; border-radius:12px; font-family:var(--font-display); font-weight:700; font-size:16px; text-decoration:none; border:none; cursor:pointer; transition:all 0.25s; }
.btn-primary:hover{ background:var(--green-dark); transform:translateY(-2px); box-shadow:0 14px 30px rgba(0,184,99,0.30); }

/* ---------- HERO ---------- */
.hero{ min-height:100vh; display:flex; align-items:center; justify-content:center; padding:120px 60px 80px; text-align:center; position:relative; overflow:hidden; background:var(--white); }
.hero-bg{ position:absolute; inset:0; background: radial-gradient(ellipse 55% 40% at 50% 0%, rgba(0,184,99,0.07) 0%, transparent 60%), radial-gradient(ellipse 35% 30% at 85% 90%, rgba(47,111,224,0.05) 0%, transparent 55%); }
.hero-grid{ position:absolute; inset:0; background-image: linear-gradient(rgba(20,24,31,0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(20,24,31,0.025) 1px, transparent 1px); background-size:72px 72px; mask-image:radial-gradient(ellipse 70% 60% at 50% 30%, #000 0%, transparent 75%); -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 30%, #000 0%, transparent 75%); }
.hero-inner{ max-width:900px; position:relative; z-index:2; width:100%; }
.hero-badge{ display:inline-flex; align-items:center; gap:8px; padding:7px 16px; background:var(--green-soft); border:1px solid var(--green-line); border-radius:100px; font-size:12px; font-weight:700; color:var(--green-dark); letter-spacing:0.04em; margin-bottom:26px; animation:fadeInDown 0.7s ease-out; }
.hero-badge::before{ content:''; width:6px; height:6px; background:var(--green); border-radius:50%; animation:pulse-dot 2s infinite; }
@keyframes pulse-dot{ 0%,100%{opacity:1} 50%{opacity:.3} }
.hero h1{ font-family:var(--font-display); font-size:clamp(36px,5.6vw,64px); font-weight:900; color:var(--ink); line-height:1.07; letter-spacing:-0.04em; margin-bottom:24px; animation:fadeInUp 0.7s ease-out 0.1s both; }
.hero h1 em{ font-style:normal; color:var(--green); }
.hero-sub{ font-size:18px; line-height:1.7; color:var(--ink-2); max-width:720px; margin:0 auto 30px; animation:fadeInUp 0.7s ease-out 0.2s both; }

.hero-pain-gain{ display:grid; grid-template-columns:1fr 1fr; gap:10px; max-width:760px; margin:0 auto 32px; text-align:left; animation:fadeInUp 0.7s ease-out 0.25s both; }
.pg-item{ display:flex; align-items:center; gap:10px; padding:12px 16px; border-radius:10px; font-size:14px; font-weight:500; border:1px solid var(--border); background:var(--gray-soft); color:var(--ink-2); }
.pg-item .pg-icon{ flex-shrink:0; width:20px; height:20px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:800; }
.pg-item.pain .pg-icon{ background:var(--red-soft); color:var(--red); }
.pg-item.gain .pg-icon{ background:var(--green-soft); color:var(--green-dark); }
.pg-item.gain{ border-color:var(--green-line); }

.hero-cta{ display:flex; justify-content:center; flex-wrap:wrap; animation:fadeInUp 0.7s ease-out 0.3s both; }
.hero-social-proof{ margin-top:18px; font-size:13.5px; color:var(--ink-3); animation:fadeInUp 0.7s ease-out 0.35s both; }
.hero-social-proof strong{ color:var(--ink); }

/* ---------- PROBLEMA ---------- */
.problema-wrapper{ max-width:1100px; margin:0 auto; }
.problema-header{ text-align:center; margin-bottom:50px; }
.problema-header .section-desc{ margin:0 auto; }
.problema-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.problema-card{ background:var(--gray-card); border:1px solid var(--border); border-radius:16px; padding:32px 26px; transition:all 0.3s; }
.problema-card:hover{ border-color:var(--red); box-shadow:0 12px 30px rgba(20,24,31,0.05); }
.problema-icon{ display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:11px; background:var(--red-soft); color:var(--red); font-size:20px; margin-bottom:16px; }
.problema-card h4{ font-family:var(--font-display); font-size:17px; font-weight:700; color:var(--ink); margin-bottom:8px; }
.problema-card p{ font-size:14px; line-height:1.65; color:var(--ink-3); }

/* ---------- SOLUÇÃO ---------- */
.solucao-wrapper{ max-width:820px; margin:0 auto; text-align:center; }
.solucao-highlight{ background:var(--gray-soft); border:1px solid var(--border); border-left:4px solid var(--green); border-radius:16px; padding:36px 34px; text-align:left; margin-top:8px; }
.solucao-highlight h3{ font-family:var(--font-display); font-size:22px; font-weight:800; color:var(--ink); line-height:1.3; margin-bottom:14px; letter-spacing:-0.02em; }
.solucao-highlight p{ font-size:15.5px; line-height:1.7; color:var(--ink-2); }

/* ---------- BENEFÍCIOS ---------- */
.ben-wrapper{ max-width:1100px; margin:0 auto; }
.ben-header{ text-align:center; margin-bottom:50px; }
.ben-header .section-desc{ margin:0 auto; }
.ben-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.ben-card{ background:var(--gray-card); border:1px solid var(--border); border-radius:14px; padding:28px 24px; display:flex; gap:14px; align-items:flex-start; transition:all 0.3s; }
.ben-card:hover{ border-color:var(--green-line); box-shadow:0 12px 30px rgba(20,24,31,0.05); }
.ben-icon{ flex-shrink:0; width:38px; height:38px; border-radius:10px; background:var(--green-soft); color:var(--green-dark); display:flex; align-items:center; justify-content:center; font-size:16px; font-weight:800; }
.ben-card h4{ font-family:var(--font-display); font-size:16px; font-weight:700; color:var(--ink); margin-bottom:6px; }
.ben-card p{ font-size:13.5px; line-height:1.6; color:var(--ink-3); }

/* ---------- INCLUSO ---------- */
.incluso-wrapper{ max-width:1000px; margin:0 auto; }
.incluso-header{ text-align:center; margin-bottom:46px; }
.incluso-header .section-desc{ margin:0 auto; }
.incluso-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.incluso-card{ background:var(--gray-card); border:1px solid var(--border); border-radius:16px; padding:28px 26px; display:flex; gap:16px; align-items:flex-start; transition:all 0.3s; }
.incluso-card:hover{ box-shadow:0 12px 30px rgba(20,24,31,0.06); }
.incluso-card.bonus{ border-color:var(--green-line); background:linear-gradient(180deg,var(--green-soft),#fff 70%); }
.incluso-icon{ flex-shrink:0; width:42px; height:42px; border-radius:11px; background:var(--blue-soft); color:var(--blue); display:flex; align-items:center; justify-content:center; font-size:18px; }
.incluso-card.bonus .incluso-icon{ background:#fff; color:var(--green-dark); }
.bonus-tag{ display:inline-block; padding:3px 10px; background:var(--green); color:#fff; font-size:10.5px; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; border-radius:5px; margin-bottom:8px; }
.incluso-card h4{ font-family:var(--font-display); font-size:16.5px; font-weight:700; color:var(--ink); margin-bottom:7px; }
.incluso-card p{ font-size:13.5px; line-height:1.6; color:var(--ink-3); }
.incluso-cta{ text-align:center; margin-top:40px; }

/* ---------- DEPOIMENTOS ---------- */
.dep-wrapper{ max-width:1100px; margin:0 auto; }
.dep-header{ text-align:center; margin-bottom:44px; }
.dep-header .section-desc{ margin:0 auto; }
.dep-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.dep-card{ background:var(--gray-card); border:1px solid var(--border); border-radius:16px; padding:30px 24px; }
.dep-card .stars{ color:var(--amber); font-size:13px; letter-spacing:2px; margin-bottom:14px; }
.dep-card blockquote{ font-size:14px; line-height:1.7; color:var(--ink-2); font-style:italic; margin-bottom:20px; }
.dep-card .d-author{ display:flex; align-items:center; gap:10px; }
.dep-card .d-avatar{ width:36px; height:36px; border-radius:50%; background:var(--green-soft); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:700; color:var(--green-dark); font-size:14px; }
.dep-card .d-author h4{ font-family:var(--font-display); font-size:13px; font-weight:700; color:var(--ink); }
.dep-card .d-author p{ font-size:11px; color:var(--ink-3); }
.dep-cta{ text-align:center; margin-top:40px; }

/* ---------- OFERTA ---------- */
.oferta-wrapper{ max-width:620px; margin:0 auto; }
.oferta-box{ background:var(--gray-card); border:1px solid var(--green-line); border-radius:24px; padding:48px 40px; text-align:center; position:relative; overflow:hidden; box-shadow:0 24px 60px rgba(20,24,31,0.08); }
.oferta-box::before{ content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--green),var(--blue)); }
.oferta-badge{ display:inline-block; padding:5px 14px; background:var(--green-soft); color:var(--green-dark); font-size:11px; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; border-radius:6px; margin-bottom:18px; }
.oferta-box h2{ font-family:var(--font-display); font-size:clamp(22px,3.4vw,30px); font-weight:800; color:var(--ink); line-height:1.25; margin-bottom:10px; letter-spacing:-0.02em; }
.oferta-sub{ font-size:15px; color:var(--ink-3); margin-bottom:26px; }
.price-block{ margin-bottom:6px; }
.price-old{ font-size:17px; color:var(--ink-3); text-decoration:line-through; }
.price-current{ font-family:var(--font-display); font-size:60px; font-weight:900; color:var(--ink); letter-spacing:-0.03em; line-height:1; }
.price-current .currency{ font-size:26px; font-weight:700; vertical-align:super; color:var(--ink-3); }
.price-note{ font-size:13px; color:var(--ink-3); margin-bottom:24px; }
.oferta-bonuses{ list-style:none; text-align:left; max-width:420px; margin:0 auto 28px; }
.oferta-bonuses li{ font-size:14px; color:var(--ink-2); padding:9px 0; border-bottom:1px solid var(--border); display:flex; gap:10px; align-items:flex-start; }
.oferta-bonuses li:last-child{ border-bottom:none; }
.oferta-bonuses li::before{ content:'✓'; color:var(--green); font-weight:800; flex-shrink:0; }
.oferta-box .btn-primary{ width:100%; justify-content:center; font-size:18px; padding:20px; }
.oferta-guarantee{ font-size:12.5px; color:var(--ink-3); margin-top:14px; }

/* ---------- FAQ ---------- */
.faq-wrapper{ max-width:820px; margin:0 auto; }
.faq-header{ text-align:center; margin-bottom:44px; }
.faq-header .section-desc{ margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--border); }
.faq-question{ width:100%; background:none; border:none; padding:22px 0; text-align:left; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq-question h3{ font-family:var(--font-display); font-size:15.5px; font-weight:700; color:var(--ink); line-height:1.4; }
.faq-icon{ width:26px; height:26px; border-radius:50%; border:1.5px solid var(--border-strong); display:flex; align-items:center; justify-content:center; font-size:16px; color:var(--ink-3); transition:all 0.3s; flex-shrink:0; }
.faq-answer{ max-height:0; overflow:hidden; transition:max-height 0.4s ease; }
.faq-answer p{ padding-bottom:22px; font-size:14px; line-height:1.7; color:var(--ink-2); }
.faq-item.open .faq-icon{ transform:rotate(45deg); border-color:var(--green); color:var(--green); }

/* ---------- FOOTER ---------- */
.lp-footer{ padding:40px; text-align:center; border-top:1px solid var(--border); background:var(--gray-bg); }
.lp-footer p{ font-size:12px; color:var(--ink-3); }
.lp-footer a{ color:var(--green-dark); text-decoration:none; font-weight:600; }

/* ---------- ANIMAÇÕES ---------- */
@keyframes fadeInUp{ from{opacity:0; transform:translateY(24px);} to{opacity:1; transform:translateY(0);} }
@keyframes fadeInDown{ from{opacity:0; transform:translateY(-12px);} to{opacity:1; transform:translateY(0);} }
.reveal{ opacity:0; transform:translateY(30px); transition:all 0.7s cubic-bezier(0.22,1,0.36,1); }
.reveal.active{ opacity:1; transform:translateY(0); }

/* ---------- RESPONSIVE ---------- */
@media (max-width:1024px){
  .problema-grid{ grid-template-columns:1fr; }
  .ben-grid{ grid-template-columns:1fr 1fr; }
  .dep-grid{ grid-template-columns:1fr; }
}
@media (max-width:768px){
  .navbar{ padding:0 20px; }
  .nav-links{ display:none; }
  .mobile-toggle{ display:block; }
  .nav-links.open{ display:flex; flex-direction:column; position:fixed; top:68px; left:0; right:0; bottom:0; background:var(--white); padding:32px 20px; gap:20px; z-index:999; }
  .nav-links.open a{ font-size:16px; }
  section{ padding:70px 20px; }
  .hero{ padding:100px 20px 60px; }
  .hero-pain-gain{ grid-template-columns:1fr; }
  .ben-grid{ grid-template-columns:1fr; }
  .incluso-grid{ grid-template-columns:1fr; }
  .oferta-box{ padding:36px 24px; }
}
