:root{
  /* Caliber brand manual palette — Purple #522E90, Green #007D3F, Red #F04E53 */
  --purple:#522E90; --purple-d:#3f2370; --purple-dd:#2c1750;
  --green:#007D3F; --green-d:#016334; --red:#F04E53; --red-d:#cf3b40;
  --ink:#221a31; --mut:#6f6783; --line:#e7e2f0; --bg:#f6f4fb; --card:#fff;
  --font:'Calibri','Segoe UI',system-ui,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);font-size:14px}
button{font-family:var(--font);cursor:pointer}
.hidden{display:none!important}

#login{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--purple),var(--purple-d) 55%,var(--purple-dd))}
.login-card{background:var(--card);width:380px;border-radius:14px;padding:34px 30px;box-shadow:0 24px 60px rgba(44,23,80,.45);border-top:4px solid var(--purple)}
.brand{display:flex;align-items:center;gap:11px}
.diamond{width:30px;height:30px;background:var(--purple);transform:rotate(45deg);border-radius:6px;position:relative;flex:none}
.diamond:after{content:"";position:absolute;inset:7px;background:var(--green);border-radius:3px}
.brand h1{font-size:19px;color:var(--purple)}
.brand small{display:block;color:var(--mut);font-size:11px;letter-spacing:2px}
.login-card h2{font-size:15px;margin:18px 0 14px}
label{display:block;font-size:12px;color:var(--mut);margin:11px 0 4px;font-weight:600}
input,select{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;background:#fbfaff;outline:none}
input:focus,select:focus{border-color:var(--purple)}
.btn{background:var(--purple);color:#fff;border:none;padding:11px;border-radius:8px;width:100%;font-size:14px;font-weight:700;margin-top:18px}
.btn:hover{background:var(--purple-d)}
.lock{text-align:center;margin-top:14px;font-size:11px;color:var(--mut)} .lock b{color:var(--green)}
.err{color:var(--red);font-size:12.5px;margin-top:10px;text-align:center;min-height:16px}
.rememberrow{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--mut);margin-top:12px;font-weight:600}
.rememberrow input{width:auto}
.modal{position:fixed;inset:0;background:rgba(44,23,80,.55);display:flex;align-items:center;justify-content:center;z-index:50}
.modal-card{background:var(--card);width:400px;max-width:92vw;border-radius:14px;padding:30px;box-shadow:0 24px 60px rgba(44,23,80,.45);border-top:4px solid var(--purple)}
.modal-card h2{font-size:15px;margin:16px 0 4px}

#app{display:flex;flex-direction:column;min-height:100vh}
.side{width:100%;background:var(--purple);color:#ece5f7;flex:none;padding:8px 12px;position:sticky;top:0;z-index:20;height:auto;overflow-x:auto;overflow-y:hidden;display:flex;align-items:center;gap:6px;white-space:nowrap;box-shadow:0 2px 12px rgba(44,23,80,.18)}
.side .brand{padding:0 14px 0 4px;border-right:1px solid rgba(255,255,255,.18);margin-right:8px;flex:0 0 auto}
.side .brand h1{color:#fff;font-size:16px;line-height:1}
.side .brand small{font-size:9px;letter-spacing:1.4px}
.side .diamond{background:#fff} .side .diamond:after{background:var(--green)}
.nav-group{font-size:13px;letter-spacing:1.6px;color:var(--red);font-weight:800;padding:0 6px;text-transform:uppercase;flex:0 0 auto}
.nav-item{display:inline-flex;align-items:center;gap:5px;padding:8px 10px;color:#ece5f7;font-size:13px;border:none;background:none;width:auto;text-align:left;border-radius:7px;flex:0 0 auto}
.nav-item:hover{background:rgba(255,255,255,.12)}
.nav-item.active{background:#fff;color:var(--purple);font-weight:700;border-radius:8px;margin-right:0}

.main{flex:1;display:flex;flex-direction:column;min-width:0}
.top{background:var(--card);border-bottom:1px solid var(--line);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:static;z-index:5}
.ctx{display:flex;gap:18px;align-items:center;font-size:12.5px;color:var(--mut)} .ctx b{color:var(--ink)}
.pill{background:#ece5f7;color:var(--purple);padding:3px 10px;border-radius:20px;font-weight:700;font-size:12px}
.who{display:flex;align-items:center;gap:9px}
.av{width:30px;height:30px;border-radius:50%;background:var(--purple);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}
.logout{font-size:12px;color:var(--red);background:none;border:1px solid var(--line);padding:6px 12px;border-radius:7px}
.appbtn{font-size:12px;color:var(--purple);background:#f3eefb;border:1px solid var(--purple);padding:6px 12px;border-radius:7px;font-weight:600}
.appbtn:hover{background:#ece5f7}
.appbtn.on{background:var(--green);color:#fff;border-color:var(--green)}
.content{padding:24px;overflow:auto}
.foot{padding:14px 24px;color:var(--mut);font-size:11px;border-top:1px solid var(--line);background:var(--card)} .foot b{color:var(--purple)}

.page-title{font-size:20px;color:var(--purple);margin-bottom:3px}
.page-sub{color:var(--mut);font-size:12.5px;margin-bottom:20px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;border-left:3px solid var(--purple)}
.kpi .lab{font-size:11.5px;color:var(--mut);text-transform:uppercase}
.kpi .val{font-size:24px;font-weight:800;margin-top:6px}
.kpi .sub{font-size:11.5px;color:var(--mut);margin-top:3px}
.up{color:var(--green)} .down{color:var(--red)}

.panel{background:var(--card);border:1px solid var(--line);border-radius:12px;margin-bottom:20px}
.panel h3{font-size:14px;padding:13px 18px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.panel .body{padding:18px}
.fg{display:grid;grid-template-columns:repeat(4,1fr);gap:13px 16px}
.fg .col2{grid-column:span 2} .fg label{margin-top:0}
.form-actions{margin-top:18px;display:flex;gap:10px}
.bg2{width:auto;padding:9px 20px;margin-top:0}
.b2{background:var(--green)} .b2:hover{background:var(--green-d)}
.ghost{background:#fff;color:var(--purple);border:1px solid var(--purple)} .ghost:hover{background:#f3eefb}
input[readonly]{background:#f1ecf9;color:var(--purple);font-weight:700}

table{width:100%;border-collapse:collapse;font-size:13px}
th{background:#f4f0fb;color:var(--mut);text-align:left;padding:9px 12px;font-size:11px;text-transform:uppercase;border-bottom:1px solid var(--line)}
td{padding:9px 12px;border-bottom:1px solid var(--line)}
tr:hover td{background:#faf8fd}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.chip{font-size:11px;font-weight:700;padding:2px 9px;border-radius:6px}
.chip.buy{background:#dcefe3;color:var(--green-d)} .chip.sell{background:#fde3e4;color:var(--red-d)}
.chip.lt{background:#e7e0f3;color:var(--purple)} .chip.st{background:#fff0d6;color:#8a5a00}
.toast{position:fixed;bottom:22px;right:22px;background:var(--purple);color:#fff;padding:12px 18px;border-radius:9px;font-size:13px;opacity:0;transition:.25s;pointer-events:none}
.toast.show{opacity:1}
.toast.ok{background:var(--green)} .toast.bad{background:var(--red)}
@media(max-width:900px){.kpis,.fg{grid-template-columns:1fr 1fr}.side{padding:8px}.side .brand{padding-right:10px;margin-right:4px}.side .brand small{display:none}.nav-group{font-size:11px;padding:0 4px}.nav-item{font-size:12.5px;padding:8px 9px}.content{padding:16px}.top{padding:10px 12px;gap:10px;align-items:flex-start;flex-direction:column}.ctx,.who{flex-wrap:wrap;gap:8px}}
