@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-surface: #ffffff;--color-surface-raised: #f9fafb;--color-surface-overlay: #f3f4f6;--color-surface-sunken: #f3f4f6;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--color-border-medium: #d1d5db;--color-widget-track: var(--color-slate-300);--color-text-primary: #1a1a1a;--color-text-secondary: #374151;--color-text-muted: #6b7280;--color-text-subtle: #9ca3af;--color-primary: #10b981;--color-primary-hover: #059669;--color-primary-bg: #d1fae5;--color-primary-border: #a7f3d0;--color-blue: #1C78E6;--color-blue-hover: #1565C0;--color-blue-bg: #E3F2FD;--color-blue-border: #BBDEFB;--color-green: #24D678;--color-green-hover: #1B8A4A;--color-green-bg: #E8F5E9;--color-green-border: #C8E6C9;--color-red: #DC2626;--color-red-hover: #991B1B;--color-red-bg: #FEE2E2;--color-red-border: #FECACA;--color-purple: #A830DB;--color-purple-hover: #7B1FA2;--color-purple-bg: #F3E5F5;--color-purple-border: #E1BEE7;--color-yellow: #F59E0B;--color-yellow-bg: #FEF3C7;--color-yellow-border: #FDE68A;--color-input-bg: #ffffff;--color-input-border: #e0e0e0;--color-input-focus-border: #10b981;--color-input-focus-shadow: rgba(var(--color-primary-rgb), .1);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .12);--shadow-card: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-dropdown: 0 10px 25px rgba(0, 0, 0, .12), 0 4px 8px rgba(0, 0, 0, .08);--color-body-bg: #f3f4f6;--color-sidebar-bg: #1a2035;--color-sidebar-text: rgba(255, 255, 255, .7);--color-sidebar-text-active: #ffffff;--color-sidebar-item-hover: rgba(255, 255, 255, .08);--color-sidebar-item-active: rgba(16, 185, 129, .2);--color-sidebar-border: rgba(255, 255, 255, .1);--color-primary-50: #ecfdf5;--color-primary-100: #d1fae5;--color-primary-200: #a7f3d0;--color-primary-300: #6ee7b7;--color-primary-400: #34d399;--color-primary-500: #10b981;--color-primary-600: #059669;--color-primary-700: #047857;--color-primary-800: #065f46;--color-primary-900: #064e3b;--color-primary-rgb: 16, 185, 129;--color-primary-hover-rgb: 5, 150, 105;--color-blue-400: #60a5fa;--color-blue-500: #3b82f6;--color-blue-600: #2563eb;--color-blue-700: #1d4ed8;--color-blue-rgb: 59, 130, 246;--color-red-400: #f87171;--color-red-500: #ef4444;--color-red-600: #dc2626;--color-red-700: #b91c1c;--color-red-800: #991b1b;--color-red-rgb: 220, 38, 38;--color-success-400: #4ade80;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-success-700: #15803d;--color-success-rgb: 34, 197, 94;--color-amber-400: #fbbf24;--color-amber-500: #f59e0b;--color-amber-600: #d97706;--color-amber-700: #b45309;--color-amber-rgb: 245, 158, 11;--color-black-rgb: 0, 0, 0;--color-white-rgb: 255, 255, 255;--color-red-500-rgb: 239, 68, 68;--color-violet-500-rgb: 139, 92, 246;--color-violet-600-rgb: 124, 58, 237;--color-violet-800-rgb: 91, 33, 182;--color-indigo-500-rgb: 99, 102, 241;--color-cyan-500-rgb: 6, 182, 212;--color-sky-500-rgb: 14, 165, 233;--color-blue-600-rgb: 37, 99, 235;--color-blue-400-rgb: 96, 165, 250;--color-blue-cornflower-rgb: 49, 130, 206;--color-blue-grad-4f-rgb: 79, 141, 255;--color-blue-sky-mid-rgb: 99, 179, 237;--color-legacy-blue-rgb: 28, 120, 230;--color-legacy-blue-bright-rgb: 56, 103, 214;--color-legacy-green-rgb: 36, 214, 120;--color-legacy-green-dark-rgb: 11, 158, 60;--color-legacy-orange-light-rgb: 253, 150, 68;--color-orange-600-tw-rgb: 234, 88, 12;--color-nav-storage-rgb: 32, 191, 107;--color-surface-dark-rgb: 30, 30, 30;--color-slate-950-rgb: 2, 6, 23;--color-gray-500-rgb: 107, 114, 128;--color-amber-600-rgb: 217, 119, 6;--color-nav-users-rgb: 43, 203, 186;--color-nav-devices-rgb: 165, 94, 234;--color-red-coral-rgb: 252, 92, 101;--color-amber-text-brown-rgb: 194, 65, 12;--color-slate-800-rgb: 30, 41, 59;--color-amber-300-rgb: 252, 211, 77;--color-blue-300-rgb: 147, 197, 253;--color-amber-200-rgb: 253, 230, 138;--color-amber-400-rgb: 251, 191, 36;--color-pink-600-rgb: 219, 39, 119;--color-violet-555-rgb: 168, 85, 247;--color-teal-500-rgb: 20, 184, 166;--color-orange-tw-500-rgb: 249, 115, 22;--color-purple-400: #c084fc;--color-purple-500: #a830db;--color-purple-600: #7c3aed;--color-purple-700: #6d28d9;--color-purple-rgb: 168, 48, 219;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--gradient-primary: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-primary-hover: linear-gradient(135deg, #34d399 0%, #10b981 100%);--gradient-fab-edit: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);--gradient-fab-edit-hover: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--gradient-danger-hover: linear-gradient(135deg, #f87171 0%, #ef4444 100%);--gradient-warning: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);--gradient-success: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);--gradient-purple: linear-gradient(135deg, #a830db 0%, #7c3aed 100%);--color-red-100: #fee2e2;--color-red-200: #fecaca;--color-red-300: #fca5a5;--color-success-50: #f0fdf4;--color-success-100: #dcfce7;--color-success-200: #bbf7d0;--color-success-300: #86efac;--color-success-900: #064e3b;--color-blue-100: #dbeafe;--color-blue-200: #bfdbfe;--color-blue-300: #93c5fd;--color-blue-800: #1e40af;--color-blue-900: #1e3a8a;--color-amber-100: #fef3c7;--color-amber-200: #fde68a;--color-amber-300: #fcd34d;--color-purple-100: #ede9fe;--color-purple-200: #ddd6fe;--color-purple-300: #c4b5fd;--color-purple-800: #5b21b6;--color-violet-500: #8b5cf6;--color-violet-600: #7c3aed;--color-violet-700: #6d28d9;--color-indigo-500: #6366f1;--color-indigo-600: #4f46e5;--color-teal-500: #2bcbba;--color-teal-600: #14b8a6;--color-legacy-blue: #1c78e6;--color-legacy-blue-dark: #1565c0;--color-legacy-green: #24d678;--color-legacy-green-dark: #0b9e3c;--color-legacy-orange: #cc6f00;--color-legacy-orange-light:#fd9644;--color-gray-50: #fafafa;--color-white: #ffffff;--color-black: #000000;--color-orange-50: #fff7ed;--color-orange-100: #ffedd5;--color-orange-200: #fed7aa;--color-orange-300: #fdba74;--color-orange-500-tw: #f97316;--color-orange-600-tw: #ea580c;--color-slate-100: #f1f5f9;--color-slate-200: #e2e8f0;--color-slate-300: #cbd5e1;--color-slate-400: #94a3b8;--color-slate-500: #64748b;--color-slate-600: #475569;--color-slate-700: #334155;--color-slate-800: #1e293b;--color-slate-900: #0f172a;--color-sky-50: #f0f9ff;--color-sky-100: #e0f2fe;--color-sky-500: #0ea5e9;--color-purple-50: #f3e8ff;--color-violet-100: #e9d5ff;--color-violet-800: #5b21b6;--color-red-50: #fef2f2;--color-red-coral: #fc5c65;--color-amber-50: #fffbeb;--color-success-800: #166534;--color-indigo-700: #5558e3;--color-legacy-blue-bright:#3867d6;--color-gray-200-soft: #f0f0f0;--color-gray-300-soft: #d0d0d0;--color-gray-ccc: #cccccc;--color-nav-dashboard: #2c53b5;--color-nav-dashboard-bg: #e8eefe;--color-nav-users: #0fb9b1;--color-nav-users-bg: #e0faf8;--color-nav-devices: #a55eea;--color-nav-devices-hover: #8e44d8;--color-nav-devices-bg: #f3e8fe;--color-nav-monitoring: #fa8231;--color-nav-monitoring-bg: #fff0e0;--color-nav-storage: #20bf6b;--color-nav-storage-hover: #0a9e53;--color-nav-storage-bg: #e0faf0;--color-nav-notifications: #eb3b5a;--color-nav-notifications-bg: #fee8ea;--color-nav-tracking: #45aaf2;--color-nav-tracking-hover:#2d98da;--color-nav-settings: #5f7fe6;--color-nav-settings-bg: #edf0ff;--color-teal-50: #f0fdfa;--color-teal-100: #ccfbf1;--color-teal-200: #99f6e4;--color-teal-300: #5eead4;--color-teal-400: #2dd4bf;--color-teal-700: #0d9488;--color-teal-800: #115e59;--color-sky-200: #bae6fd;--color-sky-300: #7dd3fc;--color-sky-400: #38bdf8;--color-sky-600: #0284c7;--color-sky-700: #0369a1;--color-sky-800: #075985;--color-cyan-300: #67e8f9;--color-cyan-500: #06b6d4;--color-cyan-600: #0891b2;--color-cyan-700: #0e7490;--color-surface-terminal: #1e1e2e;--color-text-on-dark: #a8dadc;--color-indigo-100: #e0e7ff;--color-indigo-200: #c7d2fe;--color-blue-darker: #1e40af;--color-blue-cornflower: #3182ce;--color-blue-cornflower-d: #2b6cb0;--color-blue-sky-mid: #63b3ed;--color-blue-deepest: #0d47a1;--color-blue-tint-50: #f0f4ff;--color-amber-text-mid: #b45309;--color-amber-text-dark: #92400e;--color-amber-text-darkest:#78350f;--color-amber-text-burnt: #c76900;--color-amber-text-brown: #c2410c;--color-orange-tw-400: #fb923c;--color-yellow-500-tw: #eab308;--color-violet-50: #f5f3ff;--color-violet-600-alt: #9333ea;--color-purple-tint: #fdf4ff;--color-surface-navy: #1a1a2e;--color-surface-navy-2: #2d2d44;--color-surface-gray-800: #1f2937;--color-gray-50-tw: #f9fafb;--color-gray-e8: #e8e8e8;--color-gray-c0: #c0c0c0;--color-gray-222: #222;--color-gray-ddd: #ddd;--color-gray-3a: #3a3a3a;--color-gray-78: #787878;--color-slate-mid: #4a5568;--color-warm-white: #fffbf5;--color-warm-orange-tint: #fff7f0;--color-orange-tint-light: #fffaf5;--color-red-material: #f44336;--color-sidebar-blue: #0068FF;--color-sidebar-blue-dark: #0052CC;--color-material-blue: #2196F3;--color-material-orange: #FF9800;--color-surface-slate-900: #0f172a;--color-surface-dark-1: #27323d;--color-surface-dark-2: #14202e;--color-surface-dark-3: #1b242d;--color-border-dark-1: #384554;--color-violet-400: #a78bfa;--color-gray-b0: #b0b0b0;--color-legacy-green-dark2:#0a8233;--color-legacy-green-mid: #1B8A4A;--color-indigo-light-bg: #667eea;--color-indigo-light-text: #a5b4fc;--color-success-deep: #15803d;--color-purple-deep: #6b21a8;--color-gray-f5: #f5f5f5;--color-gray-33: #333333;--color-green-mid-light: #2bb968;--color-surface-25: #252525;--color-pink-300: #f9a8d4;--color-pink-500: #ec4899;--color-pink-600: #db2777;--color-purple-faint: #faf5ff;--color-blue-very-light: #f8fbff;--color-gray-50-soft: #f8f9fa;--color-blue-tint-eff: #eff6ff;--color-amber-burnt-d6: #d96e00;--color-gray-d4: #d4d4d4;--color-violet-555: #a855f7;--color-blue-grad-155: #155CB0;--color-blue-navy-grad: #16213e;--color-blue-grad-4f: #4f8dff;--color-violet-indigo: #4F46E5;--color-green-grad-3d: #3ddc84;--color-green-grad-2b: #2bb968;--color-green-grad-22: #229954;--color-purple-vivid: #7e22ce;--color-orange-burnt: #9a3412;--color-amber-text-burnt-7: #b45309;--color-orange-grad-764: #764ba2;--color-success-grad-mid: #4ade80;--color-amber-yellow: #f59e0b}[data-theme=dark]{--color-surface: #1e1e1e;--color-surface-raised: #252525;--color-surface-overlay: #2e2e2e;--color-surface-sunken: #181818;--color-border: #3a3a3a;--color-border-light: #2e2e2e;--color-border-medium: #484848;--color-text-primary: #f0f0f0;--color-text-secondary: #d1d5db;--color-text-muted: #9ca3af;--color-text-subtle: #6b7280;--color-primary: #10b981;--color-primary-hover: #34d399;--color-primary-hover-rgb: 52, 211, 153;--color-primary-bg: #0e3e2a;--color-primary-border: #155e42;--color-blue: #4B9FFF;--color-blue-hover: #60aeff;--color-blue-bg: #1a2e4a;--color-blue-border: #1e3a5a;--color-green: #34D678;--color-green-hover: #4de890;--color-green-bg: #0d2e1a;--color-green-border: #0e3820;--color-red: #F87171;--color-red-hover: #fc8e8e;--color-red-bg: #2e0d0d;--color-red-border: #3e1010;--color-orange: #10b981;--color-orange-hover: #34d399;--color-orange-bg: #0a2e1f;--color-orange-border: #0e3e2a;--color-purple: #C77DFF;--color-purple-hover: #d498ff;--color-purple-bg: #1e0d2e;--color-purple-border: #2e1040;--color-yellow: #FBBF24;--color-yellow-bg: #2e2000;--color-yellow-border: #3e2c00;--color-neutral-bg: #2e2e2e;--color-neutral-text: #9ca3af;--color-neutral-border: #3a3a3a;--color-input-bg: #2a2a2a;--color-input-border: #444444;--color-input-focus-border: #10b981;--color-input-focus-shadow: rgba(16, 185, 129, .15);--color-input-placeholder: #6b7280;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .5);--shadow-card: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-dropdown: 0 10px 25px rgba(0, 0, 0, .5), 0 4px 8px rgba(0, 0, 0, .3);--color-body-bg: #141414;--color-sidebar-bg: #111827;--color-sidebar-text: rgba(255, 255, 255, .6);--color-sidebar-text-active: #ffffff;--color-sidebar-item-hover: rgba(255, 255, 255, .06);--color-sidebar-item-active: rgba(16, 185, 129, .25);--color-sidebar-border: rgba(255, 255, 255, .08);--color-primary-50: #0a2e1f;--color-primary-100: #0e3e2a;--color-primary-200: #14513a;--color-primary-300: #1b6549;--color-primary-400: #34d399;--color-primary-500: #10b981;--color-primary-600: #34d399;--color-primary-700: #6ee7b7;--color-blue-400: #93c5fd;--color-blue-500: #60a5fa;--color-blue-600: #3b82f6;--color-blue-700: #2563eb;--color-red-400: #fca5a5;--color-red-500: #f87171;--color-red-600: #ef4444;--color-red-700: #dc2626;--color-success-400: #86efac;--color-success-500: #4ade80;--color-success-600: #22c55e;--color-amber-400: #fcd34d;--color-amber-500: #fbbf24;--color-amber-600: #f59e0b;--color-purple-400: #d8b4fe;--color-purple-500: #c084fc;--color-purple-600: #a830db}html{transition:background-color .25s ease,color .25s ease}.icon-spin,.icon-pulse,.spinner-ring,[class*=animation],[class*=animate],canvas,svg{transition:none!important}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-surface-raised)}::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}::-webkit-scrollbar-corner{background:var(--color-surface-raised)}*{scrollbar-width:thin;scrollbar-color:var(--color-border-medium) var(--color-surface-raised)}input[type=checkbox],input[type=radio],input[type=range],progress{accent-color:var(--color-primary)}input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;min-width:18px;border:1.5px solid var(--color-border-medium);border-radius:4px;background:var(--color-surface);cursor:pointer;position:relative;vertical-align:middle;flex-shrink:0;transition:background .15s,border-color .15s}input[type=checkbox]:hover:not(:disabled){border-color:var(--color-primary)}input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}input[type=checkbox]:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}button{padding:0;margin:0;font-family:inherit;font-size:inherit;line-height:1;border:none;background:none;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;font-weight:500;line-height:1.5;border-radius:.5rem;transition:all .2s ease-in-out;cursor:pointer;border:1px solid transparent;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn:focus{outline:none;box-shadow:0 0 0 3px rgba(var(--color-legacy-blue-rgb),.3)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-xs{padding:.25rem .5rem;font-size:.75rem;border-radius:.375rem}.btn-sm{padding:.375rem .75rem;font-size:.8125rem;border-radius:.375rem}.btn-md{padding:.5rem 1rem;font-size:.875rem;border-radius:.5rem}.btn-lg{padding:.625rem 1.25rem;font-size:.9375rem;border-radius:.5rem}.btn-xl{padding:.75rem 1.5rem;font-size:1rem;border-radius:.5rem}.btn-primary{background:var(--gradient-primary);color:var(--color-white);border:none;box-shadow:0 4px 6px -1px rgba(var(--color-primary-rgb),.25)}.btn-primary:hover:not(:disabled){background:var(--gradient-primary-hover);box-shadow:0 10px 15px -3px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.btn-secondary{background-color:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background-color:var(--color-surface-raised);border-color:var(--color-border-medium);box-shadow:var(--shadow-md)}.btn-success{background-color:var(--color-green);color:var(--color-white);border:none;box-shadow:0 4px 6px -1px rgba(var(--color-legacy-green-rgb),.25)}.btn-success:hover:not(:disabled){background-color:var(--color-green-hover);box-shadow:0 10px 15px -3px rgba(var(--color-legacy-green-rgb),.35);transform:translateY(-1px)}.btn-danger{background-color:var(--color-red);color:var(--color-white);border:none;box-shadow:0 4px 6px -1px rgba(var(--color-red-rgb),.25)}.btn-danger:hover:not(:disabled){background-color:var(--color-red-hover);box-shadow:0 10px 15px -3px rgba(var(--color-red-rgb),.35);transform:translateY(-1px)}.btn-cancel,.btn-close{background:var(--color-surface)!important;color:var(--color-text-muted)!important;border:1.5px solid var(--color-border)!important}.btn-cancel:hover:not(:disabled),.btn-close:hover:not(:disabled){background:var(--color-surface-overlay)!important;border-color:var(--color-text-subtle)!important;color:var(--color-text-secondary)!important;transform:translateY(-1px)}.btn-cancel:disabled,.btn-close:disabled{opacity:.6;cursor:not-allowed}.modal-close{color:var(--color-text-muted)!important}.modal-close:hover{background:var(--color-surface-overlay)!important;color:var(--color-text-primary)!important}.btn-warning{background-color:var(--color-primary);color:var(--color-white);border:none;box-shadow:0 4px 6px -1px rgba(var(--color-primary-rgb),.25)}.btn-warning:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:0 10px 15px -3px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.btn-ghost{background-color:transparent;color:var(--color-text-muted);border:none}.btn-ghost:hover:not(:disabled){background-color:var(--color-surface-overlay);color:var(--color-text-secondary)}.btn-icon-only{padding:.5rem;aspect-ratio:1}.btn-icon-only.btn-xs{padding:.25rem}.btn-icon-only.btn-sm{padding:.375rem}.btn-icon-only.btn-md{padding:.5rem}.btn-icon-only.btn-lg{padding:.625rem}.btn-icon-only.btn-xl{padding:.75rem}.icon-container{padding:.5rem;border-radius:.5rem}.icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}.icon-xs{width:.875rem;height:.875rem}.icon-sm{width:1rem;height:1rem}.icon-md{width:1.25rem;height:1.25rem}.icon-lg{width:1.5rem;height:1.5rem}.icon-xl{width:2rem;height:2rem}.icon-2xl{width:2.5rem;height:2.5rem}.icon-3xl{width:3rem;height:3rem}.btn .icon{margin:-.125rem 0}.btn-xs .icon{width:.875rem;height:.875rem}.btn-sm .icon{width:1rem;height:1rem}.btn-md .icon{width:1.125rem;height:1.125rem}.btn-lg .icon{width:1.25rem;height:1.25rem}.btn-xl .icon{width:1.5rem;height:1.5rem}.icon-spin{animation:icon-spin 1s linear infinite}@keyframes icon-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.icon-pulse{animation:icon-pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes icon-pulse{0%,to{opacity:1}50%{opacity:.5}}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;font-size:.6875rem;font-weight:500;line-height:1.5;border-radius:9999px;white-space:nowrap}.badge-xs{padding:.125rem .375rem;font-size:.5625rem}.badge-sm{padding:.25rem .5rem;font-size:.625rem}.badge-md{padding:.25rem .625rem;font-size:.6875rem}.badge-lg{padding:.375rem .75rem;font-size:.75rem}.badge .icon{width:.875rem;height:.875rem}.badge-success{background-color:var(--color-green-bg);color:var(--color-green-hover);border:1px solid var(--color-green-border)}.badge-error{background-color:var(--color-red-bg);color:var(--color-red-hover);border:1px solid var(--color-red-border)}.badge-warning{background-color:var(--color-primary-bg);color:var(--color-primary-hover);border:1px solid var(--color-primary-border)}.badge-info{background-color:var(--color-blue-bg);color:var(--color-blue-hover);border:1px solid var(--color-blue-border)}.badge-neutral{background-color:var(--color-surface-overlay);color:var(--color-text-secondary);border:1px solid var(--color-border)}.card{background:var(--color-surface);border-radius:.75rem;box-shadow:var(--shadow-card);border:1px solid var(--color-border-light);padding:1rem}.card-sm{padding:.75rem;border-radius:.5rem}.card-md{padding:1rem;border-radius:.75rem}.card-lg{padding:1.5rem;border-radius:1rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.flex{display:flex}.inline-flex{display:inline-flex}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}@media (min-width: 640px){.sm\:btn-xs{padding:.25rem .5rem;font-size:.75rem}.sm\:btn-sm{padding:.375rem .75rem;font-size:.8125rem}.sm\:btn-md{padding:.5rem 1rem;font-size:.875rem}.sm\:btn-lg{padding:.625rem 1.25rem;font-size:.9375rem}}@media (min-width: 768px){.md\:btn-xs{padding:.25rem .5rem;font-size:.75rem}.md\:btn-sm{padding:.375rem .75rem;font-size:.8125rem}.md\:btn-md{padding:.5rem 1rem;font-size:.875rem}.md\:btn-lg{padding:.625rem 1.25rem;font-size:.9375rem}}@media (min-width: 1024px){.lg\:btn-xs{padding:.25rem .5rem;font-size:.75rem}.lg\:btn-sm{padding:.375rem .75rem;font-size:.8125rem}.lg\:btn-md{padding:.5rem 1rem;font-size:.875rem}.lg\:btn-lg{padding:.625rem 1.25rem;font-size:.9375rem}}.grid-2{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 768px){.grid-2{grid-template-columns:repeat(2,1fr)}}.grid-3{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.grid-3{grid-template-columns:repeat(3,1fr)}}.grid-4{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.grid-4{grid-template-columns:repeat(4,1fr)}}.grid-2-col{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.grid-2-col{grid-template-columns:repeat(2,1fr)}}.grid-2x2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.sortable-th{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .15s,background .15s}.sortable-th:hover{background:var(--color-surface-overlay);color:var(--color-primary)!important}.sortable-th:hover .sort-icon{color:var(--color-primary)}.sort-icon{margin-left:4px;color:var(--color-text-subtle);vertical-align:middle;transition:color .15s;flex-shrink:0}.sortable-th.is-sorted .sort-icon{color:var(--color-primary)}.std-table{width:100%;border-collapse:collapse}.std-table thead{background:var(--color-surface-raised);border-bottom:1px solid var(--color-border-light);position:sticky;top:0;z-index:10}.std-table th{padding:9px 12px;text-align:left;font-size:13px;font-weight:600;color:var(--color-text-muted);white-space:nowrap}.std-table td{padding:9px 12px;font-size:13px;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-light)}.std-table tbody tr{transition:background .15s}.std-table tbody tr:hover{background:var(--color-surface-raised)}.std-table tbody tr:last-child td{border-bottom:none}.toggle-switch{position:relative;display:inline-block;width:38px;height:22px;cursor:pointer;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;inset:0;background:var(--color-border-medium);border-radius:11px;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:var(--color-surface);border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(var(--color-black-rgb),.2)}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(16px)}.toggle-switch input:disabled+.toggle-slider{opacity:.55;cursor:not-allowed}.loading-container{display:flex;flex:1 1 auto;flex-direction:column;justify-content:center;align-items:center;gap:1rem;width:100%;min-height:60vh;padding:2rem;box-sizing:border-box;background:transparent}.loading-container .ov-icon{color:var(--color-primary)}.loading-container .loading-text{color:var(--color-text-secondary)}.loading-container-sm{display:flex;flex:0 1 auto;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;width:100%;min-height:auto;padding:2rem 0;box-sizing:border-box}.loading-container-lg{padding:10rem 0;min-height:60vh}.loading-container-full{position:fixed;inset:0;background:var(--color-primary-bg);z-index:9999}.loading-container-center{position:fixed;inset:0;width:100%;height:100vh;background:var(--color-surface-raised);z-index:1000}.loading-container-overlay{position:absolute;inset:0;background:rgba(var(--color-primary-rgb),.1);z-index:100}.loading-container-page-overlay{position:absolute;inset:0;background:var(--color-surface-raised);z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-spinner{position:relative;width:4rem;height:4rem}.loading-spinner-sm{width:2rem;height:2rem}.loading-spinner-lg{width:6rem;height:6rem}.spinner-ring{width:100%;height:100%;border:4px solid var(--color-primary-bg);border-radius:50%;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.loading-spinner-sm .spinner-ring{border-width:2px}.loading-spinner-lg .spinner-ring{border-width:6px}.spinner-icon{width:100%;height:100%;color:var(--color-primary);animation:spin 1s linear infinite;position:absolute;top:0;left:0;display:flex;align-items:center;justify-content:center;line-height:1}.spinner-border{display:inline-block;width:2rem;height:2rem;border:3px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .75s linear infinite}.spinner-border-sm{width:1rem;height:1rem;border-width:2px}.spinner-border-lg{width:3rem;height:3rem;border-width:4px}.spinner-dots{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner-dots .dot{width:.75rem;height:.75rem;background-color:#fff;border-radius:50%;animation:bounce 1.4s ease-in-out infinite both}.spinner-dots .dot:nth-child(1){animation-delay:-.32s}.spinner-dots .dot:nth-child(2){animation-delay:-.16s}.spinner-dots .dot:nth-child(3){animation-delay:0s}.spinner-dots-sm .dot{width:.5rem;height:.5rem}.spinner-pulse{width:2.5rem;height:2.5rem;background-color:#fff;border-radius:50%;animation:pulse-scale 1.5s ease-in-out infinite}.spinner-pulse-sm{width:1.5rem;height:1.5rem}.spinner-pulse-lg{width:4rem;height:4rem}.loading-text{margin:0;color:var(--color-text-muted);font-weight:400;font-size:.875rem}.loading-text-sm{margin-top:.5rem;font-size:.75rem}.loading-text-lg{margin-top:1.5rem;font-size:1rem}.skeleton{background:var(--color-surface-overlay);animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:.25rem}.skeleton-text{height:1rem;margin-bottom:.5rem}.skeleton-text-sm{height:.75rem}.skeleton-text-lg{height:1.5rem}.skeleton-title{height:1.5rem;width:60%;margin-bottom:1rem}.skeleton-avatar{width:3rem;height:3rem;border-radius:50%}.skeleton-avatar-sm{width:2rem;height:2rem}.skeleton-avatar-lg{width:4rem;height:4rem}.skeleton-card{height:120px;border-radius:.5rem}.skeleton-button{height:2.5rem;width:6rem;border-radius:.5rem}.skeleton-image{height:200px;border-radius:.5rem}.loading-overlay{position:absolute;inset:0;background:transparent;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:inherit}.loading-overlay-dark{background:var(--color-text-muted)}.loading-overlay-dark .spinner-border,.loading-overlay-dark .spinner-icon,.loading-overlay-dark .loading-text{color:#fff}.btn-loading{position:relative;pointer-events:none}.btn-loading .btn-text{opacity:0}.btn-loading .spinner-border{position:absolute;width:1.25rem;height:1.25rem;border-width:2px}.progress-bar{width:100%;height:.5rem;background-color:var(--color-border);border-radius:9999px;overflow:hidden}.progress-bar-fill{height:100%;background-color:var(--color-primary);border-radius:9999px;transition:width .3s ease}.progress-bar-indeterminate .progress-bar-fill{width:30%;animation:progress-indeterminate 1.5s ease-in-out infinite}.spinner-primary,.spinner-border.spinner-primary{color:var(--color-primary)}.spinner-pulse.spinner-primary,.spinner-dots.spinner-primary .dot{background-color:var(--color-primary)}.spinner-success,.spinner-border.spinner-success{color:var(--color-teal-500)}.spinner-pulse.spinner-success,.spinner-dots.spinner-success .dot{background-color:var(--color-teal-500)}.spinner-danger,.spinner-border.spinner-danger{color:var(--color-red-coral)}.spinner-pulse.spinner-danger,.spinner-dots.spinner-danger .dot{background-color:var(--color-red-coral)}.spinner-warning,.spinner-border.spinner-warning{color:var(--color-legacy-orange-light)}.spinner-pulse.spinner-warning,.spinner-dots.spinner-warning .dot{background-color:var(--color-legacy-orange-light)}.spinner-white,.spinner-border.spinner-white{color:#fff}.spinner-pulse.spinner-white,.spinner-dots.spinner-white .dot{background-color:#fff}.spinner-gray,.spinner-border.spinner-gray{color:var(--color-text-muted)}.spinner-pulse.spinner-gray,.spinner-dots.spinner-gray .dot{background-color:var(--color-text-muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulse-scale{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(400%)}}:root{--vt-c-white: #ffffff;--vt-c-white-soft: #f8f8f8;--vt-c-white-mute: #f2f2f2;--vt-c-black: #181818;--vt-c-black-soft: #222222;--vt-c-black-mute: #282828;--vt-c-indigo: #2c3e50;--vt-c-divider-light-1: rgba(60, 60, 60, .29);--vt-c-divider-light-2: rgba(60, 60, 60, .12);--vt-c-divider-dark-1: rgba(84, 84, 84, .65);--vt-c-divider-dark-2: rgba(84, 84, 84, .48);--vt-c-text-light-1: var(--vt-c-indigo);--vt-c-text-light-2: rgba(60, 60, 60, .66);--vt-c-text-dark-1: var(--vt-c-white);--vt-c-text-dark-2: rgba(235, 235, 235, .64);--font-size-xs: 12px;--font-size-sm: 14px;--font-size-md: 15px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-xxl: 32px;--color-background: var(--vt-c-white);--color-background-soft: var(--vt-c-white-soft);--color-background-mute: var(--vt-c-white-mute);--color-border: var(--vt-c-divider-light-2);--color-border-hover: var(--vt-c-divider-light-1);--color-heading: var(--vt-c-text-light-1);--color-text: var(--vt-c-text-light-1);--section-gap: 160px}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;overflow-x:hidden}body{background-color:var(--color-body-bg);transition:color .5s,background-color .5s;line-height:1.6;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:15px;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}:root{--font-size-xs: 12px;--font-size-sm: 14px;--font-size-md: 15px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-xxl: 32px}.users-management-page,.analytics-container{min-height:100vh;padding-bottom:0;position:relative}h1{font-size:var(--font-size-xxl);font-weight:700;line-height:1.2}h2{font-size:var(--font-size-xl);font-weight:600;line-height:1.25}h3{font-size:var(--font-size-lg);font-weight:600;line-height:1.3}h4{font-size:var(--font-size-md);font-weight:600;line-height:1.35}h5{font-size:var(--font-size-sm);font-weight:500;line-height:1.4}h6{font-size:var(--font-size-xs);font-weight:500;line-height:1.45}.title-page{font-size:1.2rem;font-weight:700;color:var(--color-blue)}.title-xl{font-size:1.125rem;font-weight:700;color:var(--color-text-primary)}.title-lg{font-size:1rem;font-weight:700;color:var(--color-text-primary)}.title-md{font-size:.95rem;font-weight:600;color:var(--color-text-secondary)}.title-sm{font-size:.875rem;font-weight:600;color:var(--color-text-secondary)}.subtitle-base{font-size:.875rem;color:var(--color-text-muted);margin-top:.25rem}.subtitle-sm{font-size:.75rem;color:var(--color-text-subtle)}a,.green{text-decoration:none;color:var(--color-teal-500);transition:.4s;padding:3px}@media (hover: hover){a:hover{background-color:#e0f7f6}}.main-content{height:100vh;overflow:hidden;display:flex;flex-direction:column;background:var(--color-surface-raised)}.main-content .content-area{display:block;margin:60px 0 0 220px;min-width:0;height:calc(100vh - 60px);overflow-y:auto;overflow-x:hidden;transition:all .5s ease;flex:1}.main-content.sidebar-collapsed .content-area{margin-left:75px}.main-content.sidebar-collapsed .app-header{margin-left:85px;margin-right:15px;width:calc(100% - 110px)}@media (max-width: 1024px){.main-content,.main-content.sidebar-collapsed{margin-left:0;width:100%}.main-content .content-area,.main-content.sidebar-collapsed .content-area{margin:50px 0 0!important;width:100%}.main-content.sidebar-collapsed .app-header{margin-left:14px!important;width:calc(100% - 28px)!important}}.container{max-width:1200px;margin:0 auto;padding:0 1rem}@media (max-width: 768px){.container{padding:0 .5rem}}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text-primary)}.form-control{width:100%;padding:.75rem;border:2px solid var(--color-input-border);border-radius:6px;font-size:1rem;background-color:var(--color-input-bg);color:var(--color-text-primary);transition:border-color .3s ease}.form-control:focus{outline:none;border-color:var(--color-input-focus-border);box-shadow:0 0 0 3px var(--color-input-focus-shadow)}.form-control:disabled{background-color:var(--color-surface-raised);cursor:not-allowed}.card{background:var(--color-surface);border-radius:8px;padding:1.5rem;box-shadow:var(--shadow-md);margin-bottom:1rem}.card-title{margin:0;color:var(--color-text-primary);font-size:1.25rem}.alert{padding:.75rem;border-radius:6px;margin-bottom:1rem}.alert-danger{background-color:var(--color-red-bg);color:var(--color-red-hover);border:1px solid var(--color-red-border)}.alert-success{background-color:var(--color-green-bg);color:var(--color-green-hover);border:1px solid var(--color-green-border)}.alert-info{background-color:var(--color-blue-bg);color:var(--color-blue-hover);border:1px solid var(--color-blue-border)}.section-card{background:var(--color-surface);border-radius:1rem;box-shadow:var(--shadow-md);border:1px solid var(--color-border-light);padding:1rem}.section-title{margin:0}.content-grid{display:flex;flex-direction:column;gap:1.5rem}.analytics-container{min-height:100vh}.health-status-card{position:relative;background:var(--color-surface);border-radius:.5rem;border:1px solid;padding:1rem;transition:all .3s ease;overflow:hidden}.health-status-card:hover{box-shadow:0 4px 6px -1px rgba(var(--color-black-rgb),.1),0 2px 4px -1px rgba(var(--color-black-rgb),.06)}.status-indicator{position:absolute;top:0;left:0;width:100%;height:.4rem}.status-line-up{background:var(--color-teal-500)}.status-line-down{background:var(--color-red-coral)}.status-line-unknown{background:var(--color-text-subtle)}.card-up{border-color:var(--color-green-border)}.card-up:hover{border-color:var(--color-green)}.card-down{border-color:var(--color-red-border)}.card-down:hover{border-color:var(--color-red)}.card-unknown{border-color:var(--color-border)}.card-unknown:hover{border-color:var(--color-border-medium)}.ping-container{position:relative;display:inline-flex;align-items:center;justify-content:center;width:8px;height:8px;flex-shrink:0}.ping-animation{position:absolute;inset:0;border-radius:50%;background:var(--color-green);opacity:.6;animation:pingPulse 1.5s ease-out infinite}.ping-dot{position:relative;width:6px;height:6px;border-radius:50%;background:var(--color-green);flex-shrink:0}.offline-dot{width:6px;height:6px;border-radius:50%;background:var(--color-red);flex-shrink:0}@keyframes pingPulse{0%{transform:scale(1);opacity:.6}to{transform:scale(2.2);opacity:0}}.header-left{display:flex;align-items:center;gap:.75rem}.card-title{font-size:.875rem;font-weight:600;color:var(--color-text-secondary)}.card-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;justify-content:space-between;font-size:.75rem}.detail-key{color:var(--color-text-subtle);text-transform:capitalize}.detail-value{color:var(--color-text-muted);font-weight:500;padding:.125rem .5rem;border-radius:.25rem}.metric-title{font-size:.75rem;font-weight:500;color:var(--color-text-subtle);letter-spacing:.05em;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.metric-card{background:var(--color-surface);border-radius:.75rem;border:1px solid var(--color-border-light);padding:1rem;transition:all .3s ease}.metric-card:hover{box-shadow:0 4px 6px -1px rgba(var(--color-black-rgb),.1),0 2px 4px -1px rgba(var(--color-black-rgb),.06);border-color:var(--color-border)}.subtitle-dot{display:inline-block;width:.375rem;height:.375rem;border-radius:50%;background-color:var(--color-border-medium)}.footer{margin-top:2rem;margin-bottom:.5rem;text-align:center;font-size:.75rem;color:var(--color-text-subtle)}.zenopcb-mobile-fab{display:none}@media (max-width: 1024px){.zenopcb-mobile-fab{display:flex;align-items:center;justify-content:center;position:fixed;bottom:20px;left:16px;width:42px;height:42px;border-radius:12px;background:var(--color-primary);color:#fff;border:none;box-shadow:0 3px 12px rgba(var(--color-primary-rgb),.4);cursor:pointer;z-index:9999;transition:transform .2s ease}.zenopcb-mobile-fab svg{width:18px;height:18px}.zenopcb-mobile-fab:active{transform:scale(.92)}}[data-theme=dark] .main-content{background:var(--color-body-bg)}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:40px;height:28px;padding:0;border:1.75px solid var(--color-text-muted);border-radius:7px;background:none;cursor:pointer;overflow:hidden;transition:border-color .15s,box-shadow .15s,transform .15s}input[type=color]:hover:not(:disabled){border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12);transform:translateY(-1px)}input[type=color]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.18)}input[type=color]:disabled{opacity:.5;cursor:not-allowed}input[type=color]::-webkit-color-swatch-wrapper{padding:0;border:none;border-radius:5px}input[type=color]::-webkit-color-swatch{border:none;border-radius:5px}input[type=color]::-moz-color-swatch{border:none;border-radius:5px}.vue-grid-item{touch-action:none}:root{--toastify-z-index: 2147483000}.Toastify__toast-container{z-index:2147483000!important}:root{--auth-primary: var(--color-primary);--auth-primary-hover: var(--color-primary-hover);--auth-text-dark: #1a1a1a;--auth-text-medium: #666;--auth-text-light: var(--color-text-subtle);--auth-border: #e0e0e0;--auth-bg-light: #f8f9fa;--auth-error: var(--color-red-500);--auth-error-bg: rgba(var(--color-red-500-rgb), .15);--auth-error-border: rgba(var(--color-red-500-rgb), .3);--auth-white: #ffffff}[data-theme=dark]{--auth-text-dark: var(--color-gray-200-soft);--auth-text-medium: var(--color-text-subtle);--auth-text-light: var(--color-text-muted);--auth-border: #444444;--auth-bg-light: #2a2a2a;--auth-white: var(--color-surface)}.login-layout,.auth-wrapper{height:100vh;max-height:100vh;display:flex;font-family:Inter,sans-serif;background:var(--auth-white);justify-content:center;overflow:hidden}.auth-left-panel,.login-container{flex:0 0 480px;background:var(--auth-white);display:flex;align-items:safe center;justify-content:center;padding:20px;position:relative;overflow-y:auto;overflow-x:hidden;height:100%;box-sizing:border-box}.auth-form-container,.login-card{width:100%;max-width:480px;margin:0 auto;position:relative;z-index:1}.auth-header,.login-header{text-align:center;margin-bottom:32px}.auth-title,.login-title{font-size:2rem;font-weight:700;color:var(--auth-text-dark);margin:0 0 8px}.auth-subtitle{font-size:1rem;color:var(--auth-text-light);margin:0}.login-logo{max-width:250px;height:auto;margin-bottom:.5rem;filter:drop-shadow(0 2px 8px rgba(var(--color-black-rgb),.1))}.auth-form,.login-form{display:flex;flex-direction:column;gap:20px}.auth-form-group,.form-group{display:flex;flex-direction:column;gap:8px}.auth-label,.form-group label{font-size:.875rem;font-weight:500;color:var(--auth-text-dark)}.auth-input-wrap,.input-wrap{position:relative;display:flex;align-items:center}.auth-input-icon,.login-icon{position:absolute;left:14px;width:20px;height:20px;color:var(--auth-text-light);pointer-events:none;transition:color .3s}.auth-input,.input-wrap input{width:100%;padding:14px 14px 14px 48px;background:var(--auth-bg-light);border:1.5px solid var(--auth-border);border-radius:12px;font-size:.95rem;color:var(--auth-text-dark);transition:all .3s ease}.auth-input::-moz-placeholder,.input-wrap input::-moz-placeholder{color:var(--auth-text-light)}.auth-input::placeholder,.input-wrap input::placeholder{color:var(--auth-text-light)}.auth-input:focus,.input-wrap input:focus{outline:none;border-color:var(--auth-primary);background:var(--auth-white);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.auth-input:focus+.auth-input-icon,.auth-input-wrap:focus-within .auth-input-icon,.input-wrap input:focus+.login-icon{color:var(--auth-primary)}.auth-input:disabled,.input-wrap input:disabled{opacity:.6;cursor:not-allowed}.auth-password-toggle{position:absolute;right:14px;background:transparent;border:none;color:var(--auth-text-light);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .3s}.auth-password-toggle:hover,.auth-password-toggle:focus{color:var(--auth-primary);outline:none}.icon-toggle{width:20px;height:20px}.auth-error,.error-message{display:flex;align-items:center;gap:8px;padding:12px 14px;background:var(--auth-error-bg);border:1px solid var(--auth-error-border);border-radius:10px;color:var(--color-red-300);font-size:.875rem}.error-icon{width:18px;height:18px;flex-shrink:0}.auth-options{display:flex;justify-content:space-between;align-items:center}.auth-checkbox-label{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--auth-text-medium);cursor:pointer}.auth-checkbox{width:16px;height:16px;accent-color:var(--auth-primary);cursor:pointer}.auth-forgot-link{font-size:.875rem;color:var(--auth-primary);text-decoration:none;transition:color .3s}.auth-forgot-link:hover{color:var(--auth-primary-hover);text-decoration:underline}.auth-submit-btn,.login-button{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 24px;background:linear-gradient(135deg,var(--auth-primary) 0%,var(--auth-primary-hover) 100%);border:none;border-radius:12px;font-size:1rem;font-weight:600;color:var(--auth-white);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px rgba(var(--color-primary-rgb),.3);letter-spacing:.5px}.auth-submit-btn:hover:not(:disabled),.login-button:hover:not(:disabled){background:linear-gradient(135deg,var(--auth-primary-hover) 0%,var(--auth-primary) 100%);box-shadow:0 6px 20px rgba(var(--color-primary-rgb),.4);transform:translateY(-2px)}.auth-submit-btn:active:not(:disabled){transform:translateY(0)}.auth-submit-btn:disabled,.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-icon{width:20px;height:20px}.btn-icon.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-footer,.login-footer{text-align:center;margin-top:24px}.auth-footer p,.login-footer p{color:var(--auth-text-medium);font-size:.9rem;margin:0}.auth-link,.login-link{color:var(--auth-primary);text-decoration:none;font-weight:500;transition:color .3s}.auth-link:hover,.login-link:hover{color:var(--auth-primary-hover);text-decoration:underline}.recaptcha-notice{margin-top:16px;text-align:center}.recaptcha-notice p{font-size:11px;color:var(--auth-text-light);line-height:1.5;margin:0}.recaptcha-notice a{color:var(--auth-primary);text-decoration:none;transition:color .2s}.recaptcha-notice a:hover{color:var(--auth-primary-hover);text-decoration:underline}.auth-terms-group{padding:12px 14px;background:var(--auth-bg-light);border:1.5px solid var(--auth-border);border-radius:10px}.terms-label{align-items:flex-start!important}.terms-label .auth-checkbox{margin-top:2px;flex-shrink:0}.terms-text{font-size:.875rem;color:var(--auth-text-medium);line-height:1.5}.terms-link{color:var(--auth-primary);text-decoration:none;font-weight:500;transition:color .2s}.terms-link:hover{color:var(--auth-primary-hover);text-decoration:underline}.auth-bottom-row{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:32px}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;width:42px;height:42px;background:var(--auth-bg-light);border:1px solid var(--auth-border);border-radius:10px;color:var(--auth-text-dark);cursor:pointer;transition:all .3s;flex-shrink:0}.theme-toggle-btn:hover{background:var(--auth-primary);border-color:var(--auth-primary);color:#fff;transform:scale(1.05)}.theme-icon{width:18px;height:18px}.auth-lang-selector,.lang-popup-switch{position:relative;display:flex;justify-content:center}.lang-btn,.flag-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--auth-bg-light);border:1px solid var(--auth-border);border-radius:10px;color:var(--auth-text-dark);font-size:.875rem;cursor:pointer;transition:all .3s}.lang-btn:hover,.flag-btn:hover{background:#efefef;border-color:var(--color-gray-ccc)}.lang-icon,.flag-img{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.chevron-icon{width:16px;height:16px;transition:transform .3s}.chevron-icon.rotate{transform:rotate(180deg)}.lang-dropdown,.lang-popup-dropdown{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;background:var(--auth-white);border:1px solid var(--auth-border);border-radius:10px;box-shadow:0 4px 12px rgba(var(--color-black-rgb),.1);overflow:hidden;min-width:160px;z-index:20;display:flex;flex-direction:column}.lang-option,.lang-popup-option{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:transparent;border:none;color:var(--auth-text-dark);font-size:.9rem;cursor:pointer;transition:background .2s}.lang-option:hover,.lang-popup-option:hover{background:var(--auth-bg-light);color:var(--auth-primary)}.lang-flag{font-size:1.2rem}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease,transform .2s ease}.fade-enter-from,.fade-leave-to{opacity:0;transform:translate(-50%) translateY(10px)}.auth-mobile-logo{display:none}.auth-right-panel{flex:1;align-items:center;justify-content:center;padding:20px 20px 40px;overflow:hidden}.hero-content{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;max-width:600px}.hero-decoration{position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(var(--color-white-rgb),.1);filter:blur(60px)}.hero-decoration.top-left{top:-100px;left:-100px}.hero-decoration.bottom-right{bottom:-100px;right:-100px}.hero-image-container{position:relative;height:100%;max-width:800px;border-radius:24px;overflow:hidden;margin:10px 10px 20px}.hero-image{width:100%;height:100%;display:block;-o-object-fit:cover;object-fit:cover}.hero-text{text-align:center;margin-top:40px;position:relative;z-index:1}.hero-title{font-size:2.5rem;font-weight:700;color:var(--auth-white);margin:0 0 16px;text-shadow:0 2px 10px rgba(var(--color-black-rgb),.2)}.hero-description{font-size:1.1rem;color:rgba(var(--color-white-rgb),.9);line-height:1.6;margin:0}@media (max-width: 900px){.auth-right-panel{display:none}.auth-left-panel,.login-container{flex:1 1 100%}}@media (max-width: 600px){.auth-mobile-logo{display:flex;justify-content:center;margin-bottom:16px}.auth-mobile-logo img{width:160px;height:auto;-o-object-fit:contain;object-fit:contain}.login-layout,.auth-wrapper{overflow-y:auto;overflow-x:hidden;height:100vh;max-height:100vh;-webkit-overflow-scrolling:touch}.auth-left-panel,.login-container{flex:1 1 100%;padding:48px 20px 24px;overflow:visible;min-height:100vh;height:auto;align-items:flex-start}.auth-form-container,.login-card{max-width:100%;width:100%;padding:0}.auth-title,.login-title{font-size:1.6rem}.auth-subtitle{font-size:.9rem}.auth-header,.login-header{margin-bottom:24px}.auth-form,.login-form{gap:16px}.auth-input,.input-wrap input{padding:12px 12px 12px 44px;font-size:.9rem}.auth-submit-btn,.login-button{padding:12px 20px;font-size:.95rem}.auth-options{flex-wrap:wrap;gap:8px}.auth-bottom-row{margin-top:24px}.auth-right-panel{display:none}}.sidebar[data-v-cee4f15d]{width:200px;height:calc(100vh - 30px);background:var(--color-surface);color:var(--color-text-primary);display:flex;flex-direction:column;position:fixed;z-index:100;box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:width .3s ease;border-radius:10px;margin:15px;overflow:hidden}.sidebar.collapsed[data-v-cee4f15d]{width:60px;overflow:visible}.sidebar.collapsed .sidebar-nav[data-v-cee4f15d]{overflow:visible}.sidebar-logo[data-v-cee4f15d]{display:flex;align-items:center;justify-content:center;padding:16px 12px;border-bottom:1px solid var(--color-border);transition:all .3s ease;min-height:70px;position:relative;z-index:102}.logo-img[data-v-cee4f15d]{width:80%;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.menu-btn[data-v-cee4f15d]{background:var(--color-surface-overlay);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:8px;border-radius:8px;width:40px;height:40px;position:relative;z-index:1000}.menu-btn[data-v-cee4f15d]:hover{background:var(--color-primary);transform:scale(1.05)}.menu-btn:hover .menu-icon[data-v-cee4f15d]{color:var(--color-white)}.menu-icon[data-v-cee4f15d]{width:20px;height:20px;color:var(--color-text-muted);transition:all .3s ease}.sidebar-nav[data-v-cee4f15d]{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;padding-bottom:60px;margin-top:0;position:relative;z-index:1}.nav-section[data-v-cee4f15d]{padding:0}.nav-item[data-v-cee4f15d],.nav-group-header[data-v-cee4f15d]{display:flex;align-items:center;gap:12px;padding:8px;color:var(--color-text-secondary);text-decoration:none;font-size:14px;cursor:pointer;transition:all .3s ease;border-radius:0;position:relative;justify-content:flex-start}.sidebar.collapsed .nav-item[data-v-cee4f15d],.sidebar.collapsed .nav-group-header[data-v-cee4f15d]{gap:12px;padding:8px;justify-content:center}.nav-item[data-v-cee4f15d]:hover,.nav-group-header[data-v-cee4f15d]:hover{background:var(--color-surface-overlay)}.sidebar.collapsed .nav-item[data-v-cee4f15d]:hover,.sidebar.collapsed .nav-group-header[data-v-cee4f15d]:hover{transform:none}.icon-wrapper[data-v-cee4f15d]{position:relative;width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;border:2px solid transparent;flex-shrink:0;background:transparent}.nav-cart-badge[data-v-cee4f15d]{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--color-red);color:var(--color-white);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--color-surface);pointer-events:none}.nav-item .nav-icon[data-v-cee4f15d],.nav-group-header .nav-icon[data-v-cee4f15d]{color:var(--color-text-muted);transition:color .3s ease}.nav-item:hover .nav-icon[data-v-cee4f15d],.nav-group-header:hover .nav-icon[data-v-cee4f15d]{color:var(--color-primary)}.nav-item.active .icon-wrapper[data-v-cee4f15d]{background:var(--color-primary);border:3px solid var(--color-primary);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.nav-item.active .nav-icon[data-v-cee4f15d]{color:var(--color-white)!important}.nav-item.active[data-v-cee4f15d]{color:var(--color-text-primary)}.nav-item:hover .icon-wrapper[data-v-cee4f15d],.nav-group-header:hover .icon-wrapper[data-v-cee4f15d]{transform:scale(1.1)}.nav-icon[data-v-cee4f15d]{width:22px;height:22px;transition:color .3s ease;flex-shrink:0}.nav-text[data-v-cee4f15d]{flex:1;min-width:0;font-weight:500;white-space:nowrap;overflow:hidden;display:flex;align-items:center}.nav-text-label[data-v-cee4f15d]{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-arrow[data-v-cee4f15d]{width:16px;height:16px;opacity:.7;color:var(--color-text-muted);transition:transform .3s,color .3s;flex-shrink:0}.nav-group[data-v-cee4f15d]{margin-bottom:4px;position:relative}.nav-flyout[data-v-cee4f15d]{position:absolute;left:calc(100% + 8px);top:0;min-width:185px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:6px 0;box-shadow:0 8px 24px rgba(var(--color-black-rgb),.15),0 2px 8px rgba(var(--color-black-rgb),.08);z-index:9999}.nav-flyout-title[data-v-cee4f15d]{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--color-text-muted);padding:6px 14px 8px;border-bottom:1px solid var(--color-border-light);margin-bottom:4px;white-space:nowrap}.nav-flyout-item[data-v-cee4f15d]{display:flex;align-items:center;justify-content:space-between;padding:9px 16px;font-size:13px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:background .15s,color .15s;white-space:nowrap}.nav-flyout-item[data-v-cee4f15d]:hover,.nav-flyout-item.active[data-v-cee4f15d]{background:var(--color-surface-overlay);color:var(--color-primary)}.flyout-badge[data-v-cee4f15d]{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--color-red-500);color:var(--color-white);font-size:10px;font-weight:600;border-radius:5px}.flyout-count[data-v-cee4f15d]{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;min-width:18px;height:18px;padding:0 5px;background:var(--color-red-500);color:var(--color-white);font-size:10px;font-weight:600;border-radius:5px}.nav-sub-menu[data-v-cee4f15d]{padding-left:38px;display:flex;flex-direction:column;gap:2px}.nav-sub-item[data-v-cee4f15d]{display:flex;align-items:center;justify-content:space-between;color:var(--color-text-secondary);font-size:13px;padding:8px 12px;border-radius:4px;text-decoration:none;transition:background .2s,color .2s;margin-bottom:2px}.nav-sub-item[data-v-cee4f15d]:hover,.nav-sub-item.active[data-v-cee4f15d]{background:var(--color-surface-overlay);color:var(--color-primary)}.sidebar.collapsed .nav-sub-menu[data-v-cee4f15d]{display:none}.sidebar-footer[data-v-cee4f15d]{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;display:flex;justify-content:flex-end;align-items:center;z-index:101}.sidebar.collapsed .sidebar-footer[data-v-cee4f15d]{padding:8px 4px;justify-content:center}.nav-item-support:hover .icon-wrapper[data-v-cee4f15d]{transform:scale(1.1)}.toggle-btn[data-v-cee4f15d]{background:var(--color-surface-overlay);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:8px;margin-bottom:5px;border-radius:8px;width:40px;height:40px}.toggle-btn[data-v-cee4f15d]:hover{background:var(--color-primary);transform:scale(1.05)}.toggle-btn:hover .toggle-icon[data-v-cee4f15d]{color:var(--color-white)}.toggle-icon[data-v-cee4f15d]{width:20px;height:20px;color:var(--color-text-muted);transition:all .3s ease}.badge[data-v-cee4f15d]{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;min-width:20px;height:20px;padding:0 6px;margin-left:8px;background:var(--color-red-500);color:var(--color-white);font-size:11px;font-weight:600;border-radius:5px;line-height:1}.sub-badge[data-v-cee4f15d]{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;min-width:18px;height:18px;padding:0 5px;margin-left:auto;background:var(--color-red-500);color:var(--color-white);font-size:10px;font-weight:600;border-radius:5px;line-height:1}.sidebar-nav[data-v-cee4f15d]::-webkit-scrollbar{width:6px}.sidebar-nav[data-v-cee4f15d]::-webkit-scrollbar-track{background:var(--color-surface-raised)}.sidebar-nav[data-v-cee4f15d]::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.sidebar-nav[data-v-cee4f15d]::-webkit-scrollbar-thumb:hover{background:var(--color-border-medium)}@media (max-width: 1024px){.sidebar[data-v-cee4f15d],.sidebar-footer[data-v-cee4f15d],.toggle-btn[data-v-cee4f15d]{display:none!important}}.sidebar.collapsed .nav-group-header.flyout-active[data-v-cee4f15d]{background:var(--color-surface-overlay)}.sidebar.collapsed .nav-group-header.flyout-active .icon-wrapper[data-v-cee4f15d]{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3);transform:scale(1.1)}.sidebar.collapsed .nav-group-header.flyout-active .nav-icon[data-v-cee4f15d]{color:var(--color-white)!important}[data-theme=dark] .sidebar[data-v-cee4f15d]{border-color:transparent}.app-header[data-v-3c22ab8a]{border-bottom:none;display:flex;align-items:center;justify-content:space-between;position:fixed;margin-left:230px;width:calc(100% - 255px);margin-right:15px;top:15px;z-index:999;gap:20px;transition:all .3s ease;border-radius:16px}.app-header.scrolled[data-v-3c22ab8a]{background:rgba(var(--color-white-rgb),.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border);box-shadow:0 4px 20px rgba(var(--color-black-rgb),.08);padding:10px 20px}.header-left[data-v-3c22ab8a]{display:flex;align-items:center;gap:12px;transition:all .3s ease}.page-title-wrapper[data-v-3c22ab8a]{display:flex;align-items:center;gap:8px;transition:all .3s ease}.page-icon[data-v-3c22ab8a]{width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--color-primary-hover);font-size:24px;transition:all .3s ease}.device-header-inline[data-v-3c22ab8a]{display:flex;align-items:center;gap:12px;min-width:0}.page-icon--device[data-v-3c22ab8a]{width:38px;height:38px;border-radius:9px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);flex-shrink:0;box-shadow:0 3px 8px rgba(var(--color-primary-rgb),.28)}.device-header-name[data-v-3c22ab8a]{margin:0;font-size:18px;font-weight:700;color:var(--color-text-primary);line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:420px}.device-skeleton-icon[data-v-3c22ab8a]{background:linear-gradient(110deg,rgba(var(--color-primary-rgb),.35),rgba(var(--color-primary-rgb),.55),rgba(var(--color-primary-rgb),.35));background-size:200% 100%;animation:skeleton-shimmer-3c22ab8a 1.4s ease-in-out infinite;color:transparent!important}.device-skeleton-name[data-v-3c22ab8a]{height:22px;width:180px;border-radius:6px;background:linear-gradient(110deg,var(--color-surface-overlay) 0%,var(--color-border-light) 50%,var(--color-surface-overlay) 100%);background-size:200% 100%;animation:skeleton-shimmer-3c22ab8a 1.4s ease-in-out infinite}@keyframes skeleton-shimmer-3c22ab8a{0%{background-position:200% 0}to{background-position:-200% 0}}.device-meta-pills[data-v-3c22ab8a]{display:flex;align-items:center;gap:6px;margin-right:4px}.device-meta-pill[data-v-3c22ab8a]{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 12px;border-radius:18px;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;box-shadow:var(--shadow-md);border:1px solid var(--color-border);background:var(--color-surface);transition:all .2s}.device-meta-pill--type[data-v-3c22ab8a]{color:var(--color-primary-hover);background:linear-gradient(135deg,rgba(var(--color-primary-rgb),.12),rgba(var(--color-primary-rgb),.06));border-color:rgba(var(--color-primary-rgb),.32)}.device-meta-pill--online[data-v-3c22ab8a]{color:var(--color-primary-hover);background:linear-gradient(135deg,rgba(var(--color-legacy-green-rgb),.12),rgba(var(--color-legacy-green-rgb),.06));border-color:rgba(var(--color-legacy-green-rgb),.32)}.device-meta-pill--offline[data-v-3c22ab8a]{color:var(--color-text-muted);background:var(--color-surface);border-color:var(--color-border)}.device-meta-pill--perm-owner[data-v-3c22ab8a]{color:var(--color-amber-700);background:linear-gradient(135deg,rgba(var(--color-amber-rgb),.16),rgba(var(--color-amber-rgb),.06));border-color:rgba(var(--color-amber-rgb),.36);gap:4px}.device-meta-pill--perm-full[data-v-3c22ab8a]{color:var(--color-green-hover);background:linear-gradient(135deg,rgba(var(--color-success-rgb),.14),rgba(var(--color-success-rgb),.06));border-color:rgba(var(--color-success-rgb),.32);gap:4px}.device-meta-pill--perm-view[data-v-3c22ab8a]{color:var(--color-blue-hover);background:linear-gradient(135deg,rgba(var(--color-blue-rgb),.14),rgba(var(--color-blue-rgb),.06));border-color:rgba(var(--color-blue-rgb),.32);gap:4px}.device-meta-pill-dot[data-v-3c22ab8a]{width:7px;height:7px;border-radius:50%;background:currentColor}.device-meta-pill--online .device-meta-pill-dot[data-v-3c22ab8a]{animation:header-dot-pulse-3c22ab8a 2s infinite}@keyframes header-dot-pulse-3c22ab8a{0%,to{box-shadow:0 0 rgba(var(--color-legacy-green-rgb),.55)}50%{box-shadow:0 0 0 4px rgba(var(--color-legacy-green-rgb),0)}}.device-menu-wrapper[data-v-3c22ab8a]{position:relative;margin-right:4px}.device-menu-trigger[data-v-3c22ab8a]{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border:none;box-shadow:0 3px 10px rgba(var(--color-primary-rgb),.32);cursor:pointer;color:var(--color-white);display:flex;align-items:center;justify-content:center;transition:all .2s}.device-menu-trigger[data-v-3c22ab8a]:hover{transform:translateY(-1px);box-shadow:0 5px 16px rgba(var(--color-primary-rgb),.45)}.device-menu-trigger.is-open[data-v-3c22ab8a]{background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary-700) 100%);box-shadow:0 0 0 4px rgba(var(--color-primary-rgb),.22),0 3px 10px rgba(var(--color-primary-rgb),.4)}.device-menu-dropdown[data-v-3c22ab8a]{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 12px 28px rgba(var(--color-black-rgb),.14);padding:6px;z-index:1001;display:flex;flex-direction:column;gap:2px}.device-menu-item[data-v-3c22ab8a]{display:flex;align-items:center;gap:10px;padding:8px 12px;border:none;background:none;width:100%;text-align:left;font-size:13px;font-weight:500;color:var(--color-text-primary);border-radius:7px;cursor:pointer;transition:background .15s,color .15s}.device-menu-item[data-v-3c22ab8a]:hover{background:var(--color-surface-raised);color:var(--color-primary)}.device-menu-item[data-v-3c22ab8a]:disabled{opacity:.55;cursor:not-allowed}.device-menu-item .icon-spin[data-v-3c22ab8a]{animation:spin-3c22ab8a 1s linear infinite}@keyframes spin-3c22ab8a{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dh-menu-fade-enter-active[data-v-3c22ab8a],.dh-menu-fade-leave-active[data-v-3c22ab8a]{transition:opacity .15s ease,transform .15s ease}.dh-menu-fade-enter-from[data-v-3c22ab8a],.dh-menu-fade-leave-to[data-v-3c22ab8a]{opacity:0;transform:translateY(-4px)}@media (max-width: 1100px){.device-meta-pill--type[data-v-3c22ab8a]{display:none}}@media (max-width: 900px){.device-header-name[data-v-3c22ab8a]{max-width:160px;font-size:15px}.device-meta-pill[data-v-3c22ab8a]{padding:0;width:36px;justify-content:center;font-size:0}.device-meta-pill-dot[data-v-3c22ab8a]{width:9px;height:9px}}@media (max-width: 1024px){.device-header-name[data-v-3c22ab8a]{max-width:75px;font-size:14px}.device-meta-pill[data-v-3c22ab8a]{width:30px;height:30px;padding:0;gap:0;border-radius:50%;font-size:0;justify-content:center;align-items:center}.device-meta-pill--type[data-v-3c22ab8a]{display:none}.device-meta-pill-dot[data-v-3c22ab8a]{width:10px;height:10px;margin:0}}.back-btn[data-v-3c22ab8a]{width:40px;height:40px;border-radius:50%;background:var(--color-surface);box-shadow:var(--shadow-md);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:var(--color-text-muted)}.back-btn[data-v-3c22ab8a]:hover{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);transform:translate(-2px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.page-title[data-v-3c22ab8a]{font-size:20px;font-weight:600;color:var(--color-text-primary);margin:0;transition:all .3s ease;white-space:nowrap}.sidebar-toggle[data-v-3c22ab8a]{background:var(--color-surface-raised);border:1px solid var(--color-border);padding:10px;cursor:pointer;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--color-text-muted);width:40px;height:40px}.sidebar-toggle[data-v-3c22ab8a]:hover{background:var(--color-surface-overlay);border-color:var(--color-border-medium);color:var(--color-blue)}.sidebar-toggle-icon[data-v-3c22ab8a]{width:20px;height:20px}.header-logo[data-v-3c22ab8a]{display:flex;align-items:center;gap:10px;padding:8px 16px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:12px;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.2)}.logo-icon[data-v-3c22ab8a]{width:20px;height:20px;color:var(--color-white)}.logo-text[data-v-3c22ab8a]{font-size:16px;font-weight:700;color:var(--color-white)}.header-center[data-v-3c22ab8a]{flex:1;max-width:500px;margin:0 20px}.search-box[data-v-3c22ab8a]{position:relative;width:100%}.search-icon[data-v-3c22ab8a]{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-subtle);pointer-events:none}.search-input[data-v-3c22ab8a]{padding:10px 16px 10px 42px;border:1px solid var(--color-input-border);border-radius:12px;background:var(--color-input-bg);font-size:14px;color:var(--color-text-primary);outline:none;transition:all .2s ease}.search-input[data-v-3c22ab8a]::-moz-placeholder{color:var(--color-text-muted)}.search-input[data-v-3c22ab8a]::placeholder{color:var(--color-text-muted)}.search-input[data-v-3c22ab8a]:focus{background:var(--color-surface);border-color:var(--color-blue);box-shadow:0 0 0 3px rgba(var(--color-blue-rgb),.1)}.header-right[data-v-3c22ab8a]{display:flex;align-items:center;gap:12px}.header-nav[data-v-3c22ab8a]{display:flex;align-items:center;gap:8px}.nav-link-round[data-v-3c22ab8a]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--color-text-muted);text-decoration:none;background:var(--color-surface);box-shadow:var(--shadow-md);border:1px solid var(--color-border);border-radius:12px;transition:all .2s ease}.nav-link-round[data-v-3c22ab8a]:hover{color:var(--color-white);background:var(--color-primary-hover);transform:translateY(-2px)}.lang-label[data-v-3c22ab8a]{font-size:11px;font-weight:700;letter-spacing:.5px}.user-menu[data-v-3c22ab8a]{position:relative}.user-avatar-wrapper[data-v-3c22ab8a]{height:40px;display:flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;border-radius:12px;background:var(--color-surface);box-shadow:var(--shadow-md);border:1px solid var(--color-border);cursor:pointer;transition:all .2s ease}.user-avatar-wrapper[data-v-3c22ab8a]:hover{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-color:var(--color-primary-hover);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3);transform:translateY(-2px)}.user-avatar-wrapper:hover .user-name-header[data-v-3c22ab8a]{color:var(--color-white)}.user-avatar[data-v-3c22ab8a]{width:32px;height:32px;border-radius:50%;overflow:hidden;border:2px solid var(--color-white);box-shadow:var(--shadow-md);flex-shrink:0;transition:all .2s ease}.user-avatar img[data-v-3c22ab8a]{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.user-info-header[data-v-3c22ab8a]{display:flex;flex-direction:column;gap:2px}.user-name-header[data-v-3c22ab8a]{font-size:13px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;transition:color .2s ease}.user-dropdown[data-v-3c22ab8a]{position:absolute;top:calc(100% + 10px);right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-dropdown);min-width:220px;z-index:1000;overflow:hidden}.user-info[data-v-3c22ab8a]{padding:16px;background:linear-gradient(135deg,rgba(var(--color-legacy-blue-rgb),.05),rgba(var(--color-purple-rgb),.05));border-bottom:1px solid var(--color-border)}.user-name[data-v-3c22ab8a]{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.user-email[data-v-3c22ab8a]{font-size:12px;color:var(--color-text-muted)}.user-dropdown hr[data-v-3c22ab8a]{margin:0;border:none;border-top:1px solid var(--color-border)}.dropdown-item[data-v-3c22ab8a]{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;color:var(--color-text-primary);text-decoration:none;font-size:14px;border:none;background:none;text-align:left;cursor:pointer;transition:all .2s ease}.dropdown-item[data-v-3c22ab8a]:hover{background:var(--color-surface-raised);padding-left:20px}.dropdown-item.logout[data-v-3c22ab8a]{color:var(--color-red-500)}.dropdown-item.logout[data-v-3c22ab8a]:hover{background:var(--color-red-bg);color:var(--color-red)}.dropdown-icon[data-v-3c22ab8a]{width:16px;height:16px;flex-shrink:0}@media (max-width: 1024px){.app-header[data-v-3c22ab8a]{margin-left:14px!important;width:calc(100% - 28px)!important;margin-right:14px;top:10px;border-radius:14px;background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;border:none!important;box-shadow:none!important;gap:10px}.back-btn[data-v-3c22ab8a]{display:flex;width:32px;height:32px;padding:0;background:rgba(var(--color-white-rgb),.85);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 1px 4px rgba(var(--color-black-rgb),.08);color:var(--color-text-primary);align-items:center;justify-content:center;flex-shrink:0}.page-title[data-v-3c22ab8a]{font-size:15px}.page-icon[data-v-3c22ab8a]{width:32px;height:32px}.header-center[data-v-3c22ab8a],.header-nav .nav-link-round[data-v-3c22ab8a],.user-info-header[data-v-3c22ab8a]{display:none}.user-avatar-wrapper[data-v-3c22ab8a]{height:36px;padding:2px;gap:0;border-radius:50%}.user-avatar[data-v-3c22ab8a]{width:30px;height:30px}}[data-theme=dark] .app-header.scrolled[data-v-3c22ab8a]{background:rgba(var(--color-surface-dark-rgb),.92);border-color:var(--color-border);box-shadow:0 4px 20px rgba(var(--color-black-rgb),.35)}.sidebar[data-v-4a414527]{width:200px;height:calc(100vh - 30px);background:var(--color-surface);color:var(--color-text-primary);display:flex;flex-direction:column;position:fixed;z-index:100;box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:width .3s ease;border-radius:10px;margin:15px;overflow:hidden}.sidebar-logo[data-v-4a414527]{display:flex;align-items:center;justify-content:center;padding:16px 12px;border-bottom:1px solid var(--color-border);transition:all .3s ease;min-height:70px;position:relative;z-index:102}.logo-img[data-v-4a414527]{width:80%;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.menu-btn[data-v-4a414527]{background:var(--color-surface-overlay);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:8px;border-radius:8px;width:40px;height:40px;position:relative;z-index:1000}.menu-btn[data-v-4a414527]:hover{background:var(--color-primary);transform:scale(1.05)}.menu-btn:hover .menu-icon[data-v-4a414527]{color:var(--color-white)}.menu-icon[data-v-4a414527]{width:20px;height:20px;color:var(--color-text-muted);transition:all .3s ease}.sidebar.collapsed[data-v-4a414527]{width:60px;overflow:visible}.sidebar.collapsed .sidebar-nav[data-v-4a414527]{overflow:visible}.sidebar-nav[data-v-4a414527]{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:60px;margin-top:0;position:relative;z-index:1}.nav-section[data-v-4a414527]{padding:0}.nav-item[data-v-4a414527],.nav-group-header[data-v-4a414527]{display:flex;align-items:center;gap:12px;padding:8px;color:var(--color-text-secondary);text-decoration:none;font-size:14px;cursor:pointer;transition:all .3s ease;border-radius:0;position:relative;justify-content:flex-start}.sidebar.collapsed .nav-item[data-v-4a414527],.sidebar.collapsed .nav-group-header[data-v-4a414527]{gap:12px;padding:8px;justify-content:center}.nav-item[data-v-4a414527]:hover,.nav-group-header[data-v-4a414527]:hover{background:var(--color-surface-overlay)}.sidebar.collapsed .nav-item[data-v-4a414527]:hover,.sidebar.collapsed .nav-group-header[data-v-4a414527]:hover{transform:none}.sidebar.collapsed .nav-group-header.flyout-active[data-v-4a414527]{background:var(--color-surface-overlay)}.sidebar.collapsed .nav-group-header.flyout-active .icon-wrapper[data-v-4a414527]{background:var(--color-legacy-orange-light);border-color:var(--color-legacy-orange-light);box-shadow:0 4px 12px rgba(var(--color-legacy-orange-light-rgb),.3);transform:scale(1.1)}.sidebar.collapsed .nav-group-header.flyout-active .nav-icon[data-v-4a414527]{color:var(--color-white)!important}.icon-wrapper[data-v-4a414527]{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;border:2px solid transparent;flex-shrink:0;background:transparent}.nav-item-dashboard .nav-icon[data-v-4a414527]{color:var(--color-legacy-blue-bright);transition:color .3s ease}.nav-item-dashboard:hover .nav-icon[data-v-4a414527]{color:var(--color-nav-dashboard)}.nav-item-users .nav-icon[data-v-4a414527]{color:var(--color-teal-500);transition:color .3s ease}.nav-item-users:hover .nav-icon[data-v-4a414527]{color:var(--color-nav-users)}.nav-item-devices .nav-icon[data-v-4a414527]{color:var(--color-nav-devices);transition:color .3s ease}.nav-item-devices:hover .nav-icon[data-v-4a414527]{color:var(--color-nav-devices-hover)}.nav-item-monitoring .nav-icon[data-v-4a414527]{color:var(--color-legacy-orange-light);transition:color .3s ease}.nav-item-monitoring:hover .nav-icon[data-v-4a414527]{color:var(--color-nav-monitoring)}.nav-item-storage .nav-icon[data-v-4a414527]{color:var(--color-nav-storage);transition:color .3s ease}.nav-item-storage:hover .nav-icon[data-v-4a414527]{color:var(--color-nav-storage-hover)}.nav-item-notifications .nav-icon[data-v-4a414527]{color:var(--color-red-coral);transition:color .3s ease}.nav-item-notifications:hover .nav-icon[data-v-4a414527]{color:var(--color-nav-notifications)}.nav-item-tracking .nav-icon[data-v-4a414527]{color:var(--color-nav-tracking);transition:color .3s ease}.nav-item-tracking:hover .nav-icon[data-v-4a414527]{color:var(--color-nav-tracking-hover)}.nav-item-settings .nav-icon[data-v-4a414527]{color:var(--color-nav-settings);transition:color .3s ease}.nav-item-settings:hover .nav-icon[data-v-4a414527]{color:var(--color-legacy-blue-bright)}.nav-item-commission .nav-icon[data-v-4a414527]{color:var(--color-primary);transition:color .3s ease}.nav-item-commission:hover .nav-icon[data-v-4a414527]{color:var(--color-primary-hover)}.nav-item.active .icon-wrapper[data-v-4a414527]{background:var(--color-legacy-orange-light);border:3px solid var(--color-legacy-orange-light);box-shadow:0 4px 12px rgba(var(--color-legacy-orange-light-rgb),.3)}.nav-item.active .nav-icon[data-v-4a414527]{color:var(--color-white)!important}.nav-item.active[data-v-4a414527]{color:var(--color-text-primary)}.nav-item:hover .icon-wrapper[data-v-4a414527],.nav-group-header:hover .icon-wrapper[data-v-4a414527]{transform:scale(1.1)}.nav-icon[data-v-4a414527]{width:22px;height:22px;transition:color .3s ease;flex-shrink:0}.nav-text[data-v-4a414527]{flex:1;font-weight:500;white-space:nowrap;overflow:hidden}.nav-arrow[data-v-4a414527]{width:16px;height:16px;opacity:.7;color:var(--color-text-muted);transition:transform .3s,color .3s;flex-shrink:0}.nav-group[data-v-4a414527]{margin-bottom:4px;position:relative}.nav-flyout[data-v-4a414527]{position:absolute;left:calc(100% + 8px);top:0;min-width:185px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:6px 0;box-shadow:0 8px 24px rgba(var(--color-black-rgb),.15),0 2px 8px rgba(var(--color-black-rgb),.08);z-index:9999}.nav-flyout-title[data-v-4a414527]{font-size:11px;font-weight:700;color:var(--color-text-muted);padding:6px 14px 8px;border-bottom:1px solid var(--color-border-light);margin-bottom:4px;white-space:nowrap}.nav-flyout-item[data-v-4a414527]{display:block;padding:9px 16px;font-size:13px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:background .15s,color .15s;white-space:nowrap}.nav-flyout-item[data-v-4a414527]:hover,.nav-flyout-item.active[data-v-4a414527]{background:var(--color-surface-overlay);color:var(--color-legacy-orange-light)}.nav-sub-menu[data-v-4a414527]{padding-left:38px;display:flex;flex-direction:column;gap:2px}.nav-sub-item[data-v-4a414527]{display:flex;align-items:center;color:var(--color-text-secondary);font-size:13px;padding:8px 12px;border-radius:4px;text-decoration:none;transition:background .2s,color .2s;margin-bottom:2px}.nav-sub-item[data-v-4a414527]:hover,.nav-sub-item.active[data-v-4a414527]{background:var(--color-surface-overlay);color:var(--color-blue)}.sidebar.collapsed .nav-sub-menu[data-v-4a414527]{display:none}.sidebar-footer[data-v-4a414527]{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;display:flex;justify-content:flex-end;align-items:center;z-index:101}.sidebar.collapsed .sidebar-footer[data-v-4a414527]{padding:8px 4px;justify-content:center}.toggle-btn[data-v-4a414527]{background:var(--color-surface-overlay);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:8px;margin-bottom:5px;border-radius:8px;width:40px;height:40px}.toggle-btn[data-v-4a414527]:hover{background:var(--color-primary);transform:scale(1.05)}.toggle-btn:hover .toggle-icon[data-v-4a414527]{color:var(--color-white)}.toggle-icon[data-v-4a414527]{width:20px;height:20px;color:var(--color-text-muted);transition:all .3s ease}.sidebar-nav[data-v-4a414527]::-webkit-scrollbar{width:6px}.sidebar-nav[data-v-4a414527]::-webkit-scrollbar-track{background:var(--color-surface-raised)}.sidebar-nav[data-v-4a414527]::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.sidebar-nav[data-v-4a414527]::-webkit-scrollbar-thumb:hover{background:var(--color-border-medium)}@media (max-width: 768px){.sidebar[data-v-4a414527],.sidebar-footer[data-v-4a414527]{display:none!important}}[data-theme=dark] .sidebar[data-v-4a414527]{border-color:transparent}.admin-mobile-fab[data-v-16efaeb5],.admin-mobile-overlay[data-v-16efaeb5],.admin-mobile-drawer[data-v-16efaeb5]{display:none}@media (max-width: 768px){.admin-mobile-fab[data-v-16efaeb5]{display:flex;align-items:center;justify-content:center;position:fixed;bottom:20px;left:20px;width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--color-legacy-orange-light) 0%,var(--color-nav-monitoring) 100%);border:none;cursor:pointer;z-index:1000;box-shadow:0 4px 16px rgba(var(--color-legacy-orange-light-rgb),.45);transition:transform .2s ease,box-shadow .2s ease}.admin-mobile-fab[data-v-16efaeb5]:active{transform:scale(.92);box-shadow:0 2px 8px rgba(var(--color-legacy-orange-light-rgb),.3)}.admin-mobile-overlay[data-v-16efaeb5]{display:block;position:fixed;inset:0;background:rgba(var(--color-black-rgb),.45);z-index:1100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.admin-mobile-drawer[data-v-16efaeb5]{display:flex;flex-direction:column;position:fixed;top:0;left:0;width:280px;height:100dvh;background:var(--color-surface);z-index:1200;overflow-y:auto;box-shadow:4px 0 24px rgba(var(--color-black-rgb),.15)}.drawer-header[data-v-16efaeb5]{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--color-border);background:var(--color-surface-raised)}.drawer-logo[data-v-16efaeb5]{height:36px;-o-object-fit:contain;object-fit:contain}.drawer-close[data-v-16efaeb5]{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--color-surface-overlay);border-radius:8px;cursor:pointer;color:var(--color-text-muted);transition:background .15s}.drawer-close[data-v-16efaeb5]:hover{background:var(--color-border)}.drawer-nav[data-v-16efaeb5]{flex:1;padding:8px 0;overflow-y:auto}.drawer-item[data-v-16efaeb5]{display:flex;align-items:center;gap:12px;padding:11px 16px;color:var(--color-text-secondary);text-decoration:none;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;border-radius:0}.drawer-item[data-v-16efaeb5]:hover{background:var(--color-surface-raised)}.drawer-item.active[data-v-16efaeb5]{background:var(--color-primary-bg);color:var(--color-primary-hover)}.drawer-item.active .drawer-icon-wrap[data-v-16efaeb5]{background:var(--color-legacy-orange-light);color:var(--color-white)}.drawer-icon-wrap[data-v-16efaeb5]{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-overlay);color:var(--color-text-muted);flex-shrink:0;transition:all .2s}.drawer-item-dashboard .drawer-icon-wrap[data-v-16efaeb5]{color:var(--color-legacy-blue-bright);background:var(--color-nav-dashboard-bg)}.drawer-item-users .drawer-icon-wrap[data-v-16efaeb5]{color:var(--color-teal-500);background:var(--color-nav-users-bg)}.drawer-item-devices .drawer-icon-wrap[data-v-16efaeb5]{color:var(--color-nav-devices);background:var(--color-nav-devices-bg)}.drawer-item-monitoring .drawer-icon-wrap[data-v-16efaeb5]{color:var(--color-legacy-orange-light);background:var(--color-nav-monitoring-bg)}.drawer-item-storage .drawer-icon-wrap[data-v-16efaeb5]{color:var(--color-nav-storage);background:var(--color-nav-storage-bg)}.drawer-item-notifications .drawer-icon-wrap[data-v-16efaeb5]{color:var(--color-red-coral);background:var(--color-nav-notifications-bg)}.drawer-item-tracking .drawer-icon-wrap[data-v-16efaeb5]{color:var(--color-nav-storage);background:var(--color-nav-storage-bg)}.drawer-item-settings .drawer-icon-wrap[data-v-16efaeb5]{color:var(--color-nav-settings);background:var(--color-nav-settings-bg)}.chevron[data-v-16efaeb5]{margin-left:auto;color:var(--color-text-subtle);transition:transform .2s}.chevron.open[data-v-16efaeb5]{transform:rotate(180deg)}.drawer-sub[data-v-16efaeb5]{background:var(--color-surface-raised);border-left:3px solid var(--color-border);margin-left:16px}.drawer-sub-item[data-v-16efaeb5]{display:block;padding:10px 16px;color:var(--color-text-muted);text-decoration:none;font-size:13px;transition:color .15s,background .15s}.drawer-sub-item[data-v-16efaeb5]:hover{color:var(--color-primary-hover);background:var(--color-primary-bg)}.drawer-sub-item.active[data-v-16efaeb5]{color:var(--color-primary);font-weight:600;background:var(--color-primary-bg)}.drawer-footer[data-v-16efaeb5]{padding:12px 16px;border-top:1px solid var(--color-border)}.drawer-logout[data-v-16efaeb5]{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:var(--color-red-bg);color:var(--color-red);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.drawer-logout[data-v-16efaeb5]:hover{background:var(--color-red-border)}}.fade-enter-active[data-v-16efaeb5],.fade-leave-active[data-v-16efaeb5]{transition:opacity .25s ease}.fade-enter-from[data-v-16efaeb5],.fade-leave-to[data-v-16efaeb5]{opacity:0}.slide-enter-active[data-v-16efaeb5],.slide-leave-active[data-v-16efaeb5]{transition:transform .28s cubic-bezier(.4,0,.2,1)}.slide-enter-from[data-v-16efaeb5],.slide-leave-to[data-v-16efaeb5]{transform:translate(-100%)}.submenu-enter-active[data-v-16efaeb5],.submenu-leave-active[data-v-16efaeb5]{transition:all .2s ease;overflow:hidden}.submenu-enter-from[data-v-16efaeb5],.submenu-leave-to[data-v-16efaeb5]{max-height:0;opacity:0}.submenu-enter-to[data-v-16efaeb5],.submenu-leave-from[data-v-16efaeb5]{max-height:200px;opacity:1}[data-theme=dark] .drawer-item-dashboard .drawer-icon-wrap[data-v-16efaeb5]{background:rgba(var(--color-legacy-blue-bright-rgb),.2)}[data-theme=dark] .drawer-item-users .drawer-icon-wrap[data-v-16efaeb5]{background:rgba(var(--color-nav-users-rgb),.2)}[data-theme=dark] .drawer-item-devices .drawer-icon-wrap[data-v-16efaeb5]{background:rgba(var(--color-nav-devices-rgb),.2)}[data-theme=dark] .drawer-item-storage .drawer-icon-wrap[data-v-16efaeb5]{background:rgba(var(--color-nav-storage-rgb),.2)}[data-theme=dark] .drawer-item-notifications .drawer-icon-wrap[data-v-16efaeb5]{background:rgba(var(--color-red-coral-rgb),.2)}[data-theme=dark] .drawer-item-tracking .drawer-icon-wrap[data-v-16efaeb5]{background:rgba(var(--color-nav-storage-rgb),.2)}.mobile-overlay[data-v-1292d620]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.5);z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.mobile-drawer[data-v-1292d620]{position:fixed;top:0;left:0;width:280px;height:100vh;background:var(--color-surface);z-index:1001;display:flex;flex-direction:column;box-shadow:4px 0 24px rgba(var(--color-black-rgb),.15);overflow-y:auto}.drawer-header[data-v-1292d620]{display:flex;align-items:center;justify-content:space-between;padding:20px 16px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.drawer-logo[data-v-1292d620]{height:48px;-o-object-fit:contain;object-fit:contain}.drawer-close[data-v-1292d620]{width:36px;height:36px;border:none;background:var(--color-surface-overlay);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-muted);transition:all .2s}.drawer-close[data-v-1292d620]:hover{background:var(--color-red-bg);color:var(--color-red)}.drawer-nav[data-v-1292d620]{flex:1;padding:12px 0;overflow-y:auto}.drawer-item[data-v-1292d620]{display:flex;align-items:center;gap:14px;padding:5px 10px;color:var(--color-text-secondary);font-size:15px;font-weight:500;text-decoration:none;transition:background .2s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.drawer-item[data-v-1292d620]:hover{background:var(--color-surface-raised)}.drawer-item.active[data-v-1292d620]{background:var(--color-primary-bg);color:var(--color-primary);font-weight:600}.drawer-item.active .drawer-icon-wrap[data-v-1292d620]{background:var(--color-primary);color:var(--color-white)}.drawer-icon-wrap[data-v-1292d620]{position:relative;width:38px;height:38px;border-radius:10px;background:var(--color-surface-overlay);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.drawer-cart-badge[data-v-1292d620]{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--color-red);color:var(--color-white);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--color-surface);pointer-events:none}.drawer-item .drawer-icon-wrap[data-v-1292d620],.drawer-group-header .drawer-icon-wrap[data-v-1292d620]{color:var(--color-text-muted)}.drawer-item:hover .drawer-icon-wrap[data-v-1292d620],.drawer-group-header:hover .drawer-icon-wrap[data-v-1292d620]{color:var(--color-primary)}.drawer-group-header[data-v-1292d620]{justify-content:flex-start}.chevron[data-v-1292d620]{margin-left:auto;color:var(--color-text-subtle);transition:transform .2s}.chevron.open[data-v-1292d620]{transform:rotate(180deg)}.drawer-sub[data-v-1292d620]{padding:4px 0 4px 72px;background:var(--color-surface-raised)}.drawer-sub-item[data-v-1292d620]{display:flex;align-items:center;justify-content:space-between;padding:5px 10px 5px 0;color:var(--color-text-muted);font-size:14px;text-decoration:none;border-radius:6px;transition:color .2s}.drawer-sub-item[data-v-1292d620]:hover{color:var(--color-primary)}.drawer-sub-item.active[data-v-1292d620]{color:var(--color-primary);font-weight:600}.badge[data-v-1292d620]{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--color-red-500);color:var(--color-white);font-size:11px;font-weight:600;border-radius:5px;margin-left:6px}.sub-badge[data-v-1292d620]{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;background:var(--color-red-500);color:var(--color-white);font-size:10px;font-weight:600;border-radius:4px}.fade-enter-active[data-v-1292d620],.fade-leave-active[data-v-1292d620]{transition:opacity .25s ease}.fade-enter-from[data-v-1292d620],.fade-leave-to[data-v-1292d620]{opacity:0}.slide-enter-active[data-v-1292d620],.slide-leave-active[data-v-1292d620]{transition:transform .28s ease}.slide-enter-from[data-v-1292d620],.slide-leave-to[data-v-1292d620]{transform:translate(-100%)}.submenu-enter-active[data-v-1292d620],.submenu-leave-active[data-v-1292d620]{transition:all .2s ease;overflow:hidden}.submenu-enter-from[data-v-1292d620],.submenu-leave-to[data-v-1292d620]{max-height:0;opacity:0}.submenu-enter-to[data-v-1292d620],.submenu-leave-from[data-v-1292d620]{max-height:200px;opacity:1}.modal-fade-enter-active[data-v-7e38fbec],.modal-fade-leave-active[data-v-7e38fbec]{transition:opacity .2s ease}.modal-fade-enter-from[data-v-7e38fbec],.modal-fade-leave-to[data-v-7e38fbec]{opacity:0}.modal-fade-enter-active .modal-container[data-v-7e38fbec],.modal-fade-leave-active .modal-container[data-v-7e38fbec]{transition:transform .2s ease}.modal-fade-enter-from .modal-container[data-v-7e38fbec],.modal-fade-leave-to .modal-container[data-v-7e38fbec]{transform:scale(.95)}.confirm-dialog-overlay[data-v-7e38fbec]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:100000}.modal-container[data-v-7e38fbec]{background:var(--color-surface);border-radius:12px;width:100%;max-width:420px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px rgba(var(--color-black-rgb),.25)}.modal-header[data-v-7e38fbec]{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-7e38fbec]{display:flex;align-items:center;gap:10px}.modal-icon[data-v-7e38fbec]{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.3)}.modal-icon.is-alert[data-v-7e38fbec]{background:linear-gradient(135deg,var(--color-yellow) 0%,var(--color-amber-600) 100%);box-shadow:0 2px 6px rgba(var(--color-amber-rgb),.3)}.modal-header h3[data-v-7e38fbec]{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.modal-body[data-v-7e38fbec]{padding:18px 16px}.confirm-dialog-message[data-v-7e38fbec]{margin:0;font-size:13px;line-height:1.55;color:var(--color-text-primary);white-space:pre-line;word-break:break-word}.modal-footer[data-v-7e38fbec]{display:flex;justify-content:flex-end;gap:8px;padding:11px 16px;border-top:1px solid var(--color-border-light)}.btn-cancel[data-v-7e38fbec]{padding:7px 16px;border:1.5px solid var(--color-border);border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;background:var(--color-surface);color:var(--color-text-muted)}.btn-cancel[data-v-7e38fbec]:hover{background:var(--color-surface-overlay)}.btn-save[data-v-7e38fbec]{display:flex;align-items:center;gap:5px;padding:7px 16px;border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;color:var(--color-white);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%)}.btn-save[data-v-7e38fbec]:hover{filter:brightness(1.05)}.modal-fade-enter-active[data-v-c8d1d9c4],.modal-fade-leave-active[data-v-c8d1d9c4]{transition:opacity .25s ease}.modal-fade-enter-from[data-v-c8d1d9c4],.modal-fade-leave-to[data-v-c8d1d9c4]{opacity:0}.modal-fade-enter-active .modal-container[data-v-c8d1d9c4],.modal-fade-leave-active .modal-container[data-v-c8d1d9c4]{transition:transform .25s ease}.modal-fade-enter-from .modal-container[data-v-c8d1d9c4],.modal-fade-leave-to .modal-container[data-v-c8d1d9c4]{transform:scale(.97)}.modal-overlay[data-v-c8d1d9c4]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:20px}.modal-container[data-v-c8d1d9c4]{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;width:100%;max-width:460px;box-shadow:0 20px 40px rgba(var(--color-black-rgb),.15);display:flex;flex-direction:column;overflow:hidden}.modal-container.modal-small[data-v-c8d1d9c4]{max-width:420px}.modal-header[data-v-c8d1d9c4]{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-light)}.modal-title-section[data-v-c8d1d9c4]{display:flex;align-items:center;gap:12px}.modal-icon[data-v-c8d1d9c4]{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3);display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0}.modal-icon.is-alert[data-v-c8d1d9c4]{background:linear-gradient(135deg,var(--color-yellow) 0%,var(--color-amber-600) 100%);box-shadow:0 2px 6px rgba(var(--color-amber-rgb),.3)}.modal-header h3[data-v-c8d1d9c4]{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-c8d1d9c4]{background:none;border:none;cursor:pointer;color:var(--color-text-subtle);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;transition:all .15s}.modal-close[data-v-c8d1d9c4]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-close[data-v-c8d1d9c4]:disabled{opacity:.5;cursor:not-allowed}.modal-body[data-v-c8d1d9c4]{padding:20px;display:flex;flex-direction:column;gap:16px}.loading-center[data-v-c8d1d9c4]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px;color:var(--color-text-muted);font-size:13px}.info-rows[data-v-c8d1d9c4]{display:flex;flex-direction:column;gap:10px}.info-row[data-v-c8d1d9c4]{display:flex;align-items:center;gap:12px}.info-label[data-v-c8d1d9c4]{font-size:13px;font-weight:600;color:var(--color-text-muted);min-width:88px;flex-shrink:0}.info-value[data-v-c8d1d9c4]{font-size:13px;color:var(--color-text-secondary)}.fw-500[data-v-c8d1d9c4]{font-weight:500}.info-id[data-v-c8d1d9c4]{font-family:Courier New,monospace;font-size:12px;color:var(--color-text-muted);word-break:break-all}.plan-row-value[data-v-c8d1d9c4]{display:flex;align-items:center;gap:8px}.plan-badge[data-v-c8d1d9c4]{display:inline-block;padding:3px 10px;border-radius:6px;font-size:12px;font-weight:700;letter-spacing:.3px}.badge-plan-free[data-v-c8d1d9c4]{background:var(--color-green-bg);color:var(--color-green-hover)}.badge-plan-basic[data-v-c8d1d9c4]{background:var(--color-blue-bg);color:var(--color-blue-hover)}.badge-plan-standard[data-v-c8d1d9c4]{background:var(--color-orange-100);color:var(--color-amber-text-brown)}.badge-plan-pro[data-v-c8d1d9c4]{background:var(--color-purple-100);color:var(--color-violet-800)}.badge-plan-default[data-v-c8d1d9c4]{background:var(--color-surface-overlay);color:var(--color-text-secondary)}.btn-upgrade[data-v-c8d1d9c4]{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border:1.5px solid var(--color-primary);background:transparent;border-radius:6px;color:var(--color-primary);font-size:11px;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap}.btn-upgrade[data-v-c8d1d9c4]:hover{background:var(--color-primary);color:var(--color-white);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.plan-specs[data-v-c8d1d9c4]{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:10px;padding:12px 14px}.plan-specs-title[data-v-c8d1d9c4]{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.plan-specs-grid[data-v-c8d1d9c4]{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.spec-item[data-v-c8d1d9c4]{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--color-surface);border-radius:7px;padding:8px 6px;border:1px solid var(--color-border);transition:border-color .18s,background .18s}.spec-value-row[data-v-c8d1d9c4]{display:flex;align-items:baseline;gap:2px;justify-content:center}.spec-current[data-v-c8d1d9c4]{font-size:18px;font-weight:700;line-height:1;color:var(--color-text-primary)}.spec-sep[data-v-c8d1d9c4]{font-size:14px;color:var(--color-text-subtle)}.spec-limit[data-v-c8d1d9c4]{font-size:13px;color:var(--color-text-muted);font-weight:500}.spec-label[data-v-c8d1d9c4]{font-size:10px;color:var(--color-text-subtle);text-align:center;font-weight:500}.spec-tier-green[data-v-c8d1d9c4]{border-color:rgba(var(--color-legacy-green-dark-rgb),.35)}.spec-tier-green .spec-current[data-v-c8d1d9c4]{color:var(--color-legacy-green-dark)}.spec-tier-orange[data-v-c8d1d9c4]{border-color:rgba(var(--color-primary-rgb),.35);background:var(--color-primary-bg)}.spec-tier-orange .spec-current[data-v-c8d1d9c4]{color:var(--color-primary-hover)}.spec-tier-red[data-v-c8d1d9c4]{border-color:rgba(var(--color-red-rgb),.45);background:var(--color-red-bg)}.spec-tier-red .spec-current[data-v-c8d1d9c4]{color:var(--color-red)}.token-section[data-v-c8d1d9c4]{background:var(--color-surface-raised);border-radius:10px;padding:14px}.token-label[data-v-c8d1d9c4]{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:10px}.token-box[data-v-c8d1d9c4]{display:flex;align-items:flex-start;background:var(--color-surface-gray-800);border-radius:8px;padding:12px;gap:8px}.token-defines[data-v-c8d1d9c4]{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0;overflow-x:auto;scrollbar-width:none}.token-defines[data-v-c8d1d9c4]::-webkit-scrollbar{display:none}.token-defines code[data-v-c8d1d9c4]{font-family:Fira Code,Consolas,monospace;font-size:12px;white-space:nowrap}.ck[data-v-c8d1d9c4]{color:var(--color-purple-400)}.cn[data-v-c8d1d9c4]{color:var(--color-primary-400)}.cs[data-v-c8d1d9c4]{color:var(--color-orange-tw-400)}.btn-copy[data-v-c8d1d9c4],.btn-regen[data-v-c8d1d9c4]{background:rgba(var(--color-white-rgb),.1);border:none;border-radius:6px;color:var(--color-text-subtle);cursor:pointer;padding:6px 8px;flex-shrink:0;transition:all .15s;display:flex;align-items:center}.btn-copy[data-v-c8d1d9c4]:hover,.btn-regen[data-v-c8d1d9c4]:hover:not(:disabled){background:rgba(var(--color-white-rgb),.2);color:var(--color-white)}.btn-regen[data-v-c8d1d9c4]:disabled{opacity:.5;cursor:not-allowed}.icon-spin[data-v-c8d1d9c4]{animation:spin-c8d1d9c4 1s linear infinite}@keyframes spin-c8d1d9c4{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-footer[data-v-c8d1d9c4]{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--color-border-light)}.btn-cancel[data-v-c8d1d9c4]{display:flex;align-items:center;gap:6px;padding:8px 18px;border:1.5px solid var(--color-border);border-radius:7px;background:var(--color-surface);color:var(--color-text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn-cancel[data-v-c8d1d9c4]:hover:not(:disabled){background:var(--color-surface-raised);border-color:var(--color-text-subtle);color:var(--color-text-secondary)}.btn-cancel[data-v-c8d1d9c4]:disabled{opacity:.6;cursor:not-allowed}.btn-save[data-v-c8d1d9c4]{display:flex;align-items:center;gap:5px;padding:8px 18px;border:none;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;color:var(--color-white);transition:all .15s;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%)}.btn-save[data-v-c8d1d9c4]:disabled{opacity:.6;cursor:not-allowed}.btn-save.btn-danger[data-v-c8d1d9c4]{background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%)}.btn-save.btn-danger[data-v-c8d1d9c4]:hover:not(:disabled){box-shadow:0 4px 12px rgba(var(--color-red-rgb),.35);transform:translateY(-1px)}.regen-warning-text[data-v-c8d1d9c4]{margin:0;font-size:13px;line-height:1.55;color:var(--color-text-primary)}.lock-status-banner[data-v-c8d1d9c4]{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;margin:16px 0 0;background:var(--color-red-bg);border:1px solid var(--color-red-300);border-left:3px solid var(--color-red-500);border-radius:8px}.lock-status-icon[data-v-c8d1d9c4]{width:32px;height:32px;border-radius:8px;background:var(--color-red-bg);color:var(--color-red);display:flex;align-items:center;justify-content:center;flex-shrink:0}.lock-status-info[data-v-c8d1d9c4]{display:flex;flex-direction:column;gap:2px}.lock-status-info strong[data-v-c8d1d9c4]{font-size:13px;color:var(--color-red-hover)}.lock-status-info span[data-v-c8d1d9c4]{font-size:12px;color:var(--color-red-hover)}.lock-date[data-v-c8d1d9c4]{font-size:11px!important;color:var(--color-text-subtle)!important}[data-theme=dark] .badge-plan-standard[data-v-c8d1d9c4]{background:rgba(var(--color-amber-text-brown-rgb),.15);color:var(--color-orange-300)}[data-theme=dark] .badge-plan-pro[data-v-c8d1d9c4]{background:rgba(var(--color-violet-800-rgb),.2);color:var(--color-purple-300)}[data-theme=dark] .spec-tier-orange[data-v-c8d1d9c4]{background:rgba(var(--color-primary-rgb),.08)}[data-theme=dark] .spec-tier-red[data-v-c8d1d9c4]{background:rgba(var(--color-red-rgb),.1)}.modal-fade-enter-active[data-v-c121e186],.modal-fade-leave-active[data-v-c121e186]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-c121e186],.modal-fade-leave-to[data-v-c121e186]{opacity:0}.modal-fade-enter-active .plan-modal-container[data-v-c121e186],.modal-fade-leave-active .plan-modal-container[data-v-c121e186]{transition:transform .3s ease}.modal-fade-enter-from .plan-modal-container[data-v-c121e186],.modal-fade-leave-to .plan-modal-container[data-v-c121e186]{transform:scale(.97)}.modal-overlay[data-v-c121e186]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:10002;padding:20px}.plan-modal-container[data-v-c121e186]{background:var(--color-surface);border-radius:12px;width:auto;max-width:min(1060px,calc(100vw - 40px));max-height:92vh;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(var(--color-black-rgb),.18);overflow:hidden}.plan-modal-header[data-v-c121e186]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px 14px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised);flex-shrink:0}.plan-modal-title[data-v-c121e186]{display:flex;align-items:center;gap:14px}.plan-modal-header-right[data-v-c121e186]{display:flex;align-items:center;gap:10px}.plan-modal-vat-chip[data-v-c121e186]{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;color:var(--color-primary-hover);background:var(--color-primary-bg);border:1px solid var(--color-primary-border);line-height:1.2;white-space:nowrap}.plan-modal-vat-chip .v-icon[data-v-c121e186]{color:var(--color-primary)}@media (max-width: 480px){.plan-modal-vat-chip[data-v-c121e186]{font-size:10px;padding:3px 7px}}.plan-modal-icon[data-v-c121e186]{width:40px;height:40px;border-radius:9px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-size:20px;box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35);flex-shrink:0}.plan-modal-title h3[data-v-c121e186]{margin:0 0 2px;font-size:20px;font-weight:700;color:var(--color-text-primary)}.plan-modal-title p[data-v-c121e186]{margin:0;font-size:13px;color:var(--color-text-subtle)}.modal-close[data-v-c121e186]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;transition:all .2s}.modal-close[data-v-c121e186]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.plan-cards-scroll[data-v-c121e186]{display:flex;gap:14px;padding:24px 28px;overflow:visible;flex:1;align-items:stretch}.plan-cards-scroll[data-v-c121e186]::-webkit-scrollbar{height:6px}.plan-cards-scroll[data-v-c121e186]::-webkit-scrollbar-track{background:var(--color-surface-overlay);border-radius:3px}.plan-cards-scroll[data-v-c121e186]::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:3px}.plan-card[data-v-c121e186]{flex:1 1 0;min-width:160px;background:var(--color-surface-raised);border:2px solid var(--color-border);border-radius:10px;padding:20px 16px 18px;display:flex;flex-direction:column;position:relative;transition:all .2s}.plan-top[data-v-c121e186]{min-height:72px}.plan-card[data-v-c121e186]:hover{border-color:var(--color-primary);box-shadow:0 8px 24px rgba(var(--color-primary-rgb),.15);transform:translateY(-3px);background:var(--color-surface)}.plan-card-popular[data-v-c121e186]{border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 4px 16px rgba(var(--color-primary-rgb),.12)}.plan-card-custom[data-v-c121e186]{border-color:var(--color-violet-400);background:var(--color-surface-raised)}.plan-card-free[data-v-c121e186]{border-color:var(--color-success-500);background:var(--color-surface);box-shadow:0 0 0 2px rgba(var(--color-success-rgb),.18),0 6px 20px rgba(var(--color-success-rgb),.18);transform:translateY(-2px)}.plan-card-free .plan-code[data-v-c121e186]{color:var(--color-success-700)}.plan-price-free[data-v-c121e186]{color:var(--color-success-600);font-size:22px;font-weight:700;letter-spacing:.5px}.plan-popular-badge[data-v-c121e186]{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:var(--color-white);font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap;display:flex;align-items:center;gap:4px}.plan-free-badge[data-v-c121e186]{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--color-success-500),var(--color-success-600));color:var(--color-white);font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;white-space:nowrap;display:flex;align-items:center;gap:5px;box-shadow:0 2px 8px rgba(var(--color-success-rgb),.4)}.plan-code[data-v-c121e186]{font-size:16px;font-weight:800;color:var(--color-text-primary);margin-bottom:6px;letter-spacing:.3px}.plan-card-custom .plan-code[data-v-c121e186]{font-size:13px;line-height:1.4;color:var(--color-violet-600)}.plan-price[data-v-c121e186]{display:flex;align-items:baseline;gap:3px;margin-bottom:2px;flex-wrap:wrap}.plan-price-amount[data-v-c121e186]{font-size:18px;font-weight:700;color:var(--color-red-500)}.plan-price-unit[data-v-c121e186]{font-size:11px;color:var(--color-text-subtle)}.plan-price-custom[data-v-c121e186]{font-size:15px;font-weight:700;color:var(--color-violet-600)}.plan-price-permanent[data-v-c121e186]{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--color-primary-hover);margin-top:2px;font-weight:500;white-space:nowrap}.plan-permanent-icon[data-v-c121e186]{color:var(--color-primary);opacity:.8}.plan-divider[data-v-c121e186]{height:1px;background:var(--color-border);margin:12px 0 10px}.plan-card-custom .plan-divider[data-v-c121e186]{background:var(--color-purple-200)}.plan-card-popular .plan-divider[data-v-c121e186]{background:var(--color-orange-200)}.plan-features[data-v-c121e186]{list-style:none;padding:0;margin:0 0 16px;flex:1;display:flex;flex-direction:column;gap:7px}.plan-features li[data-v-c121e186]{display:flex;align-items:flex-start;gap:6px;font-size:12px;color:var(--color-text-secondary);line-height:1.4}.plan-feat-check[data-v-c121e186]{color:var(--color-primary);flex-shrink:0;margin-top:1px}.plan-card-custom .plan-features li[data-v-c121e186]{color:var(--color-purple-hover);font-weight:500}.plan-select-btn[data-v-c121e186]{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 10px;border:none;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:auto;white-space:nowrap}.plan-btn-paid[data-v-c121e186]{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:var(--color-white)}.plan-btn-paid[data-v-c121e186]:hover{background:linear-gradient(135deg,var(--color-primary-hover),var(--color-primary-700));box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.plan-btn-contact[data-v-c121e186]{background:linear-gradient(135deg,var(--color-violet-600),var(--color-violet-700));color:var(--color-white)}.plan-btn-contact[data-v-c121e186]:hover{background:linear-gradient(135deg,var(--color-violet-700),var(--color-violet-800));box-shadow:0 4px 12px rgba(var(--color-violet-600-rgb),.35);transform:translateY(-1px)}.plan-btn-free[data-v-c121e186]{background:linear-gradient(135deg,var(--color-success-500),var(--color-success-600));color:var(--color-white)}.plan-btn-free[data-v-c121e186]:hover{background:linear-gradient(135deg,var(--color-success-600),var(--color-success-700));box-shadow:0 4px 12px rgba(var(--color-success-rgb),.35);transform:translateY(-1px)}.plan-card-skeleton[data-v-c121e186]{border-color:var(--color-border)!important;background:var(--color-surface-raised)!important;pointer-events:none;min-width:160px;gap:10px;display:flex;flex-direction:column}.skel[data-v-c121e186]{border-radius:6px;background:linear-gradient(90deg,var(--color-surface-overlay) 25%,var(--color-border) 50%,var(--color-surface-overlay) 75%);background-size:200% 100%;animation:skel-shimmer-c121e186 1.4s infinite}@keyframes skel-shimmer-c121e186{0%{background-position:200% 0}to{background-position:-200% 0}}.skel-code[data-v-c121e186]{height:16px;width:60%;border-radius:4px}.skel-price[data-v-c121e186]{height:22px;width:80%;border-radius:4px;margin-bottom:4px}.skel-divider[data-v-c121e186]{height:1px;background:var(--color-border);animation:none}.skel-feat[data-v-c121e186]{height:12px;width:90%}.skel-feat-short[data-v-c121e186]{width:65%}.skel-btn[data-v-c121e186]{height:34px;width:100%;border-radius:7px;margin-top:auto}.plans-error[data-v-c121e186]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 20px;color:var(--color-text-subtle);text-align:center}.plans-error-icon[data-v-c121e186]{color:var(--color-yellow)}.plans-error p[data-v-c121e186]{margin:0;font-size:14px;color:var(--color-text-muted)}.plans-retry-btn[data-v-c121e186]{display:flex;align-items:center;gap:6px;padding:8px 18px;border:1.5px solid var(--color-border);background:var(--color-surface);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;color:var(--color-text-secondary);transition:all .2s}.plans-retry-btn[data-v-c121e186]:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-bg)}@media (max-width: 700px){.plan-modal-container[data-v-c121e186]{border-radius:10px;max-height:95vh}.plan-modal-header[data-v-c121e186]{padding:16px 20px 12px}.plan-modal-title h3[data-v-c121e186]{font-size:16px}.plan-cards-scroll[data-v-c121e186]{flex-direction:column;overflow-x:unset;overflow-y:auto;padding:16px 20px;gap:12px;align-items:stretch}.plan-card[data-v-c121e186]{flex:none;width:100%}}.contact-fade-enter-active[data-v-c121e186],.contact-fade-leave-active[data-v-c121e186]{transition:opacity .25s ease}.contact-fade-enter-from[data-v-c121e186],.contact-fade-leave-to[data-v-c121e186]{opacity:0}.contact-fade-enter-active .contact-modal[data-v-c121e186],.contact-fade-leave-active .contact-modal[data-v-c121e186]{transition:transform .25s ease}.contact-fade-enter-from .contact-modal[data-v-c121e186],.contact-fade-leave-to .contact-modal[data-v-c121e186]{transform:scale(.95) translateY(10px)}.contact-overlay[data-v-c121e186]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:10003;padding:20px}.contact-modal[data-v-c121e186]{background:var(--color-surface);border-radius:14px;width:100%;max-width:440px;box-shadow:0 24px 60px rgba(var(--color-black-rgb),.18);overflow:hidden;display:flex;flex-direction:column}.contact-header[data-v-c121e186]{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.contact-header-left[data-v-c121e186]{display:flex;align-items:center;gap:12px}.contact-icon[data-v-c121e186]{width:42px;height:42px;border-radius:10px;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:var(--color-white);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35);flex-shrink:0}.contact-header h3[data-v-c121e186]{margin:0 0 2px;font-size:17px;font-weight:700;color:var(--color-text-primary)}.contact-header p[data-v-c121e186]{margin:0;font-size:12px;color:var(--color-text-subtle)}.contact-close[data-v-c121e186]{background:none;border:none;cursor:pointer;color:var(--color-text-subtle);display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;transition:all .2s;flex-shrink:0}.contact-close[data-v-c121e186]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.contact-body[data-v-c121e186]{padding:20px 24px;display:flex;flex-direction:column;gap:16px}.contact-plan-row[data-v-c121e186]{display:flex;align-items:center;gap:10px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;padding:10px 14px}.contact-plan-label[data-v-c121e186]{font-size:13px;color:var(--color-text-muted);flex-shrink:0}.contact-plan-badge[data-v-c121e186]{font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.3px}.contact-badge-free[data-v-c121e186]{background:var(--color-green-bg);color:var(--color-green-hover)}.contact-badge-paid[data-v-c121e186]{background:var(--color-orange-100);color:var(--color-amber-text-brown)}.contact-badge-popular[data-v-c121e186]{background:var(--color-primary-bg);color:var(--color-primary-hover)}.contact-badge-custom[data-v-c121e186]{background:var(--color-purple-100);color:var(--color-purple-hover)}.contact-plan-price[data-v-c121e186]{font-size:13px;color:var(--color-red-500);font-weight:600;margin-left:auto}.contact-desc-box[data-v-c121e186]{display:flex;align-items:flex-start;gap:8px;background:var(--color-blue-bg);border:1px solid var(--color-blue-200);border-radius:8px;padding:10px 14px}.contact-desc-icon[data-v-c121e186]{color:var(--color-blue-500);flex-shrink:0;margin-top:2px}.contact-desc-box p[data-v-c121e186]{margin:0;font-size:13px;color:var(--color-blue-hover);line-height:1.5}.contact-form-group[data-v-c121e186]{display:flex;flex-direction:column;gap:6px}.pricing-mode-group[data-v-c121e186]{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.pricing-mode-options[data-v-c121e186]{display:grid;grid-template-columns:1fr 1fr;gap:8px}.pricing-mode-option[data-v-c121e186]{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1.5px solid var(--color-border);border-radius:8px;cursor:pointer;background:var(--color-surface);transition:all .15s}.pricing-mode-option[data-v-c121e186]:hover{border-color:var(--color-primary);background:var(--color-primary-bg)}.pricing-mode-option.active[data-v-c121e186]{border-color:var(--color-primary);background:var(--color-primary-bg);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12)}.pricing-mode-option input[type=radio][data-v-c121e186]{margin:0;accent-color:var(--color-primary);flex-shrink:0}.pricing-mode-content[data-v-c121e186]{display:flex;flex-direction:column;gap:2px;line-height:1.2}.pricing-mode-title[data-v-c121e186]{font-size:13px;font-weight:600;color:var(--color-text-primary);display:inline-flex;align-items:center;gap:4px}.pricing-mode-price[data-v-c121e186]{font-size:12px;color:var(--color-primary);font-weight:700}@media (max-width: 480px){.pricing-mode-options[data-v-c121e186]{grid-template-columns:1fr}}.duration-group[data-v-c121e186]{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.duration-chips[data-v-c121e186]{display:flex;flex-wrap:wrap;gap:6px}.duration-chip[data-v-c121e186]{flex:1 1 auto;min-width:60px;padding:8px 10px;border:1.5px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-align:center}.duration-chip[data-v-c121e186]:hover:not(.active){border-color:var(--color-primary);background:var(--color-primary-bg)}.duration-chip.active[data-v-c121e186]{border-color:var(--color-primary);background:var(--color-primary-bg);color:var(--color-primary-hover);font-weight:600;box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12)}.duration-total[data-v-c121e186]{font-size:12px;color:var(--color-text-muted);text-align:right}.duration-total strong[data-v-c121e186]{color:var(--color-primary-hover);font-weight:700;margin-left:4px}.contact-label[data-v-c121e186]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.required-star[data-v-c121e186]{color:var(--color-red-500);margin-left:2px}.contact-input[data-v-c121e186]{width:100%;padding:11px 14px;border:1.5px solid var(--color-border);border-radius:8px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;color:var(--color-text-primary);background:var(--color-surface);box-sizing:border-box}.contact-input[data-v-c121e186]:hover{border-color:var(--color-gray-b0)}.contact-input[data-v-c121e186]:focus{border-color:var(--color-legacy-blue);box-shadow:0 0 0 3px rgba(var(--color-legacy-blue-rgb),.12)}.contact-input-error[data-v-c121e186]{border-color:var(--color-red-500)!important;box-shadow:0 0 0 3px rgba(var(--color-red-500-rgb),.1)!important}.contact-field-error[data-v-c121e186]{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--color-red-500);font-weight:500}.contact-field-hint[data-v-c121e186]{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--color-text-muted);font-weight:500;margin-top:2px}.contact-field-hint .v-icon[data-v-c121e186]{color:var(--color-primary);opacity:.7}.contact-textarea[data-v-c121e186]{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:8px;font-size:13px;outline:none;transition:all .2s;font-family:inherit;color:var(--color-text-primary);background:var(--color-surface);box-sizing:border-box;resize:vertical;min-height:60px}.contact-textarea[data-v-c121e186]:hover{border-color:var(--color-gray-b0)}.contact-textarea[data-v-c121e186]:focus{border-color:var(--color-legacy-blue);box-shadow:0 0 0 3px rgba(var(--color-legacy-blue-rgb),.12)}.contact-char-count[data-v-c121e186]{display:block;text-align:right;font-size:11px;color:var(--color-text-subtle);margin-top:2px}.contact-note-locked-prefix[data-v-c121e186]{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-bottom:6px;background:var(--color-primary-bg);border:1px solid var(--color-primary-border);border-radius:8px;font-size:12px;color:var(--color-text-primary);line-height:1.4}.contact-note-locked-prefix .v-icon[data-v-c121e186]{color:var(--color-primary);flex-shrink:0}.contact-note-locked-prefix strong[data-v-c121e186]{color:var(--color-primary-hover);margin-right:4px}.contact-device-id[data-v-c121e186]{color:var(--color-text-muted);font-family:ui-monospace,monospace;font-size:11px}.contact-footer[data-v-c121e186]{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px 20px;border-top:1px solid var(--color-border-light)}.contact-btn-cancel[data-v-c121e186]{padding:10px 20px;border:1.5px solid var(--color-border);background:var(--color-surface);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;color:var(--color-text-muted);transition:all .2s}.contact-btn-cancel[data-v-c121e186]:hover{background:var(--color-surface-raised);border-color:var(--color-text-subtle)}.contact-btn-submit[data-v-c121e186]{display:flex;align-items:center;gap:7px;padding:10px 22px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;background:var(--gradient-primary);color:var(--color-white);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.25);transition:all .2s}.contact-btn-submit[data-v-c121e186]:hover:not(:disabled){background:var(--gradient-primary-hover);box-shadow:0 4px 14px rgba(var(--color-primary-rgb),.4);transform:translateY(-1px)}.contact-btn-submit[data-v-c121e186]:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 480px){.contact-modal[data-v-c121e186]{border-radius:10px}.contact-body[data-v-c121e186]{padding:16px 18px}.contact-footer[data-v-c121e186]{padding:14px 18px 18px}}[data-theme=dark] .plan-card-custom[data-v-c121e186]{border-color:var(--color-violet-600);background:rgba(var(--color-violet-600-rgb),.08)}[data-theme=dark] .plan-card-custom .plan-code[data-v-c121e186],[data-theme=dark] .plan-card-custom .plan-price-custom[data-v-c121e186],[data-theme=dark] .plan-card-custom .plan-features li[data-v-c121e186]{color:var(--color-purple-300)}.plan-modal-upgrade-footer[data-v-c121e186]{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-top:1px solid var(--color-border-light);background:var(--color-surface-raised);font-size:13px;flex-wrap:wrap}.upgrade-footer-text[data-v-c121e186]{color:var(--color-text-secondary)}.upgrade-footer-link[data-v-c121e186]{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--color-primary-border);border-radius:8px;background:var(--color-primary-bg);color:var(--color-primary);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease}.upgrade-footer-link[data-v-c121e186]:hover{background:var(--color-primary);color:var(--color-white);transform:translateY(-1px)}.route-progress-bar{position:fixed;top:0;left:0;height:3px;background:var(--gradient-primary);box-shadow:0 0 8px rgba(var(--color-primary-rgb),.6);z-index:99999;transition:width .25s ease-out;pointer-events:none}.scada-ctx-backdrop[data-v-37bbf355]{position:fixed;inset:0;z-index:99999;background:transparent}.scada-ctx-menu[data-v-37bbf355]{position:fixed;min-width:220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-lg);padding:4px;z-index:100000;font-size:13px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ctx-header[data-v-37bbf355]{display:flex;align-items:center;gap:6px;padding:6px 10px;font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--color-border-light);margin-bottom:4px}.ctx-item[data-v-37bbf355]{display:flex;align-items:center;gap:10px;width:100%;padding:7px 10px;border:none;background:transparent;color:var(--color-text-primary);cursor:pointer;border-radius:5px;text-align:left;font-size:13px}.ctx-item[data-v-37bbf355]:hover{background:var(--color-surface-overlay)}.ctx-item.ctx-danger[data-v-37bbf355]{color:var(--color-red)}.ctx-item.ctx-danger[data-v-37bbf355]:hover{background:var(--color-red-bg)}.ctx-shortcut[data-v-37bbf355]{margin-left:auto;font-size:11px;color:var(--color-text-muted);font-family:ui-monospace,monospace}.ctx-divider[data-v-37bbf355]{height:1px;background:var(--color-border-light);margin:4px 6px}.info-btn[data-v-4887607a]{color:var(--color-text-muted)}.info-btn[data-v-4887607a]:hover{color:var(--color-primary)}.shortcut-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;box-shadow:var(--shadow-dropdown);overflow:hidden}.shortcut-panel-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-size:13px;font-weight:600}.shortcut-close{margin-left:auto;background:none;border:none;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;padding:2px;border-radius:4px;transition:color .15s}.shortcut-close:hover{color:var(--color-text-primary)}.shortcut-list{padding:6px 0;max-height:380px;overflow-y:auto}.shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;gap:12px;transition:background .1s}.shortcut-row:hover{background:rgba(var(--color-primary-rgb),.06)}.shortcut-keys{display:flex;align-items:center;gap:3px;flex-shrink:0}.shortcut-panel kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;background:var(--color-surface-sunken);border:1px solid var(--color-border-medium);border-bottom-width:2px;border-radius:4px;font-family:Courier New,monospace;font-size:10px;color:var(--color-text-secondary);white-space:nowrap;min-width:20px}.shortcut-desc{font-size:12px;color:var(--color-text-muted);text-align:right;flex:1}.shortcut-fade-enter-active,.shortcut-fade-leave-active{transition:opacity .15s ease,transform .15s ease}.shortcut-fade-enter-from,.shortcut-fade-leave-to{opacity:0;transform:translateY(-6px)}.title-styling-section[data-v-d36f853c],.visual-section[data-v-d36f853c]{background:var(--color-surface-raised);border:1px solid var(--color-border-light);border-radius:8px;margin-bottom:12px}.title-styling-section summary[data-v-d36f853c],.visual-section summary[data-v-d36f853c]{cursor:pointer;padding:8px 12px;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--color-text-primary);list-style:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.title-styling-section summary[data-v-d36f853c]::-webkit-details-marker,.visual-section summary[data-v-d36f853c]::-webkit-details-marker{display:none}.ts-leading-icon[data-v-d36f853c]{color:var(--color-primary);flex-shrink:0}.ts-label[data-v-d36f853c]{flex:1}.ts-chevron[data-v-d36f853c]{color:var(--color-text-muted);transition:transform .2s ease;flex-shrink:0;margin-left:auto}details[open] .ts-chevron[data-v-d36f853c]{transform:rotate(180deg)}.title-styling-section[open] summary[data-v-d36f853c],.visual-section[open] summary[data-v-d36f853c]{border-bottom:1px solid var(--color-border-light)}.title-styling-grid[data-v-d36f853c],.visual-grid[data-v-d36f853c]{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px;padding:10px 12px 12px}.span-2[data-v-d36f853c]{grid-column:span 2}.title-styling-grid .form-group[data-v-d36f853c],.visual-grid .form-group[data-v-d36f853c],.visual-sub-block .form-group[data-v-d36f853c]{margin-bottom:0;display:flex;flex-direction:column;gap:4px;min-width:0}.title-styling-grid .form-group label.form-label[data-v-d36f853c],.visual-grid .form-group label.form-label[data-v-d36f853c],.visual-sub-block .form-group label.form-label[data-v-d36f853c]{display:block;margin:0;padding:0;font-size:11px;font-weight:500;color:var(--color-text-secondary);line-height:1.3}.title-styling-grid .form-input[data-v-d36f853c],.visual-grid .form-input[data-v-d36f853c],.visual-sub-block .form-input[data-v-d36f853c],.threshold-row .form-input[data-v-d36f853c]{width:100%;padding:6px 10px;border:1.5px solid var(--color-border);border-radius:6px;font-size:12px;outline:none;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .15s,box-shadow .15s;font-family:inherit;height:32px}.title-styling-grid .form-input[data-v-d36f853c]:focus,.visual-grid .form-input[data-v-d36f853c]:focus,.visual-sub-block .form-input[data-v-d36f853c]:focus,.threshold-row .form-input[data-v-d36f853c]:focus{border-color:var(--color-primary);box-shadow:var(--color-input-focus-shadow)}.title-styling-grid select.form-input[data-v-d36f853c],.visual-grid select.form-input[data-v-d36f853c],.visual-sub-block select.form-input[data-v-d36f853c]{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;cursor:pointer}.title-styling-grid input[type=color][data-v-d36f853c],.visual-grid input[type=color][data-v-d36f853c],.visual-sub-block input[type=color][data-v-d36f853c]{height:32px;width:100%;box-sizing:border-box}.visual-sub-block[data-v-d36f853c]{padding:10px 12px 12px}.visual-sub-block+.visual-sub-block[data-v-d36f853c]{border-top:1px solid var(--color-border-light)}.visual-sub-label[data-v-d36f853c]{font-size:12px;font-weight:600;color:var(--color-text-primary);margin:0 0 8px}.visual-hint[data-v-d36f853c]{font-size:11px;color:var(--color-text-muted);margin:0 0 8px}.threshold-list[data-v-d36f853c]{display:flex;flex-direction:column;gap:6px}.threshold-row[data-v-d36f853c]{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center}.threshold-remove-btn[data-v-d36f853c]{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1px solid var(--color-red-border);background:var(--color-red-bg);color:var(--color-red);cursor:pointer;transition:background .2s}.threshold-remove-btn[data-v-d36f853c]:hover{background:var(--color-red);color:var(--color-white)}.threshold-add-btn[data-v-d36f853c]{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px dashed var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text-secondary);font-size:12px;cursor:pointer;transition:all .2s}.threshold-add-btn[data-v-d36f853c]:hover{border-color:var(--color-primary);color:var(--color-primary)}.widget-no-options[data-v-d36f853c]{text-align:center;padding:24px;color:var(--color-text-subtle)}.widget-no-options p[data-v-d36f853c]{margin-top:8px;color:var(--color-text-muted);font-size:13px}.wizard-preview-frame[data-v-1113834e]{position:relative;width:100%;height:100%}.wizard-preview-stage[data-v-1113834e]{width:100%;height:100%;position:relative}.wizard-preview-render[data-v-1113834e]{width:100%!important;height:100%!important}.wizard-preview-render[data-v-1113834e] [disabled] .slider-connect,.wizard-preview-render[data-v-1113834e] .slider-target[disabled] .slider-connect{background:var(--slider-connect-bg, var(--color-primary))!important}.wizard-preview-placeholder[data-v-1113834e]{color:var(--color-text-subtle);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px}.property-dialog.property-dialog-wizard-style[data-v-bce5e8ff]{width:96%;max-width:min(1080px,96vw);height:auto;min-height:70vh;max-height:90vh}.settings-only-body[data-v-bce5e8ff]{flex:1;padding:16px;overflow-y:auto;display:block}.settings-step3-split[data-v-bce5e8ff]{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:16px}.settings-preview-pane[data-v-bce5e8ff]{display:flex;flex-direction:column;gap:10px;min-width:0;min-height:360px}.preview-pane-header[data-v-bce5e8ff]{display:flex;align-items:center;gap:8px}.preview-pane-label[data-v-bce5e8ff]{font-size:11px;font-weight:600;color:var(--color-text-muted)}.settings-preview-frame[data-v-bce5e8ff]{flex:1;background:var(--color-surface-raised);border:1.5px dashed var(--color-border);border-radius:10px;padding:14px;display:flex;align-items:center;justify-content:center;min-height:320px;max-height:480px;overflow:hidden;position:relative}.settings-form-pane[data-v-bce5e8ff]{display:flex;flex-direction:column;gap:12px;min-width:0}.settings-data-source-section[data-v-bce5e8ff]{border:1px solid var(--color-border-light);border-radius:8px;background:var(--color-surface-raised);overflow:hidden}.settings-data-source-section>summary[data-v-bce5e8ff]{list-style:none;cursor:pointer;padding:10px 12px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--color-text-primary);-webkit-user-select:none;-moz-user-select:none;user-select:none}.settings-data-source-section>summary[data-v-bce5e8ff]::-webkit-details-marker{display:none}.settings-data-source-section>summary .ts-leading-icon[data-v-bce5e8ff]{color:var(--color-primary);flex-shrink:0}.settings-data-source-section>summary .ts-label[data-v-bce5e8ff]{flex:1}.settings-data-source-section>summary .ts-chevron[data-v-bce5e8ff]{color:var(--color-text-muted);transition:transform .2s ease}.settings-data-source-section[open]>summary .ts-chevron[data-v-bce5e8ff]{transform:rotate(180deg)}.settings-data-source-section[open]>summary[data-v-bce5e8ff]{border-bottom:1px solid var(--color-border-light)}.settings-data-source-body[data-v-bce5e8ff]{padding:10px 12px}.settings-form-pane[data-v-bce5e8ff] .gauge-options,.settings-form-pane[data-v-bce5e8ff] .chart-options,.settings-form-pane[data-v-bce5e8ff] .control-options,.settings-form-pane[data-v-bce5e8ff] .map-options,.settings-form-pane[data-v-bce5e8ff] .alarm-options,.settings-form-pane[data-v-bce5e8ff] .chart-bar-options,.settings-form-pane[data-v-bce5e8ff] .pb-options,.settings-form-pane[data-v-bce5e8ff] .switch-options,.settings-form-pane[data-v-bce5e8ff] .led-options{padding:0}@media (max-width: 900px){.settings-step3-split[data-v-bce5e8ff]{grid-template-columns:1fr}}.gauge-options[data-v-d6e4c843]{padding:12px;background:transparent;font-size:13px;color:var(--color-text-primary)}.group-title[data-v-d6e4c843]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.group-desc[data-v-d6e4c843]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-d6e4c843]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:4px}.section-head[data-v-d6e4c843]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-d6e4c843]:hover{background:var(--color-surface-overlay);border-radius:4px 4px 0 0}.options-section.section-collapsed[data-v-d6e4c843]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-d6e4c843]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-d6e4c843]:hover{border-radius:4px}.section-head-icon[data-v-d6e4c843]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-d6e4c843]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-d6e4c843]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-d6e4c843]{display:flex;flex-direction:column;gap:12px}.field-row[data-v-d6e4c843]{display:flex;gap:10px}.field-row .input-group[data-v-d6e4c843]{flex:1;min-width:0}.input-group[data-v-d6e4c843]{display:flex;flex-direction:column;gap:4px}.input-label[data-v-d6e4c843]{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-field[data-v-d6e4c843]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-field[data-v-d6e4c843]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.input-row[data-v-d6e4c843]{display:flex;gap:8px;align-items:center}.range-input[data-v-d6e4c843]{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-border);border-radius:3px;outline:none}.range-input[data-v-d6e4c843]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer}.range-input[data-v-d6e4c843]::-moz-range-thumb{width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:none}.value-display[data-v-d6e4c843]{min-width:70px;flex:none;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);text-align:center;font-weight:500}.color-row[data-v-d6e4c843]{display:flex;flex-wrap:nowrap;gap:12px;overflow-x:auto;padding-bottom:4px}.color-row[data-v-d6e4c843]::-webkit-scrollbar{height:4px}.color-row[data-v-d6e4c843]::-webkit-scrollbar-track{background:var(--color-surface-sunken);border-radius:2px}.color-row[data-v-d6e4c843]::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:2px}.color-item[data-v-d6e4c843]{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.color-label[data-v-d6e4c843]{font-size:12px;color:var(--color-text-secondary)}.color-picker[data-v-d6e4c843]{width:32px;height:32px}.checkbox-group[data-v-d6e4c843]{display:flex;flex-wrap:wrap;gap:8px 16px}.checkbox-item[data-v-d6e4c843]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-primary);cursor:pointer}.checkbox-item input[type=checkbox][data-v-d6e4c843]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.checkbox-item span[data-v-d6e4c843]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.control-options[data-v-c952635d]{padding:12px;background:transparent;font-size:13px;color:var(--color-text-primary)}.group-title[data-v-c952635d]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.group-desc[data-v-c952635d]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-c952635d]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:4px}.section-head[data-v-c952635d]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-c952635d]:hover{background:var(--color-surface-overlay);border-radius:4px 4px 0 0}.section-head-icon[data-v-c952635d]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-c952635d]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-c952635d]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-c952635d]{display:flex;flex-direction:column;gap:12px}.options-section.section-collapsed[data-v-c952635d]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-c952635d]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-c952635d]:hover{border-radius:4px}.section-title[data-v-c952635d]{margin:0 0 4px;font-size:13px;font-weight:600;color:var(--color-text-secondary);letter-spacing:.5px}.input-group[data-v-c952635d]{display:flex;flex-direction:column;gap:4px}.input-label[data-v-c952635d]{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-field[data-v-c952635d]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-field[data-v-c952635d]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.field-row[data-v-c952635d]{display:flex;gap:10px}.field-row .input-group[data-v-c952635d]{flex:1;min-width:0}.input-row[data-v-c952635d]{display:flex;gap:8px;align-items:center}.input-row .input-field[data-v-c952635d]{flex:1}.input-small[data-v-c952635d]{width:70px!important;flex:none!important}.range-input[data-v-c952635d]{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-border);border-radius:3px;outline:none}.range-input[data-v-c952635d]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer}.value-display[data-v-c952635d]{font-size:12px;color:var(--color-text-secondary);text-align:center;margin-top:4px;font-weight:500}.color-row[data-v-c952635d]{display:flex;flex-wrap:nowrap;gap:12px;overflow-x:auto;padding-bottom:4px}.color-row[data-v-c952635d]::-webkit-scrollbar{height:4px}.color-row[data-v-c952635d]::-webkit-scrollbar-track{background:var(--color-surface-sunken);border-radius:2px}.color-row[data-v-c952635d]::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:2px}.color-row[data-v-c952635d]::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}.color-item[data-v-c952635d]{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.color-label[data-v-c952635d]{font-size:12px;color:var(--color-text-secondary)}.color-picker[data-v-c952635d]{width:32px;height:32px}.checkbox-group[data-v-c952635d]{display:flex;flex-wrap:wrap;gap:8px 16px}.checkbox-item[data-v-c952635d]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-primary);cursor:pointer}.checkbox-item input[type=checkbox][data-v-c952635d]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.checkbox-item span[data-v-c952635d]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.chart-options[data-v-ac1c458b]{padding:12px;background:var(--color-surface);color:var(--color-text-primary)}.option-group[data-v-ac1c458b]{margin-bottom:16px}.group-title[data-v-ac1c458b]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.option-section[data-v-ac1c458b]{margin-bottom:12px;padding:12px;background:var(--color-surface-raised);border-radius:8px;border:1px solid var(--color-border)}.group-desc[data-v-ac1c458b]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.section-head[data-v-ac1c458b]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-ac1c458b]:hover{background:var(--color-surface-overlay);border-radius:8px 8px 0 0}.option-section.section-collapsed[data-v-ac1c458b]{padding-bottom:0}.option-section.section-collapsed .section-head[data-v-ac1c458b]{margin-bottom:0;border-bottom:none}.option-section.section-collapsed .section-head[data-v-ac1c458b]:hover{border-radius:8px}.section-head-icon[data-v-ac1c458b]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-ac1c458b]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-ac1c458b]{color:var(--color-text-muted);flex-shrink:0}.checkbox-grid[data-v-ac1c458b]{display:flex;flex-wrap:wrap;gap:6px 20px}.checkbox-grid .checkbox-item[data-v-ac1c458b]{margin-bottom:0}.section-body .option-row[data-v-ac1c458b]{margin-bottom:12px}.data-rows-head[data-v-ac1c458b]{display:grid;grid-template-columns:18px minmax(0,1fr) minmax(0,1fr) 28px;gap:8px;padding:0 2px 2px}.data-rows-head-label[data-v-ac1c458b]{grid-column:span 1;font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px}.data-rows-head-label[data-v-ac1c458b]:first-child{grid-column:2}.row-grip[data-v-ac1c458b]{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.btn-add-row[data-v-ac1c458b]{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px;margin-top:8px;background:transparent;color:var(--color-primary);border:1px dashed var(--color-border-medium);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .15s,border-color .15s}.btn-add-row[data-v-ac1c458b]:hover:not(:disabled){background:rgba(var(--color-blue-400-rgb),.08);border-color:var(--color-primary)}.btn-add-row[data-v-ac1c458b]:disabled{opacity:.5;cursor:not-allowed}.rows-hint[data-v-ac1c458b]{margin:8px 0 0;font-size:13px;color:var(--color-text-muted)}.section-title[data-v-ac1c458b]{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin:0 0 10px;letter-spacing:.5px}.option-item[data-v-ac1c458b]{margin-bottom:12px}.option-item[data-v-ac1c458b]:last-child{margin-bottom:0}.option-item label[data-v-ac1c458b]{display:block;font-size:13px;font-weight:500;color:var(--color-text-primary);margin-bottom:6px}.option-row[data-v-ac1c458b]{display:flex;gap:10px}.option-item.half[data-v-ac1c458b]{flex:1}.checkbox-item[data-v-ac1c458b]{display:flex;align-items:center;gap:6px}.checkbox-item label[data-v-ac1c458b]{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;margin-bottom:0;color:var(--color-text-primary)}.help-text[data-v-ac1c458b]{font-size:12px;color:var(--color-text-muted);font-style:italic;margin-top:2px;display:block}.input-field[data-v-ac1c458b],.select-field[data-v-ac1c458b]{width:100%;padding:6px 10px;border:1px solid var(--color-border);border-radius:4px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);transition:border-color .2s,box-shadow .2s}.input-field[data-v-ac1c458b]:focus,.select-field[data-v-ac1c458b]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.input-field[data-v-ac1c458b]::-moz-placeholder{color:var(--color-text-muted)}.input-field[data-v-ac1c458b]::placeholder{color:var(--color-text-muted)}.select-field option[data-v-ac1c458b]{background:var(--color-input-bg);color:var(--color-text-primary)}.checkbox-field[data-v-ac1c458b]{width:auto;margin:0;accent-color:var(--color-primary)}.color-field[data-v-ac1c458b]{width:32px;height:32px}.series-management[data-v-ac1c458b],.columns-management[data-v-ac1c458b]{margin-top:12px}.section-header[data-v-ac1c458b]{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.section-header label[data-v-ac1c458b]{font-size:13px;font-weight:600;color:var(--color-text-primary)}.btn-add[data-v-ac1c458b]{display:flex;align-items:center;gap:4px;padding:5px 10px;background:var(--color-legacy-blue);color:var(--color-white);border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:background-color .2s}.btn-add[data-v-ac1c458b]:hover{background:var(--color-legacy-blue-dark)}.series-item[data-v-ac1c458b],.column-item[data-v-ac1c458b]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:10px;margin-bottom:8px}.section-body .column-item[data-v-ac1c458b]{background:transparent;border:none;padding:0;margin-bottom:8px}.section-body .series-item[data-v-ac1c458b]{background:transparent;border:none;border-bottom:1px solid var(--color-border-light);border-radius:0;padding:0 0 14px;margin-bottom:14px}.section-body .series-item[data-v-ac1c458b]:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}.series-header[data-v-ac1c458b],.column-controls[data-v-ac1c458b]{display:grid;gap:8px;align-items:center;margin-bottom:8px}.series-header[data-v-ac1c458b]{grid-template-columns:1fr 50px 28px}.column-controls[data-v-ac1c458b]{grid-template-columns:1fr 1fr 80px 28px}.series-name-input[data-v-ac1c458b],.column-key-input[data-v-ac1c458b],.column-title-input[data-v-ac1c458b]{padding:5px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary)}.series-name-input[data-v-ac1c458b]:focus,.column-key-input[data-v-ac1c458b]:focus,.column-title-input[data-v-ac1c458b]:focus{outline:none;border-color:var(--color-primary)}.color-input[data-v-ac1c458b]{width:32px;height:32px}.type-select[data-v-ac1c458b],.column-type-select[data-v-ac1c458b]{padding:5px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:12px;background:var(--color-input-bg);color:var(--color-text-primary)}.btn-remove[data-v-ac1c458b]{width:26px;height:26px;background:var(--color-red);color:var(--color-white);border:none;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s}.btn-remove[data-v-ac1c458b]:hover{background:var(--color-red-700)}.icon[data-v-ac1c458b]{width:12px;height:12px}.series-data[data-v-ac1c458b]{margin-top:8px}.series-data label[data-v-ac1c458b]{font-size:12px;color:var(--color-text-secondary);margin-bottom:4px}.data-textarea[data-v-ac1c458b]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:12px;min-height:50px;resize:vertical;background:var(--color-input-bg);color:var(--color-text-primary)}.data-textarea[data-v-ac1c458b]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.series-source[data-v-ac1c458b]{margin-top:8px}.source-row[data-v-ac1c458b]{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px}.source-field[data-v-ac1c458b]{display:flex;flex-direction:column;gap:4px}.source-field label[data-v-ac1c458b]{font-size:12px;color:var(--color-text-secondary);font-weight:500}.date-range-section[data-v-ac1c458b]{margin-top:8px;padding-top:8px;border-top:1px dashed var(--color-border)}.tag-selection[data-v-ac1c458b]{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.btn-add-tag[data-v-ac1c458b]{display:flex;align-items:center;gap:4px;padding:5px 12px;background:var(--color-primary);color:var(--color-white);border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:background-color .2s;white-space:nowrap}.btn-add-tag[data-v-ac1c458b]:hover:not(:disabled){background:var(--color-primary-hover)}.btn-add-tag[data-v-ac1c458b]:disabled{opacity:.5;cursor:not-allowed}.data-row-controls[data-v-ac1c458b]{display:grid;grid-template-columns:18px minmax(0,1fr) minmax(0,1fr) 28px;gap:8px;align-items:center}.row-device-select[data-v-ac1c458b],.row-data-select[data-v-ac1c458b]{width:100%;min-width:0;padding:5px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.row-device-select[data-v-ac1c458b]:focus,.row-data-select[data-v-ac1c458b]:focus{outline:none;border-color:var(--color-primary)}.row-data-select[data-v-ac1c458b]:disabled{opacity:.5;cursor:not-allowed}.empty-rows-hint[data-v-ac1c458b]{text-align:center;padding:20px;color:var(--color-text-muted);font-size:13px;font-style:italic;background:var(--color-surface-sunken);border-radius:6px;border:1px dashed var(--color-border)}.section-subtitle[data-v-ac1c458b]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 8px}.loading-hint[data-v-ac1c458b]{font-size:13px;color:var(--color-yellow);font-style:italic;margin-left:8px}.devices-count[data-v-ac1c458b]{font-size:12px;color:var(--color-success-500);margin-left:8px}.hint-text[data-v-ac1c458b]{display:block;font-size:13px;color:var(--color-text-muted);margin-top:4px;font-style:italic}.info-text-hint[data-v-ac1c458b]{color:var(--color-text-muted);font-size:13px;margin:0}.map-options[data-v-09ed7b20]{display:flex;flex-direction:column;padding:12px;background:transparent;font-size:13px;color:var(--color-text-primary)}.group-title[data-v-09ed7b20]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.group-desc[data-v-09ed7b20]{margin:0 0 4px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-09ed7b20]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:4px}.section-head[data-v-09ed7b20]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-09ed7b20]:hover{background:var(--color-surface-overlay);border-radius:4px 4px 0 0}.options-section.section-collapsed[data-v-09ed7b20]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-09ed7b20]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-09ed7b20]:hover{border-radius:4px}.section-head-icon[data-v-09ed7b20]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-09ed7b20]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-09ed7b20]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-09ed7b20]{display:flex;flex-direction:column;gap:10px}.option-item[data-v-09ed7b20]{display:flex;flex-direction:column;gap:4px}.option-item label[data-v-09ed7b20]{display:block;font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-row[data-v-09ed7b20]{display:flex;gap:8px;align-items:center}.input-row .input-field[data-v-09ed7b20]{flex:1}.input-small[data-v-09ed7b20]{width:70px!important;flex:none!important}.input-field[data-v-09ed7b20],.select-field[data-v-09ed7b20]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-field[data-v-09ed7b20]:focus,.select-field[data-v-09ed7b20]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.range-input[data-v-09ed7b20]{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-border);border-radius:3px;outline:none}.range-input[data-v-09ed7b20]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer}.range-input[data-v-09ed7b20]::-moz-range-thumb{width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:none}.range-value[data-v-09ed7b20]{font-size:12px;color:var(--color-text-secondary);min-width:40px;text-align:center}.color-field[data-v-09ed7b20]{width:60px;height:32px;padding:2px;border:1px solid var(--color-border);border-radius:3px;cursor:pointer;background:var(--color-input-bg)}.checkbox-item[data-v-09ed7b20]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-primary);cursor:pointer;width:100%}.checkbox-item label[data-v-09ed7b20]{display:flex;align-items:center;gap:6px;cursor:pointer;width:100%;margin:0}.checkbox-field[data-v-09ed7b20]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.section-header label[data-v-09ed7b20]{font-size:13px;font-weight:500;color:var(--color-text-primary)}.btn-add[data-v-09ed7b20]{display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;background:var(--gradient-primary);color:var(--color-white);border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-add[data-v-09ed7b20]:hover{background:var(--gradient-primary-hover);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.marker-item[data-v-09ed7b20]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:12px;margin-bottom:8px}.marker-header[data-v-09ed7b20]{display:grid;grid-template-columns:28px 1fr 40px 28px;gap:8px;align-items:center;margin-bottom:8px}.marker-index[data-v-09ed7b20]{font-size:11px;font-weight:600;color:var(--color-text-secondary);text-align:center}.marker-label-input[data-v-09ed7b20]{padding:6px 8px;border:1px solid var(--color-border);border-radius:6px;font-size:12px;background:var(--color-input-bg);color:var(--color-text-primary)}.color-input[data-v-09ed7b20]{width:32px;height:32px}.btn-remove[data-v-09ed7b20]{width:28px;height:28px;background:var(--gradient-danger);color:var(--color-white);border:none;border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-remove[data-v-09ed7b20]:hover{background:var(--gradient-danger-hover);box-shadow:0 2px 8px rgba(var(--color-red-rgb),.3)}.icon[data-v-09ed7b20]{width:14px;height:14px}.empty-markers[data-v-09ed7b20]{text-align:center;padding:24px 16px;background:var(--color-surface-sunken);border:2px dashed var(--color-border);border-radius:8px;color:var(--color-text-muted)}.empty-markers .empty-icon[data-v-09ed7b20]{color:var(--color-text-muted);margin-bottom:8px}.empty-markers p[data-v-09ed7b20]{margin:0 0 4px;font-weight:500;color:var(--color-text-primary)}.empty-markers span[data-v-09ed7b20]{font-size:12px}.marker-device-section[data-v-09ed7b20]{margin:12px 0;padding:12px;background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:6px}.marker-device-section .option-item[data-v-09ed7b20]{margin-bottom:8px}.marker-device-section .option-item[data-v-09ed7b20]:last-child{margin-bottom:0}.datamonitors-section[data-v-09ed7b20]{margin-top:12px;padding:10px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px}.section-header-small[data-v-09ed7b20]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.section-header-small label[data-v-09ed7b20]{font-size:11px;color:var(--color-text-primary);font-weight:500;margin:0}.btn-add-small[data-v-09ed7b20]{display:flex;align-items:center;gap:4px;padding:5px 10px;background:var(--gradient-primary);color:var(--color-white);border:none;border-radius:6px;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s}.btn-add-small[data-v-09ed7b20]:hover:not(:disabled){background:var(--gradient-primary-hover);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3);transform:translateY(-1px)}.btn-add-small[data-v-09ed7b20]:disabled{opacity:.5;cursor:not-allowed}.empty-datamonitors[data-v-09ed7b20]{padding:12px;text-align:center;color:var(--color-text-muted);font-size:11px;font-style:italic}.datamonitor-item[data-v-09ed7b20]{display:flex;gap:6px;align-items:center;margin-bottom:6px}.datamonitor-item[data-v-09ed7b20]:last-child{margin-bottom:0}.select-field-small[data-v-09ed7b20]{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;font-size:12px;background:var(--color-input-bg);color:var(--color-text-primary);outline:none;cursor:pointer;transition:all .2s}.select-field-small[data-v-09ed7b20]:hover{border-color:var(--color-text-muted)}.select-field-small[data-v-09ed7b20]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.select-field-small[data-v-09ed7b20]:disabled{opacity:.5;cursor:not-allowed}.btn-remove-small[data-v-09ed7b20]{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--gradient-danger);color:var(--color-white);border:none;border-radius:6px;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-remove-small[data-v-09ed7b20]:hover{background:var(--gradient-danger-hover);box-shadow:0 2px 8px rgba(var(--color-red-rgb),.3);transform:translateY(-1px)}.marker-popup[data-v-09ed7b20]{margin-top:8px}.marker-popup label[data-v-09ed7b20]{display:block;font-size:11px;color:var(--color-text-secondary);margin-bottom:4px}.popup-textarea[data-v-09ed7b20]{width:100%;padding:8px;border:1px solid var(--color-border);border-radius:6px;font-size:12px;resize:vertical;min-height:40px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box}.popup-textarea[data-v-09ed7b20]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.center-coordinate-display[data-v-09ed7b20]{display:flex;flex-direction:column;gap:8px}.coordinate-info[data-v-09ed7b20]{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:7px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px}.coord-label[data-v-09ed7b20]{color:var(--color-text-secondary);font-weight:500}.coord-value[data-v-09ed7b20]{color:var(--color-text-primary);font-weight:600;min-width:70px}.select-center-btn[data-v-09ed7b20]{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;background:var(--gradient-primary);color:var(--color-white);border:none;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.select-center-btn[data-v-09ed7b20]:hover{background:var(--gradient-primary-hover);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.select-center-btn.active[data-v-09ed7b20]{background:var(--gradient-warning);animation:pulse-btn-09ed7b20 1.5s infinite}@keyframes pulse-btn-09ed7b20{0%,to{opacity:1}50%{opacity:.8}}.hint-text[data-v-09ed7b20]{margin:0;padding:8px 12px;background:var(--color-yellow-bg);border:1px solid var(--color-yellow-border);border-radius:6px;font-size:11px;color:var(--color-yellow)}.marker-coordinates-select[data-v-09ed7b20]{display:flex;flex-direction:column;gap:8px;padding:8px;background:var(--color-surface-sunken);border-radius:6px;margin-top:8px}.coordinate-info-row[data-v-09ed7b20]{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.coordinate-info-row .coord-label[data-v-09ed7b20]{font-size:11px;color:var(--color-text-secondary);font-weight:500}.coordinate-info-row .coord-value[data-v-09ed7b20]{color:var(--color-text-primary);font-weight:600;font-size:12px;min-width:60px}.size-input-small[data-v-09ed7b20]{width:50px;padding:4px 6px;border:1px solid var(--color-border);border-radius:6px;font-size:11px;text-align:center;background:var(--color-input-bg);color:var(--color-text-primary)}.select-marker-btn[data-v-09ed7b20]{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:var(--gradient-primary);color:var(--color-white);border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.select-marker-btn[data-v-09ed7b20]:hover{background:var(--gradient-primary-hover);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.select-marker-btn.active[data-v-09ed7b20]{background:var(--gradient-warning);animation:pulse-btn-09ed7b20 1.5s infinite}.icon-spin[data-v-09ed7b20]{animation:spin-09ed7b20 1s linear infinite}@keyframes spin-09ed7b20{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.unified-alarm-options[data-v-abacc95c]{padding:12px;background:transparent;font-size:13px;color:var(--color-text-primary)}.group-title[data-v-abacc95c]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.group-desc[data-v-abacc95c]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-abacc95c]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:4px}.section-head[data-v-abacc95c]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-abacc95c]:hover{background:var(--color-surface-overlay);border-radius:4px 4px 0 0}.options-section.section-collapsed[data-v-abacc95c]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-abacc95c]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-abacc95c]:hover{border-radius:4px}.section-head-icon[data-v-abacc95c]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-abacc95c]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-abacc95c]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-abacc95c]{display:flex;flex-direction:column;gap:12px}.input-group[data-v-abacc95c]{display:flex;flex-direction:column;gap:4px}.input-label[data-v-abacc95c]{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-field[data-v-abacc95c],.select-field[data-v-abacc95c]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-field[data-v-abacc95c]:focus,.select-field[data-v-abacc95c]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.select-field[data-v-abacc95c]{cursor:pointer}.checkbox-item[data-v-abacc95c]{display:flex;align-items:center;gap:8px}.checkbox-item input[type=checkbox][data-v-abacc95c]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.checkbox-label[data-v-abacc95c]{font-size:13px;color:var(--color-text-primary);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.data-binding-picker[data-v-d39b72b9]{display:flex;flex-direction:column;gap:12px}.step-hint[data-v-d39b72b9]{font-size:12px;color:var(--color-text-muted);margin:0 0 8px}.binding-none[data-v-d39b72b9]{display:flex;flex-direction:column;gap:8px}.binding-none-frame[data-v-d39b72b9]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 16px;background:var(--color-surface-raised);border:1px dashed var(--color-border);border-radius:8px}.binding-none-icon[data-v-d39b72b9]{color:var(--color-primary)}.binding-none-text[data-v-d39b72b9]{margin:0;font-size:13px;font-weight:500;color:var(--color-text-primary)}.binding-single[data-v-d39b72b9]{display:flex;flex-direction:column;gap:8px}.form-group[data-v-d39b72b9]{margin-bottom:0}.form-label[data-v-d39b72b9]{display:block;margin-bottom:5px;font-weight:500;font-size:12px;color:var(--color-text-primary)}.form-input[data-v-d39b72b9]{width:100%;padding:7px 10px;border:1.5px solid var(--color-border);border-radius:7px;font-size:13px;outline:none;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.form-input[data-v-d39b72b9]:focus{border-color:var(--color-primary);box-shadow:var(--color-input-focus-shadow)}.form-input[data-v-d39b72b9]:disabled{background:var(--color-surface-overlay);color:var(--color-text-subtle);cursor:not-allowed}.loading-hint[data-v-d39b72b9]{display:inline-flex;align-items:center;gap:6px;margin:4px 0 0;font-size:12px;color:var(--color-text-muted)}.binding-multi[data-v-d39b72b9]{display:flex;flex-direction:column;gap:10px}.multi-header[data-v-d39b72b9]{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.multi-count[data-v-d39b72b9]{font-size:12px;color:var(--color-text-muted);white-space:nowrap}.devices-list[data-v-d39b72b9]{display:flex;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto;padding:4px;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:7px}.device-row[data-v-d39b72b9]{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:background .15s}.device-row[data-v-d39b72b9]:hover{background:var(--color-surface-overlay)}.device-row input[type=checkbox][data-v-d39b72b9]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.device-name[data-v-d39b72b9]{flex:1;font-size:13px;color:var(--color-text-primary)}.device-code[data-v-d39b72b9]{font-size:11px;color:var(--color-text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.multi-bindings-list[data-v-d39b72b9]{display:flex;flex-direction:column;gap:8px}.multi-binding-row[data-v-d39b72b9]{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:6px;padding:8px;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:7px;transition:background .15s}.multi-binding-row[data-v-d39b72b9]:hover{background:var(--color-surface-overlay)}.icon-btn-danger[data-v-d39b72b9]{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;cursor:pointer;background:transparent;color:var(--color-text-muted);transition:background .15s,color .15s}.icon-btn-danger[data-v-d39b72b9]:hover{background:var(--color-red-bg);color:var(--color-red)}.btn-add-tag[data-v-d39b72b9]{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px dashed var(--color-border-medium);border-radius:7px;background:transparent;color:var(--color-text-muted);font-size:12px;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s}.btn-add-tag[data-v-d39b72b9]:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-add-tag[data-v-d39b72b9]:disabled{opacity:.5;cursor:not-allowed}.empty-devices[data-v-d39b72b9]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px 16px;background:var(--color-surface-raised);border:1px dashed var(--color-border);border-radius:8px}.empty-devices-icon[data-v-d39b72b9]{color:var(--color-text-subtle)}.empty-devices-text[data-v-d39b72b9]{margin:0;font-size:13px;color:var(--color-text-muted);text-align:center}.modal-fade-enter-active[data-v-555f0a20],.modal-fade-leave-active[data-v-555f0a20]{transition:opacity .25s ease}.modal-fade-enter-from[data-v-555f0a20],.modal-fade-leave-to[data-v-555f0a20]{opacity:0}.modal-fade-enter-active .modal-container[data-v-555f0a20],.modal-fade-leave-active .modal-container[data-v-555f0a20]{transition:transform .25s ease}.modal-fade-enter-from .modal-container[data-v-555f0a20],.modal-fade-leave-to .modal-container[data-v-555f0a20]{transform:scale(.95)}.modal-overlay[data-v-555f0a20]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container[data-v-555f0a20]{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-container.modal-extra-wide[data-v-555f0a20]{max-width:min(1080px,96vw)}.modal-header[data-v-555f0a20]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-555f0a20]{display:flex;align-items:center;gap:10px}.modal-icon[data-v-555f0a20]{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-white);background:var(--gradient-primary);box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.3)}.modal-header h3[data-v-555f0a20]{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-555f0a20]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;transition:all .2s}.modal-close[data-v-555f0a20]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.step-indicator[data-v-555f0a20]{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border-light)}.step-pill[data-v-555f0a20]{display:inline-flex;align-items:center;gap:7px;padding:6px 12px 6px 6px;border-radius:18px;background:var(--color-surface);border:1.5px solid var(--color-border);font-size:11px;font-weight:600;color:var(--color-text-muted);transition:all .22s}.step-pill .step-num[data-v-555f0a20]{width:20px;height:20px;border-radius:50%;background:var(--color-border);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;transition:all .22s}.step-pill.is-active[data-v-555f0a20]{background:linear-gradient(135deg,rgba(var(--color-primary-rgb),.12),rgba(var(--color-primary-rgb),.04));border-color:var(--color-primary);color:var(--color-primary-hover)}.step-pill.is-active .step-num[data-v-555f0a20]{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:var(--color-white)}.step-pill.is-done[data-v-555f0a20]{color:var(--color-primary-hover)}.step-pill.is-done .step-num[data-v-555f0a20]{background:var(--color-primary);color:var(--color-white)}.step-label[data-v-555f0a20]{white-space:nowrap}.modal-body[data-v-555f0a20]{padding:16px;overflow-y:auto;flex:1}.step-hint[data-v-555f0a20]{margin:0 0 14px;font-size:12px;color:var(--color-text-muted)}.step2-wrap[data-v-555f0a20]{display:flex;flex-direction:column}.category-strip[data-v-555f0a20]{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;scrollbar-width:thin;padding-bottom:4px}.cat-tab[data-v-555f0a20]{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1.5px solid var(--color-border);border-radius:18px;background:var(--color-surface);color:var(--color-text-muted);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}.cat-tab[data-v-555f0a20]:hover{border-color:var(--color-border-medium);color:var(--color-text-primary)}.cat-tab.is-active[data-v-555f0a20]{background:var(--gradient-primary);border-color:transparent;color:var(--color-white);box-shadow:0 3px 8px rgba(var(--color-primary-rgb),.32)}.cat-tab-count[data-v-555f0a20]{display:inline-flex;align-items:center;justify-content:center;min-width:18px;padding:0 5px;height:16px;border-radius:8px;background:var(--color-surface-overlay);color:var(--color-text-muted);font-size:10px;font-weight:700}.cat-tab.is-active .cat-tab-count[data-v-555f0a20]{background:rgba(var(--color-white-rgb),.28);color:var(--color-white)}.step1-split[data-v-555f0a20]{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:stretch}.type-list[data-v-555f0a20]{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow-y:auto;padding-right:4px}.type-card[data-v-555f0a20]{position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:10px;background:var(--color-surface);cursor:pointer;transition:all .18s;text-align:left;color:var(--color-text-primary);font-family:inherit}.type-card[data-v-555f0a20]:hover{background:var(--color-surface-raised);border-color:var(--color-border-medium)}.type-card.is-selected[data-v-555f0a20]{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.06)}.type-card-text[data-v-555f0a20]{display:flex;flex-direction:column;gap:2px;min-width:0}.type-card-text strong[data-v-555f0a20]{font-size:13px;font-weight:600;color:var(--color-text-primary)}.type-card-text span[data-v-555f0a20]{font-size:11px;color:var(--color-text-muted);line-height:1.4}.type-card-check[data-v-555f0a20]{color:var(--color-primary);flex-shrink:0}.preview-pane[data-v-555f0a20]{display:flex;flex-direction:column;gap:8px;min-height:220px}.preview-pane-label[data-v-555f0a20]{font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:none}.preview-pane-header[data-v-555f0a20]{display:flex;align-items:center;gap:8px}.preview-live-chip[data-v-555f0a20]{display:inline-flex;align-items:center;gap:5px;padding:2px 7px;font-size:10px;font-weight:600;color:var(--color-primary-hover);background:var(--color-primary-bg);border-radius:10px}.preview-live-dot[data-v-555f0a20]{width:7px;height:7px;border-radius:50%;background:var(--color-primary);box-shadow:0 0 rgba(var(--color-primary-rgb),.55);animation:preview-live-pulse-555f0a20 1.8s infinite}@keyframes preview-live-pulse-555f0a20{0%{box-shadow:0 0 rgba(var(--color-primary-rgb),.55)}70%{box-shadow:0 0 0 7px rgba(var(--color-primary-rgb),0)}to{box-shadow:0 0 rgba(var(--color-primary-rgb),0)}}.preview-frame[data-v-555f0a20]{flex:1;background:var(--color-surface-raised);border:1.5px dashed var(--color-border);border-radius:10px;padding:14px;display:flex;align-items:center;justify-content:center;min-height:280px;max-height:360px;overflow:hidden;position:relative}.preview-empty[data-v-555f0a20]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--color-text-subtle)}.preview-empty p[data-v-555f0a20]{margin:0;font-size:12px;color:var(--color-text-muted)}.empty-state[data-v-555f0a20]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 16px;color:var(--color-text-subtle)}.empty-state p[data-v-555f0a20]{margin:0;font-size:12px;color:var(--color-text-muted)}.step3-split[data-v-555f0a20]{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:16px}.step3-preview-pane[data-v-555f0a20]{display:flex;flex-direction:column;gap:10px;min-width:0;min-height:360px}.step3-preview-frame[data-v-555f0a20]{flex:1;background:var(--color-surface-raised);border:1.5px dashed var(--color-border);border-radius:10px;padding:14px;display:flex;align-items:center;justify-content:center;min-height:420px;max-height:540px;overflow:hidden;position:relative}.step3-form-pane[data-v-555f0a20]{display:flex;flex-direction:column;gap:12px;min-width:0}.step3-form-pane[data-v-555f0a20] .gauge-options,.step3-form-pane[data-v-555f0a20] .chart-options,.step3-form-pane[data-v-555f0a20] .control-options,.step3-form-pane[data-v-555f0a20] .map-options,.step3-form-pane[data-v-555f0a20] .alarm-options,.step3-form-pane[data-v-555f0a20] .chart-bar-options,.step3-form-pane[data-v-555f0a20] .pb-options,.step3-form-pane[data-v-555f0a20] .switch-options,.step3-form-pane[data-v-555f0a20] .led-options{padding:0}.modal-footer[data-v-555f0a20]{display:flex;align-items:center;gap:8px;padding:11px 16px;border-top:1px solid var(--color-border-light)}.footer-spacer[data-v-555f0a20]{flex:1}.btn-cancel[data-v-555f0a20],.btn-back[data-v-555f0a20]{padding:7px 14px;border:1.5px solid var(--color-border);border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;background:var(--color-surface);color:var(--color-text-muted);display:inline-flex;align-items:center;gap:5px;transition:all .18s;font-family:inherit}.btn-back[data-v-555f0a20]{color:var(--color-text-primary)}.btn-back[data-v-555f0a20]:hover{background:var(--color-surface-raised);border-color:var(--color-border-medium)}.btn-cancel[data-v-555f0a20]{color:var(--color-red);border-color:rgba(var(--color-red-rgb),.42)}.btn-cancel[data-v-555f0a20]:hover{background:linear-gradient(135deg,var(--color-red-500),var(--color-red));color:var(--color-white);border-color:transparent;box-shadow:0 4px 10px rgba(var(--color-red-rgb),.32)}.btn-next[data-v-555f0a20],.btn-finish[data-v-555f0a20]{padding:7px 14px;border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:var(--color-white);background:var(--gradient-primary);font-family:inherit;transition:all .18s}.btn-next[data-v-555f0a20]:hover:not(:disabled),.btn-finish[data-v-555f0a20]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35)}.btn-next[data-v-555f0a20]:disabled,.btn-finish[data-v-555f0a20]:disabled{opacity:.6;cursor:not-allowed}.icon-spin[data-v-555f0a20]{animation:spin-555f0a20 1s linear infinite}@keyframes spin-555f0a20{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.step1-split[data-v-555f0a20],.step3-split[data-v-555f0a20]{grid-template-columns:1fr}.step3-preview-pane[data-v-555f0a20]{position:static}.preview-frame[data-v-555f0a20]{min-height:220px;max-height:280px}}@media (max-width: 600px){.step-label[data-v-555f0a20]{display:none}.step-pill[data-v-555f0a20]{padding:4px}}.dialog-view-close[data-v-dfee9493]:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.preview-control-block[data-v-dfee9493]{position:absolute;inset:0;z-index:50;background:transparent;cursor:not-allowed}.device-status-options[data-v-e097e14c]{padding:12px;background:transparent;font-size:13px}.group-title[data-v-e097e14c]{font-size:13px;font-weight:600;color:var(--color-slate-100);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-slate-700)}.group-desc[data-v-e097e14c]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-e097e14c]{margin-bottom:16px;padding:12px;background:var(--color-surface-dark-1);border:1px solid var(--color-border-dark-1);border-radius:4px}.section-head[data-v-e097e14c]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-slate-700);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-e097e14c]:hover{background:var(--color-surface-dark-2);border-radius:4px 4px 0 0}.options-section.section-collapsed[data-v-e097e14c]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-e097e14c]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-e097e14c]:hover{border-radius:4px}.section-head-icon[data-v-e097e14c]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-e097e14c]{flex:1;font-size:13px;font-weight:600;color:var(--color-slate-100)}.section-head-chevron[data-v-e097e14c]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-e097e14c]{display:flex;flex-direction:column;gap:12px}.option-group[data-v-e097e14c]{display:flex;flex-direction:column;gap:4px}.option-label[data-v-e097e14c]{font-size:13px;font-weight:500;color:var(--color-text-subtle);display:block}.checkbox-label-inline[data-v-e097e14c]{display:flex;align-items:center;gap:8px;cursor:pointer}.input-field[data-v-e097e14c]{width:100%;padding:6px 8px;border:1px solid var(--color-border-dark-1);border-radius:3px;font-size:13px;background:var(--color-surface-dark-3);color:var(--color-slate-200);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-field[data-v-e097e14c]:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 1px rgba(var(--color-blue-rgb),.4)}.color-picker-row[data-v-e097e14c]{display:flex;align-items:center;gap:8px}.color-input[data-v-e097e14c]{width:36px;height:32px;flex-shrink:0}.color-text-input[data-v-e097e14c]{flex:1;min-width:0}input[type=checkbox][data-v-e097e14c]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.alarm-devices-picker[data-v-b01d3cd5]{display:flex;flex-direction:column;gap:10px}.picker-hint[data-v-b01d3cd5]{font-size:12px;color:var(--color-text-muted);margin:0}.picker-empty[data-v-b01d3cd5]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px;color:var(--color-text-subtle);border:1px dashed var(--color-border);border-radius:8px}.picker-list[data-v-b01d3cd5]{display:flex;flex-direction:column;gap:4px;max-height:320px;overflow-y:auto;padding:4px;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:7px}.picker-row[data-v-b01d3cd5]{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:background .15s}.picker-row[data-v-b01d3cd5]:hover{background:var(--color-surface-overlay)}.picker-row input[type=checkbox][data-v-b01d3cd5]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.picker-name[data-v-b01d3cd5]{flex:1;font-size:13px;color:var(--color-text-primary)}.picker-code[data-v-b01d3cd5]{font-size:11px;color:var(--color-text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.picker-count[data-v-b01d3cd5]{font-size:11px;color:var(--color-text-muted);margin:0}.icon-spin[data-v-b01d3cd5]{animation:spin-b01d3cd5 1s linear infinite}@keyframes spin-b01d3cd5{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.device-status-widget[data-v-7bdcdfa4]{display:flex;flex-direction:column;height:100%;background:var(--color-surface);border-radius:8px;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.widget-header[data-v-7bdcdfa4]{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.header-left[data-v-7bdcdfa4]{display:flex;align-items:center;gap:8px}.header-icon[data-v-7bdcdfa4]{color:var(--color-success-500)}.header-title[data-v-7bdcdfa4]{font-size:13px;font-weight:600;color:var(--color-text-primary)}.header-right[data-v-7bdcdfa4]{display:flex;align-items:center;gap:8px}.online-badge[data-v-7bdcdfa4]{background:rgba(var(--color-success-rgb),.2);color:var(--color-success-500);padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.refresh-btn[data-v-7bdcdfa4]{background:var(--color-surface-overlay);border:none;color:var(--color-text-secondary);width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.refresh-btn[data-v-7bdcdfa4]:hover{background:var(--color-border)}.refresh-btn[data-v-7bdcdfa4]:disabled{opacity:.5;cursor:not-allowed}.device-list[data-v-7bdcdfa4]{flex:1;overflow-y:auto;padding:8px}.state-empty[data-v-7bdcdfa4]{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:var(--color-text-subtle);font-size:12px}.device-item[data-v-7bdcdfa4]{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;margin-bottom:4px;background:var(--color-surface-raised);transition:background .15s}.device-item[data-v-7bdcdfa4]:hover{background:var(--color-surface-overlay)}.device-item.is-online[data-v-7bdcdfa4]{background:var(--color-green-bg)}.status-dot[data-v-7bdcdfa4]{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online[data-v-7bdcdfa4]{background:var(--color-success-500);box-shadow:0 0 6px rgba(var(--color-success-rgb),.5)}.status-dot.offline[data-v-7bdcdfa4]{background:var(--color-red-500)}.device-name[data-v-7bdcdfa4]{flex:1;font-size:12px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.icon-online[data-v-7bdcdfa4]{color:var(--color-success-500)}.icon-offline[data-v-7bdcdfa4]{color:var(--color-red-500)}.widget-footer[data-v-7bdcdfa4]{padding:8px 12px;border-top:1px solid var(--color-border);text-align:center}.more-text[data-v-7bdcdfa4]{font-size:11px;color:var(--color-text-muted)}.animate-spin[data-v-7bdcdfa4]{animation:spin-7bdcdfa4 1s linear infinite}@keyframes spin-7bdcdfa4{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.unified-alarm-widget[data-v-2fd2b296]{display:flex;flex-direction:column;height:100%;background:var(--color-surface);border-radius:8px;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.widget-header[data-v-2fd2b296]{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.header-left[data-v-2fd2b296]{display:flex;align-items:center;gap:8px}.header-icon[data-v-2fd2b296]{color:var(--color-amber-400)}.header-title[data-v-2fd2b296]{font-size:14px;font-weight:600;color:var(--color-text-primary)}.header-right[data-v-2fd2b296]{display:flex;align-items:center;gap:8px}.alarm-badge[data-v-2fd2b296]{min-width:24px;height:24px;padding:0 6px;border-radius:12px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center}.badge-success[data-v-2fd2b296]{background:var(--color-primary);color:var(--color-white)}.badge-critical[data-v-2fd2b296]{background:var(--color-red-500);color:var(--color-white);animation:pulse-2fd2b296 1.5s infinite}.badge-warning[data-v-2fd2b296]{background:var(--color-yellow);color:var(--color-white)}.badge-info[data-v-2fd2b296]{background:var(--color-blue-500);color:var(--color-white)}@keyframes pulse-2fd2b296{0%,to{opacity:1}50%{opacity:.7}}.refresh-btn[data-v-2fd2b296]{background:var(--color-surface-overlay);border:none;color:var(--color-text-secondary);padding:4px 6px;border-radius:4px;cursor:pointer;transition:background .2s}.refresh-btn[data-v-2fd2b296]:hover:not(:disabled){background:var(--color-border)}.refresh-btn[data-v-2fd2b296]:disabled{opacity:.5;cursor:not-allowed}.filter-row[data-v-2fd2b296]{padding:8px 12px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border)}.device-select[data-v-2fd2b296]{width:100%;padding:6px 10px;border:1px solid var(--color-border-medium);border-radius:6px;font-size:12px;background:var(--color-input-bg);color:var(--color-text-primary);cursor:pointer}.device-select[data-v-2fd2b296]:focus{outline:none;border-color:var(--color-blue-500)}.alarm-list[data-v-2fd2b296]{flex:1;overflow-y:auto;padding:8px}.state-empty[data-v-2fd2b296]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;color:var(--color-text-subtle);font-size:13px}.empty-icon[data-v-2fd2b296]{color:var(--color-primary)}.alarm-item[data-v-2fd2b296]{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--color-surface-raised);border-radius:8px;margin-bottom:6px;transition:background .15s;cursor:pointer;border-left:3px solid transparent}.alarm-item[data-v-2fd2b296]:hover{background:var(--color-surface-overlay)}.alarm-item[data-v-2fd2b296]:last-child{margin-bottom:0}.alarm-item.alarm-unread[data-v-2fd2b296]{background:var(--color-yellow-bg)}.alarm-item.alarm-unread[data-v-2fd2b296]:hover{background:rgba(var(--color-amber-200-rgb),.3)}.alarm-content[data-v-2fd2b296]{flex:1;min-width:0}.alarm-message[data-v-2fd2b296]{font-size:13px;font-weight:500;color:var(--color-text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alarm-meta[data-v-2fd2b296]{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--color-text-muted);margin-bottom:4px}.alarm-value[data-v-2fd2b296]{font-size:11px;color:var(--color-text-secondary)}.alarm-value strong[data-v-2fd2b296]{color:var(--color-red-500)}.separator[data-v-2fd2b296]{color:var(--color-text-subtle)}.ack-btn[data-v-2fd2b296]{padding:4px 8px;background:var(--color-primary);color:var(--color-white);border:none;border-radius:4px;cursor:pointer;transition:background .2s;flex-shrink:0;align-self:center}.ack-btn[data-v-2fd2b296]:hover{background:var(--color-primary-hover)}.severity-critical[data-v-2fd2b296]{border-left-color:var(--color-red-500)}.severity-warning[data-v-2fd2b296]{border-left-color:var(--color-yellow)}.severity-low[data-v-2fd2b296]{border-left-color:var(--color-blue-500)}.severity-info[data-v-2fd2b296]{border-left-color:var(--color-text-muted)}.widget-footer[data-v-2fd2b296]{padding:8px 12px;background:var(--color-surface-raised);border-top:1px solid var(--color-border);text-align:center}.more-text[data-v-2fd2b296]{font-size:11px;color:var(--color-text-muted)}.animate-spin[data-v-2fd2b296]{animation:spin-2fd2b296 1s linear infinite}@keyframes spin-2fd2b296{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-fade-enter-active[data-v-2fd2b296],.modal-fade-leave-active[data-v-2fd2b296]{transition:opacity .2s}.modal-fade-enter-from[data-v-2fd2b296],.modal-fade-leave-to[data-v-2fd2b296]{opacity:0}.unified-alarm-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(var(--color-black-rgb),.5);display:flex;align-items:center;justify-content:center;z-index:99999}.unified-alarm-modal-container{background:var(--color-surface);border-radius:12px;width:90%;max-width:420px;max-height:80vh;overflow:hidden;box-shadow:0 20px 25px -5px rgba(var(--color-black-rgb),.1)}.unified-alarm-modal-header{display:flex;align-items:center;gap:12px;padding:16px;background:linear-gradient(135deg,var(--color-slate-800) 0%,var(--color-slate-700) 100%);color:var(--color-white)}.unified-alarm-modal-header h3{flex:1;font-size:16px;font-weight:600;margin:0}.unified-alarm-modal-header .modal-icon-wrapper{width:36px;height:36px;background:rgba(var(--color-amber-400-rgb),.2);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-amber-400)}.unified-alarm-modal-header .modal-close-btn{background:rgba(var(--color-white-rgb),.1);border:none;color:var(--color-white);padding:6px;border-radius:6px;cursor:pointer}.unified-alarm-modal-header .modal-close-btn:hover{background:rgba(var(--color-white-rgb),.2)}.unified-alarm-modal-container .modal-body{padding:16px}.unified-alarm-modal-container .detail-grid{display:grid;gap:12px}.unified-alarm-modal-container .detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--color-border)}.unified-alarm-modal-container .detail-label{font-size:13px;color:var(--color-text-muted)}.unified-alarm-modal-container .detail-value{font-size:13px;font-weight:500;color:var(--color-text-primary)}.unified-alarm-modal-container .detail-value.highlight{color:var(--color-red-500);font-weight:600}.unified-alarm-modal-container .status-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:500}.unified-alarm-modal-container .status-badge.unread{background:var(--color-yellow-bg);color:var(--color-primary-hover)}.unified-alarm-modal-container .status-badge.read{background:var(--color-green-bg);color:var(--color-green-hover)}.unified-alarm-modal-container .detail-message{margin-top:12px;padding:12px;background:var(--color-surface-raised);border-radius:8px;font-size:13px;color:var(--color-text-secondary)}.unified-alarm-modal-container .modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:12px 16px;background:var(--color-surface-raised);border-top:1px solid var(--color-border)}.unified-alarm-modal-container .btn-cancel,.unified-alarm-modal-container .btn-action{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.unified-alarm-modal-container .btn-cancel{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-muted)}.unified-alarm-modal-container .btn-cancel:hover{background:var(--color-surface-overlay)}.unified-alarm-modal-container .btn-action{background:linear-gradient(135deg,var(--color-blue-500) 0%,var(--color-blue-600) 100%);border:none;color:var(--color-white)}.unified-alarm-modal-container .btn-action:hover{box-shadow:0 4px 12px rgba(var(--color-blue-rgb),.35)}.chart-bar-options[data-v-3f0d9408]{display:flex;flex-direction:column;gap:8px;padding:4px 0}.cbo-section[data-v-3f0d9408]{border:1px solid var(--color-border-light);border-radius:8px;overflow:hidden}.cbo-section-header[data-v-3f0d9408]{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;background:var(--color-surface-raised);border:none;font-size:12px;font-weight:600;color:var(--color-text-primary);cursor:pointer}.cbo-section-body[data-v-3f0d9408]{padding:10px 12px;background:var(--color-surface);display:flex;flex-direction:column;gap:8px}.cbo-hint[data-v-3f0d9408]{font-size:12px;color:var(--color-text-muted)}.cbo-row[data-v-3f0d9408]{display:flex;align-items:flex-end;gap:8px}.cbo-row-key[data-v-3f0d9408]{flex:1;margin-bottom:0}.cbo-row-color[data-v-3f0d9408]{width:56px;margin-bottom:0}.cbo-remove[data-v-3f0d9408]{width:28px;height:28px;border:none;background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);color:var(--color-white);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center}.cbo-add-btn[data-v-3f0d9408]{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;padding:6px 12px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);border:none;border-radius:7px;cursor:pointer;font-size:12px;font-weight:500}.form-group[data-v-3f0d9408]{margin-bottom:0}.form-label[data-v-3f0d9408]{display:block;margin-bottom:4px;font-size:11px;font-weight:500;color:var(--color-text-primary)}.form-input[data-v-3f0d9408]{width:100%;padding:7px 10px;border:1.5px solid var(--color-border);border-radius:7px;font-size:12px;background:var(--color-input-bg);color:var(--color-text-primary);outline:none;box-sizing:border-box}.form-input[data-v-3f0d9408]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-color[data-v-3f0d9408]{width:40px;height:32px}.cbo-toggle-row[data-v-3f0d9408]{display:flex;align-items:center;justify-content:space-between;gap:8px}.cbo-toggle-row .form-label[data-v-3f0d9408]{margin-bottom:0}.chart-bar-widget[data-v-79f692c5]{width:100%;height:100%;display:flex;flex-direction:column;background:var(--color-surface);border-radius:8px;overflow:hidden;box-sizing:border-box}.chart-bar-header[data-v-79f692c5]{padding:8px 12px;border-bottom:1px solid var(--color-border);background:var(--color-surface-raised);flex-shrink:0}.chart-bar-title[data-v-79f692c5]{font-size:13px;font-weight:600;color:var(--color-text-primary)}.chart-bar-body[data-v-79f692c5]{flex:1;position:relative;min-height:0;padding:8px}.chart-bar-canvas[data-v-79f692c5]{width:100%!important;height:100%!important}.chart-bar-empty[data-v-79f692c5]{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:12px}.dp--btn-base{font:inherit;transition:var(--dp-common-transition);border:none;line-height:normal}.dp--bg-none{background:0 0}.dp--active{background:var(--dp-primary-color);color:var(--dp-primary-text-color)}.dp--flex{align-items:center;display:flex}.dp--pointer{cursor:pointer}.dp--icon{stroke:currentColor;fill:currentColor}.dp--button{text-align:center;width:100%;color:var(--dp-icon-color);cursor:pointer;padding:var(--dp-common-padding);box-sizing:border-box;height:var(--dp-button-height);place-content:center;align-items:center;display:flex}.dp--button.dp--overlay-action{position:absolute;bottom:0}.dp--button .dp--main{font-family:var(--dp-font-family);-webkit-user-select:none;-moz-user-select:none;user-select:none;box-sizing:border-box;width:100%;position:relative}.dp--button .dp--main *{direction:var(--dp-direction,ltr)}.dp--button:hover{background:var(--dp-hover-color);color:var(--dp-hover-icon-color)}.dp--button svg{height:var(--dp-button-icon-height);width:auto}.dp--button-bottom{border-bottom-left-radius:var(--dp-border-radius);border-bottom-right-radius:var(--dp-border-radius)}.dp--flex-display{display:flex}.dp--relative{position:relative}.dp--highlighted{background-color:var(--dp-highlight-color)}.dp--hidden-el{visibility:hidden}.dp--centered{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.dp--action-row{width:100%;padding:var(--dp-action-row-padding);box-sizing:border-box;color:var(--dp-text-color);flex-flow:row;align-items:center;display:flex}.dp--action-row svg{height:var(--dp-button-icon-height);width:auto}.dp--selection-preview{color:var(--dp-text-color);font-size:var(--dp-preview-font-size);white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.dp--action-buttons{white-space:nowrap;flex:0;justify-content:flex-end;align-items:center;margin-inline-start:auto;display:flex}.dp--action-button{padding:var(--dp-action-buttons-padding);line-height:var(--dp-action-button-height);height:var(--dp-action-button-height);cursor:pointer;border-radius:var(--dp-border-radius);font-size:var(--dp-preview-font-size);font-family:var(--dp-font-family);background:0 0;border:1px solid #0000;align-items:center;margin-inline-start:3px;display:inline-flex}.dp--action-cancel{color:var(--dp-text-color);border:1px solid var(--dp-border-color)}.dp--action-cancel:hover{border-color:var(--dp-primary-color);transition:var(--dp-action-row-transition)}.dp--action-buttons .dp--action-select{background:var(--dp-primary-color);color:var(--dp-primary-text-color)}.dp--action-buttons .dp--action-select:hover{background:var(--dp-primary-color);transition:var(--dp-action-row-transition)}.dp--action-buttons .dp--action-select:disabled{background:var(--dp-primary-disabled-color);cursor:not-allowed}.dp--calendar-header{color:var(--dp-text-color);white-space:nowrap;justify-content:center;align-items:center;font-weight:700;display:flex;position:relative}.dp--calendar-header-item{text-align:center;height:var(--dp-cell-size);padding:var(--dp-cell-padding);width:var(--dp-cell-size);box-sizing:border-box;flex-grow:1}.dp--calendar-row{margin:var(--dp-row-margin);justify-content:center;align-items:center;display:flex}.dp--calendar-item{text-align:center;box-sizing:border-box;color:var(--dp-text-color);flex-grow:1}.dp--calendar{position:relative}.dp--calendar-header-cell{border-bottom:thin solid var(--dp-border-color);padding:var(--dp-calendar-header-cell-padding)}.dp--cell-inner{text-align:center;border-radius:var(--dp-cell-border-radius);height:var(--dp-cell-size);padding:var(--dp-cell-padding);width:var(--dp-cell-size);box-sizing:border-box;border:1px solid #0000;justify-content:center;align-items:center;display:flex;position:relative}.dp--cell-inner:hover{transition:all .2s}.dp--range-border-start{border-start-end-radius:0;border-end-end-radius:0}.dp--range-border-end{border-start-start-radius:0;border-end-start-radius:0}.dp--range-preview{border-top:1px dashed var(--dp-primary-color);border-bottom:1px dashed var(--dp-primary-color)}.dp--cell-offset{color:var(--dp-secondary-color)}.dp--cell-disabled{color:var(--dp-secondary-color);cursor:not-allowed}.dp--date-hoverable:hover{background:var(--dp-hover-color);color:var(--dp-hover-text-color)}.dp--date-hoverable-start:hover{border-start-end-radius:0;border-end-end-radius:0}.dp--date-hoverable-end:hover{border-start-start-radius:0;border-end-start-radius:0}.dp--range-between{background:var(--dp-range-between-dates-background-color);color:var(--dp-range-between-dates-text-color);border:1px solid var(--dp-range-between-border-color);border-radius:0}.dp--range-between-week{background:var(--dp-primary-color);color:var(--dp-primary-text-color);border-radius:0}.dp--today{border:1px solid var(--dp-primary-color)}.dp--week-num{color:var(--dp-secondary-color);text-align:center}.dp--cell-auto-range{border-radius:0}.dp--cell-auto-range-start{border-inline-start:1px dashed var(--dp-primary-color);border-start-start-radius:var(--dp-cell-border-radius);border-end-start-radius:var(--dp-cell-border-radius)}.dp--cell-auto-range-end{border-inline-end:1px dashed var(--dp-primary-color);border-start-end-radius:var(--dp-cell-border-radius);border-end-end-radius:var(--dp-cell-border-radius)}.dp--calendar-header-separator{background:var(--dp-border-color);width:100%;height:1px}.dp--calendar-next{margin-inline-start:var(--dp-multi-calendars-spacing)}.dp--marker-base{background-color:var(--dp-marker-color);height:5px;position:absolute;bottom:0}.dp--marker-dot{border-radius:50%;width:5px;left:50%;transform:translate(-50%)}.dp--marker-line{width:100%;left:0}.dp--marker-tooltip{border-radius:var(--dp-border-radius);background-color:var(--dp-tooltip-color);border:1px solid var(--dp-border-color);z-index:99999;box-sizing:border-box;cursor:default;padding:5px;position:absolute}.dp--tooltip-content{white-space:nowrap}.dp--tooltip-text{color:var(--dp-text-color);flex-flow:row;align-items:center;display:flex}.dp--tooltip-mark{background-color:var(--dp-text-color);width:5px;height:5px;color:var(--dp-text-color);border-radius:50%;margin-inline-end:5px}.dp--arrow-bottom-tp{background-color:var(--dp-tooltip-color);border-inline-end:1px solid var(--dp-border-color);border-bottom:1px solid var(--dp-border-color);width:8px;height:8px;position:absolute;bottom:0;transform:translate(-50%,50%)rotate(45deg)}.dp--instance-calendar{width:100%;position:relative}.dp--flex-display[data-dp-mobile],.dp--flex-display-collapsed{flex-direction:column}.dp--cell-highlight{background-color:var(--dp-highlight-color)}.dp--input-wrap{width:100%;box-sizing:unset;position:relative}.dp--input-wrap:focus{border-color:var(--dp-border-color-hover);outline:none}.dp--input-valid{box-shadow:0 0 var(--dp-border-radius) var(--dp-success-color);border-color:var(--dp-success-color)}.dp--input-valid:hover{border-color:var(--dp-success-color)}.dp--input-invalid{box-shadow:0 0 var(--dp-border-radius) var(--dp-danger-color);border-color:var(--dp-danger-color)}.dp--input-invalid:hover{border-color:var(--dp-danger-color)}.dp--input{background-color:var(--dp-background-color);border-radius:var(--dp-border-radius);font-family:var(--dp-font-family);border:1px solid var(--dp-border-color);width:100%;font-size:var(--dp-font-size);line-height:calc(var(--dp-font-size) * 1.5);padding:var(--dp-input-padding);color:var(--dp-text-color);box-sizing:border-box;outline:none;transition:border-color .2s cubic-bezier(.645,.045,.355,1)}.dp--input::-moz-placeholder{opacity:.7}.dp--input::placeholder{opacity:.7}.dp--input:hover:not(.dp--input-focus){border-color:var(--dp-border-color-hover)}.dp--input-not-clearable{padding-inline-end:var(--dp-input-not-clearable-padding)!important}.dp--input-reg{caret-color:#0000}.dp--input-focus{border-color:var(--dp-border-color-focus)}.dp--disabled{background:var(--dp-disabled-color)}.dp--disabled::-moz-placeholder{color:var(--dp-disabled-color-text)}.dp--disabled::placeholder{color:var(--dp-disabled-color-text)}.dp--input-icons{width:var(--dp-font-size);height:var(--dp-font-size);stroke-width:0;font-size:var(--dp-font-size);line-height:calc(var(--dp-font-size) * 1.5);color:var(--dp-icon-color);box-sizing:content-box;padding:6px 12px;display:inline-block}.dp--input-icon{cursor:pointer;top:50%;color:var(--dp-icon-color);position:absolute;inset-inline-start:0;transform:translateY(-50%)}.dp--clear-btn{top:50%;cursor:pointer;color:var(--dp-icon-color);background:0 0;border:none;align-items:center;margin:0;padding:0;display:inline-flex;position:absolute;inset-inline-end:0;transform:translateY(-50%)}.dp--input-icon-pad{padding-inline-start:var(--dp-input-icon-padding)}.dp--menu{background:var(--dp-background-color);border-radius:var(--dp-border-radius);min-width:var(--dp-menu-min-width);font-family:var(--dp-font-family);font-size:var(--dp-font-size);-webkit-user-select:none;-moz-user-select:none;user-select:none;border:1px solid var(--dp-menu-border-color);box-sizing:border-box}.dp--menu:after,.dp--menu:before{box-sizing:border-box}.dp--menu:focus{border:1px solid var(--dp-menu-border-color);outline:none}.dp--menu-wrapper{z-index:99999;position:absolute}.dp--menu-inner{padding:var(--dp-menu-padding)}.dp--menu--inner-stretched{padding:6px 0}.dp--menu-index{z-index:99999}.dp--menu-unclickable{z-index:999999;position:absolute;inset:0}.dp--menu-disabled{cursor:not-allowed;background:#ffffff80}.dp--menu-readonly{cursor:default;background:0 0}.dp-menu-loading{cursor:default;background:#ffffff80}.dp--menu-load-container{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.dp--menu-loader{border:var(--dp-loader);box-sizing:border-box;border-bottom-color:#0000;border-radius:50%;width:48px;height:48px;animation:1s linear infinite dp-load-rotation;display:inline-block;position:absolute}@keyframes dp-load-rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dp--arrow-top{background-color:var(--dp-background-color);border-inline-end:1px solid var(--dp-menu-border-color);border-top:1px solid var(--dp-menu-border-color);width:12px;height:12px;position:absolute;transform:translateY(-50%)rotate(-45deg)}.dp--arrow-bottom{left:var(--dp-arrow-left);background-color:var(--dp-background-color);border-inline-end:1px solid var(--dp-menu-border-color);border-bottom:1px solid var(--dp-menu-border-color);width:12px;height:12px;position:absolute;bottom:0;transform:translate(-50%,50%)rotate(45deg)}.dp--action-extra{text-align:center;padding:2px 0}.dp--preset-dates{border-inline-end:1px solid var(--dp-border-color);padding:5px}.dp--preset-dates[data-dp-mobile],.dp--preset-dates-collapsed{max-width:calc(var(--dp-menu-width) - var(--dp-action-row-padding) * 2);border:none;align-self:center;display:flex;overflow-x:auto}.dp--sidebar-left{border-inline-end:1px solid var(--dp-border-color);padding:5px}.dp--sidebar-right{margin-inline-end:1px solid var(--dp-border-color);padding:5px}.dp--preset-range{text-align:left;white-space:nowrap;width:100%;color:var(--dp-text-color);border-radius:var(--dp-border-radius);transition:var(--dp-common-transition);padding:5px;display:block}.dp--preset-range:hover{background-color:var(--dp-hover-color);color:var(--dp-hover-text-color);cursor:pointer}.dp--preset-range[data-dp-mobile]{border:1px solid var(--dp-border-color);margin:0 3px}.dp--preset-range[data-dp-mobile]:first-child{margin-left:0}.dp--preset-range[data-dp-mobile]:last-child{margin-right:0}.dp--preset-range-collapsed{border:1px solid var(--dp-border-color);margin:0 3px}.dp--preset-range-collapsed:first-child{margin-left:0}.dp--preset-range-collapsed:last-child{margin-right:0}.dp--menu-content-wrapper{display:flex}.dp--menu-content-wrapper[data-dp-mobile],.dp--menu-content-wrapper-collapsed{flex-direction:column-reverse}.dp--month-year-row{height:var(--dp-month-year-row-height);color:var(--dp-text-color);box-sizing:border-box;align-items:center;display:flex}.dp--inner-nav{cursor:pointer;height:var(--dp-month-year-row-button-size);width:var(--dp-month-year-row-button-size);color:var(--dp-icon-color);text-align:center;border-radius:50%;justify-content:center;align-items:center;display:flex}.dp--inner-nav svg{height:var(--dp-button-icon-height);width:var(--dp-button-icon-height)}.dp--inner-nav:hover{background:var(--dp-hover-color);color:var(--dp-hover-icon-color)}[dir=rtl] .dp--inner-nav{transform:rotate(180deg)}.dp--inner-nav-disabled,.dp--inner-nav-disabled:hover{background:var(--dp-disabled-color);color:var(--dp-disabled-color-text);cursor:not-allowed}.dp--month-year-select-base{text-align:center;cursor:pointer;height:var(--dp-month-year-row-height);border-radius:var(--dp-border-radius);box-sizing:border-box;color:var(--dp-text-color);justify-content:center;align-items:center;display:flex}.dp--month-year-select-base:hover{background:var(--dp-hover-color);color:var(--dp-hover-text-color);transition:var(--dp-common-transition)}.dp--month-year-select{width:50%}.dp--year-select{width:100%}.dp--month-year-wrap{flex-direction:row;align-items:center;width:100%;display:flex}.dp--year-disable-select{justify-content:space-around}.dp--header-wrap{flex-direction:column;width:100%;display:flex}.dp--year-mode-picker{width:100%;height:var(--dp-cell-size);justify-content:space-between;align-items:center;display:flex}.dp--arrow-btn-nav{transition:var(--dp-common-transition);height:100%}.dp-quarter-picker-wrap{height:100%;min-width:var(--dp-menu-min-width);flex-direction:column;display:flex}.dp--qr-btn-disabled{cursor:not-allowed;background:var(--dp-disabled-color)}.dp--qr-btn-disabled:hover{background:var(--dp-disabled-color)}.dp--qr-btn{width:100%;padding:var(--dp-common-padding)}.dp--qr-btn:not(.dp--highlighted,.dp--active,.dp--qr-btn-disabled,.dp--qr-btn-between){background:0 0}.dp--qr-btn:hover:not(.dp--active,.dp--qr-btn-disabled){background:var(--dp-hover-color);color:var(--dp-hover-text-color);transition:var(--dp-common-transition)}.dp--quarter-items{flex-direction:column;flex:1;justify-content:space-evenly;width:100%;height:100%;display:flex}.dp--qr-btn-between{background:var(--dp-hover-color);color:var(--dp-hover-text-color)}.dp--overlay{background:var(--dp-background-color);z-index:99999;width:100%;font-family:var(--dp-font-family);color:var(--dp-text-color);box-sizing:border-box;transition:opacity 1s ease-out}.dp--overlay-absolute{height:100%;position:absolute;top:0;left:0}.dp--overlay-relative{position:relative}.dp--overlay-container::-webkit-scrollbar-track{box-shadow:var(--dp-scroll-bar-background);background-color:var(--dp-scroll-bar-background)}.dp--overlay-container::-webkit-scrollbar{background-color:var(--dp-scroll-bar-background);width:5px}.dp--overlay-container::-webkit-scrollbar-thumb{background-color:var(--dp-scroll-bar-color);border-radius:10px}.dp--overlay:focus{border:none;outline:none}.dp--container-flex{display:flex}.dp--container-block{display:block}.dp--overlay-container{height:var(--dp-overlay-height);flex-direction:column;overflow-y:auto}.dp--time-picker-overlay-container{height:100%}.dp--overlay-row{box-sizing:border-box;flex-wrap:wrap;align-items:center;width:100%;max-width:100%;margin-inline:auto;padding:0;display:flex}.dp--flex-row{flex:1}.dp--overlay-col{box-sizing:border-box;width:33%;padding:var(--dp-overlay-col-padding);white-space:nowrap}.dp--overlay-cell-pad{padding:var(--dp-common-padding) 0}.dp--overlay-cell-active,.dp--overlay-cell{cursor:pointer;border-radius:var(--dp-border-radius);text-align:center}.dp--overlay-cell:hover{background:var(--dp-hover-color);color:var(--dp-hover-text-color);transition:var(--dp-common-transition)}.dp--cell-in-between{background:var(--dp-hover-color);color:var(--dp-hover-text-color)}.dp--over-action-scroll{box-sizing:border-box;right:5px}.dp--overlay-cell-disabled{cursor:not-allowed;background:var(--dp-disabled-color)}.dp--overlay-cell-disabled:hover{background:var(--dp-disabled-color)}.dp--overlay-cell-active-disabled{cursor:not-allowed;background:var(--dp-primary-disabled-color)}.dp--overlay-cell-active-disabled:hover{background:var(--dp-primary-disabled-color)}.dp--tp-wrap{width:100%}.dp--tp-wrap[data-dp-mobile]{max-width:100%}.dp--time-input{-webkit-user-select:none;-moz-user-select:none;user-select:none;width:100%;font-family:var(--dp-font-family);color:var(--dp-text-color);justify-content:center;align-items:center;display:flex}.dp--time-col-reg-block{padding:0 20px}.dp--time-col-reg-inline{padding:0 10px}.dp--time-col-reg-with-button{padding:0 15px}.dp--time-col-reg-with-button[data-compact~=true]{padding:0 5px}.dp--time-col-sec{padding:0 10px}.dp--time-col-sec-with-button{padding:0 5px}.dp--time-col-sec-with-button[data-collapsed~=true]{padding:0}.dp--time-col{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.dp--time-col-block{font-size:var(--dp-time-font-size)}.dp--inc-dec-button-disabled,.dp--inc-dec-button-disabled:hover{background:var(--dp-disabled-color);color:var(--dp-disabled-color-text);cursor:not-allowed}.dp--time-display-block{padding:0 3px}.dp--time-display-inline{padding:5px}.dp--time-picker-inline-container{justify-content:center;width:100%;display:flex}.dp--inc-dec-button{height:var(--dp-time-inc-dec-button-size);width:var(--dp-time-inc-dec-button-size);cursor:pointer;color:var(--dp-icon-color);box-sizing:border-box;border-radius:50%;justify-content:center;align-items:center;margin:0;padding:5px;display:flex}.dp--inc-dec-button svg{height:var(--dp-time-inc-dec-button-size);width:var(--dp-time-inc-dec-button-size)}.dp--inc-dec-button:hover{background:var(--dp-hover-color);color:var(--dp-hover-icon-color)}.dp--time-display{cursor:pointer;color:var(--dp-text-color);border-radius:var(--dp-border-radius);justify-content:center;align-items:center;display:flex}.dp--time-display:hover:enabled{background:var(--dp-hover-color);color:var(--dp-hover-text-color)}.dp--inc-dec-button-inline{cursor:pointer;align-items:center;width:100%;height:8px;padding:0;display:flex}.dp--pm-am-button{background:var(--dp-primary-color);color:var(--dp-primary-text-color);padding:var(--dp-common-padding);border-radius:var(--dp-border-radius);cursor:pointer;border:none}.dp--pm-am-button[data-compact~=true]{padding:7px}.dp--tp-inline-btn-bar{background-color:var(--dp-secondary-color);width:100%;height:4px;transition:var(--dp-common-transition);border-collapse:collapse}.dp--tp-inline-btn-top:hover .dp--tp-btn-in-r{background-color:var(--dp-primary-color);transform:rotate(12deg)scale(1.15)translateY(-2px)}.dp--tp-inline-btn-top:hover .dp--tp-btn-in-l,.dp--tp-inline-btn-bottom:hover .dp--tp-btn-in-r{background-color:var(--dp-primary-color);transform:rotate(-12deg)scale(1.15)translateY(-2px)}.dp--tp-inline-btn-bottom:hover .dp--tp-btn-in-l{background-color:var(--dp-primary-color);transform:rotate(12deg)scale(1.15)translateY(-2px)}.dp--time-overlay-btn{background:0 0}.dp--time-invalid{background-color:var(--dp-disabled-color)}:root{--dp-common-transition:all .1s ease-in;--dp-menu-padding:6px 8px;--dp-animation-duration:.1s;--dp-menu-appear-transition-timing:cubic-bezier(.4, 0, 1, 1);--dp-transition-timing:ease-out;--dp-action-row-transition:all .2s ease-in;--dp-font-family:-apple-system, blinkmacsystemfont, "Segoe UI", roboto, oxygen, ubuntu, cantarell, "Open Sans", "Helvetica Neue", sans-serif;--dp-border-radius:4px;--dp-cell-border-radius:4px;--dp-transition-length:22px;--dp-transition-timing-general:.1s;--dp-button-height:35px;--dp-month-year-row-height:35px;--dp-month-year-row-button-size:25px;--dp-button-icon-height:20px;--dp-calendar-wrap-padding:0 5px;--dp-cell-size:35px;--dp-cell-padding:5px;--dp-common-padding:10px;--dp-input-icon-padding:35px;--dp-input-padding:6px 30px 6px 12px;--dp-input-not-clearable-padding:12px;--dp-menu-min-width:260px;--dp-action-buttons-padding:1px 6px;--dp-row-margin:5px 0;--dp-calendar-header-cell-padding:.5rem;--dp-multi-calendars-spacing:10px;--dp-overlay-col-padding:3px;--dp-time-inc-dec-button-size:32px;--dp-font-size:1rem;--dp-preview-font-size:.8rem;--dp-time-font-size:2rem;--dp-action-button-height:22px;--dp-action-row-padding:8px;--dp-direction:ltr}.dp--theme-dark{--dp-background-color:#212121;--dp-text-color:#fff;--dp-hover-color:#484848;--dp-hover-text-color:#fff;--dp-hover-icon-color:#959595;--dp-primary-color:#005cb2;--dp-primary-disabled-color:#61a8ea;--dp-primary-text-color:#fff;--dp-secondary-color:#a9a9a9;--dp-border-color:#2d2d2d;--dp-menu-border-color:#2d2d2d;--dp-border-color-hover:#aaaeb7;--dp-border-color-focus:#aaaeb7;--dp-disabled-color:#737373;--dp-disabled-color-text:#d0d0d0;--dp-scroll-bar-background:#212121;--dp-scroll-bar-color:#484848;--dp-success-color:#00701a;--dp-success-color-disabled:#428f59;--dp-icon-color:#959595;--dp-danger-color:#e53935;--dp-marker-color:#e53935;--dp-tooltip-color:#3e3e3e;--dp-highlight-color:#005cb233;--dp-range-between-dates-background-color:var(--dp-hover-color,#484848);--dp-range-between-dates-text-color:var(--dp-hover-text-color,#fff);--dp-range-between-border-color:var(--dp-hover-color,#fff);--dp-loader:5px solid #005cb2}.dp--theme-light{--dp-background-color:#fff;--dp-text-color:#212121;--dp-hover-color:#f3f3f3;--dp-hover-text-color:#212121;--dp-hover-icon-color:#959595;--dp-primary-color:#1976d2;--dp-primary-disabled-color:#6bacea;--dp-primary-text-color:#fff;--dp-secondary-color:#c0c4cc;--dp-border-color:#ddd;--dp-menu-border-color:#ddd;--dp-border-color-hover:#aaaeb7;--dp-border-color-focus:#aaaeb7;--dp-disabled-color:#f6f6f6;--dp-scroll-bar-background:#f3f3f3;--dp-scroll-bar-color:#959595;--dp-success-color:#76d275;--dp-success-color-disabled:#a3d9b1;--dp-icon-color:#959595;--dp-danger-color:#ff6f60;--dp-marker-color:#ff6f60;--dp-tooltip-color:#fafafa;--dp-disabled-color-text:#8e8e8e;--dp-highlight-color:#1976d21a;--dp-range-between-dates-background-color:var(--dp-hover-color,#f3f3f3);--dp-range-between-dates-text-color:var(--dp-hover-text-color,#212121);--dp-range-between-border-color:var(--dp-hover-color,#f3f3f3);--dp-loader:5px solid #1976d2}.calendar-next-enter-active,.calendar-next-leave-active,.calendar-prev-enter-active,.calendar-prev-leave-active{transition:all var(--dp-transition-timing-general) ease-out}.calendar-next-enter-from{opacity:0;transform:translate(var(--dp-transition-length))}.calendar-next-leave-to,.calendar-prev-enter-from{opacity:0;transform:translate(calc(var(--dp-transition-length) * -1))}.calendar-prev-leave-to{opacity:0;transform:translate(var(--dp-transition-length))}.dp-menu-appear-bottom-enter-active,.dp-menu-appear-bottom-leave-active,.dp-menu-appear-top-enter-active,.dp-menu-appear-top-leave-active,.dp-slide-up-enter-active,.dp-slide-up-leave-active,.dp-slide-down-enter-active,.dp-slide-down-leave-active{transition:all var(--dp-animation-duration) var(--dp-transition-timing)}.dp-menu-appear-top-enter-from,.dp-menu-appear-top-leave-to,.dp-slide-down-leave-to,.dp-slide-up-enter-from{opacity:0;transform:translateY(var(--dp-transition-length))}.dp-menu-appear-bottom-enter-from,.dp-menu-appear-bottom-leave-to,.dp-slide-down-enter-from,.dp-slide-up-leave-to{opacity:0;transform:translateY(calc(var(--dp-transition-length) * -1))}.dp--flex-display-with-input{flex-direction:column;align-items:flex-start}.dp__menu,.dp__outer_menu_wrap{z-index:1100!important}body.has-dp-open .modal-overlay{background:rgba(var(--color-black-rgb),.7)!important}body.has-dp-open .modal-container{opacity:.45;pointer-events:none;transition:opacity .15s ease}.zeno-datepicker{--dp-font-family: inherit;--dp-border-radius: 7px;--dp-cell-border-radius: 6px;--dp-input-padding: 6px 30px 6px 10px;--dp-font-size: 13px;--dp-input-icon-padding: 28px;--dp-common-padding: 6px;--dp-background-color: var(--color-input-bg);--dp-text-color: var(--color-text-primary);--dp-border-color: var(--color-input-border);--dp-border-color-hover: var(--color-primary);--dp-icon-color: var(--color-text-muted);--dp-menu-border-color: var(--color-border);--dp-primary-color: var(--color-primary);--dp-primary-text-color: var(--color-white);--dp-primary-disabled-color: var(--color-primary-200);--dp-hover-color: var(--color-primary-bg);--dp-hover-text-color: var(--color-text-primary);--dp-disabled-color: var(--color-surface-overlay);--dp-disabled-color-text: var(--color-text-subtle);--dp-success-color: var(--color-legacy-green);--dp-danger-color: var(--color-red)}.zeno-datepicker .dp__input{font-family:inherit;font-size:13px;height:32px;line-height:1;box-sizing:border-box}.zeno-datepicker:not(input).date-input,.zeno-datepicker:not(input).filter-date,.zeno-datepicker:not(input).form-input,.zeno-datepicker:not(input).filter-input,.zeno-datepicker:not(input).history-modal-input{border:0!important;padding:0!important;background:transparent!important;box-shadow:none!important;height:auto!important;outline:none!important}input.zeno-datepicker--time{font-family:inherit;font-size:13px;height:32px;padding:6px 10px;border:1px solid var(--color-input-border);border-radius:7px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;outline:none;transition:border-color .15s,box-shadow .15s}input.zeno-datepicker--time:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}input.zeno-datepicker--time::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer}[data-theme=dark] input.zeno-datepicker--time::-webkit-calendar-picker-indicator{filter:invert(.8)}.zeno-datepicker .dp__input:focus,.zeno-datepicker .dp__input_focus{border-color:var(--color-primary)!important;box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)!important}[data-theme=dark] .zeno-datepicker,.zeno-datepicker.dp__theme_dark,.dp__theme_dark{--dp-background-color: var(--color-surface);--dp-text-color: var(--color-text-primary);--dp-border-color: var(--color-input-border);--dp-menu-border-color: var(--color-border);--dp-hover-color: rgba(var(--color-primary-rgb), .18);--dp-hover-text-color: var(--color-text-primary);--dp-icon-color: var(--color-text-muted);--dp-disabled-color: var(--color-surface-raised);--dp-disabled-color-text: var(--color-text-subtle)}.chart-line-widget[data-v-77bccdac]{display:flex;flex-direction:column;width:100%;height:100%;min-height:0;background:var(--color-surface);border-radius:8px;border:1px solid var(--color-border);overflow:hidden;box-sizing:border-box}.chart-header[data-v-77bccdac]{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border);flex-shrink:0;flex-wrap:wrap;gap:8px}.header-left[data-v-77bccdac]{display:flex;flex-direction:column;gap:2px}.chart-title[data-v-77bccdac]{font-weight:600;color:var(--color-text-primary)}.header-right[data-v-77bccdac]{display:flex;align-items:center;gap:8px}.time-range-buttons[data-v-77bccdac]{display:flex;gap:3px;background:var(--color-surface-overlay);padding:3px;border-radius:6px}.range-btn[data-v-77bccdac]{padding:4px 10px;font-weight:500;border:none;background:transparent;color:var(--color-text-muted);border-radius:4px;cursor:pointer;transition:all .15s}.range-btn[data-v-77bccdac]:hover{color:var(--color-text-primary);background:var(--color-surface-overlay)}.range-btn.active[data-v-77bccdac]{background:var(--color-legacy-blue);color:var(--color-white);box-shadow:0 1px 3px rgba(var(--color-legacy-blue-rgb),.3)}.date-controls[data-v-77bccdac]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.control-group[data-v-77bccdac]{display:flex;align-items:center;gap:6px}.control-group label[data-v-77bccdac]{font-weight:500;color:var(--color-text-muted)}.date-input[data-v-77bccdac]{padding:4px 8px;border:1px solid var(--color-border-medium);border-radius:4px;background:var(--color-surface);color:var(--color-text-secondary);min-width:140px}.date-input[data-v-77bccdac]:focus{outline:none;border-color:var(--color-legacy-blue);box-shadow:0 0 0 2px rgba(var(--color-legacy-blue-rgb),.1)}.refresh-btn[data-v-77bccdac]{display:flex;align-items:center;gap:4px;padding:5px 12px;background:var(--color-legacy-blue);color:var(--color-white);border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s}.refresh-btn[data-v-77bccdac]:hover{background:var(--color-legacy-blue-dark)}.history-controls[data-v-77bccdac]{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.source-controls[data-v-77bccdac]{display:flex;align-items:center;gap:8px}.source-select[data-v-77bccdac]{padding:5px 24px 5px 8px;border:1px solid var(--color-border-medium);border-radius:4px;background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;min-width:100px;max-width:150px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.source-select[data-v-77bccdac]:focus{outline:none;border-color:var(--color-legacy-blue);box-shadow:0 0 0 2px rgba(var(--color-legacy-blue-rgb),.1)}.source-select[data-v-77bccdac]:hover{border-color:var(--color-text-subtle)}.device-select[data-v-77bccdac]{background-color:rgba(var(--color-amber-300-rgb),.15);border-color:var(--color-amber-300)}.device-select[data-v-77bccdac]:focus{border-color:var(--color-yellow);box-shadow:0 0 0 2px rgba(var(--color-amber-rgb),.1)}.monitor-select[data-v-77bccdac]{background-color:rgba(var(--color-blue-300-rgb),.15);border-color:var(--color-blue-300)}.monitor-select[data-v-77bccdac]:focus{border-color:var(--color-blue-500);box-shadow:0 0 0 2px rgba(var(--color-blue-rgb),.1)}.reset-zoom-btn[data-v-77bccdac]{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:var(--color-surface-overlay);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;transition:all .2s}.reset-zoom-btn[data-v-77bccdac]:hover{background:var(--color-surface-sunken);color:var(--color-text-secondary);border-color:var(--color-border-medium)}.statistics-bar[data-v-77bccdac]{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--color-surface-overlay);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);font-size:12px}.stat-item[data-v-77bccdac]{display:flex;align-items:center;gap:4px}.stat-label[data-v-77bccdac]{color:var(--color-text-muted);font-weight:500}.stat-value[data-v-77bccdac]{font-weight:600;font-size:13px}.stat-current[data-v-77bccdac]{color:var(--color-legacy-blue);background:var(--color-sky-100);padding:2px 8px;border-radius:4px}.stat-divider[data-v-77bccdac]{color:var(--color-slate-300);font-weight:300}.chart-body[data-v-77bccdac]{flex:1;display:flex;flex-direction:column;padding:12px;min-height:0;overflow:hidden}.chart-container[data-v-77bccdac]{flex:1;position:relative;height:100%;min-height:120px;contain:layout style;transform:translateZ(0);will-change:contents;backface-visibility:hidden}.chart-canvas[data-v-77bccdac]{position:absolute!important;top:0;left:0;width:100%!important;height:100%!important;isolation:isolate}@media (max-width: 480px){.chart-header[data-v-77bccdac]{flex-direction:column;align-items:flex-start}.time-range-buttons[data-v-77bccdac]{width:100%;justify-content:space-between}.range-btn[data-v-77bccdac]{flex:1;text-align:center;padding:5px 4px}.date-controls[data-v-77bccdac]{flex-direction:column;align-items:flex-start;gap:6px;width:100%}.date-input[data-v-77bccdac]{width:100%}}.chart-table-widget[data-v-371c3041]{display:flex;flex-direction:column;width:100%;height:100%;background:var(--color-surface);border-radius:8px;border:1px solid var(--color-border);overflow:hidden}.chart-header[data-v-371c3041]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.chart-title[data-v-371c3041]{font-size:14px;font-weight:600;color:var(--color-text-primary)}.data-count[data-v-371c3041]{font-size:12px;color:var(--color-text-muted)}.chart-controls[data-v-371c3041]{display:flex;gap:8px;padding:10px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-sunken)}.control-item[data-v-371c3041]{display:flex;flex:1;min-width:0}.search-input[data-v-371c3041],.select-field[data-v-371c3041]{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:4px;font-size:12px;background:var(--color-surface);color:var(--color-text-secondary)}.search-input[data-v-371c3041]:focus,.select-field[data-v-371c3041]:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 2px rgba(var(--color-blue-rgb),.1)}.chart-body[data-v-371c3041]{flex:1;overflow:hidden;display:flex;flex-direction:column}.table-container[data-v-371c3041]{flex:1;overflow-y:auto;overflow-x:auto}.data-table[data-v-371c3041]{width:100%;border-collapse:collapse;font-size:12px}.table-header[data-v-371c3041]{background:var(--color-surface-raised);color:var(--color-text-secondary);font-weight:600;padding:0;text-align:left;border-bottom:1px solid var(--color-border);-webkit-user-select:none;-moz-user-select:none;user-select:none}.header-cell[data-v-371c3041]{display:flex;align-items:center;gap:4px;padding:8px 10px;cursor:pointer;transition:background .2s}.header-cell[data-v-371c3041]:hover{background:var(--color-surface-overlay)}.sort-icon[data-v-371c3041]{font-size:10px;color:var(--color-primary)}.col-index[data-v-371c3041]{width:40px;text-align:center;background:var(--color-surface-raised);border-right:1px solid var(--color-border)}.table-row[data-v-371c3041]{border-bottom:1px solid var(--color-border-light);transition:background .15s}.table-row[data-v-371c3041]:hover{background:var(--color-surface-raised)}.data-table.striped tbody tr[data-v-371c3041]:nth-child(odd){background:var(--color-surface-raised)}.data-table.striped tbody tr[data-v-371c3041]:nth-child(2n){background:var(--color-surface)}.data-table.striped tbody tr[data-v-371c3041]:hover{background:var(--color-surface-overlay)!important}.table-cell[data-v-371c3041]{padding:8px 10px;color:var(--color-text-secondary);font-size:11px}.col-index[data-v-371c3041]{width:40px;text-align:center;color:var(--color-text-subtle);background:var(--color-surface-overlay);border-right:1px solid var(--color-border-light)}.time-cell[data-v-371c3041]{color:var(--color-text-muted)}.value-cell[data-v-371c3041]{font-weight:500;color:var(--color-text-primary)}.empty-state[data-v-371c3041]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:200px;color:var(--color-text-subtle);font-size:12px}.chart-footer[data-v-371c3041]{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-top:1px solid var(--color-border-light);background:var(--color-surface-raised);font-size:12px}.pagination-info[data-v-371c3041]{color:var(--color-text-muted)}.pagination-controls[data-v-371c3041]{display:flex;align-items:center;gap:8px}.pagination-btn[data-v-371c3041]{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s}.pagination-btn[data-v-371c3041]:hover:not(:disabled){border-color:var(--color-blue-500);color:var(--color-blue-500);background:var(--color-blue-bg)}.pagination-btn[data-v-371c3041]:disabled{opacity:.5;cursor:not-allowed}.page-number[data-v-371c3041]{color:var(--color-text-muted);font-size:11px;min-width:50px;text-align:center}@media (max-width: 768px){.chart-controls[data-v-371c3041]{flex-direction:column}.control-item[data-v-371c3041]{width:100%}.data-table[data-v-371c3041]{font-size:10px}.table-cell[data-v-371c3041],.header-cell[data-v-371c3041]{padding:6px 8px}.col-index[data-v-371c3041]{width:32px}.chart-header[data-v-371c3041]{flex-direction:column;align-items:flex-start;gap:6px}}.value-control-widget[data-v-6eec0708]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px;height:100%;gap:8px}.control-label[data-v-6eec0708]{font-size:14px;font-weight:500;text-align:center;margin-bottom:4px}.control-container[data-v-6eec0708]{display:flex;align-items:center;justify-content:center}.control-btn[data-v-6eec0708]{display:flex;align-items:center;justify-content:center;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;flex-shrink:0;box-shadow:0 2px 4px rgba(var(--color-black-rgb),.1)}.control-btn[data-v-6eec0708]:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 8px rgba(var(--color-black-rgb),.15)}.control-btn[data-v-6eec0708]:active:not(:disabled){transform:scale(.95)}.control-btn[data-v-6eec0708]:disabled{opacity:.4;cursor:not-allowed}.minus-btn[data-v-6eec0708]:hover:not(:disabled){filter:brightness(.9)}.plus-btn[data-v-6eec0708]:hover:not(:disabled){filter:brightness(1.1)}.value-display[data-v-6eec0708]{display:flex;align-items:baseline;justify-content:center;gap:4px;padding:0 16px;text-align:center}.current-value[data-v-6eec0708]{font-weight:700;font-variant-numeric:tabular-nums}.value-unit[data-v-6eec0708]{font-size:.7em;opacity:.7;font-weight:500}.range-labels[data-v-6eec0708]{display:flex;justify-content:space-between;width:100%;max-width:200px;font-size:11px;opacity:.6;margin-top:4px}.min-label[data-v-6eec0708],.max-label[data-v-6eec0708]{font-weight:500}.slider-target,.slider-target *{-webkit-touch-callout:none;-webkit-tap-highlight-color:rgba(0,0,0,0);box-sizing:border-box;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.slider-target{position:relative}.slider-base,.slider-connects{height:100%;position:relative;width:100%;z-index:1}.slider-connects{overflow:hidden;z-index:0}.slider-connect,.slider-origin{height:100%;position:absolute;right:0;top:0;transform-origin:0 0;transform-style:flat;width:100%;will-change:transform;z-index:1}.slider-txt-dir-rtl.slider-horizontal .slider-origin{left:0;right:auto}.slider-vertical .slider-origin{top:-100%;width:0}.slider-horizontal .slider-origin{height:0}.slider-handle{backface-visibility:hidden;position:absolute}.slider-touch-area{height:100%;width:100%}.slider-state-tap .slider-connect,.slider-state-tap .slider-origin{transition:transform .3s}.slider-state-drag *{cursor:inherit!important}.slider-tooltip-drag .slider-tooltip,.slider-tooltip-focus .slider-tooltip{display:none!important}.slider-tooltip-drag .slider-active .slider-tooltip,.slider-tooltip-drag.slider-state-drag .slider-tooltip:not(.slider-tooltip-hidden),.slider-tooltip-focus.slider-focused .slider-tooltip:not(.slider-tooltip-hidden){display:block!important}.slider-horizontal{height:var(--slider-height,6px)}.slider-horizontal .slider-handle{height:var(--slider-handle-height,16px);right:calc(var(--slider-handle-width, 16px)/2*-1);top:calc((var(--slider-handle-height, 16px) - var(--slider-height, 6px))/2*-1 + -1px);width:var(--slider-handle-width,16px)}.slider-vertical{height:var(--slider-vertical-height,300px);width:var(--slider-height,6px)}.slider-vertical .slider-handle{bottom:calc(var(--slider-handle-width, 16px)/2*-1);height:var(--slider-handle-width,16px);right:calc((var(--slider-handle-height, 16px) - var(--slider-height, 6px))/2*-1 + -1px);width:var(--slider-handle-height,16px)}.slider-txt-dir-rtl.slider-horizontal .slider-handle{left:calc(var(--slider-handle-width, 16px)/2*-1);right:auto}.slider-base{background-color:var(--slider-bg,#d1d5db)}.slider-base,.slider-connects{border-radius:var(--slider-radius,9999px)}.slider-connect{background:var(--slider-connect-bg,#10b981);cursor:pointer}.slider-draggable{cursor:ew-resize}.slider-vertical .slider-draggable{cursor:ns-resize}.slider-handle{background:var(--slider-handle-bg,#fff);border:var(--slider-handle-border,0);border-radius:var(--slider-handle-radius,9999px);box-shadow:var(--slider-handle-shadow,.5px .5px 2px 1px rgba(0,0,0,.32));cursor:grab;height:var(--slider-handle-height,16px);width:var(--slider-handle-width,16px)}.slider-handle:focus{box-shadow:0 0 0 var(--slider-handle-ring-width,3px) var(--slider-handle-ring-color,rgba(16,185,129,.188)),var(--slider-handle-shadow,.5px .5px 2px 1px rgba(0,0,0,.32));outline:none}.slider-active{box-shadow:var(--slider-handle-shadow-active,.5px .5px 2px 1px rgba(0,0,0,.42));cursor:grabbing}[disabled] .slider-connect{background:var(--slider-connect-bg-disabled,#9ca3af)}[disabled] .slider-handle,[disabled].slider-handle,[disabled].slider-target{cursor:not-allowed}[disabled] .slider-tooltip{background:var(--slider-tooltip-bg-disabled,#9ca3af);border-color:var(--slider-tooltip-bg-disabled,#9ca3af)}.slider-tooltip{background:var(--slider-tooltip-bg,#10b981);border:1px solid var(--slider-tooltip-bg,#10b981);border-radius:var(--slider-tooltip-radius,5px);color:var(--slider-tooltip-color,#fff);display:block;font-size:var(--slider-tooltip-font-size,.875rem);font-weight:var(--slider-tooltip-font-weight,600);line-height:var(--slider-tooltip-line-height,1.25rem);min-width:var(--slider-tooltip-min-width,20px);padding:var(--slider-tooltip-py,2px) var(--slider-tooltip-px,6px);position:absolute;text-align:center;white-space:nowrap}.slider-horizontal .slider-tooltip-top{bottom:calc(var(--slider-handle-height, 16px) + var(--slider-tooltip-arrow-size, 5px) + var(--slider-tooltip-distance, 3px));left:50%;transform:translate(-50%)}.slider-horizontal .slider-tooltip-top:before{border:var(--slider-tooltip-arrow-size,5px) solid transparent;border-top-color:inherit;bottom:calc(var(--slider-tooltip-arrow-size, 5px)*-2);content:"";height:0;left:50%;position:absolute;transform:translate(-50%);width:0}.slider-horizontal .slider-tooltip-bottom{left:50%;top:calc(var(--slider-handle-height, 16px) + var(--slider-tooltip-arrow-size, 5px) + var(--slider-tooltip-distance, 3px));transform:translate(-50%)}.slider-horizontal .slider-tooltip-bottom:before{border:var(--slider-tooltip-arrow-size,5px) solid transparent;border-bottom-color:inherit;content:"";height:0;left:50%;position:absolute;top:calc(var(--slider-tooltip-arrow-size, 5px)*-2);transform:translate(-50%);width:0}.slider-vertical .slider-tooltip-left{right:calc(var(--slider-handle-height, 16px) + var(--slider-tooltip-arrow-size, 5px) + var(--slider-tooltip-distance, 3px));top:50%;transform:translateY(-50%)}.slider-vertical .slider-tooltip-left:before{border:var(--slider-tooltip-arrow-size,5px) solid transparent;border-left-color:inherit;content:"";height:0;position:absolute;right:calc(var(--slider-tooltip-arrow-size, 5px)*-2);top:50%;transform:translateY(-50%);width:0}.slider-vertical .slider-tooltip-right{left:calc(var(--slider-handle-height, 16px) + var(--slider-tooltip-arrow-size, 5px) + var(--slider-tooltip-distance, 3px));top:50%;transform:translateY(-50%)}.slider-vertical .slider-tooltip-right:before{border:var(--slider-tooltip-arrow-size,5px) solid transparent;border-right-color:inherit;content:"";height:0;left:calc(var(--slider-tooltip-arrow-size, 5px)*-2);position:absolute;top:50%;transform:translateY(-50%);width:0}.slider-horizontal .slider-origin>.slider-tooltip{left:auto;transform:translate(50%)}.slider-horizontal .slider-origin>.slider-tooltip-top{bottom:calc(var(--slider-tooltip-arrow-size, 5px) + (var(--slider-handle-height, 16px) - var(--slider-height, 6px))/2 + var(--slider-tooltip-distance, 3px) + 1px)}.slider-horizontal .slider-origin>.slider-tooltip-bottom{top:calc(var(--slider-tooltip-arrow-size, 5px) + (var(--slider-handle-height, 16px) - var(--slider-height, 6px))/2 + var(--slider-tooltip-distance, 3px) + var(--slider-height, 6px) - 1px)}.slider-vertical .slider-origin>.slider-tooltip{top:auto;transform:translateY(calc((var(--slider-tooltip-line-height, 1.25rem) - var(--slider-tooltip-py, 2px))*-1 + 1px))}.slider-vertical .slider-origin>.slider-tooltip-left{right:calc(var(--slider-tooltip-arrow-size, 5px) + var(--slider-height, 6px) + (var(--slider-handle-height, 16px) - var(--slider-height, 6px))/2 + var(--slider-tooltip-distance, 3px) - 1px)}.slider-vertical .slider-origin>.slider-tooltip-right{left:calc(var(--slider-tooltip-arrow-size, 5px) + var(--slider-height, 6px) + (var(--slider-handle-height, 16px) - var(--slider-height, 6px))/2 + var(--slider-tooltip-distance, 3px) - var(--slider-height, 6px) + 1px)}.slider-shell[data-v-bff4044c]{width:100%;height:100%;padding:9px 24px;box-sizing:border-box;container-type:size;display:flex;flex-direction:column;justify-content:center;gap:6px;overflow:visible}.slider-row[data-v-bff4044c]{width:100%;overflow:visible}.labels-row[data-v-bff4044c]{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;line-height:1;font-weight:500}.label-min[data-v-bff4044c]{text-align:left}.label-value[data-v-bff4044c]{text-align:center;font-weight:600}.label-max[data-v-bff4044c]{text-align:right}.label-unit[data-v-bff4044c]{font-size:.7em;opacity:.85}[data-v-bff4044c] .slider-base,[data-v-bff4044c] .slider-connects,[data-v-bff4044c] .slider-connect{border-radius:9999px!important}[data-v-bff4044c] .slider-target.slider-horizontal,[data-v-bff4044c] .slider-horizontal .slider-base,[data-v-bff4044c] .slider-horizontal .slider-connects{height:var(--7a401468)!important}[data-v-bff4044c] .slider-handle{background-color:var(--dfee5430)!important;border:2px solid var(--855bfeca)!important;box-shadow:0 2px 4px rgba(var(--color-black-rgb),.1)!important;transition:transform .2s ease!important}[data-v-bff4044c] .slider-horizontal .slider-handle{top:calc((var(--slider-handle-height) - var(--slider-height)) / 2 * -1)!important;right:calc(var(--slider-handle-width) / 2 * -1)!important}[data-v-bff4044c] .slider-handle:hover{transform:scale(1.1)!important}[data-v-bff4044c] .slider-tooltip{font-size:12px!important;padding:4px 8px!important;border-radius:4px!important}.pb-options[data-v-8df113fc]{background:transparent;font-size:13px;color:var(--color-text-primary)}.group-title[data-v-8df113fc]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.group-desc[data-v-8df113fc]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-8df113fc]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:4px}.section-head[data-v-8df113fc]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-8df113fc]:hover{background:var(--color-surface-overlay);border-radius:4px 4px 0 0}.options-section.section-collapsed[data-v-8df113fc]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-8df113fc]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-8df113fc]:hover{border-radius:4px}.section-head-icon[data-v-8df113fc]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-8df113fc]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-8df113fc]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-8df113fc]{display:flex;flex-direction:column;gap:12px}.field-row[data-v-8df113fc]{display:flex;gap:10px}.field-row .input-group[data-v-8df113fc]{flex:1;min-width:0}.input-group[data-v-8df113fc]{display:flex;flex-direction:column;gap:4px}.input-label[data-v-8df113fc]{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-field[data-v-8df113fc]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-field[data-v-8df113fc]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.color-row[data-v-8df113fc]{display:flex;flex-wrap:nowrap;gap:12px;overflow-x:auto;padding-bottom:4px}.color-item[data-v-8df113fc]{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.color-label[data-v-8df113fc]{font-size:12px;color:var(--color-text-secondary)}.color-picker[data-v-8df113fc]{width:32px;height:32px}.hint[data-v-8df113fc]{margin:0;font-size:12px;color:var(--color-text-muted)}.checkbox-group[data-v-8df113fc]{display:flex;flex-wrap:wrap;gap:8px 16px}.checkbox-item[data-v-8df113fc]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-primary);cursor:pointer}.checkbox-item input[type=checkbox][data-v-8df113fc]{width:16px;height:16px;accent-color:var(--color-primary)}.icon-picker-row[data-v-8df113fc]{display:flex;gap:10px;align-items:flex-start}.icon-preview[data-v-8df113fc]{flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface-overlay);color:var(--color-primary)}.icon-grid[data-v-8df113fc]{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;flex:1;min-width:0;max-height:240px;overflow-y:auto;padding:6px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-input-bg)}.icon-cell[data-v-8df113fc]{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--color-text-secondary);cursor:pointer;padding:0;transition:background .15s,border-color .15s,color .15s}.icon-cell[data-v-8df113fc]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.icon-cell.is-selected[data-v-8df113fc]{background:rgba(var(--color-primary-rgb),.12);border-color:var(--color-primary);color:var(--color-primary)}.btn-widget[data-v-f6d1cd05]{container-type:size;container-name:btn;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;padding:10px;gap:clamp(4px,2cqmin,12px);box-sizing:border-box}.btn-circle[data-v-f6d1cd05]{position:relative;width:clamp(60px,78cqmin,320px);height:clamp(60px,78cqmin,320px);border-radius:50%;border:3px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:transform .1s ease,box-shadow .2s ease,border-color .2s ease;display:flex;align-items:center;justify-content:center;-moz-user-select:none;user-select:none;-webkit-user-select:none;padding:0;font-size:clamp(28px,40cqmin,160px)}.btn-circle[data-v-f6d1cd05]:disabled{opacity:.5;cursor:not-allowed}.btn-circle[data-v-f6d1cd05]:focus,.btn-circle[data-v-f6d1cd05]:focus-visible{outline:none}.btn-icon[data-v-f6d1cd05]{width:1em!important;height:1em!important;background:transparent;border:none;transition:color .2s ease}.btn-circle[data-v-f6d1cd05] svg,.btn-circle[data-v-f6d1cd05] .ov-icon{background:transparent!important;border:none!important;outline:none!important}.btn-raw[data-v-f6d1cd05]{font-size:clamp(10px,5cqmin,14px);color:var(--color-text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.switch-options[data-v-f193b12e]{background:transparent;font-size:13px;color:var(--color-text-primary)}.group-title[data-v-f193b12e]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.group-desc[data-v-f193b12e]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-f193b12e]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:4px}.section-head[data-v-f193b12e]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-f193b12e]:hover{background:var(--color-surface-overlay);border-radius:4px 4px 0 0}.options-section.section-collapsed[data-v-f193b12e]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-f193b12e]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-f193b12e]:hover{border-radius:4px}.section-head-icon[data-v-f193b12e]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-f193b12e]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-f193b12e]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-f193b12e]{display:flex;flex-direction:column;gap:12px}.field-row[data-v-f193b12e]{display:flex;gap:10px}.field-row .input-group[data-v-f193b12e]{flex:1;min-width:0}.input-group[data-v-f193b12e]{display:flex;flex-direction:column;gap:4px}.input-label[data-v-f193b12e]{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-field[data-v-f193b12e]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-field[data-v-f193b12e]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.color-row[data-v-f193b12e]{display:flex;flex-wrap:nowrap;gap:12px;overflow-x:auto;padding-bottom:4px}.color-item[data-v-f193b12e]{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.color-label[data-v-f193b12e]{font-size:12px;color:var(--color-text-secondary)}.color-picker[data-v-f193b12e]{width:32px;height:32px}.checkbox-group[data-v-f193b12e]{display:flex;flex-wrap:wrap;gap:8px 16px}.checkbox-item[data-v-f193b12e]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-primary);cursor:pointer}.checkbox-item input[type=checkbox][data-v-f193b12e]{width:16px;height:16px;accent-color:var(--color-primary)}.hint[data-v-f193b12e]{margin:0;font-size:12px;color:var(--color-text-muted)}.switch-widget[data-v-130d6833]{container-type:size;container-name:sw;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;padding:10px;gap:clamp(4px,2cqmin,12px);box-sizing:border-box}.switch-track[data-v-130d6833]{position:relative;display:inline-block;width:clamp(60px,85cqmin,240px);height:clamp(32px,42cqmin,120px);background:var(--color-border-medium);border-radius:999px;cursor:pointer;transition:background .25s ease;flex-shrink:0}.switch-track.is-on[data-v-130d6833]{background:color-mix(in srgb,var(--color-primary) 30%,transparent)}.switch-track.is-disabled[data-v-130d6833]{opacity:.5;cursor:not-allowed}.switch-track input[data-v-130d6833]{position:absolute;opacity:0;pointer-events:none}.switch-thumb[data-v-130d6833]{position:absolute;top:8%;left:4%;width:44%;height:84%;border-radius:50%;background:var(--color-surface);box-shadow:0 2px 6px rgba(var(--color-black-rgb),.25);transition:transform .25s ease,background .2s ease}.switch-track.is-on .switch-thumb[data-v-130d6833]{transform:translate(109%)}.switch-raw[data-v-130d6833]{font-size:clamp(10px,5cqmin,14px);color:var(--color-text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.vertical-slider-widget[data-v-b4d1e138]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:4px;box-sizing:border-box;overflow:visible}.vbar-inner[data-v-b4d1e138]{display:flex;align-items:stretch;gap:10px;width:-moz-max-content;width:max-content;max-width:100%;height:100%;padding:var(--12f2bb7c);box-sizing:border-box;overflow:visible}.bar-area[data-v-b4d1e138]{position:relative;height:100%;flex:0 0 auto}.labels-stack[data-v-b4d1e138]{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;height:100%;line-height:1;white-space:nowrap;flex:0 0 auto}.label-value[data-v-b4d1e138]{margin:auto 0;font-weight:600}.label-unit[data-v-b4d1e138]{font-size:.75em;margin-left:1px}[data-v-b4d1e138] .slider-base,[data-v-b4d1e138] .slider-connects,[data-v-b4d1e138] .slider-connect{border-radius:9999px!important}[data-v-b4d1e138] .slider-target.slider-vertical,[data-v-b4d1e138] .slider-vertical .slider-base,[data-v-b4d1e138] .slider-vertical .slider-connects{width:var(--333ce25d)!important}[data-v-b4d1e138] .slider-handle{background-color:var(--2929045a)!important;border:2px solid var(--5b04ccd0)!important;box-shadow:0 2px 4px rgba(var(--color-black-rgb),.1)!important;transition:transform .2s ease!important}[data-v-b4d1e138] .slider-vertical .slider-handle{right:calc((var(--slider-handle-width) - var(--slider-height)) / 2 * -1)!important;bottom:calc(var(--slider-handle-height) / 2 * -1)!important;top:auto!important}[data-v-b4d1e138] .slider-handle:hover{transform:scale(1.1)!important}[data-v-b4d1e138] .slider-tooltip{font-size:12px!important;padding:4px 8px!important;border-radius:4px!important}.led-options[data-v-4a67e6f1]{background:transparent;font-size:13px;color:var(--color-text-primary)}.group-title[data-v-4a67e6f1]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.group-desc[data-v-4a67e6f1]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-4a67e6f1]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:4px}.section-head[data-v-4a67e6f1]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-4a67e6f1]:hover{background:var(--color-surface-overlay);border-radius:4px 4px 0 0}.options-section.section-collapsed[data-v-4a67e6f1]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-4a67e6f1]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-4a67e6f1]:hover{border-radius:4px}.section-head-icon[data-v-4a67e6f1]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-4a67e6f1]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-4a67e6f1]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-4a67e6f1]{display:flex;flex-direction:column;gap:12px}.field-row[data-v-4a67e6f1]{display:flex;gap:10px}.field-row .input-group[data-v-4a67e6f1]{flex:1;min-width:0}.input-group[data-v-4a67e6f1]{display:flex;flex-direction:column;gap:4px}.input-label[data-v-4a67e6f1]{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-field[data-v-4a67e6f1]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.input-field[data-v-4a67e6f1]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.color-row[data-v-4a67e6f1]{display:flex;flex-wrap:nowrap;gap:12px;overflow-x:auto;padding-bottom:4px}.color-item[data-v-4a67e6f1]{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.color-label[data-v-4a67e6f1]{font-size:12px;color:var(--color-text-secondary)}.color-picker[data-v-4a67e6f1]{width:32px;height:32px}.checkbox-group[data-v-4a67e6f1]{display:flex;flex-wrap:wrap;gap:8px 16px}.checkbox-item[data-v-4a67e6f1]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-primary);cursor:pointer}.checkbox-item input[type=checkbox][data-v-4a67e6f1]{width:16px;height:16px;accent-color:var(--color-primary)}.hint[data-v-4a67e6f1]{margin:0;font-size:12px;color:var(--color-text-muted)}.led-widget[data-v-c6de69ae]{container-type:size;container-name:led;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;padding:10px;gap:6px;box-sizing:border-box}.led-stage[data-v-c6de69ae]{display:flex;flex-direction:column;align-items:center;gap:clamp(4px,2cqmin,12px);flex:1;min-height:0;justify-content:center}.led-bulb[data-v-c6de69ae]{position:relative;width:clamp(24px,45cqmin,200px);height:clamp(24px,45cqmin,200px);border-radius:50%;transition:background .25s ease,box-shadow .25s ease}.led-bulb--on[data-v-c6de69ae]{animation:led-pulse-c6de69ae 2s ease-in-out infinite}.led-bulb-glow[data-v-c6de69ae]{position:absolute;inset:-16px;border-radius:50%;pointer-events:none;z-index:-1}.led-bulb-shine[data-v-c6de69ae]{position:absolute;top:14%;left:22%;width:30%;height:22%;border-radius:50%;background:rgba(var(--color-white-rgb),.55);filter:blur(2px);pointer-events:none}@keyframes led-pulse-c6de69ae{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.vc-options[data-v-bddc4087]{padding:12px;background:transparent;font-size:13px;color:var(--color-text-primary)}.group-title[data-v-bddc4087]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.group-desc[data-v-bddc4087]{margin:-4px 0 14px;font-size:13px;color:var(--color-text-muted)}.options-section[data-v-bddc4087]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:4px}.section-head[data-v-bddc4087]{display:flex;align-items:center;gap:8px;margin:-12px -12px 12px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-head[data-v-bddc4087]:hover{background:var(--color-surface-overlay);border-radius:4px 4px 0 0}.options-section.section-collapsed[data-v-bddc4087]{padding-bottom:0}.options-section.section-collapsed .section-head[data-v-bddc4087]{margin-bottom:0;border-bottom:none}.options-section.section-collapsed .section-head[data-v-bddc4087]:hover{border-radius:4px}.section-head-icon[data-v-bddc4087]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-bddc4087]{flex:1;font-size:13px;font-weight:600;color:var(--color-text-primary)}.section-head-chevron[data-v-bddc4087]{color:var(--color-text-muted);flex-shrink:0}.section-body[data-v-bddc4087]{display:flex;flex-direction:column;gap:10px}.field-row[data-v-bddc4087]{display:flex;gap:10px}.field-row .input-group[data-v-bddc4087]{flex:1;min-width:0}.input-group[data-v-bddc4087]{display:flex;flex-direction:column;gap:4px}.input-label[data-v-bddc4087]{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-field[data-v-bddc4087]{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:3px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box}.input-field[data-v-bddc4087]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.color-picker-row[data-v-bddc4087]{display:flex;gap:8px;align-items:center}.color-picker-native[data-v-bddc4087]{width:40px;height:32px;flex-shrink:0}.color-picker-hex[data-v-bddc4087]{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.color-preset-row[data-v-bddc4087]{display:flex;gap:8px;flex-wrap:wrap}.color-preset[data-v-bddc4087]{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:all .15s ease}.color-preset[data-v-bddc4087]:hover{transform:scale(1.1)}.color-preset.is-active[data-v-bddc4087]{border-color:var(--color-text-primary);box-shadow:0 0 0 2px var(--color-surface-raised)}.value-card[data-v-0bdb84ad]{container-type:inline-size;display:flex;flex-direction:column;justify-content:space-between;gap:clamp(4px,1.5cqi,10px);width:100%;height:100%;padding:clamp(8px,3cqi,16px) clamp(10px,4cqi,20px);background:var(--color-surface);border-radius:10px;border-left:4px solid var(--accent, var(--color-primary));box-sizing:border-box;overflow:hidden;transition:background-color .2s ease,border-color .2s ease}.value-card--orange[data-v-0bdb84ad]{--accent: var(--color-primary)}.value-card--blue[data-v-0bdb84ad]{--accent: var(--color-blue-500)}.value-card--green[data-v-0bdb84ad]{--accent: var(--color-primary)}.value-card--purple[data-v-0bdb84ad]{--accent: var(--color-purple)}.value-card--yellow[data-v-0bdb84ad]{--accent: var(--color-amber-400)}.value-card-title[data-v-0bdb84ad]{font-size:clamp(11px,3.5cqi,18px);font-weight:500;color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden;margin:0;transition:color .2s ease,font-size .2s ease}.value-card-body[data-v-0bdb84ad]{display:flex;align-items:baseline;gap:clamp(4px,1.5cqi,10px);flex:1;min-height:0}.value-card-number[data-v-0bdb84ad]{font-size:36px;font-weight:700;color:var(--accent);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;line-height:1;letter-spacing:-.5px;transition:color .2s ease,font-size .2s ease}.value-card-unit[data-v-0bdb84ad]{font-size:clamp(12px,4cqi,20px);font-weight:500;color:var(--color-text-muted)}.value-card-status[data-v-0bdb84ad]{display:flex;align-items:center;gap:5px;font-size:clamp(9px,2.5cqi,13px);color:var(--color-text-muted)}.status-dot[data-v-0bdb84ad]{width:clamp(5px,1.5cqi,9px);height:clamp(5px,1.5cqi,9px);border-radius:50%}.status-dot--live[data-v-0bdb84ad]{background:var(--color-primary);box-shadow:0 0 rgba(var(--color-primary-rgb),.5);animation:live-pulse-0bdb84ad 2s infinite}.status-dot--idle[data-v-0bdb84ad]{background:var(--color-text-subtle)}@keyframes live-pulse-0bdb84ad{0%,to{box-shadow:0 0 rgba(var(--color-primary-rgb),.5)}50%{box-shadow:0 0 0 4px rgba(var(--color-primary-rgb),0)}}.value-card.is-pulsing[data-v-0bdb84ad]{animation:dwc-threshold-pulse-0bdb84ad .6s ease-out}@keyframes dwc-threshold-pulse-0bdb84ad{0%{box-shadow:0 0 0 0 var(--accent)}50%{box-shadow:0 0 0 6px rgba(var(--color-primary-rgb),0)}to{box-shadow:0 0 rgba(var(--color-primary-rgb),0)}}.gauge-svg[data-v-eeab2f2d],.gauge-svg[data-v-0fd53e24],.gauge-svg[data-v-09f1cdf1]{width:100%;height:100%;overflow:visible}.gauge-shell[data-v-dc1af34f]{width:100%;height:100%;padding:5px 20px;box-sizing:border-box;container-type:size;display:flex;flex-direction:column;justify-content:center;gap:6px;overflow:visible}.bar-track[data-v-dc1af34f]{width:100%;border-radius:9999px;position:relative;overflow:hidden}.bar-fill[data-v-dc1af34f]{height:100%;border-radius:9999px;transition:width .3s ease}.labels-row[data-v-dc1af34f]{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;line-height:1;font-weight:500}.label-min[data-v-dc1af34f]{text-align:left}.label-value[data-v-dc1af34f]{text-align:center;font-weight:600}.label-max[data-v-dc1af34f]{text-align:right}.label-unit[data-v-dc1af34f]{font-size:.7em;opacity:.85}.vbar-widget[data-v-0ca1f316]{width:100%;height:100%;display:flex;align-items:center;justify-content:flex-start;padding:4px;box-sizing:border-box;overflow:visible}.vbar-shell[data-v-0ca1f316]{position:relative;aspect-ratio:50 / 100;max-width:100%;max-height:100%;height:100%;overflow:visible}.bar-track[data-v-0ca1f316]{position:absolute;border-radius:9999px;overflow:hidden}.bar-fill[data-v-0ca1f316]{position:absolute;left:0;right:0;bottom:0;width:100%;border-radius:9999px;transition:height .3s ease}.label[data-v-0ca1f316]{position:absolute;line-height:1;white-space:nowrap;transform:translateY(-80%);pointer-events:none}.label-value[data-v-0ca1f316]{transform:translateY(-50%)}.label-unit[data-v-0ca1f316]{font-size:.75em;margin-left:1px}.gauge-widget[data-v-3eec2679]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:4px;box-sizing:border-box}.gauge-container[data-v-3eec2679]{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.gauge-svg-wrapper[data-v-3eec2679]{width:100%;height:100%}.gauge-value[data-v-3eec2679]{position:absolute;bottom:8px;left:50%;transform:translate(-50%);text-align:center;display:flex;align-items:baseline;gap:2px;z-index:10}.gauge-number[data-v-3eec2679]{font-weight:700}.gauge-unit[data-v-3eec2679]{font-weight:400}.gauge-center-value[data-v-3eec2679]{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:none}.gauge-center-value .gauge-number[data-v-3eec2679]{line-height:1}.gauge-center-inline[data-v-3eec2679]{display:flex;align-items:baseline;gap:6px}.gauge-center-inline .gauge-unit[data-v-3eec2679]{opacity:.9}.gauge-container[data-v-20f8ba23]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;min-width:20px;min-height:40px}.gauge-bar-container[data-v-20f8ba23]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:max(2px,1%);box-sizing:border-box}.gauge-bar-bg[data-v-20f8ba23]{width:max(0px,100%);height:100%;position:relative;border-radius:max(2px,1%);background-color:var(--color-surface-overlay);border:1px solid var(--color-border);display:flex;align-items:flex-end;overflow:hidden;box-sizing:border-box}.gauge-bar-fill[data-v-20f8ba23]{width:100%;background-color:var(--color-primary);border-radius:0 0 max(1px,.5%) max(1px,.5%);min-height:2px;position:relative}.simple-map-widget[data-v-e6ac11d2]{width:100%;height:100%;background:var(--color-surface);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;position:relative}.map-header[data-v-e6ac11d2]{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--color-border);background:var(--color-surface-raised);flex-shrink:0}.map-title[data-v-e6ac11d2]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0}.map-controls[data-v-e6ac11d2]{display:flex;gap:4px}.control-btn[data-v-e6ac11d2]{width:26px;height:26px;border:none;background:var(--color-surface-overlay);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--color-text-secondary)}.control-btn[data-v-e6ac11d2]:hover{background:var(--color-border);color:var(--color-text-primary)}.control-btn.active[data-v-e6ac11d2]{background:var(--color-primary);color:var(--color-white)}.map-container[data-v-e6ac11d2]{flex:1;position:relative;min-height:0;width:100%;overflow:hidden}.loading-container[data-v-e6ac11d2],.map-error[data-v-e6ac11d2]{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:var(--color-surface);color:var(--color-text-subtle);font-size:13px;z-index:1000}.error-icon[data-v-e6ac11d2]{color:var(--color-red-500)}.retry-btn[data-v-e6ac11d2]{padding:8px 16px;background:var(--gradient-primary);color:var(--color-white);border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s,box-shadow .2s}.retry-btn[data-v-e6ac11d2]:hover{background:var(--gradient-primary-hover);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.add-marker-hint[data-v-e6ac11d2]{position:absolute;top:10px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--gradient-primary);color:var(--color-white);border-radius:20px;font-size:12px;font-weight:500;z-index:1000;box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35)}.cancel-btn[data-v-e6ac11d2]{padding:4px 8px;background:rgba(var(--color-white-rgb),.2);color:var(--color-white);border:none;border-radius:4px;font-size:11px;cursor:pointer}.cancel-btn[data-v-e6ac11d2]:hover{background:rgba(var(--color-white-rgb),.3)}.marker-modal-overlay[data-v-e6ac11d2]{position:absolute;inset:0;background:rgba(var(--color-black-rgb),.7);display:flex;align-items:center;justify-content:center;z-index:2000}.marker-modal[data-v-e6ac11d2]{background:var(--color-surface);border-radius:12px;width:90%;max-width:360px;box-shadow:0 20px 40px rgba(var(--color-black-rgb),.5);overflow:hidden}.modal-header[data-v-e6ac11d2]{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border)}.modal-header h4[data-v-e6ac11d2]{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.close-btn[data-v-e6ac11d2]{width:28px;height:28px;border:none;background:transparent;color:var(--color-text-subtle);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.close-btn[data-v-e6ac11d2]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-body[data-v-e6ac11d2]{padding:16px}.form-group[data-v-e6ac11d2]{margin-bottom:12px}.form-group label[data-v-e6ac11d2]{display:block;font-size:11px;font-weight:500;color:var(--color-text-subtle);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.form-row[data-v-e6ac11d2]{display:flex;gap:12px}.form-row .form-group[data-v-e6ac11d2]{flex:1}.form-input[data-v-e6ac11d2],.form-textarea[data-v-e6ac11d2]{width:100%;padding:8px 10px;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-primary);font-size:13px;outline:none;transition:border-color .2s}.form-input[data-v-e6ac11d2]:focus,.form-textarea[data-v-e6ac11d2]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-textarea[data-v-e6ac11d2]{min-height:60px;resize:vertical}.form-color[data-v-e6ac11d2]{width:40px;height:32px}.form-range[data-v-e6ac11d2]{flex:1;height:4px;background:var(--color-surface-overlay);border-radius:2px;outline:none;cursor:pointer}.range-value[data-v-e6ac11d2]{font-size:11px;color:var(--color-text-subtle);margin-left:8px}.modal-footer[data-v-e6ac11d2]{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;background:var(--color-surface-raised);border-top:1px solid var(--color-border)}.btn-cancel[data-v-e6ac11d2],.btn-confirm[data-v-e6ac11d2]{padding:8px 14px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.btn-cancel[data-v-e6ac11d2]{background:var(--color-surface-overlay);color:var(--color-text-secondary)}.btn-cancel[data-v-e6ac11d2]:hover{background:var(--color-border);color:var(--color-text-primary)}.btn-confirm[data-v-e6ac11d2]{background:var(--gradient-primary);color:var(--color-white);box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.25)}.btn-confirm[data-v-e6ac11d2]:hover{background:var(--gradient-primary-hover);box-shadow:0 3px 10px rgba(var(--color-primary-rgb),.35)}.map-legend[data-v-e6ac11d2]{padding:8px 12px;background:var(--color-surface-raised);border-top:1px solid var(--color-border);flex-shrink:0;max-height:120px;overflow-y:auto}.legend-header[data-v-e6ac11d2]{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:10px;font-weight:600;color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.5px}.legend-icon[data-v-e6ac11d2]{color:var(--color-text-muted)}.legend-items[data-v-e6ac11d2]{display:flex;flex-direction:column;gap:4px}.legend-item[data-v-e6ac11d2]{display:flex;align-items:center;gap:8px;font-size:11px;padding:4px 6px;border-radius:4px;transition:background .2s}.legend-item[data-v-e6ac11d2]:hover{background:var(--color-surface-overlay)}.legend-marker[data-v-e6ac11d2]{width:8px;height:8px;border-radius:50%;border:1.5px solid rgba(var(--color-white-rgb),.3);flex-shrink:0}.legend-label[data-v-e6ac11d2]{color:var(--color-text-primary);font-weight:500;cursor:pointer;flex:1}.legend-label[data-v-e6ac11d2]:hover{color:var(--color-primary)}.legend-remove[data-v-e6ac11d2]{width:20px;height:20px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s}.legend-item:hover .legend-remove[data-v-e6ac11d2]{opacity:1}.legend-remove[data-v-e6ac11d2]:hover{background:var(--color-red-500);color:var(--color-white)}.map-stats[data-v-e6ac11d2]{display:flex;justify-content:space-around;padding:6px 12px;background:var(--color-surface-raised);border-top:1px solid var(--color-border);flex-shrink:0}.stat-item[data-v-e6ac11d2]{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-label[data-v-e6ac11d2]{font-size:9px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-value[data-v-e6ac11d2]{font-size:11px;font-weight:600;color:var(--color-text-primary)}[data-v-e6ac11d2] .leaflet-container{background:var(--color-slate-800);font-family:inherit;width:100%!important;height:100%!important}[data-v-e6ac11d2] .leaflet-popup-content-wrapper{background:var(--color-surface-raised);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-dropdown);padding:2px}[data-v-e6ac11d2] .marker-popup{min-width:180px;color:var(--color-text-primary)}[data-v-e6ac11d2] .marker-popup strong{color:var(--color-primary);font-size:14px;font-weight:600;display:block;margin-bottom:8px}[data-v-e6ac11d2] .marker-data{margin:8px 0;padding:8px 10px;background:var(--color-surface-overlay);border-left:3px solid var(--color-primary);border-radius:6px}[data-v-e6ac11d2] .marker-data .data-label{color:var(--color-text-muted);font-size:12px;font-weight:500}[data-v-e6ac11d2] .marker-data .data-value{color:var(--color-text-primary);font-size:16px;font-weight:600;margin-left:4px}[data-v-e6ac11d2] .marker-data-waiting{margin:8px 0;padding:6px 10px;background:var(--color-surface-overlay);border-left:3px solid var(--color-border);border-radius:6px;color:var(--color-text-muted);font-style:italic}[data-v-e6ac11d2] .marker-description{margin:8px 0;font-size:12px;color:var(--color-text-secondary);line-height:1.4}[data-v-e6ac11d2] .marker-coords{display:block;margin-top:8px;padding-top:8px;border-top:1px solid var(--color-border-light);color:var(--color-text-muted);font-size:11px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}[data-v-e6ac11d2] .leaflet-popup-content{margin:12px 14px;font-size:12px;line-height:1.4;color:var(--color-text-primary)}[data-v-e6ac11d2] .leaflet-popup-tip{background:var(--color-surface-raised);border:1px solid var(--color-border)}[data-v-e6ac11d2] .leaflet-popup-close-button{color:var(--color-text-muted)!important;font-size:18px!important;padding:6px 8px!important;transition:color .15s}[data-v-e6ac11d2] .leaflet-popup-close-button:hover{color:var(--color-text-primary)!important;background:transparent!important}[data-v-e6ac11d2] .leaflet-control-attribution{display:none!important}[data-v-e6ac11d2] .custom-marker-icon{background:transparent!important;border:none!important;display:flex!important;align-items:center!important;justify-content:center!important}[data-v-e6ac11d2] .map-marker-radar{position:absolute;left:50%;top:50%;width:var(--marker-halo);height:var(--marker-halo);transform:translate(-50%,-50%);pointer-events:auto;display:flex;align-items:center;justify-content:center}[data-v-e6ac11d2] .map-marker-halo{position:absolute;left:50%;top:50%;width:var(--marker-dot);height:var(--marker-dot);transform:translate(-50%,-50%);background:var(--marker-color);border-radius:50%;opacity:.45;animation:marker-radar-e6ac11d2 1.8s cubic-bezier(.4,0,.2,1) infinite}[data-v-e6ac11d2] .map-marker-dot{position:relative;width:var(--marker-dot);height:var(--marker-dot);background:var(--marker-color);border-radius:50%;box-shadow:0 0 0 2px rgba(var(--color-white-rgb),.85),0 2px 8px rgba(var(--color-black-rgb),.35);transition:transform .15s ease;z-index:1}[data-v-e6ac11d2] .map-marker-radar:hover .map-marker-dot{transform:scale(1.15)}@keyframes marker-radar-e6ac11d2{0%{transform:translate(-50%,-50%) scale(1);opacity:.55}80%,to{transform:translate(-50%,-50%) scale(2.4);opacity:0}}[data-v-e6ac11d2] .flag-icon{background:transparent!important;border:none!important;display:flex!important;align-items:center!important;justify-content:center!important}[data-v-e6ac11d2] .vietnam-flag-marker{font-size:20px;text-shadow:0 2px 4px rgba(var(--color-black-rgb),.5)}[data-v-e6ac11d2] .current-location-icon{background:transparent!important;border:none!important}[data-v-e6ac11d2] .current-location-marker{position:relative;width:24px;height:24px}[data-v-e6ac11d2] .pulse-ring{position:absolute;width:24px;height:24px;border:2px solid var(--color-primary);border-radius:50%;animation:pulse-ring-e6ac11d2 2s infinite}[data-v-e6ac11d2] .marker-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:var(--color-primary);border:2px solid var(--color-white);border-radius:50%;box-shadow:0 2px 4px rgba(var(--color-black-rgb),.3)}@keyframes pulse-ring-e6ac11d2{0%{transform:scale(.5);opacity:1}to{transform:scale(1.5);opacity:0}}.map-container.selecting-mode[data-v-e6ac11d2]{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='36' viewBox='0 0 24 36'%3E%3Cpath d='M12 0C5.4 0 0 5.4 0 12c0 7.5 12 24 12 24s12-16.5 12-24c0-6.6-5.4-12-12-12z' fill='%23ef4444'/%3E%3Ccircle cx='12' cy='12' r='5' fill='white'/%3E%3C/svg%3E") 12 36,crosshair!important}.map-container.selecting-mode[data-v-e6ac11d2] .leaflet-container{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='36' viewBox='0 0 24 36'%3E%3Cpath d='M12 0C5.4 0 0 5.4 0 12c0 7.5 12 24 12 24s12-16.5 12-24c0-6.6-5.4-12-12-12z' fill='%23ef4444'/%3E%3Ccircle cx='12' cy='12' r='5' fill='white'/%3E%3C/svg%3E") 12 36,crosshair!important}.map-container.selecting-center[data-v-e6ac11d2] .leaflet-container{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='10' fill='none' stroke='%233b82f6' stroke-width='2'/%3E%3Ccircle cx='12' cy='12' r='3' fill='%233b82f6'/%3E%3Cline x1='12' y1='0' x2='12' y2='6' stroke='%233b82f6' stroke-width='2'/%3E%3Cline x1='12' y1='18' x2='12' y2='24' stroke='%233b82f6' stroke-width='2'/%3E%3Cline x1='0' y1='12' x2='6' y2='12' stroke='%233b82f6' stroke-width='2'/%3E%3Cline x1='18' y1='12' x2='24' y2='12' stroke='%233b82f6' stroke-width='2'/%3E%3C/svg%3E") 12 12,crosshair!important}.selecting-indicator[data-v-e6ac11d2]{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:1000;pointer-events:none;display:flex;align-items:center;gap:8px;padding:7px 14px;background:var(--gradient-warning);color:var(--color-white);border-radius:20px;font-size:12px;font-weight:500;box-shadow:0 4px 12px rgba(var(--color-amber-rgb),.4);animation:pulse-indicator-e6ac11d2 1.5s ease-in-out infinite}@keyframes pulse-indicator-e6ac11d2{0%,to{opacity:1}50%{opacity:.7}}.tracking-map-widget[data-v-e79af244]{display:flex;flex-direction:column;width:100%;height:100%;background:var(--color-surface);border-radius:8px;overflow:hidden}.map-header[data-v-e79af244]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border);background:var(--color-surface-raised)}.map-title[data-v-e79af244]{font-size:14px;font-weight:600;color:var(--color-text-secondary);margin:0}.map-controls[data-v-e79af244]{display:flex;gap:8px}.tracking-btn[data-v-e79af244],.clear-btn[data-v-e79af244]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--color-border-medium);background:var(--color-surface);border-radius:6px;cursor:pointer;transition:all .2s ease}.tracking-btn[data-v-e79af244]:hover,.clear-btn[data-v-e79af244]:hover{background:var(--color-surface-overlay);border-color:var(--color-text-subtle)}.tracking-btn.active[data-v-e79af244]{background:var(--color-blue-500);border-color:var(--color-blue-500);color:var(--color-white)}.map-container[data-v-e79af244]{flex:1;position:relative;min-height:200px}.map-info[data-v-e79af244]{display:flex;justify-content:space-between;padding:12px 16px;background:var(--color-surface-raised);border-top:1px solid var(--color-border)}.info-item[data-v-e79af244]{display:flex;flex-direction:column;align-items:center}.info-label[data-v-e79af244]{font-size:11px;color:var(--color-text-muted);margin-bottom:2px}.info-value[data-v-e79af244]{font-size:13px;font-weight:600;color:var(--color-text-secondary)}.custom-marker{background:transparent!important;border:none!important}.route-marker{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--color-white)}.route-marker.start{background:var(--color-primary)}.route-marker.end{background:var(--color-red-500)}.current-marker{width:16px;height:16px;background:var(--color-blue-500);border:3px solid var(--color-white);border-radius:50%;box-shadow:0 2px 8px rgba(var(--color-black-rgb),.3);animation:pulse-e79af244 2s infinite}@keyframes pulse-e79af244{0%{box-shadow:0 0 rgba(var(--color-blue-rgb),.7)}70%{box-shadow:0 0 0 10px rgba(var(--color-blue-rgb),0)}to{box-shadow:0 0 rgba(var(--color-blue-rgb),0)}}.stats-bar-chart[data-v-bd36bb8e]{display:flex;flex-direction:column;gap:12px;width:100%;height:100%;box-sizing:border-box;color:var(--color-text-primary);padding-top:10px}.chart-header[data-v-bd36bb8e]{padding-left:8px;padding-right:8px}.custom-range-row[data-v-bd36bb8e]{display:flex;gap:10px;align-items:center;padding:0 8px;flex-wrap:wrap;flex-shrink:0}.cr-label[data-v-bd36bb8e]{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-secondary);font-weight:500}.cr-picker[data-v-bd36bb8e]{min-width:200px;font-size:12px}.cr-picker[data-v-bd36bb8e] .dp__input{height:36px;font-size:12px;padding:0 10px}.cr-apply[data-v-bd36bb8e]{height:36px;padding:0 18px;border:none;border-radius:6px;background:var(--color-blue);color:var(--color-white);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.cr-apply[data-v-bd36bb8e]:hover:not(:disabled){background:var(--color-blue-hover)}.cr-apply[data-v-bd36bb8e]:disabled{opacity:.5;cursor:not-allowed}.chart-header[data-v-bd36bb8e]{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;flex-shrink:0}.header-left[data-v-bd36bb8e]{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.header-icon[data-v-bd36bb8e]{color:var(--color-blue);flex-shrink:0}.widget-title[data-v-bd36bb8e]{font-size:14px;font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-right[data-v-bd36bb8e]{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.mode-toggle[data-v-bd36bb8e]{display:inline-flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden;background:var(--color-surface-raised);padding:2px}.mode-btn[data-v-bd36bb8e]{padding:6px 12px;border:none;background:transparent;color:var(--color-text-secondary);font-size:13px;font-weight:500;border-radius:4px;cursor:pointer;transition:background .2s ease,color .2s ease}.mode-btn[data-v-bd36bb8e]:hover:not(.active){background:var(--color-surface-overlay);color:var(--color-text-primary)}.mode-btn.active[data-v-bd36bb8e]{background:var(--color-blue);color:var(--color-white);box-shadow:0 1px 2px rgba(var(--color-blue-rgb),.25)}.stat-field-select[data-v-bd36bb8e]{padding:5px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface-raised);color:var(--color-text-primary);font-size:12.5px;font-weight:500;cursor:pointer;outline:none;transition:border-color .15s,background .15s}.stat-field-select[data-v-bd36bb8e]:hover{border-color:var(--color-primary)}.stat-field-select[data-v-bd36bb8e]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12)}.btn-refresh[data-v-bd36bb8e]{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:background .2s ease,color .2s ease}.btn-refresh[data-v-bd36bb8e]:hover:not(:disabled){background:var(--color-primary-bg);color:var(--color-primary)}.btn-refresh[data-v-bd36bb8e]:disabled{opacity:.5;cursor:not-allowed}.last-fetched[data-v-bd36bb8e]{font-size:12px;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.chart-body[data-v-bd36bb8e]{flex:1;min-height:0;position:relative;display:flex;flex-direction:column}.chart-canvas-wrap[data-v-bd36bb8e]{width:100%;height:100%;min-height:100px;position:relative;overflow:hidden}.state-debug[data-v-bd36bb8e]{font-size:11px;color:var(--color-text-muted);font-family:Fira Code,Courier New,monospace;font-variant-numeric:tabular-nums;margin-top:6px}.state-empty[data-v-bd36bb8e],.state-error[data-v-bd36bb8e],.state-no-config[data-v-bd36bb8e],.state-loading[data-v-bd36bb8e]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;color:var(--color-text-muted);padding:16px}.state-heading[data-v-bd36bb8e]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.state-body[data-v-bd36bb8e]{font-size:13px;color:var(--color-text-muted);line-height:1.4}.state-error[data-v-bd36bb8e]{color:var(--color-red)}.state-error .state-heading[data-v-bd36bb8e]{color:var(--color-text-primary)}.btn-retry[data-v-bd36bb8e]{margin-top:8px;padding:4px 12px;font-size:12px;border-radius:6px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;transition:background .15s ease,border-color .15s ease}.btn-retry[data-v-bd36bb8e]:hover{background:var(--color-surface-overlay);border-color:var(--color-primary)}.footer-summary[data-v-bd36bb8e]{display:flex;justify-content:space-around;align-items:center;padding:12px 16px;background:var(--color-surface-raised);border-top:1px solid var(--color-border-light);border-radius:0 0 8px 8px;gap:12px;flex-wrap:wrap;flex-shrink:0}.footer-cell[data-v-bd36bb8e]{display:flex;flex-direction:row;align-items:baseline;gap:8px;min-width:0}.footer-summary-label[data-v-bd36bb8e]{font-size:11px;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.4px}.footer-summary-value[data-v-bd36bb8e]{font-size:18px;font-weight:700;color:var(--color-text-primary);font-variant-numeric:tabular-nums;line-height:1}.footer-unit[data-v-bd36bb8e]{font-size:14px;font-weight:500;color:var(--color-text-secondary);margin-left:4px}.footer-cell-cost .cost-label[data-v-bd36bb8e]{color:var(--color-text-muted);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.4px}.footer-cell-cost .cost-value[data-v-bd36bb8e]{color:var(--color-amber-500)}.footer-cell-cost .cost-unit[data-v-bd36bb8e]{color:var(--color-amber-500);opacity:.85}.icon-spin[data-v-bd36bb8e]{animation:spin-bd36bb8e 1s linear infinite}@keyframes spin-bd36bb8e{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stats-options[data-v-9fabfac0]{display:flex;flex-direction:column;gap:16px}.options-section[data-v-9fabfac0]{border:1px solid var(--color-border-light);border-radius:8px;overflow:hidden;background:var(--color-surface)}.section-head[data-v-9fabfac0]{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--color-surface-raised);cursor:pointer;font-size:14px;font-weight:600;color:var(--color-text-primary);-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .15s}.section-head[data-v-9fabfac0]:hover{background:var(--color-surface-overlay)}.section-head-icon[data-v-9fabfac0]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-9fabfac0]{flex:1}.section-head-chevron[data-v-9fabfac0]{color:var(--color-text-muted);flex-shrink:0;transition:transform .2s ease}.section-body[data-v-9fabfac0]{padding:16px;display:flex;flex-direction:column;gap:12px;background:var(--color-surface)}.field-row[data-v-9fabfac0]{display:flex;flex-direction:column;gap:4px}.checkbox-row[data-v-9fabfac0]{flex-direction:row;align-items:center;gap:12px;flex-wrap:wrap}.input-label[data-v-9fabfac0]{font-size:12px;font-weight:500;color:var(--color-text-primary)}.input-field[data-v-9fabfac0]{width:100%;padding:7px 10px;border:1.5px solid var(--color-border);border-radius:7px;font-size:13px;outline:none;transition:all .2s;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box}.input-field[data-v-9fabfac0]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.hint[data-v-9fabfac0]{font-size:11px;color:var(--color-text-muted);margin:0}.checkbox-item[data-v-9fabfac0]{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-primary);cursor:pointer}.checkbox-item input[type=checkbox][data-v-9fabfac0]{width:16px;height:16px;accent-color:var(--color-primary)}.color-row[data-v-9fabfac0]{display:flex;align-items:center;gap:10px}.color-swatch[data-v-9fabfac0]{width:40px;height:32px;cursor:pointer}.color-hex[data-v-9fabfac0]{font-size:12px;font-family:Fira Code,Courier New,monospace;color:var(--color-text-muted)}.stats-value-card[data-v-bf76cf2d]{display:flex;flex-direction:column;gap:0;width:100%;height:100%;box-sizing:border-box;color:var(--color-text-primary)}.card-header[data-v-bf76cf2d]{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-shrink:0;padding:10px 14px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border-light)}.header-left[data-v-bf76cf2d]{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.header-icon[data-v-bf76cf2d]{color:var(--color-blue);flex-shrink:0}.widget-title[data-v-bf76cf2d]{font-size:14px;font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.period-badge[data-v-bf76cf2d]{display:inline-flex;align-items:center;padding:2px 10px;height:22px;border-radius:11px;font-size:12px;font-weight:500;background:var(--color-blue-bg);color:var(--color-blue);border:1px solid rgba(var(--color-blue-rgb),.3);flex-shrink:0;white-space:nowrap;cursor:help}.range-line[data-v-bf76cf2d]{display:inline-flex;align-items:center;gap:6px;padding:8px 14px 0;font-size:11.5px;color:var(--color-text-muted);font-variant-numeric:tabular-nums;align-self:flex-start}.card-body[data-v-bf76cf2d]{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:stretch;padding:6px 14px 10px;gap:8px;min-height:0;overflow:hidden}.state-idle[data-v-bf76cf2d]{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;width:100%;text-align:left}.primary-row[data-v-bf76cf2d]{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;width:100%;flex-wrap:wrap}.primary-block[data-v-bf76cf2d]{display:flex;flex-direction:column;align-items:flex-start;gap:4px;flex:1;min-width:0}.primary-value[data-v-bf76cf2d]{font-size:48px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;color:var(--color-text-primary);text-align:left}.primary-unit[data-v-bf76cf2d]{font-size:24px;font-weight:500;color:var(--color-text-secondary);margin-left:6px}.cost-block[data-v-bf76cf2d]{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.cost-title[data-v-bf76cf2d]{font-size:11px;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px;line-height:1;margin-bottom:4px}.cost-text[data-v-bf76cf2d]{display:inline-flex;align-items:baseline;gap:4px;font-variant-numeric:tabular-nums;flex-shrink:0}.cost-text-value[data-v-bf76cf2d]{font-size:22px;font-weight:700;color:var(--color-amber-500);line-height:1.2}.cost-text-unit[data-v-bf76cf2d]{font-size:14px;font-weight:500;color:var(--color-amber-500);opacity:.85}.cost-text-formula[data-v-bf76cf2d]{font-size:11px;color:var(--color-text-muted);font-variant-numeric:tabular-nums;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left;align-self:flex-start}.state-empty[data-v-bf76cf2d],.state-error[data-v-bf76cf2d],.state-no-config[data-v-bf76cf2d],.state-loading[data-v-bf76cf2d]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;color:var(--color-text-muted);padding:16px}.state-heading[data-v-bf76cf2d]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.state-body[data-v-bf76cf2d]{font-size:12px;color:var(--color-text-muted);line-height:1.4}.state-error[data-v-bf76cf2d]{color:var(--color-red)}.state-error .state-heading[data-v-bf76cf2d]{color:var(--color-text-primary)}.btn-retry[data-v-bf76cf2d]{margin-top:8px;padding:4px 12px;font-size:12px;border-radius:6px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;transition:background .15s,border-color .15s}.btn-retry[data-v-bf76cf2d]:hover{background:var(--color-surface-overlay);border-color:var(--color-primary)}.card-footer[data-v-bf76cf2d]{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface-raised);border-top:1px solid var(--color-border-light);flex-shrink:0}.footer-secondary[data-v-bf76cf2d]{font-size:12.5px;color:var(--color-text-muted);font-variant-numeric:tabular-nums;text-align:left;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.footer-actions[data-v-bf76cf2d]{display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.btn-refresh[data-v-bf76cf2d]{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:background .2s ease,color .2s ease}.btn-refresh[data-v-bf76cf2d]:hover:not(:disabled){background:var(--color-primary-bg);color:var(--color-primary)}.btn-refresh[data-v-bf76cf2d]:disabled{opacity:.5;cursor:not-allowed}.last-fetched[data-v-bf76cf2d]{font-size:12px;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.icon-spin[data-v-bf76cf2d]{animation:spin-bf76cf2d 1s linear infinite}@keyframes spin-bf76cf2d{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stats-options[data-v-448d1503]{display:flex;flex-direction:column;gap:16px}.options-section[data-v-448d1503]{border:1px solid var(--color-border-light);border-radius:8px;overflow:hidden;background:var(--color-surface)}.section-head[data-v-448d1503]{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--color-surface-raised);cursor:pointer;font-size:14px;font-weight:600;color:var(--color-text-primary);-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .15s}.section-head[data-v-448d1503]:hover{background:var(--color-surface-overlay)}.section-head-icon[data-v-448d1503]{color:var(--color-primary);flex-shrink:0}.section-head-title[data-v-448d1503]{flex:1}.section-head-chevron[data-v-448d1503]{color:var(--color-text-muted);flex-shrink:0;transition:transform .2s ease}.section-body[data-v-448d1503]{padding:16px;display:flex;flex-direction:column;gap:12px;background:var(--color-surface)}.field-row[data-v-448d1503]{display:flex;flex-direction:column;gap:4px}.checkbox-row[data-v-448d1503]{flex-direction:row;align-items:center;gap:12px;flex-wrap:wrap}.input-label[data-v-448d1503]{font-size:12px;font-weight:500;color:var(--color-text-primary)}.input-field[data-v-448d1503]{width:100%;padding:7px 10px;border:1.5px solid var(--color-border);border-radius:7px;font-size:13px;outline:none;transition:all .2s;background:var(--color-input-bg);color:var(--color-text-primary);box-sizing:border-box}.input-field[data-v-448d1503]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.hint[data-v-448d1503]{font-size:11px;color:var(--color-text-muted);margin:0}.checkbox-item[data-v-448d1503]{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-primary);cursor:pointer}.checkbox-item input[type=checkbox][data-v-448d1503]{width:16px;height:16px;accent-color:var(--color-primary)}.widget-frame[data-v-45306a04]{display:flex;flex-direction:column;height:100%;background:transparent;border-radius:8px;overflow:hidden}.widget-frame-title[data-v-45306a04]{padding:6px 10px;font-size:13px;font-weight:600;color:var(--color-text-secondary);background:var(--color-surface-raised);border-bottom:1px solid var(--color-border)}.widget-frame-title[data-v-45306a04]:first-child{border-radius:8px 8px 0 0}.widget-frame-title[data-v-45306a04]:last-child{border-radius:0 0 8px 8px;border-bottom:none;border-top:1px solid var(--color-border)}.widget-frame-title.align-left[data-v-45306a04]{text-align:left}.widget-frame-title.align-center[data-v-45306a04]{text-align:center}.widget-frame-title.align-right[data-v-45306a04]{text-align:right}.widget-frame-body[data-v-45306a04]{flex:1 1 auto;display:flex;align-items:center;justify-content:center;padding:8px}@keyframes scaleUp{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@keyframes glow{0%,to{box-shadow:0 0 5px rgba(var(--color-blue-rgb),.6)}50%{box-shadow:0 0 20px rgba(var(--color-blue-rgb),1),0 0 30px rgba(var(--color-blue-rgb),.8)}}@keyframes outlineGlow{0%,to{filter:drop-shadow(0 0 3px rgba(var(--color-blue-rgb),.8)) drop-shadow(0 0 6px rgba(var(--color-blue-rgb),.6))}50%{filter:drop-shadow(0 0 8px rgba(var(--color-blue-rgb),1)) drop-shadow(0 0 15px rgba(var(--color-blue-rgb),.8)) drop-shadow(0 0 20px rgba(var(--color-blue-rgb),.6))}}@keyframes outlineGlowRed{0%,to{filter:drop-shadow(0 0 3px rgba(var(--color-red-500-rgb),.8)) drop-shadow(0 0 6px rgba(var(--color-red-500-rgb),.6))}50%{filter:drop-shadow(0 0 8px rgba(var(--color-red-500-rgb),1)) drop-shadow(0 0 15px rgba(var(--color-red-500-rgb),.8)) drop-shadow(0 0 20px rgba(var(--color-red-500-rgb),.6))}}@keyframes outlineGlowGreen{0%,to{filter:drop-shadow(0 0 3px rgba(var(--color-success-rgb),.8)) drop-shadow(0 0 6px rgba(var(--color-success-rgb),.6))}50%{filter:drop-shadow(0 0 8px rgba(var(--color-success-rgb),1)) drop-shadow(0 0 15px rgba(var(--color-success-rgb),.8)) drop-shadow(0 0 20px rgba(var(--color-success-rgb),.6))}}@keyframes outlineGlowOrange{0%,to{filter:drop-shadow(0 0 3px rgba(var(--color-primary-rgb),.8)) drop-shadow(0 0 6px rgba(var(--color-primary-rgb),.6))}50%{filter:drop-shadow(0 0 8px rgba(var(--color-primary-rgb),1)) drop-shadow(0 0 15px rgba(var(--color-primary-rgb),.8)) drop-shadow(0 0 20px rgba(var(--color-primary-rgb),.6))}}.widget-action-outline-glow{animation:outlineGlow var(--animation-duration, 2s) var(--animation-easing, ease) var(--animation-delay, 0s) infinite}.widget-action-outline-glow-red{animation:outlineGlowRed var(--animation-duration, 2s) var(--animation-easing, ease) var(--animation-delay, 0s) infinite}.widget-action-outline-glow-green{animation:outlineGlowGreen var(--animation-duration, 2s) var(--animation-easing, ease) var(--animation-delay, 0s) infinite}.widget-action-outline-glow-orange{animation:outlineGlowOrange var(--animation-duration, 2s) var(--animation-easing, ease) var(--animation-delay, 0s) infinite}.interactive-widget{transition:filter .1s,transform .1s}.interactive-widget:hover{filter:brightness(1.1)}.interactive-widget:active,.widget-pressed{transform:scale(.97)!important}.scada-canvas-wrapper{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background-color:inherit}.scada-canvas-content{position:relative;transform-origin:center center}.preview-widget{position:absolute;box-sizing:border-box}.dialog-view-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(var(--color-black-rgb),.5);display:flex;align-items:center;justify-content:center;overflow:hidden}.dialog-view-container{position:relative;border-radius:8px;box-shadow:0 20px 40px rgba(var(--color-black-rgb),.3);overflow:hidden;flex-shrink:0;transform-origin:center center}.dialog-view-overlay.is-fullscreen{padding:0;background:transparent}.dialog-view-container.is-fullscreen-container{border-radius:0;box-shadow:none;overflow:visible;max-width:none;max-height:none;display:block}.scada-loading-container,.scada-error-container,.scada-empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:rgba(var(--color-white-rgb),.9)}.scada-loading-spinner{width:48px;height:48px;border:4px solid rgba(var(--color-white-rgb),.2);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.scada-loading-container p,.scada-error-container p,.scada-empty-container p{color:rgba(var(--color-white-rgb),.7);font-size:14px;margin:8px 0 0}.scada-error-container h3,.scada-empty-container h3{margin:16px 0 8px;font-size:18px;font-weight:600}.label-warning{background-color:var(--63d0ff44)!important;border-color:var(--2ec229b8)!important}.label-critical{background-color:var(--04066887)!important;border-color:var(--59c654bb)!important}.scada-dashboard-root{width:100vw;height:100vh;background:var(--color-body-bg);display:flex;flex-direction:column;-moz-user-select:none;user-select:none;-webkit-user-select:none}.scada-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:42px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:10}.dashboard-title{font-size:15px;font-weight:800;color:var(--color-primary);letter-spacing:.6px;text-transform:uppercase}.toolbar-center{display:flex;padding-left:40px;align-items:center;justify-content:center;height:auto}.toolbar-icon-group{display:flex;gap:2px;align-items:center}.toolbar-icon{width:14px;height:14px;color:var(--color-text-secondary);transition:color .2s}.toolbar-zoom-group{display:flex;flex-direction:column;align-items:center;position:relative;width:54px}.toolbar-zoom-indicator{color:var(--color-text-secondary);margin-top:2px;font-weight:600;background:var(--color-surface-overlay);border-radius:6px;padding:0 6px;min-width:32px;text-align:center;box-shadow:0 1px 4px rgba(var(--color-black-rgb),.1);margin-bottom:2px}.toolbar-center-info{flex:1;display:flex;gap:10px;padding:12px;justify-content:left;align-items:center}.view-size-info{color:var(--color-text-subtle);font-size:11px;font-weight:500;background:var(--color-surface-raised);padding:2px 8px;border-radius:4px;border:1px solid var(--color-border)}.control-hint{display:inline-flex;align-items:center;gap:5px;color:var(--color-amber-700);background:var(--color-amber-50);border:1px solid var(--color-amber-300);font-size:11px;font-weight:500;padding:2px 8px;border-radius:4px;cursor:help;white-space:nowrap}.toolbar-right{display:flex;gap:6px;align-items:center}.toolbar-btn{border:none;border-radius:5px;padding:5px 7px;cursor:pointer;font-size:12px;color:var(--color-text-secondary);background:transparent;display:flex;align-items:center;gap:4px;justify-content:center;min-width:28px;height:28px;transition:all .2s;position:relative}.toolbar-btn.active{background:var(--color-primary);color:var(--color-white)}.toolbar-btn.active .toolbar-icon{color:var(--color-white)}.grid-size-control{display:flex;align-items:center;gap:4px;margin-left:4px}.grid-size-select{background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);padding:2px 4px;font-size:11px;min-width:52px}.grid-size-select:focus{outline:none;border-color:var(--color-primary)}.toolbar-btn.primary{font-weight:600;font-size:12px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);padding:5px 12px;min-width:auto;height:28px;box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.35)}.toolbar-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-400) 0%,var(--color-primary) 100%);transform:translateY(-1px);box-shadow:0 4px 10px rgba(var(--color-primary-rgb),.45)}.toolbar-btn.primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.toolbar-btn.preview{font-weight:600;font-size:12px;background:linear-gradient(135deg,var(--color-blue-500) 0%,var(--color-blue-600) 100%);color:var(--color-white);padding:5px 12px;min-width:auto;height:28px;box-shadow:0 2px 6px rgba(var(--color-blue-600-rgb),.35)}.toolbar-btn.preview:hover{background:linear-gradient(135deg,var(--color-blue-400) 0%,var(--color-blue-500) 100%);transform:translateY(-1px);box-shadow:0 4px 10px rgba(var(--color-blue-600-rgb),.45)}.toolbar-btn.live-view{font-weight:600;font-size:12px;background:linear-gradient(135deg,var(--color-orange-500-tw) 0%,var(--color-orange-600-tw) 100%);color:var(--color-white);padding:5px 12px;min-width:auto;height:28px;box-shadow:0 2px 6px rgba(var(--color-orange-tw-500-rgb),.35)}.toolbar-btn.live-view:hover:not(:disabled){background:linear-gradient(135deg,var(--color-orange-tw-400) 0%,var(--color-orange-500-tw) 100%);transform:translateY(-1px);box-shadow:0 4px 10px rgba(var(--color-orange-tw-500-rgb),.45)}.toolbar-btn.live-view:disabled{opacity:.5;cursor:not-allowed;transform:none}.toolbar-btn:hover:not(.primary):not(.preview):not(.live-view){color:var(--color-text-primary);background:var(--color-surface-overlay)}.toolbar-zoom-display{min-width:42px;background:var(--color-input-bg);border:1px solid var(--color-border)}.toolbar-zoom-text{font-size:11px;font-weight:600;color:var(--color-text-primary)}.toolbar-zoom-display:hover{background:var(--color-surface-overlay);border-color:var(--color-text-muted)}.toolbar-btn[title*=nhỏ],.toolbar-btn[title*=to]{background:var(--color-surface-overlay);border:1px solid var(--color-border-medium)}.toolbar-btn[title*=nhỏ]:hover,.toolbar-btn[title*=to]:hover{background:var(--color-surface-sunken);border-color:var(--color-text-subtle)}.scada-main-layout{flex:1;display:flex;height:calc(100vh - 78px);min-height:0}.scada-status-bar{height:36px;background:var(--color-surface-raised);border-top:1px solid var(--color-border);display:flex;align-items:center;padding:0 10px;gap:4px;flex-shrink:0;z-index:10;overflow:hidden}.status-bar-group{display:flex;align-items:center;gap:3px}.status-bar-sep{width:1px;height:18px;background:var(--color-border);margin:0 6px;flex-shrink:0}.status-bar-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--color-text-muted);border-radius:4px;cursor:pointer;transition:background .15s,color .15s;flex-shrink:0}.status-bar-btn:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.status-bar-zoom{min-width:44px;height:24px;border:1px solid var(--color-border);background:var(--color-input-bg);color:var(--color-text-primary);border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;text-align:center;padding:0 4px;transition:background .15s}.status-bar-zoom:hover{background:var(--color-surface-overlay)}.status-color-label{font-size:10px;color:var(--color-text-subtle);margin-right:2px;flex-shrink:0}.status-color-swatch-wrap{position:relative;width:22px;height:22px;border-radius:4px;border:1px solid var(--color-border);overflow:hidden;cursor:pointer;flex-shrink:0}.status-color-swatch{width:100%;height:100%}.status-color-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;padding:0;border:none}.status-quick-color{width:18px;height:18px;border-radius:3px;border:1px solid rgba(var(--color-white-rgb),.15);cursor:pointer;flex-shrink:0;transition:transform .1s,border-color .1s}.status-quick-color:hover{transform:scale(1.2);border-color:var(--color-primary);z-index:1}.status-bar-info{font-size:10px;color:var(--color-text-subtle);font-family:Courier New,monospace;white-space:nowrap;padding:0 4px}.scada-widget-manager{width:280px;background:var(--color-surface);border-left:1px solid var(--color-border);padding:12px 8px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;height:100%;position:relative;z-index:100}.widget-manager-tabs{display:flex;gap:6px}.widget-manager-tabs button{flex:1;padding:6px 0;border:1px solid transparent;background:var(--color-surface-overlay);color:var(--color-text-muted);font-size:12px;font-weight:500;border-radius:6px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.widget-manager-tabs button:hover{color:var(--color-text-primary);background:var(--color-surface-raised)}.widget-manager-tabs button.active{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);font-weight:600}.widget-manager-title{font-size:12px;color:var(--color-text-primary);font-weight:600;margin-bottom:5px;text-align:center}.widget-manager-empty{color:var(--color-text-subtle);font-size:13px;text-align:center;padding:16px 8px}.widget-manager-list{display:flex;flex-direction:column;gap:10px}.widget-manager-item{background:var(--color-surface);border-radius:8px;box-shadow:0 1px 4px rgba(var(--color-primary-rgb),.06);padding:8px;display:flex;flex-direction:column;gap:6px}.widget-manager-item.active{border:2px solid var(--color-primary-hover)}.widget-manager-row{display:flex;align-items:center;gap:8px}.widget-manager-icon{width:22px;height:22px;color:var(--color-blue)}.widget-manager-input{flex:1;font-size:13px;padding:2px 6px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface-raised);color:var(--color-blue)}.widget-manager-note{width:100%;padding:2px 6px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface-raised);color:var(--color-text-muted);resize:none}.widget-manager-actions{display:flex;gap:8px;margin-top:2px}.widget-manager-btn{border:none;background:none;cursor:pointer;font-size:18px;color:var(--color-blue);padding:2px 6px;border-radius:4px;transition:background .2s,color .2s}.widget-manager-btn:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.scada-sidebar{max-width:200px;background:var(--color-surface);border-right:1px solid var(--color-border);padding:12px 0;display:flex;flex-direction:column;gap:5px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--color-border-medium) transparent;height:100%;position:relative;z-index:100}.scada-sidebar::-webkit-scrollbar{width:8px}.scada-sidebar::-webkit-scrollbar-track{background:transparent}.scada-sidebar::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:4px}.scada-sidebar::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}.sidebar-section{margin-bottom:0}.sidebar-title{font-size:13px;color:var(--color-text-secondary);font-weight:500;text-align:left;padding:5px 12px;line-height:1.2}.sidebar-icons{display:flex;flex-wrap:wrap;gap:15px;justify-content:left;padding-left:12px}.sidebar-icons>*{width:32px;height:32px;color:var(--color-text-secondary);background:var(--color-surface-overlay);border-radius:6px;cursor:pointer;transition:background .2s,color .2s;display:flex;align-items:center;justify-content:center}.sidebar-icons>*:hover{background:var(--color-surface-raised);color:var(--color-text-primary)}.switch-variants-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;padding-left:12px}.switch-icon{position:relative;width:40px;height:40px;background:var(--color-surface-overlay);border-radius:8px;cursor:grab;transition:all .2s ease;display:flex;align-items:center;justify-content:center;overflow:hidden}.switch-icon:hover{background:var(--color-surface-raised);transform:scale(1.05)}.switch-icon:active{cursor:grabbing;transform:scale(.95)}.switch-icon img{width:32px;height:32px;-o-object-fit:contain;object-fit:contain}.switch-variant-label{position:absolute;bottom:2px;right:2px;font-size:9px;font-weight:600;color:var(--color-white);background:rgba(var(--color-black-rgb),.6);padding:1px 4px;border-radius:3px;line-height:1}.drawing-tool.active{background:var(--color-primary)!important;color:var(--color-white)!important}.drawing-preview{transition:none!important;animation:none!important}.scada-canvas{flex:1;background:var(--color-surface-sunken);position:relative;min-height:0;height:100%;overflow:hidden;-moz-user-select:none;user-select:none;-webkit-user-select:none}.scada-canvas:before{content:"";position:absolute;top:0;left:0;width:20px;height:20px;background:var(--color-surface-raised);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);z-index:11}.ruler-horizontal{position:absolute;top:0;left:20px;right:0;height:20px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border);z-index:10}.ruler-horizontal .ruler-marks{position:relative;height:100%}.ruler-horizontal .ruler-mark{position:absolute;top:0;width:1px;background:var(--color-text-subtle);height:8px}.ruler-horizontal .ruler-mark.major{background:var(--color-text-primary);height:15px}.ruler-horizontal .ruler-mark.zero{background:var(--color-primary)!important;height:20px!important;width:3px!important}.ruler-horizontal .ruler-label{position:absolute;top:-2px;left:2px;font-size:9px;color:var(--color-text-primary);font-weight:500;white-space:nowrap;transform:scaleX(calc(1 / var(--scale, 1)))}.ruler-horizontal .ruler-mark.zero .ruler-label{color:var(--color-primary);font-weight:700;background:var(--color-surface);padding:1px 3px;border-radius:2px}.ruler-horizontal .ruler-mark.negative{background:var(--color-red-500)!important}.ruler-horizontal .ruler-mark.negative.major{height:15px}.ruler-horizontal .ruler-mark.negative .ruler-label{color:var(--color-red-500);background:var(--color-surface);padding:1px 3px;border-radius:2px}.ruler-vertical{position:absolute;top:20px;left:0;width:20px;bottom:0;background:var(--color-surface-raised);border-right:1px solid var(--color-border);z-index:10}.ruler-vertical .ruler-marks{position:relative;width:100%;height:100%}.ruler-vertical .ruler-mark{position:absolute;left:0;height:1px;background:var(--color-text-subtle);width:8px}.ruler-vertical .ruler-mark.major{background:var(--color-text-primary);width:15px}.ruler-vertical .ruler-mark.zero{background:var(--color-primary)!important;width:20px!important;height:3px!important}.ruler-vertical .ruler-label{position:absolute;left:-2px;top:2px;font-size:9px;color:var(--color-text-primary);font-weight:500;white-space:nowrap;writing-mode:vertical-rl;text-orientation:mixed;transform:scaleY(calc(1 / var(--scale, 1)))}.ruler-vertical .ruler-mark.zero .ruler-label{color:var(--color-primary);font-weight:700;background:var(--color-surface);padding:1px 3px;border-radius:2px;writing-mode:horizontal-tb;text-orientation:initial}.ruler-vertical .ruler-mark.negative{background:var(--color-red-500)!important}.ruler-vertical .ruler-mark.negative.major{width:15px}.ruler-vertical .ruler-mark.negative .ruler-label{color:var(--color-red-500);background:var(--color-surface);padding:1px 3px;border-radius:2px;writing-mode:horizontal-tb;text-orientation:initial}.canvas-content{position:absolute;inset:20px 0 0 20px;background:var(--color-surface-sunken);display:flex;align-items:center;justify-content:center;overflow:visible;transform:translateZ(0);backface-visibility:hidden}.origin-axis-x{position:absolute;height:2px;width:12px;background:var(--color-red);border-radius:1px;z-index:2}.origin-axis-y{position:absolute;width:2px;height:12px;background:var(--color-red);border-radius:1px;z-index:2}.grid-overlay{position:absolute;top:0;left:0;z-index:10;pointer-events:none;background-image:linear-gradient(to right,rgba(var(--color-success-rgb),.4) 1px,transparent 1px),linear-gradient(to bottom,rgba(var(--color-success-rgb),.4) 1px,transparent 1px);background-size:20px 20px;opacity:1;transition:opacity .3s ease}.view-boundary{position:absolute;top:40px;left:40px;border:1px solid var(--color-border-medium);box-shadow:var(--shadow-md);z-index:1;overflow:hidden}.canvas-placeholder{position:absolute;inset:0;background:transparent;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-text-subtle);font-size:18px;font-weight:500;letter-spacing:1px;border:2px dashed var(--color-border-medium);z-index:0}.canvas-widgets{position:relative;width:100%;height:100%;transform:translateZ(0);will-change:transform;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;image-rendering:optimizeQuality}.canvas-widget{border:none;background:transparent;box-shadow:none;transition:none;border-radius:10px;pointer-events:auto;transform:translateZ(0);backface-visibility:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;will-change:auto}.canvas-widget *{pointer-events:auto}.canvas-widget svg{shape-rendering:geometricPrecision;image-rendering:optimizeQuality;backface-visibility:hidden}.canvas-widget polyline,.canvas-widget line,.canvas-widget path{shape-rendering:geometricPrecision;vector-effect:non-scaling-stroke}.canvas-widget.selected{border:.5px solid var(--color-primary-hover);border-radius:10px}.library-widget-container,.canvas-widget .library-widget-container *,.canvas-widget.locked .library-widget-container,.canvas-widget.locked .library-widget-container *{pointer-events:auto!important}.canvas-widget .library-widget-container.widget-control-locked,.canvas-widget .library-widget-container.widget-control-locked *,.canvas-content .canvas-widgets.tool-active .canvas-widget,.canvas-content .canvas-widgets.tool-active .canvas-widget *{pointer-events:none!important}.resize-handle{position:absolute;right:-8px;bottom:-8px;width:16px;height:16px;background:var(--color-primary-hover);border-radius:50%;cursor:nwse-resize;border:2px solid var(--color-white);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.18);z-index:2}.selection-overlay{position:absolute;pointer-events:none;z-index:9999}.selection-border{position:absolute;inset:0;border:1px solid rgba(var(--color-primary-rgb),.9);outline:1px solid rgba(var(--color-primary-rgb),.4);box-shadow:0 0 0 1px rgba(var(--color-primary-rgb),.3);border-radius:2px}.selection-pivot-line{position:absolute;top:-30px;height:30px;width:2px;background:rgba(var(--color-primary-rgb),.9);transform:translate(-50%);pointer-events:none}.selection-handle{position:absolute;width:12px;height:12px;background:var(--color-surface);border:2px solid var(--color-primary);border-radius:2px;box-shadow:0 1px 4px rgba(var(--color-black-rgb),.25);pointer-events:auto}.selection-handle[data-handle=tl]{transform:translate(-100%,-100%)}.selection-handle[data-handle=t]{transform:translate(-50%,-100%)}.selection-handle[data-handle=tr]{transform:translateY(-100%)}.selection-handle[data-handle=l]{transform:translate(-100%,-50%)}.selection-handle[data-handle=r]{transform:translateY(-50%)}.selection-handle[data-handle=bl]{transform:translate(-100%)}.selection-handle[data-handle=b]{transform:translate(-50%)}.selection-handle[data-handle=br]{transform:translate(0)}.selection-pivot{position:absolute;width:20px;height:20px;background:var(--color-success-600);border:3px solid var(--color-white);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 6px rgba(var(--color-black-rgb),.35);pointer-events:auto;cursor:grab;transition:background .15s,transform .15s}.selection-pivot:active{cursor:grabbing}.selection-pivot:hover{background:var(--color-success-deep)}.widget-config-tabs{background:var(--color-surface-raised);border-radius:8px;box-shadow:0 1px 4px rgba(var(--color-black-rgb),.2);padding:8px}.widget-tabs-header{display:flex;gap:8px;margin-bottom:8px}.widget-tabs-header button{flex:1;padding:6px 0;border:none;background:var(--color-surface);color:var(--color-text-secondary);font-weight:500;border-radius:6px;cursor:pointer;transition:background .2s,color .2s}.widget-tabs-header button.active{background:var(--color-surface-overlay);color:var(--color-text-primary)}.widget-tabs-content{margin-top:4px}.widget-config-section{margin-bottom:8px}.widget-config-tabs textarea,.widget-config-tabs select{width:100%;padding:4px 6px;border:1px solid var(--color-border-medium);border-radius:5px;background:var(--color-input-bg);color:var(--color-text-primary);font-size:11px;box-sizing:border-box;outline:none}.widget-config-tabs textarea{resize:vertical;font-family:inherit;font-size:12px;padding:6px}.widget-config-tabs select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.widget-config-tabs select option{background:var(--color-input-bg);color:var(--color-text-primary)}.iframe-ratio-btn{padding:3px 10px;border-radius:5px;border:1.5px solid var(--color-border);background:var(--color-surface-overlay);color:var(--color-text-primary);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.iframe-ratio-btn:hover{background:rgba(var(--color-primary-rgb),.25);border-color:var(--color-primary);color:var(--color-primary)}.widget-config-title{font-size:11px;color:var(--color-text-primary);font-weight:700;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.widget-config-row{display:grid;grid-template-columns:1fr 100px;align-items:center;gap:6px;margin-bottom:4px}.widget-config-row label{font-size:11px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-config-row input[type=number],.widget-config-row input[type=text],.widget-config-row select{width:100px;padding:2px 6px;border:1px solid var(--color-border-medium);border-radius:5px;background:var(--color-input-bg);color:var(--color-text-primary);font-size:11px;height:24px;cursor:pointer;text-align:right;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.widget-config-row input[type=number]::-webkit-inner-spin-button,.widget-config-row input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.widget-config-row input[type=number]{-moz-appearance:textfield}.widget-config-row select{text-align:left;cursor:pointer;padding-right:4px}.widget-config-row input[type=range]{flex:1}.opacity-label-group{display:flex;align-items:center;gap:4px}.opacity-value{font-size:11px;color:var(--color-text-muted);white-space:nowrap}.align-section-header{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:6px}.align-section-header .widget-config-title{flex-shrink:0;margin-bottom:0}.align-count{font-size:10px;color:var(--color-text-subtle);font-style:italic}.align-count.active{color:var(--color-primary);font-style:normal;font-weight:600}.align-row{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:4px}.align-btn2{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:5px 2px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface-overlay);color:var(--color-text-muted);cursor:pointer;transition:all .15s}.align-btn2 span{font-size:8.5px;line-height:1.1;text-align:center;word-break:break-word;color:var(--color-text-subtle)}.align-btn2:hover:not(:disabled){background:var(--color-surface-raised);border-color:var(--color-primary);color:var(--color-primary)}.align-btn2:hover:not(:disabled) span{color:var(--color-primary)}.align-btn2:disabled{opacity:.35;cursor:not-allowed}.align-btn{display:flex;align-items:center;justify-content:center;height:30px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface-overlay);color:var(--color-text-muted);cursor:pointer;transition:all .15s;font-size:11px}.align-btn:hover:not(:disabled){background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.align-btn:disabled{opacity:.3;cursor:not-allowed}@media (max-width: 900px){.scada-toolbar{padding:0 8px}.scada-sidebar{width:56px;padding:6px 0}.sidebar-icons>*{width:22px;height:22px}.canvas-placeholder{font-size:16px;padding:8px}}@media (max-width: 600px){.scada-dashboard-root,.scada-main-layout{flex-direction:column}.scada-sidebar{flex-direction:row;width:100%;height:56px;border-right:none;border-bottom:1px solid var(--color-border);overflow-x:auto;overflow-y:hidden;padding:0 4px}.sidebar-section{margin-bottom:0;margin-right:12px}.scada-canvas{min-height:300px;height:auto}}.canvas-zoom-indicator{position:absolute;right:16px;bottom:16px;background:rgba(var(--color-primary-hover-rgb),.85);color:var(--color-white);padding:2px 10px;border-radius:8px;font-size:15px;z-index:10;pointer-events:none}.widget-manager-list-simple{display:flex;flex-direction:column;gap:6px}.widget-manager-item-simple{display:flex;align-items:center;justify-content:space-between;background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:6px;box-shadow:0 1px 4px rgba(var(--color-black-rgb),.1);padding:4px 8px;transition:border .2s,box-shadow .2s;cursor:pointer}.widget-manager-item-simple.active{border:2px solid var(--color-text-muted);box-shadow:0 2px 8px rgba(var(--color-black-rgb),.2)}.widget-names{flex:1;display:flex;flex-direction:column;gap:2px;margin-right:8px;overflow:hidden}.widget-manager-name-primary{font-size:14px;color:var(--color-text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-manager-name-system{font-size:11px;color:var(--color-text-subtle);font-weight:400;font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.8}.widget-manager-name{flex:1;font-size:14px;color:var(--color-text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:8px}.widget-manager-btn-simple{border:none;background:none;padding:2px 4px;margin-left:2px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.widget-manager-btn-simple:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.widget-manager-icon-simple{width:14px;height:14px;color:var(--color-text-secondary);transition:color .2s}.widget-manager-list-advanced{display:flex;flex-direction:column;gap:3px}.widget-manager-hint{font-size:10px;color:var(--color-text-subtle);margin-bottom:2px}.widget-manager-item-adv{display:flex;flex-direction:column;background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:5px;padding:4px 6px;gap:2px;cursor:grab;transition:background .15s,border .15s}.widget-manager-item-adv.active{border:2px solid var(--color-primary);background:var(--color-surface-raised)}.widget-manager-item-adv.dragging{opacity:.55}.widget-manager-item-adv.dragover{outline:2px dashed var(--color-primary-400)}.widget-row-1{display:flex;align-items:center;gap:8px;width:100%}.widget-names-row{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.widget-name-user{font-size:12px;color:var(--color-text-primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-names-row>.widget-value{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--color-primary);background:rgba(var(--color-primary-rgb),.1);padding:1px 6px;border-radius:4px;align-self:flex-start;white-space:nowrap}.widget-names-row>.widget-value .widget-value-icon{color:var(--color-primary)}.widget-name-system{font-size:11px;color:var(--color-text-subtle);font-weight:400;font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.8}.widget-row-2{display:flex;align-items:center;justify-content:space-between;gap:4px;width:100%;padding-top:0}.widget-properties{display:flex;align-items:center;gap:8px}.widget-prop{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--color-text-subtle);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.widget-prop.visible.disabled{color:var(--color-red-500)}.widget-prop.locked.active{color:var(--color-yellow)}.widget-prop.layer{background:var(--color-surface-sunken);padding:2px 6px;border-radius:4px;border:1px solid var(--color-border)}.widget-toggles{display:flex;gap:4px}.widget-toggle-btn{background:var(--color-surface-sunken);border:1px solid var(--color-border);color:var(--color-text-subtle);padding:4px;border-radius:4px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.widget-toggle-btn:hover{background:var(--color-surface-overlay);border-color:var(--color-text-muted);color:var(--color-text-primary)}.widget-toggle-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.widget-toggle-btn.active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:var(--color-white)}.widget-toggle-btn.lock-btn.active{background:var(--color-orange-500-tw);border-color:var(--color-orange-500-tw);color:var(--color-white)}.widget-toggle-btn.lock-btn.active:hover{background:var(--color-orange-600-tw);border-color:var(--color-orange-600-tw);color:var(--color-white)}.widget-toggle-btn:focus,.widget-toggle-btn:focus-visible,.layer-btn:focus,.layer-btn:focus-visible,.drag-handle:focus,.drag-handle:focus-visible,.align-btn2:focus,.align-btn2:focus-visible,.widget-manager-tabs button:focus,.widget-manager-tabs button:focus-visible,.scada-sidebar button:focus,.scada-sidebar button:focus-visible,.scada-widget-manager button:focus,.scada-widget-manager button:focus-visible{outline:none;box-shadow:none}.drag-handle{padding:2px 4px;cursor:grab;display:flex;align-items:center;justify-content:center;color:var(--color-text-subtle)}.drag-handle:hover{color:var(--color-text-primary)}.layer-buttons{display:flex;align-items:center;gap:2px;margin-left:auto}.layer-btn{background:var(--color-surface-overlay);border:none;color:var(--color-text-primary);font-size:10px;line-height:1;padding:4px;border-radius:4px;cursor:pointer}.layer-btn:hover{background:var(--color-primary);color:var(--color-white)}.btn-property-open{background:var(--color-surface-overlay);color:var(--color-text-primary);border:1px solid var(--color-border-medium);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:13px;box-shadow:0 1px rgba(var(--color-white-rgb),.02) inset;transition:background .15s,border-color .15s,transform .12s,box-shadow .15s}.btn-property-open:hover{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);box-shadow:0 8px 20px rgba(var(--color-primary-hover-rgb),.12);transform:translateY(-1px)}.btn-property-open:focus{outline:none;box-shadow:0 0 0 4px rgba(var(--color-primary-hover-rgb),.12);border-color:var(--color-primary)}.btn-property-open:disabled{background:var(--color-surface-sunken);color:var(--color-text-muted);cursor:not-allowed;border-color:var(--color-border);transform:none;box-shadow:none}.btn-add{background:var(--color-primary-hover);color:var(--color-white);border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px}.btn-add:hover{background:var(--color-blue-700)}.btn-danger{background:var(--color-red);color:var(--color-white);border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px}.btn-danger:hover{background:var(--color-red-700)}.property-dialog{display:flex;flex-direction:column}.property-tabs{display:flex;gap:4px;padding:8px 12px 0}.property-tabs button{flex:1;background:var(--color-surface-overlay);border:1px solid var(--color-border);color:var(--color-text-primary);padding:8px 10px;border-radius:6px;font-size:13px;cursor:pointer;transition:background .15s,border-color .15s;display:flex;align-items:center;justify-content:center;gap:6px}.property-tabs button .tab-icon{font-size:14px}.property-tabs button .tab-icon-vue{flex-shrink:0}.property-tabs button.active{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:var(--color-white);box-shadow:0 0 0 1px rgba(var(--color-primary-hover-rgb),.4)}.property-tabs button:hover:not(.active){background:var(--color-surface-raised)}.property-panel{display:flex;flex-direction:column;gap:12px}.property-body::-webkit-scrollbar{width:8px}.property-body::-webkit-scrollbar-track{background:var(--color-surface-sunken)}.property-body::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:4px}.property-body::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}.tab-description{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:var(--color-surface-raised);border-radius:8px;border-left:3px solid var(--color-primary);margin-bottom:8px}.tab-desc-icon{font-size:18px;flex-shrink:0}.tab-desc-icon-vue{flex-shrink:0;color:var(--color-primary-400)}.tab-desc-text{font-size:13px;color:var(--color-text-subtle);line-height:1.5}.switch-state-config{background:var(--color-surface-raised);border-radius:8px;padding:12px 16px;margin-bottom:12px;border:1px solid var(--color-border)}.switch-state-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.switch-state-row{display:flex;gap:16px}.switch-state-row .state-item{flex:1;display:flex;flex-direction:column;gap:4px}.switch-state-row .state-item label{font-size:12px;color:var(--color-text-subtle)}.switch-state-row .state-item input{padding:6px 10px;background:var(--color-input-bg);border:1px solid var(--color-border-medium);border-radius:4px;color:var(--color-text-primary);font-size:13px}.switch-state-row .state-item input:focus{outline:none;border-color:var(--color-primary)}.switch-state-hint{margin-top:8px;font-size:11px;color:var(--color-text-muted);font-style:italic}.widget-settings-panel{background:transparent;padding:0}.widget-settings-two-column-styled{display:grid;grid-template-columns:minmax(0,1fr) 460px;gap:16px;height:auto;min-height:auto}.widget-preview-column-styled{border-radius:6px;padding:16px;display:flex;flex-direction:column}.preview-header-styled{margin-bottom:12px;border-bottom:1px solid var(--color-border);padding-bottom:8px}.preview-title-styled{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0}.preview-container-styled{flex:1;justify-content:center;align-items:center;min-height:320px}.actual-widget-preview-styled,.widget-preview-frame-styled{width:100%;min-height:320px;padding:5px;border-radius:8px;overflow:hidden;display:flex;justify-content:center;align-items:center;background:var(--color-surface);border:1px solid var(--color-border-light)}.preview-widget-fallback-styled{display:flex;align-items:center;justify-content:center}.generic-widget-preview-styled{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px}.widget-icon-large-styled{font-size:32px;margin-bottom:8px;color:var(--color-text-subtle)}.widget-info-styled{display:flex;flex-direction:column;gap:4px}.widget-title-styled{font-size:14px;font-weight:600;color:var(--color-text-primary)}.widget-subtitle-styled{color:var(--color-text-subtle)}.widget-options-column-styled{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px;display:flex;flex-direction:column;height:auto;overflow-y:visible}.options-header-styled{padding:12px 16px;border-bottom:1px solid var(--color-border);background:var(--color-surface-overlay);border-radius:6px 6px 0 0}.options-title-styled{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.widget-type-name-styled{font-size:11px;color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.5px}.widget-options-wrapper{padding:0;margin:0;background:transparent}.widget-options-wrapper .chart-options{background:transparent;overflow-y:visible}.widget-options-wrapper .option-section{margin-bottom:16px;padding:12px;background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:4px}.widget-options-wrapper .section-title{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.widget-options-wrapper .option-item{margin-bottom:8px}.widget-options-wrapper .option-item label{font-size:13px;font-weight:500;color:var(--color-text-subtle);margin-bottom:4px}.widget-options-wrapper .input-field,.widget-options-wrapper .select-field,.widget-options-wrapper .textarea-field{padding:6px 8px;font-size:13px;background:var(--color-input-bg);border:1px solid var(--color-border-medium);color:var(--color-text-primary);border-radius:3px}.widget-options-wrapper .input-field:focus,.widget-options-wrapper .select-field:focus,.widget-options-wrapper .textarea-field:focus{border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(var(--color-primary-rgb),.4)}.no-options-wrapper{padding:32px 16px;display:flex;justify-content:center;align-items:center;min-height:200px}.no-options-content{text-align:center}.no-options-icon{font-size:32px;display:block;margin-bottom:12px}.property-list{display:flex;flex-direction:column;gap:6px;background:var(--color-surface-sunken);padding:10px 12px;border:1px solid var(--color-border);border-radius:8px}.property-list select,.property-list input,.property-list textarea{background:var(--color-input-bg);border:1px solid var(--color-border-medium);color:var(--color-text-primary);border-radius:6px;padding:6px 8px;font-size:13px;width:100%}.property-list textarea{resize:vertical}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mini-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-subtle);margin-bottom:2px}.event-config-group{display:flex;flex-direction:column;gap:6px;background:var(--color-surface-overlay);padding:8px 10px;border:1px solid var(--color-border);border-radius:6px}.event-panel{gap:10px}.event-item{background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:10px;overflow:hidden;transition:border-color .18s,background .18s}.event-item:not(.collapsed):hover{border-color:var(--color-border-medium)}.event-item-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;font-size:13px;font-weight:500;background:var(--color-surface-overlay)}.event-item.collapsed .event-item-header{border-radius:10px}.event-item-title{display:flex;align-items:center;gap:6px;color:var(--color-text-primary);font-weight:500}.evt-type{color:var(--color-primary-400);font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.evt-action{color:var(--color-amber-400);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.evt-sep{opacity:.4}.evt-desc{font-size:11px;color:var(--color-text-subtle);font-weight:400}.chevron{display:inline-block;transform:rotate(0);transition:transform .2s;font-size:11px;color:var(--color-text-muted)}.chevron.open{transform:rotate(90deg);color:var(--color-text-subtle)}.event-item-body{padding:12px 12px 14px;display:flex;flex-direction:column;gap:10px;animation:fadeIn .25s}.row-compact{display:flex;gap:12px}.row-compact .col{flex:1;display:flex;flex-direction:column;gap:4px}.event-config-line{display:flex;flex-direction:column;gap:6px}.event-config-grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px}.event-config-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.mini-btn{background:var(--color-surface-overlay);color:var(--color-text-primary);border:1px solid var(--color-border);padding:2px 6px;border-radius:5px;font-size:11px;cursor:pointer;line-height:1.2}.mini-btn:hover{background:var(--color-surface-raised);color:var(--color-text-primary)}.mini-btn.danger{background:var(--color-red-bg);border-color:var(--color-red-border);color:var(--color-red)}.mini-btn.danger:hover{background:var(--color-red);color:var(--color-white)}.fade-scale-enter-active,.fade-scale-leave-active{transition:all .18s ease}.fade-scale-enter-from,.fade-scale-leave-to{opacity:0;transform:translateY(-4px) scale(.98)}.property-flat{display:flex;flex-direction:column;gap:6px}.property-row{display:grid;grid-template-columns:140px 200px 1fr;gap:8px;align-items:center;padding:6px 8px;color:var(--color-text-primary)}.mapping-input-group{display:flex;align-items:center;gap:8px;margin-bottom:8px}.mapping-input-group label{min-width:40px;text-align:left;font-size:13px;color:var(--color-text-subtle);font-weight:500}.mapping-input-group input{flex:1;padding:6px 10px;background:var(--color-input-bg);border:1px solid var(--color-border-medium);color:var(--color-text-primary);border-radius:5px;font-size:13px}.mapping-input-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.1)}.property-row.tag-row-full{display:flex;flex-direction:column;align-items:stretch;gap:12px;padding:12px}.property-row.header{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-subtle);background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:6px;padding:8px;font-weight:600}.property-row:not(.header){background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px}.property-row:not(.header):hover{background:var(--color-surface-overlay)}.property-row .col input{width:100%;background:var(--color-input-bg);border:1px solid var(--color-border-medium);color:var(--color-text-primary);border-radius:5px;font-size:12px;padding:6px 8px}.property-row .col input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(var(--color-primary-rgb),.4)}.property-row .field-col label{color:var(--color-text-primary);font-weight:500;font-size:12px}.property-row .desc-col .desc-text{color:var(--color-text-subtle);font-size:11px;font-style:italic}.checkbox-wrapper{display:flex;align-items:center;gap:8px}.checkbox-wrapper input[type=checkbox]{transform:scale(1.2);cursor:pointer}.checkbox-wrapper span{color:var(--color-text-primary);font-size:12px}.event-flat{display:flex;flex-direction:column;gap:6px}.event-row{display:grid;grid-template-columns:110px 140px 1fr 180px 70px;gap:8px;align-items:start;padding:4px 8px;border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.event-row.header{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-subtle);background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:6px;padding:6px 8px;font-weight:600}.event-row.footer-row{border:none;justify-content:space-between;grid-template-columns:1fr 1fr}.event-row:not(.header):not(.footer-row):hover{background:var(--color-surface-overlay)}.event-row:not(.header):not(.footer-row){background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px}.event-row .col select,.event-row .col input,.event-row .col textarea{width:100%;background:var(--color-input-bg);border:1px solid var(--color-border-medium);color:var(--color-text-primary);border-radius:5px;font-size:12px;padding:4px 6px}.event-row .col textarea{resize:vertical}.event-row .col select:focus,.event-row .col input:focus,.event-row .col textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(var(--color-primary-rgb),.4)}.tag-row-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border);margin-bottom:4px}.tag-row-header label{color:var(--color-text-primary);font-weight:600;font-size:13px}.tag-row-hint{font-size:11px;color:var(--color-text-muted);font-style:italic}.tag-config-section{display:flex;flex-direction:column;gap:12px;width:100%}.tag-selector-row{display:grid;grid-template-columns:110px 1fr auto;align-items:center;gap:12px;min-height:36px}.tag-label{font-size:13px;color:var(--color-text-subtle);font-weight:500;text-align:right;white-space:nowrap}.tag-select{width:100%;padding:8px 12px;border:1px solid var(--color-border-medium);border-radius:6px;background:var(--color-input-bg);color:var(--color-text-primary);min-height:36px;font-size:13px}.tag-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.2)}.tag-select:disabled{background:var(--color-surface-sunken);color:var(--color-text-muted);cursor:not-allowed}.tag-reload-btn{padding:8px 12px;border:1px solid var(--color-border-medium);border-radius:6px;background:var(--color-input-bg);color:var(--color-text-primary);font-size:14px;cursor:pointer;min-width:40px;height:36px;display:flex;align-items:center;justify-content:center;transition:all .2s}.tag-reload-btn:hover:not(:disabled){background:var(--color-surface-overlay);border-color:var(--color-text-muted)}.tag-reload-btn:disabled{cursor:not-allowed;opacity:.6}.tag-reload-placeholder{min-width:40px;height:36px;display:flex;align-items:center;justify-content:center}.tag-input-readonly{width:100%;padding:8px 12px;border:1px solid var(--color-border-medium);border-radius:6px;background:var(--color-surface-sunken);color:var(--color-text-subtle);min-height:36px;font-size:13px}.tag-loading{font-size:13px;color:var(--color-text-muted);font-style:italic;min-width:40px;text-align:center}.tag-instruction{padding:12px 14px;background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:6px}.instruction-text{font-size:12px;color:var(--color-amber-400);line-height:1.5}.actions-compact{display:flex;flex-direction:column;gap:8px}.actions-list{display:flex;flex-direction:column;gap:6px}.action-item{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;padding:8px;transition:background-color .2s}.action-item:hover{background:var(--color-surface-overlay)}.action-main-row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;padding:8px 0}.action-enable{display:flex;align-items:center;justify-content:center;align-self:flex-end;height:36px;width:36px;flex:0 0 36px}.action-enable input[type=checkbox]{width:18px;height:18px;cursor:pointer}.action-device-selector,.action-datamonitor-selector,.action-condition,.action-effect,.action-timing{display:flex;flex-direction:column;gap:4px;min-width:120px}.action-device-selector label,.action-datamonitor-selector label,.action-condition label,.action-effect label,.action-timing label{font-size:12px;color:var(--color-text-secondary);font-weight:500}.action-device-select,.action-datamonitor-select{padding:7px 10px;background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:7px;color:var(--color-text-primary);font-size:13px;min-width:140px;transition:border-color .2s,box-shadow .2s}.action-device-select:focus,.action-datamonitor-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.condition-row{display:flex;gap:4px}.operator-select{width:56px;padding:7px 6px;background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:7px;color:var(--color-text-primary);font-size:13px;text-align:center;transition:border-color .2s,box-shadow .2s}.condition-value-input{width:90px;padding:7px 10px;background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:7px;color:var(--color-text-primary);font-size:13px;transition:border-color .2s,box-shadow .2s}.timing-single{display:flex;align-items:center;gap:6px}.timing-input{width:82px;padding:7px 10px;background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:7px;color:var(--color-text-primary);font-size:13px;transition:border-color .2s,box-shadow .2s}.operator-select:focus,.condition-value-input:focus,.timing-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.timing-unit{color:var(--color-text-subtle);font-size:11px;font-weight:500}.action-controls{display:flex;gap:4px;align-items:flex-end;padding-bottom:4px;margin-left:auto}.action-basic{display:grid;grid-template-columns:120px 1fr;gap:8px}.action-details-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;padding-top:6px;border-top:1px solid var(--color-border)}.detail-group{display:flex;flex-direction:column;gap:4px}.detail-group label{font-size:10px;color:var(--color-text-subtle);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.timing-inputs,.condition-inputs,.animation-inputs{display:flex;gap:4px}.loop-checkbox{display:flex;align-items:center;gap:6px}.loop-checkbox input[type=checkbox]{transform:scale(1.1)}.loop-checkbox span{color:var(--color-text-primary);font-size:11px}.actions-compact input,.actions-compact select{background:var(--color-input-bg);border:1px solid var(--color-border-medium);color:var(--color-text-primary);border-radius:4px;font-size:11px;padding:3px 6px;height:26px}.actions-compact input:focus,.actions-compact select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(var(--color-primary-rgb),.4)}.tag-input{min-width:100px}.effect-select{min-width:140px;padding:7px 10px;background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:7px;color:var(--color-text-primary);font-size:13px;transition:border-color .2s,box-shadow .2s}.effect-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.bitmask-select{min-width:70px}.direction-select{min-width:100px}@media (max-width: 1100px){.action-basic{grid-template-columns:100px 1fr}.action-details-row{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}}@media (max-width: 880px){.action-main-row{grid-template-columns:30px 1fr}.action-controls{grid-column:1 / -1;justify-content:flex-end;margin-top:4px}.action-basic{grid-template-columns:1fr}.action-details-row{grid-template-columns:1fr;gap:8px}}.inline-pair{display:grid;grid-template-columns:1fr 1fr;gap:6px}.inline-triple{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.setvalue-config{display:flex;flex-direction:column;gap:6px;width:100%}.setvalue-row{display:flex;gap:6px}.setvalue-row select,.setvalue-row input{flex:1}.screen-select{width:100%;padding:6px 8px;background:var(--color-input-bg);border:1px solid var(--color-border-medium);border-radius:5px;color:var(--color-text-primary);font-size:12px}.screen-select:focus{outline:none;border-color:var(--color-primary-400)}.device-select,.datakey-select{width:100%;padding:6px 8px;background:var(--color-input-bg);border:1px solid var(--color-border-medium);border-radius:5px;color:var(--color-text-primary);font-size:12px}.device-select:focus,.datakey-select:focus{outline:none;border-color:var(--color-primary-400)}.value-input{width:100%;padding:6px 8px;background:var(--color-input-bg);border:1px solid var(--color-border-medium);border-radius:5px;color:var(--color-text-primary);font-size:12px}.value-input:focus{outline:none;border-color:var(--color-primary-400)}.switch-values-inline{display:flex;gap:8px;width:100%}.switch-value-item{display:flex;align-items:center;gap:4px;flex:1}.switch-value-item label{font-size:11px;color:var(--color-text-subtle);font-weight:500;white-space:nowrap}.value-input-small{flex:1;padding:5px 8px;background:var(--color-input-bg);border:1px solid var(--color-border-medium);border-radius:5px;color:var(--color-text-primary);font-size:12px;min-width:40px}.value-input-small:focus{outline:none;border-color:var(--color-primary-400)}.icon-btn{background:var(--color-surface-overlay);border:1px solid var(--color-border);color:var(--color-text-primary);padding:4px 6px;border-radius:5px;font-size:12px;cursor:pointer;margin-right:4px;display:inline-flex;align-items:center;justify-content:center}.icon-btn:last-child{margin-right:0}.icon-btn:hover{background:var(--color-surface-raised);color:var(--color-text-primary)}.icon-btn.danger{background:var(--color-red-bg);border-color:var(--color-red-border);color:var(--color-red)}.icon-btn.danger:hover{background:var(--color-red);color:var(--color-white)}.icon-btn.test{background:var(--color-primary);border-color:var(--color-primary-hover);color:var(--color-white)}.icon-btn.test:hover{background:var(--color-primary-hover)}.icon-btn.small{padding:2px 4px;font-size:10px}.add-context{cursor:pointer;color:var(--color-primary-400);font-size:13px}.add-context:hover{text-decoration:underline}.add-binding{cursor:pointer;color:var(--color-text-subtle);font-size:12px;text-align:right}.add-binding:hover{color:var(--color-text-primary)}.actions-flat{display:flex;flex-direction:column;gap:6px}.actions-row{display:grid;grid-template-columns:50px 1fr 100px 80px 80px 160px 70px;gap:8px;align-items:center;padding:4px 8px;color:var(--color-text-primary)}.actions-row.header{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-subtle);background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:6px;padding:6px 8px;font-weight:600}.actions-row.footer-row{border:none;grid-template-columns:1fr}.actions-row:not(.header):not(.footer-row){background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px}.actions-row:not(.header):not(.footer-row):hover{background:var(--color-surface-overlay)}.actions-row .col input,.actions-row .col select{width:100%;background:var(--color-input-bg);border:1px solid var(--color-border-medium);color:var(--color-text-primary);border-radius:5px;font-size:12px;padding:4px 6px}.actions-row .col input:focus,.actions-row .col select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(var(--color-primary-rgb),.4)}.add-action{cursor:pointer;color:var(--color-primary-400);font-size:13px;padding:6px 4px}.add-action:hover{text-decoration:underline}.widget-preview-section-compact{grid-column:1 / -1;margin-bottom:8px;padding:12px 16px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px}.preview-header-compact{margin-bottom:8px}.preview-title-compact{font-weight:600;color:var(--color-text-primary);margin:0}.preview-container-compact{display:flex;justify-content:center;align-items:center;min-height:120px}.actual-widget-preview-compact{width:100%;max-width:200px;height:120px;display:flex;justify-content:center;align-items:center;background:var(--color-surface-overlay);border:1px solid var(--color-border-medium);border-radius:6px;overflow:hidden}.preview-widget-fallback-compact{width:100%;max-width:200px;height:120px;background:var(--color-surface-overlay);border:1px solid var(--color-border-medium);border-radius:6px;display:flex;align-items:center;justify-content:center}.generic-widget-preview-compact{display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px}.widget-icon-compact{font-size:24px;margin-bottom:4px;color:var(--color-text-subtle)}.widget-info-compact{display:flex;flex-direction:column;gap:2px}.widget-title-compact{font-weight:600;color:var(--color-text-primary)}.widget-subtitle-compact{font-size:10px;color:var(--color-text-subtle)}.no-options-text h5{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.no-options-text p{color:var(--color-text-subtle);margin:0}@media (max-width:1100px){.actions-row{grid-template-columns:40px 1fr 80px 70px 70px 140px 60px}}@media (max-width:900px){.actions-row{grid-template-columns:40px 1fr 80px 70px 70px}.actions-row .mode-col,.actions-row .ctrl-col{grid-column:1 / -1;display:flex;gap:8px}.actions-row .ctrl-col{justify-content:flex-end}}@media (max-width: 1100px){.property-row{grid-template-columns:120px 180px 1fr}.event-row{grid-template-columns:90px 120px 1fr 150px 60px}}@media (max-width: 880px){.property-row{grid-template-columns:1fr}.property-row .field-col{margin-bottom:4px}.property-row .desc-col{margin-top:4px;padding-left:8px}.event-row{grid-template-columns:90px 120px 1fr}.event-row .desc-col,.event-row .ctrl-col{grid-column:1 / -1;display:flex;gap:6px}.event-row .ctrl-col{justify-content:flex-end}}.property-list select:focus,.property-list input:focus,.property-list textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.25)}.property-actions-line{display:flex;justify-content:flex-end}.sidebar-title-svg-group{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding-right:10px}.sidebar-group-name{flex:1}.sidebar-group-arrow{margin-left:8px;font-size:11px;color:var(--color-text-subtle);transition:color .2s}.view-section{padding:0 12px;position:relative}.view-create-bar{margin-bottom:8px;display:flex;gap:4px}.view-create-btn-small{flex:1;display:flex;align-items:center;justify-content:center;padding:5px;background:var(--color-surface-overlay);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.view-create-btn-small:hover{background:var(--color-surface-raised);border-color:var(--color-text-subtle);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-black-rgb),.2)}.view-create-icon{width:14px;height:14px}.view-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;overflow-x:visible;scrollbar-width:thin;scrollbar-color:var(--color-border-medium) transparent}.view-list::-webkit-scrollbar{width:8px}.view-list::-webkit-scrollbar-track{background:transparent}.view-list::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:4px}.view-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}.view-item{display:flex;align-items:center;justify-content:space-between;padding:0 10px;background:var(--color-surface-overlay);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.view-item:hover{border-color:var(--color-text-subtle)}.view-item.active{background:var(--color-primary-bg);border:2px solid var(--color-primary);padding:0 9px;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.18)}.view-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-primary)}.view-item.active .view-name{color:var(--color-primary-hover);font-weight:600}.view-item.view-item-default,.view-item.view-item-default.active{border-color:var(--color-primary)}.view-name-wrapper{flex:1;min-width:0}.view-name{font-size:13px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.view-name-input{width:100%;font-size:13px;font-weight:500;color:var(--color-text-primary);background:var(--color-input-bg);border:1px solid var(--color-border-medium);border-radius:3px;padding:2px 4px;outline:none}.view-menu-wrapper{position:relative}.view-menu-btn{background:none;border:none;color:var(--color-text-subtle);font-size:16px;font-weight:700;cursor:pointer;border-radius:3px;transition:all .2s;line-height:1}.view-menu-btn:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.view-menu-dropdown{position:absolute;top:0;left:100%;margin-top:4px;margin-left:50px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;box-shadow:0 6px 16px rgba(var(--color-black-rgb),.4);z-index:9999;min-width:100px;padding:3px}.menu-item{display:flex;align-items:center;gap:6px;width:100%;padding:5px 10px;background:none;border:none;border-radius:4px;text-align:left;font-size:11px;color:var(--color-text-primary);cursor:pointer;transition:background .15s}.menu-item:hover{background:var(--color-surface-overlay)}.menu-item.danger{color:var(--color-red)}.menu-item.danger:hover{background:var(--color-red-bg)}.menu-item.menu-item-active{color:var(--color-primary)}.menu-item span{font-size:11px}.color-palette{height:40px;background:var(--color-surface-raised);border-top:1px solid var(--color-border);display:flex;align-items:center;padding:0 16px;gap:16px}.color-palette-info{display:flex;align-items:center;gap:12px}.zoom-indicator{color:var(--color-text-primary);font-weight:500;min-width:40px}.color-display{display:flex;align-items:center}.current-colors{display:flex;gap:4px}.color-box{width:24px;height:24px;border:2px solid var(--color-border);border-radius:3px;cursor:pointer;transition:all .2s;position:relative}.color-box:hover{border-color:var(--color-border);transform:scale(1.1)}.color-box.primary{z-index:2}.color-box.secondary{margin-left:-8px;z-index:1}.color-palette-colors{display:flex;gap:2px;flex:1;overflow-x:auto;padding:4px 0}.palette-color{width:20px;height:20px;border:1px solid var(--color-border);border-radius:2px;cursor:pointer;transition:all .2s;flex-shrink:0}.palette-color:hover{border-color:var(--color-border);transform:scale(1.2);z-index:10;box-shadow:0 2px 8px rgba(var(--color-black-rgb),.3)}.create-view-dialog-overlay{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.6);display:flex;align-items:center;justify-content:center;z-index:6000}.create-view-dialog{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;box-shadow:0 24px 72px rgba(var(--color-black-rgb),.55);width:780px;max-width:96vw;max-height:96vh;min-height:70vh;overflow:hidden;display:flex;flex-direction:column}.create-view-dialog.create-view-modal{width:480px;min-height:auto;max-height:90vh}.create-view-dialog.property-dialog{width:80%;height:80%}.property-body{padding:10px;display:flex;flex-direction:column;gap:18px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;max-height:calc(100vh - 280px)}.create-view-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--color-border);background:var(--color-surface-raised)}.create-view-header h3{margin:0;font-size:16px;color:var(--color-text-primary);font-weight:600}.close-btn{border:none;background:none;font-size:24px;color:var(--color-text-subtle);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s,color .2s}.close-btn:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.create-view-close{border:none;background:none;font-size:24px;color:var(--color-text-subtle);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s,color .2s}.create-view-close:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.create-view-content{padding:12px 14px}.form-group{margin-bottom:10px}.form-row{display:flex;gap:10px}.form-row .form-group{flex:1}.form-group label{display:block;font-size:11px;color:var(--color-text-primary);font-weight:500;margin-bottom:5px}.form-input{width:100%;padding:6px 10px;border:1px solid var(--color-border-medium);border-radius:6px;font-size:12px;color:var(--color-text-primary);background:var(--color-input-bg);transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--color-blue-sky-mid);box-shadow:0 0 0 3px rgba(var(--color-blue-sky-mid-rgb),.2)}.form-select{width:100%;padding:6px 10px;border:1px solid var(--color-border-medium);border-radius:6px;font-size:12px;color:var(--color-text-primary);background:var(--color-input-bg);transition:border-color .2s,box-shadow .2s;cursor:pointer}.form-select:focus{outline:none;border-color:var(--color-blue-sky-mid);box-shadow:0 0 0 3px rgba(var(--color-blue-sky-mid-rgb),.2)}.form-select option{background:var(--color-input-bg);color:var(--color-text-primary);padding:8px 12px}.size-display{padding:6px 10px;border:1px solid var(--color-border-medium);border-radius:6px;font-size:12px;color:var(--color-text-subtle);background:var(--color-input-bg);font-family:monospace;text-align:center}.color-picker-group{display:flex;gap:10px;align-items:center}.color-picker{width:44px;height:32px}.color-text{flex:1;padding:6px 10px;border:1px solid var(--color-border-medium);border-radius:6px;font-size:12px;color:var(--color-text-primary);background:var(--color-input-bg)}.create-view-actions{display:flex;gap:8px;justify-content:flex-end;padding:10px 14px;border-top:1px solid var(--color-border);background:var(--color-surface-raised)}.btn-cancel,.btn-create{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-cancel{background:var(--color-surface-overlay);color:var(--color-text-primary)}.btn-cancel:hover{background:var(--color-surface-raised)}.btn-create{background:var(--color-blue-cornflower);color:var(--color-white)}.btn-create:hover{background:var(--color-blue-cornflower-d);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-blue-cornflower-rgb),.4)}.btn-save{background:var(--color-success-600);color:var(--color-white);padding:5px 10px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid var(--color-success-600);transition:all .2s}.btn-close{background:var(--color-red);color:var(--color-white);padding:5px 10px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid var(--color-red);transition:all .2s}.btn-close:hover{background:var(--color-red-hover);border-color:var(--color-red-hover);box-shadow:0 4px 12px rgba(var(--color-red-rgb),.35);transform:translateY(-1px)}.btn-close:active{transform:translateY(0);box-shadow:none}.btn-save:hover:not(:disabled){background:var(--color-success-deep);border-color:var(--color-success-deep);box-shadow:0 4px 12px rgba(var(--color-black-rgb),.35);transform:translateY(-1px)}.btn-save:active:not(:disabled){background:var(--color-success-800);transform:translateY(0);box-shadow:none}.btn-save:disabled{background:var(--color-text-subtle);border-color:var(--color-text-subtle);cursor:not-allowed;opacity:.6}.canvas-widgets.drawing-active .canvas-widget{pointer-events:none!important}.canvas-widgets.drawing-active[data-drawing-tool=pentool] .canvas-widget{visibility:hidden!important}.canvas-widgets.drawing-active:not([data-drawing-tool=pentool]) .canvas-widget{opacity:.5!important}.canvas-widgets.drawing-active{cursor:crosshair!important}.dialog-view-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(var(--color-black-rgb),.5);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.dialog-view-container{background:var(--color-surface);border-radius:8px;box-shadow:0 20px 60px rgba(var(--color-black-rgb),.4);overflow:hidden;display:flex;flex-direction:column}.dialog-view-header{height:36px;background:linear-gradient(135deg,var(--color-surface-navy) 0%,var(--color-blue-navy-grad) 100%);display:flex;align-items:center;justify-content:space-between;padding:0 12px;cursor:move;-webkit-user-select:none;-moz-user-select:none;user-select:none}.dialog-view-title{color:var(--color-white);font-weight:500}.dialog-view-close{background:transparent;border:none;color:var(--color-white);font-size:20px;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .15s}.dialog-view-close:hover{background:rgba(var(--color-white-rgb),.1)}.dialog-view-content{flex:1;overflow:auto}.scada-preview-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-black);z-index:15000;overflow:hidden}.scada-preview-modal{width:100%;height:100%;position:relative}.preview-exit-btn{position:absolute;top:16px;right:16px;z-index:16000;width:40px;height:40px;background:rgba(var(--color-black-rgb),.7);color:var(--color-white);border:1px solid rgba(var(--color-white-rgb),.2);border-radius:8px;cursor:pointer;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-exit-btn:hover{background:rgba(var(--color-red-500-rgb),.9);border-color:rgba(var(--color-white-rgb),.4);transform:scale(1.05)}.preview-canvas-wrapper{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;overflow-x:hidden;overflow-y:hidden;background:var(--color-black);-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.preview-canvas-wrapper::-webkit-scrollbar{height:10px}.preview-canvas-wrapper::-webkit-scrollbar-track{background:rgba(var(--color-white-rgb),.05)}.preview-canvas-wrapper::-webkit-scrollbar-thumb{background:rgba(var(--color-white-rgb),.3);border-radius:5px}.preview-canvas-wrapper::-webkit-scrollbar-thumb:hover{background:rgba(var(--color-white-rgb),.5)}.preview-canvas-content{position:relative;flex-shrink:0}.preview-widget{transition:all .2s ease;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-user-drag:none}.preview-widget.interactive-widget{transition:filter .15s ease-out}.preview-widget.interactive-widget:hover{filter:brightness(1.08)}.preview-widget.widget-pressed,.widget-pressed{transform:scale(.95) translateY(-1px)!important;transition:all .1s ease-out!important}.widget-element,.draggable-widget,[draggable=true]{transition:all .2s ease-out}.widget-element:hover,.draggable-widget:hover,[draggable=true]:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-black-rgb),.1)}.widget-library-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(var(--color-black-rgb),.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center}.widget-library-modal{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;box-shadow:0 25px 80px rgba(var(--color-black-rgb),.6);width:90%;max-width:1100px;height:85%;max-height:750px;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--color-border)}.widget-library-modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border);background:var(--color-surface-raised)}.widget-library-modal-title{color:var(--color-text-primary);font-size:16px;font-weight:600;margin:0;display:flex;align-items:center;gap:8px}.widget-library-modal-title:before{content:"";width:3px;height:14px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:2px}.widget-library-modal-close{background:none;border:none;color:var(--color-text-muted);font-size:18px;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.widget-library-modal-close:hover{background:var(--color-red-bg);color:var(--color-red)}.widget-library-modal-content{display:flex;flex:1;overflow:hidden}.widget-library-categories{width:160px;background:var(--color-surface-sunken);border-right:1px solid var(--color-border);overflow-y:auto;padding:8px 0;flex-shrink:0}.widget-library-category-item{padding:8px 14px;color:var(--color-text-muted);cursor:pointer;transition:all .2s;border-left:3px solid transparent;font-size:13px;font-weight:500;margin:1px 6px;border-radius:0 6px 6px 0}.widget-library-category-item:hover{background:var(--color-surface-overlay);color:var(--color-text-primary);border-left-color:var(--color-border-medium)}.widget-library-category-item.active{background:rgba(var(--color-primary-rgb),.15);color:var(--color-primary);border-left-color:var(--color-primary);font-weight:600}.widget-library-grid-modal{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;padding:14px;overflow-y:auto;background:var(--color-surface);align-content:start}.widget-library-modal-item{background:var(--color-surface-raised);border-radius:8px;padding:10px;cursor:pointer;transition:all .2s ease;border:1px solid var(--color-border);display:flex;flex-direction:column;height:260px;box-shadow:0 2px 8px rgba(var(--color-black-rgb),.3)}.widget-library-modal-item:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 6px 16px rgba(var(--color-primary-rgb),.2)}.widget-library-modal-item:has(.thumbnail-vertical-slider){height:420px}.widget-library-modal-item:hover .widget-thumbnail-container{background:var(--color-white)}.widget-library-modal-preview{width:100%;flex:1;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.widget-library-modal-preview>*{pointer-events:none}.widget-thumbnail-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-white);border-radius:6px;overflow:hidden;position:relative;transition:all .2s}.widget-thumbnail{width:100%;height:100%;max-width:100%;max-height:100%;pointer-events:none;box-sizing:border-box;display:flex;justify-content:center}.widget-thumbnail-container.thumbnail-chart{padding:0}.widget-thumbnail-container.thumbnail-chart .widget-thumbnail{transform-origin:center center}.widget-thumbnail-container.thumbnail-control{padding:8px;display:flex;align-items:center;justify-content:center;background:var(--color-white)}.widget-thumbnail-container.thumbnail-control .widget-thumbnail{transform:scale(.75);transform-origin:center center;width:133%;height:133%;filter:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.widget-thumbnail-container.thumbnail-circular-slider{padding:10px;display:flex;align-items:center;justify-content:center;background:var(--color-white)}.widget-thumbnail-container.thumbnail-circular-slider .widget-thumbnail{transform-origin:center center;width:154%;height:154%;filter:none}.widget-thumbnail-container.thumbnail-horizontal-slider{padding:20px 12px;display:flex;align-items:center;justify-content:center;background:var(--color-white)}.widget-thumbnail-container.thumbnail-horizontal-slider .widget-thumbnail{transform-origin:center center;width:100%;height:100%;filter:none}.widget-thumbnail-container.thumbnail-vertical-slider{padding:12px 16px;display:flex;align-items:center;justify-content:center;background:var(--color-white);min-height:360px}.widget-thumbnail-container.thumbnail-vertical-slider .widget-thumbnail{transform-origin:center center;width:180%;height:180%;filter:none}.widget-thumbnail-container.thumbnail-gauge{padding:10px}.widget-thumbnail-container.thumbnail-gauge .widget-thumbnail{transform:scale(.8);transform-origin:center center;width:160%;height:160%}.widget-thumbnail-container.thumbnail-map{padding:0}.widget-thumbnail-container.thumbnail-map .widget-thumbnail{transform-origin:center center}.widget-thumbnail-container.thumbnail-alarm{padding:0;overflow:hidden;align-items:flex-start;justify-content:flex-start}.widget-thumbnail-container.thumbnail-alarm .widget-thumbnail{transform-origin:top left;margin:0}.widget-thumbnail-container.thumbnail-device{padding:0;overflow:hidden;align-items:flex-start;justify-content:flex-start}.widget-thumbnail-container.thumbnail-device .widget-thumbnail{transform-origin:top left;margin:0}.widget-thumbnail-container.thumbnail-vertical-box{padding:8px;display:flex;align-items:center;justify-content:center}.widget-thumbnail-container.thumbnail-vertical-box .widget-thumbnail{transform:scale(.45);transform-origin:center center;width:220%;height:220%}.widget-preview-placeholder{width:100%;height:100%;min-height:80px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-overlay);border-radius:6px;color:var(--color-text-subtle)}.widget-library-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-subtle);text-align:center}.widget-library-empty p{margin-top:12px;font-size:13px;color:var(--color-text-muted)}.widget-library-modal-name{color:var(--color-text-primary);font-size:13px;font-weight:500;text-align:center;line-height:1.4;padding:8px 4px 2px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-library-modal-item.selected{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.1);box-shadow:0 4px 16px rgba(var(--color-primary-rgb),.25)}.widget-library-modal-item.selected .widget-thumbnail-container{background:var(--color-white)}.widget-library-modal-item.selected .widget-library-modal-name{color:var(--color-primary);font-weight:600}.widget-library-modal-footer{display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:10px 16px;border-top:1px solid var(--color-border);background:var(--color-surface-raised)}.widget-library-modal-footer .btn-cancel{padding:6px 14px;background:var(--color-surface-overlay);color:var(--color-text-secondary);border:1px solid var(--color-border-medium);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.widget-library-modal-footer .btn-cancel:hover{background:var(--color-surface-raised);color:var(--color-text-primary)}.widget-library-modal-footer .btn-primary{padding:6px 16px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.widget-library-modal-footer .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary-700) 100%);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.4);transform:translateY(-1px)}.widget-library-modal-footer .btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.widget-library-container{padding:4px 12px 8px}.widget-library-button-full{width:100%;height:32px;background:var(--color-surface-overlay);color:var(--color-text-secondary);border:none;border-radius:6px;cursor:pointer;transition:background .2s,color .2s;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:500;box-shadow:0 1px 4px rgba(var(--color-black-rgb),.1)}.widget-library-button-full:hover{background:var(--color-surface-raised);color:var(--color-text-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes scaleUp{0%{transform:scale(1)}to{transform:scale(1.2)}}@keyframes scaleDown{0%{transform:scale(1)}to{transform:scale(.8)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes bounce{0%,20%,53%,80%,to{transform:translateY(0)}40%,43%{transform:translateY(-15px)}70%{transform:translateY(-7px)}90%{transform:translateY(-3px)}}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutUp{0%{transform:translateY(0);opacity:1}to{transform:translateY(-100%);opacity:0}}@keyframes slideOutDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}@keyframes slideOutLeft{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@keyframes flash{0%,50%,to{opacity:1}25%,75%{opacity:.3}}@keyframes glow{0%,to{box-shadow:0 0 5px rgba(var(--color-primary-rgb),.6)}50%{box-shadow:0 0 20px rgba(var(--color-primary-rgb),1),0 0 30px rgba(var(--color-primary-rgb),.8)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes turnClockwise{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes turnCounterClockwise{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}@keyframes zoomIn{0%{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}@keyframes zoomOut{0%{transform:scale(1);opacity:1}to{transform:scale(.3);opacity:0}}@keyframes rotate360{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes elastic{0%{transform:scale(1)}20%{transform:scale(1.2)}40%{transform:scale(.9)}60%{transform:scale(1.1)}80%{transform:scale(.95)}to{transform:scale(1)}}.widget-action-fade-in{animation:fadeIn var(--animation-duration, 1s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-fade-out{animation:fadeOut var(--animation-duration, 1s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-scale-up{animation:scaleUp var(--animation-duration, .5s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-scale-down{animation:scaleDown var(--animation-duration, .5s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-shake{animation:shake var(--animation-duration, .6s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-pulse{animation:pulse var(--animation-duration, 1s) var(--animation-easing, ease) var(--animation-delay, 0s) infinite}.widget-action-bounce{animation:bounce var(--animation-duration, 1s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-slide-in-up{animation:slideInUp var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-slide-in-down{animation:slideInDown var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-slide-in-left{animation:slideInLeft var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-slide-in-right{animation:slideInRight var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-slide-out-up{animation:slideOutUp var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-slide-out-down{animation:slideOutDown var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-slide-out-left{animation:slideOutLeft var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-slide-out-right{animation:slideOutRight var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-flash{animation:flash var(--animation-duration, 1s) var(--animation-easing, ease) var(--animation-delay, 0s) infinite}.widget-action-glow{animation:glow var(--animation-duration, 2s) var(--animation-easing, ease) var(--animation-delay, 0s) infinite}.widget-action-blink{animation:blink var(--animation-duration, 1s) var(--animation-easing, step-end) var(--animation-delay, 0s) infinite}.widget-action-turn-cw{animation:turnClockwise var(--animation-duration, 2s) var(--animation-easing, linear) var(--animation-delay, 0s) infinite}.widget-action-turn-ccw{animation:turnCounterClockwise var(--animation-duration, 2s) var(--animation-easing, linear) var(--animation-delay, 0s) infinite}.widget-action-zoom-in{animation:zoomIn var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-zoom-out{animation:zoomOut var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-rotate-360{animation:rotate360 var(--animation-duration, 1s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-wiggle{animation:wiggle var(--animation-duration, .8s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-elastic{animation:elastic var(--animation-duration, 1.2s) var(--animation-easing, ease) var(--animation-delay, 0s)}.widget-action-hidden{opacity:0!important;pointer-events:none;visibility:hidden}.widget-action-stopped *{animation-play-state:paused!important}.actions-enhanced{max-height:500px;overflow-y:auto;padding:16px}.actions-grid{margin-bottom:20px}.action-card{border:2px solid var(--color-border);border-radius:12px;background:var(--color-surface);box-shadow:var(--shadow-md);overflow:hidden;transition:all .2s ease}.action-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.15)}.action-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border)}.action-title{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--color-text-secondary)}.action-title input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary)}.action-title span{font-size:14px;color:var(--color-text-muted);font-family:monospace}.action-body{padding:16px}.action-section{margin-bottom:20px}.action-section:last-child{margin-bottom:0}.action-section h4{margin:0 0 12px;font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border);padding-bottom:6px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-weight:500;color:var(--color-text-muted);display:flex;align-items:center;gap:6px}.form-group input,.form-group select{border-radius:6px;font-size:13px;transition:all .2s ease}.form-group input:focus,.form-group select:focus{outline:none;box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.effect-select{font-weight:500}.effect-select optgroup{font-weight:600;color:var(--color-text-secondary);background:var(--color-surface-raised)}.effect-select option{font-weight:400;color:var(--color-text-muted);padding:4px 8px}.icon-btn.small{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center}.add-action-section{padding:16px;border-top:2px dashed var(--color-border-medium);text-align:center}.action-buttons{display:flex;gap:12px;justify-content:center;align-items:center}.action-controls{display:flex;align-items:center;gap:8px}.icon-btn.test{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);border:none;width:24px;height:24px;border-radius:4px;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px rgba(var(--color-primary-rgb),.3)}.icon-btn.test:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.4)}.icon-btn.test:active{transform:translateY(0);box-shadow:0 1px 2px rgba(var(--color-primary-rgb),.3)}.test-all-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,var(--color-yellow) 0%,var(--color-amber-600) 100%);color:var(--color-white);border:none;border-radius:8px;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px rgba(var(--color-amber-rgb),.3)}.test-all-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-amber-rgb),.4)}.test-all-btn:active{transform:translateY(0);box-shadow:0 2px 4px rgba(var(--color-amber-rgb),.3)}.test-all-btn span{font-size:14px}.form-hint{font-size:11px;color:var(--color-text-muted);font-style:italic;margin-top:2px}.add-action-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-blue-700) 100%);color:var(--color-white);border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.add-action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.4)}.add-action-btn:active{transform:translateY(0);box-shadow:0 2px 4px rgba(var(--color-primary-rgb),.3)}.add-action-btn span{font-size:18px;font-weight:700}.form-group label input[type=checkbox]{width:16px;height:16px;margin-right:8px;accent-color:var(--color-primary)}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}.action-header{flex-direction:column;gap:8px;align-items:flex-start}}.create-view-dialog-overlay.minimized{opacity:0;pointer-events:none;transition:opacity .3s ease}.create-view-dialog-overlay.minimized .create-view-dialog{transform:translate(100%);transition:transform .3s ease}.header-buttons{display:flex;gap:8px;align-items:center}.restore-button{background:var(--color-primary);color:var(--color-white);border:none;width:28px;height:28px;border-radius:4px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.restore-button:hover{background:var(--color-primary-hover)}.floating-restore-button{position:fixed;bottom:20px;right:20px;background:var(--color-primary);color:var(--color-white);border:none;padding:12px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;box-shadow:0 4px 12px rgba(var(--color-black-rgb),.15);z-index:1000;transition:all .2s ease;display:flex;align-items:center;gap:8px}.floating-restore-button:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px rgba(var(--color-black-rgb),.2)}.tag-apply-section{margin-top:12px;padding:12px;background:var(--color-surface-raised);border-radius:6px;border:1px solid var(--color-border)}.apply-tag-btn{width:100%;background:var(--color-primary);color:var(--color-white);border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.apply-tag-btn:disabled{background:var(--color-text-subtle);cursor:not-allowed}.tag-info{margin-top:8px;display:flex;flex-direction:column;gap:4px}.tag-info small{color:var(--color-text-muted);font-size:11px}.tag-value{color:var(--color-primary-hover)!important;font-weight:500}.tag-apply-section{margin-top:10px;padding:8px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px}.apply-tag-btn{background:var(--color-primary);color:var(--color-white);border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s ease;width:100%}.apply-tag-btn:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.apply-tag-btn:disabled{background:var(--color-text-subtle);cursor:not-allowed;transform:none}.tag-info{margin-top:4px;display:flex;flex-direction:column;gap:2px}.tag-info small{color:var(--color-text-muted);font-size:10px}.tag-value{font-weight:600;color:var(--color-primary-hover)}.canvas-widget span{display:inline-block;word-break:break-word;text-align:center}.canvas-widget .widget-value{color:var(--color-primary-hover);font-weight:600}.options-section-title{margin:0 0 1rem;font-size:.95rem;font-weight:600;color:var(--color-text-secondary);display:flex;align-items:center;gap:.5rem}.no-specific-options{padding:1.5rem;text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;margin-top:1rem}.option-info{margin:0 0 .5rem;font-size:.9rem;color:var(--color-primary-hover);font-weight:500}.option-hint{margin:0;font-size:.8rem;color:var(--color-text-muted)}.widget-settings-steps em{color:var(--color-primary-hover);font-style:normal;font-weight:500}.drawing-preview-layer{transform:translateZ(0);backface-visibility:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;z-index:99999!important;position:absolute!important;pointer-events:none!important;isolation:isolate;mix-blend-mode:normal}.fixed-drawing-overlay{transform:translateZ(0);backface-visibility:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;isolation:isolate}.fixed-drawing-overlay svg{shape-rendering:geometricPrecision;image-rendering:optimizeQuality}.fixed-drawing-overlay polyline{shape-rendering:geometricPrecision}.drawing-preview-layer svg{shape-rendering:geometricPrecision;image-rendering:optimizeQuality;position:relative;z-index:1}.drawing-preview-layer polyline,.drawing-preview-layer line{shape-rendering:geometricPrecision;stroke-linecap:round;stroke-linejoin:round}.tag-apply-section{display:flex;flex-direction:column;gap:10px;margin-top:8px;padding:10px 12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px}.tag-preview-info{display:flex;flex-direction:row;align-items:center;gap:20px;padding:0;background:transparent;border:none;flex-wrap:wrap}.tag-preview-item{display:flex;align-items:center;gap:8px}.tag-preview-item:not(:last-child):after{content:""}.tag-preview-label{font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px}.tag-preview-value{font-size:13px;color:var(--color-text-primary);font-family:Courier New,monospace;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-value-highlight{color:var(--color-primary);font-weight:600;font-size:13px}.apply-tag-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.apply-tag-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary-700) 100%);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.4);transform:translateY(-1px)}.apply-tag-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.apply-tag-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px rgba(var(--color-primary-rgb),.3)}.mapping-row-full{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;align-items:self-start}.mapping-row-header{display:flex;flex-direction:column;gap:4px;padding-bottom:8px;border-bottom:1px solid var(--color-border);text-align:left}.mapping-row-header label{font-size:14px;font-weight:600;color:var(--color-text-primary);text-transform:none;letter-spacing:.5px;text-align:left}.mapping-row-hint{font-size:12px;color:var(--color-text-subtle);font-style:italic;text-align:left}.mapping-config-section{display:flex;flex-direction:column;gap:16px}.mapping-checkbox-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:6px}.mapping-checkbox-row .checkbox-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-secondary);cursor:pointer;margin:0}.mapping-checkbox-row .checkbox-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.mapping-hint-text{font-size:11px;color:var(--color-text-muted);font-style:italic}.mapping-values-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:center;padding:12px;background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:6px}.mapping-column{display:flex;flex-direction:column;gap:10px}.mapping-column-label{font-size:12px;font-weight:600;color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.mapping-input-group{display:flex;align-items:center;gap:8px}.mapping-input-group label{font-size:12px;color:var(--color-text-secondary);min-width:35px}.mapping-input-group input{flex:1;padding:6px 10px;border:1px solid var(--color-border-medium);border-radius:4px;font-size:13px;background:var(--color-input-bg);color:var(--color-text-primary);transition:all .2s}.mapping-input-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.mapping-arrow{display:flex;align-items:center;justify-content:center;color:var(--color-primary);font-size:20px}.mapping-preview{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-surface-raised);border-left:3px solid var(--color-primary);border-radius:6px;flex-wrap:wrap}.mapping-preview-label{font-size:12px;font-weight:600;color:var(--color-text-subtle);text-transform:uppercase}.mapping-preview-example{font-size:12px;color:var(--color-text-secondary)}.mapping-preview-example strong{color:var(--color-primary);font-weight:700}.mapping-preview-divider{color:var(--color-border-medium);font-size:14px}.scada-loading-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(var(--color-white-rgb),.92);z-index:100;gap:16px}[data-theme=dark] .scada-loading-overlay{background:rgba(var(--color-surface-dark-rgb),.92)}.scada-load-error{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--color-red-500);z-index:100}.loading-spinner{width:48px;height:48px}.spinner-ring{width:100%;height:100%;border:4px solid var(--color-primary-100);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:14px;color:var(--color-text-muted)}[data-v-dba44f66]:root{--auth-primary: var(--color-primary);--auth-primary-hover: var(--color-primary-hover);--auth-text-dark: #1a1a1a;--auth-text-medium: #666;--auth-text-light: var(--color-text-subtle);--auth-border: #e0e0e0;--auth-bg-light: #f8f9fa;--auth-error: var(--color-red-500);--auth-error-bg: rgba(var(--color-red-500-rgb), .15);--auth-error-border: rgba(var(--color-red-500-rgb), .3);--auth-white: #ffffff}[data-theme=dark][data-v-dba44f66]{--auth-text-dark: var(--color-gray-200-soft);--auth-text-medium: var(--color-text-subtle);--auth-text-light: var(--color-text-muted);--auth-border: #444444;--auth-bg-light: #2a2a2a;--auth-white: var(--color-surface)}.login-layout[data-v-dba44f66],.auth-wrapper[data-v-dba44f66]{height:100vh;max-height:100vh;display:flex;font-family:Inter,sans-serif;background:var(--auth-white);justify-content:center;overflow:hidden}.auth-left-panel[data-v-dba44f66],.login-container[data-v-dba44f66]{flex:0 0 480px;background:var(--auth-white);display:flex;align-items:safe center;justify-content:center;padding:20px;position:relative;overflow-y:auto;overflow-x:hidden;height:100%;box-sizing:border-box}.auth-form-container[data-v-dba44f66],.login-card[data-v-dba44f66]{width:100%;max-width:480px;margin:0 auto;position:relative;z-index:1}.auth-header[data-v-dba44f66],.login-header[data-v-dba44f66]{text-align:center;margin-bottom:32px}.auth-title[data-v-dba44f66],.login-title[data-v-dba44f66]{font-size:2rem;font-weight:700;color:var(--auth-text-dark);margin:0 0 8px}.auth-subtitle[data-v-dba44f66]{font-size:1rem;color:var(--auth-text-light);margin:0}.login-logo[data-v-dba44f66]{max-width:250px;height:auto;margin-bottom:.5rem;filter:drop-shadow(0 2px 8px rgba(var(--color-black-rgb),.1))}.auth-form[data-v-dba44f66],.login-form[data-v-dba44f66]{display:flex;flex-direction:column;gap:20px}.auth-form-group[data-v-dba44f66],.form-group[data-v-dba44f66]{display:flex;flex-direction:column;gap:8px}.auth-label[data-v-dba44f66],.form-group label[data-v-dba44f66]{font-size:.875rem;font-weight:500;color:var(--auth-text-dark)}.auth-input-wrap[data-v-dba44f66],.input-wrap[data-v-dba44f66]{position:relative;display:flex;align-items:center}.auth-input-icon[data-v-dba44f66],.login-icon[data-v-dba44f66]{position:absolute;left:14px;width:20px;height:20px;color:var(--auth-text-light);pointer-events:none;transition:color .3s}.auth-input[data-v-dba44f66],.input-wrap input[data-v-dba44f66]{width:100%;padding:14px 14px 14px 48px;background:var(--auth-bg-light);border:1.5px solid var(--auth-border);border-radius:12px;font-size:.95rem;color:var(--auth-text-dark);transition:all .3s ease}.auth-input[data-v-dba44f66]::-moz-placeholder,.input-wrap input[data-v-dba44f66]::-moz-placeholder{color:var(--auth-text-light)}.auth-input[data-v-dba44f66]::placeholder,.input-wrap input[data-v-dba44f66]::placeholder{color:var(--auth-text-light)}.auth-input[data-v-dba44f66]:focus,.input-wrap input[data-v-dba44f66]:focus{outline:none;border-color:var(--auth-primary);background:var(--auth-white);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.auth-input:focus+.auth-input-icon[data-v-dba44f66],.auth-input-wrap:focus-within .auth-input-icon[data-v-dba44f66],.input-wrap input:focus+.login-icon[data-v-dba44f66]{color:var(--auth-primary)}.auth-input[data-v-dba44f66]:disabled,.input-wrap input[data-v-dba44f66]:disabled{opacity:.6;cursor:not-allowed}.auth-password-toggle[data-v-dba44f66]{position:absolute;right:14px;background:transparent;border:none;color:var(--auth-text-light);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .3s}.auth-password-toggle[data-v-dba44f66]:hover,.auth-password-toggle[data-v-dba44f66]:focus{color:var(--auth-primary);outline:none}.icon-toggle[data-v-dba44f66]{width:20px;height:20px}.auth-error[data-v-dba44f66],.error-message[data-v-dba44f66]{display:flex;align-items:center;gap:8px;padding:12px 14px;background:var(--auth-error-bg);border:1px solid var(--auth-error-border);border-radius:10px;color:var(--color-red-300);font-size:.875rem}.error-icon[data-v-dba44f66]{width:18px;height:18px;flex-shrink:0}.auth-options[data-v-dba44f66]{display:flex;justify-content:space-between;align-items:center}.auth-checkbox-label[data-v-dba44f66]{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--auth-text-medium);cursor:pointer}.auth-checkbox[data-v-dba44f66]{width:16px;height:16px;accent-color:var(--auth-primary);cursor:pointer}.auth-forgot-link[data-v-dba44f66]{font-size:.875rem;color:var(--auth-primary);text-decoration:none;transition:color .3s}.auth-forgot-link[data-v-dba44f66]:hover{color:var(--auth-primary-hover);text-decoration:underline}.auth-submit-btn[data-v-dba44f66],.login-button[data-v-dba44f66]{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 24px;background:linear-gradient(135deg,var(--auth-primary) 0%,var(--auth-primary-hover) 100%);border:none;border-radius:12px;font-size:1rem;font-weight:600;color:var(--auth-white);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px rgba(var(--color-primary-rgb),.3);letter-spacing:.5px}.auth-submit-btn[data-v-dba44f66]:hover:not(:disabled),.login-button[data-v-dba44f66]:hover:not(:disabled){background:linear-gradient(135deg,var(--auth-primary-hover) 0%,var(--auth-primary) 100%);box-shadow:0 6px 20px rgba(var(--color-primary-rgb),.4);transform:translateY(-2px)}.auth-submit-btn[data-v-dba44f66]:active:not(:disabled){transform:translateY(0)}.auth-submit-btn[data-v-dba44f66]:disabled,.login-button[data-v-dba44f66]:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-icon[data-v-dba44f66]{width:20px;height:20px}.btn-icon.spin[data-v-dba44f66]{animation:spin-dba44f66 1s linear infinite}@keyframes spin-dba44f66{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-footer[data-v-dba44f66],.login-footer[data-v-dba44f66]{text-align:center;margin-top:24px}.auth-footer p[data-v-dba44f66],.login-footer p[data-v-dba44f66]{color:var(--auth-text-medium);font-size:.9rem;margin:0}.auth-link[data-v-dba44f66],.login-link[data-v-dba44f66]{color:var(--auth-primary);text-decoration:none;font-weight:500;transition:color .3s}.auth-link[data-v-dba44f66]:hover,.login-link[data-v-dba44f66]:hover{color:var(--auth-primary-hover);text-decoration:underline}.recaptcha-notice[data-v-dba44f66]{margin-top:16px;text-align:center}.recaptcha-notice p[data-v-dba44f66]{font-size:11px;color:var(--auth-text-light);line-height:1.5;margin:0}.recaptcha-notice a[data-v-dba44f66]{color:var(--auth-primary);text-decoration:none;transition:color .2s}.recaptcha-notice a[data-v-dba44f66]:hover{color:var(--auth-primary-hover);text-decoration:underline}.auth-terms-group[data-v-dba44f66]{padding:12px 14px;background:var(--auth-bg-light);border:1.5px solid var(--auth-border);border-radius:10px}.terms-label[data-v-dba44f66]{align-items:flex-start!important}.terms-label .auth-checkbox[data-v-dba44f66]{margin-top:2px;flex-shrink:0}.terms-text[data-v-dba44f66]{font-size:.875rem;color:var(--auth-text-medium);line-height:1.5}.terms-link[data-v-dba44f66]{color:var(--auth-primary);text-decoration:none;font-weight:500;transition:color .2s}.terms-link[data-v-dba44f66]:hover{color:var(--auth-primary-hover);text-decoration:underline}.auth-bottom-row[data-v-dba44f66]{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:32px}.theme-toggle-btn[data-v-dba44f66]{display:flex;align-items:center;justify-content:center;width:42px;height:42px;background:var(--auth-bg-light);border:1px solid var(--auth-border);border-radius:10px;color:var(--auth-text-dark);cursor:pointer;transition:all .3s;flex-shrink:0}.theme-toggle-btn[data-v-dba44f66]:hover{background:var(--auth-primary);border-color:var(--auth-primary);color:#fff;transform:scale(1.05)}.theme-icon[data-v-dba44f66]{width:18px;height:18px}.auth-lang-selector[data-v-dba44f66],.lang-popup-switch[data-v-dba44f66]{position:relative;display:flex;justify-content:center}.lang-btn[data-v-dba44f66],.flag-btn[data-v-dba44f66]{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--auth-bg-light);border:1px solid var(--auth-border);border-radius:10px;color:var(--auth-text-dark);font-size:.875rem;cursor:pointer;transition:all .3s}.lang-btn[data-v-dba44f66]:hover,.flag-btn[data-v-dba44f66]:hover{background:#efefef;border-color:var(--color-gray-ccc)}.lang-icon[data-v-dba44f66],.flag-img[data-v-dba44f66]{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.chevron-icon[data-v-dba44f66]{width:16px;height:16px;transition:transform .3s}.chevron-icon.rotate[data-v-dba44f66]{transform:rotate(180deg)}.lang-dropdown[data-v-dba44f66],.lang-popup-dropdown[data-v-dba44f66]{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;background:var(--auth-white);border:1px solid var(--auth-border);border-radius:10px;box-shadow:0 4px 12px rgba(var(--color-black-rgb),.1);overflow:hidden;min-width:160px;z-index:20;display:flex;flex-direction:column}.lang-option[data-v-dba44f66],.lang-popup-option[data-v-dba44f66]{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:transparent;border:none;color:var(--auth-text-dark);font-size:.9rem;cursor:pointer;transition:background .2s}.lang-option[data-v-dba44f66]:hover,.lang-popup-option[data-v-dba44f66]:hover{background:var(--auth-bg-light);color:var(--auth-primary)}.lang-flag[data-v-dba44f66]{font-size:1.2rem}.fade-enter-active[data-v-dba44f66],.fade-leave-active[data-v-dba44f66]{transition:opacity .2s ease,transform .2s ease}.fade-enter-from[data-v-dba44f66],.fade-leave-to[data-v-dba44f66]{opacity:0;transform:translate(-50%) translateY(10px)}.auth-mobile-logo[data-v-dba44f66]{display:none}.auth-right-panel[data-v-dba44f66]{flex:1;align-items:center;justify-content:center;padding:20px 20px 40px;overflow:hidden}.hero-content[data-v-dba44f66]{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;max-width:600px}.hero-decoration[data-v-dba44f66]{position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(var(--color-white-rgb),.1);filter:blur(60px)}.hero-decoration.top-left[data-v-dba44f66]{top:-100px;left:-100px}.hero-decoration.bottom-right[data-v-dba44f66]{bottom:-100px;right:-100px}.hero-image-container[data-v-dba44f66]{position:relative;height:100%;max-width:800px;border-radius:24px;overflow:hidden;margin:10px 10px 20px}.hero-image[data-v-dba44f66]{width:100%;height:100%;display:block;-o-object-fit:cover;object-fit:cover}.hero-text[data-v-dba44f66]{text-align:center;margin-top:40px;position:relative;z-index:1}.hero-title[data-v-dba44f66]{font-size:2.5rem;font-weight:700;color:var(--auth-white);margin:0 0 16px;text-shadow:0 2px 10px rgba(var(--color-black-rgb),.2)}.hero-description[data-v-dba44f66]{font-size:1.1rem;color:rgba(var(--color-white-rgb),.9);line-height:1.6;margin:0}@media (max-width: 900px){.auth-right-panel[data-v-dba44f66]{display:none}.auth-left-panel[data-v-dba44f66],.login-container[data-v-dba44f66]{flex:1 1 100%}}@media (max-width: 600px){.auth-mobile-logo[data-v-dba44f66]{display:flex;justify-content:center;margin-bottom:16px}.auth-mobile-logo img[data-v-dba44f66]{width:160px;height:auto;-o-object-fit:contain;object-fit:contain}.login-layout[data-v-dba44f66],.auth-wrapper[data-v-dba44f66]{overflow-y:auto;overflow-x:hidden;height:100vh;max-height:100vh;-webkit-overflow-scrolling:touch}.auth-left-panel[data-v-dba44f66],.login-container[data-v-dba44f66]{flex:1 1 100%;padding:48px 20px 24px;overflow:visible;min-height:100vh;height:auto;align-items:flex-start}.auth-form-container[data-v-dba44f66],.login-card[data-v-dba44f66]{max-width:100%;width:100%;padding:0}.auth-title[data-v-dba44f66],.login-title[data-v-dba44f66]{font-size:1.6rem}.auth-subtitle[data-v-dba44f66]{font-size:.9rem}.auth-header[data-v-dba44f66],.login-header[data-v-dba44f66]{margin-bottom:24px}.auth-form[data-v-dba44f66],.login-form[data-v-dba44f66]{gap:16px}.auth-input[data-v-dba44f66],.input-wrap input[data-v-dba44f66]{padding:12px 12px 12px 44px;font-size:.9rem}.auth-submit-btn[data-v-dba44f66],.login-button[data-v-dba44f66]{padding:12px 20px;font-size:.95rem}.auth-options[data-v-dba44f66]{flex-wrap:wrap;gap:8px}.auth-bottom-row[data-v-dba44f66]{margin-top:24px}.auth-right-panel[data-v-dba44f66]{display:none}}.modal-large[data-v-291aa972]{max-width:640px}.screen-info-card[data-v-291aa972]{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;margin-bottom:12px}.screen-icon[data-v-291aa972]{color:var(--color-primary)}.screen-details h4[data-v-291aa972]{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--color-text-primary)}.screen-details p[data-v-291aa972]{margin:0;font-size:13px;color:var(--color-text-muted)}.section-header[data-v-291aa972]{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--color-border-light)}.section-header h4[data-v-291aa972]{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.add-share-form[data-v-291aa972]{margin-bottom:16px;padding:12px;background:var(--color-surface-raised);border-radius:8px}.form-row[data-v-291aa972]{display:flex;gap:12px;margin-bottom:12px}.form-row[data-v-291aa972]:last-child{margin-bottom:0}.flex-1[data-v-291aa972]{flex:1}.flex-2[data-v-291aa972]{flex:2}.form-actions[data-v-291aa972]{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}.form-select[data-v-291aa972]{cursor:pointer}.error-message[data-v-291aa972]{display:flex;align-items:center;gap:8px;padding:12px;background:var(--color-red-bg);border:1px solid var(--color-red-bg);border-radius:8px;color:var(--color-red-hover);font-size:13px;margin-bottom:16px}.empty-state-small[data-v-291aa972]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;color:var(--color-text-subtle)}.empty-state-small .empty-icon[data-v-291aa972]{color:var(--color-border-medium);margin-bottom:8px}.empty-state-small p[data-v-291aa972]{margin:0;font-size:14px}.shares-list[data-v-291aa972]{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.share-item[data-v-291aa972]{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:all .2s}.share-item[data-v-291aa972]:hover{border-color:var(--color-text-subtle);box-shadow:0 2px 4px rgba(var(--color-black-rgb),.05)}.share-user-info[data-v-291aa972]{display:flex;align-items:center;gap:10px;flex:2;min-width:0}.user-avatar[data-v-291aa972]{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0}.user-details[data-v-291aa972]{display:flex;flex-direction:column;min-width:0}.user-name[data-v-291aa972]{font-size:13px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email[data-v-291aa972]{font-size:11px;color:var(--color-text-subtle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-permissions[data-v-291aa972],.share-expiry[data-v-291aa972]{flex:1}.expiry-badge[data-v-291aa972]{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--color-surface-overlay);border-radius:4px;font-size:11px;color:var(--color-text-muted)}.expiry-badge.expired[data-v-291aa972]{background:var(--color-red-bg);color:var(--color-red-hover)}.expiry-badge.permanent[data-v-291aa972]{background:var(--color-green-bg);color:var(--color-green-hover)}.share-actions[data-v-291aa972]{display:flex;gap:4px}.action-btn[data-v-291aa972]{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;cursor:pointer;transition:all .2s}.action-btn.btn-edit[data-v-291aa972]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white)}.action-btn.btn-edit[data-v-291aa972]:hover{box-shadow:0 2px 8px rgba(var(--color-blue-rgb),.4)}.action-btn.btn-danger[data-v-291aa972]{background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);color:var(--color-white)}.action-btn.btn-danger[data-v-291aa972]:hover{box-shadow:0 2px 8px rgba(var(--color-red-500-rgb),.4)}.action-btn[data-v-291aa972]:disabled{opacity:.6;cursor:not-allowed}.btn-danger-outline[data-v-291aa972]{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--color-surface);color:var(--color-red-hover);border:1.5px solid var(--color-red-hover);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger-outline[data-v-291aa972]:hover:not(:disabled){background:var(--color-red-bg)}.btn-danger-outline[data-v-291aa972]:disabled{opacity:.6;cursor:not-allowed}.user-info-display[data-v-291aa972]{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;font-size:14px;color:var(--color-text-primary)}.modal-icon-share[data-v-291aa972]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%)!important;box-shadow:0 2px 8px rgba(var(--color-blue-rgb),.3)!important}.badge[data-v-291aa972]{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500}.badge-success[data-v-291aa972]{background:var(--color-green-bg);color:var(--color-green-hover)}.badge-warning[data-v-291aa972]{background:var(--color-orange-200);color:var(--color-primary-hover)}[data-theme=dark] .badge-warning[data-v-291aa972]{background:rgba(var(--color-amber-600-rgb),.2);color:var(--color-amber-400)}[data-theme=dark] .empty-state-small .empty-icon[data-v-291aa972]{color:var(--color-text-subtle)}.badge-info[data-v-291aa972]{background:var(--color-blue-bg);color:var(--color-blue-hover)}.badge-neutral[data-v-291aa972]{background:var(--color-surface-overlay);color:var(--color-text-muted)}.icon-spin[data-v-291aa972]{animation:spin 1s linear infinite}.form-group[data-v-291aa972]{margin-bottom:0}.form-label[data-v-291aa972]{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--color-text-primary)}.required[data-v-291aa972]{color:var(--color-red-500)}.form-input[data-v-291aa972]{width:100%;padding:8px 12px;border:1.5px solid var(--color-border);border-radius:8px;font-size:14px;color:var(--color-text-primary);background:var(--color-surface);outline:none;transition:all .2s}.form-input[data-v-291aa972]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-hint[data-v-291aa972]{display:block;margin-top:4px;font-size:11px;color:var(--color-text-subtle)}.btn[data-v-291aa972]{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-sm[data-v-291aa972]{padding:8px 14px;font-size:13px}.btn-primary[data-v-291aa972]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white)}.btn-primary[data-v-291aa972]:hover:not(:disabled){box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35)}.btn-primary[data-v-291aa972]:disabled{opacity:.6;cursor:not-allowed}.modal-fade-enter-active[data-v-291aa972],.modal-fade-leave-active[data-v-291aa972]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-291aa972],.modal-fade-leave-to[data-v-291aa972]{opacity:0}.modal-overlay[data-v-291aa972]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-overlay-nested[data-v-291aa972]{z-index:1100;background:rgba(var(--color-black-rgb),.65)}.modal-container[data-v-291aa972]{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;width:100%;max-height:90vh;overflow:hidden;box-shadow:0 20px 25px -5px rgba(var(--color-black-rgb),.1);display:flex;flex-direction:column}.modal-small[data-v-291aa972]{max-width:420px}.modal-header[data-v-291aa972]{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border-light)}.modal-title-section[data-v-291aa972]{display:flex;align-items:center;gap:12px}.modal-icon[data-v-291aa972]{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-white);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%)}.modal-header h3[data-v-291aa972]{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-291aa972]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:8px;border-radius:6px;transition:all .2s}.modal-close[data-v-291aa972]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-body[data-v-291aa972]{padding:16px;overflow-y:auto;flex:1}.modal-footer[data-v-291aa972]{display:flex;justify-content:flex-end;gap:8px;padding:11px 16px;border-top:1px solid var(--color-border-light)}.permanent-toggle[data-v-291aa972]{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-primary);cursor:pointer;margin-bottom:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.permanent-hint[data-v-291aa972]{font-size:12px;color:var(--color-text-muted);font-style:italic}.btn-cancel[data-v-291aa972]{padding:10px 16px;background:var(--color-surface);color:var(--color-text-muted);border:1.5px solid var(--color-border);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel[data-v-291aa972]:hover{background:var(--color-surface-raised);border-color:var(--color-text-subtle)}.btn-save[data-v-291aa972]{display:flex;align-items:center;gap:6px;padding:10px 16px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-save[data-v-291aa972]:hover:not(:disabled){box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35)}.btn-save[data-v-291aa972]:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 640px){.modal-overlay[data-v-291aa972]{padding:12px;align-items:flex-end}.modal-container[data-v-291aa972]{max-height:92vh;border-radius:12px}.modal-large[data-v-291aa972]{max-width:100%}.modal-body[data-v-291aa972]{padding:14px}.form-row[data-v-291aa972]{flex-direction:column;gap:10px}.flex-2[data-v-291aa972],.flex-1[data-v-291aa972]{flex:none;width:100%}.add-share-form[data-v-291aa972]{padding:12px}.share-item[data-v-291aa972]{flex-wrap:wrap;gap:8px}.share-user-info[data-v-291aa972]{flex:1 1 100%;min-width:0}.share-permissions[data-v-291aa972],.share-expiry[data-v-291aa972]{flex:0 0 auto}.share-actions[data-v-291aa972]{flex:0 0 auto;margin-left:auto}.shares-list[data-v-291aa972]{max-height:220px}.modal-footer[data-v-291aa972]{flex-wrap:wrap;gap:8px;padding:12px 14px}.btn-danger-outline[data-v-291aa972]{flex:1;justify-content:center}.btn-cancel[data-v-291aa972]{flex:1;text-align:center;justify-content:center}}.scada-list-view[data-v-875c3e27]{padding:15px;max-width:100%;overflow-x:hidden;display:flex;flex-direction:column;min-height:100%;box-sizing:border-box}.page-header[data-v-875c3e27]{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h2[data-v-875c3e27]{font-size:20px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.header-subtitle[data-v-875c3e27]{margin:0;color:var(--color-text-muted);font-size:13px;display:flex;align-items:center;gap:8px}.stat-item[data-v-875c3e27]{display:inline-flex;align-items:center;gap:4px}.stat-item.stat-shared[data-v-875c3e27]{color:var(--color-purple-hover)}.stat-divider[data-v-875c3e27]{color:var(--color-border-medium)}.header-actions[data-v-875c3e27]{display:flex;gap:8px}.btn[data-v-875c3e27]{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-md[data-v-875c3e27]{padding:8px 16px}.btn-sm[data-v-875c3e27]{padding:6px 12px;font-size:13px}.search-box[data-v-875c3e27]{position:relative;display:flex;align-items:center}.search-icon[data-v-875c3e27]{position:absolute;left:10px;color:var(--color-text-subtle);pointer-events:none}.search-input[data-v-875c3e27]{padding:6px 12px 6px 32px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;outline:none;transition:all .2s;color:var(--color-text-primary);background:var(--color-input-bg);height:36px;box-sizing:border-box}.search-input[data-v-875c3e27]:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.1)}.search-input[data-v-875c3e27]::-moz-placeholder{color:var(--color-text-subtle)}.search-input[data-v-875c3e27]::placeholder{color:var(--color-text-subtle)}.btn-primary[data-v-875c3e27]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white)}.btn-primary[data-v-875c3e27]:hover{background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary-700) 100%);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.btn-secondary[data-v-875c3e27]{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary[data-v-875c3e27]:hover:not(:disabled){background:var(--color-surface-raised);border-color:var(--color-border-medium)}.btn-secondary[data-v-875c3e27]:disabled{opacity:.6;cursor:not-allowed}.filter-btn[data-v-875c3e27]{position:relative;background:var(--color-surface);color:var(--color-text-muted);border:1.5px solid var(--color-border);transition:all .2s}.filter-btn[data-v-875c3e27]:hover{border-color:var(--color-violet-500);color:var(--color-violet-500);background:rgba(var(--color-violet-500-rgb),.12)}.filter-btn.filter-active[data-v-875c3e27]{background:linear-gradient(135deg,var(--color-violet-500) 0%,var(--color-violet-600) 100%);color:var(--color-white);border-color:transparent}.filter-btn.filter-active[data-v-875c3e27]:hover{box-shadow:0 6px 20px rgba(var(--color-violet-500-rgb),.45);transform:translateY(-1px)}.filter-badge[data-v-875c3e27]{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;background:rgba(var(--color-white-rgb),.25);border-radius:9px;font-size:11px;font-weight:600}.filter-btn:not(.filter-active) .filter-badge[data-v-875c3e27]{background:var(--color-violet-500);color:var(--color-white)}.error-message[data-v-875c3e27]{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--color-red-bg);border:1px solid var(--color-red-border);border-radius:12px;color:var(--color-red);font-size:14px}.empty-state[data-v-875c3e27]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon[data-v-875c3e27]{color:var(--color-text-subtle);margin-bottom:16px}.empty-state h3[data-v-875c3e27]{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--color-text-secondary)}.empty-state p[data-v-875c3e27]{margin:0 0 24px;color:var(--color-text-muted);font-size:14px}.empty-state p.no-devices-warning[data-v-875c3e27]{display:flex;align-items:center;gap:8px;color:var(--color-yellow);background:var(--color-yellow-bg);padding:12px 16px;border-radius:8px;border:1px solid var(--color-yellow-border)}.scada-grid[data-v-875c3e27]{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}@media (max-width: 1600px){.scada-grid[data-v-875c3e27]{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1200px){.scada-grid[data-v-875c3e27]{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.scada-grid[data-v-875c3e27]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.scada-list-view[data-v-875c3e27]{padding:10px}.card-actions[data-v-875c3e27]{gap:6px}.action-btn[data-v-875c3e27]{width:34px;height:34px;border-radius:8px}}@media (max-width: 600px){.scada-grid[data-v-875c3e27]{grid-template-columns:1fr}.page-header[data-v-875c3e27]{flex-direction:column;gap:12px;align-items:stretch}.header-actions[data-v-875c3e27]{flex-wrap:wrap;gap:8px}.search-box[data-v-875c3e27]{flex:1;min-width:0}.search-input[data-v-875c3e27]{width:100%}.filter-btn[data-v-875c3e27],.btn-primary[data-v-875c3e27]{flex:0 0 auto;white-space:nowrap}}.scada-card[data-v-875c3e27]{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);border-radius:10px;padding:12px;display:flex;flex-direction:column;transition:all .2s}.scada-card[data-v-875c3e27]:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-header[data-v-875c3e27]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;border-bottom:none;padding:0;background:transparent}.card-icon[data-v-875c3e27]{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-white);box-shadow:0 2px 4px rgba(var(--color-primary-rgb),.2)}.card-status[data-v-875c3e27]{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.2px}.status-active[data-v-875c3e27]{background:var(--color-green-bg);color:var(--color-green-hover)}.status-inactive[data-v-875c3e27]{background:var(--color-surface-overlay);color:var(--color-text-muted)}.status-shared[data-v-875c3e27]{display:flex;align-items:center;gap:3px;background:var(--color-purple-bg);color:var(--color-purple-hover)}.status-shared.status-shared-full[data-v-875c3e27]{background:var(--color-primary-bg);color:var(--color-primary-hover)}.status-shared.status-shared-control[data-v-875c3e27]{background:var(--color-blue-bg);color:var(--color-blue-hover)}.status-shared.status-shared-view[data-v-875c3e27]{background:var(--color-surface-overlay);color:var(--color-text-muted)}.scada-card.shared-card[data-v-875c3e27]{border-color:var(--color-purple-border);background:var(--color-purple-bg)}.card-body[data-v-875c3e27]{flex:1;margin-bottom:8px}.card-title[data-v-875c3e27]{margin:0 0 4px;font-size:13px;font-weight:600;color:var(--color-text-primary);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-desc[data-v-875c3e27]{margin:0 0 6px;font-size:11px;color:var(--color-text-muted);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta[data-v-875c3e27]{display:flex;flex-wrap:wrap;gap:8px}.meta-item[data-v-875c3e27]{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--color-text-subtle)}.meta-item.shared-by[data-v-875c3e27]{color:var(--color-purple-hover);font-weight:500}.card-actions[data-v-875c3e27]{display:flex;gap:4px;padding-top:8px;border-top:1px solid var(--color-border-light)}.action-btn[data-v-875c3e27]{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;cursor:pointer;transition:all .2s;border:none}.action-btn.btn-view[data-v-875c3e27]{color:var(--color-white);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%)}.action-btn.btn-view[data-v-875c3e27]:hover{box-shadow:0 4px 12px rgba(var(--color-blue-rgb),.35);transform:translateY(-1px)}.action-btn.btn-edit[data-v-875c3e27]{color:var(--color-white);background:linear-gradient(135deg,var(--color-success-500) 0%,var(--color-success-600) 100%)}.action-btn.btn-edit[data-v-875c3e27]:hover{box-shadow:0 4px 12px rgba(var(--color-success-rgb),.35);transform:translateY(-1px)}.action-btn.btn-danger[data-v-875c3e27]{color:var(--color-white);background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%)}.action-btn.btn-danger[data-v-875c3e27]:hover{box-shadow:0 4px 12px rgba(var(--color-red-500-rgb),.35);transform:translateY(-1px)}.action-btn.btn-leave[data-v-875c3e27]{color:var(--color-white);background:linear-gradient(135deg,var(--color-slate-500) 0%,var(--color-slate-600) 100%)}.action-btn.btn-leave[data-v-875c3e27]:hover{box-shadow:0 4px 12px rgba(var(--color-slate-500-rgb, 100, 116, 139),.35);transform:translateY(-1px)}.action-btn.btn-settings[data-v-875c3e27]{color:var(--color-white);background:linear-gradient(135deg,var(--color-violet-500) 0%,var(--color-violet-600) 100%)}.action-btn.btn-settings[data-v-875c3e27]:hover{box-shadow:0 4px 12px rgba(var(--color-violet-500-rgb),.35);transform:translateY(-1px)}.action-btn.btn-share[data-v-875c3e27]{color:var(--color-white);background:linear-gradient(135deg,var(--color-yellow) 0%,var(--color-amber-600) 100%)}.action-btn.btn-share[data-v-875c3e27]:hover{box-shadow:0 4px 12px rgba(var(--color-amber-rgb),.35);transform:translateY(-1px)}.modal-fade-enter-active[data-v-875c3e27],.modal-fade-leave-active[data-v-875c3e27]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-875c3e27],.modal-fade-leave-to[data-v-875c3e27]{opacity:0}.modal-fade-enter-active .modal-container[data-v-875c3e27],.modal-fade-leave-active .modal-container[data-v-875c3e27]{transition:transform .3s ease}.modal-fade-enter-from .modal-container[data-v-875c3e27],.modal-fade-leave-to .modal-container[data-v-875c3e27]{transform:scale(.95)}.modal-overlay[data-v-875c3e27]{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(var(--color-black-rgb),.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container[data-v-875c3e27]{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.modal-small[data-v-875c3e27]{max-width:420px}.modal-header[data-v-875c3e27]{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-875c3e27]{display:flex;align-items:center;gap:12px}.modal-icon[data-v-875c3e27]{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.modal-icon-danger[data-v-875c3e27]{background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);box-shadow:0 2px 8px rgba(var(--color-red-500-rgb),.3)}.modal-icon-info[data-v-875c3e27]{background:linear-gradient(135deg,var(--color-legacy-blue) 0%,var(--color-legacy-blue-dark) 100%);box-shadow:0 2px 8px rgba(var(--color-legacy-blue-rgb),.3)}.desktop-required-content[data-v-875c3e27]{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:12px 0}.desktop-icon-large[data-v-875c3e27]{color:var(--color-blue);opacity:.8;margin-bottom:4px}.desktop-hint[data-v-875c3e27]{margin:0;font-size:13px;color:var(--color-text-muted);line-height:1.6}.modal-header h3[data-v-875c3e27]{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-875c3e27]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;transition:all .2s}.modal-close[data-v-875c3e27]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-body[data-v-875c3e27]{padding:24px;overflow-y:auto;flex:1}.modal-text[data-v-875c3e27]{margin:0 0 8px;font-size:14px;color:var(--color-text-primary);line-height:1.5}.warning-text[data-v-875c3e27]{margin:0 0 16px;font-size:13px;color:var(--color-red);font-weight:500;padding:12px;background:var(--color-red-bg);border:1px solid var(--color-red-border);border-radius:8px}.modal-footer[data-v-875c3e27]{display:flex;justify-content:flex-end;gap:12px;padding:18px 24px;border-top:1px solid var(--color-border-light);background:var(--color-surface)}.form-group[data-v-875c3e27]{margin-bottom:18px}.form-group[data-v-875c3e27]:last-child{margin-bottom:0}.form-label[data-v-875c3e27]{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--color-text-primary)}.required[data-v-875c3e27]{color:var(--color-red);margin-left:2px}.form-input[data-v-875c3e27],.form-textarea[data-v-875c3e27]{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:8px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;color:var(--color-text-primary);background:var(--color-input-bg);box-sizing:border-box}.form-input[data-v-875c3e27]:hover,.form-textarea[data-v-875c3e27]:hover{border-color:var(--color-border-medium)}.form-input[data-v-875c3e27]:focus,.form-textarea[data-v-875c3e27]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-textarea[data-v-875c3e27]{resize:vertical;min-height:80px}.form-hint[data-v-875c3e27]{display:block;margin-top:6px;font-size:12px;color:var(--color-text-subtle)}.delete-input[data-v-875c3e27]{border-color:var(--color-red);font-family:monospace}.delete-input[data-v-875c3e27]:focus{border-color:var(--color-red);box-shadow:0 0 0 3px rgba(var(--color-red-rgb),.1)}.toggle-container[data-v-875c3e27]{display:flex;align-items:center;gap:12px}.toggle[data-v-875c3e27]{position:relative;display:inline-block;width:44px;height:24px}.toggle input[data-v-875c3e27]{opacity:0;width:0;height:0}.toggle-slider[data-v-875c3e27]{position:absolute;cursor:pointer;inset:0;background-color:var(--color-border);transition:.3s;border-radius:24px}.toggle-slider[data-v-875c3e27]:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:var(--color-surface);transition:.3s;border-radius:50%;box-shadow:0 1px 3px rgba(var(--color-black-rgb),.2)}.toggle input:checked+.toggle-slider[data-v-875c3e27]{background:linear-gradient(135deg,var(--color-success-500) 0%,var(--color-success-600) 100%)}.toggle input:checked+.toggle-slider[data-v-875c3e27]:before{transform:translate(20px)}.toggle-label[data-v-875c3e27]{font-size:14px;color:var(--color-text-secondary)}.btn-cancel[data-v-875c3e27],.btn-save[data-v-875c3e27],.btn-delete[data-v-875c3e27]{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-cancel[data-v-875c3e27]{background:var(--color-surface);color:var(--color-text-muted);border:1.5px solid var(--color-border)}.btn-cancel[data-v-875c3e27]:hover{background:var(--color-surface-raised);border-color:var(--color-text-subtle);color:var(--color-text-secondary)}.btn-save[data-v-875c3e27]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);box-shadow:0 1px 3px rgba(var(--color-primary-rgb),.2)}.btn-save[data-v-875c3e27]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary-700) 100%);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.btn-save[data-v-875c3e27]:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-delete[data-v-875c3e27]{background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);color:var(--color-white);box-shadow:0 1px 3px rgba(var(--color-red-500-rgb),.2)}.btn-delete[data-v-875c3e27]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-700) 100%);box-shadow:0 4px 12px rgba(var(--color-red-500-rgb),.35);transform:translateY(-1px)}.btn-delete[data-v-875c3e27]:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.icon-spin[data-v-875c3e27]{animation:spin 1s linear infinite}.modal-fade-enter-active[data-v-cca687a7],.modal-fade-leave-active[data-v-cca687a7]{transition:opacity .25s ease}.modal-fade-enter-from[data-v-cca687a7],.modal-fade-leave-to[data-v-cca687a7]{opacity:0}.modal-fade-enter-active .modal-container[data-v-cca687a7],.modal-fade-leave-active .modal-container[data-v-cca687a7]{transition:transform .25s ease}.modal-fade-enter-from .modal-container[data-v-cca687a7],.modal-fade-leave-to .modal-container[data-v-cca687a7]{transform:scale(.95)}.modal-overlay[data-v-cca687a7]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container[data-v-cca687a7]{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;width:100%;max-width:720px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-large[data-v-cca687a7]{max-width:720px}.modal-header[data-v-cca687a7]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-cca687a7]{display:flex;align-items:center;gap:10px}.modal-icon[data-v-cca687a7]{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-white);background:var(--gradient-primary);box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.3)}.modal-header h3[data-v-cca687a7]{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-cca687a7]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;transition:all .2s}.modal-close[data-v-cca687a7]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.share-tabs[data-v-cca687a7]{display:flex;border-bottom:1px solid var(--color-border-light);background:var(--color-surface);padding:0 16px;flex-shrink:0}.share-tab-btn[data-v-cca687a7]{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;font-size:12px;font-weight:500;color:var(--color-text-muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .18s,border-color .18s;margin-bottom:-1px}.share-tab-btn[data-v-cca687a7]:hover{color:var(--color-text-primary)}.share-tab-btn.is-active[data-v-cca687a7]{color:var(--color-primary);border-bottom-color:var(--color-primary)}.modal-body[data-v-cca687a7]{padding:16px;overflow-y:auto;flex:1}.tab-pane[data-v-cca687a7]{display:flex;flex-direction:column;gap:14px}.modal-body strong[data-v-cca687a7]{color:var(--color-text-primary);font-weight:600}.form-group[data-v-cca687a7]{display:flex;flex-direction:column;gap:5px}.form-row[data-v-cca687a7]{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.form-label[data-v-cca687a7]{display:block;font-weight:500;font-size:12px;color:var(--color-text-primary)}.required[data-v-cca687a7]{color:var(--color-red);margin-left:2px}.form-input[data-v-cca687a7]{width:100%;padding:7px 10px;border:1.5px solid var(--color-border);border-radius:7px;font-size:13px;outline:none;transition:border-color .18s,box-shadow .18s;font-family:inherit;color:var(--color-text-primary);background:var(--color-input-bg);box-sizing:border-box}.form-input[data-v-cca687a7]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12)}.form-textarea[data-v-cca687a7]{resize:vertical;min-height:56px;font-family:inherit}.form-hint[data-v-cca687a7]{margin:0;font-size:11px;color:var(--color-text-muted)}.form-label-row[data-v-cca687a7]{display:flex;justify-content:space-between;align-items:center;gap:8px}.forever-toggle[data-v-cca687a7]{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.forever-toggle input[type=checkbox][data-v-cca687a7]{accent-color:var(--color-primary);cursor:pointer;margin:0}.form-input[data-v-cca687a7]:disabled{opacity:.5;cursor:not-allowed;background:var(--color-surface-overlay)}.permission-options[data-v-cca687a7]{display:grid;grid-template-columns:1fr 1fr;gap:8px}.permission-option[data-v-cca687a7]{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;border:1.5px solid var(--color-border);border-radius:8px;cursor:pointer;transition:border-color .18s,background .18s;background:var(--color-surface)}.permission-option[data-v-cca687a7]:hover{border-color:var(--color-primary-border);background:var(--color-surface-raised)}.permission-option.is-selected[data-v-cca687a7]{border-color:var(--color-primary);background:var(--color-primary-bg)}.permission-option input[type=radio][data-v-cca687a7]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;margin-top:2px;border:2px solid var(--color-border-medium);border-radius:50%;background:var(--color-surface);cursor:pointer;position:relative;flex-shrink:0;transition:border-color .15s,background .15s}.permission-option input[type=radio][data-v-cca687a7]:hover{border-color:var(--color-primary)}.permission-option input[type=radio][data-v-cca687a7]:checked{border-color:var(--color-primary);background:var(--color-primary)}.permission-option input[type=radio][data-v-cca687a7]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background:var(--color-white)}.permission-option-content[data-v-cca687a7]{display:flex;flex-direction:column;gap:2px}.permission-option-title[data-v-cca687a7]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--color-text-primary)}.permission-option-desc[data-v-cca687a7]{font-size:11px;color:var(--color-text-muted)}.form-actions[data-v-cca687a7]{display:flex;justify-content:flex-end;gap:8px;padding-top:4px}.btn-save[data-v-cca687a7]{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;background:var(--gradient-primary);color:var(--color-white);transition:background .18s,box-shadow .18s,transform .18s;box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.32)}.btn-save[data-v-cca687a7]:hover:not(:disabled){background:var(--gradient-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35)}.btn-save[data-v-cca687a7]:disabled{opacity:.6;cursor:not-allowed}.qr-result[data-v-cca687a7]{margin-top:16px;padding-top:14px;border-top:1px solid var(--color-border-light);display:flex;flex-direction:column;align-items:center;gap:8px}.qr-canvas-wrapper[data-v-cca687a7]{display:flex;justify-content:center;padding:12px;background:var(--color-surface-sunken);border-radius:8px;border:1px solid var(--color-border-light)}.qr-canvas-wrapper canvas[data-v-cca687a7]{display:block}.qr-code-label[data-v-cca687a7]{font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.qr-sharecode[data-v-cca687a7]{font-family:SFMono-Regular,Consolas,Monaco,monospace;letter-spacing:.1em;font-size:17px;font-weight:600;color:var(--color-text-primary);text-align:center}.qr-meta[data-v-cca687a7]{display:flex;gap:16px;font-size:12px;color:var(--color-text-muted);flex-wrap:wrap;justify-content:center}.qr-meta strong[data-v-cca687a7]{color:var(--color-text-primary);font-weight:600}.qr-actions[data-v-cca687a7]{display:flex;gap:8px;justify-content:center;margin-top:4px}.btn-secondary-action[data-v-cca687a7]{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border:1.5px solid var(--color-border);border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;background:var(--color-surface);color:var(--color-text-primary);transition:background .18s,border-color .18s}.btn-secondary-action[data-v-cca687a7]:hover{background:var(--color-surface-raised);border-color:var(--color-primary);color:var(--color-primary)}.manage-loading[data-v-cca687a7]{display:flex;align-items:center;justify-content:center;gap:8px;padding:28px 0;color:var(--color-text-muted);font-size:13px}.manage-section[data-v-cca687a7]{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.manage-section[data-v-cca687a7]:last-child{margin-bottom:0}.manage-section-title[data-v-cca687a7]{margin:0;font-size:12px;font-weight:600;color:var(--color-text-secondary)}.manage-empty[data-v-cca687a7]{padding:14px 12px;text-align:center;font-size:12px;color:var(--color-text-muted);background:var(--color-surface-sunken);border-radius:7px;border:1px dashed var(--color-border-light)}.manage-list[data-v-cca687a7]{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.manage-item[data-v-cca687a7]{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:7px}.manage-item-info[data-v-cca687a7]{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.manage-item-primary[data-v-cca687a7]{font-size:13px;font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manage-item-code[data-v-cca687a7]{font-family:SFMono-Regular,Consolas,Monaco,monospace;letter-spacing:.05em}.manage-item-meta[data-v-cca687a7]{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:var(--color-text-muted)}.manage-item-expire[data-v-cca687a7],.manage-item-uses[data-v-cca687a7]{display:inline-flex;align-items:center;gap:3px}.permission-pill[data-v-cca687a7]{display:inline-block;padding:2px 7px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.permission-pill.pill-full[data-v-cca687a7]{background:var(--color-primary-bg);color:var(--color-primary-hover)}.permission-pill.pill-view[data-v-cca687a7]{background:var(--color-surface-overlay);color:var(--color-text-secondary)}.btn-revoke[data-v-cca687a7]{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;background:transparent;border:1.5px solid var(--color-red-border);border-radius:6px;font-size:11px;font-weight:500;color:var(--color-red);cursor:pointer;transition:background .18s,color .18s}.btn-revoke[data-v-cca687a7]:hover{background:var(--color-red-bg);color:var(--color-red-hover)}.icon-spin[data-v-cca687a7]{animation:spin-cca687a7 1s linear infinite}@keyframes spin-cca687a7{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 640px){.modal-container[data-v-cca687a7]{max-width:calc(100vw - 24px)}.form-row[data-v-cca687a7],.permission-options[data-v-cca687a7]{grid-template-columns:1fr}.qr-meta[data-v-cca687a7]{flex-direction:column;gap:4px;align-items:center}}.modal-fade-enter-active[data-v-4f6403b9],.modal-fade-leave-active[data-v-4f6403b9]{transition:opacity .25s ease}.modal-fade-enter-from[data-v-4f6403b9],.modal-fade-leave-to[data-v-4f6403b9]{opacity:0}.modal-fade-enter-active .modal-container[data-v-4f6403b9],.modal-fade-leave-active .modal-container[data-v-4f6403b9]{transition:transform .25s ease}.modal-fade-enter-from .modal-container[data-v-4f6403b9],.modal-fade-leave-to .modal-container[data-v-4f6403b9]{transform:scale(.95)}.modal-overlay[data-v-4f6403b9]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container[data-v-4f6403b9]{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-small[data-v-4f6403b9]{max-width:480px}.modal-header[data-v-4f6403b9]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-4f6403b9]{display:flex;align-items:center;gap:10px}.modal-icon[data-v-4f6403b9]{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-white);background:var(--gradient-primary);box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.3)}.modal-header h3[data-v-4f6403b9]{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-4f6403b9]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;transition:all .2s}.modal-close[data-v-4f6403b9]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-body[data-v-4f6403b9]{padding:16px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:14px}.modal-subtitle[data-v-4f6403b9]{margin:0;font-size:12px;color:var(--color-text-muted)}.modal-footer[data-v-4f6403b9]{display:flex;justify-content:flex-end;gap:8px;padding:11px 16px;border-top:1px solid var(--color-border-light)}.btn-cancel[data-v-4f6403b9]{padding:7px 14px;border:1.5px solid var(--color-border);border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;background:var(--color-surface);color:var(--color-text-muted);transition:all .2s}.btn-cancel[data-v-4f6403b9]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.btn-save[data-v-4f6403b9]{display:flex;align-items:center;gap:5px;padding:7px 14px;border:none;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;background:var(--gradient-primary);color:var(--color-white);transition:all .2s}.btn-save[data-v-4f6403b9]:hover:not(:disabled){background:var(--gradient-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.btn-save[data-v-4f6403b9]:disabled{opacity:.6;cursor:not-allowed}.form-section[data-v-4f6403b9]{display:flex;flex-direction:column}.form-label[data-v-4f6403b9]{display:block;margin-bottom:6px;font-weight:500;font-size:12px;color:var(--color-text-primary)}.required[data-v-4f6403b9]{color:var(--color-red);margin-left:2px}.input-row[data-v-4f6403b9]{display:flex;gap:8px;align-items:stretch}.form-input.code-input[data-v-4f6403b9]{flex:1;padding:9px 12px;border:1.5px solid var(--color-border);border-radius:8px;font-size:15px;font-family:Courier New,monospace;letter-spacing:.16em;text-transform:uppercase;outline:none;transition:all .2s;background:var(--color-input-bg);color:var(--color-text-primary);text-align:center;font-weight:600}.form-input.code-input[data-v-4f6403b9]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12)}.form-input.code-input[data-v-4f6403b9]::-moz-placeholder{color:var(--color-text-muted);font-weight:500;opacity:.5}.form-input.code-input[data-v-4f6403b9]::placeholder{color:var(--color-text-muted);font-weight:500;opacity:.5}.btn-preview[data-v-4f6403b9]{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border:1.5px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-preview[data-v-4f6403b9]:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-bg)}.btn-preview[data-v-4f6403b9]:disabled{opacity:.55;cursor:not-allowed}.empty-state[data-v-4f6403b9]{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px;text-align:center;background:var(--color-surface-sunken);border:1px dashed var(--color-border-medium);border-radius:10px}.expired-state .empty-icon[data-v-4f6403b9]{color:var(--color-yellow)}.empty-text[data-v-4f6403b9]{margin:0;font-size:12px;color:var(--color-text-secondary)}.preview-block[data-v-4f6403b9]{background:var(--color-surface-sunken);border:1px solid var(--color-border-light);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px}.preview-row[data-v-4f6403b9]{display:flex;flex-direction:column;gap:5px}.preview-label[data-v-4f6403b9]{font-size:10px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.preview-owner[data-v-4f6403b9]{display:flex;align-items:center;gap:10px}.owner-avatar[data-v-4f6403b9]{width:34px;height:34px;border-radius:50%;background:var(--gradient-primary);color:var(--color-white);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.owner-info[data-v-4f6403b9]{display:flex;flex-direction:column;gap:2px;min-width:0}.owner-name[data-v-4f6403b9]{font-size:13px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.owner-meta[data-v-4f6403b9]{font-size:11px;color:var(--color-text-secondary);display:flex;flex-wrap:wrap;gap:6px;align-items:center}.owner-meta strong[data-v-4f6403b9]{color:var(--color-text-primary);font-weight:600}.device-code-chip[data-v-4f6403b9]{display:inline-block;padding:2px 6px;background:var(--color-surface-overlay);color:var(--color-text-muted);border:1px solid var(--color-border-light);border-radius:4px;font-family:Courier New,monospace;font-size:10px}.permission-badge[data-v-4f6403b9]{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:6px;font-size:11px;font-weight:600;width:-moz-fit-content;width:fit-content}.permission-full[data-v-4f6403b9]{background:var(--color-success-100);color:var(--color-success-700);border:1px solid var(--color-success-300)}.permission-view[data-v-4f6403b9]{background:var(--color-blue-bg);color:var(--color-blue-hover);border:1px solid var(--color-blue-100)}.validity-chip[data-v-4f6403b9]{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:6px;font-size:11px;font-weight:500;width:-moz-fit-content;width:fit-content}.validity-forever[data-v-4f6403b9]{background:var(--color-primary-bg);color:var(--color-primary-hover);border:1px solid var(--color-primary-border)}.validity-active[data-v-4f6403b9]{background:var(--color-amber-100);color:var(--color-amber-700);border:1px solid var(--color-amber-300)}.validity-expired[data-v-4f6403b9]{background:var(--color-red-bg);color:var(--color-red-hover);border:1px solid var(--color-red-border)}.icon-spin[data-v-4f6403b9]{animation:spin-4f6403b9 1s linear infinite}@keyframes spin-4f6403b9{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 480px){.input-row[data-v-4f6403b9]{flex-direction:column}.btn-preview[data-v-4f6403b9]{justify-content:center}}.modal-fade-enter-active[data-v-b30594a0],.modal-fade-leave-active[data-v-b30594a0]{transition:opacity .25s ease}.modal-fade-enter-from[data-v-b30594a0],.modal-fade-leave-to[data-v-b30594a0]{opacity:0}.modal-fade-enter-active .modal-container[data-v-b30594a0],.modal-fade-leave-active .modal-container[data-v-b30594a0]{transition:transform .25s ease}.modal-fade-enter-from .modal-container[data-v-b30594a0],.modal-fade-leave-to .modal-container[data-v-b30594a0]{transform:scale(.95)}.modal-overlay[data-v-b30594a0]{position:fixed;inset:0;background:rgba(var(--color-black-rgb),.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container[data-v-b30594a0]{background:var(--color-surface);color:var(--color-text-primary);border-radius:12px;width:100%;max-width:420px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-header[data-v-b30594a0]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-b30594a0]{display:flex;align-items:center;gap:10px}.modal-icon[data-v-b30594a0]{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-white);background:var(--gradient-warning);box-shadow:0 2px 6px rgba(var(--color-amber-rgb),.3)}.modal-icon-warning[data-v-b30594a0]{background:var(--gradient-warning)}.modal-header h3[data-v-b30594a0]{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-b30594a0]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;transition:all .2s}.modal-close[data-v-b30594a0]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-body[data-v-b30594a0]{padding:16px;overflow-y:auto;flex:1}.modal-text-muted[data-v-b30594a0]{font-size:13px;color:var(--color-text-muted);margin:0 0 8px;line-height:1.5}.modal-text-muted strong[data-v-b30594a0]{color:var(--color-text-primary);font-weight:600}.modal-secondary[data-v-b30594a0]{margin-top:8px;font-size:12px}.modal-footer[data-v-b30594a0]{display:flex;justify-content:flex-end;gap:8px;padding:11px 16px;border-top:1px solid var(--color-border-light)}.btn-cancel[data-v-b30594a0]{padding:7px 14px;border:1.5px solid var(--color-border);border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;background:var(--color-surface);color:var(--color-text-muted);transition:all .2s}.btn-cancel[data-v-b30594a0]:hover:not(:disabled){background:var(--color-surface-overlay);color:var(--color-text-primary)}.btn-cancel[data-v-b30594a0]:disabled{opacity:.6;cursor:not-allowed}.btn-leave[data-v-b30594a0]{display:flex;align-items:center;gap:5px;padding:7px 14px;border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;background:var(--gradient-danger);color:var(--color-white);transition:all .2s}.btn-leave[data-v-b30594a0]:hover:not(:disabled){background:var(--gradient-danger-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-red-rgb),.3)}.btn-leave[data-v-b30594a0]:disabled{opacity:.6;cursor:not-allowed}.icon-spin[data-v-b30594a0]{animation:spin-b30594a0 1s linear infinite}@keyframes spin-b30594a0{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.device-all-view[data-v-d4eb2a72]{padding:10px;margin-bottom:5px;min-height:100%;display:flex;flex-direction:column;box-sizing:border-box}.device-all-header[data-v-d4eb2a72]{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.device-all-header h2[data-v-d4eb2a72]{font-size:17px;font-weight:600;color:var(--color-text-primary);margin:0 0 2px}.device-all-header p[data-v-d4eb2a72]{margin:0;color:var(--color-text-muted);font-size:12px}.header-subtitle[data-v-d4eb2a72]{display:flex;align-items:center;gap:8px;margin-top:4px}.stat-item[data-v-d4eb2a72]{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--color-text-muted)}.stat-dot[data-v-d4eb2a72]{width:8px;height:8px;border-radius:50%}.stat-dot.online[data-v-d4eb2a72]{background:var(--color-success-500)}.stat-dot.offline[data-v-d4eb2a72]{background:var(--color-red-500)}.stat-divider[data-v-d4eb2a72]{color:var(--color-border-medium)}.device-all-actions[data-v-d4eb2a72]{display:flex;gap:8px}.device-type-tabs[data-v-d4eb2a72]{display:flex;gap:6px;margin-bottom:10px;background:var(--color-surface);padding:8px 12px;border-radius:8px;border:1px solid var(--color-border);box-shadow:0 1px 4px rgba(var(--color-black-rgb),.06)}.tab-action-btn[data-v-d4eb2a72]{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1.5px solid var(--color-primary);background:var(--color-primary-bg);color:var(--color-primary-hover);border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;margin-left:auto}.tab-action-btn[data-v-d4eb2a72]:hover{background:var(--gradient-primary);color:var(--color-white);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.tab-btn[data-v-d4eb2a72]{display:flex;align-items:center;gap:6px;padding:6px 14px;border:none;background:transparent;border-radius:6px;font-size:13px;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all .2s}.tab-btn[data-v-d4eb2a72]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.tab-btn.active[data-v-d4eb2a72]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white)}.tab-btn.active[data-v-d4eb2a72]:hover{background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary) 100%)}.tab-count[data-v-d4eb2a72]{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;background:rgba(var(--color-black-rgb),.1)}.tab-btn.active .tab-count[data-v-d4eb2a72]{background:rgba(var(--color-white-rgb),.25)}.error-banner[data-v-d4eb2a72]{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-red-bg);border:1px solid var(--color-red-border);border-radius:8px;margin-bottom:16px;color:var(--color-red-hover);font-size:13px}.btn-retry[data-v-d4eb2a72]{margin-left:auto;padding:6px 12px;background:var(--color-red-500);color:var(--color-white);border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s}.btn-retry[data-v-d4eb2a72]:hover{background:var(--color-red)}.ws-status-banner[data-v-d4eb2a72]{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-yellow-bg);border:1px solid var(--color-yellow);border-radius:8px;margin-bottom:16px;color:var(--color-primary-hover);font-size:13px}.btn-reconnect[data-v-d4eb2a72]{margin-left:auto;padding:6px 12px;background:var(--color-yellow);color:var(--color-white);border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s}.btn-reconnect[data-v-d4eb2a72]:hover{background:var(--color-amber-600)}.btn[data-v-d4eb2a72]{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary[data-v-d4eb2a72]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white)}.btn-primary[data-v-d4eb2a72]:hover{background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary) 100%);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.btn-primary[data-v-d4eb2a72]:disabled{opacity:.6;cursor:not-allowed}.btn-secondary[data-v-d4eb2a72]{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary[data-v-d4eb2a72]:hover{background:var(--color-surface-raised);border-color:var(--color-gray-300-soft)}.btn-secondary[data-v-d4eb2a72]:disabled{opacity:.6;cursor:not-allowed}.spinning[data-v-d4eb2a72]{animation:spin-d4eb2a72 1s linear infinite}@keyframes spin-d4eb2a72{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.icon[data-v-d4eb2a72]{width:16px;height:16px}.filters-section[data-v-d4eb2a72]{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 1px 4px rgba(var(--color-black-rgb),.06);border-radius:10px;padding:10px 14px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;gap:12px}.filters-left[data-v-d4eb2a72]{display:flex;flex-wrap:wrap;gap:8px;flex:1}.filters-right[data-v-d4eb2a72]{display:flex;align-items:center;gap:10px;flex-shrink:0}.filter-input[data-v-d4eb2a72]{padding:8px 12px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;color:var(--color-text-primary);background:var(--color-surface);outline:none;transition:border-color .2s;min-width:200px;flex:1}.filter-input[data-v-d4eb2a72]:focus{border-color:var(--color-primary)}.filter-select[data-v-d4eb2a72]{padding:8px 12px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;color:var(--color-text-primary);background:var(--color-surface);outline:none;transition:border-color .2s;min-width:150px;cursor:pointer}.filter-select[data-v-d4eb2a72]:focus{border-color:var(--color-primary)}.device-all-grid-wrapper[data-v-d4eb2a72]{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 1px 4px rgba(var(--color-black-rgb),.06);border-radius:10px;overflow:hidden;min-height:auto}.devices-container[data-v-d4eb2a72]{background:var(--color-surface);overflow:hidden}.devices-header[data-v-d4eb2a72]{display:grid;gap:10px;padding:8px 14px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border-light);font-size:13px;font-weight:600;color:var(--color-text-muted)}.tab-owned .devices-header[data-v-d4eb2a72]{grid-template-columns:minmax(0,2.5fr) minmax(0,.8fr) minmax(0,.8fr) 90px 140px}.tab-shared .devices-header[data-v-d4eb2a72]{grid-template-columns:minmax(0,2fr) minmax(0,.7fr) minmax(0,1.2fr) minmax(0,1.3fr) 90px 100px}.header-cell[data-v-d4eb2a72]{display:flex;align-items:center;gap:4px;background:var(--color-surface-raised);font-size:13px;font-weight:600;color:var(--color-text-muted)}.header-cell.sortable-th[data-v-d4eb2a72]{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.header-cell.sortable-th[data-v-d4eb2a72]:hover{color:var(--color-text-primary)}.header-cell.is-sorted[data-v-d4eb2a72]{color:var(--color-primary)}.devices-list[data-v-d4eb2a72]{max-height:70vh;overflow-y:auto}.device-row[data-v-d4eb2a72]{display:grid;gap:10px;padding:8px 14px;border-bottom:1px solid var(--color-border-light);transition:background .15s;cursor:pointer;font-size:13px}.tab-owned .device-row[data-v-d4eb2a72]{grid-template-columns:minmax(0,2.5fr) minmax(0,.8fr) minmax(0,.8fr) 90px 140px}.tab-shared .device-row[data-v-d4eb2a72]{grid-template-columns:minmax(0,2fr) minmax(0,.7fr) minmax(0,1.2fr) minmax(0,1.3fr) 90px 100px}.device-row[data-v-d4eb2a72]:hover{background:var(--color-surface-raised)}.device-row[data-v-d4eb2a72]:last-child{border-bottom:none}.device-row.device-offline[data-v-d4eb2a72]{cursor:not-allowed}.device-row.device-offline>.row-cell[data-v-d4eb2a72]:not(.actions-col){opacity:.38;filter:saturate(.4)}.device-row.device-offline[data-v-d4eb2a72]:hover{background:transparent}.row-cell[data-v-d4eb2a72]{display:flex;align-items:center;min-width:0}.device-info[data-v-d4eb2a72]{display:flex;align-items:center;gap:8px}.device-icon[data-v-d4eb2a72]{width:28px;height:28px;background:var(--color-primary-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-primary-hover);flex-shrink:0}.device-details h4[data-v-d4eb2a72]{margin:0 0 2px;font-size:13px;font-weight:500;color:var(--color-text-primary)}.owner-info[data-v-d4eb2a72]{display:flex;flex-direction:column;gap:2px}.owner-name[data-v-d4eb2a72]{font-size:13px;font-weight:500;color:var(--color-text-primary)}.owner-email[data-v-d4eb2a72]{font-size:11px;color:var(--color-text-subtle)}.type-badge[data-v-d4eb2a72]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;background:var(--color-green-bg);color:var(--color-green-hover);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.group-badge[data-v-d4eb2a72]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;background:var(--color-surface-overlay);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.permission-stack[data-v-d4eb2a72]{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.permission-badge[data-v-d4eb2a72]{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap;line-height:1}.permission-badge.is-full[data-v-d4eb2a72]{background:var(--color-success-100);color:var(--color-success-700);border:1px solid var(--color-success-300)}.permission-badge.is-view[data-v-d4eb2a72]{background:var(--color-blue-100);color:var(--color-blue-700);border:1px solid var(--color-blue-300)}.validity-chip[data-v-d4eb2a72]{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap;line-height:1}.validity-chip.is-forever[data-v-d4eb2a72]{background:var(--color-surface-overlay);color:var(--color-text-muted)}.validity-chip.is-neutral[data-v-d4eb2a72]{background:var(--color-surface-overlay);color:var(--color-text-secondary)}.validity-chip.is-warning[data-v-d4eb2a72]{background:var(--color-amber-100);color:var(--color-amber-700);border:1px solid var(--color-amber-300)}.validity-chip.is-expired[data-v-d4eb2a72]{background:var(--color-red-bg);color:var(--color-red);border:1px solid var(--color-red-border)}.status-badge[data-v-d4eb2a72]{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;white-space:nowrap}.status-badge.online[data-v-d4eb2a72]{background:var(--color-green-bg);color:var(--color-green-hover)}.status-badge.offline[data-v-d4eb2a72]{background:var(--color-red-bg);color:var(--color-red)}.status-dot[data-v-d4eb2a72]{width:6px;height:6px;border-radius:50%;display:inline-block}.status-dot.online[data-v-d4eb2a72]{background:var(--color-success-500);box-shadow:0 0 8px rgba(var(--color-success-rgb),.4)}.status-dot.offline[data-v-d4eb2a72]{background:var(--color-red-500);box-shadow:0 0 8px rgba(var(--color-red-500-rgb),.4)}.empty-state[data-v-d4eb2a72]{display:flex;align-items:center;justify-content:center;padding:40px 16px;color:var(--color-text-subtle);font-size:13px}.empty-content[data-v-d4eb2a72]{text-align:center;color:var(--color-text-subtle)}.empty-icon[data-v-d4eb2a72]{margin-bottom:16px;color:var(--color-gray-ccc)}.empty-content h3[data-v-d4eb2a72]{margin:0 0 8px;font-size:16px;font-weight:500;color:var(--color-text-muted)}.empty-content p[data-v-d4eb2a72]{margin:0;font-size:13px;color:var(--color-text-subtle)}.pagination-info[data-v-d4eb2a72]{color:var(--color-text-muted);font-size:13px}.pagination-info strong[data-v-d4eb2a72]{color:var(--color-text-primary);font-weight:600}.pagination-controls[data-v-d4eb2a72]{display:flex;align-items:center;gap:8px}.page-size-select[data-v-d4eb2a72]{padding:4px 8px;border:1px solid var(--color-border);border-radius:5px;font-size:12px;outline:none;cursor:pointer;background:var(--color-surface);color:var(--color-text-primary)}.pagination-text[data-v-d4eb2a72]{color:var(--color-text-muted);font-size:12px}.pagination-nav[data-v-d4eb2a72]{display:flex;gap:4px}.nav-btn[data-v-d4eb2a72]{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);background:var(--color-surface);border-radius:5px;cursor:pointer;color:var(--color-text-primary);font-size:16px;transition:all .15s}.nav-btn[data-v-d4eb2a72]:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.nav-btn[data-v-d4eb2a72]:disabled{opacity:.4;cursor:not-allowed}.action-buttons[data-v-d4eb2a72]{display:flex;gap:4px}.action-btn[data-v-d4eb2a72]{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;cursor:pointer;transition:all .2s;border:none}.action-btn.btn-edit[data-v-d4eb2a72]{color:var(--color-white);background:linear-gradient(135deg,var(--color-success-500) 0%,var(--color-success-600) 100%)}.action-btn.btn-edit[data-v-d4eb2a72]:hover{box-shadow:0 4px 12px rgba(var(--color-success-rgb),.35);background:linear-gradient(135deg,var(--color-success-600) 0%,var(--color-success-700) 100%);transform:translateY(-1px)}.action-btn.btn-share[data-v-d4eb2a72]{color:var(--color-white);background:linear-gradient(135deg,var(--color-purple) 0%,var(--color-purple-hover) 100%)}.action-btn.btn-share[data-v-d4eb2a72]:hover{box-shadow:0 4px 12px rgba(var(--color-purple-rgb),.35);transform:translateY(-1px)}.action-btn.btn-danger[data-v-d4eb2a72]{color:var(--color-white);background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%)}.action-btn.btn-danger[data-v-d4eb2a72]:hover{box-shadow:0 4px 12px rgba(var(--color-red-500-rgb),.35);background:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-700) 100%);transform:translateY(-1px)}.modal-fade-enter-active[data-v-d4eb2a72],.modal-fade-leave-active[data-v-d4eb2a72]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-d4eb2a72],.modal-fade-leave-to[data-v-d4eb2a72]{opacity:0}.modal-fade-enter-active .modal-container[data-v-d4eb2a72],.modal-fade-leave-active .modal-container[data-v-d4eb2a72]{transition:transform .3s ease}.modal-fade-enter-from .modal-container[data-v-d4eb2a72],.modal-fade-leave-to .modal-container[data-v-d4eb2a72]{transform:scale(.95)}.modal-overlay[data-v-d4eb2a72]{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(var(--color-black-rgb),.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container[data-v-d4eb2a72]{background:var(--color-surface);border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow:hidden;box-shadow:0 20px 25px -5px rgba(var(--color-black-rgb),.1),0 10px 10px -5px rgba(var(--color-black-rgb),.04);display:flex;flex-direction:column}.modal-small[data-v-d4eb2a72]{max-width:420px}.modal-header[data-v-d4eb2a72]{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-d4eb2a72]{display:flex;align-items:center;gap:12px}.modal-icon[data-v-d4eb2a72]{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.modal-icon-danger[data-v-d4eb2a72]{background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);box-shadow:0 2px 8px rgba(var(--color-red-500-rgb),.3)}.modal-header h3[data-v-d4eb2a72]{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-d4eb2a72]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;transition:all .2s}.modal-close[data-v-d4eb2a72]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-body[data-v-d4eb2a72]{padding:24px;overflow-y:auto;flex:1}.modal-text[data-v-d4eb2a72]{margin:0 0 16px;font-size:14px;color:var(--color-text-primary);line-height:1.5}.warning-text[data-v-d4eb2a72]{margin:0;font-size:13px;color:var(--color-red);font-weight:500;display:flex;align-items:flex-start;gap:8px;padding:12px;background:var(--color-red-bg);border-radius:8px}.modal-footer[data-v-d4eb2a72]{display:flex;justify-content:flex-end;gap:12px;padding:18px 24px;border-top:1px solid var(--color-border-light);background:var(--color-surface)}.form-group[data-v-d4eb2a72]{margin-bottom:18px}.form-label[data-v-d4eb2a72]{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--color-text-primary)}.required[data-v-d4eb2a72]{color:var(--color-red-500);margin-left:2px}.form-input[data-v-d4eb2a72]{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:8px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;color:var(--color-text-primary);background:var(--color-surface)}.form-input[data-v-d4eb2a72]:hover{border-color:var(--color-border-medium)}.form-input[data-v-d4eb2a72]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.btn-cancel[data-v-d4eb2a72],.btn-save[data-v-d4eb2a72],.btn-delete[data-v-d4eb2a72]{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-cancel[data-v-d4eb2a72]{background:var(--color-surface);color:var(--color-text-muted);border:1.5px solid var(--color-border)}.btn-cancel[data-v-d4eb2a72]:hover{background:var(--color-surface-raised);border-color:var(--color-text-subtle);color:var(--color-text-secondary)}.btn-save[data-v-d4eb2a72]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);box-shadow:0 1px 3px rgba(var(--color-primary-rgb),.2);border:1.5px solid transparent}.btn-save[data-v-d4eb2a72]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary-700) 100%);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.btn-save[data-v-d4eb2a72]:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-delete[data-v-d4eb2a72]{background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);color:var(--color-white);box-shadow:0 1px 3px rgba(var(--color-red-500-rgb),.2);border:1.5px solid transparent}.btn-delete[data-v-d4eb2a72]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-700) 100%);box-shadow:0 4px 12px rgba(var(--color-red-500-rgb),.35);transform:translateY(-1px)}.btn-delete[data-v-d4eb2a72]:disabled{opacity:.6;cursor:not-allowed}.btn-delete.btn-unlink[data-v-d4eb2a72]{background:linear-gradient(135deg,var(--color-amber-500),var(--color-amber-600));box-shadow:0 1px 3px rgba(var(--color-amber-rgb),.25)}.btn-delete.btn-unlink[data-v-d4eb2a72]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-amber-600),var(--color-amber-700));box-shadow:0 4px 12px rgba(var(--color-amber-rgb),.4);transform:translateY(-1px)}.warning-text.warning-danger[data-v-d4eb2a72]{color:var(--color-red)}.warning-text.warning-info[data-v-d4eb2a72]{color:var(--color-amber-700)}.action-btn.btn-info[data-v-d4eb2a72]{color:var(--color-white);background:linear-gradient(135deg,var(--color-blue-500) 0%,var(--color-blue-600) 100%)}.action-btn.btn-info[data-v-d4eb2a72]:hover{box-shadow:0 4px 12px rgba(var(--color-blue-rgb),.35);background:linear-gradient(135deg,var(--color-blue-600) 0%,var(--color-blue-700) 100%);transform:translateY(-1px)}.devices-mobile-cards[data-v-d4eb2a72]{display:none}@media (max-width: 768px){.device-all-view[data-v-d4eb2a72]{padding:10px}.device-all-header[data-v-d4eb2a72]{flex-direction:column;align-items:stretch;gap:10px}.device-all-header h2[data-v-d4eb2a72]{font-size:16px}.device-all-actions[data-v-d4eb2a72]{display:flex;gap:8px}.device-all-actions .btn[data-v-d4eb2a72]{flex:1;justify-content:center;font-size:12px;padding:7px 10px}.device-type-tabs[data-v-d4eb2a72]{padding:6px 8px}.tab-btn[data-v-d4eb2a72]{flex:1;justify-content:center;font-size:12px;padding:6px 8px}.filters-section[data-v-d4eb2a72]{flex-direction:column;align-items:stretch;gap:8px;padding:10px 12px}.filters-left[data-v-d4eb2a72]{flex-direction:column;gap:6px}.filter-input[data-v-d4eb2a72],.filter-select[data-v-d4eb2a72]{min-width:0;width:100%}.filters-right[data-v-d4eb2a72]{justify-content:space-between;width:100%}.devices-desktop[data-v-d4eb2a72]{display:none!important}.devices-mobile-cards[data-v-d4eb2a72]{display:flex;flex-direction:column;gap:8px;padding:8px}.device-mobile-card[data-v-d4eb2a72]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:12px;cursor:pointer;transition:box-shadow .2s,border-color .2s}.device-mobile-card[data-v-d4eb2a72]:active{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.12)}.device-mobile-card.device-offline[data-v-d4eb2a72]{cursor:not-allowed}.device-mobile-card.device-offline[data-v-d4eb2a72]>:not(.mobile-card-actions){opacity:.38;filter:saturate(.4)}.device-mobile-card.device-offline[data-v-d4eb2a72]:active{border-color:var(--color-gray-200-soft);box-shadow:none}.mobile-card-top[data-v-d4eb2a72]{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.mobile-card-meta[data-v-d4eb2a72]{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.mobile-card-actions[data-v-d4eb2a72]{display:flex;gap:6px;padding-top:8px;border-top:1px solid var(--color-border-light)}.mobile-card-actions .action-btn[data-v-d4eb2a72]{width:32px;height:32px}.owner-badge[data-v-d4eb2a72]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;background:var(--color-purple-50);color:var(--color-violet-600)}.error-banner[data-v-d4eb2a72],.ws-status-banner[data-v-d4eb2a72]{flex-direction:column;gap:8px;text-align:center}.btn-retry[data-v-d4eb2a72],.btn-reconnect[data-v-d4eb2a72]{margin-left:0;align-self:center}}.loading-center[data-v-d4eb2a72]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px;color:var(--color-text-muted)}.device-name-row[data-v-d4eb2a72]{display:flex;align-items:center;gap:6px}.lock-badge[data-v-d4eb2a72]{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;background:var(--color-red-bg);color:var(--color-red);border-radius:4px;font-size:10px;font-weight:600;white-space:nowrap;line-height:1}.quota-exceeded-banner[data-v-d4eb2a72]{display:flex;align-items:center;gap:8px;padding:10px 14px;margin-top:12px;background:var(--color-blue-bg);border:1px solid var(--color-blue-border);border-radius:8px;font-size:13px;color:var(--color-blue-hover)}.action-btn.btn-edit[data-v-d4eb2a72]:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}[data-theme=dark] .filter-input[data-v-d4eb2a72],[data-theme=dark] .filter-select[data-v-d4eb2a72],[data-theme=dark] .page-size-select[data-v-d4eb2a72]{background:var(--color-input-bg);border-color:var(--color-input-border);color:var(--color-text-primary)}[data-theme=dark] .filter-input[data-v-d4eb2a72]:focus,[data-theme=dark] .filter-select[data-v-d4eb2a72]:focus,[data-theme=dark] .page-size-select[data-v-d4eb2a72]:focus{border-color:var(--color-input-focus-border);box-shadow:0 0 0 3px var(--color-input-focus-shadow)}[data-theme=dark] .form-input[data-v-d4eb2a72]{background:var(--color-input-bg);border-color:var(--color-input-border)}[data-theme=dark] .form-input[data-v-d4eb2a72]:focus{border-color:var(--color-input-focus-border);box-shadow:0 0 0 3px var(--color-input-focus-shadow)}[data-theme=dark] .btn-secondary[data-v-d4eb2a72]{background:var(--color-surface-raised);border-color:var(--color-border-medium)}[data-theme=dark] .btn-secondary[data-v-d4eb2a72]:hover{background:var(--color-surface-overlay)}[data-theme=dark] .btn-cancel[data-v-d4eb2a72]{background:var(--color-surface-raised);border-color:var(--color-border-medium);color:var(--color-text-secondary)}[data-theme=dark] .nav-btn[data-v-d4eb2a72]{background:var(--color-surface-raised);border-color:var(--color-border);color:var(--color-text-secondary)}[data-theme=dark] .owner-badge[data-v-d4eb2a72]{background:var(--color-purple-bg);color:var(--color-purple-hover)}[data-theme=dark] .device-mobile-card[data-v-d4eb2a72]:active{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.2)}.device-group-devices[data-v-b54b5dc9]{display:flex;flex-direction:column;min-height:100%;box-sizing:border-box;padding:15px}.devices-header[data-v-b54b5dc9]{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.header-left[data-v-b54b5dc9]{display:flex;align-items:center;gap:12px}.btn-back[data-v-b54b5dc9]{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:var(--color-text-primary);transition:all .2s;white-space:nowrap}.btn-back[data-v-b54b5dc9]:hover{background:var(--color-surface-raised);border-color:var(--color-gray-300-soft)}.header-title h2[data-v-b54b5dc9]{margin:0 0 2px;font-size:17px;font-weight:600;color:var(--color-text-primary)}.header-subtitle[data-v-b54b5dc9]{margin:0;color:var(--color-text-muted);font-size:12px;display:flex;align-items:center;gap:6px}.stat-item[data-v-b54b5dc9]{display:inline-flex;align-items:center;gap:4px}.stat-divider[data-v-b54b5dc9]{color:var(--color-gray-ccc)}.header-actions[data-v-b54b5dc9]{display:flex;gap:8px}.btn-primary[data-v-b54b5dc9]{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary[data-v-b54b5dc9]:hover{background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary) 100%);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.btn-secondary[data-v-b54b5dc9]{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary[data-v-b54b5dc9]:hover{background:var(--color-surface-raised);border-color:var(--color-gray-300-soft)}.btn-secondary[data-v-b54b5dc9]:disabled{opacity:.6;cursor:not-allowed}.devices-content[data-v-b54b5dc9]{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-md);border-radius:12px;overflow:hidden}.empty-state[data-v-b54b5dc9]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-subtle)}.spinning[data-v-b54b5dc9]{animation:spin-b54b5dc9 1s linear infinite}@keyframes spin-b54b5dc9{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-icon[data-v-b54b5dc9]{margin-bottom:16px;color:var(--color-gray-ccc)}.empty-state h4[data-v-b54b5dc9]{margin:0 0 8px;font-size:16px;color:var(--color-text-muted)}.empty-state p[data-v-b54b5dc9]{margin:0;font-size:14px;color:var(--color-text-subtle)}.devices-table-wrapper[data-v-b54b5dc9]{background:var(--color-surface);overflow:hidden}.devices-table[data-v-b54b5dc9]{width:100%}.table-header[data-v-b54b5dc9]{display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr 120px;gap:16px;padding:14px 20px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border-light);font-size:13px;font-weight:600;color:var(--color-text-muted)}.header-cell[data-v-b54b5dc9]{display:flex;align-items:center;gap:4px}.header-cell.sortable-th[data-v-b54b5dc9]{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .15s}.header-cell.sortable-th[data-v-b54b5dc9]:hover,.header-cell.is-sorted[data-v-b54b5dc9]{color:var(--color-primary)}.header-cell .sort-icon[data-v-b54b5dc9]{color:var(--color-text-subtle);transition:color .15s}.header-cell.is-sorted .sort-icon[data-v-b54b5dc9],.header-cell.sortable-th:hover .sort-icon[data-v-b54b5dc9]{color:var(--color-primary)}.table-body[data-v-b54b5dc9]{max-height:70vh;overflow-y:auto}.table-row[data-v-b54b5dc9]{display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr 120px;gap:16px;padding:14px 20px;border-bottom:1px solid var(--color-border-light);transition:background .15s;font-size:13px;cursor:pointer}.table-row[data-v-b54b5dc9]:hover{background:var(--color-surface-raised)}.table-row[data-v-b54b5dc9]:last-child{border-bottom:none}.row-cell[data-v-b54b5dc9]{display:flex;align-items:center}.device-col[data-v-b54b5dc9]{min-width:200px}.device-info[data-v-b54b5dc9]{display:flex;align-items:center;gap:12px}.device-icon[data-v-b54b5dc9]{width:36px;height:36px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0;box-shadow:0 2px 4px rgba(var(--color-black-rgb),.1)}.device-details[data-v-b54b5dc9]{display:flex;flex-direction:column;gap:2px}.device-name[data-v-b54b5dc9]{margin:0;font-size:13px;font-weight:500;color:var(--color-text-primary)}.device-id[data-v-b54b5dc9]{font-size:11px;color:var(--color-text-subtle);font-family:Courier New,monospace}.type-col[data-v-b54b5dc9]{min-width:150px}.device-type[data-v-b54b5dc9]{font-size:13px;color:var(--color-text-muted)}.status-col[data-v-b54b5dc9]{min-width:120px;justify-content:center}.badge-status[data-v-b54b5dc9]{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.badge-active[data-v-b54b5dc9]{background:var(--color-green-bg);color:var(--color-green-hover)}.badge-inactive[data-v-b54b5dc9]{background:var(--color-surface-overlay);color:var(--color-text-muted)}.date-col[data-v-b54b5dc9]{min-width:100px}.date-text[data-v-b54b5dc9]{font-size:13px;color:var(--color-text-muted)}.actions-col[data-v-b54b5dc9]{min-width:120px;justify-content:center}.btn-remove[data-v-b54b5dc9]{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;cursor:pointer;transition:all .2s;border:none;color:var(--color-white);background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%)}.btn-remove[data-v-b54b5dc9]:hover{box-shadow:0 4px 12px rgba(var(--color-red-500-rgb),.35);background:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-700) 100%);transform:translateY(-1px)}.modal-fade-enter-active[data-v-b54b5dc9],.modal-fade-leave-active[data-v-b54b5dc9]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-b54b5dc9],.modal-fade-leave-to[data-v-b54b5dc9]{opacity:0}.modal-overlay[data-v-b54b5dc9]{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(var(--color-black-rgb),.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container[data-v-b54b5dc9]{background:var(--color-surface);border-radius:12px;width:100%;max-width:540px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-small[data-v-b54b5dc9]{max-width:420px}.modal-header[data-v-b54b5dc9]{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-b54b5dc9]{display:flex;align-items:center;gap:12px}.modal-icon[data-v-b54b5dc9]{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.modal-icon-danger[data-v-b54b5dc9]{background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);box-shadow:0 2px 8px rgba(var(--color-red-500-rgb),.3)}.modal-header h3[data-v-b54b5dc9]{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-b54b5dc9]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;transition:all .2s}.modal-close[data-v-b54b5dc9]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-body[data-v-b54b5dc9]{padding:20px 24px 24px;overflow-y:auto;flex:1}.modal-text[data-v-b54b5dc9]{margin:0 0 8px;font-size:14px;color:var(--color-text-primary);line-height:1.5}.warning-text[data-v-b54b5dc9]{margin:0;font-size:13px;color:var(--color-red);font-weight:500}.search-box[data-v-b54b5dc9]{margin-bottom:16px}.form-input[data-v-b54b5dc9]{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:8px;font-size:14px;outline:none;transition:all .2s;color:var(--color-text-primary);background:var(--color-surface)}.form-input[data-v-b54b5dc9]:hover{border-color:var(--color-gray-c0)}.form-input[data-v-b54b5dc9]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.available-devices[data-v-b54b5dc9]{max-height:400px;overflow-y:auto}.loading-inline[data-v-b54b5dc9],.empty-inline[data-v-b54b5dc9]{padding:40px;text-align:center;color:var(--color-text-subtle);font-size:14px}.loading-inline[data-v-b54b5dc9]{display:flex;align-items:center;justify-content:center;gap:8px}.device-item[data-v-b54b5dc9]{display:flex;align-items:center;gap:12px;padding:12px;border:1.5px solid var(--color-border);border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all .2s;background:var(--color-surface)}.device-item[data-v-b54b5dc9]:hover{border-color:var(--color-primary);background:var(--color-primary-bg)}.device-item.selected[data-v-b54b5dc9]{border-color:var(--color-primary);background:var(--color-primary-bg);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.15)}.device-item-info[data-v-b54b5dc9]{flex:1}.device-item-info h5[data-v-b54b5dc9]{margin:0 0 2px;font-size:13px;font-weight:500;color:var(--color-text-primary)}.device-item-info span[data-v-b54b5dc9]{font-size:12px;color:var(--color-text-subtle)}.device-item-check[data-v-b54b5dc9]{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 4px rgba(var(--color-primary-rgb),.3)}.modal-footer[data-v-b54b5dc9]{display:flex;justify-content:flex-end;gap:12px;padding:18px 24px;border-top:1px solid var(--color-border-light);background:var(--color-surface)}.btn-cancel[data-v-b54b5dc9],.btn-save[data-v-b54b5dc9]{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-cancel[data-v-b54b5dc9]{background:var(--color-surface);color:var(--color-text-muted);border:1.5px solid var(--color-border)}.btn-cancel[data-v-b54b5dc9]:hover{background:var(--color-surface-raised);border-color:var(--color-text-subtle);color:var(--color-text-secondary)}.btn-save[data-v-b54b5dc9]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);box-shadow:0 1px 3px rgba(var(--color-primary-rgb),.2);border:1.5px solid transparent}.btn-save[data-v-b54b5dc9]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary-700) 100%);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.btn-save[data-v-b54b5dc9]:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-delete[data-v-b54b5dc9]{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);color:var(--color-white);border:1.5px solid transparent;box-shadow:0 1px 3px rgba(var(--color-red-500-rgb),.2)}.btn-delete[data-v-b54b5dc9]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-700) 100%);box-shadow:0 4px 12px rgba(var(--color-red-500-rgb),.35);transform:translateY(-1px)}.btn-delete[data-v-b54b5dc9]:disabled{opacity:.6;cursor:not-allowed}.devices-mobile-cards[data-v-b54b5dc9]{display:none}.device-mobile-card[data-v-b54b5dc9]{background:var(--color-surface);border:1px solid var(--color-gray-200-soft);border-radius:10px;padding:12px;transition:box-shadow .2s,border-color .2s}.mobile-card-top[data-v-b54b5dc9]{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.mobile-card-meta[data-v-b54b5dc9]{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--color-text-subtle);margin-bottom:10px}.mobile-card-actions[data-v-b54b5dc9]{padding-top:8px;border-top:1px solid var(--color-surface-overlay);display:flex;justify-content:flex-end}.mobile-card-actions .btn-remove[data-v-b54b5dc9]{width:auto;height:auto;padding:6px 12px;border-radius:6px;display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500}@media (max-width: 768px){.device-group-devices[data-v-b54b5dc9]{padding:10px}.devices-header[data-v-b54b5dc9]{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:14px}.header-title[data-v-b54b5dc9]{margin-left:0}.header-title h3[data-v-b54b5dc9]{font-size:16px}.btn-back[data-v-b54b5dc9]{width:-moz-fit-content;width:fit-content}.btn-primary[data-v-b54b5dc9]{width:100%;justify-content:center;padding:10px 16px}.devices-table-wrapper[data-v-b54b5dc9]{display:none}.devices-mobile-cards[data-v-b54b5dc9]{display:flex;flex-direction:column;gap:8px;padding:8px}.modal-overlay[data-v-b54b5dc9]{padding:12px}.available-devices[data-v-b54b5dc9]{max-height:320px}}.device-group-view[data-v-0220dc91]{min-height:100%;padding:15px;display:flex;flex-direction:column;box-sizing:border-box}.device-group-header[data-v-0220dc91]{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.device-group-header h2[data-v-0220dc91]{font-size:17px;font-weight:600;color:var(--color-text-primary);margin:0 0 2px}.header-subtitle[data-v-0220dc91]{margin:0;color:var(--color-text-muted);font-size:12px;display:flex;align-items:center;gap:6px}.stat-item[data-v-0220dc91]{display:inline-flex;align-items:center;gap:4px}.stat-divider[data-v-0220dc91]{color:var(--color-gray-ccc)}.device-group-actions[data-v-0220dc91]{display:flex;gap:8px}.filters-section[data-v-0220dc91]{display:flex;justify-content:space-between;align-items:center;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 1px 4px rgba(var(--color-black-rgb),.06);border-radius:10px;padding:10px 14px;margin-bottom:10px;gap:12px;flex-wrap:wrap}.filters-left[data-v-0220dc91]{display:flex;gap:8px;flex:1}.filters-right[data-v-0220dc91]{display:flex;align-items:center;gap:10px}.filter-input[data-v-0220dc91]{padding:8px 12px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;color:var(--color-text-primary);background:var(--color-surface);outline:none;transition:border-color .2s;flex:1;min-width:200px;max-width:300px}.filter-input[data-v-0220dc91]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.btn[data-v-0220dc91]{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary[data-v-0220dc91]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white)}.btn-primary[data-v-0220dc91]:hover{background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary) 100%);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.btn-primary[data-v-0220dc91]:disabled{opacity:.6;cursor:not-allowed}.btn-secondary[data-v-0220dc91]{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary[data-v-0220dc91]:hover{background:var(--color-surface-raised);border-color:var(--color-gray-300-soft)}.btn-secondary[data-v-0220dc91]:disabled{opacity:.6;cursor:not-allowed}.spinning[data-v-0220dc91]{animation:spin-0220dc91 1s linear infinite}@keyframes spin-0220dc91{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.device-group-grid-wrapper[data-v-0220dc91]{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 1px 4px rgba(var(--color-black-rgb),.06);border-radius:10px;overflow:hidden;min-height:auto}.groups-container[data-v-0220dc91]{background:var(--color-surface);overflow:hidden}.groups-header[data-v-0220dc91]{display:grid;grid-template-columns:2fr 2.5fr .8fr 1fr 120px;gap:10px;padding:8px 14px;background:var(--color-surface-raised);border-bottom:1px solid var(--color-border-light);font-size:13px;font-weight:600;color:var(--color-text-muted)}.header-cell[data-v-0220dc91]{display:flex;align-items:center;gap:4px;background:var(--color-surface-raised);font-size:13px;font-weight:600;color:var(--color-text-muted)}.header-cell.sortable-th[data-v-0220dc91]{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .15s}.header-cell.sortable-th[data-v-0220dc91]:hover{color:var(--color-text-primary)}.header-cell.is-sorted[data-v-0220dc91]{color:var(--color-primary)}.sort-icon[data-v-0220dc91]{color:var(--color-text-subtle);transition:color .15s}.header-cell.is-sorted .sort-icon[data-v-0220dc91],.header-cell.sortable-th:hover .sort-icon[data-v-0220dc91]{color:var(--color-primary)}.group-col[data-v-0220dc91],.description-col[data-v-0220dc91]{min-width:200px}.count-col[data-v-0220dc91]{min-width:80px;justify-content:center}.date-col[data-v-0220dc91]{min-width:100px;color:var(--color-text-primary)}.actions-col[data-v-0220dc91]{min-width:120px;justify-content:center}.groups-list[data-v-0220dc91]{max-height:70vh;overflow-y:auto}.group-row[data-v-0220dc91]{display:grid;grid-template-columns:2fr 2.5fr .8fr 1fr 120px;gap:10px;padding:8px 14px;border-bottom:1px solid var(--color-border-light);transition:background .15s;font-size:13px;cursor:pointer}.group-row[data-v-0220dc91]:hover{background:var(--color-surface-raised)}.group-row[data-v-0220dc91]:last-child{border-bottom:none}.row-cell[data-v-0220dc91]{display:flex;align-items:center}.group-info[data-v-0220dc91]{display:flex;align-items:center;gap:8px}.group-icon[data-v-0220dc91]{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0;box-shadow:0 2px 4px rgba(var(--color-black-rgb),.1)}.group-details h4[data-v-0220dc91]{margin:0;font-size:13px;font-weight:500;color:var(--color-text-primary)}.description-text[data-v-0220dc91]{color:var(--color-text-muted);font-size:13px}.count-badge[data-v-0220dc91]{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-width:24px;padding:2px 8px;background:var(--color-green-bg);color:var(--color-green-hover);border-radius:4px;font-size:11px;font-weight:500}.action-buttons[data-v-0220dc91]{display:flex;gap:4px}.action-btn[data-v-0220dc91]{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:5px;cursor:pointer;transition:all .2s;border:none}.action-btn.btn-view[data-v-0220dc91]{color:var(--color-white);background:linear-gradient(135deg,var(--color-blue-500) 0%,var(--color-blue-600) 100%)}.action-btn.btn-view[data-v-0220dc91]:hover{box-shadow:0 4px 12px rgba(var(--color-blue-rgb),.35);background:linear-gradient(135deg,var(--color-blue-600) 0%,var(--color-blue-700) 100%);transform:translateY(-1px)}.action-btn.btn-edit[data-v-0220dc91]{color:var(--color-white);background:linear-gradient(135deg,var(--color-success-500) 0%,var(--color-success-600) 100%)}.action-btn.btn-edit[data-v-0220dc91]:hover{box-shadow:0 4px 12px rgba(var(--color-success-rgb),.35);background:linear-gradient(135deg,var(--color-success-600) 0%,var(--color-success-700) 100%);transform:translateY(-1px)}.action-btn.btn-danger[data-v-0220dc91]{color:var(--color-white);background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%)}.action-btn.btn-danger[data-v-0220dc91]:hover{box-shadow:0 4px 12px rgba(var(--color-red-500-rgb),.35);background:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-700) 100%);transform:translateY(-1px)}.empty-state[data-v-0220dc91]{display:flex;align-items:center;justify-content:center;padding:40px 16px;color:var(--color-text-subtle);font-size:13px}.empty-content[data-v-0220dc91]{text-align:center;color:var(--color-text-subtle)}.empty-icon[data-v-0220dc91]{margin-bottom:16px;color:var(--color-gray-ccc)}.empty-content h3[data-v-0220dc91]{margin:0 0 8px;font-size:16px;font-weight:500;color:var(--color-text-muted)}.empty-content p[data-v-0220dc91]{margin:0;font-size:13px;color:var(--color-text-subtle)}.pagination[data-v-0220dc91]{display:flex;justify-content:space-between;align-items:center;background:var(--color-surface);padding:8px 12px;border-radius:8px;font-size:12px;margin-top:8px}.pagination-info[data-v-0220dc91]{color:var(--color-text-muted);font-size:12px}.pagination-info strong[data-v-0220dc91]{color:var(--color-text-primary);font-weight:600}.pagination-controls[data-v-0220dc91]{display:flex;align-items:center;gap:8px}.page-size-select[data-v-0220dc91]{padding:4px 8px;border:1px solid var(--color-border);border-radius:5px;font-size:12px;outline:none;cursor:pointer;background:var(--color-surface);color:var(--color-text-primary)}.pagination-text[data-v-0220dc91]{color:var(--color-text-muted);font-size:12px}.pagination-nav[data-v-0220dc91]{display:flex;gap:4px}.nav-btn[data-v-0220dc91]{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);background:var(--color-surface);border-radius:5px;cursor:pointer;color:var(--color-text-primary);font-size:16px;transition:all .15s}.nav-btn[data-v-0220dc91]:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-bg)}.nav-btn[data-v-0220dc91]:disabled{opacity:.4;cursor:not-allowed}.modal-fade-enter-active[data-v-0220dc91],.modal-fade-leave-active[data-v-0220dc91]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-0220dc91],.modal-fade-leave-to[data-v-0220dc91]{opacity:0}.modal-fade-enter-active .modal-container[data-v-0220dc91],.modal-fade-leave-active .modal-container[data-v-0220dc91]{transition:transform .3s ease}.modal-fade-enter-from .modal-container[data-v-0220dc91],.modal-fade-leave-to .modal-container[data-v-0220dc91]{transform:scale(.95)}.modal-overlay[data-v-0220dc91]{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(var(--color-black-rgb),.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container[data-v-0220dc91]{background:var(--color-surface);border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow:hidden;box-shadow:0 20px 25px -5px rgba(var(--color-black-rgb),.1),0 10px 10px -5px rgba(var(--color-black-rgb),.04);display:flex;flex-direction:column}.modal-small[data-v-0220dc91]{max-width:420px}.modal-header[data-v-0220dc91]{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-raised)}.modal-title-section[data-v-0220dc91]{display:flex;align-items:center;gap:12px}.modal-icon[data-v-0220dc91]{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.modal-header h3[data-v-0220dc91]{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.modal-close[data-v-0220dc91]{background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;transition:all .2s}.modal-close[data-v-0220dc91]:hover{background:var(--color-surface-overlay);color:var(--color-text-primary)}.modal-body[data-v-0220dc91]{padding:20px 24px 24px;overflow-y:auto;flex:1}.modal-body p[data-v-0220dc91]{margin:0 0 8px;font-size:14px;color:var(--color-text-primary);line-height:1.5}.form-group[data-v-0220dc91]{margin-bottom:18px}.form-label[data-v-0220dc91]{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--color-text-primary)}.required[data-v-0220dc91]{color:var(--color-red);margin-left:2px}.form-input[data-v-0220dc91],.form-textarea[data-v-0220dc91]{width:100%;padding:9px 12px;border:1.5px solid var(--color-border);border-radius:8px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;color:var(--color-text-primary);background:var(--color-surface)}.form-input[data-v-0220dc91]:hover,.form-textarea[data-v-0220dc91]:hover{border-color:var(--color-gray-c0)}.form-input[data-v-0220dc91]:focus,.form-textarea[data-v-0220dc91]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-textarea[data-v-0220dc91]{resize:vertical;min-height:100px}.form-hint[data-v-0220dc91]{display:block;margin-top:6px;font-size:12px;color:var(--color-text-subtle)}.warning-text[data-v-0220dc91]{margin:8px 0 0;font-size:13px;color:var(--color-red)}.color-selector[data-v-0220dc91]{display:flex;gap:12px;align-items:center}.color-preview-wrapper[data-v-0220dc91]{position:relative}.color-picker-input[data-v-0220dc91]{position:absolute;opacity:0;width:0;height:0}.color-preview[data-v-0220dc91]{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--color-white);cursor:pointer;border:3px solid var(--color-surface);box-shadow:0 0 0 1.5px var(--color-border),0 2px 8px rgba(var(--color-black-rgb),.1);transition:all .2s}.color-preview[data-v-0220dc91]:hover{transform:scale(1.05);box-shadow:0 0 0 1.5px var(--color-indigo-500),0 4px 12px rgba(var(--color-indigo-500-rgb),.3)}.color-code-input[data-v-0220dc91]{flex:1;font-family:Courier New,monospace;text-transform:uppercase}.color-presets[data-v-0220dc91]{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}.color-preset-btn[data-v-0220dc91]{width:38px;height:38px;border-radius:8px;border:3px solid var(--color-surface);cursor:pointer;transition:all .2s;box-shadow:0 0 0 1.5px var(--color-border)}.color-preset-btn[data-v-0220dc91]:hover{transform:scale(1.1);box-shadow:0 0 0 2px var(--color-primary),0 2px 8px rgba(var(--color-primary-rgb),.3)}.color-preset-btn.active[data-v-0220dc91]{box-shadow:0 0 0 3px var(--color-primary),0 2px 8px rgba(var(--color-primary-rgb),.3);transform:scale(1.05)}.modal-footer[data-v-0220dc91]{display:flex;justify-content:flex-end;gap:12px;padding:10px;border-top:1px solid var(--color-border-light);background:var(--color-surface)}.btn-cancel[data-v-0220dc91],.btn-save[data-v-0220dc91]{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-cancel[data-v-0220dc91]{background:var(--color-surface);color:var(--color-text-muted);border:1.5px solid var(--color-border)}.btn-cancel[data-v-0220dc91]:hover{background:var(--color-surface-raised);border-color:var(--color-text-subtle);color:var(--color-text-secondary)}.btn-save[data-v-0220dc91]{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-white);box-shadow:0 1px 3px rgba(var(--color-primary-rgb),.2);border:1.5px solid transparent}.btn-save[data-v-0220dc91]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary-700) 100%);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.35);transform:translateY(-1px)}.btn-save[data-v-0220dc91]:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-delete[data-v-0220dc91]{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;background:linear-gradient(135deg,var(--color-red-500) 0%,var(--color-red) 100%);color:var(--color-white);box-shadow:0 1px 3px rgba(var(--color-red-500-rgb),.2);border:1.5px solid transparent}.btn-delete[data-v-0220dc91]:hover:not(:disabled){background:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-700) 100%);box-shadow:0 4px 12px rgba(var(--color-red-500-rgb),.35);transform:translateY(-1px)}.btn-delete[data-v-0220dc91]:disabled{opacity:.6;cursor:not-allowed}.groups-mobile-cards[data-v-0220dc91]{display:none}@media (max-width: 768px){.device-group-view[data-v-0220dc91]{padding:10px}.device-group-header[data-v-0220dc91]{flex-direction:column;align-items:stretch;gap:10px}.device-group-header h2[data-v-0220dc91]{font-size:16px}.device-group-actions[data-v-0220dc91]{display:flex;gap:8px}.device-group-actions .btn[data-v-0220dc91]{flex:1;justify-content:center;font-size:12px;padding:7px 10px}.filters-section[data-v-0220dc91]{flex-direction:column;align-items:stretch;gap:8px;padding:10px 12px}.filters-left[data-v-0220dc91]{flex-direction:column}.filter-input[data-v-0220dc91]{min-width:0;max-width:none;width:100%}.filters-right[data-v-0220dc91]{justify-content:space-between;width:100%}.groups-container[data-v-0220dc91]{display:none!important}.groups-mobile-cards[data-v-0220dc91]{display:flex;flex-direction:column;gap:8px;padding:8px}.group-mobile-card[data-v-0220dc91]{background:var(--color-surface);border:1px solid var(--color-gray-200-soft);border-radius:10px;padding:12px;cursor:pointer;transition:box-shadow .2s,border-color .2s}.group-mobile-card[data-v-0220dc91]:active{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.12)}.mobile-card-top[data-v-0220dc91]{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.mobile-card-top .group-details h4[data-v-0220dc91]{font-size:14px}.mobile-card-top .description-text[data-v-0220dc91]{font-size:12px;color:var(--color-text-subtle);display:block;margin-top:2px}.mobile-card-meta[data-v-0220dc91]{display:flex;gap:8px;margin-bottom:8px}.mobile-date[data-v-0220dc91]{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--color-text-subtle)}.mobile-card-actions[data-v-0220dc91]{display:flex;gap:6px;padding-top:8px;border-top:1px solid var(--color-surface-overlay)}.mobile-card-actions .action-btn[data-v-0220dc91]{width:32px;height:32px}.pagination-bottom[data-v-0220dc91]{flex-direction:column;gap:8px;align-items:center}}.admin-main[data-v-ddf360d4]{min-height:100vh;flex:1;display:flex;flex-direction:column}.page-content[data-v-ddf360d4]{flex:1;padding:10px;margin-bottom:5px}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74c3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-toast-width:320px;--toastify-toast-background:#fff;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error);--toastify-color-progress-colored:#ddd}.Toastify__toast-container{box-sizing:border-box;color:#fff;padding:4px;position:fixed;transform:translate3d(0,0,var(--toastify-z-index) px);width:var(--toastify-toast-width);z-index:var(--toastify-z-index)}.Toastify__toast-container--top-left{left:1em;top:1em}.Toastify__toast-container--top-center{left:50%;top:1em;transform:translate(-50%)}.Toastify__toast-container--top-right{right:1em;top:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width:480px){.Toastify__toast-container{left:0;margin:0;padding:0;width:100vw}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:0;transform:translate(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:0;transform:translate(0)}.Toastify__toast-container--rtl{left:auto;right:0}}.Toastify__toast{border-radius:4px;box-shadow:0 1px 10px #0000001a,0 2px 15px #0000000d;box-sizing:border-box;cursor:pointer;direction:ltr;display:flex;font-family:var(--toastify-font-family);justify-content:space-between;margin-bottom:1rem;max-height:var(--toastify-toast-max-height);min-height:var(--toastify-toast-min-height);overflow:hidden;padding:8px;position:relative;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast-body{align-items:center;display:flex;flex:1 1 auto;margin:auto 0;padding:6px;white-space:pre-wrap}.Toastify__toast-body>div:last-child{flex:1}.Toastify__toast-icon{display:flex;flex-shrink:0;margin-inline-end:10px;width:20px}.Toastify--animate{animation-duration:.7s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}@media only screen and (max-width:480px){.Toastify__toast{border-radius:0;margin-bottom:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--colored.Toastify__toast--default,.Toastify__toast-theme--light{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{background:var(--toastify-color-info);color:var(--toastify-text-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{background:var(--toastify-color-success);color:var(--toastify-text-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{background:var(--toastify-color-warning);color:var(--toastify-text-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{background:var(--toastify-color-error);color:var(--toastify-text-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--default{background:var(--toastify-color-progress-colored)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning{background:var(--toastify-color-transparent)}.Toastify__close-button{align-self:flex-start;background:#0000;border:none;color:#fff;cursor:pointer;opacity:.7;outline:none;padding:0;transition:.3s ease}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentcolor;height:16px;width:14px}.Toastify__close-button:focus,.Toastify__close-button:hover{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{bottom:0;height:5px;left:0;opacity:.7;position:absolute;transform-origin:left;width:100%;z-index:var(--toastify-z-index)}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{left:auto;right:0;transform-origin:right}.Toastify__spinner{animation:Toastify__spin .65s linear infinite;border:2px solid;border-color:var(--toastify-spinner-color-empty-area);border-radius:100%;border-right-color:var(--toastify-spinner-color);box-sizing:border-box;height:20px;width:20px}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--bottom-left,.Toastify__bounce-enter--top-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--bottom-right,.Toastify__bounce-enter--top-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--bottom-left,.Toastify__bounce-exit--top-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--bottom-right,.Toastify__bounce-exit--top-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__none{0%,60%,75%,90%,to{animation-duration:0;animation-timing-function:none}0%{opacity:1;transform:translateZ(0)}to{transform:translateZ(0)}}.Toastify__none-enter--bottom-center,.Toastify__none-enter--bottom-left,.Toastify__none-enter--bottom-right,.Toastify__none-enter--top-center,.Toastify__none-enter--top-left,.Toastify__none-enter--top-right{animation-name:Toastify__none}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{animation-timing-function:ease-in;opacity:0;transform:perspective(400px) rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px) rotateX(-20deg)}60%{opacity:1;transform:perspective(400px) rotateX(10deg)}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:perspective(400px)}30%{opacity:1;transform:perspective(400px) rotateX(-20deg)}to{opacity:0;transform:perspective(400px) rotateX(90deg)}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{transform:translate3d(110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{transform:translate3d(-110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{transform:translate3d(0,500px,0);visibility:hidden}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(0)}to{transform:translate3d(0,-500px,0);visibility:hidden}}.Toastify__slide-enter--bottom-left,.Toastify__slide-enter--top-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--bottom-right,.Toastify__slide-enter--top-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--bottom-left,.Toastify__slide-exit--top-left{animation-name:Toastify__slideOutLeft}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}
