/* ====================================================================
   BLACKGRIP — Protótipo · design system do PRODUTO (premium / claro+grafite)
   Usa brand/tokens.css. Hierarquia, respiro, disciplina de cor.
   Regra: SANGUE = só ação primária · DOURADO = conquista · estados = verde/âmbar/aço/cinza.
   ==================================================================== */
:root{ --amber:#B8860B; --alert:var(--steel); --ok:var(--green);
        --shadow:0 1px 2px rgba(22,20,15,.03),0 8px 24px rgba(22,20,15,.05);
        --shadow-sm:0 1px 2px rgba(22,20,15,.05); }
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--paper);color:var(--ink);font-family:var(--font-body);font-size:var(--t-body);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit;text-decoration:none}
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* ---------- Sidebar (CLARA — leve, menos cansativa) ---------- */
aside{background:var(--card);color:var(--ink);border-right:1px solid var(--line-light);padding:var(--s5) var(--s4);position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:2px}
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px var(--s5);margin-bottom:var(--s3)}
.brand img{width:30px;height:30px}
.brand .t{font-family:var(--font-display);font-size:20px;letter-spacing:.5px;color:var(--ink)}
.brand .t b{color:var(--blood-light)}
.navlabel{font-family:var(--font-mono);font-size:9.5px;letter-spacing:1.5px;color:var(--faint);text-transform:uppercase;padding:var(--s5) 12px var(--s2)}
nav a{display:flex;align-items:center;gap:13px;padding:11px 12px;border-radius:8px;color:var(--muted);font-size:14px;transition:.15s}
nav a:hover{background:var(--paper);color:var(--ink)}
nav a.active{background:#fbf3f1;color:var(--blood-light);font-weight:600;box-shadow:inset 2px 0 0 var(--blood-light)}
nav a .ic{width:20px;text-align:center;font-size:16px;opacity:.8}
.side-foot{margin-top:auto;border-top:1px solid var(--line-light);padding-top:var(--s3);font-family:var(--font-mono);font-size:11px;color:var(--faint);line-height:1.6}
.side-foot .ac{color:var(--muted)}
.side-foot a.sair{display:inline-block;margin-top:8px;color:var(--muted);text-decoration:none;border:1px solid var(--line-light-2);border-radius:99px;padding:5px 11px;font-size:11px}
.side-foot a.sair:hover{background:var(--paper);color:var(--ink)}

/* ---------- Topbar ---------- */
main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:16px;padding:14px var(--s6);background:var(--card);border-bottom:1px solid var(--line-light);position:sticky;top:0;z-index:5}
.acad{display:flex;align-items:center;gap:9px;font-weight:600}
.acad .dot{width:8px;height:8px;border-radius:99px;background:var(--ok)}
.search{flex:1;max-width:340px;background:var(--paper);border:1px solid var(--line-light-2);border-radius:99px;padding:9px 15px;color:var(--muted);font-size:13px}
.top-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.pill{font-family:var(--font-mono);font-size:10px;letter-spacing:.5px;color:var(--muted);border:1px solid var(--line-light-2);padding:4px 9px;border-radius:99px;text-transform:uppercase}
.bell{position:relative;color:var(--muted);font-size:17px}
.bell .b{position:absolute;top:-5px;right:-5px;background:var(--blood-light);color:#fff;font-size:9px;border-radius:99px;padding:1px 5px;font-family:var(--font-mono)}
.avatar{width:34px;height:34px;border-radius:99px;background:var(--graphite-900);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}

/* ---------- Content / hierarquia ---------- */
.content{padding:var(--s6) var(--s6) 64px;max-width:1200px;width:100%}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:var(--s6)}
.page-head h1{font-family:var(--font-display);font-weight:400;font-size:34px;letter-spacing:.4px}
.page-head .sub{font-size:13px;color:var(--muted);margin-top:5px}
.page-head .sub b{color:var(--ink)}
.kick{font-family:var(--font-mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin:var(--s7) 0 var(--s4)}

/* ---------- Nível 1 · Health Score ---------- */
.health{display:flex;align-items:center;gap:var(--s6);background:var(--card);border:1px solid var(--line-light);border-radius:14px;padding:var(--s5) var(--s6);box-shadow:var(--shadow)}
.health .ring{width:96px;height:96px;border-radius:99px;display:grid;place-items:center;flex:none;position:relative;
  background:conic-gradient(var(--ok) calc(var(--p,82)*1%), var(--line-light) 0)}
.health .ring::after{content:"";position:absolute;inset:8px;background:var(--card);border-radius:99px}
.health .ring .sc{position:relative;font-family:var(--font-display);font-size:34px;color:var(--ok);line-height:1}
.health .ht{flex:1;min-width:200px}
.health .ht .st{font-family:var(--font-display);font-weight:400;font-size:26px;letter-spacing:.3px}
.health .ht p{color:var(--muted);font-size:14px;margin-top:4px;max-width:60ch}
.health .side{display:flex;gap:var(--s6);flex-wrap:wrap}
.health .mini .l{font-family:var(--font-mono);font-size:10px;color:var(--faint);text-transform:uppercase;letter-spacing:.5px}
.health .mini .v{font-size:20px;font-weight:600;margin-top:3px}
.health.warn .ring{--gradc:var(--amber)} .health.warn .ring{background:conic-gradient(var(--amber) calc(var(--p)*1%),var(--line-light) 0)} .health.warn .ring .sc{color:var(--amber)} .health.warn .ht .st{color:var(--ink)}

/* ---------- Nível 2 · KPIs agrupados ---------- */
.kgroup{margin-top:var(--s4)}
.kgroup .gl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.kpis{display:grid;grid-template-columns:repeat(var(--n,4),1fr);gap:var(--s4)}
.kpi{background:var(--card);border:1px solid var(--line-light);border-radius:var(--radius-card);padding:var(--s5);box-shadow:var(--shadow-sm)}
.kpi.hero{box-shadow:var(--shadow)}
.kpi .lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--faint)}
.kpi .val{font-size:26px;font-weight:600;line-height:1.1;margin:10px 0 2px;letter-spacing:-.3px;font-variant-numeric:tabular-nums}
.kpi .delta{font-size:12px;font-weight:600;display:flex;align-items:center;gap:8px}
.kpi .foot{margin-top:12px;border-top:1px solid var(--line-light);padding-top:9px;font-size:11.5px;color:var(--muted);display:flex;justify-content:space-between;gap:8px;align-items:center}
.up{color:var(--ok)} .down{color:var(--alert)} .warn{color:var(--amber)}
.sdot{width:7px;height:7px;border-radius:99px;display:inline-block;vertical-align:middle}
.s-green{background:var(--ok)} .s-amber{background:var(--amber)} .s-red{background:var(--alert)}
/* sparkline */
.spark{height:26px;width:74px;display:inline-block}
.spark polyline{fill:none;stroke:var(--steel);stroke-width:2;opacity:.7}
.spark.gd polyline{stroke:var(--ok)} .spark.bd polyline{stroke:var(--amber)}

