/* ============================================
   ANA — Site Público (XAMPP ready)
   Design System · 2026
   ============================================ */

:root {
  --bg:         #030208;
  --bg-card:    rgba(15, 10, 28, 0.72);
  --bg-card-2:  rgba(22, 14, 40, 0.55);
  --border:     rgba(194,181,245,0.13);
  --border-h:   rgba(98,24,233,0.45);
  --text:       #ede2ff;
  --text-muted: #9b8ab8;
  --primary:    #6218e9;
  --primary-h:  #7a30ff;
  --teal:       #0d9488;
  --teal-h:     #2dd4bf;
  --gold:       #f59e0b;
  --glow:       rgba(98,24,233,0.45);
  --radius-sm:  10px;
  --radius:     14px;
  --radius-lg:  20px;
  --font-d:     "Inter", system-ui, sans-serif;
  --font-b:     "Inter", system-ui, sans-serif;
  --max:        1120px;
  --transition: 0.22s cubic-bezier(0.4,0,0.2,1);
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }

body {
  font-family: var(--font-b);
  font-size: 17px;
  line-height: 1.65;
  color: var(--text);
  background: var(--bg);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

a { color:inherit; text-decoration:none; }
img,svg { display:block; }
button { font-family:inherit; cursor:pointer; }

/* ── Background layers ── */
.bg-scene {
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(ellipse 130% 80% at 50% -15%, rgba(98,24,233,.38), transparent 55%),
    radial-gradient(ellipse 70% 50% at 95% 45%,  rgba(13,148,136,.12), transparent 50%),
    radial-gradient(ellipse 55% 35% at 5%  90%,  rgba(122,48,255,.15), transparent 45%),
    var(--bg);
}
.bg-scene::before {
  content:"";
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(194,181,245,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(194,181,245,.035) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: radial-gradient(ellipse 75% 65% at 50% 25%, black 10%, transparent 70%);
}
/* floating orbs */
.orb {
  position:fixed; border-radius:50%; pointer-events:none; z-index:-1;
  filter: blur(90px);
}
.orb-1 { width:520px;height:520px;top:-120px;left:-140px;
  background:radial-gradient(circle,rgba(98,24,233,.18),transparent 70%); animation:drift1 18s ease-in-out infinite; }
.orb-2 { width:380px;height:380px;bottom:-80px;right:-80px;
  background:radial-gradient(circle,rgba(13,148,136,.14),transparent 70%); animation:drift2 22s ease-in-out infinite; }
.orb-3 { width:280px;height:280px;top:45%;left:55%;
  background:radial-gradient(circle,rgba(245,158,11,.07),transparent 70%); animation:drift3 26s ease-in-out infinite; }

@keyframes drift1 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(60px,40px)} }
@keyframes drift2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-50px,-30px)} }
@keyframes drift3 { 0%,100%{transform:translate(0,0)} 33%{transform:translate(40px,-30px)} 66%{transform:translate(-30px,20px)} }

/* ── Layout helpers ── */
.wrap { width: min(100% - 40px, var(--max)); margin-inline:auto; }

/* ── HEADER ── */
.site-header {
  position:sticky; top:0; z-index:100;
  padding:14px 0;
  backdrop-filter:blur(20px) saturate(160%);
  background:rgba(3,2,8,.68);
  border-bottom:1px solid var(--border);
  transition:background var(--transition);
}
.header-inner {
  display:flex; align-items:center; justify-content:space-between; gap:20px;
}

/* Logo */
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-d);
  font-weight: 700;
  font-size: 1.2rem;
  letter-spacing: -.01em;
  color: var(--text);
  flex-shrink: 0;
  text-decoration: none;
}
.logo-img {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  object-fit: contain;
  flex-shrink: 0;
  filter: drop-shadow(0 0 12px rgba(98,24,233,.65));
}
.logo-wordmark {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
}
.logo-wordmark-img {
  /* mesma altura do ico.ico para ficar proporcional */
  height: 28px;
  width: auto;
  object-fit: contain;
  object-position: left center;
  display: block;
}
.logo-wordmark span {
  font-size: 0.53rem;
  font-weight: 500;
  color: var(--text-muted);
  letter-spacing: .07em;
  text-transform: uppercase;
  line-height: 1;
}

