html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{color:#f5f5f5;background:#000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji;font-size:14px;line-height:1.6;overflow:hidden}:root{--bg-body:#000;--bg-elevated:#080808;--bg-card:#0d0d0d;--bg-card-hover:#141414;--bg-input:#0a0a0a;--bg-surface:#111;--accent:#00e676;--accent-dim:#00c853;--accent-glow:#00e67640;--accent-soft:#00e67614;--accent-blue:#4fc3f7;--accent-blue-soft:#4fc3f71a;--accent-red:#ff5252;--accent-red-soft:#ff52521a;--accent-amber:#ffca28;--accent-amber-soft:#ffca281a;--accent-purple:#b388ff;--accent-purple-soft:#b388ff1a;--accent-orange:#ff9100;--accent-orange-soft:#ff91001a;--gradient-primary:linear-gradient(135deg, #00e676 0%, #00bfa5 100%);--gradient-card:linear-gradient(160deg, #0d0d0d 0%, #161616 100%);--gradient-hero:radial-gradient(ellipse at 20% 0%, #00e6760a 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, #4fc3f708 0%, transparent 50%), #000;--text:#f5f5f5;--text-muted:#888;--text-dim:#555;--text-heading:#fff;--border:#1a1a1a;--border-light:#ffffff0a;--border-accent:#00e6764d;--border-hover:#2a2a2a;--shadow-sm:0 1px 4px #0009;--shadow-md:0 4px 16px #000000b3;--shadow-lg:0 8px 32px #000c;--shadow-glow:0 0 24px #00e6761f;--shadow-glow-lg:0 0 40px #00e67626;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--ease:cubic-bezier(.4, 0, .2, 1);--duration:.25s;--sidebar-width:260px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{background:var(--bg-body);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji;font-size:14px;line-height:1.6;overflow:hidden}#root{min-height:100vh;display:flex}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#222;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#333}::selection{color:#fff;background:#00e6764d}.nav-item,.menu-btn,.sidebar-close,.drop-zone,.export-card,.control-group select{min-height:48px}.nav-item,.menu-btn,.sidebar-close{min-width:48px;min-height:48px}.menu-btn,.sidebar-close{position:relative}.menu-btn:before,.sidebar-close:before{content:"";position:absolute;inset:-8px}.mobile-header{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:100;background:#000000d9;align-items:center;gap:12px;height:56px;padding:0 16px;display:none;position:fixed;top:0;left:0;right:0}.menu-btn{border-radius:var(--radius-sm);width:48px;height:48px;color:var(--text);transition:all var(--duration) var(--ease);justify-content:center;align-items:center;display:flex}.menu-btn:hover{background:var(--accent-soft);color:var(--accent)}.mobile-title{color:var(--text-heading);align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.mobile-spacer{flex:1}.sidebar-backdrop{z-index:199;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:none;position:fixed;inset:0}.sidebar{width:var(--sidebar-width);background:var(--bg-body);border-right:1px solid var(--border);transition:transform var(--duration) var(--ease);z-index:200;flex-direction:column;flex-shrink:0;padding:0;display:flex;position:relative}.sidebar-header{justify-content:space-between;align-items:center;padding:20px 20px 0;display:flex}.sidebar-brand{border-bottom:1px solid var(--border);color:var(--text-heading);white-space:nowrap;align-items:center;gap:10px;padding-bottom:20px;font-size:16px;font-weight:800;display:flex}.sidebar-brand svg{filter:drop-shadow(0 0 6px #00e6764d)}.sidebar-close{border-radius:var(--radius-sm);width:48px;height:48px;color:var(--text-muted);transition:all var(--duration) var(--ease);justify-content:center;align-items:center;display:none}.sidebar-close:hover{background:var(--accent-soft);color:var(--accent)}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 0;display:flex}.nav-item{color:var(--text-muted);transition:all var(--duration) var(--ease);text-align:left;background:0 0;border-radius:0;align-items:center;gap:12px;width:100%;padding:12px 20px;font-size:14px;font-weight:500;display:flex;position:relative}.nav-item:hover{color:var(--text);background:#ffffff08}.nav-item.active{background:var(--accent-soft);color:var(--accent)}.nav-item.active:after{content:"";background:var(--accent);width:3px;height:50%;box-shadow:0 0 8px var(--accent-glow);border-radius:0 3px 3px 0;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-jobs{border-top:1px solid var(--border);padding:16px 20px}.sidebar-jobs h4{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-bottom:10px;font-size:10px;font-weight:700}.job-chip{color:var(--text-muted);align-items:center;gap:8px;padding:7px 0;font-size:12px;display:flex}.job-chip .name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.main{background:var(--gradient-hero);flex:1;max-height:100vh;padding:36px 40px;overflow-y:auto}.tab-content{max-width:1200px;margin:0 auto}.tab-content h2{color:var(--text-heading);letter-spacing:-.3px;align-items:center;gap:12px;margin-bottom:6px;font-size:26px;font-weight:800;display:flex}.subtitle{color:var(--text-muted);margin-bottom:32px;font-size:15px;line-height:1.5}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius-xl);text-align:center;cursor:pointer;transition:all .35s var(--ease);background:var(--bg-card);padding:64px 40px;position:relative;overflow:hidden}.drop-zone:before{content:"";background:radial-gradient(circle at 50% 50%, var(--accent-soft) 0%, transparent 60%);opacity:0;transition:opacity .35s var(--ease);position:absolute;inset:0}.drop-zone:hover:before,.drop-zone.drag-over:before{opacity:1}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);box-shadow:var(--shadow-glow-lg)}.drop-zone-icon{z-index:1;background:var(--accent-soft);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;animation:3s ease-in-out infinite pulse-glow;display:flex;position:relative}@keyframes pulse-glow{0%,to{box-shadow:0 0 #00e67626}50%{box-shadow:0 0 0 12px #00e67600}}.drop-zone h3{z-index:1;color:var(--text-heading);margin:0 0 8px;font-size:18px;font-weight:600;position:relative}.drop-zone .text-muted{z-index:1;position:relative}.progress-section{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);align-items:center;gap:14px;margin-top:24px;padding:16px 20px;display:flex}.progress-bar{border-radius:var(--radius-full);background:#1a1a1a;flex:1;height:6px;overflow:hidden}.progress-fill{background:var(--gradient-primary);border-radius:var(--radius-full);height:100%;transition:width .5s var(--ease);box-shadow:0 0 10px var(--accent-glow)}.error-box{background:var(--accent-red-soft);border-radius:var(--radius-md);color:var(--accent-red);border:1px solid #ff525233;align-items:center;gap:10px;margin-top:16px;padding:14px 18px;font-size:14px;display:flex}.controls-row{flex-wrap:wrap;gap:16px;margin-bottom:28px;display:flex}.control-group{flex-direction:column;gap:6px;display:flex}.control-group label{text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);font-size:11px;font-weight:700}.control-group select{background:var(--bg-input);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);min-width:180px;transition:all var(--duration) var(--ease);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;padding:10px 36px 10px 14px;font-size:14px}.control-group select:hover{border-color:var(--border-hover)}.control-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.video-container{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);background:#000;overflow:hidden}.video-player{width:100%;max-height:70vh;display:block}.empty-state{text-align:center;color:var(--text-muted);padding:64px 20px}.empty-state p{margin-top:12px;font-size:15px}.trajectory-canvas-wrapper{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-md);padding:24px}.trajectory-canvas-wrapper canvas{border-radius:var(--radius-sm);max-width:100%;height:auto}.legend{justify-content:center;gap:24px;margin-top:16px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.loading{text-align:center;color:var(--text-muted);padding:40px;font-size:15px}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px;display:grid}.kpi-card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;transition:all .3s var(--ease);padding:24px 20px;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--gradient-primary);opacity:0;height:2px;transition:opacity var(--duration) var(--ease);position:absolute;top:0;left:0;right:0}.kpi-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-md), var(--shadow-glow);transform:translateY(-2px)}.kpi-card:hover:before{opacity:1}.kpi-icon{justify-content:center;margin-bottom:12px;display:flex}.kpi-card h3{color:var(--text-heading);margin:4px 0 6px;font-size:32px;font-weight:800;line-height:1.2}.kpi-card p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.stats-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .3s var(--ease);padding:24px}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.card-full{grid-column:1/-1}.card h3{color:var(--text-heading);letter-spacing:-.1px;margin-bottom:16px;font-size:15px;font-weight:700}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:600px}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 14px;font-size:13px}.data-table th{color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;background:var(--bg-card);font-size:10px;font-weight:700;position:sticky;top:0}.data-table tr:hover td{background:#ffffff04}.data-table tr:last-child td{border-bottom:none}.team-badge{border-radius:var(--radius-full);padding:3px 12px;font-size:11px;font-weight:700;display:inline-block}.team-1{background:var(--accent-blue-soft);color:var(--accent-blue)}.team-2{background:var(--accent-red-soft);color:var(--accent-red)}.export-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:20px;display:grid}.export-card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .3s var(--ease);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:10px;padding:28px 24px;display:flex;position:relative;overflow:hidden}.export-card:after{content:"";background:radial-gradient(circle at 50% 0%, var(--accent-soft) 0%, transparent 60%);opacity:0;transition:opacity var(--duration) var(--ease);position:absolute;inset:0}.export-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-3px)}.export-card:hover:after{opacity:1}.export-icon{z-index:1;border:1px solid var(--border);background:#ffffff08;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;display:flex;position:relative}.export-card h3{color:var(--text-heading);z-index:1;font-size:15px;font-weight:600;position:relative}.dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.dot.green{background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.dot.red{background:var(--accent-red);box-shadow:0 0 6px var(--accent-red-soft)}.dot.yellow{background:var(--accent-amber);box-shadow:0 0 6px var(--accent-amber-soft)}.text-muted{color:var(--text-muted)}@media (width<=1024px){.main{padding:24px}.stats-row{grid-template-columns:1fr}.kpi-grid,.export-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.mobile-header{display:flex}.sidebar{z-index:200;width:300px;box-shadow:var(--shadow-lg);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar-open{transform:translate(0)}.sidebar-close{display:flex}.sidebar-backdrop{display:block}.main{max-height:calc(100vh - 56px);padding:72px 16px 24px}.tab-content h2{font-size:20px}.subtitle{margin-bottom:20px;font-size:14px}.drop-zone{padding:40px 20px}.drop-zone-icon{width:64px;height:64px}.drop-zone h3{font-size:16px}.controls-row{flex-direction:column;gap:12px}.control-group select{width:100%;min-width:100%}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.kpi-card{padding:16px 12px}.kpi-card h3{font-size:24px}.card{padding:16px}.export-grid{grid-template-columns:1fr}.video-player{max-height:40vh}.legend{flex-wrap:wrap;gap:12px}.trajectory-canvas-wrapper{padding:12px}}@media (width<=480px){.mobile-header{height:50px;padding:0 12px}.main{max-height:calc(100vh - 50px);padding:66px 12px 16px}.tab-content h2{font-size:18px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px}.kpi-card{padding:12px 8px}.kpi-card h3{font-size:20px}.kpi-card p{font-size:10px}.drop-zone{padding:32px 16px}.drop-zone h3{font-size:14px}.progress-section{padding:12px 14px;font-size:13px}.export-card{padding:20px 16px}.export-icon{width:52px;height:52px}.export-card h3{font-size:14px}.error-box{padding:12px 14px;font-size:13px}.sidebar{width:280px}}@media print{.mobile-header,.sidebar,.sidebar-backdrop,.controls-row,.export-grid{display:none!important}.main{background:#fff;max-height:none;padding:0}.tab-content{max-width:100%}.card{box-shadow:none;background:#fff;border:1px solid #ddd}}
