.app-navigation{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;padding:1rem 1.5rem;box-shadow:var(--shadow-md);flex-shrink:0}.nav-content{display:flex;justify-content:space-between;align-items:center;gap:2rem;max-width:1600px;margin:0 auto}.nav-branding{flex:0 0 auto}.nav-branding h1{font-size:1.75rem;margin:0 0 .15rem}.nav-branding .subtitle{font-size:.8rem;opacity:.9;font-weight:400;margin:0}.nav-branding .version-info{font-size:.65rem;opacity:.7;font-weight:400;margin:.25rem 0 0;font-family:JetBrains Mono,monospace}.nav-links{display:flex;gap:.5rem;flex:1;justify-content:center}.nav-links a{padding:.75rem 1.5rem;color:#ffffffd9;text-decoration:none;font-weight:500;font-size:.9375rem;border-radius:.5rem;transition:all .2s;border-bottom:3px solid transparent;position:relative}.nav-links a:hover{color:#fff;background-color:#ffffff1a}.nav-links a.active{color:#fff;font-weight:600;border-bottom-color:#ffffffe6;background-color:#ffffff26}.nav-stats{display:flex;gap:1rem;align-items:center;flex-shrink:0}.stat-badge{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1rem;border-radius:.75rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-badge.online{background:#22c55e40}.stat-badge.offline{background:#ef444440}.stat-badge-value{font-size:1.5rem;font-weight:700;color:#fff;line-height:1}.stat-badge.online .stat-badge-value{color:var(--color-success)}.stat-badge.offline .stat-badge-value{color:var(--color-error)}.stat-badge-label{font-size:.6rem;color:#fffffff2;text-transform:uppercase;letter-spacing:.5px;font-weight:600}@media (max-width: 1024px){.nav-content{gap:1rem}.nav-links a{padding:.6rem 1rem;font-size:.875rem}.nav-stats{gap:.75rem}.stat-badge{padding:.4rem .8rem}.stat-badge-value{font-size:1.25rem}}@media (max-width: 768px){.app-navigation{padding:1rem}.nav-content{flex-direction:column;gap:1rem;align-items:stretch}.nav-branding{text-align:center}.nav-branding h1{font-size:1.5rem}.nav-links{justify-content:center;gap:.5rem}.nav-links a{flex:1;text-align:center;padding:.75rem .5rem;font-size:.875rem}.nav-stats{justify-content:center;gap:.75rem}.stat-badge{flex:1;padding:.6rem .8rem}.stat-badge-value{font-size:1.5rem}.stat-badge-label{font-size:.65rem}}.app-layout{height:100vh;display:flex;flex-direction:column;background-color:var(--color-gray-50);overflow:hidden}.app-content{flex:1;overflow-y:auto;overflow-x:hidden}.icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.icon svg{width:100%;height:100%;display:block}.icon.online{color:var(--color-success)}.icon.offline{color:var(--color-error)}.icon.critical{color:var(--color-critical)}.icon.high{color:var(--color-high)}.icon.medium{color:var(--color-medium)}.icon.low{color:var(--color-low)}.icon.olton{color:var(--color-olton)}.icon.donat{color:var(--color-donat)}.icon.info-icon{color:var(--color-gray-500)}.icon.device-icon{color:var(--color-primary)}.device-card{background:#fff;border-radius:.5rem;box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition);border-left:3px solid;display:flex;flex-direction:column;padding:.75rem;min-height:150px;max-height:190px}.device-card.online{border-left-color:var(--color-success)}.device-card.online:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.device-card.offline{border-left-color:var(--color-error);background:#ef444414}.device-card.offline:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.device-header{padding:0;margin-bottom:.4rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.device-name{font-size:1.1rem;color:var(--color-gray-900);font-weight:500;margin:0;flex:0 1 auto;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-id{font-size:1.15rem;color:var(--color-primary);font-weight:700;margin-left:0;white-space:nowrap;flex-shrink:0}.device-body{padding:0;flex:1;display:flex;flex-direction:column;gap:.35rem;overflow:hidden}.device-badges{display:flex;gap:.25rem;flex-wrap:wrap}.badge{padding:.25rem .625rem;border-radius:.25rem;font-size:.95rem;font-weight:600;white-space:nowrap;line-height:1}.type-badge{background-color:var(--color-gray-200);color:var(--color-gray-800)}.server-badge{background-color:var(--color-gray-100);color:var(--color-gray-700)}.server-badge.olton{background-color:#1e40af1a;color:var(--color-olton)}.server-badge.donat{background-color:#ea580c1a;color:var(--color-donat)}.status-badge{display:inline-flex;align-items:center;gap:.2rem}.status-badge.online{background-color:#22c55e26;color:var(--color-success)}.status-badge.offline{background-color:#ef444426;color:var(--color-error)}.device-timing{display:flex;align-items:center;gap:1rem;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--color-gray-200)}.last-communication{display:flex;gap:.5rem;align-items:baseline}.last-communication .label{color:var(--color-gray-600);font-weight:500;flex-shrink:0;font-size:.875rem}.last-communication .time{color:var(--color-gray-900);font-weight:700;font-size:1rem;font-family:var(--font-mono)}.time-offline{display:flex;align-items:center;gap:.5rem;padding:.375rem .625rem;background-color:#ef444414;border-radius:.25rem}.time-offline .label{color:var(--color-error);font-weight:600;flex-shrink:0;font-size:.8rem}.time-offline .time{color:var(--color-error);font-weight:700;font-size:.95rem;font-family:var(--font-mono)}@media (max-width: 640px){.device-card{min-height:120px;max-height:150px}.device-name{font-size:.95rem}.last-communication{font-size:.9rem}}.device-grid-container{margin-top:.5rem;flex:1;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.device-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;width:100%;height:fit-content}.loading,.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:var(--color-gray-500)}.spinner{border:4px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.empty-state p{font-size:1.125rem}@media (max-width: 1400px){.device-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1024px){.device-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.device-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.device-grid{grid-template-columns:1fr}}.filters-container{background:linear-gradient(135deg,var(--color-primary) 0%,#0d9488 100%);padding:.75rem 1.5rem;border-radius:.75rem;box-shadow:var(--shadow-md);transition:background .3s ease;margin-bottom:1rem;flex-shrink:0}.filters-container.has-offline{background:linear-gradient(135deg,#dc2626,#991b1b)}.filters-container.has-duplicates{background:linear-gradient(135deg,#ea580c,#c2410c)}.banner-content{display:flex;justify-content:space-between;align-items:center;gap:2rem}.type-display{display:flex;align-items:center;gap:.75rem}.type-label{font-size:.9rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.type-badge{padding:.4rem 1rem;background:#fff;color:var(--color-primary);border-radius:6px;font-size:1rem;font-weight:700;box-shadow:0 2px 8px #00000026;text-transform:uppercase;letter-spacing:1px;display:inline-block}.filters-container.has-offline .type-badge{color:#dc2626}.type-badge.pi32{background:#dbeafe;color:#1e40af}.type-badge.pi10{background:#d1fae5;color:#065f46}.type-badge.txt{background:#fef3c7;color:#92400e}.type-badge.cc{background:#f3e8ff;color:#6b21a8}.filters-container.has-offline .type-badge.pi32,.filters-container.has-offline .type-badge.pi10,.filters-container.has-offline .type-badge.txt,.filters-container.has-offline .type-badge.cc{color:#dc2626}.duplicate-warning{display:flex;align-items:center;gap:.75rem;background:#fff3;padding:.5rem 1rem;border-radius:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.warning-icon{font-size:1.25rem;flex-shrink:0}.warning-text{font-size:.9rem;color:#fff;font-weight:600}@media (max-width: 640px){.filters-container{padding:.75rem 1rem}.banner-content{flex-direction:column;gap:.75rem}.type-label{font-size:.75rem}.type-badge{font-size:.85rem;padding:.35rem .75rem}.duplicate-warning{width:100%;justify-content:center}.warning-text{font-size:.8rem}}.dashboard-page{padding:1rem;width:100%;margin:0 auto}.error-message{background-color:var(--color-gray-100);border-left:4px solid var(--color-error);padding:1rem;border-radius:.5rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}.error-message p{color:var(--color-error);margin:0}.error-message button{background-color:var(--color-error);color:#fff;padding:.5rem 1rem;font-size:.875rem;margin-left:1rem}.error-message button:hover{background-color:#dc2626}@media (max-width: 768px){.dashboard-page{padding:1rem}.error-message{flex-direction:column;align-items:flex-start}.error-message button{margin-left:0;margin-top:.5rem}}.offline-table-container{background:#fff;border-radius:.75rem;box-shadow:var(--shadow-md);overflow:hidden}.offline-table{width:100%;border-collapse:collapse}.offline-table thead{background-color:var(--color-primary);color:#fff}.offline-table th{padding:1rem;text-align:left;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.offline-table th:hover{background-color:#0d9488}.offline-table tbody tr{border-bottom:1px solid var(--color-gray-200);transition:background-color .2s}.offline-table tbody tr:hover{background-color:var(--color-gray-50)}.offline-table td{padding:.75rem 1rem}.priority-critical{background-color:#ef44441a}.priority-high{background-color:#f973161a}.priority-medium{background-color:#f59e0b1a}.priority-low{background-color:transparent}.device-id{font-weight:700;color:var(--color-primary)}.device-name{font-weight:500}.time-offline strong{color:var(--color-error)}.badge{display:inline-block;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.type-badge{background-color:var(--color-gray-200);color:var(--color-gray-700)}.server-badge{background-color:var(--color-primary-light);color:#fff}@media (max-width: 768px){.offline-table{font-size:.875rem}.offline-table th,.offline-table td{padding:.5rem}.offline-table th:nth-child(4),.offline-table td:nth-child(4),.offline-table th:nth-child(5),.offline-table td:nth-child(5){display:none}}.history-container{background:#fff;border-radius:.75rem;box-shadow:var(--shadow-md);padding:1.5rem}.history-timeline{display:flex;flex-direction:column;gap:0}.history-entry{display:flex;gap:1rem;position:relative}.entry-indicator{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.indicator-dot{width:12px;height:12px;border-radius:50%;background-color:var(--color-gray-400);margin-top:.5rem;z-index:1}.indicator-dot.online{background-color:var(--color-success)}.indicator-dot.offline{background-color:var(--color-error)}.indicator-line{width:2px;flex:1;background-color:var(--color-gray-200);margin-top:.25rem}.history-entry:last-child .indicator-line{display:none}.entry-content{flex:1;padding-bottom:1.5rem;border-bottom:1px solid var(--color-gray-100)}.history-entry:last-child .entry-content{border-bottom:none}.entry-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.device-name{font-weight:600;color:var(--color-gray-900)}.device-id{font-weight:700;color:var(--color-primary);font-size:.875rem}.time-ago{margin-left:auto;font-size:.875rem;color:var(--color-gray-500)}.entry-body{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.change-description{font-size:.9375rem;color:var(--color-gray-700)}.entry-meta{display:flex;gap:.5rem}.entry-meta .badge{display:inline-block;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.entry-meta .type-badge{background-color:var(--color-gray-200);color:var(--color-gray-700)}.entry-meta .server-badge{background-color:var(--color-primary-light);color:#fff}.entry-footer{font-size:.8125rem;color:var(--color-gray-500)}@media (max-width: 768px){.entry-header{flex-wrap:wrap}.time-ago{width:100%;margin-left:0;margin-top:.25rem}.entry-body{flex-direction:column;align-items:flex-start;gap:.5rem}}.priority-alerts{display:flex;flex-direction:column;gap:1.5rem}.alert-section{background:#fff;border-radius:.75rem;box-shadow:var(--shadow-md);overflow:hidden}.alert-section.critical{border-left:6px solid var(--color-critical)}.alert-section.high{border-left:6px solid var(--color-high)}.alert-section.medium{border-left:6px solid var(--color-medium)}.alert-section.low{border-left:6px solid var(--color-low)}.alert-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background-color:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200)}.alert-icon{font-size:1.5rem}.alert-header h3{flex:1;margin:0;font-size:1.125rem}.alert-count{background-color:var(--color-gray-700);color:#fff;padding:.25rem .75rem;border-radius:999px;font-size:.875rem;font-weight:600}.alert-devices{padding:1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.alert-device-card{background-color:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:.5rem;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.device-info{display:flex;align-items:center;gap:.5rem}.device-info .device-id{font-weight:700;color:var(--color-primary)}.device-info .device-name{font-weight:500}.device-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.device-meta .badge{display:inline-block;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.device-meta .type-badge{background-color:var(--color-gray-200);color:var(--color-gray-700)}.device-meta .server-badge{background-color:var(--color-primary-light);color:#fff}.device-meta .time-offline{margin-left:auto;font-weight:700;color:var(--color-error)}.empty-state{text-align:center;padding:3rem;color:var(--color-gray-500);font-size:1.125rem;background:#fff;border-radius:.75rem;box-shadow:var(--shadow-md)}@media (max-width: 768px){.alert-devices{grid-template-columns:1fr}.alert-header h3{font-size:1rem}}.offline-summary-page{padding:1.5rem;max-width:1600px;margin:0 auto}.page-header h2{font-size:2rem;color:var(--color-gray-900);margin-bottom:.5rem}.page-header .subtitle{color:var(--color-gray-600);font-size:1rem}.view-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--color-gray-200)}.view-tabs button{padding:.75rem 1.5rem;background:transparent;color:var(--color-gray-600);font-weight:500;border:none;border-bottom:3px solid transparent;cursor:pointer;transition:all .2s}.view-tabs button:hover{color:var(--color-primary);background-color:var(--color-gray-50)}.view-tabs button.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.page-content{min-height:400px}.loading{text-align:center;padding:3rem;color:var(--color-gray-500);font-size:1.125rem}@media (max-width: 768px){.offline-summary-page{padding:1rem}.page-header h2{font-size:1.5rem}.view-tabs{overflow-x:auto;scrollbar-width:thin}.view-tabs button{padding:.5rem 1rem;font-size:.875rem;white-space:nowrap}}.priority-alerts-page{padding:2rem;background:#f9fafb;min-height:100vh}.page-header{margin-bottom:2rem}.page-header h2{font-size:1.875rem;font-weight:700;color:#111827;margin:0 0 1.5rem}.stats-summary{display:flex;gap:1rem;flex-wrap:wrap}.stat-chip{display:flex;align-items:center;gap:.625rem;padding:.75rem 1.25rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;border-left:4px solid transparent}.stat-chip.critical{border-left-color:var(--color-critical)}.stat-chip.high{border-left-color:var(--color-high)}.stat-chip.medium{border-left-color:var(--color-medium)}.stat-chip.low{border-left-color:var(--color-low)}.stat-icon{font-size:1.25rem;line-height:1}.stat-value{font-size:1.5rem;font-weight:700;color:#111827;line-height:1}.stat-label{font-size:.875rem;color:#6b7280;font-weight:500}.alerts-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;margin-top:1.5rem}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.empty-state p{color:#6b7280;font-size:1rem;margin:0}.loading{grid-column:1 / -1;text-align:center;padding:3rem;color:#6b7280;font-size:1.125rem}@media (max-width: 1400px){.alerts-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1024px){.alerts-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.alerts-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.alerts-grid{grid-template-columns:1fr}.priority-alerts-page{padding:1rem}.page-header h2{font-size:1.5rem}.stats-summary{gap:.75rem}.stat-chip{padding:.625rem 1rem;flex:1;min-width:calc(50% - .375rem)}.stat-value{font-size:1.25rem}.stat-label{font-size:.8125rem}.alerts-grid{grid-template-columns:1fr;gap:1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--font-mono: "JetBrains Mono", "Courier New", monospace;--color-primary: #1e40af;--color-primary-light: #3b82f6;--color-primary-dark: #1e3a8a;--color-success: #10b981;--color-error: #dc2626;--color-warning: #f59e0b;--color-info: #3b82f6;--color-gray-50: #f9fafb;--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;--color-critical: #dc2626;--color-high: #ea580c;--color-medium: #f59e0b;--color-low: #10b981;--color-pi32: #dbeafe;--color-pi10: #d1fae5;--color-txt: #fef3c7;--color-cc: #e0e7ff;--color-olton: #1e40af;--color-donat: #ea580c;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--transition: all .3s ease}body{background-color:var(--color-gray-50);color:var(--color-gray-900);line-height:1.6}button{cursor:pointer;font-family:inherit;border:none;border-radius:.5rem;transition:var(--transition)}button:disabled{opacity:.5;cursor:not-allowed}input,select{font-family:inherit;border:1px solid var(--color-gray-300);border-radius:.5rem;padding:.5rem .75rem;transition:var(--transition)}input:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f766e1a}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}