/* Nav */
.nav-desktop { display:flex; align-items:center; gap:4px; }
.nav-desktop a {
  padding:9px 16px; border-radius:999px;
  color:var(--text-muted); font-weight:500; font-size:.94rem;
  transition:color var(--transition), background var(--transition);
}
.nav-desktop a:hover,
.nav-desktop a.active { color:var(--text); background:rgba(98,24,233,.18); }

.nav-cta {
  padding:9px 20px !important;
  background:linear-gradient(135deg,var(--primary),var(--primary-h)) !important;
  color:#fff !important; font-weight:600 !important;
  box-shadow:0 4px 20px rgba(98,24,233,.4);
}
.nav-cta:hover { filter:brightness(1.08); color:#fff !important; }

.menu-toggle {
  display:none; width:42px; height:42px;
  border:1px solid var(--border); border-radius:var(--radius-sm);
  background:var(--bg-card); color:var(--text);
  align-items:center; justify-content:center;
}
.nav-mobile {
  display:none; flex-direction:column; gap:2px;
  padding:12px 0 8px; border-top:1px solid var(--border); margin-top:12px;
}
.nav-mobile a { padding:12px 14px; border-radius:var(--radius-sm); color:var(--text-muted); font-weight:500; transition:background .2s,color .2s; }
.nav-mobile a:hover,.nav-mobile a.active { background:rgba(98,24,233,.15); color:var(--text); }

@media(max-width:820px){
  .nav-desktop { display:none; }
  .menu-toggle { display:flex; }
  .nav-mobile.open { display:flex; }
}

/* ── Header estilo app (Sobre / Planos) — alinhado ao CustomHeader / WebView do app ── */
.site-header--app {
  padding: 0;
  padding-top: env(safe-area-inset-top, 0px);
  background: linear-gradient(135deg, #6218e9 0%, #7c3aed 52%, #8b5cf6 100%);
  border-bottom: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-radius: 0 0 28px 28px;
  box-shadow: 0 10px 36px rgba(98, 24, 233, 0.38);
}
.site-header--app .wrap {
  width: min(100% - 36px, var(--max));
}
.header-inner-app {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 44px;
  padding: 12px 0 14px;
}
.header-app-logo {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.22);
  z-index: 2;
  transition: background var(--transition), transform var(--transition);
}
.header-app-logo:hover {
  background: rgba(255, 255, 255, 0.22);
  transform: scale(1.02);
}
.header-app-logo-img {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  object-fit: contain;
}
.header-app-title {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  max-width: min(280px, calc(100% - 140px));
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  letter-spacing: -0.02em;
  line-height: 1.15;
  pointer-events: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.header-app-right {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 2;
}
.nav-desktop--app {
  display: flex;
  align-items: center;
  gap: 2px;
}
.nav-desktop--app a {
  padding: 8px 12px;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.88);
  font-weight: 500;
  font-size: 0.88rem;
  background: transparent;
}
.nav-desktop--app a:hover,
.nav-desktop--app a.active {
  color: #fff;
  background: rgba(255, 255, 255, 0.16);
}
.nav-desktop--app .nav-cta {
  padding: 8px 16px !important;
  margin-left: 4px;
  background: rgba(255, 255, 255, 0.95) !important;
  color: #6218e9 !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.18);
}
.nav-desktop--app .nav-cta:hover {
  filter: brightness(1.06);
  color: #5b16d4 !important;
}
.menu-toggle--app {
  border-color: rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}
.menu-toggle--app:hover {
  background: rgba(255, 255, 255, 0.2);
}
.site-header--app .nav-mobile {
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  margin-top: 0;
  padding: 10px 0 14px;
}
.site-header--app .nav-mobile a {
  color: rgba(255, 255, 255, 0.92);
}
.site-header--app .nav-mobile a:hover,
.site-header--app .nav-mobile a.active {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}
.site-header--app.scrolled {
  background: linear-gradient(135deg, #5a16d4 0%, #6f35d1 52%, #7a4fd9 100%);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}

/* WebView do app: sem header do site (o app já exibe barra com título e fechar) */
.webview-embed .site-header--app {
  display: none !important;
}

@media (max-width: 380px) {
  .header-app-title {
    font-size: 18px;
    max-width: calc(100% - 116px);
  }
}

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:13px 28px; border-radius:999px;
  font-family:var(--font-b); font-weight:600; font-size:1rem; border:none;
  cursor:pointer; transition:transform var(--transition),box-shadow var(--transition),filter var(--transition);
  text-decoration:none;
}
.btn-primary {
  background:linear-gradient(135deg,var(--primary),var(--primary-h));
  color:#fff; box-shadow:0 8px 28px rgba(98,24,233,.4);
}
.btn-primary:hover { transform:translateY(-2px); filter:brightness(1.06); box-shadow:0 12px 36px rgba(98,24,233,.5); }
.btn-ghost {
  background:transparent; color:var(--text);
  border:1.5px solid var(--border);
}
.btn-ghost:hover { background:rgba(255,255,255,.05); border-color:rgba(194,181,245,.35); }
.btn-teal {
  background:linear-gradient(135deg,var(--teal),#059669);
  color:#fff; box-shadow:0 8px 28px rgba(13,148,136,.3);
}
.btn-teal:hover { transform:translateY(-2px); filter:brightness(1.06); }
.btn-sm { padding:9px 20px; font-size:.9rem; }
.btn-full { width:100%; }

/* ── SECTION helpers ── */
section { padding:72px 0; }

.section-label {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px; border-radius:999px;
  border:1px solid var(--border); background:rgba(98,24,233,.1);
  color:var(--text-muted); font-size:.75rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:20px;
}
.section-label svg { width:13px; height:13px; flex-shrink:0; }

.section-title {
  font-family:var(--font-d); font-weight:700;
  font-size:clamp(1.7rem,3vw,2.2rem); letter-spacing:-.02em;
  line-height:1.15; text-align:center; margin-bottom:14px;
}
.section-sub {
  text-align:center; color:var(--text-muted); max-width:580px;
  margin:0 auto 52px; font-size:.97rem;
}
.gradient-text {
  background:linear-gradient(135deg,#fff 0%,#c4b5f5 45%,var(--primary-h) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* Divider */
.section-divider {
  border:none; height:1px;
  background:linear-gradient(90deg,transparent,var(--border) 30%,var(--border) 70%,transparent);
  margin:0;
}

/* ── HERO ── */
.hero {
  padding:80px 0 96px; text-align:center; position:relative;
}
.badge {
  display:inline-flex; align-items:center; gap:9px;
  padding:8px 18px; border-radius:999px;
  border:1px solid var(--border); background:rgba(98,24,233,.12);
  color:var(--text-muted); font-size:.85rem; font-weight:500; margin-bottom:30px;
}
.badge-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--teal-h); box-shadow:0 0 12px var(--teal);
  animation:pulse 2.5s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.85)} }

.hero h1 {
  font-family:var(--font-d); font-weight:700;
  font-size:clamp(2.2rem,5vw,3.4rem); line-height:1.1; letter-spacing:-.025em;
  margin-bottom:22px;
  background:linear-gradient(140deg,#fff 0%,#d8c9ff 40%,var(--primary-h) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-lead {
  max-width:640px; margin:0 auto 38px; color:var(--text-muted); font-size:1.1rem;
}
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }

/* Hero visual strip */
.hero-strip {
  display:flex; justify-content:center; gap:16px; flex-wrap:wrap;
  margin-top:56px;
}
.hero-stat {
  display:flex; flex-direction:column; align-items:center;
  padding:18px 28px; border-radius:var(--radius);
  background:var(--bg-card); border:1px solid var(--border);
  backdrop-filter:blur(12px); min-width:120px;
}
.hero-stat-num {
  font-family:var(--font-d); font-weight:800; font-size:1.6rem;
  background:linear-gradient(135deg,#fff,#c4b5f5);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  line-height:1;
}
.hero-stat-label { font-size:.78rem; color:var(--text-muted); margin-top:4px; font-weight:500; }

/* ── FEATURES GRID ── */
.features-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(290px,1fr));
  gap:18px;
}
.feature-card {
  padding:30px; border-radius:var(--radius);
  background:var(--bg-card); border:1px solid var(--border);
  backdrop-filter:blur(14px);
  transition:border-color var(--transition), transform var(--transition), box-shadow var(--transition);
  position:relative; overflow:hidden;
}
.feature-card::before {
  content:""; position:absolute; inset:0; opacity:0;
  background:radial-gradient(ellipse 80% 60% at 20% 20%, rgba(98,24,233,.12), transparent 60%);
  transition:opacity var(--transition);
}
.feature-card:hover { border-color:var(--border-h); transform:translateY(-5px); box-shadow:0 24px 52px rgba(0,0,0,.38); }
.feature-card:hover::before { opacity:1; }

