/*
Theme Name: Pacto
Theme URI: https://pacto.app
Author: Pacto Dev
Author URI: https://pacto.app
Description: Site oficial do Pacto - marketplace de servicos. Landing page ultra-moderna, micro-interacoes 3D, 100% responsiva.
Version: 2026.0420.0643
Build: 20260420064304
Requires at least: 6.2
Tested up to: 6.7
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: pacto
*/

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; font-size: 16px; }
body { font-family: var(--font-body); background: var(--bg); color: var(--text); overflow-x: hidden; line-height: 1.6; -webkit-font-smoothing: antialiased; }
/* Ancoração de scroll abaixo do header fixo */
html { scroll-padding-top: 80px; }
img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ============================================================
   DESIGN TOKENS — Espelho exato do AppTheme Flutter
   ============================================================ */
:root {
  --primary:         #7C3AED;
  --primary-dark:    #6D28D9;
  --primary-light:   #9F67FF;
  --primary-surface: rgba(124,58,237,.12);

  --secondary:       #FB7185;
  --secondary-dark:  #E11D48;
  --secondary-light: #FC8C9E;

  --success: #10B981;
  --warning: #F59E0B;
  --error:   #EF4444;
  --info:    #3B82F6;
  --amber:   #F59E0B;

  --bg:       #0B0614;
  --bg-2:     #100B1E;
  --bg-3:     #16102A;
  --bg-card:  rgba(255,255,255,.04);
  --bg-glass: rgba(255,255,255,.06);

  --text:      #F8FAFC;
  --text-2:    rgba(248,250,252,.72);
  --text-3:    rgba(248,250,252,.42);

  --border:   rgba(255,255,255,.08);
  --border-2: rgba(124,58,237,.30);

  --g-brand:  linear-gradient(135deg, #7C3AED 0%, #FB7185 100%);
  --g-hero:   linear-gradient(135deg, #4C1D95 0%, #7C3AED 50%, #FB7185 100%);
  --g-purple: linear-gradient(135deg, #4C1D95 0%, #7C3AED 100%);
  --g-card:   linear-gradient(135deg, rgba(124,58,237,.10) 0%, rgba(251,113,133,.08) 100%);
  --g-text:   linear-gradient(135deg, #C4B5FD 0%, #FB7185 100%);

  --shadow-sm:   0 2px 8px rgba(124,58,237,.12);
  --shadow-md:   0 8px 24px rgba(124,58,237,.20), 0 2px 8px rgba(0,0,0,.15);
  --shadow-lg:   0 24px 64px rgba(124,58,237,.25), 0 8px 24px rgba(0,0,0,.20);
  --shadow-glow: 0 0 48px rgba(124,58,237,.45);

  --font-body:    'Plus Jakarta Sans', 'Inter', system-ui, sans-serif;
  --font-display: 'Plus Jakarta Sans', system-ui, sans-serif;

  --r-sm:   8px;
  --r-md:   16px;
  --r-lg:   24px;
  --r-xl:   32px;
  --r-full: 9999px;

  --container:        min(1200px, 100% - 48px);
  --container-narrow: min(800px, 100% - 48px);

  --t-fast:   150ms cubic-bezier(.4,0,.2,1);
  --t-normal: 300ms cubic-bezier(.4,0,.2,1);
  --t-slow:   500ms cubic-bezier(.4,0,.2,1);
  --t-spring: 400ms cubic-bezier(.34,1.56,.64,1);
}

/* ============================================================
   UTILITÁRIOS
   ============================================================ */
.container { width: var(--container); margin-inline: auto; }
.container--narrow { width: var(--container-narrow); margin-inline: auto; }
.text-gradient { background: var(--g-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.text-gradient-brand { background: var(--g-brand); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

.section-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 16px; border-radius: var(--r-full);
  background: rgba(124,58,237,.15); border: 1px solid rgba(124,58,237,.30);
  color: var(--primary-light); font-size: .75rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
}
.section-badge::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--primary-light); animation: pulse-dot 1.5s infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:.5; transform:scale(.7); }
}

/* ============================================================
   NAVBAR — GLASS
   ============================================================ */
.pacto-nav {
  position: fixed; top:0; left:0; right:0; z-index:1000;
  padding-inline: 24px;
  /* Borda sutil sempre visível — não desaparece nunca */
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: background var(--t-normal), box-shadow var(--t-normal),
              border-color var(--t-normal), padding var(--t-normal);
}
/* Estado inicial: leve véu tônico para legibilidade */
.pacto-nav::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(11,6,20,.6) 0%, transparent 100%);
  pointer-events:none; z-index:-1;
  opacity:1; transition:opacity var(--t-normal);
}
.pacto-nav.scrolled::before { opacity:0; }
.pacto-nav.scrolled {
  background: rgba(11,6,20,.94);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 1px 0 rgba(255,255,255,.06), 0 8px 32px rgba(0,0,0,.4);
}
.pacto-nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 72px; max-width:1200px; margin-inline:auto; gap:8px;
  transition: height var(--t-normal);
}
.pacto-nav.scrolled .pacto-nav__inner { height: 60px; }

.pacto-nav__logo {
  display: flex; align-items: center; gap:10px;
  font-weight:800; font-size:1.25rem; letter-spacing:-.02em; color:var(--text);
}
.pacto-nav__logo-mark {
  width:36px; height:36px; border-radius:10px;
  background: var(--g-brand); display:grid; place-items:center;
  box-shadow: var(--shadow-glow); transition: transform var(--t-spring);
}
.pacto-nav__logo:hover .pacto-nav__logo-mark { transform: scale(1.08) rotate(-4deg); }
.pacto-nav__logo-mark svg { width:20px; height:20px; }
.pacto-nav__logo em { background:var(--g-brand); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; font-style:normal; }
/* Wordmark gradiente — moderno e impactante (sem imagem, sem ícone) */
.pacto-wordmark {
  /* fallback para navegadores sem background-clip:text */
  color: var(--primary);
  background: var(--g-brand);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 900;
  font-size: 1.45rem;
  letter-spacing: -.04em;
  line-height: 1;
  display: inline-block;
  user-select: none;
  -webkit-user-select: none;
  /* Glow sutil no hover */
  transition: filter var(--t-normal);
}
.pacto-nav__logo:hover .pacto-wordmark {
  filter: drop-shadow(0 0 12px rgba(124,58,237,.6));
}


.pacto-nav__links { display:flex; align-items:center; gap:2px; }
.pacto-nav__links a {
  position:relative; padding:8px 14px; border-radius:var(--r-sm);
  font-size:.875rem; font-weight:500; color:var(--text-2);
  transition: color var(--t-fast), background var(--t-fast);
}
.pacto-nav__links a::after {
  content:''; position:absolute; bottom:2px; left:50%; transform:translateX(-50%);
  width:0; height:2px; border-radius:2px;
  background:var(--g-brand); transition:width var(--t-normal);
}
.pacto-nav__links a:hover { color:var(--text); background:rgba(255,255,255,.06); }
.pacto-nav__links a:hover::after,
.pacto-nav__links a.active::after { width:18px; }
.pacto-nav__links a.active { color:var(--text); }

.btn-nav-download {
  display:inline-flex; align-items:center; gap:8px; flex-shrink:0;
  padding:10px 22px; border-radius:var(--r-full);
  background:var(--g-brand); color:#fff; font-size:.875rem; font-weight:700;
  box-shadow: 0 4px 16px rgba(124,58,237,.35);
  transition: transform var(--t-spring), box-shadow var(--t-normal), opacity var(--t-fast);
  white-space:nowrap;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  border: 1px solid rgba(255,255,255,.15);
}
.btn-nav-download:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(124,58,237,.55); }
.btn-nav-download:active { transform:translateY(0); opacity:.9; }
.btn-nav-download svg { width:15px; height:15px; flex-shrink:0; }

.pacto-nav__toggle {
  display:none; flex-direction:column; justify-content:center; align-items:center; gap:5px;
  width:44px; height:44px; padding:10px; border-radius:var(--r-sm);
  transition: background var(--t-fast);
  /* Área mínima de toque 44×44 WCAG */
  touch-action: manipulation;
}
.pacto-nav__toggle:hover { background:rgba(255,255,255,.08); }
.pacto-nav__toggle:active { background:rgba(255,255,255,.14); }
.pacto-nav__toggle:focus-visible { outline:2px solid var(--primary); outline-offset:2px; }
.pacto-nav__toggle span {
  display:block; width:22px; height:2px; background:var(--text); border-radius:2px;
  transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .22s ease, width .22s ease;
  transform-origin:center;
  flex-shrink:0;
}
.pacto-nav__toggle.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.pacto-nav__toggle.open span:nth-child(2) { opacity:0; width:0; transform:scaleX(0); }
.pacto-nav__toggle.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ==== OVERLAY — usa opacity para animar entrada/saída corretamente ==== */
.nav-overlay {
  position: fixed; inset: 0; z-index: 998;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  /* Fechado: invisível e sem cliques */
  opacity: 0;
  pointer-events: none;
  transition: opacity .32s ease;
}
.nav-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

