/* ============================================================
   Wobe — Design System compartilhado (sidebar + bento)
   Paleta oficial Wobe. Usado por todas as telas do mini-ERP.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,600;0,700;0,800;1,800&family=Nunito+Sans:opsz,wght@6..12,400;6..12,600;6..12,700&display=swap');

:root{
  --marrom:#4a1811; --marrom2:#5e3326; --creme:#fff8d6;
  --ambar:#ffab00; --laranja:#ef7d00; --vermelho:#d10000; --azul:#003fbd; --ciano:#00d3d3; --verde:#1f7a3d;
  --bg:#fbf6e4; --panel:#fffef8; --panel2:#f4ebcb; --line:#e7d9a8; --txt:#4a1811; --muted:#9a7b4e;
  --radius:14px; --radius-sm:10px;
  --shadow:0 1px 3px rgba(74,24,17,.07),0 1px 2px rgba(74,24,17,.04);
  --shadow-lg:0 6px 20px rgba(74,24,17,.10);
  --title:"Poppins","Segoe UI",sans-serif; --body:"Nunito Sans","Segoe UI",system-ui,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);font-family:var(--body);font-size:14px;line-height:1.45}
a{color:inherit;text-decoration:none}

/* ---- shell: sidebar + main ---- */
.app{display:flex;min-height:100vh;visibility:hidden}
body.authed .app{visibility:visible}
.sidebar{width:212px;flex-shrink:0;background:var(--marrom);color:var(--creme);
  padding:18px 12px;position:sticky;top:0;height:100vh;overflow-y:auto}