.feature-icon {
  width:52px; height:52px; border-radius:14px;
  display:grid; place-items:center; margin-bottom:20px;
  position:relative;
}
.feature-icon svg { width:24px; height:24px; }
.fi-purple { background:linear-gradient(135deg,rgba(98,24,233,.35),rgba(122,48,255,.15)); border:1px solid rgba(98,24,233,.3); }
.fi-teal   { background:linear-gradient(135deg,rgba(13,148,136,.35),rgba(5,150,105,.15)); border:1px solid rgba(13,148,136,.3); }
.fi-gold   { background:linear-gradient(135deg,rgba(245,158,11,.25),rgba(234,179,8,.12)); border:1px solid rgba(245,158,11,.25); }
.fi-blue   { background:linear-gradient(135deg,rgba(59,130,246,.25),rgba(99,102,241,.12)); border:1px solid rgba(59,130,246,.25); }
.fi-rose   { background:linear-gradient(135deg,rgba(244,63,94,.22),rgba(236,72,153,.1)); border:1px solid rgba(244,63,94,.22); }
.fi-cyan   { background:linear-gradient(135deg,rgba(6,182,212,.22),rgba(14,165,233,.1)); border:1px solid rgba(6,182,212,.22); }

.feature-card h3 {
  font-family:var(--font-d); font-weight:600; font-size:1.05rem; margin-bottom:10px;
}
.feature-card p { color:var(--text-muted); font-size:.93rem; line-height:1.65; }

