.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}.login-wrap{width:100%;max-width:440px;position:relative;z-index:2}.brand-block{text-align:center;margin-bottom:48px}.brand-cn{color:#1a3a6e;font-size:48px;font-weight:300;letter-spacing:8px;text-indent:8px;margin-bottom:16px;text-shadow:0 2px 24px rgba(74,144,226,.15)}.brand-en{color:#4a90e2;font-size:14px;letter-spacing:6px;text-indent:6px;margin-bottom:12px;font-weight:500}.brand-sub{color:#94a8c4;font-size:13px;letter-spacing:2px}.login-card{padding:36px 32px}.card-title-row{display:flex;align-items:center;gap:12px;margin-bottom:28px}.title-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(74,144,226,.3),transparent)}.card-title{color:#4a90e2;font-size:14px;letter-spacing:6px;text-indent:6px;font-weight:500}.err-row{margin:0 0 16px;padding:10px 14px;background:#ff636314;border:1px solid rgba(255,99,99,.2);border-radius:10px;color:#d65a5a;font-size:13px}.card-sub{margin-top:20px;color:#94a8c4;font-size:12px;letter-spacing:2px;text-align:center}.copyright{text-align:center;color:#b4c2d6;font-size:11px;letter-spacing:3px;margin-top:40px}.deco-ring{position:fixed;left:50%;top:30%;border-radius:50%;border:1px solid rgba(140,175,220,.15);transform:translate(-50%,-50%);pointer-events:none;z-index:0}.deco-ring.r1{width:320px;height:320px}.deco-ring.r2{width:480px;height:480px;border-color:#8cafdc1a}.deco-ring.r3{width:640px;height:640px;border-color:#8cafdc0f}.cl-page{min-height:100vh;padding-bottom:60px}.teacher-card{display:flex;align-items:center;gap:16px;padding:20px 24px;margin-bottom:24px}.t-avatar{width:64px;height:64px;font-size:26px}.teacher-info{flex:1}.teacher-name{color:#1a3a6e;font-size:22px;font-weight:500;letter-spacing:1px}.empty-state{text-align:center;padding:80px 0}.empty-circle{width:100px;height:100px;border:2px dashed rgba(74,144,226,.3);border-radius:50%;margin:0 auto;background:#ffffff80}.class-grid{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 600px){.class-grid{grid-template-columns:1fr 1fr}}@media (min-width: 1024px){.class-grid{grid-template-columns:1fr 1fr 1fr}}.class-card{cursor:pointer;transition:all .25s ease}.class-card:hover{transform:translateY(-3px);background:#ffffffd9;box-shadow:0 16px 40px #4a90e226}.class-name{color:#1a3a6e;font-size:22px;font-weight:500;letter-spacing:1px}.class-meta{margin-top:20px;padding:16px 0;background:#4a90e20f;border-radius:14px;display:flex;align-items:center;justify-content:space-around}.meta-pair{text-align:center}.meta-num{font-size:22px;font-weight:500;margin-top:4px}.meta-divider{width:1px;height:32px;background:#4a90e233}.class-cta{margin-top:20px;text-align:right;color:#4a90e2;font-size:13px;letter-spacing:1px}.dash-page{min-height:100vh;padding-bottom:60px}.dash-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:16px;padding:14px 24px;margin:16px 24px;border-radius:18px}.dash-title{flex:1;color:#1a3a6e;font-size:20px;font-weight:500;letter-spacing:1px}.progress-card{margin-bottom:16px;display:flex;align-items:center;gap:20px}.progress-label{width:200px;display:flex;flex-direction:column;gap:4px}.progress-bar{flex:1;height:8px;background:#4a90e21a;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4a90e2,#c9a44a);border-radius:4px;transition:width .5s ease-out}.progress-num{font-size:22px;font-weight:500;color:#1a3a6e;min-width:50px;text-align:right}.exhibit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px;margin-bottom:24px}.exhibit-stat{padding:14px;text-align:center}.exhibit-num{font-size:26px;font-weight:500;color:#4a90e2;margin-top:4px}.section-title{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px;padding:0 4px}.student-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}.student-card{padding:20px 12px;text-align:center;cursor:pointer;transition:all .2s}.student-card:hover{transform:translateY(-2px);background:#ffffffd9}.student-avatar{width:64px;height:64px;font-size:24px;margin:0 auto 12px}.student-name{font-weight:500;color:#1a3a6e;font-size:16px}.student-tag{display:inline-block;margin-top:8px;padding:4px 10px;border-radius:10px;font-size:11px;letter-spacing:.5px;font-weight:500}.student-score{margin-top:10px;color:#4a90e2;font-size:22px;font-weight:500}.drawer-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1e3c66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;animation:fadeIn .25s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;top:0;right:0;width:500px;max-width:95vw;height:100vh;background:#f8fbfeeb;backdrop-filter:blur(30px) saturate(160%);-webkit-backdrop-filter:blur(30px) saturate(160%);border-left:1px solid rgba(255,255,255,.85);z-index:101;display:flex;flex-direction:column;box-shadow:-20px 0 60px #4a90e226;animation:slideIn .3s ease-out}.drawer-sm{width:420px}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:none;opacity:1}}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(180,199,224,.2)}.drawer-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px}.drawer-body .glass{padding:20px}.student-hero{text-align:center;padding:28px 20px!important}.student-hero-avatar{width:96px;height:96px;font-size:36px;margin:0 auto;border:3px solid rgba(255,255,255,.95);box-shadow:0 6px 20px #4a90e233}.hero-score{margin-top:20px;padding:16px 0;background:#4a90e20f;border-radius:14px}.hs-num{font-size:36px;font-weight:500}.hero-code{margin-top:14px;padding:14px 18px;background:linear-gradient(135deg,#5ba0f226,#4a90e214);border-radius:14px}.hc-num{color:#1a3a6e;font-size:34px;font-weight:500;letter-spacing:8px;font-family:SF Mono,Courier New,monospace;margin-top:4px}.rate-block{background:#ffffff80;border:1px solid rgba(180,199,224,.2);border-radius:12px;padding:14px 16px;margin-bottom:10px}.rate-block:last-child{margin-bottom:0}.rate-block-head{display:flex;justify-content:space-between;align-items:center;color:#2c3e5d;font-size:14px;margin-bottom:8px}.rate-row{display:flex;align-items:center;gap:10px;margin:4px 0;font-size:13px}.rr-label{width:50px;color:#6b7f9c}.rate-comment{margin-top:8px;padding:8px 12px;background:#4a90e20f;border-radius:8px;color:#6b7f9c;font-size:13px;font-style:italic}.rate{display:inline-flex;gap:2px}.rate-star{color:#b4c7e066;font-size:18px;cursor:pointer;transition:color .15s}.rate-star.active{color:#c9a44a}.rate-star.readonly{cursor:default}.board-row{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid rgba(180,199,224,.15)}.board-rank{width:32px;text-align:center;font-size:22px;font-weight:600}.board-score{color:#4a90e2;font-size:20px;font-weight:500}.toast{position:fixed;top:24px;right:24px;z-index:999;padding:12px 20px;border-radius:12px;background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.85);box-shadow:0 8px 24px #4a90e226;color:#2c3e5d;font-size:14px;animation:toastIn .3s ease-out;max-width:360px}@keyframes toastIn{0%{transform:translateY(-12px);opacity:0}to{transform:none;opacity:1}}.toast-success{border-left:4px solid #4caa78}.toast-error{border-left:4px solid #d65a5a}.toast-info{border-left:4px solid #4A90E2}.exhibit-root{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;color:#fff;font-family:-apple-system,PingFang SC,Microsoft YaHei,sans-serif;overflow:hidden;-webkit-user-select:none;user-select:none}.exhibit-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1);filter:brightness(.45) saturate(.7)}.exhibit-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(#000a1e80,#00050fb3),repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(0,212,255,.04) 60px,rgba(0,212,255,.04) 61px),repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(0,212,255,.04) 60px,rgba(0,212,255,.04) 61px);pointer-events:none}.exhibit-header{position:absolute;top:60px;left:0;right:0;text-align:center;z-index:10}.exhibit-chapter{font-size:18px;letter-spacing:8px;color:#00d4ff;margin-bottom:12px;text-shadow:0 0 20px #00D4FF}.exhibit-title{font-size:72px;font-weight:200;letter-spacing:12px;margin-bottom:8px}.exhibit-subtitle{font-size:22px;color:#fff9;letter-spacing:6px}.exhibit-idle{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;z-index:5}.scan-frame{width:400px;height:480px;border:3px solid #00D4FF;border-radius:50%;box-shadow:0 0 60px #00d4ff66,inset 0 0 60px #00d4ff33;animation:pulse 2s ease-in-out infinite;margin-bottom:60px}@keyframes pulse{0%,to{box-shadow:0 0 60px #00d4ff66,inset 0 0 60px #00d4ff33;transform:scale(1)}50%{box-shadow:0 0 100px #00d4ffb3,inset 0 0 80px #00d4ff4d;transform:scale(1.02)}}.idle-tip{font-size:28px;color:#ffffffbf;margin-bottom:32px;letter-spacing:3px}.idle-cta{font-size:32px;color:#00d4ff;letter-spacing:4px;padding:24px 60px;border:2px solid #00D4FF;border-radius:60px;background:#00d4ff14;text-shadow:0 0 10px #00D4FF;animation:glow 1.5s ease-in-out infinite}@keyframes glow{0%,to{box-shadow:0 0 20px #00d4ff4d}50%{box-shadow:0 0 40px #00d4ffb3}}.exhibit-count{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.count-num{font-size:280px;font-weight:100;color:#00d4ff;text-shadow:0 0 60px #00D4FF;line-height:1;animation:count-pop 1s ease-out}@keyframes count-pop{0%{transform:scale(2);opacity:0}50%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}.count-tip{margin-top:60px;font-size:28px;color:#ffffffb3;letter-spacing:4px}.exhibit-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.loading-ring{width:160px;height:160px;border:4px solid rgba(0,212,255,.2);border-top-color:#00d4ff;border-radius:50%;animation:spin .9s linear infinite;margin-bottom:48px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:32px;color:#00d4ff;letter-spacing:4px}.exhibit-welcome{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;animation:fade-in .5s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.welcome-hi{font-size:40px;color:#ffffffb3;letter-spacing:8px;margin-bottom:20px;animation:slide-up .6s ease-out}.welcome-name{font-size:140px;font-weight:200;color:#fff;text-shadow:0 0 40px #00D4FF;letter-spacing:8px;margin-bottom:40px;animation:slide-up .8s ease-out .2s backwards}.welcome-sub{font-size:32px;color:#00d4ff;letter-spacing:6px;animation:slide-up .6s ease-out .5s backwards}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.particles span{position:absolute;bottom:0;width:4px;height:4px;background:#00d4ff;border-radius:50%;box-shadow:0 0 8px #00d4ff;animation:particle-rise 3s linear infinite}@keyframes particle-rise{0%{transform:translateY(0);opacity:0}20%{opacity:1}to{transform:translateY(-100vh);opacity:0}}.exhibit-choose{position:absolute;top:40px;right:80px;bottom:40px;left:80px;display:flex;flex-direction:column;z-index:10}.choose-title{font-size:40px;text-align:center;margin-bottom:32px;letter-spacing:4px;color:#fff;text-shadow:0 0 20px rgba(0,212,255,.5)}.choose-grid{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:48px;overflow:hidden}.choose-col{display:flex;flex-direction:column;gap:14px}.col-label{font-size:22px;letter-spacing:8px;color:#00d4ff;margin-bottom:8px;padding-bottom:12px;border-bottom:1px solid rgba(0,212,255,.3)}.prof-card{background:#001428b3;border:2px solid rgba(0,212,255,.3);border-radius:12px;padding:16px 22px;cursor:pointer;transition:all .2s}.prof-card:hover{border-color:#00d4ff;transform:translate(6px)}.prof-card.selected{border-color:#00d4ff;background:#00d4ff2e;box-shadow:0 0 30px #00d4ff66}.prof-name{font-size:26px;font-weight:500;margin-bottom:6px}.prof-slogan{font-size:16px;color:#ffffffa6;line-height:1.5}.color-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.color-card{background:#001428b3;border:2px solid rgba(255,255,255,.2);border-radius:12px;padding:22px;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:all .2s}.color-card:hover{transform:translateY(-3px)}.color-card.selected{background:#ffffff14}.color-dot{width:56px;height:56px;border-radius:50%;margin-bottom:12px;box-shadow:0 0 24px currentColor}.color-name{font-size:20px;letter-spacing:2px}.confirm-btn{margin:32px auto 0;padding:22px 80px;font-size:28px;letter-spacing:6px;background:linear-gradient(135deg,#00d4ff,#0080ff);color:#000;border:none;border-radius:60px;cursor:pointer;font-weight:600;box-shadow:0 0 30px #00d4ff80;transition:all .2s}.confirm-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 50px #00d4ffcc}.confirm-btn:disabled{opacity:.3;cursor:not-allowed;background:#555;color:#999;box-shadow:none}.exhibit-born{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.born-ring{width:240px;height:240px;border:6px solid;border-radius:50%;margin-bottom:48px;animation:born-pulse 1.5s ease-in-out infinite}@keyframes born-pulse{0%,to{transform:scale(1);box-shadow:0 0 40px currentColor}50%{transform:scale(1.15);box-shadow:0 0 100px currentColor}}.born-text{font-size:36px;letter-spacing:6px;color:#fff;animation:dots 1.5s steps(4) infinite}@keyframes dots{0%{content:"数字分身合成中"}to{content:"数字分身合成中..."}}.exhibit-done{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;animation:fade-in .6s ease-out}.done-card{background:#000a19d9;border:3px solid;border-radius:24px;padding:56px 72px;text-align:center;margin-bottom:32px;min-width:600px}.done-title{font-size:48px;font-weight:300;letter-spacing:6px;margin-bottom:20px;text-shadow:0 0 30px currentColor}.done-name{font-size:64px;font-weight:200;margin-bottom:24px;letter-spacing:8px}.done-slogan{font-size:22px;color:#ffffffbf;font-style:italic;margin-bottom:32px;letter-spacing:2px}.done-badge{display:inline-block;padding:12px 32px;border-radius:30px;color:#000;font-weight:600;font-size:22px;letter-spacing:3px}.done-tip{font-size:24px;color:#00d4ff;letter-spacing:6px;margin-top:24px}.done-reset{margin-top:16px;font-size:16px;color:#fff6;cursor:pointer}.done-reset:hover{color:#fffc}.exhibit-fail{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.fail-icon{width:160px;height:160px;border:4px solid #ff4d4f;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:100px;color:#ff4d4f;margin-bottom:32px;box-shadow:0 0 40px #ff4d4f66}.fail-text{font-size:32px;margin-bottom:16px}.fail-retry{font-size:20px;color:#fff9;margin-bottom:32px}.fail-call{text-align:center;font-size:22px;color:#fa0}.finale-root{overflow-y:auto}.finale-root .exhibit-video{filter:brightness(.25) saturate(.5)}.finale-code{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;text-align:center;background:#000a19d9;border:2px solid rgba(0,212,255,.4);border-radius:24px;padding:48px 56px;box-shadow:0 0 60px #00d4ff4d}.code-title{font-size:36px;letter-spacing:8px;margin-bottom:24px;color:#00d4ff}.code-hint{color:#ff8c00;font-size:18px;margin-bottom:20px}.code-boxes{display:flex;gap:12px;justify-content:center;margin-bottom:32px}.code-box{width:60px;height:80px;border:2px solid rgba(0,212,255,.5);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:600;background:#001e3c99}.code-pad{display:grid;grid-template-columns:repeat(3,80px);gap:12px;justify-content:center;margin-bottom:24px}.code-key{width:80px;height:80px;border:2px solid rgba(0,212,255,.3);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px;cursor:pointer;background:#00142899;transition:all .15s}.code-key:hover{background:#00d4ff33;border-color:#00d4ff}.finale-portrait{position:relative;z-index:10;padding:24px 60px 60px;min-height:100vh;box-sizing:border-box;background:#00050fa6}.portrait-header{display:grid;grid-template-columns:140px 1fr auto;gap:32px;align-items:center;padding:24px;background:#001428a6;border:1px solid rgba(0,212,255,.3);border-radius:20px;margin-bottom:24px}.portrait-avatar{width:140px;height:140px;border-radius:50%;object-fit:cover;border:3px solid #00D4FF;box-shadow:0 0 30px #00d4ff80}.portrait-name{font-size:48px;font-weight:300;letter-spacing:6px;margin-bottom:12px}.portrait-avatar-tag{display:inline-block;padding:8px 20px;border-radius:20px;color:#000;font-weight:600;font-size:18px;letter-spacing:2px}.portrait-stats{display:flex;gap:32px}.portrait-stat{text-align:center}.stat-num{font-size:56px;font-weight:200;line-height:1}.stat-label{font-size:14px;color:#fff9;margin-top:6px;letter-spacing:3px}.portrait-charts{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.chart-card{background:#001428a6;border:1px solid rgba(0,212,255,.3);border-radius:20px;padding:24px;display:flex;flex-direction:column;align-items:center}.chart-title{font-size:18px;letter-spacing:6px;color:#00d4ff;margin-bottom:16px}.portrait-timeline{background:#001428a6;border:1px solid rgba(0,212,255,.3);border-radius:20px;padding:24px;margin-bottom:24px}.timeline-row{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;position:relative}.timeline-row:before{content:"";position:absolute;left:8%;right:8%;top:18px;height:2px;background:#00d4ff33;z-index:0}.timeline-node{text-align:center;position:relative;opacity:.4}.timeline-node.done{opacity:1}.node-dot{width:16px;height:16px;border-radius:50%;background:#fff3;border:2px solid rgba(0,212,255,.4);margin:12px auto;position:relative;z-index:1}.timeline-node.done .node-dot{background:#00d4ff;border-color:#00d4ff;box-shadow:0 0 12px #00d4ff}.node-seq{font-size:12px;color:#fff9}.node-name{font-size:15px;margin-top:4px}.node-rating{font-size:12px;color:gold;margin-top:4px;font-family:monospace}.portrait-eulogy{background:#001428a6;border:1px solid rgba(0,212,255,.3);border-radius:20px;padding:32px;text-align:center}.eulogy-text{font-size:22px;line-height:1.8;color:#fff;font-style:italic;letter-spacing:1px}.finale-done{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,PingFang SC,Microsoft YaHei,sans-serif;background:#f5f7fa}.app-layout{min-height:100vh}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.student-card{transition:transform .15s;cursor:pointer}.student-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px}.status-online{background:#52c41a}.status-offline{background:#d9d9d9}.status-alert{background:#ff4d4f}*{-webkit-tap-highlight-color:transparent;box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;color:#2c3e5d;background:#f0f5fb;overflow-x:hidden}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(circle at 20% 10%,#d6e7fa 0%,transparent 50%),radial-gradient(circle at 80% 90%,#e6effa 0%,transparent 50%),linear-gradient(180deg,#f0f5fb,#e8f0fa);overflow:hidden}.app-bg:before,.app-bg:after{content:"";position:absolute;width:800px;height:800px;border-radius:50%;filter:blur(120px);opacity:.4;pointer-events:none}.app-bg:before{top:-200px;left:-300px;background:radial-gradient(circle,#a8c8f0 0%,transparent 70%)}.app-bg:after{bottom:-200px;right:-300px;background:radial-gradient(circle,#c4d9f3 0%,transparent 70%)}.glass{background:#ffffffb3;backdrop-filter:blur(30px) saturate(160%);-webkit-backdrop-filter:blur(30px) saturate(160%);border:1px solid rgba(255,255,255,.85);border-radius:20px;padding:24px;box-shadow:0 12px 32px #4a90e214,0 2px 8px #4a90e20a,inset 0 1px #ffffffe6;position:relative}.glass-strong{background:#ffffffd9}.t-h1{color:#1a3a6e;font-size:28px;font-weight:500;letter-spacing:1px}.t-h2{color:#1a3a6e;font-size:22px;font-weight:500}.t-h3{color:#2c3e5d;font-size:18px;font-weight:500}.t-label{color:#4a90e2;font-size:13px;letter-spacing:4px}.t-default{color:#2c3e5d;font-size:15px}.t-muted{color:#94a8c4;font-size:13px}.t-faint{color:#b4c2d6;font-size:12px}.t-primary{color:#4a90e2}.t-gold{color:#c9a44a}.t-success{color:#4caa78}.t-error{color:#d65a5a}.btn-primary{display:inline-flex;align-items:center;justify-content:center;height:48px;padding:0 32px;background:linear-gradient(135deg,#5ba0f2,#4a90e2,#3a7fcc);border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:500;letter-spacing:1px;cursor:pointer;box-shadow:0 6px 16px #4a90e259,inset 0 1px #fff6;transition:all .2s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 24px #4a90e273}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary.block{width:100%}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 24px;background:#fff9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(74,144,226,.3);border-radius:12px;color:#4a90e2;font-size:14px;cursor:pointer;transition:all .2s}.btn-ghost:hover{background:#ffffffd9}.btn-text{background:transparent;border:none;color:#4a90e2;font-size:14px;cursor:pointer;padding:4px 8px}.btn-text:hover{color:#1a3a6e}.field{width:100%;height:48px;padding:0 16px;background:#fff9;border:1px solid rgba(180,199,224,.5);border-radius:12px;font-size:15px;color:#2c3e5d;outline:none;transition:all .2s}.field:focus{border-color:#4a90e2;background:#ffffffd9;box-shadow:0 0 0 3px #4a90e21a}.field-textarea{min-height:96px;padding:12px 16px;resize:vertical}.field-label{display:block;color:#6b7f9c;font-size:13px;margin-bottom:8px;letter-spacing:.5px}.tag{display:inline-block;padding:4px 12px;border-radius:10px;font-size:12px;letter-spacing:.5px}.tag-primary{background:#4a90e21f;color:#4a90e2}.tag-success{background:#52c48c26;color:#4caa78}.tag-warning{background:#faad1426;color:#d4920f}.tag-error{background:#ff636326;color:#d65a5a}.tag-gold{background:#c9a44a26;color:#c9a44a}.avatar{background:linear-gradient(135deg,#5ba0f2,#4a90e2);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:500;flex-shrink:0;border:2px solid rgba(255,255,255,.9);overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.container{max-width:1280px;margin:0 auto;padding:24px}.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(74,144,226,.2),transparent);margin:16px 0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#4a90e233;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#4a90e259}.ant-message-notice-content{background:#fffffff2!important;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.85)}.ant-rate-star.ant-rate-star-zero{color:#b4c7e066}.ant-rate{color:#c9a44a!important}.ant-rate-star-second{color:#b4c7e066}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.anim-in{animation:fadeInUp .4s ease-out}@media (min-width: 768px){.container{padding:32px}}
