/* Botoes */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--surface); color: var(--text);
  font-size: var(--fs-sm); cursor: pointer; transition: .15s;
  font-family: inherit; text-decoration: none;
}
.btn:hover { border-color: var(--accent); color: var(--text); }
.btn-primary { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; }
.btn-primary:hover { background: var(--accent-hover); color: #fff; }
.btn-danger { background: transparent; border-color: var(--danger); color: var(--danger); }
.btn-danger:hover { background: var(--danger); color: #fff; }
.btn-sm { padding: 4px 10px; font-size: var(--fs-xs); }
.btn-ghost { background: transparent; border-color: transparent; color: var(--text-dim); }
.btn-ghost:hover { background: var(--surface); border-color: var(--border); }

/* Cards e paineis */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: var(--sp-5);
  box-shadow: var(--shadow);
}
.glass {
  background: var(--surface-glass); backdrop-filter: var(--blur);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-glass);
}
.card-titulo { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-4); color: var(--text); }

/* KPI card */
.kpi { display: flex; flex-direction: column; gap: var(--sp-2); }
.kpi .kpi-label { color: var(--text-dim); font-size: var(--fs-sm); display: flex; align-items: center; gap: var(--sp-2); }
.kpi .kpi-valor { font-size: var(--fs-2xl); font-weight: 700; color: var(--text); }
.kpi .kpi-valor.accent { color: var(--accent); }