/* ── STEPS ── */
.steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:20px; counter-reset:step; }
.step {
  position:relative; padding:26px 24px 26px 76px;
  border-radius:var(--radius); border:1px solid var(--border);
  background:rgba(8,6,18,.5);
  transition:border-color var(--transition),transform var(--transition);
}
.step:hover { border-color:rgba(98,24,233,.3); transform:translateY(-3px); }
.step::before {
  counter-increment:step; content:counter(step);
  position:absolute; left:20px; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:10px;
  background:linear-gradient(135deg,var(--primary),var(--primary-h));
  display:grid; place-items:center;
  font-family:var(--font-d); font-weight:700; font-size:.95rem;
  box-shadow:0 6px 20px rgba(98,24,233,.35);
}
.step h3 { font-size:1rem; font-weight:600; margin-bottom:8px; }
.step p  { color:var(--text-muted); font-size:.9rem; }

/* ── CTA STRIP ── */
.cta-strip {
  padding:52px 36px; border-radius:var(--radius-lg); text-align:center;
  border:1px solid rgba(98,24,233,.28);
  background:linear-gradient(140deg,rgba(98,24,233,.18),rgba(13,148,136,.1));
  position:relative; overflow:hidden; margin-top:36px;
}
.cta-strip::before {
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 60% 60% at 25% 50%, rgba(98,24,233,.13), transparent 55%);
}
.cta-strip h2 { font-family:var(--font-d); font-weight:700; font-size:1.6rem; letter-spacing:-.015em; margin-bottom:12px; position:relative; }
.cta-strip p  { color:var(--text-muted); margin-bottom:26px; position:relative; max-width:480px; margin-left:auto; margin-right:auto; }
.cta-actions  { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; position:relative; }

