@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
  --bg-primary: #0F1117;
  --bg-surface: #1A1D27;
  --bg-elevated: #222533;
  --bg-overlay: #2A2E3F;

  --border: #2E3247;
  --border-subtle: #242738;

  --text-primary: #F0F2FA;
  --text-secondary: #8B92B3;
  --text-disabled: #4A5068;

  --accent: #6344BC;
  --accent-hover: #7150D0;
  --accent-fg: #A589EA;
  --accent-subtle: rgba(99,68,188,0.16);
  --accent-rgb: 99, 68, 188;

  --secondary: #73D2E6;
  --secondary-hover: #5BC2D8;
  --secondary-subtle: rgba(115,210,230,0.14);

  --success: #22C55E;
  --success-subtle: rgba(34,197,94,0.12);
  --error: #EF4444;
  --error-subtle: rgba(239,68,68,0.12);
  --warning: #EAB308;
  --warning-subtle: rgba(234,179,8,0.12);
  --info: #3B82F6;
  --info-subtle: rgba(59,130,246,0.12);

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.5), 0 1px 3px rgba(0,0,0,0.3);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.6);

  --radius-sm: 6px;
  --radius: 10px;
  --radius-lg: 14px;
  --radius-xl: 18px;
}

* { box-sizing: border-box; }

body {
  font-family: 'Plus Jakarta Sans', -apple-system, sans-serif;
  margin: 0;
  background: var(--bg-primary);
  color: var(--text-primary);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

h1 { font-size: 15px; font-weight: 700; margin: 0; letter-spacing: -0.3px; }
h2 { font-size: 15px; font-weight: 700; margin: 0 0 4px; letter-spacing: -0.2px; color: var(--text-primary); }
h3 {
  font-size: 11px;
  font-weight: 700;
  margin: 0 0 16px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-subtle);
}
.sub { color: var(--text-secondary); margin: 0 0 20px; font-size: 13px; line-height: 1.5; }

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg-primary); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-disabled); }

/* ---------- Auth (Login / Cadastro) ---------- */
.tela-auth {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: var(--bg-primary);
  padding: 24px 16px;
}

.auth-layout {
  display: flex;
  width: 100%;
  max-width: 820px;
  min-height: 520px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

.auth-marca {
  flex: 1;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E") repeat,
    linear-gradient(135deg, var(--accent) 0%, #5C7FD0 50%, var(--secondary) 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 40px;
  text-align: center;
  text-shadow: 0 1px 4px rgba(0,0,0,0.35);
}

.auth-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}

.auth-logo svg { color: #fff; }

.auth-logo-nome {
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.3px;
}

.auth-tagline {
  font-size: 13px;
  color: rgba(255,255,255,0.82);
  line-height: 1.6;
  max-width: 200px;
}

.auth-form-area {
  width: 380px;
  flex-shrink: 0;
  background: var(--bg-surface);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 48px 40px 36px;
}

.auth-card h1 { font-size: 20px; margin-bottom: 4px; }
.auth-card .sub { margin-bottom: 28px; }

.auth-card-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.auth-campo {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.auth-campo label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.input-icon {
  position: absolute;
  left: 12px;
  color: var(--text-disabled);
  display: flex;
  align-items: center;
  pointer-events: none;
}

.input-icon-right {
  position: absolute;
  right: 10px;
  color: var(--text-disabled);
  display: flex;
  align-items: center;
  background: none;
  border: none;
  padding: 4px;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: color 0.15s;
}

.input-icon-right:hover { color: var(--text-secondary); }

.input-wrap input {
  padding-left: 38px;
  width: 100%;
}

.input-wrap input.com-icone-dir { padding-right: 38px; }

.auth-btn {
  width: 100%;
  padding: 11px;
  font-size: 14px;
  font-weight: 600;
  margin-top: 4px;
}

.auth-aceite {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  margin: 16px 0 6px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-secondary);
  cursor: pointer;
}
.auth-aceite input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 1px 0 0;
  flex-shrink: 0;
  accent-color: var(--accent);
  cursor: pointer;
}
.auth-aceite a { color: var(--accent-fg); text-decoration: none; }
.auth-aceite a:hover { text-decoration: underline; }

.auth-footer {
  margin-top: 24px;
  text-align: center;
  font-size: 13px;
  color: var(--text-secondary);
}

.auth-footer a {
  color: var(--accent-fg);
  text-decoration: none;
}

.auth-footer a:hover { text-decoration: underline; }

.auth-copy {
  margin-top: auto;
  padding-top: 32px;
  font-size: 12px;
  color: var(--text-disabled);
  text-align: center;
}

/* ---------- Header ---------- */
/* ---------- Shell: sidebar + conteúdo ---------- */
.app-layout {
  display: flex;
  min-height: 100vh;
}

.sidebar {
  width: 240px;
  flex-shrink: 0;
  background: var(--bg-surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
  z-index: 100;
}

.sidebar-marca {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 20px 18px;
  border-bottom: 1px solid var(--border-subtle);
}
.sidebar-marca svg { color: var(--accent-fg); flex-shrink: 0; }
.sidebar-marca-txt { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; }
.sidebar-marca-nome { font-size: 15px; font-weight: 700; color: var(--text-primary); letter-spacing: -0.2px; }
.sidebar-marca-sub {
  font-size: 11px; font-weight: 600; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.5px;
}

.sidebar-rodape {
  padding: 14px 16px;
  border-top: 1px solid var(--border-subtle);
}
.sidebar-rodape .btn-sair { width: 100%; }

.conteudo {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

header {
  background: var(--bg-surface);
  color: var(--text-primary);
  padding: 0 24px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 90;
  border-bottom: 1px solid var(--border);
}

.header-esquerda {
  display: flex;
  align-items: center;
  gap: 14px;
}

.header-direita {
  display: flex;
  align-items: center;
  gap: 10px;
}

.header-sair { display: none; } /* Sair no header só no mobile */

/* Chip de teste grátis no header (atalho pra aba Assinatura) */
.header-trial {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 999px;
  background: var(--secondary-subtle);
  color: var(--secondary);
  border: 1px solid rgba(115,210,230,0.28);
  cursor: pointer;
  transition: background 0.15s ease, transform 0.08s ease;
}
.header-trial::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}
.header-trial:hover { background: var(--secondary-subtle); transform: translateY(-1px); }

/* ---------- Badge de status do atendimento ---------- */
.badge-atendimento {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 4px 10px;
  border-radius: 20px;
  border: 1px solid;
  cursor: default;
  user-select: none;
}

.badge-atendimento.aberto {
  background: var(--success-subtle);
  color: var(--success);
  border-color: rgba(34,197,94,0.3);
}

.badge-atendimento.fechado {
  background: var(--error-subtle);
  color: var(--error);
  border-color: rgba(239,68,68,0.3);
}

.badge-atendimento .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}

/* ---------- Nav (lista vertical na sidebar) ---------- */
nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 12px;
  flex: 1;
  overflow-y: auto;
}

nav button {
  position: relative;
  background: none;
  color: var(--text-secondary);
  border: none;
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  font-size: 14px;
  font-weight: 600;
  width: 100%;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}

/* Indicador de ativo: barra de acento que cresce à esquerda */
nav button::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  width: 3px; height: 0;
  border-radius: 0 3px 3px 0;
  background: var(--accent-fg);
  transform: translateY(-50%);
  transition: height 0.18s ease;
}

nav button:hover {
  background: var(--bg-elevated);
  color: var(--text-primary);
  transform: none;
}

nav button.ativo {
  background: var(--accent-subtle);
  color: var(--accent-fg);
}
nav button.ativo::before { height: 20px; }

nav button svg {
  flex-shrink: 0;
  opacity: 0.7;
  transition: opacity 0.15s;
}

nav button.ativo svg { opacity: 1; }

/* Badge de contagem no nav */
.nav-badge {
  background: var(--accent);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 10px;
  min-width: 18px;
  text-align: center;
  line-height: 16px;
}

/* ---------- Main ---------- */
main {
  padding: 28px 32px 80px;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

.aba { display: none; }
.aba.ativa { display: block; }

/* Entrada em cascata: cada bloco de topo da aba sobe com fade em sequência.
   Recomeça a cada troca de aba (display none→block reinicia a animação). */
.aba.ativa > * {
  animation: fadeSlide 0.42s cubic-bezier(.22,.61,.36,1) both;
}
.aba.ativa > *:nth-child(1) { animation-delay: 0.02s; }
.aba.ativa > *:nth-child(2) { animation-delay: 0.07s; }
.aba.ativa > *:nth-child(3) { animation-delay: 0.12s; }
.aba.ativa > *:nth-child(4) { animation-delay: 0.17s; }
.aba.ativa > *:nth-child(5) { animation-delay: 0.22s; }
.aba.ativa > *:nth-child(6) { animation-delay: 0.27s; }
.aba.ativa > *:nth-child(n+7) { animation-delay: 0.3s; }

@keyframes fadeSlide {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .aba.ativa > * { animation: none; }
}

/* ---------- Inputs e textarea ---------- */
input, textarea, select {
  font-family: inherit;
  font-size: 14px;
  padding: 9px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg-elevated);
  width: 100%;
  color: var(--text-primary);
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
}

input::placeholder, textarea::placeholder {
  color: var(--text-disabled);
}

input:focus, textarea:focus, select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-subtle);
}

textarea {
  resize: vertical;
  min-height: 72px;
  line-height: 1.55;
}

/* ---------- Botões ---------- */
button {
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  padding: 9px 16px;
  cursor: pointer;
  background: var(--accent);
  color: #fff;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  transition: background 0.15s, box-shadow 0.12s, transform 0.08s;
  white-space: nowrap;
}

button:hover { background: var(--accent-hover); }
button:active { transform: translateY(1px); }

button.secundario {
  background: transparent;
  color: var(--text-primary);
  border-color: var(--border);
}

button.secundario:hover {
  background: var(--bg-elevated);
  border-color: var(--text-secondary);
}

button.perigo {
  background: transparent;
  color: var(--error);
  border-color: transparent;
  padding: 6px 10px;
}

button.perigo:hover {
  background: var(--error-subtle);
  border-color: var(--error);
}

button.mini { padding: 6px 12px; font-size: 12px; }

button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none !important;
}

/* ---------- Cards ---------- */
.card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 22px;
  margin-bottom: 16px;
  box-shadow: var(--shadow-sm);
}

/* ---------- Campos de formulário ---------- */
.campo { margin-bottom: 14px; }
.campo:last-child { margin-bottom: 0; }

.campo label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 5px;
}

.linha { display: flex; gap: 12px; flex-wrap: wrap; }
.linha > .campo { flex: 1; min-width: 140px; }

/* ---------- Barra salvar ---------- */
.barra-salvar {
  position: sticky;
  bottom: 0;
  background: rgba(15, 17, 23, 0.92);
  backdrop-filter: blur(12px);
  padding: 14px 0;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 8px;
}

.aviso { color: var(--success); font-size: 13px; font-weight: 600; }
.erro { color: var(--error); font-size: 13px; min-height: 18px; }

/* ---------- Cardápio — categorias ---------- */
/* ---------- Cardápio — cabeçalho de ação ---------- */
.cardapio-topo {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.cardapio-titulo {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--text-primary);
}

.cardapio-topo-texto .sub { margin: 4px 0 0; }

.cardapio-topo-acoes {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}

.cardapio-topo-acoes button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* ---------- Cardápio — faixa de métricas ---------- */
.metricas-cardapio {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 22px;
}

.metrica-ico {
  display: inline-flex;
  color: var(--text-secondary);
}

.categoria {
  margin-bottom: 28px;
}

.categoria-cabeca {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 0 12px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--border-subtle);
}

