html,body,#root{height:100%}.xterm{cursor:text;-webkit-user-select:none;user-select:none;position:relative}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{z-index:5;position:absolute;top:0}.xterm .xterm-helper-textarea{opacity:0;z-index:-5;white-space:nowrap;resize:none;border:0;width:0;height:0;margin:0;padding:0;position:absolute;top:0;left:-9999em;overflow:hidden}.xterm .composition-view{color:#fff;white-space:nowrap;z-index:1;background:#000;display:none;position:absolute}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{cursor:default;background-color:#000;position:absolute;inset:0;overflow-y:scroll}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;top:0;left:0}.xterm-char-measure-element{visibility:hidden;line-height:normal;display:inline-block;position:absolute;top:0;left:-9999em}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{z-index:10;color:#0000;pointer-events:none;position:absolute;inset:0}.xterm .xterm-accessibility-tree:not(.debug) ::selection{color:#0000}.xterm .xterm-accessibility-tree{-webkit-user-select:text;user-select:text;white-space:pre;font-family:monospace}.xterm .xterm-accessibility-tree>div{transform-origin:0;width:fit-content}.xterm .live-region{width:1px;height:1px;position:absolute;left:-9999px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:underline double;text-decoration:underline double}.xterm-underline-3{-webkit-text-decoration:underline wavy;text-decoration:underline wavy}.xterm-underline-4{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.xterm-underline-5{-webkit-text-decoration:underline dashed;text-decoration:underline dashed}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:underline overline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;pointer-events:none;position:absolute;top:0;right:0}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;z-index:11;background:0 0;transition:opacity .1s linear}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{display:none;position:absolute}.xterm .xterm-scrollable-element>.shadow.top{width:100%;height:3px;box-shadow:var(--vscode-scrollbar-shadow,#000) 0 6px 6px -6px inset;display:block;top:0;left:3px}.xterm .xterm-scrollable-element>.shadow.left{width:3px;height:100%;box-shadow:var(--vscode-scrollbar-shadow,#000) 6px 0 6px -6px inset;display:block;top:3px;left:0}.xterm .xterm-scrollable-element>.shadow.top-left-corner{width:3px;height:3px;display:block;top:0;left:0}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow,#000) 6px 0 6px -6px inset}:root{--bg:#0f1419;--panel:#1a212b;--panel-2:#222c38;--border:#2b3644;--text:#e6edf3;--muted:#8b98a8;--accent:#2f81f7;--ok:#3fb950;--warn:#d29922;--danger:#f85149}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{min-height:100vh}.topbar{background:var(--panel);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;font-size:17px;font-weight:700;display:flex}.brand .logo{color:var(--accent);font-size:20px}.status{align-items:center;gap:16px;font-size:13px;display:flex}.status .ok{color:var(--ok)}.content{max-width:1200px;margin:0 auto;padding:28px 24px}.page-head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.page-head h1{margin:0 0 4px;font-size:22px}.head-actions{gap:8px;display:flex}.shell{height:100vh;display:flex}.sidebar{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;display:flex}.sidebar .brand{border-bottom:1px solid var(--border);padding:18px 20px}.nav{flex-direction:column;gap:2px;padding:12px 10px;display:flex}.nav-item{color:var(--muted);border-radius:8px;align-items:center;gap:11px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--panel-2);color:var(--text)}.nav-item.active{color:var(--accent);background:#2f81f724}.nav-icon{text-align:center;width:18px;font-size:15px}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.main .topbar{position:static}.main .content{flex:1;overflow:auto}.role-badge{text-transform:uppercase;letter-spacing:.04em;background:var(--panel-2);color:var(--muted);border-radius:10px;padding:2px 7px;font-size:10px}.role-badge.admin{color:var(--ok);background:#3fb95026}.warn{color:var(--warn)}.inline-form{gap:8px;margin:16px 0;display:flex}.input,.textarea{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:7px;padding:8px 11px;font-size:14px}.input{flex:1;max-width:420px}.textarea{resize:vertical;width:100%}.code{font-family:ui-monospace,monospace;font-size:12.5px;line-height:1.5}.stack-editor{flex-direction:column;align-items:flex-start;gap:10px;margin:16px 0;display:flex}.stack-editor .input{max-width:320px}.output-box{border:1px solid var(--border);border-radius:8px;max-height:240px;margin:16px 0;overflow:auto}.muted{color:var(--muted)}.banner{border-radius:8px;margin:16px 0;padding:10px 14px;font-size:14px}.banner.error,.error{color:var(--danger)}.banner.error{background:#f851491f;border:1px solid #f851494d}.grid{border-collapse:collapse;background:var(--panel);border:1px solid var(--border);border-radius:10px;width:100%;margin-top:16px;overflow:hidden}.grid th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--border);background:var(--panel-2);padding:12px 14px;font-size:12px}.grid td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px;font-size:14px}.grid tr:last-child td{border-bottom:none}.grid tr:hover td{background:#ffffff05}.name{font-weight:600}.name .sub{color:var(--muted);font-family:ui-monospace,monospace;font-size:12px;font-weight:400}.image,.ports{color:var(--muted);font-family:ui-monospace,monospace;font-size:12.5px}.actions-col{text-align:right}.actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.badge{text-transform:capitalize;background:var(--panel-2);color:var(--muted);border-radius:20px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}.badge-running{color:var(--ok);background:#3fb95026}.badge-exited{color:var(--danger);background:#f851491f}.badge-paused{color:var(--warn);background:#d2992226}.btn{background:var(--panel-2);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:7px;padding:7px 12px;font-size:13px;transition:background .15s,border-color .15s}.btn:hover{background:#2c3847;border-color:#3a485a}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:5px 10px;font-size:12px}.btn-ok{color:var(--ok);border-color:#3fb95066}.btn-warn{color:var(--warn);border-color:#d2992266}.btn-danger{color:var(--danger);border-color:#f8514966}.btn-icon{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:16px}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:#2570d4;border-color:#2570d4}.btn-lg{padding:11px 20px;font-size:15px}.center{justify-content:center;align-items:center;height:100vh;display:flex}.user{color:var(--text);align-items:center;gap:10px;display:inline-flex}.logout{text-decoration:none}.login-screen{justify-content:center;align-items:center;height:100vh;display:flex}.login-card{background:var(--panel);border:1px solid var(--border);text-align:center;border-radius:14px;flex-direction:column;align-items:center;gap:16px;padding:40px 48px;display:flex}.brand-lg{font-size:26px}.brand-lg .logo{font-size:30px}.modal-backdrop{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:min(900px,92vw);max-height:80vh;display:flex}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.modal-header h3{margin:0;font-size:15px}.modal-body{padding:0;overflow:auto}.logs{white-space:pre-wrap;word-break:break-word;color:#c9d4e0;max-height:60vh;margin:0;padding:16px 18px;font-family:ui-monospace,monospace;font-size:12.5px;line-height:1.5;overflow:auto}.modal-wide{width:min(1100px,94vw)}.live-dot{font-size:11px;font-weight:500}.live-dot.ok{color:var(--ok)}.live-dot.muted{color:var(--muted)}.term-body{background:#11171f;padding:8px}.term-host{width:100%;height:60vh}.stats-body{flex-direction:column;gap:18px;padding:20px;display:flex}.stat-row{flex-direction:column;gap:8px;display:flex}.stat-label{color:var(--muted);justify-content:space-between;font-size:13px;display:flex}.stat-val{color:var(--text);font-family:ui-monospace,monospace}.bar{background:var(--panel-2);border-radius:6px;height:10px;overflow:hidden}.bar-fill{height:100%;transition:width .4s}.create-form{flex-direction:column;gap:14px;padding:18px;display:flex}.create-form label{color:var(--muted);flex-direction:column;gap:6px;font-size:13px;display:flex}.create-form .input,.create-form .textarea,.create-form select.input{max-width:none}.field-group{color:var(--muted);flex-direction:column;gap:8px;font-size:13px;display:flex}.port-row{align-items:center;gap:8px;display:flex}.port-row .input{max-width:120px}
