*{margin:0;padding:0;box-sizing:border-box}:root{--bg-0: #f3f6fb;--bg-1: #ffffff;--bg-2: #ecf1f7;--bg-3: #e2e8f0;--border: #d8e0ea;--border-light: #c6d0dc;--text-0: #0f172a;--text-1: #1e293b;--text-2: #475569;--text-3: #64748b;--accent: #0b66c3;--accent-soft: rgba(11,102,195,.12);--green: #15803d;--red: #c2410c;--yellow: #9a6700;--purple: #8250df;--sidebar-w: 230px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 2px 8px rgba(0,0,0,.08);--shadow-lg: 0 4px 16px rgba(0,0,0,.1);--radius: 8px;--radius-sm: 6px;--transition: .2s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;background:var(--bg-0);color:var(--text-1);display:flex;min-height:100vh;line-height:1.5;font-size:14px;-webkit-font-smoothing:antialiased}#app{display:flex;width:100%;min-height:100vh}.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#fff,#f8fbff);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;bottom:0;z-index:10;box-shadow:1px 0 10px #0f172a0f}.sidebar-logo{padding:18px 20px;font-size:1.1em;font-weight:700;color:var(--accent);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;letter-spacing:0;background:#ffffffd6}.sidebar-logo span{font-size:1.3em}.sidebar nav{flex:1;padding:10px 0;overflow-y:auto}.sidebar a{display:flex;align-items:center;gap:10px;padding:9px 18px;color:var(--text-2);text-decoration:none;font-size:.88em;border-left:3px solid transparent;transition:all var(--transition);font-weight:450}.sidebar a:hover{color:var(--text-0);background:var(--bg-2)}.sidebar a.active,.sidebar a.router-link-active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-soft);font-weight:550}.sidebar a .icon{width:20px;text-align:center;font-size:1.05em}.sidebar-footer{padding:6px 0;border-top:1px solid var(--border)}.sidebar-overlay{display:none}.nav-group-label{padding:10px 18px 4px;font-size:.7em;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:0}.nav-group-label:not(:first-child){margin-top:2px;border-top:1px solid var(--bg-2);padding-top:10px}.user-menu-wrapper{position:relative}.user-menu-btn{display:flex;align-items:center;gap:8px;width:100%;padding:10px 18px;background:none;border:none;cursor:pointer;color:var(--text-2);font-size:.85em;text-align:left;transition:background var(--transition);font-family:inherit}.user-menu-btn:hover{background:var(--bg-2)}.user-menu-btn small{color:var(--text-3)}.user-menu-arrow{margin-left:auto;font-size:.8em;color:var(--text-3)}.user-popup{position:absolute;bottom:100%;left:8px;right:8px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);overflow:hidden;z-index:20;margin-bottom:4px}.user-popup a{display:block;padding:10px 16px;color:var(--text-2);text-decoration:none;font-size:.85em;transition:background var(--transition)}.user-popup a:hover{background:var(--bg-2);color:var(--text-0)}.user-popup a:last-child:hover{color:var(--red)}.sidebar-version{display:block;padding:4px 18px;font-size:.72em;color:var(--text-3)}.hamburger{display:none;background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:1.2em;cursor:pointer;line-height:1}.mobile-topbar{display:none}.mobile-topbar-title{font-weight:700;font-size:1.05em;color:var(--text-1)}.main{margin-left:var(--sidebar-w);flex:1;min-width:0;padding:28px 36px;min-height:100vh;max-width:1600px}.page-header{margin-bottom:24px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:4px 14px;align-items:end}.page-header>h1,.page-header>p,.page-header>div:first-child{grid-column:1}.page-header h1{font-size:1.5em;color:var(--text-0);font-weight:700;letter-spacing:0}.page-header p{color:var(--text-2);font-size:.9em;margin-top:4px}.page-header .cluster-badge{grid-column:2;grid-row:1 / span 2;align-self:center;justify-self:end;margin-left:0}.subtitle{color:var(--text-2);font-size:.88em;margin:4px 0 14px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.card{background:#fffffff5;border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:0 4px 14px #0f172a0a;transition:box-shadow var(--transition),border-color var(--transition),transform var(--transition)}.card.clickable{cursor:pointer}.card.clickable:hover{border-color:#0b66c366;box-shadow:0 10px 24px #0f172a14;transform:translateY(-1px)}.card h3{color:var(--text-2);font-size:.75em;margin-bottom:8px;text-transform:uppercase;letter-spacing:0;font-weight:700}.card .value{font-size:1.7em;font-weight:700;color:var(--text-0);letter-spacing:0}.card .value.positive{color:var(--green)}.card .value.negative{color:var(--red)}.card .sub{color:var(--text-2);font-size:.8em;margin-top:4px}.card-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.card-sub{font-size:.85em;color:var(--text-2)}.strat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:12px}.stat-card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--border);border-radius:8px;padding:12px}.stat-label{font-size:.78em;color:var(--text-2)}.stat-value{font-size:1.1em;font-weight:600}.section{background:#fffffff5;border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:0 6px 18px #0f172a0a}.section-title{color:var(--text-0);font-size:1em;font-weight:600;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}th,td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--bg-2);font-size:.85em}th{color:var(--text-2);font-weight:700;position:sticky;top:0;background:var(--bg-1);white-space:nowrap;text-transform:uppercase;font-size:.75em;letter-spacing:0}td{color:var(--text-1)}tbody tr:nth-child(2n) td{background:#f8fafcb3}tr:hover td{background:var(--accent-soft)}.mono-sm{font-family:monospace;font-size:.78em}.mono-input{font-family:monospace;font-size:.85em}.ellipsis{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.75em;font-weight:600}.badge-running{background:#dafbe1;color:var(--green)}.badge-stopped{background:#ffebe9;color:var(--red)}.badge-idle{background:var(--bg-2);color:var(--text-3)}.badge-warn{background:#fff8c5;color:#9a6700}.badge-halted{background:#ffebe9;color:var(--red);animation:pulse 1.5s infinite}.cluster-badge{display:inline-block;padding:4px 14px;border-radius:12px;font-size:.75em;font-weight:700;margin-left:12px;vertical-align:middle}.cluster-mainnet{background:#fff1f0;color:#dc2626;border:1px solid #fca5a5}.cluster-devnet{background:#eff6ff;color:#2563eb;border:1px solid #93c5fd}@keyframes pulse{50%{opacity:.6}}.btn,.btn-primary,.btn-danger,.btn-accent{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-1);color:var(--text-1);cursor:pointer;font-size:.82em;transition:all var(--transition);white-space:nowrap;font-weight:600;box-shadow:var(--shadow-sm);text-decoration:none}.btn:hover{border-color:var(--border-light);background:var(--bg-2);box-shadow:none}.btn:active{transform:scale(.98)}.btn-sm{padding:4px 10px;font-size:.78em}.btn-copy{background:none;border:none;cursor:pointer;padding:0 2px;font-size:.85em;opacity:.4;transition:opacity var(--transition);vertical-align:middle;box-shadow:none}.btn-copy:hover{opacity:1}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:#0956a5;border-color:#0956a5;box-shadow:0 8px 20px #0b66c32e}.btn-danger{background:var(--red);border-color:var(--red);color:#fff}.btn-danger:hover{background:#9a3412;border-color:#9a3412;box-shadow:0 8px 20px #c2410c29}.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff}.btn-accent:hover{background:#0956a5;border-color:#0956a5;box-shadow:0 8px 20px #0b66c32e}.btn[disabled],.btn-primary[disabled],.btn-danger[disabled],.btn-accent[disabled]{opacity:.35;cursor:not-allowed;pointer-events:none;box-shadow:none}.btn-group{display:flex;gap:6px;flex-wrap:wrap}input,select,textarea{padding:8px 12px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-1);font-size:.85em;outline:none;max-width:100%;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}input::placeholder,textarea::placeholder{color:var(--text-3)}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff}label{color:var(--text-2);font-size:.82em;display:block;margin-bottom:5px;font-weight:600}.form-row{display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin-bottom:12px}.form-group{display:flex;flex-direction:column;min-width:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-box{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:28px;width:420px;max-width:100%;box-shadow:var(--shadow-lg)}.pagination{display:flex;align-items:center;justify-content:space-between;margin-top:12px;font-size:.82em;color:var(--text-2);flex-wrap:wrap;gap:8px}.pagination .btn{min-width:60px;text-align:center}.chart-box{height:200px;position:relative}.toast-container{position:fixed;bottom:20px;right:20px;z-index:100;display:flex;flex-direction:column;gap:8px}.log-viewer{background:#1a1d23;color:#d4d4d4;font-family:Consolas,Courier New,monospace;font-size:.8em;padding:16px;border-radius:var(--radius);max-height:600px;overflow-y:auto;line-height:1.6}.log-viewer .log-line{white-space:pre-wrap;word-break:break-all;padding:1px 0}.log-viewer .log-ts{color:#858585}.log-viewer .log-mod{color:#569cd6;font-weight:600}.log-viewer .log-DEBUG{color:#858585}.log-viewer .log-INFO{color:#4ec9b0}.log-viewer .log-WARN{color:#dcdcaa}.log-viewer .log-ERROR{color:#f44747}.log-controls{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.log-controls .badge{cursor:pointer;-webkit-user-select:none;user-select:none}.log-controls .badge.active{outline:2px solid var(--accent)}.toast{padding:12px 18px;border-radius:var(--radius-sm);font-size:.85em;color:#fff;animation:slideIn .3s;min-width:200px;box-shadow:var(--shadow-md);font-weight:500}.toast-ok{background:var(--green)}.toast-err{background:var(--red)}@keyframes slideIn{0%{transform:translate(100px);opacity:0}to{transform:translate(0);opacity:1}}.toast-enter-active{animation:slideIn .3s}.toast-leave-active{transition:opacity .3s,transform .3s}.toast-leave-to{opacity:0;transform:translate(100px)}.empty{text-align:center;padding:40px;color:var(--text-2);font-size:.9em}@media (max-width: 1024px){:root{--sidebar-w: 60px}.sidebar a .nav-label,.sidebar-logo .logo-text,.sidebar-footer .nav-label,.nav-group-label,.sidebar-version{display:none}.sidebar a{justify-content:center;padding:12px 0}.sidebar a .icon{width:auto;font-size:1.1em}.sidebar-logo{justify-content:center;padding:12px 8px}.sidebar-footer{text-align:center}.user-menu-btn{justify-content:center;padding:10px 0}.user-popup{left:4px;right:auto;min-width:160px}.main{padding:20px 16px}.page-header{grid-template-columns:1fr}.page-header .cluster-badge{grid-column:1;grid-row:auto;justify-self:start}.grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.status-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (max-width: 768px){:root{--sidebar-w: 220px}.sidebar{transform:translate(-100%);transition:transform .25s ease;width:var(--sidebar-w)}.sidebar.open{transform:translate(0)}.sidebar.open~.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:9}.sidebar a .nav-label,.sidebar-logo .logo-text,.sidebar-footer .nav-label,.nav-group-label,.sidebar-version{display:block}.sidebar a{justify-content:flex-start;padding:10px 16px}.hamburger{display:block}.mobile-topbar{display:flex;align-items:center;gap:12px;position:fixed;top:0;left:0;right:0;height:50px;padding:0 12px;background:var(--bg-1);border-bottom:1px solid var(--border);z-index:15;box-shadow:0 1px 4px #0000000a}.main{margin-left:0;padding:62px 12px 16px}.page-header h1{font-size:1.2em}.grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.card .value{font-size:1.3em}.status-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.form-row{flex-direction:column;gap:8px}.form-group,.form-group input,.form-group select{width:100%}.section{padding:12px}.section-title{font-size:.9em}.btn{padding:8px 16px;font-size:.85em}.btn-sm{padding:6px 12px}.btn-group{gap:4px}th,td{padding:6px 8px;font-size:.8em}.chart-box{height:160px}.log-viewer{max-height:400px;font-size:.72em}.toast-container{bottom:12px;right:12px;left:12px}.toast{min-width:auto}.strat-cards{grid-template-columns:1fr}table.card-on-mobile thead{display:none}table.card-on-mobile,table.card-on-mobile tbody,table.card-on-mobile tr,table.card-on-mobile td{display:block;width:100%}table.card-on-mobile tr{margin-bottom:10px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-1)}table.card-on-mobile td{border:0;text-align:right;position:relative;padding:4px 0 4px 38%;min-height:24px;font-size:.85em}table.card-on-mobile td:before{content:attr(data-label);position:absolute;left:0;top:4px;width:36%;text-align:left;font-weight:600;color:var(--text-3)}}.text-green{color:var(--green)}.text-red{color:var(--red)}.badge-green{background:#dafbe1;color:var(--green);padding:2px 8px;border-radius:999px;font-size:.8em}.badge-red{background:#ffebe9;color:var(--red);padding:2px 8px;border-radius:999px;font-size:.8em}@media (max-width: 480px){.grid{grid-template-columns:1fr 1fr;gap:8px}.card{padding:12px}.card h3{font-size:.72em}.card .value{font-size:1.1em}.status-grid{grid-template-columns:1fr 1fr}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;background:linear-gradient(135deg,#f0f4ff,#e8f0fe 30%,#f5f6f8 70%,#fef3f2)}.login-card{background:var(--bg-1);border:1px solid var(--border);border-radius:16px;padding:48px 40px 40px;width:100%;max-width:400px;box-shadow:0 8px 32px #00000014}.login-logo{font-size:1.6em;font-weight:700;color:var(--accent);text-align:center;margin-bottom:4px;letter-spacing:0}.login-card h2{text-align:center;font-size:1em;color:var(--text-3);margin-bottom:32px;font-weight:400}.login-card .form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:20px;align-items:stretch}.login-card label{font-weight:500;color:var(--text-2);font-size:.85em;text-align:left}.login-card input{padding:11px 14px;border:1px solid var(--border);border-radius:8px;font-size:.95em;background:var(--bg-0);transition:border-color var(--transition),box-shadow var(--transition)}.login-card input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--bg-1)}.login-error{color:var(--red);font-size:.85em;margin-bottom:12px;padding:8px 12px;background:#fff1f0;border-radius:var(--radius-sm);border:1px solid #fca5a5}.login-btn{width:100%;padding:12px;font-size:1em;border-radius:8px;font-weight:600;letter-spacing:0;transition:all var(--transition);background:var(--accent);border-color:var(--accent)}.login-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0969da40;background:#0557b3}.logout-link{display:flex;align-items:center;gap:8px;padding:8px 18px;color:var(--text-2);text-decoration:none;font-size:.82em;margin-bottom:4px;transition:color var(--transition)}.logout-link:hover{color:var(--red)}.user-info{display:flex;align-items:center;gap:8px;padding:8px 18px;color:var(--text-2);font-size:.85em;margin-bottom:2px}.user-info small{color:var(--text-3);font-size:.9em}.role-select{padding:4px 8px;font-size:.85em;border-radius:4px;border:1px solid var(--border);cursor:pointer;background:#fff}.role-select.role-admin{color:var(--red);border-color:var(--red)}.role-select.role-operator{color:var(--accent);border-color:var(--accent)}.role-select.role-viewer{color:var(--text-3)}.role-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.8em;font-weight:600}.role-badge.role-admin{background:#cf222e1a;color:var(--red)}.role-badge.role-operator{background:#0969da1a;color:var(--accent)}.role-badge.role-viewer{background:var(--bg-2);color:var(--text-3)}.btn-sm.btn-danger-outline{color:var(--red);border-color:var(--red);background:var(--bg-1)}.btn-sm.btn-danger-outline:hover{background:#cf222e14}.btn-sm:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:100;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:28px;width:min(100%,480px);box-shadow:var(--shadow-lg)}.modal-card h3{margin-bottom:16px}.grid-4{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.perm-table{width:100%;border-collapse:separate;border-spacing:0}.perm-table th,.perm-table td{text-align:center;padding:10px 8px}.perm-table th:first-child,.perm-table td:first-child{text-align:left;font-weight:500}.perm-table th{border-bottom:2px solid var(--border)}.perm-cell{cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);-webkit-user-select:none;user-select:none;font-size:.82em;padding:6px 8px}.perm-cell:hover{filter:brightness(.92);transform:scale(1.02)}.perm-none{background:#cf222e0f;color:var(--red)}.perm-read{background:var(--accent-soft);color:var(--accent)}.perm-write{background:#1a7f3714;color:var(--green)}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:16px;font-size:.82em;font-weight:550}.role-admin{background:#cf222e14;color:var(--red)}.role-operator{background:var(--accent-soft);color:var(--accent)}.role-viewer{background:#1a7f3714;color:var(--green)}.role-custom{background:#8250df14;color:#8250df}.role-system-tag{font-size:.72em;opacity:.5;font-weight:400}.role-delete-btn{background:none;border:none;color:inherit;cursor:pointer;font-size:1.1em;padding:0 2px;opacity:.4;transition:opacity var(--transition)}.role-delete-btn:hover{opacity:1;color:var(--red)}
