:root{--bg-base:#f5f7fa;--bg-surface:#fff;--bg-elevated:#fff;--bg-overlay:#f0f2f5;--bg-input:#f5f7fa;--text-primary:#1a1a2e;--text-secondary:#4a4a68;--text-tertiary:#8c8ca1;--text-disabled:#b4b4c4;--border-default:#e2e5ea;--border-subtle:#eef0f4;--border-strong:#ccd0d8;--accent-blue:#3b82f6;--accent-purple:#8b5cf6;--accent-cyan:#06b6d4;--accent-green:#10b981;--accent-amber:#f59e0b;--accent-red:#ef4444;--glow-blue:#3b82f61a;--glow-purple:#8b5cf61a;--glow-cyan:#06b6d41a;--glass-bg:#fff9;--glass-border:#fffc;--glass-blur:16px;--shadow-sm:0 1px 3px #0000000f, 0 4px 12px #0000000a;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001a;--shadow-xl:0 16px 48px #0000001f;--shadow-glow:0 0 20px var(--glow-blue);--radius-xs:6px;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:20px;--font-sans:"Inter", "Outfit", -apple-system, "PingFang SC", "Microsoft YaHei", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Menlo", monospace;--text-page-title:28px;--text-section-title:16px;--text-card-title:15px;--text-body:14px;--text-caption:13px;--text-small:12px;--text-label:11px;--gradient-primary:linear-gradient(135deg, var(--accent-blue), var(--accent-purple));--gradient-cyan:linear-gradient(135deg, var(--accent-cyan), var(--accent-blue));--gradient-border:linear-gradient(135deg, #3b82f64d, #8b5cf64d);--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in:cubic-bezier(.7, 0, .84, 0);--duration-fast:.15s;--duration:.25s;--duration-slow:.4s;--sidebar-bg:#ffffffb3;--sidebar-text:#4a4a68;--sidebar-text-dim:#4a4a688c;--sidebar-border:#0000000f;--sidebar-hover:#3b82f60f;--sidebar-active-bg:#3b82f61a;--sidebar-icon:#4a4a6873;--login-card-bg:#ffffffd9;--login-hero-deco:#3b82f60f;--el-bg-color:var(--bg-surface);--el-bg-color-overlay:var(--bg-elevated);--el-bg-color-page:var(--bg-base);--el-text-color-primary:var(--text-primary);--el-text-color-regular:var(--text-secondary);--el-text-color-secondary:var(--text-tertiary);--el-text-color-placeholder:var(--text-disabled);--el-border-color:var(--border-default);--el-border-color-light:var(--border-subtle);--el-border-color-lighter:var(--border-subtle);--el-fill-color:var(--bg-overlay);--el-fill-color-light:var(--bg-elevated);--el-fill-color-lighter:var(--bg-surface);--el-fill-color-blank:var(--bg-surface);--el-mask-color:#0006;--el-mask-color-extra-light:#00000026;--van-primary-color:var(--accent-blue);--van-success-color:var(--accent-green);--van-danger-color:var(--accent-red);--van-warning-color:var(--accent-amber);--van-background-2:var(--bg-surface);--van-background:var(--bg-base);--van-text-color:var(--text-primary);--van-text-color-2:var(--text-secondary);--van-text-color-3:var(--text-tertiary);--van-border-color:var(--border-default);--van-active-color:var(--bg-overlay);--van-nav-bar-background:#ffffffdb;--van-tabbar-background:#fffffff0;--van-card-background:var(--bg-surface)}[data-theme=dark]{--bg-base:#0a0a0a;--bg-surface:#111;--bg-elevated:#1a1a1a;--bg-overlay:#222;--bg-input:#181818;--text-primary:#f0f0f0;--text-secondary:#a0a0a0;--text-tertiary:#666;--text-disabled:#444;--border-default:#2a2a2a;--border-subtle:#1e1e1e;--border-strong:#3a3a3a;--accent-blue:#3b82f6;--accent-purple:#8b5cf6;--accent-cyan:#06b6d4;--accent-green:#10b981;--accent-amber:#f59e0b;--accent-red:#ef4444;--glow-blue:#3b82f626;--glow-purple:#8b5cf626;--glow-cyan:#06b6d426;--glass-bg:#ffffff08;--glass-border:#ffffff0f;--glass-blur:16px;--shadow-sm:0 1px 2px #0000004d, 0 4px 12px #00000026;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-xl:0 16px 48px #0009;--shadow-glow:0 0 20px var(--glow-blue);--sidebar-bg:#1119;--sidebar-text:#ffffff8c;--sidebar-text-dim:#ffffff59;--sidebar-border:#ffffff0f;--sidebar-hover:#ffffff0f;--sidebar-active-bg:#3b82f61f;--sidebar-icon:#ffffff59;--login-card-bg:#111c;--login-hero-deco:#3b82f614;--el-bg-color:var(--bg-surface);--el-bg-color-overlay:var(--bg-elevated);--el-bg-color-page:var(--bg-base);--el-text-color-primary:var(--text-primary);--el-text-color-regular:var(--text-secondary);--el-text-color-secondary:var(--text-tertiary);--el-text-color-placeholder:var(--text-disabled);--el-border-color:var(--border-default);--el-border-color-light:var(--border-subtle);--el-border-color-lighter:var(--border-subtle);--el-fill-color:var(--bg-overlay);--el-fill-color-light:var(--bg-elevated);--el-fill-color-lighter:var(--bg-surface);--el-fill-color-blank:var(--bg-surface);--el-mask-color:#000000b3;--el-mask-color-extra-light:#0000004d;--van-primary-color:var(--accent-blue);--van-success-color:var(--accent-green);--van-danger-color:var(--accent-red);--van-warning-color:var(--accent-amber);--van-background-2:var(--bg-surface);--van-background:var(--bg-base);--van-text-color:var(--text-primary);--van-text-color-2:var(--text-secondary);--van-text-color-3:var(--text-tertiary);--van-border-color:var(--border-default);--van-active-color:var(--bg-overlay);--van-nav-bar-background:#111111eb;--van-tabbar-background:#111111f5;--van-card-background:var(--bg-surface)}*,:before,:after{box-sizing:border-box}body{min-width:320px;color:var(--text-primary);background:radial-gradient(circle at top left, var(--glow-blue), transparent 28%), radial-gradient(circle at top right, var(--glow-purple), transparent 22%), var(--bg-base);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--duration-slow), color var(--duration-slow);margin:0;font-size:14px;line-height:1.65}#app{min-height:100vh}::selection{background:var(--accent-blue);color:#fff}[data-theme=light] ::selection{background:var(--accent-blue);color:#fff}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.page-enter-active{transition:opacity var(--duration) var(--ease-out)}.page-enter-from{opacity:0}.fade-enter-active{transition:opacity var(--duration) var(--ease-out)}.fade-enter-from{opacity:0}.page{min-height:100dvh;padding:32px 28px}.shell{max-width:1520px;transition:grid-template-columns var(--duration) var(--ease-out);grid-template-columns:248px minmax(0,1fr);gap:28px;margin:0 auto;display:grid;position:relative}.sidebar-collapsed .shell{grid-template-columns:76px minmax(0,1fr)}.sidebar{background:var(--sidebar-bg);height:calc(100vh - 64px);-webkit-backdrop-filter:blur(var(--glass-blur));border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--glass-border);transition:background var(--duration-slow), border-color var(--duration-slow), box-shadow var(--duration-slow);flex-direction:column;display:flex;position:sticky;top:32px;overflow:hidden}[data-theme=dark] .page--student .sidebar{background:#0a0e1499}.sidebar-backdrop{display:none}.collapse-toggle{cursor:pointer;color:var(--sidebar-text-dim);transition:color var(--duration-fast), background var(--duration-fast);border-top:1px solid var(--sidebar-border);justify-content:center;align-items:center;margin-top:auto;padding:14px 12px;display:flex}.collapse-toggle:hover{color:var(--text-primary);background:var(--sidebar-hover)}.collapse-toggle .el-icon{font-size:16px}.sidebar-collapsed .sidebar{width:76px;min-width:76px}.sidebar-collapsed .brand{justify-content:center;padding:18px 14px;display:flex}.sidebar-collapsed .brand-logo{gap:0}.sidebar-collapsed .brand-icon{width:36px;height:36px;font-size:15px}.sidebar-collapsed .el-menu{padding:6px 4px}.sidebar-collapsed .el-menu-item{justify-content:center;padding:0 8px!important}.sidebar-collapsed .el-menu-item .el-icon{margin-right:0!important}.sidebar-collapsed .sidebar-footer{display:none}.brand{border-bottom:1px solid var(--sidebar-border);padding:24px 20px 20px}.brand-logo{align-items:center;gap:12px;display:flex}.brand-icon{background:var(--gradient-primary);color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:17px;font-weight:700;display:flex}.brand h2{color:var(--text-primary);letter-spacing:-.2px;margin:0;font-size:17px;font-weight:700;line-height:1.2}.brand p{color:var(--text-tertiary);font-size:var(--text-label);letter-spacing:.2px;margin:3px 0 0}.user-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;align-items:center;gap:10px;margin:14px 14px 8px;padding:12px 14px;display:flex}.user-avatar{background:var(--gradient-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.user-name{font-size:var(--text-caption);color:var(--text-primary);font-weight:600}.user-role{font-size:var(--text-label);color:var(--text-tertiary)}.user-pulse{background:var(--accent-cyan);border-radius:50%;width:8px;height:8px;margin-left:auto;box-shadow:0 0 #06b6d480}.el-menu{flex:1;padding:6px 10px;overflow-y:auto;background:0 0!important;border-right:none!important}.el-menu-item,.el-sub-menu__title{transition:background var(--duration-fast), color var(--duration-fast);margin-bottom:4px;font-size:13px;font-weight:500;border-radius:var(--radius-sm)!important;height:42px!important;color:var(--sidebar-text)!important;padding:0 12px!important;line-height:42px!important}.el-menu-item:hover,.el-sub-menu__title:hover{background:var(--sidebar-hover)!important;color:var(--text-primary)!important}.el-menu-item.is-active{font-weight:600;box-shadow:inset 0 0 0 1px #3b82f626;background:var(--sidebar-active-bg)!important;color:var(--accent-blue)!important}.el-menu-item .el-icon,.el-sub-menu__title .el-icon{transition:color var(--duration-fast);font-size:15px;color:var(--sidebar-icon)!important;margin-right:8px!important}.el-menu-item.is-active .el-icon,.el-menu-item:hover .el-icon,.el-sub-menu__title:hover .el-icon{color:var(--text-secondary)!important}.el-sub-menu .el-menu{background:var(--bg-overlay)!important;border-radius:var(--radius-sm)!important;padding:6px!important}.el-sub-menu .el-menu .el-menu-item{height:38px!important;padding-left:28px!important;font-size:12px!important;line-height:38px!important}.sidebar-footer{border-top:1px solid var(--sidebar-border);font-size:var(--text-label);color:var(--text-disabled);text-align:center;letter-spacing:.3px;padding:14px 20px}.sidebar-header{display:contents}.mobile-hamburger{cursor:pointer;width:36px;height:36px;color:var(--sidebar-text);border-radius:var(--radius-sm);transition:background var(--duration-fast);justify-content:center;align-items:center;display:none}.mobile-hamburger:hover{background:var(--sidebar-hover)}.content{align-content:start;gap:24px;display:grid}.page-title{border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:flex-end;gap:16px;min-height:90px;margin-bottom:6px;padding:8px 4px 18px;display:flex;position:relative}.page-title:after{content:"";background:linear-gradient(90deg, var(--accent-blue), #3b82f600);will-change:transform;border-radius:999px;width:100px;height:3px;position:absolute;bottom:-1px;left:4px}.page--student .page-title:after{background:linear-gradient(90deg, var(--accent-cyan), #06b6d400)}.page-title h1{font-size:var(--text-page-title);letter-spacing:-.4px;color:var(--text-primary);margin:0;font-weight:700;line-height:1.2}.page-title p{color:var(--text-tertiary);font-size:var(--text-caption);margin:5px 0 0;line-height:1.6}.page-title__copy{min-width:0}.page-title__meta{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.page-chip{min-height:28px;color:var(--accent-blue);letter-spacing:.3px;background:#3b82f61a;border-radius:999px;align-items:center;padding:0 12px;font-size:11px;font-weight:600;display:inline-flex}.page-chip--soft{color:var(--text-secondary);border:1px solid var(--border-default);background:#ffffff0a}.page--student .page-chip{color:var(--accent-cyan);background:#06b6d41a}.muted{color:var(--text-tertiary)}.text-page-title{font-size:var(--text-page-title);color:var(--text-primary);letter-spacing:-.3px;font-weight:700;line-height:1.3}.text-section-title{font-size:var(--text-section-title);color:var(--text-primary);font-weight:700;line-height:1.4}.text-card-title{font-size:var(--text-card-title);color:var(--text-primary);font-weight:600;line-height:1.4}.text-body{font-size:var(--text-body);color:var(--text-secondary);line-height:1.6}.text-caption{font-size:var(--text-caption);color:var(--text-tertiary);line-height:1.6}.text-small{font-size:var(--text-small);color:var(--text-tertiary);line-height:1.5}.text-label{font-size:var(--text-label);color:var(--text-tertiary);letter-spacing:.4px;font-weight:600;line-height:1.4}.login-page{background:radial-gradient(circle at top left, var(--glow-blue), transparent 34%), radial-gradient(circle at bottom left, var(--glow-purple), transparent 26%), var(--bg-base);grid-template-columns:minmax(0,1fr) 480px;gap:0;min-height:100dvh;display:grid;position:relative;overflow:hidden}.login-logo{z-index:10;cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity var(--duration-fast) var(--ease-out);position:fixed;top:24px;left:28px}.login-logo:hover{opacity:.8}.login-logo-icon{border-radius:var(--radius);object-fit:contain;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);border:1px solid #3b82f626;width:56px;height:56px;padding:8px;display:block}.login-page:before{content:"";pointer-events:none;z-index:0;width:400px;height:400px;animation:float-subtle 7s var(--ease-out) infinite;border:1px solid #3b82f614;border-radius:50%;position:absolute;top:12%;right:40%}.login-page:after{content:"";pointer-events:none;z-index:0;width:220px;height:220px;animation:float-subtle 5.5s var(--ease-out) infinite 1.5s;border:1px solid #8b5cf60f;border-radius:50%;position:absolute;bottom:6%;left:30%}.login-hero{z-index:1;will-change:transform;flex-direction:column;justify-content:center;padding:72px 72px 64px;display:flex;position:relative}.login-hero:before{content:"";background:var(--accent-blue);width:52px;height:3px;position:absolute;top:48px;left:72px}.login-hero:after{content:"";background:radial-gradient(circle, var(--login-hero-deco), transparent 65%);pointer-events:none;z-index:-1;width:300px;height:300px;animation:float-subtle 8s var(--ease-out) infinite 2s;border-radius:50%;position:absolute;bottom:-10px;right:8%}.login-hero h1{letter-spacing:-1.5px;color:var(--text-primary);margin:0 0 20px;font-size:56px;font-weight:700;line-height:1.04}.login-hero h1 span{background:var(--gradient-primary);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text}.login-hero .hero-sub{max-width:400px;color:var(--text-secondary);font-size:var(--text-card-title);margin:0 0 44px;line-height:1.85}.hero-divider{background:var(--accent-blue);width:40px;height:2px;animation:float-subtle 4s var(--ease-out) infinite .5s;margin-bottom:24px}.hero-features{flex-direction:column;gap:12px;display:flex;position:relative}.hero-feature{color:var(--text-secondary);border-radius:var(--radius);transition:background var(--duration-fast), transform var(--duration-fast) var(--ease-out);will-change:transform;align-items:center;gap:14px;padding:6px 12px 6px 6px;font-size:14px;display:flex}.hero-feature:hover{background:var(--sidebar-hover);transform:translate(4px)}.hero-feature-icon{border-radius:var(--radius-sm);background:var(--gradient-primary);color:#fff;width:32px;height:32px;transition:transform var(--duration-fast) var(--ease-out);flex-shrink:0;justify-content:center;align-items:center;font-size:15px;display:flex}.hero-feature:hover .hero-feature-icon{transform:scale(1.06)}.login-card{background:var(--login-card-bg);border-left:1px solid var(--glass-border);z-index:1;-webkit-backdrop-filter:blur(20px);flex-direction:column;justify-content:center;padding:64px 56px;display:flex;position:relative;box-shadow:-4px 0 24px #00000014}.login-card:before{content:"";background:linear-gradient(180deg, transparent, var(--accent-blue), transparent);opacity:.3;width:1px;position:absolute;top:10%;bottom:10%;left:0}.login-card h2{font-size:var(--text-page-title);color:var(--text-primary);letter-spacing:-.3px;margin:0 0 6px;font-weight:700}.login-card .login-muted{font-size:var(--text-caption);color:var(--text-tertiary);margin:0 0 36px}.login-form .el-form-item{margin-bottom:20px}.form-item-role{margin-bottom:24px}.form-item-role .el-form-item__label{font-weight:600}.form-item-role .el-segmented{width:100%}.form-item-role .el-segmented .el-segmented__item{flex:1;justify-content:center}.login-form-footnote{text-align:center;color:var(--text-tertiary);margin-top:18px;padding-top:0;font-size:12px}.login-form .el-input__wrapper{border-radius:var(--radius)!important;box-shadow:0 0 0 1px var(--border-default) inset!important;background:var(--bg-input)!important;transition:box-shadow var(--duration-fast)!important}.login-form .el-input__wrapper:hover{box-shadow:0 0 0 1px var(--accent-blue) inset!important}.login-form .el-input__wrapper.is-focus{box-shadow:inset 0 0 0 2px #3b82f640!important}.login-submit{letter-spacing:.5px;will-change:transform;width:100%;height:46px;margin-top:6px;font-size:14px;font-weight:600;border-radius:var(--radius)!important;background:var(--gradient-primary)!important;transition:box-shadow var(--duration-fast), transform var(--duration-fast) var(--ease-out)!important;border:none!important}.login-submit:hover{transform:translateY(-1px);box-shadow:0 0 24px #3b82f659!important}.login-submit:active{transform:scale(.98)!important}.login-footer{border-top:1px solid var(--border-subtle);color:var(--text-tertiary);text-align:center;margin-top:28px;padding-top:20px;font-size:12px}.el-card{transition:box-shadow var(--duration), border-color var(--duration), transform var(--duration);will-change:transform;overflow:hidden;border-radius:var(--radius-lg)!important;border:1px solid var(--border-default)!important;box-shadow:var(--shadow-sm)!important;background:var(--bg-surface)!important}.el-card:hover{transform:translateY(-1px);box-shadow:0 0 20px var(--glow-blue)!important;border-color:#3b82f633!important}.el-card__header{color:var(--text-primary);font-size:14px;font-weight:600;border-bottom:1px solid var(--border-subtle)!important;background:var(--bg-overlay)!important;padding:16px 18px!important}.el-card__body{padding:18px!important}.el-button{letter-spacing:.1px;position:relative;border-radius:var(--radius-sm)!important;transition:all var(--duration-fast) var(--ease-out)!important;font-size:13px!important;font-weight:500!important}.el-button:active{transform:scale(.97)}.el-button:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.el-button--primary{background:var(--gradient-primary)!important;color:#fff!important;border:none!important}.el-button--primary:hover{transform:translateY(-1px);box-shadow:0 0 20px #3b82f64d!important}.el-button--primary:active{box-shadow:none!important;transform:scale(.97)!important}.el-button--primary.is-plain{color:var(--accent-blue)!important;background:#3b82f61a!important;border:1px solid #3b82f640!important}.el-button--primary.is-plain:hover{transform:translateY(-.5px);background:var(--gradient-primary)!important;color:#fff!important;box-shadow:0 0 16px #3b82f640!important}.el-button--success.is-plain{color:var(--accent-green)!important;background:#10b9811a!important;border:1px solid #10b98140!important}.el-button--success.is-plain:hover{transform:translateY(-.5px);background:var(--accent-green)!important;color:#fff!important;box-shadow:0 0 16px #10b98140!important}.el-button--warning.is-plain{color:var(--accent-amber)!important;background:#f59e0b1a!important;border:1px solid #f59e0b40!important}.el-button--warning.is-plain:hover{transform:translateY(-.5px);background:var(--accent-amber)!important;color:#fff!important;box-shadow:0 0 16px #f59e0b40!important}.el-button--danger.is-plain{color:var(--accent-red)!important;background:#ef44441a!important;border:1px solid #ef444440!important}.el-button--danger.is-plain:hover{transform:translateY(-.5px);background:var(--accent-red)!important;color:#fff!important;box-shadow:0 0 16px #ef444440!important}.el-button.is-plain:active{transform:scale(.97)!important}.el-button--danger:not(.is-plain):not(.is-link){background:var(--accent-red)!important;border-color:var(--accent-red)!important}.el-button--danger:not(.is-plain):not(.is-link):hover{background:#dc2626!important;border-color:#dc2626!important}.el-button--success:not(.is-plain):not(.is-link){background:var(--accent-green)!important;border-color:var(--accent-green)!important}.el-button--success:not(.is-plain):not(.is-link):hover{background:#059669!important;border-color:#059669!important}.el-button--warning:not(.is-plain):not(.is-link){background:var(--accent-amber)!important;border-color:var(--accent-amber)!important}.el-button--warning:not(.is-plain):not(.is-link):hover{background:#d97706!important;border-color:#d97706!important}.el-button.is-link{transition:color var(--duration-fast), opacity var(--duration-fast)!important;padding:4px 8px!important;font-weight:500!important}.el-button.is-link:hover{opacity:.75}.el-button--large{padding:12px 24px!important;font-size:14px!important}.el-button--small{font-size:12px!important}.el-button+.el-button{margin-left:8px}.el-button-group{gap:0;display:inline-flex}.el-button-group .el-button:not(:last-child){border-right-color:#ffffff1a!important}.el-table{--el-table-border-color:var(--border-subtle);--el-table-header-bg-color:var(--bg-overlay);--el-table-header-text-color:var(--text-secondary);--el-table-bg-color:transparent;--el-table-tr-bg-color:transparent;--el-table-row-hover-bg-color:var(--sidebar-hover);--el-table-text-color:var(--text-primary);font-size:13px;overflow:hidden;border-radius:var(--radius)!important}.el-table th.el-table__cell{text-transform:uppercase;letter-spacing:.4px;font-size:12px!important;font-weight:600!important}.el-table--striped .el-table__body tr.el-table__row--striped td.el-table__cell{background:var(--bg-overlay)!important}.el-table__row:hover>td.el-table__cell{background:var(--sidebar-hover)!important}.el-input__wrapper{border-radius:var(--radius-sm)!important;box-shadow:0 0 0 1px var(--border-default) inset!important;background:var(--bg-input)!important;transition:box-shadow var(--duration-fast)!important}.el-input__wrapper:hover{box-shadow:0 0 0 1px var(--accent-blue) inset!important}.el-input__wrapper.is-focus{box-shadow:inset 0 0 0 2px #3b82f640!important}.el-textarea__inner{color:var(--text-primary);border-radius:var(--radius-sm)!important;box-shadow:0 0 0 1px var(--border-default) inset!important;background:var(--bg-input)!important}.el-textarea__inner:focus{box-shadow:inset 0 0 0 2px #3b82f640!important}.el-segmented{padding:3px;border:1px solid var(--border-default)!important;border-radius:var(--radius-sm)!important;background:var(--bg-input)!important}.el-segmented__item{border-radius:4px!important;font-size:13px!important;font-weight:500!important}.el-segmented__item.is-selected{background:var(--accent-blue)!important;color:#fff!important}.el-radio__inner{border-color:var(--border-default)!important}.el-radio.is-checked .el-radio__inner{border-color:var(--accent-blue)!important;background:var(--accent-blue)!important}.el-checkbox__inner{border-color:var(--border-default)!important;background:var(--bg-input)!important}.el-checkbox.is-checked .el-checkbox__inner{border-color:var(--accent-blue)!important;background:var(--accent-blue)!important}.el-switch{--el-switch-off-color:var(--bg-overlay)!important;--el-switch-on-color:var(--accent-blue)!important}.el-tag{letter-spacing:.3px;border-radius:var(--radius-xs)!important;padding:0 6px!important;font-size:11px!important;font-weight:600!important}.el-tag--primary{color:var(--accent-blue)!important;background:#3b82f626!important;border-color:#3b82f633!important}.el-tag--success{color:var(--accent-green)!important;background:#10b98126!important;border-color:#10b98133!important}.el-tag--warning{color:var(--accent-amber)!important;background:#f59e0b26!important;border-color:#f59e0b33!important}.el-tag--danger{color:var(--accent-red)!important;background:#ef444426!important;border-color:#ef444433!important}.el-tag--info{background:var(--bg-overlay)!important;border-color:var(--border-default)!important;color:var(--text-tertiary)!important}.el-statistic .el-statistic__head{margin-bottom:2px;text-transform:uppercase!important;letter-spacing:.5px!important;color:var(--text-tertiary)!important;font-size:11px!important;font-weight:600!important}.el-statistic .el-statistic__number{letter-spacing:-.5px;font-family:var(--font-sans);font-variant-numeric:tabular-nums;color:var(--text-primary)!important;font-size:28px!important;font-weight:700!important}.el-progress-bar__outer{background:var(--bg-overlay)!important;border-radius:99px!important}.el-progress-bar__inner{transition:width .8s var(--ease-out)!important;border-radius:99px!important}.el-dialog{-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-xl)!important;border:1px solid var(--glass-border)!important;background:var(--bg-elevated)!important}.el-dialog__header{color:var(--text-primary)!important;padding:22px 28px 0!important;font-size:16px!important;font-weight:700!important}.el-dialog__body{padding:20px 28px!important}.el-dialog__footer{justify-content:flex-end;gap:10px;display:flex;padding:0 28px 22px!important}.el-dialog__footer .el-button{margin-left:0!important}.el-drawer{border-radius:var(--radius-lg) 0 0 var(--radius-lg)!important;background:var(--bg-elevated)!important}.el-drawer__header{border-bottom:1px solid var(--border-subtle);padding:20px 24px!important;font-weight:700!important}.el-drawer__body{padding:20px 24px!important}.el-steps{--el-step-title-font-size:13px;--el-step-description-font-size:12px}.el-step__title{font-weight:600!important}.el-step__icon-inner{font-size:13px!important}.el-descriptions--small{--el-descriptions-item-bordered-label-background:var(--bg-overlay)}.el-descriptions__label{color:var(--text-tertiary)!important;font-size:12px!important;font-weight:600!important}.el-descriptions__content{color:var(--text-secondary)!important;font-size:13px!important}.el-divider{border-color:var(--border-subtle)!important}.el-divider__text{background-color:var(--bg-surface)!important;color:var(--text-tertiary)!important;font-size:12px!important;font-weight:500!important}.announce-item{padding:12px 0}.announce-item--unread{background:var(--sidebar-active-bg);border-radius:var(--radius);margin:0 -16px;padding:12px 16px}.announce-item__header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.announce-item__header strong{color:var(--text-primary);font-size:14px;font-weight:600}.announce-item__content{white-space:pre-wrap;color:var(--text-secondary);margin:0;font-size:13px;line-height:1.7}.el-message{border-radius:var(--radius)!important;box-shadow:var(--shadow-md)!important;background:var(--bg-elevated)!important;border-color:var(--border-default)!important}.el-message--success{border-color:#10b9814d!important}.el-message--warning{border-color:#f59e0b4d!important}.el-message--error{border-color:#ef44444d!important}.el-message--info{border-color:var(--border-default)!important}.el-badge__content{border:none!important;font-size:10px!important;font-weight:600!important}.el-badge__content--danger{background-color:var(--accent-red)!important}.el-upload-dragger{border-radius:var(--radius)!important;border:2px dashed var(--border-default)!important;background:var(--bg-input)!important;transition:border-color var(--duration-fast), background var(--duration-fast)!important}.el-upload-dragger:hover{border-color:var(--accent-blue)!important;background:var(--sidebar-hover)!important}.el-empty__description p{font-size:13px;color:var(--text-tertiary)!important}.bento-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.bento-cell{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:box-shadow var(--duration), border-color var(--duration);box-shadow:var(--shadow-sm);will-change:transform;padding:20px 22px}.bento-cell:hover{box-shadow:0 0 24px var(--glow-blue);border-color:#3b82f633}.bento-cell-wide{grid-column:span 2}.bento-cell-full{grid-column:1/-1}.bento-label{font-size:var(--text-label);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px;font-weight:600}.bento-value{letter-spacing:-.5px;color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:28px;font-weight:700;line-height:1.1}.bento-trend{font-size:var(--text-small);color:var(--text-tertiary);margin-top:6px}.quick-actions{flex-direction:column;flex:1;justify-content:center;gap:8px;display:flex}.quick-action-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);will-change:transform;border:1px solid #0000;align-items:center;gap:12px;padding:10px 12px;display:flex}.quick-action-item:hover{background:var(--sidebar-hover);border-color:var(--border-default);transform:translate(4px)}.quick-action-item:active{transform:translate(4px)scale(.97)}.qa-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.qa-label{color:var(--text-primary);font-size:13px;font-weight:600;line-height:1.3}.qa-desc{color:var(--text-tertiary);margin-top:1px;font-size:11px;line-height:1.4}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.toolbar-left,.toolbar-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.answer-layout{grid-template-columns:minmax(0,1fr) 260px;align-items:start;gap:20px;display:grid}.answer-index{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);padding:18px 16px;position:sticky;top:32px}.logout-button{z-index:100;-webkit-backdrop-filter:blur(8px);align-items:center;gap:8px;display:inline-flex;position:fixed;top:24px;right:76px;box-shadow:var(--shadow-md)!important;transition:all var(--duration-fast) var(--ease-out)!important;border:1px solid var(--border-default)!important;background:var(--bg-surface)!important;color:var(--text-secondary)!important;border-radius:999px!important;padding:8px 16px!important;font-size:12px!important}.logout-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)!important;border-color:var(--accent-red)!important;color:var(--accent-red)!important;background:#ef444414!important}.logout-button:active{transform:scale(.97)!important}.theme-toggle{z-index:101;-webkit-backdrop-filter:blur(8px);width:40px;height:40px;position:fixed;top:24px;right:24px;box-shadow:var(--shadow-md)!important;transition:all var(--duration-fast) var(--ease-out)!important;border:1px solid var(--border-default)!important;background:var(--bg-surface)!important;color:var(--text-secondary)!important;border-radius:50%!important}.theme-toggle:hover{transform:translateY(-1px)rotate(15deg);box-shadow:var(--shadow-lg)!important;border-color:var(--accent-blue)!important;color:var(--accent-blue)!important}.theme-toggle:active{transform:scale(.9)!important}.logout-role{height:22px;color:var(--accent-blue);background:#3b82f61f;border-radius:999px;align-items:center;padding:0 8px;font-size:11px;font-weight:600;display:inline-flex}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-in{animation:fadeSlideUp .45s var(--ease-out) both;opacity:0}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.stagger-7{animation-delay:.35s}.stagger-8{animation-delay:.4s}@keyframes skeleton-loading{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-block{background:linear-gradient(90deg, var(--bg-overlay) 25%, var(--bg-elevated) 50%, var(--bg-overlay) 75%);border-radius:var(--radius-sm);will-change:background-position;background-size:200% 100%;animation:1.8s ease-in-out infinite skeleton-loading}.skeleton-line{width:100%;height:14px;margin-bottom:10px}.skeleton-line:last-child{width:60%}.skeleton-line--short{width:40%}.skeleton-line--medium{width:70%}.skeleton-avatar{background:linear-gradient(90deg, var(--bg-overlay) 25%, var(--bg-elevated) 50%, var(--bg-overlay) 75%);background-size:200% 100%;border-radius:50%;flex-shrink:0;width:80px;height:80px;animation:1.6s ease-in-out infinite skeleton-loading}.table-empty-state{color:var(--text-tertiary);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 24px;display:flex}.table-empty-state .empty-icon{background:var(--bg-overlay);width:48px;height:48px;color:var(--text-tertiary);border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;display:flex}.table-empty-state p{color:var(--text-tertiary);margin:0;font-size:14px;line-height:1.6}.table-empty-state .empty-action{margin-top:16px}@keyframes float-subtle{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes pulse-ring{0%{box-shadow:0 0 #06b6d480}70%{box-shadow:0 0 0 12px #06b6d400}to{box-shadow:0 0 #06b6d400}}.animate-float{animation:float-subtle 4s var(--ease-out) infinite}.animate-pulse-ring{animation:2s ease-out infinite pulse-ring}.stagger-group>*{opacity:0;animation:fadeSlideUp .4s var(--ease-out) both}.stagger-group>:first-child{animation-delay:20ms}.stagger-group>:nth-child(2){animation-delay:60ms}.stagger-group>:nth-child(3){animation-delay:.1s}.stagger-group>:nth-child(4){animation-delay:.14s}.stagger-group>:nth-child(5){animation-delay:.18s}.stagger-group>:nth-child(6){animation-delay:.22s}.stagger-group>:nth-child(7){animation-delay:.26s}.stagger-group>:nth-child(8){animation-delay:.3s}.stagger-group>:nth-child(9){animation-delay:.34s}.stagger-group>:nth-child(10){animation-delay:.38s}.edit-enter-active,.edit-leave-active{transition:opacity .2s var(--ease-out), transform .2s var(--ease-out)}.edit-enter-from,.edit-leave-to{opacity:0;transform:translateY(-6px)}.sidebar-backdrop{background:var(--glass-bg)}.student-mobile-shell{min-height:100dvh}.student-mobile-shell .van-nav-bar{-webkit-backdrop-filter:blur(14px);box-shadow:0 6px 18px #0000000f}.student-mobile-shell__notice-btn{min-width:52px}.student-mobile-shell__body{padding:calc(56px + env(safe-area-inset-top)) 0 calc(74px + env(safe-area-inset-bottom))}.student-mobile-shell__hero{padding:14px 14px 8px}.student-mobile-shell__hero-main{box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#3b82f624,#8b5cf61f);border:1px solid #3b82f629;border-radius:18px;padding:16px 16px 14px}.student-mobile-shell__eyebrow{color:var(--accent-blue);letter-spacing:.08em;margin:0 0 6px;font-size:12px;font-weight:700}.student-mobile-shell__hero h1{margin:0;font-size:22px;line-height:1.3}.student-mobile-shell__subtitle{color:var(--text-secondary);margin:8px 0 0;font-size:13px;line-height:1.6}.student-mobile-shell__hero-side{align-items:center;gap:10px;margin-top:12px;padding:0 4px;display:flex}.student-mobile-shell__avatar{background:var(--gradient-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-weight:700;display:inline-flex}.student-mobile-shell__name{font-size:14px;font-weight:600}.student-mobile-shell__role{color:var(--text-tertiary);font-size:12px}.student-mobile-shell__content{padding:6px 12px 24px}.student-mobile-shell__popup{max-height:75vh;padding:16px 16px calc(16px + env(safe-area-inset-bottom))}.student-mobile-shell__popup-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.student-mobile-shell__empty{text-align:center;color:var(--text-tertiary);padding:28px 0}.student-mobile-shell__announce-item{border-bottom:1px solid var(--border-subtle);padding:14px 0}.student-mobile-shell__announce-item:last-child{border-bottom:none}.student-mobile-shell__announce-title-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.student-mobile-shell__announce-time{color:var(--text-tertiary);margin-top:4px;font-size:12px}.student-mobile-shell__announce-content{color:var(--text-secondary);white-space:pre-wrap;margin:8px 0 10px;font-size:13px;line-height:1.7}@media (width<=1100px){.login-page{grid-template-columns:1fr;gap:0;padding:0}.login-logo{top:16px;left:20px}.login-logo-icon{width:44px;height:44px}.login-hero{padding:60px 36px 48px}.login-card{border-left:none;border-top:1px solid var(--border-default);padding:44px 36px}.bento-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=980px){.page{padding:20px 16px}.shell{grid-template-columns:1fr;gap:16px}.sidebar{z-index:20;border-radius:16px;flex-wrap:wrap;height:auto;padding:0;position:relative}.sidebar-header{align-items:center;width:100%;min-height:52px;padding:0 16px;display:flex}.brand{border-bottom:none;flex:1;padding:12px 0}.mobile-hamburger{display:flex}.user-card,.collapse-toggle{display:none}.sidebar-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;background:#0006;display:block;position:fixed;inset:0}.el-menu{flex-basis:100%;order:2;width:100%;display:none}.sidebar.menu-open .el-menu{border-top:1px solid var(--sidebar-border);display:block}.sidebar-footer{display:none}.bento-grid{grid-template-columns:repeat(2,1fr)}.bento-cell-wide{grid-column:span 1}.answer-layout{grid-template-columns:1fr}.answer-index{position:static}.theme-toggle{top:auto;bottom:70px;right:20px}.logout-button{top:auto;bottom:24px;right:20px}.student-mobile-shell .el-row{margin-left:0!important;margin-right:0!important}.student-mobile-shell .el-row>[class*=el-col]{padding-left:0!important;padding-right:0!important}.student-mobile-shell .results-toolbar,.student-mobile-shell .practice-toolbar,.student-mobile-shell .result-card__footer,.student-mobile-shell .practice-card__header,.student-mobile-shell .exam-section__header,.student-mobile-shell .nb-meta{flex-direction:column;align-items:stretch;gap:10px}.student-mobile-shell .result-card__inner,.student-mobile-shell .profile-hero{flex-direction:column;align-items:flex-start}.student-mobile-shell .result-progress{align-self:center}.student-mobile-shell .result-card__name,.student-mobile-shell .exam-card__name{white-space:normal}.student-mobile-shell .practice-category-select,.student-mobile-shell .practice-fill-input,.student-mobile-shell .info-row.editing .el-input{width:100%;min-width:0;max-width:none}.student-mobile-shell .profile-page{max-width:none;margin:0;padding:0}.student-mobile-shell .page-title{display:none}.student-mobile-shell .profile-card{padding:20px 16px}.student-mobile-shell .profile-card:before{left:16px;right:16px}.student-mobile-shell .info-row{flex-direction:column;align-items:flex-start;gap:8px}.student-mobile-shell .info-label{width:auto}.student-mobile-shell .profile-actions{flex-direction:column;justify-content:stretch}.student-mobile-shell .profile-actions .el-button{width:100%}.student-mobile-shell .practice-actions{background:linear-gradient(180deg, #f5f7fa00, var(--bg-base) 32%);padding-top:12px;padding-bottom:8px;position:sticky;bottom:0}.student-mobile-shell .answer-layout{flex-direction:column;gap:12px;display:flex}.student-mobile-shell .answer-index{width:100%;position:static}.student-mobile-shell .q-nav-btn{border-radius:10px;width:36px;height:36px}}@media (width<=720px){.page-title{flex-direction:column;align-items:flex-start;min-height:auto}.page-title h1{font-size:24px}.logout-role{display:none}}@media (width<=560px){.page{padding:14px 12px 88px}.shell{gap:12px}.theme-toggle{bottom:58px;right:12px}.logout-button{left:12px;right:12px;bottom:calc(68px + env(safe-area-inset-bottom));justify-content:center}.theme-toggle{bottom:calc(114px + env(safe-area-inset-bottom))}}
