*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}:root{--bg: #0d1117;--card-bg: #161b22;--border: #30363d;--text: #e6edf3;--text-muted: #8b949e;--primary: #58a6ff;--green: #3fb950;--red: #f85149;--yellow: #d29922;--purple: #bc8cff;--radius: 6px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.layout{height:100vh;display:flex;flex-direction:column}.fullscreen-center{height:100vh;display:flex;align-items:center;justify-content:center}.setup-box{display:flex;flex-direction:column;align-items:center;gap:16px}.setup-label{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.setup-input-row{display:flex;gap:8px}.setup-input{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:14px 20px;font-size:18px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;outline:none;width:360px;text-align:center}.setup-input:focus{border-color:var(--primary)}.setup-input::placeholder{color:var(--text-muted);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-size:16px}.setup-btn{padding:14px 24px;font-size:16px;font-weight:600}.setup-hint{font-size:12px;color:var(--text-muted)}.auth-error-box{display:flex;flex-direction:column;align-items:center;gap:12px}.auth-error-icon{width:48px;height:48px;border-radius:50%;background:#f8514926;border:2px solid var(--red);color:var(--red);font-size:24px;font-weight:700;display:flex;align-items:center;justify-content:center}.auth-error-label{font-size:16px;font-weight:600;color:var(--text)}.auth-error-detail{font-size:14px;color:var(--red)}.enroll-box{display:flex;flex-direction:column;align-items:center;gap:16px}.enroll-spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.enroll-label{font-size:16px;font-weight:600;color:var(--text-muted)}.enroll-id{font-size:20px;font-weight:700;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;color:var(--primary)}.enroll-reset{margin-top:8px}.dashboard{display:flex;flex-direction:column;gap:16px;padding:24px;max-width:1200px;width:100%;margin:0 auto}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.card h2{font-size:13px;font-weight:600;margin-bottom:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.card-warn{border-color:#d2992266}.two-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:16px}.device-type-badge{display:inline-block;padding:2px 12px;border-radius:4px;font-size:12px;font-weight:700;letter-spacing:1px;margin-bottom:10px}.device-type-badge.tvm{background:#58a6ff1f;color:var(--primary);border:1px solid rgba(88,166,255,.25)}.device-type-badge.gate{background:#bc8cff1f;color:var(--purple);border:1px solid rgba(188,140,255,.25)}.status-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:13px;font-weight:600;margin-bottom:12px}.status-badge.online{background:#3fb95026;color:var(--green)}.status-badge.offline{background:#f8514926;color:var(--red)}.status-row{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:12px}.green{color:var(--green)}.red{color:var(--red)}.yellow{color:var(--yellow)}.stat-grid{display:flex;gap:24px;flex-wrap:wrap}.stat{display:flex;flex-direction:column;align-items:center;min-width:80px}.stat-value{font-size:28px;font-weight:700;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;line-height:1.1}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.config-pre{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-size:12px;overflow-x:auto;margin-bottom:12px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.form-row{display:flex;gap:8px;flex-wrap:wrap}input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:6px 12px;font-size:14px;outline:none}input:focus{border-color:var(--primary)}.btn{background:var(--border);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:6px 16px;font-size:14px;cursor:pointer;transition:background .15s}.btn:hover{background:#484f58}.btn.primary{background:#58a6ff26;color:var(--primary);border-color:#58a6ff4d}.btn.primary:hover{background:#58a6ff40}.btn.danger{background:#f851491a;color:var(--red);border-color:#f851494d}.btn.danger:hover{background:#f8514933}.btn.small{padding:2px 10px;font-size:12px}.btn.scenario{text-align:left;padding:8px 14px}.scenario-id{color:var(--text-muted);margin-right:4px}.button-row{display:flex;gap:8px;flex-wrap:wrap}.scenario-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;padding:6px 10px;border-bottom:1px solid var(--border);color:var(--text-muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}td{padding:4px 10px;border-bottom:1px solid rgba(48,54,61,.5)}.row-active{background:#d299220f}.mono{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px}.ts{color:var(--text-muted);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px}.counter-actions{display:flex;gap:4px;align-items:center}.counter-input{width:70px;padding:2px 6px;font-size:12px}.connectors{display:flex;gap:10px;flex-wrap:wrap}.connector{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:6px 12px;font-size:12px;min-width:0}.connector-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.connector-dot.ok{background:var(--green)}.connector-dot.warn{background:var(--yellow)}.connector-dot.off{background:var(--text-muted)}.connector-name{font-weight:600;color:var(--text);white-space:nowrap}.connector-status{color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast{position:fixed;top:16px;right:16px;background:var(--card-bg);border:1px solid var(--primary);color:var(--primary);padding:8px 16px;border-radius:var(--radius);font-size:13px;z-index:1000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