.side-wm{font-family:var(--title);font-weight:800;font-style:italic;font-size:25px;letter-spacing:-1px;margin:2px 8px 4px}
.side-wm sup{font-size:11px;font-style:normal;opacity:.7;margin-left:2px}
.side-logo{display:block;width:128px;margin:4px 8px 2px}
.side-tag{font-size:10.5px;color:#c9a86a;margin:0 8px 16px}
.side-grp{font-size:10px;letter-spacing:.9px;color:#c9a86a;text-transform:uppercase;margin:15px 8px 6px;font-weight:700}
.side-it{display:flex;align-items:center;gap:10px;padding:8px 11px;border-radius:9px;font-size:13px;color:#f3e4c0;margin-bottom:2px;transition:.12s}
.side-it:hover{background:#5e3326}
.side-it.on{background:var(--laranja);color:#fff;font-weight:700}
.side-it i{font-size:17px;width:17px;text-align:center}
.main{flex:1;min-width:0;padding:22px 26px 60px}

/* ---- topbar ---- */
.topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.topbar h1{font-family:var(--title);font-size:21px;font-weight:800;margin:0;letter-spacing:-.3px}
.topbar .sub{font-size:12.5px;color:var(--muted);margin-top:3px}
.topbar .actions{display:flex;gap:8px;align-items:center}

/* ---- bento grid (12 colunas) ---- */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.c2{grid-column:span 2}.c3{grid-column:span 3}.c4{grid-column:span 4}.c5{grid-column:span 5}
.c6{grid-column:span 6}.c7{grid-column:span 7}.c8{grid-column:span 8}.c9{grid-column:span 9}.c12{grid-column:span 12}
.r2{grid-row:span 2}
@media(max-width:980px){.bento>[class*="c"]{grid-column:span 6}}
@media(max-width:640px){.bento>[class*="c"]{grid-column:span 12}.sidebar{width:64px}.side-wm{font-size:18px}.side-logo{width:40px}.side-tag,.side-grp,.side-it span{display:none}.side-it{justify-content:center}}

/* ---- cards ---- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.card.dark{background:var(--marrom);color:var(--creme);border-color:var(--marrom)}
.card.dark .sec-h,.card.dark .l{color:#e8d6a8}
.sec-h{font-family:var(--title);font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--marrom);font-weight:700;margin:0 0 12px;opacity:.85}

/* ---- kpi ---- */
.kpi .v{font-family:var(--title);font-size:23px;font-weight:800;letter-spacing:-.5px}
.kpi .l{font-size:11.5px;color:var(--muted);margin-top:4px}
.kpi .h{font-size:11px;color:var(--laranja);margin-top:6px;font-weight:600}
.kpi.acc{background:var(--marrom);color:var(--creme);border-color:var(--marrom)}
.kpi.acc .l{color:#e8d6a8}.kpi.acc .h{color:var(--ambar)}
.kpi.good .v{color:var(--verde)}.kpi.bad .v{color:var(--vermelho)}

/* ---- tabela ---- */
table{width:100%;border-collapse:collapse;font-size:12.5px}
th,td{padding:8px 10px;text-align:right;border-bottom:1px solid var(--line)}
th:first-child,td:first-child{text-align:left}
th{color:var(--muted);font-weight:700;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px}
td.num{font-variant-numeric:tabular-nums}
tbody tr:hover td{background:var(--panel2)}
tfoot td{font-weight:800;border-top:2px solid var(--line);border-bottom:none;font-family:var(--title)}

/* ---- charts ---- */
.bars{display:flex;align-items:flex-end;gap:5px;height:140px}
.bars .col{flex:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:4px}
.bars .bx{width:72%;min-height:3px;border-radius:4px 4px 0 0;background:linear-gradient(180deg,var(--ambar),var(--laranja))}
.bars .ml{font-size:8.5px;color:var(--muted)}
.hbar{height:15px;border-radius:5px;background:var(--laranja)}
.track{background:var(--panel2);border-radius:5px;height:15px;overflow:hidden}

/* ---- bits ---- */
.pos{color:var(--verde);font-weight:700}.neg{color:var(--vermelho);font-weight:700}.muted{color:var(--muted)}
.pill{display:inline-block;padding:1px 9px;border-radius:20px;font-size:10.5px;font-weight:700}
.p-ok{background:#e6f3e8;color:#1f7a3d}.p-amb{background:#fff0cc;color:#8a5a00}.p-red{background:#fdeaea;color:#9a0000}.p-info{background:#e8eefc;color:#1c3f9a}
.chip{background:var(--panel2);border:1px solid var(--line);color:var(--marrom);padding:5px 12px;border-radius:20px;cursor:pointer;font-size:12.5px;user-select:none}
.chip.on{background:var(--marrom);border-color:var(--marrom);color:var(--creme);font-weight:700}
.btn{background:var(--panel);border:1px solid var(--line);color:var(--marrom);border-radius:9px;padding:7px 12px;font-size:12.5px;cursor:pointer;font-family:var(--body)}
.btn.pri{background:var(--marrom);color:var(--creme);border-color:var(--marrom);font-weight:700}
input,select{font-family:var(--body);font-size:13px;border:1px solid var(--line);border-radius:9px;padding:8px 10px;background:var(--panel);color:var(--marrom)}
.note{font-size:11.5px;color:var(--muted);margin-top:10px}
.err{background:#fdeaea;border:1px solid var(--vermelho);padding:20px;border-radius:var(--radius);color:#8a0000}

/* ============================================================
   Shell overrides — encaixa as telas legadas no novo layout
   (sidebar + conteúdo). As telas mantêm o markup; aqui só reskin.
   ============================================================ */
.app>.wrap{flex:1;min-width:0;max-width:none;margin:0;padding:22px 26px 60px}
.brand{display:flex!important;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:12px;
  background:none!important;color:var(--txt)!important;margin:0 0 18px!important;padding:0!important;border-radius:0!important;box-shadow:none!important}
.brand .wordmark{display:none!important}
.brand .ttl{text-align:left!important}
.brand .ttl h1{font-family:var(--title);font-size:21px;font-weight:800;color:var(--txt)!important;margin:0}
.brand .ttl .sub{font-size:12.5px;color:var(--muted)!important;opacity:1!important;margin-top:3px}
.nav{display:none!important}
h2{font-family:var(--title);font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--marrom);margin:0 0 12px;font-weight:700;opacity:.85}

/* ---- classes legadas usadas pelas telas ---- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.kpi.accent{background:var(--marrom);color:var(--creme);border-color:var(--marrom)}
.kpi.accent .l{color:#e8d6a8}.kpi.accent .h{color:var(--ambar)}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:20px;box-shadow:var(--shadow)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid{display:grid;grid-template-columns:300px 1fr;gap:20px}
@media(max-width:820px){.kpis{grid-template-columns:repeat(2,1fr)}.grid2,.grid{grid-template-columns:1fr}}

/* faturamento — barras mensais */
.months{display:flex;align-items:flex-end;gap:4px;height:200px;padding-top:10px;overflow-x:auto}
.mb{flex:1;min-width:18px;display:flex;flex-direction:column;align-items:center;gap:5px;justify-content:flex-end;height:100%}
.mb .bar{width:72%;background:linear-gradient(180deg,var(--ambar),var(--laranja));border-radius:4px 4px 0 0;min-height:2px}
.mb:hover .bar{background:linear-gradient(180deg,var(--laranja),var(--vermelho))}
.mb .mlab{font-size:9px;color:var(--muted);white-space:nowrap;transform:rotate(-45deg);height:34px}
.mb .mval{font-size:9px;color:var(--muted);opacity:0}.mb:hover .mval{opacity:1;color:var(--txt);font-weight:700}
/* rankings */
.rank{display:flex;flex-direction:column;gap:9px}
.row{display:grid;grid-template-columns:130px 1fr 110px;align-items:center;gap:10px;font-size:13px}
.row .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .track{height:18px}
.row .fill{height:100%;border-radius:5px;background:var(--laranja)}
.row .val{text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}
.row.f0 .fill{background:var(--laranja)}.row.f1 .fill{background:var(--ambar)}.row.f2 .fill{background:var(--marrom)}.row.f3 .fill{background:#00b8b8}.row.f4 .fill{background:var(--azul)}
/* filtros */
.filtros{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
/* meta — DRE + input */
.dre td:first-child{font-weight:600}.dre .tot td{font-weight:800;font-family:var(--title)}
input.meta{width:84px;text-align:right;border:1px solid var(--ambar);border-radius:6px;padding:5px 7px;font-variant-numeric:tabular-nums;font-size:13px;background:#fffdf0;color:var(--marrom)}
input.meta:focus{outline:2px solid var(--laranja);border-color:var(--laranja)}
.bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.hint{background:#fff4d6;border:1px solid var(--ambar);border-radius:8px;padding:10px 12px;font-size:12.5px;margin-bottom:18px}
/* produção */
.need{font-family:var(--title);font-weight:800}.need.go{color:var(--vermelho)}.need.ok{color:var(--verde)}
.ped{border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:10px;background:var(--panel2)}
.ped .top{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;font-size:13px}
.ped .itens{margin-top:8px;font-size:12.5px;color:var(--muted)}
/* receitas — árvore */
.skulist{display:flex;flex-direction:column;gap:6px;max-height:560px;overflow:auto}
.skubtn{text-align:left;background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:8px 10px;cursor:pointer;font-size:12.5px;color:var(--marrom)}
.skubtn:hover{border-color:var(--laranja)}
.skubtn.on{background:var(--marrom);color:var(--creme);border-color:var(--marrom);font-weight:700}
.skubtn .small{display:block;font-size:11px;opacity:.7;font-weight:400}
.tree{font-size:13px}
.node{display:flex;justify-content:space-between;gap:10px;padding:5px 0;border-bottom:1px dashed var(--line)}
.node .nm{display:flex;gap:6px;align-items:baseline}
.node .qt{font-variant-numeric:tabular-nums;color:var(--muted);white-space:nowrap}
.lvl0{font-weight:700}
.badge{font-size:10px;border-radius:4px;padding:1px 6px;font-weight:700}
.b-emb{background:#e8eefc;color:#1c3f9a}.b-cookie{background:#fff0cc;color:#8a5a00}.b-batida{background:#f0e6f7;color:#5a2a8a}.b-ins{background:var(--panel2);color:var(--muted)}
.skuhead{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.skuhead .cost{font-family:var(--title);font-weight:800;font-size:18px}
.wf td:first-child{font-weight:600}
/* fluxo — barras pareadas */
.legend{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-bottom:6px}
.legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:5px;vertical-align:middle}
.chart{display:flex;align-items:flex-end;gap:6px;height:210px;padding-top:18px;overflow-x:auto}
.chart .col{flex:1;min-width:26px;display:flex;flex-direction:column;align-items:center;gap:4px;justify-content:flex-end;height:100%}
.pair{display:flex;align-items:flex-end;gap:2px;height:100%;width:100%;justify-content:center}
.pair .bar{display:block;width:9px;border-radius:3px 3px 0 0;min-height:1px;margin:0}
.bar.ent{background:var(--ambar)}.bar.sai{background:var(--marrom)}.bar.rec{background:var(--ciano)}.bar.pag{background:var(--vermelho)}
.chart .lab{font-size:9px;color:var(--muted);white-space:nowrap;transform:rotate(-45deg);height:30px}
.warn{background:#fff4d6;border:1px solid var(--ambar);border-radius:8px;padding:10px 12px;font-size:12.5px;margin-top:10px}
/* diversos */
.tag{font-size:10px;background:var(--ambar);color:var(--marrom);border-radius:4px;padding:1px 5px;margin-left:5px;font-weight:700}
.empty{color:var(--muted);font-style:italic;padding:8px 0}
.src{color:var(--muted);font-size:12px}
.p-pend{background:#fff0cc;color:#8a5a00}.p-new{background:#e8eefc;color:#1c3f9a}.p-sell{background:#e8eefc;color:#1c3f9a}
.p-off{background:var(--panel2);color:var(--muted)}.p-muted{background:var(--panel2);color:var(--muted)}
.p-warn{background:#fff0cc;color:#8a5a00}.p-yellow{background:#fbf6d6;color:#7a6a1a}
.p-in{background:#e6f3e8;color:#1f7a3d}.p-out{background:#fdeaea;color:#9a0000}
.skuhead h2{margin:0}
