/* ═══════════════════════════════════════════════════
   GAMEMESTRE — Chess Strategy Dark Premium Theme
   Cores: Navy + Dourado + Azul Elétrico
   ═══════════════════════════════════════════════════ */

/* ─── 1. TOKENS ─── */
:root {
  /* Backgrounds */
  --bg:   #080B18;
  --bg-2: #0D1126;
  --bg-3: #111830;
  --card:  #131729;
  --card-2:#1A1F3C;

  /* Borders */
  --border:      rgba(255,255,255,0.07);
  --border-gold: rgba(245,166,35,0.30);
  --border-blue: rgba(67,97,238,0.25);

  /* Brand — Dourado */
  --gold:       #F5A623;
  --gold-dark:  #C67E0F;
  --gold-light: #FFD166;
  --gold-dim:   rgba(245,166,35,0.12);

  /* Acento — Azul */
  --blue:       #4361EE;
  --blue-light: #7B9FFF;
  --blue-dim:   rgba(67,97,238,0.12);

  /* Outros */
  --emerald: #06D6A0;
  --red:     #EF4444;

  /* Gradientes */
  --grad-brand:  linear-gradient(135deg, #F5A623 0%, #FFD166 100%);
  --grad-hero:   linear-gradient(135deg, #F5A623 0%, #4361EE 60%, #06D6A0 100%);
  --grad-card:   linear-gradient(135deg, rgba(245,166,35,.08) 0%, rgba(67,97,238,.08) 100%);
  --grad-dark:   linear-gradient(180deg, #080B18 0%, #0D1126 100%);
  --grad-text:   linear-gradient(135deg, #F5A623 0%, #FFD166 50%, #F5A623 100%);

  /* Texto */
  --text:        #FFFFFF;
  --text-muted:  rgba(255,255,255,0.65);
  --text-subtle: rgba(255,255,255,0.35);
  --success:     #06D6A0;
  --error:       #EF4444;

  /* Espaçamento */
  --space-1:4px;  --space-2:8px;   --space-3:12px;  --space-4:16px;
  --space-5:20px; --space-6:24px;  --space-8:32px;  --space-10:40px;
  --space-12:48px;--space-16:64px; --space-20:80px; --space-24:96px;

  /* Tipografia */
  --font:      'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'Share Tech Mono', 'Courier New', monospace;

  /* Bordas arredondadas */
  --r-sm:4px; --r-md:10px; --r-lg:16px; --r-xl:24px; --r-2xl:32px; --r-full:9999px;

  /* Sombras */
  --sh-sm:   0 2px 8px rgba(0,0,0,.4);
  --sh-md:   0 8px 24px rgba(0,0,0,.5);
  --sh-lg:   0 20px 60px rgba(0,0,0,.6);
  --sh-gold: 0 0 30px rgba(245,166,35,.25), 0 8px 32px rgba(0,0,0,.4);
  --sh-blue: 0 0 30px rgba(67,97,238,.2),   0 8px 32px rgba(0,0,0,.4);
  --sh-card: 0 0 0 1px rgba(255,255,255,.06), 0 20px 60px rgba(0,0,0,.5);

  /* Transições */
  --fast: 150ms ease;
  --base: 260ms ease;
  --slow: 450ms cubic-bezier(.4,0,.2,1);

  --container: 1180px;
  --pad: clamp(16px,4vw,24px);
}

/* ─── 2. RESET ─── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100% }
body { font-family:var(--font); color:var(--text); background:var(--bg); line-height:1.6; -webkit-font-smoothing:antialiased }
img,svg { display:block; max-width:100% }
a { color:inherit; text-decoration:none }
ul,ol { list-style:none }
button { font-family:inherit; cursor:pointer; border:none; background:none }
input,textarea,select { font-family:inherit }
address { font-style:normal }

/* ─── 3. TIPOGRAFIA ─── */
h1,h2,h3,h4,h5,h6 { font-weight:700; line-height:1.15; color:var(--text); letter-spacing:-.02em }
h1 { font-size:clamp(2.1rem,5.5vw,3.8rem); font-weight:800; font-family:var(--font-mono) }
h2 { font-size:clamp(1.6rem,3.5vw,2.5rem) }
h3 { font-size:clamp(1.1rem,2vw,1.4rem); font-weight:600 }
p  { color:var(--text-muted); line-height:1.75 }

.gradient-text {
  background: var(--grad-text);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer-text 4s linear infinite;
}

/* ─── 4. LAYOUT ─── */
.container { width:100%; max-width:var(--container); margin:0 auto; padding:0 var(--pad) }
.section    { padding:var(--space-20) 0 }
.section--alt { background:var(--bg-2) }
.section-header { text-align:center; max-width:680px; margin:0 auto var(--space-12) }
.section-header h2 { margin:var(--space-3) 0 var(--space-4) }
.section-header p  { font-size:1.1rem }

.grid-2 { display:grid; grid-template-columns:1fr; gap:var(--space-6) }
.grid-3 { display:grid; grid-template-columns:1fr; gap:var(--space-6) }
.grid-4 { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-6) }

@media(min-width:640px){
  .grid-2 { grid-template-columns:repeat(2,1fr) }
  .grid-4 { grid-template-columns:repeat(2,1fr) }
}
@media(min-width:900px){
  .grid-3 { grid-template-columns:repeat(3,1fr) }
  .grid-4 { grid-template-columns:repeat(4,1fr) }
}

/* ─── 5. BADGE ─── */
.badge {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.78rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  padding:5px 14px; border-radius:var(--r-full);
  background:var(--gold-dim); color:var(--gold);
  border:1px solid rgba(245,166,35,.22);
  animation: pulse-gold 3s ease-in-out infinite;
}

/* ─── 6. BOTÕES ─── */
.btn {
  display:inline-flex; align-items:center; gap:var(--space-2);
  font-family:var(--font); font-weight:700; font-size:1rem; line-height:1;
  padding:14px 26px; border-radius:var(--r-full);
  border:2px solid transparent; transition:all var(--base);
  white-space:nowrap; cursor:pointer; text-decoration:none; position:relative; overflow:hidden
}

/* Shine sweep effect */
.btn::after {
  content:''; position:absolute; top:0; left:-100%; width:60%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  transition:.6s ease; pointer-events:none
}
.btn:hover::after { left:140% }

.btn--primary {
  background:var(--grad-brand); color:#000;
  box-shadow: var(--sh-gold)
}
.btn--primary:hover {
  transform:translateY(-2px);
  box-shadow: 0 0 50px rgba(245,166,35,.4), 0 12px 40px rgba(0,0,0,.4)
}
.btn--primary:active { transform:translateY(0) }

.btn--outline {
  background:transparent; color:var(--gold);
  border-color:rgba(245,166,35,.4)
}
.btn--outline:hover {
  background:rgba(245,166,35,.08); border-color:var(--gold);
  transform:translateY(-2px); box-shadow:0 0 20px rgba(245,166,35,.15)
}

.btn--ghost {
  background:rgba(255,255,255,.06); color:var(--text); border-color:var(--border)
}
.btn--ghost:hover { background:rgba(255,255,255,.1); transform:translateY(-2px) }

.btn--lg  { padding:17px 34px; font-size:1.1rem }
.btn--sm  { padding:10px 18px; font-size:.9rem }
.btn--block { width:100%; justify-content:center }
.btn--dark { background:var(--grad-brand); color:#000; font-weight:800; box-shadow:var(--sh-gold) }
.btn--dark:hover { transform:translateY(-2px); box-shadow:0 0 50px rgba(245,166,35,.5) }

/* ─── 7. CARDS ─── */
.card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-6);
  position:relative; overflow:hidden;
  transition:all var(--base)
}

/* Card shine */
.card::before {
  content:''; position:absolute; top:0; left:-100%; width:60%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(245,166,35,.04),transparent);
  transition:.6s ease; pointer-events:none
}
.card:hover::before { left:140% }
.card:hover {
  border-color:rgba(245,166,35,.3);
  box-shadow: 0 0 40px rgba(245,166,35,.06), 0 20px 60px rgba(0,0,0,.5);
  transform:translateY(-4px)
}

.card--feature::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad-brand); opacity:0; transition:opacity var(--base)
}
.card--feature:hover::after { opacity:1 }