/* Tabelas */
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: var(--sp-3) var(--sp-4); text-align: left; border-bottom: 1px solid var(--border); }
.table th { color: var(--text-dim); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
.table tr:hover td { background: var(--bg-elev); }
.table .acoes { display: flex; gap: var(--sp-2); justify-content: flex-end; }
.table-wrap { overflow-x: auto; }
.num { text-align: right; font-variant-numeric: tabular-nums; }

/* Forms */
.field { margin-bottom: var(--sp-4); }
.field label { display: block; font-size: var(--fs-sm); color: var(--text-dim); margin-bottom: var(--sp-2); }
.input, .textarea, select.input {
  width: 100%; padding: var(--sp-3) var(--sp-4);
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: var(--fs-base);
  font-family: inherit;
}
.input:focus, .textarea:focus, select.input:focus { outline: none; border-color: var(--accent); }
.textarea { resize: vertical; min-height: 80px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.form-actions { display: flex; gap: var(--sp-3); margin-top: var(--sp-5); }
@media (max-width: 640px) { .form-row { grid-template-columns: 1fr; } }

/* Badges */
.badge { padding: 2px 10px; border-radius: 999px; font-size: var(--fs-xs); font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
.badge-success { background: rgba(46,204,113,.15); color: var(--success); }
.badge-danger { background: rgba(231,76,60,.15); color: var(--danger); }
.badge-warning { background: rgba(241,196,15,.15); color: var(--warning); }
.badge-accent { background: var(--accent-soft); color: var(--accent); }
.badge-dim { background: var(--bg-elev); color: var(--text-dim); }

/* Filtros (topo das telas de listagem) */
.filtros { display: flex; gap: var(--sp-3); flex-wrap: wrap; margin-bottom: var(--sp-4); align-items: flex-end; }
.filtros .input { min-width: 220px; width: auto; }

/* Flash messages */
.flash { padding: var(--sp-3) var(--sp-4); border-radius: var(--radius-sm); margin-bottom: var(--sp-3); display: flex; align-items: center; gap: var(--sp-2); }
.flash.success { background: rgba(46,204,113,.12); color: var(--success); }
.flash.error { background: rgba(231,76,60,.12); color: var(--danger); }

/* Estado vazio */
.vazio { text-align: center; padding: var(--sp-6); color: var(--text-dim); }
.vazio .icon-lg { opacity: .4; margin-bottom: var(--sp-3); }

/* Barra simples para grafico de vendas por mes */
.bar-row { display: grid; grid-template-columns: 90px 1fr 110px; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-2); }
.bar-track { background: var(--bg-elev); border-radius: 999px; height: 14px; overflow: hidden; }
.bar-fill { background: var(--accent); height: 100%; border-radius: 999px; }

/* Lista de itens da venda */
.itens-tabela { width: 100%; border-collapse: collapse; margin-top: var(--sp-2); }
.itens-tabela td { padding: var(--sp-2); }
.itens-tabela .input { padding: var(--sp-2) var(--sp-3); }
.link-whats { display: inline-flex; align-items: center; gap: 6px; color: var(--success); }

/* SelectBusca (substitui o select nativo) */
.selectbusca { position: relative; width: 100%; }
.selectbusca .sb-display {
  padding: var(--sp-3) var(--sp-4); background: var(--bg-elev);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
  color: var(--text); font-size: var(--fs-base);
}
.selectbusca.open .sb-display { border-color: var(--accent); }
.selectbusca .sb-caret { color: var(--text-dim); }
.selectbusca .sb-panel {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 50;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm); margin-top: 4px; box-shadow: var(--shadow);
  max-height: 280px; overflow-y: auto; display: none;
}
.selectbusca.open .sb-panel { display: block; }
.selectbusca .sb-search { width: 100%; padding: var(--sp-3); background: var(--bg-elev); border: none; border-bottom: 1px solid var(--border); color: var(--text); font-family: inherit; }
.selectbusca .sb-search:focus { outline: none; }
.selectbusca .sb-opt { padding: var(--sp-3) var(--sp-4); cursor: pointer; }
.selectbusca .sb-opt:hover { background: var(--accent-soft); color: var(--accent); }
.filtros .selectbusca { min-width: 220px; width: auto; }

/* Hub / tela inicial de modulos */
.hub-wrap { min-height: 100vh; display: flex; flex-direction: column; }
.hub-top { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--border); }
.hub-top .logo { font-size: var(--fs-xl); font-weight: 700; color: var(--accent); letter-spacing: .5px; }
.hub-top .logo small { color: var(--text-dim); font-weight: 500; font-size: var(--fs-xs); letter-spacing: 2px; text-transform: uppercase; margin-left: 6px; }
.hub-main { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: var(--sp-6) var(--sp-4); text-align: center; }
.hub-main h1 { margin-bottom: var(--sp-2); }
.hub-main .hub-sub { color: var(--text-dim); margin-bottom: var(--sp-6); }
.hub-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 280px)); gap: var(--sp-5); justify-content: center; width: 100%; max-width: 640px; }
.modulo-card {
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-3);
  padding: var(--sp-6) var(--sp-5);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  background: var(--surface); box-shadow: var(--shadow);
  color: var(--text); transition: .18s; text-align: center;
}
a.modulo-card:hover { border-color: var(--accent); transform: translateY(-4px); color: var(--text); }
.modulo-card .mod-ico { width: 64px; height: 64px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; background: var(--accent-soft); color: var(--accent); }
.modulo-card .mod-ico .icon { width: 34px; height: 34px; }
.modulo-card .mod-nome { font-size: var(--fs-lg); font-weight: 600; }
.modulo-card .mod-desc { font-size: var(--fs-sm); color: var(--text-dim); }
.modulo-card .mod-cta { display: inline-flex; align-items: center; gap: 6px; color: var(--accent); font-size: var(--fs-sm); font-weight: 600; margin-top: var(--sp-2); }
.modulo-card.disabled { opacity: .55; cursor: not-allowed; }
.modulo-card.disabled .mod-ico { background: var(--bg-elev); color: var(--text-dim); }

/* Auth */
.auth-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--sp-4); }
.auth-card { width: 100%; max-width: 380px; }
.auth-logo { text-align: center; font-size: var(--fs-2xl); font-weight: 700; color: var(--accent); margin-bottom: var(--sp-2); letter-spacing: 1px; }
.auth-sub { text-align: center; color: var(--text-dim); margin-bottom: var(--sp-5); font-size: var(--fs-sm); }
