.prompt-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.prompt-editor-modal{background:#0f172a;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0009;border:1px solid rgba(255,255,255,.1);animation:slideUp .3s ease-out}.prompt-editor-header{padding:24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#0f172a}.prompt-editor-header h2{margin:0;font-size:24px;font-weight:600;color:#f8fafc}.close-button{background:none;border:none;font-size:32px;color:#94a3b8;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;line-height:1}.close-button:hover{background:#ffffff1a;color:#f8fafc}.prompt-editor-content{padding:24px;overflow-y:auto;flex:1;background:#0f172a}.camera-name{font-size:16px;font-weight:500;color:#94a3b8;margin:0 0 16px}.info-message{background:#3b82f626;border:1px solid rgba(59,130,246,.3);color:#93c5fd;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px;line-height:1.5}.loading{text-align:center;padding:40px;color:#94a3b8;font-size:16px}label{display:block;width:100%}.label-text{font-weight:600;margin-bottom:8px;color:#f8fafc;font-size:14px}.prompt-textarea{width:100%;padding:12px;border:1px solid rgba(255,255,255,.15);border-radius:8px;font-size:14px;font-family:Monaco,Menlo,Courier New,monospace;resize:vertical;min-height:100px;transition:border-color .2s,box-shadow .2s;color:#f8fafc;background:#1e293b;box-sizing:border-box}.prompt-textarea:focus{outline:none;border-color:#22c55e;box-shadow:0 0 0 3px #22c55e33}.prompt-textarea::placeholder{color:#64748b}.hint{background:#22c55e1a;border-left:4px solid #22c55e;padding:12px 16px;margin-top:16px;font-size:13px;color:#94a3b8;line-height:1.6;border-radius:4px}.hint p{margin:4px 0 0}.hint p:first-child{margin-top:0}.hint strong{color:#f8fafc;font-weight:600}.error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:12px 16px;border-radius:8px;margin-top:16px;font-size:14px}.prompt-editor-footer{padding:16px 24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end;gap:12px;background:#0f172a}.button-primary,.button-secondary,.button-danger{padding:10px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none;font-family:inherit}.button-primary{background:#22c55e;color:#fff;box-shadow:0 1px 2px #0003}.button-primary:hover:not(:disabled){background:#16a34a;transform:translateY(-1px);box-shadow:0 4px 12px #22c55e66}.button-primary:disabled{background:#334155;color:#64748b;cursor:not-allowed;transform:none;box-shadow:none}.button-secondary{background:transparent;color:#94a3b8;border:1px solid rgba(255,255,255,.15)}.button-secondary:hover{background:#ffffff0d;border-color:#ffffff40;color:#f8fafc}.button-danger{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.button-danger:hover:not(:disabled){background:#ef444440;border-color:#ef444480}.button-danger:disabled{opacity:.5;cursor:not-allowed}.user-prompts-section{margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.connection-badge{background:#3b82f633;color:#93c5fd;font-size:12px;font-weight:500;padding:4px 10px;border-radius:9999px}.user-tags-container{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.user-tag{background:#22c55e26;color:#86efac;border:1px solid rgba(34,197,94,.3);font-size:13px;font-weight:500;padding:6px 12px;border-radius:6px;font-family:Monaco,Menlo,Courier New,monospace}.no-user-prompts{color:#64748b;font-size:13px;font-style:italic;margin:0}.clear-user-prompts-btn{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3);font-size:12px;font-weight:500;padding:4px 12px;border-radius:6px;cursor:pointer;transition:all .2s}.clear-user-prompts-btn:hover:not(:disabled){background:#ef444440;border-color:#ef444480}.clear-user-prompts-btn:disabled{opacity:.5;cursor:not-allowed}.combined-prompt-section{margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.combined-prompt-display{background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px;font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;color:#f8fafc;word-break:break-word}.combined-hint{margin-top:8px;margin-bottom:0;font-size:12px;color:#64748b;font-style:italic}@media (max-width: 640px){.prompt-editor-modal{width:95%;max-height:95vh}.prompt-editor-header,.prompt-editor-content,.prompt-editor-footer{padding:16px}.prompt-editor-header h2{font-size:20px}}.camera-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.camera-card{background:#0f1420;border-radius:8px;overflow:hidden;transition:all .3s ease;border:1px solid rgb(30 41 59)}.camera-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d;border-color:#334155}.camera-card.offline{opacity:.6}.camera-thumbnail{position:relative;width:100%;height:200px;background:#1a1f2e;overflow:hidden}.camera-thumbnail img{width:100%;height:100%;object-fit:cover}.camera-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:56px;color:#94a3b8cc;background:radial-gradient(circle at 30% 20%,rgba(99,102,241,.18),transparent 55%),radial-gradient(circle at 70% 80%,rgba(16,185,129,.12),transparent 55%),#1a1f2e}.status-badge{position:absolute;top:10px;right:10px;padding:5px 12px;border-radius:20px;font-size:.85rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.status-badge.online{background:#10b981e6;color:#fff}.status-badge.offline{background:#ef4444e6;color:#fff}.camera-info{padding:15px}.camera-info h3{margin:0 0 8px;color:#fff;font-size:1.1rem}.camera-id{font-size:.85rem;color:#94a3b8;margin:4px 0;font-family:monospace}.camera-rtsp{font-size:.8rem;color:#94a3b8;margin:8px 0;word-break:break-all}.camera-rtsp .label{font-weight:600;color:#fff}.camera-prompt{font-size:.85rem;color:#94a3b8;margin:8px 0}.camera-prompt .label{font-weight:600;color:#fff}.camera-prompt .prompt-not-set{color:#94a3b899;font-style:italic}.assignment-info{display:flex;justify-content:space-between;align-items:center;margin-top:12px;gap:10px}.assigned-badge{padding:6px 12px;background:#10b981;color:#fff;border-radius:6px;font-size:.85rem;font-weight:500;flex:1}.btn-assign,.btn-unassign{width:100%;margin-top:12px;padding:10px;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-assign{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-assign:hover:not(:disabled){transform:scale(1.02);box-shadow:0 2px 8px #667eea66}.btn-assign:disabled{background:#ccc;cursor:not-allowed}.btn-unassign{background:#ef4444;color:#fff;width:auto;margin-top:0;padding:6px 12px;font-size:.85rem}.btn-unassign:hover{background:#dc2626}.empty-state{text-align:center;padding:60px 20px;color:#94a3b8e6}.empty-state p{font-size:1.2rem;margin-bottom:10px;color:#fffc}.empty-state-hint{font-size:.95rem!important;color:#94a3b8b3}.button-group{display:flex;gap:8px;flex-wrap:wrap}.btn-edit-prompt{padding:6px 12px;background:#2196f3;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .2s}.btn-edit-prompt:hover{background:#1976d2}.btn-calibrate{padding:6px 12px;background:#f59e0b;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .2s}.btn-calibrate:hover{background:#d97706}.camera-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.camera-popover{position:relative;width:320px;background:#1a1a2e;border-radius:12px;box-shadow:0 8px 32px #00000080;border:1px solid #2a2a4a;overflow:visible;pointer-events:auto;transform:translateY(calc(-50% - 45px))}.camera-popover .popover-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#16162a;border-bottom:1px solid #2a2a4a;border-radius:12px 12px 0 0}.camera-popover .camera-status{display:flex;align-items:center;gap:8px;height:24px}.camera-popover .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.camera-popover .camera-name{font-size:.9rem;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;padding-top:14px}.camera-popover .header-actions{display:flex;align-items:center;gap:4px}.camera-popover .action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:none;border-radius:6px;color:#999;cursor:pointer;transition:all .2s}.camera-popover .action-btn:hover{background:#ffffff26;color:#fff}.camera-popover .align-btn:hover{background:#3b82f633;color:#3b82f6}.camera-popover .close-btn:hover{background:#ef444433;color:#ef4444}.camera-popover .popover-body{aspect-ratio:16 / 9;background:#000;overflow:hidden;border-radius:0 0 12px 12px}.camera-popover .live-feed{width:100%;height:100%;object-fit:cover}.camera-popover .no-feed{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#666;font-size:.85rem}.camera-popover .no-feed .icon{font-size:1.5rem;opacity:.5}.camera-popover .popover-tail{position:absolute;width:0;height:0;border-style:solid;bottom:-12px;left:50%;transform:translate(-50%);border-width:10px 10px 0 10px;border-color:#1a1a2e transparent transparent transparent}@keyframes popoverFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.camera-popover{animation:popoverFadeIn .2s ease-out}@keyframes popoverFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.camera-placement-map{display:flex;flex-direction:column;height:100%;position:relative}.camera-placement-map .floor-selector{position:absolute;top:12px;left:12px;z-index:10;display:flex;align-items:center;gap:8px;padding:8px 12px;background:#1a1a2ef2;border-radius:6px;box-shadow:0 2px 8px #0000004d}.camera-placement-map .floor-selector label{font-size:.85rem;color:#999}.camera-placement-map .floor-selector select{padding:4px 8px;background:#ffffff1a;border:1px solid #3a3a5a;border-radius:4px;color:#fff;font-size:.85rem}.placement-instructions{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:10;padding:10px 20px;background:#1a1a2ef2;border-radius:20px;box-shadow:0 2px 8px #0000004d}.instruction-text{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#fff}.instruction-text .icon{font-size:1.1rem}.camera-placement-map .map-container{flex:1;position:relative;background:#0f0f1a}.camera-placement-map .map-container.dragging{cursor:grabbing!important}.camera-placement-map .map-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0f0f1ae6;z-index:5}.camera-placement-map .loading-spinner{width:40px;height:40px;border:3px solid rgba(59,130,246,.2);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.camera-placement-map .map-loading p{margin-top:16px;color:#666}.camera-placement-map .map-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#f87171}.camera-placement-map .error-icon{font-size:2rem;display:block;margin-bottom:8px}.camera-info-display{position:absolute;bottom:12px;left:12px;z-index:10;padding:12px 16px;background:#1a1a2ef2;border-radius:8px;box-shadow:0 2px 8px #0000004d}.camera-info-display .info-item{display:flex;gap:8px;font-size:.8rem;padding:2px 0}.camera-info-display .label{color:#999}.camera-info-display .value{color:#fff;font-family:monospace}.camera-dot-marker{width:24px;height:24px;margin-left:-12px;margin-top:-12px;display:flex;align-items:center;justify-content:center;pointer-events:none}.camera-dot-marker .camera-dot{width:14px;height:14px;background:#111;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 6px #00000080}.target-marker{position:relative;width:32px;height:32px;margin-left:-16px;margin-top:-16px;display:flex;align-items:center;justify-content:center}.target-marker .target-crosshair{font-size:24px;color:#ef4444;text-shadow:0 0 8px rgba(239,68,68,.5)}.visible-edge-marker{position:relative;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.visible-edge-marker .edge-dot{width:10px;height:10px;background:#22c55e;border:2px solid rgba(255,255,255,.8);border-radius:50%;box-shadow:0 0 6px #22c55e80}.boresight-wall-overlay-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.boresight-wall-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.fine-tune-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.fine-tune-modal{background:#1a1a2e;border-radius:12px;width:95vw;height:92vh;max-width:1800px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000080}.fine-tune-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#16162a;border-bottom:1px solid #2a2a4a}.fine-tune-modal .header-left{display:flex;align-items:center;gap:16px}.fine-tune-modal .modal-header h2{margin:0;font-size:1.2rem;font-weight:600;color:#fff}.fine-tune-modal .step-indicator{padding:6px 14px;background:#3b82f6;color:#fff;border-radius:20px;font-size:.8rem;font-weight:500}.fine-tune-modal .close-btn{width:32px;height:32px;border:none;background:#ffffff1a;color:#999;font-size:1.5rem;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.fine-tune-modal .close-btn:hover{background:#fff3;color:#fff}.fine-tune-modal .modal-content{flex:1;display:flex;overflow:hidden}.fine-tune-modal .controls-sidebar{width:260px;background:#16162a;border-right:1px solid #2a2a4a;padding:16px;overflow-y:auto}.fine-tune-modal .controls-sidebar h4{margin:0 0 16px;font-size:.85rem;font-weight:600;color:#999;text-transform:uppercase}.fine-tune-modal .control-group{margin-bottom:16px}.fine-tune-modal .control-group label{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#ccc;margin-bottom:6px}.fine-tune-modal .control-group input[type=number]{width:100%;padding:8px 12px;background:#ffffff0d;border:1px solid #3a3a5a;border-radius:6px;color:#fff;font-size:.9rem}.fine-tune-modal .control-group.stepper-control .stepper-row{display:flex;align-items:center;gap:4px}.fine-tune-modal .control-group.stepper-control .stepper-row input[type=number]{flex:1;text-align:center;padding:8px 4px;-moz-appearance:textfield}.fine-tune-modal .control-group.stepper-control .stepper-row input[type=number]::-webkit-outer-spin-button,.fine-tune-modal .control-group.stepper-control .stepper-row input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.fine-tune-modal .stepper-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid #3a3a5a;border-radius:6px;color:#ccc;font-size:1.2rem;font-weight:500;cursor:pointer;transition:all .15s;flex-shrink:0}.fine-tune-modal .stepper-btn:hover{background:#ffffff26;border-color:#4a4a6a;color:#fff}.fine-tune-modal .control-group.model-selector select{width:100%;padding:10px 36px 10px 12px;background:#ffffff0d;border:1px solid #3a3a5a;border-radius:6px;color:#fff;font-size:.9rem;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23999'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px}.fine-tune-modal .control-group.model-selector select option{background:#1a1a2e;color:#fff}.fine-tune-modal .model-info{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px;background:#ffffff08;border-radius:4px;font-size:.8rem}.fine-tune-modal .model-color-badge{width:12px;height:12px;border-radius:2px;flex-shrink:0}.fine-tune-modal .model-fov{color:#3b82f6;font-family:monospace}.fine-tune-modal .wall-overlay-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:#ffffff14;border:1px solid #3a3a5a;border-radius:8px;color:#ccc;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.fine-tune-modal .wall-overlay-btn:hover:not(:disabled){background:#ffffff1f;border-color:#4a4a6a}.fine-tune-modal .wall-overlay-btn:disabled{opacity:.4;cursor:not-allowed}.fine-tune-modal .wall-overlay-btn.active{background:#3b82f633;border-color:#3b82f6;color:#8bb4f0}.fine-tune-modal .wall-overlay-btn .btn-icon{font-size:1.1rem}.fine-tune-modal .calculated-values{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:8px;padding:12px;margin-bottom:16px}.fine-tune-modal .calculated-values h5{margin:0 0 8px;font-size:.8rem;color:#3b82f6;text-transform:uppercase}.fine-tune-modal .value-row{display:flex;justify-content:space-between;font-size:.85rem;padding:4px 0}.fine-tune-modal .value-row .label{color:#999}.fine-tune-modal .value-row .value{color:#fff;font-family:monospace}.fine-tune-modal .control-group.calculated-value .calculated-display{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:4px;padding:8px 12px;font-family:monospace;font-size:.9rem}.fine-tune-modal .control-group.calculated-value .resolution-value{color:#3b82f6;font-weight:500}.fine-tune-modal .control-group.calculated-value .resolution-pending{color:#999;font-style:italic}.fine-tune-modal .adjustment-controls{margin-top:16px;padding-top:16px;border-top:1px solid #2a2a4a}.fine-tune-modal .adjustment-controls h5{margin:0 0 12px;font-size:.8rem;color:#999;text-transform:uppercase}.fine-tune-modal .adjustment-buttons{display:flex;gap:8px}.fine-tune-modal .adjust-btn{flex:1;padding:10px 12px;background:#ffffff14;border:1px solid #3a3a5a;border-radius:6px;color:#ccc;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.fine-tune-modal .adjust-btn:hover{background:#ffffff1f;border-color:#4a4a6a}.fine-tune-modal .adjust-btn.active{background:#22c55e33;border-color:#22c55e;color:#4ade80}.fine-tune-modal .adjustment-hint{margin:12px 0 0;padding:8px 12px;background:#22c55e1a;border-radius:4px;font-size:.8rem;color:#4ade80;text-align:center}.fine-tune-modal .adjustment-hint strong{font-weight:600;letter-spacing:1px}.fine-tune-modal .action-buttons{display:flex;gap:8px;margin-top:16px}.fine-tune-modal .action-buttons button{flex:1;padding:10px 16px;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.fine-tune-modal .action-buttons .btn-secondary{background:#ffffff1a;color:#ccc}.fine-tune-modal .action-buttons .btn-secondary:hover{background:#ffffff26}.fine-tune-modal .action-buttons .btn-primary{background:#3b82f6;color:#fff}.fine-tune-modal .action-buttons .btn-primary:hover:not(:disabled){background:#2563eb}.fine-tune-modal .action-buttons button:disabled{opacity:.5;cursor:not-allowed}.fine-tune-modal .error-message{display:flex;align-items:center;gap:8px;margin-top:12px;padding:10px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#f87171;font-size:.85rem}.fine-tune-modal .main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:16px;gap:16px}.fine-tune-modal .map-section{flex:1;min-height:300px;border-radius:8px;overflow:hidden;background:#0f0f1a;transition:all .3s ease}.fine-tune-modal .main-area:has(.pip-section.expanded) .map-section{flex:0 0 auto;height:250px;min-height:250px}.fine-tune-modal .pip-section{height:200px;background:#16162a;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:all .3s ease}.fine-tune-modal .pip-section.expanded{flex:1;height:auto;min-height:400px}.fine-tune-modal .pip-section.expanded .pip-container{flex:1;display:flex;align-items:center;justify-content:center;background:#000}.fine-tune-modal .pip-section.expanded .pip-feed-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.fine-tune-modal .pip-section.expanded .pip-feed-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.fine-tune-modal .pip-header{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#1a1a2e;border-bottom:1px solid #2a2a4a;font-size:.85rem;font-weight:500;color:#ccc}.fine-tune-modal .pip-collapse-btn{margin-left:auto;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:4px;color:#999;font-size:.9rem;cursor:pointer;transition:all .2s}.fine-tune-modal .pip-collapse-btn:hover{background:#fff3;color:#fff}.fine-tune-modal .pip-icon{font-size:1.1rem}.fine-tune-modal .pip-container{flex:1;position:relative;overflow:hidden}.fine-tune-modal .pip-feed-wrapper{position:relative;width:100%;height:100%}.fine-tune-modal .pip-feed-image{width:100%;height:100%;object-fit:contain;background:#000}.fine-tune-modal .pip-crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.fine-tune-modal .pip-crosshair .crosshair-h,.fine-tune-modal .pip-crosshair .crosshair-v{position:absolute;background:#3b82f6cc}.fine-tune-modal .pip-crosshair .crosshair-h{width:40px;height:2px;left:-20px;top:-1px}.fine-tune-modal .pip-crosshair .crosshair-v{width:2px;height:40px;left:-1px;top:-20px}.fine-tune-modal .pip-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666;gap:8px}.fine-tune-modal .pip-placeholder .icon{font-size:2rem}.fine-tune-modal .stream-resolution-warning{position:absolute;top:12px;left:50%;transform:translate(-50%);background:#f59e0be6;color:#1a1a2e;padding:8px 16px;border-radius:6px;font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:8px;z-index:20;box-shadow:0 2px 8px #0000004d}.fine-tune-modal .stream-resolution-warning .warning-icon{font-size:1rem}.fine-tune-modal .pip-instructions{padding:12px 16px;background:#3b82f61a;border-top:1px solid rgba(59,130,246,.2);font-size:.85rem;color:#8bb4f0}.fine-tune-modal .pip-instructions p{margin:0}.fine-tune-modal .pip-instructions .success{color:#4ade80}.camera-map-view{position:relative;width:100%;height:500px;min-height:400px;background:#0f1420;border-radius:8px;overflow:hidden}.section-map-expanded .camera-map-view{height:calc(100vh - 350px);min-height:600px}.camera-map-view .floor-selector{position:absolute;top:12px;left:12px;z-index:10;display:flex;align-items:center;gap:8px;padding:8px 12px;background:#16162af2;border:1px solid #2a2a4a;border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.camera-map-view .floor-selector label{font-size:.85rem;color:#999;font-weight:500}.camera-map-view .floor-selector select{padding:6px 28px 6px 10px;background:#ffffff0d;border:1px solid #3a3a5a;border-radius:4px;color:#fff;font-size:.85rem;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23999'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;background-size:14px}.camera-map-view .floor-selector select:hover{border-color:#4a4a6a}.camera-map-view .floor-selector select:focus{outline:none;border-color:#3b82f6}.camera-map-view .camera-count-badge{position:absolute;top:12px;right:12px;z-index:10;display:flex;align-items:center;gap:6px;padding:8px 12px;background:#16162af2;border:1px solid #2a2a4a;border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.camera-map-view .camera-count-badge .count{font-size:1.1rem;font-weight:600;color:#3b82f6}.camera-map-view .camera-count-badge .label{font-size:.8rem;color:#999}.camera-map-view .map-container{width:100%;height:100%}.camera-map-view .map-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;color:#999}.camera-map-view .map-loading .loading-spinner{width:40px;height:40px;border:3px solid rgba(59,130,246,.2);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.camera-map-view .map-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;color:#ef4444;text-align:center}.camera-map-view .map-error .error-icon{font-size:2rem}.camera-map-view .no-cameras-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:#666;text-align:center;z-index:5}.camera-map-view .no-cameras-overlay .icon{font-size:3rem;opacity:.5}.camera-map-view .no-cameras-overlay p{margin:0;font-size:1rem}.camera-map-view .no-cameras-overlay .hint{font-size:.85rem;color:#555}.camera-map-marker{display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .15s ease;pointer-events:auto!important}.camera-map-marker:hover{transform:scale(1.1)}.camera-map-marker.active{transform:scale(1.15)}.camera-map-marker .marker-camera-icon{position:relative;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#000000b3;border-radius:50%;border:2px solid currentColor;box-shadow:0 2px 8px #00000080}.camera-map-marker .marker-camera-icon svg{display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.camera-map-marker .status-dot{position:absolute;top:-2px;right:-2px;width:10px;height:10px;border-radius:50%;border:2px solid rgba(0,0,0,.7);box-shadow:0 1px 3px #0000004d}.camera-map-marker .marker-label{margin-top:6px;padding:3px 10px;background:#000000d9;border-radius:4px;font-size:11px;color:#fff;white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis;font-weight:500;box-shadow:0 2px 4px #0000004d}.popover-portal-root{pointer-events:auto}.speech-bubble-popover{position:absolute;bottom:100%;left:50%;transform:translate(-50%);width:320px;margin-bottom:14px;display:flex;flex-direction:column;background:#1e1e2e;border:1px solid #2a2a4a;border-radius:12px;box-shadow:0 20px 40px #0009;pointer-events:auto;z-index:1000;animation:popIn .2s cubic-bezier(.175,.885,.32,1.275);transform-origin:bottom center}.speech-bubble-popover:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:8px;border-style:solid;border-color:#1e1e2e transparent transparent transparent}.speech-bubble-popover:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:9px;border-style:solid;border-color:#2a2a4a transparent transparent transparent}.speech-bubble-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #2a2a4a;background:#ffffff08;border-radius:12px 12px 0 0}.speech-bubble-header .camera-info{display:flex;align-items:center;gap:8px}.speech-bubble-header .camera-title{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.speech-bubble-header .status-dot{width:8px;height:8px;background:#10b981;border-radius:50%;box-shadow:0 0 8px #10b98166}.speech-bubble-header .header-actions{display:flex;gap:4px}.speech-bubble-header .icon-btn{background:transparent;border:none;color:#94a3b8;padding:4px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.speech-bubble-header .icon-btn:hover{background:#ffffff1a;color:#fff}.speech-bubble-body{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:0 0 12px 12px;overflow:hidden}@keyframes popIn{0%{opacity:0;transform:translate(-50%) scale(.9) translateY(10px)}to{opacity:1;transform:translate(-50%) scale(1) translateY(0)}}.processor-list{display:flex;flex-direction:column;gap:16px}.processor-card{background:#1a1f2e;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;transition:all .2s ease}.processor-card:hover{border-color:#fff3;box-shadow:0 4px 20px #0000004d}.processor-card.offline{opacity:.5;border-color:#ef44444d}.processor-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.processor-header h3{margin:0 0 6px;color:#fff;font-size:1.1rem;font-weight:600}.processor-id{font-size:.8rem;color:#94a3b8cc;margin:0;font-family:ui-monospace,monospace}.status-indicator{font-size:1.2rem;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff0d;border-radius:8px}.processor-stats{margin-bottom:16px}.stat-item{display:flex;justify-content:space-between;margin-bottom:10px}.stat-label{font-weight:500;color:#94a3b8e6;font-size:.875rem}.stat-value{color:#fff;font-weight:600;font-size:.875rem}.load-bar{width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.load-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:3px;transition:width .3s ease}.load-fill-offline{position:absolute;right:0;height:100%;background:linear-gradient(90deg,#ef4444,#dc2626);border-radius:3px;transition:width .3s ease}.load-bar{position:relative}.camera-status-breakdown{font-size:.75rem;font-weight:400;color:#94a3b8e6}.camera-status-breakdown .status-online{color:#22c55e}.camera-status-breakdown .status-offline{color:#ef4444}.camera-status-breakdown .status-unknown{color:#94a3b8b3}.capabilities{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}.capabilities-label{font-size:.8rem;font-weight:500;color:#94a3b8cc;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.capability-tags{display:flex;flex-wrap:wrap;gap:8px}.capability-tag{padding:6px 12px;background:#6366f126;color:#a5b4fc;border:1px solid rgba(99,102,241,.3);border-radius:6px;font-size:.75rem;font-weight:500;transition:all .2s}.capability-tag:hover{background:#6366f140;border-color:#6366f180}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dialog-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #e0e0e0}.dialog-header h2{margin:0;color:#333;font-size:1.4rem}.close-btn{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.close-btn:hover{background:#f0f0f0}.dialog-body{padding:25px;overflow-y:auto}.camera-preview{display:flex;gap:15px;margin-bottom:25px;padding:15px;background:#f8f9fa;border-radius:8px}.camera-preview img{width:120px;height:90px;object-fit:cover;border-radius:6px}.camera-details h3{margin:0 0 8px;color:#333}.camera-details p{margin:0;color:#666;font-size:.9rem;font-family:monospace}.no-processors{text-align:center;padding:40px 20px}.no-processors p{margin:10px 0;color:#666}.no-processors .hint{font-size:.9rem;color:#999}form label{display:block;margin-bottom:12px;font-weight:600;color:#333}.processor-options{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.processor-option{padding:15px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease}.processor-option:hover{border-color:#667eea;background:#f8f9ff}.processor-option.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a)}.processor-option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.processor-name{font-weight:600;color:#333}.processor-load{font-size:.9rem;color:#666;font-family:monospace}.processor-option-details{display:flex;justify-content:space-between;align-items:center}.processor-id{font-size:.85rem;color:#999;font-family:monospace}.mini-tags{display:flex;gap:5px}.mini-tag{padding:2px 8px;background:#667eea;color:#fff;border-radius:10px;font-size:.7rem}.dialog-actions{display:flex;gap:10px;justify-content:flex-end}.btn-cancel,.btn-submit{padding:10px 24px;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel{background:#e0e0e0;color:#333}.btn-cancel:hover{background:#d0d0d0}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-submit:hover:not(:disabled){transform:scale(1.02);box-shadow:0 2px 8px #667eea66}.btn-submit:disabled{background:#ccc;cursor:not-allowed}.app{max-width:1600px;margin:0 auto}.readonly-banner{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:8px;margin-bottom:12px}.readonly-banner-icon{font-size:14px;flex-shrink:0}.readonly-banner-message{font-size:13px;color:#f59e0b}.app-topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 0;margin-bottom:16px;border-bottom:1px solid rgb(30 41 59)}.app-topbar h1{color:#fff;font-size:1.5rem;margin:0;font-weight:600}.topbar-right{display:flex;align-items:center;gap:12px}.stats-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.stat{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#1a1f2e;border:1px solid rgb(51 65 85);border-radius:8px;color:#fff;min-width:140px;transition:border-color .2s}.stat:hover{border-color:#475569}.stat-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#6366f11a;border-radius:8px;font-size:18px;flex-shrink:0}.stat-content{display:flex;flex-direction:column;min-width:0}.stat-value{font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:4px;color:#fff}.stat-label{font-size:.875rem;color:#94a3b8}.venue-stat{min-width:200px}.venue-stat .stat-content{flex:1}.venue-name-value{font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;color:#fff}.refresh-controls{min-width:auto;margin-left:auto}.refresh-controls.stat{padding:8px 12px}.refresh-icon{animation:spin 2s linear infinite}.refresh-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#6366f126;border:1px solid rgba(99,102,241,.3);color:#a5b4fc;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.refresh-button:hover{background:#6366f140;border-color:#6366f1;transform:translateY(-1px)}.refresh-button:active{transform:translateY(0)}.btn-change-venue,.btn-sign-out{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-change-venue{background:#6366f11a;color:#a5b4fc;border:1px solid transparent}.btn-change-venue:hover{background:#6366f133;border-color:#6366f1}.btn-sign-out{background:transparent;color:#94a3b8;border:none;padding:8px;display:flex;align-items:center;justify-content:center}.btn-sign-out:hover{background:#ffffff0d;color:#fff}.venue-info{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffff08;border-radius:6px;border:1px solid rgb(51 65 85)}.venue-label{font-size:14px;color:#94a3b8;font-weight:500}.venue-info .venue-name{font-size:14px;color:#fff;font-weight:600}.content{display:grid;grid-template-columns:2fr 1fr;gap:30px}.section{background:#0f1420;border-radius:12px;padding:25px;box-shadow:0 4px 6px #0000004d;border:1px solid rgb(30 41 59)}.section h2{color:#fff;margin-bottom:20px;font-size:1.5rem}.content.map-view-expanded{grid-template-columns:1fr}.section.section-map-expanded{min-height:600px}.section-header{display:flex;align-items:center;justify-content:flex-start;gap:12px;margin-bottom:20px}.section-header h2{margin-bottom:0;margin-right:0}.view-toggle{display:flex;gap:4px;background:#ffffff0d;padding:4px;border-radius:8px;margin-left:0}.toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:none;background:transparent;color:#888;cursor:pointer;border-radius:6px;font-size:.85rem;font-weight:500;transition:all .2s}.toggle-btn:hover{color:#ccc;background:#ffffff0d}.toggle-btn.active{background:#6366f1;color:#fff}.toggle-btn svg{flex-shrink:0}@media (max-width: 1024px){.content{grid-template-columns:1fr}}.no-venue-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;color:#94a3b8}.no-venue-icon{font-size:64px;margin-bottom:16px;opacity:.5}.no-venue-container h2{color:#fff;margin-bottom:8px}.no-venue-container p{font-size:14px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;color:#94a3b8}.loading-spinner{width:48px;height:48px;border:3px solid rgb(51 65 85);border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;color:#f87171}.retry-button{margin-top:16px;padding:10px 20px;background:#6366f133;border:1px solid rgb(99 102 241);color:#a5b4fc;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.retry-button:hover{background:#6366f14d}.error-banner{display:flex;align-items:center;gap:12px;padding:10px 16px;margin-bottom:16px;background:#ef444426;border:1px solid rgba(239,68,68,.4);border-radius:8px;color:#f87171;font-size:14px}.error-banner-icon{flex-shrink:0}.error-banner-message{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-banner-retry{padding:4px 12px;background:#6366f133;border:1px solid rgb(99 102 241);color:#a5b4fc;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;flex-shrink:0}.error-banner-retry:hover{background:#6366f14d}.error-banner-dismiss{padding:4px 8px;background:transparent;border:none;color:#94a3b8;font-size:14px;cursor:pointer;transition:color .2s;flex-shrink:0}.error-banner-dismiss:hover{color:#f87171}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0b0f19;min-height:100vh;color:#fff}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;padding:20px;background:#0b0f19}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:80vh;color:#94a3b8}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.1);border-top:4px solid rgb(99,102,241);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:80vh;color:#ef4444;text-align:center;padding:20px}.retry-button{margin-top:16px;background:#6366f11a;border:1px solid rgba(99,102,241,.3);color:#fff;padding:10px 20px;border-radius:8px;cursor:pointer;transition:all .2s}.retry-button:hover{background:#6366f133;border-color:#6366f180}.no-venue-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:80vh;color:#94a3b8;text-align:center;padding:20px}.user-stat{margin-left:auto}
