.avatar{border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0;position:relative;overflow:hidden}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-status:after{content:"";position:absolute;bottom:-2px;right:-2px;width:10px;height:10px;background:var(--success);border-radius:50%;border:2px solid var(--bg-sidebar)}.avatar-round{border-radius:50%}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-w);height:100vh;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;transition:width .35s cubic-bezier(.4,0,.2,1),background-color .4s ease,border-color .35s ease;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-c)}.sb-header{padding:18px 20px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--border);min-height:var(--topbar-h)}.sb-logo{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sb-logo img{width:100%;height:100%;object-fit:contain}.sb-brand{overflow:hidden;white-space:nowrap;transition:opacity .25s}.collapsed .sb-brand{opacity:0;pointer-events:none;width:0}.sb-brand-name{font-size:20px;font-weight:800;letter-spacing:3px;background:linear-gradient(135deg,var(--primary-400),var(--primary-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sb-brand-name .a-light{-webkit-text-fill-color:var(--silver-400)}.sb-brand-sub{font-size:9.5px;color:var(--text-3);letter-spacing:1px;text-transform:uppercase;font-weight:600}.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:10px}.sb-group{margin-bottom:6px}.sb-label{padding:10px 14px 5px;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;color:var(--text-3);white-space:nowrap;overflow:hidden;transition:opacity .25s,height .25s,padding .25s}.collapsed .sb-label{opacity:0;height:0;padding:0;overflow:hidden}.sb-item{display:flex;align-items:center;gap:13px;padding:10px 14px;border-radius:var(--r-sm);cursor:pointer;position:relative;white-space:nowrap;color:var(--text-2);border:1px solid transparent;transition:all .25s cubic-bezier(.4,0,.2,1)}.sb-item:hover{background:var(--bg-card-hover);color:var(--text-1);border-color:var(--border)}.sb-item.active{background:var(--bg-badge);color:var(--primary-400);border-color:#8b5cf626}.sb-item.active:before{content:"";position:absolute;left:-1px;top:50%;transform:translateY(-50%);width:3px;height:22px;background:linear-gradient(180deg,var(--primary-400),var(--primary-600));border-radius:0 4px 4px 0;animation:slideInLeft .3s ease-out}.sb-item i.icon{width:20px;text-align:center;font-size:15px;flex-shrink:0}.sb-item .label{font-size:13.5px;font-weight:500;transition:opacity .2s}.collapsed .sb-item .label{opacity:0;pointer-events:none}.sb-badge{margin-left:auto;font-size:10px;font-weight:700;padding:2px 8px;border-radius:var(--r-full);background:var(--primary-600);color:#fff;transition:opacity .2s}.collapsed .sb-badge{opacity:0}.sb-footer{padding:10px;border-top:1px solid var(--border)}.sb-user{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-md);cursor:pointer;transition:all .25s;margin-bottom:8px}.sb-user:hover{background:var(--bg-card-hover)}.sb-user-info{overflow:hidden;transition:opacity .2s}.collapsed .sb-user-info{opacity:0;width:0}.sb-user-name{font-size:13px;font-weight:600;color:var(--text-1)}.sb-user-role{font-size:11px;color:var(--text-3)}.sb-toggle{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px;border:1px solid var(--border);background:transparent;color:var(--text-3);border-radius:var(--r-sm);cursor:pointer;font-size:13px;transition:all .25s}.sb-toggle:hover{background:var(--bg-card-hover);border-color:var(--primary-500);color:var(--primary-400)}.sb-toggle span{transition:opacity .2s}.collapsed .sb-toggle span{opacity:0;display:none}.sb-toggle i{transition:transform .35s cubic-bezier(.4,0,.2,1)}.collapsed .sb-toggle i{transform:rotate(180deg)}.sb-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sb-overlay.on{display:block}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-w)}.sidebar.mob-open{transform:translate(0);box-shadow:20px 0 60px #00000080}}.topbar{position:sticky;top:0;height:var(--topbar-h);background:var(--bg-topbar);backdrop-filter:blur(24px) saturate(1.6);-webkit-backdrop-filter:blur(24px) saturate(1.6);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;z-index:90}.tb-left{display:flex;align-items:center;gap:16px}.tb-crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-3)}.tb-crumb .here{color:var(--text-1);font-weight:600}.tb-crumb i{font-size:9px}.tb-search{position:relative;width:340px}.tb-search input{width:100%;padding:10px 16px 10px 42px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-full);color:var(--text-1);font-family:inherit;font-size:13px;outline:none;transition:all .35s cubic-bezier(.4,0,.2,1)}.tb-search input::placeholder{color:var(--text-3)}.tb-search input:focus{border-color:var(--primary-500);box-shadow:0 0 0 4px #8b5cf61f;width:420px;background:var(--bg-card)}.tb-search .s-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px;pointer-events:none}.tb-search .s-key{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xs);padding:2px 8px;font-size:10.5px;color:var(--text-3);font-family:inherit;pointer-events:none}.tb-right{display:flex;align-items:center;gap:4px}.tb-btn{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-2);font-size:17px;transition:all .25s}.tb-btn:hover{background:var(--bg-card-hover);color:var(--primary-400);transform:translateY(-1px)}.tb-btn:active{transform:scale(.92)}.tb-btn .dot{position:absolute;top:7px;right:7px;width:9px;height:9px;background:var(--danger);border-radius:50%;border:2px solid var(--bg-body);animation:pulseDot 2s ease-in-out infinite}.theme-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-2);font-size:16px;transition:all .3s;overflow:hidden}.theme-btn:hover{background:var(--bg-card-hover);color:var(--warning);transform:rotate(15deg)}.theme-btn:active{transform:scale(.88) rotate(15deg)}.tb-divider{width:1px;height:28px;background:var(--border);margin:0 10px;flex-shrink:0}.tb-user{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;border-radius:var(--r-lg);cursor:pointer;transition:all .25s;border:1px solid transparent}.tb-user:hover{background:var(--bg-card-hover);border-color:var(--border)}.tb-user-info{line-height:1.3}.tb-user-name{font-size:13px;font-weight:600;color:var(--text-1)}.tb-user-role{font-size:10.5px;color:var(--text-3)}.tb-user .fa-chevron-down{font-size:10px;color:var(--text-3)}.mobile-btn{display:none;width:40px;height:40px;border:none;background:transparent;color:var(--text-2);font-size:20px;border-radius:var(--r-sm);align-items:center;justify-content:center}.mobile-btn:hover{background:var(--bg-card-hover)}@media(max-width:768px){.mobile-btn{display:flex}.tb-search,.tb-user-info{display:none}}.app{display:flex;min-height:100vh}.main{flex:1;margin-left:var(--sidebar-w);transition:margin-left .35s cubic-bezier(.4,0,.2,1);min-height:100vh}.main-collapsed{margin-left:var(--sidebar-c)}.content{padding:28px;max-width:1440px}@media(max-width:768px){.main{margin-left:0!important}.content{padding:16px}}.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:var(--r-full);font-family:inherit;font-size:13px;font-weight:600;border:none;cursor:pointer;position:relative;overflow:hidden;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn:active{transform:scale(.95)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:after{content:"";position:absolute;width:200px;height:200px;background:#ffffff40;border-radius:50%;transform:scale(0);opacity:0;pointer-events:none;top:var(--ripple-y, 50%);left:var(--ripple-x, 50%);transform-origin:center}.btn.ripple:after{animation:rippleAnim .65s ease-out}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;box-shadow:0 4px 16px #8b5cf659}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 28px #8b5cf673;background:linear-gradient(135deg,var(--primary-500),var(--primary-400))}.btn-glass{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-glass:hover:not(:disabled){background:#ffffff2e;transform:translateY(-2px)}.btn-outline{background:transparent;color:var(--primary-400);border:1px solid var(--primary-500)}.btn-outline:hover:not(:disabled){background:var(--bg-badge);transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-1)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-light);transform:translateY(-2px)}.btn-sm{padding:8px 16px;font-size:12px}.btn-lg{padding:14px 28px;font-size:14px}.input-group{display:flex;flex-direction:column;gap:6px}.input-label{font-size:12px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px}.input-wrapper{position:relative}.input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px;pointer-events:none}.input{width:100%;padding:11px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-full);color:var(--text-1);font-family:inherit;font-size:13px;outline:none;transition:all .35s cubic-bezier(.4,0,.2,1)}.input.has-icon{padding-left:42px}.input::placeholder{color:var(--text-3)}.input:focus{border-color:var(--primary-500);box-shadow:0 0 0 4px #8b5cf61f;background:var(--bg-card)}.input-error{border-color:var(--danger)!important}.input-error-text{font-size:11px;color:var(--danger);font-weight:500}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.textarea{border-radius:var(--r-md);min-height:80px;resize:vertical}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-body);position:relative;overflow:hidden}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.login-orb{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.12),transparent 70%)}.login-orb.orb-1{width:600px;height:600px;top:-20%;right:-15%;animation:orbFloat 8s ease-in-out infinite}.login-orb.orb-2{width:400px;height:400px;bottom:-20%;left:-10%;animation:orbFloat 6s ease-in-out infinite reverse}.login-orb.orb-3{width:200px;height:200px;top:40%;left:30%;animation:orbFloat 10s ease-in-out infinite 2s}.login-card{position:relative;z-index:1;width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-2xl);padding:48px 40px;box-shadow:var(--shadow-lg);animation:fadeUp .5s ease-out}.login-header{text-align:center;margin-bottom:36px}.login-logo{width:64px;height:64px;margin:0 auto 16px}.login-logo img{width:100%;height:100%;object-fit:contain}.login-brand{font-size:32px;font-weight:800;letter-spacing:4px;background:linear-gradient(135deg,var(--primary-400),var(--primary-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-brand .a-light{-webkit-text-fill-color:var(--silver-400)}.login-subtitle{color:var(--text-3);font-size:13px;margin-top:4px}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{padding:10px 16px;background:var(--danger-bg);color:var(--danger);border-radius:var(--r-sm);font-size:13px;font-weight:500}.login-btn{width:100%;justify-content:center;padding:14px;font-size:14px}.login-footer{text-align:center;color:var(--text-3);font-size:11px;margin-top:32px}.welcome{position:relative;padding:34px 38px;border-radius:var(--r-2xl);background:linear-gradient(135deg,var(--primary-900) 0%,var(--primary-700) 40%,var(--primary-500) 100%);overflow:hidden;margin-bottom:28px}.welcome:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.06) 50%,transparent 70%);background-size:200% 100%;animation:shimmer 4s ease-in-out infinite}.welcome .orb{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);pointer-events:none}.welcome .orb-1{width:400px;height:400px;top:-50%;right:-10%;animation:orbFloat 8s ease-in-out infinite}.welcome .orb-2{width:250px;height:250px;bottom:-40%;left:30%;animation:orbFloat 6s ease-in-out infinite reverse}.welcome .orb-3{width:150px;height:150px;top:20%;left:-5%;animation:orbFloat 10s ease-in-out infinite 2s}.welcome-inner{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:24px}.welcome h1{font-size:28px;font-weight:800;color:#fff;margin-bottom:8px}.wave-emoji{display:inline-block;animation:wave 2.5s ease-in-out infinite;transform-origin:70% 70%}.welcome p{color:#ffffffb8;font-size:14.5px;max-width:560px;line-height:1.7}.welcome p strong{color:#fff}.welcome-btns{display:flex;gap:10px;margin-top:18px}.welcome-date{text-align:right;color:#ffffff8c;flex-shrink:0}.welcome-date .day{font-size:48px;font-weight:900;color:#fff;line-height:1}.welcome-date .month{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:3px}.welcome-date .year{font-size:13px;margin-top:2px}@media(max-width:768px){.welcome-inner{flex-direction:column}.welcome-date{text-align:left}}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}.stat{background:var(--bg-card);background-image:var(--gradient-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;position:relative;overflow:hidden;cursor:default;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.stat:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--primary-500)}.stat:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-500),var(--primary-300));border-radius:var(--r-xl) var(--r-xl) 0 0;opacity:0;transition:opacity .3s}.stat:hover:before{opacity:1}.stat:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 40%,rgba(139,92,246,.03) 50%,transparent 60%);background-size:300% 100%;opacity:0;transition:opacity .3s}.stat:hover:after{opacity:1;animation:shimmer 2s ease-in-out infinite}.stat-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;position:relative;z-index:1}.stat-icon{width:48px;height:48px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:19px;transition:transform .3s}.stat:hover .stat-icon{transform:scale(1.1) rotate(-5deg)}.stat-icon.purple{background:var(--bg-badge);color:var(--primary-400)}.stat-icon.green{background:var(--success-bg);color:var(--success)}.stat-icon.blue{background:var(--info-bg);color:var(--info)}.stat-icon.amber{background:var(--warning-bg);color:var(--warning)}.stat-trend{display:flex;align-items:center;gap:4px;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:var(--r-full)}.stat-trend.up{color:var(--success);background:var(--success-bg)}.stat-trend.down{color:var(--danger);background:var(--danger-bg)}.stat-val{font-size:34px;font-weight:800;line-height:1;margin-bottom:5px;position:relative;z-index:1}.stat-lbl{font-size:13px;color:var(--text-3);font-weight:500;position:relative;z-index:1}@media(max-width:768px){.stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.stats{grid-template-columns:1fr}}.bars{display:flex;gap:10px;align-items:flex-end;height:200px;padding:0 4px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}.bar{width:100%;border-radius:var(--r-sm) var(--r-sm) 4px 4px;min-height:8px;cursor:pointer;position:relative;animation:growBar .9s cubic-bezier(.4,0,.2,1) both}.bar:hover{filter:brightness(1.25)}.bar:after{content:attr(data-tip);position:absolute;top:-32px;left:50%;transform:translate(-50%) translateY(6px);background:var(--bg-tooltip);color:var(--text-1);font-size:11px;font-weight:600;padding:4px 10px;border-radius:var(--r-xs);white-space:nowrap;opacity:0;pointer-events:none;transition:all .25s;border:1px solid var(--border);box-shadow:var(--shadow-md)}.bar:hover:after{opacity:1;transform:translate(-50%) translateY(0)}.bar.purple{background:linear-gradient(180deg,var(--primary-400),var(--primary-700))}.bar.silver{background:linear-gradient(180deg,var(--silver-400),var(--silver-600));opacity:.45}.bar-lbl{font-size:11px;color:var(--text-3);font-weight:600}.chart-legend{display:flex;gap:20px;padding:14px 4px 0;margin-top:14px;border-top:1px solid var(--border-subtle)}.legend-item{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-3)}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.purple{background:var(--primary-500)}.legend-dot.silver{background:var(--silver-400);opacity:.5}.list-col{display:flex;flex-direction:column;gap:12px}.list-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-input);border-radius:var(--r-md);border:1px solid var(--border-subtle);cursor:pointer;transition:all .28s cubic-bezier(.4,0,.2,1)}.list-item:hover{border-color:var(--primary-500);background:var(--bg-card-hover);transform:translate(5px);box-shadow:var(--shadow-md)}.list-info{flex:1;min-width:0}.list-name{font-size:13.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-sub{font-size:11.5px;color:var(--text-3);margin-top:1px}.list-progress{display:flex;flex-direction:column;align-items:flex-end;gap:6px;min-width:100px}.pct{font-size:12px;font-weight:700;color:var(--primary-400)}.pbar{width:100px;height:6px;background:var(--border-subtle);border-radius:var(--r-full);overflow:hidden}.pfill{height:100%;background:linear-gradient(90deg,var(--primary-600),var(--primary-400));border-radius:var(--r-full);animation:fillW 1.1s cubic-bezier(.4,0,.2,1) both}.feed{display:flex;flex-direction:column;gap:0}.feed-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-subtle)}.feed-item:last-child{border-bottom:none}.feed-icon{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.feed-icon.purple{background:var(--bg-badge);color:var(--primary-400)}.feed-icon.green{background:var(--success-bg);color:var(--success)}.feed-icon.blue{background:var(--info-bg);color:var(--info)}.feed-icon.amber{background:var(--warning-bg);color:var(--warning)}.feed-icon.red{background:var(--danger-bg);color:var(--danger)}.feed-body{flex:1}.feed-text{font-size:13px;color:var(--text-2);line-height:1.55}.feed-text strong{color:var(--text-1);font-weight:600}.feed-time{font-size:11px;color:var(--text-3);margin-top:3px}.qgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.qbtn{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 14px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--r-lg);cursor:pointer;color:var(--text-2);font-family:inherit;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.qbtn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--primary-600),var(--primary-400));opacity:0;transition:opacity .35s;border-radius:inherit}.qbtn:hover{border-color:var(--primary-500);transform:translateY(-3px);box-shadow:var(--shadow-glow);color:#fff}.qbtn:hover:before{opacity:1}.qbtn:active{transform:translateY(-1px) scale(.97)}.qbtn i{font-size:22px;position:relative;z-index:1;transition:transform .35s}.qbtn:hover i{transform:scale(1.2) rotate(-5deg)}.qbtn span{font-size:11.5px;font-weight:600;position:relative;z-index:1;text-align:center}@media(max-width:768px){.qgrid{grid-template-columns:1fr}}.bday-list{display:flex;flex-direction:column;gap:10px}.bday-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-input);border-radius:var(--r-md);border:1px solid var(--border-subtle);transition:all .25s}.bday-item:hover{background:var(--bg-card-hover);border-color:var(--border);transform:translate(3px)}.bday-info{flex:1}.bday-name{font-size:13px;font-weight:600}.bday-date{font-size:11px;color:var(--text-3)}.bday-emoji{font-size:22px;animation:bFloat 2.5s ease-in-out infinite}.approval-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-input);border-radius:var(--r-md);border:1px solid var(--border-subtle);transition:all .25s}.approval-item:hover{background:var(--bg-card-hover);border-color:var(--border)}.approval-info{flex:1}.approval-name{font-size:13px;font-weight:600}.approval-detail{font-size:11.5px;color:var(--text-3);margin-top:1px}.approval-actions{display:flex;gap:6px}.abtn{width:34px;height:34px;border-radius:var(--r-sm);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;transition:all .25s}.abtn:active{transform:scale(.88)}.abtn.ok{background:var(--success-bg);color:var(--success)}.abtn.ok:hover{background:var(--success);color:#fff;box-shadow:0 4px 12px #10b9814d}.abtn.no{background:var(--danger-bg);color:var(--danger)}.abtn.no:hover{background:var(--danger);color:#fff;box-shadow:0 4px 12px #ef44444d}.donut{position:relative;width:170px;height:170px;margin:0 auto 16px;flex-shrink:0}.donut svg{width:100%;height:100%;transform:rotate(-90deg)}.donut circle{fill:none;stroke-width:14;stroke-linecap:round}.donut .bg{stroke:var(--border)}.donut .fill{stroke:url(#purpleGradient);stroke-dasharray:0 440;animation:donutAnim 1.6s cubic-bezier(.4,0,.2,1) forwards;animation-delay:.6s;filter:drop-shadow(0 0 6px rgba(139,92,246,.3))}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.donut-val{font-size:30px;font-weight:800;color:var(--primary-400)}.donut-lbl{font-size:11px;color:var(--text-3);font-weight:500}.dept-layout{display:flex;gap:28px;align-items:center}@media(max-width:600px){.dept-layout{flex-direction:column}}.dept-list{display:flex;flex-direction:column;gap:13px;flex:1}.dept-row{display:flex;align-items:center;gap:12px}.dept-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dept-nm{font-size:13px;color:var(--text-2);flex:1}.dept-ct{font-size:13px;font-weight:700;color:var(--text-1);min-width:28px;text-align:right}.dept-bar{width:80px;height:5px;background:var(--border-subtle);border-radius:var(--r-full);overflow:hidden}.dept-fill{height:100%;border-radius:var(--r-full);animation:fillW 1s ease-out both}.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.status-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-input);border-radius:var(--r-md);border:1px solid var(--border-subtle)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--success);box-shadow:0 0 8px #10b98180;animation:pulseDot 2s infinite}.status-dot.warn{background:var(--warning);box-shadow:0 0 8px #f59e0b80}.status-name{font-size:12px;color:var(--text-2);flex:1}.status-val{font-size:12px;font-weight:700;color:var(--text-1)}.card{background:var(--bg-card);background-image:var(--gradient-card);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{box-shadow:var(--shadow-lg)}.card-h{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 14px}.card-t{font-size:15px;font-weight:700;display:flex;align-items:center;gap:9px;color:var(--text-1)}.card-t i{color:var(--primary-400);font-size:14px}.card-a{font-size:12px;color:var(--primary-400);font-weight:600;cursor:pointer;padding:5px 12px;border-radius:var(--r-full);border:none;background:transparent;font-family:inherit;display:flex;align-items:center;gap:5px;transition:all .25s}.card-a:hover{background:var(--bg-badge);transform:translate(2px)}.card-b{padding:0 24px 24px}.grid-main{display:grid;grid-template-columns:1fr 400px;gap:24px}.grid-left,.grid-right{min-width:0}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}.mt-24{margin-top:24px}.mt-8{margin-top:8px}@media(max-width:1200px){.grid-main,.grid-2{grid-template-columns:1fr}}.table-wrapper{overflow-x:auto;border-radius:var(--r-md);border:1px solid var(--border)}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);background:var(--bg-input);border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:12px 16px;border-bottom:1px solid var(--border-subtle);color:var(--text-2)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr.clickable{cursor:pointer}.table tbody tr.clickable:hover{background:var(--bg-card-hover)}.table tbody tr.clickable:hover td{color:var(--text-1)}.table-empty{text-align:center;padding:40px 16px!important;color:var(--text-3)}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 0}.pg-btn{width:36px;height:36px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .25s}.pg-btn:hover:not(:disabled){background:var(--bg-card-hover);color:var(--primary-400);border-color:var(--primary-500)}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.pg-info{font-size:13px;color:var(--text-3);font-weight:500}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--r-full);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;background:var(--bg-badge);color:var(--primary-400)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-purple{background:var(--bg-badge);color:var(--primary-400)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-title{font-size:24px;font-weight:800}.page-subtitle{font-size:13px;color:var(--text-3);margin-top:4px}.page-actions{display:flex;gap:10px;align-items:center}.filter-bar{display:flex;gap:12px;margin-bottom:20px;align-items:center}.filter-search{flex:1;max-width:400px}.view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}.vt-btn{width:36px;height:36px;border:none;background:transparent;color:var(--text-3);display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .2s}.vt-btn:hover{color:var(--text-1);background:var(--bg-card-hover)}.vt-btn.active{color:var(--primary-400);background:var(--bg-badge)}.emp-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.emp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;cursor:pointer;transition:all .3s}.emp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-500)}.emp-card-name{font-size:14px;font-weight:700;margin-top:4px}.emp-card-role{font-size:12px;color:var(--text-2)}.emp-card-area{font-size:11px;color:var(--text-3)}.emp-cell{display:flex;align-items:center;gap:12px}.emp-cell-name{font-size:13px;font-weight:600;color:var(--text-1)}.emp-cell-sub{font-size:11px;color:var(--text-3)}.emp-profile{display:flex;align-items:center;gap:20px;margin:20px 0 24px;padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl)}.emp-profile-name{font-size:22px;font-weight:800}.emp-profile-role{font-size:14px;color:var(--text-2);margin-top:4px}.emp-profile-meta{display:flex;align-items:center;gap:12px;margin-top:8px}.emp-profile-id{font-size:12px;color:var(--text-3);font-weight:600}.detail-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:0;overflow-x:auto}.detail-tab{padding:10px 20px;border:none;background:transparent;color:var(--text-3);font-size:13px;font-weight:600;font-family:inherit;border-bottom:2px solid transparent;transition:all .25s;white-space:nowrap}.detail-tab:hover{color:var(--text-1)}.detail-tab.active{color:var(--primary-400);border-bottom-color:var(--primary-500)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.detail-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin-bottom:4px}.detail-value{font-size:14px;color:var(--text-1);font-weight:500}.text-muted{color:var(--text-3);font-size:13px;text-align:center;padding:32px 0}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeUp .2s ease-out}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;max-height:85vh;display:flex;flex-direction:column;animation:fadeUp .3s ease-out}.modal-sm{max-width:420px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-xl{max-width:1000px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:700}.modal-close{width:32px;height:32px;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-3);font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .25s}.modal-close:hover{background:var(--bg-card-hover);color:var(--text-1)}.modal-body{padding:24px;overflow-y:auto}.org-tree{padding:8px 0}.org-node-wrapper{margin-bottom:4px}.org-node{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .25s}.org-node:hover{background:var(--bg-card-hover);border-color:var(--primary-500);transform:translate(3px)}.org-node-color{width:6px;height:36px;border-radius:3px;flex-shrink:0}.org-node-info{flex:1}.org-node-name{font-size:14px;font-weight:700}.org-node-head{font-size:12px;color:var(--text-2)}.org-node-count{font-size:11px;color:var(--text-3);margin-top:2px}.org-node-arrow{font-size:11px;color:var(--text-3);transition:transform .2s}.org-children{margin-left:32px;padding-left:16px;border-left:2px solid var(--border);margin-top:4px}.onb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}.onb-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px;transition:all .3s;cursor:pointer}.onb-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--primary-500)}.onb-card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.onb-card-info{flex:1}.onb-card-name{font-size:14px;font-weight:700}.onb-card-role{font-size:12px;color:var(--text-3)}.onb-card-body{margin-bottom:14px}.onb-card-template{font-size:12px;color:var(--text-2);font-weight:600;margin-bottom:4px}.onb-card-dates{font-size:11px;color:var(--text-3)}.onb-progress-bar{height:6px;background:var(--border-subtle);border-radius:var(--r-full);overflow:hidden;margin-bottom:6px}.onb-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-600),var(--primary-400));border-radius:var(--r-full);transition:width .8s ease}.onb-progress-label{font-size:11px;color:var(--primary-400);font-weight:700;text-align:right}.pending-list{display:flex;flex-direction:column;gap:12px}.pending-card{display:flex;align-items:center;gap:16px;padding:18px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);transition:all .25s}.pending-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-500)}.pending-info{flex:1}.pending-name{font-size:14px;font-weight:700}.pending-detail{font-size:12px;color:var(--text-3);margin-top:3px}.pending-actions{display:flex;gap:8px}:root{--primary-50: #f5f0ff;--primary-100: #ede5ff;--primary-200: #ddd0ff;--primary-300: #c4a8ff;--primary-400: #a875ff;--primary-500: #8b5cf6;--primary-600: #7c3aed;--primary-700: #6d28d9;--primary-800: #5b21b6;--primary-900: #4c1d95;--silver-50: #f8fafc;--silver-100: #f1f5f9;--silver-200: #e2e8f0;--silver-300: #cbd5e1;--silver-400: #94a3b8;--silver-500: #64748b;--silver-600: #475569;--silver-700: #334155;--silver-800: #1e293b;--silver-900: #0f172a;--success: #10b981;--success-light: #34d399;--success-bg: rgba(16, 185, 129, .12);--warning: #f59e0b;--warning-light: #fbbf24;--warning-bg: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-light: #f87171;--danger-bg: rgba(239, 68, 68, .12);--info: #3b82f6;--info-light: #60a5fa;--info-bg: rgba(59, 130, 246, .12);--r-xs: 8px;--r-sm: 12px;--r-md: 16px;--r-lg: 20px;--r-xl: 24px;--r-2xl: 28px;--r-full: 9999px;--sidebar-w: 272px;--sidebar-c: 78px;--topbar-h: 66px;--t-theme: background .45s ease, color .35s ease, border-color .35s ease, box-shadow .35s ease, fill .35s ease, stroke .35s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-body);color:var(--text-1);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:var(--t-theme)}*,*:before,*:after{transition:background-color .4s ease,border-color .35s ease,box-shadow .35s ease,color .3s ease}.progress-fill,.chart-bar,.dept-bar-fill,.donut-fill{transition:none!important}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--primary-700);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--primary-500)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}::selection{background:var(--primary-600);color:#fff}img{max-width:100%}[data-theme=dark]{--bg-body: #08060e;--bg-sidebar: #0c0a14;--bg-topbar: rgba(12, 10, 20, .82);--bg-card: #110e1a;--bg-card-hover: #19142a;--bg-input: #16122a;--bg-badge: rgba(139, 92, 246, .14);--bg-tooltip: #221c38;--border: rgba(139, 92, 246, .1);--border-subtle: rgba(255,255,255,.045);--text-1: #f1f5f9;--text-2: #a6afc0;--text-3: #64748b;--shadow-sm: 0 2px 8px rgba(0,0,0,.25);--shadow-md: 0 4px 24px rgba(0,0,0,.3), 0 0 0 1px rgba(139,92,246,.06);--shadow-lg: 0 8px 40px rgba(139,92,246,.12), 0 0 0 1px rgba(139,92,246,.1);--shadow-glow: 0 0 40px rgba(139,92,246,.18);--shadow-inset: inset 0 1px 0 rgba(255,255,255,.03);--gradient-card: linear-gradient(180deg, rgba(139,92,246,.04) 0%, transparent 100%)}[data-theme=light]{--bg-body: #f4f2f8;--bg-sidebar: #ffffff;--bg-topbar: rgba(255,255,255,.82);--bg-card: #ffffff;--bg-card-hover: #faf8ff;--bg-input: #f0edf6;--bg-badge: rgba(109, 40, 217, .07);--bg-tooltip: #ffffff;--border: rgba(109, 40, 217, .1);--border-subtle: rgba(0,0,0,.055);--text-1: #1a1530;--text-2: #5a5477;--text-3: #9890ad;--shadow-sm: 0 1px 4px rgba(109,40,217,.05);--shadow-md: 0 2px 12px rgba(109,40,217,.06), 0 0 0 1px rgba(109,40,217,.05);--shadow-lg: 0 8px 32px rgba(109,40,217,.08), 0 0 0 1px rgba(109,40,217,.08);--shadow-glow: 0 0 32px rgba(109,40,217,.08);--shadow-inset: inset 0 1px 0 rgba(255,255,255,.8);--gradient-card: linear-gradient(180deg, rgba(109,40,217,.02) 0%, transparent 100%)}@keyframes fadeUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeRight{0%{opacity:0;transform:translate(22px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes orbFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-25px) scale(1.05)}}@keyframes wave{0%,60%,to{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}@keyframes pulseDot{0%,to{transform:scale(1);box-shadow:0 0 #ef444480}50%{transform:scale(1.15);box-shadow:0 0 0 4px #ef444400}}@keyframes bFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-5px) rotate(8deg)}}@keyframes growBar{0%{height:0!important}}@keyframes fillW{0%{width:0!important}}@keyframes donutAnim{to{stroke-dasharray:var(--da) 440}}@keyframes rippleAnim{to{transform:scale(4);opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes skeleton{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-up{animation:fadeUp .55s ease-out both}.fade-right{animation:fadeRight .5s ease-out both}.skeleton{background:linear-gradient(90deg,var(--bg-input) 25%,var(--bg-card-hover) 50%,var(--bg-input) 75%);background-size:200% 100%;animation:skeleton 1.5s infinite;border-radius:var(--r-sm)}
