/* =========================================================
   Suporte ao Revendedor — GestoDentis
   Paleta oficial do site (indigo/violet) + fontes Manrope
   (body) e Plus Jakarta Sans (headlines).
   ========================================================= */

:root {
  /* paleta GestoDentis (extraída do CSS oficial) */
  --primary: #4F46E5;             /* indigo-600 */
  --primary-600: #4338CA;
  --primary-700: #3730A3;          /* on-primary-container */
  --primary-200: #C7D2FE;
  --primary-100: #E0E7FF;          /* primary-container */
  --primary-50:  #EEF2FF;          /* surface-variant */
  --violet:      #625FFF;
  --violet-2:    #8D54FF;
  --violet-3:    #AC4BFF;

  --accent-green:  #00C758;
  --accent-green-d:#00BB7F;
  --accent-orange: #F99C00;

  --dark-1: #1A1A2E;
  --dark-2: #1E1E2E;
  --dark-3: #252536;
  --dark-4: #2A2A3C;

  --gray-50:  #F9FAFB;
  --gray-100: #F3F4F6;
  --gray-200: #E5E7EB;
  --gray-300: #D1D5DB;
  --gray-500: #6B7280;
  --gray-600: #4B5563;
  --gray-700: #374151;
  --gray-900: #111827;

  --danger:    #DC2626;
  --danger-bg: #FEE2E2;

  --texto:       var(--gray-900);
  --texto-mid:   var(--gray-600);
  --texto-light: var(--gray-500);
  --linha:       var(--gray-200);
  --fundo:       var(--gray-50);

  --sombra-sm: 0 1px 2px rgba(17, 24, 39, .06), 0 4px 14px rgba(17, 24, 39, .04);
  --sombra-md: 0 6px 16px rgba(79, 70, 229, .10), 0 18px 48px rgba(17, 24, 39, .08);
  --sombra-lg: 0 20px 60px rgba(17, 24, 39, .22);
  --ring:      0 0 0 3px rgba(79, 70, 229, .18);

  --raio: 14px;
  --raio-sm: 10px;
  --transi: .22s cubic-bezier(.4, 0, .2, 1);

  --font-body: "Manrope", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-headline: "Plus Jakarta Sans", "Manrope", ui-sans-serif, system-ui, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
/* Override CRÍTICO: classes com `display:` venceriam o atributo `hidden`
   (UA stylesheet). Sem isto, modais/level-up/login ficam sempre visíveis. */
[hidden] { display: none !important; }

/* SVG sem width/height explícito sai com 300×150 (default replaced
   element). Garante um tamanho razoável herdando do contexto. */
svg { max-width: 100%; }
button svg, a svg { flex: 0 0 auto; }
body {
  font-family: var(--font-body);
  background:
    radial-gradient(1200px 600px at 90% -10%, rgba(98, 95, 255, .12), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(79, 70, 229, .10), transparent 65%),
    var(--fundo);
  color: var(--texto);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
  font-feature-settings: "cv02", "cv03", "cv04", "cv11";
}

h1, h2, h3, h4 { font-family: var(--font-headline); letter-spacing: -0.018em; }

img { max-width: 100%; display: block; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
input, select, textarea { font: inherit; color: inherit; }
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* =========================================================
   Login
   ========================================================= */
.tela-login {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 1.5rem;
}
.login-card {
  width: min(420px, 100%);
  background: #fff;
  border-radius: 22px;
  padding: 2.2rem 1.8rem;
  box-shadow: var(--sombra-md);
  border: 1px solid var(--linha);
  animation: fadeUp .5s var(--transi);
}
.login-brand { text-align: center; margin-bottom: 1.6rem; }
.login-logo {
  width: 80px; height: 80px; margin: 0 auto 0.9rem;
  filter: drop-shadow(0 10px 24px rgba(79, 70, 229, .28));
}
.login-brand h1 { font-size: 1.5rem; margin: 0; font-weight: 800; color: var(--texto); }
.login-sub { color: var(--texto-mid); margin: .35rem 0 0; font-size: .95rem; }
.login-label {
  display: block; font-size: .9rem; color: var(--texto-mid);
  margin-bottom: .6rem; text-align: center;
}
.pin-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: .5rem;
  margin: 0 auto 1rem;
}
.pin {
  /* Sem `min-width: 0` + `width: 100%`, o input mantém min-content ~200px
     (vem do atributo `size=20` default) e fura o grid de 6 colunas. */
  min-width: 0; width: 100%;
  height: 56px; text-align: center; font-size: 1.5rem; font-weight: 700;
  border: 2px solid var(--linha); background: #fff;
  border-radius: 12px; outline: none;
  color: var(--primary-700);
  padding: 0; /* evita interferência do user-agent */
  transition: border-color var(--transi), transform var(--transi), box-shadow var(--transi);
  -webkit-text-security: disc; text-security: disc;
}
.pin:focus { border-color: var(--primary); box-shadow: var(--ring); }
.pin.preenchido { background: var(--primary-50); border-color: var(--primary); }
.pin.erro { border-color: var(--danger); animation: shake .35s; }
.login-erro {
  background: var(--danger-bg); color: #991B1B;
  padding: .65rem .9rem; border-radius: 10px; font-size: .9rem;
  margin-bottom: .8rem; text-align: center;
}
.login-foot { text-align: center; margin-top: 1.2rem; color: var(--texto-light); }

/* =========================================================
   Top bar
   ========================================================= */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 1rem;
  padding: .85rem 1.25rem;
  background: rgba(255,255,255,.85);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--linha);
}
.topbar-brand {
  display: flex; align-items: center; gap: .6rem;
  font-weight: 800; color: var(--texto);
  text-decoration: none;
  font-family: var(--font-headline);
}
.topbar-brand img { width: 32px; height: 32px; border-radius: 8px; }
.topbar-brand span { font-size: 1.02rem; letter-spacing: -.012em; }
.topbar-brand em { font-style: normal; color: var(--primary); font-weight: 700; }
.topbar-nav { display: flex; gap: .25rem; margin-left: auto; }
.nav-link {
  padding: .5rem .9rem; border-radius: 999px; color: var(--texto-mid);
  font-weight: 600; transition: background var(--transi), color var(--transi);
}
.nav-link:hover { color: var(--primary-700); text-decoration: none; background: var(--primary-50); }
.nav-link.ativo {
  background: linear-gradient(135deg, var(--primary), var(--violet));
  color: #fff;
  box-shadow: 0 4px 14px rgba(79, 70, 229, .35);
}
.topbar-perfil { display: flex; align-items: center; gap: .5rem; margin-left: .5rem; }

