/* ========== Valorux UI Refresh (override aditivo) ==========
   Seguro: não remove regras antigas; apenas refina.
   Escopo: fontes, espaçamentos, botões, tabelas, cards, formulários, modais.
   ---------------------------------------------------------- */

/* ----- Design tokens (fáceis de ajustar depois) ----- */
:root {
  --vx-font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  --vx-font-size-base: 14px;         /* ↓ fontes menos “gritonas” */
  --vx-font-size-sm: 13px;
  --vx-font-size-xs: 12px;
  --vx-radius: 10px;
  --vx-radius-sm: 8px;
  --vx-shadow-1: 0 6px 18px rgba(0,0,0,.07);
  --vx-shadow-2: 0 10px 30px rgba(0,0,0,.08);

  --vx-bg: #f7f8fb;
  --vx-card: #ffffff;
  --vx-line: #e9edf3;
  --vx-text: #1f2937;
  --vx-text-muted: #6b7280;

  --vx-primary: #2563eb;
  --vx-primary-600: #1d4ed8;
  --vx-success: #16a34a;
  --vx-danger: #dc2626;
  --vx-warning: #d97706;
}

/* ----- Base tipografia / reset suave ----- */
html { font-size: 100%; }  /* não mexe no zoom do user */
body {
  font-family: var(--vx-font-family);
  font-size: var(--vx-font-size-base);
  color: var(--vx-text);
  background: var(--vx-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Títulos mais elegantes (sem exagero no tamanho) */
h1 { font-size: 1.6rem; font-weight: 700; margin: .2rem 0 .8rem; }
h2 { font-size: 1.35rem; font-weight: 700; margin: .2rem 0 .7rem; }
h3 { font-size: 1.15rem; font-weight: 600; margin: .2rem 0 .6rem; }
h4,h5,h6 { font-size: 1rem; font-weight: 600; margin: .2rem 0 .5rem; }

/* Texto secundário */
.muted, .text-muted { color: var(--vx-text-muted) !important; }

/* ----- Layouts / Containers ----- */
.main, .content, main, .page-container { background: transparent; }
.card, .panel, .box, .widget, .resumo, .resumo-card {
  background: var(--vx-card);
  border: 1px solid var(--vx-line);
  border-radius: var(--vx-radius);
  box-shadow: var(--vx-shadow-1);
}

/* ----- Tabelas (compactas e legíveis) ----- */
table { border-collapse: collapse; width: 100%; }
th, td {
  padding: .55rem .65rem;
  border-bottom: 1px solid var(--vx-line);
  vertical-align: middle;
  font-size: var(--vx-font-size-sm);
}
th {
  text-align: left;
  color: var(--vx-text-muted);
  font-weight: 700;
  background: #f9fafb;
}
.table-compact th, .table-compact td { padding: .45rem .55rem; }
.table-striped tbody tr:nth-child(odd) { background: #fafbff; }
.table-hover tbody tr:hover { background: #f3f6ff; }

/* ----- Botões ----- */
.btn, button, .vx-btn {
  --btn-bg: var(--vx-primary);
  --btn-bg-h: var(--vx-primary-600);
  --btn-color: #fff;
  --btn-pad-y: .5rem;
  --btn-pad-x: .9rem;
  border-radius: var(--vx-radius-sm);
  padding: var(--btn-pad-y) var(--btn-pad-x);
  border: 1px solid transparent;
  background: var(--btn-bg);
  color: var(--btn-color);
  font-weight: 600;
  font-size: var(--vx-font-size-sm);
  cursor: pointer;
  transition: filter .15s ease, transform .02s ease;
}
.btn:hover, button:hover, .vx-btn:hover { filter: brightness(0.98); }
.btn:active, button:active, .vx-btn:active { transform: translateY(1px); }

/* Variações */
.btn-ghost, .vx-btn.ghost { background: #f2f4f8; color: var(--vx-text); border-color: var(--vx-line); }
.btn-success { --btn-bg: var(--vx-success); }
.btn-danger  { --btn-bg: var(--vx-danger);  }
.btn-warning { --btn-bg: var(--vx-warning); }

/* Links de ação discretos */
.action-link, .link { color: var(--vx-primary); text-decoration: none; font-weight: 600; }
.action-link:hover, .link:hover { text-decoration: underline; }

/* ----- Inputs / Formulários ----- */
input[type="text"], input[type="number"], input[type="date"],
input[type="email"], input[type="password"], select, textarea {
  border: 1px solid var(--vx-line);
  border-radius: 9px;
  padding: .48rem .6rem;
  font-size: var(--vx-font-size-sm);
  outline: none;
  background: #fff;
  transition: box-shadow .15s ease, border-color .15s ease;
}
input:focus, select:focus, textarea:focus {
  border-color: #c7d2fe;
  box-shadow: 0 0 0 3px rgba(37,99,235,.15);
}

/* Campos compactos opcionais */
.form-compact input, .form-compact select, .form-compact textarea {
  padding: .4rem .55rem;
  font-size: var(--vx-font-size-xs);
}

/* ----- Badges / Status ----- */
.status-badge, .badge {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .18rem .5rem;
  border-radius: 999px;
  font-size: var(--vx-font-size-xs);
  font-weight: 700;
  border: 1px solid var(--vx-line);
  background: #f9fafb; color: var(--vx-text);
}
.status-badge.confirmado { background: #ecfdf5; color: #065f46; border-color: #d1fae5; }
.status-badge.pendente   { background: #fff7ed; color: #9a3412; border-color: #ffedd5; }
.status-badge.parcial    { background: #eef2ff; color: #3730a3; border-color: #e0e7ff; }

/* ----- Listas / Cards de pedido ----- */
.pedido, .order-card, .client-row, .product-row {
  background: var(--vx-card);
  border: 1px solid var(--vx-line);
  border-radius: var(--vx-radius);
  box-shadow: var(--vx-shadow-1);
}
.pedido:hover, .order-card:hover, .client-row:hover, .product-row:hover {
  box-shadow: var(--vx-shadow-2);
}

/* ----- Header / Menu mais “slim” ----- */
header, .topbar, .app-header { background: var(--vx-card); border-bottom: 1px solid var(--vx-line); }
header .logo, header h3, .topbar h3 { margin: 0; }

/* ----- Utilitários ----- */
.text-xs{ font-size: var(--vx-font-size-xs) !important; }
.text-sm{ font-size: var(--vx-font-size-sm) !important; }
.text-right{ text-align: right !important; }
.text-center{ text-align: center !important; }
.flex{ display:flex; gap:.6rem; align-items:center; }
.grid-2{ display:grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.grid-3{ display:grid; grid-template-columns: repeat(3,1fr); gap: .8rem; }
.mt-0{ margin-top:0!important; } .mt-1{ margin-top:.25rem!important; } .mt-2{ margin-top:.5rem!important; }
.mb-0{ margin-bottom:0!important; } .mb-1{ margin-bottom:.25rem!important; } .mb-2{ margin-bottom:.5rem!important; }

/* ----- Modais ----- */
.modal, .modal-content, .modal-content-update-setor, .cupom-container {
  border-radius: var(--vx-radius);
  box-shadow: var(--vx-shadow-2);
}
.modal .modal-header{ border-bottom: 1px solid var(--vx-line); }
.modal .modal-footer{ border-top: 1px solid var(--vx-line); }

/* ----- Tabelas específicas comuns ----- */
#transactionsTable tbody tr td { font-size: var(--vx-font-size-sm); }
#transactionsTable tbody tr:hover { background: #f6faff; }

/* ----- Acessibilidade / Focus visível ----- */
:focus-visible { outline: 2px solid #93c5fd; outline-offset: 2px; border-radius: 6px; }

/* ============= MICRO-POLISH POR TELA ============= */

/* DASHBOARD -------------------------------------- */
.dashboard, .dashboard-wrapper, .dashboard-content { display: grid; gap: 14px; }
.kpi-grid, .resumo, .cards-resumo, .dashboard-cards {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 12px;
}
.kpi, .kpi-card, .resumo-card {
  padding: 12px; border-radius: var(--vx-radius); background: var(--vx-card);
  border: 1px solid var(--vx-line); box-shadow: var(--vx-shadow-1);
}
.kpi .value, .kpi-card .value { font-size: 1.2rem; font-weight: 800; }
.kpi .label, .kpi-card .label { color: var(--vx-text-muted); font-size: var(--vx-font-size-xs); }
.dashboard-section-title { margin: 2px 0 6px; font-size: 1.05rem; font-weight: 700; }

/* PEDIDOS (orders.php, show-order.php) ----------- */
.filters-bar, .orders-filter, .orders-actions {
  display: flex; flex-wrap: wrap; gap: .5rem; align-items: center;
  background: var(--vx-card); border: 1px solid var(--vx-line);
  padding: .5rem .6rem; border-radius: var(--vx-radius);
}
.orders-table, #ordersTable, .table-orders { border: 1px solid var(--vx-line); border-radius: var(--vx-radius); overflow: hidden; }
.orders-table thead th, #ordersTable thead th, .table-orders thead th { position: sticky; top: 0; z-index: 1; background: #f9fafb; }
.orders-table tbody tr:hover, #ordersTable tbody tr:hover, .table-orders tbody tr:hover { background: #f6faff; }
.order-card, .pedido { transition: box-shadow .15s ease, transform .04s ease; }
.order-card:hover, .pedido:hover { box-shadow: var(--vx-shadow-2); }
.order-meta { color: var(--vx-text-muted); font-size: var(--vx-font-size-xs); }

/* CHECKOUT (checkout.php/checkout2.php) ---------- */
.checkout-wrapper, .checkout-page, .checkout-grid { display: grid; gap: 10px; }
@media (min-width: 900px){ .checkout-grid { grid-template-columns: 2fr 1fr; } }
.checkout-panel, .totals-box, .summary-box {
  background: var(--vx-card); border: 1px solid var(--vx-line); border-radius: var(--vx-radius);
  padding: .7rem .8rem; box-shadow: var(--vx-shadow-1);
}
.checkout-panel h3, .summary-box h3 { margin: 2px 0 6px; font-size: 1.05rem; }
.checkout-tabs, .step-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 6px; }
.checkout-tabs .tab, .step-tabs .tab-btn, .step-tabs .tab {
  padding: .35rem .6rem; border-radius: 999px; font-weight: 700;
  background: #eef2ff; color: #3730a3; border: 1px solid #e0e7ff; cursor: pointer;
}
.checkout-tabs .tab.active, .step-tabs .tab-btn.active { background: #dbeafe; color: #1e3a8a; border-color: #bfdbfe; }

/* RELATÓRIOS (reports.php) ----------------------- */
.reports-topbar, .reports-controls, .period-bar {
  display:flex; flex-wrap: wrap; gap:.5rem; align-items:center;
  background: var(--vx-card); border: 1px solid var(--vx-line);
  padding: .5rem .6rem; border-radius: var(--vx-radius);
}
.period-buttons button {
  border: 1px solid var(--vx-line); background: #fff; color: var(--vx-text);
  padding: .35rem .6rem; border-radius: 999px; font-weight: 700;
}
.period-buttons button.active { background: #eaf1ff; border-color: #c7d2fe; color: #1d4ed8; }
.custom-period { display: flex; gap: .4rem; align-items: center; }
.custom-period input[type="date"] { padding: .35rem .45rem; font-size: var(--vx-font-size-xs); }
.reports-tabs { display:flex; gap:6px; margin:.3rem 0 .4rem; }
.reports-tabs .tab-btn {
  padding:.35rem .6rem; border-radius:999px; background:#f2f4f8; border:1px solid var(--vx-line); font-weight:700;
}
.reports-tabs .tab-btn.active { background:#eaf1ff; border-color:#c7d2fe; color:#1d4ed8; }
#transactionsTable { border: 1px solid var(--vx-line); border-radius: var(--vx-radius); overflow: hidden; }
#transactionsTable thead th { position: sticky; top: 0; z-index: 1; background: #f9fafb; }
#transactionsTable tbody tr:hover { background: #f6faff; }

/* LISTAS / ITENS COM HOVER (produtos, clientes) -- */
.product-row, .client-row { cursor: pointer; transition: box-shadow .15s ease, transform .04s ease; }
.product-row:hover, .client-row:hover { box-shadow: var(--vx-shadow-2); }

/* FORM GRID SUAVE -------------------------------- */
.form-grid-2 { display:grid; grid-template-columns: 1fr; gap:.6rem; }
@media(min-width:900px){ .form-grid-2 { grid-template-columns: 1fr 1fr; } }
.form-row { display:flex; gap:.6rem; align-items:center; }

/* DENSIDADE COMPACTA GLOBAL (toggle Shift+D) ------ */
.ui-compact table th, .ui-compact table td { padding: .4rem .5rem; }
.ui-compact .btn, .ui-compact button, .ui-compact .vx-btn { --btn-pad-y:.42rem; --btn-pad-x:.72rem; font-size: var(--vx-font-size-xs); }
.ui-compact input, .ui-compact select, .ui-compact textarea { padding:.38rem .5rem; font-size: var(--vx-font-size-xs); }

/* PRINT CUPOM / COMANDA (mais limpo) ------------- */
@media print {
  body { background:#fff; }
  header, .topbar, .app-header, .sidebar, .filters-bar, .reports-topbar, .period-bar, .reports-tabs, .btn, .actions, .modal .modal-footer { display:none !important; }
  .cupom-container, .comanda, .print-area { box-shadow:none !important; border:0 !important; }
  table, th, td { border-color:#000 !important; }
}

/* ===== Busy Overlay (global) ===== */
.vx-busy {
  position: fixed; inset: 0; z-index: 99999;
  display: none; align-items: center; justify-content: center;
  background: rgba(255,255,255,.65); backdrop-filter: blur(2px);
}
.vx-busy.show { display: flex; }
.vx-busy-box {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  background:#ffffff; border:1px solid var(--vx-line);
  border-radius: 12px; padding: 14px 18px; box-shadow: var(--vx-shadow-2);
  color: var(--vx-text); font-weight: 600; font-size: var(--vx-font-size-sm);
}
.vx-spinner {
  width: 28px; height: 28px; border-radius: 50%;
  border: 3px solid #c7d2fe; border-top-color: var(--vx-primary);
  animation: vxspin .8s linear infinite;
}
@keyframes vxspin { to { transform: rotate(360deg); } }

/* ===== Inline spinner para itens de menu ===== */
.vx-inline-spinner {
  width: 16px; height: 16px; border-radius: 50%;
  border: 2px solid #c7d2fe; border-top-color: var(--vx-primary);
  animation: vxspin .8s linear infinite;
  margin-left: .5rem; flex: 0 0 auto;
}
nav a.is-loading, .menu a.is-loading, .sidebar a.is-loading, .topbar a.is-loading, .menu-item.is-loading {
  display: inline-flex; align-items: center; gap: .25rem;
  pointer-events: none; opacity: .9;
}

/* ========= LOGIN MINIMALISTA ========= */
.page-login {
  min-height: 100vh; display: grid; place-items: center; background: var(--vx-bg);
}
.page-login .login-card {
  width: min(420px, 92vw);
  background: var(--vx-card);
  border: 1px solid var(--vx-line);
  border-radius: 14px;
  box-shadow: var(--vx-shadow-2);
  padding: 18px 18px 16px;
}
.page-login .login-card h1,
.page-login .login-card h2 {
  margin: 0 0 8px; font-size: 1.25rem; font-weight: 800;
}
.page-login .login-card p.subtitle {
  margin: 0 0 12px; color: var(--vx-text-muted); font-size: var(--vx-font-size-sm);
}
.page-login .login-card .form-row { display: grid; gap: 8px; margin-bottom: 10px; }
.page-login .login-card .btn {
  width: 100%; padding: .55rem .9rem; font-weight: 700;
}

/* etiquetas compactas caso existam */
.page-login label { font-size: var(--vx-font-size-xs); color: var(--vx-text-muted); font-weight: 700; }

/* ajuda/rodapé */
.page-login .login-help { margin-top: 10px; text-align: center; font-size: var(--vx-font-size-xs); color: var(--vx-text-muted); }

/* ========= TABELAS STICKY / COMPACTAS ========= */
.table-sticky thead th { position: sticky; top: 0; z-index: 1; background: #f9fafb; }
.table-tight th, .table-tight td { padding: .42rem .5rem; font-size: var(--vx-font-size-xs); }

/* barras de filtro ainda mais compactas (reports/show-order) */
.filters-bar.tight, .reports-topbar.tight, .period-bar.tight {
  padding: .4rem .5rem; gap: .4rem;
}
.filters-bar.tight input, .filters-bar.tight select { padding: .35rem .5rem; font-size: var(--vx-font-size-xs); }

/* ========= SPINNER WAVE PARA MENUS ========= */
.vx-inline-wave{ display:inline-flex; align-items:center; gap:3px; margin-left:.5rem; flex:0 0 auto; }
.vx-inline-wave i{
  width:3px; height:14px; background: var(--vx-primary);
  border-radius: 2px;
  animation: vxwave 1s ease-in-out infinite; opacity: .9;
}
.vx-inline-wave i:nth-child(1){ animation-delay: 0s;   }
.vx-inline-wave i:nth-child(2){ animation-delay: .08s; }
.vx-inline-wave i:nth-child(3){ animation-delay: .16s; }
.vx-inline-wave i:nth-child(4){ animation-delay: .24s; }
.vx-inline-wave i:nth-child(5){ animation-delay: .32s; }

@keyframes vxwave{
  0%, 100% { transform: scaleY(.45); }
  50%      { transform: scaleY(1.0); }
}

/* mantém compat do spinner circular caso ainda seja usado em algum lugar */
.vx-inline-spinner {
  width: 16px; height: 16px; border-radius: 50%;
  border: 2px solid #c7d2fe; border-top-color: var(--vx-primary);
  animation: vxspin .8s linear infinite;
  margin-left: .5rem; flex: 0 0 auto;
}
@keyframes vxspin { to { transform: rotate(360deg); } }

nav a.is-loading, .menu a.is-loading, .sidebar a.is-loading, .topbar a.is-loading, .menu-item.is-loading {
  display: inline-flex; align-items: center; gap: .25rem;
  pointer-events: none; opacity: .9;
}

/* ===== Spinner branco nos botões do menu ===== */
.vx-inline-wave i {
  background: #fff !important; /* branco puro */
}
.vx-inline-spinner {
  border-color: rgba(255, 255, 255, 0.35);
  border-top-color: #fff;
}

/* ===== Tabelas: contraste + scroll responsivo ===== */
.table-scroll { overflow: auto; border: 1px solid var(--vx-line); border-radius: var(--vx-radius); }
.table-scroll table { min-width: 720px; } /* evita quebra feia em telas menores */
tbody tr:focus-within { outline: 2px solid #bfdbfe; outline-offset: -2px; }
tbody tr td:first-child { font-weight: 600; }

/* ===== Chips (abas/filtros) mais elegantes ===== */
.chip {
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.35rem .65rem; border-radius:999px; border:1px solid var(--vx-line);
  background:#f2f4f8; color:var(--vx-text); font-weight:700; font-size: var(--vx-font-size-xs);
  cursor:pointer; user-select:none;
}
.chip:hover { background:#eaf1ff; border-color:#c7d2fe; }
.chip.active { background:#dbeafe; color:#1e3a8a; border-color:#bfdbfe; }

/* ===== Skeletons (carregamento) ===== */
.skeleton { position:relative; overflow:hidden; background:#eef2ff; border-radius:8px; }
.skeleton::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  transform: translateX(-100%); animation: vx-skel 1.2s infinite;
}
@keyframes vx-skel { to { transform: translateX(100%); } }

.skeleton-line { height: 10px; margin: 6px 0; border-radius:6px; }
.skeleton-avatar { width:32px; height:32px; border-radius:50%; }
.skeleton-table { border:1px solid var(--vx-line); border-radius:var(--vx-radius); padding:.6rem; }

/* ===== Acessibilidade: reduzir animações se preferido ===== */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
}