.card__icon {
  width:52px; height:52px; border-radius:var(--r-md);
  background:var(--gold-dim); border:1px solid rgba(245,166,35,.15);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--space-4); color:var(--gold);
  transition:all var(--base)
}
.card:hover .card__icon {
  background:var(--grad-brand); color:#000; border-color:transparent;
  box-shadow:0 0 20px rgba(245,166,35,.3)
}
.card__title { margin-bottom:var(--space-2); font-size:1.1rem }
.card__desc  { font-size:.95rem; color:var(--text-muted); line-height:1.65 }

/* Checklist */
.checklist { display:flex; flex-direction:column; gap:var(--space-3) }
.checklist li {
  display:flex; align-items:flex-start; gap:var(--space-3);
  font-size:1rem; color:var(--text-muted)
}
.checklist li::before {
  content:''; width:20px; height:20px; border-radius:50%; flex-shrink:0; margin-top:2px;
  background:var(--emerald);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:12px; background-position:center; background-repeat:no-repeat
}

/* Trust badges inline */
.trust-badge {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.9rem; font-weight:500; color:var(--text-muted)
}
.trust-badge svg { color:var(--emerald); flex-shrink:0 }

/* ─── 8. NAVEGAÇÃO ─── */
.nav {
  position:sticky; top:0; z-index:100;
  background:rgba(8,11,24,.92);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border)
}
.nav__inner { display:flex; align-items:center; height:68px; gap:var(--space-6) }
.nav__logo {
  display:flex; align-items:center; gap:10px;
  font-weight:800; font-size:1.2rem; color:var(--text); letter-spacing:-.03em; flex-shrink:0
}
.nav__logo-icon {
  width:36px; height:36px; border-radius:10px;
  background:var(--grad-brand);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 16px rgba(245,166,35,.3)
}
.nav__links { display:none; align-items:center; gap:2px; margin:0 auto }
.nav__links a {
  font-size:.9rem; font-weight:500; color:var(--text-muted);
  padding:7px 13px; border-radius:var(--r-full); transition:all var(--fast)
}
.nav__links a:hover { color:var(--gold); background:var(--gold-dim) }
.nav__actions { display:flex; align-items:center; gap:var(--space-3); margin-left:auto }
.nav__cta { padding:9px 18px; font-size:.875rem }