/* ── PLANS ── */
.plans-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(285px,1fr));
  gap:22px; align-items:stretch;
}
.plan-card {
  padding:34px 28px; border-radius:var(--radius);
  border:1px solid var(--border); background:rgba(8,6,18,.58);
  display:flex; flex-direction:column; position:relative; overflow:hidden;
  transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.plan-card:hover { transform:translateY(-5px); }
.plan-card::before {
  content:""; position:absolute; inset:0; opacity:0; pointer-events:none;
  background:radial-gradient(ellipse 70% 50% at 50% -10%,rgba(98,24,233,.12),transparent 60%);
  transition:opacity var(--transition);
}
.plan-card:hover::before { opacity:1; }
/* Garantir que CTAs fiquem acima de qualquer camada do card */
.plan-card > .btn { position: relative; z-index: 1; }

.plan-card.featured {
  border-color:rgba(98,24,233,.5);
  box-shadow:0 0 0 1.5px rgba(98,24,233,.18), 0 28px 56px rgba(98,24,233,.14);
  background:linear-gradient(160deg,rgba(98,24,233,.16),rgba(8,6,18,.85));
}

.plan-badge-popular {
  position:absolute; top:18px; right:18px;
  padding:4px 12px; border-radius:999px; font-size:.72rem;
  background:linear-gradient(135deg,var(--primary),var(--primary-h));
  color:#fff; font-weight:700; letter-spacing:.04em;
}
.plan-label { font-size:.75rem; text-transform:uppercase; letter-spacing:.12em; color:var(--text-muted); font-weight:600; margin-bottom:8px; }
.plan-name {
  font-family:var(--font-d); font-weight:700; font-size:1.8rem;
  letter-spacing:-.015em; margin-bottom:8px;
}
.plan-price {
  font-family:var(--font-d); font-weight:700; font-size:2.5rem;
  letter-spacing:-.025em; line-height:1; margin-bottom:6px; color:var(--text);
}
.plan-price .amount {
  background:linear-gradient(135deg,#fff,#c4b5f5);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.plan-price .currency {
  font-size:1.1rem; font-weight:700; margin-right:3px;
  vertical-align:super; color:var(--text-muted);
}
.plan-period { color:var(--text-muted); font-size:.88rem; margin-bottom:28px; }
.plan-divider { border:none; height:1px; background:var(--border); margin-bottom:22px; }
.plan-card ul { list-style:none; margin-bottom:28px; flex:1; }
.plan-card li {
  padding:10px 0 10px 32px; position:relative;
  color:var(--text-muted); font-size:.93rem;
  border-bottom:1px solid rgba(194,181,245,.06);
}
.plan-card li:last-child { border-bottom:none; }
.plan-card li::before {
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:20px; height:20px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%232dd4bf'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E") no-repeat center;
}
.plan-note {
  text-align:center; color:var(--text-muted); font-size:.87rem;
  margin-top:44px; max-width:580px; margin-left:auto; margin-right:auto;
  line-height:1.7;
}

/* Comparison table */
.comparison { overflow-x:auto; margin-top:20px; }
.comparison table { width:100%; min-width:540px; border-collapse:collapse; font-size:.91rem; }
.comparison th,.comparison td { padding:14px 18px; text-align:left; border-bottom:1px solid var(--border); }
.comparison thead th { font-family:var(--font-d); font-weight:600; background:rgba(98,24,233,.12); }
.comparison td { color:var(--text-muted); }
.comparison .yes { color:var(--teal-h); font-weight:600; }
.comparison .no  { color:var(--text-muted); opacity:.4; }

/* ── SOBRE page ── */
.page-hero { padding:52px 0 36px; text-align:center; }
.page-hero h1 {
  font-family:var(--font-d); font-weight:700;
  font-size:clamp(2rem,4vw,2.65rem); letter-spacing:-.02em; margin-bottom:16px;
}
.page-hero p { color:var(--text-muted); max-width:650px; margin:0 auto; font-size:1.05rem; }

.glass-panel {
  padding:34px 32px; border-radius:var(--radius);
  background:var(--bg-card); border:1px solid var(--border);
  backdrop-filter:blur(14px); margin-bottom:28px;
}

.content-block { max-width:740px; margin:0 auto 48px; }
.content-block h2 {
  font-family:var(--font-d); font-weight:600; font-size:1.25rem;
  letter-spacing:-.01em; margin:40px 0 14px; padding-bottom:10px;
  border-bottom:1px solid var(--border);
}
.content-block h2:first-child { margin-top:0; }
.content-block p  { color:var(--text-muted); margin-bottom:16px; }
.content-block ul { padding-left:.2em; }
.content-block li {
  color:var(--text-muted); margin-bottom:12px; padding-left:28px;
  position:relative; list-style:none;
}
.content-block li::before {
  content:""; position:absolute; left:0; top:6px;
  width:18px; height:18px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236218e9'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E") no-repeat center;
}

/* ── FOOTER ── */
.site-footer {
  padding:52px 0 32px; border-top:1px solid var(--border); margin-top:64px;
}
.footer-grid {
  display:grid; grid-template-columns:1.4fr repeat(2,1fr); gap:48px;
}
@media(max-width:720px){ .footer-grid{ grid-template-columns:1fr; gap:32px; } }

.footer-brand .logo { margin-bottom:14px; }
.footer-brand p { color:var(--text-muted); font-size:.92rem; max-width:300px; line-height:1.65; }
.footer-col h4 {
  font-family:var(--font-d); font-weight:600; font-size:.78rem;
  text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); margin-bottom:18px;
}
.footer-col ul { list-style:none; }
.footer-col li { margin-bottom:12px; }
.footer-col a { color:rgba(237,226,255,.75); font-size:.93rem; transition:color .2s; }
.footer-col a:hover { color:var(--text); }
.footer-bottom {
  margin-top:44px; padding-top:24px; border-top:1px solid var(--border);
  text-align:center; color:var(--text-muted); font-size:.86rem;
}

/* ── Entrance animations ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
.fade-up { animation:fadeUp .65s cubic-bezier(.4,0,.2,1) both; }
.fade-up-d1 { animation-delay:.1s; }
.fade-up-d2 { animation-delay:.2s; }
.fade-up-d3 { animation-delay:.3s; }
.fade-up-d4 { animation-delay:.4s; }

/* ── Misc ── */
@media(max-width:600px){
  section { padding:52px 0; }
  .hero { padding:56px 0 72px; }
  .hero-strip { gap:10px; }
  .hero-stat { padding:14px 18px; min-width:100px; }
}

/* ════════════════════════════════════════
   EXTRAS — scroll reveal, hero 2-col,
   chat demo, FABs, back-to-top, suporte
   ════════════════════════════════════════ */

/* ── Header scrolled state ── */
.site-header.scrolled {
  background: rgba(3,2,8,.88);
  box-shadow: 0 1px 24px rgba(0,0,0,.35);
}

/* ── Scroll reveal ── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .6s cubic-bezier(.4,0,.2,1), transform .6s cubic-bezier(.4,0,.2,1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-d1 { transition-delay: .08s; }
.reveal-d2 { transition-delay: .16s; }
.reveal-d3 { transition-delay: .24s; }
.reveal-d4 { transition-delay: .32s; }
.reveal-d5 { transition-delay: .40s; }
.reveal-d6 { transition-delay: .48s; }

/* ── Hero 2-col ── */
.hero { padding: 72px 0 88px; }
.hero-wrap {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 64px;
  align-items: center;
}
.hero-content { text-align: left; }
.hero-content .badge { margin-bottom: 24px; }
.hero-content h1 { text-align: left; }
.hero-content .hero-lead { text-align: left; margin: 0 0 32px; max-width: 560px; }
.hero-content .hero-actions { justify-content: flex-start; }
.hero-strip {
  display: flex; flex-wrap: wrap; gap: 12px; margin-top: 40px;
}
.hero-stat {
  display: flex; flex-direction: column; align-items: center;
  padding: 16px 22px; border-radius: var(--radius);
  background: var(--bg-card); border: 1px solid var(--border);
  backdrop-filter: blur(12px); min-width: 108px;
}
.hero-stat-num {
  font-family: var(--font-d); font-weight: 700; font-size: 1.45rem;
  background: linear-gradient(135deg,#fff,#c4b5f5);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  line-height: 1;
}
.hero-stat-label { font-size: .72rem; color: var(--text-muted); margin-top: 4px; font-weight: 500; }

@media (max-width: 920px) {
  .hero-wrap {
    grid-template-columns: 1fr;
    gap: 48px;
    text-align: center;
  }
  .hero-content { text-align: center; }
  .hero-content h1 { text-align: center; }
  .hero-content .hero-lead { text-align: center; margin-inline: auto; }
  .hero-content .hero-actions { justify-content: center; }
  .hero-strip { justify-content: center; }
  .hero-visual { display: flex; justify-content: center; }
}

/* ── Chat Demo ── */
.chat-demo {
  width: 288px;
  background: #0a0716;
  border-radius: 22px;
  border: 1px solid rgba(194,181,245,.18);
  box-shadow:
    0 40px 80px rgba(0,0,0,.55),
    0 0 0 1px rgba(98,24,233,.12),
    inset 0 1px 0 rgba(255,255,255,.06);
  overflow: hidden;
  flex-shrink: 0;
}
.chat-demo-top {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(194,181,245,.1);
  background: rgba(98,24,233,.08);
}
.chat-demo-avatar {
  width: 32px; height: 32px; border-radius: 10px; flex-shrink: 0;
  background: linear-gradient(135deg, var(--primary), var(--primary-h));
  display: grid; place-items: center;
  font-family: var(--font-d); font-weight: 700; font-size: .85rem; color: #fff;
  box-shadow: 0 4px 12px rgba(98,24,233,.4);
}
.chat-demo-info { flex: 1; }
.chat-demo-name { font-size: .82rem; font-weight: 600; line-height: 1.2; }
.chat-demo-status {
  font-size: .68rem; color: var(--teal-h); font-weight: 500;
  display: flex; align-items: center; gap: 5px;
}
.chat-demo-status::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--teal-h); box-shadow: 0 0 8px var(--teal);
  animation: pulse 2s ease-in-out infinite;
}
.chat-demo-dots { display: flex; gap: 5px; }
.chat-demo-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(194,181,245,.35);
}

