/*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-border-style:solid}}}.container{width:100%}.block{display:block}.flex{display:flex}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}body{color:#333;background-color:#f4f7f6;margin:0;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.container{background-color:#fff;border-radius:8px;max-width:1200px;margin:0 auto;padding:20px;box-shadow:0 2px 10px #0000001a}h1{color:#2c3e50;text-align:center}form,h1{margin-bottom:30px}form{justify-content:center;gap:10px;width:100%;max-width:1200px;margin-left:auto;margin-right:auto;display:flex}input[type=text]{max-width:200px}input[type=text],input[type=url]{border:1px solid #ddd;border-radius:4px;flex-grow:1;padding:10px}input[type=url]{max-width:500px}button{color:#fff;cursor:pointer;background-color:#3498db;border:none;border-radius:4px;padding:10px 15px;transition:background-color .2s}button:hover{background-color:#2980b9}button:disabled{cursor:not-allowed;background-color:#ccc}h2{color:#2c3e50;text-align:center;margin-top:40px;margin-bottom:20px}ul{padding:0;list-style:none}li{background-color:#ecf0f1;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:10px;padding:15px;display:flex;box-shadow:0 1px 3px #0000000d}li.initializing{color:#856404;background-color:#fff3cd;border:1px solid #ffeeba}li button{margin-left:10px;padding:8px 12px;font-size:.9em}.video-player-container{text-align:center;margin-top:40px}video{background-color:#000;border:1px solid #ddd;border-radius:8px;width:100%;max-width:640px;height:auto}.video-controls{justify-content:center;gap:10px;margin-top:10px;display:flex}.video-controls button{padding:8px 12px;font-size:.9em}.modal-overlay{background-color:#000000b3}.modal-content{text-align:center;background-color:#fff;width:900px;max-width:90%;padding:30px;box-shadow:0 4px 20px #0003}.video-modal-content{width:700px}.modal-content h2{color:#2c3e50;margin-top:0}.modal-content textarea{white-space:pre;overflow-wrap:normal;border:1px solid #ddd;border-radius:4px;height:400px;padding:10px;font-family:monospace;overflow-x:auto}.modal-buttons{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.modal-buttons button{cursor:pointer;border-radius:4px;padding:10px 15px;transition:background-color .2s}.modal-buttons button:first-child{color:#fff;background-color:#28a745}.modal-buttons button:first-child:hover{background-color:#218838}.modal-buttons button:nth-child(2){color:#fff;background-color:#007bff}.modal-buttons button:nth-child(2):hover{background-color:#0056b3}.modal-buttons button:nth-child(3){color:#000;background-color:#ffc107}.modal-buttons button:nth-child(3):hover{background-color:#e0a800}.modal-buttons button:nth-child(4){color:#fff;background-color:#17a2b8}.modal-buttons button:nth-child(4):hover{background-color:#138496}.modal-buttons button:nth-child(5){color:#fff;background-color:#6c757d}.modal-buttons button:nth-child(5):hover{background-color:#5a6268}.modal-buttons button:nth-child(6){color:#fff;background-color:#e74c3c}.modal-buttons button:nth-child(6):hover{background-color:#c0392b}.cameras-table{border-collapse:collapse;background-color:#fff;border-radius:8px;width:100%;max-width:1200px;margin:20px auto 0;overflow:hidden;box-shadow:0 2px 10px #0000001a}.cameras-table td,.cameras-table th{text-align:left;border-bottom:1px solid #e0e0e0;padding:12px 15px}.cameras-table td:first-child,.cameras-table th:first-child{text-align:center;width:100px}.cameras-table td:nth-child(2),.cameras-table th:nth-child(2){width:200px}.cameras-table td:nth-child(3),.cameras-table th:nth-child(3){width:300px;font-family:monospace;font-size:14px}.cameras-table td:nth-child(4),.cameras-table th:nth-child(4){width:auto}.cameras-table th{color:#333;text-transform:uppercase;font-size:14px;font-weight:600}.cameras-table th,.cameras-table tr:hover{background-color:#f8f9fa}.cameras-table tr.initializing{background-color:#fff3cd}.cameras-table tr.initializing:hover{background-color:#ffeaa7}.status{text-transform:uppercase;border-radius:12px;align-items:center;gap:6px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-flex}.status.ready{color:#155724;background-color:#d4edda}.status.initializing{color:#856404;background-color:#fff3cd}.status.error{color:#721c24;background-color:#f8d7da}.status.inactive{color:#6c757d;background-color:#e9ecef}.spinner{border:2px solid #f3f3f3;border-top-color:#856404;width:14px;height:14px;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.cameras-table td button{cursor:pointer;border:none;border-radius:4px;margin-right:5px;padding:6px 12px;font-size:12px;transition:background-color .2s}.cameras-table td button:disabled{color:#6c757d;cursor:not-allowed;background-color:#e9ecef}.camera-name{align-items:center;display:flex}.status-badge{text-transform:uppercase;border-radius:12px;padding:4px 8px;font-size:12px;font-weight:600}.status-badge.active{color:#155724;background-color:#d4edda}.status-badge.initializing{color:#856404;background-color:#fff3cd}.status-badge.error{color:#721c24;background-color:#f8d7da}.url-container{align-items:center;gap:12px;width:100%;display:flex}.masked-url{color:#666;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-family:monospace;font-size:14px;overflow:hidden}.copy-btn{background-color:#6c757d;border-radius:4px;flex-shrink:0;min-width:50px;padding:6px 12px;font-size:12px;transition:background-color .2s}.copy-btn:hover:not(:disabled){background-color:#5a6268}.copy-btn:disabled{color:#6c757d;cursor:not-allowed;background-color:#e9ecef}.action-buttons{gap:8px}.action-buttons button{border-radius:4px;padding:6px 12px;font-size:12px;transition:background-color .2s}.restart-btn{color:#000;background-color:#ffc107}.restart-btn:hover{background-color:#e0a800}.play-btn{color:#fff;background-color:#28a745}.play-btn:hover:not(:disabled){background-color:#218838}.embed-btn{color:#fff;background-color:#17a2b8}.embed-btn:hover:not(:disabled){background-color:#138496}.start-btn{color:#fff;background-color:#28a745}.start-btn:hover:not(:disabled){background-color:#218838}.stop-btn{color:#212529;background-color:#ffc107}.stop-btn:hover:not(:disabled){background-color:#e0a800}.delete-btn{color:#fff;background-color:#dc3545}.delete-btn:hover{background-color:#c82333}.action-buttons button:disabled{color:#6c757d;cursor:not-allowed;background-color:#e9ecef}.import-export-buttons{justify-content:center;gap:10px;max-width:1200px;margin:20px auto;display:flex}.export-btn{color:#fff;cursor:pointer;background-color:#17a2b8;border:none;border-radius:5px;padding:10px 20px;font-size:14px;transition:background-color .3s}.export-btn:hover{background-color:#138496}.import-btn{color:#fff;cursor:pointer;background-color:#6f42c1;border:none;border-radius:5px;padding:10px 20px;font-size:14px;transition:background-color .3s;display:inline-block}.import-btn:hover{background-color:#5a3691}.import-info{background-color:#f8f9fa;border-radius:5px;margin:15px 0;padding:15px}.import-cameras-list{border:1px solid #dee2e6;border-radius:5px;max-height:300px;margin:15px 0;padding:10px;overflow-y:auto}.import-cameras-list ul{margin:0;padding:0;list-style:none}.import-cameras-list li{border-bottom:1px solid #e9ecef;padding:8px 0}.import-cameras-list li:last-child{border-bottom:none}.import-options{background-color:#f8f9fa;border-radius:5px;margin:15px 0;padding:15px}.checkbox-label{cursor:pointer;align-items:center;gap:8px;display:flex}.checkbox-label input[type=checkbox]{margin:0}.import-progress{text-align:center;background-color:#f8f9fa;border-radius:5px;margin-top:20px;padding:20px}.spinner{border:3px solid #f3f3f3;border-top-color:#007bff;width:30px;height:30px;margin:0 auto 10px}.modal{z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal.password-modal{z-index:1100}.modal-header{border-bottom:2px solid #f0f0f0;padding-bottom:15px}.close-btn{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:50%;justify-content:center;align-items:center;width:35px;height:35px;font-size:20px;transition:all .3s;display:flex}.close-btn:hover{background:#c0392b;transform:scale(1.1)}.video-modal{z-index:1000;background-color:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.video-modal-content{background-color:#fff;border-radius:12px;max-width:90%;max-height:90%;padding:20px;box-shadow:0 10px 30px #0000004d}.video-header{justify-content:space-between;align-items:center;margin-bottom:15px;display:flex}.video-header h3{color:#2c3e50;margin:0;font-size:1.3em}.embed-tabs{border-bottom:2px solid #f0f0f0;margin-bottom:20px;display:flex}.tab-button{cursor:pointer;color:#6c757d;background:0 0;border:none;border-bottom:3px solid #0000;border-radius:0;flex:1;padding:12px 20px;font-size:14px;font-weight:500;transition:all .3s}.tab-button:hover{color:#495057;background-color:#f8f9fa}.tab-button.active{color:#3498db;background-color:#f8f9fa;border-bottom-color:#3498db}.modal-actions{justify-content:center;gap:12px;margin-top:20px;display:flex}.copy-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .3s;box-shadow:0 4px 15px #28a7454d}.copy-btn:hover{background:linear-gradient(135deg,#218838,#1ba88a);transform:translateY(-2px);box-shadow:0 6px 20px #28a74566}.save-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .3s;box-shadow:0 4px 15px #007bff4d}.save-btn:hover{background:linear-gradient(135deg,#0056b3,#004085);transform:translateY(-2px);box-shadow:0 6px 20px #007bff66}.close-btn-modal{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6c757d,#5a6268);border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .3s;box-shadow:0 4px 15px #6c757d4d}.close-btn-modal:hover{background:linear-gradient(135deg,#5a6268,#495057);transform:translateY(-2px);box-shadow:0 6px 20px #6c757d66}.modal-content textarea{resize:vertical;color:#495057;background-color:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;width:calc(100% - 20px);height:350px;margin-bottom:20px;padding:15px;font-family:Courier New,monospace;font-size:13px;line-height:1.5;transition:border-color .3s}.modal-content textarea:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 3px #3498db1a}@media (max-width:768px){.cameras-table{font-size:14px}.cameras-table td,.cameras-table th{padding:8px 10px}.action-buttons{flex-direction:column;gap:4px}.action-buttons button{text-align:center;width:100%}.modal-content{max-width:calc(100% - 40px);margin:20px}.modal-actions{flex-direction:column;gap:8px}.close-btn-modal,.copy-btn{width:100%}.embed-tabs{flex-direction:column}.tab-button{border-bottom:1px solid #dee2e6}.tab-button.active{border-bottom-color:#3498db}}.timelapse-modal{color:#2c3e50;background-color:#fff;width:1200px;max-width:95vw;height:800px;max-height:95vh;overflow-y:auto}.timelapse-modal .modal-header{background-color:#f8f9fa;border-bottom:2px solid #e9ecef;border-radius:12px 12px 0 0;margin:-20px -20px 20px;padding:15px 20px}.timelapse-modal .close-btn{color:#fff;background:#ef4444;font-size:18px;font-weight:700}.timelapse-modal .close-btn:hover{background:#dc2626}.slider{appearance:none;background:#4b5563;outline:none}.slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#3b82f6;border-radius:50%;width:20px;height:20px}.slider::-moz-range-thumb{cursor:pointer;background:#3b82f6;border:none;border-radius:50%;width:20px;height:20px}.cameras-table button[onclick*=openTimelapsePanel]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:6px;padding:8px 12px;font-size:12px;font-weight:500;transition:all .3s;box-shadow:0 2px 8px #8b5cf64d}.cameras-table button[onclick*=openTimelapsePanel]:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.frame-thumbnail{border-radius:4px;transition:all .2s;overflow:hidden}.frame-thumbnail:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.frame-thumbnail.selected{box-shadow:0 0 0 3px #3b82f6}.playback-controls{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;justify-content:center;align-items:center;gap:16px;margin:16px 0;padding:16px;display:flex}.playback-controls button{color:#fff;cursor:pointer;background:#3498db;border:none;border-radius:6px;min-width:80px;padding:10px 20px;font-weight:500;transition:all .2s}.playback-controls button:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.playback-controls button:disabled{opacity:.5;cursor:not-allowed;background:#bdc3c7}.playback-controls select{color:#2c3e50;background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:8px 12px;font-size:14px}.date-range-inputs{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;flex-wrap:wrap;align-items:end;gap:20px;margin:16px 0;padding:16px;display:flex}.date-range-inputs>div{flex-direction:column;gap:6px;display:flex}.date-range-inputs label{color:#2c3e50;font-size:14px;font-weight:500}.date-range-inputs input[type=date]{color:#2c3e50;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:8px 12px}.date-range-inputs button{color:#fff;cursor:pointer;background:#27ae60;border:none;border-radius:6px;padding:10px 20px;font-weight:500;transition:all .2s}.date-range-inputs button:hover{background:#229954;transform:translateY(-1px)}.clip-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;margin-bottom:12px;padding:16px;transition:all .2s}.clip-card:hover{border-color:#3498db;transform:translateY(-2px);box-shadow:0 4px 12px #3498db1a}.clip-card h5{color:#2c3e50;margin:0 0 8px;font-weight:600}.clip-card p{color:#5a6c7d;margin:4px 0;font-size:14px}.clip-card a{color:#fff;background:#3498db;border-radius:4px;margin-top:8px;padding:8px 16px;font-size:14px;text-decoration:none;transition:background .2s;display:inline-block}.clip-card a:hover{background:#2980b9}.timelapse-loading{color:#5a6c7d;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.spinner{border:4px solid #e9ecef;border-top-color:#3498db;border-radius:50%;width:40px;height:40px;margin-bottom:16px;animation:spin 1s linear infinite}.timelapse-error{color:#fca5a5;background:#7f1d1d;border:1px solid #b91c1c;border-radius:6px;margin-bottom:16px;padding:12px}@media (max-width:1024px){.timelapse-modal{width:90vw;height:90vh}}@media (max-width:768px){.date-range-inputs{flex-direction:column;align-items:stretch}.playback-controls{flex-wrap:wrap;gap:8px}.frame-thumbnails{grid-template-columns:repeat(3,1fr)!important}}.timelapse-intro{color:#fff;text-align:center;background:linear-gradient(135deg,#3498db,#2c3e50);border-radius:8px;margin-bottom:24px;padding:24px}.timelapse-intro h2{margin:0 0 12px;font-size:24px;font-weight:600}.timelapse-intro p{opacity:.9;margin:8px 0;font-size:16px;line-height:1.5}.timelapse-intro .features{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:20px;display:grid}.timelapse-intro .feature{text-align:left;background:#ffffff1a;border-radius:6px;padding:16px}.timelapse-intro .feature-icon{margin-bottom:8px;font-size:24px;display:block}.timelapse-intro .feature h4{margin:0 0 6px;font-size:16px}.timelapse-intro .feature p{opacity:.8;margin:0;font-size:14px}.timelapse-tabs{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:24px;padding:4px;display:flex}.timelapse-tab{cursor:pointer;color:#5a6c7d;background:0 0;border:none;border-radius:6px;flex:1;padding:12px 20px;font-size:16px;font-weight:500;transition:all .2s}.timelapse-tab:hover{color:#2c3e50;background:#e9ecef}.timelapse-tab.active{color:#fff;background:#3498db;box-shadow:0 2px 8px #3498db4d}.timelapse-settings{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px}.timelapse-settings h3{color:#2c3e50;margin:0 0 20px;font-size:20px}.setting-group{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-bottom:20px;padding:16px}.setting-group label{color:#2c3e50;margin-bottom:8px;font-weight:500;display:block}.setting-group input,.setting-group select{color:#2c3e50;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;max-width:300px;padding:10px 12px;font-size:14px}.setting-group .help-text{color:#5a6c7d;margin-top:4px;font-size:12px;line-height:1.4}.toggle-switch{width:60px;height:34px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:#ccc;border-radius:34px;transition:all .4s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:26px;height:26px;transition:all .4s;position:absolute;bottom:4px;left:4px}.toggle-switch input:checked+.toggle-slider{background-color:#3498db}.toggle-switch input:checked+.toggle-slider:before{transform:translate(26px)}.message{border-radius:6px;margin-bottom:16px;padding:12px 16px;font-weight:500}.message.success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.message.error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}.message.info{color:#0c5460;background:#d1ecf1;border:1px solid #bee5eb}.frame-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin:16px 0;display:grid}.frame-item{cursor:pointer;border:2px solid #0000;border-radius:6px;transition:all .2s;position:relative;overflow:hidden}.frame-item:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000026}.frame-item.selected{border-width:4px;border-color:#e74c3c;box-shadow:0 0 0 2px #e74c3c66}.frame-item img{object-fit:cover;width:100%;height:100px}.frame-timestamp{color:#fff;text-align:center;background:linear-gradient(#0000,#000000b3);padding:8px 6px 4px;font-size:11px;position:absolute;bottom:0;left:0;right:0}.main-video-display{text-align:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;min-height:300px;margin:16px 0;padding:16px;display:flex}.main-video-display img{border-radius:6px;max-width:100%;max-height:400px;box-shadow:0 4px 12px #0000001a}.main-video-display .placeholder{color:#5a6c7d;font-size:16px}.action-buttons{flex-wrap:wrap;justify-content:center;gap:12px;margin:20px 0;display:flex}.action-buttons button{cursor:pointer;border:none;border-radius:6px;min-width:120px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{color:#fff;background:#3498db}.btn-primary:hover{background:#2980b9;transform:translateY(-1px)}.btn-success{color:#fff;background:#27ae60}.btn-success:hover{background:#229954;transform:translateY(-1px)}.btn-secondary{color:#fff;background:#95a5a6}.btn-secondary:hover{background:#7f8c8d;transform:translateY(-1px)}.btn-danger{color:#fff;background:#e74c3c}.btn-danger:hover{background:#c0392b;transform:translateY(-1px)}.pagination{background:#f8f9fa;border-radius:8px;gap:12px;margin:20px 0;padding:16px}.modal-overlay,.pagination{justify-content:center;align-items:center;display:flex}.modal-overlay{z-index:1000;background:#00000080;position:fixed;inset:0}.modal-content{background:#fff;border-radius:8px;max-width:90vw;max-height:90vh;overflow:auto;box-shadow:0 10px 25px #0000004d}.modal-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;margin-bottom:20px;padding:20px 24px 0;display:flex}.modal-header h3{color:#2c3e50;margin:0;font-size:18px}.modal-close{cursor:pointer;color:#999;background:0 0;border:none;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:24px;display:flex}.modal-close:hover{color:#666}.modal-body{padding:0 24px 24px}.confirm-modal{text-align:center;min-width:400px}.confirm-icon{margin-bottom:16px;font-size:48px}.confirm-message{color:#5a6c7d;margin-bottom:24px;font-size:16px;line-height:1.5}.confirm-actions{justify-content:center;gap:12px;display:flex}.alert-modal{text-align:center;min-width:350px}.alert-icon{margin-bottom:16px;font-size:48px}.alert-message{color:#5a6c7d;margin-bottom:24px;font-size:16px;line-height:1.5}.alert-actions{justify-content:center;display:flex}.btn-unified{text-align:center;cursor:pointer;box-sizing:border-box;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;gap:4px;min-width:100px;height:32px;line-height:1;transition:all .2s;padding:8px 16px!important;font-size:12px!important;display:inline-flex!important}a.btn-unified{color:inherit;vertical-align:top}a.btn-unified,a.btn-unified:hover{text-decoration:none}.btn-primary.btn-unified{color:#fff;background:#3498db;border-color:#3498db}.btn-primary.btn-unified:hover{background:#2980b9;border-color:#2980b9}.btn-secondary.btn-unified{color:#fff;background:#6c757d;border-color:#6c757d}.btn-secondary.btn-unified:hover{background:#5a6268;border-color:#5a6268}.btn-danger.btn-unified{color:#fff;background:#e74c3c;border-color:#e74c3c}.btn-danger.btn-unified:hover{background:#c0392b;border-color:#c0392b}.btn-success.btn-unified{color:#fff;background:#27ae60;border-color:#27ae60}.btn-success.btn-unified:hover{background:#229954;border-color:#229954}.btn-warning.btn-unified{color:#fff;background:#f39c12;border-color:#f39c12}.btn-warning.btn-unified:hover{background:#e67e22;border-color:#e67e22}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}