/* ---------- Grids ---------- */
.cols-2{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--s5);align-items:start}
.cols-2b{display:grid;grid-template-columns:1fr 1fr;gap:var(--s5);align-items:start}
.stack{display:flex;flex-direction:column;gap:var(--s5)}

/* ---------- Panels ---------- */
.panel{background:var(--card);border:1px solid var(--line-light);border-radius:var(--radius-card);overflow:hidden;box-shadow:var(--shadow-sm)}
.panel h2{font-size:15px;font-weight:600;padding:var(--s4) var(--s4);border-bottom:1px solid var(--line-light);display:flex;align-items:center;justify-content:space-between;gap:10px}
.panel h2 .tag{font-family:var(--font-mono);font-size:10px;color:var(--faint);font-weight:400}
.panel .pad{padding:var(--s4)}

/* ---------- Tables ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{font-family:var(--font-mono);font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--faint);text-align:left;padding:11px var(--s4);border-bottom:1px solid var(--line-light);font-weight:500}
.tbl td{padding:13px var(--s4);border-bottom:1px solid var(--line-light)}
.tbl tr:last-child td{border-bottom:0}
.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}
.tbl .nm{font-weight:600}
.tbl tr:hover td{background:#fcfaf6}

/* ---------- Buttons (disciplina) ---------- */
.btn{background:var(--blood-light);color:#fff;border:0;border-radius:8px;padding:10px 15px;font-size:13.5px;font-weight:600;cursor:pointer;font-family:var(--font-body);white-space:nowrap}
.btn:hover{filter:brightness(1.06)}
.btn.sm{padding:7px 12px;font-size:12.5px}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line-light-2)}     /* secundário = NEUTRO */
.btn.ghost:hover{background:#f4f1ea;filter:none}
.btn.neutral{background:var(--graphite-900);color:#fff}
.btn.gold{background:var(--gold);color:#3a2c08}

/* ---------- Badges / chips ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:99px}
.b-green{background:#eef4ef;color:#236943} .b-amber{background:#fbf4e3;color:#8a6608}
.b-red{background:#eef0f3;color:#33414f} .b-blood{background:#fbf3f1;color:var(--blood-light)}
.b-gray{background:#f1efe9;color:var(--muted)} .b-gold{background:var(--gold-soft);color:var(--gold-deep)}
.chip{font-family:var(--font-mono);font-size:10px;color:var(--muted);border:1px solid var(--line-light-2);padding:4px 9px;border-radius:99px}

/* ---------- Progress / bars ---------- */
.bar{height:8px;background:var(--line-light);border-radius:99px;overflow:hidden}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--blood),var(--blood-bright))}
.bars{display:flex;align-items:flex-end;gap:10px;height:150px;padding:10px 4px 0}
.bars .c{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;height:100%;justify-content:flex-end}
.bars .c .col{width:100%;max-width:36px;background:var(--steel);border-radius:4px 4px 0 0;opacity:.8}
.bars .c .col.acc{background:linear-gradient(180deg,var(--blood-bright),var(--blood));opacity:1}
.bars .c small{font-family:var(--font-mono);font-size:10px;color:var(--faint)}

