*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f7f8fa;--surface:#fff;--surface2:#f2f4f7;--surface3:#e8eaed;--border:#e2e5ea;--border2:#cbd0d8;--text:#1a1d23;--text2:#5a6072;--text3:#9ba3b2;--accent:#1a9e77;--accent-d:#0e6e54;--accent-l:#e6f7f2;--blue:#185fa5;--blue-l:#e6f1fb;--amber:#854f0b;--amber-l:#faeeda;--amber-m:#ef9f27;--red:#a32d2d;--red-l:#fcebeb;--green:#3b6d11;--green-l:#eaf3de;--purple:#534ab7;--purple-l:#eeedfe;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014;--sidebar:224px;--header:56px;--font:"Inter","Segoe UI",system-ui,sans-serif}[data-theme=dark]{--bg:#0f1117;--surface:#1a1d23;--surface2:#22262f;--surface3:#2a2f3a;--border:#2e3340;--border2:#3d4455;--text:#e8eaed;--text2:#9ba3b2;--text3:#5a6072;--accent:#1a9e77;--accent-d:#24c290;--accent-l:#0d2e24;--blue:#378add;--blue-l:#0c1e35;--amber-l:#2a1f0a;--amber:#ef9f27;--red-l:#2a0f0f;--red:#e24b4a;--green-l:#1a2e0a;--green:#639922;--purple-l:#1e1b40;--purple:#7f77dd}html,body{height:100%;font-family:var(--font);color:var(--text);background:var(--bg);font-size:14px;line-height:1.5}.pp-loader-bg{background:var(--bg);justify-content:center;align-items:center;height:100vh;display:flex}.pp-loader-card{flex-direction:column;align-items:center;gap:0;display:flex}.pp-loader-logo{width:80px;height:80px;margin-bottom:20px;position:relative}.pp-loader-ring{border:3px solid #0000;border-radius:50%;position:absolute;inset:0}.pp-ring-1{border-top-color:var(--accent);animation:1.1s linear infinite pp-spin}.pp-ring-2{border-top-color:var(--blue);animation:1.4s linear infinite reverse pp-spin;inset:10px}.pp-ring-3{border-top-color:var(--purple);animation:.9s linear infinite pp-spin;inset:20px}.pp-loader-mark{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.pp-loader-mark svg{width:26px;height:26px;stroke:var(--accent);animation:1.5s ease-in-out infinite pp-pulse}.pp-loader-dots{gap:6px;margin-bottom:14px;display:flex}.pp-loader-dots span{background:var(--accent);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite pp-bounce}.pp-loader-dots span:nth-child(2){background:var(--blue);animation-delay:.2s}.pp-loader-dots span:nth-child(3){background:var(--purple);animation-delay:.4s}.pp-loader-label{letter-spacing:-.3px;color:var(--text);margin-bottom:4px;font-size:18px;font-weight:700}.pp-loader-sub{color:var(--text3);font-size:12px}@keyframes pp-spin{to{transform:rotate(360deg)}}@keyframes pp-bounce{0%,80%,to{opacity:.4;transform:scale(0)}40%{opacity:1;transform:scale(1)}}@keyframes pp-pulse{0%,to{opacity:.6;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}#app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{height:var(--header);background:var(--surface);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;align-items:center;gap:12px;padding:0 1.25rem;display:flex}.logo{letter-spacing:-.4px;color:var(--text);align-items:center;gap:8px;font-size:16px;font-weight:600;text-decoration:none;display:flex}.logo-mark{background:var(--accent);border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.logo-mark svg{fill:#fff;width:16px;height:16px}.header-sep{background:var(--border);width:1px;height:20px;margin:0 4px}.cycle-pill{background:var(--accent-l);color:var(--accent);border-radius:20px;padding:3px 10px;font-size:12px;font-weight:500}.header-right{align-items:center;gap:8px;margin-left:auto;display:flex}.theme-btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;width:32px;height:32px;color:var(--text2);justify-content:center;align-items:center;font-size:14px;display:flex}.theme-btn:hover{background:var(--surface2)}.role-select{border:1px solid var(--border2);background:var(--surface2);cursor:pointer;color:var(--text);border-radius:20px;outline:none;padding:4px 10px;font-size:12px;font-weight:500}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:600;display:flex}.layout{flex:1;display:flex;overflow:hidden}.sidebar{width:var(--sidebar);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden auto}.sidebar-user{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:6px;padding:14px 14px 12px;display:flex}.sidebar-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;transition:box-shadow .2s;display:flex}.sidebar-user-info{min-width:0}.sidebar-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text3);margin-top:1px;font-size:11px}.sidebar-nav{flex:1;padding:4px 0 8px}.nav-group{margin-bottom:2px}.nav-group-header{cursor:pointer;width:100%;color:var(--text3);letter-spacing:.9px;text-transform:uppercase;background:0 0;border:none;align-items:center;gap:8px;padding:6px 14px;font-size:10px;font-weight:700;transition:color .15s;display:flex}.nav-group-header:hover{color:var(--text2)}.nav-group-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.nav-group-label{text-align:left;flex:1}.nav-group-chevron{color:var(--text3);flex-shrink:0;transition:transform .2s cubic-bezier(.4,0,.2,1)}.nav-group-body{grid-template-rows:0fr;transition:grid-template-rows .22s cubic-bezier(.4,0,.2,1);display:grid}.nav-group-body.open{grid-template-rows:1fr}.nav-group-body>div,.nav-group-body-inner{overflow:hidden}.nav-item{cursor:pointer;color:var(--text2);border-radius:var(--radius);align-items:center;gap:9px;margin:1px 8px;padding:7px 10px 7px 14px;font-size:13px;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent-l);color:var(--accent);font-weight:500}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:-8px;transform:translateY(-50%)}.nav-item.active .nav-icon{color:var(--accent)}.nav-icon{width:18px;color:var(--text3);flex-shrink:0;justify-content:center;align-items:center;transition:color .12s;display:flex}.nav-item:hover .nav-icon{color:var(--text2)}.nav-item-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.nav-badge{text-align:center;border-radius:20px;flex-shrink:0;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:600}.nav-badge--red{background:var(--red);color:#fff}.nav-badge--blue{background:var(--blue-l);color:var(--blue)}.nav-badge--amber{background:var(--amber-l);color:var(--amber)}.sidebar-footer{border-top:1px solid var(--border);padding:10px 14px}.sidebar-footer-text{color:var(--text3);text-align:center;font-size:11px}.main{background:var(--bg);flex:1;overflow-y:auto}.page-wrap{max-width:1200px;padding:1.5rem}.page{display:none}.page.active{display:block}.page-head{margin-bottom:1.25rem}.page-title{letter-spacing:-.3px;margin-bottom:3px;font-size:19px;font-weight:600}.page-sub{color:var(--text2);font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:1rem;padding:1.1rem 1.25rem}.card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:1rem;display:flex}.card-title{letter-spacing:-.2px;font-size:14px;font-weight:600}.card-sub{color:var(--text2);margin-top:2px;font-size:12px}.metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:1.25rem;display:grid}.metric{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:14px 16px}.metric-label{color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-size:11px;font-weight:500}.metric-value{letter-spacing:-.5px;font-size:26px;font-weight:700;line-height:1}.metric-sub{color:var(--text2);margin-top:4px;font-size:11px}.metric-trend{font-size:11px;font-weight:500}.trend-up{color:var(--accent)}.trend-dn{color:var(--red)}.btn{border-radius:var(--radius);cursor:pointer;border:1px solid var(--border2);background:var(--surface);color:var(--text);white-space:nowrap;font-size:13px;font-weight:500;font-family:var(--font);outline:none;align-items:center;gap:6px;padding:7px 14px;transition:all .12s;display:inline-flex}.btn:hover{background:var(--surface2)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent-d)}.btn-primary:hover{background:var(--accent-d)}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--surface2)}.btn-danger{background:var(--red-l);color:var(--red);border-color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}.btn-sm{padding:5px 11px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px}.btn-icon{border-radius:var(--radius);justify-content:center;width:32px;height:32px;padding:0}.btn-group{flex-wrap:wrap;gap:6px;display:flex}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.b-pending{background:var(--amber-l);color:var(--amber)}.b-active{background:var(--accent-l);color:var(--accent)}.b-frozen{background:var(--blue-l);color:var(--blue)}.b-done{background:var(--green-l);color:var(--green)}.b-review{background:var(--purple-l);color:var(--purple)}.b-rejected{background:var(--red-l);color:var(--red)}.b-hod{background:var(--blue-l);color:var(--blue)}.b-hr{background:var(--accent-l);color:var(--accent)}.b-lm{background:var(--amber-l);color:var(--amber)}.b-emp{background:var(--purple-l);color:var(--purple)}.tbl-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{text-align:left;color:var(--text2);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;background:var(--surface);padding:8px 12px;font-size:11px;font-weight:600}tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 12px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--surface2)}.form-group{margin-bottom:14px}.form-label{color:var(--text2);margin-bottom:5px;font-size:12px;font-weight:500;display:block}.form-control{border:1px solid var(--border2);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);font-size:13px;font-family:var(--font);outline:none;padding:8px 11px;transition:border .12s}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1a9e771f}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:72px;line-height:1.5}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.form-hint{color:var(--text3);margin-top:3px;font-size:11px}.two-col{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.three-col{grid-template-columns:1fr 1fr 1fr;gap:1rem;display:grid}.timeline{padding-left:28px;position:relative}.timeline:before{content:"";background:var(--border);width:2px;position:absolute;top:6px;bottom:6px;left:9px}.tl-item{margin-bottom:20px;position:relative}.tl-item:last-child{margin-bottom:0}.tl-dot{border:2px solid var(--accent);background:var(--surface);z-index:1;border-radius:50%;width:12px;height:12px;position:absolute;top:3px;left:-23px}.tl-dot.done{background:var(--accent);border-color:var(--accent)}.tl-dot.current{background:var(--amber-m);border-color:var(--amber-m);box-shadow:0 0 0 4px #ef9f2733}.tl-dot.future{border-color:var(--border2);background:var(--surface2)}.tl-title{margin-bottom:2px;font-size:13px;font-weight:600}.tl-desc{color:var(--text2);font-size:12px}.tl-date{color:var(--text3);margin-top:2px;font-size:11px}.progress{background:var(--surface3);border-radius:4px;height:7px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .4s}.tab-bar{border-bottom:1px solid var(--border);gap:2px;margin-bottom:1rem;display:flex}.tab-btn{cursor:pointer;color:var(--text2);font-size:13px;font-family:var(--font);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:9px 16px;font-weight:500;transition:all .12s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-panel{display:none}.tab-panel.active{display:block}.alert{border-radius:var(--radius);align-items:flex-start;gap:8px;margin-bottom:12px;padding:10px 14px;font-size:13px;line-height:1.5;display:flex}.alert-icon{flex-shrink:0;margin-top:1px}.alert-info{background:var(--blue-l);color:var(--blue);border:1px solid #b5d4f4}.alert-warn{background:var(--amber-l);color:var(--amber);border:1px solid #fac775}.alert-success{background:var(--accent-l);color:var(--accent);border:1px solid #9fe1cb}.alert-danger{background:var(--red-l);color:var(--red);border:1px solid #f7c1c1}.score-ring{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:12px;font-weight:700;display:inline-flex}.sr-hi{background:var(--green-l);color:var(--green)}.sr-mid{background:var(--amber-l);color:var(--amber)}.sr-lo{background:var(--red-l);color:var(--red)}.sr-none{background:var(--surface3);color:var(--text3)}.divider{background:var(--border);height:1px;margin:12px 0}.emp-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 0;display:flex}.emp-row:last-child{border-bottom:none}.mini-av{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:10px;font-weight:600;display:flex}.av-hr{color:#085041;background:#9fe1cb}.av-hod{color:#0c447c;background:#b5d4f4}.av-lm{color:#633806;background:#fac775}.av-emp{color:#3c3489;background:#cecbf6}.av-sm{width:24px;height:24px;font-size:9px}.kpi-cols{align-items:center;gap:8px;display:grid}.kpi-6{grid-template-columns:2fr 2.5fr 1fr 70px 70px 70px}.kpi-7{grid-template-columns:2fr 2fr 1fr 70px 70px 70px 80px}.kpi-head-row{color:var(--text3);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border);padding:6px 0 4px;font-size:10px;font-weight:600}.kpi-data-row{border-bottom:1px solid var(--border);padding:8px 0;font-size:13px}.kpi-data-row:last-child{border-bottom:none}.kpi-data-row:hover{background:0 0}.comp-level{color:var(--text2);max-width:200px;font-size:11px}.notif-dot{background:var(--red);border-radius:50%;flex-shrink:0;width:7px;height:7px}.notif-dot.warn{background:var(--amber-m)}.step-circle{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:flex}.sc-done{background:var(--accent);color:#fff}.sc-active{background:var(--amber-m);color:#fff}.sc-future{background:var(--surface3);color:var(--text3);border:1px solid var(--border2)}.approval-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);margin-bottom:10px;padding:14px 16px}.approval-card:hover{border-color:var(--border2)}.section-label{align-items:center;gap:8px;margin-bottom:10px;font-size:13px;font-weight:600;display:flex}.section-label:after{content:"";background:var(--border);flex:1;height:1px}.stat-box{text-align:center;border-radius:var(--radius-lg);padding:14px}input[type=number].score-input{text-align:center;border:1px solid var(--border2);border-radius:var(--radius);background:var(--surface);width:62px;color:var(--text);outline:none;padding:5px 6px;font-size:13px;font-weight:600}input[type=number].score-input:focus{border-color:var(--accent)}.level-bar{gap:3px;margin-top:4px;display:flex}.level-seg{background:var(--border);border-radius:2px;flex:1;height:4px}.level-seg.filled{background:var(--accent)}.role-tag{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}#toast{background:var(--text);color:var(--bg);border-radius:var(--radius-lg);opacity:0;pointer-events:none;z-index:9999;max-width:320px;box-shadow:var(--shadow-md);padding:10px 18px;font-size:13px;font-weight:500;transition:all .2s;position:fixed;bottom:24px;right:24px;transform:translateY(8px)}#toast.show{opacity:1;transform:translateY(0)}.modal-bg{z-index:500;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-xl);width:520px;max-width:95vw;max-height:85vh;box-shadow:var(--shadow-md);padding:1.5rem;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.modal-title{font-size:16px;font-weight:600}@media (max-width:900px){.metrics-grid{grid-template-columns:1fr 1fr}.two-col,.three-col,.form-grid{grid-template-columns:1fr}}@media (max-width:640px){.sidebar{display:none}.metrics-grid,.kpi-6,.kpi-7{grid-template-columns:1fr}}@media print{.sidebar,.app-header,.btn-group{display:none}.main{overflow:visible}.page-wrap{padding:0}}.chart-wrap{width:100%;position:relative;overflow:hidden}.bar-chart{align-items:flex-end;gap:6px;height:140px;padding:0 4px;display:flex}.bar-col{flex-direction:column;flex:1;align-items:center;gap:4px;height:100%;display:flex}.bar-col-inner{flex-direction:column;flex:1;justify-content:flex-end;width:100%;display:flex}.bar{cursor:pointer;border-radius:4px 4px 0 0;width:100%;min-height:4px;transition:opacity .15s}.bar:hover{opacity:.8}.bar-label{color:var(--text3);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:10px;overflow:hidden}.bar-val{color:var(--text2);text-align:center;font-size:10px;font-weight:600}.donut-wrap{align-items:center;gap:20px;display:flex}.donut-legend{flex-direction:column;flex:1;gap:8px;display:flex}.legend-item{align-items:center;gap:8px;font-size:12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.hbar-wrap{flex-direction:column;gap:10px;display:flex}.hbar-row{align-items:center;gap:10px;display:flex}.hbar-label{color:var(--text2);flex-shrink:0;min-width:90px;font-size:12px}.hbar-track{background:var(--surface3);border-radius:4px;flex:1;height:8px;overflow:hidden}.hbar-fill{border-radius:4px;height:100%;transition:width .6s}.hbar-val{text-align:right;min-width:28px;font-size:12px;font-weight:600}.sparkline{align-items:flex-end;gap:2px;height:32px;display:flex}.spark-bar{border-radius:2px 2px 0 0;flex:1;min-height:2px}.notif-panel{background:var(--surface);border-left:1px solid var(--border);z-index:200;flex-direction:column;width:360px;height:calc(100vh - 56px);transition:transform .22s;display:flex;position:fixed;top:56px;right:0;transform:translate(100%);box-shadow:-4px 0 20px #0000001a}.notif-panel.open{transform:translate(0)}.notif-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 18px 12px;display:flex}.notif-title{font-size:14px;font-weight:600}.notif-list{flex:1;overflow-y:auto}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:12px;padding:13px 18px;transition:background .1s;display:flex}.notif-item:hover{background:var(--surface2)}.notif-item.unread{background:var(--accent-l)}.notif-btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;width:36px;height:36px;color:var(--text2);justify-content:center;align-items:center;font-size:15px;display:flex;position:relative}.notif-btn:hover{background:var(--surface2)}.notif-count{background:var(--red);color:#fff;text-align:center;border:2px solid var(--surface);border-radius:20px;min-width:16px;padding:1px 5px;font-size:9px;font-weight:700;position:absolute;top:-5px;right:-5px}.band-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface2);margin-bottom:8px;padding:12px 14px}.band-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.band-name{flex:1;font-size:13px;font-weight:600}.band-code{background:var(--blue-l);color:var(--blue);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.grade-list{flex-wrap:wrap;gap:6px;padding-left:4px;display:flex}.grade-chip{background:var(--surface);border:1px solid var(--border2);color:var(--text2);border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:11px;font-weight:500;display:inline-flex}.rp-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);margin-bottom:10px;overflow:hidden}.rp-header{cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid #0000;align-items:center;gap:10px;padding:12px 16px;transition:background .12s;display:flex}.rp-header:hover{background:var(--surface2)}.rp-title{flex:1;font-size:13px;font-weight:600}.rp-meta{color:var(--text3);flex-wrap:wrap;gap:10px;font-size:11px;display:flex}.rp-body{padding:14px 16px;display:none}.rp-body.open{display:block}.skill-tag{white-space:nowrap;border-radius:20px;align-items:center;gap:5px;margin:2px;padding:3px 9px;font-size:11px;font-weight:500;display:inline-flex}.skill-req{background:var(--accent-l);color:var(--accent);border:1px solid #1a9e7740}.skill-pref{background:var(--blue-l);color:var(--blue);border:1px solid #185fa533}.kpi-level-org{border-left:3px solid var(--purple);background:var(--purple-l)}.kpi-level-dept{border-left:3px solid var(--blue);background:var(--blue-l)}.kpi-level-emp{border-left:3px solid var(--accent);background:var(--accent-l)}.kpi-builder-row{border-bottom:1px solid var(--border);grid-template-columns:1.8fr 2fr 1fr 70px 80px 90px 100px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;display:grid}.kpi-builder-row:last-child{border-bottom:none}.kpi-builder-row:hover{background:var(--surface2)}.kpi-builder-head{color:var(--text3);text-transform:uppercase;letter-spacing:.6px;border-bottom:2px solid var(--border);background:var(--surface2);grid-template-columns:1.8fr 2fr 1fr 70px 80px 90px 100px;padding:7px 12px;font-size:10px;font-weight:600}.kpi-source-org{background:var(--purple-l);color:var(--purple);border:1px solid #534ab733}.kpi-source-dept{background:var(--blue-l);color:var(--blue);border:1px solid #185fa533}.toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.toggle-row:last-child{border-bottom:none}.toggle{background:var(--surface3);cursor:pointer;border:none;border-radius:11px;flex-shrink:0;width:38px;height:22px;transition:background .15s;position:relative}.toggle.on{background:var(--accent)}.toggle:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:left .15s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.toggle.on:after{left:19px}.pip-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);margin-bottom:10px;padding:14px 16px}.pip-goal-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:6px 0;font-size:12px;display:flex}.pip-goal-row:last-child{border-bottom:none}.pip-progress-bar{background:var(--surface3);border-radius:3px;flex:1;height:6px;overflow:hidden}.pip-progress-fill{border-radius:3px;height:100%;transition:width .4s}.feedback-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);margin-bottom:10px;padding:14px 16px}.feedback-type-commendation{border-left:3px solid var(--accent)}.feedback-type-improvement{border-left:3px solid var(--amber-m)}.feedback-type-peer{border-left:3px solid var(--blue)}.feedback-tag{background:var(--surface2);color:var(--text2);border:1px solid var(--border);border-radius:20px;align-items:center;margin:2px;padding:2px 8px;font-size:10px;font-weight:500;display:inline-flex}.ld-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);margin-bottom:10px;padding:14px 16px}.team-member-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow);align-items:center;gap:12px;margin-bottom:8px;padding:14px 16px;transition:border-color .12s;display:flex}.team-member-card:hover{border-color:var(--border2)}.anomaly-row td{background:#a32d2d0f!important}.anomaly-row:hover td{background:#a32d2d1a!important}.anomaly-flag{color:var(--red);background:var(--red-l);border:1px solid #a32d2d4d;border-radius:20px;align-items:center;gap:4px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.bulk-check{cursor:pointer;width:16px;height:16px;accent-color:var(--accent)}.bulk-action-bar{background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius-lg);align-items:center;gap:10px;margin-bottom:10px;padding:10px 16px;font-size:13px;display:none}.bulk-action-bar.show{display:flex}.negotiation-item{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);margin-bottom:8px;padding:12px 16px}.negotiation-item.open-neg{border-color:var(--amber-m);background:var(--amber-l)}.negotiation-item.resolved{background:var(--green-l);border-color:#a8d982}.evidence-btn{border:1px dashed var(--border2);color:var(--text3);cursor:pointer;border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:11px;transition:all .12s;display:inline-flex}.evidence-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}.score-gauge-wrap{text-align:center;padding:8px 0}.score-gauge-val{letter-spacing:-1px;font-size:36px;font-weight:800;line-height:1}.score-gauge-label{color:var(--text3);margin-top:3px;font-size:11px}.score-breakdown{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.score-break-item{border-radius:var(--radius);border:1px solid var(--border);text-align:center;background:var(--surface2);flex:1;min-width:80px;padding:8px;font-size:11px}.score-break-val{margin-bottom:2px;font-size:16px;font-weight:700}.export-opt{border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;align-items:flex-start;gap:14px;margin-bottom:8px;padding:14px 16px;transition:all .12s;display:flex}.export-opt:hover{border-color:var(--accent);background:var(--accent-l)}.export-opt-icon{flex-shrink:0;margin-top:1px;font-size:22px}.export-opt-title{margin-bottom:2px;font-size:13px;font-weight:600}.export-opt-sub{color:var(--text2);font-size:12px}.emp-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;padding:14px}.emp-stat-val{margin:6px 0 3px;font-size:22px;font-weight:700}.emp-stat-label{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-size:11px}