.cat-cabeca-esq {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}

.cat-icone {
  color: var(--accent-fg);
  flex-shrink: 0;
}

.catNome {
  background: transparent;
  border: 1px solid transparent;
  color: var(--text-primary);
  font-size: 15px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  flex: 1;
  min-width: 0;
}

.catNome:hover,
.catNome:focus {
  background: var(--bg-elevated);
  border-color: var(--border);
}

.cat-badge {
  display: inline-flex;
  align-items: center;
  background: var(--bg-elevated);
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ---------- Cardápio — grid de cards ---------- */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 12px;
}

/* Telas médias: cai para 2 colunas antes do mobile (1 coluna em <=640px) */
@media (max-width: 1024px) {
  .cards-grid { grid-template-columns: repeat(2, 1fr); }
}

.item-card {
  display: flex;
  flex-direction: row;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color 0.15s;
}

.item-card:hover { border-color: var(--accent-fg); }

.item-card-foto {
  width: 104px;
  min-width: 104px;
  align-self: stretch;
  background: var(--bg-elevated);
  overflow: hidden;
  flex-shrink: 0;
}

.item-card-foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.item-card-placeholder {
  width: 100%;
  height: 100%;
  min-height: 88px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-disabled);
}

.item-card-info {
  flex: 1;
  min-width: 0;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 8px;
}

.item-card-meta {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.item-card-linha1 {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

.item-card-nome {
  font-weight: 600;
  font-size: 14px;
  line-height: 1.3;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.item-card-preco {
  color: var(--accent-fg);
  font-weight: 700;
  font-size: 14px;
  white-space: nowrap;
  flex-shrink: 0;
}

.item-card-desc {
  font-size: 12px;
  line-height: 1.4;
  color: var(--text-secondary);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.item-card-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.item-card-disp {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.item-card-disp-txt {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
}

.item-card-acoes {
  display: flex;
  gap: 4px;
  align-items: center;
}

/* Item indisponível: borda tracejada + conteúdo esmaecido */
.item-indisp {
  border-style: dashed;
  background: transparent;
}
.item-indisp .item-card-nome,
.item-indisp .item-card-preco,
.item-indisp .item-card-desc,
.item-indisp .item-card-foto { opacity: 0.4; }
.item-indisp .item-card-disp-txt { color: var(--text-disabled); }

.toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0;
}

.toggle input[type="checkbox"].itDisp {
  appearance: none;
  -webkit-appearance: none;
  width: 36px;
  height: 20px;
  min-width: 36px;
  background: var(--bg-overlay);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  position: relative;
  transition: background 0.2s, border-color 0.2s;
  margin: 0;
}

.toggle input[type="checkbox"].itDisp::before {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  background: var(--text-disabled);
  border-radius: 50%;
  top: 50%;
  left: 2px;
  transform: translateY(-50%);
  transition: transform 0.2s, background 0.2s;
}

.toggle input[type="checkbox"].itDisp:checked {
  background: var(--accent);
  border-color: var(--accent);
}

.toggle input[type="checkbox"].itDisp:checked::before {
  background: #fff;
  transform: translateX(16px) translateY(-50%);
}

/* Card tracejado "+ Adicionar item" no fim de cada categoria */
.item-card-add {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 88px;
  background: transparent;
  border: 1.5px dashed var(--border);
  border-radius: var(--radius);
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.item-card-add:hover {
  border-color: var(--accent-fg);
  color: var(--accent-fg);
  background: var(--accent-subtle);
}

/* ---------- Conexão ---------- */
.conexao-topo { margin-bottom: 22px; }
.conexao-titulo {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--text-primary);
}
.conexao-topo .sub { margin: 4px 0 0; }

.conexao-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: start;
}

/* Card "Como conectar" */
.conexao-passos { padding: 24px; }
.conexao-passos-titulo {
  font-size: 16px;
  font-weight: 700;
  color: var(--accent-fg);
  margin-bottom: 18px;
}
.passos-lista {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: 0;
  padding: 0;
}
.passos-lista li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--text-primary);
}
.passos-lista strong { font-weight: 700; }
.passo-num {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--accent-subtle);
  color: var(--accent-fg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
}
.conexao-dica {
  display: flex;
  gap: 10px;
  margin-top: 20px;
  padding: 14px 16px;
  background: var(--secondary-subtle);
  border: 1px solid rgba(115, 210, 230, 0.2);
  border-radius: var(--radius);
}
.conexao-dica svg { color: var(--secondary); flex-shrink: 0; margin-top: 1px; }
.conexao-dica p { margin: 0; font-size: 13px; line-height: 1.5; color: var(--text-secondary); }
.conexao-dica strong { color: var(--secondary); font-weight: 700; }

/* Painel de QR / estado dinâmico */
.conexao-painel {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  min-height: 340px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px 24px;
}
.conexao-estado {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
  width: 100%;
}
.conexao-estado-txt { margin: 0; font-size: 14px; color: var(--text-secondary); }
.conexao-estado-txt.aguardando { color: var(--secondary); font-weight: 600; }
.conexao-estado button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Moldura gradiente roxo→ciano do QR */
.qr-frame {
  padding: 4px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--accent) 0%, var(--secondary) 100%);
}
.qr-img {
  display: block;
  width: 240px;
  height: 240px;
  border-radius: var(--radius);
  background: #fff;
  padding: 10px;
}

/* Spinner de carregamento */
.qr-spinner {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 3px solid var(--border);
  border-top-color: var(--accent-fg);
  animation: spin 0.8s linear infinite;
}

/* Ícone grande do estado desligado */
.conexao-icone-grande {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--bg-elevated);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Estado conectado */
.conexao-conectado-cabeca {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--success);
}
.conexao-conectado-titulo { font-size: 20px; font-weight: 700; }
.conexao-numero { margin: 0; font-size: 14px; color: var(--text-secondary); }
.conexao-numero strong { color: var(--text-primary); }
.conexao-acoes { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }

/* Link discreto (escape hatch "limpar sessão" no estado desligado) */
.link-discreto {
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 12px;
  cursor: pointer;
  padding: 4px;
  text-decoration: underline;
}
.link-discreto:hover { color: var(--text-primary); background: none; transform: none; }

.bolinha {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.on  { background: var(--success); box-shadow: 0 0 0 3px var(--success-subtle); }
.off { background: var(--error);   box-shadow: 0 0 0 3px var(--error-subtle); }
.wait{ background: var(--warning); box-shadow: 0 0 0 3px var(--warning-subtle); }

/* ---------- Configurações ---------- */
.cfg-topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 22px;
}
.cfg-titulo {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--text-primary);
}
.cfg-status-label { font-size: 13px; color: var(--text-secondary); }
.cfg-status-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid transparent;
}
.cfg-status-chip.aberto  { background: var(--success-subtle); color: var(--success); border-color: rgba(34, 197, 94, 0.3); }
.cfg-status-chip.fechado { background: var(--error-subtle);   color: var(--error);   border-color: rgba(239, 68, 68, 0.3); }

/* Switch reutilizável (status do atendimento + fechado por dia) */
.switch { display: inline-flex; align-items: center; }
.switch input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 40px;
  height: 22px;
  min-width: 40px;
  background: var(--bg-overlay);
  border: 1.5px solid var(--border);
  border-radius: 11px;
  cursor: pointer;
  position: relative;
  transition: background 0.2s, border-color 0.2s;
  margin: 0;
}
.switch input[type="checkbox"]::before {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  background: var(--text-disabled);
  border-radius: 50%;
  top: 50%;
  left: 2px;
  transform: translateY(-50%);
  transition: transform 0.2s, background 0.2s;
}
.switch input[type="checkbox"]:checked {
  background: var(--accent);
  border-color: var(--accent);
}
.switch input[type="checkbox"]:checked::before {
  background: #fff;
  transform: translateX(18px) translateY(-50%);
}

/* Card de destaque — Status do Atendimento */
.cfg-status-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 26px;
}
.cfg-status-texto h3 { font-size: 16px; font-weight: 700; }
.cfg-status-texto .sub { margin: 4px 0 0; }
.cfg-status-toggle {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  flex-shrink: 0;
}
.cfg-status-toggle-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
}

