:root{--bg:#0e0e0f;--surface:#161618;--surface2:#1e1e21;--border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);--text:#f0ede8;--muted:#7a7875;--accent:#e8b84b;--accent2:#c49a2a;--green:#4ade80;--red:#f87171;--yellow:#fbbf24;--blue:#60a5fa;--purple:#c084fc;--font-head:'Syne',sans-serif;--font-body:'DM Sans',sans-serif;--font-mono:'DM Mono',monospace;--radius:10px;--sidebar:220px}
[data-theme='light']{--bg:#f7f4ee;--surface:#ffffff;--surface2:#f1ece2;--border:rgba(15,23,42,0.08);--border2:rgba(15,23,42,0.14);--text:#1f2937;--muted:#6b7280;--accent:#c99216;--accent2:#af7f12;--green:#15803d;--red:#dc2626;--yellow:#d97706;--blue:#2563eb;--purple:#7c3aed}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:14px;line-height:1.6;min-height:100vh;display:flex}
#sidebar{width:var(--sidebar);min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}
.logo{padding:24px 20px 20px;border-bottom:1px solid var(--border)}
.logo-text{font-family:var(--font-head);font-size:17px;font-weight:800;color:var(--accent)}
.logo-sub{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
nav{flex:1;padding:16px 10px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;color:var(--muted);font-size:13px;font-weight:500;transition:all .15s;margin-bottom:2px;user-select:none}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:rgba(232,184,75,.12);color:var(--accent)}
.nav-icon{width:16px;text-align:center;font-size:15px}
.sidebar-footer{padding:16px;border-top:1px solid var(--border)}
.version{font-size:11px;color:var(--muted);font-family:var(--font-mono)}
#main{margin-left:var(--sidebar);flex:1;padding:32px;min-height:100vh}
.page{display:none}.page.active{display:block}
.page-title{font-family:var(--font-head);font-size:24px;font-weight:700;margin-bottom:6px}
.page-sub{color:var(--muted);font-size:13px;margin-bottom:28px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.card-label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:8px}
.card-value{font-family:var(--font-head);font-size:26px;font-weight:700;margin-top:6px}
.card-clickable{cursor:pointer;transition:border-color .2s,box-shadow .2s}
.card-clickable:hover{border-color:rgba(232,184,75,.4);box-shadow:0 0 0 1px rgba(232,184,75,.1) inset}
.card-critical{border-color:rgba(248,113,113,.35)!important;box-shadow:0 0 18px rgba(248,113,113,.08),0 0 0 1px rgba(248,113,113,.1) inset!important}
.card-critical .card-value{text-shadow:0 0 24px rgba(248,113,113,.45)}
/* Charts */
.chart-wrap{width:100%;overflow:hidden;margin-top:8px}
canvas.rb-chart{width:100%!important;display:block}
.chart-legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;font-size:11px;color:var(--muted)}
.chart-legend-item{display:flex;align-items:center;gap:5px}
.chart-legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
/* ABC badge */
.abc-a{color:#4ade80;font-weight:700}
.abc-b{color:#fbbf24;font-weight:700}
.abc-c{color:#f87171;font-weight:700}
.card-value.green{color:var(--green)}.card-value.accent{color:var(--accent)}.card-value.red{color:var(--red)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:10px 14px;color:var(--muted);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border)}
td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.02)}
.mono{font-family:var(--font-mono)}
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:500}
.badge-green{background:rgba(74,222,128,.12);color:var(--green)}
.badge-yellow{background:rgba(251,191,36,.12);color:var(--yellow)}
.badge-red{background:rgba(248,113,113,.15);color:var(--red)}
.badge-gray{background:rgba(255,255,255,.06);color:var(--muted)}
.badge-blue{background:rgba(96,165,250,.12);color:var(--blue)}
.badge-purple{background:rgba(192,132,252,.12);color:var(--purple)}
.form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px}
.form-title{font-family:var(--font-head);font-size:15px;font-weight:600;margin-bottom:18px}
.form-grid{display:grid;gap:14px}
.form-grid-2{grid-template-columns:1fr 1fr}
.form-grid-3{grid-template-columns:1fr 1fr 1fr}
.field{display:flex;flex-direction:column;gap:6px}
label{font-size:12px;color:var(--muted);font-weight:500}
input,select,textarea{background:var(--bg);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-family:var(--font-body);font-size:13px;padding:9px 12px;outline:none;transition:border-color .15s;width:100%}
input:focus,select:focus{border-color:var(--accent)}
select option{background:var(--surface);color:var(--text)}
[data-theme='light'] select option{background:#ffffff;color:#1f2937}
input[type='date'],input[type='month']{cursor:pointer;height:40px;line-height:20px;padding-right:12px}
input[type='date']::-webkit-calendar-picker-indicator,input[type='month']::-webkit-calendar-picker-indicator{cursor:pointer;width:18px;height:18px;padding:4px;margin-left:6px;border-radius:7px;background-color:rgba(232,184,75,.18);filter:invert(1);opacity:1}
[data-theme='light'] input[type='date']::-webkit-calendar-picker-indicator,[data-theme='light'] input[type='month']::-webkit-calendar-picker-indicator{filter:none;background-color:rgba(201,146,22,.16)}
.filter-panel{display:grid;grid-template-columns:150px 1fr auto;gap:10px;align-items:end;width:100%}
.filter-date-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pie-filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.pie-chip{border:1px solid var(--border2);border-radius:999px;background:var(--surface2);color:var(--text);padding:5px 10px;font-size:12px;cursor:pointer}
.pie-chip.off{text-decoration:line-through;opacity:.45}
.parcela-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.comprovante-link{color:var(--blue);font-size:12px;text-decoration:none}
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;font-family:var(--font-body);transition:all .15s}
.btn-primary{background:var(--accent);color:#0e0e0f}.btn-primary:hover{background:var(--accent2)}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border2)}.btn-ghost:hover{color:var(--text);border-color:var(--border);background:var(--surface2)}
.btn-danger{background:rgba(248,113,113,.12);color:var(--red);border:1px solid rgba(248,113,113,.2)}.btn-danger:hover{background:rgba(248,113,113,.2)}
.btn-edit{background:rgba(96,165,250,.1);color:var(--blue);border:1px solid rgba(96,165,250,.2)}.btn-edit:hover{background:rgba(96,165,250,.2)}
.btn-success{background:rgba(74,222,128,.12);color:var(--green);border:1px solid rgba(74,222,128,.2)}.btn-success:hover{background:rgba(74,222,128,.2)}
.btn-sm{padding:5px 11px;font-size:12px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.section-header h3{font-family:var(--font-head);font-size:15px;font-weight:600}
.alert-bar{background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2);border-radius:8px;padding:12px 16px;font-size:13px;color:var(--yellow);margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}
.progress-bar{background:rgba(255,255,255,.06);border-radius:4px;height:5px;overflow:hidden;margin-top:5px}
.progress-fill{height:100%;border-radius:4px;transition:width .3s}
.divider{border:none;border-top:1px solid var(--border);margin:20px 0}
.empty{text-align:center;padding:40px;color:var(--muted);font-size:13px}
.tag{font-family:var(--font-mono);font-size:12px}
.calc-box{background:rgba(232,184,75,.06);border:1px solid rgba(232,184,75,.15);border-radius:8px;padding:16px}
.calc-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0}
.calc-row.total{border-top:1px solid rgba(232,184,75,.2);margin-top:8px;padding-top:10px;font-weight:600;color:var(--accent)}
.actions-cell{display:flex;gap:5px}
.export-row{display:flex;gap:6px;flex-wrap:wrap}