/* Mobile menu */
.nav__toggle-input { display:none }
.nav__hamburger {
  display:flex; flex-direction:column; justify-content:center; gap:5px;
  width:36px; height:36px; padding:6px; cursor:pointer;
  border-radius:var(--r-sm); transition:background var(--fast)
}
.nav__hamburger:hover { background:rgba(255,255,255,.06) }
.nav__hamburger span { display:block; height:2px; background:var(--text-muted); border-radius:2px; transition:all var(--base) }
.nav__toggle-input:checked ~ .nav__mobile-menu {
  display:flex; flex-direction:column;
  position:absolute; top:68px; left:0; right:0;
  background:rgba(8,11,24,.98); border-bottom:1px solid var(--border);
  padding:var(--space-4) var(--pad); gap:var(--space-2);
  box-shadow:var(--sh-lg); z-index:99
}
.nav__mobile-menu { display:none }
.nav__mobile-menu a {
  font-size:1rem; font-weight:500; color:var(--text-muted);
  padding:12px 16px; border-radius:var(--r-md); transition:background var(--fast)
}
.nav__mobile-menu a:hover { background:var(--gold-dim); color:var(--gold) }
.nav__mobile-menu .btn { width:100%; justify-content:center; margin-top:var(--space-2) }

@media(min-width:900px){
  .nav__links { display:flex }
  .nav__hamburger { display:none }
}

/* ─── 9. HERO ─── */
.hero {
  position:relative; overflow:hidden;
  background:var(--bg);
  padding:var(--space-20) 0 0; min-height:92vh;
  display:flex; align-items:center
}

/* Chess grid lines */
.hero__grid {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(245,166,35,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,166,35,.04) 1px, transparent 1px);
  background-size: 60px 60px
}

/* Chess board checkerboard overlay */
.hero::after {
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(45deg, rgba(245,166,35,.025) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(245,166,35,.025) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(245,166,35,.025) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(245,166,35,.025) 75%);
  background-size: 60px 60px;
  background-position: 0 0, 0 30px, 30px -30px, -30px 0px
}

/* Gold radial glow (right side) */
.hero__glow {
  position:absolute; right:0; top:50%; transform:translateY(-50%);
  width:700px; height:700px;
  background:radial-gradient(circle, rgba(245,166,35,.08) 0%, transparent 65%);
  z-index:1; pointer-events:none
}

/* Dark overlay — keeps text readable */
.hero__overlay {
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(90deg, rgba(8,11,24,.97) 38%, rgba(8,11,24,.65) 65%, rgba(8,11,24,.1) 100%)
}

/* Bottom fade */
.hero__fade {
  position:absolute; bottom:0; left:0; right:0; height:220px; z-index:3; pointer-events:none;
  background:linear-gradient(0deg, var(--bg) 0%, transparent 100%)
}