/* Sub-abas das Configurações (Empresa × Bot) */
.cfg-subnav {
  display: flex;
  gap: 6px;
  margin-bottom: 22px;
  padding: 4px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  width: fit-content;
}
.cfg-subnav button {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 600;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.cfg-subnav button svg { flex-shrink: 0; }
.cfg-subnav button:hover { color: var(--text-primary); }
.cfg-subnav button.ativo { background: var(--accent); color: #fff; }
.cfg-subnav button.ativo svg { color: #fff; }

.cfg-sub { display: none; }
.cfg-sub.ativa { display: block; }

/* Conta de acesso (e-mail/senha) */
.cfg-conta-card { display: flex; flex-direction: column; }
.cfg-conta-linha {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.cfg-conta-info { display: flex; flex-direction: column; gap: 3px; }
.cfg-conta-rotulo {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--text-secondary);
}
.cfg-conta-valor { font-size: 15px; color: var(--text-primary); font-weight: 600; }
.cfg-conta-valor-mascarado { letter-spacing: 2px; color: var(--text-secondary); }
.cfg-conta-divisor { height: 1px; background: var(--border-subtle); margin: 18px 0; }
.cfg-conta-form {
  margin-top: 16px;
  padding: 16px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.cfg-conta-form .campo { margin-bottom: 12px; }
.cfg-conta-form .linha { margin-bottom: 0; }
.cfg-conta-acoes {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.cfg-horario-texto { margin-top: 16px; }

/* Zona de perigo (excluir conta) */
.cfg-perigo-card {
  display: flex; flex-direction: column;
  margin-top: 14px;
  border-color: rgba(239,68,68,0.35);
  background: var(--error-subtle, rgba(239,68,68,0.06));
}
.cfg-perigo-titulo { color: var(--error); }
.cfg-perigo-divisor { height: 1px; background: rgba(239,68,68,0.25); margin: 4px 0 16px; }
.cfg-perigo-aviso {
  display: flex; align-items: flex-start; gap: 10px;
  margin: 0 0 16px; padding: 12px 14px; border-radius: var(--radius);
  background: var(--warning-subtle, rgba(234,179,8,0.12));
  border: 1px solid rgba(234,179,8,0.4);
  font-size: 13px; line-height: 1.5; color: var(--text-primary);
}
.cfg-perigo-aviso svg { color: var(--warning); flex-shrink: 0; margin-top: 1px; }
.cfg-perigo-aviso b { font-weight: 700; }

/* Seções com cabeçalho + ícone */
.cfg-secao { margin-bottom: 26px; }
.cfg-secao-cabeca {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.cfg-secao-cabeca svg { color: var(--accent-fg); flex-shrink: 0; }
.cfg-secao-cabeca h3 { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.cfg-secao-sub { margin: -6px 0 14px; }

/* Linha de switch (label + toggle) — comportamento do bot */
.cfg-switch-linha {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
}
.cfg-switch-linha + .cfg-switch-linha { border-top: 1px solid var(--border-subtle); }
.cfg-switch-texto { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cfg-switch-texto strong { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.cfg-switch-texto .sub { font-size: 12px; }
.cfg-switch-linha .switch { flex-shrink: 0; }

/* Labels da config em caixa-baixa (fiel ao protótipo) */
.cfg-secao .campo > label {
  text-transform: none;
  letter-spacing: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
}

/* Mensagens automáticas — grid */
.cfg-msgs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.cfg-msg label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 10px;
}
.cfg-msg-hint { font-weight: 400; font-size: 11px; color: var(--text-disabled); }
.cfg-msg textarea { min-height: 92px; }

/* Horário de funcionamento — tabela (desktop) */
.cfg-horarios-card { padding: 8px 6px; }
.tabela-horarios { width: 100%; border-collapse: collapse; }
.tabela-horarios th {
  text-align: left;
  padding: 10px 12px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-subtle);
}
.tabela-horarios th:last-child { text-align: right; }
.hor-linha td {
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-subtle);
  vertical-align: middle;
}
.hor-linha:last-child td { border-bottom: none; }
.hor-dia { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.hor-time { width: 130px; }
.hor-fechado-cel { text-align: right; }
.hor-fechado .hor-dia { color: var(--text-disabled); }

/* Entrega e pagamento — pills */
.cfg-pagamentos {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.pag-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--accent-subtle);
  color: var(--text-primary);
  border: 1px solid rgba(99, 68, 188, 0.3);
  border-radius: 20px;
  padding: 6px 8px 6px 14px;
  font-size: 13px;
  font-weight: 600;
}
.pag-pill-del {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  padding: 0;
}
.pag-pill-del:hover { background: var(--error-subtle); color: var(--error); }
.pag-add {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 1.5px dashed var(--border);
  color: var(--text-secondary);
  border-radius: 20px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
.pag-add:hover { border-color: var(--accent-fg); color: var(--accent-fg); background: none; transform: none; }
.pag-input { width: 170px; border-radius: 20px; padding: 6px 14px; }

/* Botão "Gerar automaticamente" sob o campo de texto do horário */
/* Texto de horário é gerado automaticamente da tabela (campo read-only). */
.cfg-horario-hint { font-size: 12px; color: var(--text-secondary); margin-top: 6px; line-height: 1.4; }
#cfgHorario[readonly] { color: var(--text-secondary); cursor: default; }

/* Barra inferior com Descartar + Salvar */
.cfg-barra { justify-content: space-between; }
.cfg-barra-aviso { font-size: 13px; color: var(--text-secondary); }
.cfg-barra-acoes { display: flex; align-items: center; gap: 12px; }

/* ---------- Pedidos ---------- */
.pedidos-topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.pedidos-topo .sub { margin-bottom: 0; }

/* ---------- Pedidos: métricas + filtros ---------- */
.metricas-cards {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr; /* primeiro card (Total) domina */
  gap: 16px;
  margin-bottom: 18px;
}
.metrica-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}
.metrica-card:hover {
  border-color: var(--border);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.metrica-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
}
.metrica-valor {
  font-size: 32px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.5px;
  line-height: 1.1;
}
/* Card de destaque: Total de pedidos com mais peso visual (dark surface) */
.metrica-card.destaque { gap: 6px; }
.metrica-topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.metrica-trend {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--secondary-subtle);
  color: var(--secondary);
  flex-shrink: 0;
}
.metrica-num { display: flex; align-items: baseline; gap: 8px; }
.metrica-card.destaque .metrica-valor {
  font-size: 46px;
  color: var(--accent-fg);
}
.metrica-unidade { font-size: 18px; font-weight: 600; color: var(--text-secondary); }
.metrica-comparativo {
  font-size: 13px;
  font-weight: 700;
  color: var(--secondary);
}
.metrica-subtitulo { font-size: 12px; color: var(--text-disabled); }

.pedidos-filtros {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px 14px;
  box-shadow: var(--shadow-sm);
}
.filtro-chips {
  display: inline-flex;
  gap: 4px;
  background: var(--bg-elevated);
  padding: 4px;
  border-radius: var(--radius-sm);
}
.filtro-chip {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.filtro-chip.ativo { background: var(--accent); color: #fff; box-shadow: 0 1px 4px rgba(var(--accent-rgb), 0.4); }
.filtro-chip:not(.ativo):hover { color: var(--text-primary); }
.filtro-datas { display: inline-flex; align-items: center; gap: 8px; }
.filtro-datas input { width: auto; }
.filtro-datas .sub { margin: 0; }
.filtro-tipo { width: auto; }

/* Busca com ícone (empurrada para a direita, como no protótipo) */
.busca-wrap {
  position: relative;
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 200px;
  margin-left: auto;
}
.busca-icone {
  position: absolute;
  left: 12px;
  display: flex;
  align-items: center;
  color: var(--text-disabled);
  pointer-events: none;
}
.pedidos-busca { width: 100%; padding-left: 38px; }

/* Fade suave ao trocar o filtro de período/tipo */
@keyframes fadeTroca {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.fade-troca { animation: fadeTroca 0.25s ease; }

.pedido-linha { cursor: pointer; }

/* Cards de pedido (mobile) — escondidos no desktop */
.pedidos-cards { display: none; }
.pedido-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: border-color 0.15s;
}
.pedido-card:hover { border-color: var(--accent-fg); }
.pedido-card:active { border-color: var(--accent); background: var(--bg-elevated); }
.pedido-card-topo { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.pedido-card-num { font-size: 12px; font-weight: 600; color: var(--text-secondary); }
.pedido-card-cliente { font-weight: 600; font-size: 15px; margin: 6px 0; color: var(--text-primary); }
.pedido-card-rodape { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.pedido-card-rodape .sub { margin: 0; }
.pedido-card-total { font-weight: 700; color: var(--accent-fg); }

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

th, td {
  border-bottom: 1px solid var(--border-subtle);
  padding: 10px 14px;
  text-align: left;
  vertical-align: top;
}

th {
  background: var(--bg-elevated);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
}

tbody tr:last-child td { border-bottom: none; }
tbody tr td { transition: background 0.14s ease, box-shadow 0.14s ease; }
tbody tr:hover td { background: var(--bg-elevated); }
tbody tr:hover td:first-child { box-shadow: inset 3px 0 0 var(--accent-fg); }

.tag {
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
  border: 1px solid transparent;
}

/* Pills outlined (borda + texto na cor semântica), como no protótipo */
.tag-entrega  { background: var(--info-subtle);    color: var(--info);    border-color: rgba(59,130,246,0.4); }
.tag-retirada { background: var(--success-subtle); color: var(--success); border-color: rgba(34,197,94,0.4); }

/* ---------- Tabela de pedidos (refino visual) ---------- */
.pedidos-tabela th,
.pedidos-tabela td {
  padding: 14px 16px;
  vertical-align: middle;
}
.pedidos-tabela .pedido-linha { transition: background 0.12s; }
.pedidos-tabela .pedido-linha:hover td { background: var(--bg-elevated); }
.pedidos-tabela .ped-num { color: var(--accent-fg); font-weight: 700; }
.pedidos-tabela .col-total,
.pedidos-tabela .ped-total { text-align: right; }
.pedidos-tabela .ped-total { font-weight: 700; color: var(--text-primary); white-space: nowrap; }

/* Paginação da lista */
.pedidos-paginacao {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  background: var(--bg-surface);
  margin-top: -1px;
}
.pag-info { font-size: 13px; color: var(--text-secondary); }
.pag-controles { display: flex; align-items: center; gap: 4px; }
.pag-btn {
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.pag-btn:hover:not(:disabled):not(.ativo) { background: var(--bg-elevated); color: var(--text-primary); }
.pag-btn.ativo { background: var(--accent); border-color: var(--accent); color: #fff; }
.pag-btn:disabled { opacity: 0.4; cursor: default; }
.pag-reticencias { color: var(--text-disabled); padding: 0 2px; }

/* ---------- Loading spinner ---------- */
.load {
  display: inline-block;
  width: 24px;
  height: 24px;
  border: 3px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.75s linear infinite;
  margin: 12px 0;
}

@keyframes spin { to { transform: rotate(360deg); } }

/* ---------- Toggle atendimento (config) ---------- */
.campo.toggle {
  display: flex;
  align-items: center;
  gap: 10px;
}

.campo.toggle input[type="checkbox"] {
  width: 17px;
  height: 17px;
  accent-color: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
}

.campo.toggle label {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  text-transform: none;
  letter-spacing: 0;
  margin: 0;
  cursor: pointer;
}

/* ---------- Estado vazio (pedidos) ---------- */
.estado-vazio {
  text-align: center;
  padding: 56px 24px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  color: var(--text-disabled);
}

.estado-vazio svg {
  display: block;
  margin: 0 auto 14px;
  stroke: var(--text-disabled);
}

.estado-vazio p {
  margin: 0 0 6px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text-secondary);
}

.estado-vazio .sub { margin: 0; }

/* ---------- Toast (substitui flash) ---------- */
#toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--radius);
  border: 1px solid;
  font-size: 13px;
  font-weight: 500;
  box-shadow: var(--shadow-md);
  min-width: 260px;
  max-width: 380px;
  animation: toastIn 0.2s ease both;
  pointer-events: auto;
}

.toast.saindo { animation: toastOut 0.25s ease both; }

.toast.sucesso {
  background: var(--bg-surface);
  border-color: rgba(34,197,94,0.4);
  color: var(--success);
}

.toast.erro {
  background: var(--bg-surface);
  border-color: rgba(239,68,68,0.4);
  color: var(--error);
}

@keyframes toastIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes toastOut {
  from { opacity: 1; transform: translateY(0); }
  to   { opacity: 0; transform: translateY(12px); }
}

/* ---------- Modal de confirmação ---------- */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn 0.15s ease;
}

.modal-overlay.saindo { animation: fadeOut 0.15s ease both; }

@keyframes fadeIn  { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeOut { from { opacity: 1; } to { opacity: 0; } }

.modal-caixa {
  background: var(--bg-overlay);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 28px 28px 24px;
  width: 90%;
  max-width: 360px;
  box-shadow: var(--shadow-lg);
  animation: modalIn 0.18s ease both;
}

.modal-overlay.saindo .modal-caixa { animation: modalOut 0.15s ease both; }

@keyframes modalIn  { from { opacity: 0; transform: scale(0.96) translateY(8px); } to { opacity: 1; transform: none; } }
@keyframes modalOut { from { opacity: 1; transform: none; } to { opacity: 0; transform: scale(0.96); } }

.modal-caixa h3 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 8px;
  text-transform: none;
  letter-spacing: 0;
  border: none;
  padding: 0;
}

.modal-caixa p {
  color: var(--text-secondary);
  font-size: 13px;
  margin: 0 0 24px;
}

.modal-acoes {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.modal-confirmar {
  background: var(--error) !important;
  color: #fff !important;
  border: none !important;
}

.modal-confirmar:hover { background: #DC2626 !important; }

/* ---------- Simulador de chat ---------- */
/* Cabeçalho de ação */
.sim-topo {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.sim-titulo {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--text-primary);
}
.sim-topo-texto .sub { margin: 4px 0 0; }
#btnSimReset { display: inline-flex; align-items: center; gap: 8px; flex-shrink: 0; }

.sim-grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 20px;
  align-items: start;
}

.sim-wrapper {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 240px);
  min-height: 460px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* Painel "Variáveis de Contexto" (direita) */
.sim-contexto { display: flex; flex-direction: column; gap: 16px; }
.sim-ctx-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow-sm);
}
.sim-ctx-titulo {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
  margin-bottom: 14px;
}
.sim-ctx-titulo svg { color: var(--accent-fg); flex-shrink: 0; }
.sim-ctx-linha {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 10px;
  background: var(--bg-elevated);
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
  font-size: 13px;
  color: var(--text-secondary);
}
.sim-ctx-linha:last-child { margin-bottom: 0; }
.sim-ctx-val {
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-weight: 700;
  color: var(--accent-fg);
  word-break: break-word;
  text-align: right;
}

.sim-chat {
  flex: 1;
  overflow-y: auto;
  padding: 16px 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sim-hint {
  text-align: center;
  color: var(--text-disabled);
  font-size: 13px;
  padding: 24px 0 8px;
}

.sim-hint strong { color: var(--text-secondary); }

/* Balão do bot (esquerda) */
.sim-balao-bot {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  align-self: flex-start;
  max-width: 85%;
}

.sim-msg-col {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.sim-msg-nome {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-secondary);
  padding-left: 2px;
}
.sim-hora {
  font-size: 10px;
  color: var(--text-disabled);
  padding: 0 2px;
}

.sim-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bg-overlay);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}
.sim-avatar svg { color: var(--accent-fg); }

.sim-bubble-bot {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 2px 14px 14px 14px;
  padding: 9px 12px;
  font-size: 13px;
  color: var(--text-primary);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
}

/* Balão do usuário (direita) */
.sim-balao-user {
  align-self: flex-end;
  max-width: 75%;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
}

.sim-bubble-user {
  background: var(--accent);
  border-radius: 14px 14px 2px 14px;
  padding: 9px 12px;
  font-size: 13px;
  color: #fff;
  line-height: 1.55;
  word-break: break-word;
}

/* Indicador de digitando */
.sim-typing {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  align-self: flex-start;
}

.sim-typing-dots {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 2px 14px 14px 14px;
  padding: 10px 14px;
  display: flex;
  gap: 4px;
  align-items: center;
}

.sim-typing-dots span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--text-secondary);
  animation: typingBounce 1.2s ease infinite;
}

.sim-typing-dots span:nth-child(2) { animation-delay: 0.2s; }
.sim-typing-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes typingBounce {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30% { transform: translateY(-5px); opacity: 1; }
}

/* Separador de reset */
.sim-separador {
  text-align: center;
  font-size: 11px;
  color: var(--text-disabled);
  padding: 4px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.sim-separador::before,
.sim-separador::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--border-subtle);
}

/* Input row */
.sim-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px 8px;
  border-top: 1px solid var(--border);
  background: var(--bg-elevated);
  flex-shrink: 0;
}

.sim-input-row input {
  flex: 1;
  background: var(--bg-overlay);
  border-color: var(--border);
  border-radius: 22px;
  padding: 11px 16px;
  font-size: 13px;
}

.sim-input-row input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-subtle);
}

