:root{--replay-bg:#0a0a0f;--replay-surface:#12121a;--replay-surface-2:#1a1a28;--replay-surface-3:#222236;--replay-border:rgba(255, 255, 255, 0.06);--replay-accent:#6c5ce7;--replay-accent-glow:rgba(108, 92, 231, 0.3);--replay-atk:#4dabf7;--replay-atk-bg:rgba(77, 171, 247, 0.12);--replay-def:#ff6b6b;--replay-def-bg:rgba(255, 107, 107, 0.12);--replay-text:#e4e4e8;--replay-text-dim:#8888a0;--replay-text-muted:#55556a;--replay-gold:#ffd43b;--replay-green:#51cf66;--replay-orange:#ff922b;--replay-radius:12px;--replay-glass:rgba(18, 18, 26, 0.85)}.upload-wrapper{--replay-bg:#0f172a;--replay-surface:#1e293b;--replay-surface-2:#334155;--replay-surface-3:#475569;--replay-border:#334155;--replay-accent:#f5a623;--replay-accent-glow:rgba(245, 166, 35, 0.3);--replay-text:#f8fafc;--replay-text-dim:#94a3b8;--replay-text-muted:#64748b}.upload-wrapper{max-width:680px;margin:60px auto;padding:0 20px;animation:fadeUp .6s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.upload-hero{text-align:center;margin-bottom:40px}.upload-hero h1{font-size:2.6rem;font-weight:800;background:linear-gradient(135deg,#f5a623,#ffba52);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px;letter-spacing:-.02em}.upload-hero p{color:var(--replay-text-dim);font-size:1.05rem;line-height:1.6}.upload-zone{border:2px dashed var(--replay-surface-3);border-radius:20px;padding:60px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--replay-surface);position:relative;overflow:hidden}.upload-zone::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,var(--replay-accent-glow),transparent 70%);opacity:0;transition:opacity .3s ease}.upload-zone:hover,.upload-zone.dragover{border-color:var(--replay-accent);transform:translateY(-2px);box-shadow:0 8px 32px var(--replay-accent-glow)}.upload-zone:hover::before,.upload-zone.dragover::before{opacity:1}.upload-icon{font-size:56px;color:var(--replay-accent);margin-bottom:16px;position:relative}.upload-zone h3{font-size:1.2rem;font-weight:600;margin-bottom:8px;position:relative}.upload-zone .sub{color:var(--replay-text-muted);font-size:.85rem;position:relative}.upload-progress{margin-top:30px;text-align:center}.progress-bar-track{width:100%;height:4px;background:var(--replay-surface-3);border-radius:4px;overflow:hidden;margin:16px 0}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--replay-accent),#ffba52);border-radius:4px;transition:width .3s ease;animation:progressPulse 1.5s ease infinite}@keyframes progressPulse{0%,to{opacity:1}50%{opacity:.7}}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}.feature-card{background:var(--replay-surface);border:1px solid var(--replay-border);border-radius:var(--replay-radius);padding:20px;text-align:center;transition:all .2s ease}.feature-card:hover{border-color:var(--replay-accent);transform:translateY(-2px)}.feature-card .material-icons-round{font-size:28px;color:var(--replay-accent);margin-bottom:10px}.feature-card h4{font-size:.85rem;font-weight:600;margin-bottom:4px}.feature-card p{font-size:.75rem;color:var(--replay-text-muted)}.error-box{background:rgba(255,107,107,.08);border:1px solid rgba(255,107,107,.2);border-radius:var(--replay-radius);padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;gap:12px;animation:fadeUp .3s ease}.error-box .material-icons-round{color:var(--replay-def);font-size:22px}.error-box span{color:var(--replay-def);font-size:.9rem}.viewer-layout{display:grid;grid-template-columns:1fr 320px;grid-template-rows:1fr auto;gap:0;height:calc(100vh - 70px);background:var(--replay-bg);animation:fadeUp .5s ease}.map-viewport{position:relative;overflow:hidden;background:var(--replay-bg);display:flex;justify-content:center;align-items:center;border-right:1px solid var(--replay-border)}.map-container{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center}.map-image{max-width:95%;max-height:95%;object-fit:contain;border-radius:8px;opacity:.75;filter:saturate(.8) brightness(.85);transition:opacity .3s}.map-overlay-info{position:absolute;top:16px;left:16px;display:flex;flex-direction:column;gap:8px;z-index:10}.map-badge{background:var(--replay-glass);backdrop-filter:blur(12px);border:1px solid var(--replay-border);border-radius:8px;padding:8px 14px;font-size:.8rem;color:var(--replay-text);display:flex;align-items:center;gap:8px}.map-badge .material-icons-round{font-size:16px;color:var(--replay-accent)}.map-badge strong{color:#fff;font-weight:600}.player-marker{position:absolute;width:14px;height:14px;border-radius:50%;border:2px solid #fff;transform:translate(-50%,-50%);transition:all .15s linear;z-index:20;cursor:pointer}.player-marker.atk{background:var(--replay-atk);box-shadow:0 0 10px rgba(77,171,247,.5)}.player-marker.def{background:var(--replay-def);box-shadow:0 0 10px rgba(255,107,107,.5)}.player-marker.dead{opacity:.3;border-style:dashed}.player-marker .marker-label{position:absolute;top:-22px;left:50%;transform:translateX(-50%);font-size:.65rem;font-weight:600;color:#fff;white-space:nowrap;text-shadow:0 1px 4px rgba(0,0,0,.8);pointer-events:none}.event-marker{position:absolute;transform:translate(-50%,-50%);z-index:15;font-size:18px;animation:eventPop .4s ease;pointer-events:none}@keyframes eventPop{0%{transform:translate(-50%,-50%) scale(0);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.time-overlay{position:absolute;bottom:16px;left:16px;background:var(--replay-glass);backdrop-filter:blur(12px);border:1px solid var(--replay-border);border-radius:10px;padding:10px 18px;font-size:1.4rem;font-weight:700;font-variant-numeric:tabular-nums;color:#fff;z-index:10}.sidebar-panel{background:var(--replay-surface);display:flex;flex-direction:column;overflow:hidden;border-bottom:1px solid var(--replay-border);min-height:0}.sidebar-header{padding:20px;border-bottom:1px solid var(--replay-border);flex-shrink:0}.match-title{font-size:1rem;font-weight:700;margin-bottom:4px}.match-meta{font-size:.75rem;color:var(--replay-text-muted)}.score-display{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px 20px;border-bottom:1px solid var(--replay-border);flex-shrink:0}.team-score{text-align:center;flex:1}.team-score .team-name{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.team-score .team-name.atk{color:var(--replay-atk)}.team-score .team-name.def{color:var(--replay-def)}.team-score .score-num{font-size:2rem;font-weight:800}.score-vs{font-size:.8rem;font-weight:600;color:var(--replay-text-muted)}.round-tabs{display:flex;gap:4px;padding:12px 20px;border-bottom:1px solid var(--replay-border);overflow-x:auto;flex-shrink:0}.round-tabs::-webkit-scrollbar{height:0}.round-tab{padding:6px 12px;background:var(--replay-surface-2);border:1px solid var(--replay-border);border-radius:8px;cursor:pointer;font-size:.75rem;font-weight:600;color:var(--replay-text-dim);transition:all .2s ease;white-space:nowrap}.round-tab:hover{background:var(--replay-surface-3);color:var(--replay-text)}.round-tab.active{background:var(--replay-accent);border-color:var(--replay-accent);color:#fff;box-shadow:0 2px 12px var(--replay-accent-glow)}.players-section{padding:8px 20px;border-bottom:1px solid var(--replay-border);flex-shrink:0;max-height:160px;overflow-y:auto}.section-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--replay-text-muted);margin-bottom:10px}.player-row{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:.8rem}.player-dot-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.player-dot-indicator.atk{background:var(--replay-atk)}.player-dot-indicator.def{background:var(--replay-def)}.player-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-op{font-size:.7rem;color:var(--replay-text-muted);font-weight:500}.player-kd{font-size:.75rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--replay-text-dim)}.killfeed-section{flex:0 0 auto;overflow-y:auto;padding:0 20px 12px 20px;min-height:200px;max-height:280px}.killfeed-section .section-label{position:sticky;top:0;z-index:2;background:var(--replay-surface);padding-top:10px;padding-bottom:10px;margin-bottom:0;border-bottom:1px solid var(--replay-border);box-shadow:0 8px 14px rgba(0,0,0,.35)}.events-tabs{display:flex;gap:4px;padding:8px 0 10px 0;position:sticky;top:32px;z-index:2;background:var(--replay-surface)}.events-tab{flex:0 0 auto;padding:4px 10px;font-size:.7rem;border-radius:999px;border:1px solid var(--replay-border);background:var(--replay-surface-2);color:var(--replay-text-muted);cursor:pointer;transition:all .15s ease}.events-tab.active{background:var(--replay-accent);color:#fff;border-color:var(--replay-accent);box-shadow:0 0 10px var(--replay-accent-glow)}.killfeed-section::-webkit-scrollbar{width:4px}.killfeed-section::-webkit-scrollbar-track{background:0 0}.killfeed-section::-webkit-scrollbar-thumb{background:var(--replay-surface-3);border-radius:4px}.feed-item{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:4px;background:var(--replay-surface-2);border-radius:8px;font-size:.8rem;transition:background .15s}@keyframes feedSlide{0%{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}.feed-item:hover{background:var(--replay-surface-3)}.feed-content{display:flex;align-items:center;gap:6px;flex:1;min-width:0;overflow:hidden}.feed-item .feed-icon{font-size:16px;flex-shrink:0}.feed-item .feed-killer{color:var(--replay-atk);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feed-item .feed-victim{color:var(--replay-def);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feed-item .feed-arrow{color:var(--replay-text-muted);font-size:.7rem}.feed-item .feed-headshot{color:var(--replay-gold);font-size:14px}.feed-item .feed-time{margin-left:auto;font-size:.7rem;color:var(--replay-text-muted);font-variant-numeric:tabular-nums;flex-shrink:0}.feed-item.event-plant{border-left:3px solid var(--replay-orange)}.feed-item.event-disable{border-left:3px solid var(--replay-atk)}.feed-item.event-death{border-left:3px solid var(--replay-def)}.feed-item.event-other{border-left:3px solid var(--replay-text-muted)}.timeline-bar{grid-column:1/-1;background:var(--replay-surface);border-top:1px solid var(--replay-border);padding:14px 24px;display:flex;align-items:center;gap:16px}.tl-btn{background:var(--replay-surface-2);border:1px solid var(--replay-border);border-radius:10px;color:var(--replay-text);cursor:pointer;display:flex;align-items:center;justify-content:center;width:40px;height:40px;transition:all .2s;flex-shrink:0}.tl-btn:hover{background:var(--replay-accent);border-color:var(--replay-accent);box-shadow:0 2px 12px var(--replay-accent-glow)}.tl-btn .material-icons-round{font-size:20px}.tl-slider-wrap{flex:1;position:relative}.tl-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--replay-surface-3);border-radius:6px;outline:0;cursor:pointer}.tl-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--replay-accent);border:3px solid #fff;cursor:grab;box-shadow:0 2px 8px var(--replay-accent-glow);transition:transform .15s}.tl-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.tl-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--replay-accent);border:3px solid #fff;cursor:grab}.tl-events{position:absolute;top:0;left:0;right:0;height:6px;pointer-events:none}.tl-event-dot{position:absolute;width:6px;height:6px;border-radius:50%;top:0;transform:translateX(-50%)}.tl-event-dot.kill{background:var(--replay-def)}.tl-event-dot.plant{background:var(--replay-orange)}.tl-event-dot.obj{background:var(--replay-green)}.tl-event-dot.loc{background:var(--replay-accent)}.tl-time-display{font-size:.9rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--replay-text);min-width:50px;text-align:center;flex-shrink:0}.tl-speed{background:var(--replay-surface-2);border:1px solid var(--replay-border);border-radius:8px;color:var(--replay-text);padding:6px 12px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;flex-shrink:0}.tl-speed:hover{background:var(--replay-accent);border-color:var(--replay-accent)}@media (max-width:900px){.viewer-layout{grid-template-columns:1fr;grid-template-rows:50vh auto auto}.sidebar-panel{max-height:40vh}.features-grid{grid-template-columns:1fr}.upload-hero h1{font-size:1.8rem}}.position-info{position:absolute;bottom:16px;right:16px;background:var(--replay-glass);backdrop-filter:blur(12px);border:1px solid var(--replay-border);border-radius:10px;padding:8px 14px;font-size:.7rem;color:var(--replay-text-muted);z-index:10}.stats-overlay{width:100%;height:100%;display:flex;flex-direction:column;padding:24px;box-sizing:border-box;overflow:hidden;background:radial-gradient(ellipse at 30% 20%,rgba(77,171,247,.06) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(255,107,107,.06) 0%,transparent 60%),var(--replay-bg)}.stats-teams-container{display:grid;grid-template-columns:1fr;gap:20px;flex:1;align-items:center}.stats-team-col{display:flex;flex-direction:column;gap:4px;width:100%;max-width:480px}.stats-team-header{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;padding:10px 16px;display:flex;align-items:center;gap:10px;border-radius:6px 6px 2px 2px}.stats-team-header.atk{color:#fff;background:linear-gradient(135deg,rgba(77,171,247,.25)0,rgba(77,171,247,.08) 100%);border-bottom:2px solid var(--replay-atk);text-shadow:0 0 20px rgba(77,171,247,.5)}.stats-team-header.def{color:#fff;background:linear-gradient(135deg,rgba(255,107,107,.25)0,rgba(255,107,107,.08) 100%);border-bottom:2px solid var(--replay-def);text-shadow:0 0 20px rgba(255,107,107,.5)}.stats-team-header .team-header-icon{font-size:18px}.stats-player-card{background:rgba(18,18,26,.7);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.05);border-left:3px solid transparent;border-radius:4px;padding:8px 14px;display:flex;align-items:center;gap:12px;transition:all .2s ease}.stats-player-card:hover{background:rgba(30,30,44,.85);border-left-color:rgba(255,255,255,.2);transform:translateX(2px)}.stats-player-card.team-atk{border-left-color:rgba(77,171,247,.4)}.stats-player-card.team-atk:hover{border-left-color:var(--replay-atk);box-shadow:-2px 0 12px rgba(77,171,247,.15)}.stats-player-card.team-def{border-left-color:rgba(255,107,107,.4)}.stats-player-card.team-def:hover{border-left-color:var(--replay-def);box-shadow:-2px 0 12px rgba(255,107,107,.15)}.stats-rank-icon{width:34px;height:34px;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}.stats-player-info{flex:1;min-width:0}.stats-player-name{font-size:.82rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.01em}.stats-player-op{font-size:.65rem;color:var(--replay-text-muted);font-weight:500;margin-top:1px}.stats-player-stats{display:flex;gap:14px;flex-shrink:0}.stats-stat-item{text-align:center;min-width:38px}.stats-stat-label{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--replay-text-muted);margin-bottom:2px}.stats-stat-value{font-size:.8rem;font-weight:700;font-variant-numeric:tabular-nums;color:#fff}.stats-loading{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--replay-text-muted)}.stats-loading .spinner{width:14px;height:14px;border:2px solid var(--replay-surface-3);border-top-color:var(--replay-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(360deg)}}.stats-error{font-size:.7rem;color:var(--replay-text-muted);font-style:italic}.back-btn{display:inline-flex;align-items:center;gap:6px;background:var(--replay-surface-2);border:1px solid var(--replay-border);border-radius:8px;color:var(--replay-text-dim);padding:6px 14px;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.back-btn:hover{background:var(--replay-accent);border-color:var(--replay-accent);color:#fff;box-shadow:0 2px 12px var(--replay-accent-glow)}.back-btn .material-icons-round{font-size:16px}@media (max-width:900px){.stats-teams-container{grid-template-columns:1fr}}.stats-player-card.is-recorder{border-color:var(--replay-gold)!important;box-shadow:0 0 12px rgba(255,215,0,.15),inset 0 0 20px rgba(255,215,0,.03)}.recorder-badge{font-size:.6rem;background:var(--replay-gold);color:#0a0a0f;padding:1px 5px;border-radius:4px;font-weight:700;letter-spacing:.03em;margin-left:6px}.player-row.is-recorder{border-left:2px solid var(--replay-gold);padding-left:6px}.win-condition-banner{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:8px;font-size:.8rem;font-weight:700;letter-spacing:.04em;margin-top:6px}.win-condition-banner.atk-win{background:rgba(78,164,255,.1);border:1px solid rgba(78,164,255,.3);color:var(--replay-atk)}.win-condition-banner.def-win{background:rgba(255,152,56,.1);border:1px solid rgba(255,152,56,.3);color:var(--replay-orange)}.map-badge.badge-ranked{border-color:var(--replay-gold);color:var(--replay-gold);background:rgba(255,215,0,.08)}.map-badge.badge-unranked{border-color:#8e8e93;color:#8e8e93;background:rgba(142,142,147,.08)}.map-badge.badge-standard{border-color:var(--replay-atk);color:var(--replay-atk);background:rgba(78,164,255,.08)}.map-badge.badge-custom{border-color:var(--replay-text-muted);color:var(--replay-text-muted);background:rgba(120,120,128,.08)}.round-info-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.round-info-tag{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;color:var(--replay-text-dim);background:var(--replay-surface-2);border:1px solid var(--replay-border);border-radius:6px;padding:3px 8px}.round-info-tag .material-icons-round{font-size:13px}.player-score{font-size:.68rem;color:var(--replay-text-muted);margin-left:auto;font-variant-numeric:tabular-nums}