:root{--font-family: "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;--color-primary: #a6093d;--color-secondary: #b73861;--color-secondary-hover: #9f3055;--color-accent: #2f4858;--color-white: #fff;--color-bg: #f8f7fa;--color-bg-secondary: #f1f5f9;--color-bg-hover: #f9fafb;--color-surface: #fff;--color-text: #111;--color-text-dark: #2f4858;--color-text-muted: #6b7280;--color-border: #ededed;--color-border-light: #e5e7eb;--color-success: #22c55e;--color-success-soft: #dcfce7;--color-danger: #dc2626;--color-danger-dark: #b91c1c;--color-danger-soft: #fee2e2;--color-warning: #bb7906;--color-info: #3730a3;--system-color: #166534;--device-color: #3b82f6;--proxy-color: #f59e0b;--unknown-color: #1f2022;--connection-color: #10b981;--management-color: #f59e0b;--restart-color: #ef4444;--rfid-color: #8b5cf6;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 6px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-base: .2s ease;--border-radius-sm: 4px;--border-radius-md: 5px;--border-radius-lg: 8px;--border-radius-xl: 12px;--border-radius-pill: 50px;--z-sidebar-overlay: 900;--z-sidebar: 1000;--z-popover: 1100;--z-modal-backdrop: 1200;--z-modal: 1210;--z-sheet-backdrop: 1300;--z-sheet: 1310;--z-toast: 2000}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0;font-family:var(--font-family)}html,body{height:100%;background:var(--color-bg);color:var(--color-text);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:#78787866;border-radius:var(--border-radius-sm)}::-webkit-scrollbar-thumb:hover{background-color:#78787899}.mono{font-family:var(--font-mono)}.stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.app-shell{height:100vh;overflow:hidden;display:flex;flex-direction:column}.page{padding:.75rem 1.5rem;max-width:1700px}.page-header{display:flex;align-items:end;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.page-header-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.page-header h1{margin:0 0 4px;font-size:1.5rem;font-weight:700;color:var(--color-text-dark)}.page-header p{color:var(--color-text-muted);font-size:.85rem;margin:0}.section-title{font-size:1rem;font-weight:600;color:var(--color-text-dark);margin-bottom:.35rem}.section-subtitle{color:var(--color-text-muted);font-size:.8rem}.divider{border:none;border-top:1px solid var(--color-border);margin:12px 0}.tab-toolbar,.device-nav,.dropdown-menu{padding:0}.layout-body{display:flex;align-items:stretch;height:100%;overflow:hidden}.content-area{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.content{flex:1 1 auto;min-width:0;overflow-y:auto;overflow-x:hidden}.app-overlay{display:none}.app-shell.is-sidebar-open .app-overlay{display:block}.loading-state{display:flex;justify-content:center;align-items:center;min-height:200px;padding:2rem}.spinner-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:1rem;color:var(--color-text-muted);font-weight:500;margin:0;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.desktop-only{display:flex!important}.mobile-only{display:none!important}.dropdown{position:relative;display:inline-block}.dropdown-toggle{display:flex;align-items:center;gap:.4rem;background:none;border:none;padding:.35rem .75rem;cursor:pointer;font-size:.8rem;color:inherit}.dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);border-bottom:6px solid var(--color-primary);box-shadow:var(--shadow-lg);padding:0;overflow:hidden;z-index:var(--z-popover)}.dropdown-menu ul{list-style:none;padding:0;margin:0}.dropdown-menu li a{color:var(--color-text)}.dropdown-menu li a,.dropdown-menu li button{width:100%;display:flex;align-items:center;gap:8px;background:none;border:0;padding:6px 10px;border-radius:0;cursor:pointer;text-decoration:none;font-family:var(--font-family);font-size:.8rem;transition:background var(--transition-fast),color var(--transition-fast)}.dropdown-menu li a:hover,.dropdown-menu li button:hover{background:var(--color-secondary);color:var(--color-white)}.load-more-container{display:flex;justify-content:center;margin-top:2rem;padding:1rem 0}.load-more-container .btn{min-width:200px}@media (max-width: 960px){.layout-body{flex-direction:column}}@media (max-width: 768px){::-webkit-scrollbar{display:none;width:0}*{scrollbar-width:none}.page-header{flex-direction:column;align-items:flex-start;gap:.5rem}.page-header-actions{margin-right:auto}.page-header-actions{margin-left:0;width:100%}.desktop-only{display:none!important}.mobile-only{display:flex!important}}@media (max-width: 480px){.page-header h1{font-size:1.5rem}.page{padding:.75rem 1rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}}.badge{display:inline-block;padding:1px 7px;border-radius:var(--border-radius-pill);font-size:11px;font-weight:600;line-height:1.4;background:var(--color-bg-secondary);color:var(--color-text-dark)}.badge-outline{border:1px solid currentColor;background:transparent}.badge-info{background:#eef2ff;color:var(--color-info)}.badge-warning{background:#fef3c7;color:var(--color-warning)}.badge-success{background:var(--color-success-soft);color:var(--color-success)}.badge-error{background:var(--color-danger-soft);color:var(--color-danger)}.badge-muted,.badge-debug{background:var(--color-bg-secondary);color:var(--color-text-muted)}.type-system{color:var(--system-color)}.type-device{color:var(--device-color)}.type-proxy{color:var(--proxy-color)}.type-unknown{color:var(--unknown-color)}.status{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .6rem;text-transform:uppercase;border-radius:var(--border-radius-pill);font-size:.7rem;line-height:1;border:1px solid transparent}.status-online{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:var(--color-success);border-color:var(--color-success);font-weight:500}.status-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:var(--color-warning);border-color:var(--proxy-color);font-weight:500}.status-error,.status-offline{background:linear-gradient(135deg,#fef2f2,#fecaca);color:var(--color-danger);border-color:var(--color-danger);font-weight:500}.status-info{background:var(--color-accent);color:var(--color-white)}.status-unknown{background:linear-gradient(135deg,#f3f4f6,var(--color-border-light));color:var(--color-text-muted);border-color:#9ca3af}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;height:34px;padding:0 .7rem;border-radius:var(--border-radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.8rem;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.btn.is-active{background:var(--color-secondary);border-color:var(--color-secondary);color:var(--color-white)}.btn:hover{background:var(--color-secondary-hover);border-color:var(--color-secondary-hover);color:var(--color-white)}.btn:hover.is-active{background:var(--color-secondary);border-color:var(--color-secondary);color:var(--color-white)}.btn:disabled{opacity:.55;filter:grayscale(30%);pointer-events:none}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px #2f485826;border-color:var(--color-accent)}.btn-primary{background:var(--color-accent);color:var(--color-white);border-color:var(--color-accent)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-md)}.btn-outline{background:var(--color-white);color:var(--color-accent);border-color:var(--color-accent)}.btn-outline:hover{background:var(--color-accent);color:var(--color-white);border-color:var(--color-accent)}.btn-danger{background:var(--color-danger);color:var(--color-white);border:1px solid var(--color-danger)}.btn-danger:hover:not(:disabled){background:var(--color-danger-dark)}.btn-icon{min-width:34px;width:34px;padding:0;gap:0}.btn-icon-success{color:var(--color-success);border:1px solid var(--color-border);background:transparent}.btn-icon-success:hover{color:var(--color-success);background:var(--color-success-soft);border-color:var(--color-success)}.btn-icon-danger{color:var(--color-danger);border:1px solid transparent;background:transparent}.btn-icon-danger:hover{color:var(--color-danger);background:var(--color-danger-soft);border-color:var(--color-danger)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;height:28px;width:28px;border-radius:var(--border-radius-sm);border:1px solid transparent;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.icon-btn:hover{background:var(--color-bg-hover);color:var(--color-text)}@media (max-width: 768px){.btn{min-width:0;font-size:13px}}@media (max-width: 480px){.btn{width:100%}}.card{position:relative;display:flex;flex-direction:column;justify-content:space-between;gap:.5rem;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base),outline-color var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card:focus-visible{outline:3px solid rgba(47,72,88,.35)}.card-header{display:flex;align-items:start;justify-content:space-between;gap:.5rem}.card-header>:first-child{min-width:0}.card-header h4{margin:0;font-size:1rem}.card-title{font-weight:700;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin:0}.card-subtitle{margin-top:.15rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;overflow-wrap:anywhere;word-break:break-word;white-space:normal;max-width:100%;line-height:1.35}.card-content{display:flex;flex-direction:column;gap:.5rem;flex:1}.card-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);line-height:1.2}.card-value{font-size:.96rem;line-height:1.45;color:var(--color-text);word-break:break-word}.card-value.mono{font-family:var(--font-mono);font-weight:600}.card-row{display:flex;flex-direction:column;gap:4px;min-width:260px}.field-stack{display:flex;flex-direction:column;gap:.5rem}.field-stack-tight{gap:2px}.meta-row{display:flex;align-items:center;justify-content:space-between;font-size:.9rem;color:var(--color-text-muted)}.kv{display:flex;flex-wrap:wrap;align-items:center;gap:.2rem .75rem;font-size:.85rem}.kv .key{flex:0 0 auto;color:var(--color-text);white-space:nowrap}.kv .val{flex:1 1 auto;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:clamp(1rem,1vw,1.25rem)}.panel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;width:100%}.panel-table{display:flex;flex-direction:column;gap:1rem;padding:clamp(1rem,1.2vw,1.5rem)}.panel-table .tanstack-table-container{border:1px solid var(--color-border);box-shadow:none;background:var(--color-surface);border-radius:var(--border-radius-md);overflow:hidden}.panel-table .table-wrapper{border-radius:0}.empty-state{padding:4rem 2rem;text-align:center;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--border-radius-lg);color:var(--color-text-muted);margin:2rem 0;box-shadow:var(--shadow-sm)}.empty-state h3{margin:0 0 .5rem;font-size:1.1rem;color:var(--color-text-dark)}.empty-state p{max-width:400px;margin:0 auto;line-height:1.5}.empty-state.compact{padding:24px 16px;margin:12px}.form-error-card{border:1px solid var(--color-danger);border-radius:var(--border-radius-lg);padding:12px 14px;background:#fff5f5;color:var(--color-danger);font-weight:600;margin-top:.5rem;width:100%}.form-error-card p{margin:0}.details-flex{display:flex;flex-direction:column;gap:1rem}.card-small,.card-medium,.card-large{display:flex;justify-content:space-between;min-width:0}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.detail{display:flex;flex-direction:column;gap:6px;min-width:0}.detail.span-2{grid-column:span 2}.detail .key{font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.detail .val{font-weight:600;color:var(--color-text);word-break:break-word}@media (min-width: 768px){.details-flex{flex-direction:row;gap:2rem}.details-flex .group{flex:1;display:flex;flex-direction:column;gap:.75rem}}@media (max-width: 640px){.detail.span-2{grid-column:auto}}.tanstack-table-container{width:100%;background:transparent;border-radius:0;box-shadow:none;overflow:hidden;border:none;display:flex;flex-direction:column}.table-wrapper{overflow-x:auto;overflow-y:visible;width:100%;display:block;background:var(--color-surface);min-height:200px}.data-table{width:100%;border-collapse:collapse;font-size:13px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;table-layout:auto;display:table;background:var(--color-surface)}.data-table thead{display:table-header-group;background:var(--color-bg-hover);border-bottom:2px solid var(--color-border)}.data-table tbody{display:table-row-group}.data-table tbody tr:hover{background:var(--color-bg-hover)}.data-table tbody tr:last-child .table-cell{border-bottom:none}.data-table tr{display:table-row}.data-table th,.data-table td{display:table-cell;vertical-align:middle}.table-header{background:transparent;border-bottom:none;padding:8px 12px;text-align:left;font-weight:600;font-size:.8rem;color:var(--color-text-dark);text-transform:uppercase;letter-spacing:.025em;-webkit-user-select:none;user-select:none;position:static;white-space:nowrap;vertical-align:middle}.data-table th:first-child,.data-table td:first-child{position:static;background:transparent;box-shadow:none}.data-table .table-row.selected td:first-child{background:linear-gradient(to right,#eff6ff,#f0f9ff)}.table-header.sortable{cursor:pointer;transition:all var(--transition-base)}.table-header.sortable:hover{background:linear-gradient(to bottom,var(--color-bg-secondary),#e2e8f0);color:var(--color-text-dark)}.header-content{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:20px}.sort-indicator{opacity:.4;font-size:14px;font-weight:700;transition:opacity var(--transition-base);color:var(--color-text-muted)}.table-header.sortable:hover .sort-indicator{opacity:.8;color:#3b82f6}.table-row{border-bottom:1px solid var(--color-bg-secondary)}.table-row:hover{background:var(--color-bg-secondary)}.table-row.selected{background:linear-gradient(to right,#eff6ff,#f0f9ff)}.table-row.selected:hover{background:linear-gradient(to right,#dbeafe,#e0f2fe)}.table-row.clickable{cursor:pointer}.table-cell{padding:10px 12px;vertical-align:middle;color:var(--color-text);font-size:.8rem;border-bottom:1px solid var(--color-border);border-right:none;white-space:normal;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-height:1.35;max-height:2.7em;word-break:normal;overflow-wrap:break-word}.table-cell:last-child{border-right:none}.table-cell .mobile-cell-content{display:flex;flex-direction:column;gap:6px}.table-cell .mobile-primary{font-weight:600;color:var(--color-text);font-size:14px}.table-cell .mobile-secondary{font-size:12px;color:var(--color-text-muted);font-family:var(--font-mono);background:var(--color-bg-secondary);padding:2px 6px;border-radius:var(--border-radius-sm);display:inline-block;max-width:fit-content}.cell-nowrap{white-space:nowrap!important;display:inline-block;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp:initial}.table-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent);border-radius:var(--border-radius-sm);border:2px solid var(--color-border);background:var(--color-surface);position:relative}.select-header{display:flex;align-items:center;justify-content:center;width:100%;min-height:20px;padding:0}.select-cell{display:flex;align-items:center;justify-content:center;width:100%;padding:0}.pagination-controls{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--color-bg-hover);border-top:1px solid var(--color-border);font-size:13px}.pagination-info{color:var(--color-text-muted);font-weight:500}.pagination-buttons{display:flex;align-items:center;gap:4px}.pagination-btn{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--border-radius-lg);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:13px;font-weight:500;transition:all var(--transition-base);min-width:36px;display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:var(--color-bg-secondary);border-color:var(--color-text-muted);box-shadow:var(--shadow-sm)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--color-bg-hover)}.page-info{color:var(--color-text);font-weight:600;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--border-radius-lg);padding:8px 16px}.mobile-cards-container{width:100%;background:var(--color-surface)}.mobile-card{padding:1.25rem;border-radius:var(--border-radius-lg);border:1px solid var(--color-border);margin-bottom:1rem;display:flex;flex-direction:column}.mobile-card:hover{background:transparent}.mobile-card.selected{background:transparent;border-left:1px solid var(--color-border);padding-left:1.25rem}.mobile-card.clickable{cursor:pointer}.mobile-card-body{display:flex;flex-direction:column;gap:0}.mobile-field{display:flex;flex-direction:row;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--color-border)}.mobile-field:last-of-type{border-bottom:none}.mobile-label{font-weight:500;color:var(--color-text-muted);font-size:.875rem;min-width:100px;flex-shrink:0;text-transform:none;letter-spacing:normal}.mobile-value{flex:1;text-align:right;word-break:break-word;font-size:.9rem;color:var(--color-text)}.mobile-card-header{display:flex;align-items:flex-start;gap:12px}.mobile-card-title{flex:1}.mobile-card-title h4{margin:0;font-size:15px;font-weight:600;color:var(--color-text)}.mobile-subtitle{font-size:12px;color:var(--color-text-muted);margin-top:4px}.mobile-actions-slot{display:flex;gap:8px;flex-shrink:0}.mobile-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent);flex-shrink:0}@media (max-width: 1200px){.data-table{table-layout:auto}.table-header{white-space:normal;padding:12px 14px;font-size:13px}.table-cell{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;max-height:2.7em;word-break:normal;overflow-wrap:break-word;padding:12px 14px;font-size:13px}.cell-nowrap{white-space:nowrap!important;overflow:hidden;text-overflow:ellipsis}}@media (max-width: 1100px) and (min-width: 901px){.table-header{padding:10px 12px;font-size:12.5px}.table-cell{padding:10px 12px;font-size:12.5px;line-height:1.3}.data-table{font-size:12.5px}}@media (max-width: 900px){.table-header{padding:8px 12px;font-size:13px}.table-cell{padding:12px}.table-row{min-height:60px}.table-checkbox{width:20px;height:20px}.pagination-controls{flex-direction:column;gap:12px;text-align:center}.pagination-buttons{justify-content:center}.pagination-btn{padding:10px 14px;min-width:44px}.mobile-cards-container{padding:12px;gap:8px}.mobile-card-header{padding:12px}.mobile-card-title h4{font-size:15px}.mobile-card-title span{font-size:13px}.mobile-card-body{padding:12px}}@media (max-width: 480px){.table-header{padding:6px 8px;font-size:12px}.table-cell{padding:8px}.mobile-primary{font-size:14px}.mobile-secondary{font-size:11px}.mobile-field{flex-direction:column;align-items:flex-start;gap:6px;padding:12px 0}.mobile-label{min-width:auto}.mobile-value{text-align:left;max-width:100%}}.date-range-picker{position:relative;display:inline-block}.date-range-trigger{display:flex;align-items:center;justify-content:center;padding:.5rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-md);color:var(--color-text);cursor:pointer;transition:all .2s ease;min-width:38px;min-height:38px}.date-range-trigger:hover{background:#e2e8f0;border-color:#94a3b8}.date-range-trigger:focus{outline:2px solid var(--color-primary);outline-offset:2px}.date-range-dropdown{position:absolute;top:calc(100% + .5rem);right:0;z-index:var(--z-sidebar);min-width:300px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);box-shadow:0 4px 16px #0000004d;padding:1rem}.date-range-inputs{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.date-input-group{display:flex;flex-direction:column;gap:.25rem}.date-input-group label{font-size:.75rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.date-input-group input[type=date]{padding:.5rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text);font-size:.875rem;font-family:inherit}.date-input-group input[type=date]:focus{outline:none;border-color:var(--color-primary);background:var(--color-surface)}.date-range-actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.date-range-actions .btn{font-size:.875rem;padding:.5rem 1rem}.date-range-actions .btn-text{background:transparent;color:var(--color-text-muted);border:none}.date-range-actions .btn-text:hover{background:var(--color-bg-secondary);color:var(--color-text)}.date-range-inline{display:block;width:100%}.date-range-inline .date-range-inputs{margin-bottom:1rem}.date-range-inline .date-range-actions{padding-top:.5rem;border-top:none}@media (max-width: 768px){.date-range-dropdown{right:auto;left:0;min-width:280px}.date-range-trigger{width:100%;justify-content:center}}.select,select{min-width:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:var(--color-surface);background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' 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:calc(100% - .6rem) center;background-size:.85rem;padding:6px 2rem 6px 10px;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text);font-size:.8rem;font-family:inherit;cursor:pointer;transition:border-color var(--transition-base),box-shadow var(--transition-base),background-color var(--transition-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select:hover,select:hover{border-color:var(--color-accent)}.select:focus,select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #2f48581a,inset 0 1px 2px #0000000f;background-color:var(--color-white)}.select:disabled,select:disabled{opacity:.55;filter:grayscale(30%);pointer-events:none}input,textarea{border:1px solid var(--color-border);border-radius:var(--border-radius-sm);padding:6px 10px;color:var(--color-text);font-size:.8rem;background-color:var(--color-bg-hover);font-family:inherit;max-width:100%;box-sizing:border-box;box-shadow:inset 0 1px 2px #0000000f;transition:border-color var(--transition-base),box-shadow var(--transition-base),background-color var(--transition-base)}input:hover:not(:disabled),textarea:hover:not(:disabled){border-color:var(--color-accent)}input:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #2f48581a,inset 0 1px 2px #0000000f;background-color:var(--color-white)}input:disabled,textarea:disabled{opacity:.55;filter:grayscale(30%);pointer-events:none}textarea{resize:vertical;min-height:120px;line-height:1.6}input.error,textarea.error,select.error{border-color:var(--color-danger)}input.error:focus,textarea.error:focus,select.error:focus{box-shadow:0 0 0 3px #dc26261a}.input-muted{background-color:var(--color-bg-secondary)}input[type=checkbox]{accent-color:var(--color-accent);cursor:pointer;width:15px;height:15px;flex-shrink:0}input[type=checkbox]:focus,input[type=radio]:focus{box-shadow:none;background-color:transparent;outline:none}.checkbox-label{display:inline-flex;align-items:center;gap:8px;margin-top:8px;margin-bottom:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{margin:0;vertical-align:middle}.checkbox-label span{font-size:.85rem;line-height:1}input[type=radio]{accent-color:var(--color-accent);cursor:pointer;width:15px;height:15px;flex-shrink:0;background:transparent;border:none;box-shadow:none}.radio-label{display:inline-flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;min-width:0}.radio-label input[type=radio]{margin:0}.radio-label span{font-size:.85rem;line-height:18px}.checkbox-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--border-radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast)}.checkbox-row:hover{background:var(--color-bg-hover)}.checkbox-row input[type=checkbox]{margin:0}.form-compact{display:flex;flex-direction:column;justify-content:end;flex:1 1 100%;gap:.35rem;min-width:fit-content}.form-compact.wide{min-width:0}.form-compact label{font-size:.7rem;color:var(--color-text-muted);margin-bottom:0;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.form-flex{display:flex;flex-wrap:wrap;gap:16px}.form-flex.two-col .form-compact{flex:1 1 calc(50% - 12px);min-width:260px;justify-content:start}.form-flex.two-col .form-compact.span-2{flex:1 1 100%;min-width:100%}.input-with-actions{display:flex;align-items:stretch;gap:6px}.input-with-actions input{flex:1 1 auto}.input-error{border-color:var(--color-danger)!important;background-color:#ef44440d}.input-error:focus{border-color:var(--color-danger)!important;box-shadow:0 0 0 3px #ef44441a}.input-success{border-color:var(--color-success)!important;background-color:#10b9810d}.input-success:focus{border-color:var(--color-success)!important;box-shadow:0 0 0 3px #10b9811a}.error-text{display:block;margin-top:4px;font-size:.85rem;color:var(--color-danger);font-weight:500}.help-text{margin-top:12px;color:var(--color-text-muted);font-size:.85rem}.submit-row{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-top:1rem}.strength-checks{list-style:none;padding:0;margin:.25rem 0 0;display:flex;flex-direction:column;gap:.15rem;font-size:.75rem;color:var(--color-text-muted)}.strength-checks li.passed{color:var(--color-success)}@media (max-width: 768px){.form-flex.two-col .form-compact{flex:1 1 100%;min-width:0}.form-compact.wide,.form-compact.wide input{width:100%;flex:1 1 100%}}.topbar{flex-shrink:0;display:flex;align-items:center;height:44px;gap:.75rem;padding:0 1rem;background:var(--color-primary);color:var(--color-white);border-bottom:1px solid rgba(0,0,0,.25)}.topbar-dev{background:#d97706;border-bottom:3px solid #f59e0b}.hamburger-menu-toggle{display:none;background:none;color:var(--color-white);border:none;cursor:pointer;padding:.5rem}.topbar-actions{margin-left:auto;display:flex}.logout-btn{text-align:start;font-weight:600;color:var(--color-danger)}.logout-btn:hover{background:var(--color-secondary);color:var(--color-white)}.dev-mode-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background:#fbbf2433;border:2px solid #fbbf24;border-radius:var(--border-radius-md);font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#fbbf24;animation:pulse-glow 2s ease-in-out infinite}.dev-mode-badge-text{text-shadow:0 0 10px rgba(251,191,36,.5)}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #fbbf2466}50%{box-shadow:0 0 20px #fbbf2499}}@media (max-width: 960px){.hamburger-menu-toggle{display:inline-flex;align-items:center;justify-content:center}}.modal-backdrop{position:fixed;inset:0;display:grid;place-items:center;background:#03080f85;z-index:var(--z-modal-backdrop);animation:modal-fade .16s ease-out;padding:16px}.modal{background:var(--color-surface);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-lg);width:min(100%,720px);display:flex;flex-direction:column;max-height:90vh;overflow:hidden;animation:modal-pop .18s ease-out;z-index:var(--z-modal)}.modal-sm{max-width:420px}.modal-md{max-width:640px}.modal-lg{max-width:920px}.modal-header{display:flex;align-items:start;justify-content:space-between;gap:.5rem;padding:.75rem 1rem .6rem;border-bottom:1px solid var(--color-border);background:var(--color-surface);position:sticky;top:0;z-index:2}.modal-title{margin:0;font-weight:700;font-size:clamp(.95rem,1.2vw,1.05rem);color:var(--color-text-dark)}.modal-scroll-area{flex:1 1 auto;overflow-y:auto;padding:0 1rem}.modal-body{padding:.75rem 0 1rem;display:grid;gap:10px}.modal-body form{display:flex;flex-direction:column;gap:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.6rem 1rem .75rem;border-top:1px solid var(--color-border);background:var(--color-surface);position:sticky;bottom:0;z-index:2}.modal-close{appearance:none;border:none;background:transparent;color:var(--color-text-muted);width:28px;height:28px;border-radius:var(--border-radius-sm);cursor:pointer;font-size:20px;line-height:1;display:grid;place-items:center;transition:background var(--transition-fast),color var(--transition-fast)}.modal-close:hover{background:var(--color-bg-hover);color:var(--color-text)}.modal-close:focus-visible{outline:none;box-shadow:0 0 0 3px #2f485826}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{0%{transform:translateY(4px) scale(.985);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.form-description{margin:0 0 1.5rem;padding:.875rem;background:var(--color-bg);border-left:3px solid var(--color-accent);border-radius:var(--border-radius-md);font-size:.9rem;line-height:1.5;color:var(--color-text-muted)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;font-size:.9rem;color:var(--color-text);margin:0}.form-group label .required{color:var(--color-danger);margin-left:2px}.form-hint{font-size:.85rem;color:var(--color-text-muted);margin-top:-.25rem}.form-group input,.form-group textarea,.form-group select{width:100%}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af;opacity:1}.form-error{font-size:.85rem;color:var(--color-danger);margin-top:-.25rem}.forget-info{margin-top:1rem;padding:.75rem;background-color:#3b82f61a;border-left:3px solid rgba(59,130,246,.5);border-radius:var(--border-radius-sm);color:var(--color-text);font-size:.9rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;width:100%}.modal-actions .btn{min-width:100px}.success-modal{display:flex;flex-direction:column;gap:1rem;padding:0 .5rem}.icon-success{color:var(--color-success)}@media (max-width: 768px){.modal{max-width:95%;max-height:92vh}.modal-scroll-area{padding:0 .75rem}.modal-header,.modal-footer{padding:.75rem}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}.sheet-backdrop{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:var(--z-sheet-backdrop);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease,visibility .2s ease}.sheet-backdrop.is-open{opacity:1;visibility:visible;pointer-events:auto}.bottom-sheet{display:flex;flex-direction:column;position:fixed;left:0;right:0;bottom:0;background:var(--color-surface);border-top-left-radius:16px;border-top-right-radius:16px;box-shadow:0 -8px 24px #00000026;z-index:var(--z-sheet);padding:.75rem 1rem 1rem;transform:translateY(100%);visibility:hidden;pointer-events:none;transition:transform .22s ease,visibility .22s ease}.bottom-sheet.is-open{transform:translateY(0);visibility:visible;pointer-events:auto}.sheet-handle{width:40px;height:4px;background:var(--color-border);border-radius:var(--border-radius-pill);margin:.25rem auto .75rem}.sheet-title{margin:0 0 .5rem;font-size:1rem;text-align:center;color:var(--color-text)}.sheet-actions{display:flex;flex-direction:column;gap:.5rem}.sheet-actions .btn{width:100%;justify-content:center;min-height:44px}.sheet-close{margin-top:.5rem;width:100%;background:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);padding:.75rem;cursor:pointer}.bottom-sheet .filter-tabs{display:flex;flex-direction:column;gap:8px;flex-wrap:nowrap;overflow:visible}.bottom-sheet .tab-btn{width:100%}.app-sidebar{position:relative;top:0;left:0;display:flex;flex-direction:column;flex:0 0 220px;width:220px;height:100vh;background:var(--color-surface);box-shadow:2px 0 8px #0000001f;overflow:hidden;transition:width .25s ease,flex-basis .25s ease,box-shadow .2s ease}.sidebar-header{display:flex;align-items:center;justify-content:center;padding:1.25rem .75rem .25rem}.sidebar-header img{max-width:80%}.customer-wrap{margin:1rem;padding:.75rem 0;border-bottom:1px solid rgba(148,163,184,.35)}.sidebar-select-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);display:block;margin-bottom:.4rem}.customer-wrap select{width:100%;border:1px solid rgba(148,163,184,.6);border-radius:var(--border-radius-md);padding:.55rem .75rem;font-size:.9rem;color:var(--color-text)}.customer-wrap select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #a6093d26;outline:none}nav.sidebar-menu{padding:0 .5rem;margin:0 1rem;display:flex;flex-direction:column;gap:.25rem;align-items:stretch;flex:1;overflow-x:hidden}.menu-link,.menu-group-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.35rem .5rem;border-radius:var(--border-radius-sm);text-decoration:none;border:1px solid transparent;background:none;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);font:inherit;line-height:1.2;font-size:13px;box-sizing:border-box;color:var(--color-text)}.menu-group-btn[aria-expanded=true]{background:var(--color-bg-hover);border-color:var(--color-border)}.menu-link:hover,.menu-group-btn:hover{background-color:var(--color-secondary);color:var(--color-white)}.menu-link.is-active,.menu-group-btn.is-active{color:var(--color-white)!important;background:var(--color-primary);border-color:var(--color-primary)}.menu-link:focus-visible,.menu-group-btn:focus-visible,.submenu-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--border-radius-sm)}.menu-link svg,.menu-group-btn svg,.submenu-link svg{flex:none}.submenu{display:flex;flex-direction:column;gap:1px;margin-left:1.1rem;margin-top:.25rem;padding-left:.75rem;border-left:1px solid var(--color-border)}.submenu-link{display:flex;align-items:center;gap:.4rem;padding:.3rem .5rem;border-radius:var(--border-radius-sm);text-decoration:none;box-sizing:border-box;transition:background var(--transition-fast),color var(--transition-fast);color:var(--color-text-muted);font-size:12px}.submenu-link:hover{background-color:var(--color-bg-hover);color:var(--color-text)}.submenu-link.is-active{background:transparent;color:var(--color-primary);font-weight:600}@media (max-width: 960px){.app-sidebar{position:fixed;left:0;top:44px;bottom:0;width:320px;max-width:84vw;transform:translate(-105%);transition:transform .25s ease,box-shadow .25s ease;box-shadow:none;z-index:var(--z-sidebar)}.app-sidebar>*{opacity:1;visibility:visible;pointer-events:auto}.app-shell.is-sidebar-open .app-sidebar{transform:translate(0);box-shadow:1px 0 10px #00000073}.app-overlay{position:fixed;inset:44px 0 0;background:#0006;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:var(--z-sidebar-overlay)}.app-shell.is-sidebar-open .app-overlay{opacity:1;pointer-events:auto}}@media (prefers-reduced-motion: reduce){.app-sidebar,.menu-link,.menu-group-btn,.submenu-link{transition:none!important}}.tab-toolbar{display:flex;gap:.5rem;border:none;padding:0;margin-bottom:1rem}.tab{flex:1 1 0;display:inline-flex;justify-content:center;align-items:center;font-weight:600}.filter-tabs{display:flex;flex-wrap:wrap;gap:6px}.tab-btn{padding:6px 10px;border-radius:var(--border-radius-sm);font-size:14px;white-space:nowrap}.tab-btn.is-active{background:var(--color-primary);color:var(--color-surface);border-color:var(--color-primary)}@media (max-width: 1024px){.tab{width:100%}}@media (max-width: 768px){.filter-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:4px}.tab-btn{font-size:13px;padding:4px 8px;flex:0 0 auto}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-container{position:fixed;top:80px;right:20px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:400px}.toast{pointer-events:auto;display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:var(--border-radius-md);border:1px solid transparent;border-left-width:4px;box-shadow:var(--shadow-md);animation:slideIn .3s ease;max-width:350px;background:var(--color-bg-secondary);border-color:var(--color-info);color:var(--color-text)}.toast--success{background:var(--color-success-soft);border-color:var(--color-success)}.toast--error{background:var(--color-danger-soft);border-color:var(--color-danger)}.toast--warning{background:#fff3cd;border-color:var(--color-warning)}.toast--info{background:var(--color-bg-secondary);border-color:var(--color-info)}.toast_message{flex:1;font-size:14px}.toast_close{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);opacity:.5;transition:opacity var(--transition-fast),background var(--transition-fast)}.toast_close:hover{opacity:1;background:#00000014}@media (max-width: 768px){.toast-container{top:60px;right:10px;left:10px;max-width:none}.toast{max-width:none}}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background:var(--color-border);border-radius:var(--border-radius-pill);transition:background var(--transition-fast)}.slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:var(--color-surface);border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.switch input:checked+.slider{background:var(--color-accent)}.switch input:checked+.slider:before{transform:translate(20px)}.toggle{display:flex;align-items:center;padding-top:.5rem;gap:.75rem}.toggle input[type=checkbox]{appearance:none;-webkit-appearance:none;width:42px;height:24px;border-radius:var(--border-radius-pill);background:var(--color-bg-secondary);border:1px solid var(--color-border);position:relative;outline:none;cursor:pointer;transition:background var(--transition-base),border-color var(--transition-base)}.toggle input[type=checkbox]:before{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--color-surface);transition:transform var(--transition-base)}.toggle input[type=checkbox]:checked{background:var(--color-accent);border-color:var(--color-accent)}.toggle input[type=checkbox]:checked:before{transform:translate(18px)}.search-controls{display:flex;flex-direction:column;align-items:stretch;gap:.75rem;margin-bottom:1rem;padding:12px 16px;background:var(--color-bg-secondary);border-radius:var(--border-radius-md);border:1px solid var(--color-border)}.search-controls input{flex:1 1 auto;width:100%;min-width:0;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);font-size:.9rem;box-sizing:border-box;background:var(--color-white);transition:border-color .2s ease,box-shadow .2s ease}.search-controls input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #2f485826}.export-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-start;width:100%}.created-link-row{display:flex;align-items:stretch;gap:.75rem;margin-top:.5rem}.created-link-row input{flex:1 1 auto;min-width:0;width:100%;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.95rem;padding:.65rem .75rem;border-radius:var(--border-radius-sm);border:1px solid var(--color-border);background:var(--color-surface);box-shadow:inset 0 1px 2px #0f172a14;overflow-x:auto;white-space:nowrap}.created-link-row .btn{flex:0 0 auto;white-space:nowrap}.char-counter{font-size:.75rem;color:var(--color-text-muted)}.modal-body-inner .form-compact+.form-compact{margin-top:1rem}.ext-link-device-info{margin-top:1rem}.ext-link-filters{margin-top:.5rem}.toolbar{display:flex;min-width:0;gap:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);margin-bottom:1rem;padding:clamp(.5rem,.8vw,.75rem);flex-wrap:wrap;align-items:end}.toolbar-row{display:flex;gap:1rem;align-items:end;width:100%}.toolbar-row-item{display:flex;width:100%;justify-content:space-between;gap:.5rem}.view-mode-selector{display:flex;gap:.3rem}.action-toolbar{display:flex;align-items:center;justify-content:center;gap:1.75rem;margin:1.25rem 0;padding:1rem 0;flex-wrap:wrap}.selection-info{font-size:.9rem;color:var(--color-text-muted);font-weight:500;white-space:nowrap;padding-left:.5rem}.selection-count{font-weight:700;color:var(--color-accent)}.action-buttons{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.action-group{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.action-divider{width:1px;height:24px;background:var(--color-border);margin:0 .25rem;flex-shrink:0}@media (min-width: 769px){.toolbar>.form-compact.wide{flex:1 1 auto;min-width:200px}.toolbar>.form-compact:not(.wide){flex:0 0 auto;min-width:fit-content}}@media (min-width: 1201px){.action-toolbar{justify-content:space-between}}@media (min-width: 1200px){.search-controls{flex-direction:row;align-items:center;flex-wrap:nowrap;gap:1rem}.search-controls input{flex:1 1 auto;max-width:none}.export-buttons{width:auto;margin-left:auto;justify-content:flex-end;flex-wrap:wrap;flex:0 0 auto}}@media (max-width: 1200px){.action-toolbar{flex-direction:column}.action-divider{display:none}.action-group{display:contents}}@media (max-width: 960px){.toolbar-row{flex-direction:column;align-items:stretch}.toolbar-row-item .form-compact{flex:1 1 0}}@media (max-width: 768px){.toolbar{margin:.5rem 0;flex-direction:column;align-items:stretch;gap:12px}.action-toolbar{flex-direction:row;align-items:center;justify-content:space-between;margin:.75rem 0;padding:.75rem 0}.action-buttons{display:none}.selection-info{font-size:.9rem;font-weight:600}.action-toolbar .mobile-only{flex-shrink:0}.action-toolbar .mobile-only .btn{min-width:120px;padding:.75rem 1.25rem;font-weight:600}}@media (max-width: 640px){.created-link-row{flex-direction:column}.created-link-row .btn{width:100%}}@media (max-width: 480px){.toolbar{gap:.5rem;padding:.75rem}.toolbar-row{width:100%}.toolbar-row-item{flex-direction:column;gap:.75rem;width:100%}.toolbar-row-item .form-compact{width:100%;min-width:0}.toolbar-row-item .form-compact select,.toolbar-row-item .form-compact input{width:calc(100% - 4px);max-width:calc(100% - 4px);box-sizing:border-box;font-size:.85rem}.toolbar select{font-size:.75rem;padding:6px 1.8rem 6px 8px;max-width:100%;width:100%!important}.toolbar select option{font-size:.75rem;max-width:100%;overflow:hidden;text-overflow:ellipsis}.toolbar .form-compact label{font-size:.7rem}.view-mode-selector{width:100%;justify-content:center}.filter-dropdown-wrapper,.filter-dropdown-wrapper .btn{width:100%}}@media (max-width: 320px){.search-controls input{width:calc(100% - 2rem);margin:0 auto;padding:10px;font-size:13px}}.tooltip{position:relative;display:inline-flex;align-items:center}.tooltip-trigger{all:unset;cursor:help;display:inline-flex;align-items:center;justify-content:center;line-height:1;padding:2px;color:var(--color-accent);border-radius:var(--border-radius-sm)}.tooltip-trigger:hover,.tooltip-trigger:focus-visible{color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2f48581f}.tooltip-content{position:fixed;left:var(--tt-left, 0px);top:var(--tt-top, 0px);background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--border-radius-md);box-shadow:0 2px 12px #00000014;padding:12px 14px;font-size:.95rem;line-height:1.5;width:max-content;max-width:calc(100vw - 16px);overflow-wrap:anywhere;opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .15s ease,transform .15s ease;z-index:var(--z-popover)}.tooltip-content:after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:6px;background:var(--color-primary);border-bottom-left-radius:6px;border-bottom-right-radius:6px;box-shadow:0 6px 10px #00000026}.tooltip-content.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}@media (hover: none){.tooltip-content{position:fixed!important;left:50%!important;right:auto;top:auto!important;bottom:max(16px,env(safe-area-inset-bottom));transform:translate(-50%);max-width:min(92vw,560px);width:auto;padding:14px 16px;font-size:1rem;line-height:1.6}.tooltip-content:after{display:none}}@media (max-width: 380px) and (hover: none){.tooltip-content{max-width:calc(100vw - 24px);padding:12px 14px;font-size:.95rem}}.event-card{padding:.875rem 1rem}.event-item{display:flex;gap:1rem;align-items:flex-start}.event-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;flex-shrink:0}.event-icon.type-device{background:#3b82f61a;color:var(--device-color)}.event-icon.type-system{background:#22c55e1a;color:var(--system-color)}.event-icon.type-proxy{background:#f59e0b1a;color:var(--proxy-color)}.event-icon.type-unknown{background:#6b72801a;color:var(--unknown-color)}.event-body{flex:1;min-width:0}.event-top-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem}.event-header{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--color-text-muted)}.event-header .sender{font-weight:600;color:var(--color-text)}.event-header .etype,.event-header .event-time{color:var(--color-text-muted)}.event-title{font-size:1rem;font-weight:600;color:var(--color-text);margin:.25rem 0;line-height:1.4}.event-desc{text-align:start;font-size:.9rem;color:var(--color-text-muted);line-height:1.5;margin:0 0 .75rem}.event-footer{display:flex;justify-content:flex-end}.event-exact-time{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap}@media (max-width: 768px){.event-item{gap:.75rem}.event-icon{width:36px;height:36px}.event-header{flex-wrap:wrap}}@media (max-width: 480px){.event-item{gap:.5rem}.event-icon{width:32px;height:32px}.event-title{font-size:.95rem}.event-desc{font-size:.85rem}.event-exact-time{display:none}}.activity-layout{display:flex;gap:1.5rem;align-items:flex-start}.activity-container{display:flex;flex-direction:column;flex:1;min-width:0;gap:2rem}.activity-sidebar{flex:0 0 300px;display:flex;flex-direction:column;gap:1rem;position:sticky;top:1rem;margin-top:3.5rem;border-left:1px solid var(--color-border);padding-left:1.5rem}.sidebar-title{font-size:.85rem;font-weight:600;color:var(--color-text-dark);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.025em}.sidebar-legend{display:flex;flex-direction:column;gap:.5rem}.sidebar-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--color-text)}.sidebar-stats{display:flex;flex-direction:column;gap:.75rem}.sidebar-stat{display:flex;justify-content:space-between;align-items:center}.sidebar-stat-num{font-weight:700;font-size:1.1rem;color:var(--color-text)}.time-group{display:flex;flex-direction:column;gap:.75rem}.time-group-header{display:flex;align-items:center;gap:.75rem;margin:.5rem 0}.time-group-header .line{flex:1 1 auto;height:1px;background:var(--color-border);min-width:2rem}.time-chip-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:600;color:var(--color-text-dark)}.activity-legend-container{display:none;justify-content:flex-end;margin:0;position:relative;z-index:var(--z-popover)}.event-color-legend{position:relative;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--color-bg-secondary);color:var(--color-text-muted);cursor:help;transition:all .2s ease}.event-color-legend:hover{background:#e2e8f0;color:var(--color-text);transform:scale(1.1)}.color-legend-tooltip{position:absolute;top:100%;right:0;margin-top:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:12px;box-shadow:0 4px 12px #00000026;z-index:var(--z-popover);min-width:180px}.tooltip-title{font-size:.85rem;font-weight:600;color:var(--color-text);margin:0 0 8px}.tooltip-item{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:.8rem}.tooltip-item:last-child{margin-bottom:0}.tooltip-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.tooltip-color.device{background:var(--device-color)}.tooltip-color.system{background:var(--system-color)}.tooltip-color.proxy{background:var(--proxy-color)}.tooltip-color.unknown{background:var(--unknown-color)}.tooltip-label{color:var(--color-text)}@media (max-width: 1024px){.activity-sidebar{display:none}.activity-legend-container{display:flex}}@media (max-width: 768px){.activity-legend-container{margin:.75rem 0}.event-color-legend{width:20px;height:20px}.color-legend-tooltip{right:-8px;min-width:160px}.color-legend-tooltip:before{right:16px}}@media (max-width: 480px){.activity-legend-container{margin:.5rem 0}.event-color-legend{width:18px;height:18px}.color-legend-tooltip{right:-16px;min-width:140px;padding:8px;font-size:.75rem}.tooltip-title{font-size:.8rem;margin-bottom:6px}.tooltip-item{font-size:.75rem;margin-bottom:4px}.tooltip-color{width:10px;height:10px}}.create-admin-user .card.panel,.create-admin-user .submit-row{max-width:900px}.org-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px 18px;padding-top:8px}.org-name{font-size:.95rem;line-height:18px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.radio-label-super{margin-top:6px}.radio-label-super .org-name{font-weight:600}.success-title{display:inline-flex;align-items:center;gap:8px}.section-heading{margin:8px 0 6px;font-weight:800;color:var(--color-text-dark);font-size:1rem}.actions-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}.actions-list li{display:inline-flex;align-items:center;gap:8px;color:var(--color-text)}.actions-list li .icon-success+span{color:var(--color-success);font-weight:600}.checkbox-label-spaced{margin-top:16px}.section-heading-spaced{margin-top:14px}.create-new-customer .card.panel,.create-new-customer .submit-row{max-width:900px}.create-customer-form .card{margin-bottom:1rem}.inline-flex-center{display:inline-flex;align-items:center;gap:.5rem}.org-email-notif{display:inline-flex;align-items:center;gap:6px;margin-top:4px;font-size:.85rem}.org-mail-active{color:var(--color-success)}.org-mail-inactive{color:var(--color-text-muted)}.org-kpis{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;text-align:center;margin-top:6px}.org-kpi{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1 1 22%}.kpi-num{font-family:var(--font-mono);font-weight:600;font-size:1rem;line-height:1;color:var(--color-text)}.kpi-num.kpi-online{color:var(--color-success)}.kpi-num.kpi-offline{color:var(--color-danger)}.panel-grid{grid-template-columns:repeat(auto-fill,minmax(max(280px,19%),1fr))}.list-view{width:100%}.list-view td,.list-view th{overflow:visible}.actions-col{width:1%;min-width:56px;text-align:right}.list-view .data-table{table-layout:auto}.danger-zone-content{display:flex;flex-direction:column;gap:1rem}.danger-zone-content ul{margin-left:1.5rem}.danger-zone-content .form-compact{margin-top:1rem}.notif-checkbox-disabled{opacity:.6;cursor:not-allowed}.notif-checkbox-disabled input{cursor:not-allowed}.coming-soon-badge{font-size:.85rem;margin-left:8px;color:var(--color-text-muted);font-style:italic}.dashboard-top{display:flex;gap:1.5rem;align-items:stretch;flex-wrap:wrap}.kpi-row{display:flex;flex-direction:column;gap:.9rem;flex:2 1 auto;align-content:flex-start;align-self:stretch;padding:16px}.kpi-card{position:relative;-webkit-appearance:none;appearance:none;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:4px;padding:14px 12px;border-radius:var(--border-radius-md);background:var(--color-surface);border:1px solid var(--color-border);flex:0 0 auto;width:100%;min-height:92px;cursor:default;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.kpi-value{font-family:var(--font-mono);font-size:clamp(22px,2vw,28px);font-weight:700;line-height:1.1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi-dot{position:absolute;right:12px;top:12px;width:20px;height:20px;border-radius:var(--border-radius-pill);background:var(--color-border);box-shadow:0 0 0 3px #0000000d inset}.kpi-card.is-danger .kpi-dot{background:var(--color-danger)}.kpi-card.is-success .kpi-dot{background:var(--color-success)}.gauge-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:center;flex:1 1 320px;min-width:280px;margin-left:0;padding:16px 20px}.gauge-fallback{height:260px}.legend{list-style:none;padding:0;margin:6px 0 0;display:flex;gap:10px;flex-wrap:wrap;justify-content:center;font-size:12px}.legend li{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--border-radius-pill)}.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px}.dot-green{background:var(--color-success)}.dot-red{background:var(--color-danger)}.chart-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.chart-title{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text)}.custom{display:flex;align-items:center;gap:6px}.muted{color:var(--color-text-muted);font-size:12px;margin-top:8px}.dashboard-charts{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-top:1rem}.dashboard-charts>.card{min-width:0;overflow:hidden}@media (max-width: 1100px){.gauge-wrapper{flex-basis:320px;min-width:260px}}@media (max-width: 1024px){.dashboard-top{flex-direction:column}.gauge-wrapper{flex:0 1 auto;width:100%;min-width:0;margin-left:0}}@media (max-width: 900px){.dashboard{padding:.75rem;gap:1rem}.legend{justify-content:flex-start}}@media (max-width: 768px){.dashboard-charts{grid-template-columns:1fr}}@media (max-width: 480px){.card-title{font-size:16px}.kpi-value{font-size:26px}.stat-label{font-size:12px}.dashboard{padding:.5rem;gap:.75rem}}.device-detail{height:100%;display:flex;flex-direction:column;overflow:hidden}.device-content{display:flex;flex:1;overflow:hidden;margin:clamp(.75rem,2vw,1.5rem);gap:clamp(1rem,2vw,1.5rem);position:relative;transition:margin .2s ease,padding .2s ease}.device-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:clamp(.75rem,2vw,1rem);flex-shrink:0;box-shadow:#3c40434d 0 1px 2px,#3c404326 0 1px 3px 1px}.nav-actions{display:flex;justify-content:space-between;margin-bottom:1rem}.help-button{display:flex;justify-content:flex-end}.header-summary{display:flex;flex-direction:column}.header-row p{padding:.2rem 0}.header-row{display:flex;flex-direction:column}.header-summary-content{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.device-status-section{margin-top:.5rem}.header-summary-main{display:flex;align-items:center;gap:1rem}.header-summary-main h1{margin:0;font-size:clamp(1.25rem,4vw,1.8rem);color:var(--color-text);line-height:1.2}.header-summary-main p{margin:0;color:var(--color-text-muted);font-size:clamp(.8rem,2vw,.9rem)}.device-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:clamp(.5rem,1vw,.75rem)}.device-actions .btn{flex:0 1 auto;min-width:160px}.patchview-section{display:flex;flex-direction:column}.status-message{display:flex;flex-direction:column;gap:.5rem}.install-btn{background:var(--color-accent);color:var(--color-surface);border:none;padding:.75rem 1.5rem;margin-top:1rem;border-radius:var(--border-radius-sm);cursor:pointer;font-weight:600;align-self:flex-end}.install-btn:hover{background:var(--color-secondary)}.details-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:4px 8px;border-radius:var(--border-radius-sm);transition:background-color .2s}.details-btn:hover{background:var(--color-bg-secondary)}.menu-toggle{display:none;background:var(--color-accent);color:var(--color-surface);padding:.75rem 1rem;border:none;cursor:pointer;font-weight:600;font-size:.9rem;font-family:inherit;width:100%;justify-content:space-between;align-items:center;transition:all .3s ease}.menu-toggle:active{background-color:var(--color-bg);color:var(--color-text-muted)}.device-sidebar{width:clamp(200px,25vw,260px);height:fit-content;max-height:calc(100vh - 200px);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);flex-shrink:0;position:sticky;top:1rem;overflow-y:auto}.device-nav{display:flex;flex-direction:column;width:100%;padding:0;margin:0}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;border-radius:0;text-align:left;cursor:pointer;color:var(--color-text);font-size:.85rem;transition:background-color .2s;width:100%;justify-content:flex-start}.nav-item:hover{background:var(--color-bg)}.nav-item.is-active{background:var(--color-primary);color:var(--color-surface)}.nav-item.destructive{color:var(--color-danger)}.nav-item.destructive:hover{background:var(--color-danger-soft)}.nav-item.destructive.is-active{background:var(--color-danger);color:var(--color-surface)}.device-main{flex:1;overflow-y:auto;background:var(--color-bg);min-width:0}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.section-header.destructive{color:var(--color-danger);border-color:var(--color-danger-soft)}.section-header h2{margin:0;font-size:1.2rem;color:inherit}.subsection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.subsection-header h3{margin:0;font-size:1.1rem}.info-grid{display:flex;flex-wrap:wrap;gap:clamp(1rem,3vw,2rem)}.info-group{flex:1;min-width:400px;max-width:100%;background:var(--color-surface)}.info-group h3{margin:0 0 1rem;font-size:1rem;color:var(--color-text)}.field-row{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-bg);padding:.75rem;border-radius:var(--border-radius-md);border:2px solid var(--color-border);margin:.75rem 0;flex-wrap:wrap;gap:.5rem;font-size:.9rem}.field-row-editing{flex-direction:column;align-items:stretch}.field-row-editing .label{margin-bottom:.5rem}.edit-field-wrapper{width:100%}.field-row-editing .edit-field{justify-content:stretch}.field-row-editing .edit-field input{flex:1}.field-row .value{flex:1;text-align:right;color:var(--color-text);min-width:120px;word-break:break-word;overflow-wrap:break-word}.value-with-edit{display:flex;align-items:center;justify-content:flex-end;gap:1rem;flex:1}.value-with-edit .value{margin:0;text-align:right;word-break:break-word;overflow-wrap:break-word}.edit-icon{color:var(--color-text-dark);cursor:pointer}.edit-icon:hover{transform:scale(1.15)}.edit-field{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:flex-end}.edit-field input{flex:1;padding:.5rem;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);font-size:.875rem;text-align:left}.edit-field input:focus{outline:none;border-color:var(--color-primary)}.field-row .value.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.85rem}.patches{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end}.patch-tag{background:var(--color-accent);color:var(--color-surface);padding:.5rem 1rem;border-radius:var(--border-radius-pill);font-size:.75rem}.status-message h3{margin:0 0 1rem;font-size:1.1rem}.status-message-input{width:100%;min-height:300px;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);background:var(--color-bg);color:var(--color-text-muted);resize:none}.status-message-input::placeholder{text-align:left}.confirmation-input{margin-bottom:1.5rem}.confirmation-input label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-danger)}.confirmation-input input{width:100%;padding:.75rem;border:2px solid var(--color-danger-soft);border-radius:var(--border-radius-sm);font-size:1rem}.confirmation-input input:focus{outline:none;border-color:var(--color-danger)}.actions-content{display:flex;flex-direction:column;gap:2rem}.scheduled-grid{display:flex;flex-wrap:wrap;gap:1rem}.scheduled-card{flex:1;min-width:250px;background:var(--color-bg-secondary)}.device-detail .card-content p{margin:.25rem 0;font-size:.85rem;color:var(--color-text-muted)}.recent-actions-section .data-table td,.recent-actions-section .data-table th{padding:1rem .75rem}.recent-actions-section .data-table tbody tr{height:3.5rem}.final-warning{margin-top:2rem;background-color:var(--color-danger-soft);padding:1rem;border-radius:var(--border-radius-lg);border:2px solid var(--color-danger)}.final-warning p{padding-block:1rem}.warning-text{color:var(--color-danger);line-height:1.6;margin-bottom:1.5rem;font-size:1rem}.device-info-box{background-color:var(--color-bg);padding:1rem;border-radius:var(--border-radius-sm);margin:1rem 0;text-align:center;font-size:1.05rem}.error-state{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:400px;font-size:1.1rem;color:var(--color-text-muted)}.error-detail-text{font-size:.8rem;color:var(--color-text-muted)}.mobile-actions-container{display:none;gap:.625rem;align-items:center;padding:.75rem 1rem;background:var(--color-surface)}.mobile-actions-container .btn-label{font-weight:600;letter-spacing:.01em}.mobile-actions-container .btn-icon{flex-shrink:0}.section-dropdown{flex:1 1 auto;min-width:0;padding:.5rem 2rem .5rem .75rem;min-height:44px;font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.indicator:hover{background:var(--color-text-muted);transform:scale(1.1)}@media (min-width: 769px){.mobile-actions-container{display:none!important}}@media (max-width: 1200px){.info-group{min-width:450px}.device-actions{gap:.625rem}.device-actions .btn{flex:1 1 auto;min-width:150px;max-width:180px}}@media (max-width: 1024px){.info-grid{flex-direction:column}.info-group{min-width:100%}.device-actions{justify-content:flex-start;gap:.625rem}.device-actions .btn{flex:1 1 calc(33.333% - .625rem);min-width:140px;max-width:none}}@media (max-width: 768px){.device-detail .panel .section-header,.device-detail .section-header{display:none}.management-log-section .mobile-card-header,.recent-actions-section .mobile-card-header{display:none!important}.nav-actions .btn{min-height:44px}.help-button{display:none}.header-summary-content{flex-wrap:wrap}.header-row,.header-summary-main{flex:1;min-width:200px;gap:.25rem}.header-row{gap:1.5rem;flex-direction:row}.device-status-section{align-self:center}.device-actions{width:100%;justify-content:center;gap:.75rem}.device-actions .btn{flex:1 1 calc(50% - .5rem);min-width:130px;max-width:200px}.section-header{margin:1rem 0}.device-content{flex-direction:column;gap:1rem;margin:0;padding:.75rem .75rem 1.25rem;height:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.device-main{padding:0;order:2;min-height:calc(100vh - 250px);height:auto;overflow-y:visible}.device-main .panel{margin-bottom:1rem;padding:1rem}.device-main .panel:last-child{margin-bottom:0}.field-row{flex-direction:column;align-items:stretch}.field-row .label{text-align:left;font-weight:600;color:var(--color-text)}.field-row .value{text-align:left}.value-with-edit{justify-content:space-between}.patches{justify-content:flex-start}.export-buttons{justify-content:center}.mobile-actions-container{display:flex}}@media (max-width: 480px){.device-header{padding:.5rem}.nav-actions{flex-direction:column;margin-bottom:.5rem;gap:.5rem}.nav-actions .btn{min-height:40px;padding:.375rem .75rem;font-size:.85rem;margin-bottom:0}.help-button .btn{padding:.375rem .75rem;font-size:.85rem;min-height:40px}.header-summary{align-items:center;margin-bottom:.5rem}.header-row,.header-summary-main{min-width:150px}.header-summary-content{margin-bottom:.25rem}.device-status-section{margin-top:.25rem}.header-summary-main h1{font-size:clamp(1.1rem,6vw,1.4rem);margin:0 0 .25rem;word-break:break-word}.header-summary-main p{font-size:clamp(.8rem,4vw,.9rem);color:var(--color-text-muted)}.device-sidebar{border-radius:0;margin:0}.device-main{padding:.5rem;min-height:calc(100vh - 200px)}.info-group{padding:.75rem;margin-bottom:.75rem}.section-header h2{font-size:1.1rem}.edit-icon{padding:.25rem;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}.data-table td,.data-table th{padding:.5rem .25rem;font-size:.75rem;min-width:60px}.mobile-actions-container{padding:.5rem;gap:.375rem}.mobile-actions-container{gap:.5rem;padding:.625rem .75rem}.mobile-actions-container .btn{padding:.5rem .625rem;font-size:.85rem;min-height:40px}.mobile-actions-container .btn-label{font-size:.85rem}.btn-icon{padding:.375rem;min-width:40px}.device-actions{flex-direction:column;align-items:stretch}.device-actions .btn{width:100%}.mobile-actions-container{gap:.5rem;padding:.5rem;flex-wrap:wrap}.mobile-actions-container .btn-icon{min-width:38px;width:38px;height:38px;padding:.25rem;flex-shrink:0}.mobile-actions-container .btn-primary{flex:1 1 100%;width:100%;padding:.625rem 1rem;font-size:.85rem;min-height:42px;order:10}.section-dropdown{flex:1 1 auto;min-width:0;font-size:.85rem;padding:.5rem 1.75rem .5rem .625rem;min-height:38px;height:38px}}.dynamic-addressing-page{padding:1.5rem;width:100%}.dynamic-addressing-page .card{margin-bottom:1.5rem}.dynamic-addressing-page .create-row{display:flex;align-items:center;justify-content:space-between;flex:1 1 100%;min-width:100%;margin-top:.5rem}.dynamic-addressing-page .modal-body-inner .form-flex.two-col,.dynamic-addressing-page .sheet .form-flex.two-col{grid-template-columns:1fr}.dynamic-addressing-page .data-table td:nth-child(2){max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}.device-picker{display:flex;flex-direction:column;max-height:180px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);padding:.25rem .5rem}.extmon.is-fullscreen{position:fixed;inset:0;background:var(--color-bg);overflow:auto}.extmon-header{display:flex;flex-direction:column;gap:.35rem;padding:18px 20px}.extmon-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.extmon-title{margin:0;font-size:24px;font-weight:800;color:var(--color-text-dark)}.extmon-sub{color:var(--color-text-muted);font-size:14px}.extmon-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.extmon-badges{display:flex;flex-wrap:wrap;gap:8px}.extmon-grid{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:flex-start;gap:16px;padding:10px 20px 30px}.extmon-card{flex:0 0 auto;width:clamp(280px,30vw,360px);max-width:100%;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.extmon-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.extmon-host{font-size:1rem;font-weight:700;color:var(--color-text-dark);word-break:break-all;line-height:1.3}.extmon-site{font-size:.8rem;color:var(--color-text-muted);margin-top:-.15rem}.extmon-meta{display:flex;flex-direction:column;gap:2px;margin-top:.25rem;padding-top:.6rem;border-top:1px solid var(--color-border)}.extmon-meta-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.extmon-meta-value{font-size:.875rem;color:var(--color-text)}@media (max-width: 1200px){.extmon-card{width:clamp(260px,32vw,340px)}}@media (max-width: 900px){.extmon-grid{justify-content:center}.extmon-card{width:clamp(240px,44vw,320px)}}@media (max-width: 600px){.extmon-grid{gap:12px;padding:8px 12px 24px}.extmon-card{width:100%;max-width:520px}}.login-page{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,2.5vw,2rem);overflow:auto;background:url(/assets/rod-bg-BZJOsQii.png) center/cover no-repeat fixed}.login-form{width:100%;max-width:450px;padding:2rem;display:flex;flex-direction:column;text-align:left;gap:.75rem}.login-logo img{display:block;margin:0 auto .8rem;max-width:180px}.login-title{margin:.25rem 0 .75rem;font-size:clamp(1.1rem,1.3rem + .2vw,1.4rem);font-weight:800;color:var(--color-text-dark);text-align:center}.login-label{font-weight:600;font-size:.95rem;color:var(--color-text-muted);margin-top:.2rem}.login-form input[type=text],.login-form input[type=password]{width:100%;min-height:clamp(40px,4.2vw,46px);font-size:clamp(.95rem,.9rem + .25vw,1rem)}.remember{display:inline-flex;align-self:flex-start;gap:.5rem;font-size:clamp(.85rem,.8rem + .25vw,.95rem);color:var(--color-text-muted);-webkit-user-select:none;user-select:none}.remember input{min-width:16px;min-height:16px}.login-btn{margin-top:1rem;width:100%;height:clamp(40px,4.5vw,48px);font-weight:700;font-size:clamp(.95rem,.9rem + .2vw,1rem);display:flex;align-items:center;justify-content:center;text-align:center}.login-powered{font-size:clamp(.75rem,.7rem + .25vw,.85rem);color:var(--color-text-muted);text-align:center;width:100%;margin-top:1rem}@media (min-width: 1440px){.login-form{max-width:520px;gap:1rem}.login-title{font-size:1.5rem}}@media (max-width: 768px){.login-logo img{max-width:150px}}@media (max-width: 480px){.login-logo img{max-width:140px}}@media (max-width: 320px){.login-logo img{max-width:100px}}@media (prefers-reduced-motion: reduce){.login-form,.login-page{transition:none!important;animation:none!important}}.logs-grid{display:flex;flex-direction:column;gap:.5rem}.log-card{display:flex;flex-direction:column;gap:.5rem;padding:1rem 1.25rem}.log-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.log-header-left{display:flex;align-items:center;gap:.5rem;min-width:0}.log-time{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap}.log-device-info{display:flex;flex-direction:column;gap:.15rem}.log-device-name{font-size:.95rem;font-weight:600;color:var(--color-text)}.log-message{font-size:.9rem;color:var(--color-text);line-height:1.4;margin:0}.log-details{font-size:.8rem;color:var(--color-text-muted);margin:0}.log-card .type-system{color:var(--system-color)}.log-card .type-device{color:var(--device-color)}.log-card .type-proxy{color:var(--proxy-color)}.log-card .type-connection{color:var(--connection-color)}.log-card .type-management{color:var(--management-color)}.log-card .type-restart{color:var(--restart-color)}.log-card .type-rfid{color:var(--rfid-color)}.log-card .type-unknown{color:var(--unknown-color)}@media (max-width: 768px){.log-header{flex-wrap:wrap}.log-message{font-size:.85rem}}@media (max-width: 480px){.log-card{padding:.5rem .75rem}}.devices-section{margin-bottom:32px}.devices-section .data-table th:first-child,.devices-section .data-table td:first-child{width:60px;min-width:60px;max-width:60px;padding:8px;position:relative;overflow:visible}.devices-section .table-cell:first-child{padding:8px}.devices-section .data-table .select-cell,.devices-section .data-table .select-header{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:visible;padding:0}.devices-section .table-checkbox{width:18px;height:18px;min-width:18px;max-width:18px;cursor:pointer;accent-color:var(--color-accent);border:2px solid var(--color-border);background:var(--color-surface);position:relative;flex-shrink:0;box-sizing:border-box}.devices-section .tanstack-table-container{overflow:visible}.devices-section .table-wrapper{overflow-x:auto;overflow-y:visible}.devices-section .mobile-card.selected{border-color:var(--color-accent);box-shadow:0 0 0 2px #2f485833;background:linear-gradient(to right,var(--color-bg-secondary),var(--color-bg))}.devices-section .mobile-checkbox{accent-color:var(--color-accent)}.devices-section .mobile-checkbox:hover{border-color:var(--color-accent);box-shadow:0 0 0 3px #2f48581a}.devices-section .mobile-checkbox:checked{background:var(--color-accent);border-color:var(--color-accent)}.site-list{max-height:280px;overflow-y:auto;background:var(--color-bg-hover);border:1px solid var(--color-border);border-radius:var(--border-radius-md)}.site-list-item{width:100%;padding:.875rem 1rem;border:none;border-bottom:1px solid var(--color-bg-secondary);background:transparent;text-align:left;cursor:pointer;transition:background .15s ease;font-size:.9375rem;color:var(--color-text);display:flex;align-items:center;justify-content:space-between}.site-list-item:hover{background:var(--color-bg-hover)}.site-list-item.selected{background:#a6093d1a;font-weight:500}.site-list-empty{padding:2rem;text-align:center;color:var(--color-text-muted);font-size:.875rem}.site-confirmation-box{padding:1rem;background-color:#a6093d1a;border-radius:var(--border-radius-md);border:1px solid var(--color-primary)}.site-confirmation-box p{margin:0;color:var(--color-text);font-size:.875rem}.forget-modal-text{margin-bottom:1rem}.forget-device-list{list-style:disc;padding-left:1.5rem;max-height:300px;overflow-y:auto}.forget-warning{margin-top:1rem;color:var(--color-danger);font-weight:600}.device-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;align-items:stretch}.device-card-grid--small{grid-template-columns:repeat(auto-fill,minmax(max(240px,19%),1fr))}.device-card-grid--medium{grid-template-columns:repeat(auto-fit,minmax(max(320px,20%),1fr))}.device-card-grid--large{grid-template-columns:repeat(auto-fit,minmax(max(420px,32%),1fr));gap:1.25rem}@media (max-width: 767px){.device-card-grid{gap:.75rem}}@media (max-width: 480px){.device-card-grid{gap:.5rem}.device-card-grid--small,.device-card-grid--medium,.device-card-grid--large{grid-template-columns:1fr;gap:.75rem}}.list-view{margin-top:1rem}.error-state{padding:20px;text-align:center;background:var(--color-danger-soft);border:1px solid var(--color-danger);border-radius:var(--border-radius-sm);margin:10px 0}.filter-dropdown-wrapper{position:relative;align-self:flex-end}.filter-dropdown-wrapper .btn{border:none}.filter-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:var(--z-popover);min-width:240px;max-width:320px;max-height:50vh;overflow:auto;padding:10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-md);box-shadow:0 6px 12px #0000000f,0 2px 4px #0000000a;transform-origin:top right;animation:filterMenuIn .14s ease-out}.filter-menu:before{content:"";position:absolute;top:-7px;right:16px;width:12px;height:12px;background:var(--color-surface);border-left:1px solid var(--color-border);border-top:1px solid var(--color-border);transform:rotate(45deg)}@keyframes filterMenuIn{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.menu-list{list-style:none;margin:0;padding:0}.menu-actions{display:flex;justify-content:space-between;gap:8px;padding-top:8px;margin-top:8px;border-top:1px solid var(--color-border)}.filter-chip{display:flex;align-items:end;max-width:fit-content;gap:6px;padding:6px 12px;font-size:.85rem;line-height:1;border-radius:var(--border-radius-pill);border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-dark);cursor:pointer;transition:background .14s ease,border-color .14s ease,color .14s ease,transform 80ms ease}.filter-chip svg{display:block;flex-shrink:0}.filter-chip:hover{background:var(--color-bg-hover);border-color:var(--color-accent);color:var(--color-accent)}.filter-chip:active{transform:translateY(1px)}.filter-chip span{font-weight:500}@keyframes chipPop{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.filter-chip{animation:chipPop .15s ease-out}.active-filters{flex-direction:row;align-items:center}.active-filters .btn.btn-subtle{height:32px;padding:0 12px;border-radius:var(--border-radius-pill);color:var(--color-danger);border-color:var(--color-danger);font-weight:500}.active-filters .btn.btn-subtle:hover{background:var(--color-danger-soft);border-color:var(--color-danger)}@media (max-width: 480px){.load-more-container .btn{min-width:0;width:100%}.active-filters{flex-wrap:wrap}.filter-chip{font-size:.8rem;padding:4px 10px}.active-filters .btn.btn-subtle{width:100%;margin-top:.5rem}}.notfound-page{min-height:calc(100vh - 80px);display:grid;place-items:center;padding:clamp(2rem,4vw,3rem) 1.5rem;background:var(--color-bg)}.notfound-card{display:flex;align-items:center;gap:clamp(1.5rem,3vw,2.5rem);padding:clamp(1.5rem,3vw,2.75rem);max-width:900px;width:100%}.notfound-graphic{display:flex;align-items:center;justify-content:center;width:140px;height:140px;border-radius:var(--border-radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border)}.nf-code{font-size:44px;font-weight:800;color:var(--color-primary)}.notfound-content{flex:1 1 auto;display:flex;flex-direction:column;gap:1.25rem}.notfound-row{min-width:0}.notfound-title{margin:0;font-size:clamp(1.5rem,1.3rem + .3vw,1.8rem);color:var(--color-text-dark)}.notfound-subtitle{margin:0;color:var(--color-text-muted);line-height:1.45}.notfound-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.notfound-actions .btn{min-width:0}.notfound-help{margin:0;color:var(--color-text-muted)}@media (max-width: 768px){.notfound-card{flex-direction:column;text-align:center}.notfound-actions{justify-content:center}.notfound-graphic{width:120px;height:120px}}@media (max-width: 480px){.notfound-actions{flex-direction:column}.notfound-actions .btn{width:100%}}.settings-page .card-content>div{display:flex;flex-wrap:wrap;gap:1rem}.password-section{width:100%;padding:1rem 0}.password-feedback{margin-top:.5rem;padding:.5rem .75rem;border-radius:var(--border-radius-sm);font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.feedback-error{color:var(--color-danger);background-color:#ef44441a;border:1px solid rgba(239,68,68,.2)}.feedback-success{color:var(--color-success);background-color:#10b9811a;border:1px solid rgba(16,185,129,.2)}.site-actions{display:flex;align-self:start;justify-content:center;gap:0;flex-shrink:0}.site-table-actions{display:flex;gap:.25rem;justify-content:center}.site-actions-col{text-align:center}.site-contact .label,.site-notes .label{font-size:.85rem;color:var(--color-text-muted);margin-bottom:.15rem}.site-contact .value,.site-notes .value{font-weight:600;margin:0 0 .25rem}.site-contact ul{list-style:none;padding:0;margin:0;color:var(--color-text-muted);font-size:.9rem}.site-contact ul li+li{margin-top:.15rem}.site-modal-form,.site-modal-full,.site-modal-full input{width:100%}.site-modal-notes textarea{width:100%;resize:vertical;min-height:120px}.site-modal-notes textarea::placeholder{color:var(--color-text-muted)}.devices-list{display:flex;flex-direction:column;gap:.5rem;padding:.5rem 0}.device-list-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;transition:background-color .2s ease,border-color .2s ease;text-align:left}.device-list-item:hover{background-color:var(--color-bg-hover);border-color:var(--color-accent)}.device-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.device-name{font-weight:600;color:var(--color-text)}.device-serial{font-size:.85rem;color:var(--color-text-muted)}.devices-list .empty-state{padding:2rem;text-align:center;color:var(--color-text-muted)}@media (max-width: 768px){.site-modal-form .form-flex.two-col .form-compact{min-width:100%}}.support-page .card.panel,.support-page .submit-row{max-width:900px}.support-form.card-content{gap:1rem}.support-actions{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.user-statistics-page{display:flex;flex-direction:column;gap:1.5rem}.filters{display:flex;gap:1rem;flex-wrap:wrap;justify-content:flex-end;align-items:flex-end}.stats-grid{grid-template-columns:repeat(4,minmax(220px,1fr));text-align:center}.stat-icon{font-size:1.75rem}.stat-body{display:flex;flex-direction:column;gap:.5rem}.stat-value{font-size:2rem;margin:0;font-weight:700}.stat-change{font-size:.85rem;color:var(--color-text-muted);margin:0}.chart-card.full-width{width:100%}.chart-subtitle{font-size:.85rem;color:var(--color-text-muted);margin:0}.chart-placeholder{flex:1;min-height:220px;border:1px dashed var(--color-border);border-radius:var(--border-radius-md);display:grid;place-items:center;color:var(--color-text-muted);font-size:.9rem}.table-card .section-subtitle{margin:0;color:var(--color-text-muted);font-size:.9rem}@media (max-width: 1400px){.stats-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (max-width: 1200px){.filters{justify-content:flex-start;width:100%}}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}
