:root{--primary:#1a56db;--primary-hover:#1e40af;--primary-light:#1a56db14;--sidebar-bg:#001529;--sidebar-bg-hover:#ffffff14;--sidebar-bg-active:#1a56db;--bg-page:#f0f2f5;--bg-card:#fff;--text-primary:#262626;--text-secondary:#595959;--text-muted:#8c8c8c;--border:#f0f0f0;--border-light:#f5f5f5;--success:#52c41a;--warning:#faad14;--danger:#ff4d4f;--info:#1677ff;--radius-sm:4px;--radius:6px;--radius-lg:8px;--radius-xl:12px;--shadow-sm:0 1px 2px #0000000f;--shadow:0 2px 8px #00000014;--shadow-md:0 4px 16px #0000001f;--shadow-lg:0 8px 32px #00000029;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", "Helvetica Neue", sans-serif;--text-xs:12px;--text-sm:13px;--text-base:14px;--text-lg:16px;--text-xl:18px;--text-2xl:22px;--text-3xl:28px;--text-4xl:36px;--sidebar-width:220px;--sidebar-collapsed:64px;--header-height:56px;--space-sm:8px;--space-md:16px;--space-lg:24px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--text-base)}body{height:100%;font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.55}#app{height:100%;min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-hover)}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);z-index:100;background:var(--sidebar-bg);flex-direction:column;transition:width .3s cubic-bezier(.4,0,.2,1),min-width .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}.sidebar-logo{height:var(--header-height);border-bottom:1px solid #ffffff14;flex-shrink:0;align-items:center;gap:10px;padding:0 20px;display:flex}.sidebar-logo .logo-icon{flex-shrink:0;font-size:30px;line-height:1}.sidebar-logo .logo-img{object-fit:cover;border-radius:10px;flex-shrink:0;width:44px;height:44px}.sidebar-logo .logo-text{color:#fff;font-size:var(--text-lg);white-space:nowrap;letter-spacing:.5px;font-weight:700;overflow:hidden}.sidebar-nav{flex:1;padding:8px 0;overflow:hidden auto}.nav-item{color:#ffffffa6;cursor:pointer;white-space:nowrap;align-items:center;gap:10px;margin:2px 0;padding:10px 20px;font-size:14px;font-weight:400;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item:hover{color:#fff;background:var(--sidebar-bg-hover)}.nav-item.active,.nav-item.router-link-active{color:#fff;background:var(--sidebar-bg-active);font-weight:500}.nav-item .nav-icon{text-align:center;opacity:.7;flex-shrink:0;width:20px;font-size:16px;line-height:1;transition:opacity .2s}.nav-item:hover .nav-icon,.nav-item.active .nav-icon,.nav-item.router-link-active .nav-icon{opacity:1}.nav-item .nav-label{text-overflow:ellipsis;overflow:hidden}.menu-group{margin:2px 0}.menu-parent{cursor:pointer;color:#ffffffa6;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:10px 20px;font-size:14px;transition:all .2s;display:flex;position:relative}.menu-parent:hover{color:#fff;background:var(--sidebar-bg-hover)}.menu-parent.active{color:#fff;background:var(--sidebar-bg-active)}.menu-arrow{opacity:.5;margin-left:auto;font-size:10px;transition:transform .3s}.menu-arrow.open{opacity:.8;transform:rotate(180deg)}.submenu{background:#00000026;margin:0;padding:4px 0;overflow:hidden}.submenu a{color:#ffffff80;padding:8px 14px 8px 50px;font-size:13px;text-decoration:none;transition:all .2s;display:block}.submenu a:hover{color:#ffffffd9;background:#ffffff0a}.submenu a.active,.submenu a.router-link-active{color:#fff;background:#1a56db4d}.sidebar-bottom{border-top:1px solid #ffffff14;flex-shrink:0;padding:10px 12px}.collapse-btn{color:#ffffff80;cursor:pointer;border-radius:var(--radius);width:100%;font-size:13px;font-family:var(--font-sans);background:#ffffff0d;border:1px solid #ffffff14;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.collapse-btn:hover{color:#ffffffd9;background:#ffffff1a;border-color:#ffffff26}.main-area{z-index:1;background:var(--bg-page);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.topbar{height:var(--header-height);border-bottom:1px solid var(--border);z-index:50;background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex;box-shadow:0 1px 4px #0000000a}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-left h2{font-size:var(--text-lg);color:var(--text-primary);letter-spacing:-.2px;font-weight:600}.topbar-right{align-items:center;gap:16px;display:flex}.user-info{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.logout-btn{color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;font-size:12px;font-family:var(--font-sans);background:0 0;border:1px solid #d9d9d9;padding:6px 16px;transition:all .2s}.logout-btn:hover{border-color:var(--danger);color:var(--danger);background:#ff4d4f0a}.page-content{z-index:1;flex:1;padding:24px;position:relative;overflow-y:auto}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:24px}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:14px;display:flex}.card-title{font-size:var(--text-lg);color:var(--text-primary);font-weight:600}.stat-grid{grid-template-columns:repeat(8,1fr);gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;align-items:center;gap:12px;padding:14px 16px;transition:all .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow);border-color:var(--primary);transform:translateY(-2px)}.stat-icon-box{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.stat-icon-box.blue{color:#1677ff;background:#e6f4ff}.stat-icon-box.green{color:#52c41a;background:#f6ffed}.stat-icon-box.orange{color:#fa8c16;background:#fff7e6}.stat-icon-box.purple{color:#722ed1;background:#f9f0ff}.stat-icon-box.cyan{color:#13c2c2;background:#e6fffb}.stat-icon-box.red{color:#ff4d4f;background:#fff2f0}.stat-icon-box.pink{color:#eb2f96;background:#fff0f6}.stat-icon-box.indigo{color:#2f54eb;background:#f0f5ff}.stat-info{flex:1;min-width:0}.stat-value{color:var(--text-primary);letter-spacing:-.5px;font-size:22px;font-weight:700;line-height:1.2}.stat-label{color:var(--text-secondary);white-space:nowrap;margin-top:2px;font-size:11px;font-weight:400}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;font-size:13px;font-weight:500;line-height:1.4;font-family:var(--font-sans);color:var(--text-primary);background:#fff;border:1px solid #d9d9d9;justify-content:center;align-items:center;gap:6px;padding:6px 16px;transition:all .2s;display:inline-flex}.btn:hover:not(:disabled){color:var(--primary);border-color:var(--primary)}.btn:active:not(:disabled){transform:translateY(1px)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px #1a56db14}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover);color:#fff}.btn-default{color:var(--text-secondary);background:#fff;border:1px solid #d9d9d9}.btn-default:hover{color:var(--primary);border-color:var(--primary)}.btn-secondary{color:var(--text-primary);background:#fff;border:1px solid #d9d9d9}.btn-secondary:hover:not(:disabled){background:#fafafa;border-color:#b3b3b3}.btn-danger{color:var(--danger);border:1px solid var(--danger);background:#fff}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff;border-color:var(--danger)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){color:#fff;background:#389e0d;border-color:#389e0d}.btn-info{background:var(--info);color:#fff;border-color:var(--info)}.btn-info:hover:not(:disabled){color:#fff;background:#0958d9;border-color:#0958d9}.btn-warning{color:#d48806;background:#fff;border:1px solid #ffc53d}.btn-warning:hover:not(:disabled){border-color:var(--warning);background:#fffbe6}.btn-outline{color:var(--text-secondary);background:0 0;border-color:#d9d9d9}.btn-outline:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.btn-sm{border-radius:var(--radius-sm);padding:4px 12px;font-size:12px}.btn-xs{border-radius:var(--radius-sm);padding:2px 10px;font-size:11px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.badge{letter-spacing:.2px;white-space:nowrap;border-radius:100px;align-items:center;padding:2px 10px;font-size:11px;font-weight:500;line-height:1.6;display:inline-flex}.badge-primary{color:#1677ff;background:#e6f4ff}.badge-success{color:#52c41a;background:#f6ffed}.badge-danger{color:#ff4d4f;background:#fff2f0}.badge-warning{color:#d48806;background:#fff7e6}.badge-info{color:#1677ff;background:#e6f4ff}.badge-secondary{color:#8c8c8c;background:#f5f5f5}.badge-purple{color:#722ed1;background:#f9f0ff}.table-wrap,.table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border);background:#fff;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}table tbody tr:nth-child(2n){background:#fafafa}table th,table td{text-align:left;border-bottom:1px solid var(--border);color:var(--text-primary);padding:11px 16px}table th{color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;background:#fafafa;font-size:12px;font-weight:500;position:sticky;top:0}table tbody tr:hover td{background:#f0f5ff}.search-input{border-radius:var(--radius);width:260px;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238c8c8c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cpath d='m21 21-4.3-4.3'%3E%3C/path%3E%3C/svg%3E") 10px no-repeat;border:1px solid #d9d9d9;outline:none;padding:8px 12px 8px 34px;transition:all .3s}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #1a56db1a}.search-input::placeholder{color:#bfbfbf}.toolbar .search-input{background-position:8px;width:160px;padding:5px 8px 5px 30px;font-size:12px}.form-select{border-radius:var(--radius);color:var(--text-primary);cursor:pointer;appearance:none;min-width:130px;font-size:13px;font-family:var(--font-sans);background:#fff 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='%238c8c8c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'%3E%3C/path%3E%3C/svg%3E") right 10px center no-repeat;border:1px solid #d9d9d9;outline:none;padding:8px 32px 8px 12px;transition:all .3s}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #1a56db1a}.toolbar .form-select{background-position:right 6px center;width:auto;min-width:100px;max-width:140px;padding:5px 24px 5px 8px;font-size:12px}.filter-bar{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);background:#fff;margin-bottom:16px;padding:20px 24px}.filter-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.filter-item{flex-direction:row;align-items:center;gap:6px;display:flex}.filter-item label{color:var(--text-secondary);white-space:nowrap;margin-bottom:0;font-size:13px;font-weight:500}.filter-item .form-input,.filter-item .form-select{width:140px;min-width:auto}.filter-actions{align-items:center;gap:8px;display:flex}.form-group{margin-bottom:16px}.form-group label,.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input{border-radius:var(--radius);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);background:#fff;border:1px solid #d9d9d9;outline:none;padding:8px 12px;transition:all .3s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #1a56db1a}.form-input::placeholder{color:#bfbfbf}textarea.form-input{resize:vertical;min-height:80px}.form-hint{color:var(--text-secondary);margin-top:4px;font-size:11px}.form-error{color:var(--danger);margin-top:4px;font-size:11px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.date-input{border-radius:var(--radius);color:var(--text-primary);cursor:pointer;min-width:140px;font-size:13px;font-family:var(--font-sans);background:#fff;border:1px solid #d9d9d9;outline:none;padding:8px 12px;transition:all .3s}.date-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #1a56db1a}.toolbar .date-input{width:130px;padding:5px 8px;font-size:12px}.toolbar{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fafafa;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:14px 18px;display:flex}.toolbar-left{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.toolbar-right{align-items:center;gap:8px;display:flex}.pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:20px;margin-top:16px;padding:16px 0 0;display:flex}.pagination-info,.pagination .page-info{color:var(--text-secondary);white-space:nowrap;font-size:13px}.pagination-btns{flex-wrap:wrap;gap:4px;display:flex}.pagination-btns button,.pagination button{border-radius:var(--radius-sm);cursor:pointer;min-width:32px;height:32px;color:var(--text-secondary);font-size:13px;font-weight:400;font-family:var(--font-sans);background:#fff;border:1px solid #d9d9d9;justify-content:center;align-items:center;padding:0 8px;transition:all .2s;display:inline-flex}.pagination-btns button:hover:not(:disabled),.pagination button:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.pagination-btns button.active,.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:500}.pagination-btns button:disabled,.pagination button:disabled{opacity:.3;cursor:not-allowed}.pagination-btns .ellipsis{min-width:32px;height:32px;color:var(--text-muted);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:13px;display:flex}.page-size-select{border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;appearance:none;font-size:13px;font-family:var(--font-sans);background:#fff 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='%238c8c8c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'%3E%3C/path%3E%3C/svg%3E") right 8px center no-repeat;border:1px solid #d9d9d9;outline:none;padding:6px 28px 6px 10px;transition:all .2s}.page-size-select:focus{border-color:var(--primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--border);background:#fff;border-radius:16px;flex-direction:column;width:90%;max-width:560px;max-height:85vh;animation:.3s cubic-bezier(.16,1,.3,1) modalIn;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000026,0 0 0 1px #00000008}.modal-lg{max-width:720px}.modal-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-header h3{font-size:var(--text-lg);color:#1e293b;font-weight:600}.modal-close{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:all .2s;display:flex}.modal-close:hover{color:#1e293b;background:#e2e8f0}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);background:#fafafa;justify-content:flex-end;gap:8px;padding:14px 24px;display:flex}.tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab{color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:400;font-family:var(--font-sans);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 20px;transition:all .2s}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:500}.tab-content{animation:.2s fadeIn}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-header h1{font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.3px;font-weight:700}.page-header p{color:var(--text-secondary);margin-top:4px;font-size:13px}.empty-state{text-align:center;color:var(--text-muted);padding:56px 24px}.empty-state .empty-icon{opacity:.3;margin-bottom:16px;font-size:52px;display:block}.empty-state .empty-text,.empty-state p{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.confirm-content,.confirm-dialog{text-align:center;padding:8px 0}.confirm-icon{opacity:.4;margin-bottom:14px;font-size:48px}.confirm-title{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:8px;font-weight:600}.confirm-text{color:var(--text-secondary);margin-bottom:20px;font-size:13px}.chart-container{width:100%;height:340px}.charts-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.charts-grid-full{grid-template-columns:1fr;gap:20px;display:grid}.section-title{font-size:var(--text-base);color:var(--text-primary);border-left:3px solid var(--primary);margin-bottom:16px;padding-left:12px;font-weight:600}.section-label{font-size:var(--text-base);color:var(--text-primary);margin-bottom:16px;font-weight:600}.quick-actions{margin-bottom:28px}.quick-actions-grid,.quick-actions{grid-template-columns:repeat(6,1fr);gap:12px;display:grid}.quick-action-card,.quick-action{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;color:var(--text-primary);box-shadow:var(--shadow-sm);flex-direction:column;align-items:center;gap:6px;padding:16px 10px;font-size:12px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.quick-action-card:hover,.quick-action:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-1px)}.qa-icon{font-size:28px;transition:transform .2s}.quick-action-card:hover .qa-icon,.quick-action:hover .qa-icon{transform:scale(1.1)}.qa-label{color:var(--text-primary);font-size:13px;font-weight:500}.login-page{background:#f0f2f5 50%/cover no-repeat;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:#0000004d;position:absolute;inset:0}.login-card{z-index:2;border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);background:#fff;width:420px;padding:48px 40px;animation:.5s modalIn;position:relative}.login-card .login-logo{border-radius:var(--radius-lg);background:var(--primary);color:#fff;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:26px;display:flex}.login-card h1{text-align:center;font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.3px;margin-bottom:6px;font-weight:700}.login-card .login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:13px}.login-card .form-group label,.login-card .form-label{color:var(--text-secondary);font-size:12px;font-weight:500}.login-card .form-input{border-radius:var(--radius);color:var(--text-primary);font-size:var(--text-base);border:1px solid #d9d9d9;padding:10px 14px}.login-card .form-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #1a56db1a}.login-card .btn-primary{border-radius:var(--radius);justify-content:center;width:100%;margin-top:8px;padding:10px;font-size:15px}.login-error{color:var(--danger);border-radius:var(--radius);background:#fff2f0;border:1px solid #ffccc7;margin-bottom:20px;padding:10px 14px;font-size:13px}.loading-wrap{justify-content:center;align-items:center;padding:48px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex{display:flex}.flex-gap{gap:12px}.flex-wrap{flex-wrap:wrap}.gap-sm{gap:8px}.gap-md{gap:16px}.mt-md{margin-top:16px}.mb-md{margin-bottom:16px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0003}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.96)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}@media (width<=1024px){.charts-grid,.form-row{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(4,1fr)}}@media (width<=768px){.stat-grid{grid-template-columns:repeat(2,1fr)}.quick-actions{grid-template-columns:repeat(3,1fr)}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}.sidebar{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}.sidebar .logo-text,.sidebar .nav-label,.sidebar .menu-group,.sidebar .menu-arrow{display:none!important}.nav-item{justify-content:center;padding:10px 8px}.page-content{padding:16px}.modal{max-width:calc(100vw - 32px)}}@media (width<=640px){.login-card{width:90vw;padding:32px 24px}.topbar{padding:0 16px}}.toast-stack[data-v-f5118959]{z-index:10000;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;top:20px;left:50%;transform:translate(-50%)}.toast[data-v-f5118959]{pointer-events:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;align-items:center;gap:10px;min-width:200px;max-width:420px;padding:12px 24px;font-size:14px;font-weight:500;display:flex;box-shadow:0 8px 32px #0000001f}.toast-success[data-v-f5118959]{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.toast-error[data-v-f5118959]{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.toast-info[data-v-f5118959]{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.toast-warning[data-v-f5118959]{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.toast-icon[data-v-f5118959]{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:700;display:flex}.toast-success .toast-icon[data-v-f5118959]{color:#fff;background:#22c55e}.toast-error .toast-icon[data-v-f5118959]{color:#fff;background:#ef4444}.toast-info .toast-icon[data-v-f5118959]{color:#fff;background:#3b82f6}.toast-warning .toast-icon[data-v-f5118959]{color:#fff;background:#f59e0b}.toast-msg[data-v-f5118959]{line-height:1.4}.toast-enter-active[data-v-f5118959]{transition:all .3s}.toast-leave-active[data-v-f5118959]{transition:all .25s}.toast-enter-from[data-v-f5118959]{opacity:0;transform:translateY(-16px)scale(.92)}.toast-leave-to[data-v-f5118959]{opacity:0;transform:translateY(-8px)scale(.95)}