/* UX geral: leitura mais clara para usuários não técnicos */
.card,.form-section{box-shadow:0 10px 26px rgba(0,0,0,.10)}
input,select,textarea{min-height:40px}
table{font-size:13.5px}
th{padding:12px 14px;color:#8f8b86}
td{padding:12px 14px}
tr:hover td{background:rgba(232,184,75,.035)}
.data-strong{font-weight:800;color:var(--text)}
.money-strong{font-weight:800;color:var(--accent)}
.modelos-count{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:800;background:rgba(192,132,252,.16);color:var(--purple);white-space:nowrap}
.stock-cell{min-width:112px;font-family:var(--font-mono);font-weight:800;color:var(--text)}
.stock-cell .mini{display:block;font-family:var(--font-body);font-size:11px;font-weight:500;color:var(--muted);margin-top:2px}
.stock-mini-bar{height:5px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden;margin-top:6px;width:86px}
.stock-mini-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--yellow))}
.lote-master-row td{font-weight:700;background:rgba(255,255,255,.012)}
.modelo-subrow td{background:rgba(192,132,252,.04)!important;color:var(--muted);font-size:12.5px;padding-top:9px;padding-bottom:9px}
.modelo-name{color:var(--purple);font-weight:800;display:block;padding-left:12px}
.modelo-name:before{content:'↳ ';color:var(--muted);font-weight:500}
.modelo-cost{font-family:var(--font-mono);color:var(--muted)}
.status-open{font-weight:800;text-transform:lowercase}
.help-text{font-size:12px;color:var(--muted);line-height:1.4}
@media(max-width:900px){#main{padding:20px}.grid-4,.grid-3,.grid-2,.form-grid-3,.form-grid-2{grid-template-columns:1fr}.filter-panel{grid-template-columns:1fr}.table-wrap{overflow-x:auto}table{min-width:760px}}

.subtabs{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0 22px}
.subtab{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;border:1px solid var(--border2);background:var(--surface);color:var(--muted);cursor:pointer;transition:all .18s;min-width:220px;box-shadow:0 6px 18px rgba(0,0,0,.08)}
.subtab:hover{color:var(--text);border-color:var(--accent);transform:translateY(-1px)}
.subtab.active{background:linear-gradient(135deg, rgba(232,184,75,.16), rgba(232,184,75,.06));border-color:rgba(232,184,75,.38);color:var(--text);box-shadow:0 10px 24px rgba(0,0,0,.12)}
.subtab-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(232,184,75,.14);color:var(--accent);font-size:16px;font-weight:700;flex:0 0 auto}
.subtab-title{font-family:var(--font-head);font-size:14px;font-weight:700;line-height:1.2}
.subtab-desc{font-size:11px;color:var(--muted);margin-top:2px}
.subpage{display:none}
.subpage.active{display:block}
.section-note{color:var(--muted);font-size:12px;margin:0 0 16px}

/* MODELO BUILDER — 4 columns: nome | qtd | custo_unit | delete */
.modelos-builder{border:1px solid rgba(192,132,252,.2);border-radius:8px;padding:16px;background:rgba(192,132,252,.04);margin-top:4px}
.modelos-builder-header{font-size:12px;font-weight:500;color:var(--purple);margin-bottom:12px}
.modelos-col-heads{display:grid;grid-template-columns:1fr 80px 110px 32px;gap:8px;margin-bottom:6px}
.modelos-col-heads span{font-size:11px;color:var(--muted);font-weight:500}
.modelo-row{display:grid;grid-template-columns:1fr 80px 110px 32px;gap:8px;align-items:center;margin-bottom:8px}
.modelo-row input{padding:7px 10px;font-size:13px}
.del-btn{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.2);border-radius:6px;color:var(--red);cursor:pointer;padding:4px 8px;font-size:14px;line-height:1}
.add-modelo-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;background:rgba(192,132,252,.06);border:1px dashed rgba(192,132,252,.3);border-radius:8px;color:var(--purple);font-size:12px;font-weight:500;cursor:pointer;width:100%;transition:all .15s;margin-top:4px}
.add-modelo-btn:hover{background:rgba(192,132,252,.14)}
.lote-summary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:12px}
.lote-summary-card{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;padding:10px 14px}
.lote-summary-card .ls-label{font-size:11px;color:var(--muted);margin-bottom:2px}
.lote-summary-card .ls-val{font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--accent)}

/* modelo subrow in table */
.modelo-subrow td{padding:5px 14px 5px 30px;background:rgba(192,132,252,.03);border-bottom:1px solid rgba(255,255,255,.03);font-size:12px;color:var(--muted)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-box{background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:28px;width:100%;max-width:620px;max-height:90vh;overflow-y:auto}
.modal-title{font-family:var(--font-head);font-size:17px;font-weight:700;margin-bottom:20px}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;padding-top:16px;border-top:1px solid var(--border)}