/* ==== MENU MOBILE ==== */
.pacto-nav__mobile {
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; right: 0;
  /* Altura ocupa tela inteira considerando safe-area (iPhone com notch) */
  bottom: 0;
  width: min(320px, 88vw);
  z-index: 999;
  background: linear-gradient(160deg, #0e0720 0%, #0a0518 100%);
  border-left: 1px solid rgba(124,58,237,.3);
  overflow-y: auto;
  overflow-x: hidden;
  /* Fechado: fora de tela à direita + sem eventos de ponteiro */
  transform: translateX(110%);
  pointer-events: none;
  /* GPU acceleration */
  will-change: transform;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  transition: transform .34s cubic-bezier(.4,0,.2,1);
  box-shadow: -32px 0 80px rgba(0,0,0,.7), -1px 0 0 rgba(124,58,237,.15);
  scrollbar-width: thin;
  scrollbar-color: rgba(124,58,237,.3) transparent;
  -webkit-font-smoothing: antialiased;
  /* Padding inferior respeitando safe-area (botão home do iPhone) */
  padding-bottom: env(safe-area-inset-bottom, 0px);
}
.pacto-nav__mobile.open {
  transform: translateX(0);
  pointer-events: auto;
}
/* Barra de destaque na borda esquerda do menu aberto */
.pacto-nav__mobile.open::before {
  content: '';
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 2px;
  background: var(--g-brand);
  border-radius: 2px;
  opacity: .5;
}

.mobile-menu__header {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 20px;
  border-bottom:1px solid rgba(124,58,237,.15);
  position:sticky; top:0;
  background:rgba(11,5,24,.97);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  z-index:2;
  /* Safe area para iPhones com notch (Dynamic Island) */
  padding-top: max(18px, env(safe-area-inset-top));
}
.mobile-menu__brand {
  display:flex; align-items:center;
  text-decoration: none;
}
.mobile-menu__brand .pacto-wordmark {
  font-size: 1.3rem;
  font-weight: 900;
}
.mobile-menu__close {
  /* Área de toque ótima para thumbs */
  width:38px; height:38px; border-radius:var(--r-sm);
  background:rgba(255,255,255,.07); color:var(--text-2);
  display:flex; align-items:center; justify-content:center;
  transition:background var(--t-fast), color var(--t-fast), transform var(--t-fast);
  touch-action: manipulation;
}
.mobile-menu__close:hover { background:rgba(255,255,255,.14); color:var(--text); }
.mobile-menu__close:active { transform:scale(.92); }
.mobile-menu__close svg { width:17px; height:17px; }

.mobile-menu__section { padding:14px 14px 6px; }
.mobile-menu__label {
  display:block; font-size:.6rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--text-3); padding:0 10px 10px;
}
.mobile-menu__item {
  display:flex; align-items:center; gap:12px;
  padding:11px 12px; border-radius:var(--r-md); color:var(--text-2);
  transition:color var(--t-fast), background var(--t-fast);
  margin-bottom:2px;
  text-decoration:none;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.mobile-menu__item:hover,
.mobile-menu__item:focus-visible { color:var(--text); background:rgba(124,58,237,.14); }
.mobile-menu__item:active { background:rgba(124,58,237,.22); transform:scale(.99); }
.mobile-menu__item.active { color:var(--text); background:rgba(124,58,237,.1); }
.mobile-menu__item.active .mobile-menu__icon { background:rgba(124,58,237,.25); }
.mobile-menu__item.active .mobile-menu__arrow { opacity:.7; }
.mobile-menu__item--sm { padding:9px 12px; }
.mobile-menu__icon {
  width:36px; height:36px; border-radius:var(--r-sm);
  background:rgba(255,255,255,.06); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  transition:background var(--t-fast);
}
.mobile-menu__item:hover .mobile-menu__icon { background:rgba(124,58,237,.2); }
.mobile-menu__icon svg { width:15px; height:15px; stroke:var(--primary-light); }
.mobile-menu__item--sm .mobile-menu__icon { width:30px; height:30px; border-radius:6px; }
.mobile-menu__item--sm .mobile-menu__icon svg { width:13px; height:13px; }
.mobile-menu__text { flex:1; font-size:.925rem; font-weight:600; line-height:1.2; }
.mobile-menu__item--sm .mobile-menu__text { font-size:.85rem; font-weight:500; }
.mobile-menu__arrow { width:15px; height:15px; opacity:.3; flex-shrink:0; transition:opacity var(--t-fast), transform var(--t-fast); }
.mobile-menu__item:hover .mobile-menu__arrow { opacity:.65; transform:translateX(2px); }

.mobile-menu__divider {
  height:1px; margin:6px 20px;
  background:linear-gradient(90deg, transparent, rgba(124,58,237,.22), transparent);
}
.mobile-menu__footer {
  padding:16px 14px;
  /* Padding inferior respeita safe-area do iPhone */
  padding-bottom: max(28px, calc(env(safe-area-inset-bottom) + 16px));
  margin-top:auto;
}
.mobile-menu__cta {
  display:flex; align-items:center; justify-content:center; gap:10px;
  width:100%; padding:16px 20px; border-radius:var(--r-full);
  background:var(--g-brand); color:#fff; font-weight:700; font-size:.95rem;
  box-shadow:0 8px 28px rgba(124,58,237,.45);
  transition:transform var(--t-spring), box-shadow var(--t-normal), opacity var(--t-fast);
  letter-spacing:.01em;
  touch-action: manipulation;
  /* Borda interna sutil que destaca no dark */
  border: 1px solid rgba(255,255,255,.15);
}
.mobile-menu__cta:hover { transform:translateY(-2px); box-shadow:0 12px 36px rgba(124,58,237,.6); }
.mobile-menu__cta:active { transform:scale(.97); opacity:.9; }
.mobile-menu__cta svg { width:17px; height:17px; flex-shrink:0; }
.mobile-menu__platforms {
  text-align:center; font-size:.7rem; color:var(--text-3);
  margin-top:10px; display:flex; align-items:center; justify-content:center; gap:5px;
}
.mobile-menu__platforms svg { opacity:.45; }

/* ============================================================
   HERO — Fullscreen 3D
   ============================================================ */
.pacto-hero {
  position:relative; min-height:100svh;
  display:flex; align-items:center;
  background:var(--bg); overflow:hidden;
  padding-block:100px 60px;
}
#hero-canvas {
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:0;
}
.pacto-hero__orb {
  position:absolute; border-radius:50%;
  filter:blur(80px); pointer-events:none; z-index:0;
  animation:orb-drift 8s ease-in-out infinite alternate;
}
.pacto-hero__orb--1 {
  width:600px; height:600px; top:-200px; left:-150px;
  background:radial-gradient(circle, rgba(124,58,237,.45) 0%, transparent 70%);
}
.pacto-hero__orb--2 {
  width:500px; height:500px; bottom:-150px; right:-100px;
  background:radial-gradient(circle, rgba(251,113,133,.30) 0%, transparent 70%);
  animation-delay:-4s;
}
.pacto-hero__orb--3 {
  width:300px; height:300px; top:40%; left:40%;
  background:radial-gradient(circle, rgba(79,70,229,.25) 0%, transparent 70%);
  animation-delay:-2s; animation-duration:6s;
}
@keyframes orb-drift {
  0% { transform:translate(0,0) scale(1); }
  100% { transform:translate(40px,30px) scale(1.1); }
}
.pacto-hero__grid {
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(rgba(124,58,237,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,58,237,.06) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 20%, transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 20%, transparent 100%);
}
.pacto-hero__inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr;
  gap:64px; align-items:center;
  padding-block:20px;
}
.pacto-hero__badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px 6px 10px; border-radius:var(--r-full);
  background:rgba(16,185,129,.15); border:1px solid rgba(16,185,129,.30);
  color:#34D399; font-size:.75rem; font-weight:700; letter-spacing:.06em;
  margin-bottom:24px;
}
.pacto-hero__badge-dot {
  width:8px; height:8px; border-radius:50%; background:#34D399;
  animation:pulse-dot 1.5s infinite;
}
.pacto-hero__headline {
  font-size:clamp(2.5rem,6vw,4.25rem);
  font-weight:800; line-height:1.08; letter-spacing:-.03em;
  color:var(--text); margin-bottom:24px;
  text-rendering: optimizeLegibility;
}
.hl-gradient {
  background:var(--g-brand); -webkit-background-clip:text;
  background-clip:text; -webkit-text-fill-color:transparent;
}
.pacto-hero__sub {
  font-size:clamp(1rem,1.5vw,1.2rem);
  color:var(--text-2); line-height:1.7; margin-bottom:40px;
}
.pacto-hero__actions { display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.pacto-hero__proof {
  display:flex; align-items:center; gap:12px;
  margin-top:32px; padding-top:24px; border-top:1px solid var(--border);
}
.pacto-hero__avatars { display:flex; }
.pacto-hero__avatars span {
  width:32px; height:32px; border-radius:50%;
  border:2px solid var(--bg); background:var(--g-brand);
  display:grid; place-items:center; font-size:.65rem; font-weight:700; color:#fff;
  margin-left:-8px;
}
.pacto-hero__avatars span:first-child { margin-left:0; }
.pacto-hero__proof-text { font-size:.85rem; color:var(--text-2); }
.pacto-hero__proof-text strong { color:var(--text); }

/* 3D Phone */
.pacto-hero__phone-wrap {
  display:flex; justify-content:center; align-items:center;
  perspective:1200px; padding:40px; position:relative;
}
.pacto-hero__phone {
  width:280px; position:relative;
  transform:rotateY(-18deg) rotateX(8deg);
  transform-style:preserve-3d;
  animation:phone-float 6s ease-in-out infinite;
  filter:drop-shadow(0 40px 80px rgba(124,58,237,.5));
}
@keyframes phone-float {
  0%,100% { transform:rotateY(-18deg) rotateX(8deg) translateY(0); }
  50% { transform:rotateY(-18deg) rotateX(6deg) translateY(-16px); }
}
.pacto-hero__phone-shell {
  width:280px; height:550px; border-radius:40px;
  background:linear-gradient(145deg, #1A1A2E, #16213E);
  border:1px solid rgba(255,255,255,.12);
  overflow:hidden; position:relative;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.06),
    20px 40px 80px rgba(0,0,0,.6);
}
.pacto-hero__phone-screen {
  position:absolute; inset:10px; border-radius:32px;
  background:var(--bg); overflow:hidden;
}
.phone-screen-bg {
  position:absolute; inset:0;
  background:linear-gradient(160deg, #4C1D95 0%, #3B0764 40%, #0B0614 100%);
}
.phone-notch {
  position:absolute; top:12px; left:50%; transform:translateX(-50%);
  width:80px; height:20px; border-radius:10px; background:#000; z-index:10;
}
.phone-content {
  position:absolute; inset:36px 12px 12px;
  display:flex; flex-direction:column; gap:10px;
}
.phone-topbar { display:flex; justify-content:space-between; align-items:center; padding:0 4px; }
.phone-topbar span { font-size:.6rem; color:rgba(255,255,255,.8); }
.phone-search {
  height:36px; border-radius:12px;
  background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; padding:0 12px; gap:6px;
}
.phone-search span { font-size:.62rem; color:rgba(255,255,255,.5); }
.phone-cards { display:flex; flex-direction:column; gap:8px; flex:1; }
.phone-card {
  padding:10px 12px; border-radius:14px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.06);
  display:flex; align-items:center; gap:10px;
}
.phone-card-icon {
  width:32px; height:32px; border-radius:10px; flex-shrink:0;
  display:grid; place-items:center;
}
.phone-card-info { flex:1; }
.phone-card-title { font-size:.65rem; font-weight:700; color:rgba(255,255,255,.95); }
.phone-card-sub { font-size:.58rem; color:rgba(255,255,255,.5); margin-top:2px; }
.phone-card-price {
  font-size:.65rem; font-weight:700;
  background:var(--g-brand); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.phone-navbar {
  height:40px; border-radius:12px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.06);
  display:flex; align-items:center; justify-content:space-around;
}
.phone-nav-dot { width:5px; height:5px; border-radius:50%; }
.phone-badge {
  position:absolute; padding:8px 14px; border-radius:12px;
  backdrop-filter:blur(20px); background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.15);
  font-size:.78rem; font-weight:700; color:var(--text);
  white-space:nowrap; display:flex; align-items:center; gap:8px;
  box-shadow:0 8px 32px rgba(0,0,0,.30);
  animation:badge-float 4s ease-in-out infinite;
}
.phone-badge--1 { top:18%; right:-64px; animation-delay:0s; }
.phone-badge--2 { bottom:35%; left:-72px; animation-delay:-2s; }
.phone-badge--3 { bottom:8%; right:-52px; animation-delay:-1s; }
@keyframes badge-float {
  0%,100% { transform:translateY(0); }
  50% { transform:translateY(-8px); }
}
.badge-icon { width:24px; height:24px; border-radius:8px; display:grid; place-items:center; }

