@import"https://fonts.googleapis.com/css2?family=Unbounded:wght@200..900&display=swap";*{font-family:Unbounded,sans-serif;font-weight:700}:root{--bg: #ffffff;--bg-secondary: #f8f8f6;--bg-tertiary: #f1f0ec;--text-primary: #1a1a18;--text-secondary: #6b6b67;--text-tertiary: #a8a8a4;--border: rgba(0, 0, 0, .1);--border-hover: rgba(0, 0, 0, .2);--radius-md: 8px;--radius-lg: 12px;--font-sans: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--green: #1D9E75;--green-bg: #E1F5EE;--red: #E24B4A;--red-bg: #FCEBEB;--amber: #EF9F27;--amber-bg: #FAEEDA}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--bg: #181816;--bg-secondary: #222220;--bg-tertiary: #2a2a28;--text-primary: #f0efe8;--text-secondary: #9a9994;--text-tertiary: #6a6a65;--border: rgba(255, 255, 255, .1);--border-hover: rgba(255, 255, 255, .2)}}[data-theme=dark]{--bg: #181816;--bg-secondary: #222220;--bg-tertiary: #2a2a28;--text-primary: #f0efe8;--text-secondary: #9a9994;--text-tertiary: #6a6a65;--border: rgba(255, 255, 255, .1);--border-hover: rgba(255, 255, 255, .2)}[data-theme=light]{--bg: #ffffff;--bg-secondary: #f8f8f6;--bg-tertiary: #f1f0ec;--text-primary: #1a1a18;--text-secondary: #6b6b67;--text-tertiary: #a8a8a4;--border: rgba(0, 0, 0, .1);--border-hover: rgba(0, 0, 0, .2)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;min-height:100vh}.lp{min-height:100vh;background:var(--bg-secondary);color:var(--text-primary);display:flex;flex-direction:column}.lp-header{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;border-bottom:.5px solid var(--border);background:var(--bg);flex-shrink:0}.lp-header-right{display:flex;align-items:center;gap:.5rem}.lp-enter-btn{display:inline-flex;align-items:center;gap:.35rem;font-weight:600;background:var(--text-primary);color:var(--bg);border:none;padding:6px 14px}.lp-enter-btn:hover{opacity:.85}.lp-hero{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:4rem 1.5rem 3rem;gap:2rem;max-width:820px;margin:0 auto;width:100%}.lp-badge{display:inline-flex;align-items:center;gap:.45rem;padding:.3rem .9rem;border-radius:999px;background:var(--bg);border:.5px solid var(--border);color:var(--text-secondary);font-size:.78rem;font-weight:500;letter-spacing:.03em}.lp-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 2px var(--green-bg);animation:lp-pulse 2.5s ease-in-out infinite}@keyframes sk-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.sk-card{pointer-events:none}.sk-line,.sk-badge,.sk-avatar,.sk-dot,.sk-bar-track,.sk-bar-fill,.sk-badge-sm{background:linear-gradient(90deg,var(--bg-tertiary) 25%,color-mix(in srgb,var(--bg-tertiary) 60%,var(--text-primary)) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:sk-shimmer 1.6s ease-in-out infinite;border-radius:6px}.sk-vm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.sk-title{height:14px;width:42%}.sk-sub{height:11px;width:60%;margin-top:6px}.sk-badge{height:22px;width:68px;border-radius:12px}.sk-badge-sm{height:18px;width:52px;border-radius:10px}.sk-bars{display:flex;flex-direction:column;gap:.55rem}.sk-bar-row{display:flex;align-items:center;gap:.5rem}.sk-label{height:10px;width:28px;flex-shrink:0}.sk-bar-track{flex:1;height:6px;border-radius:4px;overflow:hidden}.sk-bar-fill{height:100%;border-radius:4px}.sk-proj-header{display:flex;align-items:center;gap:.85rem;margin-bottom:.85rem}.sk-avatar{width:42px;height:42px;border-radius:10px;flex-shrink:0}.sk-proj-text{flex:1;min-width:0}.sk-procs{display:flex;flex-direction:column;gap:.5rem}.sk-proc-row{display:flex;align-items:center;gap:.5rem}.sk-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sk-proc-name{height:11px;flex:1}@keyframes lp-pulse{0%,to{opacity:1}50%{opacity:.5}}.lp-title{font-size:clamp(2.2rem,5.5vw,3.6rem);font-weight:800;line-height:1.12;letter-spacing:-.03em;color:var(--text-primary)}.lp-title-accent{color:var(--green)}.lp-subtitle{font-size:1rem;color:var(--text-secondary);line-height:1.7;max-width:520px}.lp-stats{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.lp-stat{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.85rem 1.4rem;border-radius:var(--radius-lg);background:var(--bg);border:.5px solid var(--border);min-width:100px;transition:border-color .15s}.lp-stat:hover{border-color:var(--border-hover)}.lp-stat-value{font-size:1.7rem;font-weight:800;color:var(--text-primary);line-height:1}.lp-val-green{color:var(--green)}.lp-val-red{color:var(--red)}.lp-stat-label{font-size:.7rem;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.lp-cta{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 2rem;font-size:.95rem;font-weight:700;border-radius:var(--radius-md);background:var(--text-primary);color:var(--bg);border:none;cursor:pointer;transition:opacity .15s,transform .1s}.lp-cta:hover{opacity:.88}.lp-cta:active{transform:scale(.98)}.lp-features{padding:0 1.5rem 3rem;max-width:960px;margin:0 auto;width:100%}.lp-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}@media (max-width: 720px){.lp-features-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.lp-features-grid{grid-template-columns:1fr}}.lp-feature-card{background:var(--bg);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.25rem;text-align:left;transition:border-color .15s,transform .15s}.lp-feature-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.lp-feature-icon{display:flex;align-items:center;margin-bottom:.55rem;color:var(--text-secondary);font-size:1.3rem}.lp-feature-title{font-size:.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.3rem}.lp-feature-desc{font-size:.78rem;color:var(--text-tertiary);line-height:1.55}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--bg-secondary)}.auth-card{background:var(--bg);padding:2rem;border-radius:var(--radius-lg);border:.5px solid var(--border);width:100%;max-width:360px;box-shadow:0 4px 20px #0000000d}.auth-title{font-size:1.25rem;font-weight:500;margin-bottom:1.5rem;text-align:center}.auth-input{width:100%;padding:.75rem;margin-bottom:1rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);color:var(--text-primary);font-family:system-ui,sans-serif;outline:none;font-size:16px}.auth-input:focus{border-color:var(--text-primary)}.auth-btn{width:100%;padding:.75rem;background:var(--text-primary);color:var(--bg);border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:opacity .2s}.auth-btn:hover{opacity:.9}.auth-error{color:var(--red);font-size:.875rem;margin-bottom:1rem;text-align:center}.auth-2fa-hint{font-size:.875rem;color:var(--text-secondary);text-align:center;line-height:1.6;margin-bottom:1.25rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border)}.auth-code-input{font-family:var(--font-mono);font-size:.95rem;letter-spacing:.04em;text-align:center}.auth-back-btn{background:none;border:none;color:var(--text-tertiary);font-size:.85rem;cursor:pointer;padding:.4rem 0;margin-top:.25rem;width:100%}.auth-back-btn:hover{color:var(--text-secondary)}.app-container{max-width:1200px;margin:0 auto;padding:2rem}@media (max-width: 768px){.app-container{padding:1rem}}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-body{display:flex;width:100%;max-width:1400px;margin:0 auto;padding:0 2rem;gap:2rem;box-sizing:border-box}.app-main{flex:1;min-width:0}@media (max-width: 900px){.app-body{padding:0 1rem;gap:1rem;flex-direction:column}}.filter-sidebar{flex-shrink:0;width:240px;padding:2.5rem 1.25rem 2rem 0;position:sticky;top:56px;align-self:flex-start;max-height:calc(100vh - 56px);overflow-y:auto;border-right:.5px solid var(--border);margin-right:-1px}@media (max-width: 900px){.filter-sidebar{width:100%;position:static;max-height:none;border-right:none;border-bottom:.5px solid var(--border);padding:1rem 0;margin-right:0}}.filter-sidebar-header{display:flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--text-tertiary);margin-bottom:1.25rem}.filter-group{margin-bottom:1.5rem}.filter-group-title{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;margin-bottom:.5rem}.filter-group-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:0 0 .5rem}.filter-list{display:flex;flex-direction:column;gap:2px}.filter-item{display:flex;align-items:center;justify-content:space-between;gap:8px;background:transparent;border:1px solid transparent;border-radius:8px;padding:7px 10px;color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:background .12s,color .12s,border-color .12s;text-align:left}.filter-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.filter-item.active{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-hover);font-weight:600}.filter-item-left{display:flex;align-items:center;gap:8px;min-width:0}.filter-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-item-count{font-size:.72rem;color:var(--text-tertiary);background:var(--bg-tertiary);padding:1px 7px;border-radius:99px;font-weight:600;flex-shrink:0}.filter-item.active .filter-item-count{background:var(--bg);color:var(--text-primary)}.vm-charts-card{margin-bottom:2rem}.vm-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width: 900px){.vm-charts-grid{grid-template-columns:1fr}}.chart-wrap{background:var(--bg-secondary);border:.5px solid var(--border);border-radius:10px;padding:12px;position:relative}.chart-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.chart-label{font-size:.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.chart-current{font-size:1rem;font-weight:700;font-family:var(--font-mono)}.chart-empty{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:.85rem}.chart-tooltip{position:absolute;top:10px;right:12px;background:var(--bg);border:1px solid var(--border-hover);border-radius:6px;padding:4px 8px;font-size:.75rem;display:flex;gap:8px;box-shadow:0 4px 16px #0003;pointer-events:none}.topbar{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:0 2.5rem;height:56px;border-bottom:.5px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:10;margin-bottom:0}@media (max-width: 768px){.topbar{padding:0 1rem;gap:.75rem}}.topbar-logo{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.9rem;letter-spacing:-.02em;white-space:nowrap;flex-shrink:0}@media (max-width: 480px){.topbar-logo span{display:none}}.topbar-search{flex:1;max-width:480px;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;height:34px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:0 32px 0 36px;font-size:16px;font-family:var(--font-sans);color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s}.search-input::placeholder{color:var(--text-tertiary);font-size:.85rem}.search-input:focus{border-color:var(--border-hover);box-shadow:0 0 0 3px #80808014}.search-clear{position:absolute;right:8px;background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;padding:4px;border-radius:4px;transition:color .15s}.search-clear:hover{color:var(--text-primary)}.topbar-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.icon-btn{width:34px;height:34px;padding:0;display:flex;align-items:center;justify-content:center}.section{margin-bottom:3rem;padding-top:2.5rem}.section-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);font-weight:500;margin-bottom:16px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}@media (max-width: 768px){.grid{grid-template-columns:1fr;gap:1rem}}.card{background:var(--bg);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;transition:border-color .2s;min-width:0}.card:hover{border-color:var(--border-hover)}.vm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.vm-name{font-weight:500;font-size:1rem}.stat-row{display:flex;flex-direction:column;gap:.75rem}.stat-item{display:flex;align-items:center;gap:1rem}.stat-label{font-size:.75rem;color:var(--text-secondary);width:40px}.bar-track{flex:1;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.bar-fill{height:100%;background:var(--green);transition:width .4s ease,background-color .2s}.bar-fill.warn{background:var(--amber)}.bar-fill.danger{background:var(--red)}.stat-val{font-size:.75rem;color:var(--text-primary);width:36px;text-align:right;font-variant-numeric:tabular-nums}.proj-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.proj-name{font-weight:500;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-sub{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.proj-vm{font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono)}.proj-card-compact{display:flex;flex-direction:column;min-height:200px;transition:transform .15s}.proj-card-compact:hover{border-color:var(--border-hover)}.proc-pills{display:flex;flex-wrap:wrap;gap:6px;flex:1;align-content:flex-start}.proc-pill{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:.78rem;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border);white-space:nowrap}.proc-pill-online{border-color:#1d9e7540;background:#1d9e750f;color:#1d9e75}.proc-pill-stopped,.proc-pill-errored{border-color:#e24b4a33;background:#e24b4a0d;color:var(--red)}.proc-pill-offline{border-color:var(--border);background:var(--bg-secondary);color:var(--text-tertiary)}.proc-pill-more{border-style:dashed;color:var(--text-secondary)}.proc-pill-name{max-width:100px;overflow:hidden;text-overflow:ellipsis}.proj-card-hint{margin-top:auto;padding-top:.75rem;font-size:.75rem;color:var(--text-tertiary);text-align:right;transition:color .15s}.proj-card-compact:hover .proj-card-hint{color:var(--text-secondary)}.proc-list{display:flex;flex-direction:column;gap:.75rem}.proc-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.proc-name{display:flex;align-items:center;gap:6px;font-size:.9rem;font-weight:500;flex:1;min-width:0}.proc-name-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.autostart-icon{font-size:.85rem;flex-shrink:0;opacity:.8;cursor:default}.autostart-badge{font-size:.7rem;font-weight:500;padding:2px 6px;border-radius:99px;background:#ffc8001a;color:#c89b0a;border:1px solid rgba(255,200,0,.2);letter-spacing:.02em;white-space:nowrap;flex-shrink:0}.proc-actions{display:flex;gap:.25rem}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-tertiary)}.status-dot.online{background:var(--green);box-shadow:0 0 8px var(--green-bg)}.status-dot.offline{background:var(--text-tertiary)}.status-dot.errored{background:var(--red);box-shadow:0 0 8px var(--red-bg)}.status-dot.stopped{background:var(--red)}.badge{font-size:11px;padding:3px 8px;border-radius:var(--radius-md);font-weight:500}.badge.online{background:var(--green-bg);color:var(--green)}.badge.offline{background:var(--bg-tertiary);color:var(--text-secondary)}.badge.errored,.badge.stopped{background:var(--red-bg);color:var(--red)}.btn{font-size:11px;padding:4px 10px;min-height:36px;border-radius:6px;border:.5px solid var(--border);background:var(--bg);color:var(--text-primary);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:4px}.btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.danger{color:var(--red)}.btn.danger:hover:not(:disabled){background:var(--red-bg);border-color:#e24b4a4d}@media (max-width: 768px){.btn{min-height:44px;padding:6px 12px;font-size:12px}}.log-overlay-wrapper{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:50;padding:2rem}@media (max-width: 768px){.log-overlay-wrapper{padding:0}}.log-overlay{background:#161616b3;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);width:100%;max-width:900px;height:80vh;display:flex;flex-direction:column;box-shadow:0 30px 60px #00000080,inset 0 1px #ffffff0d;overflow:hidden}@media (max-width: 768px){.log-overlay{height:100vh;border-radius:0;max-width:none}}.log-header{padding:1rem 1.5rem;border-bottom:.5px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary)}.log-title{font-weight:500;display:flex;align-items:center;gap:.5rem}.log-title-sub{color:var(--text-secondary);font-family:var(--font-mono);font-size:.875rem}.log-body-wrap{flex:1;display:flex;flex-direction:column;min-height:0}.log-body-toolbar{display:flex;align-items:center;justify-content:flex-end;padding:.4rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.log-body{flex:1;padding:1rem 1.5rem;font-family:var(--font-mono);font-size:13px;line-height:1.6;color:var(--text-primary);background:var(--bg);overflow-y:auto}.btn-danger-ghost{color:var(--danger, #f87171);background:transparent;border:1px solid var(--danger, #f87171);opacity:.8}.btn-danger-ghost:hover{background:#f871711f;opacity:1}.btn-sm{padding:.25rem .6rem;font-size:.78rem;gap:.3rem}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000073;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:confirm-fade-in .15s ease}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}.confirm-modal{background:var(--bg);border:.5px solid var(--border-hover);border-radius:var(--radius-lg);padding:1.75rem 1.75rem 1.5rem;width:100%;max-width:340px;display:flex;flex-direction:column;gap:1rem;box-shadow:0 16px 48px #00000059;animation:confirm-slide-up .15s ease}@keyframes confirm-slide-up{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:var(--red-bg);color:var(--red);flex-shrink:0}.confirm-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin-top:-.25rem}.confirm-message{font-size:.875rem;color:var(--text-secondary);line-height:1.55}.confirm-message strong{color:var(--text-primary);font-weight:600}.confirm-icon-warn{background:var(--amber-bg);color:var(--amber)}.confirm-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.25rem}.confirm-cancel{background:var(--bg-secondary);border-color:var(--border);color:var(--text-secondary);font-size:.85rem;padding:.45rem 1rem}.confirm-cancel:hover{border-color:var(--border-hover)}.confirm-ok{background:var(--red);border-color:var(--red);color:#fff;font-size:.85rem;font-weight:600;padding:.45rem 1.1rem}.confirm-ok:hover{opacity:.85}.log-line{word-break:break-all;white-space:pre-wrap}.log-line.err{color:var(--red)}.log-line.warn{color:var(--amber)}.log-line.ok{color:var(--green)}.log-time{color:var(--text-tertiary);margin-right:12px;-webkit-user-select:none;user-select:none}.log-line.highlight-action{color:var(--amber);background:var(--amber-bg);font-weight:500;display:inline-block;padding:0 4px;border-radius:4px;margin:2px 0}.log-line.highlight-action-stop{color:var(--red);background:var(--red-bg);font-weight:500;display:inline-block;padding:0 4px;border-radius:4px;margin:2px 0}.log-line.highlight-action-start{color:var(--green);background:var(--green-bg);font-weight:500;display:inline-block;padding:0 4px;border-radius:4px;margin:2px 0}.toast-container{position:fixed;bottom:2rem;right:2rem;display:flex;flex-direction:column;gap:.75rem;z-index:100;pointer-events:none}@media (max-width: 480px){.toast-container{bottom:1rem;right:1rem;left:1rem}}.toast{pointer-events:auto;display:flex;align-items:center;gap:.75rem;background:var(--bg);color:var(--text-primary);padding:1rem 1.25rem;border-radius:var(--radius-md);box-shadow:0 8px 30px #0000001f;border:1px solid var(--border);min-width:320px;max-width:400px;animation:toast-slide-in .3s cubic-bezier(.2,.8,.2,1) forwards}@media (max-width: 480px){.toast{min-width:0;width:100%}}.toast-success{border-left:3px solid var(--green)}.toast-success .toast-icon{color:var(--green)}.toast-error{border-left:3px solid var(--red)}.toast-error .toast-icon{color:var(--red)}.toast-msg{flex:1;font-size:.875rem;font-weight:500;line-height:1.4}.toast-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;padding:4px;transition:color .15s}.toast-close:hover{color:var(--text-primary)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(110%) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.detail-tabs{display:flex;gap:4px;border-bottom:.5px solid var(--border);margin-bottom:0}.detail-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-tertiary);font-size:.85rem;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px;white-space:nowrap}.detail-tab:hover{color:var(--text-primary)}.detail-tab.active{color:var(--text-primary);border-bottom-color:var(--text-primary)}.detail-tab-sub{font-family:var(--font-mono);font-size:.72rem;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;padding:1px 6px;margin-left:4px}.inline-log-wrap{background:var(--bg);border:.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;height:calc(100vh - 320px);min-height:400px}.inline-log-proc-tabs{display:flex;gap:0;background:var(--bg-secondary);border-bottom:.5px solid var(--border);overflow-x:auto;flex-shrink:0}.inline-log-proc-tab{padding:8px 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-tertiary);font-size:.8rem;font-family:var(--font-mono);font-weight:500;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;margin-bottom:-1px}.inline-log-proc-tab:hover{color:var(--text-primary)}.inline-log-proc-tab.active{color:var(--text-primary);border-bottom-color:var(--text-primary);background:var(--bg)}.inline-log-wrap .log-body{flex:1;overflow-y:auto;background:var(--bg)}.vm-sparklines-card{margin-bottom:2rem}.vm-sparklines-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.sparkline-chart-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:500;margin-bottom:.5rem}@media (max-width: 640px){.vm-sparklines-card{display:none}}.proc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.5rem}@media (max-width: 640px){.proc-card-header{flex-wrap:wrap}}.proc-actions-wrap{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0}@media (max-width: 640px){.proc-actions-wrap{width:100%;justify-content:stretch}.proc-actions-wrap .btn{flex:1}}.proc-stats-grid{display:flex;gap:2.5rem;flex-wrap:wrap}@media (max-width: 640px){.proc-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}}.vm-metrics-grid{display:flex;gap:3rem;flex-wrap:wrap}@media (max-width: 640px){.vm-metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}}.profile-wrap{position:relative}.profile-avatar{width:34px;height:34px;border-radius:50%;background:var(--text-primary);color:var(--bg);font-size:.8rem;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;flex-shrink:0}.profile-avatar:hover{opacity:.8}.profile-avatar--ro{background:var(--amber);color:#fff}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:210px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;z-index:100;overflow:hidden;animation:ddFadeIn .12s ease}@keyframes ddFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.profile-dd-header{display:flex;align-items:center;gap:.75rem;padding:14px 16px}.profile-dd-avatar{width:36px;height:36px;border-radius:50%;background:var(--text-primary);color:var(--bg);font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-dd-name{font-weight:600;font-size:.9rem;color:var(--text-primary)}.profile-dd-role{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.profile-dd-role--ro{color:var(--amber);font-weight:600}.profile-dd-divider{height:1px;background:var(--border);margin:0}.profile-dd-logout{width:100%;padding:11px 16px;background:none;border:none;text-align:left;font-size:.875rem;color:var(--red);cursor:pointer;font-family:var(--font-sans);transition:background .12s}.profile-dd-logout:hover{background:var(--red-bg)}.vpn-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.vpn-modal{background:var(--bg);border:.5px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:88vh;overflow-y:auto;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column}.vpn-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .75rem;border-bottom:.5px solid var(--border);flex-shrink:0}.vpn-modal-title{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;color:var(--text-primary)}.vpn-modal-close{background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:4px;border-radius:6px;display:flex;transition:color .15s}.vpn-modal-close:hover{color:var(--text-primary)}.vpn-back-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.82rem;padding:0;transition:color .15s}.vpn-back-btn:hover{color:var(--text-primary)}.vpn-step{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.vpn-hint{font-size:.82rem;color:var(--text-secondary);line-height:1.55}.vpn-url-input{width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);font-size:.8rem;padding:.75rem;resize:vertical;outline:none;transition:border-color .15s;line-height:1.6}.vpn-url-input:focus{border-color:var(--border-hover)}.vpn-examples{display:flex;flex-direction:column;gap:.3rem;font-size:.75rem}.vpn-example-label{color:var(--text-tertiary);font-weight:600}.vpn-examples code{font-family:var(--font-mono);font-size:.72rem;color:var(--text-secondary);background:var(--bg-tertiary);padding:2px 8px;border-radius:4px}.vpn-error{font-size:.8rem;color:var(--red);background:var(--red-bg);border-radius:var(--radius-md);padding:.5rem .75rem}.vpn-server-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;max-height:320px;overflow-y:auto}@media (max-width: 480px){.vpn-server-grid{grid-template-columns:1fr 1fr}}.vpn-server-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:4px;background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:.75rem;cursor:pointer;text-align:left;transition:border-color .15s,background .15s,transform .1s}.vpn-server-card:hover{border-color:var(--border-hover);background:var(--bg-tertiary);transform:translateY(-1px)}.vpn-server-card.selected{border-color:var(--green);background:#1d9e750d}.vpn-server-flag{font-size:1.35rem;line-height:1}.vpn-server-name{font-size:.75rem;font-weight:700;color:var(--text-primary);word-break:break-word;line-height:1.3}.vpn-server-proto{font-size:.65rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.vpn-server-addr{font-size:.65rem;font-family:var(--font-mono);color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.vpn-server-check{position:absolute;top:6px;right:8px;font-size:.75rem;color:var(--green);font-weight:800}.vpn-log{background:var(--bg-secondary);border:.5px solid var(--border);border-radius:var(--radius-md);padding:.75rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;max-height:280px;overflow-y:auto;line-height:1.6}.vpn-result-badge{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:600}.vpn-result-ok{background:#1d9e7514;border:1px solid rgba(29,158,117,.3);color:var(--green)}.vpn-result-err{background:var(--red-bg);border:1px solid rgba(226,75,74,.3);color:var(--red)}.vpn-step-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.25rem}.vpn-primary-btn{background:var(--text-primary)!important;color:var(--bg)!important;border-color:var(--text-primary)!important;display:inline-flex;align-items:center;gap:.4rem}.vpn-primary-btn:hover{opacity:.85}.vpn-primary-btn:disabled{opacity:.4;cursor:not-allowed}.vpn-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:99px;white-space:nowrap}.vpn-flag{font-size:14px;line-height:1;display:inline-block}.vpn-status-badge.vpn-on{background:#1d9e751a;color:var(--green);border:1px solid rgba(29,158,117,.25)}.vpn-status-badge.vpn-off{background:var(--bg-tertiary);color:var(--text-tertiary);border:1px solid var(--border)}.vpn-detail-btn{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem}.vpn-sudo-info{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem 1rem;background:#ef9f2714;border:1px solid rgba(239,159,39,.3);border-radius:var(--radius-md);font-size:.82rem;color:var(--amber);line-height:1.5;flex-shrink:0}.vpn-sudo-info code{font-family:var(--font-mono);font-size:.78rem;background:#ef9f2726;padding:1px 5px;border-radius:3px}.vpn-sudo-input{width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);font-size:.9rem;padding:.7rem .9rem;outline:none;letter-spacing:.1em;transition:border-color .15s}.vpn-sudo-input:focus{border-color:var(--amber)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite;display:inline-block}.speedtest-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.speedtest-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0000004d;max-width:400px;width:90%;overflow:hidden}.speedtest-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.speedtest-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.speedtest-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.speedtest-close:hover{background-color:#ffffff1a;color:var(--text-primary)}.speedtest-body{padding:2rem 1.5rem;min-height:150px;display:flex;align-items:center;justify-content:center}.speedtest-loading{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}.speedtest-results{width:100%;display:flex;flex-direction:column;gap:1.5rem}.speedtest-result-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border-radius:8px;border-left:3px solid var(--blue)}.speedtest-label{color:var(--text-secondary);font-size:.9rem}.speedtest-value{color:var(--blue);font-size:1.3rem;font-weight:700;font-family:var(--font-mono)}.speedtest-error{text-align:center;color:var(--red);padding:1rem}.speedtest-footer{display:flex;gap:.5rem;padding:1.5rem;border-top:1px solid var(--border-color)}.speedtest-footer .btn{flex:1}@property --lg-angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}:root{--accent: #1D9E75;--accent-light: #1D9E75;--accent-mid: #1D9E75;--accent-rgb: 29, 158, 117;--neon-1: #15b882;--neon-2: #34c99a;--neon-3: #6edbb8;--nav-frost-bg: rgba(255, 255, 255, .68);--nav-frost-border: rgba(0, 0, 0, .08);--nav-frost-shadow: 0 14px 40px rgba(0,0,0,.14), inset 0 1px 0 rgba(255,255,255,.8);--nav-pill-face: rgba(255, 255, 255, .88);--nav-label-idle: #8A8A9A;--nav-label-active: var(--accent)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--accent: #1D9E75;--accent-light: #34c99a;--accent-mid: #1D9E75;--accent-rgb: 29, 158, 117;--neon-1: #15b882;--neon-2: #34c99a;--neon-3: #6edbb8;--nav-frost-bg: rgba(18, 18, 22, .72);--nav-frost-border: rgba(255, 255, 255, .1);--nav-frost-shadow: 0 14px 40px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.07);--nav-pill-face: rgba(22, 22, 32, .88);--nav-label-idle: #6B6A85;--nav-label-active: var(--accent-light)}}[data-theme=dark]{--accent: #1D9E75;--accent-light: #34c99a;--accent-mid: #1D9E75;--accent-rgb: 29, 158, 117;--neon-1: #15b882;--neon-2: #34c99a;--neon-3: #6edbb8;--nav-frost-bg: rgba(18, 18, 22, .72);--nav-frost-border: rgba(255, 255, 255, .1);--nav-frost-shadow: 0 14px 40px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.07);--nav-pill-face: rgba(22, 22, 32, .88);--nav-label-idle: #6B6A85;--nav-label-active: var(--accent-light)}[data-theme=light]{--accent: #1D9E75;--accent-light: #1D9E75;--accent-mid: #1D9E75;--accent-rgb: 29, 158, 117;--neon-1: #15b882;--neon-2: #34c99a;--neon-3: #6edbb8;--nav-frost-bg: rgba(255, 255, 255, .68);--nav-frost-border: rgba(0, 0, 0, .08);--nav-frost-shadow: 0 14px 40px rgba(0,0,0,.14), inset 0 1px 0 rgba(255,255,255,.8);--nav-pill-face: rgba(255, 255, 255, .88);--nav-label-idle: #8A8A9A;--nav-label-active: var(--accent)}.lg-nav{position:fixed;left:0;right:0;bottom:0;z-index:50;padding:0 .7rem calc(1.4rem + env(safe-area-inset-bottom,0px));pointer-events:none}@media (min-width: 961px){.lg-nav{display:none}}.lg-nav-bar{pointer-events:auto;position:relative;border-radius:28px;background:var(--nav-frost-bg);-webkit-backdrop-filter:blur(22px) saturate(140%);backdrop-filter:blur(22px) saturate(140%);border:1px solid var(--nav-frost-border);box-shadow:var(--nav-frost-shadow);overflow:hidden}.lg-nav-scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-x;scrollbar-width:none;scroll-behavior:smooth}.lg-nav-scroll::-webkit-scrollbar{display:none}.lg-nav-track{position:relative;display:flex;align-items:stretch;min-width:100%;padding:7px;gap:2px}.lg-nav-pill{position:absolute;top:0;left:0;width:0;height:0;border-radius:20px;z-index:0;pointer-events:none;opacity:0;background:conic-gradient(from var(--lg-angle),rgba(var(--accent-rgb),.18) 0deg,rgba(var(--accent-rgb),.18) 200deg,var(--neon-1) 270deg,var(--neon-3) 320deg,var(--neon-2) 345deg,rgba(var(--accent-rgb),.18) 360deg);animation:lg-pill-spin 2.6s linear infinite;transition:transform .45s cubic-bezier(.34,1.28,.4,1),width .45s cubic-bezier(.34,1.28,.4,1),height .45s cubic-bezier(.34,1.28,.4,1),opacity .25s ease;box-shadow:0 0 18px -2px rgba(var(--accent-rgb),.5)}.lg-nav-pill.is-ready{opacity:1}.lg-nav-pill:after{content:"";position:absolute;top:1.8px;right:1.8px;bottom:1.8px;left:1.8px;border-radius:18.2px;background:var(--nav-pill-face);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes lg-pill-spin{to{--lg-angle: 360deg}}.lg-nav-tab{position:relative;z-index:1;flex:1 0 auto;min-width:66px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 14px;background:none;border:none;cursor:pointer;color:var(--nav-label-idle);-webkit-tap-highlight-color:transparent;transition:color .3s ease;font-family:inherit}.lg-nav-tab.is-active{color:var(--nav-label-active)}.lg-nav-tab svg{display:block}.lg-nav-icon{display:flex;transform-origin:center}.lg-nav-label{font-size:10px;font-weight:700;line-height:1;white-space:nowrap;letter-spacing:.2px}.lg-nav-icon.anim-home{animation:ic-home .6s ease both}.lg-nav-icon.anim-vms{animation:ic-bounce .6s ease both}.lg-nav-icon.anim-stats{animation:ic-bars .6s ease both}.lg-nav-icon.anim-profile{animation:ic-twirl .6s ease both}@keyframes ic-home{0%{transform:translateY(0) scale(1)}30%{transform:translateY(-4px) scale(1.08)}55%{transform:translateY(1px) scale(.96)}75%{transform:translateY(-1px) scale(1.02)}to{transform:translateY(0) scale(1)}}@keyframes ic-bounce{0%{transform:scale(1)}30%{transform:scale(1.18)}55%{transform:scale(.92)}75%{transform:scale(1.06)}to{transform:scale(1)}}@keyframes ic-bars{0%{transform:scaleY(.55);transform-origin:bottom}45%{transform:scaleY(1.12);transform-origin:bottom}70%{transform:scaleY(.94);transform-origin:bottom}to{transform:scaleY(1);transform-origin:bottom}}@keyframes ic-twirl{0%{transform:rotateY(0) scale(1)}50%{transform:rotateY(180deg) scale(1.1)}to{transform:rotateY(360deg) scale(1)}}@media (max-width: 960px){.app-main{padding-bottom:calc(90px + env(safe-area-inset-bottom,0px))}.filter-sidebar,.topbar-theme-btn,.topbar-profile-wrap{display:none}.topbar-search{flex:1;max-width:unset;min-width:0}.topbar{padding:0 1rem;height:52px}.topbar-logo{font-size:.8rem}.app-body{padding:0 .75rem}.section{padding-top:1.5rem;margin-bottom:1.5rem}.toast-container{bottom:calc(90px + env(safe-area-inset-bottom,0px) + .5rem);right:.75rem;left:.75rem}}