/* Indicador de sincronização com o servidor */
.sync-indicador {
  font-size: .72rem;
  font-weight: 700;
  padding: .25rem .55rem;
  border-radius: 999px;
  letter-spacing: .02em;
  white-space: nowrap;
  transition: background var(--transi), color var(--transi);
}
.sync-indicador[data-estado="ok"]            { background: #E6F7EE; color: #0A6B5C; }
.sync-indicador[data-estado="sincronizando"] { background: var(--primary-50); color: var(--primary-700); }
.sync-indicador[data-estado="offline"]       { background: #FEF3C7; color: #92400E; }
@media (max-width: 720px) {
  .sync-indicador { display: none; }
}
.perfil-btn {
  display: flex; align-items: center; gap: .55rem;
  padding: .35rem .75rem .35rem .35rem; border-radius: 999px;
  background: var(--primary-50); color: var(--primary-700); font-weight: 700;
  transition: background var(--transi);
}
.perfil-btn:hover { background: var(--primary-100); }
.perfil-btn img {
  width: 30px; height: 30px; border-radius: 50%; object-fit: cover;
  background: #fff; border: 1.5px solid #fff;
}
.btn-fantasma {
  padding: .55rem .85rem; border-radius: 10px; color: var(--texto-mid);
  display: inline-flex; align-items: center; gap: .4rem;
  transition: background var(--transi), color var(--transi);
}
.btn-fantasma:hover { background: var(--primary-50); color: var(--primary-700); }

/* =========================================================
   Conteúdo
   ========================================================= */
.conteudo { max-width: 1200px; margin: 0 auto; padding: 1.5rem 1.25rem 4rem; }

.kicker {
  display: inline-block; margin: 0 0 .35rem;
  color: var(--primary); font-weight: 800; font-size: .75rem;
  letter-spacing: .14em; text-transform: uppercase;
}

.hero {
  display: grid; gap: 1.25rem;
  grid-template-columns: 1.1fr 1fr;
  align-items: stretch;
  margin-bottom: 1.5rem;
}
.hero-info { padding: .25rem .25rem 0; align-self: center; }
.hero-titulo { font-size: clamp(1.65rem, 2.4vw, 2.1rem); margin: 0 0 .5rem; font-weight: 800; }
.hero-sub { color: var(--texto-mid); margin: 0; max-width: 56ch; }

/* ============ Card RPG (gamificação) ============ */
.rpg-card {
  background:
    radial-gradient(600px 220px at 110% -10%, rgba(172, 75, 255, .35), transparent 60%),
    radial-gradient(500px 180px at -10% 110%, rgba(0, 199, 88, .18), transparent 60%),
    linear-gradient(150deg, var(--dark-2) 0%, var(--dark-3) 55%, var(--dark-4) 100%);
  color: #fff;
  border-radius: 22px;
  padding: 1.25rem 1.4rem 1.35rem;
  box-shadow: var(--sombra-md), inset 0 0 0 1px rgba(255,255,255,.04);
  position: relative; overflow: hidden;
}
.rpg-card::before {
  content: ""; position: absolute; inset: -40% -20% auto auto;
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(98, 95, 255, .25), transparent 60%);
  pointer-events: none;
}
.rpg-topo { display: flex; align-items: center; gap: 1rem; position: relative; }
.rpg-avatar { position: relative; width: 64px; height: 64px; flex: 0 0 64px; }
.rpg-avatar img {
  width: 64px; height: 64px; border-radius: 50%; object-fit: cover;
  border: 3px solid rgba(255,255,255,.9);
  background: #fff;
}
.rpg-anel {
  position: absolute; inset: -6px; border-radius: 50%;
  border: 2px dashed rgba(249, 156, 0, .9);
  animation: spinSlow 18s linear infinite;
  pointer-events: none;
}
.rpg-id { flex: 1; min-width: 0; }
.rpg-nome {
  font-family: var(--font-headline);
  font-weight: 800; font-size: 1.1rem; letter-spacing: -0.01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rpg-classe { font-size: .85rem; opacity: .75; }
.rpg-nivel { text-align: right; }
.rpg-nivel-label {
  font-size: .68rem; text-transform: uppercase; letter-spacing: .14em; opacity: .75;
}
.rpg-nivel-num {
  font-family: var(--font-headline);
  font-size: 2.1rem; font-weight: 900;
  background: linear-gradient(135deg, #FFE08A 0%, var(--accent-orange) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 2px 14px rgba(249, 156, 0, .35);
  line-height: 1;
}
.rpg-progresso { margin-top: 1rem; position: relative; }
.rpg-progresso-info {
  display: flex; justify-content: space-between;
  font-size: .8rem; opacity: .9; margin-bottom: .35rem;
}
.rpg-barra {
  position: relative; height: 14px; border-radius: 999px;
  background: rgba(255,255,255,.12);
  overflow: hidden;
}
.rpg-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--violet), var(--violet-2) 50%, var(--violet-3));
  border-radius: 999px;
  box-shadow: 0 0 14px rgba(141, 84, 255, .55), inset 0 -2px 0 rgba(0,0,0,.08);
  transition: width 1s cubic-bezier(.22, .9, .2, 1);
}
.rpg-shine {
  position: absolute; top: 0; left: -40%; width: 35%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  filter: blur(2px);
  animation: shineMove 2.4s ease-in-out infinite;
  pointer-events: none;
}
.rpg-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: .6rem;
  margin-top: 1.1rem; position: relative;
}
.stat {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px; padding: .55rem .4rem;
  text-align: center;
}
.stat-num {
  display: block; font-size: 1.18rem; font-weight: 800;
  font-family: var(--font-headline);
}
.stat-lbl { display: block; font-size: .68rem; opacity: .8; letter-spacing: .04em; }