.sim-enviar {
  width: 42px;
  height: 42px;
  min-width: 42px;
  padding: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sim-input-dica {
  text-align: right;
  font-size: 11px;
  color: var(--text-disabled);
  padding: 0 16px 10px;
  background: var(--bg-elevated);
  flex-shrink: 0;
}
.sim-input-dica strong { color: var(--text-secondary); }

/* ---------- Modal de detalhes do pedido ---------- */
.pedido-detalhe {
  max-width: 720px;
  width: 95%;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}

.pedido-detalhe-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 22px 22px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.pedido-detalhe-header h3 {
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary);
  text-transform: none;
  letter-spacing: -0.3px;
  border: none;
  padding: 0;
  margin: 0 0 4px;
}

#pedido-detalhe-corpo {
  overflow-y: auto;
  padding: 18px 22px 22px;
  flex: 1;
}

/* Grid de 2 colunas do detalhe */
.ped-det-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 22px;
}
.ped-det-col { min-width: 0; }

.ped-bloco { margin-bottom: 20px; }
.ped-bloco:last-child { margin-bottom: 0; }
.ped-bloco-titulo {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
  margin-bottom: 10px;
}

/* Cliente */
.ped-cliente { display: flex; align-items: center; gap: 12px; }
.ped-cliente-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--accent-subtle);
  color: var(--accent-fg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ped-cliente-dados { min-width: 0; }
.ped-cliente-nome { font-size: 15px; font-weight: 600; color: var(--text-primary); }
.ped-cliente-tel { font-size: 13px; color: var(--text-secondary); margin-top: 2px; }

/* Observação destacada (faixa amarela) */
.ped-obs {
  background: var(--warning-subtle);
  border-left: 3px solid var(--warning);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  margin-bottom: 20px;
}
.ped-obs-titulo {
  display: block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--warning);
  margin-bottom: 6px;
}
.ped-obs p {
  margin: 0;
  font-size: 13px;
  font-style: italic;
  color: var(--text-primary);
  line-height: 1.5;
}
.ped-obs p + p { margin-top: 4px; }

/* Itens como cards de leitura */
.ped-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
}
.ped-item:last-child { margin-bottom: 0; }
.ped-item-qtd {
  font-size: 13px;
  font-weight: 700;
  color: var(--accent-fg);
  white-space: nowrap;
  flex-shrink: 0;
}
.ped-item-info { flex: 1; min-width: 0; }
.ped-item-nome { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.ped-item-opc { font-size: 12px; color: var(--text-secondary); margin-top: 4px; line-height: 1.5; }
.ped-item-preco {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Linha de info (Entrega / Pagamento) */
.ped-linha-info { display: flex; align-items: flex-start; gap: 10px; }
.ped-info-icone { color: var(--accent-fg); flex-shrink: 0; margin-top: 1px; }
.ped-info-texto { font-size: 13px; color: var(--text-primary); line-height: 1.5; min-width: 0; }
.ped-info-texto .sub { display: block; margin: 2px 0 0; }
.ped-info-vazio { color: var(--text-disabled); }
.ped-info-tag { margin-top: 8px; }

/* Resumo de valores */
.ped-resumo {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  padding: 16px;
}
.ped-resumo-linha {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  color: var(--text-secondary);
  padding: 4px 0;
}
.ped-resumo-total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
}
.ped-resumo-total span:last-child { font-size: 20px; color: var(--accent-fg); }

/* Rodapé fixo: ações (avisar) + fechar */
.ped-rodape {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 14px 22px;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}
.pedido-acoes {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
}
.pedido-acoes:empty { display: none; }
.pedido-acoes button { width: 100%; }
.pedido-acoes button.mini { width: auto; }
.ped-rodape #pedido-fechar-rodape { flex-shrink: 0; }
.pedido-avisado {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  min-width: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--success);
}

/* ---------- Modal de edição de item do cardápio ---------- */
.editor-caixa {
  max-width: 720px;
  width: 95%;
  max-height: 90vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  padding: 0;
}

.editor-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px 14px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.editor-header-info {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--accent-fg);
}

.editor-header h3 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  text-transform: none;
  letter-spacing: 0;
  border: none;
  padding: 0;
  margin: 0;
}

.editor-corpo {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 24px;
  padding: 20px 24px 16px;
}

.editor-foto-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.editor-foto-bloco {
  width: 100%;
  aspect-ratio: 1 / 1;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
}

#editor-foto-preview {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: none;
}

#editor-foto-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: 100%;
  color: var(--text-disabled);
  font-size: 12px;
  font-weight: 500;
  cursor: default;
  user-select: none;
}

.editor-foto-acoes {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

#editor-foto-input { display: none; }

.editor-campos-col {
  display: flex;
  flex-direction: column;
}

.editor-textareas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding: 0 24px 20px;
}

.editor-textareas textarea { min-height: 100px; }

.editor-rodape {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 14px 24px;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--bg-overlay);
  border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}

.editor-erro {
  flex: 1;
  color: var(--error);
  font-size: 13px;
  font-weight: 500;
}

/* ---------- Construtor de Composição ---------- */
.comp-builder {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 4px;
}

.comp-subgrupo {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 12px;
  background: var(--bg-elevated);
}

.comp-subgrupo-cabeca {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.comp-sg-nome {
  flex: 1;
  font-size: 13px;
  font-weight: 600;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  padding: 3px 6px;
  color: var(--text-primary);
  min-width: 0;
}
.comp-sg-nome:hover,
.comp-sg-nome:focus { border-color: var(--border); background: var(--bg-overlay); outline: none; }

.comp-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
  min-height: 20px;
}

.comp-chip {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: var(--bg-overlay);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 3px 6px 3px 10px;
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.4;
}

.comp-chip-del {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  padding: 0;
  background: none;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1;
  flex-shrink: 0;
  box-shadow: none;
}
.comp-chip-del:hover { color: var(--error); background: var(--error-subtle); }

.comp-add-ing {
  display: flex;
  gap: 6px;
  align-items: center;
}

.comp-ing-input {
  flex: 1;
  font-size: 13px;
  padding: 5px 9px;
  min-width: 0;
}

/* ---------- Construtor de Opcionais ---------- */
.opc-builder {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 4px;
}

.opc-linha {
  display: flex;
  align-items: center;
  gap: 6px;
}

.opc-nome {
  flex: 1;
  font-size: 13px;
  min-width: 0;
}

.opc-preco-wrap {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.opc-rs {
  font-size: 12px;
  color: var(--text-secondary);
  white-space: nowrap;
}

.opc-preco {
  width: 76px;
  font-size: 13px;
  text-align: right;
}

/* ---------- Mobile: bordas de edição sempre visíveis ---------- */
@media (hover: none) {
  .catNome { border-color: var(--border-subtle); }
}

/* ---------- Responsivo ---------- */
@media (max-width: 640px) {
  main { padding: 16px 14px 84px; }

  /* Shell vira coluna; sidebar vira bottom-nav fixa */
  .app-layout { flex-direction: column; }
  .sidebar {
    position: fixed;
    top: auto;             /* anula o top:0 do desktop — senão top+bottom esticam a barra pra tela toda */
    bottom: 0; left: 0; right: 0;
    width: 100%;
    height: auto;
    flex-direction: row;
    border-right: none;
    border-top: 1px solid var(--border);
    z-index: 100;
  }
  .sidebar-marca, .sidebar-rodape { display: none; }

  nav {
    flex-direction: row;
    padding: 0;
    gap: 0;
    overflow: visible;
  }
  nav button {
    flex: 1;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 4px;
    padding: 8px 4px;
    font-size: 11px;
    border-radius: 0;
  }
  nav button.ativo { background: none; color: var(--accent-fg); }
  /* No bottom-nav o indicador vira uma barra no topo do item */
  nav button::before {
    left: 50%; top: 0; transform: translateX(-50%);
    width: 0; height: 3px; border-radius: 0 0 3px 3px;
    transition: width 0.18s ease;
  }
  nav button.ativo::before { width: 22px; height: 3px; }

  .card { padding: 16px; }

  header { padding: 0 16px; }
  .header-sair { display: inline-flex; } /* Sair acessível no header (mobile) */

  /* Pedidos: métricas compactas (destaque full-width), troca tabela → cards */
  .metricas-cards { grid-template-columns: 1fr 1fr; gap: 8px; }
  .metrica-card.destaque { grid-column: 1 / -1; }
  .metrica-card { padding: 14px; }
  .metrica-valor { font-size: 20px; }
  .metrica-card.destaque .metrica-valor { font-size: 32px; }
  .pedidos-busca { min-width: 100%; }
  .pedidos-tabela { display: none; }
  .pedidos-cards { display: block; }

  /* Detalhe do pedido: 2 colunas → 1 coluna empilhada */
  .ped-det-grid { grid-template-columns: 1fr; gap: 16px; }

  /* Paginação: empilha info + controles, centralizado (desencaixa da tabela) */
  .pedidos-paginacao {
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin-top: 10px;
    border-top: 1px solid var(--border);
    border-radius: var(--radius);
  }
  .pag-controles { flex-wrap: wrap; justify-content: center; }

  table { font-size: 12px; }
  th, td { padding: 8px 10px; }

  #toast-container {
    bottom: 16px;
    right: 16px;
    left: 16px;
  }

  .toast { min-width: unset; max-width: unset; width: 100%; }

  .editor-corpo {
    grid-template-columns: 1fr;
  }

  .editor-foto-bloco {
    max-width: 180px;
    margin: 0 auto;
  }

  .editor-textareas {
    grid-template-columns: 1fr;
  }

  .cardapio-topo-acoes { width: 100%; }
  .cardapio-topo-acoes button { flex: 1; justify-content: center; }
  .metricas-cardapio { display: none; }

  .cards-grid { grid-template-columns: 1fr; }
  .item-card-foto { display: none; }
  .item-card-desc { display: none; }
  .item-card-add { min-height: 56px; flex-direction: row; }

  /* Conexão: 1 coluna, QR primeiro (como no protótipo mobile) */
  .conexao-grid { grid-template-columns: 1fr; gap: 16px; }
  .conexao-painel { order: -1; min-height: 300px; }
  .qr-img { width: 200px; height: 200px; }

  /* Configurações: empilha tudo */
  .cfg-msgs-grid { grid-template-columns: 1fr; }
  .cfg-status-card { flex-direction: column; align-items: stretch; gap: 14px; }
  .cfg-status-toggle { width: 100%; justify-content: space-between; }
  .cfg-barra { flex-direction: column; align-items: stretch; gap: 10px; }
  .cfg-barra-acoes { justify-content: flex-end; }

  /* Horário: tabela vira cards por dia (dia+fechado no topo, abre/fecha lado a lado) */
  .cfg-horarios-card { padding: 0; background: none; border: none; box-shadow: none; }
  .tabela-horarios thead { display: none; }
  .tabela-horarios, .tabela-horarios tbody, .hor-linha { display: block; width: 100%; }
  .hor-linha {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px;
    margin-bottom: 10px;
    background: var(--bg-surface);
    display: flex;
    flex-wrap: wrap;
    gap: 10px 12px;
    align-items: center;
  }
  .hor-linha td { display: block; border: none !important; padding: 0; }
  .hor-linha .hor-dia { flex: 1; font-size: 15px; order: 1; }
  .hor-linha .hor-fechado-cel {
    order: 2;
    display: flex;
    align-items: center;
    gap: 8px;
    text-align: left;
  }
  .hor-linha .hor-fechado-cel::before {
    content: "Fechado";
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
  }
  .hor-linha td[data-label="Abre"],
  .hor-linha td[data-label="Fecha"] {
    order: 3;
    flex: 1 1 calc(50% - 6px);
    min-width: 120px;
  }
  .hor-linha td[data-label="Abre"]::before,
  .hor-linha td[data-label="Fecha"]::before {
    content: attr(data-label);
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-secondary);
    margin-bottom: 5px;
  }
  .hor-linha .hor-time { width: 100%; }

  /* Simulador: 1 coluna, painel de contexto oculto, chat ocupa a tela */
  .sim-grid { grid-template-columns: 1fr; gap: 14px; }
  .sim-contexto { display: none; }
  .sim-wrapper { height: calc(100vh - 210px); min-height: 380px; }

  .auth-layout { flex-direction: column; min-height: unset; border-radius: var(--radius-lg); }
  .auth-marca { padding: 28px 24px; flex-direction: row; gap: 16px; text-align: left; justify-content: flex-start; }
  .auth-logo { flex-direction: row; gap: 12px; margin-bottom: 0; }
  .auth-logo-nome { font-size: 18px; }
  .auth-tagline { display: none; }
  .auth-form-area { width: 100%; padding: 32px 24px 28px; }
  .auth-copy { padding-top: 20px; }
}

