*{margin:0;padding:0;box-sizing:border-box}.app{width:100%;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f172a;color:#fff;display:flex;flex-direction:column}.page{width:100%;min-height:100vh;display:flex;flex-direction:column}.header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#0000004d}.test-header{background:#8b5cf626;border-bottom:1px solid rgba(139,92,246,.3)}.title{font-size:18px;font-weight:700;flex:1}.btn-back{width:36px;height:36px;border:none;border-radius:8px;background:#ffffff1a;color:#fff;font-size:18px;cursor:pointer}.game-info{flex:1;text-align:center}.game-title-small{font-size:14px;font-weight:600}.test-badge{font-size:13px;font-weight:600;color:#a78bfa}.status-item{font-size:12px;padding:4px 10px;border-radius:12px;background:#ef444433;color:#ef4444}.status-item.online{background:#22c55e33;color:#22c55e}.test-entry{display:flex;align-items:center;gap:14px;padding:16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:12px;cursor:pointer;margin-bottom:20px;transition:all .2s}.test-entry:active{background:#8b5cf633;transform:scale(.98)}.test-icon{font-size:28px}.test-text{flex:1}.test-title{font-size:15px;font-weight:600;color:#a78bfa;margin-bottom:2px}.test-desc{font-size:12px;color:#64748b}.test-arrow{font-size:18px;color:#64748b}.divider{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:#475569;font-size:12px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#ffffff14}.page-body{flex:1;padding:16px;overflow-y:auto}.section-title{font-size:16px;margin-bottom:16px;color:#e2e8f0}.loading{text-align:center;padding:40px;color:#94a3b8}.empty-state{text-align:center;padding:60px 20px;color:#64748b}.empty-state .sub{font-size:13px;margin-top:8px}.game-list{display:flex;flex-direction:column;gap:12px}.game-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s}.game-card:active{background:#ffffff1a;transform:scale(.98)}.game-teams{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.team{font-size:18px;font-weight:700}.vs{font-size:12px;color:#64748b}.game-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:#94a3b8}.game-title{flex:1}.game-status{padding:2px 8px;border-radius:4px;font-size:11px}.game-status.in_progress{background:#22c55e33;color:#22c55e}.game-status.upcoming{background:#3b82f633;color:#3b82f6}.game-status.completed{background:#94a3b833;color:#94a3b8}.game-score{font-weight:700;color:#e2e8f0}.btn-refresh{margin-top:20px;width:100%;padding:14px;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:transparent;color:#94a3b8;font-size:14px;cursor:pointer}.btn-refresh:disabled{opacity:.4}.lineup-bar{padding:8px 12px;background:#0003;border-bottom:1px solid rgba(255,255,255,.05)}.lineup-team{display:flex;align-items:center;gap:8px;margin-bottom:4px}.team-label{font-size:11px;font-weight:700;min-width:40px}.player-chips{display:flex;gap:4px;flex-wrap:wrap}.chip{font-size:10px;padding:2px 6px;background:#ffffff14;border-radius:4px;color:#94a3b8}.no-lineup{text-align:center;font-size:12px;color:#fbbf24;padding:8px}.camera-container{position:relative;width:100%;aspect-ratio:4/3;background:#000;overflow:hidden}.camera-video{width:100%;height:100%;object-fit:cover}.recording-overlay{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:8px;padding:6px 12px;background:#000000b3;border-radius:20px;font-size:14px}.rec-dot{width:10px;height:10px;background:#ef4444;border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.detection-toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:16px 32px;border-radius:12px;font-size:20px;font-weight:700;text-align:center;animation:pop .3s ease}.detection-toast.made{background:#22c55ee6}.detection-toast.miss{background:#ef4444e6}.detection-toast small{display:block;font-size:12px;font-weight:400;margin-top:4px}@keyframes pop{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.controls{padding:12px 16px}.btn-record{width:100%;padding:14px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff}.btn-record.recording{background:linear-gradient(135deg,#ef4444,#dc2626)}.btn-record:disabled{opacity:.5;cursor:not-allowed}.stats-panel{display:flex;padding:0 16px 12px;gap:10px}.stat-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px;border-radius:10px;background:#ffffff0d}.stat-item.auto{background:#22c55e1f;border:1px solid rgba(34,197,94,.25)}.stat-item.pending{background:#fbbf241f;border:1px solid rgba(251,191,36,.25)}.stat-item.unsynced{background:#94a3b814;border:1px solid rgba(148,163,184,.15)}.stat-item.made-stat{background:#22c55e1f;border:1px solid rgba(34,197,94,.25)}.stat-item.miss-stat{background:#ef44441f;border:1px solid rgba(239,68,68,.25)}.stat-item.total-stat{background:#3b82f61f;border:1px solid rgba(59,130,246,.25)}.stat-label{font-size:10px;color:#94a3b8;margin-bottom:2px}.stat-value{font-size:18px;font-weight:700}.stat-item.auto .stat-value,.stat-item.made-stat .stat-value{color:#22c55e}.stat-item.pending .stat-value{color:#fbbf24}.stat-item.unsynced .stat-value,.stat-item.total-stat .stat-value{color:#94a3b8}.stat-item.miss-stat .stat-value{color:#ef4444}.data-section{flex:1;display:flex;flex-direction:column;margin:0 16px 16px;background:#ffffff08;border-radius:12px;overflow:hidden;min-height:120px}.data-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.1)}.data-header h3{font-size:13px;color:#e2e8f0}.btn-clear{padding:3px 10px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#94a3b8;font-size:11px;cursor:pointer}.data-list{flex:1;overflow-y:auto;padding:6px}.data-item{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:4px;background:#ffffff0d;border-radius:6px;border-left:3px solid #64748b;font-size:13px}.data-item.synced.auto_recorded{border-left-color:#22c55e}.data-item.synced.pending_review{border-left-color:#fbbf24}.time{color:#64748b;font-size:11px;min-width:55px}.label{flex-shrink:0;font-weight:500}.label.made{color:#22c55e}.label.miss{color:#ef4444}.player-name{flex:1;color:#94a3b8;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sync-badge{font-size:9px;padding:2px 6px;border-radius:8px;background:#94a3b833;color:#94a3b8;white-space:nowrap}.sync-badge.auto_recorded{background:#22c55e33;color:#22c55e}.sync-badge.pending_review{background:#fbbf2433;color:#fbbf24}.confidence-bar{width:50px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;flex-shrink:0}.conf-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#ef4444,#fbbf24,#22c55e);transition:width .3s}.conf-text{font-size:10px;color:#94a3b8;min-width:30px;text-align:right}.empty{flex:1;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:13px}.error-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:12px 24px;background:#ef4444;border-radius:8px;font-size:14px;z-index:100;max-width:90%;text-align:center}
