*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d1117;--bg-card: #161b22;--bg-titlebar: #1c2128;--bg-input: #0d1117;--border: #30363d;--text: #e6edf3;--text-muted: #7d8590;--text-dim: #484f58;--green: #2ecc71;--red: #e74c3c;--yellow: #f1c40f;--gray: #6c757d;--blue: #58a6ff;--radius: 8px;--radius-sm: 4px;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", Consolas, monospace}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}.splash{display:flex;align-items:center;justify-content:center;height:100vh}.spinner{display:inline-block;width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;width:360px;display:flex;flex-direction:column;gap:28px}.login-logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:var(--text)}.login-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.field input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;padding:9px 12px;outline:none;transition:border-color .15s}.field input:focus{border-color:var(--green)}.login-error{background:#e74c3c1f;border:1px solid rgba(231,76,60,.4);border-radius:var(--radius-sm);color:#ff6b6b;font-size:13px;padding:8px 12px}.btn-primary{background:var(--green);color:#000;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;padding:10px;cursor:pointer;transition:opacity .15s}.btn-primary:hover:not(:disabled){opacity:.85}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.dashboard{display:flex;flex-direction:column;height:100vh;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}.topbar-logo{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:var(--text)}.topbar-right{display:flex;align-items:center;gap:14px}.ws-indicator{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.ws-dot{width:7px;height:7px;border-radius:50%;background:var(--gray)}.ws-indicator--connected .ws-dot{background:var(--green);box-shadow:0 0 6px var(--green)}.ws-indicator--connected{color:var(--green)}.btn-logout{background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;padding:5px 12px;cursor:pointer;transition:border-color .15s,color .15s}.btn-logout:hover{border-color:var(--text-muted);color:var(--text)}.disconnect-banner{background:#e74c3c26;border-bottom:1px solid rgba(231,76,60,.4);color:#ff6b6b;font-size:12px;font-weight:600;padding:6px 20px;text-align:center;flex-shrink:0}.topbar-stats-group{display:flex;align-items:center;gap:10px;padding-left:14px;border-left:1px solid var(--border);color:var(--text-muted);font-size:12px;white-space:nowrap;cursor:default}.topbar-stat{font-variant-numeric:tabular-nums}.topbar-control{display:flex;align-items:center;gap:6px;color:var(--text-muted);cursor:pointer}.topbar-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;padding:4px 24px 4px 8px;cursor:pointer;outline:none;transition:border-color .15s,color .15s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237d8590' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center}.topbar-select:hover,.topbar-select:focus{border-color:var(--text-muted);color:var(--text)}.topbar-select option{background:#1c2128;color:var(--text)}.grid-container{flex:1;overflow-y:auto;padding:16px;display:grid;gap:12px;align-content:start}.service-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;height:var(--card-height, 308px);position:relative;transition:border-color .15s}.service-card:hover{border-color:#3d444d}.service-card--dragging{box-shadow:0 8px 32px #0009;z-index:100}.service-card--drop-target{border-left:3px solid var(--blue);box-shadow:inset 2px 0 8px #58a6ff26}.card-titlebar{display:flex;align-items:center;gap:8px;padding:0 10px;height:40px;background:var(--bg-titlebar);border-bottom:1px solid var(--border);cursor:grab;-webkit-user-select:none;user-select:none;flex-shrink:0}.card-titlebar:active{cursor:grabbing}.card-title-left{display:flex;align-items:center;gap:7px;min-width:0;flex:1}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.card-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.card-status{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.card-stats{display:flex;gap:10px;font-size:11px;color:var(--text-muted);flex-shrink:0}.card-stats span{white-space:nowrap}.card-actions{display:flex;gap:2px;flex-shrink:0}.action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.action-btn:hover:not(:disabled){background:#ffffff12;border-color:var(--border);color:var(--text)}.action-btn--stop:hover:not(:disabled){background:#e74c3c26;border-color:#e74c3c66;color:var(--red)}.action-btn:disabled{opacity:.35;cursor:not-allowed}.action-btn--start:hover:not(:disabled){background:#2ecc7126;border-color:#2ecc7166;color:var(--green)}.titlebar-filter{display:flex;align-items:center;gap:4px;flex-shrink:0}.titlebar-filter-pills{display:flex;gap:1px;background:#00000040;border:1px solid var(--border);border-radius:10px;padding:2px}.titlebar-filter-select{font-size:10px;padding:2px 20px 2px 6px;height:22px}@keyframes warnPulse{0%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.warn-triangle{display:flex;align-items:center;justify-content:center;position:relative;background:transparent;border:none;color:var(--yellow);cursor:pointer;padding:0 2px;flex-shrink:0;animation:warnPulse 1.4s ease-in-out 2}.warn-triangle:hover{color:gold}.warn-badge{position:absolute;top:-5px;right:-5px;background:var(--red);color:#fff;font-size:9px;font-weight:700;border-radius:8px;padding:1px 4px;line-height:1.3;pointer-events:none}.card-filter-btn{background:transparent;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;font-size:10px;font-weight:600;padding:1px 8px;line-height:1.6;transition:background .12s,color .12s;display:flex;align-items:center;gap:4px;white-space:nowrap}.card-filter-btn:hover{color:var(--text);background:#ffffff0f}.card-filter-btn--active{background:var(--bg-card);color:var(--text)}.card-filter-btn--err-active{background:#e74c3c33;color:#ff6b6b}.card-filter-count{background:#e74c3c59;border-radius:6px;color:#ff6b6b;font-size:9px;padding:0 4px;line-height:14px}.log-window{flex:1;overflow-y:auto;background:var(--bg);padding:6px 10px;font-family:var(--font-mono);font-size:11.5px;line-height:1.55;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.log-window::-webkit-scrollbar{width:6px}.log-window::-webkit-scrollbar-track{background:transparent}.log-window::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.log-window--modal{font-size:13px;padding:10px 16px}.log-window--offline{display:flex;align-items:center;justify-content:center}.log-offline{color:var(--text-dim);font-size:12px;font-style:italic}.log-line{display:flex;gap:8px;align-items:baseline;padding:.5px 0;white-space:pre-wrap;word-break:break-all}.log-line--err .log-msg{color:#ff6b6b}.log-ts{color:var(--text-dim);flex-shrink:0;font-size:10px;padding-top:1px;min-width:76px}.log-msg{color:var(--text);flex:1;min-width:0}.scroll-to-bottom{position:absolute;bottom:12px;right:14px;background:var(--bg-titlebar);border:1px solid var(--border);border-radius:20px;color:var(--text-muted);font-size:11px;padding:4px 12px;cursor:pointer;transition:color .12s,border-color .12s;z-index:10;box-shadow:0 2px 8px #0006}.scroll-to-bottom:hover{color:var(--text);border-color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:flex-start;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:24px 16px}.modal-expanded{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;width:min(1100px,100%);height:calc(100vh - 48px);max-height:100%;overflow:hidden;position:relative}.modal-header{display:flex;align-items:center;gap:12px;justify-content:space-between;padding:0 16px;height:48px;background:var(--bg-titlebar);border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:15px;font-weight:600;color:var(--text)}.modal-close{background:transparent;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .12s,color .12s}.modal-close:hover{background:#ffffff14;color:var(--text)}.log-filter{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:2px;margin:0 auto 0 12px}.log-filter-btn{background:transparent;border:none;border-radius:16px;color:var(--text-muted);cursor:pointer;font-size:11px;font-weight:600;padding:3px 12px;transition:background .12s,color .12s;display:flex;align-items:center;gap:5px}.log-filter-btn:hover{color:var(--text);background:#ffffff0f}.log-filter-btn--active{background:var(--bg-titlebar);color:var(--text)}.log-filter-btn--err{color:var(--text-muted)}.log-filter-btn--err-active{background:#e74c3c33;color:#ff6b6b}.log-filter-count{background:#e74c3c59;border-radius:8px;color:#ff6b6b;font-size:10px;padding:0 5px;line-height:16px}.modal-pause-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:background .12s,color .12s,border-color .12s;flex-shrink:0}.modal-pause-btn:hover{background:#ffffff14;border-color:var(--border);color:var(--text)}.modal-pause-btn--active{background:#f1c40f26;border-color:#f1c40f66;color:var(--yellow)}.clipboard-msg{font-size:11px;color:var(--green);font-style:italic;white-space:nowrap;opacity:1;transition:opacity .4s;margin-left:auto;margin-right:8px;flex-shrink:0}.clipboard-msg--fade{opacity:0}.paused-banner{flex-shrink:0;background:#f1c40f1a;border-top:1px solid rgba(241,196,15,.3);color:var(--yellow);font-size:12px;font-weight:600;padding:5px 16px;display:flex;align-items:center;gap:8px}.paused-banner button{background:transparent;border:1px solid rgba(241,196,15,.4);border-radius:var(--radius-sm);color:var(--yellow);cursor:pointer;font-size:11px;font-weight:600;padding:2px 10px;transition:background .12s}.paused-banner button:hover{background:#f1c40f26}.confirm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px;width:min(420px,90vw);display:flex;flex-direction:column;gap:20px}.confirm-modal p{color:var(--text);font-size:14px;line-height:1.5}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.btn-secondary{background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:13px;padding:7px 16px;cursor:pointer;transition:border-color .12s,color .12s}.btn-secondary:hover{border-color:var(--text-muted);color:var(--text)}.btn-danger{background:var(--red);border:none;border-radius:var(--radius-sm);color:#fff;font-size:13px;font-weight:600;padding:7px 16px;cursor:pointer;transition:opacity .12s}.btn-danger:hover{opacity:.85}.card-action-error{background:#e74c3c26;border-top:1px solid rgba(231,76,60,.4);color:#ff6b6b;font-size:12px;padding:5px 10px;animation:fadeIn .15s ease}.server-error-banner{background:#e74c3c26;border-bottom:1px solid rgba(231,76,60,.4);color:#ff6b6b;font-size:13px;padding:10px 20px;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.service-summary{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px;background:#2ecc711a;border:1px solid rgba(46,204,113,.3);color:var(--green);white-space:nowrap}.service-summary--error{background:#e74c3c1a;border-color:#e74c3c4d;color:#ff6b6b}.service-summary--stopped{background:#6c757d26;border-color:#6c757d4d;color:var(--gray)}.summary-dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0}.summary-errored{opacity:.85}.modal-search-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:12px;padding:4px 10px;outline:none;width:180px;transition:border-color .15s}.modal-search-input:focus{border-color:var(--blue)}.log-line mark{background:#f1c40f59;color:inherit;border-radius:2px;padding:0 1px}.modal-font-btns{display:flex;gap:1px}.modal-actions{display:flex;gap:2px;align-items:center;border-left:1px solid var(--border);padding-left:8px;margin-left:4px}.port-badge{display:inline-block;background:var(--bg-titlebar);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--blue);font-family:var(--font-mono);font-size:11px;padding:1px 6px;white-space:nowrap}.port-select-badge{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-titlebar);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--blue);font-family:var(--font-mono);font-size:11px;padding:1px 20px 1px 6px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2358a6ff' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center}.port-select-badge option{background:#1c2128;color:var(--blue)}.modal-ports{display:flex;gap:4px;flex-shrink:0}.topbar-icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:background .12s,color .12s,border-color .12s;flex-shrink:0}.topbar-icon-btn:hover{background:#ffffff12;border-color:var(--border);color:var(--text)}.ports-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;width:min(640px,94vw);max-height:calc(100vh - 80px);overflow:hidden}.ports-modal-body{overflow-y:auto;flex:1;padding:0}.ports-modal-note{font-size:11px;color:var(--text-dim);font-style:italic;margin-left:auto;margin-right:8px;flex-shrink:0}.ports-table{width:100%;border-collapse:collapse;font-size:13px}.ports-th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:8px 16px;border-bottom:1px solid var(--border);background:var(--bg-titlebar);position:sticky;top:0}.ports-row:last-child td{border-bottom:none}.ports-row td{padding:9px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.ports-svc-name{font-weight:600;color:var(--text);width:40%;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ports-list{display:flex;flex-wrap:wrap;gap:5px}.ports-none{color:var(--text-dim);font-style:italic}.ports-loading,.ports-error{padding:24px 16px;color:var(--text-muted);font-size:13px;font-style:italic}.ports-error{color:#ff6b6b}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}@media (max-width: 600px){.grid-container{grid-template-columns:1fr;padding:10px}.card-stats{display:none}.topbar{padding:0 12px}}
