:root{--bg-base:#f0f2f6;--bg-surface:#fff;--bg-elevated:#fff;--bg-overlay:#e8ebf0;--bg-input:#f3f4f8;--text-primary:#0f0f1a;--text-secondary:#3d3d5c;--text-tertiary:#8888a0;--text-disabled:#b0b0c4;--border-default:#d8dce4;--border-subtle:#e6e9f0;--border-strong:#c4c8d4;--accent-blue:#0d9488;--accent-purple:#0891b2;--accent-cyan:#0284c7;--accent-green:#059669;--accent-amber:#d97706;--accent-red:#dc2626;--accent-pink:#db2777;--glow-blue:#0d94881a;--glow-purple:#0891b21a;--glow-cyan:#0284c71a;--glass-bg:#ffffff8c;--glass-border:#ffffffb3;--glass-blur:20px;--shadow-sm:0 1px 2px #0000000a, 0 2px 8px #0000000a;--shadow-md:0 4px 12px #0000000f, 0 2px 4px #0000000a;--shadow-lg:0 8px 28px #00000014;--shadow-xl:0 16px 48px #0000001a;--shadow-glow:0 0 24px var(--glow-blue);--radius-xs:6px;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--font-sans:"Inter", "Outfit", -apple-system, "PingFang SC", "Microsoft YaHei", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Menlo", monospace;--text-page-title:30px;--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, #0d9488, #0891b2);--gradient-cyan:linear-gradient(135deg, #0891b2, #0284c7);--gradient-warm:linear-gradient(135deg, var(--accent-pink), var(--accent-amber));--gradient-border:linear-gradient(135deg, #0d948840, #0891b240);--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in:cubic-bezier(.7, 0, .84, 0);--duration-fast:.15s;--duration:.3s;--duration-slow:.5s;--sidebar-bg:#ffffffa6;--sidebar-text:#3d3d5c;--sidebar-text-dim:#3d3d5c80;--sidebar-border:#0000000d;--sidebar-hover:#0d94880f;--sidebar-active-bg:#0d94881a;--sidebar-icon:#3d3d5c66;--login-card-bg:#ffffffe0;--login-hero-deco:#0d94880f;--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:#0b0b16;--bg-surface:#16162a;--bg-elevated:#1e1e36;--bg-overlay:#22223c;--bg-input:#1a1a30;--text-primary:#eaeaef;--text-secondary:#acacc2;--text-tertiary:#70708a;--text-disabled:#4a4a62;--border-default:#2a2a48;--border-subtle:#22223c;--border-strong:#363658;--accent-blue:#2dd4bf;--accent-purple:#22d3ee;--accent-cyan:#38bdf8;--accent-green:#34d399;--accent-amber:#fbbf24;--accent-red:#f87171;--accent-pink:#f472b6;--glow-blue:#2dd4bf26;--glow-purple:#22d3ee26;--glow-cyan:#38bdf826;--glass-bg:#16162aa6;--glass-border:#ffffff0f;--glass-blur:20px;--shadow-sm:0 1px 2px #0000004d, 0 2px 8px #0003;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 28px #00000059;--shadow-xl:0 16px 48px #0006;--shadow-glow:0 0 24px var(--glow-blue);--sidebar-bg:#16162ab3;--sidebar-text:#c8c8dc;--sidebar-text-dim:#c8c8dc66;--sidebar-border:#ffffff0a;--sidebar-hover:#2dd4bf14;--sidebar-active-bg:#2dd4bf24;--sidebar-icon:#c8c8dc59;--login-card-bg:#16162ae0;--login-hero-deco:#2dd4bf14;--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:#16162aeb;--van-tabbar-background:#16162af5;--van-card-background:var(--bg-surface)}[data-theme=dark] .login-card{background:#16162aeb}[data-theme=dark] .login-hero h1{color:#fffffff2}[data-theme=dark] .login-hero h1 span{background:linear-gradient(135deg,#2dd4bf 30%,#22d3ee 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}[data-theme=dark] .login-hero .hero-sub,[data-theme=dark] .hero-feature{color:#c8c8dcb3}[data-theme=dark] .el-card{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background:linear-gradient(135deg,#1e1e38,#18182e)!important;border:1px solid #2dd4bf1a!important;box-shadow:0 2px 8px #00000059,inset 0 1px #2dd4bf0a!important}[data-theme=dark] .el-card:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#2dd4bf26,#0000);height:1px;position:absolute;top:0;left:0;right:0}[data-theme=dark] .el-card:hover{border-color:#2dd4bf33!important;box-shadow:0 8px 32px #0006,0 0 28px #2dd4bf14,inset 0 1px #2dd4bf0f!important}[data-theme=dark] .el-card__header{border-bottom-color:#2dd4bf0f!important}[data-theme=dark] .bento-cell{background:linear-gradient(135deg,#1e1e38,#18182e);border-color:#2dd4bf1a;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000059,inset 0 1px #2dd4bf0a;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}[data-theme=dark] .bento-cell:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#2dd4bf1f,#0000);height:1px;position:absolute;top:0;left:0;right:0}[data-theme=dark] .bento-cell:hover{border-color:#2dd4bf33;box-shadow:0 8px 32px #0006,0 0 28px #2dd4bf1a,inset 0 1px #2dd4bf0f}*,: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 30%), radial-gradient(circle at top right, var(--glow-purple), transparent 24%), radial-gradient(circle at bottom left, var(--glow-cyan), transparent 24%), 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);background-attachment:fixed;min-height:100vh;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), #0d948800);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 15% 20%, var(--accent-blue), transparent 40%), radial-gradient(circle at 85% 30%, var(--accent-purple), transparent 35%), radial-gradient(circle at 50% 80%, var(--accent-cyan), transparent 30%), var(--bg-base);grid-template-columns:minmax(0,1fr) 460px;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:.9}.login-logo:before{content:"";border-radius:calc(var(--radius) + 4px);z-index:-1;transition:opacity var(--duration-fast), transform var(--duration-fast);opacity:0;background:linear-gradient(135deg,#0d94881f,#0891b214);position:absolute;inset:-3px}.login-logo:hover:before{opacity:1;transform:scale(1.04)}.login-logo-icon{border-radius:var(--radius);object-fit:contain;-webkit-backdrop-filter:blur(12px);width:54px;height:54px;transition:border-color var(--duration-fast), box-shadow var(--duration-fast);background:#ffffffb3;border:1px solid #0d948826;padding:10px;display:block}.login-logo:hover .login-logo-icon{border-color:#0d94884d;box-shadow:0 0 20px #0d948814}[data-theme=dark] .login-logo-icon{background:#16162ab3;border-color:#2dd4bf1f}[data-theme=dark] .login-logo:hover .login-logo-icon{border-color:#2dd4bf40;box-shadow:0 0 20px #2dd4bf14}[data-theme=dark] .login-logo:before{background:linear-gradient(135deg,#2dd4bf1f,#22d3ee14)}.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 #0d94881a;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 #0891b214;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;overflow:hidden}.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:-2px;color:#fffffff2;text-shadow:0 2px 40px #0000001a;margin:0 0 16px;font-size:60px;font-weight:750;line-height:1.02}.login-hero h1 span{background:linear-gradient(135deg,#fff 30%,#fff9 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text}.login-hero .hero-sub{color:#ffffffb3;text-shadow:0 1px 20px #00000014;max-width:420px;margin:0 0 44px;font-size:16px;line-height:1.8}.hero-divider{background:linear-gradient(90deg,#fff9,#fff3);border-radius:2px;width:56px;height:3px;margin-bottom:28px}.hero-features{flex-direction:column;gap:14px;display:flex;position:relative}.hero-feature{color:#ffffffbf;border-radius:var(--radius);transition:background var(--duration-fast), transform var(--duration-fast) var(--ease-out);will-change:transform;cursor:default;align-items:center;gap:14px;padding:8px 14px 8px 8px;font-size:14px;display:flex}.hero-feature:hover{background:#ffffff14;transform:translate(6px)}.hero-feature-icon{border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;width:34px;height:34px;transition:transform var(--duration-fast) var(--ease-out), background var(--duration-fast);background:linear-gradient(135deg,#0d948833,#0891b226);flex-shrink:0;justify-content:center;align-items:center;font-size:15px;display:flex;box-shadow:0 0 12px #0d948814}.hero-feature:nth-child(2) .hero-feature-icon{background:linear-gradient(135deg,#0891b233,#0284c726)}.hero-feature:nth-child(3) .hero-feature-icon{background:linear-gradient(135deg,#05966933,#0d948826)}.hero-feature:nth-child(4) .hero-feature-icon{background:linear-gradient(135deg,#d9770633,#0d948826)}.hero-feature:hover .hero-feature-icon{background:#fff3;transform:scale(1.1)}.login-card{z-index:1;-webkit-backdrop-filter:blur(24px);background:#fffffff0;border-left:1px solid #0d948814;flex-direction:column;justify-content:center;padding:56px 52px;display:flex;position:relative;box-shadow:-8px 0 48px #0000000d}.login-card:before{content:"";opacity:1;background:linear-gradient(#0000,#0d948826,#0000);width:2px;position:absolute;top:6%;bottom:6%;left:0}.login-card h2{color:var(--text-primary);letter-spacing:-.5px;margin:0 0 4px;font-size:26px;font-weight:700}.login-card .login-muted{color:var(--text-tertiary);margin:0 0 28px;font-size:14px}.login-card .login-muted:after{content:"";background:var(--accent-blue);opacity:.3;border-radius:1px;width:24px;height:2px;margin-top:12px;display:block}.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-form-item{margin-bottom:22px}.login-form .el-input__wrapper{height:44px;box-shadow:0 0 0 1px var(--border-default) inset!important;background:var(--bg-input)!important;transition:box-shadow var(--duration-fast), background var(--duration-fast)!important;border-radius:10px!important;padding-left:14px!important}.login-form .el-input__wrapper:hover{box-shadow:0 0 0 1px var(--accent-blue) inset!important;background:var(--bg-surface)!important}.login-form .el-input__wrapper.is-focus{background:var(--bg-surface)!important;box-shadow:inset 0 0 0 2px #0d948833!important}.login-form .el-input__inner{height:44px!important}.login-submit{letter-spacing:.5px;will-change:transform;color:#fff;cursor:pointer;width:100%;height:48px;margin-top:8px;font-size:15px;font-weight:600;box-shadow:0 4px 14px #0d94884d;transition:box-shadow var(--duration-fast), transform var(--duration-fast) var(--ease-out)!important;background:linear-gradient(135deg,#0d9488,#0891b2)!important;border:none!important;border-radius:10px!important}.login-submit:hover{transform:translateY(-2px);box-shadow:0 6px 24px #0d948866!important}.login-submit:active{transform:scale(.98)!important;box-shadow:0 2px 8px #0d948840!important}.login-footer{border-top:1px solid var(--border-subtle);color:var(--text-tertiary);text-align:center;flex-direction:column;gap:8px;margin-top:28px;padding-top:20px;font-size:12px;display:flex}.login-footer .el-button{color:var(--text-tertiary);transition:color var(--duration-fast);font-size:12px}.login-footer .el-button:hover{color:var(--accent-blue)}.el-card{-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));transition:box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);will-change:transform;overflow:hidden;border-radius:var(--radius-lg)!important;border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-sm)!important;background:var(--glass-bg)!important}.el-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg), 0 0 28px var(--glow-blue)!important;border-color:var(--accent-blue)!important}.el-card__header{color:var(--text-primary);font-size:14px;font-weight:600;border-bottom:1px solid var(--border-subtle)!important;background:0 0!important;padding:16px 20px!important}.el-card__body{padding:20px!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 24px #0d948859!important}.el-button--primary:active{box-shadow:none!important;transform:scale(.97)!important}.el-button--primary.is-plain{color:var(--accent-blue)!important;background:#0d948814!important;border:1px solid #0d948833!important}.el-button--primary.is-plain:hover{transform:translateY(-1px);background:var(--gradient-primary)!important;color:#fff!important;box-shadow:0 0 20px #0d94884d!important}.el-button--success.is-plain{color:var(--accent-green)!important;background:#05966914!important;border:1px solid #05966933!important}.el-button--success.is-plain:hover{transform:translateY(-1px);background:var(--accent-green)!important;color:#fff!important;box-shadow:0 0 20px #0596694d!important}.el-button--warning.is-plain{color:var(--accent-amber)!important;background:#d9770614!important;border:1px solid #d9770633!important}.el-button--warning.is-plain:hover{transform:translateY(-1px);background:var(--accent-amber)!important;color:#fff!important;box-shadow:0 0 20px #d977064d!important}.el-button--danger.is-plain{color:var(--accent-red)!important;background:#dc262614!important;border:1px solid #dc262633!important}.el-button--danger.is-plain:hover{transform:translateY(-1px);background:var(--accent-red)!important;color:#fff!important;box-shadow:0 0 20px #dc26264d!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:#b91c1c!important;border-color:#b91c1c!important;box-shadow:0 0 20px #dc26264d!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:#047857!important;border-color:#047857!important;box-shadow:0 0 20px #0596694d!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:#b45309!important;border-color:#b45309!important;box-shadow:0 0 20px #d977064d!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:transparent;--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;border:1px solid var(--border-subtle)!important}.el-table th.el-table__cell{text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border-subtle)!important;padding:12px 0!important;font-size:12px!important;font-weight:600!important}.el-table td.el-table__cell{border-bottom:1px solid var(--border-subtle)!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-table__body tr.el-table__row:last-child td.el-table__cell{border-bottom:none!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(--glass-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);box-shadow:var(--shadow-sm);will-change:transform;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:22px 24px}.bento-cell:hover{border-color:var(--accent-blue);box-shadow:var(--shadow-lg), 0 0 28px var(--glow-blue);transform:translateY(-2px)}.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:.8px;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(12px);letter-spacing:.2px;align-items:center;gap:6px;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-subtle)!important;background:var(--glass-bg)!important;color:var(--text-secondary)!important;border-radius:10px!important;padding:7px 14px 7px 12px!important;font-size:12px!important}.logout-button .logout-role{height:20px;color:var(--accent-blue);letter-spacing:.3px;transition:background var(--duration-fast);background:#0d94881a;border-radius:6px;align-items:center;padding:0 7px;font-size:10px;font-weight:600;display:inline-flex}.logout-button .logout-icon{width:18px;height:18px;transition:all var(--duration-fast);color:var(--text-tertiary);border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.logout-button .logout-label{transition:color var(--duration-fast);font-weight:500}.logout-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)!important;background:#dc26260a!important;border-color:#dc262633!important}.logout-button:hover .logout-role,.logout-button:hover .logout-icon{color:var(--accent-red);background:#dc262614}.logout-button:hover .logout-label{color:var(--accent-red)}.logout-button:active{transform:scale(.97)!important}[data-theme=dark] .logout-button{background:#16162ab3!important;border-color:#ffffff0f!important}[data-theme=dark] .logout-button:hover{background:#dc262614!important;border-color:#f8717140!important}[data-theme=dark] .logout-button .logout-role{color:var(--accent-blue);background:#2dd4bf1f}[data-theme=dark] .logout-button:hover .logout-role,[data-theme=dark] .logout-button:hover .logout-icon{color:var(--accent-red);background:#f871711f}.theme-toggle{z-index:101;-webkit-backdrop-filter:blur(12px);width:38px;height:38px;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-subtle)!important;background:var(--glass-bg)!important;color:var(--text-secondary)!important;border-radius:10px!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;background:#0d94880f!important}.theme-toggle:active{transform:scale(.9)!important}[data-theme=dark] .theme-toggle{background:#16162ab3!important;border-color:#ffffff0f!important}[data-theme=dark] .theme-toggle:hover{color:var(--accent-blue)!important;background:#2dd4bf14!important;border-color:#2dd4bf33!important}@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(--glass-border);padding:44px 36px}.login-hero h1{font-size:42px}.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, transparent, 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))}}
