:root{
  --navy:#14171f; --navy2:#1d222e; --navy3:#272d3c;
  --gold:#f4761f; --gold2:#ff9447;
  --ink:#1a2230; --muted:#7d8aa0; --line:#e6e9f0;
  --bg:#f4f6fb; --card:#ffffff;
  --green:#1f9d6b; --green-bg:#e6f6ef;
  --red:#d24b4b; --red-bg:#fbe9e9;
  --amber:#cf9b1f; --amber-bg:#fbf2dc;
  --blue:#2f6fd6; --blue-bg:#e8f0fc;
  --radius:12px; --shadow:0 1px 3px rgba(16,30,54,.08),0 6px 24px rgba(16,30,54,.06);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--ink); font-size:14px; -webkit-font-smoothing:antialiased}
#app{display:flex; min-height:100vh; width:100%}

/* Sidebar */
#sidebar{width:236px; background:linear-gradient(180deg,var(--navy),var(--navy2)); color:#cdd7e6;
  display:flex; flex-direction:column; position:sticky; top:0; height:100vh; flex-shrink:0}
.brand{display:flex; gap:12px; align-items:center; padding:20px 18px 16px; flex-shrink:0}
.brand-mark{width:38px;height:38px;border:2px solid var(--gold); color:var(--gold);
  border-radius:9px; display:grid; place-items:center; font-size:20px}
.brand-title{font-weight:700; color:#fff; font-size:17px; letter-spacing:.3px}
.brand-sub{font-size:12px; color:var(--gold2)}
#nav{display:flex; flex-direction:column; gap:2px; padding:8px 10px; flex:1 1 auto; min-height:0; overflow-y:scroll; overflow-x:hidden}
#nav::-webkit-scrollbar{width:11px}
#nav::-webkit-scrollbar-track{background:rgba(0,0,0,.18); border-radius:8px}
#nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.32); border-radius:8px; border:2px solid transparent; background-clip:padding-box}
#nav::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.5); background-clip:padding-box}
#nav{scrollbar-width:thin; scrollbar-color:rgba(255,255,255,.4) rgba(0,0,0,.18)}
#nav button{display:flex; align-items:center; gap:11px; background:none; border:0; color:#b6c2d6;
  padding:11px 13px; border-radius:9px; font-size:14px; cursor:pointer; text-align:left; width:100%}
#nav button span{font-size:16px; width:20px; text-align:center}
#nav button:hover{background:rgba(255,255,255,.06); color:#fff}
#nav button.active{background:var(--navy3); color:#fff; box-shadow:inset 3px 0 0 var(--gold)}
.side-foot{padding:14px; border-top:1px solid rgba(255,255,255,.08); flex-shrink:0}
.year-pick{display:flex; align-items:center; gap:8px; margin-bottom:10px}
.year-pick label{font-size:12px;color:var(--gold2)}
.year-pick select{flex:1; background:var(--navy3); color:#fff; border:1px solid rgba(255,255,255,.15);
  border-radius:7px; padding:6px 8px; font-size:14px}
.save-state{font-size:12px; color:#8fb9a4} .save-state.saving{color:var(--gold2)}
#btnSalvar{background:var(--gold); color:#311700; border:0; border-radius:7px; padding:6px 11px; font-size:12px; font-weight:700; cursor:pointer; white-space:nowrap}
#btnSalvar:hover{background:var(--gold2)}
#btnSalvar:active{transform:translateY(1px)}

/* Main */
#main{flex:1; min-width:0}
#view{padding:26px 30px 60px; width:100%; max-width:none}
.page-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:20px; flex-wrap:wrap}
.page-head h1{font-size:23px; margin:0 0 3px}
.page-head .sub{color:var(--muted); font-size:13px}
.head-actions{display:flex; gap:8px; flex-wrap:wrap; align-items:center}

/* Buttons */
.btn{border:1px solid var(--line); background:#fff; color:var(--ink); padding:8px 14px; border-radius:9px;
  font-size:13px; font-weight:600; cursor:pointer; display:inline-flex; align-items:center; gap:7px}
