*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4f5f7;--bg2:#fff;--card:#fff;--card-h:#f8fafb;--c360:#0077b6;--rsc:#e63946;--dig:#e69b00;--admin:#7b2d8e;--intl:#00856a;--pos:#0f7b46;--neg:#c1292e;--t1:#1a1d21;--t2:#5f6b7a;--t3:#9ca5b0;--grid:#e8ecf0;--border:#dfe3e8;--new:#2e86ab;--renew:#a23b72;--expand:#f18f01;--shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-lg:0 4px 20px #00000014}html,body{height:100%;color:var(--t1);background:#ebeef2;font-family:DM Sans,sans-serif;overflow:hidden}.loading-overlay{z-index:9999;color:var(--t2);background:#f4f5f7f2;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex;position:fixed;inset:0}.loading-overlay .spinner{border:3px solid var(--border);border-top-color:var(--c360);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-overlay{z-index:9999;background:#f4f5f7f2;flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex;position:fixed;inset:0}.error-overlay .err{color:var(--neg);font-size:14px;font-weight:600}.error-overlay .msg{color:var(--t2);font-size:12px}.app{width:100vw;height:100vh;display:flex;overflow:hidden}.main-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.canvas{background:var(--bg);flex-direction:column;flex:1;animation:.3s slideIn;display:flex;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:scale(.985)}to{opacity:1;transform:scale(1)}}.side-nav{border-right:1px solid var(--border);background:#fff;flex-direction:column;flex-shrink:0;width:160px;display:flex;overflow:hidden}.side-nav-brand{box-sizing:border-box;align-items:center;gap:8px;min-height:42px;padding:10px 14px;display:flex}.side-nav-logo-img{width:80px;height:auto;display:block}.side-nav-subtitle{color:var(--t3);margin-top:2px;font-size:10px;font-weight:500}.side-nav-items{flex-direction:column;flex:1;gap:1px;padding:6px 0;display:flex;overflow-y:auto}.side-nav-btn{cursor:pointer;color:var(--t3);text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:7px 14px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:500;transition:all .15s;display:flex}.side-nav-btn:hover{color:var(--t2);background:#0077b608}.side-nav-btn.active{color:var(--c360);background:#0077b60f;font-weight:600}.side-nav-num{opacity:.4;flex-shrink:0;width:12px;font-family:JetBrains Mono,monospace;font-size:8px}.side-nav-label{text-overflow:ellipsis;overflow:hidden}.filter-bar{border-top:1px solid var(--border);background:#fff;flex-shrink:0;justify-content:flex-start;align-items:center;padding:6px 16px 6px 24px;display:flex}.filter-bar-items{align-items:center;gap:6px;display:flex}.top-bar{border-bottom:1px solid var(--border);box-sizing:border-box;background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;min-height:42px;padding:10px 20px;display:flex}.top-bar .title-area h1{letter-spacing:-.2px;color:var(--t1);font-size:13px;font-weight:700}.top-bar .title-area p{color:var(--t3);margin-top:1px;font-size:9.5px}.top-bar .filters{align-items:center;gap:6px;display:flex}.chip{border:1px solid var(--border);color:var(--t2);cursor:pointer;background:#fff;border-radius:14px;padding:4px 10px;font-family:inherit;font-size:11.5px;transition:all .2s}.chip:hover,.chip.on{border-color:var(--c360);color:var(--c360);background:#0077b60a}.chip select{color:inherit;font:inherit;cursor:pointer;-webkit-appearance:none;background:0 0;border:none;outline:none}.chip select option{color:var(--t1);background:#fff}.refresh{color:var(--t3);font-family:JetBrains Mono,monospace;font-size:8.5px}.bu-dropdown{position:relative}.bu-menu{border:1px solid var(--border);z-index:999;background:#fff;border-radius:8px;min-width:160px;margin-top:4px;padding:4px 0;position:absolute;top:100%;left:0;box-shadow:0 4px 12px #0000001a}.bu-option{color:var(--t1);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding:5px 12px;font-size:11.5px;display:flex}.bu-option:hover{background:#0077b60a}.bu-option input[type=checkbox]{width:12px;height:12px;accent-color:var(--c360);cursor:pointer;margin:0}.bu-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.body{flex:1;gap:10px;padding:12px 16px;display:grid;overflow:hidden}.g-p1{grid-template-rows:auto auto 1fr;grid-template-columns:3fr 2fr}.g-p1 .kpi-strip{grid-column:1/-1}.g-2col{grid-template-rows:1fr;grid-template-columns:1fr 1fr}.g-6040{grid-template-rows:auto 1fr;grid-template-columns:3fr 2fr}.g-6040 .kpi-strip{grid-column:1/-1}.g-5050k{grid-template-rows:auto 1fr;grid-template-columns:1fr 1fr}.g-5050k .kpi-strip{grid-column:1/-1}.g-full-k{grid-template-rows:auto 1fr;grid-template-columns:1fr}.g-full-k .kpi-strip{grid-column:1/-1}.g-kpi-3col{grid-template-rows:auto 1fr;grid-template-columns:1fr 1fr 1fr}.g-kpi-3col .kpi-strip{grid-column:1/-1}.g-top4-bot2{grid-template-rows:auto 1fr 1fr;grid-template-columns:1fr 1fr}.g-top4-bot2 .kpi-strip{grid-column:1/-1}.g-ret{grid-template-rows:1fr;grid-template-columns:1fr 1fr}.ret-right{flex-direction:column;gap:10px;min-height:0;display:flex;overflow:hidden}.ret-right .card,.ret-right .chart-card-wrap{flex:1;min-height:0}.kpi-strip{gap:8px;display:flex}.kpi{background:var(--card);border:1px solid var(--border);min-height:0;box-shadow:var(--shadow);border-radius:8px;flex-direction:column;flex:1;justify-content:center;padding:8px 12px;display:flex;overflow:visible}.kpi .label{color:var(--t2);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;align-items:center;gap:3px;font-size:8.5px;font-weight:500;display:flex;overflow:visible}.kpi-info{border:1px solid var(--t3);width:12px;height:12px;color:var(--t3);cursor:help;text-transform:none;letter-spacing:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:7px;font-style:italic;font-weight:600;line-height:1;display:inline-flex}.kpi-tooltip{color:#fff;text-transform:none;letter-spacing:0;white-space:normal;z-index:9999;pointer-events:none;background:#1a1d21;border-radius:6px;width:220px;padding:8px 10px;font-size:9px;font-weight:400;line-height:1.4;position:fixed;box-shadow:0 4px 12px #00000026}.kpi .val{letter-spacing:-.8px;color:var(--t1);margin:2px 0 1px;font-family:JetBrains Mono,DM Sans,sans-serif;font-size:20px;font-weight:700;line-height:1.1}.kpi .val.sm{font-size:16px}.kpi .delta{align-items:center;gap:2px;font-size:9px;font-weight:600;display:inline-flex}.kpi .delta.up{color:var(--pos)}.kpi .delta.down{color:var(--neg)}.card{background:var(--card);border:1px solid var(--border);min-height:0;box-shadow:var(--shadow);border-radius:8px;flex-direction:column;padding:10px 14px;display:flex;overflow:hidden}.card h3{white-space:nowrap;color:var(--t1);flex-shrink:0;align-items:center;gap:6px;margin-bottom:4px;font-size:11px;font-weight:600;display:flex}.card h3 .badge{color:var(--c360);text-transform:uppercase;letter-spacing:.4px;background:#0077b614;border-radius:8px;padding:1px 6px;font-size:8px;font-weight:600}.card .chart-area{flex:1;min-height:0;position:relative}.card canvas{position:absolute;inset:0;width:100%!important;height:100%!important}.legend{flex-wrap:wrap;flex-shrink:0;gap:8px;margin:3px 0;display:flex}.legend-item{color:var(--t2);align-items:center;gap:4px;font-size:8.5px;display:flex}.legend-dot{border-radius:2px;flex-shrink:0;width:7px;height:7px}.donut-wrap{flex:1;min-height:0;position:relative}.donut-center{text-align:center;pointer-events:none;position:absolute;top:45%;left:50%;transform:translate(-50%,-50%)}.donut-center .dv{color:var(--t1);font-family:JetBrains Mono,monospace;font-size:18px;font-weight:700}.donut-center .dl{color:var(--t2);font-size:8.5px}.mini-row{flex-shrink:0;justify-content:center;gap:12px;margin-top:4px;display:flex}.mini-row .mk{text-align:center}.mini-row .mk .mv{color:var(--t1);font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.mini-row .mk .ml{color:var(--t2);text-transform:uppercase;letter-spacing:.4px;font-size:7.5px}.decay-list{flex-direction:column;flex:1;justify-content:center;gap:6px;padding:4px 8px;display:flex}.decay-row{align-items:center;gap:8px;display:flex}.decay-yr{width:38px;color:var(--t2);flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:10px}.decay-bg{background:var(--grid);border-radius:5px;flex:1;height:20px;overflow:hidden}.decay-fill{color:#fff;border-radius:5px;align-items:center;height:100%;padding-left:6px;font-family:JetBrains Mono,monospace;font-size:9px;font-weight:600;transition:width 1s;display:flex}.decay-n{text-align:right;width:64px;color:var(--t2);flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:10px}.tbl-wrap{border-radius:4px;flex:1;min-height:0;overflow:auto}.tbl-wrap::-webkit-scrollbar{width:3px}.tbl-wrap::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.tbl{border-collapse:collapse;width:100%;font-size:9.5px}.tbl th{text-align:left;color:var(--t2);text-transform:uppercase;letter-spacing:.4px;background:var(--card);z-index:1;box-shadow:inset 0 -2px 0 var(--border);border-bottom:none;padding:5px 8px;font-size:8px;font-weight:600;position:sticky;top:0}.tbl td{border-bottom:1px solid var(--grid);padding:4px 8px}.tbl tr:hover td{background:#0077b608}.mono{font-family:JetBrains Mono,monospace}.tag{border-radius:4px;padding:1px 6px;font-size:8px;font-weight:600}.t-hi{color:var(--neg);background:#c1292e14}.t-lo{color:var(--pos);background:#0f7b4614}.t-warn{color:#e69b00;background:#f18f0114}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable:hover{color:#e76f51}.toggle-btn{border:1px solid var(--border);background:var(--card);color:var(--t2);cursor:pointer;text-transform:uppercase;letter-spacing:.3px;border-radius:4px;padding:4px 12px;font-size:9px;font-weight:600;transition:all .15s}.toggle-btn:hover{color:#e76f51;border-color:#e76f51}.toggle-active,.toggle-btn.active{background:var(--c360);color:#fff;border-color:var(--c360)}.toggle-active:hover,.toggle-btn.active:hover{color:#fff;background:#e76f51;border-color:#e76f51}.modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--card);border-radius:8px;flex-direction:column;width:90%;max-width:600px;max-height:80vh;padding:16px;display:flex;box-shadow:0 8px 32px #0003}.recon-tbl{border-collapse:separate;border-spacing:0}.recon-tbl .sticky-col{background:var(--card);z-index:2;white-space:nowrap;text-overflow:ellipsis;max-width:150px;position:sticky;left:0;overflow:hidden}.recon-tbl tr:hover .sticky-col{background:#f5f8fa}.recon-tbl tr:hover .fy-total{background:#0077b60f}.recon-tbl tr:hover .grand-total{background:#0077b617}.recon-tbl thead .sticky-col{z-index:3}.recon-tbl th,.recon-tbl td{text-align:right;white-space:nowrap;border-right:1px solid var(--border)}.recon-tbl .sticky-col{text-align:left}.recon-tbl .client-name{font-size:8.5px;font-weight:500}.cell-pos{color:var(--pos)}.cell-neg{color:var(--neg)}.fy-total{background:#0000000a;font-weight:700}.fy-total-hdr{border-left:2px solid var(--border);font-weight:700;background:#f0f1f3!important;font-size:9px!important}td.fy-total{border-left:2px solid var(--border)}.grand-total{background:#00000014;font-weight:700}.grand-total-hdr{border-left:2px solid var(--border);font-weight:700;background:#e6e8eb!important;font-size:9px!important}td.grand-total{border-left:2px solid var(--border)}.map-ph{border:1px dashed var(--border);background:linear-gradient(135deg,#f8fafb,#eef1f5);border-radius:6px;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.map-ph:before{content:"";opacity:.5;background:url("data:image/svg+xml,%3Csvg width='300' height='300' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M150 30C80 50 40 100 50 150C55 180 80 200 100 210C120 220 130 250 150 270C170 250 180 220 200 210C220 200 245 180 250 150C260 100 220 50 150 30Z' fill='none' stroke='%23DFE3E8' stroke-width='2'/%3E%3Ccircle cx='120' cy='130' r='5' fill='%230077B6' opacity='0.5'/%3E%3Ccircle cx='155' cy='115' r='8' fill='%230077B6' opacity='0.7'/%3E%3Ccircle cx='138' cy='155' r='3' fill='%23E63946' opacity='0.5'/%3E%3Ccircle cx='172' cy='140' r='6' fill='%230077B6' opacity='0.6'/%3E%3Ccircle cx='130' cy='100' r='4' fill='%23E69B00' opacity='0.5'/%3E%3C/svg%3E") 50%/contain no-repeat;position:absolute;inset:0}.map-ph .mt{color:var(--t2);z-index:1;font-size:11px;font-weight:600}.map-ph .ms{color:var(--t3);z-index:1;margin-top:2px;font-size:9px}.login-page{background:var(--bg);justify-content:center;align-items:center;font-family:DM Sans,sans-serif;display:flex;position:fixed;inset:0}.login-card{background:var(--card);border:1px solid var(--border);text-align:center;border-radius:12px;width:340px;padding:40px 36px;box-shadow:0 4px 24px #00000014}.login-title{color:var(--t1);margin-bottom:2px;font-size:20px;font-weight:700}.login-subtitle{color:var(--t3);margin-bottom:24px;font-size:12px}.login-form{flex-direction:column;gap:12px;display:flex}.login-form input{border:1px solid var(--border);color:var(--t1);border-radius:6px;outline:none;padding:10px 14px;font-family:DM Sans,sans-serif;font-size:13px;transition:border-color .15s}.login-form input:focus{border-color:var(--c360)}.login-form button{background:var(--c360);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:10px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:opacity .15s}.login-form button:hover{opacity:.9}.login-form button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--neg);text-align:left;font-size:11px}