/* ============================================================ */
/* PAINEL MASTER (super-admin) — /admin-master.html            */
/* ============================================================ */

/* Layout do dashboard master reusa .app-layout/.sidebar/.conteudo/main do
   painel do cliente — não há mais topbar/página dedicadas aqui. */
.am-cabeca { margin-bottom: 18px; }

/* Faixa de métricas (4 cards) — reusa .metrica-card do design system */
.am-metricas {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

/* Coluna "Pedidos no mês" + bolinha de conectado */
.am-col-pedidos { font-weight: 700; color: var(--text-primary); }
.am-col-status { white-space: nowrap; }
.am-col-status .bolinha { margin-left: 8px; vertical-align: middle; }
.am-titulo { font-size: 20px; font-weight: 700; letter-spacing: -0.3px; color: var(--text-primary); }
.am-cabeca .sub { margin-top: 2px; }

/* Slug em código */
.am-slug, .am-slug-alvo {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  background: var(--bg-elevated);
  color: var(--accent-fg);
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-subtle);
}

/* Pills de status (semânticas: ativo verde / suspenso vermelho) */
.am-status {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
  border: 1px solid transparent;
}
.am-status.ativo    { background: var(--success-subtle); color: var(--success); border-color: rgba(34,197,94,0.4); }
.am-status.suspenso { background: var(--error-subtle);   color: var(--error);   border-color: rgba(239,68,68,0.4); }

/* Ações da linha */
.am-acoes { white-space: nowrap; }
.am-acoes button.mini { width: auto; }
.am-tabela td.am-acoes { display: flex; gap: 8px; }

/* As tabelas do master têm muitas colunas: na faixa de tablet (641–1024px),
   onde ainda não viram cards (≤640), rolam na horizontal DENTRO da caixa em vez
   de estourar a largura da página. No desktop largo cabem sem rolagem. */
#am-lista, #am-ultimos { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* Modais maiores que o de confirmação padrão */
.am-del-caixa, .am-criar-caixa { max-width: 440px; }
.am-del-aviso {
  background: var(--error-subtle);
  border: 1px solid rgba(239,68,68,0.4);
  border-radius: var(--radius);
  padding: 12px 14px;
  color: var(--text-secondary) !important;
  font-size: 13px;
  line-height: 1.55;
  margin-bottom: 18px !important;
}
.am-del-aviso strong { color: var(--error); }
.am-del-caixa .auth-campo, .am-criar-caixa .auth-campo { margin-bottom: 18px; }
.am-criar-caixa .auth-card-form { gap: 0; }
.am-criar-caixa .erro { margin: 0 0 8px; }

.am-cabeca-acao { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.am-cabeca-acao button.mini { width: auto; }

/* Filtro por plano + coluna Plano + alerta de inadimplência (super-admin) */
.am-filtros { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.am-filtros label { font-size: 12px; font-weight: 600; color: var(--text-secondary); }
.am-filtros select { width: auto; min-width: 180px; }
.am-plano-sub { display: block; font-size: 11px; color: var(--text-secondary); margin-top: 3px; }
.am-metrica-alerta { border-color: rgba(239,68,68,0.4); }
.am-metrica-alerta .metrica-valor { color: var(--error); }
.am-vazio-filtro { text-align: center; color: var(--text-secondary); padding: 24px; font-size: 14px; }

/* ---- Dashboard do master (redesign) ---- */
.am-dash-topo {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
  flex-wrap: wrap; margin-bottom: 22px;
}
.am-dash-topo .am-titulo { font-size: 26px; }
.am-dash-topo button.mini { width: auto; }

/* 4 métricas hero (ícone + rótulo + número) */
.am-hero-metricas { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 16px; }
.am-hero-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 22px;
  display: flex; flex-direction: column; gap: 14px;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}
.am-hero-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.am-hero-ico {
  width: 44px; height: 44px; border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  background: var(--accent-subtle); color: var(--accent-fg);
}
.am-hero-card.alerta .am-hero-ico { background: var(--error-subtle); color: var(--error); }
.am-hero-label { font-size: 11px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase; color: var(--text-secondary); }
.am-hero-valor { font-size: 32px; font-weight: 800; letter-spacing: -1px; color: var(--text-primary); line-height: 1; }

/* Faixa secundária de métricas */
.am-metricas-sec { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 28px; }
.am-sec-card { padding: 16px 18px; gap: 6px; }
.am-sec-card .metrica-valor { font-size: 24px; }

/* Cabeçalho "Últimos Clientes" + link */
.am-ultimos-cab { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.am-secao-titulo { font-size: 18px; font-weight: 700; letter-spacing: -0.3px; color: var(--text-primary); }
.am-link-ver { background: none; border: none; padding: 0; color: var(--accent-fg); font-size: 13px; font-weight: 700; cursor: pointer; }
.am-link-ver:hover { color: var(--accent-hover); text-decoration: underline; transform: none; box-shadow: none; }

/* Célula de cliente (avatar neutro + nome + e-mail) */
.am-cliente { display: flex; align-items: center; gap: 12px; }
.am-avatar {
  width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700;
  background: var(--accent-subtle); color: var(--accent-fg);
  border: 1px solid var(--border);
}
.am-cliente-txt { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.am-cliente-nome { font-weight: 600; color: var(--text-primary); }
.am-cliente-email { font-size: 12px; color: var(--text-secondary); }

/* Botão "olho" de ação */
.am-olho {
  width: 34px; height: 34px; padding: 0;
  display: inline-flex; align-items: center; justify-content: center;
  background: none; border: 1px solid var(--border); border-radius: var(--radius-sm);
  color: var(--accent-fg);
}
.am-olho:hover { background: var(--bg-elevated); transform: none; box-shadow: none; }
.am-ultimos-tabela td { vertical-align: middle; }

/* Card de Configurações Master */
.am-config-card { max-width: 560px; }
.am-config-acoes { display: flex; align-items: center; gap: 12px; margin-top: 4px; }
.am-config-acoes button { width: auto; }

/* Aba Configurações Master: 2 cards lado a lado + salvar + card de acesso */
.am-config-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; max-width: 940px; align-items: start; }
.am-config-grid .am-config-card { max-width: none; margin: 0; }
.am-config-salvar { max-width: 940px; margin-top: 16px; justify-content: flex-start; }
.am-config-salvar button { width: auto; }
.am-config-acesso { max-width: 940px; margin-top: 26px; }
.am-opcional { font-weight: 400; color: var(--text-secondary); font-size: 11px; text-transform: none; letter-spacing: 0; }
@media (max-width: 760px) { .am-config-grid { grid-template-columns: 1fr; } }

@media (max-width: 1024px) {
  .am-hero-metricas, .am-metricas-sec { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .am-hero-metricas, .am-metricas-sec { grid-template-columns: 1fr; }
  .am-dash-topo .am-titulo { font-size: 22px; }
}

/* ---- Modal de gestão de um restaurante (assinatura + ações + faturas) ---- */
.am-tenant-caixa { max-width: 600px; width: 92%; max-height: 88vh; overflow-y: auto; padding: 0; }
.am-tenant-header {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
  padding: 22px 24px 16px; border-bottom: 1px solid var(--border-subtle);
  position: sticky; top: 0; background: var(--bg-overlay); z-index: 2;
}
.am-tenant-header-info { min-width: 0; }
.am-tenant-header .secundario.mini { width: auto; flex-shrink: 0; }
.am-tenant-sub { display: block; margin-top: 4px; word-break: break-word; }
.am-tenant-corpo { padding: 18px 24px 24px; }

.am-t-resumo {
  border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--bg-surface); padding: 2px 14px; margin-bottom: 22px;
}
.am-t-linha {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 11px 0; border-bottom: 1px solid var(--border-subtle);
}
.am-t-linha:last-child { border-bottom: none; }
.am-t-rotulo {
  font-size: 11px; font-weight: 700; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.4px; flex-shrink: 0;
}
.am-t-valor { font-size: 14px; color: var(--text-primary); text-align: right; }
.am-t-detalhe { color: var(--text-secondary); font-size: 13px; }
.am-t-conectado { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text-secondary); }

.am-t-secao { margin-bottom: 22px; }
.am-t-secao:last-child { margin-bottom: 0; }
.am-t-secao-titulo {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text-secondary); margin: 0 0 10px;
}
.am-t-acoes { display: flex; flex-wrap: wrap; gap: 8px; }
.am-t-acoes button.mini { width: auto; }
.am-t-vazio { padding: 6px 0; }

.am-faturas-tabela { margin: 0; }
.am-fatura-link { color: var(--secondary); font-weight: 600; font-size: 13px; }
.am-fatura-acao { text-align: right; }

