:root{--color-bg-primary: #0f172a;--color-bg-secondary: #1e293b;--color-bg-tertiary: #334155;--color-border: #334155;--color-text-primary: #f1f5f9;--color-text-secondary: #cbd5e1;--color-accent-blue: #059669;--color-accent-blue-dark: #047857;--color-accent-purple: #10b981;--color-accent-cyan: #14b8a6;--color-success: #10b981;--color-traffic-low: #34d399;--color-traffic-medium: #fbbf24;--color-traffic-warning: #fb923c;--color-traffic-heavy: #f87171;--color-alert-badge: #ef4444;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-glow-blue: 0 0 20px rgba(5, 150, 105, .4);--shadow-glow-purple: 0 0 30px rgba(16, 185, 129, .4);--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--transition-fast: all .3s cubic-bezier(.4, 0, .2, 1);--transition-smooth: all .5s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width: 300px}.theme-light{--color-bg-primary: #f9fbfd;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f0f4f8;--color-border: #e2e8f0;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-accent-blue: #059669;--color-accent-blue-dark: #047857;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .15);--shadow-glow-blue: 0 0 20px rgba(5, 150, 105, .15)}.theme-light .logo-text{background:linear-gradient(135deg,var(--color-accent-blue),var(--color-accent-blue-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.theme-light body{background:var(--color-bg-primary)}.theme-light .sidebar{background:var(--color-bg-secondary);border-right:1px solid var(--color-border)}.theme-light .search-box input{background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-primary)}.theme-light .intersection-item{background-color:var(--color-bg-secondary);border:1px solid var(--color-border)}.theme-light .intersection-item:hover{background-color:var(--color-bg-tertiary)}.theme-light .segment-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border)}.theme-light .trend-chart{background-color:var(--color-bg-tertiary);border:1px dashed var(--color-border)}.theme-light .filter-controls select{background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23475569"><path d="M7 10l5 5 5-5z"/></svg>');background-color:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}.theme-light .custom-select{background-color:var(--color-bg-secondary);border-color:var(--color-border)}.theme-light .custom-select:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-accent-blue)}.theme-light .login-form input{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}.theme-light .account-settings-grid .form-group small{color:var(--color-text-secondary)}.theme-light .ai-window{background:var(--color-bg-secondary);border:1px solid var(--color-border);box-shadow:0 10px 25px #0000001a}.theme-light .ai-header,.theme-light .msg.bot{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.theme-light .ai-input-area input{background:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border)}*{box-sizing:border-box;margin:0;padding:0}body:before{content:"";position:fixed;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(5,150,105,.1) 0%,transparent 70%);animation:rotate 30s linear infinite;pointer-events:none;z-index:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);color:var(--color-text-primary);font-size:16px;line-height:1.6;transition:background .5s ease,color .3s;position:relative;overflow-x:hidden}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes alertPulse{0%{box-shadow:0 0 #ef4444b3;transform:scale(1)}70%{box-shadow:0 0 0 10px #ef444400;transform:scale(1.05)}to{box-shadow:0 0 #ef444400;transform:scale(1)}}@keyframes statusDotPulse{0%{transform:scale(.8);box-shadow:0 0 0 0 currentColor}50%{transform:scale(1.1);box-shadow:0 0 0 4px #fff0}to{transform:scale(.8);box-shadow:0 0 0 0 currentColor}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes spin{to{transform:rotate(360deg)}}h1,h2,h3{font-family:Montserrat,sans-serif;color:var(--color-text-primary)}.app{display:flex;height:100vh;overflow:hidden;border-radius:var(--radius-xl);box-shadow:0 20px 60px #00000080,var(--shadow-glow-blue);margin:20px;position:relative;z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .6s ease-out}.app-layout{display:flex;height:100vh;overflow:hidden;background:var(--color-bg-primary)}.app-loading{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:18px;flex-direction:column;gap:16px}.app-loading:after{content:"";width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-accent-blue);border-radius:50%;animation:spin 1s linear infinite}.app-loading-spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-accent-blue);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px;margin-right:10px}.login-container{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;align-items:center;justify-content:center;padding:20px;font-family:Inter,sans-serif}.login-card{background:#1e293bb3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:48px 56px;border-radius:20px;box-shadow:0 25px 50px #00000080;width:100%;max-width:440px;border:1px solid rgba(255,255,255,.1)}.login-header{text-align:center;margin-bottom:32px}.login-title{color:#f8fafc;font-size:32px;font-weight:700;margin:0 0 12px;font-family:Montserrat,sans-serif}.login-subtitle{color:#94a3b8;font-size:16px;margin:0}.login-error{background:#ef44441a;color:#fca5a5;padding:14px 16px;border-radius:10px;margin-bottom:24px;font-size:14px;border:1px solid rgba(239,68,68,.2)}.login-form .form-group{margin-bottom:20px}.login-form label{display:block;margin-bottom:8px;font-weight:600;color:#e2e8f0;font-size:14.5px}.login-form input{width:100%;padding:14px 16px;background:#0f172a;border:1.5px solid #334155;border-radius:10px;font-size:16px;transition:all .2s ease;color:#f1f5f9}.login-form input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f626}.login-submit{width:100%;padding:15px;background:#2563eb;color:#fff;border:none;border-radius:10px;font-size:17px;font-weight:600;cursor:pointer;transition:all .25s ease;margin-top:8px}.login-submit:hover{background:#1d4ed8;transform:translateY(-1px)}.login-submit:disabled{background:#334155;color:#94a3b8;cursor:not-allowed;transform:none}.login-toggle{text-align:center;margin-top:28px;color:#94a3b8;font-size:15px}.login-toggle button{color:#60a5fa;background:none;border:none;font-weight:600;cursor:pointer;padding:0;margin-left:4px;text-decoration:underline;text-underline-offset:3px}.login-footer{text-align:center;margin-top:25px;font-size:14px;color:#94a3b8}.login-footer button{background:none;border:none;color:#60a5fa;font-weight:600;cursor:pointer;margin-left:5px;transition:color .2s}.login-footer button:hover{color:#93c5fd;text-decoration:underline}.login-hint{margin-top:24px;padding:16px;background:#0f172a80;border-radius:12px;font-size:13.5px;color:#cbd5e1;border:1px solid #334155}.login-hint strong{color:#f1f5f9}.bg-glow-1,.bg-glow-2{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;z-index:0;animation:float 10s infinite ease-in-out}.bg-glow-1{width:300px;height:300px;background:#04785b;top:-50px;left:-50px}.bg-glow-2{width:400px;height:400px;background:#03801a;bottom:-100px;right:-100px;animation-delay:-5s}.sidebar-user-info{margin-top:auto;padding:20px 0 10px;border-top:1px solid var(--color-border)}.account-settings-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:30px}.account-info-group{display:flex;flex-direction:column;gap:30px}.account-settings-grid .segment-card{padding:30px}.account-settings-grid .login-submit{padding:14px 20px;font-size:16px;font-weight:600}.account-settings-grid .form-group small{font-size:13px;color:var(--color-text-secondary)}.avatar-upload-file-input{display:block;width:100%;padding:10px 0;margin-bottom:15px;color:var(--color-text-secondary);border:1px dashed var(--color-border);border-radius:8px;text-align:center;cursor:pointer;background-color:var(--color-bg-tertiary)}.hidden-file-input{display:none}.sidebar-user-avatar .icon-user-placeholder{width:28px;height:28px;color:var(--color-text-secondary)}.sidebar-user-card{position:relative;cursor:pointer;border-radius:var(--radius-md);transition:var(--transition-fast);padding:12px;margin:0 -12px;display:flex;align-items:center;gap:10px}.sidebar-user-card:hover,.sidebar-user-card.active-dropdown{background-color:var(--color-bg-tertiary)}.sidebar-user-avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0}.icon-chevron{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M7 10l5 5 5-5z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M7 10l5 5 5-5z"/></svg>');width:1.4em;height:1.4em;color:var(--color-text-secondary);transition:transform .3s ease}.icon-chevron.open{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;bottom:calc(100% + 10px);left:0;width:280px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;padding:10px 0;animation:fadeIn .2s ease-out,slideInUp .3s cubic-bezier(.175,.885,.32,1.275);transform-origin:bottom}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header-compact{display:flex;align-items:center;gap:12px;padding:10px 15px;margin-bottom:10px;border-bottom:1px solid var(--color-border)}.user-info-text{overflow:hidden;min-width:0}.user-info-text strong{display:block;font-size:15px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info-text small{display:block;font-size:12px;color:var(--color-text-secondary)}.dropdown-item{display:flex;align-items:center;width:100%;padding:12px 15px;background:none;border:none;color:var(--color-text-primary);font-size:15px;text-align:left;cursor:pointer;transition:var(--transition-fast);gap:12px}.dropdown-item:hover,.dropdown-item:focus{background-color:var(--color-bg-tertiary);color:var(--color-accent-blue);outline:none}.dropdown-item.logout{color:var(--color-traffic-heavy)}.dropdown-item.logout:hover{background-color:#ef44441a;color:var(--color-traffic-heavy)}.dropdown-divider{height:1px;background-color:var(--color-border);margin:8px 0}.icon-settings-dropdown{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M19.43 12.98c.04-.32.07-.64.07-.98s-.03-.66-.07-.98l2.11-1.65c.24-.19.26-.54.02-.75l-1.89-3.28a.75.75 0 00-.8-.33l-2.49 1c-.52-.38-1.09-.72-1.71-.97L14 3.46c-.05-.24-.27-.42-.5-.46l-4-1.39c-.23-.04-.46.1-.5.35L8.2 4.03c-.62.25-1.19.59-1.71.97l-2.49-1c-.23-.09-.48.0-.61.22l-1.89 3.28a.75.75 0 00.02.75l2.11 1.65c-.04.32-.07.64-.07.98s.03.66.07.98l-2.11 1.65c-.24.19-.26.54-.02.75l1.89 3.28a.75.75 0 00.8.33l2.49-1c.52.38 1.09.72 1.71.97l.31 2.51c.05.24.27.42.5.46l4 1.39c.23.04.46-.1.5-.35l.31-2.51c.62-.25 1.19-.59 1.71-.97l2.49 1c.23.09.48.0.61-.22l1.89-3.28a.75.75 0 00-.02-.75l-2.11-1.65zM12 15.5c-1.93 0-3.5-1.57-3.5-3.5s1.57-3.5 3.5-3.5 3.5 1.57 3.5 3.5-1.57 3.5-3.5 3.5z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M19.43 12.98c.04-.32.07-.64.07-.98s-.03-.66-.07-.98l2.11-1.65c.24-.19.26-.54.02-.75l-1.89-3.28a.75.75 0 00-.8-.33l-2.49 1c-.52-.38-1.09-.72-1.71-.97L14 3.46c-.05-.24-.27-.42-.5-.46l-4-1.39c-.23-.04-.46.1-.5.35L8.2 4.03c-.62.25-1.19.59-1.71.97l-2.49-1c-.23-.09-.48.0-.61.22l-1.89 3.28a.75.75 0 00.02.75l2.11 1.65c-.04.32-.07.64-.07.98s.03.66.07.98l-2.11 1.65c-.24.19-.26.54-.02.75l1.89 3.28a.75.75 0 00.8.33l2.49-1c.52.38 1.09.72 1.71.97l.31 2.51c.05.24.27.42.5.46l4 1.39c.23.04.46-.1.5-.35l.31-2.51c.62-.25 1.19-.59 1.71-.97l2.49 1c.23.09.48.0.61-.22l1.89-3.28a.75.75 0 00-.02-.75l-2.11-1.65zM12 15.5c-1.93 0-3.5-1.57-3.5-3.5s1.57-3.5 3.5-3.5 3.5 1.57 3.5 3.5-1.57 3.5-3.5 3.5z"/></svg>')}.icon-moon-dropdown{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 3a9 9 0 009 9c0 4.39-3.08 8.05-7.23 8.88C15.42 18.78 16 16.5 16 14.5c0-4.47-4-8.09-8.94-8.09-1.91 0-3.7.53-5.26 1.44C3.95 3.73 7.6 1 12 1s8.43 2.73 9.77 6.47C20.37 5.17 17.5 3 14.5 3c-4.66 0-8.52 3.73-8.87 8.36C7.3 9.4 9.4 8.5 11.5 8.5c4.75 0 8.5 3.75 8.5 8.5 0 2.65-1.2 5.01-3.06 6.57C19.7 21.61 22 18.52 22 15.5c0-4.66-3.73-8.52-8.36-8.87C13.6 5.3 11.5 3 9.5 3c-4.47 0-8.09 4-8.09 8.94C1.91 14.7 2.44 16.5 3.35 18.06z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 3a9 9 0 009 9c0 4.39-3.08 8.05-7.23 8.88C15.42 18.78 16 16.5 16 14.5c0-4.47-4-8.09-8.94-8.09-1.91 0-3.7.53-5.26 1.44C3.95 3.73 7.6 1 12 1s8.43 2.73 9.77 6.47C20.37 5.17 17.5 3 14.5 3c-4.66 0-8.52 3.73-8.87 8.36C7.3 9.4 9.4 8.5 11.5 8.5c4.75 0 8.5 3.75 8.5 8.5 0 2.65-1.2 5.01-3.06 6.57C19.7 21.61 22 18.52 22 15.5c0-4.66-3.73-8.52-8.36-8.87C13.6 5.3 11.5 3 9.5 3c-4.47 0-8.09 4-8.09 8.94C1.91 14.7 2.44 16.5 3.35 18.06z"/></svg>')}.icon-logout-dropdown{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M17 7l-1.41 1.41L18.17 11H8v2h10.17l-2.58 2.58L17 17l5-5-5-5zM4 5h8V3H4c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h8v-2H4V5z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M17 7l-1.41 1.41L18.17 11H8v2h10.17l-2.58 2.58L17 17l5-5-5-5zM4 5h8V3H4c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h8v-2H4V5z"/></svg>')}.sidebar-user-details{flex:1;margin-right:0}.btn-logout{margin-left:auto}.sidebar-user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-preview-large{width:120px;height:120px;border-radius:50%;background-color:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;border:3px solid var(--color-accent-blue);box-shadow:var(--shadow-md)}.avatar-preview-large .icon-user-placeholder{width:80px;height:80px;color:var(--color-text-secondary)}.avatar-preview-large img{width:100%;height:100%;object-fit:cover}.sidebar-user-details{flex:1}.sidebar-user-name{font-weight:600;font-size:15px;color:var(--color-text-primary);margin-bottom:2px}.sidebar-user-role{font-size:13px;color:var(--color-text-secondary);opacity:.9}.btn-logout{padding:9px 16px;background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:10px;font-size:13.5px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-logout:hover{background:#ef444440;border-color:#ef444480;transform:translateY(-1px)}.sidebar{position:relative;z-index:1000!important;width:var(--sidebar-width);background:linear-gradient(180deg,#1e293bf2,#0f172af2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:30px 24px;border-right:1px solid rgba(5,150,105,.2);display:flex;flex-direction:column;overflow:hidden}.sidebar-list-header{display:flex;justify-content:space-between;align-items:center;margin:25px 0 15px;padding:0 5px}.sidebar-list-header .list-title{margin-bottom:0;padding-left:5px;font-size:12px;letter-spacing:1px;color:var(--color-text-secondary)}.btn-add-new{background-color:var(--color-accent-blue);color:#fff;border:none;border-radius:4px;padding:6px 12px;cursor:pointer;font-size:12px;font-weight:700;transition:all .2s;flex-shrink:0}.btn-add-new:hover{opacity:.9;transform:translateY(-1px)}.resizer-handle{position:absolute;top:0;right:0;width:5px;height:100%;cursor:col-resize;z-index:10}.item-actions-group{display:flex;flex-direction:column;gap:6px;margin-left:8px;opacity:0;visibility:hidden;transition:opacity .2s}.intersection-item:hover .item-actions-group{opacity:1;visibility:visible}.btn-icon-action{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-size:14px;transition:all .2s}.btn-icon-action.edit:hover{border-color:var(--color-accent-blue);color:var(--color-accent-blue)}.btn-icon-action.delete{background:#ef44441a;border-color:#ef444433;color:var(--color-traffic-heavy)}.btn-icon-action.delete:hover{background:#ef444433;border-color:var(--color-traffic-heavy)}.icon-settings{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M19.4 12.98c.04-.32.06-.65.06-1s-.02-.68-.06-1l2.12-1.64c.2-.15.25-.43.12-.66l-2-3.46c-.12-.22-.38-.31-.61-.22l-2.49 1c-.52-.38-1.09-.72-1.71-.97L14 3.46c-.05-.24-.27-.42-.5-.46l-4-1.39c-.23-.04-.46.1-.5.35L8.2 4.03c-.62.25-1.19.59-1.71.97l-2.49-1c-.23-.09-.48.0-.61.22l-2 3.46c-.12.23-.08.51.12.66l2.12 1.64c-.04.32-.06.65-.06 1s.02.68.06 1l-2.12 1.64c-.2.15-.25.43-.12.66l2 3.46c.12.22.38.31.61.22l2.49-1c.52.38 1.09.72 1.71.97l.31 2.51c.05.24.27.42.5.46l4 1.39c.23.04.46-.1.5-.35l.31-2.51c.62-.25 1.19-.59 1.71-.97l2.49 1c.23.09.48.0.61-.22l2-3.46c.12-.23.08-.51-.12-.66l-2.12-1.64zM12 15.5c-1.93 0-3.5-1.57-3.5-3.5s1.57-3.5 3.5-3.5 3.5 1.57 3.5 3.5-1.57 3.5-3.5 3.5z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M19.4 12.98c.04-.32.06-.65.06-1s-.02-.68-.06-1l2.12-1.64c.2-.15.25-.43.12-.66l-2-3.46c-.12-.22-.38-.31-.61-.22l-2.49 1c-.52-.38-1.09-.72-1.71-.97L14 3.46c-.05-.24-.27-.42-.5-.46l-4-1.39c-.23-.04-.46.1-.5.35L8.2 4.03c-.62.25-1.19.59-1.71.97l-2.49-1c-.23-.09-.48.0-.61.22l-2 3.46c-.12.23-.08.51.12.66l2.12 1.64c-.04.32-.06.65-.06 1s.02.68.06 1l-2.12 1.64c-.2.15-.25.43-.12.66l2 3.46c.12.22.38.31.61.22l2.49-1c.52.38 1.09.72 1.71.97l.31 2.51c.05.24.27.42.5.46l4 1.39c.23.04.46-.1.5-.35l.31-2.51c.62-.25 1.19-.59 1.71-.97l2.49 1c.23.09.48.0.61-.22l2-3.46c.12-.23.08-.51-.12-.66l-2.12-1.64zM12 15.5c-1.93 0-3.5-1.57-3.5-3.5s1.57-3.5 3.5-3.5 3.5 1.57 3.5 3.5-1.57 3.5-3.5 3.5z"/></svg>')}.icon-bell{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 22c1.1 0 2-.9 2-2h-4c0 1.1.9 2 2 2zm6-6v-5c0-3.07-1.63-5.64-4.5-6.32V4c0-.83-.67-1.5-1.5-1.5s-1.5.67-1.5 1.5v.68C7.63 5.36 6 7.93 6 11v5l-2 2v1h16v-1l-2-2z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 22c1.1 0 2-.9 2-2h-4c0 1.1.9 2 2 2zm6-6v-5c0-3.07-1.63-5.64-4.5-6.32V4c0-.83-.67-1.5-1.5-1.5s-1.5.67-1.5 1.5v.68C7.63 5.36 6 7.93 6 11v5l-2 2v1h16v-1l-2-2z"/></svg>')}.icon-moon{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 3a9 9 0 009 9c0 4.39-3.08 8.05-7.23 8.88C15.42 18.78 16 16.5 16 14.5c0-4.47-4-8.09-8.94-8.09-1.91 0-3.7.53-5.26 1.44C3.95 3.73 7.6 1 12 1s8.43 2.73 9.77 6.47C20.37 5.17 17.5 3 14.5 3c-4.66 0-8.52 3.73-8.87 8.36C7.3 9.4 9.4 8.5 11.5 8.5c4.75 0 8.5 3.75 8.5 8.5 0 2.65-1.2 5.01-3.06 6.57C19.7 21.61 22 18.52 22 15.5c0-4.66-3.73-8.52-8.36-8.87C13.6 5.3 11.5 3 9.5 3c-4.47 0-8.09 4-8.09 8.94C1.91 14.7 2.44 16.5 3.35 18.06z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 3a9 9 0 009 9c0 4.39-3.08 8.05-7.23 8.88C15.42 18.78 16 16.5 16 14.5c0-4.47-4-8.09-8.94-8.09-1.91 0-3.7.53-5.26 1.44C3.95 3.73 7.6 1 12 1s8.43 2.73 9.77 6.47C20.37 5.17 17.5 3 14.5 3c-4.66 0-8.52 3.73-8.87 8.36C7.3 9.4 9.4 8.5 11.5 8.5c4.75 0 8.5 3.75 8.5 8.5 0 2.65-1.2 5.01-3.06 6.57C19.7 21.61 22 18.52 22 15.5c0-4.66-3.73-8.52-8.36-8.87C13.6 5.3 11.5 3 9.5 3c-4.47 0-8.09 4-8.09 8.94C1.91 14.7 2.44 16.5 3.35 18.06z"/></svg>')}.icon-traffic{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 1L9 7h6zm0 2.2L13.8 6H10.2zM7 8h10l-1 2H8zm-.83 3h11.66L18 13H6zm-1.17 3h14l-1 2H4zM3 17h18l-1 2H4zM2 20h20v1H2z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 1L9 7h6zm0 2.2L13.8 6H10.2zM7 8h10l-1 2H8zm-.83 3h11.66L18 13H6zm-1.17 3h14l-1 2H4zM3 17h18l-1 2H4zM2 20h20v1H2z"/></svg>')}.icon-dashboard{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M3 13h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm4 4h14v-2H7v2zm0 4h14v-2H7v2zm0-8h14V7H7v2z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M3 13h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm4 4h14v-2H7v2zm0 4h14v-2H7v2zm0-8h14V7H7v2z"/></svg>')}.icon-search{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M15.5 14h-.79l-.28-.27A6.471 6.471 0 0016 9.5a6.5 6.5 0 10-6.5 6.5c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M15.5 14h-.79l-.28-.27A6.471 6.471 0 0016 9.5a6.5 6.5 0 10-6.5 6.5c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/></svg>')}.theme-toggle-btn{position:absolute;right:0;background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:5px;border-radius:var(--radius-md);transition:var(--transition-fast)}.theme-toggle-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-accent-blue)}.theme-light .theme-toggle-btn:hover{background-color:var(--color-bg-tertiary)}.theme-toggle-btn .icon{width:1.4em;height:1.4em;background-color:currentColor}.logo-text{font-size:24px;font-weight:800;margin-left:12px;background:linear-gradient(135deg,var(--color-accent-blue),var(--color-accent-purple),var(--color-accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.5px;text-shadow:0 0 30px rgba(5,150,105,.5);animation:pulse 2s ease-in-out infinite}.search-box{margin-bottom:30px;margin-top:50px;position:relative}.search-box input{width:100%;padding:14px 16px 14px 45px;background:#1e293b99;border:1px solid rgba(5,150,105,.3);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:15px;outline:none;transition:var(--transition-fast);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.theme-light .search-box input{background:var(--color-bg-primary);border:1px solid var(--color-border);color:var(--color-text-primary)}.search-box input:focus{border-color:var(--color-accent-blue);box-shadow:var(--shadow-sm)}.search-icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);pointer-events:none}.list-title{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;margin-bottom:15px;letter-spacing:1px;padding-left:10px}.intersection-list{list-style:none;padding:0 5px 0 0;flex-grow:1;overflow-y:auto}.intersection-list::-webkit-scrollbar,.main-content::-webkit-scrollbar,.ch-grid::-webkit-scrollbar{width:6px;height:6px}.intersection-list::-webkit-scrollbar-track,.main-content::-webkit-scrollbar-track,.ch-grid::-webkit-scrollbar-track{background:#0f172a1a;border-radius:10px}.intersection-list::-webkit-scrollbar-thumb,.main-content::-webkit-scrollbar-thumb,.ch-grid::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--color-accent-blue) 0%,var(--color-accent-purple) 100%);border-radius:10px;border:1px solid rgba(255,255,255,.05)}.intersection-list::-webkit-scrollbar-thumb:hover,.main-content::-webkit-scrollbar-thumb:hover,.ch-grid::-webkit-scrollbar-thumb:hover{background:var(--color-accent-cyan);box-shadow:0 0 8px var(--color-accent-cyan)}.intersection-list{scrollbar-width:thin;scrollbar-color:var(--color-accent-blue) transparent}.intersection-item{display:flex;justify-content:space-between;align-items:center;padding:14px 15px;margin-bottom:8px;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);box-shadow:var(--shadow-sm);background-color:var(--color-bg-secondary);border-left:4px solid transparent}.intersection-info{flex-grow:1;margin-right:10px;min-width:0}.intersection-item:hover{background-color:var(--color-bg-tertiary);transform:translateY(-2px);box-shadow:0 5px 15px #00000040}.theme-light .intersection-item:hover{background-color:var(--color-bg-tertiary);box-shadow:var(--shadow-md)}.intersection-item.active{background:linear-gradient(90deg,var(--color-bg-tertiary) 0%,rgba(5,150,105,.1) 100%);color:var(--color-text-primary);border-left:4px solid var(--color-accent-blue);padding-left:12px;box-shadow:0 5px 20px #05966933}.theme-light .intersection-item.active{background:var(--color-bg-tertiary);border-left:4px solid var(--color-accent-blue)}.intersection-item.active .intersection-label,.intersection-item.active .intersection-details{color:var(--color-text-primary)}.intersection-item.active .status-button.active{background-color:var(--color-accent-blue);color:#fff;border-color:var(--color-accent-blue)}.intersection-item.active .status-button.ready{background-color:var(--color-bg-tertiary);color:var(--color-accent-blue);border:1px solid var(--color-accent-blue)}.intersection-label{font-weight:700;font-size:16px;display:block;margin-bottom:2px}.intersection-details{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;color:var(--color-text-secondary)}.intersection-status-dot-only{padding:0!important;background:none!important}.intersection-status-dot-only .color-dot{width:12px;height:12px;animation:statusDotPulse 2s infinite ease-in-out}.intersection-item[data-status=low] .intersection-status-dot-only .color-dot{background-color:var(--color-traffic-low)}.intersection-item[data-status=medium] .intersection-status-dot-only .color-dot{background-color:var(--color-traffic-medium)}.intersection-item[data-status=heavy] .intersection-status-dot-only .color-dot{background-color:var(--color-traffic-heavy)}.filter-controls{display:flex;gap:10px;margin-bottom:20px}.filter-controls select{flex-grow:1;padding:8px;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:14px;appearance:none;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23FFFFFF"><path d="M7 10l5 5 5-5z"/></svg>');background-repeat:no-repeat;background-position:right 8px center;background-size:10px;cursor:pointer}.theme-light .filter-controls select{background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23000000"><path d="M7 10l5 5 5-5z"/></svg>');background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.report-btn{width:100%;margin-top:auto;display:flex;align-items:center;justify-content:center;gap:8px;font-weight:600;background-color:var(--color-bg-primary)!important;border-color:var(--color-border)!important;color:var(--color-accent-blue)!important}.theme-light .report-btn{background-color:var(--color-bg-secondary)!important;border-color:var(--color-border)!important;color:var(--color-accent-blue)!important}.report-btn:hover{background-color:var(--color-bg-tertiary)!important}.status-button{font-size:11px;font-weight:700;padding:6px 10px;border-radius:16px;text-transform:uppercase;flex-shrink:0;transition:var(--transition-fast)}.status-button.active{background-color:var(--color-success);color:#fff}.status-button.ready{background-color:var(--color-bg-tertiary);color:var(--color-accent-blue);border:1px solid var(--color-accent-blue)}.main-content{flex-grow:1;min-width:0;padding:30px;overflow-y:auto;background-color:var(--color-bg-primary)}.main-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid rgba(5,150,105,.2)}.theme-light .main-header{border-bottom:1px solid var(--color-border)}.header-actions{display:flex;align-items:center}.header-actions .action-btn.primary:active{transform:scale(.95);transition:transform .1s}.help-content-list{display:flex;flex-direction:column;gap:12px}.alert-btn{position:relative;padding:8px 10px!important;margin-left:0!important;color:var(--color-traffic-heavy)!important}.alert-btn .icon{width:1.4em;height:1.4em;background-color:currentColor}.alert-btn:hover{background-color:var(--color-border)}.alert-badge{position:absolute;top:5px;right:5px;width:18px;height:18px;background-color:var(--color-alert-badge);color:#fff;font-size:10px;font-weight:700;border-radius:50%;display:flex;justify-content:center;align-items:center;border:2px solid var(--color-bg-primary)}.alert-badge.pulse-animation{animation:alertPulse 2s infinite cubic-bezier(.68,-.55,.265,1.55)}.alert-dropdown-menu{position:absolute;top:calc(100% + 10px);right:0;width:350px;z-index:50;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:400px;overflow:hidden;transform-origin:top right;animation:fadeIn .2s ease-out,slideInDownAlert .3s cubic-bezier(.175,.885,.32,1.275)}.alert-panel-list::-webkit-scrollbar,.intersection-list::-webkit-scrollbar,.main-content::-webkit-scrollbar,.live-modal-content::-webkit-scrollbar,.ch-grid::-webkit-scrollbar{width:6px;height:6px}.alert-panel-list::-webkit-scrollbar-track,.intersection-list::-webkit-scrollbar-track,.main-content::-webkit-scrollbar-track,.live-modal-content::-webkit-scrollbar-track{background:#0f172a1a;border-radius:10px}.alert-panel-list::-webkit-scrollbar-thumb,.intersection-list::-webkit-scrollbar-thumb,.main-content::-webkit-scrollbar-thumb,.live-modal-content::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--color-accent-blue) 0%,var(--color-accent-purple) 100%);border-radius:10px;border:1px solid rgba(255,255,255,.05)}.alert-panel-list::-webkit-scrollbar-thumb:hover,.main-content::-webkit-scrollbar-thumb:hover{background:var(--color-accent-cyan);box-shadow:0 0 8px var(--color-accent-cyan)}.alert-panel-list,.main-content{scrollbar-width:thin;scrollbar-color:var(--color-accent-blue) transparent}@keyframes slideInDownAlert{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-dropdown-menu .alert-item{transition:background-color .2s ease;cursor:pointer}.alert-dropdown-menu .alert-item:hover{background-color:var(--color-bg-tertiary)!important}.alert-dropdown-menu .alert-item.read{opacity:.7}.alert-dropdown-menu .custom-select{padding:6px 30px 6px 10px;height:35px;font-size:13px;flex-grow:1}.alert-dropdown-menu .action-btn{padding:6px 12px;font-size:13px;background-color:var(--color-bg-tertiary)}.alert-dropdown-menu .action-btn:hover{background-color:var(--color-border)}.theme-light .alert-badge{border:2px solid var(--color-bg-secondary)}.card-header{position:relative;display:flex;gap:10px;align-items:center}.segment-card h2{flex-grow:1;margin-right:auto;font-size:18px;font-weight:600;color:var(--color-text-primary)}.quick-action-btn{background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:5px;border-radius:var(--radius-sm);transition:var(--transition-fast);flex-shrink:0}.quick-action-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-accent-blue)}.quick-action-btn .icon{width:1.2em;height:1.2em;background-color:currentColor}.btn-view-detail{transition:var(--transition-fast);box-shadow:var(--shadow-md)}.btn-view-detail:hover{background:var(--color-accent-blue-dark)!important;transform:translateY(-1px)}.page-title{font-size:28px;font-weight:700;color:var(--color-accent-blue)}.header-actions .action-btn{padding:10px 18px;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-tertiary);color:var(--color-text-primary);cursor:pointer;margin-left:15px;transition:var(--transition-fast);box-shadow:var(--shadow-sm)}.theme-light .header-actions .action-btn{background-color:var(--color-bg-secondary)}.header-actions .action-btn:hover{background-color:var(--color-border);box-shadow:var(--shadow-md);transform:translateY(-1px)}.header-actions .action-btn.primary{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue);color:#fff}.header-actions .action-btn.primary:hover{background-color:var(--color-accent-blue-dark);border-color:var(--color-accent-blue-dark)}.traffic-filters{display:flex;gap:25px;margin-bottom:40px;padding:15px 0;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.filter-item{display:flex;align-items:center;font-size:14px;color:var(--color-text-secondary)}.color-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px;box-shadow:var(--shadow-sm)}.low-traffic .color-dot{background-color:var(--color-traffic-low)}.medium-traffic .color-dot{background-color:var(--color-traffic-medium)}.heavy-traffic .color-dot{background-color:var(--color-traffic-heavy)}.no-connection .color-dot{background-color:var(--color-text-secondary)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}}.segment-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;height:auto;display:flex;flex-direction:column;box-shadow:0 5px 20px #0003;transition:var(--transition-fast)}.segment-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg),0 0 20px #05966926}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.trend-chart{height:40px;padding:5px 0;margin-bottom:15px;border-radius:var(--radius-sm);background-color:var(--color-bg-primary);display:flex;justify-content:center;align-items:center;font-size:13px;font-weight:500;color:var(--color-text-secondary);border:1px dashed var(--color-border);position:relative;overflow:hidden;margin-top:12px!important}.trend-chart[data-trend=up]{border-color:var(--color-traffic-heavy)}.trend-chart[data-trend=down]{border-color:var(--color-traffic-low)}.trend-chart[data-trend=stable]{border-color:var(--color-accent-blue)}.trend-chart p{margin:0;padding:0}.trend-chart[data-trend=up] p{color:var(--color-traffic-heavy)}.trend-chart[data-trend=down] p{color:var(--color-traffic-low)}.trend-chart[data-trend=stable] p{color:var(--color-accent-blue)}.segment-card h2{font-size:18px;font-weight:600;color:var(--color-text-primary)}.intersection-status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;min-width:68px;justify-content:center;transition:all .3s ease}.intersection-status-badge.low{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.intersection-status-badge.medium{background:#fb923c2e;color:#fb923c;border:1px solid rgba(251,146,60,.3)}.intersection-status-badge.heavy{background:#ef44442e;color:#ef4444;border:1px solid rgba(239,68,68,.3);animation:pulse-red 2s infinite}.intersection-status-badge.no-connection{background:#64748b33;color:#94a3b8}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.7}}.intersection-item:hover .intersection-status-badge.heavy{transform:scale(1.05);box-shadow:0 0 12px #ef444466}.progress-bar-container{height:12px;background-color:#ffffff0f;border-radius:8px;overflow:hidden;margin-top:12px;box-shadow:inset 0 2px 4px #0000004d}.theme-light .progress-bar-container{background-color:var(--color-bg-tertiary)}.progress-bar{height:100%;border-radius:8px;background-color:var(--color-accent-blue);transition:width .5s ease-out,background-color .5s ease-out}.progress-bar.gradient-full{background:linear-gradient(90deg,var(--color-traffic-low) 0%,var(--color-traffic-medium) 30%,var(--color-traffic-warning) 60%,var(--color-traffic-heavy) 100%)}.progress-bar.low-gradient{background:linear-gradient(90deg,var(--color-traffic-low) 0%,var(--color-traffic-medium) 100%)}.progress-bar.medium-gradient{background:linear-gradient(90deg,var(--color-traffic-medium) 0%,var(--color-traffic-warning) 100%)}.progress-bar.heavy-gradient{background:linear-gradient(90deg,var(--color-traffic-warning) 0%,var(--color-traffic-heavy) 100%)}.density-label{font-size:13px;color:var(--color-text-secondary);margin-top:10px;text-align:right;font-weight:500}.icon{display:inline-block;width:1.2em;height:1.2em;background-color:currentColor;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:50% 50%;mask-position:50% 50%;-webkit-mask-size:contain;mask-size:contain;vertical-align:middle}.icon-traffic{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z"/></svg>')}.icon-dashboard{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M3 13h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm4 4h14v-2H7v2zm0 4h14v-2H7v2zm0-8h14V7H7v2z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M3 13h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm4 4h14v-2H7v2zm0 4h14v-2H7v2zm0-8h14V7H7v2z"/></svg>')}.icon-user-placeholder{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z"/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="currentColor" d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z"/></svg>')}.custom-select{appearance:none;background-color:var(--color-bg-secondary);background-repeat:no-repeat;background-position:right 12px center;background-size:16px;border:1px solid var(--color-border);border-radius:8px;padding:10px 36px 10px 14px;font-size:14px;font-weight:500;color:var(--color-text-primary);width:100%;min-height:44px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.custom-select:hover{border-color:var(--color-accent-blue);background-color:#0596690d}.custom-select:focus{outline:none;border-color:var(--color-accent-blue);box-shadow:0 0 0 3px #05966933;background-color:#05966914}.custom-select option{padding:10px 14px;white-space:normal!important;word-wrap:break-word;line-height:1.4;max-width:100%;overflow:hidden;text-overflow:ellipsis;background:var(--color-bg-secondary);color:var(--color-text-primary)}.live-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease-out}.live-modal-content{position:relative;width:100%;max-width:1400px;max-height:95vh;background:var(--color-bg-secondary);border-radius:12px;overflow:hidden;box-shadow:0 15px 30px #00000080,var(--shadow-glow-blue);animation:slideIn .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--color-border)}.live-modal-header{position:absolute;top:0;left:0;right:0;padding:16px 24px;background:linear-gradient(to bottom,rgba(0,0,0,.9),transparent);z-index:10;display:flex;justify-content:space-between;align-items:center;color:#fff}.live-modal-title{font-size:18px;font-weight:600}.btn-close-modal{background:#fff3;color:#fff;border:none;width:48px;height:48px;border-radius:50%;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-close-modal:hover{background:#ef444466;transform:scale(1.1)}.live-modal-video{width:100%;height:95vh;max-height:95vh;object-fit:contain;background:#000}@media(max-width:768px){.live-modal-content{border-radius:12px;max-height:96vh}.live-modal-video{height:96vh}.live-modal-title{font-size:16px}}.settings-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:999;padding:1rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .2s ease-out}.settings-modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:450px;padding:25px;animation:slideIn .2s ease-out;position:relative;color:var(--color-text-primary)}.settings-modal-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:15px;margin-bottom:20px;border-bottom:1px solid var(--color-border)}.settings-modal-header h2{font-size:18px;font-weight:700;margin:0}.btn-close-modal-mini{background:none;border:none;color:var(--color-text-secondary);font-size:24px;cursor:pointer;transition:var(--transition-fast);padding:5px;border-radius:50%}.btn-close-modal-mini:hover{color:var(--color-traffic-heavy);background-color:var(--color-bg-tertiary)}.settings-camera-name{font-size:14px;color:var(--color-accent-blue);font-weight:600;margin-bottom:20px;text-align:center}.settings-form .form-group{margin-bottom:20px}.settings-form .form-group label{display:block;margin-bottom:8px;font-weight:600;font-size:14px}.settings-form .form-group input[type=number]{width:100%;padding:10px 12px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:15px;transition:var(--transition-fast)}.settings-form .form-group input[type=number]:focus{border-color:var(--color-accent-blue);outline:none;box-shadow:0 0 0 3px #05966933}.settings-form .form-group small{display:block;margin-top:5px;font-size:12px;color:var(--color-text-secondary)}.settings-form .checkbox-group{display:flex;flex-direction:column}.settings-form .checkbox-label{display:flex;align-items:center;cursor:pointer}.settings-form .checkbox-label input[type=checkbox]{margin-right:10px;width:18px;height:18px;accent-color:var(--color-accent-blue)}.settings-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:15px;border-top:1px solid var(--color-border);margin-top:25px}.ai-trigger-btn{position:relative;display:flex;align-items:center;justify-content:center;z-index:1}.ai-trigger-btn:after{display:none}.bot-floating-container{position:relative;display:flex;align-items:center;justify-content:center;animation:floating-bot 3s ease-in-out infinite}.bot-floating-container:after{content:"";position:absolute;width:60px;height:60px;border-radius:50%;border:2px solid var(--color-accent-blue);animation:pulse-ai 2s infinite;z-index:1;pointer-events:none}@keyframes floating-bot{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes pulse-ai{0%{transform:scale(1);opacity:1}to{transform:scale(1.6);opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ai-messages::-webkit-scrollbar{width:4px}.ai-messages::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:10px}@media(max-width:480px){.login-card{padding:36px 32px;border-radius:16px}.login-title{font-size:28px}}@media(max-width:768px){.custom-select{font-size:13px;padding:8px 32px 8px 12px;min-height:40px;background-position:right 10px center}}@media(max-width:1024px){.app{margin:10px}.sidebar{width:var(--sidebar-width);padding:20px 15px}.main-content{padding:25px}.page-title{font-size:24px}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.account-settings-grid{grid-template-columns:1fr}}@media(max-width:768px){.app{flex-direction:column;height:auto;min-height:100vh;margin:0;border-radius:0}.sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-border);padding-bottom:15px}.sidebar-header{justify-content:center}.main-header{flex-direction:column;align-items:flex-start}.page-title{margin-bottom:15px;font-size:22px}.header-actions{width:100%;display:flex;justify-content:space-around}.header-actions .action-btn{margin-left:0;flex-grow:1;text-align:center}.header-actions .action-btn:not(:last-child){margin-right:10px}.traffic-filters{flex-direction:column;gap:10px}.dashboard-grid{grid-template-columns:1fr}.segment-card{height:auto}}.action-btn{padding:10px 18px;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-tertiary);color:var(--color-text-primary);cursor:pointer;transition:var(--transition-fast);font-weight:600}.action-btn:hover{background-color:var(--color-border);transform:translateY(-1px)}.action-btn.primary{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue);color:#fff}@media(max-width:768px){.user-dropdown-menu{top:calc(100% + 10px);bottom:unset;left:50%;transform:translate(-50%);width:90%;max-width:300px}.sidebar-user-info{padding-top:15px}}.settings-modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:99999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal-content{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:24px;width:90%;max-width:500px;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0006;color:var(--color-text-primary);animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.settings-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid var(--color-border);padding-bottom:15px}.settings-modal-header h2{margin:0;font-size:1.25rem;color:var(--color-text-primary)}.btn-close-modal-mini{background:transparent;border:none;color:var(--color-text-secondary);font-size:24px;cursor:pointer;line-height:1}.btn-close-modal-mini:hover{color:#fff}.settings-form .form-group{margin-bottom:16px}.settings-form label{display:block;margin-bottom:8px;font-size:.9rem;color:var(--color-text-secondary)}.settings-form input,.settings-form select{width:100%;padding:10px 12px;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:6px;color:#fff;font-size:.95rem;transition:all .2s}.settings-form input:focus{outline:none;border-color:var(--color-accent-blue);box-shadow:0 0 0 2px #0ea5e933}.settings-modal-footer{margin-top:24px;display:flex;justify-content:flex-end;gap:12px;border-top:1px solid var(--color-border);padding-top:16px}.settings-modal-footer .action-btn{padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s;background-color:var(--color-bg-primary);border:1px solid var(--color-border);color:var(--color-text-secondary)}.settings-modal-footer .action-btn:hover{background-color:var(--color-bg-tertiary);color:#fff}.settings-modal-footer .action-btn.primary{background-color:var(--color-accent-blue);border:1px solid var(--color-accent-blue);color:#fff}.settings-modal-footer .action-btn.primary:hover{background-color:var(--color-accent-blue-dark)}.account-container{max-width:600px;margin:40px auto;padding:0 20px;animation:fadeIn .5s ease-out}.settings-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:32px;box-shadow:var(--shadow-md)}.settings-header{margin-bottom:24px;text-align:center}.settings-title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin-bottom:8px}.settings-subtitle{color:var(--color-text-secondary);font-size:.9rem}.avatar-upload-group{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.avatar-wrapper{position:relative;width:120px;height:120px;border-radius:50%;border:3px solid var(--color-border);overflow:hidden;cursor:pointer;transition:border-color .3s;background-color:var(--color-bg-primary)}.avatar-wrapper:hover{border-color:var(--color-accent-blue)}.avatar-image{width:100%;height:100%;object-fit:cover}.avatar-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.avatar-wrapper:hover .avatar-overlay{opacity:1}.icon-camera{font-size:24px;color:#fff}.form-section-divider{margin:32px 0;border:0;border-top:1px solid var(--color-border)}.section-label{display:block;font-size:1.1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:16px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:.9rem;font-weight:500;color:var(--color-text-secondary)}.settings-form input{width:100%;padding:12px 16px;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:.95rem;transition:all .2s ease}.settings-form input:focus{outline:none;border-color:var(--color-accent-blue);box-shadow:0 0 0 3px #05966933}.settings-form input:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7}.btn-save{width:100%;padding:14px;background-color:var(--color-accent-blue);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:background-color .2s;margin-top:10px}.btn-save:hover{background-color:var(--color-accent-blue-dark)}.btn-save:disabled{background-color:var(--color-border);cursor:wait}.alert{padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:.9rem;display:flex;align-items:center}.alert-success{background-color:#10b9811a;color:#34d399;border:1px solid rgba(16,185,129,.2)}.alert-error{background-color:#ef44441a;color:#f87171;border:1px solid rgba(239,68,68,.2)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
