.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f0f2f5;transition:background-color .3s ease}.login-container.dark{background-color:#141414;color:#fff}.login-content{background:white;padding:2rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px;transition:all .3s ease}.dark .login-content{background:#1f1f1f;box-shadow:0 2px 10px #0000004d}.login-logo{width:120px;height:auto;margin:0 auto 2rem;display:block}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{position:relative}.form-group input{width:100%;padding:12px;border:1px solid #d9d9d9;border-radius:8px;font-size:16px;transition:all .3s ease;background:white;color:#000000d9}.dark .form-group input{background:#141414;border-color:#434343;color:#ffffffd9}.form-group input:focus{outline:none;border-color:#1677ff;box-shadow:0 0 0 2px #1677ff33}.dark .form-group input:focus{border-color:#1677ff;box-shadow:0 0 0 2px #1677ff33}button{background:#1677ff;color:#fff;border:none;padding:12px;border-radius:8px;font-size:16px;cursor:pointer;display:flex;justify-content:center;align-items:center;gap:8px;transition:all .3s ease}button:hover{background:#4096ff}button:disabled{background:#d9d9d9;cursor:not-allowed}.dark button:disabled{background:#434343;color:#ffffff4d}.error-message{background:#ff4d4f1a;color:#ff4d4f;padding:12px;border-radius:8px;margin-bottom:1rem;text-align:center}.dark .error-message{background:rgba(255,77,79,.2)}.loading-spinner{border:3px solid rgba(22,119,255,.1);border-top:3px solid #1677ff;border-radius:50%;width:20px;height:20px;animation:spin 1s linear infinite}.login-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#1677ff}.dark .login-loading{color:#1677ff}:root{--input-bg: rgba(0, 0, 0, .05);--input-bg-focus: rgba(0, 0, 0, .08);--danger-bg: rgba(255, 59, 48, .1);--danger-color: #FF3B30}[data-theme=dark]{--input-bg: rgba(255, 255, 255, .05);--input-bg-focus: rgba(255, 255, 255, .08);--danger-bg: rgba(255, 69, 58, .2);--danger-color: #FF453A}@media (max-width: 480px){.login-content{padding:16px}.login-logo{width:100px;height:100px;margin-bottom:40px}}.form-checkbox{text-align:left;margin-bottom:8px}.form-checkbox label{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px;cursor:pointer}.form-checkbox input[type=checkbox]{width:16px;height:16px;margin:0;cursor:pointer;accent-color:var(--accent-color)}@keyframes pulse{0%{transform:scale(1);opacity:.8;box-shadow:0 0 #34c75966}70%{transform:scale(1.1);opacity:1;box-shadow:0 0 0 10px #34c75900}to{transform:scale(1);opacity:.8;box-shadow:0 0 #34c75900}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.footer{margin-top:.5rem;padding:1rem;background:var(--bg-secondary);border-top:1px solid var(--border-color);position:relative}.footer:before{content:"";display:block;height:.5rem;background:var(--bg-primary);position:absolute;top:-.5rem;left:0;right:0}.footer-content{max-width:1200px;margin:0 auto}.footer-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1rem;position:relative;z-index:1}.footer-card{background:var(--bg-elevated);border-radius:.75rem;padding:1rem;box-shadow:0 8px 16px #0000001a;animation:fadeIn .5s ease-out;border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .3s ease,box-shadow .3s ease}.footer-card:hover{transform:translateY(-2px);box-shadow:0 12px 20px #00000026}.system-status{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(52,199,89,.1) 0%,rgba(52,199,89,.05) 100%);border:1px solid rgba(52,199,89,.2);position:relative;overflow:hidden}.system-status:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(52,199,89,.1) 0%,transparent 70%);animation:rotate 10s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-badge{display:inline-flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#34c759 0%,#32d74b 100%);color:#fff;padding:.75rem 1.5rem;border-radius:100px;font-size:1.1rem;font-weight:500;box-shadow:0 4px 12px #34c7594d;position:relative;z-index:1;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.1)}.status-dot{width:12px;height:12px;background:#ffffff;border-radius:50%;box-shadow:0 0 #fff6;animation:pulse 2s infinite}.company-info{text-align:center}.footer-tagline{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.highlight{color:var(--accent-color);font-weight:700;font-size:1.25rem}.tagline-text{color:var(--text-primary);font-size:1.1rem}.footer-description{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin:0}.ai-features{display:flex;flex-direction:column;gap:1rem}.ai-badge{display:flex;align-items:center;gap:.5rem;color:var(--accent-color);font-weight:500;font-size:1.1rem}.ai-icon{width:24px;height:24px}.ai-features-list{list-style:none;padding:0;margin:0;color:var(--text-secondary)}.ai-features-list li{margin:.5rem 0;padding-left:1.5rem;position:relative}.ai-features-list li:before{content:"•";position:absolute;left:0;color:var(--accent-color)}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid var(--border-color)}.copyright{color:var(--text-secondary);font-size:.875rem;opacity:.8;margin:0}@media (max-width: 768px){.footer{padding:2rem 1rem 1.5rem}.footer-cards{gap:1.5rem}.footer-card{padding:1.25rem}.highlight{font-size:1.1rem}.tagline-text{font-size:1rem}.footer-description{font-size:.875rem}.ai-badge{font-size:1rem}.ai-features-list li{font-size:.875rem}.copyright{font-size:.8rem}}.home-container{max-width:1200px;margin:0 auto;padding:1rem;min-height:100vh;display:flex;flex-direction:column;gap:.5rem}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.header-brand{display:flex;align-items:center;gap:1rem}.header-logo{width:40px;height:40px;object-fit:contain}.home-header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.icon-button{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:50%;transition:all .2s ease}.icon-button:hover{background:var(--hover-bg)}.header-icon{width:24px;height:24px;fill:var(--text-secondary)}.icon-button:hover .header-icon{fill:var(--danger-color)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.5rem;margin-bottom:.5rem}.action-card{background:var(--card-bg)!important;border:1px solid var(--border-color);border-radius:.75rem;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.action-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.action-card.disabled{opacity:.7;cursor:not-allowed;pointer-events:none}.action-icon-wrapper{width:48px;height:48px;display:flex;align-items:center;justify-content:center}.action-icon{width:100%;height:100%;fill:var(--accent-color)}.disabled .action-icon{fill:var(--text-disabled)}.action-title{font-size:1.25rem;font-weight:500;color:var(--text-primary);text-align:center}.dialog{background:var(--bg-primary);border-radius:1rem;padding:1.5rem;min-width:300px;max-width:90%;box-shadow:0 8px 32px #0000001a}.dialog h2{margin:0 0 1rem;font-size:1.5rem;color:var(--text-primary)}.dialog p{margin:0 0 1.5rem;color:var(--text-secondary)}.button{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.button.secondary{background:var(--button-secondary-bg);color:var(--text-secondary)}.button.primary{background:var(--accent-color);color:#fff}.button.danger{background:var(--danger-color)}.button:hover{opacity:.9}.notification{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);padding:1rem 2rem;border-radius:.5rem;color:#fff;font-weight:500;animation:slideUp .3s ease;z-index:1000}.notification.success{background:var(--success-color)}.notification.error{background:var(--danger-color)}@keyframes slideUp{0%{transform:translate(-50%,100%);opacity:0}to{transform:translate(-50%);opacity:1}}:root{--card-bg: rgba(255, 255, 255, .05);--hover-bg: rgba(0, 0, 0, .05);--button-secondary-bg: rgba(0, 0, 0, .05);--success-color: #34c759;--danger-color: #ff3b30;--text-disabled: #999999}[data-theme=dark]{--card-bg: rgba(255, 255, 255, .1);--hover-bg: rgba(255, 255, 255, .1);--button-secondary-bg: rgba(255, 255, 255, .1);--success-color: #32d74b;--danger-color: #ff453a;--text-disabled: #666666}@media (max-width: 768px){.home-container{padding:1rem;gap:.75rem}.home-header{margin-bottom:.75rem}.home-header h1{font-size:1.5rem}.header-logo{width:32px;height:32px}.quick-actions{grid-template-columns:1fr;gap:.75rem;margin-bottom:.75rem}.action-card{padding:1.25rem}.action-icon-wrapper{width:40px;height:40px}.action-title{font-size:1.1rem}.dialog{width:calc(100% - 2rem);max-width:none;margin:1rem;padding:1.25rem}.dialog h2{font-size:1.25rem}.button{padding:.5rem 1rem;font-size:.9rem}}@media (max-width: 360px){.home-container{padding:.75rem}.home-header h1{font-size:1.25rem}.header-logo{width:28px;height:28px}.action-card{padding:1.25rem}.action-icon-wrapper{width:36px;height:36px}.action-title{font-size:1rem}}@media (min-width: 769px) and (max-width: 1024px){.home-container{padding:1.5rem}.quick-actions{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1920px){.home-container{max-width:1400px;padding:3rem}.home-header h1{font-size:2.5rem}.header-logo{width:48px;height:48px}.action-card{padding:2.5rem}.action-icon-wrapper{width:56px;height:56px}.action-title{font-size:1.5rem}}.footer{margin-top:.5rem}.video-container{width:100%;background:var(--card-bg);border-radius:.75rem;overflow:hidden;border:1px solid var(--border-color)}.video-header{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.video-title{font-weight:500;color:var(--text-primary)}.video-status{display:flex;align-items:center;gap:.5rem}.status-dot{width:8px;height:8px;border-radius:50%;background-color:var(--text-secondary)}.status-dot.active{background-color:var(--active-color);animation:pulse 2s infinite}.status-dot.error{background-color:var(--danger-color)}.status-dot.loading{background-color:var(--text-secondary);animation:pulse 1s infinite}.status-text{font-size:.875rem;color:var(--text-secondary)}.video-wrapper{position:relative;width:100%;padding-top:56.25%;background:black}.video-loading,.video-error{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-primary);gap:1rem;background:rgba(0,0,0,.7);z-index:2}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.1);border-left-color:var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}.error-icon{font-size:2rem;color:var(--danger-color)}.video-message{background-color:var(--bg-secondary)}.video-message p{margin:.5rem 0}.video-info{font-size:.875rem;color:var(--text-secondary);max-width:80%}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}to{transform:scale(1);opacity:1}}.vlc-player{width:100%;height:100%;background-color:#000}.retry-count{font-size:.75rem;color:var(--text-secondary);background:var(--bg-primary);padding:.25rem .5rem;border-radius:1rem}.retry-button{margin-top:1rem;padding:.5rem 1rem;border:none;border-radius:.5rem;background-color:var(--active-color);color:#fff;cursor:pointer;font-weight:500;transition:all .2s ease}.retry-button:hover{background-color:var(--active-color-hover);transform:scale(1.05)}.retry-button:disabled{background-color:var(--bg-secondary);cursor:not-allowed;transform:none}.stream-url{font-family:monospace;font-size:.75rem;color:var(--text-secondary);background-color:var(--bg-primary);padding:.5rem;border-radius:.25rem;margin-top:.5rem;word-break:break-all;max-width:100%}.mjpeg-stream-container{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:black}.mjpeg-stream{width:100%;height:100%;object-fit:contain;position:absolute;top:0;left:0}:root{--accent-color: #007AFF;--accent-color-rgb: 0, 122, 255;--inactive-color: #999999;--active-color: var(--accent-color)}[data-theme=dark]{--accent-color: #0A84FF;--accent-color-rgb: 10, 132, 255;--inactive-color: #666666;--active-color: var(--accent-color)}.activate-container{max-width:1200px;margin:0 auto;padding:20px;position:relative}.activate-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:var(--text-secondary)}.loading-spinner{width:32px;height:32px;border:3px solid var(--bg-secondary);border-top-color:var(--active-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.activate-error{text-align:center;padding:2rem;color:var(--text-primary);background:var(--bg-primary);border-radius:1rem;border:1px solid var(--border-color);margin-top:2rem}.error-icon{width:48px;height:48px;border-radius:24px;background:var(--inactive-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 1rem}.status-section{margin-bottom:2rem;padding-top:40px}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.status-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.status-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:1rem;background:var(--bg-secondary);font-size:.875rem;color:var(--text-secondary)}.status-indicator .status-dot{width:8px;height:8px;border-radius:50%;background-color:var(--inactive-color)}.status-indicator.active .status-dot{background-color:var(--accent-color);animation:pulse 2s infinite}.status-indicator.active{color:var(--accent-color);background:rgba(var(--accent-color-rgb),.1)}.status-image-section{margin:1.5rem 0;position:relative;min-height:200px}.status-image-title{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);margin:0 0 .75rem .5rem;font-size:.875rem}.status-image-title svg{opacity:.7}.status-image-container{width:100%;display:flex;justify-content:center;align-items:center;border-radius:12px;overflow:hidden;background:var(--bg-secondary);position:relative;cursor:pointer;transition:all .2s ease}.status-image-container:hover{transform:scale(1.01)}.status-image-container:hover .image-overlay{opacity:1}.status-image{width:100%;max-width:400px;height:auto;object-fit:contain}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.image-overlay svg{width:32px;height:32px;color:#fff}.fullscreen-image-container{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);z-index:1100;display:flex;align-items:center;justify-content:center;padding:2rem}.fullscreen-image{max-width:100%;max-height:100%;object-fit:contain}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.control-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;box-shadow:var(--card-shadow)}.control-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.control-header span{font-size:1rem;font-weight:500;color:var(--text-primary)}.control-status{font-size:.875rem;color:var(--text-secondary);margin:0}.cameras-section{margin-top:2rem}.cameras-section h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.cameras-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem}.camera-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:1rem;overflow:hidden;box-shadow:var(--card-shadow);position:relative}.camera-info{padding:1rem;border-bottom:1px solid var(--border-color)}.camera-info h3{font-size:1rem;font-weight:500;color:var(--text-primary);margin:0 0 .5rem}.camera-url{font-size:.875rem;color:var(--text-secondary);margin:.25rem 0;font-family:monospace;background:var(--bg-secondary);padding:.5rem;border-radius:.25rem;word-break:break-all}.no-cameras{text-align:center;padding:2rem;background:var(--bg-secondary);border-radius:1rem;margin-top:2rem;color:var(--text-secondary)}.no-cameras p{margin:0;font-size:1rem}.switch{position:relative;display:inline-block;width:50px;height:24px}input:checked+.slider:before{transform:translate(26px)}@keyframes pulse{0%{transform:scale(1);opacity:.8;box-shadow:0 0 0 0 rgba(var(--accent-color-rgb),.4)}70%{transform:scale(1.1);opacity:1;box-shadow:0 0 0 10px rgba(var(--accent-color-rgb),0)}to{transform:scale(1);opacity:.8;box-shadow:0 0 0 0 rgba(var(--accent-color-rgb),0)}}.fullscreen-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000;z-index:1000}.fullscreen-header{position:absolute;top:0;left:0;right:0;height:3rem;background-color:var(--bg-secondary);z-index:2;display:flex;align-items:center;padding:0 1rem}.back-button-fullscreen{background:none;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all .2s ease;margin-right:.5rem}.back-button-fullscreen:hover{background-color:#0000001a}.back-button-fullscreen svg{width:24px;height:24px}.fullscreen-title-container{flex:1;display:flex;align-items:center;justify-content:space-between}.fullscreen-title{font-size:1.1rem;font-weight:500;color:var(--text-primary);margin:0}.live-indicator{display:flex;align-items:center;gap:.5rem;color:var(--accent-color);font-size:.9rem}.live-indicator:before{content:"";width:8px;height:8px;border-radius:50%;background-color:var(--accent-color);animation:pulse 2s infinite}.fullscreen-player{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding-top:3.5rem}.fullscreen-player>div{width:100%!important;height:100%!important;max-width:100vw;max-height:100vh;object-fit:contain}.close-button{background:rgba(0,0,0,.5);border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.close-button:hover{background-color:#000000b3;transform:scale(1.1)}.close-button svg{width:24px;height:24px}.camera-card{position:relative}.expand-button{position:absolute;bottom:1rem;right:1rem;background-color:#00000080;z-index:2;width:36px;height:36px;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.expand-button:hover{background-color:#000000b3;transform:scale(1.1)}.expand-button svg{width:20px;height:20px;color:#fff}@media (max-width: 768px){.activate-container{padding:1rem .5rem}.back-button{top:1rem;left:1rem;width:36px;height:36px}.back-button svg{width:20px;height:20px}.status-section{padding-top:60px}.status-header{flex-direction:column;align-items:flex-start;gap:1rem}.status-header h1{font-size:1.5rem}.controls-grid{grid-template-columns:1fr}.camera-info{padding:.75rem}.camera-url{font-size:.75rem}.fullscreen-container:before{height:3rem}.fullscreen-controls{top:.5rem;right:.5rem}.fullscreen-player{padding-top:3rem}.close-button,.rotate-button{width:36px;height:36px}.close-button svg,.rotate-button svg{width:20px;height:20px}.fullscreen-header{height:2.75rem;padding:0 .5rem}.back-button-fullscreen{width:36px;height:36px;margin-right:.25rem}.back-button-fullscreen svg{width:20px;height:20px}.fullscreen-title{font-size:1rem}.live-indicator{font-size:.8rem}.status-image-title{font-size:.8rem;margin-left:0}.fullscreen-image-container{padding:1rem}}@media (min-width: 1920px){.fullscreen-container:before{height:4rem}.fullscreen-controls{top:1rem;right:2rem}.fullscreen-player{padding-top:4rem}.close-button,.rotate-button{width:48px;height:48px}.close-button svg,.rotate-button svg{width:28px;height:28px}.fullscreen-player>div{max-width:90vw;max-height:90vh;margin:auto}.fullscreen-header{height:3.5rem;padding:0 2rem}.back-button-fullscreen{width:44px;height:44px;margin-right:1rem}.back-button-fullscreen svg{width:28px;height:28px}.fullscreen-title{font-size:1.25rem}.live-indicator{font-size:1rem}}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:1rem;background:var(--bg-secondary);font-size:.875rem;color:var(--text-secondary)}.status-badge .status-dot{width:8px;height:8px;border-radius:50%;background-color:var(--inactive-color)}.status-badge .status-dot.active{background-color:var(--accent-color);animation:pulse 2s infinite}.image-loading-spinner{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--bg-secondary);border-radius:12px;z-index:1}.image-loading-spinner .loading-spinner{width:40px;height:40px;border:4px solid var(--bg-secondary);border-top:4px solid var(--active-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px}.image-loading-spinner span{color:var(--text-secondary);font-size:14px}.no-image-container{display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--bg-secondary);border-radius:12px;padding:2rem;text-align:center;gap:1rem}.no-image-container svg{color:var(--text-secondary);opacity:.5}.no-image-container p{color:var(--text-secondary);font-size:.875rem;margin:0}.image-loading,.image-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;background-color:#0000000d;border-radius:8px;padding:20px;gap:12px;color:var(--text-secondary)}.image-error{color:var(--error-color)}.image-error svg{width:48px;height:48px;opacity:.7}.config-container{max-width:600px;margin:0 auto;padding:20px;position:relative}.config-title{font-size:24px;font-weight:600;margin-bottom:24px}.config-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;padding:1rem;margin-bottom:1rem}.section-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.config-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.config-item:last-child{border-bottom:none}.config-item span{color:var(--text-primary);font-size:.9rem}.switch{position:relative;display:inline-block;width:48px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-secondary);transition:.4s;border-radius:24px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:2px;bottom:2px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--accent-color)}input:checked+.slider:before{transform:translate(24px)}.device-info{margin-top:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:.5rem}.device-info h3{font-size:1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}.info-item{margin-bottom:1rem}.info-item:last-child{margin-bottom:0}.info-item span{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.info-item code{display:block;padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.25rem;font-family:monospace;font-size:.875rem;color:var(--text-primary);word-break:break-all}.info-help{margin:.5rem 0 0;font-size:.75rem;color:var(--text-secondary);font-style:italic}.logout-button{width:100%;padding:16px;margin-top:32px;border:none;border-radius:12px;background:var(--danger-color);color:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:opacity .2s}.logout-button:active{opacity:.8}.config-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px}.loading-spinner{width:24px;height:24px;border:2px solid var(--spinner-color);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}:root{--text-primary: #000000;--text-secondary: #6e6e73;--section-bg: #f2f2f7;--item-bg: #ffffff;--border-color: rgba(0, 0, 0, .1);--danger-color: #ff3b30;--spinner-color: #8e8e93}[data-theme=dark]{--text-primary: #ffffff;--text-secondary: #98989d;--section-bg: #1c1c1e;--item-bg: #2c2c2e;--border-color: rgba(255, 255, 255, .1);--danger-color: #ff453a;--spinner-color: #98989d}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}.dialog{background:var(--bg-primary);border-radius:12px;padding:1.5rem;width:90%;max-width:400px;box-shadow:0 4px 6px #0000001a}.dialog h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.dialog p{color:var(--text-secondary);margin:0 0 1.5rem}.dialog-actions{display:flex;justify-content:flex-end;gap:1rem}.button{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.button.secondary{background:var(--bg-secondary);color:var(--text-primary)}.button.secondary:hover{background:var(--hover-bg)}.button.primary{background:var(--active-color);color:#fff}.button.primary.danger{background:var(--danger-color)}.button.primary:hover{opacity:.9;transform:translateY(-1px)}.back-button svg{width:24px;height:24px}.notification-status{margin:10px 0;padding:10px;border-radius:4px;font-size:14px;text-align:center;transition:all .3s ease}.notification-status.pending{background-color:#fff3cd;color:#856404;border:1px solid #ffeeba}.notification-status.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.notification-status.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.notification-status.info{background-color:#cce5ff;color:#004085;border:1px solid #b8daff}.send-container{padding:2rem;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}.send-container.dark{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--text-primary: #ffffff;--text-secondary: #a0a0a0;--border-color: #404040;--input-bg: #2d2d2d;--input-border: #404040;--button-bg: #4a90e2;--button-hover: #357abd;--error-color: #ff4d4f}.send-container.light{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--text-primary: #000000;--text-secondary: #595959;--border-color: #d9d9d9;--input-bg: #ffffff;--input-border: #d9d9d9;--button-bg: #1890ff;--button-hover: #40a9ff;--error-color: #ff4d4f}.send-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--text-secondary);border-radius:50%;border-top-color:transparent;animation:spin 1s linear infinite}.back-button{position:absolute;top:2rem;left:2rem;background:none;border:none;cursor:pointer;color:var(--text-primary);padding:.5rem;border-radius:50%;transition:background-color .3s}.back-button:hover{background-color:var(--bg-secondary)}.send-content{max-width:800px;margin:0 auto;padding-top:3rem}.send-content h1{font-size:2rem;margin-bottom:2rem;color:var(--text-primary)}.error-message{display:flex;align-items:center;gap:.5rem;padding:1rem;background-color:#ff4d4f1a;border:1px solid var(--error-color);border-radius:8px;color:var(--error-color);margin-bottom:2rem}.send-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group textarea{padding:.75rem;border:1px solid var(--input-border);border-radius:8px;background-color:var(--input-bg);color:var(--text-primary);font-size:1rem;transition:border-color .3s}.form-group textarea{min-height:100px;resize:vertical}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--button-bg)}.users-list{max-height:300px;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px;padding:.5rem}.user-item{padding:.75rem;border-bottom:1px solid var(--border-color)}.user-item:last-child{border-bottom:none}.checkbox-container{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;width:100%}.checkbox-container input[type=checkbox]{width:18px;height:18px;margin:0}.user-email{font-weight:500;color:var(--text-primary)}.device-count{font-size:.75rem;color:var(--text-secondary);background-color:#0003;padding:.25rem .5rem;border-radius:12px}.devices-list{padding:.5rem}.device-item{padding:.75rem;border-bottom:1px solid var(--border-color);transition:background-color .2s}.device-item:last-child{border-bottom:none}.device-item:hover{background-color:#0000000d}.device-info{margin-left:.5rem}.device-platform{font-size:.875rem;color:var(--text-primary);margin-bottom:.25rem}.device-last-active{font-size:.75rem;color:var(--text-secondary)}button[type=submit]{padding:.75rem 1.5rem;background-color:var(--button-bg);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}button[type=submit]:hover:not(:disabled){background-color:var(--button-hover)}button[type=submit]:disabled{opacity:.6;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.no-users-message{padding:2rem;text-align:center;color:var(--text-secondary);font-size:.875rem;background-color:var(--bg-secondary);border-radius:8px;border:1px dashed var(--border-color)}.user-section{margin-bottom:1.5rem;background-color:var(--bg-secondary);border-radius:8px;overflow:hidden}.user-header{padding:1rem;background-color:#0000001a;display:flex;justify-content:space-between;align-items:center}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.app-content{flex:1;padding:24px;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}:root{--bg-primary: #ffffff;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #eeeeee;--accent-color: #007AFF;--accent-bg: rgba(0, 122, 255, .1)}[data-theme=dark]{--bg-primary: #000000;--text-primary: #ffffff;--text-secondary: #999999;--border-color: #333333;--accent-color: #0A84FF;--accent-bg: rgba(10, 132, 255, .2)}@media (max-width: 768px){.app-content{padding:16px}}@media (max-width: 360px){.app-content{padding:12px}}@media (min-width: 769px) and (max-width: 1024px){.app-content{padding:20px;max-width:90%}}@media (min-width: 1920px){.app-content{max-width:1400px;padding:32px}}@supports (padding: env(safe-area-inset-top)){.app-layout{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}@keyframes slideIn{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes pulse{0%{background-color:#ff3b30}50%{background-color:#ffd60a}to{background-color:#ff3b30}}.panic-alert{position:fixed;top:0;left:0;right:0;z-index:9999;animation:slideIn .3s ease-out,pulse 2s infinite;background-color:#ff3b30;padding:1rem;box-shadow:0 4px 12px #ff3b3066}.panic-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1rem;color:#fff}.panic-icon{flex-shrink:0;width:32px;height:32px}.panic-icon svg{width:100%;height:100%;animation:pulse 2s infinite}.panic-message{flex-grow:1}.panic-message h3{margin:0;font-size:1.25rem;font-weight:700;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.panic-message p{margin:.25rem 0 0;font-size:1rem;opacity:.9}@media (max-width: 768px){.panic-content{padding:0 .5rem}.panic-message h3{font-size:1.1rem}.panic-message p{font-size:.9rem}}.notifications-container{max-width:800px;margin:0 auto;padding:1rem;min-height:100vh}.notifications-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;color:var(--text-secondary)}.loading-spinner{width:32px;height:32px;border:3px solid var(--bg-secondary);border-top-color:var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}.notifications-title{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:2rem 0 1.5rem}.no-notifications{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background:var(--card-bg);border-radius:1rem;gap:1rem;color:var(--text-secondary)}.no-notifications svg{opacity:.5}.notifications-list{display:flex;flex-direction:column;gap:.5rem}.notification-item{display:flex;gap:1rem;padding:1rem;background:var(--card-bg);border-radius:.75rem;border:1px solid var(--border-color);transition:all .2s ease}.notification-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.notification-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--accent-color);border-radius:50%;color:#fff;flex-shrink:0}.notification-content{flex:1}.notification-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.notification-body{color:var(--text-secondary);margin:0 0 .5rem;line-height:1.4}.notification-time{font-size:.875rem;color:var(--text-tertiary)}.back-button{position:fixed;top:20px;left:20px;width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#fff;z-index:1000;border:none}.back-button:hover{background:rgba(0,0,0,.7);transform:scale(1.1)}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.notifications-container{padding:1rem}.notifications-title{font-size:1.5rem;margin:1.5rem 0 1rem}.notification-item{padding:.75rem}.notification-icon{width:32px;height:32px}.notification-title{font-size:1rem}.notification-body{font-size:.9rem}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--text-primary: #000000;--text-secondary: #666666;--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--border-color: #e0e0e0;--active-color: #34c759;--inactive-color: #ff3b30;--gesture-color: #5856d6;--manual-color: #ff9500;--card-shadow: 0 2px 8px rgba(0, 0, 0, .05);--accent-color: #007AFF;--accent-bg: rgba(0, 122, 255, .1);--danger-color: #ff3b30;--success-color: #34c759;--input-bg: rgba(0, 0, 0, .05);--input-bg-focus: rgba(0, 0, 0, .08);--danger-bg: rgba(255, 59, 48, .1);--video-bg: #f2f2f7;--video-text: #000000;--video-text-secondary: #8e8e93;--video-overlay: rgba(0, 0, 0, .4);--video-control-bg: rgba(255, 255, 255, .2);--video-control-hover: rgba(255, 255, 255, .3);--hover-bg: rgba(0, 0, 0, .05);--button-secondary-bg: rgba(0, 0, 0, .05);--text-disabled: #999999}[data-theme=dark]{--text-primary: #ffffff;--text-secondary: #98989d;--bg-primary: #1c1c1e;--bg-secondary: #2c2c2e;--border-color: rgba(255, 255, 255, .1);--active-color: #30d158;--inactive-color: #ff453a;--gesture-color: #5e5ce6;--manual-color: #ff9f0a;--card-shadow: 0 2px 8px rgba(0, 0, 0, .2);--accent-color: #0A84FF;--accent-bg: rgba(10, 132, 255, .2);--danger-color: #ff453a;--success-color: #32d74b;--input-bg: rgba(255, 255, 255, .05);--input-bg-focus: rgba(255, 255, 255, .08);--danger-bg: rgba(255, 69, 58, .2);--video-bg: #1c1c1e;--video-text: #ffffff;--video-text-secondary: #98989d;--video-overlay: rgba(0, 0, 0, .6);--video-control-bg: rgba(0, 0, 0, .4);--video-control-hover: rgba(0, 0, 0, .5);--hover-bg: rgba(255, 255, 255, .1);--button-secondary-bg: rgba(255, 255, 255, .1);--text-disabled: #666666}body{min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overscroll-behavior-y:none;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-secondary);opacity:.2;border-radius:2px}::-webkit-scrollbar-thumb:hover{opacity:.3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ant-card{animation:fadeIn .2s ease-out}@media (max-width: 768px){.ant-card{margin-bottom:12px}.ant-table{font-size:14px}}@supports (padding-bottom: env(safe-area-inset-bottom)){.ant-layout{padding-bottom:env(safe-area-inset-bottom)}}html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}
