@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600&display=swap";:root{--bg-deep:#0f172a;--glass-bg:#1e293b66;--glass-border:#ffffff14;--accent-primary:#6366f1;--accent-secondary:#06b6d4;--text-main:#f8fafc;--text-dim:#94a3b8}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-deep);color:var(--text-main);font-family:Outfit,sans-serif;overflow:hidden}.app-container{flex-direction:column;width:100vw;height:100vh;display:flex}.dashboard-grid{grid-template:"sidebar video"1fr/400px 1fr;gap:16px;height:100%;padding:16px;display:grid}.header{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 28px;display:flex;box-shadow:0 4px 20px #0000004d}.page-content{flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.dashboard-grid{box-sizing:border-box;gap:20px;width:100%;height:100%;min-height:0;padding:20px;display:flex}.placeholder-view{color:var(--text-dim);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.standalone-chat-view{flex:1;justify-content:center;padding:32px;display:flex;overflow:hidden}.standalone-chat-view .chat-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:20px;width:100%;max-width:900px;height:100%;box-shadow:0 8px 32px #0003}.menu-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px;transition:background .2s;display:flex}.menu-btn:hover{background:#ffffff1a}.drawer-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;opacity:0;pointer-events:none;background:#00000080;transition:opacity .3s;position:fixed;inset:0}.drawer-overlay.open{opacity:1;pointer-events:auto}.drawer{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-right:1px solid var(--glass-border);z-index:50;background:#0f172af2;flex-direction:column;width:320px;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:-320px;box-shadow:20px 0 50px #00000080}.drawer.open{transform:translate(320px)}.drawer-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding:24px;display:flex}.drawer-title{color:var(--text-main);font-size:1.2rem;font-weight:600}.close-drawer{color:var(--text-dim);cursor:pointer;background:0 0;border:none}.drawer-items{flex-direction:column;gap:8px;padding:20px 12px;display:flex}.drawer-item{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:16px;padding:16px;font-family:inherit;font-size:1rem;font-weight:500;transition:all .2s;display:flex}.drawer-item:hover{color:var(--text-main);background:#ffffff0d}.drawer-item.active{color:#fff;background:var(--accent-primary);box-shadow:0 4px 15px #6366f166}.logo{letter-spacing:-.5px;background:linear-gradient(90deg,#818cf8,#34d399);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;align-items:center;gap:12px;font-size:1.25rem;font-weight:600;display:flex}.status-bar{gap:12px;display:flex}.status-badge{border:1px solid var(--glass-border);background:#ffffff08;border-radius:20px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.dot{border-radius:50%;width:8px;height:8px;box-shadow:0 0 10px}.dot[data-status=Ready]{color:#10b981;background:#10b981}.dot[data-status=Initializing]{color:#f59e0b;background:#f59e0b;animation:1.5s infinite blink}.dot[data-status=Pending]{color:#64748b;background:#64748b}@keyframes blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.sidebar.left{flex-direction:column;flex-shrink:0;width:350px;height:100%;min-height:0;display:flex}.interaction-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:20px;flex-direction:column;height:100%;display:flex;overflow:hidden;box-shadow:0 8px 32px #0003}.panel-tabs{background:#0003;gap:6px;padding:6px;display:flex}.tab-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.tab-btn:hover{color:var(--text-main);background:#ffffff0d}.tab-btn.active{color:#fff;background:var(--accent-primary);box-shadow:0 4px 15px #6366f166}.content-area{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.chat-panel,.log-panel,.instruction-panel{flex-direction:column;height:100%;padding:20px;display:flex;position:relative}.chat-messages{flex-direction:column;flex:1;gap:12px;padding-right:8px;display:flex;overflow-y:auto}.log-entries{flex-direction:column;gap:12px;display:flex;position:absolute;inset:20px 12px 20px 20px;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:4px}.log-entries::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.log-entries::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.message{border-radius:14px;max-width:85%;padding:12px 16px;font-size:14px;line-height:1.5}.message.user{background:#6366f133;border:1px solid #6366f14d;border-bottom-right-radius:4px;align-self:flex-end}.message.ai{border:1px solid var(--glass-border);background:#ffffff0d;border-bottom-left-radius:4px;align-self:flex-start}.typing-indicator{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:14px 14px 14px 4px;align-self:flex-start;align-items:center;gap:4px;width:max-content;padding:12px 16px;display:flex}.typing-dot{background-color:var(--accent-secondary);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both typingBounce}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}.typing-dot:nth-child(3){animation-delay:0s}@keyframes typingBounce{0%,80%,to{opacity:.3;transform:scale(0)}40%{opacity:1;text-shadow:0 0 10px var(--accent-secondary);transform:scale(1)}}.chat-input-area{border:1px solid var(--glass-border);background:#0003;border-radius:14px;gap:10px;margin-top:16px;padding:8px;display:flex}.chat-input{color:var(--text-main);background:0 0;border:none;outline:none;flex:1;padding:8px 12px;font-family:inherit}.send-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:transform .2s;display:flex}.send-btn:hover{transform:scale(1.05)}.log-entry{border-left:3px solid var(--accent-secondary);background:#ffffff05;border-radius:10px;padding:10px 14px}.log-time{color:var(--accent-secondary);margin-bottom:4px;font-size:11px;font-weight:600;display:block}.instruction-panel textarea{border:1px solid var(--glass-border);width:100%;height:180px;color:var(--text-main);resize:none;background:#0003;border-radius:12px;outline:none;margin-bottom:20px;padding:16px;font-family:inherit;font-size:14px;transition:border-color .2s}.instruction-panel textarea:focus{border-color:var(--accent-secondary)}.frequency-control{border:1px solid var(--glass-border);background:#ffffff08;border-radius:12px;margin-bottom:24px;padding:16px}.frequency-label{color:var(--text-dim);justify-content:space-between;margin-bottom:12px;font-size:14px;display:flex}.frequency-label strong{color:var(--accent-secondary)}.frequency-slider{appearance:none;background:#ffffff1a;border-radius:3px;outline:none;width:100%;height:6px;margin-bottom:8px}.frequency-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-secondary);cursor:pointer;border-radius:50%;width:18px;height:18px;transition:transform .2s;box-shadow:0 0 10px #38bdf866}.frequency-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.frequency-range{color:var(--text-dim);justify-content:space-between;font-size:11px;display:flex}.save-btn{background:var(--accent-secondary);color:#000;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px;font-weight:600;display:flex}.video-main{flex-direction:column;flex:1;height:100%;min-height:0;padding-right:8px;display:flex;overflow-y:auto}.video-main::-webkit-scrollbar{width:8px}.video-main::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.video-main::-webkit-scrollbar-thumb{background:#6366f180;border-radius:4px}.video-main::-webkit-scrollbar-thumb:hover{background:#6366f1cc}.cctv-container{flex:1;grid-template-columns:repeat(4,1fr);gap:12px;padding-bottom:20px;display:grid}.cctv-feed{border:1px solid var(--glass-border);cursor:pointer;background:#000;border-radius:12px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:relative;overflow:hidden}.cctv-feed:hover{border-color:#6366f199;box-shadow:0 0 15px #6366f133}.cctv-feed.active-camera{border:2px solid var(--accent-primary);box-shadow:0 0 20px #6366f166}.cctv-feed.main-feed{grid-area:span 3/span 3}.cctv-feed.dummy-feed{aspect-ratio:16/9;background:#0f172acc}.cam-label{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-dim);z-index:10;border:1px solid var(--glass-border);background:#0009;border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:600;position:absolute;top:12px;left:16px}.main-feed .cam-label{color:var(--accent-secondary);border-color:#06b6d44d}.video-feed{object-fit:contain;width:100%;height:100%}.motion-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#f87171;letter-spacing:1px;background:#ef444433;border:1px solid #ef444466;border-radius:12px;align-items:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:600;animation:2s infinite pulse;display:flex;position:absolute;top:24px;right:24px}.empty-state-small{color:#475569;justify-content:center;align-items:center;height:100%;font-size:.9rem;display:flex}.empty-state{color:#475569;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100%;display:flex}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #ef444466}70%{transform:scale(1.05);box-shadow:0 0 0 10px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}.connector-view{flex-direction:column;flex:1;min-height:0;padding:40px;display:flex;overflow-y:auto}.connector-header{margin-bottom:40px}.connector-header h1{background:linear-gradient(90deg,#6366f1,#06b6d4);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:2.5rem;font-weight:600}.connector-header p{color:var(--text-dim);font-size:1.1rem}.connector-grid{grid-template-columns:1fr 400px;gap:32px;display:grid}.connector-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:24px;padding:32px;box-shadow:0 12px 40px #0003}.card-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.card-header h2{color:var(--text-main);font-size:1.25rem;font-weight:600}.icon-blue{color:var(--accent-secondary)}.icon-purple{color:var(--accent-primary)}.icon-green{color:#10b981}.scan-btn{color:#818cf8;cursor:pointer;background:#6366f11a;border:1px solid #6366f14d;border-radius:12px;justify-content:center;align-items:center;gap:12px;width:100%;margin-bottom:12px;padding:16px;font-weight:600;transition:all .2s;display:flex}.scan-btn:hover:not(:disabled){border-color:var(--accent-primary);background:#6366f133;transform:translateY(-2px)}.scan-btn.scanning{opacity:.7;cursor:wait}.scan-info{color:var(--text-dim);text-align:center;margin-bottom:20px;font-size:12px}.device-list{flex-direction:column;gap:12px;max-height:400px;padding-right:8px;display:flex;overflow-y:auto}.device-item{border:1px solid var(--glass-border);background:#ffffff08;border-radius:12px;justify-content:space-between;align-items:center;padding:16px;transition:background .2s;display:flex}.device-item:hover{background:#ffffff0f}.device-info{align-items:center;gap:16px;display:flex}.device-ip{color:var(--text-main);font-weight:600;display:block}.device-host{color:var(--text-dim);font-size:11px;display:block}.connect-mini-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:600}.manual-input-area{flex-direction:column;gap:12px;display:flex}.manual-input-area input{border:1px solid var(--glass-border);color:var(--text-main);background:#0003;border-radius:12px;outline:none;padding:16px;font-family:inherit}.manual-input-area input:focus{border-color:var(--accent-primary)}.apply-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px;font-weight:600;display:flex}.local-cam-option{text-align:center;margin-top:20px}.text-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;font-size:13px;text-decoration:underline}.active-source-display{background:#10b9811a;border:1px solid #10b98133;border-radius:16px;flex-direction:column;gap:12px;padding:20px;display:flex}.source-tag{color:#10b981;letter-spacing:1px;font-size:10px;font-weight:800}.source-url{color:var(--text-main);word-break:break-all;font-family:monospace;font-size:13px}.spin{animation:2s linear infinite rotate}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=1100px){.connector-grid{grid-template-columns:1fr}}.connector-left-col{flex-direction:column;gap:32px;display:flex}.quick-option:hover{border-color:var(--accent-primary);background:#6366f11a;transform:translateY(-4px);box-shadow:0 8px 24px #6366f133}.quick-option.active{border-color:var(--accent-primary);background:#6366f133;border-width:2px;box-shadow:0 0 20px #6366f14d}.connector-preview-area{aspect-ratio:16/9;border:1px solid var(--glass-border);background:#000;border-radius:16px;justify-content:center;align-items:center;width:100%;margin:20px 0;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 40px #00000080}.mini-preview-container{width:100%;height:100%;position:relative}.mini-video-feed{object-fit:contain;width:100%;height:100%}.mini-preview-placeholder{color:var(--text-dim);opacity:.5;flex-direction:column;align-items:center;gap:12px;display:flex}.live-indicator{color:#fff;letter-spacing:.5px;background:#ef4444cc;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:10px;font-weight:700;display:flex;position:absolute;top:12px;right:12px}.pulse-dot{background:#fff;border-radius:50%;width:6px;height:6px;animation:1.5s infinite pulse-indicator}@keyframes pulse-indicator{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}to{opacity:1;transform:scale(1)}}.quick-connect-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.quick-option{border:1px solid var(--glass-border);text-align:center;cursor:pointer;background:#ffffff08;border-radius:16px;flex-direction:column;align-items:center;padding:20px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.quick-option:hover{background:#ffffff0f;border-color:#6366f166;transform:translateY(-4px)}.quick-option.active{border-color:var(--accent-primary);background:#6366f126;box-shadow:0 0 20px #6366f133}.option-icon{width:48px;height:48px;color:var(--accent-primary);background:#0003;border-radius:12px;justify-content:center;align-items:center;margin-bottom:12px;display:flex}.quick-option.active .option-icon{background:var(--accent-primary);color:#fff}.option-label{margin-bottom:4px;font-size:.9rem;font-weight:600}.option-desc{color:var(--text-dim);font-size:.75rem;line-height:1.4}.quick-option:hover .option-icon{background:var(--accent-primary);color:#fff}.section-desc{color:var(--text-dim);margin-bottom:20px;font-size:.85rem;line-height:1.5}.smart-connect-form{flex-direction:column;gap:16px;display:flex}.input-group{flex-direction:column;gap:8px;display:flex}.input-group label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.input-group input{border:1px solid var(--glass-border);color:var(--text-main);background:#0003;border-radius:10px;outline:none;padding:12px;font-family:inherit;transition:border-color .2s}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{width:100%;padding-right:45px}.password-toggle{color:var(--text-dim);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:color .2s;display:flex;position:absolute;right:12px}.password-toggle:hover{color:var(--text-main)}.refresh-btn{border:1px solid var(--glass-border);color:var(--text-dim);cursor:pointer;background:#ffffff14;border-radius:8px;align-items:center;gap:4px;margin-left:auto;padding:6px 10px;transition:all .2s;display:flex}.refresh-btn:hover{color:var(--text-main);border-color:var(--accent-primary);background:#ffffff26}.refresh-btn:active svg{animation:.5s spin-once}@keyframes spin-once{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.option-label{color:var(--text-main);margin-bottom:4px;font-size:1rem;font-weight:600}.option-desc{color:var(--text-dim);font-size:.8rem}