.btn:hover{border-color:#c7cee0; background:#fbfcfe}
.btn.primary{background:var(--navy); color:#fff; border-color:var(--navy)}
.btn.primary:hover{background:var(--navy2)}
.btn.gold{background:var(--gold); border-color:var(--gold); color:#311700}
.btn.gold:hover{background:var(--gold2)}
.btn.ghost{background:none;border-color:transparent}
.btn.sm{padding:5px 10px;font-size:12px}
.btn.danger{color:var(--red);border-color:#eccaca}
.btn.danger:hover{background:var(--red-bg)}

/* Cards & KPIs */
.cards{display:grid; gap:16px}
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow)}
.card.pad{padding:18px 20px}
.kpis{display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:14px; margin-bottom:18px}
.kpi{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:15px 17px; box-shadow:var(--shadow)}
.kpi .label{font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.4px; font-weight:600}
.kpi .value{font-size:25px; font-weight:700; margin-top:6px; letter-spacing:-.5px}
.kpi .meta{font-size:12px; margin-top:4px; color:var(--muted)}
.kpi .meta.up{color:var(--green)} .kpi .meta.down{color:var(--red)}
.kpi.accent{background:linear-gradient(135deg,var(--navy),var(--navy3)); border-color:var(--navy)}
.kpi.accent .label{color:var(--gold2)} .kpi.accent .value{color:#fff} .kpi.accent .meta{color:#aebfd8}
.kpi .value.green{color:var(--green)} .kpi .value.red{color:var(--red)}

.grid2{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
@media(max-width:900px){.grid2,.grid3{grid-template-columns:1fr}}
.card h3{margin:0 0 14px; font-size:15px}
.card .card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.card .card-head h3{margin:0}
.card.clickable{cursor:pointer}

/* Tables */
.tbl-wrap{overflow:auto; border-radius:var(--radius); border:1px solid var(--line); background:#fff; box-shadow:var(--shadow)}
.tbl-wrap.flat{box-shadow:none}
.tbl-wrap.borderless{border:0}
table{border-collapse:collapse; width:100%; font-size:13px}
th,td{padding:9px 12px; text-align:left; white-space:nowrap; border-bottom:1px solid var(--line)}
thead th{background:#f7f9fd; color:var(--muted); font-weight:600; font-size:11.5px; text-transform:uppercase;
  letter-spacing:.4px; position:sticky; top:0; z-index:2}
tbody tr:hover{background:#f9fbfe}
td.num,th.num{text-align:right; font-variant-numeric:tabular-nums}
tr.total-row td{font-weight:700; background:#f7f9fd; border-top:2px solid var(--line)}
.name-cell{position:sticky; left:0; background:#fff; z-index:1; font-weight:600}
tbody tr:hover .name-cell{background:#f9fbfe}
thead .name-cell{background:#f7f9fd; z-index:3}
td .money-in{color:var(--green);font-weight:700}
td .money-out{color:var(--red);font-weight:700}

/* badges */
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11.5px;font-weight:700}
.badge.ok{background:var(--green-bg);color:var(--green)}
.badge.warn{background:var(--amber-bg);color:var(--amber)}
.badge.bad{background:var(--red-bg);color:var(--red)}
.badge.info{background:var(--blue-bg);color:var(--blue)}
.badge.grau{background:#eef1f7;color:#56627a}
.badge.in{background:var(--green-bg);color:var(--green)}
.badge.out{background:var(--red-bg);color:var(--red)}

/* forms */
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.field label{font-size:12px;font-weight:600;color:#48526a}
input,select,textarea{font-family:inherit;font-size:14px;padding:9px 11px;border:1px solid var(--line);
  border-radius:9px;background:#fff;color:var(--ink);width:100%}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(244,118,31,.15)}
.row-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row-fields.three{grid-template-columns:1fr 1fr 1fr}
.search{max-width:260px}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar .spacer{flex:1}
.toolbar select,.toolbar input{width:auto}

/* modal */
#modalRoot{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:50;
  background:rgba(15,29,51,.45)}
#modalRoot.open{display:flex}
.modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);width:min(560px,94vw);
  max-height:90vh;overflow:auto;padding:24px}
.modal.wide{width:min(820px,96vw)}
.modal h2{margin:0 0 4px;font-size:19px}
.modal .modal-sub{color:var(--muted);font-size:13px;margin-bottom:18px}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}

/* toast */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;
  background:var(--navy);color:#fff;padding:11px 20px;border-radius:30px;font-size:13.5px;font-weight:600;
  box-shadow:0 8px 30px rgba(0,0,0,.25);transition:.25s;z-index:80;pointer-events:none;max-width:80vw;text-align:center}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.err{background:var(--red)} #toast.ok{background:var(--green)}

/* misc */
.empty{text-align:center;color:var(--muted);padding:50px 20px}
.empty .big{font-size:40px;margin-bottom:8px}
.hint{font-size:12.5px;color:var(--muted);line-height:1.5}
.pill-tabs{display:inline-flex;background:#eef1f7;border-radius:10px;padding:3px;flex-wrap:wrap}
.pill-tabs button{border:0;background:none;padding:7px 15px;border-radius:8px;font-size:13px;font-weight:600;
  cursor:pointer;color:var(--muted)}
.pill-tabs button.active{background:#fff;color:var(--ink);box-shadow:var(--shadow)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}
.dot.in{background:var(--green)}
.dot.out{background:var(--red)}
.legend{display:flex;flex-wrap:wrap;gap:12px;font-size:12.5px;color:#48526a;margin-top:10px}
.legend span{display:inline-flex;align-items:center}
.mono{font-variant-numeric:tabular-nums}
.right{text-align:right}
.bar-track{background:#eef1f7;border-radius:6px;height:8px;overflow:hidden}
.bar-fill{height:100%;border-radius:6px;background:var(--green)}
a.link{color:var(--blue);cursor:pointer;text-decoration:none}
a.link:hover{text-decoration:underline}
.conf{font-weight:700}
.conf.hi{color:var(--green)} .conf.md{color:var(--amber)} .conf.lo{color:var(--muted)}
.drop{border:2px dashed #cdd5e4;border-radius:12px;padding:26px;text-align:center;color:var(--muted);cursor:pointer;background:#fbfcfe}
.drop:hover{border-color:var(--gold);color:var(--ink)}
.drop.drag{border-color:var(--gold);background:#fff6ee}
.tag{display:inline-block;background:#eef1f7;color:#56627a;border-radius:6px;padding:2px 8px;font-size:11.5px;font-weight:600}
.tag.in{background:var(--green-bg);color:var(--green)}
.tag.out{background:var(--red-bg);color:var(--red)}
.tag.info{background:var(--blue-bg);color:var(--blue)}
.split{display:grid;grid-template-columns:1fr 320px;gap:16px}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.cat-color{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:7px;vertical-align:middle}
.scroll-x{overflow-x:auto}
.scroll-panel{overflow:auto}
.cell-input{border:1px solid transparent;background:transparent;padding:4px 6px;border-radius:6px}
.cell-input:hover{border-color:var(--line)}
.cell-input:focus{border-color:var(--gold);background:#fff}

/* Layout helpers shared by views */
.section{margin-bottom:16px}
.section-lg{margin-bottom:18px}
.section-md{margin-bottom:14px}
.section-sm{margin-bottom:12px}
.mt-xxs{margin-top:4px}
.mt-xs{margin-top:6px}
.mt-sm{margin-top:8px}
.mt-md{margin-top:10px}
.mt-lg{margin-top:12px}
.mt-xl{margin-top:14px}
.mb-xxs{margin-bottom:4px}
.mb-xs{margin-bottom:6px}
.mb-sm{margin-bottom:8px}
.mb-md{margin-bottom:10px}
.mb-lg{margin-bottom:12px}
.mb-xl{margin-bottom:14px}
.full{width:100%}
.auto-width{width:auto}
.grow{flex:1}
.push-left{margin-right:auto}
.pre-wrap{white-space:pre-wrap}
.nowrap{white-space:nowrap}
.resize-y{resize:vertical}
.strong{font-weight:700}
.text-danger,a.text-danger{color:var(--red)}
.text-success{color:var(--green)}
.text-muted{color:var(--muted)}
.center{text-align:center}
.text-small{font-size:13px}
.text-tiny{font-size:11px}
.toolbar.tight{gap:6px}
.inline-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.inline-actions.tight{gap:6px}
.inline-actions.top{align-items:flex-start}
.inline-actions.bottom{align-items:flex-end}
.action-row{display:flex;gap:10px;flex-wrap:wrap}
.spread{display:flex;justify-content:space-between;gap:10px}
.spread.center{align-items:center}
.spread.top{align-items:flex-start}
.list-row{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--line)}
.list-row.compact{padding:5px 0}
.list-row.loose{padding:8px 0}
.list-row.top{align-items:flex-start}
.note-row{padding:5px 0;border-bottom:1px solid var(--line);font-size:13px}
.summary-row{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;border-top:2px solid var(--line)}
.summary-row .label{font-weight:700;font-size:15px}
.summary-row .value{font-size:21px;font-weight:700}
.chart-body{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.chart-legend{flex:1;min-width:170px}
.empty-action{margin-top:12px}
.form-note{margin-bottom:12px}
.form-foot-spacer{flex:1}
@media print{ #sidebar,.no-print{display:none!important} #view{max-width:none;padding:0} }
/* modo terminal de vendas (tablet) */
#kioskSair{display:none}
body.pos-kiosk #sidebar{display:none}
body.pos-kiosk #kioskSair{display:block; position:fixed; top:10px; right:12px; z-index:60; background:var(--navy,#14171f); color:#fff; border:0; border-radius:9px; padding:9px 14px; font-size:14px; font-weight:600; cursor:pointer; box-shadow:0 2px 8px rgba(0,0,0,.2)}
body.pos-kiosk #view{padding-top:6px}
@media(max-width:860px){ .bar-pos{grid-template-columns:1fr!important} .bar-pos .card[style*="sticky"]{position:static!important} }

/* ---- Bar / POS ---- */
@media(max-width:820px){ .bar-pos{grid-template-columns:1fr!important} }
.bar-pos .card[data-act="barAdd"]:hover{border-color:var(--gold)}
.bar-pos .card[data-act="barAdd"]:active{transform:translateY(1px)}

/* ---- autenticação (login / setup) ---- */
#authRoot{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:90;
  background:linear-gradient(135deg,var(--navy),#0a0c11);padding:20px}
#authRoot.open{display:flex}
.auth-card{background:#fff;border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.5);width:min(420px,94vw);padding:30px 28px}
.auth-brand{display:flex;gap:12px;align-items:center;margin-bottom:8px}
.auth-brand .brand-mark{width:42px;height:42px;border:2px solid var(--gold);color:var(--gold);border-radius:10px;display:grid;place-items:center;font-size:22px}
.auth-card h2{margin:14px 0 2px;font-size:21px}
.auth-card .modal-sub{color:var(--muted);font-size:13px;margin-bottom:18px}
.auth-card .btn{width:100%;justify-content:center;padding:11px}
.auth-err{background:var(--red-bg);color:var(--red);border-radius:9px;padding:9px 12px;font-size:13px;font-weight:600;margin-bottom:12px;display:none}
.auth-err.show{display:block}

/* ---- caixa de usuário na sidebar ---- */
.user-box{display:flex;align-items:center;justify-content:space-between;gap:8px;background:rgba(255,255,255,.06);
  border-radius:9px;padding:8px 10px;margin-bottom:4px}
.user-info{min-width:0}
.user-name{color:#fff;font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{color:var(--gold2);font-size:11px;text-transform:capitalize}
#btnSair{background:none;border:1px solid rgba(255,255,255,.2);color:#cdd7e6;border-radius:7px;padding:5px 10px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}
#btnSair:hover{background:rgba(255,255,255,.1);color:#fff}

/* ---- permissões (checkboxes) ---- */
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:6px 0 4px}
.perm-item{display:flex;align-items:center;gap:8px;background:#f7f9fd;border:1px solid var(--line);border-radius:9px;padding:9px 11px;font-size:13px;cursor:pointer}
.perm-item input{width:auto;margin:0}
.perm-item.on{border-color:var(--gold);background:#fff6ee}
@media(max-width:560px){.perm-grid{grid-template-columns:1fr}}
.role-pick{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:6px}
.role-pick button{flex:1;min-width:100px;border:1px solid var(--line);background:#fff;border-radius:9px;padding:9px;font-size:13px;font-weight:600;cursor:pointer}
.role-pick button.on{border-color:var(--gold);background:var(--gold);color:#311700}

.config-page{max-width:100%;min-width:0}
.config-table{width:100%;table-layout:fixed}
.config-table th,.config-table td{white-space:normal;vertical-align:top;overflow-wrap:anywhere;word-break:normal}
.config-table td.num,.config-table th.num{white-space:nowrap}
.alias-table .alias-key{width:58%;line-height:1.45}
.alias-table .alias-category{width:22%}
.alias-table .alias-type{width:90px}
.alias-table .alias-action{width:96px}

@media(max-width:760px){
  #app{flex-direction:column}
  #sidebar{position:static;width:100%;height:auto;max-height:none}
  .brand{padding:14px 16px 10px}
  #nav{flex:none;flex-direction:row;gap:6px;overflow-x:auto;overflow-y:hidden;padding:8px 10px 10px}
  #nav button{flex:0 0 auto;width:auto;white-space:nowrap;padding:10px 12px}
  #nav button span{width:auto}
  .side-foot{display:grid;grid-template-columns:1fr;gap:8px;padding:10px 14px 12px}
  .year-pick{margin-bottom:0}
  .user-box{margin-bottom:0}
  #main{width:100%}
  #view{padding:18px 14px 40px}
  .page-head{align-items:flex-start}
  .head-actions{width:100%}
  .head-actions .btn{flex:1;justify-content:center}
  .toolbar select,.toolbar input{width:100%}
  .search{max-width:none}
  .row-fields,.row-fields.three{grid-template-columns:1fr}
  .config-table{min-width:640px}
  .alias-table{min-width:0}
  .alias-table thead{display:none}
  .alias-table,.alias-table tbody,.alias-table tr,.alias-table td{display:block;width:100%}
  .alias-table tr{padding:10px 0;border-bottom:1px solid var(--line)}
  .alias-table td{border-bottom:0;padding:4px 0}
  .alias-table .alias-key{font-weight:600}
  .alias-table .alias-category,.alias-table .alias-type{font-size:12.5px;color:var(--muted)}
  .alias-table .alias-category::before{content:"Categoria: ";font-weight:700;color:var(--ink)}
  .alias-table .alias-type::before{content:"Tipo: ";font-weight:700;color:var(--ink)}
  .alias-table .alias-action{text-align:left}
}