.chat-demo-body {
  padding: 14px; display: flex; flex-direction: column; gap: 10px;
  max-height: 280px; overflow-y: auto; scroll-behavior: smooth;
}
.chat-demo-body::-webkit-scrollbar { width: 3px; }
.chat-demo-body::-webkit-scrollbar-track { background: transparent; }
.chat-demo-body::-webkit-scrollbar-thumb { background: rgba(194,181,245,.2); border-radius: 4px; }

.chat-msg { opacity: 0; animation: msgIn .4s ease forwards; }
.chat-msg:nth-child(1) { animation-delay: .6s; }
.chat-msg:nth-child(2) { animation-delay: 1.4s; }
.chat-msg:nth-child(3) { animation-delay: 2.3s; }
.chat-msg:nth-child(4) { animation-delay: 3.2s; }
.chat-msg:nth-child(5) { animation-delay: 4.0s; }

@keyframes msgIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.chat-bubble {
  display: inline-block; max-width: 220px;
  padding: 9px 13px; border-radius: 14px;
  font-size: .82rem; line-height: 1.5;
}
.chat-bubble-ana {
  background: rgba(98,24,233,.25);
  border: 1px solid rgba(98,24,233,.3);
  color: var(--text); border-radius: 14px 14px 14px 4px;
}
.chat-bubble-user {
  background: rgba(45,212,191,.12);
  border: 1px solid rgba(45,212,191,.22);
  color: var(--text);
  border-radius: 14px 14px 4px 14px;
  align-self: flex-end; margin-left: auto;
  display: block;
}
.chat-bubble-label {
  font-size: .65rem; color: var(--text-muted); margin-bottom: 4px; font-weight: 500;
}
.chat-row-user { display: flex; justify-content: flex-end; }