/* ============================================================
   BOTÕES
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 28px; border-radius:var(--r-full);
  font-size:.9rem; font-weight:700; font-family:var(--font-body);
  cursor:pointer; transition:all var(--t-spring); border:none;
  white-space:nowrap; text-decoration:none;
  /* Otimizações de toque */
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.btn svg { width:18px; height:18px; flex-shrink:0; }
.btn--primary {
  background:var(--g-brand); color:#fff;
  box-shadow:0 6px 24px rgba(124,58,237,.40);
}
.btn--primary:hover { transform:translateY(-3px); box-shadow:0 12px 36px rgba(124,58,237,.55); }
.btn--primary:active { transform:translateY(-1px); }
.btn--outline {
  background:transparent; color:var(--text);
  border:1px solid rgba(255,255,255,.20);
  backdrop-filter:blur(10px);
}
.btn--outline:hover { background:rgba(255,255,255,.07); border-color:rgba(255,255,255,.35); transform:translateY(-2px); }
.btn--ghost { background:rgba(124,58,237,.12); color:var(--primary-light); border:1px solid rgba(124,58,237,.25); }
.btn--ghost:hover { background:rgba(124,58,237,.22); transform:translateY(-2px); }
.btn--lg { padding:16px 36px; font-size:1rem; }
.btn--sm { padding:10px 20px; font-size:.8rem; }

/* ============================================================
   PROOF BAR
   ============================================================ */
.proof-bar {
  background:rgba(255,255,255,.03);
  border-block:1px solid var(--border); padding-block:32px;
}
.proof-bar__inner {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:32px; align-items:center;
}
.proof-bar__item {
  text-align:center; padding:8px;
  transition:transform var(--t-normal);
}
.proof-bar__item:hover { transform:translateY(-4px); }
.proof-bar__number {
  font-size:clamp(1.75rem,3vw,2.5rem);
  font-weight:800; letter-spacing:-.03em;
  background:var(--g-brand); -webkit-background-clip:text;
  background-clip:text; -webkit-text-fill-color:transparent;
  display:block; margin-bottom:4px;
}
.proof-bar__label { font-size:.85rem; color:var(--text-2); display:block; }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.section-header { text-align:center; margin-bottom:72px; }
.section-header .section-badge { margin-bottom:20px; }
.section-title {
  font-size:clamp(2rem,4vw,3rem);
  font-weight:800; letter-spacing:-.03em; color:var(--text);
  line-height:1.15; margin-bottom:16px;
}
.section-sub {
  font-size:1.1rem; color:var(--text-2);
  max-width:560px; margin-inline:auto; line-height:1.7;
}

/* ============================================================
   COMO FUNCIONA
   ============================================================ */
.how-section { padding-block:120px; background:var(--bg); }
.how-steps {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:32px; position:relative;
}
.how-steps::before {
  content:''; position:absolute;
  top:56px; left:calc(16.67% + 40px); right:calc(16.67% + 40px); height:2px;
  background:linear-gradient(90deg, var(--primary) 0%, var(--secondary) 100%);
  opacity:.25; z-index:0;
}
.how-step {
  text-align:center; padding:40px 28px; border-radius:var(--r-xl);
  background:var(--bg-card); border:1px solid var(--border);
  position:relative; z-index:1; overflow:hidden;
  transition:transform var(--t-normal), border-color var(--t-normal), box-shadow var(--t-normal);
}
.how-step:hover { transform:translateY(-8px); border-color:rgba(124,58,237,.40); box-shadow:var(--shadow-lg); }
.how-step__number {
  position:absolute; top:12px; right:18px;
  font-size:4rem; font-weight:900; line-height:1;
  color:rgba(124,58,237,.07); letter-spacing:-.05em;
}
.how-step__icon-wrap {
  width:80px; height:80px; border-radius:24px; margin:0 auto 24px;
  display:grid; place-items:center;
  background:rgba(124,58,237,.15); border:1px solid rgba(124,58,237,.25);
  transition:transform var(--t-spring), box-shadow var(--t-normal);
}
.how-step:hover .how-step__icon-wrap {
  transform:scale(1.1) rotate(-5deg);
  box-shadow:0 12px 32px rgba(124,58,237,.35);
}
.how-step__icon-wrap svg { width:36px; height:36px; color:var(--primary-light); }
.how-step__title { font-size:1.2rem; font-weight:700; color:var(--text); margin-bottom:12px; }
.how-step__desc { font-size:.9rem; color:var(--text-2); line-height:1.7; }

/* ============================================================
   FUNCIONALIDADES
   ============================================================ */
.features-section { padding-block:120px; background:linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%); }
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:64px; }
.feature-card {
  padding:32px 28px; border-radius:var(--r-xl);
  background:var(--bg-glass); border:1px solid var(--border);
  backdrop-filter:blur(20px) saturate(140%);
  position:relative; overflow:hidden; cursor:default;
  transition:transform var(--t-normal), border-color var(--t-normal), box-shadow var(--t-normal);
}
.feature-card::after {
  content:''; position:absolute; inset:0; border-radius:inherit;
  background:var(--g-card); opacity:0;
  transition:opacity var(--t-normal); pointer-events:none;
}
.feature-card:hover { transform:translateY(-6px); border-color:rgba(124,58,237,.35); box-shadow:var(--shadow-md); }
.feature-card:hover::after { opacity:1; }
.feature-card__icon {
  width:56px; height:56px; border-radius:16px;
  display:grid; place-items:center; margin-bottom:20px;
  transition:transform var(--t-spring);
}
.feature-card:hover .feature-card__icon { transform:scale(1.12) rotate(-6deg); }
.feature-card__icon svg { width:28px; height:28px; }
.feature-card__title { font-size:1.05rem; font-weight:700; color:var(--text); margin-bottom:10px; }
.feature-card__desc { font-size:.875rem; color:var(--text-2); line-height:1.7; }

/* ============================================================
   AUDIÊNCIA — Clientes / Profissionais
   ============================================================ */
.audience-section { padding-block:120px; background:var(--bg-2); }
.audience-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; margin-top:64px; }
.audience-card {
  padding:48px 40px; border-radius:var(--r-xl);
  border:1px solid var(--border); position:relative; overflow:hidden;
  transition:transform var(--t-normal), box-shadow var(--t-normal);
}
.audience-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.audience-card--clients { background:linear-gradient(135deg, rgba(124,58,237,.12) 0%, rgba(79,70,229,.06) 100%); }
.audience-card--pros { background:linear-gradient(135deg, rgba(251,113,133,.10) 0%, rgba(224,29,72,.06) 100%); }
.audience-card__tag {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px; border-radius:var(--r-full); margin-bottom:24px;
  font-size:.75rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
}
.audience-card--clients .audience-card__tag { background:rgba(124,58,237,.18); color:var(--primary-light); }
.audience-card--pros .audience-card__tag { background:rgba(251,113,133,.18); color:var(--secondary-light); }
.audience-card__title { font-size:1.75rem; font-weight:800; color:var(--text); margin-bottom:16px; letter-spacing:-.02em; line-height:1.2; }
.audience-card__desc { font-size:.95rem; color:var(--text-2); line-height:1.7; margin-bottom:32px; }
.audience-benefits { display:flex; flex-direction:column; gap:12px; margin-bottom:32px; }
.audience-benefit { display:flex; align-items:flex-start; gap:12px; font-size:.9rem; color:var(--text-2); }
.benefit-check {
  width:20px; height:20px; border-radius:50%; flex-shrink:0;
  display:grid; place-items:center; margin-top:1px;
}
.audience-card--clients .benefit-check { background:rgba(124,58,237,.20); color:var(--primary-light); }
.audience-card--pros .benefit-check { background:rgba(251,113,133,.18); color:var(--secondary-light); }
.benefit-check svg { width:12px; height:12px; }
.audience-card__decor {
  position:absolute; bottom:-40px; right:-40px;
  width:200px; height:200px; border-radius:50%;
  opacity:.06; pointer-events:none;
}
.audience-card--clients .audience-card__decor { background:var(--primary); }
.audience-card--pros .audience-card__decor { background:var(--secondary); }

/* ============================================================
   DOWNLOADS
   ============================================================ */
