*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f1117;color:#e0e0e0;min-height:100vh}.app{max-width:1200px;margin:0 auto;padding:20px}header{display:flex;justify-content:space-between;align-items:center;padding:24px;margin-bottom:20px;background:linear-gradient(135deg,#667eea26,#764ba226);border:1px solid rgba(102,126,234,.3);border-radius:12px}header h1{font-size:1.8rem;background:linear-gradient(90deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:#888;font-size:.9rem;margin-top:4px}.header-stats{display:flex;gap:10px}.stat-pill{padding:6px 14px;border-radius:20px;font-size:.8rem;font-weight:600}.stat-pill.running{background:#2ecc7133;color:#2ecc71}.stat-pill.stopped{background:#e74c3c33;color:#e74c3c}.stat-pill.total{background:#667eea33;color:#667eea}.toast{padding:12px 20px;border-radius:8px;margin-bottom:15px;cursor:pointer;animation:slideIn .3s ease}.toast.error{background:#e74c3c33;border:1px solid rgba(231,76,60,.4);color:#e74c3c}.toast.success{background:#2ecc7133;border:1px solid rgba(46,204,113,.4);color:#2ecc71}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.tabs{display:flex;gap:4px;margin-bottom:20px;background:#ffffff0d;border-radius:10px;padding:4px}.tabs button{flex:1;padding:10px 20px;border:none;border-radius:8px;background:transparent;color:#888;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s}.tabs button.active{background:#667eea4d;color:#fff}.tabs button:hover:not(.active){color:#ccc}.panel{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px}.panel h2{margin-bottom:20px;color:#fff;font-size:1.3rem}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#aaa;font-size:.9rem;font-weight:500}.form-group textarea,.form-group input[type=text]{width:100%;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:#e0e0e0;font-family:Monaco,monospace;font-size:.85rem;resize:vertical}.form-group textarea:focus,.form-group input:focus{outline:none;border-color:#667eea}.file-input{display:block;padding:10px;border:2px dashed rgba(255,255,255,.2);border-radius:8px;width:100%;color:#aaa;cursor:pointer}.file-name{display:block;margin-top:6px;color:#667eea;font-size:.85rem}.template-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.template-card{padding:16px;border-radius:8px;cursor:pointer;border:2px solid rgba(255,255,255,.1);background:#0003;transition:all .2s;text-align:center}.template-card:hover{border-color:#667eea80}.template-card.selected{border-color:#667eea;background:#667eea26}.template-card strong{display:block;color:#fff;margin-bottom:4px}.template-card span{font-size:.8rem;color:#888}.btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s;text-decoration:none;display:inline-block;color:#fff;background:#ffffff1a;border:1px solid rgba(255,255,255,.15)}.btn:hover{background:#fff3;transform:translateY(-1px)}.btn-primary{background:linear-gradient(90deg,#667eea,#764ba2);border:none}.btn-primary:hover{box-shadow:0 4px 15px #667eea66}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-danger{background:#e74c3c4d;border-color:#e74c3c80}.btn-danger:hover{background:#e74c3c80}.btn-warning{background:#f39c124d;border-color:#f39c1280}.btn-warning:hover{background:#f39c1280}.btn-success{background:#2ecc714d;border-color:#2ecc7180}.btn-success:hover{background:#2ecc7180}.btn-lg{padding:12px 32px;font-size:1rem}.btn-sm{padding:6px 12px;font-size:.8rem}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:15px}.preview-card{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:16px;transition:all .2s}.preview-card:hover{border-color:#667eea66}.preview-card.running{border-left:3px solid #2ecc71}.preview-card.exited,.preview-card.stopped{border-left:3px solid #e74c3c}.card-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.running{background:#2ecc71;box-shadow:0 0 6px #2ecc7180}.status-dot.exited,.status-dot.stopped{background:#e74c3c}.preview-id{font-family:monospace;font-weight:700;color:#667eea;font-size:1.1rem}.template-badge{margin-left:auto;padding:2px 8px;border-radius:4px;font-size:.7rem;background:#667eea33;color:#667eea;text-transform:uppercase}.card-body{margin-bottom:12px}.info-row{display:flex;justify-content:space-between;padding:4px 0;font-size:.85rem}.info-row label{color:#888}.info-row a{color:#667eea;text-decoration:none;font-size:.8rem}.info-row a:hover{text-decoration:underline}.mono{font-family:monospace}.card-actions{display:flex;gap:6px;flex-wrap:wrap}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{padding:10px 12px;text-align:left;border-bottom:1px solid rgba(255,255,255,.08)}th{color:#888;font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}td{font-family:monospace}tr:hover{background:#ffffff08}td a{color:#667eea;text-decoration:none}td a:hover{text-decoration:underline}.empty-state{text-align:center;padding:40px;color:#666}.empty-state p{margin-bottom:15px}.login-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#0f1117}.login-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:48px;text-align:center;width:400px;max-width:90vw}.login-card h1{font-size:2rem;margin-bottom:8px;background:linear-gradient(90deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{color:#888;font-size:.9rem;margin-bottom:24px}.login-error{background:#e74c3c33;border:1px solid rgba(231,76,60,.4);color:#e74c3c;padding:10px;border-radius:8px;margin-bottom:16px;font-size:.9rem}.login-input{width:100%;padding:14px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:#e0e0e0;font-size:1rem;margin-bottom:16px;text-align:center}.login-input:focus{outline:none;border-color:#667eea}.login-btn{width:100%;margin-bottom:16px}.docs-link{color:#667eea;font-size:.85rem;text-decoration:none}.docs-link:hover{text-decoration:underline}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.header-actions{display:flex;gap:8px}.idle-warning{color:#f39c12!important;font-weight:600}.idle-danger{color:#e74c3c!important;font-weight:700;animation:pulse 1s infinite}.idle-info label{color:#f39c12}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){header{flex-direction:column;gap:15px;text-align:center}.header-right{align-items:center}.template-selector,.preview-grid{grid-template-columns:1fr}}.terminal{background:#1a1a2e;border:1px solid rgba(102,126,234,.3);border-radius:8px;overflow:hidden;margin-top:12px}.terminal-output{padding:12px;max-height:400px;overflow-y:auto;font-family:Monaco,Menlo,Courier New,monospace;font-size:.82rem;line-height:1.5;white-space:pre-wrap;word-break:break-all}.terminal-line{padding:1px 0}.terminal-line.cmd{color:#667eea;font-weight:700}.terminal-line.out{color:#e0e0e0}.terminal-line.err{color:#e74c3c}.terminal-line.exit{color:#888;font-style:italic}.terminal-line.input{color:#f39c12;font-style:italic}.terminal-line.stdin{color:#2ecc71}.terminal-line.running{color:#888;animation:pulse 1s infinite}.terminal-input-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border-top:1px solid rgba(255,255,255,.1);background:#0000004d}.terminal-prompt{color:#667eea;font-family:monospace;font-weight:700;font-size:.85rem}.terminal-input{flex:1;padding:8px;border:none;border-radius:4px;background:#0006;color:#e0e0e0;font-family:Monaco,Menlo,Courier New,monospace;font-size:.85rem}.terminal-input:focus{outline:none;background:#0009}.terminal-input:disabled{opacity:.5}.terminal-container{margin-top:12px}.computer-list{display:flex;flex-direction:column;gap:15px}.computer-card{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:16px;transition:all .2s}.computer-card:hover{border-color:#667eea66}.computer-card.running{border-left:3px solid #2ecc71}.computer-card.exited,.computer-card.stopped{border-left:3px solid #e74c3c}.template-badge.computer{background:#2ecc7133;color:#2ecc71}.panel-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.panel-header-row h2{margin-bottom:0}
