:root{--bg: #f5f6f8;--panel: #ffffff;--panel-2: #fafbfc;--border: #e3e6ea;--text: #1b1f24;--muted: #6b7280;--accent: #2563eb;--accent-soft: #eff4ff;--green: #16a34a;--red: #dc2626;--amber: #d97706;--radius: 10px;--shadow: 0 1px 2px rgba(0,0,0,.04), 0 2px 8px rgba(0,0,0,.04)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Malgun Gothic,sans-serif;background:var(--bg);color:var(--text);font-size:14px}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}.layout{display:flex;height:100vh}.sidebar{width:220px;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-logo{padding:18px 18px 12px;display:flex;align-items:center;gap:10px}.sidebar-logo .mark{width:32px;height:32px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:800}.sidebar-logo h1{font-size:17px;margin:0}.sidebar-logo small{color:var(--muted);font-size:11px}.sidebar nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--text);font-weight:500}.nav-link:hover{background:var(--panel-2)}.nav-link.active{background:var(--accent-soft);color:var(--accent)}.sidebar-foot{padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px}.sidebar-foot .who{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:56px;border-bottom:1px solid var(--border);background:var(--panel);display:flex;align-items:center;padding:0 22px;gap:12px}.topbar h2{font-size:16px;margin:0}.topbar .ws-dot{width:8px;height:8px;border-radius:50%;background:var(--red)}.topbar .ws-dot.on{background:var(--green)}.main{flex:1;overflow-y:auto;padding:22px}.nav-toggle{display:none;align-items:center;justify-content:center;width:38px;height:38px;flex-shrink:0;border:1px solid var(--border);border-radius:8px;background:var(--panel);color:var(--text);margin-left:-6px}.nav-toggle:hover{background:var(--panel-2)}.sidebar-backdrop{display:none}@media(max-width:768px){.layout{height:100dvh}.nav-toggle{display:inline-flex}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:60;width:248px;max-width:82vw;transform:translate(-100%);transition:transform .22s ease;box-shadow:8px 0 28px #00000038}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;z-index:55;width:100%;height:100%;border:0;padding:0;margin:0;background:#0000006b}.topbar{padding:0 14px;gap:10px}.main,.card{padding:14px}}.grid{display:grid;gap:16px}.cols-4{grid-template-columns:repeat(4,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}@media(max-width:980px){.cols-4,.cols-3,.cols-2{grid-template-columns:1fr 1fr}}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.card h3{margin:0 0 12px;font-size:14px}.stat .label{color:var(--muted);font-size:12px}.stat .value{font-size:26px;font-weight:700;margin-top:4px}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600;font-size:12px}tbody tr:hover{background:var(--panel-2)}.tbl-scroll{overflow-x:auto}.tbl-scroll table{min-width:100%}.tbl-scroll th,.tbl-scroll td{white-space:nowrap}.tbl-scroll td.wrap,.tbl-scroll th.wrap{white-space:normal}.tbl-scroll th.chk,.tbl-scroll td.chk{width:34px;text-align:center;padding:9px 6px}.orders-page{display:flex;flex-direction:column;gap:16px;height:100%;min-height:0}.orders-table-card{display:flex;flex-direction:column;flex:1;min-height:0}.orders-table-card .tbl-scroll{flex:1;min-height:0;overflow:auto}.orders-table-card thead th{position:sticky;top:0;z-index:2;background:var(--panel);box-shadow:inset 0 -1px 0 var(--border)}.activity-panel{flex-shrink:0;display:flex;flex-direction:column;height:300px}.activity-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;flex:1;min-height:0}.activity-col{display:flex;flex-direction:column;min-height:0}.activity-col h3{margin:0 0 10px}.activity-scroll{flex:1;min-height:0;overflow-y:auto}.activity-scroll thead th{position:sticky;top:0;z-index:1;background:var(--panel);box-shadow:inset 0 -1px 0 var(--border)}@media(max-width:980px){.activity-grid{grid-template-columns:1fr}.activity-panel{height:420px}}.catalog-scroll thead th{position:sticky;top:0;z-index:2;background:var(--panel);box-shadow:inset 0 -1px 0 var(--border)}@media(max-width:768px){.split-2{flex-direction:column;height:auto!important}.split-2>.card{min-height:62vh}}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.b-done{background:#e7f6ec;color:var(--green)}.b-run{background:#fff6e6;color:var(--amber)}.b-fail,.b-dead{background:#fde8e8;color:var(--red)}.b-pending,.b-claimed{background:#eef1f5;color:var(--muted)}.btn{padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--panel);color:var(--text);font-weight:600}.btn:hover{background:var(--panel-2)}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{filter:brightness(1.05)}.btn:disabled{opacity:.5;cursor:not-allowed}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.spacer{flex:1}input,select{padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--panel);font:inherit;color:var(--text)}label.field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.muted{color:var(--muted)}.log-feed{background:#0f1419;color:#d7dde3;font-family:ui-monospace,Menlo,monospace;font-size:12px;border-radius:8px;padding:12px;height:320px;overflow-y:auto;white-space:pre-wrap}.log-feed .err{color:#ff8a8a}.log-feed .warn{color:#ffd27a}.login-wrap{height:100vh;display:grid;place-items:center;background:var(--bg)}.login-card{width:min(340px,92vw);background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:28px}.login-card h1{margin:0 0 4px;font-size:22px}.login-card .sub{color:var(--muted);font-size:13px;margin-bottom:20px}.login-card form{display:flex;flex-direction:column;gap:12px}.login-card input{padding:11px 12px}.err-msg{color:var(--red);font-size:13px}
