@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";
:root{--bg-primary:#0a0a12;--bg-secondary:#12121f;--bg-card:#14142899;--bg-glass:#ffffff08;--border-glass:#ffffff14;--text-primary:#e8e8f0;--text-secondary:#8888a8;--text-muted:#555570;--accent-1:#7c3aed;--accent-2:#06b6d4;--accent-gradient:linear-gradient(135deg, #7c3aed 0%, #06b6d4 100%);--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--radius:12px;--radius-lg:16px;--shadow:0 8px 32px #0006;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,sans-serif;overflow-x:hidden}body:before{content:"";z-index:-1;background:radial-gradient(at 20%,#7c3aed14 0%,#0000 50%),radial-gradient(at 80% 20%,#06b6d40f 0%,#0000 50%),radial-gradient(at 50% 80%,#7c3aed0a 0%,#0000 50%);width:200%;height:200%;animation:20s ease-in-out infinite bgFloat;position:fixed;top:-50%;left:-50%}@keyframes bgFloat{0%,to{transform:translate(0)rotate(0)}33%{transform:translate(2%,-2%)rotate(1deg)}66%{transform:translate(-1%,1%)rotate(-1deg)}}.glass{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.navbar{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-glass);background:#0a0a12cc;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:fixed;top:0;left:0;right:0}.navbar-brand{color:var(--text-primary);align-items:center;gap:10px;font-size:1.2rem;font-weight:800;text-decoration:none;display:flex}.navbar-brand span{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.navbar-links{align-items:center;gap:8px;display:flex}.nav-link{color:var(--text-secondary);transition:var(--transition);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 16px;font-size:.875rem;font-weight:500;text-decoration:none}.nav-link:hover,.nav-link.active{color:var(--text-primary);background:var(--bg-glass)}.nav-link.danger:hover{color:var(--danger)}.main-content{max-width:1200px;margin:0 auto;padding:96px 2rem 2rem}.page-header{margin-bottom:2rem}.page-title{margin-bottom:.5rem;font-size:2rem;font-weight:800}.page-title span{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.page-subtitle{color:var(--text-secondary);font-size:.95rem}.btn{cursor:pointer;transition:var(--transition);border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 16px #7c3aed4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px #7c3aed66}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-glass)}.btn-secondary:hover{background:#ffffff14;border-color:#ffffff26}.btn-danger{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.btn-danger:hover{background:#ef444433}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-icon{border-radius:8px;padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-group{margin-bottom:1.25rem}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.form-input,.form-select{background:var(--bg-glass);border:1px solid var(--border-glass);width:100%;color:var(--text-primary);transition:var(--transition);border-radius:10px;outline:none;padding:12px 16px;font-family:Inter,sans-serif;font-size:.95rem}.form-input:focus,.form-select:focus{border-color:var(--accent-1);box-shadow:0 0 0 3px #7c3aed26}.form-input::placeholder{color:var(--text-muted)}.input-with-suffix{align-items:center;gap:0;display:flex}.input-with-suffix .form-input{border-right:none;border-radius:10px 0 0 10px}.input-suffix{border:1px solid var(--border-glass);color:var(--text-secondary);white-space:nowrap;background:#7c3aed1a;border-left:none;border-radius:0 10px 10px 0;padding:12px 16px;font-size:.85rem}.apps-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem;display:grid}.app-card{transition:var(--transition);padding:1.5rem;position:relative;overflow:hidden}.app-card:before{content:"";background:var(--accent-gradient);opacity:0;height:3px;transition:var(--transition);position:absolute;top:0;left:0;right:0}.app-card:hover{border-color:#7c3aed4d;transform:translateY(-4px);box-shadow:0 12px 40px #00000080}.app-card:hover:before{opacity:1}.app-card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.app-name{font-size:1.1rem;font-weight:700}.app-domain{color:var(--accent-2);margin-top:4px;font-size:.85rem;text-decoration:none;display:block}.app-domain:hover{text-decoration:underline}.app-meta{border-top:1px solid var(--border-glass);flex-wrap:wrap;gap:12px;margin-top:1rem;padding-top:1rem;display:flex}.app-meta-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;display:flex}.app-actions{gap:6px;margin-top:1rem;display:flex}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-online{color:var(--success);background:#10b9811a;border:1px solid #10b98133}.badge-offline{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.badge-deploying{color:var(--warning);background:#f59e0b1a;border:1px solid #f59e0b33}.badge-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.badge-online .badge-dot{animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.upload-zone{border:2px dashed var(--border-glass);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:var(--transition);background:var(--bg-glass);padding:3rem;position:relative}.upload-zone:hover,.upload-zone.dragging{border-color:var(--accent-1);background:#7c3aed0d}.upload-zone.has-file{border-color:var(--success);background:#10b9810d}.upload-icon{margin-bottom:1rem;font-size:3rem}.upload-text{color:var(--text-secondary);font-size:.95rem}.upload-text strong{color:var(--accent-2)}.upload-filename{color:var(--success);background:#10b9811a;border-radius:8px;margin-top:.75rem;padding:8px 16px;font-size:.9rem;font-weight:600;display:inline-block}.deploy-steps{margin-top:2rem}.deploy-step{transition:var(--transition);border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:12px 16px;display:flex}.deploy-step.active{background:var(--bg-glass)}.step-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;display:flex}.step-icon.pending{background:var(--bg-glass);border:1px solid var(--border-glass);color:var(--text-muted)}.step-icon.running{border:1px solid var(--accent-1);color:var(--accent-1);background:#7c3aed26;animation:1.5s linear infinite spinIcon}@keyframes spinIcon{to{transform:rotate(360deg)}}.step-icon.done{color:var(--success);background:#10b98126}.step-icon.error{color:var(--danger);background:#ef444426}.step-text{color:var(--text-secondary);font-size:.9rem}.step-text.active{color:var(--text-primary);font-weight:500}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-card{width:100%;max-width:420px;padding:2.5rem}.login-logo{text-align:center;margin-bottom:2rem}.login-logo h1{font-size:1.8rem;font-weight:800}.login-logo p{color:var(--text-secondary);margin-top:6px;font-size:.9rem}.login-error{color:var(--danger);background:#ef44441a;border:1px solid #ef444433;border-radius:10px;margin-bottom:1rem;padding:10px 16px;font-size:.85rem}.table-container{border-radius:var(--radius-lg);overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-bottom:1px solid var(--border-glass);padding:12px 16px;font-size:.75rem;font-weight:700}.data-table td{border-bottom:1px solid var(--border-glass);padding:14px 16px;font-size:.9rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-glass)}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;padding:2rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{width:100%;max-width:500px;padding:2rem;animation:.3s slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-title{font-size:1.2rem;font-weight:700}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-actions{justify-content:flex-end;gap:8px;margin-top:1.5rem;display:flex}.logs-container{border-radius:var(--radius);max-height:400px;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;background:#0d0d16;padding:1rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.8rem;line-height:1.6;overflow-y:auto}.empty-state{text-align:center;padding:4rem 2rem}.empty-state-icon{opacity:.3;margin-bottom:1rem;font-size:4rem}.empty-state h3{color:var(--text-secondary);margin-bottom:.5rem;font-size:1.2rem}.empty-state p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.tag{color:var(--accent-1);background:#7c3aed1a;border:1px solid #7c3aed33;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:.75rem;font-weight:500;display:inline-flex}.tags-list{flex-wrap:wrap;gap:4px;display:flex}.spinner{border:2px solid var(--border-glass);border-top:2px solid var(--accent-1);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spinIcon;display:inline-block}@media (max-width:768px){.main-content{padding:80px 1rem 1rem}.apps-grid{grid-template-columns:1fr}.navbar{padding:0 1rem}.page-title{font-size:1.5rem}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-glass);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}