.downloads-section {
  padding-block:120px; background:var(--bg);
  position:relative; overflow:hidden;
}
.downloads-section::before {
  content:''; position:absolute;
  top:-200px; left:50%; transform:translateX(-50%);
  width:800px; height:600px;
  background:radial-gradient(ellipse, rgba(124,58,237,.15) 0%, transparent 70%);
  pointer-events:none;
}
.downloads-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:64px; }
.download-card {
  padding:40px 32px; border-radius:var(--r-xl);
  background:var(--bg-glass); border:1px solid var(--border);
  backdrop-filter:blur(20px); text-align:center; position:relative; overflow:hidden;
  transition:transform var(--t-spring), border-color var(--t-normal), box-shadow var(--t-normal);
}
.download-card:hover { transform:translateY(-10px); border-color:rgba(124,58,237,.45); box-shadow:var(--shadow-lg); }
.download-card--featured {
  border-color:rgba(124,58,237,.40);
}
.download-card--featured::before {
  content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(135deg, rgba(124,58,237,.12) 0%, rgba(251,113,133,.08) 100%);
  pointer-events:none;
}
.download-card__badge {
  position:absolute; top:16px; right:16px;
  padding:4px 10px; border-radius:var(--r-full);
  background:var(--g-brand); color:#fff;
  font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
}
.download-card__icon {
  width:72px; height:72px; border-radius:20px; margin:0 auto 20px;
  display:grid; place-items:center; position:relative; z-index:1;
}
.download-card__icon svg { width:40px; height:40px; }
.download-card__platform { font-size:.8rem; font-weight:700; letter-spacing:.10em; text-transform:uppercase; color:var(--text-3); margin-bottom:8px; position:relative; z-index:1; }
.download-card__name { font-size:1.3rem; font-weight:800; color:var(--text); margin-bottom:12px; position:relative; z-index:1; }
.download-card__desc { font-size:.875rem; color:var(--text-2); line-height:1.6; margin-bottom:28px; position:relative; z-index:1; }
.download-card__btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 28px; border-radius:var(--r-full); width:100%;
  justify-content:center; font-weight:700; font-size:.9rem; font-family:var(--font-body);
  cursor:pointer; transition:all var(--t-spring); position:relative; z-index:1;
  border:none; text-decoration:none;
}
.download-card__btn,
.cta-platform-btn,
a[aria-label*="Baixar"] {
  cursor:pointer !important;
  pointer-events:auto;
}
.download-card__btn svg { width:20px; height:20px; }
.dl-android { background:linear-gradient(135deg, #3DDC84, #00B96B); color:#fff; }
.dl-android:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(61,220,132,.35); }
.dl-ios { background:linear-gradient(135deg, #007AFF, #0055CC); color:#fff; }
.dl-ios:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,122,255,.35); }
.dl-windows { background:linear-gradient(135deg, #00BCF2, #0078D4); color:#fff; }
.dl-windows:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,120,215,.35); }
.download-card__version { margin-top:12px; font-size:.75rem; color:var(--text-3); position:relative; z-index:1; }

/* ============================================================
   SEGURANÇA
   ============================================================ */
.security-section {
  padding-block:120px;
  background:linear-gradient(135deg, rgba(124,58,237,.06) 0%, rgba(16,185,129,.04) 100%);
  border-block:1px solid var(--border);
}
.security-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.security-content .section-title { text-align:left; margin-bottom:20px; }
.security-content .section-sub { text-align:left; margin-inline:0; margin-bottom:40px; }
.security-features { display:flex; flex-direction:column; gap:20px; }
.security-feature {
  display:flex; gap:16px; align-items:flex-start; padding:20px;
  border-radius:var(--r-lg); background:rgba(255,255,255,.03); border:1px solid var(--border);
  transition:border-color var(--t-normal), transform var(--t-normal);
}
.security-feature:hover { border-color:rgba(16,185,129,.25); transform:translateX(4px); }
.security-feature__icon {
  width:44px; height:44px; border-radius:12px; flex-shrink:0;
  display:grid; place-items:center; background:rgba(16,185,129,.15);
  transition:transform var(--t-spring);
}
.security-feature:hover .security-feature__icon { transform:scale(1.1); }
.security-feature__icon svg { width:22px; height:22px; color:var(--success); }
.security-feature__title { font-size:.95rem; font-weight:700; color:var(--text); margin-bottom:4px; }
.security-feature__desc { font-size:.85rem; color:var(--text-2); line-height:1.6; }
.security-visual { position:relative; display:flex; justify-content:center; align-items:center; min-height:400px; }
.shield-rings-wrap { position:relative; width:320px; height:320px; }
.security-rings { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.security-ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(16,185,129,.12);
}
.security-ring--1 { width:160px; height:160px; animation:ring-spin 10s linear infinite; }
.security-ring--2 { width:240px; height:240px; animation:ring-spin 14s linear infinite reverse; }
.security-ring--3 { width:320px; height:320px; animation:ring-spin 18s linear infinite; }
@keyframes ring-spin { 0% { transform:rotate(0deg); } 100% { transform:rotate(360deg); } }
.ring-dot { position:absolute; width:8px; height:8px; border-radius:50%; top:-4px; left:50%; transform:translateX(-50%); background:var(--success); box-shadow:0 0 12px var(--success); }
.shield-center {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
}
.shield-box {
  width:120px; height:140px;
  clip-path:polygon(50% 0%, 100% 18%, 100% 65%, 50% 100%, 0% 65%, 0% 18%);
  background:linear-gradient(135deg, rgba(16,185,129,.25), rgba(124,58,237,.20));
  border:1px solid rgba(16,185,129,.40);
  display:grid; place-items:center;
  animation:shield-pulse 3s ease-in-out infinite;
}
@keyframes shield-pulse {
  0%,100% { filter:drop-shadow(0 0 0 rgba(16,185,129,.2)); }
  50% { filter:drop-shadow(0 0 20px rgba(16,185,129,.4)); }
}
.shield-box svg { width:48px; height:48px; color:var(--success); }

/* ============================================================
   DEPOIMENTOS — Marquee
   ============================================================ */
.testimonials-section { padding-block:120px; background:var(--bg-2); overflow:hidden; }
.testimonials-track-wrap {
  overflow:hidden; margin-top:64px;
  mask-image:linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}
.testimonials-track {
  display:flex; gap:24px;
  animation:marquee-scroll 45s linear infinite;
  width:max-content;
}
.testimonials-section:hover .testimonials-track { animation-play-state:paused; }
@keyframes marquee-scroll {
  0% { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
.testimonial-card {
  width:320px; flex-shrink:0; padding:28px;
  border-radius:var(--r-xl); background:var(--bg-glass);
  border:1px solid var(--border); backdrop-filter:blur(20px);
  transition:border-color var(--t-normal), transform var(--t-normal);
}
.testimonial-card:hover { border-color:rgba(124,58,237,.35); transform:translateY(-4px); }
.testimonial-stars { display:flex; gap:4px; margin-bottom:16px; }
.testimonial-stars svg { width:16px; height:16px; fill:var(--amber); color:var(--amber); }
.testimonial-quote { font-size:.9rem; color:var(--text-2); line-height:1.7; margin-bottom:20px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:12px; }
.testimonial-avatar {
  width:40px; height:40px; border-radius:50%;
  background:var(--g-brand); display:grid; place-items:center;
  font-size:.8rem; font-weight:700; color:#fff; flex-shrink:0;
}
.testimonial-name { font-size:.875rem; font-weight:700; color:var(--text); }
.testimonial-role { font-size:.78rem; color:var(--text-3); }

/* ============================================================
   SOBRE
   ============================================================ */
.about-section { padding-block:120px; background:var(--bg); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; margin-top:64px; }
.about-content .section-title { text-align:left; margin-bottom:20px; }
.about-manifesto {
  font-size:1.05rem; color:var(--text-2); line-height:1.8;
  border-left:3px solid var(--primary); padding-left:24px;
  margin-bottom:32px; font-style:italic;
}
.about-pillars { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:32px; }
.about-pillar {
  padding:20px; border-radius:var(--r-lg);
  background:rgba(255,255,255,.03); border:1px solid var(--border);
  transition:border-color var(--t-normal), transform var(--t-normal);
}
.about-pillar:hover { border-color:rgba(124,58,237,.35); transform:translateY(-4px); }
.about-pillar__icon { font-size:1.5rem; margin-bottom:8px; }
.about-pillar__title { font-size:.9rem; font-weight:700; color:var(--text); margin-bottom:4px; }
.about-pillar__desc { font-size:.8rem; color:var(--text-2); line-height:1.6; }
.about-timeline { display:flex; flex-direction:column; }
.timeline-item { display:flex; gap:20px; position:relative; }
.timeline-item:not(:last-child)::before {
  content:''; position:absolute; left:19px; top:44px; bottom:-8px; width:2px;
  background:linear-gradient(180deg, var(--primary), rgba(124,58,237,.1));
}
.timeline-dot {
  width:40px; height:40px; border-radius:50%; flex-shrink:0;
  display:grid; place-items:center; border:2px solid var(--primary);
  background:rgba(124,58,237,.15); margin-top:4px;
  transition:background var(--t-normal);
}
.timeline-dot.completed { background:var(--primary); }
.timeline-dot.completed svg { color:#fff; }
.timeline-dot svg { width:18px; height:18px; color:var(--primary-light); }
.timeline-content { padding-bottom:32px; }
.timeline-year { font-size:.75rem; color:var(--primary-light); font-weight:700; letter-spacing:.08em; margin-bottom:4px; }
.timeline-title { font-size:.95rem; font-weight:700; color:var(--text); margin-bottom:4px; }
.timeline-desc { font-size:.83rem; color:var(--text-2); }

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta-section {
  padding-block:120px;
  background:linear-gradient(135deg, #2D1B69 0%, #4C1D95 40%, #7C3AED 70%, #E11D48 100%);
  position:relative; overflow:hidden; text-align:center;
}
.cta-section::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:40px 40px;
}
.cta-section .container { position:relative; z-index:1; }
.cta-section .section-title { color:#fff; margin-bottom:20px; }
.cta-section .section-sub { color:rgba(255,255,255,.80); margin-bottom:48px; }
.cta-download-grid { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; }
.cta-platform-btn {
  display:inline-flex; align-items:center; gap:12px;
  padding:16px 28px; border-radius:var(--r-lg);
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(20px); color:#fff; font-weight:700; font-size:.9rem;
  font-family:var(--font-body); cursor:pointer; text-decoration:none;
  transition:all var(--t-spring);
}
.cta-platform-btn:hover { background:rgba(255,255,255,.22); transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.25); }
.cta-platform-btn svg { width:24px; height:24px; }
.cta-btn-text { text-align:left; }
.cta-btn-label { font-size:.68rem; display:block; opacity:.75; font-weight:400; }
.cta-btn-name { display:block; font-weight:800; font-size:.95rem; }

/* ============================================================
   RODAPÉ
   ============================================================ */
.pacto-footer {
  background:#070412; border-top:1px solid var(--border);
  padding-block:80px 32px;
}
.pacto-footer__grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; margin-bottom:64px;
}
.footer-logo { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.footer-logo__link { text-decoration:none; }
.footer-logo__wordmark { font-size:1.3rem; }
.footer-logo-mark {
  width:40px; height:40px; border-radius:10px;
  background:var(--g-brand); display:grid; place-items:center;
}
.footer-logo-mark svg { width:22px; height:22px; color:#fff; }
.footer-logo-text { font-size:1.3rem; font-weight:800; color:var(--text); letter-spacing:-.02em; }
.footer-desc { font-size:.875rem; color:var(--text-2); line-height:1.7; max-width:280px; margin-bottom:24px; }
.footer-social { display:flex; gap:10px; }
.footer-social-btn {
  width:40px; height:40px; border-radius:10px;
  background:rgba(255,255,255,.06); border:1px solid var(--border);
  display:grid; place-items:center; color:var(--text-2); transition:all var(--t-normal);
}
.footer-social-btn:hover { background:var(--primary); border-color:var(--primary); color:#fff; transform:translateY(-2px); }
.footer-social-btn svg { width:18px; height:18px; }
.footer-col__title {
  font-size:.875rem; font-weight:700; color:var(--text);
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:20px;
}
.footer-col ul { display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { font-size:.875rem; color:var(--text-2); transition:color var(--t-fast); }
.footer-col ul li a:hover { color:var(--primary-light); }
.footer-bottom {
  padding-top:32px; border-top:1px solid var(--border);
  display:flex; flex-direction:column; align-items:center;
  gap:14px; text-align:center;
}
.footer-bottom__row {
  display:flex; align-items:center; justify-content:center;
  gap:16px; flex-wrap:wrap; width:100%;
}
.footer-copy { font-size:.8rem; color:var(--text-3); line-height:1.5; }
.footer-copy--address { font-size:.72rem; margin-top:-6px; }
.footer-bottom-links { display:flex; gap:20px; }
.footer-bottom-links a { font-size:.8rem; color:var(--text-3); transition:color var(--t-fast); white-space:nowrap; }
.footer-bottom-links a:hover { color:var(--primary-light); }
.footer-live-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:var(--r-full);
  background:rgba(16,185,129,.12); border:1px solid rgba(16,185,129,.25);
  font-size:.72rem; color:var(--success); font-weight:600; white-space:nowrap;
}
.footer-live-badge::before {
  content:''; width:6px; height:6px; border-radius:50%; flex-shrink:0;
  background:var(--success); animation:pulse-dot 1.5s infinite;
}

/* ============================================================
   PAGE TEMPLATE
   ============================================================ */
.page-wrapper { min-height:100vh; background:var(--bg); padding-top:72px; }
.page-hero {
  padding:80px 0 60px;
  background:linear-gradient(135deg, #2D1B69 0%, #4C1D95 100%);
  text-align:center; position:relative; overflow:hidden;
}
.page-hero::after {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:60px 60px; pointer-events:none;
}
.page-hero__content { position:relative; z-index:1; }
.page-hero__title { font-size:clamp(2rem,4vw,3rem); font-weight:800; color:#fff; margin-bottom:16px; letter-spacing:-.03em; }
.page-hero__sub { font-size:1.05rem; color:rgba(255,255,255,.75); }
.page-content-section { padding-block:80px; }
.page-content {
  background:var(--bg-glass); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:48px;
  backdrop-filter:blur(20px);
}
.page-content h2 {
  font-size:1.4rem; font-weight:700; color:var(--text);
  margin-block:40px 16px; display:flex; align-items:center; gap:10px;
  padding-bottom:12px; border-bottom:1px solid var(--border);
}
.page-content h2:first-child { margin-top:0; }
.page-content h2::before {
  content:''; width:4px; height:24px; border-radius:2px;
  background:var(--g-brand); flex-shrink:0;
}
.page-content h3 { font-size:1.1rem; font-weight:700; color:var(--text); margin-block:24px 12px; }
.page-content p { font-size:.95rem; color:var(--text-2); line-height:1.8; margin-bottom:16px; }
.page-content ul, .page-content ol { margin-block:12px 16px; padding-left:0; }
.page-content ul li, .page-content ol li { font-size:.9rem; color:var(--text-2); line-height:1.7; padding:6px 0 6px 20px; position:relative; }
.page-content ul li::before { content:''; position:absolute; left:0; top:15px; width:6px; height:6px; border-radius:50%; background:var(--primary); }
.page-content ol { counter-reset:list; }
.page-content ol li { counter-increment:list; }
.page-content ol li::before { content:counter(list)'. '; position:absolute; left:0; font-weight:700; color:var(--primary-light); }

/* ============================================================
   404
   ============================================================ */
.error-404-section {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:var(--bg); text-align:center; padding:40px;
}
.error-404__number {
  font-size:clamp(8rem,20vw,14rem); font-weight:900;
  letter-spacing:-.05em; line-height:1;
  background:var(--g-brand); -webkit-background-clip:text;
  background-clip:text; -webkit-text-fill-color:transparent;
  opacity:.3; margin-bottom:-20px;
}
.error-404__title { font-size:2rem; font-weight:800; color:var(--text); margin-bottom:16px; }
.error-404__desc { font-size:1rem; color:var(--text-2); margin-bottom:40px; }

/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */
[data-animate] {
  opacity:0; transform:translateY(32px);
  transition:opacity .6s ease-out, transform .6s cubic-bezier(.34,1.2,.64,1);
}
[data-animate].is-visible { opacity:1; transform:none; }
[data-animate-delay="1"] { transition-delay:.1s; }
[data-animate-delay="2"] { transition-delay:.2s; }
[data-animate-delay="3"] { transition-delay:.3s; }
[data-animate-delay="4"] { transition-delay:.4s; }
[data-animate-delay="5"] { transition-delay:.5s; }
[data-animate="fade-left"] { transform:translateX(-32px); }
[data-animate="fade-left"].is-visible { transform:none; }
[data-animate="fade-right"] { transform:translateX(32px); }
[data-animate="fade-right"].is-visible { transform:none; }
[data-animate="scale-up"] { transform:scale(.9); }
[data-animate="scale-up"].is-visible { transform:none; }

/* ============================================================
   RESPONSIVIDADE
   ============================================================ */
@media (max-width:1024px) {
  .pacto-hero__inner { grid-template-columns:1fr; text-align:center; gap:48px; }
  .pacto-hero__text { max-width:100%; }
  .pacto-hero__actions { justify-content:center; }
  .pacto-hero__proof { justify-content:center; }
  .pacto-hero__phone-wrap { order:2; }
  .pacto-hero__phone-shell { width:230px; height:450px; }
  .pacto-hero__phone { width:230px; }
  .phone-badge { display:none; }
  .how-steps { grid-template-columns:1fr; }
  .how-steps::before { display:none; }
  .features-grid { grid-template-columns:1fr 1fr; }
  .audience-grid { grid-template-columns:1fr; }
  .security-grid { grid-template-columns:1fr; }
  .about-grid { grid-template-columns:1fr; }
  .pacto-footer__grid { grid-template-columns:1fr 1fr; }
}
/* Tablet — 900px: links compactos, CTA reduzido */
@media (max-width:900px) {
  .pacto-nav { padding-inline:16px; }
  .pacto-nav__links a { padding:7px 10px; font-size:.82rem; }
  .btn-nav-download { padding:9px 16px; font-size:.82rem; }
}
@media (max-width:768px) {
  .pacto-nav { padding-inline:16px; }
  .pacto-nav__links, .btn-nav-download { display:none; }
  .pacto-nav__toggle { display:flex; }
  /* overlay e mobile-menu: controlados por transform + .open (ver linhas acima) */
  .proof-bar__inner { grid-template-columns:1fr 1fr; }
  .features-grid { grid-template-columns:1fr; }
  .downloads-grid { grid-template-columns:1fr; }
  .footer-bottom { gap:12px; }
  .footer-bottom__row { flex-direction:column; gap:12px; }
  .footer-bottom-links { justify-content:center; flex-wrap:wrap; gap:14px; }
  .pacto-footer__grid { grid-template-columns:1fr; }
  .page-content { padding:24px 20px; }
  .about-pillars { grid-template-columns:1fr; }
  .cta-download-grid { flex-direction:column; align-items:center; }
  .cta-platform-btn { width:100%; max-width:280px; }
  .security-grid { grid-template-columns:1fr; }
  .security-visual { display:none; }
  .mobile-menu__footer { /* safe-area já aplicado pelo flex */ }
}
@media (max-width:480px) {
  :root { --container:min(1200px,100% - 32px); }
  .pacto-hero__headline { font-size:2.1rem; }
  .pacto-hero__sub { font-size:.9rem; }
  .btn--lg { padding:14px 20px; font-size:.875rem; }
  .audience-card { padding:28px 20px; }
  .section-title { font-size:1.7rem; }
  /* Mockup menor em celulares pequenos */
  .pacto-hero__phone-shell { width:190px; height:370px; }
  .pacto-hero__phone { width:190px; }
  /* Prova social — coluna única */
  .proof-bar__inner { grid-template-columns:1fr 1fr; gap:20px; }
  /* Botões CTA lado a lado → pilha */
  .pacto-hero__actions { flex-direction:column; width:100%; }
  .pacto-hero__actions .btn { width:100%; justify-content:center; }
  /* Menu topo — menos padding */
  .pacto-nav { padding-inline:14px; }
  .pacto-nav__inner { height:62px; }
  .pacto-nav.scrolled .pacto-nav__inner { height:54px; }
  /* Footer — compacto em mobile */
  .pacto-footer { padding-block:48px 24px; }
  .pacto-footer__grid { gap:32px; margin-bottom:36px; }
  .footer-desc { max-width:100%; }
  .footer-copy { font-size:.72rem; }
  .footer-copy--address { font-size:.66rem; }
  .footer-bottom-links { gap:12px; }
  .footer-bottom-links a { font-size:.72rem; }
  .footer-live-badge { font-size:.66rem; padding:4px 10px; }
}

/* ============================================================
   ACESSIBILIDADE
   ============================================================ */
@media (prefers-reduced-motion:reduce) {
  *, *::before, *::after { animation-duration:.01ms !important; transition-duration:.01ms !important; }
}
:focus-visible { outline:2px solid var(--primary-light); outline-offset:3px; border-radius:4px; }

/* SCROLLBAR */
::-webkit-scrollbar { width:8px; }
::-webkit-scrollbar-track { background:var(--bg-2); }
::-webkit-scrollbar-thumb { background:rgba(124,58,237,.40); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--primary); }
::selection { background:rgba(124,58,237,.35); color:#fff; }

/* ============================================================
   PAGE TEMPLATE — classes sem underline (page.php / page-download.php)
   ============================================================ */
.page-hero-inner { position:relative; z-index:1; max-width:720px; margin-inline:auto; text-align:center; }
.page-hero-title {
  font-size:clamp(2rem,5vw,3.25rem); font-weight:800;
  color:#fff; letter-spacing:-.03em; line-height:1.15; margin-bottom:16px;
}
.page-hero-sub { font-size:1.05rem; color:rgba(255,255,255,.80); line-height:1.7; }
.page-content-wrapper { max-width:860px; margin-inline:auto; }

/* ============================================================
   404 — classes sem underline (404.php)
   ============================================================ */
.error-404-inner {
  max-width:560px; margin-inline:auto;
  display:flex; flex-direction:column; align-items:center;
}
.error-404-code {
  font-size:clamp(8rem,20vw,14rem); font-weight:900;
  letter-spacing:-.05em; line-height:1;
  background:var(--g-brand); -webkit-background-clip:text;
  background-clip:text; -webkit-text-fill-color:transparent;
  opacity:.3; margin-bottom:-20px;
}
.error-404-title { font-size:2rem; font-weight:800; color:var(--text); margin-bottom:16px; }
.error-404-sub { font-size:1rem; color:var(--text-2); margin-bottom:40px; text-align:center; line-height:1.7; }
.error-404-actions { display:flex; gap:16px; flex-wrap:wrap; justify-content:center; }

/* ============================================================
   DOWNLOAD REQUIREMENTS (page-download.php)
   ============================================================ */
.download-requirements {
  margin-top:72px; padding:40px; border-radius:var(--r-xl);
  background:var(--bg-glass); border:1px solid var(--border);
  backdrop-filter:blur(20px);
}
.download-req-title {
  font-size:1.3rem; font-weight:700; color:var(--text);
  margin-bottom:32px; text-align:center;
}
.download-req-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.download-req-item ul { list-style:none; display:flex; flex-direction:column; gap:8px; }
.download-req-item ul li {
  font-size:.875rem; color:var(--text-2); padding-left:20px; position:relative;
}
.download-req-item ul li::before {
  content:''; position:absolute; left:0; top:8px;
  width:6px; height:6px; border-radius:50%;
  background:var(--primary);
}
.download-req-platform {
  font-size:.9rem; font-weight:800; letter-spacing:.05em;
  margin-bottom:16px; text-transform:uppercase;
}
@media (max-width:768px) {
  .download-req-grid { grid-template-columns:1fr; }
  .error-404-actions { flex-direction:column; align-items:center; }
}

/* ============================================================
   LIGHT THEME — OVERRIDES (ADDITIVE — nada acima é modificado)
   Ativado via data-theme="light" no <html>.
   Padrão do sistema: light. Dark: opcional via toggle.
   ============================================================ */

/* ---- Tokens globais ---- */
[data-theme="light"] {
  --bg:       #F8FAFC;
  --bg-2:     #F1F5F9;
  --bg-3:     #E2E8F0;
  --bg-card:  rgba(0,0,0,.025);
  --bg-glass: rgba(0,0,0,.025);

  --text:      #0F172A;
  --text-2:    rgba(15,23,42,.65);
  --text-3:    rgba(15,23,42,.40);

  --border:   rgba(0,0,0,.08);
  --border-2: rgba(124,58,237,.18);

  --g-card:   linear-gradient(135deg, rgba(124,58,237,.04) 0%, rgba(251,113,133,.03) 100%);
  --g-text:   linear-gradient(135deg, #6D28D9 0%, #DB2777 100%);

  --shadow-sm:   0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.03);
  --shadow-md:   0 4px 12px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.03);
  --shadow-lg:   0 12px 32px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.04);
  --shadow-glow: 0 0 32px rgba(124,58,237,.10);
}

/* ---- Navbar ---- */
[data-theme="light"] .pacto-nav { border-bottom-color: rgba(0,0,0,.06); }
[data-theme="light"] .pacto-nav::before {
  background: linear-gradient(180deg, rgba(248,250,252,.8) 0%, transparent 100%);
}
[data-theme="light"] .pacto-nav.scrolled {
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(28px) saturate(180%); -webkit-backdrop-filter: blur(28px) saturate(180%);
  border-color: rgba(0,0,0,.06);
  box-shadow: 0 1px 0 rgba(0,0,0,.04), 0 4px 16px rgba(0,0,0,.05);
}
[data-theme="light"] .pacto-nav__links a { color: var(--text-2); }
[data-theme="light"] .pacto-nav__links a:hover { color: var(--text); background: rgba(0,0,0,.04); }
[data-theme="light"] .pacto-nav__toggle:hover { background: rgba(0,0,0,.06); }
[data-theme="light"] .pacto-nav__toggle:active { background: rgba(0,0,0,.10); }
[data-theme="light"] .pacto-nav__toggle span { background: var(--text); }

/* ---- Overlay ---- */
[data-theme="light"] .nav-overlay { background: rgba(0,0,0,.25); }

/* ---- Menu mobile ---- */
[data-theme="light"] .pacto-nav__mobile {
  background: linear-gradient(160deg, #FFFFFF 0%, #F8FAFC 100%);
  border-left-color: rgba(124,58,237,.12);
  box-shadow: -16px 0 48px rgba(0,0,0,.08), -1px 0 0 rgba(0,0,0,.04);
}
[data-theme="light"] .pacto-nav__mobile.open::before { opacity: .3; }
[data-theme="light"] .mobile-menu__header {
  background: rgba(255,255,255,.95); border-bottom-color: rgba(0,0,0,.06);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
}
[data-theme="light"] .mobile-menu__close { background: rgba(0,0,0,.05); color: var(--text-2); }
[data-theme="light"] .mobile-menu__close:hover { background: rgba(0,0,0,.10); color: var(--text); }
[data-theme="light"] .mobile-menu__item { color: var(--text-2); }
[data-theme="light"] .mobile-menu__item:hover,
[data-theme="light"] .mobile-menu__item:focus-visible { color: var(--text); background: rgba(124,58,237,.06); }
[data-theme="light"] .mobile-menu__item:active { background: rgba(124,58,237,.12); }
[data-theme="light"] .mobile-menu__item.active { background: rgba(124,58,237,.06); }
[data-theme="light"] .mobile-menu__icon { background: rgba(0,0,0,.04); }
[data-theme="light"] .mobile-menu__item:hover .mobile-menu__icon { background: rgba(124,58,237,.10); }
[data-theme="light"] .mobile-menu__divider { background: linear-gradient(90deg, transparent, rgba(0,0,0,.07), transparent); }

/* ---- Hero orbs — sutis no light ---- */
[data-theme="light"] .pacto-hero__orb--1 { opacity: .3; }
[data-theme="light"] .pacto-hero__orb--2 { opacity: .2; }
[data-theme="light"] .pacto-hero__orb--3 { opacity: .2; }
[data-theme="light"] .pacto-hero__grid {
  background-image:
    linear-gradient(rgba(124,58,237,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,58,237,.03) 1px, transparent 1px);
}

/* ---- Botões outline/ghost ---- */
[data-theme="light"] .btn--outline { color: var(--text); border-color: rgba(0,0,0,.25); background: rgba(0,0,0,.04); }
[data-theme="light"] .btn--outline:hover { background: rgba(0,0,0,.08); border-color: rgba(0,0,0,.35); }
[data-theme="light"] .btn--ghost { background: rgba(124,58,237,.08); color: #6D28D9; border-color: rgba(124,58,237,.18); }
[data-theme="light"] .btn--ghost:hover { background: rgba(124,58,237,.14); }

/* ---- Proof bar ---- */
[data-theme="light"] .proof-bar { background: rgba(0,0,0,.015); }

/* ---- How steps ---- */
[data-theme="light"] .how-step {
  background: rgba(255,255,255,.7); border-color: rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
}
[data-theme="light"] .how-step:hover { border-color: rgba(124,58,237,.25); box-shadow: var(--shadow-lg); }
[data-theme="light"] .how-step__icon-wrap { background: rgba(124,58,237,.10); border-color: rgba(124,58,237,.18); }

/* ---- Feature cards ---- */
[data-theme="light"] .feature-card {
  background: rgba(255,255,255,.7); border-color: rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
}
[data-theme="light"] .feature-card:hover { border-color: rgba(124,58,237,.22); box-shadow: var(--shadow-md); }

/* ---- Audience section ---- */
[data-theme="light"] .audience-card--clients {
  background: linear-gradient(135deg, rgba(124,58,237,.05) 0%, rgba(79,70,229,.02) 100%);
  border-color: rgba(124,58,237,.10);
}
[data-theme="light"] .audience-card--pros {
  background: linear-gradient(135deg, rgba(251,113,133,.05) 0%, rgba(224,29,72,.02) 100%);
  border-color: rgba(251,113,133,.10);
}

/* ---- Download cards ---- */
[data-theme="light"] .download-card {
  background: rgba(255,255,255,.8); border-color: rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
}
[data-theme="light"] .download-card:hover { border-color: rgba(124,58,237,.25); box-shadow: var(--shadow-lg); }
[data-theme="light"] .download-card--featured::before {
  background: linear-gradient(135deg, rgba(124,58,237,.06) 0%, rgba(251,113,133,.04) 100%);
}

/* ---- Segurança ---- */
[data-theme="light"] .security-section {
  background: linear-gradient(135deg, rgba(124,58,237,.025) 0%, rgba(16,185,129,.015) 100%);
}
[data-theme="light"] .security-feature {
  background: rgba(255,255,255,.6); border-color: rgba(0,0,0,.06);
}
[data-theme="light"] .security-feature:hover { border-color: rgba(16,185,129,.18); }
[data-theme="light"] .security-feature__icon { background: rgba(16,185,129,.10); }
[data-theme="light"] .security-ring { border-color: rgba(16,185,129,.08); }

/* ---- Depoimentos ---- */
[data-theme="light"] .testimonial-card {
  background: rgba(255,255,255,.8); border-color: rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
}
[data-theme="light"] .testimonial-card:hover { border-color: rgba(124,58,237,.22); }

/* ---- Rodapé ---- */
[data-theme="light"] .pacto-footer { background: #F1F5F9; }
[data-theme="light"] .footer-social-btn {
  background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.08);
}
[data-theme="light"] .footer-social-btn:hover { background: var(--primary); border-color: var(--primary); color: #fff; }
[data-theme="light"] .footer-live-badge {
  background: rgba(16,185,129,.06); border-color: rgba(16,185,129,.12);
}

/* ---- Page content (termos, privacidade, FAQ) ---- */
[data-theme="light"] .page-content {
  background: rgba(255,255,255,.8); border-color: rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
}
[data-theme="light"] .page-content h2 { color: #0F172A; border-bottom-color: rgba(0,0,0,.08); }
[data-theme="light"] .page-content h2::before { background: var(--primary); }
[data-theme="light"] .page-content h3 { color: #1E293B; }
[data-theme="light"] .page-content p { color: rgba(15,23,42,.65); }
[data-theme="light"] .page-content ul li,
[data-theme="light"] .page-content ol li { color: rgba(15,23,42,.65); }

/* ---- Page Hero / Sobre — light mode ---- */
[data-theme="light"] .page-hero {
  background: linear-gradient(135deg, #7C3AED 0%, #6D28D9 50%, #5B21B6 100%);
}
[data-theme="light"] .page-hero::after {
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
}
[data-theme="light"] .section-badge {
  background: rgba(124,58,237,.08); border-color: rgba(124,58,237,.15);
  color: #6D28D9;
}
[data-theme="light"] .section-badge::before {
  background: #6D28D9;
}
[data-theme="light"] .page-hero .section-badge {
  background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.25);
  color: #fff;
}
[data-theme="light"] .page-hero .section-badge::before {
  background: #fff;
}
[data-theme="light"] .page-hero-title { color: #fff !important; }
[data-theme="light"] .page-hero-sub { color: rgba(255,255,255,.85) !important; }
/* Forçar texto branco em TUDO dentro do hero roxo — light mode */
[data-theme="light"] .page-hero-inner,
[data-theme="light"] .page-hero-inner * { color: rgba(255,255,255,.85) !important; }
[data-theme="light"] .page-hero-title { color: #fff !important; }
[data-theme="light"] .page-content-section { background: #F8FAFC; }

/* ---- Navbar light mode SOBRE HERO ROXO (página interna: Sobre, Termos, etc.) ---- */
/* Quando a navbar está sobre fundo roxo, ela deve ficar transparente e usar texto branco.
   EXCLUÍMOS: home (hero claro) e marketplace (sem hero roxo).
   :not(.pacto-mkt-page) garante que marketplace NUNCA receba estilos de hero roxo. */
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) {
  border-bottom-color: transparent;
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled)::before {
  background: linear-gradient(180deg, rgba(91,33,182,.55) 0%, transparent 100%);
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) .pacto-nav__links a {
  color: rgba(255,255,255,.80);
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) .pacto-nav__links a:hover {
  color: #fff; background: rgba(255,255,255,.12);
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) .pacto-wordmark {
  background: linear-gradient(135deg, #fff 0%, rgba(255,255,255,.85) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) .pacto-theme-toggle {
  color: rgba(255,255,255,.80);
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) .pacto-theme-toggle:hover {
  color: #fff; background: rgba(255,255,255,.12);
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) .pacto-nav__toggle span {
  background: #fff;
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) .btn-nav-download {
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.30);
  color: #fff; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
[data-theme="light"] body.page:not(.home):not(.pacto-mkt-page) .pacto-nav:not(.scrolled) .btn-nav-download:hover {
  background: rgba(255,255,255,.25); border-color: rgba(255,255,255,.50);
}

/* ---- HOME PAGE — Light mode: navbar DEVE ter textos ESCUROS ---- */
/* Garante que a front-page (body.home) nunca herde estilos de hero roxo.
   WordPress pode gerar body.home com ou sem .page, dependendo da config.
   Estes seletores têm especificidade suficiente para vencer .page-wrapper. */
[data-theme="light"] body.home .pacto-nav:not(.scrolled) {
  border-bottom-color: rgba(0,0,0,.06);
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled)::before {
  background: linear-gradient(180deg, rgba(248,250,252,.8) 0%, transparent 100%);
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled) .pacto-nav__links a {
  color: var(--text-2);
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled) .pacto-nav__links a:hover {
  color: var(--text); background: rgba(0,0,0,.04);
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled) .pacto-wordmark {
  background: var(--g-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled) .pacto-theme-toggle {
  color: var(--text-2);
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled) .pacto-theme-toggle:hover {
  color: var(--text); background: rgba(0,0,0,.06);
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled) .pacto-nav__toggle span {
  background: var(--text);
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled) .btn-nav-download {
  background: var(--g-brand); color: #fff;
  border: 1px solid rgba(124,58,237,.30);
  box-shadow: 0 4px 16px rgba(124,58,237,.25);
}
[data-theme="light"] body.home .pacto-nav:not(.scrolled) .btn-nav-download:hover {
  box-shadow: 0 8px 24px rgba(124,58,237,.40);
}

/* ---- MARKETPLACE — Light mode: navbar DEVE ter textos ESCUROS (sem hero roxo) ---- */
/* Páginas do marketplace (body.page.pacto-mkt-page) não possuem hero roxo,
   portanto devem ter o mesmo tratamento da home: wordmark gradiente, ícones escuros.
   Especificidade: body.page.pacto-mkt-page = 0-2-1 empata com body.page:not(.home) = 0-2-1
   → ordem no arquivo decide → marketplace vem depois → VENCE. */
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) {
  border-bottom-color: rgba(0,0,0,.06);
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled)::before {
  background: linear-gradient(180deg, rgba(248,250,252,.8) 0%, transparent 100%);
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) .pacto-nav__links a {
  color: var(--text-2);
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) .pacto-nav__links a:hover {
  color: var(--text); background: rgba(0,0,0,.04);
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) .pacto-wordmark {
  background: var(--g-brand);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) .pacto-theme-toggle {
  color: var(--text-2);
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) .pacto-theme-toggle:hover {
  color: var(--text); background: rgba(0,0,0,.06);
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) .pacto-nav__toggle span {
  background: var(--text);
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) .btn-nav-download {
  background: var(--g-brand); color: #fff;
  border: 1px solid rgba(124,58,237,.30);
  box-shadow: 0 4px 16px rgba(124,58,237,.25);
}
[data-theme="light"] body.page.pacto-mkt-page .pacto-nav:not(.scrolled) .btn-nav-download:hover {
  box-shadow: 0 8px 24px rgba(124,58,237,.40);
}

/* ---- Sobre — pilares, manifesto, timeline no light ---- */
[data-theme="light"] .about-section { background: #F8FAFC; }
[data-theme="light"] .about-manifesto {
  color: rgba(15,23,42,.7); border-left-color: var(--primary);
}
[data-theme="light"] .about-pillar {
  background: rgba(255,255,255,.8); border-color: rgba(0,0,0,.06);
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
[data-theme="light"] .about-pillar:hover {
  border-color: rgba(124,58,237,.22);
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
}
[data-theme="light"] .about-pillar__title { color: #0F172A; }
[data-theme="light"] .about-pillar__desc { color: rgba(15,23,42,.6); }
[data-theme="light"] .timeline-dot {
  border-color: var(--primary); background: rgba(124,58,237,.08);
}
[data-theme="light"] .timeline-dot.completed { background: var(--primary); }
[data-theme="light"] .timeline-item:not(:last-child)::before {
  background: linear-gradient(180deg, var(--primary), rgba(124,58,237,.08));
}
[data-theme="light"] .timeline-year { color: #6D28D9; }
[data-theme="light"] .timeline-title { color: #0F172A; }
[data-theme="light"] .timeline-desc { color: rgba(15,23,42,.6); }

/* ---- Download requirements ---- */
[data-theme="light"] .download-requirements {
  background: rgba(255,255,255,.7); border-color: rgba(0,0,0,.06);
}

/* ---- Scrollbar ---- */
[data-theme="light"] ::-webkit-scrollbar-track { background: #F1F5F9; }
[data-theme="light"] ::-webkit-scrollbar-thumb { background: rgba(124,58,237,.22); }
[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background: var(--primary); }
[data-theme="light"] ::selection { background: rgba(124,58,237,.18); color: #0F172A; }

/* ---- Theme toggle button ---- */
.pacto-theme-toggle {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: var(--r-sm);
  background: none; border: none; color: var(--text-2);
  cursor: pointer; transition: background var(--t-fast), color var(--t-fast);
  flex-shrink: 0;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.pacto-theme-toggle:hover { background: rgba(255,255,255,.08); color: var(--text); }
[data-theme="light"] .pacto-theme-toggle:hover { background: rgba(0,0,0,.06); }
.pacto-theme-toggle svg { width: 18px; height: 18px; transition: transform var(--t-spring), opacity var(--t-fast); }
/* Moon icon: visible in light theme (clicking switches to dark) */
.pacto-theme-toggle__moon { display: none; }
[data-theme="light"] .pacto-theme-toggle__moon { display: block; }
[data-theme="light"] .pacto-theme-toggle__sun { display: none; }

/* Mobile theme toggle item (inside mobile menu) */
.mobile-menu__theme-toggle {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 12px; border-radius: var(--r-md); color: var(--text-2);
  cursor: pointer; background: none; border: none; width: 100%;
  font-family: inherit; font-size: .925rem; font-weight: 600;
  transition: color var(--t-fast), background var(--t-fast);
  touch-action: manipulation; -webkit-tap-highlight-color: transparent;
}
.mobile-menu__theme-toggle:hover { color: var(--text); background: rgba(124,58,237,.14); }
[data-theme="light"] .mobile-menu__theme-toggle:hover { background: rgba(124,58,237,.06); }
.mobile-menu__theme-toggle .mobile-menu__icon { pointer-events: none; }
.mobile-menu__theme-label-dark { display: none; }
[data-theme="light"] .mobile-menu__theme-label-light { display: none; }
[data-theme="light"] .mobile-menu__theme-label-dark { display: inline; }
.mobile-menu__theme-toggle .mobile-menu__icon svg.theme-icon-moon { display: none; }
[data-theme="light"] .mobile-menu__theme-toggle .mobile-menu__icon svg.theme-icon-sun { display: none; }
[data-theme="light"] .mobile-menu__theme-toggle .mobile-menu__icon svg.theme-icon-moon { display: block; }

/* Hide desktop toggle on mobile (mobile menu has its own) */
@media (max-width: 768px) {
  .pacto-theme-toggle { display: none !important; }
}

/* ============================================================
   SECURITY AUDIT POPUP (pso-*)
   Badge "Criptografia de Ponta-a-Ponta" → scanner → resultado
   ============================================================ */

/* Badge interativo */
.footer-live-badge#pacto-security-badge {
  cursor: pointer;
  transition: all .25s ease;
  user-select: none;
}
.footer-live-badge#pacto-security-badge:hover {
  background: rgba(16,185,129,.22);
  border-color: rgba(16,185,129,.45);
  transform: scale(1.04);
}
.footer-live-badge#pacto-security-badge:active {
  transform: scale(.97);
}

/* Overlay fullscreen */
.pso {
  position: fixed; inset: 0; z-index: 100000;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0;
  transition: opacity .35s ease;
}
.pso--visible { opacity: 1; }
.pso--closing { opacity: 0; }

/* Container central */
.pso__box {
  width: 100%; max-width: 420px;
  background: linear-gradient(145deg, #1a1130 0%, #0f0a1e 100%);
  border: 1px solid rgba(124,58,237,.25);
  border-radius: 20px;
  padding: 32px 24px;
  position: relative;
  box-shadow: 0 24px 80px rgba(0,0,0,.5), 0 0 40px rgba(124,58,237,.15);
  animation: pso-enter .5s cubic-bezier(.16,1,.3,1) both;
  max-height: 90vh;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(124,58,237,.3) transparent;
}
.pso__box::-webkit-scrollbar { width: 4px; }
.pso__box::-webkit-scrollbar-thumb { background: rgba(124,58,237,.3); border-radius: 2px; }
.pso__box--result { animation: pso-enter .4s cubic-bezier(.16,1,.3,1) both; }

@keyframes pso-enter {
  from { opacity: 0; transform: scale(.9) translateY(20px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* Fechar */
.pso__close {
  position: absolute; top: 12px; right: 12px;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.6); font-size: 1.2rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .2s; line-height: 1;
}
.pso__close:hover { background: rgba(239,68,68,.2); color: #EF4444; border-color: rgba(239,68,68,.3); }

/* ---- SCANNER (Fase 1) ---- */
.pso__scanner {
  width: 100px; height: 100px;
  margin: 0 auto 20px; position: relative;
  display: flex; align-items: center; justify-content: center;
}
.pso__ring {
  position: absolute; inset: 0;
  border: 2px solid rgba(124,58,237,.3);
  border-top-color: #7C3AED;
  border-radius: 50%;
  animation: pso-spin 1.2s linear infinite;
}
.pso__ring--2 {
  inset: 8px;
  border-color: rgba(16,185,129,.2);
  border-top-color: #10B981;
  animation-duration: .9s;
  animation-direction: reverse;
}
@keyframes pso-spin { to { transform: rotate(360deg); } }

.pso__shield {
  width: 36px; height: 36px;
  color: rgba(255,255,255,.6);
  animation: pso-pulse 1.5s ease-in-out infinite;
}
@keyframes pso-pulse {
  0%, 100% { opacity: .6; transform: scale(1); }
  50%      { opacity: 1;  transform: scale(1.08); }
}

.pso__scan-line {
  position: absolute; left: 10%; right: 10%;
  height: 2px; border-radius: 1px;
  background: linear-gradient(90deg, transparent, #7C3AED, transparent);
  animation: pso-scanline 1.5s ease-in-out infinite;
}
@keyframes pso-scanline {
  0%   { top: 15%; opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { top: 85%; opacity: 0; }
}

/* Status text */
.pso__status {
  text-align: center; font-size: .88rem; font-weight: 600;
  color: rgba(255,255,255,.7); margin: 0 0 16px;
  transition: color .3s;
  min-height: 1.3em;
}

/* Progress bar */
.pso__progress {
  height: 4px; border-radius: 2px;
  background: rgba(255,255,255,.08);
  margin-bottom: 20px; overflow: hidden;
}
.pso__progress-bar {
  height: 100%; width: 0; border-radius: 2px;
  background: linear-gradient(90deg, #7C3AED, #10B981);
  transition: width .4s ease;
}

/* Check items */
.pso__checks { display: flex; flex-direction: column; gap: 6px; }
.pso__check {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; border-radius: 8px;
  font-size: .78rem; color: rgba(255,255,255,.5);
  transition: all .35s ease;
  background: transparent;
}
.pso__check--scanning {
  animation: pso-check-pulse .8s ease infinite;
}
@keyframes pso-check-pulse {
  0%, 100% { opacity: .5; }
  50%      { opacity: 1; }
}
.pso__check--ok {
  color: #10B981;
  background: rgba(16,185,129,.08);
  animation: none;
  opacity: 1;
}
.pso__check-icon { font-size: .9rem; flex-shrink: 0; }
.pso__check-text { flex: 1; }

/* ---- RESULTADO (Fase 2) ---- */
.pso__result-header { text-align: center; margin-bottom: 24px; }
.pso__result-shield {
  width: 64px; height: 64px; margin: 0 auto 14px;
  animation: pso-shield-in .6s cubic-bezier(.16,1,.3,1) both;
}
.pso__result-shield svg { width: 100%; height: 100%; }
@keyframes pso-shield-in {
  from { opacity: 0; transform: scale(.5) rotate(-10deg); }
  to   { opacity: 1; transform: scale(1) rotate(0); }
}

.pso__result-title {
  font-size: 1.2rem; font-weight: 800; color: #fff;
  margin: 0 0 6px; letter-spacing: -.02em;
}
.pso__result-sub {
  font-size: .82rem; color: rgba(255,255,255,.5); margin: 0;
}

/* Grid de cards de segurança */
.pso__result-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 10px; margin-bottom: 20px;
}
.pso__sec-card {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 14px; border-radius: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
  transition: all .2s;
  animation: pso-card-in .4s cubic-bezier(.16,1,.3,1) both;
}
.pso__sec-card:nth-child(1) { animation-delay: .05s; }
.pso__sec-card:nth-child(2) { animation-delay: .1s; }
.pso__sec-card:nth-child(3) { animation-delay: .15s; }
.pso__sec-card:nth-child(4) { animation-delay: .2s; }
.pso__sec-card:nth-child(5) { animation-delay: .25s; }
.pso__sec-card:nth-child(6) { animation-delay: .3s; }
@keyframes pso-card-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.pso__sec-card:hover {
  background: rgba(124,58,237,.08);
  border-color: rgba(124,58,237,.2);
}
.pso__sec-icon {
  font-size: 1.3rem; flex-shrink: 0;
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(124,58,237,.12);
  display: flex; align-items: center; justify-content: center;
}
.pso__sec-info { flex: 1; min-width: 0; }
.pso__sec-info strong {
  display: block; font-size: .82rem; color: #fff;
  margin-bottom: 2px; font-weight: 700;
}
.pso__sec-info p {
  font-size: .74rem; color: rgba(255,255,255,.45);
  margin: 0; line-height: 1.4;
}

/* Selo de verificação */
.pso__result-footer { text-align: center; }
.pso__result-stamp {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 20px;
  background: rgba(16,185,129,.1); border: 1px solid rgba(16,185,129,.2);
  font-size: .72rem; font-weight: 600; color: #10B981;
}

/* ---- LIGHT MODE ---- */
[data-theme="light"] .pso {
  background: rgba(255,255,255,.7);
}
[data-theme="light"] .pso__box {
  background: linear-gradient(145deg, #fff 0%, #F8FAFC 100%);
  border-color: rgba(124,58,237,.12);
  box-shadow: 0 24px 80px rgba(0,0,0,.15), 0 0 40px rgba(124,58,237,.08);
}
[data-theme="light"] .pso__status { color: rgba(15,23,42,.6); }
[data-theme="light"] .pso__progress { background: rgba(0,0,0,.06); }
[data-theme="light"] .pso__check { color: rgba(15,23,42,.45); }
[data-theme="light"] .pso__check--ok { color: #059669; background: rgba(16,185,129,.06); }
[data-theme="light"] .pso__shield { color: rgba(15,23,42,.3); }
[data-theme="light"] .pso__result-title { color: #0F172A; }
[data-theme="light"] .pso__result-sub { color: rgba(15,23,42,.45); }
[data-theme="light"] .pso__sec-card {
  background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.05);
}
[data-theme="light"] .pso__sec-card:hover {
  background: rgba(124,58,237,.04); border-color: rgba(124,58,237,.12);
}
[data-theme="light"] .pso__sec-info strong { color: #0F172A; }
[data-theme="light"] .pso__sec-info p { color: rgba(15,23,42,.5); }
[data-theme="light"] .pso__close {
  background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.08);
  color: rgba(15,23,42,.4);
}
[data-theme="light"] .pso__close:hover { background: rgba(239,68,68,.1); color: #EF4444; }

/* ---- RESPONSIVE ---- */
@media (max-width: 480px) {
  .pso__box { padding: 24px 16px; border-radius: 16px; max-width: 95vw; }
  .pso__result-title { font-size: 1.05rem; }
  .pso__scanner { width: 80px; height: 80px; }
  .pso__shield { width: 28px; height: 28px; }
  .pso__result-shield { width: 52px; height: 52px; }
  .pso__sec-icon { width: 32px; height: 32px; font-size: 1.1rem; border-radius: 8px; }
  .pso__sec-info strong { font-size: .78rem; }
  .pso__sec-info p { font-size: .7rem; }
  .pso__sec-card { padding: 10px 12px; gap: 10px; }
}
@media (max-width: 360px) {
  .pso__box { padding: 20px 14px; }
  .pso__result-title { font-size: .95rem; }
}