/* =========================================================
   Abas / Kanban
   ========================================================= */
.abas-wrap {
  background: #fff; border-radius: 22px; padding: 1rem;
  box-shadow: var(--sombra-sm); border: 1px solid var(--linha);
}
.abas {
  display: flex; gap: .35rem; overflow-x: auto; padding-bottom: .35rem;
  scrollbar-width: thin;
}
.abas::-webkit-scrollbar { height: 6px; }
.abas::-webkit-scrollbar-thumb { background: var(--linha); border-radius: 999px; }
.aba {
  flex: 0 0 auto;
  padding: .65rem 1.1rem; border-radius: 999px;
  color: var(--texto-mid); font-weight: 700; white-space: nowrap;
  border: 1px solid transparent;
  display: inline-flex; align-items: center; gap: .45rem;
  transition: background var(--transi), color var(--transi), border var(--transi);
}
.aba:hover { background: var(--primary-50); color: var(--primary-700); }
.aba.ativa {
  background: linear-gradient(135deg, var(--primary), var(--violet));
  color: #fff; border-color: transparent;
  box-shadow: 0 4px 14px rgba(79, 70, 229, .35);
}
.aba.ativa .aba-badge { background: rgba(255,255,255,.22); color: #fff; }
.aba-badge {
  display: inline-block; min-width: 22px; padding: 0 .45rem;
  background: var(--linha); color: var(--texto-mid);
  border-radius: 999px; font-size: .75rem; font-weight: 800; text-align: center;
}

.barra-filtros {
  display: grid; grid-template-columns: 1fr 200px 200px 130px auto;
  gap: .7rem; margin: 1rem 0 1rem;
}
.filtro { display: flex; flex-direction: column; gap: .25rem; min-width: 0; }
.filtro label {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .08em;
  color: var(--texto-light); font-weight: 800;
}
.filtro input, .filtro select {
  padding: .6rem .8rem; border-radius: 10px;
  border: 1px solid var(--linha); background: #fff; outline: none;
  transition: border-color var(--transi), box-shadow var(--transi);
}
.filtro input:focus, .filtro select:focus {
  border-color: var(--primary); box-shadow: var(--ring);
}
.filtro-contador {
  display: flex; align-items: flex-end; padding-bottom: .35rem;
  color: var(--texto-mid); font-weight: 700;
}

.lista-leads {
  display: grid; gap: .75rem;
  grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
}

.lead-card {
  background: #fff; border: 1px solid var(--linha);
  border-radius: 16px; padding: 1rem 1rem .85rem;
  display: flex; flex-direction: column; gap: .55rem;
  transition: border-color var(--transi), transform var(--transi), box-shadow var(--transi);
  animation: cardIn .35s var(--transi) both;
}
.lead-card:hover {
  border-color: var(--primary);
  box-shadow: 0 8px 20px rgba(79, 70, 229, .12);
  transform: translateY(-1px);
}
.lead-card.saindo { animation: cardOut .3s var(--transi) forwards; pointer-events: none; }

.lead-topo { display: flex; align-items: flex-start; justify-content: space-between; gap: .6rem; }
.lead-titulo {
  font-family: var(--font-headline);
  font-weight: 800; line-height: 1.25; font-size: 1.02rem;
  color: var(--texto); word-break: break-word;
}
.lead-fantasia { font-size: .78rem; color: var(--texto-light); }
.lead-pill {
  font-size: .68rem; padding: .25rem .55rem; border-radius: 999px;
  font-weight: 800; letter-spacing: .04em; text-transform: uppercase; white-space: nowrap;
}
.pill-novo { background: var(--primary-50); color: var(--primary-700); }
.pill-em_visita { background: #DBEAFE; color: #1E40AF; }
.pill-qualificado { background: #FEF3C7; color: #92400E; }
.pill-desqualificado { background: var(--danger-bg); color: #991B1B; }
.pill-conquistado {
  background: linear-gradient(135deg, #FEF3C7, #FDE68A);
  color: #78350F;
}

.lead-info { display: grid; gap: .25rem; font-size: .88rem; color: var(--texto-mid); }
.lead-info b { color: var(--texto); font-weight: 700; }
.lead-row { display: flex; gap: .45rem; align-items: center; }
.lead-row svg { flex: 0 0 16px; color: var(--primary); opacity: .85; }
.lead-bairro {
  display: inline-flex; align-items: center; gap: .3rem;
  background: var(--primary-50); color: var(--primary-700);
  padding: .15rem .55rem; border-radius: 999px; font-size: .78rem; font-weight: 700;
}
.lead-obs {
  background: #FFFBEB; border-left: 3px solid var(--accent-orange);
  padding: .5rem .65rem; border-radius: 6px;
  font-size: .85rem; color: var(--texto-mid);
}
.lead-meta-conquista {
  display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .15rem;
}
.tag-plano {
  background: linear-gradient(135deg, #FDE68A, var(--accent-orange));
  color: #5A3900; font-size: .72rem; font-weight: 800;
  padding: .22rem .55rem; border-radius: 999px;
}
.tag-wl {
  background: linear-gradient(135deg, var(--primary), var(--violet));
  color: #fff;
}

.lead-acoes {
  display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .3rem;
  border-top: 1px solid var(--linha); padding-top: .65rem;
}
.lead-acoes button {
  flex: 1 1 calc(50% - .2rem); padding: .55rem .6rem;
  border-radius: 10px; font-weight: 700; font-size: .85rem;
  display: inline-flex; align-items: center; justify-content: center; gap: .35rem;
  transition: transform var(--transi), background var(--transi), color var(--transi);
}
.lead-acoes button:hover { transform: translateY(-1px); }

.bt-visita { background: var(--primary-50); color: var(--primary-700); }
.bt-visita:hover { background: var(--primary-100); }
.bt-qualif { background: #FEF3C7; color: #92400E; }
.bt-qualif:hover { background: #FDE68A; }
.bt-desqualif { background: var(--danger-bg); color: #991B1B; }
.bt-desqualif:hover { background: #FECACA; }
.bt-conquista {
  background: linear-gradient(135deg, var(--primary), var(--violet));
  color: #fff;
  box-shadow: 0 6px 14px rgba(79, 70, 229, .35);
}
.bt-conquista:hover { box-shadow: 0 8px 18px rgba(79, 70, 229, .45); }
.bt-reset { background: var(--gray-100); color: var(--texto-mid); }
.bt-reset:hover { background: var(--gray-200); }

.vazio { text-align: center; padding: 3rem 1rem; color: var(--texto-mid); }
.vazio-emoji { font-size: 3rem; margin-bottom: .25rem; }
.vazio h3 { margin: .5rem 0 .25rem; color: var(--texto); }

/* Paginação */
.paginacao {
  display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
  gap: .35rem; margin-top: 1rem; padding-top: 1rem;
  border-top: 1px solid var(--linha);
}
.pag-btn {
  background: #fff; border: 1px solid var(--linha);
  color: var(--texto-mid); font-weight: 700;
  padding: .5rem .8rem; border-radius: 10px; min-width: 40px;
  transition: background var(--transi), color var(--transi), border-color var(--transi);
}
.pag-btn:hover:not(:disabled) {
  background: var(--primary-50); color: var(--primary-700); border-color: var(--primary);
}
.pag-btn:disabled { opacity: .35; cursor: not-allowed; }
.pag-info {
  font-size: .9rem; color: var(--texto-mid); font-weight: 600;
  padding: 0 .75rem; min-width: 200px; text-align: center;
}

/* =========================================================
   Botões base
   ========================================================= */
.btn-primario {
  background: linear-gradient(135deg, var(--primary), var(--violet));
  color: #fff;
  padding: .75rem 1.15rem;
  border-radius: 12px;
  font-weight: 800;
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  box-shadow: 0 8px 18px rgba(79, 70, 229, .30);
  transition: transform var(--transi), box-shadow var(--transi), opacity var(--transi);
}
.btn-primario:hover { transform: translateY(-1px); box-shadow: 0 10px 22px rgba(79, 70, 229, .40); }
.btn-primario:disabled { opacity: .5; cursor: not-allowed; transform: none; }
.btn-primario .btn-icon,
.btn-primario svg {
  width: 18px; height: 18px; flex: 0 0 auto;
}
.btn-primario.btn-conquista {
  background: linear-gradient(135deg, var(--accent-orange), #D97706);
  box-shadow: 0 8px 18px rgba(249, 156, 0, .35);
}
.btn-secundario {
  background: var(--primary-50); color: var(--primary-700);
  padding: .6rem 1rem; border-radius: 10px; font-weight: 700;
  display: inline-flex; align-items: center; gap: .5rem;
  transition: background var(--transi);
}
.btn-secundario:hover { background: var(--primary-100); }
.btn-bloco { width: 100%; }

/* =========================================================
   Modais
   ========================================================= */
.modal {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(17, 24, 39, .55);
  display: grid; place-items: center;
  padding: 1rem;
  animation: fadeIn .2s var(--transi);
}
.modal-box {
  width: min(520px, 100%);
  background: #fff;
  border-radius: 18px; padding: 1.5rem;
  box-shadow: var(--sombra-lg);
  max-height: 92vh; overflow: auto;
  animation: popIn .25s var(--transi);
  position: relative;
}
.modal-grande { width: min(720px, 100%); }
.modal-fechar {
  position: absolute; top: .55rem; right: .75rem;
  font-size: 1.6rem; color: var(--texto-light);
  padding: .2rem .6rem; border-radius: 8px;
  line-height: 1;
}
.modal-fechar:hover { background: var(--linha); color: var(--texto); }
.modal h3 { margin: 0 0 .3rem; font-size: 1.3rem; font-weight: 800; }
.modal-sub { color: var(--texto-mid); margin: 0 0 1rem; }
.modal-acoes {
  display: flex; gap: .5rem; justify-content: flex-end; margin-top: 1.2rem;
}

.campo { display: block; margin: .9rem 0 0; }
.campo > span {
  display: block; font-size: .8rem; color: var(--texto-mid);
  font-weight: 700; margin-bottom: .3rem;
}
.campo > span em { color: var(--texto-light); font-style: normal; font-weight: 500; }
.campo input, .campo textarea {
  width: 100%; padding: .65rem .85rem;
  border: 1.5px solid var(--linha); border-radius: 10px; outline: none;
  background: #fff;
  transition: border-color var(--transi), box-shadow var(--transi);
}
.campo input:focus, .campo textarea:focus {
  border-color: var(--primary); box-shadow: var(--ring);
}
.campo textarea { resize: vertical; min-height: 80px; font-family: inherit; }

/* Cards de plano */
.planos { border: 0; padding: 0; margin: 1rem 0 .8rem; display: grid; gap: .55rem; }
.planos legend {
  font-size: .82rem; color: var(--texto-mid); font-weight: 800;
  margin-bottom: .35rem; padding: 0;
}
.plano-card {
  display: block; cursor: pointer; position: relative;
  background: #fff; border: 2px solid var(--linha); border-radius: 14px;
  padding: .8rem 1rem;
  transition: border-color var(--transi), background var(--transi), transform var(--transi);
}
.plano-card:hover { border-color: var(--primary); transform: translateY(-1px); }
.plano-card input { position: absolute; opacity: 0; pointer-events: none; }
.plano-card:has(input:checked) {
  border-color: var(--primary);
  background: linear-gradient(135deg, #F5F3FF 0%, var(--primary-50) 100%);
  box-shadow: inset 0 0 0 1px rgba(79, 70, 229, .15);
}
.plano-topo { display: flex; justify-content: space-between; align-items: baseline; gap: .5rem; }
.plano-nome {
  font-weight: 800; color: var(--texto);
  font-family: var(--font-headline);
  display: inline-flex; gap: .35rem; align-items: center;
}
.plano-nome .tag {
  background: linear-gradient(135deg, #FDE68A, var(--accent-orange));
  color: #5A3900;
  padding: .12rem .5rem; border-radius: 999px; font-size: .68rem; font-weight: 800;
}
.plano-preco { color: var(--primary); font-weight: 800; font-size: 1.1rem; font-family: var(--font-headline); }
.plano-preco small { color: var(--texto-light); font-weight: 500; font-size: .75rem; }
.plano-card ul { margin: .45rem 0 0; padding: 0 0 0 1.1rem; color: var(--texto-mid); font-size: .85rem; }
.plano-card li { margin: .1rem 0; }

.bonus {
  display: flex; gap: .8rem; align-items: flex-start;
  border: 1.5px dashed var(--accent-orange); border-radius: 14px;
  padding: .8rem 1rem; cursor: pointer;
  background: #FFFBEB;
  transition: background var(--transi);
}
.bonus:hover { background: #FEF3C7; }
.bonus input { margin-top: .2rem; width: 18px; height: 18px; accent-color: var(--accent-orange); }
.bonus strong { display: block; color: var(--texto); font-size: .95rem; font-family: var(--font-headline); }
.bonus small { color: var(--texto-mid); }

.perfil-foto-wrap { text-align: center; margin-bottom: 1rem; }
.perfil-foto-wrap img {
  width: 110px; height: 110px; border-radius: 50%; object-fit: cover;
  margin: 0 auto; border: 4px solid #fff; box-shadow: var(--sombra-sm);
}

.acordeao {
  margin-top: 1rem; padding: .55rem .9rem; border-radius: 10px;
  background: var(--fundo); border: 1px solid var(--linha);
}
.acordeao summary {
  cursor: pointer; font-weight: 700; color: var(--primary-700);
  list-style: none; padding: .25rem 0;
}
.acordeao summary::-webkit-details-marker { display: none; }
.acordeao[open] summary { margin-bottom: .25rem; }

/* =========================================================
   Toasts
   ========================================================= */
#toasts {
  position: fixed; bottom: 1.25rem; right: 1.25rem; z-index: 200;
  display: flex; flex-direction: column; gap: .5rem; pointer-events: none;
}
.toast {
  background: var(--dark-2); color: #fff;
  padding: .7rem 1rem; border-radius: 12px;
  box-shadow: var(--sombra-lg);
  display: inline-flex; align-items: center; gap: .5rem;
  animation: toastIn .25s var(--transi), toastOut .3s var(--transi) 3s forwards;
  font-size: .92rem;
}
.toast.ok { background: linear-gradient(135deg, var(--primary), var(--violet)); }
.toast.erro { background: #7F1D1D; }

/* =========================================================
   Level up overlay
   ========================================================= */
.levelup {
  position: fixed; inset: 0; z-index: 400;
  display: grid; place-items: center;
  background: rgba(17, 24, 39, .65);
  animation: fadeIn .25s var(--transi);
}
.levelup-card {
  background:
    radial-gradient(400px 200px at 100% 0%, rgba(172, 75, 255, .4), transparent 70%),
    linear-gradient(160deg, var(--dark-2) 0%, var(--dark-3) 100%);
  color: #fff; padding: 2.5rem 2.8rem; border-radius: 22px;
  text-align: center; position: relative; overflow: hidden;
  border: 2px solid rgba(249, 156, 0, .5);
  box-shadow: 0 30px 80px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.08) inset;
  animation: popIn .4s var(--transi);
}
.levelup-rays {
  position: absolute; inset: -50%;
  background: repeating-conic-gradient(rgba(249, 156, 0, .22) 0deg 8deg, transparent 8deg 18deg);
  animation: spinSlow 12s linear infinite;
  filter: blur(1px);
  pointer-events: none;
}
.levelup-titulo {
  position: relative; font-size: 1rem; letter-spacing: .35em;
  color: #FDE68A; font-weight: 800;
  font-family: var(--font-headline);
}
.levelup-num {
  position: relative;
  font-family: var(--font-headline);
  font-size: 5.5rem; font-weight: 900; line-height: 1;
  margin: .25rem 0 .5rem;
  background: linear-gradient(135deg, #FFE08A 0%, var(--accent-orange) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 4px 24px rgba(249, 156, 0, .55);
  animation: pulse 1.2s ease-in-out infinite;
}
.levelup-sub { position: relative; opacity: .92; }

/* =========================================================
   Página de dicas
   ========================================================= */
.dicas-pagina .hero-dicas { grid-template-columns: 1fr; }
.bloco {
  background: #fff; border-radius: 22px; padding: 1.5rem;
  box-shadow: var(--sombra-sm); border: 1px solid var(--linha);
  margin-bottom: 1.25rem;
}
.bloco-titulo { margin: 0 0 1rem; font-size: 1.15rem; font-weight: 800; }
.grid-cards { display: grid; gap: .85rem; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.grid-2 { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.grid-planos-dicas { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.card-dica {
  background: var(--fundo); border: 1px solid var(--linha);
  border-radius: 14px; padding: 1rem;
  transition: transform var(--transi), border-color var(--transi);
}
.card-dica:hover { transform: translateY(-2px); border-color: var(--primary); }
.card-dica.destaque {
  background: linear-gradient(135deg, #F5F3FF, var(--primary-50));
  border-color: var(--primary);
}
.card-emoji { font-size: 1.8rem; margin-bottom: .3rem; }
.card-dica h4 { margin: 0 0 .4rem; font-size: 1rem; font-weight: 800; color: var(--texto); }
.card-dica p { margin: 0 0 .35rem; color: var(--texto-mid); font-size: .92rem; }
.card-tag {
  display: inline-block; margin-top: .35rem;
  font-size: .72rem; padding: .25rem .55rem; border-radius: 999px;
  background: var(--primary-50); color: var(--primary-700); font-weight: 700;
}
.dica-plano-head {
  background: linear-gradient(135deg, var(--primary), var(--violet));
  color: #fff;
  padding: .45rem .8rem; border-radius: 8px; display: inline-block;
  font-weight: 800; font-size: .9rem; margin-bottom: .55rem;
  font-family: var(--font-headline);
}
.passos { padding-left: 1.3rem; color: var(--texto-mid); }
.passos li { margin: .55rem 0; }
.bloco-final {
  background:
    radial-gradient(500px 220px at 100% 0%, rgba(172, 75, 255, .35), transparent 60%),
    linear-gradient(135deg, var(--primary), var(--violet));
  color: #fff; border: 0;
}
.card-cta { text-align: center; padding: 1rem; }
.card-cta h3 { margin: 0 0 .35rem; font-size: 1.3rem; font-weight: 800; }
.card-cta p { margin: 0 0 1rem; opacity: .9; }
.card-cta .btn-primario { background: #fff; color: var(--primary); box-shadow: 0 10px 24px rgba(0,0,0,.18); }
.card-cta .btn-primario:hover { background: var(--primary-50); }

/* =========================================================
   Responsivo
   ========================================================= */
@media (max-width: 960px) {
  .hero { grid-template-columns: 1fr; }
  .rpg-stats { grid-template-columns: repeat(4, 1fr); }
  .barra-filtros { grid-template-columns: 1fr 1fr 1fr; }
  .filtro-contador { grid-column: 1 / -1; padding-bottom: 0; padding-top: .25rem; }
}
@media (max-width: 640px) {
  .topbar { padding: .7rem .9rem; gap: .5rem; flex-wrap: wrap; }
  .topbar-brand span { display: none; }
  .topbar-nav { order: 3; width: 100%; justify-content: center; margin: .35rem 0 0; }
  .perfil-btn span { display: none; }
  .conteudo { padding: 1rem .85rem 3rem; }
  .rpg-card { padding: 1.1rem; }
  .rpg-stats { grid-template-columns: repeat(2, 1fr); }
  .abas-wrap { padding: .7rem; }
  .barra-filtros { grid-template-columns: 1fr; }
  .lista-leads { grid-template-columns: 1fr; }
  .modal-box { padding: 1.25rem; border-radius: 16px; }
  .levelup-card { padding: 1.8rem 1.5rem; }
  .levelup-num { font-size: 4rem; }
  .lead-acoes button { flex: 1 1 100%; }
  .pin { height: 48px; font-size: 1.25rem; }
  .pin-grid { gap: .35rem; }
}
@media (max-width: 380px) {
  .pin-grid { grid-template-columns: repeat(3, 1fr); }
}

/* =========================================================
   Animações
   ========================================================= */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn { from { opacity: 0 } to { opacity: 1 } }
@keyframes popIn {
  0% { opacity: 0; transform: scale(.92); }
  100% { opacity: 1; transform: scale(1); }
}
@keyframes shake {
  10%, 90% { transform: translateX(-2px); }
  20%, 80% { transform: translateX(3px); }
  30%, 50%, 70% { transform: translateX(-5px); }
  40%, 60% { transform: translateX(5px); }
}
@keyframes shineMove {
  0% { left: -40%; }
  60%, 100% { left: 120%; }
}
@keyframes spinSlow { to { transform: rotate(360deg); } }
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}
@keyframes toastIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
@keyframes toastOut { to { opacity: 0; transform: translateY(8px); } }
@keyframes cardIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
@keyframes cardOut { to { opacity: 0; transform: scale(.95) translateY(-8px); height: 0; padding: 0; margin: 0; } }
