:root{
  --navy:#0b1220; --navy2:#131c2e; --side:#0c1426;
  --bg:#f4f6fa; --card:#fff; --borda:#e6e9f0; --borda2:#eef1f6;
  --texto:#0f1729; --muted:#6b7689; --muted2:#9aa4b5;
  --primary:#4338ca; --primary2:#6366f1;
  --green:#16a34a; --green-bg:#dcfce7; --amber:#f59e0b; --amber-bg:#fef3c7;
  --red:#ef4444; --red-bg:#fee2e2; --blue:#2563eb; --blue-bg:#dbeafe;
  --shadow:0 1px 2px rgba(11,18,32,.04),0 2px 8px rgba(11,18,32,.06);
  --shadow-lg:0 24px 60px rgba(11,18,32,.22);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter','Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--texto);font-size:14px;-webkit-font-smoothing:antialiased}
.app{display:flex;min-height:100vh}
.num{font-variant-numeric:tabular-nums}

/* Sidebar */
.sidebar{width:248px;background:var(--side);color:#aeb8c9;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:20}
.brand{padding:26px 24px 20px;border-bottom:1px solid rgba(255,255,255,.07)}
.brand img{max-height:42px;max-width:170px;display:block}
.brand-txt{font-size:24px;font-weight:900;color:#fff;letter-spacing:.5px}
.brand-sub{font-size:10.5px;color:#5b6982;text-transform:uppercase;letter-spacing:3px;margin-top:8px}
nav{padding:18px 14px;flex:1}
.nav-item{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:11px;color:#aeb8c9;text-decoration:none;cursor:pointer;font-weight:500;margin-bottom:5px;transition:.15s;font-size:14px}
.nav-item .ic{font-size:15px;width:18px;text-align:center;opacity:.8}
.nav-item:hover{background:rgba(255,255,255,.05);color:#fff}
.nav-item.active{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 6px 18px rgba(67,56,202,.4)}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:11px;font-weight:700;border-radius:999px;padding:1px 7px;min-width:20px;text-align:center}
.nav-badge:empty{display:none}
.side-foot{padding:18px 24px;border-top:1px solid rgba(255,255,255,.07);font-size:12px}
.conn{display:flex;align-items:center;gap:8px;color:#8a96ab}
.conn .dot{width:8px;height:8px;border-radius:50%;background:#5b6982}
.conn.ok .dot{background:#22c55e;box-shadow:0 0 8px #22c55e}
.conn.off .dot{background:var(--red)}
.last-sync{color:#5b6982;margin-top:6px}

/* Conteúdo */
.content{margin-left:248px;flex:1;padding:0 34px 56px}
.topbar{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 0 22px;position:sticky;top:0;background:var(--bg);z-index:10}
.topbar h1{font-size:23px;font-weight:800;letter-spacing:-.3px}
.view-sub{color:var(--muted);font-size:13px;margin-top:3px}
.top-actions{display:flex;align-items:center;gap:12px}
.btn-primary{background:var(--primary);color:#fff;border:0;padding:10px 18px;border-radius:10px;font-weight:600;cursor:pointer;font-size:13.5px;font-family:inherit}
.btn-primary:hover{background:#3730a3}.btn-primary:disabled{opacity:.6;cursor:default}
.btn-ghost{background:#fff;border:1px solid var(--borda);color:var(--texto);padding:9px 14px;border-radius:9px;font-weight:600;cursor:pointer;font-size:13px;font-family:inherit}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.chip-info{background:var(--amber-bg);color:#92400e;padding:6px 13px;border-radius:999px;font-size:12px;font-weight:600}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--card);border:1px solid var(--borda);border-radius:16px;padding:18px 20px;box-shadow:var(--shadow)}
.kpi .lbl{color:var(--muted);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.kpi .val{font-size:25px;font-weight:800;margin-top:9px;letter-spacing:-.5px}
.kpi .sub{font-size:12px;color:var(--muted);margin-top:3px}
.kpi .dotlbl{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}
.kpi.v .val{color:var(--green)}.kpi.a .val{color:var(--amber)}.kpi.r .val{color:var(--red)}

/* Grid de listas */
.lists{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:18px}
.card{background:var(--card);border:1px solid var(--borda);border-radius:16px;box-shadow:var(--shadow)}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:17px 20px;border-bottom:1px solid var(--borda2)}
.card-h h2{font-size:14px;font-weight:700}
.card-h .cnt{font-size:12px;color:var(--muted);font-weight:600;background:var(--bg);padding:2px 10px;border-radius:999px}
.card-b{padding:6px 8px}
.empty{padding:26px;text-align:center;color:var(--muted2);font-size:13px}

/* Linha de cliente */
.crow{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;cursor:pointer;transition:.12s}
.crow:hover{background:var(--bg)}
.avatar{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4338ca;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.crow .nm{font-weight:600;font-size:13.5px;line-height:1.25}
.crow .meta{font-size:11.5px;color:var(--muted);margin-top:1px}
.crow .rt{margin-left:auto;text-align:right;flex-shrink:0}
.crow .rt .big{font-weight:700;font-size:13.5px}
.crow .rt .sm{font-size:11px;color:var(--muted)}

/* Badges */
.band{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:24px;padding:0 7px;border-radius:7px;font-weight:800;font-size:12.5px;color:#fff}
.band.Aplus,.band-Ap{background:#15803d}.band.A{background:#16a34a}.band.B{background:#0891b2}
.band.C{background:#f59e0b}.band.D{background:#ea580c}.band.E{background:#dc2626}
.dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot.verde{background:var(--green)}.dot.amarelo{background:var(--amber)}.dot.vermelho{background:var(--red)}
.tag{font-size:11px;font-weight:600;padding:2px 9px;border-radius:999px}
.tag.green{background:var(--green-bg);color:#166534}.tag.amber{background:var(--amber-bg);color:#92400e}
.tag.red{background:var(--red-bg);color:#991b1b}.tag.blue{background:var(--blue-bg);color:#1e40af}
.tag.gray{background:#eef1f6;color:#516074}.tag.purple{background:#ede9fe;color:#5b21b6}
.trend.up{color:var(--green)}.trend.down{color:var(--red)}.trend.flat{color:var(--muted)}

/* Tabela carteira */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.toolbar input,.toolbar select{padding:9px 12px;border:1px solid var(--borda);border-radius:10px;font-size:13px;background:#fff;font-family:inherit}
.toolbar input{min-width:260px}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.4px;padding:11px 14px;border-bottom:1px solid var(--borda)}
td{padding:11px 14px;border-bottom:1px solid var(--borda2);font-size:13px}
tr.clickable{cursor:pointer}tr.clickable:hover{background:var(--bg)}
.right{text-align:right}
/* leitura executiva: valor R$ alinhado, % numa 2a linha discreta */
.pct{display:block;font-size:10.5px;color:var(--muted);font-weight:400;line-height:1.15;margin-top:1px;font-variant-numeric:tabular-nums}
table.exec td,table.exec th{vertical-align:top}
table.exec td.num{white-space:nowrap}
.bar{height:7px;background:#eef1f6;border-radius:999px;overflow:hidden;min-width:80px}
.bar>i{display:block;height:100%;border-radius:999px;background:var(--primary)}
.bar.v>i{background:var(--green)}.bar.a>i{background:var(--amber)}.bar.r>i{background:var(--red)}

/* Drawer Cliente 360 */
.drawer-overlay{position:fixed;inset:0;background:rgba(11,18,32,.5);backdrop-filter:blur(2px);z-index:50;display:flex;justify-content:flex-end}
.drawer{width:660px;max-width:96vw;background:var(--bg);height:100vh;overflow-y:auto;box-shadow:var(--shadow-lg);position:relative}
.drawer-close{position:absolute;top:18px;right:18px;border:0;background:rgba(255,255,255,.15);color:#fff;width:34px;height:34px;border-radius:9px;cursor:pointer;font-size:15px;z-index:2}
.d-head{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;padding:26px 28px 30px}
.d-head .nm{font-size:21px;font-weight:800;letter-spacing:-.3px}
.d-head .doc{color:#9aa6bd;font-size:13px;margin-top:4px}
.d-head .tags{display:flex;gap:7px;margin-top:12px;flex-wrap:wrap}
.score-wrap{display:flex;align-items:center;gap:22px;margin-top:22px}
.gauge{position:relative;width:120px;height:120px;flex-shrink:0}
.gauge svg{transform:rotate(-90deg)}
.gauge .gv{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.gauge .gv b{font-size:30px;font-weight:900;line-height:1}
.gauge .gv span{font-size:10px;color:#9aa6bd;text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.score-side{flex:1}
.score-side .pag{font-size:15px;font-weight:700;margin-bottom:8px}
.dpanels{padding:22px 28px;display:flex;flex-direction:column;gap:16px}
.panel{background:#fff;border:1px solid var(--borda);border-radius:14px;padding:18px 20px}
.panel h3{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:14px;font-weight:700}
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:13px 22px}
.metric .m-l{font-size:12px;color:var(--muted)}
.metric .m-v{font-size:16px;font-weight:700;margin-top:2px}
.actions{display:flex;gap:9px;flex-wrap:wrap}
.lim-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;text-align:center;margin-bottom:14px}
.lim-grid .lg-v{font-size:18px;font-weight:800}.lim-grid .lg-l{font-size:11px;color:var(--muted);margin-top:2px}
.pilar{margin-bottom:12px}
.pilar .ph{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:5px}
.pilar .ph b{font-weight:700}
.reco{border-radius:12px;padding:16px;display:flex;gap:14px;align-items:flex-start}
.reco.aumentar{background:var(--green-bg)}.reco.manter{background:var(--blue-bg)}.reco.reduzir{background:var(--red-bg)}
.reco .ri{font-size:22px}
.reco .rt2{font-weight:700;font-size:14px}.reco .rd{font-size:12.5px;color:#475569;margin-top:3px}
.reco .rv{font-size:18px;font-weight:800;margin-top:6px}
.tl-wrap{display:flex;gap:18px;align-items:flex-start}
.tl-side{width:180px;flex-shrink:0;background:var(--bg);border:1px solid var(--borda2);border-radius:12px;padding:14px 16px;position:sticky;top:8px}
.tl-leg-title{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;margin-bottom:12px}
.tl-leg-it{display:flex;align-items:center;gap:9px;font-size:12.5px;margin-bottom:10px;color:var(--texto)}
.tl-leg-it .ld{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.timeline{flex:1;position:relative;padding-left:20px;min-width:0}
@media(max-width:560px){.tl-wrap{flex-direction:column-reverse}.tl-side{width:100%}}
.tl-ev{position:relative;padding:0 0 15px 16px;border-left:2px solid var(--borda)}
.tl-ev:last-child{border-left-color:transparent}
.tl-ev::before{content:'';position:absolute;left:-6px;top:2px;width:10px;height:10px;border-radius:50%;background:var(--primary)}
.tl-ev.pagamento::before{background:var(--green)}.tl-ev.atraso::before{background:var(--amber)}
.tl-ev.pedido::before{background:var(--blue)}.tl-ev.limite::before{background:var(--primary)}.tl-ev.obs::before{background:var(--muted2)}
.tl-ev.cobranca::before{background:#e11d48}
.tl-ev.reativacao::before{background:#0d9488}
.frase{background:linear-gradient(135deg,#0d9488,#0891b2);color:#fff;border-radius:14px;padding:16px 22px;font-size:15px;font-weight:600;margin-bottom:20px;box-shadow:var(--shadow)}
.tl-ev .te-d{font-size:11px;color:var(--muted)}.tl-ev .te-t{font-size:13px;margin-top:1px}
.heat{display:flex;gap:4px;align-items:flex-end;height:60px}
.heat .hm{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:2px}
.heat .hb{border-radius:3px;min-height:3px}.heat .hb.ok{background:var(--green)}.heat .hb.late{background:var(--amber)}
.heat .hl{font-size:9px;color:var(--muted2);text-align:center;margin-top:4px}
.alert-it{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:11px;border:1px solid var(--borda2);margin-bottom:8px;cursor:pointer}
.alert-it:hover{background:var(--bg)}
.alert-it .ai{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.alert-it.danger .ai{background:var(--red-bg)}.alert-it.warn .ai{background:var(--amber-bg)}.alert-it.ok .ai{background:var(--green-bg)}
.note{background:var(--bg);border-radius:10px;padding:11px 13px;margin-bottom:8px}
.note .nh{font-size:11px;color:var(--muted);margin-bottom:3px}
.mini-input,textarea.mini-input{padding:9px 11px;border:1px solid var(--borda);border-radius:9px;font-size:13.5px;font-family:inherit;width:100%}
.muted{color:var(--muted)}.right{text-align:right}
.slider-row{display:flex;align-items:center;gap:14px;margin-bottom:13px}
.slider-row label{width:200px;font-weight:600;font-size:13px}
.slider-row input[type=range]{flex:1}
.slider-row .v{width:48px;text-align:right;font-weight:700;color:var(--primary)}
.loading{padding:50px;text-align:center;color:var(--muted)}
.modal{position:fixed;inset:0;background:rgba(11,18,32,.5);z-index:60;display:flex;align-items:center;justify-content:center}
.modal .box{background:#fff;border-radius:16px;padding:24px;width:420px;max-width:92vw;box-shadow:var(--shadow-lg)}
.modal h3{font-size:16px;font-weight:700;margin-bottom:16px}
.modal .fld{margin-bottom:13px}.modal label{font-size:12px;color:var(--muted);display:block;margin-bottom:5px}
.modal .row-btn{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.contacts{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.ct-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--borda);border-radius:9px;font-size:12.5px;font-weight:600;color:var(--texto);text-decoration:none;background:#fff;transition:.12s}
.ct-btn:hover{border-color:var(--primary);color:var(--primary)}
.ct-btn.wa{background:#25d366;color:#fff;border-color:#25d366}.ct-btn.wa:hover{background:#1eb858;color:#fff}

/* Aquisição (funil de leads) */
.rk{display:flex;align-items:center;gap:10px;padding:5px 0}
.rk-l{width:175px;flex-shrink:0;font-size:12.5px;display:flex;align-items:center;gap:7px;line-height:1.25}
.rk-n{width:34px;text-align:right;flex-shrink:0}
.rk-money{min-width:96px;text-align:right;flex-shrink:0;white-space:nowrap;font-variant-numeric:tabular-nums}
.rk-yr{display:flex;align-items:center;gap:12px;padding:7px 0}
.rk-yr .yr-l{width:60px;flex-shrink:0;font-weight:700;font-size:13px}
.rk-yr .yr-pct{width:62px;flex-shrink:0;text-align:right;font-weight:800;font-size:15px}
.rk-yr .yr-sub{width:165px;flex-shrink:0;text-align:right;font-size:11.5px;color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}
.ldot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0}
.conv{display:flex;align-items:center;justify-content:space-between;gap:6px}
.conv-step{text-align:center;flex:1}
.conv-step .cs-n{font-size:32px;font-weight:800;line-height:1}
.conv-step .cs-l{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.3}
.conv-arrow{color:var(--muted2);font-size:20px;flex-shrink:0}
.lead-st{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;white-space:nowrap}

/* Expedição — comparativo com/sem falta */
.cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cmp-box{border-radius:12px;padding:16px;text-align:center}
.cmp-box.ok{background:var(--green-bg)}.cmp-box.bad{background:var(--red-bg)}
.cmp-box .cmp-t{font-size:28px;font-weight:800;line-height:1}
.cmp-box.ok .cmp-t{color:#166534}.cmp-box.bad .cmp-t{color:#991b1b}
.cmp-box .cmp-l{font-size:12.5px;font-weight:600;margin-top:6px;color:var(--texto)}
.cmp-impact{margin-top:14px;background:var(--bg);border:1px solid var(--borda2);border-radius:10px;padding:12px 14px;font-size:13px;line-height:1.5}
#exp-mes{padding:9px 12px;border:1px solid var(--borda);border-radius:10px;font-size:13px;background:#fff;font-family:inherit;font-weight:600}
.card-note{margin:0 16px;padding:9px 12px;background:var(--amber-bg);color:#92400e;border-radius:9px;font-size:12.5px}
.aexp{border-top:3px solid var(--green)}
.aexp-list:not(.aexp-aberto) tr.aexp-hide{display:none}
.aexp-toggle{margin-top:12px;background:transparent;border:1px solid var(--borda);color:var(--primary);padding:8px 14px;border-radius:9px;font-weight:600;font-size:13px;cursor:pointer;font-family:inherit}
.aexp-toggle:hover{border-color:var(--primary);background:var(--bg)}
.sec-title{font-size:12.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:26px 0 14px}

/* Kanban de cobranças */
.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}
.kcol{background:var(--card);border:1px solid var(--borda);border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;max-height:calc(100vh - 250px)}
.kcol-h{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--borda2);font-weight:700;font-size:13px;border-radius:14px 14px 0 0;border-top:3px solid var(--borda)}
.kcol-h.a_cobrar{border-top-color:var(--red)}.kcol-h.cobrado{border-top-color:var(--amber)}.kcol-h.promessa{border-top-color:var(--blue)}
.kcol-h.cob-a_cobrar{border-top-color:var(--red)}.kcol-h.cob-em_contato{border-top-color:var(--amber)}
.kcol-h.cob-promessa{border-top-color:var(--blue)}.kcol-h.cob-acordo{border-top-color:var(--green)}
.kcol-h.cob-notificacao{border-top-color:#9a3412}.kcol-h.cob-processo{border-top-color:#7f1d1d}
.kcol-h.cob-alerta{border-top-color:var(--amber)}.kcol-h.cob-protesto{border-top-color:#b45309}
.kcol-h.cob-perdido{border-top-color:#94a3b8}
.kanban-flow{display:flex;grid-template-columns:none;overflow-x:auto;gap:14px;padding-bottom:8px}
.kanban-flow .kcol{flex:0 0 258px;min-width:258px;max-height:calc(100vh - 300px)}
/* checklist do card (modal) + progresso no mini-card */
.ckwrap{border:1px solid var(--borda2);border-radius:10px;padding:10px 12px;margin-bottom:12px;background:var(--bg)}
.ckwrap-h{font-weight:700;font-size:13px;margin-bottom:6px}
.ckgrp{border-top:1px dashed var(--borda2)}.ckgrp:first-of-type{border-top:none}
.ckgrp>summary{cursor:pointer;font-size:12.5px;font-weight:600;padding:5px 0}
.ckbody{display:flex;flex-direction:column;gap:6px;padding:2px 0 8px}
.ckitem{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:12.5px}
.ckitem .ck-l{display:flex;gap:7px;align-items:center;cursor:pointer;flex:1;min-width:170px}
.ckitem input[type=checkbox]{width:16px;height:16px;flex:none}
.kc-chk{display:flex;align-items:center;gap:6px;margin-top:5px}
.kc-chk-bar{flex:1;height:5px;background:var(--borda2);border-radius:3px;overflow:hidden}
.kc-chk-bar i{display:block;height:100%;background:var(--green)}
.kc-chk span{font-size:10.5px;color:var(--muted)}
/* modo privacidade: borra todos os valores em R$ (para prints) */
body.ocultar-valores .mny{filter:blur(7px);user-select:none;cursor:default}
#btnPriv{font-size:13px}
.kcol-h.reat-a_reativar{border-top-color:var(--amber)}.kcol-h.reat-em_contato{border-top-color:var(--blue)}
.kcol-h.reat-comprou{border-top-color:var(--green)}.kcol-h.reat-descartados{border-top-color:var(--muted2)}
.kanban4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.kanban4{grid-template-columns:repeat(2,1fr)}}
.kcol-h .cnt{background:var(--bg);color:var(--muted);border-radius:999px;padding:1px 9px;font-size:12px}
.kcol-b{padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;min-height:80px}
.kcard{background:var(--bg);border:1px solid var(--borda2);border-radius:11px;padding:12px;cursor:pointer;transition:.12s}
.kcard:hover{border-color:var(--primary);box-shadow:var(--shadow)}
.kc-top{display:flex;gap:9px;align-items:center;margin-bottom:8px}
.kc-nm{font-weight:600;font-size:13px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kc-val{font-size:13px;margin-bottom:6px}
.kc-prom{font-size:12px;color:#1e40af;background:var(--blue-bg);border-radius:7px;padding:4px 8px;margin-bottom:6px}
.kc-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11.5px}
.kc-act{margin-left:auto;color:var(--primary);font-weight:600}
@media(max-width:900px){.kanban{grid-template-columns:1fr}}

/* ===== Cockpit (cards termômetro + leitura macro + modo telão) ===== */
.cock-indice{font-size:46px;font-weight:800}
.cock-indlabel{font-size:18px;font-weight:700}
.cock-escopo{font-size:12.5px}
.cock-telao-btn{margin-left:auto;white-space:nowrap}
.cock-leitura{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 22px;border-top:1px solid var(--borda)}
.cock-leitura-dot{width:12px;height:12px;border-radius:50%;flex:none}
.cock-leitura-txt{font-size:14px;font-weight:600}
.cock-leitura-tags{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto}
.cock-tag{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.cock-grade{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.cock-card{cursor:pointer;transition:transform .12s,box-shadow .12s}
.cock-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.10)}
.cock-card-t{font-size:15px}
.cock-card-b{padding:12px 16px}
.cock-dot{width:11px;height:11px;border-radius:50%;display:inline-block}
.cock-delta{font-size:11px;font-weight:700;margin-left:6px;white-space:nowrap}
.cock-hero{margin:2px 0 10px}
.cock-hero-v{font-size:30px;font-weight:800;letter-spacing:-.5px;line-height:1.05}
.cock-hero-l{font-size:12px;color:var(--muted);margin-top:2px}
.cock-rows{display:flex;flex-direction:column;gap:2px}
.cock-row{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:8px;padding:2px 0}
.cock-row-l{font-size:12.5px;color:var(--muted)}
.cock-row-v{font-size:14.5px;text-align:right}
.cock-row-s{grid-column:1/-1;font-size:10.5px;color:var(--muted);margin-top:-2px}
.cock-insight{font-size:12px;margin-top:9px;padding:7px 10px;border-left:3px solid;border-radius:0 6px 6px 0;background:var(--bg-soft,#f6f8fb);color:var(--text)}
.cock-ver{text-align:right;color:var(--primary);font-size:12px;margin-top:8px;font-weight:600}
/* modo telão: fullscreen, fontes maiores, fundo escuro p/ a TV da sala */
.cock-telaomode{background:#0b1220;color:#e6edf6;overflow:auto;padding:26px 34px}
.cock-telaomode .card{background:#121b2e;border-color:#1e2b45;box-shadow:none}
.cock-telaomode .muted,.cock-telaomode .cock-hero-l,.cock-telaomode .cock-row-l{color:#93a4bf}
.cock-telaomode .cock-insight{background:#0e1830;color:#cbd6e8}
.cock-telaomode .cock-indice{font-size:64px}
.cock-telaomode .cock-indlabel{font-size:24px}
.cock-telaomode .cock-leitura-txt{font-size:18px}
.cock-telaomode .cock-grade{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px}
.cock-telaomode .cock-card-t{font-size:18px}
.cock-telaomode .cock-hero-v{font-size:38px}
.cock-telaomode .cock-row-l{font-size:14px}
.cock-telaomode .cock-row-v{font-size:17px}
.cock-telaomode .cock-insight{font-size:14px}
@media(max-width:900px){.cock-grade{grid-template-columns:1fr}}

/* ===== Cotação de Frete (Transporte) — cadastro de caixas ===== */
.tp-tab{background:#fff;border:1px solid var(--borda);color:var(--muted);padding:6px 14px;border-radius:999px;font-weight:600;cursor:pointer;font-size:12.5px;font-family:inherit}
.tp-tab:hover{border-color:var(--primary);color:var(--primary)}
.tp-tab.on{background:var(--primary);border-color:var(--primary);color:#fff}
.tp-tbl td{vertical-align:middle}
.tp-tbl .mini-input{padding:6px 8px;font-size:13px}
.tp-tbl tr.tp-falta{background:var(--amber-bg)}
.tp-tbl tr.tp-edit{background:var(--blue-bg)}
.tp-save{padding:5px 12px !important;font-size:12px !important;border-radius:7px !important}
.tp-tbl tr.tp-edit .tp-save{background:var(--primary);border-color:var(--primary);color:#fff}
.tp-tbl tr.tp-oculto{opacity:.7}
.tp-hide{background:none;border:none;color:var(--muted);cursor:pointer;font-size:11.5px;font-family:inherit;text-decoration:underline;padding:2px 4px}
.tp-hide:hover{color:var(--red)}
/* modo cotação */
.tp-modes{display:flex;gap:8px;margin-bottom:14px}
.tp-mode{background:#fff;border:1px solid var(--borda);color:var(--muted);padding:8px 16px;border-radius:10px;font-weight:700;cursor:pointer;font-size:13px;font-family:inherit}
.tp-mode:hover{border-color:var(--primary);color:var(--primary)}
.tp-mode.on{background:var(--primary);border-color:var(--primary);color:#fff}
.tp-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.tp-field{border:1px solid var(--borda);border-radius:10px;padding:10px 12px}
.tp-field-l{font-size:11.5px;color:var(--muted);font-weight:600}
.tp-field-v{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:4px}
.tp-field-v .num{font-size:18px;font-weight:800}
.tp-copy{background:var(--primary);border:none;color:#fff;border-radius:7px;padding:4px 10px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit}
.tp-copy.ok{background:var(--green)}
.tp-cx td{vertical-align:middle}
.tp-cell{display:inline-block;min-width:46px;padding:4px 10px;background:var(--blue-bg);color:#1e40af;border-radius:6px;font-weight:700;cursor:pointer}
.tp-cell:hover{outline:2px solid var(--primary)}
.tp-cell.ok{background:var(--green-bg);color:#166534}
.tp-est{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}
.tp-est>div{padding:8px 10px;border-radius:8px;background:var(--bg)}
.tp-est .muted{font-size:11px}.tp-est .num{font-size:17px;font-weight:800}
.tp-est-hi{background:var(--green-bg) !important}
.tp-alert{padding:10px 12px;border-radius:9px;font-size:12.5px}
.tp-alert.amber{background:var(--amber-bg);color:#92400e}
.tp-alert.gray{background:#eef1f6;color:#516074}
.tp-alert a{color:var(--primary);font-weight:700;cursor:pointer;text-decoration:underline}
.hist-emp{background:var(--card);border:1px solid var(--borda);border-radius:12px;margin-bottom:10px;box-shadow:var(--shadow)}
.hist-emp>summary{cursor:pointer;padding:12px 16px;font-size:13.5px;list-style:none}
.hist-emp>summary::-webkit-details-marker{display:none}
.hist-emp[open]>summary{border-bottom:1px solid var(--borda2)}
.hist-emp .exec{margin:0}
/* ===== Aquisição · kanban do funil ===== */
.aq-coldesc{padding:6px 14px 4px;font-size:11px;color:var(--muted);line-height:1.35;border-bottom:1px solid var(--borda2);display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.aq-rel{font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;white-space:nowrap}
.aq-card-t{margin-top:7px;font-size:11px;font-weight:600}
.aq-attrs{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.aq-attr{font-size:10px;font-weight:600;background:var(--bg);color:var(--ink);border:1px solid var(--borda2);border-radius:6px;padding:2px 7px}
.aq-noimg{font-size:10px;font-weight:600;color:#92400e;background:var(--amber-bg);border-radius:6px;padding:2px 7px}
.aq-badge-al{font-size:10px;font-weight:800;color:#fff;background:var(--red);border-radius:6px;padding:1px 6px;white-space:nowrap}
.kcard.aq-alerta{border-color:var(--red);box-shadow:0 0 0 1px var(--red) inset}
.aq-colalert{font-size:11px;font-weight:800;color:#fff;background:var(--red);border-radius:999px;padding:1px 8px;margin-right:6px}
.aq-det-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}
.aq-det-sec{margin-top:14px;border-top:1px solid var(--borda2);padding-top:10px}
.aq-det-h{font-weight:700;font-size:13px;margin-bottom:6px}
.aq-chk{display:flex;align-items:center;gap:7px;font-size:13px;margin:3px 0;color:var(--muted)}
.aq-img-ph{border:1px dashed var(--borda);border-radius:10px;padding:18px;text-align:center;font-size:12.5px;color:var(--ink);background:var(--bg)}
.aq-tl{display:flex;align-items:center;gap:10px;padding:7px 0;border-left:2px solid var(--borda2);margin-left:5px;padding-left:14px;position:relative}
.aq-tl-dot{position:absolute;left:-6px;width:10px;height:10px;border-radius:50%;border:2px solid var(--card)}
.aq-tl-now{background:var(--bg);border-radius:0 8px 8px 0}
.aq-tl-body{flex:1}
.aq-tl-st{font-size:13px;font-weight:600}
.aq-tl-d{flex:none;font-weight:800;font-size:13px}
/* ===== Treinamentos (vídeos Vimeo) ===== */
.treino-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px}
.treino-folders{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.treino-folder{cursor:pointer;padding:18px 16px;transition:transform .12s,box-shadow .12s}
.treino-folder:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.10)}
.tf-ic{font-size:30px;line-height:1}
.tf-nm{font-weight:700;font-size:15px;margin:8px 0 2px}
.vimeo-wrap{position:relative;width:100%;padding-bottom:56.25%;height:0;border-radius:10px;overflow:hidden;background:#000}
.vimeo-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
/* linha do tempo do score de mercado */
.sc-tl{display:flex;align-items:center;gap:10px;padding:5px 0;border-bottom:1px solid var(--borda2);font-size:13px}
.sc-tl:last-child{border-bottom:0}
.sc-tl-d{font-size:11.5px;color:var(--muted);min-width:74px}
.sc-tl .num{font-size:15px;font-weight:800;min-width:42px}
