:root{--bg-primary:#f4f7f6;--bg-secondary:#fff;--bg-tertiary:#f0f0f0;--bg-quaternary:#e1e1e1;--text-primary:#333;--text-secondary:#555;--text-tertiary:#777;--text-quaternary:#aaa;--sidebar-bg:#2c3e50;--sidebar-text:#ecf0f1;--sidebar-border:#34495e;--sidebar-hover:#34495e;--sidebar-secondary-text:#bdc3c7;--accent-primary:#3498db;--accent-primary-hover:#2980b9;--accent-secondary:#27ae60;--accent-secondary-hover:#229954;--danger:#e74c3c;--danger-hover:#c0392b;--border-color:#e1e1e1;--border-dark:#ccc;--shadow-light:#0000001a;--shadow-medium:#00000026;--card-bg:#fff;--card-seen-bg:#eef6fd;--card-seen-border:#3498db;--card-seen-text:#1f4f78;--card-selected-border:#2c3e50;--card-selected-shadow:#2c3e5038;--card-selected-shadow-dark:#2c3e5059;--media-viewer-bg:#f4f7f6;--media-info-bg:#fff;--media-container-bg:#111;--chip-bg:#eef6fd;--chip-text:#1f4f78;--chip-border:#3498db;--chip-unviewed-bg:#f8f9fa;--chip-unviewed-text:#6c757d;--chip-unviewed-border:#dee2e6;--chip-viewed-bg:#d4edda;--chip-viewed-text:#155724;--chip-viewed-border:#28a745;--input-bg:#2c3e50;--input-text:#ecf0f1;--input-border:#34495e;--label-bg:#f0f0f0;--login-bg:#ecf0f1;--popup-bg:#fff;--popup-overlay:#00000080}.dark-mode{--bg-primary:#1a1a1a;--bg-secondary:#242424;--bg-tertiary:#2d2d2d;--bg-quaternary:#383838;--text-primary:#e0e0e0;--text-secondary:#b8b8b8;--text-tertiary:#9a9a9a;--text-quaternary:#707070;--sidebar-bg:#1c2833;--sidebar-text:#ecf0f1;--sidebar-border:#243342;--sidebar-hover:#2c3e50;--sidebar-secondary-text:#95a5a6;--accent-primary:#3498db;--accent-primary-hover:#5dade2;--accent-secondary:#27ae60;--accent-secondary-hover:#2ecc71;--danger:#e74c3c;--danger-hover:#ec7063;--border-color:#3a3a3a;--border-dark:#4a4a4a;--shadow-light:#0000004d;--shadow-medium:#0006;--card-bg:#2a2a2a;--card-seen-bg:#1e2f3f;--card-seen-border:#3498db;--card-seen-text:#5dade2;--card-selected-border:#4dd0e1;--card-selected-shadow:#4dd0e166;--card-selected-shadow-dark:#4dd0e199;--media-viewer-bg:#1a1a1a;--media-info-bg:#242424;--media-container-bg:#000;--chip-bg:#1e2f3f;--chip-text:#5dade2;--chip-border:#3498db;--chip-unviewed-bg:#2d2d2d;--chip-unviewed-text:#9a9a9a;--chip-unviewed-border:#4a4a4a;--chip-viewed-bg:#1e3a2b;--chip-viewed-text:#27ae60;--chip-viewed-border:#27ae60;--input-bg:#1c2833;--input-text:#ecf0f1;--input-border:#243342;--label-bg:#2d2d2d;--login-bg:#1a1a1a;--popup-bg:#2a2a2a;--popup-overlay:#000000b3}.timeline-pulldown{align-items:center;background:#f0f0f0;background:var(--bg-tertiary);border:none;border-bottom:1px solid #ccc;border-bottom:1px solid var(--border-dark);border-radius:8px;box-sizing:border-box;color:#333;color:var(--text-primary);cursor:pointer;display:flex;font-size:1.7vh;font-size:min(max(1.7vh,15px),2.2vh);font-weight:700;gap:10px;height:3.6vh;justify-content:center;margin:0 auto 8px;max-height:4vh;min-height:38px;transition:background .2s;width:98%}.timeline-pulldown.auto-refreshing{animation:pulldown-flash 1.2s;background:#d0e6fa;box-shadow:0 0 0 4px #3498db44}@keyframes pulldown-flash{0%{background:#d0e6fa;box-shadow:0 0 0 4px #3498db44}50%{background:#b3d8f7;box-shadow:0 0 0 8px #3498db66}to{background:#f0f0f0;background:var(--bg-tertiary);box-shadow:none}}.timeline-pulldown:disabled{cursor:not-allowed;opacity:.7}.refresh-icon{align-items:center;display:flex;margin-right:8px;transition:transform .3s linear}.refresh-icon.spinning{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}body,html{height:100%;margin:0;min-height:0;padding:0}#root{flex-direction:column}#app-container,#root{display:flex;height:100%;min-height:0}#app-container{flex-direction:row}.main-content{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.responsive-panels{flex:1 1}#app-container,#root,.main-content{height:100%!important;overflow:hidden!important}@media (max-width:600px) and (orientation:landscape){.camera-name,.event-type{font-size:1.05rem!important;line-height:1.2}.timestamp{font-size:.85rem!important;line-height:1.2}.event-card{font-size:1.05rem!important}}@media (max-width:600px){.camera-name,.event-type{font-size:1.05rem!important;line-height:1.2}.timestamp{font-size:.85rem!important;line-height:1.2}.event-card{font-size:1.05rem!important}}@media (max-width:1190px){.timestamp{font-weight:700!important}}@media (min-width:1190px) and (max-width:1690px){.event-card-header{align-items:flex-start!important;flex-direction:column!important;gap:.1em}.camera-name,.timestamp{text-align:left;width:100%}.timestamp{font-weight:700!important}}.event-card-header.vertical{align-items:flex-start!important;flex-direction:column!important;gap:.1em}@media (min-width:1190px) and (max-width:1690px){.event-card-header{align-items:flex-start!important;flex-direction:column!important;gap:.1em}.camera-name,.timestamp{text-align:left;width:100%}}@media (min-width:1191px) and (max-width:1690px){.responsive-panels{flex-direction:row;gap:0!important;height:100%;min-height:0}.timeline-panel{background:#fff;background:var(--bg-secondary);flex:0 0 40vw;max-width:40vw;min-width:340px;position:relative;width:40vw;z-index:2}.media-viewer-panel{background:#f4f7f6;background:var(--media-viewer-bg);box-shadow:-2px 0 8px #0000000a;display:flex;flex-direction:column;height:auto;max-height:45vh;max-width:100vw;min-width:0;overflow:visible;position:relative;width:100%;z-index:1}}.event-card{box-sizing:border-box;font-size:1.8vh;height:auto;max-height:none;min-height:64px;padding:.5vh 1vw}.event-card-thumbnail{align-items:flex-start;font-size:1.5vh;height:5vh;justify-content:flex-start;overflow:visible;width:5vh}.event-card-body{padding:.5vh 1vw}.camera-name,.event-type,.timestamp{font-size:1.3vh}@media (min-width:601px) and (max-width:1190px){.responsive-panels{box-sizing:border-box;flex:1 1 auto;flex-direction:column;height:100%;min-height:0}.media-viewer-panel{display:flex!important;flex:0 0 45vh;height:45vh!important;max-height:45vh!important;max-width:100vw;min-width:0;overflow:hidden!important;position:static!important;width:100vw}.media-viewer,.media-viewer-panel{background:#f4f7f6;background:var(--media-viewer-bg);flex-direction:column}.media-viewer{box-sizing:border-box;display:flex;height:100%;min-height:0;overflow:hidden;width:100%}.media-info{background:#fff;background:var(--media-info-bg);color:#333;color:var(--text-primary);flex:0 0 auto;min-height:0;z-index:2}.media-container{flex:1 1;max-height:100%;min-height:0;overflow:hidden;z-index:1}.image-embed,.video-embed{border-left:none;box-sizing:border-box;display:flex;flex:1 1;flex-direction:row;height:auto;min-height:0;overflow-y:auto!important;padding-left:10px;padding-top:5px;width:100%!important}.timeline-panel{flex:1 1;height:auto;max-width:100vw;min-height:0;min-width:0;overflow-y:auto;width:100vw}}@media (max-width:600px) and (orientation:landscape){.responsive-panels{box-sizing:border-box;flex:1 1 auto;flex-direction:column;height:100%;min-height:0}.media-viewer-panel{background:#f4f7f6;background:var(--media-viewer-bg);flex:0 0 50vh;height:50vh!important;max-height:50vh!important;max-width:100vw;min-width:0;position:static!important;width:100vw}.media-viewer,.media-viewer-panel{display:flex!important;flex-direction:column;overflow:hidden!important}.media-viewer{height:100%!important;max-height:100%!important}.media-container{align-items:center;aspect-ratio:16/9;display:flex;flex:0 0 auto;justify-content:center;max-height:60%;min-height:0;min-width:0;overflow:hidden;width:100%}.image-embed,.video-embed{aspect-ratio:16/9;display:block;height:100%!important;max-height:100%;object-fit:contain!important;width:100%!important}.media-info{background:#fff;background:var(--media-info-bg);border-bottom:1px solid #e1e1e1;border-bottom:1px solid var(--border-color);border-left:none;box-sizing:border-box;max-width:100%;min-width:0;overflow-y:auto;padding:10px 20px;width:100%;z-index:2}@media (max-width:600px) and (orientation:landscape){.media-viewer-panel{background:#f4f7f6;background:var(--media-viewer-bg);height:auto!important;max-height:50vh!important;overflow-y:visible!important}.media-info{background:#fff;background:var(--media-info-bg);color:#333;color:var(--text-primary);font-size:.95rem;padding:8px 10px}.media-container{height:auto!important;max-height:28vh!important}}.timeline-panel{flex:1 1;height:auto;max-width:100vw;min-height:0;min-width:0;overflow-y:auto;width:100vw}}@media (max-width:600px){.media-viewer-panel{overflow-y:visible!important}.media-viewer,.media-viewer-panel{background:#f4f7f6;background:var(--media-viewer-bg);flex:0 0 auto!important;height:auto!important;max-height:35vh!important}.media-viewer{position:static!important}.media-container{height:auto!important;max-height:22vh!important}.media-info{background:#fff;background:var(--media-info-bg);color:#333;color:var(--text-primary);padding:8px 12px!important}.responsive-panels{gap:0!important}.media-viewer-panel{background:#f4f7f6;background:var(--media-viewer-bg);margin-bottom:0!important;max-height:35vh;padding-bottom:0!important}}@media (max-width:1024px){.sidebar{font-size:.95rem;max-width:38px;min-width:38px;padding:0;width:38px}.sidebar.open{font-size:1.1rem;max-width:90vw!important;min-width:90vw!important;width:90vw!important;z-index:1002}.sidebar-footer,.sidebar-header{padding:10px 8px}.sidebar-nav li button{font-size:.95rem;padding:10px 8px}.signout-button{font-size:.95rem;padding:8px}}.responsive-panels{box-sizing:border-box;display:flex;flex-direction:row;gap:20px;height:100%;max-height:100%;min-height:0;padding-left:5px;width:100%}.media-viewer-panel{align-self:flex-start;flex:2 1;flex-direction:column}.media-viewer-panel,.timeline-panel{display:flex;height:auto;max-width:none;min-width:0;overflow-y:auto}.timeline-panel{flex:1 1;flex-direction:column;min-height:0}@media (max-width:1190px){.responsive-panels{box-sizing:border-box;flex:1 1 auto;flex-direction:column;height:100%;min-height:0}.media-viewer-panel{background:#f4f7f6;background:var(--media-viewer-bg);max-height:45vh;order:1;position:-webkit-sticky;position:sticky;top:0;z-index:2}.media-viewer-panel,.timeline-panel{height:auto;max-width:100vw;min-width:0;overflow-y:auto;width:100%}.timeline-panel{flex:1 1;min-height:0;order:2;z-index:1}}.app-container{display:flex;flex-direction:row;height:100vh;overflow:hidden!important}.main-content{background-color:#f4f7f6;background-color:var(--bg-primary);box-sizing:border-box;flex:1 1 auto;height:100vh;overflow-y:auto;padding:20px 20px 0 0;transition:margin-left .3s ease-in-out}.main-header{align-items:center;border-bottom:1px solid #e1e1e1;border-bottom:1px solid var(--border-color);display:flex;margin-bottom:20px;padding-bottom:10px}.main-header h1{color:#333;color:var(--text-primary);font-size:clamp(1.2rem,4vw,2.4rem);margin:0 0 0 15px}.sidebar{background-color:#2c3e50;background-color:var(--sidebar-bg);color:#ecf0f1;color:var(--sidebar-text);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:width .3s ease-in-out;width:clamp(60px,18vw,270px)}.sidebar.closed{width:60px}.sidebar-header{border-bottom:1px solid #34495e;border-bottom:1px solid var(--sidebar-border);padding:20px;position:relative;text-align:center}.sidebar-header .profile-pic{border:3px solid #3498db;border-radius:50%;height:80px;margin-bottom:10px;width:80px}.sidebar-header h3{color:#fff;font-size:clamp(1.1rem,2vw,1.6rem);margin:0}.sidebar-header p{color:#bdc3c7;color:var(--sidebar-secondary-text);font-size:clamp(.9rem,1.5vw,1.2rem);margin:5px 0 0;word-break:break-all}.sidebar.closed .sidebar-footer,.sidebar.closed .sidebar-header h3,.sidebar.closed .sidebar-header p,.sidebar.closed .sidebar-nav{display:none}.sidebar-toggle{align-items:center;background:linear-gradient(135deg,#3498db 60%,#2980b9);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #2c3e502e,0 0 0 4px #3498db1f;color:#fff;cursor:pointer;display:flex;font-size:2.2rem;height:48px;justify-content:center;line-height:1;position:absolute;right:-16px;top:15px;touch-action:manipulation;transition:background .2s,box-shadow .2s,color .2s;width:48px;z-index:1001}.sidebar-toggle:active,.sidebar-toggle:focus{background:linear-gradient(135deg,#2980b9 80%,#3498db);box-shadow:0 0 0 4px #2980b9,0 2px 8px #2c3e502e;color:#fff;outline:none}.sidebar-toggle-main{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1.8rem;padding:5px 10px}.sidebar-nav{flex-grow:1;overflow-y:auto;padding:15px 0}.sidebar-nav h4{color:#bdc3c7;color:var(--sidebar-secondary-text);font-size:1.1rem;margin:15px 0 10px;padding:0 20px;text-transform:uppercase}.sidebar-nav ul{list-style:none;margin:0;padding:0}.sidebar-nav li button{background:none;border:none;color:#ecf0f1;color:var(--sidebar-text);cursor:pointer;display:block;font-size:clamp(.85rem,1.8vw,1.1rem);padding:clamp(8px,1.5vw,12px) clamp(10px,2vw,20px);text-align:left;transition:background-color .2s ease;width:100%}.sidebar-nav li button:hover{background-color:#34495e;background-color:var(--sidebar-hover)}.sidebar-nav li.active .filter-name,.sidebar-nav li.active>button:not(.filter-menu-btn){background-color:#3498db;background-color:var(--accent-primary);border-radius:8px;font-weight:700}.sidebar-footer{border-top:1px solid #34495e;border-top:1px solid var(--sidebar-border);padding:clamp(10px,2vw,20px)}.signout-button{background-color:#e74c3c;background-color:var(--danger);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:clamp(1rem,2vw,1.4rem);padding:clamp(7px,1.5vw,10px);width:100%}.signout-button:hover{background-color:#c0392b;background-color:var(--danger-hover)}.collapsible-section{border-bottom:1px solid #34495e;border-bottom:1px solid var(--sidebar-border);margin-bottom:15px}.collapsible-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;margin:15px 0 0;padding:0 20px 10px;transition:color .2s ease;-webkit-user-select:none;user-select:none}.collapsible-header:hover{color:#3498db;color:var(--accent-primary)}.collapse-icon{color:#bdc3c7;color:var(--sidebar-secondary-text);font-size:.8rem;transition:transform .3s ease}.collapse-icon.collapsed{transform:rotate(-90deg)}.collapse-icon.expanded{transform:rotate(0deg)}.date-time-search{overflow:hidden;padding:0 20px 15px;transition:max-height .3s ease,opacity .3s ease}.date-time-search.collapsed{max-height:0;opacity:0;padding:0 20px}.date-time-search.expanded{max-height:200px;opacity:1}.search-inputs{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.search-date-input,.search-time-input{background-color:#2c3e50;background-color:var(--input-bg);border:1px solid #34495e;border:1px solid var(--input-border);border-radius:4px;box-sizing:border-box;color:#ecf0f1;color:var(--input-text);font-size:1rem;padding:8px;width:100%}.search-date-input:focus,.search-time-input:focus{border-color:#3498db;border-color:var(--accent-primary);box-shadow:0 0 0 2px #3498db4d;outline:none}.search-button{background-color:#27ae60;background-color:var(--accent-secondary);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:10px;transition:background-color .2s ease;width:100%}.search-button:hover{background-color:#229954;background-color:var(--accent-secondary-hover)}.search-button:active{background-color:#1e8449}.popup-overlay{align-items:center;background-color:#00000080;background-color:var(--popup-overlay);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.popup-content{background:#fff;background:var(--popup-bg);border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:450px;overflow-y:auto;width:90%}.popup-header{align-items:center;border-bottom:1px solid #e1e1e1;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:20px 20px 0}.popup-header h3{color:#e74c3c;color:var(--danger);font-size:1.2rem;margin:0}.popup-close{align-items:center;background:none;border:none;color:#777;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;padding:0;width:24px}.popup-close:hover{color:#333;color:var(--text-primary)}.popup-body{line-height:1.5;padding:20px}.popup-body p{color:#333;color:var(--text-primary);margin:0 0 15px}.popup-body p:last-child{margin-bottom:0}.popup-footer{padding:0 20px 20px;text-align:right}.popup-button{background-color:#3498db;background-color:var(--accent-primary);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background-color .2s ease}.popup-button:hover{background-color:#2980b9;background-color:var(--accent-primary-hover)}.login-container{align-items:center;background-color:#ecf0f1;background-color:var(--login-bg);display:flex;flex-direction:column;height:100vh;justify-content:center}.login-container h2{color:#333;color:var(--text-primary);margin-bottom:10px}.login-container p{color:#555;color:var(--text-secondary);margin-bottom:30px}.timeline-container{align-items:flex-start;display:flex;gap:20px;height:100%}.timeline{flex:1 1}.media-viewer{background:#f4f7f6;background:var(--media-viewer-bg);box-sizing:border-box;flex-direction:column;height:100%}.media-container,.media-viewer{display:flex;min-height:0;overflow:hidden;width:100%}.media-container{align-items:center;aspect-ratio:16/9;background:#111;background:var(--media-container-bg);flex:1 1;justify-content:center;max-height:100%;min-width:0;position:relative}.media-info{background:#fff;background:var(--media-info-bg);border-bottom:1px solid #e1e1e1;border-bottom:1px solid var(--border-color);border-left:none;box-sizing:border-box;color:#333;color:var(--text-primary);flex:0 0 auto;max-width:100%;min-height:0;min-width:0;overflow-y:auto;padding:10px 20px;width:100%;z-index:2}.image-embed,.video-embed{bottom:0;display:block;height:100%;left:0;margin:auto;max-height:100%;max-width:100%;object-fit:contain;position:absolute;right:0;top:0;width:100%}.media-labels ul{list-style:none;padding:0}.media-labels li{background-color:#f0f0f0;background-color:var(--label-bg);border-radius:4px;color:#333;color:var(--text-primary);margin-bottom:5px;padding:5px 10px}.event-card{align-items:center;background-color:#fff;background-color:var(--card-bg);border:2px solid #0000;border-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--shadow-light);cursor:pointer;display:flex;font-size:clamp(.95rem,1.5vw,1.1rem);margin-bottom:clamp(8px,2vw,15px);overflow:hidden;position:relative;transition:all .2s ease-in-out}.event-card:hover{box-shadow:0 4px 8px #00000026;box-shadow:0 4px 8px var(--shadow-medium);transform:translateY(-3px)}.event-card.selected{border-color:#2c3e50;border-color:var(--card-selected-border);border-width:4px;box-shadow:0 0 0 3px #2c3e5038,0 8px 18px #2c3e5059;box-shadow:0 0 0 3px var(--card-selected-shadow),0 8px 18px var(--card-selected-shadow-dark)}.event-card.seen{background-color:#eef6fd;background-color:var(--card-seen-bg);border-color:#3498db;border-color:var(--card-seen-border);box-shadow:inset 6px 0 0 0 #3498db,0 2px 6px #3498db2e;box-shadow:inset 6px 0 0 0 var(--card-seen-border),0 2px 6px #3498db2e;opacity:1}.event-card.seen .camera-name{color:#1f4f78;color:var(--card-seen-text);font-weight:800}.event-card.seen .timestamp{color:#1f4f78;color:var(--card-seen-text);font-weight:600}.event-card-thumbnail{background-color:#e1e1e1;background-color:var(--bg-quaternary);color:#aaa;color:var(--text-quaternary);flex-shrink:0;font-size:clamp(.9rem,2vw,1.2rem);height:clamp(60px,12vw,100px);position:relative;width:clamp(60px,12vw,100px)}.event-card-thumbnail,.video-count-badge{align-items:center;display:flex;justify-content:center}.video-count-badge{background-color:#000000b3;border-radius:1em;color:#fff;font-size:max(1.2vh,13px);font-weight:700;min-height:22px;min-width:22px;padding:.2em .7em;pointer-events:none;position:absolute;right:0;top:50%;transform:translateY(-50%);z-index:2}.event-card-body{flex-grow:1;padding:clamp(8px,2vw,15px)}.event-card-header{align-items:flex-start;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.event-card-cameras{display:flex;flex-wrap:wrap;gap:6px;margin:2px 0 6px}.camera-chip{background:#eef6fd;background:var(--chip-bg);border:1px solid #3498db;border:1px solid var(--chip-border);border-radius:12px;color:#1f4f78;color:var(--chip-text);font-size:clamp(.58rem,.85vw,.9rem);line-height:1.6;padding:2px 8px;transition:all .2s ease-in-out;white-space:nowrap}.camera-chip--unviewed{background:#f8f9fa;background:var(--chip-unviewed-bg);border:1px solid #dee2e6;border:1px solid var(--chip-unviewed-border);color:#6c757d;color:var(--chip-unviewed-text);opacity:.6}.camera-chip--partially-viewed{background:linear-gradient(90deg,#d4edda,#d4edda 50%,#f8f9fa 0,#f8f9fa);background:linear-gradient(90deg,var(--chip-viewed-bg) 0,var(--chip-viewed-bg) 50%,var(--chip-unviewed-bg) 50%,var(--chip-unviewed-bg) 100%)}.camera-chip--fully-viewed,.camera-chip--partially-viewed{border:1px solid #28a745;border:1px solid var(--chip-viewed-border);color:#155724;color:var(--chip-viewed-text)}.camera-chip--fully-viewed{background:#d4edda;background:var(--chip-viewed-bg);font-weight:600}.camera-name{color:#333;color:var(--text-primary);font-size:clamp(.7rem,1vw,1.1rem);font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timestamp{color:#777;color:var(--text-tertiary);display:block;font-size:clamp(.6rem,.9vw,.95rem);line-height:1.3;min-width:0;overflow:visible;overflow-wrap:anywhere;text-overflow:clip;white-space:normal;width:100%;word-break:break-word}.event-type{color:#555;color:var(--text-secondary);font-size:clamp(.6rem,.9vw,1rem);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-card-play-icon{align-items:center;background-color:#00000080;border-radius:50%;display:flex;height:50px;justify-content:center;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity .2s ease-in-out;width:50px}.event-card:hover .event-card-play-icon{opacity:1}.view-button{display:none}.media-navigation{align-items:center;display:flex;justify-content:space-between;margin-top:10px}.media-navigation button{background-color:#3498db;background-color:var(--accent-primary);border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 12px}.media-navigation button:hover{background-color:#2980b9;background-color:var(--accent-primary-hover)}.theme-toggle{align-items:center;background:none;border:none;border-radius:50%;color:#ecf0f1;color:var(--sidebar-text);cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;margin-bottom:10px;padding:8px;transition:background-color .2s ease;width:40px}.theme-toggle:hover{background-color:#34495e;background-color:var(--sidebar-hover)}.theme-toggle:focus{outline:2px solid #3498db;outline:2px solid var(--accent-primary);outline-offset:2px}.groups-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px;margin-top:20px}.groups-header h4{margin:0}.add-filter-btn{background:#0000;border:1px solid #3498db;border:1px solid var(--accent-primary);border-radius:4px;color:#3498db;color:var(--accent-primary);cursor:pointer;font-size:12px;font-weight:500;padding:3px 9px;transition:all .2s ease}.add-filter-btn:hover{background:#3498db;background:var(--accent-primary);color:#fff}.sidebar nav ul li{align-items:center;display:flex;justify-content:space-between;position:relative}.filter-name{flex:1 1;min-width:0;overflow:hidden;text-align:left}.camera-name-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-nav li .filter-menu-btn{align-items:center;background:#0000;border:none;color:#3498db;color:var(--accent-primary);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:18px;font-weight:900;height:28px;justify-content:center;line-height:1;margin:0;max-width:28px;min-width:28px;opacity:.8;padding:2px;text-shadow:.5px 0 0 currentColor,-.5px 0 0 currentColor;transition:all .2s ease;width:28px!important}.filter-menu-btn:hover{opacity:1;transform:scale(1.1)}.filter-dropdown{background:#34495e;background:var(--sidebar-hover);border:1px solid #34495e;border:1px solid var(--sidebar-border);border-radius:6px;box-shadow:0 4px 12px #00000026;box-shadow:0 4px 12px var(--shadow-medium);margin-top:6px;min-width:110px;position:absolute;right:0;top:100%;z-index:1000}.filter-dropdown button{background:#0000;border:none;color:#ecf0f1;color:var(--sidebar-text);cursor:pointer;display:block;font-size:14px!important;line-height:1.5;padding:10px 16px!important;text-align:left;transition:background-color .2s ease;white-space:nowrap;width:100%}.filter-dropdown button:hover{background:#2c3e50;background:var(--sidebar-bg)}.filter-dropdown button:not(:last-child){border-bottom:1px solid #34495e;border-bottom:1px solid var(--sidebar-border)}.modal-overlay{align-items:center;background:#00000080;background:var(--popup-overlay);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.filter-modal{background:#fff;background:var(--popup-bg);border-radius:8px;box-shadow:0 4px 16px #00000026;box-shadow:0 4px 16px var(--shadow-medium);max-height:90vh;max-width:500px;overflow:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e1e1e1;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.modal-header h3{color:#333;color:var(--text-primary);margin:0}.close-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#777;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:background-color .2s ease,color .2s ease;width:32px}.close-btn:hover{background:#f0f0f0;background:var(--bg-tertiary);color:#333;color:var(--text-primary)}.modal-body{padding:20px}.modal-footer{border-top:1px solid #e1e1e1;border-top:1px solid var(--border-color);display:flex;gap:10px;justify-content:flex-end;padding:16px 20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:500;margin-bottom:6px}.form-group label,.form-input,.form-select{color:#333;color:var(--text-primary);font-size:14px}.form-input,.form-select{background:#fff;background:var(--bg-secondary);border:1px solid #e1e1e1;border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;padding:8px 12px;width:100%}.form-input:focus,.form-select:focus{border-color:#3498db;border-color:var(--accent-primary);outline:none}.error-messages{background:#fee;border:1px solid #e74c3c;border:1px solid var(--danger);border-radius:4px;margin-bottom:16px;padding:12px}.error-message{color:#e74c3c;color:var(--danger);font-size:14px;margin:4px 0}.camera-checklist{background:#fff;background:var(--bg-secondary);border:1px solid #e1e1e1;border:1px solid var(--border-color);border-radius:4px;max-height:200px;overflow-y:auto;padding:8px}.camera-checkbox{align-items:center;border-radius:4px;cursor:pointer;display:flex;padding:6px 8px;transition:background-color .2s ease}.camera-checkbox:hover{background:#f0f0f0;background:var(--bg-tertiary)}.camera-checkbox input[type=checkbox]{cursor:pointer;margin-right:8px}.camera-checkbox span{color:#333;color:var(--text-primary);font-size:14px}.filter-preview{background:#f0f0f0;background:var(--bg-tertiary);border-left:3px solid #3498db;border-left:3px solid var(--accent-primary);border-radius:4px;color:#555;color:var(--text-secondary);font-size:14px;margin-top:16px;padding:12px}.filter-preview strong{color:#333;color:var(--text-primary)}.filter-preview .warning{color:#e74c3c;color:var(--danger);font-weight:500}.btn-danger,.btn-primary,.btn-secondary{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background-color .2s ease}.btn-primary{background:#3498db;background:var(--accent-primary);color:#fff}.btn-primary:hover{background:#2980b9;background:var(--accent-primary-hover)}.btn-secondary{background:#f0f0f0;background:var(--bg-tertiary);color:#333;color:var(--text-primary)}.btn-secondary:hover{background:#e1e1e1;background:var(--bg-quaternary)}.btn-danger{background:#e74c3c;background:var(--danger);color:#fff}.btn-danger:hover{background:#c0392b;background:var(--danger-hover)}.confirm-dialog{background:#fff;background:var(--popup-bg);border-radius:8px;box-shadow:0 4px 16px #00000026;box-shadow:0 4px 16px var(--shadow-medium);max-width:400px;width:90%}.confirm-header{align-items:center;border-bottom:1px solid #e1e1e1;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.confirm-header h3{color:#333;color:var(--text-primary);margin:0}.confirm-body{padding:20px}.confirm-body p{color:#555;color:var(--text-secondary);line-height:1.5;margin:0}.confirm-footer{border-top:1px solid #e1e1e1;border-top:1px solid var(--border-color);display:flex;gap:10px;justify-content:flex-end;padding:16px 20px}.camera-temperature{align-self:center;color:#bdc3c7;color:var(--sidebar-secondary-text);cursor:pointer;flex-shrink:0;font-size:.75em;padding:0 4px;transition:color .2s ease;white-space:nowrap}.camera-temperature:hover{color:#3498db;color:var(--accent-primary);text-decoration:underline}.camera-battery{align-self:center;cursor:pointer;display:inline-block;flex-shrink:0;font-size:.85em;padding:0 4px;transition:transform .2s ease,filter .2s ease;white-space:nowrap}.camera-battery:hover{transform:scale(1.15)}.battery-ok{filter:grayscale(0) hue-rotate(80deg)}.battery-low{filter:grayscale(0) hue-rotate(0deg) brightness(1.2)}.temperature-modal{background:#fff;background:var(--popup-bg);border-radius:8px;box-shadow:0 4px 20px #00000026;box-shadow:0 4px 20px var(--shadow-medium);display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow-y:auto;width:90%}.temperature-modal-header{align-items:flex-start;border-bottom:1px solid #e1e1e1;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:20px}.temperature-modal-header h3{color:#333;color:var(--text-primary);font-size:1.4rem;margin:0 0 8px}.current-temperature{color:#555;color:var(--text-secondary);font-size:1.1rem;margin:0}.current-temperature .temp-value{color:#3498db;color:var(--accent-primary);font-size:1.8rem;font-weight:700;margin:0 .3em}.temperature-updated{color:#777;color:var(--text-tertiary);font-size:.85rem;margin-left:.5em}.temperature-modal-body{display:flex;flex:1 1;flex-direction:column;gap:20px;min-height:0;overflow:hidden;padding:20px}.time-range-selector{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.time-range-btn{background:#f0f0f0;background:var(--bg-tertiary);border:2px solid #e1e1e1;border:2px solid var(--border-color);border-radius:4px;color:#333;color:var(--text-primary);cursor:pointer;font-size:.95rem;font-weight:500;padding:8px 16px;transition:all .2s ease}.time-range-btn:hover:not(:disabled){background:#e1e1e1;background:var(--bg-quaternary);border-color:#3498db;border-color:var(--accent-primary)}.time-range-btn.active{background:#3498db;background:var(--accent-primary);border-color:#3498db;border-color:var(--accent-primary);color:#fff;font-weight:600}.time-range-btn:disabled{cursor:not-allowed;opacity:.5}.temperature-chart-container{background:#fff;background:var(--bg-secondary);border:1px solid #e1e1e1;border:1px solid var(--border-color);border-radius:4px;height:400px;min-height:250px;padding:15px;position:relative;width:100%}.temperature-loading{align-items:center;color:#555;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;min-height:250px}.temperature-loading-spinner{animation:spin 1s linear infinite;border:3px solid #e1e1e1;border-top-color:#3498db;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-primary);height:40px;margin-bottom:15px;width:40px}.temperature-error{align-items:center;color:#e74c3c;color:var(--danger);display:flex;flex-direction:column;justify-content:center;min-height:250px;padding:20px;text-align:center}.temperature-error-icon{font-size:3rem;margin-bottom:15px}.temperature-error-message{font-size:1.1rem;margin-bottom:15px}.temperature-retry-btn{background:#3498db;background:var(--accent-primary);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background .2s ease}.temperature-retry-btn:hover{background:#2980b9;background:var(--accent-primary-hover)}.temperature-empty{align-items:center;color:#777;color:var(--text-tertiary);display:flex;flex-direction:column;justify-content:center;min-height:250px;padding:20px;text-align:center}@media (max-width:600px){.temperature-modal{max-height:95vh;width:95%}.temperature-modal-header{padding:15px}.temperature-modal-header h3{font-size:1.2rem}.current-temperature{font-size:.95rem}.current-temperature .temp-value{font-size:1.5rem}.temperature-modal-body{padding:15px}.temperature-chart-container{height:auto;min-height:200px;padding:10px}.time-range-btn{font-size:.85rem;padding:6px 12px}}@media (min-width:601px) and (max-width:1024px){.temperature-modal{width:92%}.temperature-modal-header h3{font-size:1.3rem}.current-temperature .temp-value{font-size:1.6rem}.temperature-chart-container{height:auto;min-height:250px}.time-range-btn{font-size:.9rem;padding:7px 14px}}@media (min-width:1025px) and (max-width:1190px){.temperature-chart-container{height:auto;min-height:280px}}
/*# sourceMappingURL=main.92f23a6b.css.map*/