/* Tabela → cards no mobile */
@media (max-width: 1024px) {
  .am-metricas { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .am-metricas { grid-template-columns: 1fr 1fr; gap: 10px; }
  .am-metrica-card, .am-metricas .metrica-card { padding: 14px; }
  .am-metricas .metrica-valor { font-size: 24px; }
  .am-col-status .bolinha { margin-left: 0; }

  .am-tabela thead { display: none; }
  .am-tabela, .am-tabela tbody, .am-tabela tr, .am-tabela td { display: block; width: 100%; }
  .am-tabela tr {
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 12px;
    padding: 6px 4px;
  }
  .am-tabela td {
    border-bottom: 1px solid var(--border-subtle);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    text-align: right;
  }
  .am-tabela td:last-child { border-bottom: none; }
  .am-tabela td::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-secondary);
    text-align: left;
  }
  .am-tabela td.am-acoes { justify-content: flex-end; }
}

/* ============================================================
   WIZARD DE CADASTRO (cadastro.html — 4 etapas)
   Reusa o layout auth-* (painel de marca, card, inputs) e as
   classes do painel (.tabela-horarios, .pag-*); só acrescenta
   a barra de progresso e o agrupamento de etapas/ações.
   ============================================================ */
@media (min-width: 641px) {
  .auth-layout.wiz { max-width: 840px; max-height: calc(100vh - 48px); }
  .auth-layout.wiz .auth-form-area { width: 440px; }
}

/* O lado do formulário rola internamente quando uma etapa é alta (ex.: horário),
   mantendo o card dentro da viewport — sem barra de rolagem na página. */
.auth-layout.wiz .auth-form-area {
  overflow-y: auto;
  padding-top: 34px;
  padding-bottom: 28px;
}

/* Tabela de horários compacta no wizard: cabe nas 4 colunas sem scroll lateral */
.auth-layout.wiz .tabela-horarios th { padding-left: 4px; padding-right: 4px; }
.auth-layout.wiz .hor-linha td { padding: 7px 4px; }
.auth-layout.wiz .hor-dia { font-size: 13px; }
.auth-layout.wiz .hor-time { width: 100px; padding-left: 10px; padding-right: 4px; }

/* Etapa 1 (Conta) é a mais alta: aperta rodapé/copyright para caber sem rolar */
.auth-layout.wiz .auth-footer { margin-top: 18px; }
.auth-layout.wiz .auth-copy { padding-top: 18px; }

.input-icon-rs { font-size: 13px; font-weight: 600; color: var(--text-secondary); pointer-events: none; }

.wiz-progress { margin-bottom: 24px; }
.wiz-progress-top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 10px;
}
.wiz-etapa-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
}
.wiz-etapa-nome { font-size: 13px; font-weight: 600; color: var(--accent-fg); }
.wiz-bars { display: flex; gap: 6px; }
.wiz-bar {
  flex: 1;
  height: 4px;
  border-radius: 2px;
  background: var(--bg-elevated);
  transition: background 0.25s;
}
.wiz-bar.ativa { background: linear-gradient(90deg, var(--accent), var(--secondary)); }

.wiz-step h1 { font-size: 20px; margin-bottom: 4px; }
.wiz-step .sub { margin-bottom: 24px; }
.wiz-campos { display: flex; flex-direction: column; gap: 16px; }
.wiz-linha { display: flex; gap: 12px; }
.wiz-linha > .auth-campo { flex: 1; min-width: 0; }
.wiz-campo-sm { flex: 0 0 88px; }

/* Dica do campo de CEP (compartilhada: onboarding + painel) */
.cep-hint { font-size: 12px; color: var(--text-secondary); line-height: 1.4; }
.cep-hint.ok-hint { color: var(--success); }
.cep-hint.erro-hint { color: var(--error); }
/* Campo estreito (Número / UF) dentro de uma .linha no painel */
.linha > .campo.campo-curto { flex: 0 0 110px; min-width: 0; }
/* CEP não precisa ocupar a linha toda (só 9 caracteres) */
.wiz-cep-campo .input-wrap { max-width: 220px; }
.campo-cep input { max-width: 220px; }
.wiz-tabela-wrap { overflow-x: auto; }

.wiz-acoes {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 22px;
}
.wiz-acoes .auth-btn { margin-top: 0; flex: 1; }
.wiz-acoes .secundario { white-space: nowrap; }
.wiz-step .erro { margin-top: 10px; }

/* ============================================================
   ASSINATURA (painel) + GATE de billing
   ============================================================ */
.assin-topo { margin-bottom: 20px; }
.assin-titulo { font-size: 20px; font-weight: 700; letter-spacing: -0.3px; }

/* Card largo do plano: colunas (plano · valor · vencimento) + badge à direita */
.assin-plano-card {
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  flex-wrap: wrap;
  background:
    linear-gradient(var(--bg-surface), var(--bg-surface)) padding-box,
    linear-gradient(135deg, rgba(99,68,188,0.5), rgba(115,210,230,0.35)) border-box;
  border: 1px solid transparent;
}
.assin-plano-cols { display: flex; gap: 48px; flex-wrap: wrap; flex: 1; }
.assin-plano-col { display: flex; flex-direction: column; gap: 6px; }
.assin-col-label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase;
  color: var(--text-secondary);
}
.assin-col-valor { font-size: 18px; font-weight: 700; color: var(--text-primary); letter-spacing: -0.3px; }
.assin-col-valor.accent { color: var(--accent-fg); }
.assin-col-ciclo { font-size: 13px; font-weight: 500; color: var(--text-secondary); }
.assin-badge { font-size: 13px; font-weight: 700; padding: 6px 14px; border-radius: 999px; white-space: nowrap; }
.assin-badge.ok     { background: var(--success-subtle); color: var(--success); }
.assin-badge.trial  { background: var(--secondary-subtle); color: var(--secondary); }
.assin-badge.alerta { background: var(--error-subtle); color: var(--error); }
.assin-badge.neutro { background: var(--bg-elevated); color: var(--text-secondary); }
.assin-badge.cortesia { background: var(--accent-subtle); color: var(--accent-fg); }

/* ============================================================
   CHECKOUT PRÓPRIO (checkout.html — Stripe Elements / identidade Nymbus)
   ============================================================ */
.co-wrap { width: 100%; max-width: 440px; }
.co-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: 32px 30px 26px;
}
.co-marca { display: flex; align-items: center; gap: 9px; margin-bottom: 22px; }
.co-marca svg { color: var(--accent-fg); }
.co-marca-nome { font-size: 16px; font-weight: 700; letter-spacing: -0.2px; color: var(--text-primary); }
.co-titulo { font-size: 21px; font-weight: 700; letter-spacing: -0.3px; color: var(--text-primary); margin: 0 0 4px; }
.co-sub { margin: 0 0 20px; }

.co-plano {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  padding: 14px 16px;
  margin-bottom: 22px;
}
.co-plano-linha { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.co-plano-linha + .co-plano-linha { margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border-subtle); }
.co-plano-nome { font-weight: 600; color: var(--text-primary); }
.co-plano-preco { font-size: 18px; font-weight: 700; color: var(--text-primary); }
.co-plano-ciclo { font-size: 12px; font-weight: 500; color: var(--text-secondary); }
.co-plano-trial { font-size: 13px; color: var(--text-secondary); }
.co-plano-hoje { color: var(--success); font-weight: 700; }

.co-payment { margin-bottom: 14px; min-height: 44px; }
.co-erro { margin: 0 0 10px; }
.co-card .auth-btn { margin-top: 4px; }

.co-seguro {
  display: flex; align-items: center; gap: 7px;
  font-size: 12px; color: var(--text-secondary);
  margin: 16px 0 0; line-height: 1.4;
}
.co-seguro svg { color: var(--accent-fg); flex-shrink: 0; }
.co-voltar {
  display: block; text-align: center; margin-top: 16px;
  font-size: 13px; color: var(--text-secondary); text-decoration: none;
}
.co-voltar:hover { color: var(--text-primary); }
.assin-info { padding: 14px 2px 0; color: var(--text-secondary); font-size: 14px; line-height: 1.6; }
.assin-info strong { color: var(--text-primary); }
.assin-acoes { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.assin-acoes button { width: auto; }
.assin-rodape { margin-top: 20px; }

/* Grid de duas colunas: pagamento+ajuda (esq) · faturas (dir) */
.assin-grid {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 20px;
  margin-top: 24px;
  align-items: start;
}
.assin-col-esq { display: flex; flex-direction: column; gap: 20px; }

/* Pagamento — cartões salvos no painel */
.assin-cartoes-cab {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  flex-wrap: wrap; margin-bottom: 14px;
}
.assin-cartoes-cab h3 { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.assin-link-add {
  background: none; border: none; padding: 0;
  color: var(--accent-fg); font-size: 13px; font-weight: 700; cursor: pointer;
}
.assin-link-add:hover { color: var(--accent-hover); text-decoration: underline; transform: none; box-shadow: none; }
.assin-cartoes-sub { margin: 14px 0 0; }
.assin-cartoes-lista { display: flex; flex-direction: column; gap: 10px; }

/* Card "Precisa de ajuda?" */
.assin-ajuda-card h3 { font-size: 15px; font-weight: 700; color: var(--text-primary); margin-bottom: 6px; }
.assin-ajuda-card .sub { margin: 0 0 16px; }
.assin-suporte-btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700; text-decoration: none;
  padding: 10px 16px; border-radius: var(--radius-sm);
  background: var(--accent); color: #fff;
  transition: background 0.15s ease, transform 0.08s ease;
}
.assin-suporte-btn:hover { background: var(--accent-hover); transform: translateY(-1px); }

/* Histórico de faturas */
.assin-faturas-card h3 { font-size: 15px; font-weight: 700; color: var(--text-primary); margin-bottom: 14px; }
.assin-faturas-lista { display: flex; flex-direction: column; }
.fatura-item {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 0.9fr 56px;
  align-items: center; gap: 12px;
  padding: 14px 4px;
  border-bottom: 1px solid var(--border-subtle);
}
.fatura-item:last-child { border-bottom: none; }
.fatura-cab {
  padding: 0 4px 10px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border);
}
.fatura-cab span { font-size: 11px; }
.fatura-id { font-weight: 700; color: var(--text-primary); font-size: 13px; }
.fatura-data, .fatura-valor { font-size: 13px; color: var(--text-secondary); }
.fatura-valor { color: var(--text-primary); font-weight: 600; }
.fatura-acao-col { text-align: right; }
.fatura-status {
  display: inline-block; font-size: 11px; font-weight: 700;
  padding: 3px 10px; border-radius: 999px;
}
.fatura-status.ok     { background: var(--success-subtle); color: var(--success); }
.fatura-status.alerta { background: var(--error-subtle); color: var(--error); }
.fatura-status.neutro { background: var(--bg-elevated); color: var(--text-secondary); }
.fatura-baixar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: var(--radius-sm);
  color: var(--accent-fg); background: var(--accent-subtle);
  transition: background 0.15s ease;
}
.fatura-baixar:hover { background: var(--bg-elevated); }
.assin-faturas-vazio { padding: 28px 12px; }
.assin-faturas-vazio p { margin: 0 0 4px; color: var(--text-primary); font-weight: 600; }

