:root{
  --azul:#0A4B8D;--azul2:#1565C0;--laranja:#F87A13;
  --bg:#F4F6F9;--white:#fff;
  --sidebar-w:220px;--header-h:60px;
  --gray:#6B7280;--border:#E5E7EB;
  --red:#DC2626;--green:#16A34A;--yellow:#D97706;
  --font:'DM Sans',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font);background:var(--bg);color:#1a1a2e;font-size:14px;}

/* ── LOGIN ── */
#erp-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0A4B8D 0%,#1565C0 100%);}
.login-box{background:#fff;border-radius:16px;padding:44px;width:390px;box-shadow:0 20px 60px rgba(0,0,0,.28);}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px;}
.login-tag{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--azul);background:#EBF4FF;padding:3px 10px;border-radius:20px;}
.login-box h2{font-size:20px;font-weight:700;color:var(--azul);margin-bottom:22px;}
.erro-msg{display:none;background:#FEE2E2;border:1px solid #FECACA;color:#DC2626;padding:9px 12px;border-radius:8px;font-size:13px;margin-bottom:14px;}
.fg{margin-bottom:14px;}
.fg label{display:block;font-size:11.5px;font-weight:700;color:#4B5563;margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px;}
.fg input,.fg select,.fg textarea{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13.5px;font-family:var(--font);outline:none;transition:border-color .15s;background:#fff;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--azul);}
.fg textarea{min-height:80px;resize:vertical;}
.btn-login-main{width:100%;background:var(--azul);color:#fff;border:none;padding:12px;border-radius:9px;font-size:15px;font-weight:700;cursor:pointer;margin-top:6px;font-family:var(--font);transition:background .2s;}
.btn-login-main:hover{background:var(--azul2);}
.btn-login-main:disabled{opacity:.6;cursor:default;}

/* ── APP ── */
#erp-app{display:flex;flex-direction:column;height:100vh;}
.erp-header{background:var(--azul);height:var(--header-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;box-shadow:0 2px 12px rgba(0,0,0,.15);z-index:100;}
.header-left{display:flex;align-items:center;gap:12px;}
.erp-tag{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.6);background:rgba(255,255,255,.13);padding:3px 10px;border-radius:20px;}
.header-right{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.9);font-size:13.5px;}
.btn-sair{background:rgba(255,255,255,.13);border:none;color:#fff;padding:7px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-family:var(--font);display:flex;align-items:center;gap:6px;transition:background .2s;}
.btn-sair:hover{background:rgba(255,255,255,.24);}

/* ── LAYOUT ── */
.erp-body{flex:1;min-height:0;display:flex;overflow:hidden;}
.erp-sidebar{width:var(--sidebar-w);flex-shrink:0;background:#fff;border-right:1px solid var(--border);overflow-y:auto;padding:12px 0;}
.sidebar-section{font-size:10px;font-weight:700;color:#9CA3AF;letter-spacing:1.5px;text-transform:uppercase;padding:14px 20px 6px;}
.nav-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;padding:11px 20px;font-size:13.5px;font-family:var(--font);color:#4A5568;cursor:pointer;text-align:left;transition:all .15s;border-right:3px solid transparent;}
.nav-item i{font-size:17px;}
.nav-item:hover{background:#F5F7FA;color:var(--azul);}
.nav-item.active{background:#EBF4FF;color:var(--azul);font-weight:600;border-right-color:var(--azul);}
.nav-item .nav-label{flex:1;}
.nav-badge{display:none;align-items:center;justify-content:center;background:#DC2626;color:#fff;font-size:10px;font-weight:700;border-radius:20px;min-width:18px;height:18px;padding:0 5px;line-height:1;}
.erp-content{flex:1;overflow-y:auto;padding:28px 32px;}

/* ── VIEWS ── */
.erp-view{display:none;}
.erp-view.active{display:block;}
.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;}
.view-header h1{font-size:20px;font-weight:700;color:var(--azul);display:flex;align-items:center;gap:10px;}
.view-header h1 i{font-size:22px;}

/* ── BOTÕES ── */
.btn-primary{background:var(--azul);color:#fff;border:none;padding:9px 18px;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px;font-family:var(--font);transition:background .2s;}
.btn-primary:hover{background:var(--azul2);}
.btn-primary:disabled{opacity:.6;cursor:default;}
.btn-secondary{background:#fff;color:var(--azul);border:1.5px solid var(--border);padding:9px 18px;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px;font-family:var(--font);transition:all .2s;}
.btn-secondary:hover{border-color:var(--azul);background:#EBF4FF;}
.btn-danger{background:#FEF2F2;color:#DC2626;border:1.5px solid #FECACA;padding:9px 18px;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px;font-family:var(--font);transition:all .2s;}
.btn-danger:hover{background:#FEE2E2;}
.btn-danger:disabled{opacity:.6;cursor:default;}
.btn-icon{background:none;border:none;cursor:pointer;padding:5px 8px;border-radius:6px;color:#9CA3AF;font-size:16px;transition:all .15s;}
.btn-icon:hover{background:#F3F4F6;color:var(--azul);}

/* ── TABELA ── */
.table-wrap{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden;}
.erp-table{width:100%;border-collapse:collapse;}
.erp-table th{background:#F9FAFB;padding:11px 14px;text-align:left;font-size:11.5px;font-weight:700;color:#6B7280;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border);white-space:nowrap;}
.erp-table td{padding:10px 14px;border-bottom:1px solid #F3F4F6;font-size:13.5px;vertical-align:middle;}
.erp-table tr:last-child td{border-bottom:none;}
.erp-table tr:hover td{background:#FAFBFF;}
.tbl-empty,.tbl-loading{padding:52px 24px;text-align:center;color:#9CA3AF;font-size:14px;}

/* ── BADGES ── */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;}
.badge-ok{background:#DCFCE7;color:#166534;}
.badge-low{background:#FEF3C7;color:#92400E;}
.badge-critical{background:#FEE2E2;color:#991B1B;}
.badge-inactive{background:#F3F4F6;color:#6B7280;}
.stock-critical{color:#DC2626;font-weight:800;}
.margem-pos{color:var(--green);font-weight:600;}
.margem-neg{color:var(--red);font-weight:600;}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:999;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal-box{background:#fff;border-radius:14px;width:580px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.22);}
.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.modal-header h2{font-size:17px;font-weight:700;color:var(--azul);}
.modal-close{background:none;border:none;font-size:18px;cursor:pointer;color:#9CA3AF;padding:4px 8px;border-radius:6px;line-height:1;}
.modal-close:hover{background:#F3F4F6;color:#374151;}
.modal-body{padding:20px 24px;overflow-y:auto;flex:1;}
.modal-body .fg{margin-bottom:14px;}
.modal-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.modal-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0;}
.fg-check{display:flex;align-items:center;gap:8px;margin-bottom:14px;}
.fg-check label{font-size:13.5px;color:#374151;cursor:pointer;}
.fg-check input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--azul);}

/* ── ALERTAS ── */
.alert-card{background:#fff;border:1.5px solid #FECACA;border-radius:10px;padding:16px 20px;margin-bottom:10px;display:flex;align-items:center;gap:16px;transition:box-shadow .15s;}
.alert-card:hover{box-shadow:0 4px 16px rgba(220,38,38,.1);}
.alert-card>.ti{font-size:24px;color:#DC2626;flex-shrink:0;}
.alert-info{flex:1;min-width:0;}
.alert-info strong{display:block;font-size:14px;font-weight:700;color:#1a1a2e;margin-bottom:2px;}
.alert-info span{display:block;font-size:12.5px;color:#6B7280;}
.alert-stock{text-align:right;flex-shrink:0;}
.alert-stock .num{font-size:24px;font-weight:800;color:#DC2626;line-height:1;}
.alert-stock .lbl{font-size:11px;color:#9CA3AF;text-transform:uppercase;letter-spacing:.3px;}
.alert-ok{background:#F0FDF4;border:1.5px solid #BBF7D0;border-radius:12px;padding:40px;text-align:center;color:#166534;font-weight:600;font-size:15px;}
.alert-ok i{font-size:36px;display:block;margin-bottom:10px;}

/* ── BADGES PLANO ── */
.badge-ouro{background:#FEF9C3;color:#854D0E;border:1px solid #FCD34D;}
.badge-prata{background:#F3F4F6;color:#374151;border:1px solid #9CA3AF;}
.badge-bronze{background:#FEF3C7;color:#7C2D12;border:1px solid #D97706;}
.badge-ativo{background:#DCFCE7;color:#166534;}
.badge-encerrado{background:#F3F4F6;color:#6B7280;}
.badge-cancelado{background:#FEE2E2;color:#991B1B;}
.badge-renovacao{background:#EEF2FF;color:#3730A3;}
.badge-pago{background:#DCFCE7;color:#166534;}
.badge-pendente{background:#FEF3C7;color:#92400E;}
.badge-atrasado{background:#FEE2E2;color:#991B1B;}
.row-vencendo td{background:#FFFBEB !important;}
.row-atrasado td{background:#FEF2F2 !important;}

/* ── DASHBOARD FINANCEIRO ── */
.fin-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.fin-card{background:#fff;border-radius:12px;border:1px solid var(--border);padding:20px;}
.fin-card .fc-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#9CA3AF;margin-bottom:8px;}
.fin-card .fc-value{font-size:24px;font-weight:800;color:#1a1a2e;line-height:1;}
.fin-card .fc-value.green{color:#16A34A;}
.fin-card .fc-value.red{color:#DC2626;}
.fin-card .fc-value.orange{color:#D97706;}
.fin-card .fc-sub{font-size:12px;color:#9CA3AF;margin-top:6px;}

/* ── BAR CHART ── */
.bar-chart-wrap{background:#fff;border-radius:12px;border:1px solid var(--border);padding:20px 24px;margin-bottom:28px;}
.bar-chart-title{font-size:14px;font-weight:700;color:var(--azul);margin-bottom:20px;}
.bar-chart{display:flex;align-items:flex-end;gap:10px;height:130px;}
.bar-group{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0;}
.bar-group .bars{display:flex;gap:3px;align-items:flex-end;height:100px;width:100%;}
.bar{border-radius:3px 3px 0 0;flex:1;transition:opacity .2s;cursor:default;}
.bar:hover{opacity:.75;}
.bar.receita{background:var(--azul);}
.bar.despesa{background:var(--laranja);}
.bar-lbl{font-size:10px;color:#9CA3AF;margin-top:6px;text-align:center;white-space:nowrap;}
.bar-legend{display:flex;gap:16px;margin-top:14px;font-size:12px;color:#6B7280;}
.bar-legend span{display:flex;align-items:center;gap:6px;}
.bar-legend i{width:10px;height:10px;border-radius:2px;display:inline-block;}
.bar-legend i.rec{background:var(--azul);}
.bar-legend i.des{background:var(--laranja);}

/* ── FILTROS ── */
.view-filters{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;align-items:center;}
.view-filters select,.view-filters input[type=month]{padding:8px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--font);outline:none;background:#fff;}
.view-filters select:focus,.view-filters input:focus{border-color:var(--azul);}

/* ── FLUXO DE CAIXA ── */
.fluxo-table td.pos{color:#16A34A;font-weight:700;}
.fluxo-table td.neg{color:#DC2626;font-weight:700;}
.fluxo-table tr.acum-row td{background:#F0F4FA;font-weight:700;border-top:2px solid var(--border);}

/* ── KANBAN ── */
.kanban-wrap{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;align-items:flex-start;}
.kanban-col{min-width:190px;flex:1;background:#F4F6F9;border-radius:10px;padding:12px;}
.kanban-col-hdr{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#6B7280;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;}
.kanban-col-cnt{background:#E5E7EB;color:#6B7280;font-size:10px;font-weight:700;border-radius:20px;padding:1px 7px;}
.kanban-card{background:#fff;border-radius:8px;padding:12px;margin-bottom:8px;border:1px solid var(--border);cursor:pointer;transition:box-shadow .15s;border-left:3px solid #9CA3AF;}
.kanban-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.1);}
.kanban-card.s-novo{border-left-color:#0A4B8D;}
.kanban-card.s-em_contato{border-left-color:#0284C7;}
.kanban-card.s-proposta_enviada{border-left-color:#7C3AED;}
.kanban-card.s-negociacao{border-left-color:#D97706;}
.kanban-card.s-ganho{border-left-color:#16A34A;}
.kanban-card.s-perdido{border-left-color:#DC2626;}
.kanban-card.s-inativo{border-left-color:#9CA3AF;}
.kc-empresa{font-weight:700;font-size:13px;color:#1a1a2e;margin-bottom:3px;}
.kc-contato{font-size:12px;color:#6B7280;margin-bottom:4px;}
.kc-tel{font-size:12px;color:var(--azul);}
.kc-prox{font-size:11px;margin-top:8px;padding-top:6px;border-top:1px solid #F3F4F6;color:#6B7280;}
.kc-prox.vencido{color:#DC2626;font-weight:600;}

/* ── INTERAÇÕES ── */
.int-list{list-style:none;padding:0;}
.int-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid #F3F4F6;}
.int-item:last-child{border-bottom:none;}
.int-ico{width:32px;height:32px;border-radius:50%;background:#EBF4FF;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--azul);font-size:15px;}
.int-body{flex:1;min-width:0;}
.int-meta{display:flex;justify-content:space-between;margin-bottom:3px;}
.int-tipo{font-size:11.5px;font-weight:700;color:var(--azul);text-transform:capitalize;}
.int-data{font-size:11.5px;color:#9CA3AF;}
.int-desc{font-size:13px;color:#374151;margin-bottom:3px;}
.int-reacao{font-size:11px;}
.reacao-positiva{color:#16A34A;font-weight:600;}
.reacao-negativa{color:#DC2626;font-weight:600;}
.reacao-neutra{color:#D97706;font-weight:600;}
.modal-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}
.modal-section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.modal-section-hdr span{font-size:13px;font-weight:700;color:var(--azul);}

/* ── RESPONSIVO ── */
@media(max-width:768px){
  .erp-sidebar{width:60px;}
  .nav-item span{display:none;}
  .erp-content{padding:16px;}
  .modal-grid-2{grid-template-columns:1fr;}
  .fin-cards{grid-template-columns:1fr 1fr;}
  .kanban-wrap{flex-direction:column;}
  .kanban-col{min-width:unset;}
}
