*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#1a1a2e;color:#e0e0e0;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.login-screen{display:flex;align-items:center;justify-content:center;height:100%;padding:24px}.login-card{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:20px}.login-title{font-size:28px;font-weight:700;color:#a855f7}.judge-id-field{width:100%}.judge-id-field label{display:block;font-size:14px;color:#888;margin-bottom:6px}.judge-id-input{width:100%;padding:12px 16px;font-size:16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:10px;color:#fff;outline:none}.judge-id-input:focus{border-color:#a855f7}.pin-display{margin:8px 0}.pin-dots{display:flex;gap:10px;justify-content:center}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.2);transition:all .15s}.pin-dot.filled{background:#a855f7;border-color:#a855f7}.login-error{color:#ef4444;font-size:14px;text-align:center}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;max-width:300px}.keypad-btn{height:64px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#fff;font-size:24px;font-weight:500;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s}.keypad-btn:active{background:#a855f7;border-color:#a855f7;transform:scale(.94)}.keypad-btn.special{font-size:18px;background:#ffffff08}.keypad-btn:disabled{opacity:.4}.login-submit{width:100%;max-width:300px;padding:16px;font-size:18px;font-weight:600;border:none;border-radius:12px;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;cursor:pointer}.login-submit:disabled{opacity:.4;cursor:not-allowed}.login-submit:active:not(:disabled){transform:scale(.97)}.error-screen{display:flex;align-items:center;justify-content:center;height:100%;padding:24px}.error-card{text-align:center;max-width:400px}.error-card h2{font-size:22px;font-weight:600;color:#ef4444;margin-bottom:12px}.error-card p{font-size:14px;color:#888;margin-bottom:20px;word-break:break-all}.error-actions{display:flex;gap:12px;justify-content:center}.retry-btn{padding:12px 28px;font-size:16px;font-weight:600;border:none;border-radius:10px;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;cursor:pointer}.logout-btn-error{padding:12px 28px;font-size:16px;font-weight:600;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff0f;color:#aaa;cursor:pointer}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:#888}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#a855f7;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.judge-main{display:flex;flex-direction:column;height:100%}.judge-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:linear-gradient(135deg,#16213e,#1a1a2e);border-bottom:2px solid #a855f7;min-height:56px}.judge-identity{display:flex;align-items:center;gap:10px}.judge-badge{font-size:14px;font-weight:600;color:#a855f7;background:#a855f726;padding:4px 12px;border-radius:8px}.logout-btn{font-size:12px;color:#666;background:none;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:4px 10px;cursor:pointer}.skater-info{display:flex;align-items:center;gap:10px}.start-no{font-size:22px;font-weight:800;color:#a855f7}.skater-name{font-size:20px;font-weight:600}.submitted-badge{font-size:12px;color:#4ade80;background:#4ade8026;padding:3px 10px;border-radius:6px}.waiting-msg{font-size:16px;color:#666}.connection-status{display:flex;align-items:center;gap:6px;font-size:12px}.connection-status.online{color:#4ade80}.connection-status.offline{color:#ef4444}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.main-area{flex:1;display:flex;overflow:hidden}.main-area.waiting,.main-area.submitted{opacity:1}.dim-list{flex:0 0 320px;padding:12px;display:flex;flex-direction:column;gap:6px;overflow-y:auto;border-right:1px solid rgba(255,255,255,.06)}.dim-card{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#ffffff0a;border-radius:12px;border:2px solid transparent;cursor:pointer;transition:all .12s}.dim-card.active{border-color:#a855f7;background:#a855f71a}.dim-card.disabled{opacity:.5;cursor:default}.dim-name{font-size:16px;font-weight:600}.dim-range{font-size:11px;color:#666;margin-top:2px}.dim-value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums;color:#666}.dim-card.active .dim-value,.dim-card.completed .dim-value{color:#fff}.dim-card.completed .dim-value{color:#4ade80}.keypad-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;gap:10px}.keypad-display{display:flex;align-items:center;height:72px}.keypad-value{font-size:56px;font-weight:700;font-variant-numeric:tabular-nums;color:#fff;letter-spacing:3px}.keypad-cursor{display:inline-block;width:3px;height:52px;background:#a855f7;margin-left:3px;animation:blink 1s infinite}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.keypad-hint{font-size:13px;color:#666}.keypad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:300px}.key-btn{height:64px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#fff;font-size:24px;font-weight:500;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .1s}.key-btn:active{background:#a855f7;border-color:#a855f7;transform:scale(.94)}.key-btn.backspace{background:#ef44441f;border-color:#ef444440}.key-btn.backspace:active{background:#ef4444;border-color:#ef4444}.confirm-key{width:300px;background:#4ade801f;border-color:#4ade8040;font-size:16px;font-weight:600}.confirm-key:active{background:#4ade80;border-color:#4ade80;color:#1a1a2e}.keypad-shortcuts{display:flex;gap:6px;margin-top:4px}.shortcut-btn{padding:6px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#aaa;font-size:13px;font-weight:500;cursor:pointer;font-variant-numeric:tabular-nums}.shortcut-btn:active{background:#a855f7;color:#fff}.waiting-overlay,.submitted-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#666}.waiting-icon,.submitted-icon{font-size:48px}.waiting-text,.submitted-text{font-size:18px}.submitted-overlay{color:#4ade80}.submitted-total{font-size:28px;font-weight:700;margin-top:8px}.judge-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:linear-gradient(135deg,#16213e,#1a1a2e);border-top:1px solid rgba(255,255,255,.08);min-height:64px}.score-total{font-size:14px;color:#888}.total-value{font-size:24px;font-weight:700;color:#fff;margin-left:6px;font-variant-numeric:tabular-nums}.submit-btn{padding:12px 40px;font-size:16px;font-weight:600;border:none;border-radius:10px;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;cursor:pointer}.submit-btn:disabled{opacity:.4;cursor:not-allowed}.submit-btn:active:not(:disabled){transform:scale(.97)}.submit-error{display:block;font-size:13px;color:#ef4444;margin-top:4px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.confirm-dialog{background:#1e1e3a;border-radius:16px;padding:28px;width:360px;border:1px solid rgba(255,255,255,.1)}.confirm-dialog h2{font-size:20px;font-weight:600;margin-bottom:16px;text-align:center}.confirm-scores{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.confirm-row{display:flex;justify-content:space-between;font-size:16px;font-variant-numeric:tabular-nums}.confirm-total{display:flex;justify-content:space-between;font-size:18px;font-weight:700;border-top:1px solid rgba(255,255,255,.1);padding-top:8px}.confirm-actions{display:flex;gap:10px}.confirm-cancel,.confirm-ok{flex:1;padding:14px;font-size:16px;font-weight:600;border:none;border-radius:10px;cursor:pointer}.confirm-cancel{background:#ffffff14;color:#aaa}.confirm-ok{background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff}