.chat-typing {
  display: flex; align-items: center; gap: 5px;
  padding: 10px 13px;
  background: rgba(98,24,233,.18);
  border: 1px solid rgba(98,24,233,.25);
  border-radius: 14px 14px 14px 4px;
  width: fit-content;
  opacity: 0;
  animation: msgIn .4s ease .1s forwards;
}
.chat-typing span {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(196,181,245,.7);
  animation: typingDot 1.2s ease-in-out infinite;
}
.chat-typing span:nth-child(2) { animation-delay: .2s; }
.chat-typing span:nth-child(3) { animation-delay: .4s; }
@keyframes typingDot {
  0%,80%,100% { transform: scale(1); opacity: .5; }
  40%         { transform: scale(1.4); opacity: 1; }
}

/* ── WhatsApp FAB ── */
.fab-whatsapp {
  position: fixed; bottom: 88px; right: 24px; z-index: 200;
  width: 54px; height: 54px; border-radius: 50%;
  background: #25d366;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 28px rgba(37,211,102,.45);
  transition: transform var(--transition), box-shadow var(--transition);
  text-decoration: none;
  border: none; cursor: pointer;
}
.fab-whatsapp:hover {
  transform: translateY(-3px) scale(1.06);
  box-shadow: 0 12px 36px rgba(37,211,102,.55);
}
.fab-whatsapp svg { width: 28px; height: 28px; }

