:root{--primary: #2563EB;--primary-hover: #1D4ED8;--primary-light: rgba(37, 99, 235, .1);--accent: #06B6D4;--accent-light: rgba(6, 182, 212, .12);--warm: #F59E0B;--warm-light: rgba(245, 158, 11, .12);--purple: #7C3AED;--purple-light: rgba(124, 58, 237, .1);--green: #10B981;--green-light: rgba(16, 185, 129, .1);--rose: #F43F5E;--rose-light: rgba(244, 63, 94, .1);--success: #10B981;--warning: #F59E0B;--error: #EF4444;--info: #3B82F6;--text: #0F172A;--text-secondary: #334155;--text-tertiary: #64748B;--text-inverse: #FFFFFF;--bg: #F0F9FF;--bg-alt: #ECFDF5;--card: #FFFFFF;--border: #BAE6FD;--border-focus: var(--primary);--sidebar: #1E3A8A;--sidebar-hover: rgba(6, 182, 212, .15);--sidebar-active: rgba(6, 182, 212, .28);--sidebar-text: #FFFFFF;--sidebar-active-text: #67E8F9;--shadow-xs: 0 1px 3px rgba(15, 23, 42, .06);--shadow-sm: 0 2px 8px rgba(15, 23, 42, .09);--shadow-md: 0 4px 16px rgba(15, 23, 42, .12);--shadow-lg: 0 8px 32px rgba(15, 23, 42, .16);--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,Arial,sans-serif;background:linear-gradient(160deg,#f0f9ff,#ecfdf5,#fffbeb) fixed;color:var(--text);min-height:100vh;line-height:1.6;font-size:14px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#b8c4d2;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#8590a2}.app-sider{background:linear-gradient(180deg,#1e3a8a,#1e40af,#1d4ed8)!important;border-right:none!important;height:100vh;position:sticky;top:0;overflow-y:auto;overflow-x:hidden;box-shadow:2px 0 8px #172b4d0f;z-index:101}.logo{padding:0 18px;height:64px;display:flex;align-items:center;gap:10px;background:#ffffff14;border-bottom:1px solid rgba(255,255,255,.12);overflow:hidden}.logo-icon{font-size:24px;flex-shrink:0}.logo-text{color:#fff;font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.2px}.app-sider .ant-menu{background:transparent!important;border-inline-end:none!important;padding:8px}.app-sider .ant-menu-item{border-radius:var(--r-sm)!important;margin:1px 0!important;height:40px!important;line-height:40px!important;color:#fffc!important}.app-sider .ant-menu-item .anticon{color:#ffffffa6!important}.app-sider .ant-menu-item-group-title{color:#fff6!important;font-size:10px!important;font-weight:700!important;letter-spacing:.8px!important;text-transform:uppercase;padding:14px 16px 4px!important}.app-sider .ant-menu-item-divider{background-color:#ffffff1f!important;margin:6px 12px!important}.app-sider .ant-menu-item:hover{background:#ffffff1f!important;color:#fff!important}.app-sider .ant-menu-item:hover .anticon{color:#67e8f9!important}.app-sider .ant-menu-item-selected{background:#06b6d440!important;color:#fff!important;box-shadow:0 0 0 1px #67e8f94d inset}.app-sider .ant-menu-item-selected .anticon{color:#67e8f9!important}.app-sider .ant-menu-item-selected .ant-menu-title-content{color:#fff!important;font-weight:600!important}.app-sider .ant-menu-light,.app-sider .ant-menu-light.ant-menu-root{background:transparent!important}.app-sider .ant-menu-item-group-title span{color:#fff6!important}.sider-toggle{display:flex;justify-content:flex-end;padding:4px 12px 8px}.sider-toggle .ant-btn{color:#fff9!important}.sider-toggle .ant-btn:hover{color:#fff!important;background:#ffffff1a!important}.app-header{background:linear-gradient(90deg,#fff,#f0feff 60%,#f0fff4)!important;border-bottom:2px solid #BAE6FD;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:100;box-shadow:0 1px 4px #172b4d0f}.header-title{font-size:16px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.header-icon{color:var(--primary)}.user-profile{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 10px;border-radius:var(--r-sm);transition:background .2s}.user-profile:hover{background:var(--primary-light)}.username{font-weight:500;color:var(--text);font-size:13px}.logout-button{color:var(--text-secondary)!important;font-size:13px!important;padding:0!important}.logout-button:hover{color:var(--error)!important}.app-content{padding:20px 24px;background:transparent;min-height:calc(100vh - 56px);overflow-y:auto}.page-loading{min-height:240px;display:flex;align-items:center;justify-content:center}.panel-card,.sci-fi-card{border-radius:var(--r-md);box-shadow:0 2px 12px #2563eb14;border:1px solid #BAE6FD;background:var(--card);transition:box-shadow .2s,transform .2s,border-color .2s;overflow:hidden}.sci-fi-card:hover{box-shadow:0 6px 24px #2563eb26;transform:translateY(-2px);border-color:#7dd3fc}.sci-fi-card .ant-card-body{padding:18px 20px}.section-title{font-size:15px;font-weight:600;margin-bottom:14px;color:var(--text);display:flex;align-items:center;gap:8px}.section-title:before{content:"";display:block;width:4px;height:16px;background:linear-gradient(to bottom,var(--primary),var(--accent));border-radius:2px;flex-shrink:0}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.icon-wrapper-large,.icon-wrapper{width:52px;height:52px;border-radius:var(--r-md);background:var(--primary-light);display:flex;align-items:center;justify-content:center;border:1px solid rgba(0,82,204,.15);transition:all .2s;flex-shrink:0}.sci-fi-card:hover .icon-wrapper-large,.sci-fi-card:hover .icon-wrapper{background:var(--primary)}.sci-fi-card:hover .icon-wrapper-large .anticon,.sci-fi-card:hover .icon-wrapper .anticon,.sci-fi-card:hover .module-icon{color:#fff!important}.module-icon{font-size:24px;color:var(--primary)}.module-desc{font-size:12px;color:var(--text-secondary)!important;margin-top:4px;display:block}.module-preview-card{height:100%}.ant-btn-primary{background:var(--primary)!important;border-color:var(--primary)!important;font-weight:500;box-shadow:0 2px 6px #0052cc40!important;transition:all .2s!important}.ant-btn-primary:hover{background:var(--primary-hover)!important;border-color:var(--primary-hover)!important;box-shadow:0 3px 10px #0052cc59!important;transform:translateY(-1px)}.btn-warm{background:var(--warm)!important;border-color:var(--warm)!important;color:#fff!important;font-weight:600!important;box-shadow:0 2px 8px #f59e0b4d!important}.btn-warm:hover{background:#d97706!important;border-color:#d97706!important;box-shadow:0 4px 14px #f59e0b66!important;transform:translateY(-1px)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#1e3a8a,#2563eb 30%,#7c3aed,#db2777);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 15% 25%,rgba(255,255,255,.18) 0%,transparent 55%),radial-gradient(ellipse 45% 45% at 85% 75%,rgba(245,158,11,.18) 0%,transparent 55%),radial-gradient(ellipse 35% 35% at 50% 10%,rgba(167,243,208,.22) 0%,transparent 50%);pointer-events:none}.login-card{width:min(480px,92vw);box-shadow:0 8px 48px #11286a47,0 2px 12px #0000001f;border-radius:var(--r-xl);border:1px solid rgba(255,255,255,.22);background:#fffffffa;backdrop-filter:blur(20px);padding:40px}.login-title{margin-bottom:4px!important;font-size:24px!important;font-weight:700!important;color:var(--text)!important}.login-subtitle{font-size:13px!important;color:var(--text-secondary)!important}.login-header{text-align:center;margin-bottom:28px}.login-error-alert{margin-bottom:16px;border-radius:var(--r-sm)!important}.login-form .login-input,.login-form .login-input input{height:44px;border-radius:var(--r-sm)!important}.login-form .verify-code-input{border-right:none;border-top-right-radius:0!important;border-bottom-right-radius:0!important}.login-form .get-verify-code-btn{height:44px;border-top-left-radius:0!important;border-bottom-left-radius:0!important}.login-form .login-button{height:44px;border-radius:var(--r-sm)!important;font-size:15px;font-weight:600;background:linear-gradient(135deg,var(--primary),#0747A6)!important;border:none!important;box-shadow:0 4px 14px #0052cc59!important}.login-remember-container{display:flex;justify-content:space-between;align-items:center;width:100%;gap:12px}.login-remember-actions{display:flex;align-items:center;gap:8px;white-space:nowrap}.toggle-verify-mode-link,.forgot-pwd-link{font-size:13px;color:var(--primary)}.toggle-verify-mode-link:hover,.forgot-pwd-link:hover{color:var(--primary-hover)}.login-divider{margin:20px 0}.login-security-tip{text-align:center}.login-security-tip p{font-size:12px;color:var(--text-tertiary);margin-bottom:4px}.guest-landing{min-height:100vh;background:linear-gradient(160deg,#f0f9ff,#eff6ff 45%,#f0fff4);color:#0f172a;position:relative;overflow-x:hidden}.guest-bg-grid{position:fixed;inset:0;background-image:linear-gradient(rgba(37,99,235,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.05) 1px,transparent 1px);background-size:56px 56px;pointer-events:none;z-index:0}.guest-bg-gradient{position:fixed;inset:0;background:radial-gradient(ellipse 70% 55% at 8% 5%,rgba(37,99,235,.1) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 92% 25%,rgba(6,182,212,.1) 0%,transparent 60%),radial-gradient(ellipse 40% 35% at 50% 95%,rgba(245,158,11,.08) 0%,transparent 60%);pointer-events:none;z-index:0}.guest-nav{position:sticky;top:0;z-index:200;background:#ffffffe6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(37,99,235,.12);box-shadow:0 2px 12px #2563eb0f}.guest-nav-inner{max-width:1240px;margin:0 auto;padding:0 32px;height:60px;display:flex;align-items:center;justify-content:space-between}.guest-nav-logo{display:flex;align-items:center;gap:10px}.guest-logo-icon{font-size:22px}.guest-logo-text{font-size:15px;font-weight:700;background:linear-gradient(90deg,#2563eb,#0891b2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.guest-hero{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:90px 32px 72px;text-align:center;animation:fadeUp .8s ease-out both}.guest-hero-badge{display:inline-flex;align-items:center;gap:8px;background:#2563eb14;border:1px solid rgba(37,99,235,.25);border-radius:100px;padding:5px 16px;font-size:12px;color:#2563eb;font-weight:500;margin-bottom:28px;letter-spacing:.5px}.guest-badge-dot{width:6px;height:6px;border-radius:50%;background:#2563eb;animation:pulse 2s infinite}.guest-hero-title{font-size:clamp(32px,5vw,56px)!important;font-weight:800!important;color:#0f172a!important;line-height:1.2!important;margin-bottom:20px!important}.guest-hero-accent{background:linear-gradient(90deg,#2563eb,#0891b2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.guest-hero-sub{font-size:17px;color:#475569!important;max-width:580px;margin:0 auto 36px!important;line-height:1.75}.guest-hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.guest-cta-btn{height:48px!important;padding:0 32px!important;font-size:15px!important;font-weight:600!important;border-radius:var(--r-md)!important;background:linear-gradient(135deg,#2563eb,#1d4ed8)!important;border:none!important;color:#fff!important;box-shadow:0 4px 18px #2563eb59!important;transition:all .3s!important}.guest-cta-btn:hover{transform:translateY(-2px)!important;box-shadow:0 6px 24px #2563eb80!important}.guest-section{position:relative;z-index:1;padding:72px 32px}.guest-section-dark{background:#2563eb08;border-top:1px solid rgba(37,99,235,.08);border-bottom:1px solid rgba(37,99,235,.08)}.guest-section-inner{max-width:1240px;margin:0 auto}.guest-section-header{text-align:center;margin-bottom:52px}.guest-section-title{color:#0f172a!important;font-size:28px!important;font-weight:700!important;margin-bottom:10px!important}.guest-section-desc{color:#64748b!important;font-size:15px}.guest-feature-card{background:#ffffffd9;border:1px solid rgba(37,99,235,.12);border-radius:var(--r-lg);padding:28px 20px;text-align:center;transition:all .3s;box-shadow:0 2px 10px #2563eb0f}.guest-feature-card:hover{background:#fff;border-color:#2563eb4d;transform:translateY(-4px);box-shadow:0 10px 28px #2563eb24}.guest-feature-icon{width:52px;height:52px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 14px}.guest-feature-title{font-size:15px;font-weight:700;color:#0f172a;margin-bottom:6px}.guest-feature-desc{font-size:12px;color:#64748b;line-height:1.5}.guest-characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(136px,1fr));gap:18px}.guest-char-card{background:#fff;border:1px solid rgba(37,99,235,.12);border-radius:var(--r-lg);overflow:hidden;transition:all .3s;cursor:pointer;box-shadow:0 2px 8px #2563eb0f}.guest-char-card:hover{border-color:#2563eb59;transform:translateY(-6px) scale(1.02);box-shadow:0 14px 36px #2563eb2e}.guest-char-img-wrap{position:relative;width:100%;padding-bottom:133%;overflow:hidden}.guest-char-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s}.guest-char-card:hover .guest-char-img{transform:scale(1.06)}.guest-char-placeholder{position:absolute;inset:0;display:none;align-items:center;justify-content:center;font-size:48px}.guest-char-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,23,42,.8) 0%,transparent 50%);display:flex;align-items:flex-end;padding:10px;opacity:0;transition:opacity .3s}.guest-char-card:hover .guest-char-overlay{opacity:1}.guest-char-desc{font-size:11px;color:#ffffffeb;line-height:1.35}.guest-char-info{padding:10px 12px}.guest-char-name{font-size:13px;font-weight:700;color:#0f172a;margin-bottom:5px}.guest-char-tag{font-size:10px!important}.guest-scenario-strip{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin}.guest-scenario-card{background:#fff;border:1px solid rgba(37,99,235,.14);border-radius:var(--r-lg);overflow:hidden;min-width:200px;max-width:220px;flex-shrink:0;transition:all .25s;box-shadow:0 2px 8px #2563eb0f}.guest-scenario-img{width:100%;height:280px;object-fit:cover;display:block}.guest-scenario-card:hover{border-color:#2563eb59;transform:translateY(-2px);box-shadow:0 8px 24px #2563eb24}.guest-scenario-no{font-size:11px;font-weight:700;color:var(--primary);letter-spacing:1px;margin-bottom:8px}.guest-scenario-text{font-size:12px;color:#64748b;line-height:1.6;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.guest-scenario-fallback{width:100%;height:280px;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;text-align:center;background:linear-gradient(135deg,#2563eb1a,#06b6d41a);gap:10px}.guest-scenario-fallback-num{font-size:36px;font-weight:800;color:#2563eb80;line-height:1}.guest-scenario-fallback-title{font-size:14px;font-weight:700;color:#1e40af}.guest-scenario-fallback-desc{font-size:12px;color:#3b82f6;line-height:1.5}.guest-cta-section{position:relative;z-index:1;padding:90px 32px;text-align:center;background:linear-gradient(135deg,#2563eb0d,#06b6d40d)}.guest-cta-inner{max-width:560px;margin:0 auto}.guest-cta-title{color:#0f172a!important;font-size:32px!important;font-weight:700!important;margin-bottom:14px!important}.guest-cta-sub{color:#475569!important;font-size:15px;margin-bottom:36px!important}.guest-footer{position:relative;z-index:1;text-align:center;padding:20px;border-top:1px solid rgba(37,99,235,.08)}.stage-role-selection-wrap{border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border)}.char-roster-bar{display:flex;align-items:center;padding:10px 16px;background:var(--bg);border-bottom:1px solid var(--border);overflow-x:auto;gap:8px;scrollbar-width:thin}.char-roster-cards{display:flex;gap:10px;flex-wrap:nowrap}.char-roster-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;flex-shrink:0;transition:transform .2s}.char-roster-item:hover{transform:scale(1.1)}.char-roster-img-wrap{width:36px;height:46px;border-radius:6px;overflow:hidden;border:2px solid;display:flex;align-items:center;justify-content:center}.char-roster-img{width:100%;height:100%;object-fit:cover}.char-roster-name{font-size:10px;font-weight:600;white-space:nowrap}.stage-role-selection-table .role-table-group-header td{background:#eff6ff!important;font-weight:600}.stage-role-selection-table .ant-table-thead>tr>th{background:var(--bg)!important;font-weight:600;font-size:13px;color:var(--text-secondary)}.obs-form-wrap{max-width:1100px;margin:0 auto}.obs-form-stage-tabs .ant-tabs-tab{border-radius:var(--r-sm) var(--r-sm) 0 0!important}.obs-form-stage-tabs .ant-tabs-tab-active{background:var(--card)!important}.obs-score-card{border:1px solid var(--border);border-radius:var(--r-md);padding:16px;background:var(--card);margin-bottom:12px}.obs-score-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px}.obs-score-value{font-size:20px;font-weight:700;color:var(--primary)}.obs-total-score{font-size:28px;font-weight:800;color:var(--warm)}.obs-grade-badge{display:inline-block;width:48px;height:48px;border-radius:50%;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center}.stat-card{border-radius:var(--r-lg)!important;border:none!important;box-shadow:var(--shadow-sm)!important;overflow:hidden;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)!important}.ant-input,.ant-input-password,.ant-select-selector,.ant-input-affix-wrapper{background:#fff!important;border-color:var(--border)!important;color:var(--text)!important;border-radius:var(--r-sm)!important;transition:all .2s!important}.ant-input:focus,.ant-input-affix-wrapper-focused,.ant-select-focused .ant-select-selector{border-color:var(--primary)!important;box-shadow:0 0 0 2px #2563eb1f!important}.ant-card{border-radius:var(--r-md)!important}.ant-card-head{border-bottom:1px solid var(--border)!important;background:linear-gradient(90deg,#f0f9ff,#ecfdf5)!important}.ant-table{border-radius:var(--r-md)!important;overflow:hidden}.ant-table-thead>tr>th{background:linear-gradient(90deg,#f0f9ff,#f0fff4)!important;font-weight:600;color:var(--text-secondary)!important}.ant-tag{border-radius:4px!important;font-size:11px!important}.ant-badge-status-dot{width:8px!important;height:8px!important}.ant-tabs-ink-bar{background:var(--primary)!important;height:3px!important;border-radius:2px!important}.ant-tabs-tab-active .ant-tabs-tab-btn{color:var(--primary)!important;font-weight:600!important}.tablet-camera-btn-wrap{display:flex;align-items:center;justify-content:center}.tablet-camera-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:80px;height:80px;border-radius:50%;border:3px solid #10B981;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:28px;cursor:pointer;box-shadow:0 4px 16px #10b98166;transition:all .2s;position:relative;-webkit-tap-highlight-color:transparent;user-select:none}.tablet-camera-btn:active{transform:scale(.92);box-shadow:0 2px 8px #10b9814d}.tablet-camera-btn.uploading{background:linear-gradient(135deg,#6ee7b7,#34d399);pointer-events:none}.tablet-camera-btn-label{font-size:12px;font-weight:600;line-height:1}.tablet-camera-btn-count{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #FFFFFF}.tablet-action-bar{display:none}@media(max-width:1024px){.tablet-action-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:500;background:#fffffff7;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid #BAE6FD;padding:10px 16px calc(10px + env(safe-area-inset-bottom));gap:12px;align-items:center;justify-content:space-around;box-shadow:0 -4px 20px #2563eb1f}.app-content.has-tablet-bar{padding-bottom:90px!important}.tablet-bar-action{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;cursor:pointer;border-radius:var(--r-md);padding:8px 4px;transition:background .15s;-webkit-tap-highlight-color:transparent;user-select:none;border:none;background:transparent;color:var(--text-secondary);min-width:0;position:relative}.tablet-bar-action:active{background:var(--primary-light)}.tablet-bar-action-icon{font-size:24px;line-height:1}.tablet-bar-action-label{font-size:11px;font-weight:600;white-space:nowrap}.tablet-bar-action.primary{color:#10b981}.tablet-bar-action.primary .tablet-bar-action-icon{font-size:28px}.tablet-bar-action.save-action{color:var(--primary)}.tablet-bar-action.next-action{color:var(--warm)}.tablet-bar-action.audio-action{color:var(--purple)}.tablet-bar-action-badge{position:relative}.tablet-bar-action-badge-dot{position:absolute;top:-4px;right:-6px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid #FFF}.tablet-bar-dot{position:absolute;top:-3px;right:-3px;width:10px;height:10px;background:#ef4444;border-radius:50%;border:2px solid #FFF}}.tablet-student-photo-strip{display:flex;gap:8px;overflow-x:auto;padding:8px 0;scrollbar-width:thin}.tablet-student-photo-thumb{width:72px;height:72px;border-radius:var(--r-sm);object-fit:cover;border:2px solid #BAE6FD;flex-shrink:0;transition:border-color .2s}.tablet-student-photo-thumb:hover{border-color:var(--primary)}@keyframes fadeUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media(max-width:768px){.app-content{padding:12px}.card-grid{grid-template-columns:1fr}.guest-hero{padding:56px 20px 44px}.guest-section{padding:48px 20px}.guest-nav-inner{padding:0 16px}.guest-hero-title{font-size:26px!important}.guest-hero-sub{font-size:14px}.guest-characters-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px}}@media(max-width:480px){.guest-characters-grid{grid-template-columns:repeat(4,1fr);gap:8px}}@media(max-width:1024px){.app-content{padding:16px!important}.panel-card>.ant-card-body{padding:16px!important}.app-header{padding:0 16px!important}.app-header .header-title{font-size:15px}.logo{padding:14px 12px!important}.ant-table-wrapper{overflow-x:auto}.stage-indicator-grid{grid-template-columns:repeat(2,1fr)!important}}@media(max-width:767px){.app-content{padding:10px!important}.app-header{padding:0 12px!important;height:52px!important;line-height:52px!important}.app-header .header-title{font-size:14px;max-width:120px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.app-header .username,.app-header .logout-button{display:none}.app-sider{position:fixed!important;z-index:999;height:100vh!important;box-shadow:2px 0 12px #00000026}.panel-card{box-shadow:0 1px 4px #172b4d0f!important}.panel-card>.ant-card-body{padding:12px!important}.ant-table-wrapper{overflow-x:auto!important;-webkit-overflow-scrolling:touch}.ant-table{min-width:500px}.ant-table-thead .col-hide-mobile,.ant-table-tbody .col-hide-mobile{display:none!important}.ant-modal{max-width:calc(100vw - 24px)!important;margin:12px auto!important}.ant-modal-content{border-radius:var(--r-md)!important}h1.ant-typography,.ant-typography h1{font-size:22px!important}h2.ant-typography,.ant-typography h2{font-size:18px!important}h3.ant-typography,.ant-typography h3{font-size:16px!important}.step-cards-row .ant-col{width:100%!important;max-width:100%!important}.stage-indicator-grid{grid-template-columns:1fr!important}.scoring-radar-col{display:none!important}.ant-form-item{margin-bottom:12px!important}.ant-picker,.ant-select,.ant-input-number{width:100%!important}.ant-space:not(.ant-space-vertical){flex-wrap:wrap!important}.ant-segmented{width:100%}.ant-tabs-nav{overflow-x:auto!important}.ant-tabs-nav:before{border-bottom:1px solid var(--border)!important}.ant-steps-horizontal{flex-direction:column!important}.ant-steps-item{padding-left:0!important}}@media(max-width:480px){.guest-characters-grid{grid-template-columns:repeat(4,1fr);gap:8px}.observer-hero-title{font-size:18px!important}.stage-tabs-bar{gap:6px!important}.stage-tabs-bar>div{padding:6px 10px!important;font-size:12px!important}.perm-col-group{display:none!important}.report-stats-grid{grid-template-columns:1fr 1fr!important}}