/* Large decorative chess piece */
.hero__piece {
  position:absolute; right:4%; top:50%; transform:translateY(-52%);
  font-size:clamp(180px,26vw,380px); line-height:1;
  background:linear-gradient(135deg, rgba(245,166,35,.18) 0%, rgba(67,97,238,.12) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  pointer-events:none; z-index:2; user-select:none;
  animation:float 8s ease-in-out infinite;
  filter:drop-shadow(0 0 80px rgba(245,166,35,.1))
}

/* Content */
.hero__inner {
  position:relative; z-index:4;
  padding-bottom:var(--space-24)
}

/* Opening label (replaces matrix ribbon) */
.hero__opening {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:.78rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(245,166,35,.6); margin-bottom:var(--space-6);
  animation:fadeUp .5s ease both
}
.hero__opening-tag {
  background:var(--gold-dim); color:var(--gold);
  border:1px solid rgba(245,166,35,.22);
  padding:3px 10px; border-radius:var(--r-full);
  font-size:.72rem
}

.hero__heading { max-width:680px; margin-bottom:var(--space-5); animation:fadeUp .5s .1s ease both }
.hero__sub {
  font-size:clamp(1rem,1.8vw,1.15rem); color:var(--text-muted);
  max-width:540px; margin-bottom:var(--space-8); animation:fadeUp .5s .2s ease both
}

/* Disclaimer box */
.hero__disclaimer {
  background:rgba(245,166,35,.05); border:1px solid rgba(245,166,35,.12);
  border-radius:var(--r-md); padding:var(--space-4) var(--space-5);
  margin-bottom:var(--space-6); max-width:540px;
  animation:fadeUp .5s .25s ease both
}
.hero__disclaimer p { font-size:.84rem; color:rgba(255,255,255,.45); margin:0; line-height:1.6 }
.hero__disclaimer strong { color:rgba(255,255,255,.6); display:block; margin-bottom:4px; font-size:.86rem }

/* Piece label */
.hero__piece-label {
  font-size:.8rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(245,166,35,.5); margin-bottom:var(--space-3);
  animation:fadeUp .5s .3s ease both
}

.hero__actions {
  display:flex; flex-wrap:wrap; gap:var(--space-4);
  margin-bottom:var(--space-10); animation:fadeUp .5s .35s ease both
}
.hero__trust {
  display:flex; flex-wrap:wrap; gap:var(--space-6);
  animation:fadeUp .5s .4s ease both
}

/* ─── 10. TRUST BAR ─── */
.trust-bar {
  background:rgba(245,166,35,.04);
  border-top:1px solid rgba(245,166,35,.1);
  border-bottom:1px solid rgba(245,166,35,.1);
  padding:var(--space-6) 0
}
.trust-bar__inner {
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:var(--space-8)
}
.trust-bar__item {
  display:flex; align-items:center; gap:var(--space-3);
  font-size:.9rem; font-weight:600; color:var(--text-muted)
}
.trust-bar__item svg { color:var(--gold) }

/* ─── 11. PRODUTO ─── */
.product-grid {
  display:grid; grid-template-columns:1fr; gap:var(--space-8); align-items:start
}
@media(min-width:900px) { .product-grid { grid-template-columns:1fr 1fr; gap:var(--space-16) } }
.product-col h3 { font-size:1.25rem; margin-bottom:var(--space-5); color:var(--text) }
.pricing-box {
  background:rgba(245,166,35,.06); border:1px solid rgba(245,166,35,.18);
  border-radius:var(--r-lg); padding:var(--space-6); position:relative; overflow:hidden
}
.pricing-box::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--grad-brand)
}
.pricing-box p   { color:var(--text-muted); margin-bottom:var(--space-3); font-size:.95rem }
.pricing-box p:last-child { margin-bottom:0 }
.pricing-box strong { color:var(--gold) }
.pricing-box a   { color:var(--gold); font-weight:600; text-decoration:underline }

/* ─── 12. STEPS ─── */
.steps { display:flex; flex-direction:column; gap:0; max-width:700px; margin:0 auto }
.step  { display:flex; gap:var(--space-6); padding-bottom:var(--space-8); position:relative }
.step:not(:last-child)::before {
  content:''; position:absolute; left:23px; top:52px; bottom:0; width:2px;
  background:linear-gradient(to bottom,rgba(245,166,35,.4),transparent)
}
.step__num {
  width:48px; height:48px; border-radius:50%;
  background:var(--grad-brand); color:#000; font-weight:800; font-size:1.1rem;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  box-shadow:var(--sh-gold)
}
.step__content { padding-top:10px }
.step__content h3 { margin-bottom:var(--space-2); color:var(--text) }
.step__content p  { font-size:.95rem }

/* ─── 13. ESPECIALISTA ─── */
.specialist-grid {
  display:grid; grid-template-columns:1fr; gap:var(--space-12); align-items:center
}
@media(min-width:900px) { .specialist-grid { grid-template-columns:1fr 1fr; gap:var(--space-16) } }