.dashboard-stock-row{display:grid;grid-template-columns:minmax(520px,1fr) minmax(520px,1fr);gap:20px;margin-bottom:24px;align-items:start}
.stock-card-half{grid-column:1 / 2;min-width:0;min-height:395px;display:flex;flex-direction:column}
.stock-card-half .section-header{align-items:flex-start;margin-bottom:12px}
.stock-help{color:var(--muted);font-size:11px;line-height:1.4;text-align:right;max-width:310px}
.stock-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:0 0 16px}
.stock-tab{border:1px solid transparent;border-radius:12px;padding:10px 12px;font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;color:#0b0b0c;box-shadow:0 5px 14px rgba(0,0,0,.14);opacity:.86;display:flex;align-items:center;justify-content:center;gap:7px;min-height:40px;letter-spacing:0;white-space:nowrap}
.stock-tab:hover{transform:translateY(-1px);opacity:1;filter:brightness(1.04)}
.stock-tab.active{opacity:1;box-shadow:0 0 0 2px rgba(255,255,255,.16),0 8px 20px rgba(0,0,0,.22);transform:translateY(-1px)}
.stock-tab-esgotado{background:#777;color:#050505}
.stock-tab-critico{background:#d90000;color:#fff}
.stock-tab-urgente{background:#e8924d;color:#050505}
.stock-tab-muito_baixo{background:#4d8df7;color:#050505}
.stock-tab .count{font-family:var(--font-mono);font-size:11px;font-weight:700;background:rgba(0,0,0,.22);color:#fff;border-radius:999px;padding:1px 7px;line-height:18px;min-width:22px;text-align:center}
.stock-table-area{min-height:232px;display:flex;flex-direction:column;overflow:hidden!important}
.stock-table-area table{table-layout:fixed;width:100%;min-width:0!important}
.stock-table-area th:nth-child(1){width:47%}.stock-table-area th:nth-child(2){width:13%}.stock-table-area th:nth-child(3){width:14%}.stock-table-area th:nth-child(4){width:16%}.stock-table-area th:nth-child(5){width:10%}
.stock-table-area th,.stock-table-area td{padding:10px 12px;vertical-align:middle;overflow:hidden;text-overflow:ellipsis}
.stock-table-area th{font-size:10.5px;white-space:nowrap}
.stock-model-name{color:var(--purple);font-size:12.5px;font-weight:600;line-height:1.35;display:block}
.stock-model-lote{color:var(--muted);font-size:10.5px;margin-top:2px;display:block}
.stock-restante{font-size:13px;font-weight:800;white-space:nowrap}
.stock-media,.stock-dias{font-size:12px;white-space:nowrap}
.stock-pager{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:auto;padding-top:14px;color:var(--muted);font-size:12px;flex-wrap:wrap}
.stock-pager-actions{display:flex;gap:6px;align-items:center}
.stock-page-select{width:auto;min-width:70px;padding:5px 8px;font-size:12px}
.stock-status-pill{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;border-radius:999px;font-size:10.5px;font-weight:800;white-space:nowrap;min-width:72px}
.stock-status-esgotado{background:rgba(255,255,255,.08);color:var(--muted)}
.stock-status-critico{background:rgba(248,113,113,.18);color:#ff6b6b}
.stock-status-urgente{background:rgba(232,146,77,.18);color:#ffb16d}
.stock-status-muito_baixo{background:rgba(77,141,247,.16);color:#72a7ff}
@media(max-width:1200px){.dashboard-stock-row{grid-template-columns:1fr}.stock-card-half{grid-column:auto}.stock-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.stock-help{text-align:left;max-width:none}}
@media(max-width:720px){.stock-tabs{grid-template-columns:1fr}.stock-table-area{overflow-x:auto}.stock-table-area table{min-width:680px}}


/* Melhorias v4 */
.required::after{content:' *';color:var(--red)}
.client-card-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.modal-box{max-width:980px!important}
.client-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.info-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px}
.info-card h4{font-family:var(--font-head);font-size:14px;margin-bottom:8px;color:var(--accent)}
.payment-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:10px;display:grid;grid-template-columns:90px 120px 130px 1fr;gap:12px;align-items:center}
.payment-card.pago{border-color:rgba(74,222,128,.32);background:rgba(74,222,128,.05)}
.file-input-clean{max-width:260px;font-size:12px;padding:8px;background:var(--surface)}
.estoque-model-card{display:grid;grid-template-columns:1.6fr 1fr 1.2fr 1fr 1fr;gap:14px;align-items:center;border-bottom:1px solid var(--border);padding:16px 10px}
.estoque-model-card:hover{background:rgba(255,255,255,.025)}
.estoque-model-title{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--purple)}
.estoque-model-sub{font-size:12px;color:var(--muted);margin-top:2px}
.estoque-kpi{font-size:12px;color:var(--muted)}
.estoque-kpi b{display:block;color:var(--text);font-size:16px;margin-top:2px}
.estoque-header{display:grid;grid-template-columns:1.6fr 1fr 1.2fr 1fr 1fr;gap:14px;padding:0 10px 10px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border)}
.venda-col-heads{display:grid;grid-template-columns:1fr 1.25fr 90px 120px 32px;gap:8px;margin-bottom:6px}
.venda-col-heads span{font-size:11px;color:var(--muted);font-weight:500}
.venda-item-row{display:grid;grid-template-columns:1fr 1.25fr 90px 120px 32px;gap:8px;align-items:center;margin-bottom:8px}
@media(max-width:900px){.client-detail-grid,.payment-card,.estoque-model-card,.estoque-header,.venda-item-row,.venda-col-heads{grid-template-columns:1fr}.payment-card{gap:8px}}

/* Ajustes v6 - clientes e pagamentos */
.address-separator{grid-column:1/-1;margin:8px 0 0;padding-top:14px;border-top:1px solid var(--border);font-family:var(--font-head);font-size:14px;font-weight:800;color:var(--accent)}
.client-modal-wrap{display:grid;gap:16px}.client-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.client-info-card{border:1px solid var(--border);background:var(--surface2);border-radius:14px;padding:16px}.client-info-card h4{font-family:var(--font-head);font-size:14px;margin-bottom:10px;color:var(--accent)}.info-line{display:grid;grid-template-columns:130px 1fr;gap:8px;margin:5px 0}.info-line span:first-child{color:var(--muted);font-size:12px}.info-line span:last-child{font-weight:700}.client-section{border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.015);padding:16px}.client-section h4{font-family:var(--font-head);font-size:15px;margin-bottom:12px}.pedido-card-clean{border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:10px;background:var(--surface)}.pedido-card-top{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:14px;align-items:center}.pedido-kpi-label{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.7px}.pedido-kpi-value{font-weight:800;font-size:15px}.parcelas-grid-clean{display:grid;gap:10px}.parcela-card-clean{display:grid;grid-template-columns:1.1fr 1fr 1fr 1.6fr;gap:12px;align-items:center;border:1px solid var(--border);border-radius:14px;padding:14px;background:var(--surface)}.parcela-card-clean.pago{border-color:rgba(74,222,128,.45);background:rgba(74,222,128,.06)}.pay-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.btn-save-status{background:rgba(74,222,128,.14);color:var(--green);border:1px solid rgba(74,222,128,.25)}.modal-box{max-width:980px}.file-input-clean{max-width:260px;min-height:38px}@media(max-width:900px){.client-summary-grid,.pedido-card-top,.parcela-card-clean{grid-template-columns:1fr}.info-line{grid-template-columns:1fr}.modal-box{max-width:96vw}}


/* =========================================================
   FERREIRA BOLSAS — REDESIGN PROFISSIONAL 2026
   Alteração visual completa, mantendo funções e IDs originais.
   ========================================================= */
:root{
  --bg:#f5f1ea;
  --surface:#ffffff;
  --surface2:#fbfaf7;
  --surface3:#f0ebe2;
  --border:rgba(28,27,24,.08);
  --border2:rgba(28,27,24,.14);
  --text:#171717;
  --muted:#706a61;
  --accent:#b78234;
  --accent2:#936526;
  --gold-soft:#f1dfc5;
  --green:#128047;
  --red:#c93434;
  --yellow:#b97708;
  --blue:#2563eb;
  --purple:#7c3aed;
  --font-head:'Manrope','Inter',sans-serif;
  --font-body:'Inter',sans-serif;
  --font-mono:'JetBrains Mono','DM Mono',monospace;
  --radius:16px;
  --sidebar:252px;
}
[data-theme='dark']{
  --bg:#0f0f10;
  --surface:#181819;
  --surface2:#202022;
  --surface3:#262626;
  --border:rgba(255,255,255,.08);
  --border2:rgba(255,255,255,.14);
  --text:#f6f2ea;
  --muted:#a79f93;
  --accent:#d7a24a;
  --accent2:#f0bd65;
  --gold-soft:rgba(215,162,74,.18);
  --green:#4ade80;
  --red:#f87171;
  --yellow:#fbbf24;
  --blue:#60a5fa;
  --purple:#c084fc;
}
*{scrollbar-width:thin;scrollbar-color:rgba(183,130,52,.55) transparent}
body{
  background:
    radial-gradient(circle at 18% 0%, rgba(183,130,52,.12), transparent 32%),
    linear-gradient(135deg, #f8f5ef 0%, var(--bg) 48%, #efe8dc 100%);
  color:var(--text);
  letter-spacing:-.01em;
}
[data-theme='dark'] body{
  background:
    radial-gradient(circle at 20% 0%, rgba(215,162,74,.17), transparent 34%),
    linear-gradient(135deg,#0d0d0e,#151515 52%,#0f0f10);
}
#sidebar{
  width:var(--sidebar);
  background:linear-gradient(180deg,#111111 0%,#181818 48%,#111111 100%);
  border-right:1px solid rgba(255,255,255,.08);
  box-shadow:18px 0 50px rgba(0,0,0,.14);
}
.logo{
  min-height:94px;
  padding:22px 20px 18px;
  display:flex;
  align-items:center;
  gap:14px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.brand-logo-img{
  width:48px;
  height:48px;
  object-fit:contain;
  filter:invert(1);
  flex:0 0 auto;
}
.logo-text{
  font-family:var(--font-head);
  font-size:16px;
  line-height:1;
  letter-spacing:2.8px;
  text-transform:uppercase;
  color:#fff;
}
.logo-sub{
  margin-top:7px;
  font-size:10px;
  letter-spacing:2px;
  color:#c9a56b;
}
nav{padding:18px 12px}
.nav-item{
  position:relative;
  min-height:46px;
  padding:12px 14px;
  border-radius:14px;
  margin-bottom:6px;
  color:rgba(255,255,255,.72);
  font-weight:650;
  font-size:13px;
}
.nav-item:hover{
  background:rgba(255,255,255,.065);
  color:#fff;
  transform:translateX(2px);
}
.nav-item.active{
  background:linear-gradient(90deg,rgba(183,130,52,.25),rgba(255,255,255,.055));
  color:#f0c981;
  box-shadow:inset 3px 0 0 var(--accent),0 10px 24px rgba(0,0,0,.16);
}
.nav-icon{
  width:26px;
  height:26px;
  border-radius:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.06);
  font-size:14px;
}
.nav-item.active .nav-icon{
  background:rgba(183,130,52,.2);
}
.sidebar-footer{
  margin:12px;
  padding:14px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  background:rgba(255,255,255,.045);
}
.version{
  color:rgba(255,255,255,.68);
  line-height:1.55;
}
#main{
  margin-left:var(--sidebar);
  padding:26px 34px 42px;
  max-width:1680px;
}
.app-topbar{
  height:72px;
  margin-bottom:26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 18px;
  background:rgba(255,255,255,.66);
  border:1px solid rgba(28,27,24,.08);
  border-radius:22px;
  box-shadow:0 18px 44px rgba(48,38,22,.08);
  backdrop-filter:blur(14px);
}
[data-theme='dark'] .app-topbar{
  background:rgba(24,24,25,.72);
  border-color:rgba(255,255,255,.08);
  box-shadow:0 18px 44px rgba(0,0,0,.25);
}
.app-kicker{
  color:var(--accent);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:1.4px;
  font-weight:800;
}
.app-titlebar{
  font-family:var(--font-head);
  font-size:18px;
  font-weight:800;
}
.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.topbar-pill,.topbar-user{
  min-height:36px;
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  border:1px solid var(--border);
  background:var(--surface2);
}
.topbar-user::before{
  content:'AD';
  width:26px;height:26px;border-radius:50%;
  margin-right:8px;
  display:inline-flex;align-items:center;justify-content:center;
  background:#171717;color:#fff;font-size:11px;
}
.page-title{
  font-size:29px;
  font-weight:850;
  letter-spacing:-.035em;
  margin-bottom:4px;
}
.page-sub{
  color:var(--muted);
  margin-bottom:22px;
}
.card,.form-section,.modal-box{
  background:rgba(255,255,255,.88);
  border:1px solid var(--border);
  border-radius:20px;
  box-shadow:0 14px 34px rgba(52,42,26,.075);
}
[data-theme='dark'] .card,[data-theme='dark'] .form-section,[data-theme='dark'] .modal-box{
  background:rgba(24,24,25,.9);
  box-shadow:0 18px 42px rgba(0,0,0,.22);
}
.card{padding:22px}
.section-header h3,.form-title{
  font-family:var(--font-head);
  font-weight:820;
  font-size:16px;
}
.grid-4{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:16px;
  margin-bottom:22px;
}
.grid-3{gap:16px}
.grid-2{gap:18px}
.card-label{
  font-size:11px;
  letter-spacing:.8px;
  font-weight:800;
  color:var(--muted);
}
.card-value{
  font-family:var(--font-head);
  font-size:25px;
  font-weight:850;
  letter-spacing:-.035em;
}
#dash-metrics .card{
  position:relative;
  overflow:hidden;
  min-height:120px;
}
#dash-metrics .card::before{
  content:'';
  position:absolute;
  top:18px;right:18px;
  width:46px;height:46px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--gold-soft),rgba(183,130,52,.08));
}
#dash-metrics .card::after{
  content:'';
  position:absolute;
  inset:auto -30px -55px auto;
  width:120px;height:120px;
  border-radius:50%;
  background:rgba(183,130,52,.08);
}
input,select,textarea{
  min-height:44px;
  background:#fff;
  border:1px solid var(--border2);
  border-radius:12px;
  color:var(--text);
  font-weight:560;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55);
}
[data-theme='dark'] input,[data-theme='dark'] select,[data-theme='dark'] textarea{background:#111112}
input:focus,select:focus,textarea:focus{
  border-color:rgba(183,130,52,.55);
  box-shadow:0 0 0 4px rgba(183,130,52,.12);
}
label{font-weight:750;color:var(--muted)}
.btn{
  min-height:40px;
  border-radius:12px;
  font-weight:800;
  letter-spacing:-.01em;
}
.btn-primary{
  color:#fff;
  background:linear-gradient(135deg,#c7954c,#9f6d27);
  box-shadow:0 10px 24px rgba(159,109,39,.23);
}
.btn-primary:hover{
  background:linear-gradient(135deg,#d0a15d,#875a1d);
  transform:translateY(-1px);
}
.btn-ghost{background:rgba(255,255,255,.55);color:var(--text);border:1px solid var(--border2)}
[data-theme='dark'] .btn-ghost{background:rgba(255,255,255,.035)}
.btn-success{background:rgba(18,128,71,.10);color:var(--green);border:1px solid rgba(18,128,71,.20)}
.btn-edit{background:rgba(183,130,52,.11);color:var(--accent);border:1px solid rgba(183,130,52,.22)}
.btn-danger{background:rgba(201,52,52,.10);color:var(--red);border:1px solid rgba(201,52,52,.20)}
table{
  border-collapse:separate;
  border-spacing:0;
  font-size:13px;
}
th{
  background:var(--surface2);
  color:var(--muted);
  font-weight:850;
  letter-spacing:.7px;
  border-bottom:1px solid var(--border);
}
th:first-child{border-top-left-radius:12px}
th:last-child{border-top-right-radius:12px}
td{
  border-bottom:1px solid var(--border);
}
tr:hover td{
  background:rgba(183,130,52,.045);
}
.badge{
  min-height:25px;
  padding:4px 10px;
  border-radius:999px;
  font-weight:850;
}
.badge-green{background:rgba(18,128,71,.12);color:var(--green)}
.badge-yellow{background:rgba(185,119,8,.13);color:var(--yellow)}
.badge-red{background:rgba(201,52,52,.12);color:var(--red)}
.badge-gray{background:rgba(112,106,97,.11);color:var(--muted)}
.badge-blue{background:rgba(37,99,235,.10);color:var(--blue)}
.badge-purple{background:rgba(124,58,237,.10);color:var(--purple)}
.subtabs{
  gap:12px;
  margin:8px 0 22px;
}
.subtab{
  min-width:245px;
  border-radius:18px;
  background:rgba(255,255,255,.86);
  border:1px solid var(--border);
  box-shadow:0 12px 28px rgba(48,38,22,.06);
}
[data-theme='dark'] .subtab{background:rgba(24,24,25,.86)}
.subtab.active{
  background:linear-gradient(135deg,rgba(183,130,52,.17),rgba(255,255,255,.86));
  border-color:rgba(183,130,52,.35);
}
[data-theme='dark'] .subtab.active{background:linear-gradient(135deg,rgba(215,162,74,.20),rgba(24,24,25,.86))}
.subtab-icon{
  border-radius:14px;
  background:var(--gold-soft);
}
.modelos-builder{
  border-radius:16px;
  background:linear-gradient(180deg,rgba(183,130,52,.075),rgba(255,255,255,.28));
  border:1px solid rgba(183,130,52,.20);
}
[data-theme='dark'] .modelos-builder{background:rgba(215,162,74,.06)}
.add-modelo-btn{
  min-height:42px;
  border-radius:14px;
  color:var(--accent);
  background:rgba(183,130,52,.08);
  border-color:rgba(183,130,52,.28);
  font-weight:800;
}
.stock-tabs{gap:10px}
.stock-tab{
  border-radius:14px;
  min-height:44px;
  box-shadow:none;
}
.stock-tab-esgotado{background:#69645d;color:#fff}
.stock-tab-critico{background:#bf2d2d;color:#fff}
.stock-tab-urgente{background:#d18c48;color:#1f1308}
.stock-tab-muito_baixo{background:#4a7bd9;color:#fff}
.chart-wrap{
  background:linear-gradient(180deg,rgba(183,130,52,.035),transparent);
  border-radius:16px;
}
.form-grid-3{gap:14px}
.filter-panel,.filter-date-row{gap:12px}
.alert-bar{
  border-radius:16px;
  background:rgba(185,119,8,.10);
}
.empty{color:var(--muted)}
.money-strong{color:var(--accent);font-weight:850}
.data-strong{font-weight:850}
.modal-overlay{backdrop-filter:blur(8px)}
.modal-box{border-radius:24px}
.client-info-card,.info-card,.client-section,.pedido-card-clean,.parcela-card-clean,.payment-card{
  border-radius:18px;
}
@media(max-width:1100px){
  :root{--sidebar:88px}
  .brand-copy,.sidebar-footer{display:none}
  .logo{justify-content:center;padding:18px 10px}
  .brand-logo-img{width:42px;height:42px}
  .nav-item{justify-content:center;padding:12px}
  .nav-item{font-size:0}
  .nav-icon{font-size:15px}
  #main{padding:20px;margin-left:var(--sidebar)}
  .app-topbar{height:auto;align-items:flex-start}
}
@media(max-width:760px){
  body{display:block}
  #sidebar{position:sticky;width:100%;height:auto;min-height:auto;display:block}
  nav{display:flex;overflow-x:auto;gap:8px;padding:10px}
  .logo{display:none}
  .nav-item{font-size:12px;min-width:max-content}
  #main{margin-left:0;padding:14px}
  .app-topbar{display:none}
  .grid-4,.grid-3,.grid-2,.form-grid-3,.form-grid-2{grid-template-columns:1fr!important}
  .subtab{min-width:100%}
}

/* Produção: login, segurança e mobile */
.auth-overlay{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(circle at 20% 0%,rgba(183,130,52,.20),transparent 34%),linear-gradient(135deg,#0d0d0e,#151515 55%,#0f0f10)}
.auth-card{width:100%;max-width:420px;background:#fff;color:#171717;border-radius:26px;padding:28px;box-shadow:0 28px 90px rgba(0,0,0,.35);border:1px solid rgba(183,130,52,.22)}
.auth-logo{width:74px;height:74px;object-fit:contain;margin:0 auto 14px;display:block}.auth-title{text-align:center;font-family:var(--font-head);font-size:23px;font-weight:850;margin-bottom:4px}.auth-sub{text-align:center;color:#706a61;font-size:13px;margin-bottom:22px}.auth-card .field{margin-bottom:12px}.auth-card input{background:#f8f5ef;color:#171717}.auth-error{display:none;margin:10px 0;color:#c93434;font-size:13px;font-weight:700}.auth-help{font-size:12px;color:#706a61;text-align:center;margin-top:14px;line-height:1.45}.auth-hidden{display:none!important}.auth-loading{opacity:.55;pointer-events:none}.topbar-user{gap:8px}.mobile-menu-btn{display:none}.logout-btn{min-height:36px;padding:7px 12px}.password-grid{display:grid;gap:12px}.app-locked #main,.app-locked #sidebar{filter:blur(3px);pointer-events:none;user-select:none}
@media(max-width:760px){
  .mobile-menu-btn{display:inline-flex;position:fixed;left:14px;bottom:14px;z-index:1200;width:52px;height:52px;border-radius:18px;align-items:center;justify-content:center;background:linear-gradient(135deg,#c7954c,#9f6d27);color:#fff;border:0;box-shadow:0 18px 34px rgba(0,0,0,.26);font-size:22px}
  body{padding-bottom:72px}#sidebar{position:fixed!important;top:auto;left:0;right:0;bottom:0;width:100%!important;transform:translateY(105%);transition:transform .25s ease;border-radius:24px 24px 0 0;z-index:1100;box-shadow:0 -18px 50px rgba(0,0,0,.28)}#sidebar.mobile-open{transform:translateY(0)}#sidebar nav{display:grid!important;grid-template-columns:1fr 1fr;max-height:70vh;overflow:auto;padding:18px}.nav-item{justify-content:flex-start!important;font-size:13px!important}.logo{display:flex!important;min-height:auto}.brand-copy{display:block!important}.sidebar-footer{display:none!important}#main{padding:14px!important}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap table{min-width:760px}.modal-box{max-width:96vw!important;padding:18px!important}.auth-card{padding:22px;border-radius:22px}.btn{width:auto}.export-row{width:100%}.export-row .btn{flex:1;justify-content:center}.app-topbar{display:flex!important;border-radius:18px;padding:12px}.topbar-actions{width:100%;justify-content:flex-start}.topbar-pill{display:none}.page-title{font-size:24px}.page-sub{font-size:12px}}

/* Ajustes REF + pagamentos */
.modelo-row.ref-mode{grid-template-columns:1.4fr .8fr 80px 110px 32px!important}
.modelos-col-heads.ref-mode{grid-template-columns:1.4fr .8fr 80px 110px 32px!important}
.ref-pill{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;background:rgba(183,130,52,.12);color:var(--accent);font-size:11px;font-weight:850;margin-left:6px}
.parcela-card-clean.proximo{border-color:rgba(185,119,8,.50);background:rgba(185,119,8,.085)}
.parcela-card-clean.expirado{border-color:rgba(201,52,52,.55);background:rgba(201,52,52,.085)}
.payment-status-note{display:inline-flex;margin-top:6px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:850}
.payment-status-note.proximo{background:rgba(185,119,8,.14);color:var(--yellow)}
.payment-status-note.expirado{background:rgba(201,52,52,.14);color:var(--red)}
.payment-status-note.pago{background:rgba(18,128,71,.14);color:var(--green)}
.client-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.client-search{max-width:360px}
/* Produção: login, segurança e mobile */
.auth-overlay{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(circle at 20% 0%,rgba(183,130,52,.20),transparent 34%),linear-gradient(135deg,#0d0d0e,#151515 55%,#0f0f10)}
.auth-card{width:100%;max-width:420px;background:#fff;color:#171717;border-radius:26px;padding:28px;box-shadow:0 28px 90px rgba(0,0,0,.35);border:1px solid rgba(183,130,52,.22)}
.auth-logo{width:74px;height:74px;object-fit:contain;margin:0 auto 14px;display:block}.auth-title{text-align:center;font-family:var(--font-head);font-size:23px;font-weight:850;margin-bottom:4px}.auth-sub{text-align:center;color:#706a61;font-size:13px;margin-bottom:22px}.auth-card .field{margin-bottom:12px}.auth-card input{background:#f8f5ef;color:#171717}.auth-error{display:none;margin:10px 0;color:#c93434;font-size:13px;font-weight:700}.auth-help{font-size:12px;color:#706a61;text-align:center;margin-top:14px;line-height:1.45}.auth-hidden{display:none!important}.auth-loading{opacity:.55;pointer-events:none}.topbar-user{gap:8px}.mobile-menu-btn{display:none}.logout-btn{min-height:36px;padding:7px 12px}.password-grid{display:grid;gap:12px}.app-locked #main,.app-locked #sidebar{filter:blur(3px);pointer-events:none;user-select:none}
@media(max-width:760px){
  .mobile-menu-btn{display:inline-flex;position:fixed;left:14px;bottom:14px;z-index:1200;width:52px;height:52px;border-radius:18px;align-items:center;justify-content:center;background:linear-gradient(135deg,#c7954c,#9f6d27);color:#fff;border:0;box-shadow:0 18px 34px rgba(0,0,0,.26);font-size:22px}
  body{padding-bottom:72px}#sidebar{position:fixed!important;top:auto;left:0;right:0;bottom:0;width:100%!important;transform:translateY(105%);transition:transform .25s ease;border-radius:24px 24px 0 0;z-index:1100;box-shadow:0 -18px 50px rgba(0,0,0,.28)}#sidebar.mobile-open{transform:translateY(0)}#sidebar nav{display:grid!important;grid-template-columns:1fr 1fr;max-height:70vh;overflow:auto;padding:18px}.nav-item{justify-content:flex-start!important;font-size:13px!important}.logo{display:flex!important;min-height:auto}.brand-copy{display:block!important}.sidebar-footer{display:none!important}#main{padding:14px!important}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap table{min-width:760px}.modal-box{max-width:96vw!important;padding:18px!important}.auth-card{padding:22px;border-radius:22px}.btn{width:auto}.export-row{width:100%}.export-row .btn{flex:1;justify-content:center}.app-topbar{display:flex!important;border-radius:18px;padding:12px}.topbar-actions{width:100%;justify-content:flex-start}.topbar-pill{display:none}.page-title{font-size:24px}.page-sub{font-size:12px}}

/* Ajustes finais solicitados */
.topbar-actions{display:none!important}
.app-topbar{justify-content:flex-start!important}
.client-toolbar .help-text{display:none!important}
#clientes-cards.client-list-optimized{display:block!important}
#clientes-cards.client-list-optimized .client-row-lite{
  display:grid;
  grid-template-columns:1.3fr .95fr .95fr auto;
  gap:12px;
  align-items:center;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  padding:13px 14px;
  margin-bottom:8px;
  box-shadow:none!important;
  contain:content;
}
.client-row-lite:hover{background:rgba(183,130,52,.045)}
.client-row-title{font-weight:850;font-size:14px}
.client-row-sub{font-size:12px;color:var(--muted);margin-top:2px}
.client-row-actions{display:flex;gap:7px;justify-content:flex-end;flex-wrap:wrap}
.card,.form-section{box-shadow:0 8px 18px rgba(52,42,26,.045)!important}
#page-clientes .card,#page-clientes .form-section,#page-clientes .client-section,#page-clientes .client-info-card{box-shadow:none!important}
#pix-vencimento-wrap{display:flex}
.stock-percent{
  display:inline-flex;
  margin-top:4px;
  padding:2px 7px;
  border-radius:999px;
  background:rgba(183,130,52,.10);
  color:var(--accent);
  font-size:11px;
  font-weight:850;
}
@media(max-width:760px){
  #clientes-cards.client-list-optimized .client-row-lite{grid-template-columns:1fr}
  .client-row-actions{justify-content:flex-start}
}
/* Produção: login, segurança e mobile */
.auth-overlay{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(circle at 20% 0%,rgba(183,130,52,.20),transparent 34%),linear-gradient(135deg,#0d0d0e,#151515 55%,#0f0f10)}
.auth-card{width:100%;max-width:420px;background:#fff;color:#171717;border-radius:26px;padding:28px;box-shadow:0 28px 90px rgba(0,0,0,.35);border:1px solid rgba(183,130,52,.22)}
.auth-logo{width:74px;height:74px;object-fit:contain;margin:0 auto 14px;display:block}.auth-title{text-align:center;font-family:var(--font-head);font-size:23px;font-weight:850;margin-bottom:4px}.auth-sub{text-align:center;color:#706a61;font-size:13px;margin-bottom:22px}.auth-card .field{margin-bottom:12px}.auth-card input{background:#f8f5ef;color:#171717}.auth-error{display:none;margin:10px 0;color:#c93434;font-size:13px;font-weight:700}.auth-help{font-size:12px;color:#706a61;text-align:center;margin-top:14px;line-height:1.45}.auth-hidden{display:none!important}.auth-loading{opacity:.55;pointer-events:none}.topbar-user{gap:8px}.mobile-menu-btn{display:none}.logout-btn{min-height:36px;padding:7px 12px}.password-grid{display:grid;gap:12px}.app-locked #main,.app-locked #sidebar{filter:blur(3px);pointer-events:none;user-select:none}
@media(max-width:760px){
  .mobile-menu-btn{display:inline-flex;position:fixed;left:14px;bottom:14px;z-index:1200;width:52px;height:52px;border-radius:18px;align-items:center;justify-content:center;background:linear-gradient(135deg,#c7954c,#9f6d27);color:#fff;border:0;box-shadow:0 18px 34px rgba(0,0,0,.26);font-size:22px}
  body{padding-bottom:72px}#sidebar{position:fixed!important;top:auto;left:0;right:0;bottom:0;width:100%!important;transform:translateY(105%);transition:transform .25s ease;border-radius:24px 24px 0 0;z-index:1100;box-shadow:0 -18px 50px rgba(0,0,0,.28)}#sidebar.mobile-open{transform:translateY(0)}#sidebar nav{display:grid!important;grid-template-columns:1fr 1fr;max-height:70vh;overflow:auto;padding:18px}.nav-item{justify-content:flex-start!important;font-size:13px!important}.logo{display:flex!important;min-height:auto}.brand-copy{display:block!important}.sidebar-footer{display:none!important}#main{padding:14px!important}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap table{min-width:760px}.modal-box{max-width:96vw!important;padding:18px!important}.auth-card{padding:22px;border-radius:22px}.btn{width:auto}.export-row{width:100%}.export-row .btn{flex:1;justify-content:center}.app-topbar{display:flex!important;border-radius:18px;padding:12px}.topbar-actions{width:100%;justify-content:flex-start}.topbar-pill{display:none}.page-title{font-size:24px}.page-sub{font-size:12px}}

/* Correção de performance no modal de clientes */
.modal-overlay{
  backdrop-filter:none!important;
  background:rgba(0,0,0,.55)!important;
  align-items:flex-start!important;
  overflow:auto!important;
}
.modal-box{
  box-shadow:none!important;
  will-change:auto!important;
  transform:none!important;
  margin:18px auto!important;
}
#modal-body,.client-modal-wrap,.parcelas-grid-clean,.client-section{
  contain:layout paint;
}
.parcela-card-clean{
  box-shadow:none!important;
  contain:content;
  grid-template-columns:1.15fr .9fr .9fr 1.55fr!important;
}
.pedido-card-clean{
  box-shadow:none!important;
  contain:content;
}
.payment-title-line{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.payment-type-badge{
  display:inline-flex;
  align-items:center;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(183,130,52,.12);
  color:var(--accent);
  font-size:11px;
  font-weight:850;
  white-space:nowrap;
}
.payment-parcela-text{
  display:block;
  margin-top:3px;
  color:var(--muted);
  font-size:12px;
}
.fast-file-row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-top:8px;
}
@media(max-width:900px){
  .parcela-card-clean{grid-template-columns:1fr!important}
}
/* Produção: login, segurança e mobile */
.auth-overlay{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(circle at 20% 0%,rgba(183,130,52,.20),transparent 34%),linear-gradient(135deg,#0d0d0e,#151515 55%,#0f0f10)}
.auth-card{width:100%;max-width:420px;background:#fff;color:#171717;border-radius:26px;padding:28px;box-shadow:0 28px 90px rgba(0,0,0,.35);border:1px solid rgba(183,130,52,.22)}
.auth-logo{width:74px;height:74px;object-fit:contain;margin:0 auto 14px;display:block}.auth-title{text-align:center;font-family:var(--font-head);font-size:23px;font-weight:850;margin-bottom:4px}.auth-sub{text-align:center;color:#706a61;font-size:13px;margin-bottom:22px}.auth-card .field{margin-bottom:12px}.auth-card input{background:#f8f5ef;color:#171717}.auth-error{display:none;margin:10px 0;color:#c93434;font-size:13px;font-weight:700}.auth-help{font-size:12px;color:#706a61;text-align:center;margin-top:14px;line-height:1.45}.auth-hidden{display:none!important}.auth-loading{opacity:.55;pointer-events:none}.topbar-user{gap:8px}.mobile-menu-btn{display:none}.logout-btn{min-height:36px;padding:7px 12px}.password-grid{display:grid;gap:12px}.app-locked #main,.app-locked #sidebar{filter:blur(3px);pointer-events:none;user-select:none}
@media(max-width:760px){
  .mobile-menu-btn{display:inline-flex;position:fixed;left:14px;bottom:14px;z-index:1200;width:52px;height:52px;border-radius:18px;align-items:center;justify-content:center;background:linear-gradient(135deg,#c7954c,#9f6d27);color:#fff;border:0;box-shadow:0 18px 34px rgba(0,0,0,.26);font-size:22px}
  body{padding-bottom:72px}#sidebar{position:fixed!important;top:auto;left:0;right:0;bottom:0;width:100%!important;transform:translateY(105%);transition:transform .25s ease;border-radius:24px 24px 0 0;z-index:1100;box-shadow:0 -18px 50px rgba(0,0,0,.28)}#sidebar.mobile-open{transform:translateY(0)}#sidebar nav{display:grid!important;grid-template-columns:1fr 1fr;max-height:70vh;overflow:auto;padding:18px}.nav-item{justify-content:flex-start!important;font-size:13px!important}.logo{display:flex!important;min-height:auto}.brand-copy{display:block!important}.sidebar-footer{display:none!important}#main{padding:14px!important}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap table{min-width:760px}.modal-box{max-width:96vw!important;padding:18px!important}.auth-card{padding:22px;border-radius:22px}.btn{width:auto}.export-row{width:100%}.export-row .btn{flex:1;justify-content:center}.app-topbar{display:flex!important;border-radius:18px;padding:12px}.topbar-actions{width:100%;justify-content:flex-start}.topbar-pill{display:none}.page-title{font-size:24px}.page-sub{font-size:12px}}

/* Correção do modal: volta a ser janela, mas com fundo interno opaco */
.modal-overlay{
  background:rgba(0,0,0,.68)!important;
  backdrop-filter:none!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  padding:24px!important;
}
.modal-box{
  width:min(980px, calc(100vw - 48px))!important;
  max-width:980px!important;
  max-height:88vh!important;
  overflow-y:auto!important;
  margin:0!important;
  background:#e8e6e2!important;
  border:1px solid rgba(0,0,0,.16)!important;
  box-shadow:0 24px 70px rgba(0,0,0,.28)!important;
  transform:none!important;
}
[data-theme='dark'] .modal-box{
  background:#181819!important;
}
#modal-body,.client-modal-wrap,.parcelas-grid-clean,.client-section{
  contain:layout paint;
}

/* Evita bug visual nos campos numéricos críticos */
#v-parcelas-qtd,#v-frete,#v-embalagem{
  appearance:textfield;
}
#v-frete:invalid,#v-embalagem:invalid{
  border-color:var(--red)!important;
}
/* Produção: login, segurança e mobile */
.auth-overlay{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(circle at 20% 0%,rgba(183,130,52,.20),transparent 34%),linear-gradient(135deg,#0d0d0e,#151515 55%,#0f0f10)}
.auth-card{width:100%;max-width:420px;background:#fff;color:#171717;border-radius:26px;padding:28px;box-shadow:0 28px 90px rgba(0,0,0,.35);border:1px solid rgba(183,130,52,.22)}
.auth-logo{width:74px;height:74px;object-fit:contain;margin:0 auto 14px;display:block}.auth-title{text-align:center;font-family:var(--font-head);font-size:23px;font-weight:850;margin-bottom:4px}.auth-sub{text-align:center;color:#706a61;font-size:13px;margin-bottom:22px}.auth-card .field{margin-bottom:12px}.auth-card input{background:#f8f5ef;color:#171717}.auth-error{display:none;margin:10px 0;color:#c93434;font-size:13px;font-weight:700}.auth-help{font-size:12px;color:#706a61;text-align:center;margin-top:14px;line-height:1.45}.auth-hidden{display:none!important}.auth-loading{opacity:.55;pointer-events:none}.topbar-user{gap:8px}.mobile-menu-btn{display:none}.logout-btn{min-height:36px;padding:7px 12px}.password-grid{display:grid;gap:12px}.app-locked #main,.app-locked #sidebar{filter:blur(3px);pointer-events:none;user-select:none}
@media(max-width:760px){
  .mobile-menu-btn{display:inline-flex;position:fixed;left:14px;bottom:14px;z-index:1200;width:52px;height:52px;border-radius:18px;align-items:center;justify-content:center;background:linear-gradient(135deg,#c7954c,#9f6d27);color:#fff;border:0;box-shadow:0 18px 34px rgba(0,0,0,.26);font-size:22px}
  body{padding-bottom:72px}#sidebar{position:fixed!important;top:auto;left:0;right:0;bottom:0;width:100%!important;transform:translateY(105%);transition:transform .25s ease;border-radius:24px 24px 0 0;z-index:1100;box-shadow:0 -18px 50px rgba(0,0,0,.28)}#sidebar.mobile-open{transform:translateY(0)}#sidebar nav{display:grid!important;grid-template-columns:1fr 1fr;max-height:70vh;overflow:auto;padding:18px}.nav-item{justify-content:flex-start!important;font-size:13px!important}.logo{display:flex!important;min-height:auto}.brand-copy{display:block!important}.sidebar-footer{display:none!important}#main{padding:14px!important}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap table{min-width:760px}.modal-box{max-width:96vw!important;padding:18px!important}.auth-card{padding:22px;border-radius:22px}.btn{width:auto}.export-row{width:100%}.export-row .btn{flex:1;justify-content:center}.app-topbar{display:flex!important;border-radius:18px;padding:12px}.topbar-actions{width:100%;justify-content:flex-start}.topbar-pill{display:none}.page-title{font-size:24px}.page-sub{font-size:12px}}

/* Produção: menu do usuário e correção da topbar */
.topbar-actions{display:flex!important}
.app-topbar{justify-content:space-between!important}
.user-menu{position:relative;display:flex;align-items:center}
.user-menu-button{border:none;cursor:pointer;min-height:38px}
.user-menu-button::after{content:'▾';font-size:11px;margin-left:6px;color:var(--muted)}
.user-dropdown{display:none;position:absolute;right:0;top:calc(100% + 8px);min-width:150px;background:var(--surface);border:1px solid var(--border2);border-radius:14px;box-shadow:0 18px 46px rgba(0,0,0,.18);padding:8px;z-index:1500}
.user-dropdown.open{display:block}
.user-dropdown button{width:100%;border:0;background:transparent;color:var(--red);font-weight:800;text-align:left;padding:10px 12px;border-radius:10px;cursor:pointer}
.user-dropdown button:hover{background:rgba(248,113,113,.10)}
@media(max-width:720px){.topbar-actions{width:auto!important;margin-left:auto}.user-dropdown{right:0}.app-titlebar{font-size:15px}}

/* =========================================================
   v5 — Melhorias mobile, filtros e ações de PDF
   ========================================================= */
.pdf-action-box{display:flex;gap:16px;align-items:flex-start;background:var(--surface2);border:1px solid var(--border);border-radius:18px;padding:18px}.pdf-action-icon{width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,#c7954c,#9f6d27);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;letter-spacing:.5px;flex:0 0 auto}.pdf-action-box h3{font-family:var(--font-head);font-size:18px;margin-bottom:6px}.pdf-action-box p{color:var(--muted);font-size:13px;line-height:1.55}.btn-pdf{background:rgba(183,130,52,.12);border:1px solid rgba(183,130,52,.24);color:var(--accent)}

@media(min-width:901px){
  #dash-metrics.grid-4,#vendas-metrics.grid-4{grid-template-columns:repeat(5,minmax(160px,1fr));gap:14px}.filter-panel{display:grid;grid-template-columns:minmax(150px,190px) minmax(260px,1fr) auto;gap:12px;align-items:end}.filter-panel .export-row{display:flex;align-items:end;justify-content:flex-end;gap:8px;flex-wrap:wrap}.filter-panel .export-row .btn{min-width:auto}.chart-wrap{max-height:240px}.grid-2>.card .chart-wrap{height:220px!important}.subtabs{margin-bottom:18px}.subtab{min-width:0;width:auto;padding:10px 14px}.subtab-icon{width:30px;height:30px}.form-section,.card{padding:20px}.page-title{font-size:28px}.app-topbar{height:64px;margin-bottom:22px}
}

@media(max-width:760px){
  body{padding-bottom:76px!important}.mobile-menu-btn{display:inline-flex!important;position:fixed!important;left:50%!important;bottom:calc(env(safe-area-inset-bottom,0px) + 12px)!important;transform:translateX(-50%)!important;width:auto!important;min-width:112px!important;height:48px!important;border-radius:999px!important;gap:8px!important;padding:0 18px!important;font-size:17px!important;font-weight:850!important;letter-spacing:-.02em!important;z-index:2200!important}.mobile-menu-btn span{font-size:14px}.mobile-menu-btn:active{transform:translateX(-50%) scale(.97)!important}
  #sidebar{max-height:74vh!important;border-radius:28px 28px 0 0!important;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 68px)!important}#sidebar nav{grid-template-columns:1fr 1fr!important;gap:10px!important;padding:14px 18px!important;max-height:48vh!important}.nav-item{min-height:58px!important;border-radius:18px!important;padding:12px!important;font-size:14px!important}.nav-icon{width:36px!important;height:36px!important;border-radius:14px!important}.logo{padding:18px!important}.brand-logo-img{width:48px!important;height:48px!important}
  #main{padding:16px 14px 92px!important}.app-topbar{align-items:flex-start!important;gap:12px!important;padding:14px!important;margin-bottom:24px!important}.app-kicker{font-size:10px!important}.app-titlebar{font-size:17px!important;line-height:1.2!important}.topbar-user{padding:7px 9px!important;font-size:13px!important;white-space:nowrap}.topbar-user::before{width:34px!important;height:34px!important;margin-right:8px!important}.user-dropdown{right:0!important;top:44px!important}
  .page-title{font-size:31px!important;line-height:1.1!important;margin-top:4px}.page-sub{font-size:15px!important;line-height:1.45!important}.card,.form-section{border-radius:24px!important;padding:18px!important}.form-grid-3,.form-grid-2,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr!important}.filter-panel{display:grid!important;grid-template-columns:1fr!important;gap:12px!important}.filter-date-row{grid-template-columns:1fr!important}.filter-panel .export-row{display:grid!important;grid-template-columns:1fr 1fr!important;gap:8px!important;width:100%!important}.filter-panel .export-row .btn{width:100%!important;justify-content:center!important}.chart-wrap{height:190px!important}.subtabs{display:grid!important;grid-template-columns:1fr!important;gap:10px!important}.subtab{width:100%!important;min-width:0!important}.pdf-action-box{flex-direction:column}.modal-footer{display:grid!important;grid-template-columns:1fr!important}.modal-footer .btn{width:100%;justify-content:center}.table-wrap{border-radius:16px}.table-wrap table{min-width:720px!important}
}


/* v7 — fluxo mobile de salvar PDF no formato de botão único */
.pdf-save-panel{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:12px;
  padding:26px 18px;
  border-radius:22px;
  background:#eef4f7;
  border:1px solid rgba(15,23,42,.08);
}
.pdf-save-title{
  font-family:var(--font-head);
  font-size:22px;
  line-height:1.15;
  font-weight:900;
  color:#1f2937;
}
.pdf-save-subtitle{
  font-size:16px;
  color:#6b7280;
  margin-bottom:8px;
}
.pdf-save-button{
  width:100%;
  max-width:520px;
  min-height:70px;
  border:0;
  border-radius:14px;
  background:#20985b;
  color:#fff;
  font-family:var(--font-head);
  font-size:18px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  box-shadow:0 8px 18px rgba(32,152,91,.28);
  cursor:pointer;
}
.pdf-save-button:active{transform:scale(.99)}
.pdf-save-button-icon{font-size:28px;line-height:1}
.pdf-preview-link{
  margin-top:4px;
  border:0;
  background:transparent;
  color:var(--accent);
  font-weight:800;
  font-size:14px;
  cursor:pointer;
}
[data-theme='dark'] .pdf-save-panel{background:#1f2933;border-color:rgba(255,255,255,.08)}
[data-theme='dark'] .pdf-save-title{color:#f9fafb}
[data-theme='dark'] .pdf-save-subtitle{color:#cbd5e1}
@media(max-width:720px){
  .pdf-save-panel{padding:24px 14px;border-radius:20px}
  .pdf-save-title{font-size:24px}
  .pdf-save-subtitle{font-size:16px}
  .pdf-save-button{min-height:74px;font-size:18px}
}

/* =========================================================
   v8 — ajustes finos de responsividade mobile
   ========================================================= */
html,body{max-width:100%;overflow-x:hidden}*,*::before,*::after{min-width:0}img,canvas,svg,video{max-width:100%}input,select,textarea,button{max-width:100%}.field,.card,.form-section,.filter-panel,.filter-date-row{min-width:0}.page{width:100%}
@media(max-width:760px){
  #main{width:100%!important;max-width:100vw!important;overflow-x:hidden!important;padding-left:12px!important;padding-right:12px!important}
  .app-topbar{width:100%!important;display:grid!important;grid-template-columns:1fr auto!important;align-items:center!important}
  .topbar-actions{min-width:0!important}.topbar-user{max-width:168px!important;overflow:hidden!important;text-overflow:ellipsis!important}.topbar-user::after{flex:0 0 auto}
  .card,.form-section,.modal-box{width:100%!important;max-width:100%!important;overflow:hidden!important}
  .filter-panel,.form-grid,.form-grid-2,.form-grid-3,.filter-date-row{width:100%!important;max-width:100%!important;grid-template-columns:1fr!important}
  .filter-panel>*{width:100%!important;max-width:100%!important}
  input,select,textarea{width:100%!important;max-width:100%!important;min-width:0!important;font-size:16px!important}
  input[type='date'],input[type='month']{display:block!important;box-sizing:border-box!important;appearance:none;-webkit-appearance:none;padding-right:42px!important;text-align:left!important}
  .grid-2,.grid-3,.grid-4,#dash-metrics,#vendas-metrics{width:100%!important;grid-template-columns:1fr!important}
  .chart-wrap{width:100%!important;max-width:100%!important;overflow:hidden!important}.chart-wrap canvas{max-width:100%!important}
  .subtabs,.subtab{width:100%!important;max-width:100%!important}.subtab{box-sizing:border-box!important}
  .modal-overlay{padding:10px!important;align-items:flex-end!important}.modal-box{max-height:88vh!important;border-radius:24px 24px 18px 18px!important;overflow-y:auto!important}
  .pdf-action-box{display:flex!important;flex-direction:row!important;gap:14px!important;align-items:flex-start!important;padding:16px!important}.pdf-action-icon{width:52px!important;height:52px!important;flex:0 0 52px!important}.pdf-action-box h3{font-size:17px!important}.pdf-action-box p{font-size:13px!important}
  .mobile-menu-btn{bottom:calc(env(safe-area-inset-bottom,0px) + 14px)!important}
}

/* ===== v9 fix: modal do PDF no mobile acima do botão Menu ===== */
.modal-overlay{
  z-index:3000!important;
}

@media(max-width:760px){
  .modal-overlay{
    align-items:center!important;
    justify-content:center!important;
    padding:16px!important;
  }
  .modal-box{
    width:calc(100vw - 28px)!important;
    max-width:calc(100vw - 28px)!important;
    max-height:calc(100vh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 64px)!important;
    margin:0!important;
    border-radius:24px!important;
    overflow-y:auto!important;
  }
  .modal-footer{
    padding-bottom:2px!important;
  }
  body:has(.modal-overlay[style*="flex"]) .mobile-menu-btn{
    opacity:0!important;
    pointer-events:none!important;
  }
}

/* =========================================================
   v10 — Cadastro de vendas mais claro no celular
   ========================================================= */
.venda-item-row-labeled .venda-item-field label{
  display:block;
  margin-bottom:6px;
  font-size:11px;
  font-weight:800;
  color:var(--muted);
}
.venda-item-row-labeled .venda-remove-btn{
  align-self:end;
  min-height:44px;
}
#v-parcelas-qtd{
  width:100%;
  min-height:44px;
}
.parcelas-row .field label{
  font-size:12px;
  font-weight:800;
}
@media (min-width: 901px){
  .venda-item-row-labeled{
    grid-template-columns:1fr 1.25fr 90px 120px 32px;
    align-items:end;
  }
  .venda-item-row-labeled .venda-item-field label{
    display:none;
  }
}
@media (max-width: 900px){
  .modelos-builder{
    padding:14px;
    overflow:hidden;
  }
  .venda-col-heads{
    display:none!important;
  }
  .venda-item-row,
  .venda-item-row-labeled{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    padding:12px;
    margin-bottom:12px;
    border:1px solid var(--border);
    border-radius:16px;
    background:rgba(255,255,255,.38);
  }
  [data-theme='dark'] .venda-item-row,
  [data-theme='dark'] .venda-item-row-labeled{
    background:rgba(255,255,255,.04);
  }
  .venda-item-row-labeled select,
  .venda-item-row-labeled input,
  #v-parcelas-qtd{
    width:100%;
    max-width:100%;
    min-width:0;
    font-size:16px;
  }
  .venda-item-row-labeled .venda-remove-btn{
    width:100%;
    border-radius:12px;
    margin-top:2px;
  }
  #v-parcelas-qtd-wrap{
    width:100%;
  }
  #v-parcelas-list .form-grid-2{
    grid-template-columns:1fr!important;
  }
  #vendas-subpage-cadastro .form-section,
  #vendas-subpage-cadastro .calc-box{
    overflow:hidden;
  }
  #vendas-subpage-cadastro{
    padding-bottom:88px;
  }
}