/* Responsivo da aba Assinatura */
@media (max-width: 920px) {
  .assin-grid { grid-template-columns: 1fr; }
  .assin-plano-cols { gap: 24px; }
}
@media (max-width: 640px) {
  .assin-plano-card { align-items: flex-start; }
  .assin-plano-cols { flex-direction: column; gap: 16px; width: 100%; }
  /* Faturas viram cards: esconde o cabeçalho e empilha cada linha com rótulos */
  .fatura-cab { display: none; }
  .fatura-item {
    grid-template-columns: 1fr auto;
    gap: 8px 12px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 10px;
  }
  .fatura-item > span { display: flex; align-items: center; justify-content: space-between; }
  .fatura-item > span::before {
    content: attr(data-label);
    font-size: 11px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase;
    color: var(--text-secondary);
  }
  .fatura-id { grid-column: 1 / -1; }
  .fatura-id::before { content: ""; }
  .fatura-acao-col { text-align: left; }
}
.cartao-item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  flex-wrap: wrap;
  padding: 14px 16px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.cartao-item.padrao { border-color: var(--accent); }
.cartao-info { display: flex; align-items: center; gap: 12px; }
.cartao-icone { color: var(--accent-fg); flex-shrink: 0; }
.cartao-texto { display: flex; flex-direction: column; gap: 2px; }
.cartao-marca { font-size: 14px; font-weight: 600; color: var(--text-primary); letter-spacing: 0.3px; }
.cartao-exp { font-size: 12px; color: var(--text-secondary); }
.cartao-item-acoes { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cartao-padrao-tag {
  font-size: 11px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 999px;
  background: var(--accent-subtle); color: var(--accent-fg);
}

/* Modal de adicionar cartão */
.cartao-caixa { max-width: 440px; }
.cartao-header {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-bottom: 18px;
}
.cartao-header h3 { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.cartao-acoes { display: flex; align-items: center; gap: 10px; justify-content: flex-end; }
.cartao-acoes button { width: auto; }

/* Gate: overlay full screen que bloqueia o painel quando sem acesso */
.gate-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(15, 17, 23, 0.92);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.gate-caixa {
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  padding: 36px 32px; max-width: 440px; width: 100%; text-align: center;
}
.gate-icone {
  width: 56px; height: 56px; margin: 0 auto 18px; border-radius: 50%;
  background: var(--accent-subtle); color: var(--accent-fg);
  display: flex; align-items: center; justify-content: center;
}
.gate-caixa h2 { font-size: 20px; font-weight: 700; margin-bottom: 10px; }
.gate-caixa .sub { margin-bottom: 24px; line-height: 1.6; }
.gate-btn { width: 100%; margin-bottom: 12px; padding: 12px; font-size: 15px; }
.gate-caixa .secundario { width: auto; }

/* ============================================================
   LANDING PAGE (index.html — público) · classes .lp-*
   Reusa os tokens Nymbus; tema escuro, gradiente roxo→ciano.
   ============================================================ */
.lp-body { background: var(--bg-primary); color: var(--text-primary); }
.lp-container { max-width: 1120px; margin: 0 auto; padding: 0 24px; }

/* Botões */
.lp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: inherit; font-size: 14px; font-weight: 700; cursor: pointer;
  padding: 10px 18px; border-radius: var(--radius); border: 1px solid transparent;
  text-decoration: none; transition: transform .12s ease, background .15s ease, border-color .15s ease;
}
.lp-btn:hover { transform: translateY(-1px); }
.lp-btn-primary { background: var(--accent); color: #fff; }
.lp-btn-primary:hover { background: var(--accent-hover); }
.lp-btn-ghost { background: transparent; color: var(--text-primary); border-color: var(--border); }
.lp-btn-ghost:hover { background: var(--bg-surface); border-color: var(--accent-fg); color: var(--accent-fg); }
.lp-btn-lg { padding: 13px 26px; font-size: 15px; }
.lp-btn-bloco { width: 100%; }

/* Nav — .lp-nav é um <header> e .lp-nav-links é um <nav>: precisam anular
   as regras globais do painel (header height/flex, nav flex-direction:column). */
.lp-nav {
  display: block; height: auto; padding: 0;
  position: sticky; top: 0; z-index: 50;
  background: rgba(15,17,23,0.82); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-subtle);
}
.lp-nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; width: 100%; height: 74px; }
.lp-logo { display: inline-flex; align-items: center; gap: 9px; font-weight: 800; font-size: 16px; color: var(--text-primary); text-decoration: none; flex-shrink: 0; }
.lp-logo svg { color: var(--accent-fg); }
.lp-nav-links { display: flex; flex-direction: row; flex: 0 0 auto; gap: 34px; padding: 0; overflow: visible; white-space: nowrap; }
.lp-nav-links a { color: var(--text-secondary); text-decoration: none; font-size: 14px; font-weight: 500; }
.lp-nav-links a:hover { color: var(--text-primary); }
.lp-nav-acoes { display: flex; gap: 12px; flex-shrink: 0; }

/* Hero */
.lp-hero {
  position: relative; overflow: hidden; padding: 84px 0 72px;
  background:
    radial-gradient(900px 420px at 78% -8%, rgba(99,68,188,0.28), transparent 60%),
    radial-gradient(700px 360px at 12% 8%, rgba(115,210,230,0.12), transparent 55%);
}
.lp-hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 48px; align-items: center; }
.lp-badge {
  display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 600;
  color: var(--accent-fg); background: var(--accent-subtle);
  padding: 6px 13px; border-radius: 999px; margin-bottom: 20px;
}
.lp-hero h1 { font-size: 46px; line-height: 1.08; font-weight: 800; letter-spacing: -1px; margin: 0 0 18px; }
.lp-grad {
  background: linear-gradient(120deg, var(--accent-fg), var(--secondary));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.lp-hero-sub { font-size: 17px; line-height: 1.6; color: var(--text-secondary); max-width: 520px; margin: 0 0 28px; }
.lp-hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.lp-hero-nota { margin-top: 16px; font-size: 13px; color: var(--text-disabled); }

/* Phone / chat mockup */
.lp-hero-visual { display: flex; justify-content: center; }
.lp-phone {
  width: 320px; max-width: 100%;
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); overflow: hidden;
  padding: 4px; background-image: linear-gradient(160deg, rgba(99,68,188,0.10), rgba(115,210,230,0.06));
}
.lp-phone-topo {
  display: flex; align-items: center; gap: 9px;
  padding: 13px 16px; border-bottom: 1px solid var(--border-subtle);
  background: var(--bg-elevated); border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.lp-phone-dot { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--secondary)); display: flex; align-items: center; justify-content: center; }
.lp-phone-nome { font-weight: 700; font-size: 14px; flex: 1; }
.lp-phone-online { font-size: 11px; color: var(--success); font-weight: 600; }
.lp-chat { padding: 16px; display: flex; flex-direction: column; gap: 9px; background: var(--bg-primary); }
.lp-bubble { max-width: 84%; padding: 9px 13px; border-radius: 14px; font-size: 13px; line-height: 1.45; }
.lp-bubble.bot { align-self: flex-start; background: var(--bg-elevated); color: var(--text-primary); border-bottom-left-radius: 4px; }
.lp-bubble.user { align-self: flex-end; background: var(--accent); color: #fff; border-bottom-right-radius: 4px; }
.lp-bubble b { font-weight: 700; }

/* Faixa de números */
.lp-stats { border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); background: var(--bg-surface); }
.lp-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; padding: 32px 24px; }
.lp-stat { text-align: center; }
.lp-stat-num {
  display: block; font-size: 34px; font-weight: 800; letter-spacing: -1px; line-height: 1;
  background: linear-gradient(120deg, var(--accent-fg), var(--secondary));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.lp-stat-label { display: block; margin-top: 8px; font-size: 13px; color: var(--text-secondary); }

/* Seções genéricas */
.lp-secao { padding: 72px 0; }
.lp-secao-cabeca { text-align: center; max-width: 640px; margin: 0 auto 44px; }
.lp-secao-cabeca h2 { font-size: 32px; font-weight: 800; letter-spacing: -0.6px; margin: 0 0 12px; }
.lp-secao-sub { font-size: 16px; color: var(--text-secondary); margin: 0; }

/* Cards de vantagem */
.lp-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.lp-card {
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 26px 22px; transition: border-color .15s ease, transform .15s ease;
}
.lp-card:hover { border-color: var(--accent-fg); transform: translateY(-3px); }
.lp-card-icone {
  width: 46px; height: 46px; border-radius: var(--radius); margin-bottom: 16px;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent-subtle); color: var(--accent-fg);
}
.lp-card h3 { font-size: 17px; font-weight: 700; margin: 0 0 8px; text-transform: none; letter-spacing: normal; color: var(--text-primary); padding-bottom: 0; border-bottom: none; }
.lp-card p { font-size: 14px; line-height: 1.6; color: var(--text-secondary); margin: 0; }

/* Como funciona */
.lp-como { background: var(--bg-surface); border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); }
.lp-passos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.lp-passo { text-align: center; padding: 0 12px; }
.lp-passo-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 50%; font-size: 18px; font-weight: 800;
  color: #fff; background: linear-gradient(135deg, var(--accent), var(--secondary)); margin-bottom: 16px;
}
.lp-passo h3 { font-size: 17px; font-weight: 700; margin: 0 0 8px; text-transform: none; letter-spacing: normal; color: var(--text-primary); padding-bottom: 0; border-bottom: none; }
.lp-passo p { font-size: 14px; line-height: 1.55; color: var(--text-secondary); margin: 0; }

/* Preço */
.lp-preco-wrap { display: flex; flex-direction: column; align-items: center; }
.lp-preco-card {
  position: relative; width: 100%; max-width: 420px;
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius-xl); padding: 36px 32px; box-shadow: var(--shadow-md); text-align: center;
}
.lp-preco-selo {
  position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
  background: linear-gradient(120deg, var(--accent), var(--secondary)); color: #fff;
  font-size: 12px; font-weight: 700; padding: 5px 16px; border-radius: 999px;
}
.lp-preco-valor { display: flex; align-items: baseline; justify-content: center; gap: 4px; margin: 8px 0 6px; }
.lp-preco-cifra { font-size: 22px; font-weight: 700; color: var(--text-secondary); }
.lp-preco-num { font-size: 56px; font-weight: 800; letter-spacing: -2px; }
.lp-preco-por { font-size: 16px; color: var(--text-secondary); }
.lp-preco-desc { font-size: 13.5px; color: var(--text-secondary); margin: 0 0 22px; }
.lp-preco-lista { list-style: none; padding: 0; margin: 0 0 26px; text-align: left; display: flex; flex-direction: column; gap: 12px; }
.lp-preco-lista li { position: relative; padding-left: 28px; font-size: 14.5px; color: var(--text-primary); }
.lp-preco-lista li::before {
  content: "✓"; position: absolute; left: 0; top: 1px;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--success-subtle); color: var(--success);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
}
.lp-preco-nota { font-size: 12.5px; color: var(--text-disabled); margin: 14px 0 0; }

/* CTA final */
.lp-cta-final { padding: 80px 0; text-align: center; background: radial-gradient(700px 300px at 50% 120%, rgba(99,68,188,0.22), transparent 60%); }
.lp-cta-final h2 { font-size: 30px; font-weight: 800; letter-spacing: -0.6px; margin: 0 0 10px; }
.lp-cta-final p { font-size: 16px; color: var(--text-secondary); margin: 0 0 26px; }

