/* ============================================================
   MyMobi ERP — Painel Financeiro
   Estilos principais
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:#F4F4F0;color:#2C2C2A;font-size:14px;line-height:1.5;padding:1.5rem 1rem}
.page{max-width:1280px;margin:0 auto}

/* Header */
.hdr{background:#1F497D;color:#fff;border-radius:12px;padding:1.5rem 2rem;margin-bottom:1.25rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.hdr h1{font-size:19px;font-weight:700;margin-bottom:3px}
.hdr p{font-size:12px;opacity:.7}
.hdr-btns{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
/* Dropdown */
.dd-wrap{position:relative}
.dd-menu{display:none;position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid #D0D8E8;border-radius:8px;z-index:200;min-width:175px;box-shadow:0 6px 20px rgba(0,0,0,.2);overflow:hidden}
.dd-menu.open{display:block}
.dd-item{display:block;width:100%;text-align:left;padding:9px 14px;font-size:12px;border:none;background:none;cursor:pointer;font-family:inherit;color:#2C2C2A}
.dd-item:hover{background:#F4F4F0}
.dd-sep{border:none;border-top:1px solid #E0DDD5;margin:0}
.btn{border:none;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:700;cursor:pointer;transition:opacity .15s}
.btn:hover{opacity:.85}
.btn-green{background:#2E8B57;color:#fff}
.btn-outline{background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-ghost{background:#fff;color:#1F497D;border:1px solid #D0D8E8}
.btn-sm{padding:5px 11px;font-size:11px}
.btn-danger{background:#A32D2D;color:#fff}

/* Section label */
.slbl{display:block;font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#888780;margin:1.5rem 0 7px}

/* Health bar */
.health-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:10px;font-size:13px;font-weight:700;margin-bottom:1rem;border:2px solid}
.hb-excellent{background:#F2F9EE;color:#3B6D11;border-color:#3B6D11}
.hb-healthy{background:#EEF4FB;color:#1F497D;border-color:#1F497D}
.hb-warn{background:#FFFBF2;color:#BA7517;border-color:#BA7517}
.hb-risk{background:#FFF5F5;color:#A32D2D;border-color:#A32D2D}
.health-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:9px}
.card{background:#fff;border:1px solid #E0DDD5;border-radius:9px;padding:.8rem 1rem}
.card.hl{border-color:#1F497D;background:#EEF4FB}
.card.warn{border-color:#BA7517;background:#FFFBF2}
.card.danger{border-color:#A32D2D;background:#FFF5F5}
.card.good{border-color:#3B6D11;background:#F2F9EE}
.clbl{font-size:10px;color:#888780;margin-bottom:2px}
.cval{font-size:18px;font-weight:700;line-height:1.2}
.csub{font-size:12px;font-weight:400;color:#888780}

/* Box */
.box{background:#fff;border:1px solid #E0DDD5;border-radius:11px;padding:1.1rem 1.4rem;margin-bottom:1rem}

/* Tiers */
.tgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:1rem}
@media(max-width:560px){.tgrid{grid-template-columns:1fr 1fr}}
.tier{border-radius:8px;padding:.65rem .8rem;border:1px solid}
.trange{font-size:11px;font-weight:700;margin-bottom:1px}
.trate{font-size:16px;font-weight:700}
.tsub{font-size:11px;margin-top:2px;opacity:.72}

/* Matheus total */
.mat-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.75rem}
.mat-row label{font-size:13px;color:#5F5E5A;white-space:nowrap}
.mat-display{background:#F3EEF9;border:2px solid #C9AFEA;border-radius:8px;padding:7px 14px;font-size:16px;font-weight:700;color:#3C1A6A;min-width:130px;text-align:right}
.mat-calc{font-size:12px;color:#8A6AAF;margin-top:3px}

/* Params */
.sliders{display:grid;grid-template-columns:1fr 1fr;gap:.9rem 2rem}
@media(max-width:500px){.sliders{grid-template-columns:1fr}}
.srh{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.srl{font-size:12px;color:#5F5E5A}
.param-inp{border:2px solid #D0D8E8;border-radius:8px;background:#FAFBFE;font-size:15px;font-weight:700;color:#1F497D;width:100%;padding:7px 10px;text-align:right;outline:none}
.param-inp:focus{border-color:#2E75B6;background:#fff}

/* Goals */
.goals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}
.goal-card{background:#FAFBFE;border:1px solid #D0D8E8;border-radius:9px;padding:.8rem 1rem}
.goal-lbl{font-size:10px;color:#888780;margin-bottom:4px}
.goal-inp{width:100%;border:1.5px solid #D0D8E8;border-radius:6px;padding:5px 8px;font-size:14px;font-weight:700;color:#1F497D;background:#fff;outline:none;text-align:right}
.goal-inp:focus{border-color:#2E75B6}
.goal-bar-wrap{margin-top:5px;height:5px;background:#E0DDD5;border-radius:3px;overflow:hidden}
.goal-bar-fill{height:100%;border-radius:3px;transition:width .4s}
.goal-meta{font-size:10px;color:#888780;margin-top:3px}

/* Filter bar */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1rem;align-items:center}
.filter-bar select,.filter-bar input[type=text]{border:1px solid #D0D8E8;border-radius:7px;background:#fff;font-size:12px;color:#2C2C2A;padding:5px 9px;outline:none}
.filter-bar select:focus,.filter-bar input[type=text]:focus{border-color:#2E75B6}

/* Table */
.twrap{background:#fff;border:1px solid #E0DDD5;border-radius:11px;overflow-x:auto;margin-bottom:.5rem}
table{width:100%;border-collapse:collapse;font-size:12px}
thead tr{background:#F2F4F8}
th{text-align:right;padding:8px 6px;font-weight:600;color:#5F5E5A;font-size:11px;white-space:nowrap;border-bottom:2px solid #D8DCE8}
th:first-child{text-align:left}
td{padding:5px 5px;text-align:right;border-bottom:1px solid #F2F2F2;vertical-align:middle}
td:first-child{text-align:left}
tbody tr:hover{background:#FAFAF8}
tfoot td{font-weight:700;background:#EEF2F8;border-top:2px solid #D0D8E8;padding:7px 6px}
tfoot td:first-child{text-align:left}

/* Inline edit inputs */
.ei{border:none;border-bottom:1px solid transparent;background:transparent;font-size:12px;color:#2C2C2A;width:100%;padding:3px 4px;outline:none;border-radius:3px;min-width:55px}
.ei:hover{border-bottom-color:#D0D0D0;background:#FAFAF8}
.ei:focus{border-bottom-color:#2E75B6;background:#EEF4FB}
.ei.bold{font-weight:600;font-size:12.5px}
.ei.sub{font-size:11px;color:#888780;margin-top:1px;display:block}
.ei.center{text-align:center;min-width:50px;width:65px}
.ni{border:1px solid #E0DDD5;border-radius:6px;background:#FAFAF8;font-size:12px;font-weight:600;color:#1F497D;width:82px;padding:4px 6px;text-align:right;outline:none}
.ni:focus{border-color:#2E75B6;background:#fff}
.ni.bonus{color:#BA7517;border-color:#F5D9A8;background:#FFFBF5;width:75px}
.ni.bonus:focus{border-color:#BA7517;background:#fff}
.ni.mat-in{color:#6A329F;border-color:#C9AFEA;background:#F7F4FB;width:78px}
.ni.mat-in:focus{border-color:#6A329F;background:#fff}
.ni.pago{color:#1E6B3A;border-color:#A3D9B1;background:#F2F9EE;width:72px}
.ni.pago:focus{border-color:#1E6B3A;background:#fff}
.ni.corr-in{width:82px}
.ni.corr-in.c-auto{color:#5F5E5A;border-color:#E0DDD5;background:#FAFAF8;font-weight:500}
.ni.corr-in.c-manual{color:#BA7517;border-color:#E8A93A;background:#FFFBF5;font-weight:700}
.ni.corr-in.c-manual:focus{border-color:#BA7517;background:#fff}
.corr-hint{font-size:9px;color:#888780;margin-top:2px;text-align:right;display:block;line-height:1;white-space:nowrap}
.sel-ei{border:1px solid #E0DDD5;border-radius:5px;background:#fff;font-size:11px;color:#2C2C2A;padding:3px 5px;outline:none;max-width:100px}
.sel-ei:focus{border-color:#2E75B6}

/* Computed cells */
.cc{pointer-events:none;user-select:none}
.btrack{height:6px;border-radius:3px;background:#E0DDD5;overflow:hidden;width:46px;margin-left:auto}
.bfill{height:100%;background:#1F497D;border-radius:3px}

/* Row actions */
.row-acts{display:flex;gap:3px;justify-content:flex-end}
.rbtn{border:none;border-radius:5px;padding:3px 6px;font-size:10px;cursor:pointer;font-weight:600;line-height:1}
.rb-edit{background:#EEF4FB;color:#1F497D}
.rb-dup{background:#F2F9EE;color:#3B6D11}
.rb-del{background:#FFF5F5;color:#A32D2D}

/* Chart */
.cwrap{background:#fff;border:1px solid #E0DDD5;border-radius:11px;padding:1.1rem 1.4rem;margin-bottom:1.25rem}
.cleg{display:flex;flex-wrap:wrap;gap:8px 18px;margin-bottom:10px;font-size:11px;color:#5F5E5A}
.ldot{width:9px;height:9px;border-radius:2px;display:inline-block;margin-right:3px;vertical-align:middle}
.cc-wrap{position:relative;height:290px}

/* Operational costs table */
.cost-tbl{width:100%;border-collapse:collapse;font-size:12px}
.cost-tbl th{background:#F2F4F8;text-align:left;padding:7px 8px;font-weight:600;color:#5F5E5A;font-size:11px;border-bottom:2px solid #D8DCE8}
.cost-tbl td{padding:5px 7px;border-bottom:1px solid #F2F2F2;vertical-align:middle}
.cost-tbl tbody tr:hover{background:#FAFAF8}
.cost-tbl tfoot td{font-weight:700;background:#EEF2F8;border-top:2px solid #D0D8E8;padding:7px 8px}
.cat-badge{display:inline-block;padding:2px 6px;border-radius:8px;font-size:10px;font-weight:700}
.cat-fix{background:#DBEAFE;color:#1E40AF}
.cat-var{background:#FEF3C7;color:#92400E}
.cat-mkt{background:#EDE9FE;color:#5B21B6}
.cat-str{background:#D1FAE5;color:#065F46}

/* Two column */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:0}
@media(max-width:700px){.two-col{grid-template-columns:1fr}}

/* Rankings */
.rank-item{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid #F2F2F2;font-size:12.5px}
.rank-item:last-child{border-bottom:none}
.rank-num{background:#1F497D;color:#fff;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:700;margin-right:5px}

/* P&L rows */
.pnl-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #F2F2F2;font-size:13px}
.pnl-row:last-child{border-bottom:none;padding-top:10px;font-weight:700;font-size:14px}
.pnl-lbl{color:#5F5E5A}

/* AI Panel */
.ai-panel{background:#fff;border:2px solid #1F497D;border-radius:12px;padding:1.3rem 1.5rem;margin-bottom:1rem}
.ai-hdr{display:flex;align-items:center;gap:10px;margin-bottom:1rem}
.ai-icon{width:38px;height:38px;background:#1F497D;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ai-title{font-size:14px;font-weight:700;color:#1F497D}
.ai-sub{font-size:11px;color:#888780}
.ai-insights{display:grid;gap:8px}
.ai-ins{display:flex;gap:10px;padding:10px 12px;border-radius:8px;font-size:12px;line-height:1.55;align-items:flex-start}
.ai-ins.info{background:#EEF4FB;border-left:3px solid #1F497D}
.ai-ins.good{background:#F2F9EE;border-left:3px solid #3B6D11}
.ai-ins.warn{background:#FFFBF2;border-left:3px solid #BA7517}
.ai-ins.alert{background:#FFF5F5;border-left:3px solid #A32D2D}
.ai-ico{font-size:15px;flex-shrink:0;margin-top:1px}
.ai-ask-row{margin-top:1rem;display:flex;gap:8px}
.ai-ask-row input{flex:1;border:1px solid #D0D8E8;border-radius:8px;padding:8px 12px;font-size:13px;outline:none;font-family:inherit}
.ai-ask-row input:focus{border-color:#1F497D}
.ai-resp{margin-top:.75rem;display:none}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:14px;padding:1.5rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.modal h2{font-size:16px;font-weight:700;margin-bottom:1.2rem;color:#1F497D}
.mgrid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1.1rem}
@media(max-width:480px){.mgrid{grid-template-columns:1fr}}
.fg{display:flex;flex-direction:column;gap:4px}
.fg label{font-size:11px;font-weight:600;color:#5F5E5A;text-transform:uppercase;letter-spacing:.04em}
.fg input,.fg select,.fg textarea{border:1.5px solid #D0D8E8;border-radius:7px;padding:7px 10px;font-size:13px;color:#2C2C2A;outline:none;background:#FAFBFE;font-family:inherit}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:#2E75B6;background:#fff}
.fg textarea{resize:vertical;min-height:65px}
.modal-acts{display:flex;justify-content:flex-end;gap:8px;margin-top:1.4rem}

/* Report section */
.rep-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #F2F2F2;font-size:13px}
.rep-row:last-child{border-bottom:none;font-weight:700;font-size:13.5px;margin-top:4px}

/* CCA */
.cca-tipo{font-size:11px;border:1px solid #E0DDD5;border-radius:5px;background:#fff;padding:3px 5px;outline:none;width:100%;max-width:108px}
.cca-tipo:focus{border-color:#2E75B6}
.ni.cca-val{width:70px;margin-top:2px}
.ni.cca-val:disabled{opacity:.6;cursor:default}
/* Descontos */
.disc-btn{font-size:9px;background:#F4F4F0;color:#888780;border:1px solid #E0DDD5;border-radius:4px;padding:2px 6px;cursor:pointer;width:100%;text-align:center;margin-top:2px;font-family:inherit;display:block}
.disc-btn:hover{background:#E8E5DE}
.disc-btn.has-disc{background:#FFF5F5;color:#A32D2D;border-color:#F5C6C6}
.disc-item{display:flex;gap:6px;align-items:center;padding:6px 0;border-bottom:1px solid #F2F2F2}
.disc-item:last-child{border-bottom:none}
/* Changelog */
.cl-entry{display:flex;gap:10px;padding:5px 0;border-bottom:1px solid #F2F2F2;font-size:12px;align-items:flex-start}
.cl-entry:last-child{border-bottom:none}
.cl-ts{font-size:10px;color:#888;white-space:nowrap;min-width:115px}
.cl-badge{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;white-space:nowrap}
.cl-add{background:#D1FAE5;color:#065F46}
.cl-edit{background:#DBEAFE;color:#1E40AF}
.cl-del{background:#FEE2E2;color:#991B1B}
.cl-param{background:#FEF3C7;color:#92400E}
.cl-disc{background:#EDE9FE;color:#5B21B6}
.fnote{font-size:11px;color:#999;margin-top:1rem;padding-top:.75rem;border-top:1px solid #E8E5DE;line-height:1.5}

/* ── Toast Notifications ── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}
.toast{padding:10px 16px;border-radius:8px;font-size:12.5px;font-weight:600;color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.2);opacity:0;transform:translateY(12px) scale(.97);transition:all .25s cubic-bezier(.34,1.4,.64,1);pointer-events:none;display:flex;align-items:center;gap:8px;min-width:220px;max-width:340px}
.toast.show{opacity:1;transform:translateY(0) scale(1)}
.toast.hide{opacity:0;transform:translateY(-8px) scale(.97)}
.toast.t-success{background:#2A6010}
.toast.t-info{background:#1F497D}
.toast.t-warn{background:#8B5A00}
.toast.t-danger{background:#8B1F1F}
/* ── Auto-save badge ── */
#autosave-badge{font-size:10.5px;color:#2A6010;font-weight:700;padding:2px 9px;border-radius:10px;background:#EEF8E6;border:1px solid #B8DFA0;opacity:0;transition:opacity .35s ease;white-space:nowrap;align-self:center}
#autosave-badge.show{opacity:1}
/* ── Status row dots ── */
tr[data-status="canc"]>td:first-child{border-left:3px solid #A32D2D !important}
tr[data-status="rep_corr"]>td:first-child,tr[data-status="rep_gest"]>td:first-child{border-left:3px solid #2A6010 !important}
tr[data-status="rep_mymbi"]>td:first-child{border-left:3px solid #1F497D !important}
tr[data-status="venda"]>td:first-child,tr[data-status="form"]>td:first-child{border-left:3px solid #BA7517 !important}
tr[data-status="conf_cef"]>td:first-child,tr[data-status="conf_gar"]>td:first-child{border-left:3px solid #2E75B6 !important}
tr[data-status="minuta"]>td:first-child,tr[data-status="entrev"]>td:first-child,tr[data-status="assin"]>td:first-child,tr[data-status="itbi"]>td:first-child{border-left:3px solid #6A329F !important}

/* ── Timeline modal ── */
#tl-modal{display:none;position:fixed;inset:0;z-index:8000;background:rgba(0,0,0,.45);align-items:center;justify-content:center}
#tl-modal.open{display:flex}
#tl-box{background:#fff;border-radius:12px;width:min(580px,96vw);max-height:86vh;display:flex;flex-direction:column;box-shadow:0 8px 40px rgba(0,0,0,.22);overflow:hidden}
#tl-hdr{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid #E8E5DE;background:#F9F8F4}
#tl-hdr h3{font-size:14px;font-weight:700;color:#1F497D;margin:0}
#tl-body{overflow-y:auto;padding:14px 18px;flex:1}
.tl-entry{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid #F0EDE8;font-size:12px}
.tl-dot{width:10px;height:10px;border-radius:50%;background:#2E75B6;margin-top:3px;flex-shrink:0}
.tl-dot.tl-status{background:#6A329F}
.tl-dot.tl-create{background:#3B6D11}
.tl-dot.tl-del{background:#A32D2D}
.tl-ts{font-size:10.5px;color:#888;white-space:nowrap}
.tl-lbl{font-weight:700;color:#1F497D;min-width:90px}
.tl-chg{color:#5F5E5A;flex:1}
.tl-chg em{color:#BA7517}
.tl-chg strong{color:#3B6D11}
.tl-stg{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.tl-stg-item{font-size:11px;padding:3px 8px;border-radius:6px;background:#F0F4FA;border:1px solid #D0DCF0;color:#1F497D}
/* ── Executive snapshot modal ── */
#exec-modal{display:none;position:fixed;inset:0;z-index:8000;background:rgba(0,0,0,.45);align-items:center;justify-content:center}
#exec-modal.open{display:flex}
#exec-box{background:#fff;border-radius:12px;width:min(700px,96vw);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 40px rgba(0,0,0,.22);overflow:hidden}
#exec-hdr{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid #E8E5DE;background:#EEF4FB}
#exec-hdr h3{font-size:15px;font-weight:700;color:#1F497D;margin:0}
#exec-body{overflow-y:auto;padding:16px 20px;flex:1}
.exec-sec{font-size:10.5px;font-weight:700;color:#888780;text-transform:uppercase;letter-spacing:.05em;margin:12px 0 6px}
.exec-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid #F0EDE8;font-size:12.5px}
.exec-row span:first-child{color:#5F5E5A}
.exec-row span:last-child{font-weight:700;color:#1F497D}
.exec-scores{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:10px 0}
.exec-score-card{border-radius:8px;padding:10px 12px;text-align:center;border:1px solid #E0DDD5}
.exec-score-val{font-size:26px;font-weight:700;line-height:1}
.exec-score-lbl{font-size:10.5px;color:#5F5E5A;margin-top:4px}
/* ── Scores no health bar ── */
#score-pills{display:flex;gap:6px;flex-shrink:0}
.score-pill{font-size:11px;font-weight:700;padding:2px 9px;border-radius:10px;white-space:nowrap;border:1px solid}
/* ── Stale rows ── */
tr.row-stale>td:first-child{border-left:3px solid #BA7517 !important}
tr.row-stale>td:first-child::before{content:"⏳ ";font-size:10px;color:#BA7517}

/* ── Executive KPI Quadrants ── */
.eq-bar{display:grid;grid-template-columns:repeat(8,1fr);gap:7px;margin-bottom:1rem}
@media(max-width:1100px){.eq-bar{grid-template-columns:repeat(4,1fr)}}
@media(max-width:540px){.eq-bar{grid-template-columns:repeat(2,1fr)}}
.eq{border-radius:10px;padding:.6rem .9rem;background:#fff;border:1px solid #E0DDD5;border-top:3px solid #ccc}
.eq-blue{border-top-color:#1F497D;background:linear-gradient(160deg,#EEF4FB 0%,#fff 65%)}
.eq-orange{border-top-color:#BA7517;background:linear-gradient(160deg,#FFFBF2 0%,#fff 65%)}
.eq-purple{border-top-color:#6A329F;background:linear-gradient(160deg,#F7F0FF 0%,#fff 65%)}
.eq-green{border-top-color:#3B6D11;background:linear-gradient(160deg,#F2F9EE 0%,#fff 65%)}
.eq-lbl{font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#888780;margin-bottom:4px;line-height:1.3}
.eq-val{font-size:14px;font-weight:800;line-height:1.1;letter-spacing:-.01em}
