@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #111214;--surface: #1c1e22;--surface2: #26292f;--border: #32363e;--border-subtle: #2a2d34;--text: #eaecf0;--text-muted:#9197a3;--primary: #0ea5e9;--primary-hover: #38bdf8;--primary-dim: rgba(14,165,233,.12);--success: #10b981;--danger: #f43f5e;--warning: #f59e0b;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--shadow: 0 4px 20px rgba(0,0,0,.35);--shadow-sm: 0 2px 8px rgba(0,0,0,.25)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;font-size:14px;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::-webkit-scrollbar-corner{background:var(--bg)}*{scrollbar-width:thin;scrollbar-color:var(--border) var(--bg)}a{color:var(--primary);text-decoration:none}button{cursor:pointer;border:none;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;transition:background .15s,box-shadow .15s,opacity .15s;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 0 0 0 var(--primary)}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 0 12px #0ea5e959}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:.88}.btn-success{background:var(--success);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}input,textarea,select{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;width:100%;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-cell{height:14px;border-radius:4px;background:linear-gradient(90deg,var(--surface2) 25%,var(--border) 50%,var(--surface2) 75%);background-size:800px 100%;animation:skeleton-shimmer 1.4s infinite linear;width:70%;max-width:200px}tr:nth-child(2n) .skeleton-cell{width:55%}tr:nth-child(3n) .skeleton-cell{width:80%}tr:nth-child(4n) .skeleton-cell{width:45%}code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px;background:var(--surface2);border:1px solid var(--border-subtle);border-radius:4px;padding:1px 6px;color:var(--text);word-break:break-all;overflow-wrap:anywhere}.card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:24px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.03em}.badge-active{background:#10b98124;color:var(--success)}.badge-inactive{background:#f43f5e24;color:var(--danger)}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--border-subtle)}th{color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.07em;font-weight:600;background:var(--surface2)}th:first-child{border-radius:var(--radius-sm) 0 0 0}th:last-child{border-radius:0 var(--radius-sm) 0 0}tr:hover td{background:var(--surface2)}.layout{display:flex;min-height:100vh}.sidebar{width:230px;min-width:230px;height:100vh;position:sticky;top:0;overflow-y:auto;background:var(--surface);border-right:1px solid var(--border-subtle);padding:20px 12px;display:flex;flex-direction:column;gap:2px}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:6px 10px 22px;border-bottom:1px solid var(--border-subtle);margin-bottom:10px}.sidebar-brand-icon{width:32px;height:32px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 12px #0ea5e94d}.sidebar-brand-text{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.02em}.sidebar-brand-sub{font-size:10px;color:var(--text-muted);font-weight:500;letter-spacing:.06em;text-transform:uppercase}.sidebar-label{font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;padding:12px 10px 4px}.sidebar a,.sidebar-logout{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 10px;border-radius:var(--radius-sm);color:var(--text-muted);background:none;font-size:13px;font-weight:500;transition:background .12s,color .12s;border:none;cursor:pointer}.sidebar a:hover,.sidebar-logout:hover{background:var(--surface2);color:var(--text)}.sidebar a.active{background:var(--primary-dim);color:var(--primary)}.sidebar a.active svg{opacity:1}.sidebar a svg,.sidebar-logout svg{opacity:.65;flex-shrink:0}.sidebar a:hover svg,.sidebar-logout:hover svg,.sidebar a.active svg{opacity:1}.main{flex:1;padding:32px 36px;overflow:auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.page-header h1{font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px}.stat-card{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:6px}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary);border-radius:var(--radius) var(--radius) 0 0;opacity:.7}.stat-card .stat-icon{width:36px;height:36px;background:var(--primary-dim);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:8px;color:var(--primary)}.stat-card .value{font-size:32px;font-weight:700;color:var(--text);letter-spacing:-.03em;line-height:1}.stat-card .label{font-size:12px;color:var(--text-muted);font-weight:500}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px;letter-spacing:.03em}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow)}.modal h2{margin-bottom:20px;font-size:17px;font-weight:700}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.login-box{width:100%;max-width:400px;box-shadow:var(--shadow)}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:52px;height:52px;background:var(--primary);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 0 20px #0ea5e959}.login-header h1{font-size:20px;font-weight:700;letter-spacing:-.02em}.login-header p{font-size:13px;color:var(--text-muted);margin-top:4px}.section-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden}.section-card-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border-subtle);background:var(--surface2)}.section-card-header h2{font-size:14px;font-weight:600;color:var(--text)}.section-card table th{background:var(--surface2)}.datatable{display:flex;flex-direction:column}.datatable-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border-subtle);background:var(--surface2)}.datatable-search{position:relative;display:flex;align-items:center;gap:8px;flex:1;max-width:340px}.datatable-search svg{position:absolute;left:10px;color:var(--text-muted);pointer-events:none}.datatable-search input{padding:7px 34px 7px 32px;font-size:13px;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);width:100%}.datatable-search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}.datatable-search-clear{position:absolute;right:8px;background:none;border:none;color:var(--text-muted);padding:2px;display:flex;align-items:center;cursor:pointer;border-radius:3px}.datatable-search-clear:hover{color:var(--text);background:var(--border)}.datatable-page-size{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);white-space:nowrap}.datatable-page-size select{width:auto;padding:6px 28px 6px 10px;font-size:13px;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm)}.datatable-scroll{overflow-x:auto}.th-inner{display:inline-flex;align-items:center;gap:6px}th.th-sorted{color:var(--primary)}.datatable-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border-subtle);background:var(--surface2);font-size:12px;color:var(--text-muted);flex-wrap:wrap;gap:10px}.datatable-pages{display:flex;align-items:center;gap:4px}.page-btn{min-width:30px;height:30px;padding:0 6px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);font-size:12px;font-weight:500;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.page-btn:hover:not(:disabled){background:var(--surface2);color:var(--text);border-color:var(--primary)}.page-btn:disabled{opacity:.35;cursor:default}.page-btn-active{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}.page-ellipsis{padding:0 4px;color:var(--text-muted);font-size:13px;line-height:30px}.mobile-topbar,.sidebar-overlay{display:none}@media(max-width:768px){.layout{flex-direction:column}.mobile-topbar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:90}.mobile-menu-btn{background:none;border:none;color:var(--text);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);flex-shrink:0}.mobile-menu-btn:hover{background:var(--surface2)}.mobile-brand{display:flex;align-items:center;gap:8px}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:95}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:100;transform:translate(-100%);transition:transform .22s ease;box-shadow:var(--shadow)}.sidebar.sidebar-open{transform:translate(0)}.main{padding:20px 16px;min-height:calc(100vh - 57px)}.page-header{flex-wrap:wrap;gap:12px;margin-bottom:20px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}.datatable-toolbar{flex-direction:column;align-items:stretch;gap:10px}.datatable-search{max-width:100%}.datatable-page-size{justify-content:flex-end}.datatable-footer{flex-direction:column;align-items:stretch;gap:10px}.datatable-pages{justify-content:center;flex-wrap:wrap}.datatable-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.modal{margin:16px;padding:24px 20px;max-width:calc(100vw - 32px)}.section-card{border-radius:var(--radius-sm)}}.btn-sm{padding:4px 10px;font-size:12px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:5px}.modal-notes{max-width:680px;width:100%;max-height:80vh;display:flex;flex-direction:column;padding:0;overflow:hidden}.modal-notes-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-notes-version{font-size:20px;font-weight:700;color:var(--text);margin-right:4px}.modal-notes-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);line-height:1;transition:color .15s,background .15s}.modal-notes-close:hover{color:var(--text);background:var(--surface2)}.modal-notes-body{flex:1;overflow-y:auto;padding:20px 24px}.modal-notes-footer{padding:12px 24px;border-top:1px solid var(--border);color:var(--text-muted);font-size:13px;flex-shrink:0}.markdown-notes{color:var(--text);line-height:1.7}.markdown-notes h1,.markdown-notes h2{font-size:1.1em;font-weight:700;margin:1.2em 0 .4em;color:var(--text)}.markdown-notes h3,.markdown-notes h4{font-size:1em;font-weight:600;margin:1em 0 .3em;color:var(--text)}.markdown-notes h1:first-child,.markdown-notes h2:first-child{margin-top:0}.markdown-notes p{margin:.5em 0}.markdown-notes ul,.markdown-notes ol{padding-left:1.5em;margin:.5em 0}.markdown-notes li{margin:.2em 0}.markdown-notes code{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-size:.85em;font-family:monospace}.markdown-notes pre{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;overflow-x:auto;margin:.7em 0}.markdown-notes pre code{background:none;border:none;padding:0;font-size:.88em}.markdown-notes blockquote{border-left:3px solid var(--primary);margin:.7em 0;padding:6px 14px;color:var(--text-muted);background:var(--surface2);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.markdown-notes a{color:var(--primary);text-decoration:none}.markdown-notes a:hover{text-decoration:underline}.markdown-notes hr{border:none;border-top:1px solid var(--border);margin:1em 0}.badge-warning{background:#f59e0b26;color:var(--warning)}.badge-channel{background:#0ea5e91f;color:var(--primary)}.badge-internal{background:#8b5cf624;color:#a78bfa}.machine-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:32px}.machine-tile{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .15s,box-shadow .15s;position:relative;overflow:hidden}.machine-tile:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius) var(--radius) 0 0}.machine-tile:hover{box-shadow:var(--shadow-sm)}.machine-tile.tile-up-to-date:before{background:var(--success)}.machine-tile.tile-update-pending:before{background:var(--warning)}.machine-tile.tile-offline:before{background:var(--danger)}.machine-tile.tile-inactive:before{background:var(--border)}.machine-tile.tile-up-to-date:hover{border-color:var(--success)}.machine-tile.tile-update-pending:hover{border-color:var(--warning)}.machine-tile.tile-offline:hover{border-color:var(--danger)}.machine-tile.tile-inactive:hover{border-color:var(--text-muted)}.machine-tile-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.machine-tile-name{font-weight:700;font-size:13px;color:var(--text);word-break:break-all}.machine-tile-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}.machine-tile-badge.tile-up-to-date{background:#10b98126;color:var(--success)}.machine-tile-badge.tile-update-pending{background:#f59e0b26;color:var(--warning)}.machine-tile-badge.tile-offline{background:#f43f5e26;color:var(--danger)}.machine-tile-badge.tile-inactive{background:var(--surface2);color:var(--text-muted)}.machine-tile-customer{font-size:12px;color:var(--text-muted);margin-bottom:10px}.machine-tile-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.machine-tile-update-hint{margin-top:8px;font-size:11px;color:var(--warning);font-weight:500}.machine-legend{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px}.machine-legend:before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%}.machine-legend.tile-up-to-date{color:var(--success)}.machine-legend.tile-up-to-date:before{background:var(--success)}.machine-legend.tile-update-pending{color:var(--warning)}.machine-legend.tile-update-pending:before{background:var(--warning)}.machine-legend.tile-offline{color:var(--danger)}.machine-legend.tile-offline:before{background:var(--danger)}.machine-legend.tile-inactive{color:var(--text-muted)}.machine-legend.tile-inactive:before{background:var(--text-muted)}.bulk-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 16px;background:var(--primary-dim);border:1px solid rgba(14,165,233,.25);border-radius:var(--radius);margin-bottom:16px}.bulk-count{font-size:13px;font-weight:700;color:var(--primary);margin-right:4px}.bulk-divider{width:1px;height:20px;background:var(--border);margin:0 4px}.filter-bar{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;padding:16px 20px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);margin-bottom:20px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase}.filter-group input,.filter-group select{padding:7px 12px;font-size:13px;width:auto}.health-metrics-row{display:flex;flex-wrap:wrap;gap:12px}.health-metric-item{display:flex;flex-direction:column;gap:4px;padding:10px 14px;background:var(--surface2);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);min-width:100px}.health-metric-label{font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase}.health-metric-value{font-size:16px;font-weight:700}.health-metric-value.metric-ok{color:var(--success)}.health-metric-value.metric-danger{color:var(--danger)}@media(max-width:768px){.machine-grid{grid-template-columns:1fr 1fr}.filter-bar{gap:10px}.filter-group input,.filter-group select{width:100%}.bulk-toolbar{gap:6px}}
