: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:13px}
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:11.5px;color:var(--mut);margin:6px 0 3px;font-weight:700}
input,select,textarea{width:100%;padding:6px 9px;border:1px solid var(--line);border-radius:7px;font-size:13px;background:#fbfaff;outline:none}
input,select{height:32px}
textarea{line-height:1.35;resize:vertical;min-height:76px}
input:focus,select:focus,textarea:focus{border-color:var(--purple)}
.btn{background:var(--purple);color:#fff;border:none;padding:9px 13px;border-radius:7px;width:100%;font-size:13px;font-weight:800;margin-top:12px}
.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}
.big-notice-card{width:640px;border-top-width:8px;padding:34px 38px}
.big-notice-card h2{font-size:30px;line-height:1.15;margin:0 0 18px;color:var(--purple)}
.big-notice-msg{font-size:22px;line-height:1.45;font-weight:800;color:var(--ink);margin-bottom:22px}
.big-notice-msg p{margin:8px 0}
.big-notice-card .btn{font-size:22px;padding:14px 24px;border-radius:10px}
.modal.ok .big-notice-card{border-top-color:var(--green)}
.modal.ok .big-notice-card h2{color:var(--green-d)}
.modal.bad .big-notice-card{border-top-color:var(--red)}
.modal.bad .big-notice-card h2{color:var(--red-d)}

#app{display:flex;flex-direction:column;min-height:100vh}
.side{width:100%;background:var(--purple);color:#ece5f7;flex:none;padding:6px 12px;position:sticky;top:0;z-index:20;height:auto;overflow:visible;display:flex;align-items:center;gap:5px 8px;white-space:normal;flex-wrap:wrap;box-shadow:0 2px 12px rgba(44,23,80,.18)}
.side .brand{display:none}
.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-break{order:1;flex-basis:100%;height:0}
.nav-group{order:0;font-size:14px;letter-spacing:2px;color:var(--red);font-weight:900;padding:6px 10px;text-transform:uppercase;flex:0 0 auto;border-radius:7px;cursor:pointer}
.nav-group:hover{background:rgba(255,255,255,.12)}
.nav-group.active{background:#fff;color:var(--purple)}
.nav-item{order:2;display:inline-flex;align-items:center;gap:5px;padding:6px 9px;color:#ece5f7;font-size:15px;border:none;background:none;width:auto;text-align:left;border-radius:7px;flex:0 0 auto;font-weight:700}
.nav-item.nav-hidden{display:none}
.nav-item:hover{background:rgba(255,255,255,.12)}
.nav-item.active{background:#fff;color:var(--purple);font-weight:700;border-radius:7px;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)}
.appbtn.faved{background:var(--purple);color:#fff;border-color:var(--purple)}
.appbtn:disabled{opacity:.55;cursor:not-allowed}
.fav-title{font-weight:800;color:var(--ink)}
.fav-meta{font-size:11px;color:var(--mut)}
.fav-open{width:auto;margin-top:0;padding:7px 12px}
.content{padding:14px 16px;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:18px;color:var(--purple);margin-bottom:2px}
.page-sub{color:var(--mut);font-size:12px;margin-bottom:12px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:10px 12px;border-left:3px solid var(--purple)}
.kpi .lab{font-size:11.5px;color:var(--mut);text-transform:uppercase}
.kpi .val{font-size:20px;font-weight:800;margin-top:4px}
.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:10px;margin-bottom:12px}
.panel h3{font-size:13.5px;padding:9px 14px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.panel .body{padding:11px 14px}
.filters{display:flex;align-items:flex-end;gap:7px;flex-wrap:wrap}
.filters .f{flex:0 1 150px;min-width:130px;max-width:190px}
.filters .f.rate-file-field{flex-basis:360px;max-width:460px}
.filters .f:has(select[id*="Firm"]),.filters .f:has(select[id*="Share"]),.filters .f:has(select[id*="Name"]){flex-basis:220px;max-width:280px}
.filters label{margin:0 0 4px;font-size:11.5px}
.filters input,.filters select{height:31px;padding:5px 8px;border-radius:7px;font-size:12.5px}
.filters .btn{height:31px;min-width:82px;padding:0 12px;margin-top:0;white-space:nowrap}
.filters .chk{height:34px;display:flex;align-items:center;gap:6px;margin:0 4px 0 0;color:var(--mut);font-size:12px;font-weight:700}
.filters .chk input{width:auto}
.note{color:var(--mut);font-size:12.5px;margin-top:10px}
.result-note{display:block;width:100%;font-size:18px;line-height:1.35;font-weight:800;padding:14px 16px;border-radius:9px;border:1px solid var(--line);background:#fbfaff;color:var(--ink)}
.result-note.ok{border-color:#9ad7b6;background:#eef9f3;color:var(--green-d)}
.result-note.bad{border-color:#f5a4a7;background:#fff0f1;color:var(--red-d)}
.report-tools{margin-top:10px}
.report-tools .body{padding:9px 14px}
.report-tools .filters{align-items:center}
.report-tools .type-filter{flex-basis:160px;max-width:190px}
.mini-action{width:auto;margin-top:0;padding:6px 10px;white-space:nowrap}
.correction-grid{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(420px,1.15fr);gap:12px;align-items:start}
.correction-grid .panel:first-child{grid-row:span 2}
.correction-grid .panel .body{overflow:auto}
.suggest-wrap{position:relative}
.search-suggest{display:none;position:absolute;z-index:80;left:0;right:0;top:calc(100% + 4px);max-height:240px;overflow:auto;background:#fff;border:1px solid var(--purple);border-radius:8px;box-shadow:0 12px 28px rgba(44,23,80,.22);padding:4px}
.search-suggest.show{display:block}
.search-suggest-item{display:block;width:100%;border:0;background:#fff;color:var(--ink);text-align:left;padding:7px 8px;border-radius:6px;font-size:12.5px;line-height:1.2;white-space:normal}
.search-suggest-item:hover,.search-suggest-item:focus{background:#f3eefb;color:var(--purple)}
.search-suggest-empty{padding:8px;color:var(--mut);font-size:12px}
.report-filter-hide{display:none!important}
.fg{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:7px 12px}
.fg .col2{grid-column:span 2} .fg label{margin-top:0}
.entry-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:6px 10px}
.entry-grid input,.entry-grid select{height:31px;padding:5px 8px}
.entry-grid label{font-size:11px;margin-bottom:2px}
.form-actions{margin-top:9px;display:flex;gap:8px;flex-wrap:wrap}
.bg2{width:auto;padding:8px 16px;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:13.5px}
th{background:#f4f0fb;color:var(--mut);text-align:left;padding:8px 10px;font-size:11.5px;text-transform:uppercase;border-bottom:1px solid var(--line)}
td{padding:8px 10px;border-bottom:1px solid var(--line)}
tr:hover td{background:#faf8fd}
tr.rate-fallback td{background:#ffd99a !important;color:#3b2600}
tr.rate-fallback:hover td{background:#ffc86b !important}
tr.rate-fallback[data-rate-fix]{cursor:pointer}
tr.negative-qty td{background:#cfe7ff !important;color:#083b66}
tr.negative-qty:hover td{background:#aed7ff !important}
tr.negative-qty[data-negative-detail]{cursor:pointer}
.rate-fix-card{width:min(1040px,94vw);max-height:88vh;overflow:auto}
.rate-fix-card h2{font-size:28px;line-height:1.15;margin:0 0 8px;color:var(--purple)}
.rate-fix-table input{width:150px;text-align:right;font-weight:800}
.negative-drill-card{width:min(1180px,96vw);max-height:88vh;overflow:auto}
.negative-drill-card h2{font-size:28px;line-height:1.15;margin:0 0 8px;color:var(--purple)}
.negative-drill-section{border:1px solid var(--line);border-radius:8px;padding:12px;margin-top:12px;background:#fff}
.negative-drill-section h3{font-size:18px;line-height:1.2;margin:0 0 10px;color:#083b66}
.negative-drill-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:8px}
.negative-drill-kpis div{background:#f4f0fb;border-left:3px solid var(--purple);padding:8px;border-radius:6px}
.negative-drill-kpis span{display:block;font-size:10px;text-transform:uppercase;color:var(--mut);font-weight:800}
.negative-drill-kpis b{display:block;font-size:18px;margin-top:2px}
.negative-drill-kpis .bad{background:#fff0f1;border-left-color:var(--red);color:var(--red-d)}
.negative-drill-table{overflow:auto;max-height:360px;border:1px solid var(--line);border-radius:8px}
.negative-drill-table table{font-size:12px}
.negative-drill-table th,.negative-drill-table td{padding:6px 8px;white-space:nowrap}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.owner-profit-panel .body{overflow:hidden}
.owner-profit-table{table-layout:fixed;width:100%;font-size:13.8px}
.owner-profit-table col.op-owner{width:31%}
.owner-profit-table col.op-num{width:12.8%}
.owner-profit-table col.op-pct{width:5%}
.owner-profit-table th,.owner-profit-table td{padding:8px 9px;line-height:1.2}
.owner-profit-table .op-owner-cell{white-space:normal;overflow-wrap:anywhere;line-height:1.15}
.owner-profit-table td.num,.owner-profit-table th.num{white-space:nowrap}
.owner-profit-table tfoot td{background:#efe8fb;border-top:2px solid var(--purple);font-weight:900;color:var(--ink)}
.owner-profit-table tfoot td:first-child{color:var(--purple);letter-spacing:.04em}
.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}
.ledger-old{padding:10px 12px 14px;background:#f7f7f7;overflow-x:hidden}
.ledger-old-grid{display:grid;grid-template-columns:minmax(260px,1.05fr) minmax(300px,1.1fr) minmax(330px,1.2fr) minmax(170px,.65fr);gap:8px;align-items:start;margin-bottom:8px}
.ledger-old-box{border:1px solid #8f8f8f;background:#fff}
.ledger-old-box h3{border:0;padding:6px 8px;text-align:center;display:block;font-size:15px;line-height:1.1;font-weight:900;background:#f2f2f2;color:var(--red)}
.ledger-real h3{color:var(--green-d)}
.ledger-unreal h3{color:#111}
.ledger-net h3{color:var(--red)}
.ledger-old-box table{font-size:12px}
.ledger-old-box th{background:#f8f8f8;color:var(--purple);font-size:11px;text-align:center;border:1px solid #a9a9a9;padding:5px 6px;text-transform:none}
.ledger-old-box td{border:1px solid #a9a9a9;padding:6px 8px;background:#c9ffc3;color:#d4212a;font-weight:900}
.ledger-real td{background:#fffdb7;color:#39525b}
.ledger-unreal td{background:#8df7fa;color:#d4212a}
.ledger-rate-note{font-size:11px;color:#7a4f00;background:#ffd99a;border-top:1px solid #a9a9a9;padding:5px 8px;font-weight:700}
.ledger-net{min-height:96px}
.ledger-net-value{margin:10px 12px 14px;text-align:center;background:#0e86d8;color:#fff;font-size:22px;font-weight:900;padding:9px 8px;border:1px solid #6b6b6b}
.ledger-net-value.up{color:#fff;background:var(--green)}
.ledger-net-value.down{color:#fff;background:#0e86d8}
.ledger-old-table{font-size:11.5px;background:#fff;border:1px solid #8f8f8f}
.ledger-old-table th{background:#f6f6f6;color:#3d3450;font-size:10.5px;text-transform:none;border:1px solid #b8b8b8;padding:5px 7px}
.ledger-old-table th.ledger-sort{cursor:pointer;user-select:none}
.ledger-old-table th.ledger-sort:hover{background:#e9e0f7;color:var(--purple)}
.ledger-old-table td{border:1px solid #c4c4c4;padding:5px 7px}
.ledger-old-table tr:hover td{background:#f7fbff}
.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;z-index:80;max-width:min(92vw,560px);box-shadow:0 18px 45px rgba(44,23,80,.28)}
.toast.show{opacity:1;pointer-events:auto}
.toast.ok{background:var(--green)} .toast.bad{background:var(--red)}
.toast.sticky{font-size:18px;line-height:1.35;font-weight:800;display:flex;align-items:center;gap:14px;padding:16px 18px}
.toast.sticky button{width:auto;margin:0;background:#fff;color:var(--ink);border:none;border-radius:7px;padding:8px 14px;font-size:14px;font-weight:900}
@media(max-width:1300px){.ledger-old-grid{grid-template-columns:1fr 1fr}.ledger-net{min-height:auto}.ledger-net-value{font-size:18px}}
@media(max-width:900px){.kpis,.fg,.entry-grid{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:12.5px;padding:4px 6px}.nav-item{font-size:13.5px;padding:7px 8px}.content{padding:12px}.top{padding:10px 12px;gap:10px;align-items:flex-start;flex-direction:column}.ctx,.who{flex-wrap:wrap;gap:8px}.filters .f,.filters .f:has(select[id*="Firm"]),.filters .f:has(select[id*="Share"]),.filters .f:has(select[id*="Name"]){flex:1 1 145px;max-width:none}.ledger-old-grid{grid-template-columns:1fr}.ledger-old{overflow-x:auto}}