.specialist-photo {
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  box-shadow:0 0 0 1px var(--border-gold), var(--sh-lg)
}
.specialist-photo img {
  width:100%; height:auto; aspect-ratio:4/5;
  object-fit:cover; object-position:center top; display:block; max-height:560px
}
.specialist-photo__badge {
  position:absolute; bottom:var(--space-5); left:var(--space-5); right:var(--space-5);
  background:rgba(8,11,24,.88); backdrop-filter:blur(12px);
  border:1px solid var(--border-gold); border-radius:var(--r-md);
  padding:var(--space-4) var(--space-5); display:flex; align-items:center; gap:var(--space-3)
}
.specialist-photo__badge .dot {
  width:10px; height:10px; border-radius:50%; background:var(--emerald);
  box-shadow:0 0 0 3px rgba(6,214,160,.25); flex-shrink:0
}
.specialist-photo__badge p    { font-size:.82rem; color:var(--text-muted); margin:0 }
.specialist-photo__badge strong { color:var(--text); display:block; font-size:.95rem }
.specialist-content h2 { margin-bottom:var(--space-5) }
.specialist-content p  { margin-bottom:var(--space-4); font-size:1rem }
.specialist-stats {
  display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4);
  margin:var(--space-8) 0
}
.specialist-stat {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-md); padding:var(--space-4); text-align:center;
  transition:all var(--base)
}
.specialist-stat:hover {
  border-color:var(--border-gold); box-shadow:0 0 20px rgba(245,166,35,.08)
}
.specialist-stat__num {
  font-size:1.8rem; font-weight:800;
  background:var(--grad-brand); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text; line-height:1
}
.specialist-stat__label { font-size:.78rem; color:var(--text-subtle); margin-top:4px }

/* ─── 14. SOCIAL PROOF / STATS ─── */
.stats-bar {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:var(--space-6); text-align:center; margin-bottom:var(--space-12)
}
@media(min-width:640px) { .stats-bar { grid-template-columns:repeat(4,1fr) } }

.stat-item {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-6);
  transition:all var(--base)
}
.stat-item:hover { border-color:var(--border-gold); transform:translateY(-2px) }

.stat-num {
  font-size:clamp(2rem,4vw,2.8rem); font-weight:800;
  background:var(--grad-brand); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
  display:block; letter-spacing:-.03em; line-height:1; margin-bottom:var(--space-1)
}
.stat-label { font-size:.85rem; color:var(--text-subtle); font-weight:500 }

/* ─── 15. DEPOIMENTOS ─── */
.card--testimonial { position:relative }
.testimonial-stars {
  font-size:1.1rem; color:var(--gold); margin-bottom:var(--space-4); letter-spacing:2px
}
.testimonial-quote {
  font-size:.95rem; color:var(--text-muted); line-height:1.75;
  margin-bottom:var(--space-5); font-style:italic
}
.testimonial-author  { display:flex; align-items:center; gap:var(--space-3) }
.testimonial-avatar  {
  width:44px; height:44px; border-radius:50%; overflow:hidden; flex-shrink:0;
  background:var(--card-2); border:2px solid var(--border-gold)
}
.testimonial-avatar svg { width:44px; height:44px }
.testimonial-name  { font-weight:700; font-size:.9rem; color:var(--text); display:block }
.testimonial-role  { font-size:.78rem; color:var(--text-subtle) }

/* ─── 16. FAQ ─── */
.faq-list { max-width:760px; margin:0 auto }
details.faq-item {
  border:1px solid var(--border); border-radius:var(--r-md);
  margin-bottom:var(--space-3); overflow:hidden; transition:all var(--base)
}
details.faq-item:hover { border-color:rgba(245,166,35,.2) }
details.faq-item[open] { border-color:var(--border-gold); background:rgba(245,166,35,.03) }
summary.faq-question {
  display:flex; align-items:center; justify-content:space-between;
  padding:var(--space-5) var(--space-6); cursor:pointer;
  font-weight:600; font-size:1rem; color:var(--text);
  list-style:none; gap:var(--space-4); user-select:none
}
summary.faq-question::-webkit-details-marker { display:none }
.faq-icon {
  width:28px; height:28px; border-radius:50%;
  background:var(--gold-dim); color:var(--gold);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:all var(--base); font-size:18px; font-weight:400; line-height:1
}
details.faq-item[open] .faq-icon { background:var(--grad-brand); color:#000; transform:rotate(45deg) }
.faq-answer { padding:0 var(--space-6) var(--space-5); font-size:.95rem; color:var(--text-muted); line-height:1.7 }
.faq-answer a { color:var(--gold); font-weight:500 }

/* ─── 17. PERSONAS ─── */
.persona-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-6);
  transition:all var(--base)
}
.persona-card:hover { border-color:var(--border-gold); box-shadow:0 0 30px rgba(245,166,35,.06); transform:translateY(-3px) }
.persona-icon {
  width:52px; height:52px; border-radius:var(--r-md);
  background:var(--grad-brand);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--space-4); font-size:22px
}
.persona-card h3 { margin-bottom:var(--space-2); font-size:1.05rem; color:var(--text) }
.persona-card p  { font-size:.9rem }