/* ---------- Nível 3 · Ações de hoje ---------- */
.todo{display:flex;align-items:center;gap:13px;padding:14px var(--s4);border-bottom:1px solid var(--line-light)}
.todo:last-child{border-bottom:0}
.todo .n{width:24px;height:24px;border-radius:99px;background:var(--graphite-900);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:700;flex:none}
.todo .tx{flex:1} .todo .tx b{font-weight:600} .todo .tx .m{font-size:12px;color:var(--muted)}

/* ---------- Risk card (CRM) ---------- */
.riskgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--s4)}
.riskcard{background:var(--card);border:1px solid var(--line-light);border-radius:var(--radius-card);padding:var(--s4);box-shadow:var(--shadow-sm)}
.riskcard .hd{display:flex;align-items:center;gap:11px;margin-bottom:11px}
.riskcard .score{margin-left:auto;font-family:var(--font-mono);font-size:11px;font-weight:700;padding:3px 8px;border-radius:99px}
.sc-hi{background:#eef0f3;color:#33414f} .sc-md{background:#fbf4e3;color:#8a6608}
.riskcard .nm{font-weight:600} .riskcard .meta{font-size:11.5px;color:var(--muted)}
.riskcard .why{font-size:12.5px;color:var(--ink);background:var(--paper);border:1px solid var(--line-light);border-radius:8px;padding:8px 10px;margin-bottom:11px}
.riskcard .why span{color:var(--muted)}
.ava{width:38px;height:38px;border-radius:99px;background:var(--paper);border:1px solid var(--line-light-2);display:grid;place-items:center;font-weight:600;font-size:13px;color:var(--muted);flex:none}

/* list rows (compat) */
.lrow{display:flex;align-items:center;gap:13px;padding:14px var(--s4);border-bottom:1px solid var(--line-light)}
.lrow:last-child{border-bottom:0}
.lrow .nm{font-weight:600} .lrow .meta{font-size:12px;color:var(--muted)}
.lrow .right{margin-left:auto;text-align:right;font-size:12px;color:var(--muted)}

/* ---------- Kanban ---------- */
.kanban{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(190px,1fr);gap:var(--s4);overflow-x:auto;padding-bottom:6px}
.kcol{background:#f4f1ea;border:1px solid var(--line-light);border-radius:var(--radius-card);padding:12px;min-height:120px}
.kcol h4{font-size:12px;display:flex;justify-content:space-between;margin-bottom:10px;color:var(--muted)}
.kcol h4 b{color:var(--ink)}
.kcard{background:var(--card);border:1px solid var(--line-light);border-radius:8px;padding:10px 11px;margin-bottom:9px;box-shadow:var(--shadow-sm)}
.kcard .kn{font-weight:600;font-size:12.5px} .kcard .km{font-size:11px;color:var(--muted);margin-top:2px}

/* ---------- Copiloto (claro, com cabeçalho de acento) ---------- */
.copilot{background:var(--card);color:var(--ink);border-radius:var(--radius-card);overflow:hidden;border:1px solid var(--line-light);box-shadow:var(--shadow-sm)}
.copilot .hd{padding:14px var(--s4);border-bottom:1px solid var(--line-light);display:flex;align-items:center;gap:9px;background:#fbf3f1}
.copilot .hd .gi{width:26px;height:26px;border-radius:99px;background:linear-gradient(135deg,var(--blood),var(--blood-bright));display:grid;place-items:center;font-size:13px;color:#fff}
.copilot .hd b{font-family:var(--font-display);font-weight:400;letter-spacing:.5px;font-size:14px;color:var(--ink)}
.copilot .body{padding:var(--s4);display:flex;flex-direction:column;gap:11px}
.msg{font-size:13.5px;line-height:1.5}
.msg.ai{color:var(--ink)}
.msg.ai b{color:var(--ink)} .msg.ai .bl{color:var(--blood-light);font-weight:600}
.copilot .ipt{display:flex;gap:8px;padding:13px var(--s4);border-top:1px solid var(--line-light)}
.copilot .ipt input{flex:1;background:var(--paper);border:1px solid var(--line-light-2);border-radius:99px;padding:10px 14px;color:var(--ink);font-family:var(--font-body)}
.copilot .ipt button{background:var(--blood-light);border:0;color:#fff;border-radius:99px;width:40px;cursor:pointer}
.copilot .solve{margin:2px var(--s4) var(--s4);width:calc(100% - var(--s6));background:var(--blood-light);color:#fff;border:0;border-radius:8px;padding:12px;font-weight:700;font-size:13.5px;cursor:pointer;font-family:var(--font-body)}
.copilot .solve:hover{filter:brightness(1.06)}

.hint{font-size:11px;color:var(--faint);margin-top:var(--s5);font-family:var(--font-mono)}
.backlink{position:fixed;left:14px;bottom:12px;font-family:var(--font-mono);font-size:11px;color:var(--muted);background:var(--card);border:1px solid var(--line-light-2);padding:7px 12px;border-radius:99px;z-index:9;box-shadow:var(--shadow-sm)}
.backlink:hover{color:var(--ink)}

/* ---------- Botão de tema (Dark/Light) ---------- */
.themetoggle{width:34px;height:34px;border-radius:99px;border:1px solid var(--line-light-2);background:transparent;color:var(--muted);display:grid;place-items:center;cursor:pointer;flex:none;transition:.15s}
.themetoggle:hover{color:var(--ink);background:var(--paper)}
.themetoggle.floating{position:fixed;top:12px;right:14px;z-index:20;background:var(--card);box-shadow:var(--shadow-sm)}

/* ---------- Responsive ---------- */
@media(max-width:1080px){ .kpis{--n:2 !important} .cols-2,.cols-2b{grid-template-columns:1fr} .health{flex-wrap:wrap} }
@media(max-width:760px){ .app{grid-template-columns:1fr} aside{position:static;height:auto;flex-direction:row;flex-wrap:wrap;gap:6px} nav{display:flex;flex-wrap:wrap;gap:4px} .navlabel,.side-foot{display:none} .kpis{--n:1 !important} }
@media(max-width:560px){ .topbar{padding:12px var(--s4)} .topbar .search,.topbar .pill{display:none} .content{padding:var(--s4) var(--s4) 48px} .page-head h1{font-size:27px} }

/* ====================================================================
   TEMA ESCURO (toggle) — redefine os tokens; o resto herda via var().
   Só sobrescreve os poucos hexes claros fixos.
   ==================================================================== */
html[data-theme="dark"]{
  --paper:#141518; --card:#1C1E22; --ink:#ECECEE; --muted:#A7AAB0; --faint:#73767D;
  --line-light:#2A2D33; --line-light-2:#363941;
  --amber:#D9A521; --alert:#8FA0B0;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.4);
  --shadow-sm:0 1px 2px rgba(0,0,0,.3);
}
html[data-theme="dark"] body{background:var(--paper);color:var(--ink)}
html[data-theme="dark"] nav a.active{background:#2a1614}
html[data-theme="dark"] .copilot .hd{background:#2a1614}
html[data-theme="dark"] .tbl tr:hover td{background:#202227}
html[data-theme="dark"] .btn.ghost:hover{background:#2a2d33}
html[data-theme="dark"] .kcol{background:#1f2126}
html[data-theme="dark"] .avatar{background:#34373e}
html[data-theme="dark"] .b-green{background:rgba(60,170,110,.16);color:#6fd49a}
html[data-theme="dark"] .b-amber{background:rgba(184,134,11,.22);color:#e6c065}
html[data-theme="dark"] .b-red{background:rgba(120,140,160,.18);color:#aebecd}
html[data-theme="dark"] .b-blood{background:#2a1614;color:var(--blood-bright)}
html[data-theme="dark"] .b-gray{background:#26282d;color:var(--muted)}
html[data-theme="dark"] .b-gold{background:rgba(200,162,75,.16);color:var(--gold)}
html[data-theme="dark"] .sc-hi{background:rgba(120,140,160,.18);color:#aebecd}
html[data-theme="dark"] .sc-md{background:rgba(184,134,11,.22);color:#e6c065}
