*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0b;--surface-1:#111113;--surface-2:#18181b;--surface-3:#222226;--border:#ffffff14;--border-hover:#ffffff26;--text-primary:#f4f4f5;--text-secondary:#a1a1aa;--text-muted:#52525b;--accent:#6366f1;--accent-dim:#4f46e5;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}html,body,#root{height:100%}body{background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,system-ui,sans-serif;line-height:1.5}.page{max-width:960px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-title{letter-spacing:-.02em;color:var(--text-primary);font-size:22px;font-weight:650;line-height:1.2}.page-sub{color:var(--text-muted);margin-top:4px;font-size:13.5px}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:7px;align-items:center;gap:7px;padding:8px 16px;font-size:13.5px;font-weight:500;transition:opacity .12s,box-shadow .12s;display:inline-flex}.btn-primary:hover:not(:disabled){opacity:.9;box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 40%, transparent)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-primary.btn-full{justify-content:center;width:100%;padding:10px 16px}.btn-secondary{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:7px;align-items:center;gap:7px;padding:8px 16px;font-size:13.5px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.btn-secondary:hover{background:var(--surface-3);color:var(--text-primary)}.btn-danger{color:#f87171;cursor:pointer;background:#ef444433;border:1px solid #ef444459;border-radius:7px;align-items:center;gap:7px;padding:8px 16px;font-size:13.5px;font-weight:500;transition:background .12s;display:inline-flex}.btn-danger:hover{background:#ef44444d}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text-secondary);font-size:12.5px;font-weight:500}.field input,.field select{background:var(--surface-2);border:1px solid var(--border);color:var(--text-primary);border-radius:7px;outline:none;width:100%;padding:9px 12px;font-size:13.5px;transition:border-color .12s,box-shadow .12s}.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent)}.field input::placeholder{color:var(--text-muted)}.field select option{background:var(--surface-2)}.status-badge{letter-spacing:.01em;white-space:nowrap;border-radius:5px;align-items:center;gap:5px;padding:3px 9px;font-size:11.5px;font-weight:550;display:inline-flex}.status-badge:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px;display:inline-block}.status-running{color:#4ade80;background:#22c55e26;border:1px solid #22c55e40}.status-stopped{background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border)}.status-paused{color:#fbbf24;background:#f59e0b1f;border:1px solid #f59e0b40}.status-unknown{background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border)}.loading-state{color:var(--text-muted);text-align:center;padding:40px 0;font-size:14px}.empty-state{color:var(--text-muted);flex-direction:column;align-items:center;gap:16px;padding:80px 0;font-size:14px;display:flex}.error-banner{color:#f87171;background:#ef44441a;border:1px solid #ef444440;border-radius:8px;padding:10px 14px;font-size:13.5px}.form-error{color:#f87171;background:#ef44441a;border:1px solid #ef444440;border-radius:7px;padding:9px 12px;font-size:13px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.layout{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--surface-1);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;padding:0;display:flex}.sidebar-logo{letter-spacing:-.01em;color:var(--text-primary);border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:8px;padding:20px 20px 16px;font-size:15px;font-weight:600;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:4px 10px;display:flex}.nav-item{color:var(--text-secondary);border-radius:6px;align-items:center;gap:9px;padding:8px 10px;font-size:13.5px;font-weight:450;text-decoration:none;transition:background .12s,color .12s;display:flex}.nav-item:hover{background:var(--surface-2);color:var(--text-primary)}.nav-item.active{background:var(--surface-2);color:var(--text-primary);font-weight:500}.nav-item.active svg{color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:8px;padding:12px 10px;display:flex}.user-chip{flex:1;align-items:center;gap:9px;min-width:0;display:flex}.avatar{background:var(--accent);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:600;display:flex}.user-info{flex-direction:column;min-width:0;display:flex}.user-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}.logout-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:5px;align-items:center;padding:5px;transition:color .12s,background .12s;display:flex}.logout-btn:hover{color:var(--text-primary);background:var(--surface-2)}.main-content{flex:1;padding:36px 40px;overflow-y:auto}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;width:100%;max-width:360px;padding:36px 32px}.login-logo{color:var(--text-primary);align-items:center;gap:10px;margin-bottom:28px;font-size:16px;font-weight:600;display:flex}.login-title{color:var(--text-primary);letter-spacing:-.02em;margin:0 0 4px;font-size:22px;font-weight:600}.login-sub{color:var(--text-muted);margin:0 0 24px;font-size:13.5px}.login-form{flex-direction:column;gap:16px;display:flex}.vm-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:4px;display:grid}.vm-card{background:var(--surface-1);border:1px solid var(--border);cursor:pointer;border-radius:10px;outline:none;padding:20px;transition:border-color .15s,box-shadow .15s}.vm-card:hover{border-color:var(--border-hover);box-shadow:0 4px 20px #0000004d}.vm-card:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 30%, transparent)}.vm-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.vm-card-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14.5px;font-weight:550;overflow:hidden}.vm-card-specs{grid-template-columns:1fr 1fr;gap:10px 16px;margin-bottom:14px;display:grid}.spec{flex-direction:column;gap:2px;display:flex}.spec-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.spec-value{color:var(--text-secondary);font-size:13.5px;font-weight:450}.vm-card-cpu{border-top:1px solid var(--border);align-items:center;gap:8px;padding-top:12px;display:flex}.cpu-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;width:28px;font-size:11px}.cpu-bar-track{background:var(--surface-3);border-radius:99px;flex:1;height:4px;overflow:hidden}.cpu-bar-fill{background:var(--accent);border-radius:99px;height:100%;transition:width .4s}.cpu-pct{color:var(--text-secondary);text-align:right;flex-shrink:0;width:38px;font-size:11.5px}.back-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;gap:5px;margin-bottom:6px;padding:0;font-size:13px;transition:color .12s;display:inline-flex}.back-btn:hover{color:var(--text-secondary)}.detail-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:16px;display:grid}.detail-card{background:var(--surface-1);border:1px solid var(--border);border-radius:10px;padding:20px 24px}.section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:0 0 14px;font-size:12px;font-weight:600}.kv-list{flex-direction:column;gap:0;display:flex}.kv-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.kv-row:last-child{border-bottom:none}.kv-label{color:var(--text-muted);font-size:13.5px}.kv-value{color:var(--text-primary);font-size:13.5px;font-weight:450}.actions-card{margin-top:0}.action-buttons{flex-wrap:wrap;gap:10px;display:flex}.action-btn{cursor:pointer;border:1px solid #0000;border-radius:7px;align-items:center;gap:8px;padding:8px 16px;font-size:13.5px;font-weight:500;transition:background .12s,border-color .12s,opacity .12s;display:inline-flex}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn-secondary{background:var(--surface-2);border-color:var(--border);color:var(--text-primary)}.action-btn-secondary:hover:not(:disabled){background:var(--surface-3)}.action-btn-positive{color:#4ade80;background:#22c55e26;border-color:#22c55e4d}.action-btn-positive:hover:not(:disabled){background:#22c55e38}.action-btn-danger-outline{color:#f87171;background:0 0;border-color:#ef444459}.action-btn-danger-outline:hover:not(:disabled){background:#ef44441a}.action-btn-danger{color:#f87171;background:#ef444426;border-color:#ef44444d}.action-btn-danger:hover:not(:disabled){background:#ef444440}.action-icon{font-size:13px}.confirm-hint{color:#f87171;margin-top:12px;font-size:12.5px}.status-lg{padding:5px 12px;font-size:12.5px}.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 .xterm-scroll-area{visibility:hidden}.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,.xterm .xterm-message{z-index:10;color:#0000;pointer-events:none;position:absolute;inset:0}.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}.console-page{background:#0a0a0b;flex-direction:column;height:100vh;display:flex}.console-topbar{border-bottom:1px solid var(--border);background:var(--surface-1);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.console-label{color:var(--text-muted);font-family:JetBrains Mono,Fira Code,Menlo,monospace;font-size:13px}.console-term{flex:1;padding:12px 12px 28px;overflow:hidden}.console-term .xterm{height:100%}.console-term .xterm-viewport{background:0 0!important}.create-card{background:var(--surface-1);border:1px solid var(--border);border-radius:10px;max-width:600px;padding:28px 32px}.create-form{flex-direction:column;gap:28px;display:flex}.create-form section{flex-direction:column;gap:12px;display:flex}.template-list{flex-direction:column;gap:8px;display:flex}.template-option{border:1px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:12px 14px;transition:border-color .12s,background .12s;display:flex}.template-option input[type=radio]{display:none}.template-option:hover{border-color:var(--border-hover);background:var(--surface-2)}.template-option.selected{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent)}.template-info{flex-direction:column;flex:1;gap:2px;display:flex}.template-name{color:var(--text-primary);font-size:13.5px;font-weight:500}.template-meta{color:var(--text-muted);font-size:12px}.check-icon{color:var(--accent);flex-shrink:0}.resource-grid{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.number-input{border:1px solid var(--border);background:var(--surface-2);border-radius:7px;align-items:center;display:flex;overflow:hidden}.number-input button{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:9px 13px;font-size:16px;transition:background .1s,color .1s}.number-input button:hover{background:var(--surface-3);color:var(--text-primary)}.number-input span{text-align:center;color:var(--text-primary);flex:1;font-size:14px;font-weight:500}.disk-input{border:1px solid var(--border);background:var(--surface-2);border-radius:7px;align-items:center;gap:0;display:flex;overflow:hidden}.disk-input input{width:100%;color:var(--text-primary);background:0 0;border:none;outline:none;padding:9px 12px;font-size:14px}.disk-unit{color:var(--text-muted);border-left:1px solid var(--border);background:var(--surface-3);align-self:stretch;align-items:center;padding:0 12px;font-size:13px;display:flex}.section-title-note{color:var(--text-muted);text-transform:none;letter-spacing:0;font-size:11px;font-weight:400}.form-actions{justify-content:flex-end;gap:10px;padding-top:8px;display:flex}.admin-table-wrap{background:var(--surface-1);border:1px solid var(--border);border-radius:10px;overflow:hidden}.admin-table{border-collapse:collapse;width:100%;font-size:13.5px}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);padding:10px 16px;font-size:11px;font-weight:600}.admin-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:13px 16px}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:var(--surface-2)}.td-username{color:var(--text-primary);font-weight:500}.td-muted{color:var(--text-muted)}.td-actions{text-align:right;white-space:nowrap}.role-badge{border-radius:4px;padding:2px 8px;font-size:11.5px;font-weight:500;display:inline-block}.role-badge.role-admin{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent)}.role-badge.role-user{background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border)}.tbl-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:5px;margin-left:6px;padding:4px 10px;font-size:12px;transition:background .1s,border-color .1s,color .1s}.tbl-btn:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-hover)}.tbl-btn-danger{color:#f87171;border-color:#ef44444d}.tbl-btn-danger:hover{color:#fca5a5;background:#ef44441f;border-color:#ef444480}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface-1);border:1px solid var(--border);border-radius:12px;width:100%;max-width:420px;box-shadow:0 24px 64px #00000080}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:20px;line-height:1;transition:color .1s,background .1s}.modal-close:hover{color:var(--text-primary);background:var(--surface-2)}.modal-form{flex-direction:column;gap:14px;padding:20px 24px 24px;display:flex}.modal-actions{justify-content:flex-end;gap:10px;padding-top:4px;display:flex}