/* ─── 18. OFERTA / CTA ─── */
.cta-final {
  background:var(--bg-2); padding:var(--space-20) 0;
  text-align:center; position:relative; overflow:hidden;
  border-top:1px solid rgba(245,166,35,.12); border-bottom:1px solid rgba(245,166,35,.12)
}
.cta-final::before {
  content:''; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:800px; height:800px;
  background:radial-gradient(circle, rgba(245,166,35,.06) 0%, transparent 65%);
  pointer-events:none
}
.cta-final__inner  { position:relative; z-index:1 }
.cta-final h2 { color:var(--text); max-width:600px; margin:0 auto var(--space-4) }
.cta-final p  { color:var(--text-muted); margin-bottom:var(--space-8); font-size:1.1rem }
.cta-guarantee {
  margin-top:var(--space-5); font-size:.88rem; color:var(--text-subtle);
  display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:wrap
}
.cta-guarantee a { color:var(--text-subtle); transition:color var(--fast) }
.cta-guarantee a:hover { color:var(--gold) }

/* ─── 19. FOOTER ─── */
.footer {
  background:rgba(0,0,0,.7); border-top:1px solid var(--border);
  padding:var(--space-16) 0 0; color:var(--text-subtle)
}
.footer__top {
  display:grid; grid-template-columns:1fr; gap:var(--space-10);
  padding-bottom:var(--space-12); border-bottom:1px solid var(--border)
}
@media(min-width:640px)  { .footer__top { grid-template-columns:repeat(2,1fr) } }
@media(min-width:1024px) { .footer__top { grid-template-columns:2fr 1fr 1fr 2fr } }

.footer__logo-text {
  font-size:1.2rem; font-weight:800; color:var(--text); letter-spacing:-.03em;
  display:flex; align-items:center; gap:10px; margin-bottom:var(--space-4)
}
.footer__logo-icon {
  width:30px; height:30px; border-radius:8px; background:var(--grad-brand);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 12px rgba(245,166,35,.25)
}
.footer__brand p { font-size:.88rem; color:var(--text-subtle); max-width:280px; margin-bottom:var(--space-5) }
.footer__trust-list { display:flex; flex-direction:column; gap:var(--space-2) }
.footer__trust-item {
  display:flex; align-items:center; gap:8px; font-size:.8rem; color:var(--text-subtle)
}
.footer__trust-item svg { color:var(--emerald); flex-shrink:0 }

.footer__col h3 {
  font-size:.78rem; font-weight:700; color:var(--text);
  letter-spacing:.06em; text-transform:uppercase; margin-bottom:var(--space-5)
}
.footer__col ul { display:flex; flex-direction:column; gap:var(--space-3) }
.footer__col ul a { font-size:.88rem; color:var(--text-subtle); transition:color var(--fast) }
.footer__col ul a:hover { color:var(--gold) }

.footer__company h3 {
  font-size:.78rem; font-weight:700; color:var(--text);
  letter-spacing:.06em; text-transform:uppercase; margin-bottom:var(--space-5)
}
.footer__company address { font-size:.82rem; color:var(--text-subtle); line-height:1.9 }
.footer__company address strong { color:rgba(255,255,255,.65) }
.footer__company address a { color:var(--text-subtle); transition:color var(--fast) }
.footer__company address a:hover { color:var(--gold) }
.footer__hours {
  margin-top:var(--space-4); font-size:.75rem; color:var(--text-subtle);
  border-top:1px solid var(--border); padding-top:var(--space-4)
}
.footer__bottom {
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between;
  gap:var(--space-4); padding:var(--space-6) 0; font-size:.78rem; color:var(--text-subtle)
}
.footer__bottom-links { display:flex; flex-wrap:wrap; gap:var(--space-4) }
.footer__bottom-links a { color:var(--text-subtle); transition:color var(--fast) }
.footer__bottom-links a:hover { color:var(--gold) }