/* Footer */
.lp-footer { border-top: 1px solid var(--border-subtle); padding: 52px 0 28px; }
.lp-footer-grid { display: flex; flex-wrap: wrap; gap: 36px 56px; }
.lp-footer-brand { flex: 1 1 230px; min-width: 200px; max-width: 300px; }
.lp-footer-marca { margin-bottom: 12px; }
.lp-footer-tag { font-size: 13.5px; color: var(--text-secondary); line-height: 1.6; max-width: 240px; margin: 0; }
.lp-footer-col { display: flex; flex-direction: column; gap: 11px; min-width: 130px; }
.lp-footer-col h4 {
  font-size: 11px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase;
  color: var(--text-disabled); margin: 0 0 3px; padding: 0; border: 0;
}
.lp-footer-col a { color: var(--text-secondary); text-decoration: none; font-size: 14px; transition: color .15s ease; }
.lp-footer-col a:hover { color: var(--text-primary); }
.lp-footer-social { display: flex; flex-direction: column; gap: 11px; }
.lp-footer-social a { display: inline-flex; align-items: center; gap: 8px; color: var(--text-secondary); text-decoration: none; font-size: 14px; transition: color .15s ease; }
.lp-footer-social a:hover { color: var(--text-primary); }
.lp-footer-social a svg { flex-shrink: 0; }
.lp-footer-bloco { margin-bottom: 16px; }
.lp-footer-bloco:last-child { margin-bottom: 0; }
.lp-footer-bloco h4 {
  font-size: 11px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase;
  color: var(--text-disabled); margin: 0 0 6px; padding: 0; border: 0;
}
.lp-footer-bloco p { font-size: 14px; color: var(--text-secondary); line-height: 1.55; margin: 0; max-width: 230px; }
.lp-footer-base { margin-top: 44px; padding-top: 22px; border-top: 1px solid var(--border-subtle); }
.lp-footer-copy { display: block; font-size: 13px; color: var(--text-disabled); }

/* ---- Página de Termos de Uso ---- */
.lp-termos {
  position: relative; padding: 56px 0 64px;
  background:
    radial-gradient(820px 360px at 80% -12%, rgba(99,68,188,0.22), transparent 60%),
    radial-gradient(620px 300px at 8% -6%, rgba(115,210,230,0.10), transparent 55%);
}
.lp-termos-inner { position: relative; max-width: 820px; }
/* bloco é um <div> simples — não herda o header global do painel */
.lp-termos-cabeca {
  display: block; height: auto; padding: 0 0 24px; background: none;
  margin-bottom: 32px; border-bottom: 1px solid var(--border-subtle);
}
.lp-termos-voltar { display: inline-block; margin-bottom: 20px; font-size: 13px; font-weight: 600; color: var(--text-secondary); text-decoration: none; }
.lp-termos-voltar:hover { color: var(--accent-fg); }
.lp-termos h1 { font-size: 34px; font-weight: 800; letter-spacing: -0.6px; line-height: 1.15; color: var(--text-primary); }
.lp-termos-data { margin-top: 10px; font-size: 13px; color: var(--text-disabled); }
.lp-termos p { font-size: 14.5px; line-height: 1.75; color: var(--text-secondary); margin: 0 0 14px; }
.lp-termos-inner > p { max-width: 760px; }
.lp-termos p strong { color: var(--text-primary); font-weight: 600; }
.lp-termos-destaque {
  padding: 14px 16px; border-radius: var(--radius);
  background: var(--accent-subtle); border: 1px solid rgba(99,68,188,0.3);
  color: var(--text-primary) !important; font-weight: 500;
}
.lp-termos-secao { margin-top: 36px; }
.lp-termos-secao h2 {
  font-size: 19px; font-weight: 700; letter-spacing: -0.2px;
  color: var(--text-primary); margin-bottom: 14px;
  text-transform: none; border: 0; padding: 0;
}
.lp-termos ul { margin: 0 0 14px; padding-left: 20px; }
.lp-termos li { font-size: 14.5px; line-height: 1.7; color: var(--text-secondary); margin-bottom: 8px; }
.lp-termos li strong { color: var(--text-primary); font-weight: 600; }
.lp-termos-aviso {
  margin: 20px 0; padding: 18px 20px; border-radius: var(--radius-lg);
  background: var(--error-subtle, rgba(239,68,68,0.12)); border: 1px solid rgba(239,68,68,0.35);
}
.lp-termos-aviso h3 {
  font-size: 16px; font-weight: 700; color: var(--text-primary);
  margin-bottom: 10px; text-transform: none; letter-spacing: 0; border: 0; padding: 0;
}
.lp-termos-aviso p, .lp-termos-aviso li { color: var(--text-secondary); }
.lp-termos-aviso p:last-child, .lp-termos-aviso ul:last-child { margin-bottom: 0; }
.lp-termos-contato p { margin-bottom: 6px; }
.lp-termos-final {
  margin-top: 40px; padding: 24px; border-radius: var(--radius-lg);
  background: var(--bg-surface); border: 1px solid var(--border);
}
.lp-termos-final p:last-child { margin-bottom: 0; }
.lp-termos-assinatura { margin-top: 16px; color: var(--text-primary) !important; line-height: 1.6; }
@media (max-width: 560px) {
  .lp-termos { padding: 32px 0 48px; }
  .lp-termos h1 { font-size: 25px; }
}

/* Modo embed (Termos/Privacidade dentro de um iframe/modal): sem chrome */
html.embed, html.embed body { background: var(--bg-primary); }
.embed .lp-nav,
.embed .lp-footer,
.embed .lp-termos-cabeca { display: none !important; }
.embed .lp-termos { padding: 24px 0 36px; background: none; }

/* Modal de documento (Termos/Privacidade) na tela de cadastro — via iframe */
.doc-modal-overlay {
  position: fixed; inset: 0; z-index: 100;
  display: flex; align-items: center; justify-content: center; padding: 20px;
  background: rgba(8,9,13,0.66); backdrop-filter: blur(3px);
  opacity: 0; pointer-events: none; transition: opacity .18s ease;
}
.doc-modal-overlay.aberto { opacity: 1; pointer-events: auto; }
.doc-modal {
  width: min(800px, 100%); height: min(82vh, 780px);
  display: flex; flex-direction: column; overflow: hidden;
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  transform: translateY(10px) scale(.99); transition: transform .18s ease;
}
.doc-modal-overlay.aberto .doc-modal { transform: none; }
.doc-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--border-subtle); flex-shrink: 0;
}
.doc-modal-head h3 { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.doc-modal-fechar {
  background: none; border: 0; color: var(--text-secondary); cursor: pointer;
  font-size: 24px; line-height: 1; padding: 2px 6px; border-radius: var(--radius-sm);
  transition: color .15s ease, background .15s ease;
}
.doc-modal-fechar:hover { color: var(--text-primary); background: var(--bg-elevated); }
.doc-modal-body { flex: 1; min-height: 0; background: var(--bg-primary); }
.doc-modal-body iframe { width: 100%; height: 100%; border: 0; display: block; }
.doc-modal-loading {
  display: flex; align-items: center; justify-content: center; height: 100%;
  color: var(--text-secondary); font-size: 13px;
}
.doc-modal-foot {
  display: flex; align-items: center; justify-content: flex-end; gap: 10px;
  padding: 12px 18px; border-top: 1px solid var(--border-subtle); flex-shrink: 0;
}
@media (max-width: 560px) {
  .doc-modal-overlay { padding: 0; }
  .doc-modal { width: 100%; height: 100%; max-height: none; border-radius: 0; border: 0; }
}

/* ---- Polimento (T5a): reveal, eyebrow, moldura, cartão flutuante ---- */

/* Reveal ao rolar */
.lp-reveal {
  opacity: 0; transform: translateY(22px);
  transition: opacity .6s ease, transform .6s cubic-bezier(.22,.61,.36,1);
  will-change: opacity, transform;
}
.lp-reveal.visivel { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .lp-reveal { opacity: 1; transform: none; transition: none; }
}

/* Rótulo de seção (eyebrow) */
.lp-eyebrow {
  display: inline-block; margin-bottom: 14px;
  font-size: 12px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--accent-fg);
  background: var(--accent-subtle);
  padding: 5px 13px; border-radius: 999px;
}

/* Brilho suave no botão primário (CTA) */
.lp-btn-primary { box-shadow: 0 6px 20px -8px rgba(99,68,188,0.65); }
.lp-btn-primary:hover { box-shadow: 0 10px 26px -8px rgba(99,68,188,0.8); }

/* Glow no ícone dos cards ao passar o mouse */
.lp-card-icone { transition: background .15s ease, box-shadow .15s ease, color .15s ease; }
.lp-card:hover .lp-card-icone {
  background: linear-gradient(135deg, var(--accent), var(--secondary)); color: #fff;
  box-shadow: 0 8px 22px -10px rgba(99,68,188,0.9);
}

/* Separadores sutis na faixa de números */
.lp-stat { position: relative; }
.lp-stat + .lp-stat::before {
  content: ""; position: absolute; left: -10px; top: 50%; transform: translateY(-50%);
  width: 1px; height: 38px; background: var(--border-subtle);
}

/* Moldura com gradiente no card de preço (foco da página) */
.lp-preco-card {
  border: 2px solid transparent;
  background:
    linear-gradient(var(--bg-surface), var(--bg-surface)) padding-box,
    linear-gradient(135deg, var(--accent), var(--secondary)) border-box;
  box-shadow: var(--shadow-lg), 0 0 60px -20px rgba(99,68,188,0.5);
}

/* Indicador de "digitando…" no chat do mockup */
.lp-bubble-typing { display: inline-flex; gap: 4px; align-items: center; padding: 12px 14px; }
.lp-bubble-typing span {
  width: 7px; height: 7px; border-radius: 50%; background: var(--text-secondary);
  animation: lp-typing 1.2s infinite ease-in-out;
}
.lp-bubble-typing span:nth-child(2) { animation-delay: .18s; }
.lp-bubble-typing span:nth-child(3) { animation-delay: .36s; }
@keyframes lp-typing {
  0%, 60%, 100% { opacity: .3; transform: translateY(0); }
  30% { opacity: 1; transform: translateY(-3px); }
}

/* Cartão flutuante sobreposto ao celular */
.lp-hero-visual { position: relative; }
.lp-float-card {
  position: absolute; bottom: 22px; left: -6px;
  display: flex; align-items: center; gap: 11px;
  background: var(--bg-overlay); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 11px 14px;
  box-shadow: var(--shadow-lg);
  animation: lp-flutua 4s ease-in-out infinite;
}
.lp-float-icone {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--success-subtle); color: var(--success);
}
.lp-float-txt { display: flex; flex-direction: column; gap: 1px; }
.lp-float-tit { font-size: 13px; font-weight: 700; color: var(--text-primary); }
.lp-float-sub { font-size: 11.5px; color: var(--text-secondary); }
@keyframes lp-flutua {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-9px); }
}
@media (prefers-reduced-motion: reduce) {
  .lp-float-card, .lp-bubble-typing span { animation: none; }
}

/* Responsivo */
@media (max-width: 900px) {
  .lp-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .lp-hero h1 { font-size: 38px; }
  .lp-hero-texto { text-align: center; }
  .lp-hero-sub { margin-left: auto; margin-right: auto; }
  .lp-hero-ctas { justify-content: center; }
  .lp-cards { grid-template-columns: repeat(2, 1fr); }
  .lp-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 28px; }
  .lp-nav-links { display: none; }
}
@media (max-width: 560px) {
  .lp-hero { padding: 56px 0 48px; }
  .lp-hero h1 { font-size: 31px; }
  .lp-secao { padding: 52px 0; }
  .lp-secao-cabeca h2 { font-size: 26px; }
  .lp-cards { grid-template-columns: 1fr; }
  .lp-passos { grid-template-columns: 1fr; gap: 28px; }
  .lp-nav-acoes .lp-btn-ghost { display: none; }
  .lp-footer-grid { gap: 30px 40px; }
  .lp-footer-brand { flex-basis: 100%; max-width: none; }
  .lp-footer-col { flex: 1 1 40%; min-width: 0; }
  .lp-float-card { left: 8px; bottom: 12px; padding: 9px 12px; }
  .lp-stat + .lp-stat::before { display: none; }
}
