@import "https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=IBM+Plex+Sans:wght@400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1923;--surface:#182330;--surface-alt:#1e2d3d;--border:#2a3f54;--fg:#d4e3f0;--muted:#6b7f8e;--accent:#1a6ebf;--accent-dim:#8fbedf;--amber:#e07b00;--ok:#2ecc71;--danger:#c0392b;--font-mono:"DM Mono", "Courier New", monospace;--font-body:"IBM Plex Sans", system-ui, sans-serif;--radius:4px;--sidebar-w:220px;--row-h:40px}html,body,#root{background:var(--bg);height:100%;color:var(--fg);font-family:var(--font-body);-webkit-font-smoothing:antialiased;font-size:13px;line-height:1.4}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:16px 14px 12px;display:flex}.logo-mark{grid-template-columns:repeat(3,7px);gap:2px;display:grid}.logo-mark span{border:1px solid var(--border);background:#2c3a4a;width:7px;height:7px;display:block}.logo-mark span.center{background:var(--accent);border-color:var(--accent)}.sidebar-title{font-family:var(--font-mono);color:var(--fg);letter-spacing:.04em;font-size:13px;font-weight:500}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-section-label{font-family:var(--font-mono);letter-spacing:.1em;color:var(--muted);text-transform:uppercase;padding:10px 14px 4px;font-size:10px;font-weight:500}.nav-item{cursor:pointer;height:36px;color:var(--muted);font-size:13px;font-family:var(--font-body);text-align:left;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:9px;width:100%;padding:0 14px;text-decoration:none;transition:color .15s,border-color .15s;display:flex}.nav-item:hover{color:var(--fg);background:#ffffff08}.nav-item.active{color:var(--fg);border-left-color:var(--accent);background:#1a6ebf14}.nav-item svg{flex-shrink:0}.sidebar-footer{border-top:1px solid var(--border);font-family:var(--font-mono);color:var(--muted);padding:10px 14px;font-size:10px}.main-content{flex-direction:column;flex:1;display:flex;overflow-y:auto}.page-header{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 24px 14px;display:flex}.page-title{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg);font-size:13px;font-weight:500}.page-subtitle{color:var(--muted);margin-top:2px;font-size:11px}.page-body{flex:1;padding:20px 24px}.stat-bar{background:var(--border);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(4,1fr);gap:1px;margin-bottom:20px;display:grid;overflow:hidden}.stat-block{background:var(--surface);align-items:center;gap:12px;padding:14px 16px;display:flex}.stat-led{border-radius:50%;flex-shrink:0;width:8px;height:8px}.stat-led.ok{background:var(--ok);box-shadow:0 0 6px var(--ok);animation:2s ease-in-out infinite pulse-led}.stat-led.danger{background:var(--danger)}.stat-led.amber{background:var(--amber)}.stat-led.muted{background:var(--muted)}@keyframes pulse-led{0%,to{opacity:1}50%{opacity:.55}}.stat-num{font-family:var(--font-mono);color:var(--fg);font-size:26px;font-weight:600;line-height:1}.stat-label{color:var(--muted);font-size:11px;font-family:var(--font-body);margin-top:3px}.section-header{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:11px;font-weight:500;display:flex}.table-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead th{background:var(--surface);font-family:var(--font-body);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;height:32px;padding:0 12px;font-size:11px;font-weight:600}.data-table thead th:hover{color:var(--fg)}.data-table thead th.sorted{color:var(--accent-dim)}.data-table tbody tr{height:var(--row-h);border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:nth-child(odd){background:var(--surface)}.data-table tbody tr:nth-child(2n){background:var(--surface-alt)}.data-table tbody tr:hover{background:#1a6ebf1a}.data-table tbody tr.selected{background:#1a6ebf2e!important}.data-table td{color:var(--fg);white-space:nowrap;padding:0 12px;font-size:13px}.data-table td.mono{font-family:var(--font-mono);color:var(--accent-dim);font-size:12px}.data-table td.muted{color:var(--muted)}.status-dot{align-items:center;gap:6px;font-size:12px;display:inline-flex}.dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.dot.ok{background:var(--ok);animation:2s ease-in-out infinite pulse-led}.dot.danger{background:var(--danger)}.dot.amber{background:var(--amber)}.dot.grey{background:var(--muted)}.btn{border-radius:var(--radius);height:32px;font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:0 14px;font-size:12px;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:#1a7fd4;border-color:#1a7fd4}.btn-secondary{background:var(--surface-alt);color:var(--fg);border-color:var(--border)}.btn-secondary:hover{border-color:var(--accent-dim);color:var(--accent)}.btn-ghost{color:var(--muted);border-color:var(--border);background:0 0}.btn-ghost:hover{color:var(--fg);border-color:var(--accent-dim)}.icon-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;font-size:12px;font-family:var(--font-mono);background:0 0;border-radius:6px;align-items:center;gap:5px;padding:5px 8px;transition:all .15s;display:inline-flex}.icon-btn:hover{color:var(--fg);border-color:var(--accent-dim)}.icon-btn.danger:hover{color:var(--danger);border-color:var(--danger)}.btn-danger{color:var(--danger);border-color:var(--danger);background:0 0}.btn-danger:hover{background:#c0392b1f}.btn-sm{height:26px;padding:0 10px;font-size:11px}.toolbar{align-items:center;gap:8px;margin-bottom:12px;display:flex}.search-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:320px;height:32px;color:var(--fg);font-family:var(--font-body);outline:none;flex:1;padding:0 10px;font-size:12px;transition:border-color .15s}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--muted)}.select-filter{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);height:32px;color:var(--fg);font-family:var(--font-body);cursor:pointer;outline:none;padding:0 8px;font-size:12px}.select-filter:focus{border-color:var(--accent)}.badge{font-size:11px;font-family:var(--font-mono);letter-spacing:.04em;border-radius:2px;padding:2px 7px;font-weight:500;display:inline-block}.badge-ok{color:var(--ok);background:#2ecc711f}.badge-danger{color:#e05c4b;background:#c0392b1f}.badge-amber{color:var(--amber);background:#e07b001f}.badge-grey{color:var(--muted);background:#6b7f8e1f}.badge-blue{color:var(--accent-dim);background:#1a6ebf26}.drawer-overlay{z-index:100;background:#00000073;position:fixed;inset:0}.drawer{background:var(--surface);border-left:1px solid var(--border);z-index:101;flex-direction:column;width:420px;height:100vh;animation:.2s slide-in;display:flex;position:fixed;top:0;right:0;overflow:hidden}@keyframes slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:16px 18px;display:flex}.drawer-body{flex:1;padding:16px 18px;overflow-y:auto}.drawer-footer{border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:12px 18px;display:flex}.close-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:2px;line-height:1}.close-btn:hover{color:var(--fg)}.detail-grid{grid-template-columns:120px 1fr;gap:0;display:grid}.detail-row{display:contents}.detail-row>span:first-child{color:var(--muted);border-bottom:1px solid var(--border);font-size:11px;font-family:var(--font-body);letter-spacing:.04em;text-transform:uppercase;padding:7px 0;font-weight:600}.detail-row>span:last-child{color:var(--fg);border-bottom:1px solid var(--border);font-size:12px;font-family:var(--font-mono);padding:7px 0 7px 12px}.form-group{margin-bottom:14px}.form-label{letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:600;font-family:var(--font-body);margin-bottom:5px;display:block}.form-input,.form-select,.form-textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--fg);font-family:var(--font-body);outline:none;padding:8px 10px;font-size:13px;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--muted)}.form-textarea{resize:vertical;min-height:80px}.form-select option{background:var(--surface-alt)}.tabs{border-bottom:1px solid var(--border);margin-bottom:16px;display:flex}.tab{color:var(--muted);cursor:pointer;font-size:12px;font-family:var(--font-body);background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 14px;transition:color .15s,border-color .15s}.tab:hover{color:var(--fg)}.tab.active{color:var(--fg);border-bottom-color:var(--accent)}.log-entry{border-bottom:1px solid var(--border);gap:10px;padding:8px 0;font-size:12px;display:flex}.log-entry:last-child{border-bottom:none}.log-time{font-family:var(--font-mono);color:var(--muted);white-space:nowrap;flex-shrink:0;min-width:90px;font-size:11px}.log-text{color:var(--fg)}.empty-state{text-align:center;color:var(--muted);padding:48px 24px;font-size:13px}.empty-state-icon{opacity:.4;margin-bottom:12px}.step-bar{align-items:center;gap:0;margin-bottom:24px;display:flex}.step-item{flex:1;align-items:center;gap:8px;display:flex}.step-circle{border:2px solid var(--border);width:24px;height:24px;font-family:var(--font-mono);color:var(--muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:500;transition:all .2s;display:flex}.step-circle.active{border-color:var(--accent);color:var(--accent)}.step-circle.done{border-color:var(--ok);background:var(--ok);color:#0f1923}.step-label{color:var(--muted);font-size:12px}.step-label.active{color:var(--fg)}.step-connector{background:var(--border);flex:1;height:1px;margin:0 8px}.alert{border-radius:var(--radius);border-left:3px solid;align-items:flex-start;gap:8px;margin-bottom:8px;padding:10px 14px;font-size:12px;display:flex}.alert-amber{border-color:var(--amber);color:var(--amber);background:#e07b001a}.alert-danger{border-color:var(--danger);color:#e05c4b;background:#c0392b1a}.alert-ok{border-color:var(--ok);color:var(--ok);background:#2ecc711a}.text-mono{font-family:var(--font-mono)}.text-muted{color:var(--muted)}.text-ok{color:var(--ok)}.text-danger{color:var(--danger)}.text-amber{color:var(--amber)}.text-accent{color:var(--accent-dim)}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mb-16{margin-bottom:16px}.flex{display:flex}.items-center{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.flex-1{flex:1}