/* ─── 20. PÁGINAS SECUNDÁRIAS ─── */
.page-hero {
  background:var(--bg-2); padding:var(--space-16) 0 var(--space-12);
  border-bottom:1px solid var(--border);
  position:relative; overflow:hidden
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(245,166,35,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,166,35,.03) 1px, transparent 1px);
  background-size:60px 60px; pointer-events:none
}
.page-hero .badge { margin-bottom:var(--space-4) }
.page-hero h1 { margin-bottom:var(--space-4) }
.page-hero p  { font-size:1.05rem; max-width:560px }

/* ─── 21. POLICY CONTENT ─── */
.policy-content { max-width:800px; margin:0 auto }
.policy-content h2 {
  font-size:1.5rem; margin:var(--space-10) 0 var(--space-4);
  padding-bottom:var(--space-3); border-bottom:1px solid var(--border); color:var(--text)
}
.policy-content h2:first-child { margin-top:0 }
.policy-content h3 { font-size:1.05rem; margin:var(--space-6) 0 var(--space-3); color:var(--text-muted) }
.policy-content p  { margin-bottom:var(--space-4); font-size:.95rem; color:var(--text-muted); line-height:1.8 }
.policy-content ul,.policy-content ol { margin:var(--space-4) 0; padding-left:var(--space-6) }
.policy-content ul { list-style:disc }
.policy-content ol { list-style:decimal }
.policy-content li { font-size:.95rem; color:var(--text-muted); line-height:1.8; margin-bottom:var(--space-2) }
.policy-content a  { color:var(--gold); font-weight:500 }
.policy-content strong { color:var(--text-muted) }
.policy-content table { width:100%; border-collapse:collapse; margin:var(--space-5) 0; font-size:.88rem }
.policy-content table th {
  background:var(--card); padding:var(--space-3) var(--space-4);
  text-align:left; font-weight:600; color:var(--text-muted); border:1px solid var(--border)
}
.policy-content table td { padding:var(--space-3) var(--space-4); border:1px solid var(--border); color:var(--text-subtle); vertical-align:top }
.policy-content table tr:nth-child(even) td { background:var(--bg-2) }
.policy-update {
  background:var(--gold-dim); border:1px solid rgba(245,166,35,.2);
  border-radius:var(--r-md); padding:var(--space-4) var(--space-5);
  margin-bottom:var(--space-8); font-size:.9rem; color:var(--gold); font-weight:500
}

/* ─── 22. CONTATO ─── */
.contact-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-8) var(--space-6);
  text-align:center; transition:all var(--base)
}
.contact-card:hover { border-color:var(--border-gold); box-shadow:0 0 30px rgba(245,166,35,.06); transform:translateY(-3px) }
.contact-card-icon {
  width:64px; height:64px; border-radius:var(--r-lg);
  background:var(--gold-dim); border:1px solid rgba(245,166,35,.2);
  color:var(--gold); display:flex; align-items:center; justify-content:center; margin:0 auto var(--space-4)
}
.contact-card h3 { margin-bottom:var(--space-2); font-size:1.05rem }
.contact-card p  { font-size:.88rem; margin-bottom:var(--space-3) }
.contact-card a  { color:var(--gold); font-weight:700; font-size:.95rem; transition:color var(--fast) }
.contact-card a:hover { color:var(--gold-light) }

.form-group { margin-bottom:var(--space-5) }
.form-group label {
  display:block; font-size:.82rem; font-weight:700; color:var(--text-muted);
  margin-bottom:var(--space-2); letter-spacing:.02em
}
.form-group input,.form-group select,.form-group textarea {
  width:100%; padding:12px 16px;
  border:1.5px solid var(--border); border-radius:var(--r-md);
  font-size:.95rem; color:var(--text); background:var(--card);
  transition:border-color var(--fast),box-shadow var(--fast); outline:none
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus {
  border-color:var(--gold); box-shadow:0 0 0 3px rgba(245,166,35,.1)
}
.form-group select option { background:var(--card); color:var(--text) }
.form-group textarea { resize:vertical; min-height:120px }
.form-group input::placeholder,.form-group textarea::placeholder { color:var(--text-subtle) }
.form-privacy { font-size:.78rem; color:var(--text-subtle); margin-top:var(--space-4) }
.form-privacy a { color:var(--gold) }
.form-submit { width:100%; justify-content:center }
.contact-form-wrap { max-width:640px; margin:0 auto }

/* ─── 23. SOBRE ─── */
.value-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-6); transition:all var(--base)
}
.value-card:hover { box-shadow:0 0 30px rgba(245,166,35,.06); border-color:var(--border-gold) }
.value-icon {
  width:48px; height:48px; border-radius:var(--r-md); background:var(--grad-brand);
  display:flex; align-items:center; justify-content:center; margin-bottom:var(--space-4); font-size:22px
}
.value-card h3 { margin-bottom:var(--space-2); font-size:1rem }
.value-card p  { font-size:.88rem }

