.blackhole-container[data-v-53c9cb22]{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;background:#000}.loading-overlay[data-v-b3ce136f]{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.loading-overlay.is-visible[data-v-b3ce136f]{opacity:1;visibility:visible}.loading-content[data-v-b3ce136f]{display:flex;flex-direction:column;align-items:center;gap:16px}.loading-spinner[data-v-b3ce136f]{width:48px;height:48px;border:3px solid rgba(255,255,255,.2);border-top-color:#8b5cf6;border-radius:50%;animation:spin-b3ce136f 1s linear infinite}.loading-message[data-v-b3ce136f]{color:#fff;font-size:14px;margin:0}@keyframes spin-b3ce136f{to{transform:rotate(360deg)}}.realtime-status-badge[data-v-8d407c21]{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;font-size:13px;font-weight:500;color:#e2e8f0eb;background:#0f172a8c;border:1px solid rgba(99,102,241,.25);border-radius:8px;line-height:1.3}.realtime-dot[data-v-8d407c21]{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:#94a3b8b3;box-shadow:0 0 #94a3b866}.realtime-dot.active[data-v-8d407c21]{background:#34d399;box-shadow:0 0 10px #34d39980}@media (max-width: 768px){.realtime-status-badge[data-v-8d407c21]{padding:5px 8px;font-size:11px;gap:6px}}.app-header[data-v-d0a4e3f8]{position:fixed;top:0;left:0;right:0;height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 40px;background:#0a0f1ed9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(64,224,255,.15);z-index:1000}.header-left[data-v-d0a4e3f8]{display:flex;align-items:center;gap:12px}.header-logo[data-v-d0a4e3f8]{height:45px;width:auto}.header-brand[data-v-d0a4e3f8]{font-size:20px;font-weight:600;color:#fffffff2;letter-spacing:1px}.header-center[data-v-d0a4e3f8]{flex:1;display:flex;justify-content:center}.header-center-text[data-v-d0a4e3f8]{font-size:16px;color:#fffc;font-weight:500}.header-right[data-v-d0a4e3f8]{display:flex;align-items:center;gap:12px}.username[data-v-d0a4e3f8]{color:#e2e8f0f2;font-size:14px;font-weight:500;padding:6px 12px;background:#6366f126;border-radius:6px;border:1px solid rgba(99,102,241,.3)}.header-btn[data-v-d0a4e3f8]{padding:8px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid}.header-btn.primary[data-v-d0a4e3f8]{background:#2196f333;border-color:#2196f366;color:#64b5f6f2}.header-btn.primary[data-v-d0a4e3f8]:hover{background:#2196f359;border-color:#2196f399;color:#2196f3;box-shadow:0 2px 8px #2196f366;transform:translateY(-1px)}.header-btn.danger[data-v-d0a4e3f8]{background:#ef444426;border-color:#ef44444d;color:#f87171f2}.header-btn.danger[data-v-d0a4e3f8]:hover{background:#ef444440;border-color:#ef444480;color:#ef4444;box-shadow:0 2px 8px #ef444466;transform:translateY(-1px)}.header-btn[data-v-d0a4e3f8]:active{transform:translateY(0)}@media (max-width: 768px){.app-header[data-v-d0a4e3f8]{padding:0 16px;padding-left:max(16px,env(safe-area-inset-left,0px));padding-right:max(16px,env(safe-area-inset-right,0px));padding-top:env(safe-area-inset-top,0px);height:calc(56px + env(safe-area-inset-top,0px));box-sizing:border-box}.header-logo[data-v-d0a4e3f8]{height:36px}.header-brand[data-v-d0a4e3f8]{font-size:16px}.header-btn[data-v-d0a4e3f8]{padding:6px 12px;font-size:13px}.username[data-v-d0a4e3f8]{display:none}}#app-root{width:100%;height:auto;min-height:100vh;position:relative;background:#000}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}:root{--primary-color: #1e3a8a;--primary-light: #3b82f6;--primary-lighter: #dbeafe;--success-color: #10b981;--warning-color: #f59e0b;--danger-color: #ef4444;--bg-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--bg-color: #f8fafc;--card-bg: #ffffff;--border-color: #e2e8f0;--text-primary: #1f2937;--text-secondary: #6b7280;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 20px 25px rgba(0, 0, 0, .15)}#blackhole-loading{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);color:#ffffff80;font-size:14px;z-index:-1;opacity:0;transition:opacity .3s;pointer-events:none}#blackhole-loading.visible{opacity:1}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;background:#000;display:flex;justify-content:center;align-items:center;height:100vh;-webkit-user-select:none;user-select:none;overflow:hidden;position:relative;z-index:1}html{background:#000}.screen{display:none;width:100%;height:100%;box-sizing:border-box;position:relative;z-index:2}.test-mode .screen{background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:0;box-shadow:none;border:none}#info-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg-gradient)}.test-mode #info-screen{background:transparent}.info-layout{display:flex;gap:32px;width:min(1160px,100%);align-items:stretch}.info-card{background:var(--card-bg);border-radius:20px;padding:24px 40px;box-shadow:var(--shadow-lg);width:400px;flex-shrink:0;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.info-card h1{color:var(--primary-color);text-align:center;margin-bottom:16px;font-size:28px;font-weight:700}.info-form-group{margin-bottom:14px;display:flex;flex-direction:column}.info-form-group label{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:6px;display:flex;align-items:center}.info-form-group input,.info-form-group select{padding:12px 14px;border:2px solid var(--border-color);border-radius:10px;font-size:14px;transition:all .3s ease;background:#f9fafb;font-family:inherit}.info-form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-size:6px 6px,6px 6px;background-repeat:no-repeat;cursor:pointer}.info-form-group input:focus,.info-form-group select:focus{outline:none;border-color:var(--primary-light);background:#fff;box-shadow:0 0 0 3px var(--primary-lighter)}.info-form-group input.input-invalid,.info-form-group select.input-invalid{border-color:var(--danger-color);box-shadow:0 0 0 3px #ef44442e}.input-error-message{font-size:12px;color:var(--danger-color);margin-top:4px;line-height:1.4;min-height:18px;display:none}.input-error-message.visible{display:block}#start-test-btn{width:100%;padding:14px;margin-top:20px;background:var(--primary-light);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}#start-test-btn:hover{background:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-lg)}#start-test-btn:active{transform:translateY(0)}.prep-card{flex:1;background:#fffffff5;border-radius:28px;padding:32px;box-shadow:0 24px 45px #0f172a2e;border:1px solid rgba(226,232,240,.9);display:flex;flex-direction:column;gap:20px;animation:slideUp .6s ease-out}.prep-card-content{display:flex;gap:28px;align-items:stretch}.prep-info{flex:1;display:flex;flex-direction:column;gap:18px}.device-check-panel{width:320px;flex-shrink:0;display:flex}.device-check-panel .device-check{margin-top:0;width:100%}.prep-card-header{display:flex;gap:16px;align-items:center}.prep-card-icon{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,#38bdf8,#6366f1);display:flex;justify-content:center;align-items:center;font-size:28px;box-shadow:0 10px 30px #4f46e540}.prep-card-subtitle{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:#64748b;margin-bottom:4px}.prep-card h2{font-size:22px;color:var(--text-primary);margin:0}.prep-card-greeting{font-size:14px;line-height:1.7;color:var(--text-secondary)}.prep-checklist{list-style:none;display:flex;flex-direction:column;gap:14px;margin:0;padding:0}.prep-checklist li{display:flex;gap:12px;padding:14px 16px;border-radius:16px;background:#f8fafce6;border:1px solid rgba(226,232,240,.8)}.prep-checklist .dot{width:10px;height:10px;border-radius:3px;background:linear-gradient(135deg,#0ea5e9,#2563eb);margin-top:8px}.prep-checklist .item-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.prep-checklist .item-desc{font-size:13px;color:var(--text-secondary);line-height:1.6}.device-check{margin-top:8px;padding:12px 14px;border-radius:16px;border:1px dashed rgba(148,163,184,.8);background:linear-gradient(135deg,#f8fafcf2,#ecf4fff2);display:flex;flex-direction:column;gap:12px;box-shadow:inset 0 0 0 1px #94a3b833;transition:transform .3s ease,box-shadow .3s ease}#device-check-container{margin-top:6px}.device-check.device-check-alert{animation:deviceCheckShake .4s ease;box-shadow:inset 0 0 0 1px #ef444459,0 10px 30px #ef444426}@keyframes deviceCheckShake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(5px)}75%{transform:translate(-3px)}}.device-check-header{display:flex;align-items:center;gap:12px}.device-check-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#38bdf8,#6366f1);display:flex;align-items:center;justify-content:center;font-size:22px}.device-check-title{font-size:14px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:.02em}.device-check-tip{margin:4px 0 0;font-size:13px;color:var(--text-secondary)}.device-check-desc{font-size:13px;line-height:1.5;color:var(--text-secondary)}.device-check-actions{display:flex;gap:10px;flex-wrap:wrap}.device-check-actions button{flex:1;min-width:150px;border-radius:10px;border:2px solid var(--border-color);background:#fff;padding:10px 12px;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s ease;color:var(--text-primary);box-shadow:var(--shadow-sm)}.device-check-actions button:hover{border-color:var(--primary-light);color:var(--primary-light);box-shadow:var(--shadow-md)}.device-check-actions button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.device-check-actions button.device-check-success{border-color:#10b98199;color:var(--success-color)}.device-check-actions button.device-check-error{border-color:#ef444499;color:var(--danger-color)}.device-check-result{align-self:flex-start;padding:6px 16px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.03em;background:#f8fafce6;color:var(--primary-color);border:1px solid rgba(148,163,184,.4);text-transform:uppercase}.device-check[data-status=ready] .device-check-result{background:#10b9811f;color:var(--success-color);border-color:#10b9814d}.device-check[data-status=error] .device-check-result{background:#ef44441f;color:var(--danger-color);border-color:#ef444459}.device-check[data-status=checking] .device-check-result{background:#0ea5e926;color:var(--primary-light);border-color:#0ea5e966}@media (max-width: 1200px){.info-layout{flex-wrap:wrap;justify-content:center}.info-card{width:100%;max-width:460px}.prep-card{width:100%}.prep-card-content{flex-direction:column}.device-check-panel{width:100%}}@media (max-width: 768px){body{overflow-y:auto}#info-screen{padding:32px 16px}.info-layout{flex-direction:column;gap:20px}.info-card{padding:20px}.prep-card{padding:24px 20px}.prep-card-header{flex-direction:column;align-items:flex-start}.prep-checklist li{flex-direction:column}}#enter-btn{padding:8px 28px;margin-top:10px;background:var(--primary-light);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer}.app-window{display:flex;flex-direction:column;width:95vw;max-width:1200px;height:95vh;max-height:900px;background:transparent;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:var(--shadow-lg),0 0 60px #0000004d;overflow:hidden;position:relative;z-index:10}.test-mode .app-window{background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:0;box-shadow:none;border:none}.title-bar{background:linear-gradient(90deg,var(--primary-color),var(--primary-light));color:#fff;padding:16px 24px;font-size:18px;font-weight:600;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color)}.title-bar .logo{width:132px;height:105px;margin-right:10px}.title-content{display:flex;align-items:center}.test-mode .title-bar{background:transparent;border:none}.title-bar-right{display:flex;align-items:center;gap:16px}.progress-info{font-size:14px;opacity:.9}.auth-controls{display:flex;align-items:center;gap:12px;padding-left:16px;border-left:1px solid rgba(255,255,255,.3)}.username{font-size:14px;opacity:.95;font-weight:500}.logout-btn,.login-btn{padding:6px 16px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:inherit}.logout-btn:hover,.login-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.logout-btn:active,.login-btn:active{transform:translateY(0)}.main-content{flex:1;position:relative;display:flex;justify-content:center;align-items:center;overflow:hidden;background:transparent}.test-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#000000e6,#1e3a8ad9,#000000e6)!important;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);z-index:300;transition:opacity .25s ease;color:#fffffff2!important;box-shadow:inset 0 0 100px #667eea26}.test-loading-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none;background:linear-gradient(135deg,#000000e6,#1e3a8ad9,#000000e6)!important}.test-loading-content{text-align:center;max-width:320px;line-height:1.5;display:flex;flex-direction:column;gap:12px}.test-loading-spinner{width:56px;height:56px;border-radius:50%;border:4px solid rgba(255,255,255,.15);border-top-color:var(--primary-light);border-right-color:#3b82f680;animation:spin 1s linear infinite;margin:0 auto;box-shadow:0 0 20px #3b82f64d,inset 0 0 20px #3b82f61a}.test-loading-text{font-size:18px;font-weight:600;color:#fffffff2;text-shadow:0 2px 10px rgba(0,0,0,.3)}.test-loading-subtext{font-size:14px;color:#ffffffb3;text-shadow:0 1px 5px rgba(0,0,0,.2)}#welcome-text-container,#intro-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:6px 10px;box-sizing:border-box;animation:fadeIn .5s ease-out;overflow:hidden}#welcome-text-container{display:flex;align-items:center;justify-content:center}#welcome-text-container.hidden{opacity:0;pointer-events:none;visibility:hidden;transition:opacity .25s ease}.welcome-card{width:100%;max-width:720px;background:#fff;border-radius:22px;padding:8px 18px;box-shadow:0 25px 60px #0f172a2e;border:1px solid rgba(99,102,241,.15);display:flex;flex-direction:column;gap:8px;color:var(--text-primary)}.welcome-badge{display:flex;align-items:center;gap:16px}.welcome-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#38bdf8,#6366f1);display:flex;align-items:center;justify-content:center;font-size:28px}.welcome-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--primary-light);font-weight:700;margin-bottom:6px}.welcome-badge h2{font-size:18px;color:var(--text-primary)}.welcome-intro{font-size:13px;line-height:1.4;color:var(--text-secondary);background:#f8fafc;border-radius:14px;padding:10px 12px}.welcome-list{list-style:none;display:flex;flex-direction:column;gap:6px;padding:0;font-size:14px}.welcome-list li{display:flex;align-items:flex-start;gap:10px;padding:6px 10px;border-radius:14px;background:linear-gradient(135deg,#3b82f614,#0ea5e914);border:1px solid rgba(148,163,184,.3);box-shadow:var(--shadow-sm);line-height:1.5}.welcome-dot{width:9px;height:9px;border-radius:999px;background:var(--primary-light);margin-top:6px;flex-shrink:0}.welcome-list li>div{flex:1;word-break:break-word}.welcome-cta{align-self:flex-end;padding:11px 26px;border-radius:999px;border:none;background:linear-gradient(90deg,#2563eb,#7c3aed);color:#fff;font-weight:600;cursor:pointer;box-shadow:0 12px 30px #6366f159;transition:transform .2s ease,box-shadow .2s ease}.welcome-cta:hover{transform:translateY(-2px);box-shadow:0 18px 35px #6366f166}#intro-overlay .intro-preview-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:20px;width:100%;max-width:1200px;max-height:100%;align-items:stretch;min-height:0;overflow:hidden}.intro-preview-panel{background:#fff;border-radius:16px;padding:10px;box-shadow:0 20px 45px #0f172a1f;display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden}.test-preview-window{display:flex;flex-direction:column;gap:10px;background:#f8fafc;border-radius:16px;border:1px solid rgba(148,163,184,.3);padding:12px;min-height:0;flex:1;overflow:hidden}.test-preview-title-bar{display:flex;justify-content:center;align-items:center;padding:8px 12px;border-radius:12px;background:linear-gradient(90deg,var(--primary-color),var(--primary-light));color:#fff;font-weight:600;font-size:14px;flex-shrink:0}.test-preview-status{font-size:13px;letter-spacing:.08em;text-transform:uppercase;opacity:.85}.test-preview-body{display:flex;flex-direction:column;gap:10px;min-height:0;flex:1;overflow:hidden}.test-preview-image-area{background:#fff;border-radius:14px;padding:8px;box-shadow:inset 0 0 0 1px #94a3b833;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.test-preview-image-frame{width:100%;flex:1;min-height:0;border-radius:12px;overflow:hidden;position:relative}#intro-preview-image{width:100%;height:100%}.test-preview-canvas{position:absolute;top:0;right:0;bottom:0;left:0;cursor:crosshair;background:transparent}.test-preview-controls{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;flex-shrink:0;margin-top:8px;padding-top:8px;position:relative;z-index:10;background:#f8fafc}.test-preview-controls .control-group{background:#fff;border-radius:8px;padding:4px 8px;box-shadow:var(--shadow-sm);border:1px solid rgba(148,163,184,.2)}.test-preview-controls .control-group button,.test-preview-controls .color-option{cursor:pointer}.test-preview-controls .control-group button{min-width:70px;font-size:12px;padding:4px 8px;display:flex;align-items:center;justify-content:center;gap:4px}.intro-info-panel{background:#fff;border-radius:16px;padding:12px 16px;box-shadow:0 20px 45px #0f172a14;display:flex;flex-direction:column;gap:10px;min-height:0;max-height:100%;overflow:hidden}.intro-info-header{display:flex;gap:12px;align-items:center;flex-shrink:0}.intro-info-icon{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,#38bdf8,#6366f1);display:flex;align-items:center;justify-content:center;font-size:28px}.intro-info-label{font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--primary-light);font-weight:700}.intro-info-panel h2{color:var(--text-primary);font-size:18px;margin:0;flex-shrink:0}.intro-info-text{font-size:13px;line-height:1.7;color:#475569;background:linear-gradient(135deg,#fff,#f8fafc,#f1f5f9);border-radius:14px;padding:10px 12px;flex:1.3;min-height:0;overflow:hidden;overflow-y:hidden;border:1px solid rgba(148,163,184,.2);box-shadow:inset 0 1px 3px #0f172a0f,0 1px 2px #0f172a0a;position:relative;letter-spacing:.015em}.intro-info-text:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#38bdf8,#6366f1,#8b5cf6);border-radius:16px 16px 0 0;opacity:.85}.intro-info-text:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.2),transparent)}.intro-info-text p{margin:0 0 10px;position:relative;padding-left:24px;padding-top:3px;text-align:justify}.intro-info-text p:last-child{margin-bottom:0}.intro-info-text p:before{content:"▸";position:absolute;left:0;top:3px;color:#6366f1;font-size:16px;font-weight:400;line-height:1.8;opacity:.7}.intro-info-text p:first-child:before{content:"✦";font-size:18px;opacity:.8;color:#8b5cf6}.intro-info-text p:before{content:"✦";font-size:18px;opacity:.8;color:#8b5cf6}.intro-info-text strong{color:#1e293b;font-weight:600;background:linear-gradient(135deg,#6366f11f,#8b5cf614);padding:2px 6px;border-radius:4px;display:inline-block;margin:0 2px;border-left:2px solid rgba(99,102,241,.3)}.intro-enter-btn{align-self:center;margin-top:4px;padding:8px 22px;border-radius:999px;border:none;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-weight:600;font-size:15px;cursor:pointer;box-shadow:0 12px 30px #6366f159;flex-shrink:0}.intro-enter-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.app-window.intro-mode .progress-info{opacity:0;pointer-events:none}.intro-driver-popover{background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);box-shadow:var(--shadow-lg);color:var(--text-primary);padding:20px;min-width:260px;font-family:inherit}.intro-driver-popover .driver-popover-title{font-size:16px;font-weight:700;color:var(--primary-color);margin-bottom:8px}.intro-driver-popover .driver-popover-description{font-size:14px;line-height:1.6;color:var(--text-secondary)}.intro-driver-popover .driver-popover-progress-text{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:12px}.intro-driver-popover .driver-popover-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.intro-driver-popover .driver-popover-footer button{border-radius:999px;border:none;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:all .25s ease;box-shadow:var(--shadow-sm)}.intro-driver-popover .driver-prev-btn,.intro-driver-popover .driver-close-btn{background:#e2e8f0;color:var(--text-primary)}.intro-driver-popover .driver-next-btn,.intro-driver-popover .driver-done-btn{background:var(--primary-light);color:#fff}.intro-driver-popover .driver-popover-footer button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.intro-driver-popover .driver-popover-footer button:active{transform:translateY(0)}.intro-driver-popover .driver-next-btn,.intro-driver-popover .driver-prev-btn,.intro-driver-popover [data-action=next],.intro-driver-popover [data-action=prev]{display:none!important}.intro-driver-popover .driver-popover-close-btn,.intro-driver-popover .driver-close-btn{display:block!important}.intro-driver-popover .driver-popover-arrow{width:0;height:0;border:9px solid transparent;z-index:1;box-shadow:none}.intro-driver-popover .driver-popover-arrow-side-right,.intro-driver-popover .driver-popover-arrow-side-left{top:50%;bottom:auto;transform:translateY(-50%)}.intro-driver-popover .driver-popover-arrow-side-right.driver-popover-arrow-align-start,.intro-driver-popover .driver-popover-arrow-side-left.driver-popover-arrow-align-start{top:20px!important;bottom:auto!important;transform:none!important}.intro-step-2-popover .driver-popover-arrow-side-right.driver-popover-arrow-align-end,.intro-step-2-popover .driver-popover-arrow-side-left.driver-popover-arrow-align-end{top:95px!important;bottom:auto!important;transform:none!important}.intro-step-3-popover .driver-popover-arrow-side-right.driver-popover-arrow-align-end,.intro-step-3-popover .driver-popover-arrow-side-left.driver-popover-arrow-align-end{top:auto!important;bottom:25px!important;transform:none!important}.intro-driver-popover[data-step="2"] .driver-popover-arrow-side-right.driver-popover-arrow-align-end,.intro-driver-popover[data-step="2"] .driver-popover-arrow-side-left.driver-popover-arrow-align-end{top:95px!important;bottom:auto!important;transform:none!important}.intro-driver-popover[data-step="3"] .driver-popover-arrow-side-right.driver-popover-arrow-align-end,.intro-driver-popover[data-step="3"] .driver-popover-arrow-side-left.driver-popover-arrow-align-end{top:auto!important;bottom:25px!important;transform:none!important}.intro-driver-popover .driver-popover-arrow.driver-popover-arrow-side-right.driver-popover-arrow-align-end.intro-step-2,.intro-driver-popover .driver-popover-arrow.driver-popover-arrow-side-left.driver-popover-arrow-align-end.intro-step-2{top:95px!important;bottom:auto!important;transform:none!important}.intro-driver-popover .driver-popover-arrow.driver-popover-arrow-side-right.driver-popover-arrow-align-end.intro-step-3,.intro-driver-popover .driver-popover-arrow.driver-popover-arrow-side-left.driver-popover-arrow-align-end.intro-step-3{top:auto!important;bottom:25px!important;transform:none!important}.driver-popover-title{font-size:14px}.driver-popover-description{font-size:12px}.intro-driver-popover .driver-popover-arrow-side-right{border-right-color:var(--card-bg);border-left:none;left:-9px!important;right:auto!important;filter:drop-shadow(1px 0 0 rgba(15,23,42,.12))}.intro-driver-popover .driver-popover-arrow-side-left{border-left-color:var(--card-bg);border-right:none;right:-9px!important;left:auto!important;filter:drop-shadow(-1px 0 0 rgba(15,23,42,.12))}.intro-driver-popover .driver-popover-arrow-side-top,.intro-driver-popover .driver-popover-arrow-side-bottom{left:50%!important;right:auto!important;transform:translate(-50%)!important}.intro-driver-popover .driver-popover-arrow-side-top{border-top-color:var(--card-bg);border-bottom:none;top:auto!important;bottom:-9px!important;filter:drop-shadow(0 -1px 0 rgba(15,23,42,.12))}.intro-driver-popover .driver-popover-arrow-side-bottom{border-bottom-color:var(--card-bg);border-top:none;bottom:auto!important;top:-9px!important;filter:drop-shadow(0 1px 0 rgba(15,23,42,.12))}@media (max-width: 768px){.welcome-card{border-radius:16px;padding:24px}.welcome-badge{flex-direction:column;align-items:flex-start}.welcome-icon{width:48px;height:48px;border-radius:12px;font-size:24px}.welcome-badge h2{font-size:20px}.welcome-list li{flex-direction:row;padding:14px 16px}.welcome-cta{width:100%;justify-content:center;text-align:center}}#intro-image{max-width:300px;max-height:300px;object-fit:contain;margin-bottom:20px;border-radius:12px;box-shadow:var(--shadow-md)}#intro-text{line-height:1.8;max-width:700px;text-align:left;color:var(--text-primary);padding:20px;background:#fff;border-radius:12px;box-shadow:var(--shadow-sm)}#image-container{position:relative;display:flex;justify-content:center;align-items:center;width:100%;height:100%;background:transparent;padding:24px 24px 0;min-height:min(70vh,640px)}@keyframes spin{to{transform:rotate(360deg)}}#rorschach-image{max-width:90%;max-height:90%;object-fit:contain;border-radius:8px;transform-origin:center center;transition:transform .2s ease-out;will-change:transform}#drawing-canvas{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transform-origin:center center;max-width:90%;max-height:90%;transition:transform .2s ease-out;will-change:transform}#post-test-view,#summary-view{padding:16px 20px;overflow:hidden;height:100%;max-height:100vh;background:var(--card-bg);box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}#post-test-view{scrollbar-width:none;-ms-overflow-style:none}#post-test-view::-webkit-scrollbar{width:0;height:0;display:none}#summary-view{scrollbar-width:none;-ms-overflow-style:none}#summary-view::-webkit-scrollbar{width:0;height:0;display:none}.post-test-header{display:flex;align-items:center;justify-content:center;width:100%;max-width:1100px;margin-bottom:12px;flex-shrink:0;position:relative}#post-test-view h2{text-align:center;margin-bottom:0;margin-top:0;color:#fffffff2;font-size:22px;font-weight:700;letter-spacing:.3px;text-shadow:0 2px 8px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;gap:10px;flex-shrink:0;flex:1}#summary-view h2{text-align:center;margin-bottom:12px;margin-top:0;color:#fffffff2;font-size:22px;font-weight:700;letter-spacing:.3px;text-shadow:0 2px 8px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;gap:10px;flex-shrink:0}#question-text{font-size:14px;font-weight:500;color:#1f2937;text-align:left;line-height:1.6;padding:16px 20px;background:#fffffffa;border-radius:12px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;border:1px solid rgba(255,255,255,.2);margin-bottom:16px;animation:slideUp .3s ease-out;position:relative;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);flex-shrink:0;width:100%;max-width:1100px;box-sizing:border-box;z-index:10}#question-text:before{content:"";position:absolute;top:-1px;left:0;right:0;height:5px;background:linear-gradient(90deg,#38bdf8,#3b82f6,#6366f1,#8b5cf6,#a855f7);border-radius:12px 12px 0 0;opacity:1;box-shadow:0 2px 8px #6366f14d,0 0 12px #3b82f633}.image-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-auto-rows:1fr;gap:12px;margin-bottom:12px;width:100%;max-width:1100px;flex:1;min-height:0;align-items:stretch}.grid-item{border:2px solid rgba(100,150,255,.4);border-radius:12px;padding:8px;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:#0f172a99;overflow:hidden;box-shadow:0 4px 16px #0000004d,0 0 20px #6496ff1a,inset 0 1px #ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;min-height:0;position:relative}.grid-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:12px;background:linear-gradient(135deg,#3b82f61a,#6366f10d,#8b5cf61a);opacity:0;transition:opacity .3s ease;pointer-events:none}.grid-item:hover{border-color:#64c8ffb3;transform:translateY(-6px);box-shadow:0 12px 32px #0006,0 0 30px #64c8ff4d,0 0 60px #3b82f633,inset 0 1px #fff3;background:#0f172abf}.grid-item:hover:before{opacity:1}.grid-item.selected{border-color:#40e0ffe6;border-width:3px;background:linear-gradient(135deg,#1e3a8ab3,#3b82f680,#6366f199);box-shadow:0 0 0 4px #40e0ff4d,0 12px 32px #40e0ff66,0 0 40px #40e0ff4d,0 0 80px #64c8ff33,inset 0 1px #ffffff4d;transform:scale(1.03);position:relative}.grid-item.selected:after{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;border-radius:12px;background:linear-gradient(135deg,#40e0ff4d,#64c8ff33,#8b5cf64d);z-index:-1;animation:pulseGlow 2s ease-in-out infinite}@keyframes pulseGlow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.grid-item img{width:100%;height:auto;border-radius:10px;display:block;transition:transform .3s ease;flex:1;object-fit:contain;min-height:0}.grid-item:hover img{transform:scale(1.02)}.grid-item h4{margin-top:6px;font-size:12px;color:#ffffffe6;font-weight:600;letter-spacing:.2px;flex-shrink:0;text-shadow:0 1px 3px rgba(0,0,0,.5)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));width:100%;max-width:1100px;gap:12px;margin-bottom:0;flex:1;min-height:0;align-items:stretch}.summary-item{border:2px solid rgba(100,150,255,.4);border-radius:12px;padding:10px;text-align:center;background:#0f172a99;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #0000004d,0 0 20px #6496ff1a,inset 0 1px #ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;position:relative;overflow:hidden;min-height:0}.summary-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:16px;background:linear-gradient(135deg,#3b82f61a,#6366f10d,#8b5cf61a);opacity:0;transition:opacity .3s ease;pointer-events:none}.summary-item:hover{border-color:#64c8ffb3;transform:translateY(-6px);box-shadow:0 12px 32px #0006,0 0 30px #64c8ff4d,0 0 60px #3b82f633,inset 0 1px #fff3;background:#0f172abf}.summary-item:hover:before{opacity:1}.summary-item img{width:100%;height:auto;border-radius:10px;margin-bottom:8px;transition:transform .3s ease;flex:1;object-fit:contain;min-height:0}.summary-item h4{margin-top:0;margin-bottom:0;color:#ffffffe6;font-weight:600;font-size:12px;letter-spacing:.2px;text-shadow:0 1px 3px rgba(0,0,0,.5);flex-shrink:0}.summary-item:hover img{transform:scale(1.02)}.summary-report-card{text-align:center;padding:28px 32px;background:linear-gradient(135deg,#fffffffa,#f8fafcfa);border-radius:20px;margin-bottom:24px;box-shadow:0 10px 40px #0000001f,0 4px 12px #00000014,inset 0 1px #fffc;border:1px solid rgba(226,232,240,.6);position:relative;width:100%;max-width:1100px;box-sizing:border-box;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideUp .4s cubic-bezier(.4,0,.2,1);transition:all .4s cubic-bezier(.4,0,.2,1);overflow:hidden}.summary-report-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#38bdf8,#3b82f6,#6366f1,#8b5cf6,#a855f7,#ec4899);border-radius:20px 20px 0 0;opacity:1;box-shadow:0 4px 12px #6366f14d,0 0 20px #3b82f633,inset 0 1px 2px #ffffff80}.summary-report-card:after{content:"";position:absolute;top:5px;left:0;right:0;bottom:0;background:radial-gradient(ellipse at top,rgba(139,92,246,.03) 0%,transparent 50%);pointer-events:none;border-radius:0 0 20px 20px}.summary-report-card:hover{box-shadow:0 16px 50px #00000029,0 6px 16px #0000001a,0 0 30px #6366f126,inset 0 1px #ffffffe6;transform:translateY(-4px);border-color:#8b5cf64d}.summary-report-card:hover:before{box-shadow:0 6px 16px #6366f166,0 0 30px #3b82f64d,inset 0 1px 3px #fff9}.summary-report-card h3{color:transparent;background:linear-gradient(135deg,#1e3a8a,#6366f1,#8b5cf6);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0 0 12px;font-size:22px;font-weight:700;letter-spacing:.3px;position:relative;z-index:1;text-shadow:0 2px 4px rgba(30,58,138,.1)}.summary-report-card p{margin:0 0 8px;color:#475569;font-size:14px;line-height:1.7;font-weight:500;position:relative;z-index:1}.summary-report-card>div{font-size:13px;color:#64748b;margin-top:6px;opacity:.85;font-weight:500;position:relative;z-index:1}.summary-report-card #download-report-status{margin-top:8px;font-size:13px;color:#64748b;min-height:20px;font-weight:500;position:relative;z-index:1}.summary-report-card #download-report-btn{padding:12px 32px;background:linear-gradient(135deg,#3b82f6,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #3b82f64d,0 2px 6px #0000001a,inset 0 1px #fff3;margin-top:16px;letter-spacing:.3px;position:relative;z-index:1;overflow:hidden}.summary-report-card #download-report-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.summary-report-card #download-report-btn:hover:before{left:100%}.summary-report-card #download-report-btn:hover{background:linear-gradient(135deg,#2563eb,#4f46e5,#7c3aed);transform:translateY(-3px);box-shadow:0 8px 20px #3b82f666,0 4px 10px #00000026,0 0 20px #6366f14d,inset 0 1px #ffffff4d}.summary-report-card #download-report-btn:active{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d,0 2px 6px #0000001a,inset 0 1px #fff3}.summary-report-card #download-report-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;background:linear-gradient(135deg,#94a3b8,#64748b);box-shadow:0 2px 6px #0000001a}.summary-report-card #publicity-report-btn{padding:12px 32px;background:linear-gradient(135deg,#10b981,#14b8a6,#06b6d4);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #10b9814d,0 2px 6px #0000001a,inset 0 1px #fff3;position:relative;overflow:hidden}.summary-report-card #publicity-report-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.summary-report-card #publicity-report-btn:hover:before{left:100%}.summary-report-card #publicity-report-btn:hover{background:linear-gradient(135deg,#059669,#0d9488,#0891b2);transform:translateY(-3px);box-shadow:0 8px 20px #10b98166,0 4px 10px #00000026,0 0 20px #14b8a64d,inset 0 1px #ffffff4d}.summary-report-card #publicity-report-btn:active{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d,0 2px 6px #0000001a,inset 0 1px #fff3}.summary-report-card #publicity-report-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;background:linear-gradient(135deg,#94a3b8,#64748b);box-shadow:0 2px 6px #0000001a}#restart-test-btn{position:absolute;top:12px;right:12px;border:none;background:#3b82f61a;color:var(--primary-color);font-weight:600;font-size:14px;padding:10px 24px;min-height:44px;border-radius:999px;cursor:pointer;box-shadow:var(--shadow-sm);transition:all .2s ease;border:1px solid rgba(59,130,246,.2);z-index:10}#restart-test-btn:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;cursor:pointer}#restart-test-btn:hover{background:var(--primary-light);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}#restart-test-btn:active{transform:translateY(0)}.subtitle-container{position:relative;width:100%;min-height:50px;z-index:100}.subtitle-content{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center}.subtitle-text{height:100%;display:flex;justify-content:center;align-items:center;font-size:14px;font-weight:400;line-height:1.6;color:#ffffffeb;text-align:center;border-radius:20px;border:none;min-height:20px;word-wrap:break-word;word-break:break-all;transition:all .25s ease}.typing-cursor{display:inline-block;width:2px;height:1em;min-height:14px;background:#ffffffe6;animation:blink 1s infinite;margin-left:3px;vertical-align:middle;border-radius:1px;content:"";-webkit-user-select:none;user-select:none;pointer-events:none}.controls-bar{display:flex;justify-content:center;align-items:center;padding-bottom:16px;flex-wrap:wrap;gap:12px}.control-group{display:flex;align-items:center;gap:8px;background:#ffffff1a;padding:8px 12px;border-radius:8px;box-shadow:var(--shadow-sm);border:1px solid rgba(255,255,255,.1)}.control-group button{padding:8px 12px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff1a;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:6px}.test-mode .control-group button{color:#ffffffe6}.control-group button:hover{border-color:var(--primary-light);background:#3b82f64d;color:#fff}.control-group button:disabled{opacity:.5;cursor:not-allowed}.control-group button.selected{background:var(--primary-light);border-color:var(--primary-color);color:#fff;box-shadow:0 0 0 3px var(--primary-lighter)}.color-selector{display:flex;align-items:center;gap:8px}.color-option{width:24px;height:24px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.color-option:hover{transform:scale(1.15)}.color-option.selected{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #333}.post-test-actions{display:flex;justify-content:flex-end;width:100%;max-width:1100px;margin-top:16px;margin-bottom:16px;padding-right:0;flex-shrink:0;position:relative;z-index:10;min-height:50px}#next-question-btn{padding:7px 28px;display:inline-block;background:#0f172ab3;color:#fffffff2;border:2px solid rgba(100,200,255,.6);border-radius:12px;font-size:15px;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #0000004d,0 0 20px #64c8ff33,0 0 40px #3b82f626,inset 0 1px #ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:absolute;right:0;text-shadow:0 1px 3px rgba(0,0,0,.5);z-index:11;flex-shrink:0}#next-question-btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:12px;background:linear-gradient(135deg,#3b82f633,#6366f126,#8b5cf633);opacity:0;transition:opacity .3s ease;pointer-events:none}#next-question-btn:hover{background:#0f172ad9;border-color:#64c8ffe6;box-shadow:0 6px 20px #0006,0 0 30px #64c8ff4d,0 0 50px #3b82f633,inset 0 1px #ffffff26;transform:translateY(-1px)}#next-question-btn:hover:before{opacity:1}#next-question-btn:active{transform:translateY(0);box-shadow:0 2px 8px #0000004d,0 0 15px #64c8ff33,inset 0 1px 2px #0003}#next-question-btn:disabled{opacity:.5;cursor:not-allowed;background:#0f172a80;border-color:#64c8ff4d}.finish{display:flex;justify-content:center;width:100%;margin-top:32px;flex-shrink:0}.prompt-indicator{position:fixed;bottom:20px;right:20px;background:var(--warning-color);color:#fff;padding:12px 16px;border-radius:8px;font-size:13px;font-weight:600;animation:slideInUp .3s ease-out;box-shadow:var(--shadow-lg);z-index:200}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.info-card{padding:30px 20px}#post-test-view,#summary-view{padding:24px 20px}#post-test-view h2,#summary-view h2{font-size:24px;margin-bottom:24px}#question-text{font-size:15px;padding:20px 24px;margin-bottom:24px}.image-grid{grid-template-columns:repeat(3,minmax(100px,1fr));gap:14px;margin-bottom:24px}.grid-item{padding:10px}.grid-item h4{font-size:13px;margin-top:10px}.summary-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.summary-item{padding:16px}.controls-bar{gap:8px}.control-group{padding:6px 8px;font-size:12px}.control-group button{padding:6px 10px;font-size:12px}}@media (max-width: 480px){.image-grid{grid-template-columns:repeat(2,minmax(100px,1fr));gap:12px}#post-test-view h2,#summary-view h2{font-size:22px}#question-text{font-size:14px;padding:18px 20px}}#rorschach-image{transition:opacity .8s ease-in-out,transform .2s ease-out}#rorschach-image.image-fade-out{opacity:0;transform:scale(.95)}#rorschach-image.image-fade-in{animation:imageFadeIn .8s ease-out forwards}@keyframes imageFadeIn{0%{opacity:0;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}#drawing-canvas{transition:opacity .8s ease-in-out,transform .2s ease-out}#rorschach-image.image-fade-out~#drawing-canvas{opacity:0}#energy-pillar-container{position:fixed;right:30px;top:50%;transform:translateY(-50%);z-index:100;pointer-events:none;display:none}#energy-pillar-container.visible,.test-mode #energy-pillar-container.visible{display:block}body:not(.test-mode) #energy-pillar-container{display:none!important}#energy-pillar{width:32px;height:280px;position:relative;border-radius:16px;overflow:visible}#energy-pillar-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:#141e3299;border:1px solid rgba(100,150,200,.3);border-radius:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow:hidden}#energy-fill{position:absolute;bottom:0;left:2px;right:2px;height:0%;background:linear-gradient(to top,#40e0ff,#64c8fffa,#8cb4fff2,#b4a0ffe6,#dc8cffbf);border-radius:0 0 14px 14px;transition:height .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 35px #40e0ffcc,0 0 70px #64c8ff80,0 0 100px #b4a0ff4d,inset 0 0 30px #fff6,inset 0 -10px 25px #40e0ffb3;border-top:1px solid rgba(220,140,255,.8)}#energy-fill.empty{border-top:1px solid transparent}#energy-fill:before{content:"";position:absolute;top:0;left:0;right:0;height:20%;background:linear-gradient(to bottom,rgba(255,255,255,.3) 0%,transparent 100%);border-radius:0 0 14px 14px;pointer-events:none}#energy-ripple{position:absolute;bottom:0;left:0;right:0;height:100%;background:repeating-linear-gradient(0deg,transparent 0px,transparent 8px,rgba(255,255,255,.1) 8px,rgba(255,255,255,.1) 10px);animation:energyRipple 2s linear infinite;opacity:0;transition:opacity .3s}#energy-ripple.active{opacity:1}#energy-particles{position:absolute;top:0;right:0;width:200px;height:280px;pointer-events:none;overflow:visible}.energy-particle{position:absolute;width:6px;height:6px;border-radius:50%;pointer-events:none;animation:particleFloat 1.5s ease-in forwards}.energy-particle.cyan{background:radial-gradient(circle,#00ffff 0%,#00aaff 50%,transparent 100%);box-shadow:0 0 8px #0ff,0 0 15px #00ffff80}.energy-particle.magenta{background:radial-gradient(circle,#ff00ff 0%,#aa00ff 50%,transparent 100%);box-shadow:0 0 8px #f0f,0 0 15px #ff00ff80}.energy-particle.blue{background:radial-gradient(circle,#4080ff 0%,#0040ff 50%,transparent 100%);box-shadow:0 0 8px #4080ff,0 0 15px #4080ff80}.energy-particle.white{background:radial-gradient(circle,#ffffff 0%,#aaccff 50%,transparent 100%);box-shadow:0 0 8px #fff,0 0 15px #ffffff80}#energy-pillar:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40px;height:40px;background:radial-gradient(circle,rgba(0,220,255,.4) 0%,transparent 70%);border-radius:50%;opacity:0;animation:none}#energy-pillar.pulse:after{animation:energyPulse .6s ease-out}body:has(#post-test-view[style*="display: block"]){background:transparent!important}.app-window:has(#post-test-view[style*="display: block"]){background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;box-shadow:none!important;border:none!important}.app-window:has(#post-test-view[style*="display: block"]) .title-bar{background:transparent!important;border:none!important}#post-test-view[style*="display: block"]{background:transparent!important}body:has(#summary-view[style*="display: block"]){background:transparent!important}.app-window:has(#summary-view[style*="display: block"]){background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;box-shadow:none!important;border:none!important}.app-window:has(#summary-view[style*="display: block"]) .title-bar{background:transparent!important;border:none!important}#summary-view[style*="display: block"]{background:transparent!important}body:has(#post-test-view[style*="display: block"]) #blackhole-bg-container,body:has(#summary-view[style*="display: block"]) #blackhole-bg-container{display:block!important;visibility:visible!important;opacity:1!important;z-index:0!important}#blackhole-bg-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;background:#000}body:has(#info-screen[style*="display: flex"]) #blackhole-bg-container,body:has(#info-screen:not([style*="display: none"])) #blackhole-bg-container{display:block!important;visibility:visible!important;opacity:1!important;z-index:0!important}body:not(.test-mode) #blackhole-bg-container{display:block!important;visibility:visible!important;opacity:1!important;z-index:0!important}.app-window.intro-mode #blackhole-bg-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;background:#000;display:block!important;visibility:visible!important;opacity:1!important}body:has(#intro-overlay[style*="display: flex"]) #blackhole-bg-container,body:has(#intro-overlay[style*="display: block"]) #blackhole-bg-container,.app-window.intro-mode #blackhole-bg-container{display:block!important;visibility:visible!important;opacity:1!important;z-index:0!important}#intro-overlay{background:transparent!important;position:relative;z-index:1;animation:fadeInIntro .8s ease-out}@keyframes fadeInIntro{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}#intro-overlay[style*="display: flex"],#intro-overlay[style*="display: block"],#info-screen{background:transparent!important}.info-card{background:#0f172abf!important;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(99,102,241,.3)!important;box-shadow:0 8px 32px #0006,0 0 0 1px #6366f11a,inset 0 1px #ffffff1a!important;position:relative;overflow:hidden}.info-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.6),rgba(139,92,246,.6),transparent);opacity:.8;z-index:1;animation:shimmer 3s ease-in-out infinite}.info-card h1{position:relative;z-index:2;color:#e2e8f0f2!important;text-shadow:0 0 10px rgba(99,102,241,.3)}.info-form-group{position:relative;z-index:2}.info-form-group label{color:#cbd5e1e6!important}.info-card input,.info-card select{background:#1e293b99!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.3)!important;color:#e2e8f0f2!important;transition:all .2s ease}.info-card input::placeholder{color:#94a3b899!important}.info-card input:focus,.info-card select:focus{background:#1e293bcc!important;border-color:#6366f199!important;box-shadow:0 0 0 3px #6366f133,0 4px 12px #6366f14d!important;outline:none}.info-card select option{background:#0f172af2;color:#e2e8f0f2}#start-test-btn,#resume-test-btn{position:relative;z-index:2;background:linear-gradient(135deg,#3b82f6,#6366f1,#8b5cf6)!important;border:1px solid rgba(99,102,241,.5)!important;box-shadow:0 4px 16px #6366f166,0 0 0 1px #ffffff1a inset!important;color:#fff!important;font-weight:600;transition:all .3s ease;text-shadow:0 0 10px rgba(255,255,255,.3)}#start-test-btn:hover,#resume-test-btn:hover{background:linear-gradient(135deg,#2563eb,#4f46e5,#7c3aed)!important;box-shadow:0 6px 20px #6366f199,0 0 0 1px #fff3 inset!important;transform:translateY(-2px)}#start-test-btn:active,#resume-test-btn:active{transform:translateY(0);box-shadow:0 2px 8px #6366f166,0 0 0 1px #ffffff1a inset!important}.input-error-message{color:#f87171e6!important;text-shadow:0 0 5px rgba(248,113,113,.3)}.title-bar{background:transparent!important;border:none!important}#welcome-text-container{max-height:100vh;overflow:hidden;padding:12px 10px!important;box-sizing:border-box}.welcome-card{background:#0f172abf!important;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(99,102,241,.3)!important;box-shadow:0 8px 32px #0006,0 0 0 1px #6366f11a,inset 0 1px #ffffff1a!important;position:relative;overflow:hidden;padding:12px 16px!important;gap:6px!important;max-height:calc(100vh - 24px);display:flex;flex-direction:column;box-sizing:border-box}.welcome-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.6),rgba(139,92,246,.6),transparent);opacity:.8;z-index:1;animation:shimmer 3s ease-in-out infinite}.welcome-badge{position:relative;z-index:2;margin-bottom:0!important;gap:12px!important}.welcome-badge h2{color:#e2e8f0f2!important;text-shadow:0 0 10px rgba(99,102,241,.3);margin:0!important;font-size:16px!important}.welcome-label{color:#93c5fde6!important;margin-bottom:2px!important}.welcome-icon{background:linear-gradient(135deg,#3b82f6cc,#6366f1cc)!important;box-shadow:0 4px 12px #6366f166,0 0 0 1px #ffffff1a inset!important;width:44px!important;height:44px!important;font-size:24px!important}.welcome-intro{position:relative;z-index:2;background:#1e293b99!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.2)!important;color:#e2e8f0e6!important;padding:8px 10px!important;margin:0!important;font-size:12px!important;line-height:1.4!important}.welcome-list{position:relative;z-index:2;gap:4px!important;margin:0!important;padding:0!important;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.welcome-list li{background:#1e293b80!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.3)!important;color:#e2e8f0e6!important;box-shadow:0 2px 8px #0000004d!important;transition:all .2s ease;padding:5px 8px!important;font-size:13px!important;line-height:1.4!important;flex-shrink:0}.welcome-list li:hover{background:#1e293bb3!important;border-color:#6366f180!important;box-shadow:0 4px 12px #6366f14d!important}.welcome-dot{background:#6366f1cc!important;box-shadow:0 0 8px #6366f180;width:7px!important;height:7px!important;margin-top:5px!important}.device-check{position:relative;z-index:2;background:#1e293b99!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.3)!important;border-radius:14px!important;box-shadow:0 4px 12px #0000004d!important;padding:10px 12px!important;margin-top:4px!important;flex-shrink:0}.device-check-header{color:#e2e8f0f2!important;gap:10px!important;margin-bottom:6px!important}.device-check-title{color:#93c5fde6!important;font-size:13px!important;margin:0!important}.device-check-tip{color:#cbd5e1e6!important;font-size:12px!important;margin:2px 0 0!important}.device-check-desc{color:#cbd5e1cc!important;font-size:12px!important;line-height:1.4!important;margin:6px 0 8px!important}.device-check-icon{background:linear-gradient(135deg,#3b82f6cc,#6366f1cc)!important;box-shadow:0 4px 12px #6366f166,0 0 0 1px #ffffff1a inset!important;width:38px!important;height:38px!important;font-size:20px!important}.device-check-actions{gap:8px!important;margin-top:8px!important}.device-check-actions button{background:#1e293bb3!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.3)!important;color:#e2e8f0e6!important;transition:all .2s ease;box-shadow:0 2px 8px #0000004d!important;padding:8px 12px!important;font-size:12px!important;min-width:auto!important;flex:1}.device-check-actions button:hover{background:#334155cc!important;border-color:#6366f180!important;box-shadow:0 4px 12px #6366f14d!important;transform:translateY(-1px)}.device-check-actions button:active{transform:translateY(0);box-shadow:0 1px 4px #0000004d!important}.device-check-result{color:#cbd5e1e6!important;background:#1e293b80!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.2)!important;border-radius:8px!important;padding:4px 12px!important;font-size:11px!important;margin-top:6px!important}.device-check[data-status=error] .device-check-result{color:#ef4444f2!important;background:#ef44441f!important;border-color:#ef444459!important}.intro-preview-panel,.test-preview-panel{z-index:10;background:#0f172abf!important;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(99,102,241,.3);box-shadow:0 8px 32px #0006,0 0 0 1px #6366f11a,inset 0 1px #ffffff1a;position:relative;overflow:hidden}.intro-preview-panel:before,.test-preview-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.6),rgba(139,92,246,.6),transparent);opacity:.8;z-index:1;animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{opacity:.4;transform:translate(-100%)}50%{opacity:.8;transform:translate(100%)}}.test-preview-window{position:relative;z-index:1;background:#0f172a66!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;border:none!important;box-shadow:inset 0 2px 8px #0003}.test-preview-body{gap:8px!important}.test-preview-image-area{background:#0f172a80!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:none!important;box-shadow:inset 0 2px 8px #0000004d;border-radius:12px!important;padding:8px!important}.test-preview-image-frame{background:#0000004d;border:none!important;box-shadow:inset 0 2px 8px #0006;border-radius:10px!important}.test-preview-controls{background:transparent!important;border:none!important;box-shadow:none!important;padding-top:6px!important;margin-top:6px!important;gap:6px!important}.test-preview-controls .control-group{background:#1e293b80!important;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:8px;border:none!important;box-shadow:0 2px 8px #0000004d;padding:4px 6px!important;gap:10px!important}.test-preview-controls button{background:#334155cc!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:none!important;color:#e2e8f0f2!important;transition:all .2s ease;box-shadow:0 2px 8px #0006,0 0 0 1px #ffffff1a inset;border-radius:6px;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.5)}.test-preview-controls button:hover:not(:disabled){background:#475569e6!important;box-shadow:0 4px 12px #6366f166,0 0 0 1px #ffffff26 inset;transform:translateY(-1px);color:#fff!important}.test-preview-controls button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #0006,0 0 0 1px #ffffff1a inset}.test-preview-controls button.selected{background:linear-gradient(135deg,#3b82f6b3,#6366f1b3)!important;border:none!important;box-shadow:0 4px 12px #6366f180,inset 0 1px #fff3,0 0 0 1px #ffffff1a inset;color:#fff!important;text-shadow:0 1px 3px rgba(0,0,0,.6)}.test-preview-controls button:disabled{opacity:.5;cursor:not-allowed;background:#1e293b80!important;color:#94a3b899!important}.test-preview-controls .color-option{border:none!important;box-shadow:0 0 0 2px #ffffff4d,0 2px 8px #0006;transition:all .2s ease}.test-preview-controls .color-option:hover{transform:scale(1.1);box-shadow:0 0 0 3px #6366f180,0 4px 12px #6366f166}.test-preview-controls .color-option.selected{border:none!important;box-shadow:0 0 0 3px #6366f1b3,0 0 16px #6366f199,0 4px 12px #6366f180;transform:scale(1.15)}#intro-overlay,.intro-preview-layout{position:relative}.intro-info-panel{z-index:10;background:#0f172abf!important;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(99,102,241,.3);box-shadow:0 8px 32px #0006,0 0 0 1px #6366f11a,inset 0 1px #ffffff1a;position:relative;overflow:hidden}.intro-info-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.6),rgba(139,92,246,.6),transparent);opacity:.8;z-index:1;animation:shimmer 3s ease-in-out infinite}.intro-info-header{position:relative;z-index:2}.intro-info-text{position:relative;z-index:2;background:#1e293b99!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.2);color:#e2e8f0f2!important}.intro-info-text p{color:#e2e8f0e6!important}.intro-info-label{color:#93c5fde6!important}.intro-enter-btn{position:relative;z-index:2;background:linear-gradient(135deg,#3b82f6,#6366f1,#8b5cf6)!important;border:1px solid rgba(99,102,241,.5);box-shadow:0 4px 16px #6366f166,0 0 0 1px #ffffff1a inset;color:#fff;font-weight:600;transition:all .3s ease;text-shadow:0 0 10px rgba(255,255,255,.3)}.intro-enter-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#4f46e5,#7c3aed)!important;box-shadow:0 6px 20px #6366f199,0 0 0 1px #fff3 inset;transform:translateY(-2px)}.intro-enter-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #6366f166,0 0 0 1px #ffffff1a inset}.intro-enter-btn:disabled{opacity:.5;cursor:not-allowed;background:#47556999!important}.intro-info-icon{background:linear-gradient(135deg,#3b82f6cc,#6366f1cc)!important;box-shadow:0 4px 12px #6366f166,0 0 0 1px #ffffff1a inset}@media (max-width: 768px){#intro-overlay{background:transparent!important}.app-window.intro-mode #blackhole-bg-container{display:block!important;position:fixed;top:0;left:0;width:100%;height:100%;z-index:0}.intro-preview-panel,.test-preview-panel,.intro-info-panel{backdrop-filter:blur(15px) saturate(150%);-webkit-backdrop-filter:blur(15px) saturate(150%)}}#waiting-report-view{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;background:transparent!important;z-index:10000!important;overflow:hidden;margin:0!important;padding:0!important}#nebula-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1}#matrix-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2;pointer-events:none;opacity:.3}#wordcloud-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:3;pointer-events:none}#text-particle-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:4;pointer-events:none}#particle-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:5;pointer-events:none}.waiting-report-main-container{position:relative;z-index:6;min-height:100vh;padding:60px 20px 80px;display:flex;flex-direction:column;align-items:center}.waiting-report-header{text-align:center;margin-bottom:50px;animation:fadeInDown 1s ease-out}.waiting-report-header h1{font-size:42px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:15px;text-shadow:0 0 30px rgba(102,126,234,.5)}.waiting-report-status-text{font-size:18px;color:#a0aec0;letter-spacing:2px}.waiting-report-progress-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9;animation:fadeIn 1.5s ease-out;display:flex;flex-direction:column;align-items:center;justify-content:center}.waiting-report-blackhole{position:relative;width:200px;height:200px}.waiting-report-blackhole-core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120px;height:120px;background:radial-gradient(circle,#1a1a2e,#0f0f1a,#0a0a14);border-radius:50%;box-shadow:0 0 30px 10px #000c,0 0 60px 20px #0a0e2799,inset 0 0 30px #000;z-index:3;overflow:hidden}.waiting-report-upload-fill{position:absolute;bottom:0;left:0;width:100%;height:0%;background:linear-gradient(180deg,#ffb464e6,#ff8c32f2,#e6781e);border-radius:0 0 50% 50%;transition:height .5s ease-out;z-index:1}.waiting-report-upload-fill:before{content:"";position:absolute;top:-8px;left:-10%;width:120%;height:16px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,60 C150,120 350,0 600,60 C850,120 1050,0 1200,60 L1200,120 L0,120 Z' fill='rgba(255,180,100,0.9)'/%3E%3C/svg%3E");background-size:100% 100%;animation:waveMove 2s linear infinite}@keyframes waveMove{0%{transform:translate(0)}to{transform:translate(-50%)}}.waiting-report-upload-percent{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:24px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.8);z-index:2;font-family:-apple-system,BlinkMacSystemFont,Microsoft YaHei,sans-serif}.waiting-report-core-data-stream{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:Courier New,monospace;font-size:8px;color:#667eea99;animation:dataFlicker .1s linear infinite;overflow:hidden}.waiting-report-energy-wave{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid rgba(102,126,234,.5);animation:waveExpand 2s ease-out infinite;pointer-events:none}.waiting-report-energy-wave:nth-child(8){animation-delay:0s}.waiting-report-energy-wave:nth-child(9){animation-delay:.5s}.waiting-report-energy-wave:nth-child(10){animation-delay:1s}.waiting-report-energy-wave:nth-child(11){animation-delay:1.5s}.waiting-report-data-counter{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:Courier New,monospace;font-size:12px;color:#f093fbcc;text-shadow:0 0 10px rgba(240,147,251,.8);z-index:4;white-space:nowrap;animation:counterPulse .5s ease-in-out infinite}.waiting-report-blackhole-words{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:160px;height:160px;pointer-events:none;z-index:5;overflow:visible}.waiting-report-flying-word{position:absolute;font-family:-apple-system,BlinkMacSystemFont,Microsoft YaHei,sans-serif;font-weight:600;white-space:nowrap;opacity:0;transform-origin:center center;animation:wordFlyIn .6s ease-out forwards;text-shadow:0 0 8px currentColor;pointer-events:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@keyframes wordFlyIn{0%{opacity:0;transform:translate(var(--start-x),var(--start-y)) scale(1.5) rotate(var(--rotate))}50%{opacity:1}to{opacity:0;transform:translate(0) scale(.3) rotate(0)}}.waiting-report-center-word{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;font-weight:700;color:#fff;text-shadow:0 0 10px #667eea,0 0 20px #764ba2,0 0 30px #f093fb;opacity:0;animation:centerWordShow .5s ease-out forwards;z-index:6;white-space:nowrap;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@keyframes centerWordShow{0%{opacity:0;transform:translate(-50%,-50%) scale(2);filter:blur(10px)}50%{opacity:1;filter:blur(0)}to{opacity:0;transform:translate(-50%,-50%) scale(.5);filter:blur(5px)}}.waiting-report-processing-indicator{position:absolute;top:50%;left:50%;width:100px;height:100px;transform:translate(-50%,-50%);border-radius:50%;border:2px dashed rgba(102,126,234,.3);animation:indicatorSpin 3s linear infinite;z-index:1}.waiting-report-spark-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;pointer-events:none;z-index:2}.waiting-report-spark{position:absolute;width:4px;height:4px;background:#f093fb;border-radius:50%;box-shadow:0 0 6px #f093fb,0 0 12px #667eea;animation:sparkFly 1s ease-out infinite}@keyframes waveExpand{0%{width:60px;height:60px;opacity:.8}to{width:250px;height:250px;opacity:0}}@keyframes dataFlicker{0%,to{opacity:.4}50%{opacity:.8}}@keyframes counterPulse{0%,to{transform:translate(-50%,-50%) scale(1);text-shadow:0 0 10px rgba(240,147,251,.8)}50%{transform:translate(-50%,-50%) scale(1.1);text-shadow:0 0 20px rgba(240,147,251,1),0 0 30px rgba(102,126,234,.8)}}@keyframes indicatorSpin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes sparkFly{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(0);opacity:0}}@keyframes coreBreath{0%,to{box-shadow:0 0 30px 10px #000c,0 0 60px 20px #0a0e2799,inset 0 0 30px #000;transform:translate(-50%,-50%) scale(1)}50%{box-shadow:0 0 50px 20px #000000e6,0 0 100px 40px #0a0e27cc,0 0 150px 60px #667eea33,inset 0 0 50px #000;transform:translate(-50%,-50%) scale(1.05)}}.waiting-report-blackhole-horizon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,transparent 40%,rgba(102,126,234,.1) 60%,rgba(118,75,162,.2) 80%,transparent 100%);box-shadow:0 0 20px #667eea4d,0 0 40px #764ba233;animation:horizonPulse 3s ease-in-out infinite;z-index:2}.waiting-report-accretion-disk{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:180px;height:180px;border-radius:50%;border:2px solid transparent;background:linear-gradient(#0a0e27,#0a0e27) padding-box,conic-gradient(from 0deg,#667eea,#764ba2,#f093fb,#667eea) border-box;animation:diskRotate 8s linear infinite;z-index:1}.waiting-report-accretion-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,transparent 35%,rgba(102,126,234,.1) 50%,rgba(240,147,251,.1) 70%,transparent 90%);box-shadow:0 0 40px #667eea4d,0 0 80px #764ba233,0 0 120px #f093fb1a;animation:glowPulse 2s ease-in-out infinite;z-index:0}.waiting-report-orbit-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid;animation:ringRotate 6s linear infinite}.waiting-report-orbit-ring:nth-child(5){width:120px;height:120px;border-color:#667eea4d;animation-duration:4s}.waiting-report-orbit-ring:nth-child(6){width:150px;height:150px;border-color:#764ba233;animation-duration:6s;animation-direction:reverse}.waiting-report-orbit-ring:nth-child(7){width:180px;height:180px;border-color:#f093fb26;animation-duration:8s}.waiting-report-progress-text{margin-top:30px;font-size:16px;color:#e0e0e0;letter-spacing:2px;text-shadow:0 0 10px rgba(102,126,234,.5);text-align:center;transition:opacity .3s ease}@keyframes diskRotate{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes ringRotate{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes horizonPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.8}50%{transform:translate(-50%,-50%) scale(1.1);opacity:1}}@keyframes glowPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.05);opacity:1}}.waiting-report-scan-line{position:fixed;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent,rgba(102,126,234,.8),transparent);box-shadow:0 0 10px #667eeacc;animation:scanMove 3s linear infinite;z-index:7}@keyframes scanMove{0%{top:0}to{top:100%}}.waiting-report-data-stream{position:fixed;width:1px;height:100px;background:linear-gradient(180deg,transparent,rgba(240,147,251,.8),transparent);animation:dataFlow 2s linear infinite;z-index:7}@keyframes dataFlow{0%{top:-100px;opacity:0}50%{opacity:1}to{top:100vh;opacity:0}}.waiting-report-footer-hint{position:fixed;bottom:30px;left:50%;transform:translate(-50%);z-index:10;text-align:center;animation:fadeIn 2s ease-out}.waiting-report-footer-hint p{color:#a0aec0;font-size:14px;margin-bottom:10px}.waiting-report-dots{display:flex;gap:8px;justify-content:center}.waiting-report-dot{width:8px;height:8px;background:#667eea;border-radius:50%;animation:dotPulse 1.5s ease-in-out infinite}.waiting-report-dot:nth-child(2){animation-delay:.3s}.waiting-report-dot:nth-child(3){animation-delay:.6s}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes dotPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}}@media (max-width: 768px){.waiting-report-header h1{font-size:32px}}.upload-progress-container{width:100%;max-width:1100px;margin:0 0 20px;display:flex;flex-direction:column;gap:12px;padding:20px;background:#0a0e2799;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(102,126,234,.3);box-shadow:0 4px 20px #0000004d}.upload-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px}.upload-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#ffffff0d;border-radius:8px;transition:all .3s ease}.upload-item .upload-label{font-size:14px;color:#e0e0e0;font-weight:500}.upload-item .upload-status{font-size:18px;transition:all .3s ease}.upload-item-progress{flex-direction:column;align-items:stretch;padding:12px}.upload-item-progress .upload-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.upload-item-progress .upload-percent{font-size:12px;color:#a0aec0;font-family:Courier New,monospace}.upload-bar{width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.upload-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,#667eea,#764ba2,#f093fb);border-radius:3px;transition:width .3s ease;box-shadow:0 0 10px #667eea80}.upload-item.success .upload-status{animation:successPop .5s ease-out}.upload-item.failed .upload-status{animation:shake .5s ease-out}@keyframes successPop{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.waiting-report-retry-btn{margin-top:20px;padding:12px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:25px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66}.waiting-report-retry-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.waiting-report-retry-btn:active{transform:translateY(0)}.waiting-report-retest-btn{margin-top:12px;padding:10px 28px;background:transparent;color:#ffffffb3;border:1px solid rgba(255,255,255,.3);border-radius:25px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.waiting-report-retest-btn:hover{background:#ffffff1a;color:#fff;border-color:#ffffff80}.waiting-report-retest-btn:active{transform:translateY(0)}.waiting-report-upload-fill.failed{background:linear-gradient(180deg,#ef4444e6,#dc2626f2,#b91c1c)}.waiting-report-upload-fill.failed:before{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,60 C150,120 350,0 600,60 C850,120 1050,0 1200,60 L1200,120 L0,120 Z' fill='rgba(239,68,68,0.9)'/%3E%3C/svg%3E");background-size:100% 100%}.waiting-report-upload-fill.success{background:linear-gradient(180deg,#22c55ee6,#16a34af2,#15803d)}.waiting-report-upload-fill.success:before{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,60 C150,120 350,0 600,60 C850,120 1050,0 1200,60 L1200,120 L0,120 Z' fill='rgba(34,197,94,0.9)'/%3E%3C/svg%3E");background-size:100% 100%}#question-progress-pillar-container{position:fixed;right:30px;top:50%;transform:translateY(-50%);z-index:100;pointer-events:none;display:none}#question-progress-pillar-container.visible{display:block}#question-progress-pillar{width:32px;height:280px;position:relative;border-radius:16px;overflow:visible}#question-progress-pillar-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:#141e3299;border:1px solid rgba(100,150,200,.3);border-radius:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow:hidden}#question-progress-fill{position:absolute;bottom:0;left:2px;right:2px;height:0%;background:linear-gradient(to top,#40e0ff,#64c8fffa,#8cb4fff2,#b4a0ffe6,#dc8cffbf);border-radius:0 0 14px 14px;transition:height .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 35px #40e0ffcc,0 0 70px #64c8ff80,0 0 100px #b4a0ff4d,inset 0 0 30px #fff6,inset 0 -10px 25px #40e0ffb3;border-top:1px solid rgba(220,140,255,.8)}#question-progress-fill.empty{border-top:1px solid transparent}#question-progress-fill:before{content:"";position:absolute;top:0;left:0;right:0;height:20%;background:linear-gradient(to bottom,rgba(255,255,255,.3) 0%,transparent 100%);border-radius:0 0 14px 14px;pointer-events:none}#question-progress-ripple{position:absolute;bottom:0;left:0;right:0;height:100%;background:repeating-linear-gradient(0deg,transparent 0px,transparent 8px,rgba(255,255,255,.1) 8px,rgba(255,255,255,.1) 10px);animation:energyRipple 2s linear infinite;opacity:0;transition:opacity .3s}#question-progress-ripple.active{opacity:1}#question-progress-particles{position:absolute;top:0;right:0;width:200px;height:280px;pointer-events:none;overflow:visible}.question-progress-particle{position:absolute;width:6px;height:6px;border-radius:50%;pointer-events:none;animation:particleFloat 1.5s ease-in forwards}.question-progress-particle.cyan{background:radial-gradient(circle,#00ffff 0%,#00aaff 50%,transparent 100%);box-shadow:0 0 8px #0ff,0 0 15px #00ffff80}.question-progress-particle.magenta{background:radial-gradient(circle,#ff00ff 0%,#aa00ff 50%,transparent 100%);box-shadow:0 0 8px #f0f,0 0 15px #ff00ff80}.question-progress-particle.blue{background:radial-gradient(circle,#4080ff 0%,#0040ff 50%,transparent 100%);box-shadow:0 0 8px #4080ff,0 0 15px #4080ff80}.question-progress-particle.white{background:radial-gradient(circle,#ffffff 0%,#aaccff 50%,transparent 100%);box-shadow:0 0 8px #fff,0 0 15px #ffffff80}#question-progress-pillar:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40px;height:40px;background:radial-gradient(circle,rgba(0,220,255,.4) 0%,transparent 70%);border-radius:50%;opacity:0;animation:none}#question-progress-pillar.pulse:after{animation:energyPulse .6s ease-out}@keyframes energyRipple{0%{transform:translateY(0)}to{transform:translateY(-20px)}}@keyframes particleFloat{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(var(--end-x),var(--end-y)) scale(.3)}}@keyframes energyPulse{0%{opacity:.8;transform:translate(-50%) scale(.5)}to{opacity:0;transform:translate(-50%) scale(2)}}
