.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#666}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}#root{display:flex;flex-direction:column;min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:20px;flex:1}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:24px;margin-bottom:20px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background-color:#08c;color:#fff}.btn-primary:hover{background-color:#069}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:6px;font-weight:500;color:#333}.form-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px}.form-input:focus{outline:none;border-color:#08c}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;text-align:left;border-bottom:1px solid #ddd}.table th{background-color:#f8f9fa;font-weight:600}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-online{background-color:#d4edda;color:#155724}.status-offline{background-color:#f8d7da;color:#721c24}.status-tray{background-color:#ffe0b2;color:#e65100}.status-not-installed{background-color:#e2e3e5;color:#383d41}.navbar{background-color:#08c;color:#fff;padding:16px 0;margin-bottom:24px}.navbar-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.navbar-brand{font-size:20px;font-weight:600}.navbar-nav{display:flex;gap:24px;list-style:none}.navbar-nav a{color:#fff;text-decoration:none}.navbar-nav a:hover{text-decoration:underline}.navbar-nav .maintain-dropdown{position:relative}.navbar-nav .maintain-trigger{color:#fff;background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit;padding:0}.navbar-nav .maintain-trigger:hover{text-decoration:underline}.navbar-nav .maintain-menu{position:absolute;top:100%;left:0;background-color:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 8px #00000026;z-index:1000;min-width:140px;margin-top:8px}.navbar-nav .maintain-menu a{display:block;padding:8px 16px;color:#333;text-decoration:none;font-size:14px}.navbar-nav .maintain-menu a:hover{background-color:#e7f3ff;text-decoration:none}.error-message{background-color:#f8d7da;color:#721c24;padding:12px;border-radius:6px;margin-bottom:16px}.success-message{background-color:#d4edda;color:#155724;padding:12px;border-radius:6px;margin-bottom:16px}.app-footer{background-color:#f8f9fa;border-top:1px solid #e9ecef;padding:12px 0;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;padding:0 20px;text-align:center}.version-info{font-size:12px;color:#6c757d;font-family:SF Mono,Monaco,monospace}.btn-sm{padding:6px 12px;font-size:13px}.dashboard-page{padding-bottom:32px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-header h1{font-size:22px;font-weight:700;color:#111827;margin:0}.page-header-meta{display:flex;align-items:center;gap:12px}.dash-last-update{font-size:12px;color:#6b7280}.dash-section{background:#fff;border-radius:10px;box-shadow:0 1px 4px #00000014;padding:20px 24px;margin-bottom:24px}.dash-section-title{font-size:15px;font-weight:600;color:#374151;margin:0 0 16px;display:flex;align-items:center;gap:8px}.dash-metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:12px}.dash-metric-card{border-radius:8px;border:1px solid #e5e7eb;padding:16px;background:#f9fafb;transition:border-color .2s}.dash-metric-card--good{border-left:4px solid #22c55e}.dash-metric-card--warning{border-left:4px solid #f59e0b}.dash-metric-card--critical{border-left:4px solid #ef4444}.dash-metric-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.dash-metric-icon{font-size:18px}.dash-metric-title{font-size:13px;font-weight:600;color:#374151}.dash-metric-body{display:flex;align-items:center;gap:12px}.dash-circular{position:relative;width:80px;height:80px;flex-shrink:0}.dash-circular-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.dash-metric-details{display:flex;flex-direction:column;gap:4px}.dash-metric-detail{font-size:12px;color:#6b7280;white-space:nowrap}.dash-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px}.dash-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280}.dash-legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.dash-legend--good .dash-legend-dot{background:#22c55e}.dash-legend--warning .dash-legend-dot{background:#f59e0b}.dash-legend--critical .dash-legend-dot{background:#ef4444}.dash-sysinfo-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}.dash-sysinfo-item{display:flex;align-items:center;gap:6px;background:#f3f4f6;border-radius:6px;padding:6px 12px;font-size:13px}.dash-sysinfo-icon{font-size:15px}.dash-sysinfo-label{color:#6b7280}.dash-sysinfo-value{font-weight:600;color:#111827}.dash-health-grid{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:8px}.dash-health-badge{display:flex;align-items:center;gap:8px;border-radius:8px;padding:10px 14px;font-size:13px;border:1px solid transparent;min-width:140px}.dash-health-badge--good{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.dash-health-badge--warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.dash-health-badge--bad{background:#fef2f2;border-color:#fecaca;color:#991b1b}.dash-health-dot{font-size:12px}.dash-health-label{flex:1;font-weight:500}.dash-health-status{font-size:11px;text-transform:uppercase;letter-spacing:.05em;opacity:.75}.dash-health-note{font-size:12px;color:#6b7280;margin:4px 0 0}.dash-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.dash-stat-link{text-decoration:none;display:block}.dash-stat-box{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;transition:border-color .2s,box-shadow .2s}.dash-stat-link:hover .dash-stat-box{border-color:#08c;box-shadow:0 2px 8px #0088cc26}.dash-stat-value{font-size:28px;font-weight:700;color:#111827;line-height:1}.dash-stat-label{font-size:12px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.04em}.dash-stat-sub{font-size:12px;color:#6b7280}.dash-loading{display:flex;align-items:center;gap:10px;color:#6b7280;font-size:14px}.spinner{width:20px;height:20px;border:3px solid #e5e7eb;border-top-color:#08c;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dash-queues-content{display:flex;flex-direction:column;gap:16px}.dash-queue-group{display:flex;flex-direction:column;gap:6px}.dash-queue-label{font-size:13px;font-weight:600;color:#374151;margin:0 0 4px}.queue-bar-container{display:flex;flex-direction:column;gap:6px}.queue-bar{display:flex;height:28px;border-radius:6px;overflow:hidden;background:#f3f4f6}.queue-bar-segment{display:flex;align-items:center;justify-content:center;min-width:2px;transition:width .4s ease}.queue-bar-empty{color:#9ca3af;font-size:12px;background:#f3f4f6}.queue-bar-text{font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap}.queue-bar-legend{display:flex;flex-wrap:wrap;gap:12px}.queue-bar-legend-item{display:flex;align-items:center;gap:4px;font-size:11px;color:#6b7280}.queue-bar-legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dash-queue-info-row{display:flex;flex-wrap:wrap;gap:16px}.dash-queue-info-item{display:flex;align-items:center;gap:8px;background:#f3f4f6;border-radius:6px;padding:8px 14px;font-size:13px}.dash-queue-info-label{color:#6b7280}.dash-queue-info-value{font-weight:600;color:#111827}.dash-queue-info-value--warn{color:#d97706}.dash-oort-status-badge{display:inline-block;padding:6px 18px;border-radius:20px;font-size:14px;font-weight:600;color:#fff;letter-spacing:.03em;text-transform:capitalize}.dash-oort-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