.company-info-box {
  background:var(--card); border:1px solid var(--border); border-radius:var(--r-lg); padding:var(--space-8)
}
.company-info-box dl { display:grid; grid-template-columns:auto 1fr; gap:var(--space-3) var(--space-8) }
.company-info-box dt { font-weight:700; font-size:.9rem; color:var(--text-muted); white-space:nowrap }
.company-info-box dd { font-size:.9rem; color:var(--text-subtle) }
.company-info-box dd a { color:var(--gold); font-weight:500 }
@media(max-width:640px){
  .company-info-box dl { grid-template-columns:1fr; gap:var(--space-2) }
  .company-info-box dt { margin-bottom:-8px }
}
.team-card {
  display:flex; align-items:center; gap:var(--space-5);
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-6); transition:all var(--base)
}
.team-card:hover { border-color:var(--border-gold) }
.team-avatar {
  width:80px; height:80px; min-width:80px; border-radius:50%;
  overflow:hidden; flex-shrink:0; border:2px solid var(--border-gold)
}
.team-avatar img { width:100%; height:100%; object-fit:cover; object-position:center top; display:block }
.team-info h3 { margin-bottom:4px; font-size:1.05rem }
.team-info p  { font-size:.88rem; margin-bottom:var(--space-2) }

.compliance-strip { display:flex; flex-wrap:wrap; gap:var(--space-4); align-items:center }
.compliance-badge {
  display:flex; align-items:center; gap:8px;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-full); padding:8px 16px;
  font-size:.88rem; font-weight:600; color:var(--text-muted)
}
.compliance-badge svg { color:var(--emerald) }

.refund-highlight {
  background:rgba(6,214,160,.06); border:2px solid rgba(6,214,160,.2);
  border-radius:var(--r-xl); padding:var(--space-8); text-align:center; margin-bottom:var(--space-10)
}
.refund-highlight .days { font-size:80px; font-weight:900; color:var(--emerald); line-height:1; display:block }
.refund-highlight .days-label { font-size:1.3rem; font-weight:700; color:var(--emerald); display:block; margin-bottom:var(--space-4) }
.refund-highlight p { color:rgba(6,214,160,.8); font-size:1.05rem; max-width:480px; margin:0 auto }

/* ─── 24. SCROLL REVEAL ─── */
.reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity .65s ease, transform .65s ease
}
.reveal.visible { opacity:1; transform:translateY(0) }
.reveal[data-delay="100"] { transition-delay:.1s }
.reveal[data-delay="200"] { transition-delay:.2s }
.reveal[data-delay="300"] { transition-delay:.3s }
.reveal[data-delay="400"] { transition-delay:.4s }
.reveal[data-delay="500"] { transition-delay:.5s }
.reveal[data-delay="600"] { transition-delay:.6s }

/* ─── 25. ANIMAÇÕES ─── */
@keyframes float {
  0%,100% { transform:translateY(-52%) rotate(-3deg) }
  50%      { transform:translateY(calc(-52% - 22px)) rotate(3deg) }
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(28px) }
  to   { opacity:1; transform:translateY(0) }
}
@keyframes shimmer-text {
  0%   { background-position: 0% center }
  100% { background-position: 200% center }
}
@keyframes pulse-gold {
  0%,100% { box-shadow:none }
  50%      { box-shadow:0 0 0 4px rgba(245,166,35,.1) }
}

/* ─── 26. RESPONSIVO ─── */
@media(max-width:640px){
  :root { --pad:16px }
  .section { padding:var(--space-12) 0 }
  .hero { padding-top:var(--space-12); min-height:auto }
  .hero__piece { right:-5%; font-size:clamp(140px,55vw,220px); opacity:.6 }
  .hero__overlay { background:linear-gradient(180deg,rgba(8,11,24,.97) 0%,rgba(8,11,24,.88) 100%) }
  .hero__actions { flex-direction:column }
  .hero__actions .btn { width:100%; justify-content:center }
  .stats-bar { grid-template-columns:repeat(2,1fr) }
  .team-card { flex-direction:column; text-align:center }
  .specialist-photo img { max-height:420px }
}
@media(min-width:641px) and (max-width:899px){
  .stats-bar { grid-template-columns:repeat(2,1fr) }
}

/* ─── 27. PRINT ─── */
@media print{
  .nav,.hero__piece,.cta-final,.footer__bottom-links { display:none }
  body { font-size:12pt; background:#fff; color:#000 }
  a[href]::after { content:" (" attr(href) ")" }
}