.fab-tooltip {
  position: absolute; right: calc(100% + 12px); top: 50%; transform: translateY(-50%);
  background: rgba(10,7,22,.92); backdrop-filter: blur(8px);
  color: var(--text); font-size: .78rem; font-weight: 500;
  padding: 6px 12px; border-radius: 8px;
  border: 1px solid var(--border); white-space: nowrap;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.fab-whatsapp:hover .fab-tooltip { opacity: 1; }

/* ── Back to top ── */
.back-to-top {
  position: fixed; bottom: 24px; right: 24px; z-index: 200;
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-muted); display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: transform var(--transition), opacity var(--transition),
    border-color var(--transition), color var(--transition);
  opacity: 0; pointer-events: none; backdrop-filter: blur(12px);
}
.back-to-top.visible { opacity: 1; pointer-events: auto; }
.back-to-top:hover {
  transform: translateY(-3px); border-color: var(--border-h);
  color: var(--primary-h);
}
.back-to-top svg { width: 20px; height: 20px; }

/* ── Suporte section ── */
.suporte-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 48px;
}
@media (max-width: 660px) {
  .suporte-card { grid-template-columns: 1fr; }
}
.suporte-item {
  padding: 28px 24px; border-radius: var(--radius);
  background: var(--bg-card); border: 1px solid var(--border);
  backdrop-filter: blur(12px); display: flex; flex-direction: column; gap: 12px;
  transition: border-color var(--transition), transform var(--transition);
}
.suporte-item:hover { border-color: var(--border-h); transform: translateY(-3px); }
.suporte-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: grid; place-items: center;
}
.suporte-icon.si-green {
  background: rgba(37,211,102,.18); border: 1px solid rgba(37,211,102,.25);
}
.suporte-icon.si-purple {
  background: rgba(98,24,233,.22); border: 1px solid rgba(98,24,233,.3);
}
.suporte-icon svg { width: 22px; height: 22px; }
.suporte-item h3 { font-weight: 600; font-size: 1rem; margin: 0; }
.suporte-item p  { color: var(--text-muted); font-size: .9rem; margin: 0; line-height: 1.55; }
.suporte-item a.btn { align-self: flex-start; margin-top: 4px; }

/* ── Chat demo input ── */
.chat-demo-input-area {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px 12px;
  border-top: 1px solid rgba(194,181,245,.1);
}
.chat-demo-input {
  flex: 1; background: rgba(98,24,233,.12); border: 1px solid rgba(98,24,233,.22);
  border-radius: 10px; padding: 8px 12px;
  font-family: var(--font-b); font-size: .8rem; color: var(--text); outline: none;
  transition: border-color .2s;
}
.chat-demo-input:focus { border-color: rgba(98,24,233,.5); }
.chat-demo-input::placeholder { color: var(--text-muted); }
.chat-demo-send {
  width: 32px; height: 32px; border-radius: 9px; border: none; flex-shrink: 0;
  background: linear-gradient(135deg, var(--primary), var(--primary-h));
  color: #fff; display: grid; place-items: center; cursor: pointer;
  transition: filter .2s, transform .15s;
}
.chat-demo-send:hover  { filter: brightness(1.1); transform: scale(1.06); }
.chat-demo-send:active { transform: scale(.95); }
.chat-demo-send svg { width: 14px; height: 14px; }

/* chat-demo wider for interactive */
.hero-wrap { grid-template-columns: 1fr 310px; }

/* ── Notificações card accent ── */
.fi-indigo { background: linear-gradient(135deg,rgba(99,102,241,.3),rgba(139,92,246,.15)); border: 1px solid rgba(99,102,241,.3); }

/* ── Responsive tweaks ── */
@media (max-width: 600px) {
  .chat-demo { width: 260px; }
  .fab-whatsapp { bottom: 80px; right: 18px; width: 50px; height: 50px; }
  .back-to-top  { bottom: 18px; right: 18px; width: 40px; height: 40px; }
}
