@import"https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap";:root{--bg-dark: #0f0f0f;--neon-green: #00ff99;--neon-glow: 0 0 10px rgba(0, 255, 153, .4);--neon-glow-strong: 0 0 20px rgba(0, 255, 153, .6);--card-radius: 14px;--card-shadow: 0 0 20px rgba(0, 255, 153, .15);--font-main: "Segoe UI", "Roboto", sans-serif;--font-size-base: 16px;--input-bg: #1e1e1e;--input-border: #00ff99;--error-color: #ff4d4d;--button-bg: #00ff99;--button-text: #000}body{background-color:var(--bg-dark);font-family:var(--font-main);font-size:var(--font-size-base);color:#fff;margin:0;padding:0}.page-container{padding:80px 20px 40px;min-height:100vh;box-sizing:border-box}.neon-box{background-color:#1a1a1a;border:1px solid var(--neon-green);border-radius:var(--card-radius);box-shadow:var(--card-shadow);padding:1.5rem;margin-bottom:2rem}.neon-btn{background-color:var(--button-bg);color:var(--button-text);border:none;border-radius:20px;padding:10px 24px;font-weight:700;box-shadow:var(--neon-glow);transition:all .2s ease}.neon-btn:hover{background-color:#00e68a;box-shadow:var(--neon-glow-strong);transform:scale(1.03);cursor:pointer}.neon-btn:disabled{opacity:.5;cursor:not-allowed}.neon-input{background-color:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--card-radius);color:#fff;padding:10px;width:100%;box-shadow:inset 0 0 5px #0f93;transition:box-shadow .2s ease}.neon-input:focus{outline:none;box-shadow:0 0 10px var(--neon-green)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.section-header h2{font-size:1.8rem;font-weight:700}.section-header.with-bg{background-color:#141414;padding:1rem;border-bottom:2px solid var(--neon-green);box-shadow:0 0 10px #00ff9926}.section-header.with-bg h2{margin:0;font-size:1.4rem;color:var(--neon-green)}.form-group label{display:block;margin-bottom:5px;color:var(--neon-green)}.form-actions{display:flex;justify-content:space-between;margin-top:2rem}.error-message{background-color:#2a0000;border:1px solid var(--error-color);color:var(--error-color);padding:10px;border-radius:var(--card-radius);margin-bottom:1rem}.pulse-border{animation:pulse-border 1.5s infinite;border:1px solid var(--neon-green)}@keyframes pulse-border{0%{box-shadow:0 0 5px #0f93}50%{box-shadow:0 0 15px #00ff9980}to{box-shadow:0 0 5px #0f93}}html,body,#root{height:100%;overflow-y:auto!important;overflow-x:hidden!important}.neon-toast{background-color:#1a1a1a;border:1px solid var(--neon-green);box-shadow:0 0 10px #0f96;color:#e6ffe6;font-family:var(--font-main);border-radius:var(--card-radius);padding:1rem;font-size:.95rem;line-height:1.4;max-width:400px;margin:0 auto}header{width:100%;height:65px;background-color:#121212;border-radius:12px;border:1px solid #00ff80;box-shadow:0 0 8px #00ff8099;position:fixed;top:0;left:0;z-index:100;display:flex;align-items:center;padding:0 16px;overflow:hidden}.header-content{display:flex;align-items:center;justify-content:space-between;height:100%;width:100%;padding:0;gap:12px}.status-dot{width:12px;height:12px;border-radius:50%;background-color:#00ff80;box-shadow:0 0 6px #00ff80;margin-right:10px;flex-shrink:0}.app-title{display:flex;flex-direction:column;justify-content:center;align-items:center;color:#00ff80;text-shadow:0 0 2px #00ff80;line-height:1.2;margin-left:38px;transform:translate(8px)}.app-title .line1{font-size:18px;font-weight:700}.app-title .line2{font-size:16px}.menu-toggle{display:flex;align-items:left;justify-content:left;height:90%;width:auto;margin-left:0;margin-right:4px}.menu-toggle img{height:80%;width:auto;object-fit:contain}@media (max-width: 600px){.status-dot{width:10px;height:10px}.app-title .line1{font-size:16px}.app-title .line2{font-size:14px}.menu-toggle img{height:65%;max-width:65%}}@media (max-width: 400px){.status-dot{width:8px;height:8px}.app-title .line1{font-size:14px}.app-title .line2{font-size:12px}.menu-toggle img{height:60%;max-width:60%}}.side-menu{position:fixed;top:0;left:-250px;width:250px;height:100vh;background-color:#0000004d!important;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-right:1px solid rgba(255,255,255,.1);padding-top:60px;z-index:50;box-shadow:0 0 15px #00ff8033;transition:all .3s ease-in-out;overflow-y:auto;display:flex;flex-direction:column}.side-menu ul{list-style:none;padding:0;margin:0;flex:1}.side-menu li{padding:0;margin:0;border-left:3px solid transparent}.side-menu li a{display:block;padding:1rem;color:#00ff80!important;text-shadow:0 0 2px #00ff80;text-decoration:none;transition:all .3s ease-in-out;position:relative}.side-menu li a:hover{background-color:#00ff8014;border-left:3px solid #00ff80}.side-menu li a.active{background-color:#00ff801a;border-left:3px solid #00ff80;font-weight:600}.side-menu li i{margin-right:10px;width:20px;text-align:center;position:relative}.sidebar-footer{margin-top:auto;padding:16px;border-top:1px solid rgba(0,255,128,.2);background:#0003;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.user-info{display:flex;flex-direction:column;gap:6px;font-size:.8em}.user-role,.user-plan{padding:4px 8px;border-radius:6px;font-weight:700;text-align:center;font-size:.75em;letter-spacing:.5px;text-transform:uppercase}.user-role{background:#00ff8026;color:#00ff80;text-shadow:0 0 3px #00ff80;border:1px solid rgba(0,255,128,.3)}.user-plan{background:#ff6b0026;color:#ff6b00;text-shadow:0 0 3px #ff6b00;border:1px solid rgba(255,107,0,.3)}.sidebar-separator{margin:16px 0 8px;padding:8px 16px;font-size:.85em;font-weight:700;color:#00ff80b3;text-shadow:0 0 2px rgba(0,255,128,.5);border-bottom:1px solid rgba(0,255,128,.2);text-transform:uppercase;letter-spacing:1px}.sidebar-separator span{position:relative}.sidebar-separator span:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:4px;height:4px;background:#00ff80;border-radius:50%;box-shadow:0 0 4px #00ff80}.logout-item{margin-top:16px;border-top:1px solid rgba(255,255,255,.1);padding-top:16px}.logout-item a{color:#ff6b6b!important;text-shadow:0 0 2px #ff6b6b!important;transition:all .3s ease}.logout-item:hover{border-left:3px solid #ff6b6b!important}.logout-item:hover a{color:#f44!important;text-shadow:0 0 4px #ff4444!important;background-color:#ff6b6b14!important}.side-menu li:has(.user-role){border-left:none!important}.side-menu li:has(.sidebar-separator){border-left:none!important}.side-menu li a[href*=admin]{position:relative;overflow:hidden}.side-menu li a[href*=admin]:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,255,128,.1),transparent);transition:left .5s ease}.side-menu li a[href*=admin]:hover:before{left:100%}.side-menu li a[href="/camera-share"] i:after,.side-menu li a[href="/analytics"] i:after,.side-menu li a[href="/recordings"] i:after{content:"";position:absolute;top:-2px;right:-2px;width:6px;height:6px;background:#00ff80;border-radius:50%;box-shadow:0 0 4px #00ff80;animation:pulse-green 2s infinite}@keyframes pulse-green{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.side-menu.active .sidebar-footer{animation:slideUpFade .5s ease .3s both}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.side-menu::-webkit-scrollbar{width:4px}.side-menu::-webkit-scrollbar-track{background:#0000001a}.side-menu::-webkit-scrollbar-thumb{background:#00ff804d;border-radius:2px}.side-menu::-webkit-scrollbar-thumb:hover{background:#00ff8080}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:49;display:none;transition:var(--transition)}.sidebar-overlay.active{display:block}@media (max-width: 600px){.side-menu{width:200px;left:-200px}.side-menu li a{padding:.8rem;font-size:.9rem}.sidebar-footer{padding:12px}.user-info{font-size:.75em;gap:4px}.user-role,.user-plan{padding:3px 6px;font-size:.7em}.sidebar-separator{padding:6px 12px;font-size:.8em;margin:12px 0 6px}}@media (max-width: 400px){.side-menu{width:80%;left:-80%}.sidebar-footer{padding:10px}.user-info{font-size:.7em}.sidebar-separator{font-size:.75em}}.modal-content{background-color:#121212f2;border:2px solid #39ff14;box-shadow:0 0 12px #39ff144d,0 0 24px #39ff1433,inset 0 0 10px #39ff141a;border-radius:16px;padding:30px;width:90%;max-width:420px;margin:0 auto}.modal-content input{width:100%;padding:12px;margin-top:12px;border:1px solid rgba(57,255,20,.4);background-color:#ffffff08;color:#fff;border-radius:10px;outline:none;transition:border-color .2s,box-shadow .2s}.modal-content input:focus{border-color:#39ff14;box-shadow:0 0 8px #39ff14cc}.modal-content button{margin-top:16px;width:100%;padding:12px;font-weight:700;background-color:#39ff14;color:#000;border:none;border-radius:10px;cursor:pointer;box-shadow:0 0 10px #39ff14aa;transition:background-color .3s,transform .1s}.modal-content button:hover{background-color:#5fff3d;transform:scale(1.02)}.auth-tabs{display:flex;justify-content:space-around;margin-bottom:20px}.auth-tabs button{background:none;border:none;color:#39ff14;font-weight:700;padding:10px 16px;border-bottom:2px solid transparent;cursor:pointer;transition:.2s ease-in-out}.auth-tabs button.active{border-bottom:2px solid #39ff14;color:#fff;text-shadow:0 0 6px #39ff14aa}.recordings-view{background-color:#0006;border:2px solid #39ff14;border-radius:12px;padding:16px;margin-top:24px;color:#39ff14;box-shadow:0 0 20px #39ff14;font-family:Orbitron,sans-serif}.recordings-view h2{font-size:1.6rem;margin-bottom:16px;text-align:center;text-shadow:0 0 4px #39ff14}.recordings-view p{text-align:center;margin-bottom:12px;font-weight:700}.recordings-view ul{list-style:none;padding:0;margin:0}.recordings-view li{display:flex;align-items:center;justify-content:space-between;background:#00ff000d;border-bottom:1px solid #39ff14;padding:10px 12px;transition:background .2s}.recordings-view li:hover{background:#00ff001a}.recordings-view input[type=checkbox]{margin-right:10px;transform:scale(1.2)}.recordings-view button{background:transparent;border:1px solid #39ff14;color:#39ff14;padding:4px 10px;margin-left:6px;border-radius:6px;font-weight:700;cursor:pointer;transition:all .2s ease}.recordings-view button:hover{background:#39ff14;color:#000}.recordings-view button:disabled{opacity:.5;cursor:not-allowed}.btn{font-family:Segoe UI,sans-serif;padding:12px 20px;border:none;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:background-color .3s,box-shadow .2s,transform .1s;box-shadow:0 0 6px #39ff1433}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background-color:#39ff14;color:#000;box-shadow:0 0 10px #39ff14aa}.btn.primary:hover{background-color:#5fff3d;transform:scale(1.03)}.btn.secondary{background-color:transparent;border:2px solid #39ff14;color:#39ff14}.btn.secondary:hover{background-color:#39ff140d;transform:scale(1.02)}.btn.icon{background:none;border:none;color:#39ff14;padding:6px 10px;font-size:1.2rem;display:inline-flex;align-items:center;justify-content:center}.btn.icon:hover{color:#5fff3d}.plan-status-container{background:#0000004d;border:2px solid #39ff14;border-radius:12px;padding:16px;margin:16px auto;color:#39ff14;max-width:480px;text-align:center;box-shadow:0 0 15px #39ff14}.plan-title{font-size:1.4rem;margin-bottom:8px}.plan-details li{list-style:none;margin:6px 0;font-weight:500}.usage-section{margin-top:16px;padding-top:12px;border-top:1px solid rgba(57,255,20,.3)}.usage-title{font-size:1.1rem;margin-bottom:12px;color:#39ff14;font-weight:600}.usage-item{margin-bottom:12px;text-align:left}.usage-item:last-child{margin-bottom:0}.usage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.9rem;font-weight:500}.usage-percentage{font-family:Courier New,monospace;font-weight:600;color:#39ff14;font-size:.85rem}.progress-bar{width:100%;height:6px;background:#39ff1433;border-radius:3px;overflow:hidden;position:relative;border:1px solid rgba(57,255,20,.3)}.progress-fill{height:100%;border-radius:3px;transition:width .8s ease-out;position:relative;background:#39ff14;box-shadow:0 0 8px #39ff14}.progress-fill.good{background:#39ff14;box-shadow:0 0 8px #39ff14}.progress-fill.warning{background:linear-gradient(90deg,#39ff14,#fa0);box-shadow:0 0 8px #fa0}.progress-fill.critical{background:linear-gradient(90deg,#fa0,#ff4757);box-shadow:0 0 8px #ff4757;animation:criticalPulse 1.5s ease-in-out infinite alternate}@keyframes criticalPulse{0%{opacity:.8}to{opacity:1}}.usage-warning{display:block;margin-top:4px;font-size:.75rem;color:#fa0;font-weight:500;text-align:center}.upgrade-alert{margin-top:12px;padding:8px 12px;background:#39ff141a;border:1px solid #39ff14;border-radius:6px;font-size:.9rem;font-weight:600;animation:upgradeGlow 2s ease-in-out infinite alternate}@keyframes upgradeGlow{0%{box-shadow:0 0 5px #39ff14;background:#39ff141a}to{box-shadow:0 0 15px #39ff14;background:#39ff1426}}@media (max-width: 768px){.plan-status-container{margin:12px;padding:12px;max-width:calc(100% - 24px)}.plan-title{font-size:1.2rem}.usage-title{font-size:1rem}.usage-header{font-size:.85rem}.usage-percentage{font-size:.8rem}}@media (max-width: 480px){.usage-header{flex-direction:column;align-items:flex-start;gap:2px}.usage-percentage{align-self:flex-end}}@media (prefers-reduced-motion: reduce){.progress-fill,.upgrade-alert{transition:none;animation:none}.progress-fill.critical{animation:none}}@media (prefers-contrast: high){.plan-status-container{border-width:3px;background:#000c}.progress-bar{border-width:2px}}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a2e,#16213e);color:#fff;padding:85px 0 0;overflow-x:hidden;box-sizing:border-box}.dashboard-content{max-width:1200px;width:100%;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:24px}.neon-box{background:#ffffff05;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:24px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 0 20px #00ffff1a,inset 0 0 20px #00ffff0d;transition:all .3s ease;position:relative;overflow:hidden}.neon-box:hover{border-color:#0ff6;box-shadow:0 0 30px #0ff3,inset 0 0 30px #00ffff1a;transform:translateY(-2px)}.neon-box:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:2px;background:linear-gradient(90deg,transparent,#00ffff,transparent);animation:borderGlow 3s infinite}@keyframes borderGlow{0%{left:-100%}to{left:100%}}.neon-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#00ffff1a,#0064ff1a);border:1px solid rgba(0,255,255,.3);border-radius:8px;color:#0ff;text-decoration:none;font-weight:500;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden;justify-content:center;min-width:180px}.neon-btn:hover{background:linear-gradient(135deg,#0ff3,#0064ff33);border-color:#0ff9;box-shadow:0 0 20px #00ffff4d;transform:translateY(-1px)}.neon-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.neon-btn .btn-icon{font-size:1.1em;margin-right:8px}.logo-container{display:flex;flex-direction:column;align-items:center;margin:20px 0;padding-top:10px}.company-logo{width:150px;height:150px;object-fit:contain;border-radius:10px;margin-bottom:10px;box-shadow:0 0 15px #39ff1433}.company-name{font-size:1.5rem;color:var(--neon-green);text-shadow:0 0 10px rgba(57,255,20,.5);text-align:center}.owner-logo-wrapper{display:flex;justify-content:center;align-items:center;margin:20px 0}.owner-logo{max-height:80px;max-width:200px;width:120px;height:auto;object-fit:contain;border-radius:8px;border:2px solid rgba(0,255,255,.3);box-shadow:0 0 20px #0ff3,0 0 8px #39ff1466,0 0 16px #39ff1433,inset 0 0 6px #39ff141a;background-color:#111;transition:all .3s ease}.owner-logo:hover{transform:scale(1.05);box-shadow:0 0 30px #0ff6}.welcome-section{text-align:center;background:linear-gradient(135deg,#00ffff0d,#ff00ff0d);margin-bottom:30px;position:relative}.welcome-section h2{font-size:2.2em;margin:0 0 12px;background:linear-gradient(45deg,#0ff,#f0f,#ff0);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:gradientShift 4s ease-in-out infinite;color:var(--neon-green)}.welcome-date{font-size:1.1em;color:#fffc;margin:0 0 16px;font-size:.9rem}.user-info{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:16px}.plan-label,.role-label{display:inline-block;padding:6px 16px;border-radius:20px;font-size:.85em;font-weight:600;letter-spacing:1px}.plan-label{background:linear-gradient(135deg,#0f0,#0a0);color:#000;box-shadow:0 0 15px #00ff004d}.role-label{background:linear-gradient(135deg,#ff6b00,#ff9500);color:#fff;box-shadow:0 0 15px #ff6b004d}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.notifications-banner{background:linear-gradient(135deg,#ffc1071a,#ff98001a);border-color:#ffc10766;animation:pulseWarning 2s ease-in-out infinite}.notification-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.notification-header h3{display:flex;align-items:center;gap:8px;margin:0;color:#ffc107;font-size:1.2em}.notification-header i{animation:bellRing 1s ease-in-out infinite}.mark-read-btn{background:transparent;border:1px solid rgba(255,193,7,.5);color:#ffc107;padding:6px 12px;border-radius:6px;cursor:pointer;transition:all .3s ease;font-size:.9em}.mark-read-btn:hover{background:#ffc1071a;border-color:#ffc107}.notification-list{display:flex;flex-direction:column;gap:12px}.notification-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#0003;border-radius:8px;border-left:3px solid #ffc107}.notification-text{flex:1;color:#ffffffe6;font-size:.95em}.notification-time{color:#fff9;font-size:.8em;white-space:nowrap;margin-left:12px}@keyframes pulseWarning{0%,to{box-shadow:0 0 20px #ffc10733}50%{box-shadow:0 0 30px #ffc10766}}@keyframes bellRing{0%,to{transform:rotate(0)}25%{transform:rotate(15deg)}75%{transform:rotate(-15deg)}}.status-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin:24px 0 30px}.status-card{background-color:var(--card-background);border-radius:var(--border-radius);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);min-width:240px;flex:1 1 auto;background:linear-gradient(135deg,#ffffff08,#ffffff03);transition:all .3s ease}.status-card:hover{transform:translateY(-3px);background:linear-gradient(135deg,#ffffff0d,#ffffff05)}.status-icon{background-color:#39ff141a;color:var(--neon-green);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-right:15px;background:linear-gradient(135deg,#0ff,#0080ff);color:#000;font-size:1.5em;box-shadow:0 0 20px #00ffff4d}.status-content{flex:1}.status-content h3{font-size:1.1em;margin:0 0 8px;color:#ffffffe6;font-size:1rem;color:var(--text-secondary)}.status-value{font-size:2em;font-weight:700;margin:0 0 4px;color:#0ff;display:flex;align-items:baseline;gap:8px;font-size:1.8rem;color:var(--neon-green)}.limit-info{font-size:.6em;color:#fff9;font-weight:400}.status-detail{margin:0;font-size:.9em;color:#ffffffb3;font-size:.8rem;color:var(--text-secondary)}.warning-text{margin:4px 0 0;font-size:.85em;color:#ff6b00;font-weight:500;animation:pulseWarning 1.5s ease-in-out infinite}.quick-actions{margin-bottom:30px}.quick-actions h3{margin:0 0 15px;font-size:1.3em;color:#0ff;color:var(--text-color)}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;width:100%}.action-buttons .neon-btn{font-size:1em;width:100%;padding:15px;background-color:#39ff141a;color:var(--neon-green);border:1px solid var(--neon-green);border-radius:var(--border-radius-sm);cursor:pointer;font-size:1rem;font-weight:500;transition:var(--transition);display:flex;justify-content:center;align-items:center;text-decoration:none}.action-btn:hover{background-color:#39ff1433;box-shadow:0 0 10px #39ff144d}.btn-icon{margin-right:10px}.recent-cameras{margin-bottom:30px}.recent-cameras h3{margin:0 0 20px;font-size:1.3em;color:#0ff}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.section-header h3{color:var(--text-color)}.view-all{color:#0ffc;text-decoration:none;font-size:.9em;transition:color .3s ease;color:var(--neon-green);font-size:.9rem}.view-all:hover{color:#0ff}.camera-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.camera-card{background:#ffffff05;border:1px solid rgba(0,255,255,.15);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:all .3s ease;position:relative;background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:var(--shadow);color:var(--text-color);min-width:240px}.camera-card:hover{border-color:#0ff6;transform:translateY(-5px);box-shadow:0 10px 30px #0ff3;box-shadow:0 5px 15px #0000004d}.camera-thumbnail{width:100%;height:180px;position:relative;background-color:#000;overflow:hidden;height:120px}.camera-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.camera-card:hover .camera-thumbnail img{transform:scale(1.05)}.no-thumbnail{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#00000080,#000c);color:#ffffff80;font-size:3em;font-size:2rem;color:var(--neon-green)}.camera-status{position:absolute;font-size:.8em;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#000000b3;color:#fff;font-size:.7rem;padding:3px 8px;border-radius:10px;top:10px;right:10px}.camera-status.online{background:#0f03;color:#0f0;border:1px solid rgba(0,255,0,.5);box-shadow:0 0 10px #00ff004d;background-color:#4caf50cc}.camera-status.offline{background:#ff646433;color:#ff6464;border:1px solid rgba(255,100,100,.5);box-shadow:0 0 10px #ff64644d;background-color:#f44336cc}.camera-info{padding:15px}.camera-info h4{font-size:1.1em;color:#fff;margin:0 0 5px;font-size:1rem}.camera-info p{color:#ffffffb3;font-size:.9em;margin:0;font-size:.8rem;color:var(--text-secondary)}.last-seen{color:#ffffff80;font-size:.8em}.no-cameras{background-color:var(--card-background);border-radius:var(--border-radius);padding:30px;text-align:center}.no-cameras p{margin-bottom:20px;color:var(--text-secondary)}.fancy-no-cameras{text-align:center;background:linear-gradient(135deg,#0003,#0006);border:2px dashed rgba(255,255,255,.2);position:relative;overflow:hidden;background-color:#000;border-radius:12px;margin:30px auto;padding:40px 20px;box-shadow:inset 0 0 10px #00ff6433}.tv-interference{position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,255,255,.02) 2px,rgba(255,255,255,.02) 4px);animation:tvStatic .1s linear infinite;width:100%;height:100%;background-image:repeating-linear-gradient(to bottom,rgba(0,255,100,.04) 0px,rgba(0,255,100,.04) 2px,transparent 2px,transparent 4px),linear-gradient(to right,#00ff9605,#ffffff08,#00ff9605);animation:flicker 1.3s infinite ease-in-out,scanline 5s linear infinite;pointer-events:none;opacity:.5;z-index:0}.no-camera-icon{position:relative;z-index:1;color:#3ef0d5;font-size:1.2rem;margin-bottom:12px}.no-camera-icon i{font-size:4em;color:#ffffff4d;display:block;font-size:2.5rem;margin-bottom:10px;color:#0fc}.no-camera-icon p{font-size:1.2em;color:#fff9;margin:0 0 30px}.add-camera-link{position:relative;z-index:1;color:#00ff80;font-weight:700;text-decoration:underline;transition:color .2s}.add-camera-link:hover{color:#0fa}@keyframes tvStatic{0%{transform:translateY(0)}to{transform:translateY(2px)}}@keyframes flicker{0%,to{opacity:.4}50%{opacity:.15}}@keyframes scanline{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.carousel-upload-section{margin-bottom:30px}.carousel-upload-section h3{margin:0 0 20px;font-size:1.3em;color:#0ff}.upload-area{display:flex;flex-direction:column;gap:16px}.upload-area input[type=file]{padding:12px;background:#0003;border:2px dashed rgba(0,255,255,.3);border-radius:8px;color:#fffc;cursor:pointer;transition:all .3s ease}.upload-area input[type=file]:hover{border-color:#0ff9;background:#00ffff0d}.upload-area input[type=file]:disabled{opacity:.5;cursor:not-allowed}.selected-files{padding:16px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:8px}.selected-files p{margin:0 0 12px;color:#0ff;font-weight:500}.selected-files ul{list-style:none;padding:0;margin:0}.selected-files li{padding:4px 0;color:#fffc;font-size:.9em;border-bottom:1px solid rgba(255,255,255,.1)}.selected-files li:last-child{border-bottom:none}.upload-btn{align-self:flex-start;min-width:180px}.connection-status{position:fixed;bottom:20px;right:20px;z-index:1000}.status-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:25px;font-size:.9em;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid;transition:all .3s ease}.status-indicator.online{background:#00ff001a;color:#0f0;border-color:#00ff004d;box-shadow:0 0 15px #0f03}.status-indicator.offline{background:#ff00001a;color:#f44;border-color:#ff00004d;box-shadow:0 0 15px #f003;animation:pulseOffline 2s ease-in-out infinite}@keyframes pulseOffline{0%,to{opacity:1}50%{opacity:.7}}.loading-state{text-align:center;padding:40px 20px;color:#fff9}.loading-state i{font-size:2em;margin-bottom:16px;color:#0ff;animation:spin 1s linear infinite}.loading-state p{margin:0;font-size:1.1em}.btn{padding:10px 20px;border-radius:var(--border-radius-sm);border:none;cursor:pointer;font-size:.9rem;transition:var(--transition)}.btn.primary{background-color:#39ff1433;color:var(--neon-green);border:1px solid var(--neon-green)}.btn.primary:hover{background-color:#39ff144d;box-shadow:0 0 10px #39ff144d}@media (max-width: 768px){.dashboard-container{padding-top:90px}.dashboard-content{padding:16px;gap:20px}.welcome-section h2{font-size:1.8em}.status-summary{grid-template-columns:repeat(2,1fr);gap:16px;grid-template-columns:1fr}.status-card{padding:16px}.status-icon{width:50px;height:50px;font-size:1.3em}.status-value{font-size:1.6em}.action-buttons{grid-template-columns:1fr}.camera-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-template-columns:1fr}.notification-header{flex-direction:column;align-items:flex-start}.notification-item{flex-direction:column;align-items:flex-start;gap:8px}.connection-status{bottom:10px;right:10px}.user-info{flex-direction:column;align-items:center}.company-logo{width:120px;height:120px}}@media (max-width: 480px){.dashboard-content{padding:12px}.neon-box{padding:16px}.welcome-section h2{font-size:1.5em}.status-summary{grid-template-columns:1fr}.status-value{font-size:1.4em}.camera-grid{grid-template-columns:1fr}.camera-thumbnail{height:150px}.fancy-no-cameras{padding:40px 16px}.no-camera-icon i{font-size:3em}.company-logo{width:120px;height:120px}}.camera-share{padding-top:80px;padding-inline:20px;padding-bottom:40px;color:#0fa;background-color:#0000004d;border-radius:12px;max-width:640px;margin:auto;box-shadow:0 0 10px #0fa2}.camera-share h2{text-align:center;margin-bottom:20px;color:#39ff14;text-shadow:0 0 8px #39ff14aa}.camera-share .form-group{margin-bottom:18px;display:flex;flex-direction:column;gap:8px}.camera-share .form-group.row{flex-direction:row;align-items:center;gap:12px}.camera-share select,.camera-share input,.camera-share textarea{background-color:#ffffff0d;color:#fff;border:1px solid #00ffaa66;border-radius:8px;padding:10px;outline:none;transition:border-color .2s,box-shadow .2s}.camera-share select:focus,.camera-share input:focus,.camera-share textarea:focus{border-color:#0fa;box-shadow:0 0 8px #0faa}.time-window{display:flex;gap:8px;align-items:center}.camera-share textarea{min-height:80px;resize:vertical}.camera-share .qr-result{text-align:center;margin-top:30px}.camera-share .qr-result p{margin-bottom:10px;font-weight:700;color:#0fa;text-shadow:0 0 6px #00ffaa66}.client-view{padding:0;margin:0;background-color:#000;color:#0fc;font-family:Segoe UI,sans-serif;min-height:100vh;display:flex;flex-direction:column;align-items:center}.client-header{background-color:#000;display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid #00ffaa66;width:100%;justify-content:center}.client-header img{height:40px}.client-header h1{font-size:1.4rem;margin:0;color:#0fa}.owner-logo{margin-top:20px}.owner-logo img{height:80px;max-width:180px;object-fit:contain;border-radius:8px;box-shadow:0 0 12px #0fa5}.camera-stream{margin:30px 0 20px;width:90%;max-width:640px;height:360px;background-color:#111;border:2px solid #00ffaa88;border-radius:10px;display:flex;align-items:center;justify-content:center}.stream-placeholder{color:#fff8;font-size:1rem;text-align:center;padding:1em}.carousel{margin-top:30px;width:90%;max-width:640px;display:flex;justify-content:center;align-items:center}.carousel img{width:100%;height:auto;max-height:200px;border-radius:8px;object-fit:contain;border:1px solid #00ffaa55;box-shadow:0 0 12px #0fa3}.camera-controls{margin-top:30px;text-align:center;font-size:.9rem;color:#888}.client-loading,.client-error{color:#fff;text-align:center;padding:40px;font-size:1.2rem}.mi-plan-view{padding:2rem;min-height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a2e,#16213e);color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.mi-plan-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,255,255,.3)}.mi-plan-title{font-size:2.5rem;font-weight:700;background:linear-gradient(45deg,#0ff,#fff,#0ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px rgba(0,255,255,.5);margin:0}.current-plan-badge{padding:.5rem 1rem;border-radius:25px;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:1px;box-shadow:0 0 20px #00ffff4d;border:2px solid}.current-plan-badge.free{background:linear-gradient(45deg,#ffc107,#ffb300);border-color:#ffc107;color:#000}.current-plan-badge.basic{background:linear-gradient(45deg,#28a745,#20c997);border-color:#28a745;color:#fff}.current-plan-badge.premium{background:linear-gradient(45deg,#0ff,#09c);border-color:#0ff;color:#000}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:3rem}.plan-card{background:#0006;border:2px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;position:relative;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden}.plan-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,#00ffff,transparent);opacity:0;transition:opacity .3s ease}.plan-card:hover{transform:translateY(-5px);border-color:#0ff;box-shadow:0 10px 40px #0ff3}.plan-card:hover:before{opacity:1}.plan-card.current{border-color:#0ff;box-shadow:0 0 30px #00ffff4d}.plan-card.current:before{opacity:1}.plan-card.recommended{border-color:#28a745;position:relative}.plan-card.recommended:after{content:"RECOMENDADO";position:absolute;top:-10px;right:20px;background:linear-gradient(45deg,#28a745,#20c997);color:#fff;padding:.25rem 1rem;border-radius:15px;font-size:.8rem;font-weight:700;letter-spacing:1px}.plan-header{text-align:center;margin-bottom:2rem;position:relative}.plan-name{font-size:1.8rem;font-weight:700;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:2px}.plan-name.free{color:#ffc107}.plan-name.basic{color:#28a745}.plan-name.premium{color:#0ff}.plan-price{font-size:3rem;font-weight:800;margin-bottom:.5rem;text-shadow:0 0 20px currentColor}.plan-period{font-size:1rem;opacity:.7;margin-bottom:1rem}.plan-description{font-size:1.1rem;opacity:.8;line-height:1.5}.plan-features{list-style:none;padding:0;margin:2rem 0}.plan-feature{display:flex;align-items:center;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.1);transition:all .3s ease}.plan-feature:hover{background:#00ffff0d;border-radius:8px;border-bottom-color:transparent}.plan-feature:last-child{border-bottom:none}.plan-feature-icon{margin-right:1rem;font-size:1.2rem;width:20px;text-align:center}.plan-feature-icon.included{color:#28a745}.plan-feature-icon.not-included{color:#dc3545}.plan-feature-icon.limited{color:#ffc107}.plan-feature-text{flex:1;font-size:1rem}.plan-feature-text.not-included{opacity:.5;text-decoration:line-through}.plan-actions{margin-top:2rem}.plan-btn{width:100%;padding:1rem 2rem;border:2px solid;border-radius:50px;font-size:1.1rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;background:transparent;text-decoration:none;display:inline-block;text-align:center}.plan-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.plan-btn:hover:before{left:100%}.plan-btn.current{border-color:#6c757d;color:#6c757d;cursor:not-allowed}.plan-btn.free{border-color:#ffc107;color:#ffc107}.plan-btn.free:hover{background:#ffc107;color:#000;box-shadow:0 0 30px #ffc10780}.plan-btn.basic{border-color:#28a745;color:#28a745}.plan-btn.basic:hover{background:#28a745;color:#fff;box-shadow:0 0 30px #28a74580}.plan-btn.premium{border-color:#0ff;color:#0ff}.plan-btn.premium:hover{background:#0ff;color:#000;box-shadow:0 0 30px #00ffff80}.current-usage{background:#0006;border:2px solid rgba(0,255,255,.3);border-radius:20px;padding:2rem;margin-bottom:3rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.usage-title{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;color:#0ff;text-align:center}.usage-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.usage-stat{text-align:center;padding:1rem;background:#0000004d;border-radius:12px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.usage-stat:hover{border-color:#0ff;transform:translateY(-2px)}.usage-stat-value{font-size:2rem;font-weight:700;color:#0ff;margin-bottom:.5rem}.usage-stat-label{font-size:.9rem;opacity:.7;text-transform:uppercase;letter-spacing:1px}.usage-progress{width:100%;height:8px;background:#ffffff1a;border-radius:4px;margin-top:.5rem;overflow:hidden}.usage-progress-bar{height:100%;background:linear-gradient(90deg,#28a745,#0ff);border-radius:4px;transition:width .3s ease}.usage-progress-bar.warning{background:linear-gradient(90deg,#ffc107,#ff6b35)}.usage-progress-bar.danger{background:linear-gradient(90deg,#dc3545,#ff1744)}.faq-section{background:#0006;border:2px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.faq-title{font-size:1.8rem;font-weight:600;margin-bottom:1.5rem;text-align:center;color:#fff}.faq-item{margin-bottom:1rem;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden}.faq-question{padding:1rem 1.5rem;background:#0000004d;cursor:pointer;transition:all .3s ease;border:none;width:100%;text-align:left;color:#fff;font-size:1rem;font-weight:500;display:flex;justify-content:space-between;align-items:center}.faq-question:hover{background:#00ffff1a}.faq-answer{padding:1rem 1.5rem;background:#0003;opacity:.8;line-height:1.6;border-top:1px solid rgba(255,255,255,.1)}.faq-icon{transition:transform .3s ease;color:#0ff}.faq-icon.open{transform:rotate(180deg)}.contact-support{text-align:center;margin-top:3rem;padding:2rem;background:#00ffff0d;border:2px solid rgba(0,255,255,.2);border-radius:20px}.contact-support h3{color:#0ff;margin-bottom:1rem}.contact-support p{opacity:.8;margin-bottom:1.5rem}.contact-btn{padding:.75rem 2rem;background:linear-gradient(45deg,#0ff,#09c);color:#000;border:none;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block}.contact-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0ff6}@media (max-width: 768px){.mi-plan-view{padding:1rem}.mi-plan-header{flex-direction:column;gap:1rem;text-align:center}.mi-plan-title{font-size:2rem}.plans-grid{grid-template-columns:1fr;gap:1.5rem}.plan-card{padding:1.5rem}.usage-stats{grid-template-columns:1fr}.plan-price{font-size:2.5rem}}@media (max-width: 480px){.mi-plan-title{font-size:1.8rem}.plan-card{padding:1rem}.plan-price{font-size:2rem}.current-plan-badge{padding:.4rem .8rem;font-size:.8rem}}@keyframes glow{0%,to{box-shadow:0 0 20px #00ffff4d}50%{box-shadow:0 0 30px #0ff9}}.plan-card.current{animation:glow 2s ease-in-out infinite}@keyframes slideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.plan-card{animation:slideIn .6s ease-out forwards}.plan-card:nth-child(1){animation-delay:.1s}.plan-card:nth-child(2){animation-delay:.2s}.plan-card:nth-child(3){animation-delay:.3s}.plan-activation-container{padding:2rem;max-width:600px;margin:0 auto}.plan-activation-container h2{text-align:center;color:var(--neon-green);text-shadow:0 0 8px var(--neon-green);margin-bottom:1.5rem}.plan-info p{margin:.5rem 0}.loader-container{display:flex;flex-direction:column;align-items:center}.loader{border-radius:50%;animation:spin 1s ease-in-out infinite;margin-bottom:1rem}.loader-message{color:var(--neon-green);font-size:1rem;text-align:center}:root{--neon-green: #39ff14;--dark-background: #121212;--card-background: #1e1e1e;--card-background-lighter: #2a2a2a;--text-color: #ffffff;--text-secondary: #b0b0b0;--primary-color: #1976d2;--primary-dark: #0d47a1;--primary-light: #4791db;--secondary-color: #f50057;--secondary-dark: #c51162;--background-color: #f5f5f5;--card-color: #ffffff;--success-color: #4caf50;--warning-color: #ff9800;--error-color: #f44336;--border-radius: 15px;--border-radius-sm: 8px;--shadow-color: rgba(57, 255, 20, .3);--shadow: 0 2px 10px rgba(0, 0, 0, .1);--shadow-lg: 0 5px 15px rgba(0, 0, 0, .2);--transition-fast: all .2s ease;--transition: all .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Roboto,sans-serif;background-color:var(--dark-background);color:var(--text-color);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{width:100%;max-width:100%;height:100vh;overflow-y:auto;position:relative}header{background-color:#39ff141a;color:#fff;width:100%;z-index:100;position:fixed;top:0;box-shadow:0 2px 5px #0003}.header-content{display:flex;justify-content:space-between;align-items:center;padding:10px 15px}.app-title{font-size:1.5rem;color:var(--neon-green);text-shadow:0 0 10px rgba(57,255,20,.5)}.connection-status{display:flex;align-items:center;font-size:.8rem;margin-right:15px}.status-indicator{margin-right:5px;font-size:1.2rem}.status-indicator.online{color:var(--neon-green)}.status-indicator.offline{color:var(--error-color)}.menu-toggle{display:flex;align-items:center;justify-content:center;width:80px;height:80px;cursor:pointer;position:relative}.menu-toggle img{width:100%;height:100%;object-fit:contain}.side-menu{position:fixed;top:0;left:-250px;width:250px;height:100vh;background-color:var(--card-background);padding-top:60px;z-index:50;box-shadow:var(--shadow);transition:var(--transition)}.side-menu.active{left:0}.side-menu ul{list-style:none}.side-menu li{padding:1rem;cursor:pointer;transition:var(--transition);border-left:3px solid transparent;color:var(--text-color)}.side-menu li:hover{background-color:#39ff141a}.side-menu li.active{background-color:#39ff141a;border-left:3px solid var(--neon-green);font-weight:500}.logo-container{margin:10px auto 0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:5px}.company-logo{width:80px;height:80px;object-fit:contain;border-radius:10px;box-shadow:0 0 10px #00ff644d}.company-name{margin-top:6px;font-size:.9rem;color:#3ef0d5;text-align:center;text-shadow:0 0 4px rgba(0,255,100,.5)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.modal.hidden{display:none}.modal-content{background-color:var(--card-background);padding:20px;border-radius:var(--border-radius);width:90%;max-width:400px;box-shadow:0 0 20px var(--shadow-color)}.tab-container{display:flex;margin-bottom:20px}.tab{flex:1;text-align:center;padding:10px;cursor:pointer;border-bottom:2px solid transparent;color:var(--text-secondary)}.tab.active{color:var(--neon-green);border-bottom:2px solid var(--neon-green)}.form-container{display:none}.form-container.active{display:block}.input-field,input,select{width:100%;padding:12px;margin-bottom:15px;background-color:var(--card-background-lighter);border:1px solid #333;border-radius:var(--border-radius-sm);color:var(--text-color);font-size:1rem;transition:var(--transition)}.input-field:focus,input:focus,select:focus{outline:none;border-color:var(--neon-green);box-shadow:0 0 5px #39ff144d}.form-group{margin-bottom:1rem}label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary)}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.action-btn,.btn.primary{width:100%;padding:12px;background-color:#39ff1433;color:var(--neon-green);border:2px solid var(--neon-green);border-radius:var(--border-radius-sm);cursor:pointer;font-size:1rem;font-weight:700;transition:var(--transition);display:flex;justify-content:center;align-items:center;box-shadow:0 0 10px #39ff1433}.action-btn:hover,.action-btn:active,.btn.primary:hover,.btn.primary:active{background-color:#39ff1466;box-shadow:0 0 15px #39ff1480}.small-action-btn,.btn.secondary{padding:8px 12px;background-color:transparent;color:var(--neon-green);border:1px solid var(--neon-green);border-radius:var(--border-radius-sm);font-size:.9rem;cursor:pointer;transition:var(--transition)}.small-action-btn:hover,.btn.secondary:hover{background-color:#39ff1433}.btn-icon{margin-right:8px;font-size:1.2rem}.back-btn,.btn.back{background:none;border:none;color:var(--neon-green);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.btn.icon{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;background:none;border:none}.btn.icon img{width:24px;height:24px}.stream-container,.video-container{background-color:var(--card-background-lighter);border-radius:var(--border-radius);overflow-y:auto;margin-bottom:1rem;box-shadow:var(--shadow)}#stream-player,.video-placeholder{width:100%;aspect-ratio:16/9;background-color:#000;display:flex;justify-content:center;align-items:center;color:var(--neon-green)}.ptz-controls{padding:1rem;display:flex;justify-content:space-between;background-color:var(--card-background-lighter)}.ptz-directions{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:.5rem;width:120px;height:120px}.ptz-directions button{background-color:#39ff1433;color:var(--neon-green);border:1px solid var(--neon-green);border-radius:50%;width:40px;height:40px;font-size:1.2rem;cursor:pointer;transition:var(--transition)}.ptz-directions button:hover,.ptz-directions button:active{background-color:#39ff1466;box-shadow:0 0 10px #39ff144d}.ptz-up{grid-column:2;grid-row:1}.ptz-left{grid-column:1;grid-row:2}.ptz-right{grid-column:3;grid-row:2}.ptz-down{grid-column:2;grid-row:3}.zoom-controls{display:flex;flex-direction:column;gap:.5rem}.zoom-controls button{background-color:#39ff1433;color:var(--neon-green);border:1px solid var(--neon-green);border-radius:var(--border-radius-sm);width:40px;height:40px;font-size:1.2rem;cursor:pointer;transition:var(--transition)}.zoom-controls button:hover{background-color:#39ff1466;box-shadow:0 0 10px #39ff144d}.camera-controls{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:15px}.control-btn{background-color:#39ff1433;color:var(--neon-green);border:2px solid var(--neon-green);padding:10px;border-radius:10px;cursor:pointer;transition:var(--transition);box-shadow:0 0 10px #39ff1433;text-align:center}.control-btn:hover,.control-btn:active{background-color:#39ff1466;box-shadow:0 0 15px #39ff1480}.share-container{background-color:var(--card-background-lighter);border-radius:var(--border-radius);padding:1.5rem;box-shadow:var(--shadow);margin:0 1rem}.share-container h3{margin-bottom:15px;color:var(--neon-green)}.share-options{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.share-options .form-group{flex:1;min-width:200px}#qr-result{margin-top:1.5rem;text-align:center}#qr-code,#qr-code-container{margin:0 auto 1rem;padding:1rem;background-color:#fff;display:inline-block;border-radius:var(--border-radius)}.qr-info{margin-bottom:1rem;color:var(--text-secondary)}#qr-code canvas{border-radius:4px;padding:5px;background-color:#fff}.shared-list{background-color:var(--card-background-lighter);border-radius:var(--border-radius);overflow-y:auto;box-shadow:var(--shadow);margin:0 1rem}.shared-item{padding:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.shared-item:last-child{border-bottom:none}.shared-camera{font-weight:500;margin-bottom:.25rem}.shared-details{display:flex;justify-content:space-between;flex-wrap:wrap;font-size:.85rem;color:var(--text-secondary)}.shared-active{color:var(--neon-green);font-weight:500}.shared-expired{color:var(--error-color)}.settings-list{background-color:var(--card-background-lighter);border-radius:var(--border-radius);overflow-x:hidden;box-shadow:var(--shadow);margin:0 1rem}.setting-item{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.setting-item:last-child{border-bottom:none}.setting-item h3{margin-bottom:15px;color:var(--neon-green)}.advertising-carousel{position:relative;height:150px;overflow-x:auto;margin:10px 0;border-radius:var(--border-radius);box-shadow:var(--shadow)}.ad-slide{position:absolute;width:100%;height:100%;opacity:0;transition:opacity .5s ease-in-out}.ad-slide.active{opacity:1}.ad-slide img{width:100%;height:100%;object-fit:cover}.swiper{width:100%;height:100%}.swiper-slide{text-align:center;display:flex;justify-content:center;align-items:center}.swiper-slide img{width:100%;height:100%;object-fit:cover}.swiper-pagination-bullet{background-color:#ffffffb3}.swiper-pagination-bullet-active{background-color:var(--neon-green)}.carousel-settings{padding:15px;margin-bottom:15px;background-color:var(--card-background-lighter);border-radius:var(--border-radius)}.carousel-images{padding:15px;background-color:var(--card-background-lighter);border-radius:var(--border-radius)}.carousel-images h3{margin-bottom:15px;color:var(--neon-green)}.image-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:15px}.image-item{border-radius:var(--border-radius-sm);overflow-x:hidden;position:relative;aspect-ratio:16/9}.image-item img{width:100%;height:100%;object-fit:cover}.image-actions{position:absolute;top:5px;right:5px;display:flex;gap:5px}.image-actions button{width:30px;height:30px;border-radius:50%;background-color:#000000b3;color:#fff;border:none;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.image-actions button:hover{background-color:#39ff14b3}@keyframes spin{to{transform:rotate(360deg)}}.no-scroll{overflow-x:hidden}.custom-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%) translateY(100px);background:#000000d9;color:#fff;padding:12px 24px;border-radius:10px;font-size:14px;z-index:9999;opacity:0;transition:all .3s ease;box-shadow:0 2px 10px #39ff1466;max-width:90%;text-align:center}.custom-toast.visible{transform:translate(-50%) translateY(0);opacity:1}.custom-toast.success{background-color:#4caf50}.custom-toast.error{background-color:#f44336}.custom-toast.warning{background-color:#ff9800}.custom-toast.info{background-color:#2196f3}.persistent-overlay-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;pointer-events:none}.persistent-overlay-container>*{pointer-events:auto}.preact-persistent-overlay-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;background-color:#00000080;display:flex;justify-content:center;align-items:center;pointer-events:auto}.preact-overlay-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;background-color:#00000080;display:flex;justify-content:center;align-items:center}.preact-overlay-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;background-color:#00000080;display:flex;justify-content:center;align-items:center;pointer-events:auto}.global-loading-indicator{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.loading-content{background:#fff;padding:20px 30px;border-radius:8px;box-shadow:0 2px 15px #0003;text-align:center}.spinner{width:40px;height:40px;margin:0 auto 15px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}.loading-text{color:#333;font-weight:700}.view{padding-top:80px;padding-left:1rem;padding-right:1rem;box-sizing:border-box}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
