.toast-container[data-v-fcd5eb7a]{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:400px}.toast[data-v-fcd5eb7a]{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;cursor:pointer;transition:all .3s ease}.toast[data-v-fcd5eb7a]:hover{transform:translate(-4px)}.toast-icon[data-v-fcd5eb7a]{font-size:18px;font-weight:700}.toast-message[data-v-fcd5eb7a]{font-size:14px;font-weight:500}.toast-success[data-v-fcd5eb7a]{background-color:#10b981;color:#fff}.toast-error[data-v-fcd5eb7a]{background-color:#ef4444;color:#fff}.toast-warning[data-v-fcd5eb7a]{background-color:#f59e0b;color:#fff}.toast-info[data-v-fcd5eb7a]{background-color:#3b82f6;color:#fff}.toast-hiding[data-v-fcd5eb7a]{opacity:0;transform:translate(100%)}.toast-enter-active[data-v-fcd5eb7a],.toast-leave-active[data-v-fcd5eb7a]{transition:all .3s ease}.toast-enter-from[data-v-fcd5eb7a],.toast-leave-to[data-v-fcd5eb7a]{opacity:0;transform:translate(100%)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh}.login-container[data-v-777b044e]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box[data-v-777b044e]{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:400px}.login-header[data-v-777b044e]{text-align:center;margin-bottom:32px}.login-header h1[data-v-777b044e]{color:#1a1a2e;font-size:28px;font-weight:700;margin:0 0 8px}.login-header p[data-v-777b044e]{color:#6b7280;font-size:14px;margin:0}.login-form[data-v-777b044e]{display:flex;flex-direction:column;gap:20px}.form-group[data-v-777b044e]{display:flex;flex-direction:column;gap:8px}.form-group label[data-v-777b044e]{color:#374151;font-size:14px;font-weight:500}.form-group input[data-v-777b044e]{padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s;outline:none}.form-group input[data-v-777b044e]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input[data-v-777b044e]:disabled{background-color:#f3f4f6;cursor:not-allowed}.error-message[data-v-777b044e]{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:14px}.login-button[data-v-777b044e]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button[data-v-777b044e]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-button[data-v-777b044e]:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-footer[data-v-777b044e]{margin-top:32px;text-align:center}.login-footer p[data-v-777b044e]{color:#9ca3af;font-size:12px;margin:0}.dashboard-container[data-v-34827cea]{min-height:100vh;background-color:#f3f4f6;width:100vw;padding:0}.dashboard-header[data-v-34827cea]{background:#fff;padding:8px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000001a}.header-right[data-v-34827cea]{display:flex;align-items:center;gap:10px}.annotation-switch[data-v-34827cea]{display:inline-flex;align-items:center;gap:8px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;padding:6px 10px;font-size:13px;color:#111827;font-weight:600}.annotation-switch select[data-v-34827cea]{border:1px solid #d1d5db;border-radius:8px;padding:6px 8px;background:#fff;font-size:13px;font-weight:600;color:#111827;outline:none;cursor:pointer}.annotation-switch select[data-v-34827cea]:disabled{background:#e5e7eb;color:#6b7280;cursor:not-allowed}.annotation-switch select[data-v-34827cea]:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea40}.header-left h1[data-v-34827cea]{margin:0;font-size:24px;color:#1a1a2e;font-weight:700}.logout-button[data-v-34827cea]{background:#ef4444;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.logout-button[data-v-34827cea]:hover{background:#dc2626}.dashboard-main[data-v-34827cea]{padding:0;max-width:100vw;width:100vw;margin:0}.layout[data-v-34827cea]{display:grid;grid-template-columns:200px minmax(780px,1fr) 200px;gap:8px;height:calc(100vh - 120px);width:100vw}.pane[data-v-34827cea]{background:#fff;border-radius:14px;box-shadow:0 10px 30px #00000014;padding:16px;overflow-y:auto}.video-list[data-v-34827cea]{display:flex;flex-direction:column;gap:12px}.section-title[data-v-34827cea]{font-size:14px;font-weight:700;color:#111827;margin-bottom:12px;display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:linear-gradient(135deg,#eef2ff,#edf2f7);border:1px solid #e0e7ff;box-shadow:inset 0 1px #fff9}.state[data-v-34827cea]{font-size:14px;padding:12px;border-radius:10px}.state.muted[data-v-34827cea]{background:#f3f4f6;color:#6b7280}.state.error[data-v-34827cea]{background:#fef2f2;color:#b91c1c;border:1px solid #fecdd3}.video-list ul[data-v-34827cea]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.video-item[data-v-34827cea]{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid #e5e7eb;border-radius:10px;background:linear-gradient(145deg,#fff,#f8fafc);cursor:pointer;font-size:13px}.video-id[data-v-34827cea]{font-weight:700;color:#4b5563;min-width:56px;font-size:12px}.video-name[data-v-34827cea]{color:#111827;font-weight:600;flex:1;font-size:13px}.video-item.active[data-v-34827cea]{border-color:#667eea;box-shadow:0 0 0 2px #667eea40}.preview-area[data-v-34827cea]{display:flex;flex-direction:column;gap:12px;align-items:stretch;justify-content:stretch;height:100%;position:relative}.zoom-lens[data-v-34827cea]{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:100;border:3px solid #667eea;border-radius:12px;box-shadow:0 8px 32px #00000040;background-color:#fff;pointer-events:none}.zoom-lens[data-v-34827cea]:after{content:"";position:absolute;width:12px;height:12px;background:#ef4444;border:2px solid #ffffff;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #ef444440}.frame-preview[data-v-34827cea]{width:100%;display:flex;flex-direction:column;gap:10px;align-items:stretch;flex:1}.frame-canvas[data-v-34827cea]{position:relative;width:100%;display:flex;justify-content:center;align-items:center;flex:1;min-height:0}.frame-preview img[data-v-34827cea]{max-width:100%;max-height:100%;width:100%;height:100%;border-radius:0;box-shadow:0 12px 30px #0000001f;object-fit:contain}.frame-dot[data-v-34827cea]{position:absolute;width:12px;height:12px;background:#ef4444;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #ef444459}.frame-box[data-v-34827cea]{position:absolute;border:2px solid #2563eb;border-radius:6px;box-shadow:0 8px 24px #2563eb33;background:#2563eb14}.box-badge[data-v-34827cea]{position:absolute;top:-18px;left:0;padding:2px 6px;background:#2563eb;color:#fff;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.02em;box-shadow:0 6px 16px #2563eb4d}.frame-info[data-v-34827cea]{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.saving[data-v-34827cea]{font-weight:500;color:#6b7280}.info-card[data-v-34827cea]{background:linear-gradient(145deg,#fff,#f4f6fb);border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;box-shadow:0 6px 16px #0000000f}.info-label[data-v-34827cea]{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;font-weight:700}.info-value[data-v-34827cea]{font-size:18px;font-weight:700;color:#111827}.panel-header[data-v-34827cea]{font-weight:700;margin-bottom:12px;color:#111827;display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:linear-gradient(135deg,#ecfdf3,#f8fafc);border:1px solid #bbf7d0;box-shadow:inset 0 1px #ffffffb3;font-size:14px}.title-dot[data-v-34827cea],.panel-dot[data-v-34827cea]{width:10px;height:10px;border-radius:50%;display:inline-block}.title-dot[data-v-34827cea]{background:radial-gradient(circle at 30% 30%,#6366f1,#4f46e5);box-shadow:0 0 0 2px #6366f133}.panel-dot[data-v-34827cea]{background:radial-gradient(circle at 30% 30%,#10b981,#0ea5e9);box-shadow:0 0 0 2px #10b98133}.count-pill[data-v-34827cea]{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;background:#111827;color:#fff;font-size:12px;font-weight:700;min-width:32px;box-shadow:0 4px 10px #0000001a}.count-pill.soft[data-v-34827cea]{background:#047857;box-shadow:0 4px 12px #04785740}.frame-list[data-v-34827cea]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.frame-item[data-v-34827cea]{display:flex;gap:12px;align-items:center;padding:12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:13px}.frame-item.annotated[data-v-34827cea]{background:#ecfdf3;border-color:#bbf7d0}.frame-item[data-v-34827cea]:not(.annotated){background:#fef2f2;border-color:#fecdd3}.frame-meta[data-v-34827cea]{color:#4b5563;font-size:12px}.frame-annot[data-v-34827cea]{margin-left:auto;font-weight:600;color:#047857;font-size:12px}.frame-item:not(.annotated) .frame-annot[data-v-34827cea]{color:#b91c1c}.frame-item.active[data-v-34827cea]{box-shadow:0 0 0 2px #667eea40}.welcome-card h2[data-v-34827cea]{margin:0 0 12px;font-size:28px;font-weight:700}.welcome-card p[data-v-34827cea]{margin:0;font-size:16px;opacity:.9}.stats-grid[data-v-34827cea]{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}.stat-card[data-v-34827cea]{background:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:16px}.stat-icon[data-v-34827cea]{font-size:40px}.stat-content h3[data-v-34827cea]{margin:0 0 4px;font-size:14px;color:#6b7280;font-weight:500}.stat-value[data-v-34827cea]{margin:0;font-size:28px;font-weight:700;color:#1a1a2e}.location-dot[data-v-34827cea]{position:absolute;width:20px;height:20px;background:#f59e0b;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #f59e0b59;display:flex;align-items:center;justify-content:center}.location-dot-label[data-v-34827cea]{color:#fff;font-size:10px;font-weight:700}.locations-panel[data-v-34827cea]{display:flex;flex-direction:column;gap:12px}.location-panel-dot[data-v-34827cea]{background:radial-gradient(circle at 30% 30%,#f59e0b,#d97706);box-shadow:0 0 0 2px #f59e0b33}.location-list[data-v-34827cea]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.location-item[data-v-34827cea]{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px}.location-index[data-v-34827cea]{min-width:20px;height:20px;background:#f59e0b;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.location-inputs[data-v-34827cea]{display:flex;gap:6px;flex:1}.location-inputs label[data-v-34827cea]{display:flex;align-items:center;gap:4px;font-size:11px;color:#6b7280;font-weight:600}.location-inputs input[data-v-34827cea]{width:60px;padding:4px 6px;border:1px solid #d1d5db;border-radius:6px;font-size:12px;outline:none}.location-inputs input[data-v-34827cea]:focus{border-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b33}.remove-btn[data-v-34827cea]{background:#fef2f2;border:1px solid #fecdd3;color:#b91c1c;width:22px;height:22px;border-radius:6px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:background .15s}.remove-btn[data-v-34827cea]:hover{background:#fee2e2}.save-locations-btn[data-v-34827cea]{margin-top:8px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #f59e0b4d;transition:opacity .15s}.save-locations-btn[data-v-34827cea]:hover{opacity:.9}.save-locations-btn[data-v-34827cea]:disabled{opacity:.6;cursor:not-allowed}.draw-mode-selector[data-v-34827cea]{display:flex;gap:8px;margin-bottom:12px}.mode-btn[data-v-34827cea]{flex:1;padding:8px 12px;border:2px solid #e5e7eb;background:#fff;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;color:#6b7280}.mode-btn[data-v-34827cea]:hover{border-color:#d1d5db;background:#f9fafb}.mode-btn.active[data-v-34827cea]{border-color:#f59e0b;background:#fffbeb;color:#d97706;box-shadow:0 0 0 2px #f59e0b1a}.section-subtitle[data-v-34827cea]{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding:6px 10px;background:#f9fafb;border-radius:6px;font-size:12px;font-weight:700;color:#374151}.count-badge[data-v-34827cea]{background:#374151;color:#fff;padding:2px 8px;border-radius:999px;font-size:11px;min-width:24px;text-align:center}.points-section[data-v-34827cea],.lines-section[data-v-34827cea]{display:flex;flex-direction:column;gap:8px}.line-info[data-v-34827cea]{display:flex;align-items:center;flex:1;font-size:12px;color:#374151;font-weight:600}.lines-overlay[data-v-34827cea]{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.drawing-start-point[data-v-34827cea]{position:absolute;width:10px;height:10px;background:#3b82f6;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #3b82f666;z-index:2;animation:pulse-34827cea 1s infinite}@keyframes pulse-34827cea{0%,to{box-shadow:0 0 0 3px #3b82f666}50%{box-shadow:0 0 0 6px #3b82f633}}.hol-location-dot[data-v-34827cea]{position:absolute;width:20px;height:20px;background:#f97316;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #f9731659;display:flex;align-items:center;justify-content:center;z-index:3}.hol-dot-label[data-v-34827cea]{color:#fff;font-size:10px;font-weight:700}.hol-ball-dot[data-v-34827cea]{position:absolute;width:14px;height:14px;background:#ef4444;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #ef444466;z-index:4}.hol-peoples-box[data-v-34827cea]{position:absolute;border:2px solid #3b82f6;border-radius:6px;box-shadow:0 8px 24px #3b82f640;background:#3b82f61f;z-index:2}.hol-box-badge[data-v-34827cea]{position:absolute;top:-18px;left:0;padding:2px 6px;background:#3b82f6;color:#fff;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.02em;box-shadow:0 6px 16px #3b82f64d}.hol-frame-people-dot[data-v-34827cea]{position:absolute;width:12px;height:12px;background:#3b82f6;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #3b82f680;z-index:4}.hol-frame-ball-dot[data-v-34827cea]{position:absolute;width:14px;height:14px;background:#ef4444;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #ef444499;z-index:5}.hol-field-container[data-v-34827cea]{width:100%;margin-top:12px}.hol-field-header[data-v-34827cea]{font-size:13px;font-weight:700;color:#374151;margin-bottom:8px;padding:6px 10px;background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border:1px solid #86efac;border-radius:8px}.hol-field[data-v-34827cea]{position:relative;width:100%;aspect-ratio:2 / 1;background:linear-gradient(135deg,#166534,#15803d);border-radius:10px;border:3px solid #fff;box-shadow:0 8px 24px #00000026;overflow:hidden}.hol-field[data-v-34827cea]:before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;background:#fff6;transform:translateY(-50%)}.hol-field[data-v-34827cea]:after{content:"";position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff6;transform:translate(-50%)}.hol-field-location-dot[data-v-34827cea]{position:absolute;width:18px;height:18px;background:#22c55e;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #22c55e80;display:flex;align-items:center;justify-content:center;z-index:3}.hol-field-dot-label[data-v-34827cea]{color:#fff;font-size:9px;font-weight:700}.hol-field-people-dot[data-v-34827cea]{position:absolute;width:12px;height:12px;background:#3b82f6;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #3b82f680;z-index:4}.hol-field-ball-dot[data-v-34827cea]{position:absolute;width:14px;height:14px;background:#ef4444;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #ef444499;z-index:5}
