:root{--bg:#2f343f;--fg:#eff0eb;--surface:#444a57;--surface2:#3a3f4b;--green:#94daa9;--red:#de8990;--yellow:#dee7aa;--blue:#9cdbdf;--muted:#9a9fa8;--border:#eff0eb1a}*{box-sizing:border-box}body{background:var(--bg);color:var(--fg);font-family:var(--font-sans,system-ui, -apple-system, sans-serif);min-height:100vh;margin:0;padding:0}.topbar{background:var(--surface2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.logo{letter-spacing:.5px;align-items:center;gap:8px;font-size:15px;font-weight:500;display:flex}.logo-dot{background:var(--green);border-radius:50%;width:8px;height:8px}.topbar-right{color:var(--muted);align-items:center;gap:6px;font-size:12px;display:flex}.content{max-width:960px;margin:0 auto;padding:24px}.section-label{color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:12px;font-size:11px}.stats-row{gap:10px;margin-bottom:20px;display:flex}.stat{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex:1;padding:12px 16px}.stat-val{font-size:22px;font-weight:500}.stat-label{color:var(--muted);margin-top:2px;font-size:11px}.content-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.search-bar{background:var(--surface);border:1px solid var(--border);min-width:200px;color:var(--muted);border-radius:8px;align-items:center;gap:8px;padding:8px 14px;display:flex}.search-bar input{color:var(--fg);background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:13px}.search-bar input::placeholder{color:var(--muted)}.services-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width<=640px){.services-grid{grid-template-columns:1fr}.stats-row{flex-direction:column}}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px 18px;transition:border-color .15s}.card:hover{border-color:#eff0eb2e}.card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.service-name{font-size:14px;font-weight:500}.badge{border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:500;display:inline-flex}.badge-running{color:var(--green);background:#94daa926}.badge-stopped{color:var(--red);background:#de899026}.badge-deploying{color:var(--blue);background:#9cdbdf26}.card--deploying{border-color:#9cdbdf40;animation:2s ease-in-out infinite deploy-pulse}@keyframes deploy-pulse{0%,to{border-color:#9cdbdf26}50%{border-color:#9cdbdf66}}.meta{color:var(--muted);align-items:center;gap:14px;margin-bottom:12px;font-size:11px;display:flex}.meta-item{align-items:center;gap:4px;display:flex}.actions{flex-wrap:wrap;gap:6px;display:flex}.btn{border:1px solid var(--border);color:var(--fg);cursor:pointer;background:#eff0eb0d;border-radius:6px;align-items:center;gap:5px;padding:5px 12px;font-family:inherit;font-size:11px;transition:background .15s;display:inline-flex}.btn:hover{background:#eff0eb1f}.btn-start{color:var(--green);background:#94daa912;border-color:#94daa966}.btn-start:hover{background:#94daa926}.btn-stop{color:var(--red);background:#de899012;border-color:#de899066}.btn-stop:hover{background:#de899026}.btn-restart{color:var(--yellow);background:#dee7aa0f;border-color:#dee7aa59}.btn-restart:hover{background:#dee7aa24}.btn-deploy{color:var(--blue);background:#9cdbdf12;border-color:#9cdbdf66}.btn-deploy:hover{background:#9cdbdf26}.btn-edit{color:var(--blue);background:#9cdbdf12;border-color:#9cdbdf4d}.btn-edit:hover{background:#9cdbdf26}.btn-delete{color:var(--red);background:#de899012;border-color:#de899066}.btn-delete:hover{background:#de899026}.badge-type{letter-spacing:.3px;text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:500}.badge-type--managed{color:var(--blue);background:#9cdbdf1f}.badge-type--unmanaged{color:var(--muted);background:#9a9fa81f}.btn:disabled{opacity:.4;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}.error-banner{color:var(--red);background:#de89901a;border:1px solid #de89904d;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:12px;display:flex}.app-layout{min-height:100vh;display:flex}.app-main{flex:1;min-width:0}.sidebar{background:var(--surface2);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:200px;min-height:100vh;padding:16px 0;display:flex}.sidebar-logo{letter-spacing:.5px;border-bottom:1px solid var(--border);margin-bottom:12px;padding:0 20px 20px;font-size:15px;font-weight:600}.sidebar-nav{flex-direction:column;gap:2px;padding:0 8px;display:flex}.sidebar-item{color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:9px 14px;font-family:inherit;font-size:13px;transition:background .12s,color .12s;display:flex}.sidebar-item:hover{color:var(--fg);background:#eff0eb0f}.sidebar-item--active{color:var(--blue);background:#9cdbdf1a}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:12px 8px 4px}.sidebar-user{color:var(--muted);align-items:center;gap:8px;padding:8px 14px;font-size:12px;display:flex}.sidebar-username{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sidebar-logout{opacity:.7;width:100%;color:var(--red)!important}.sidebar-logout:hover{opacity:1}.modal-overlay{z-index:100;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:440px;max-width:90vw;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-title{margin:0;font-size:15px;font-weight:600}.modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.modal-close:hover{color:var(--fg);background:#eff0eb14}.modal-body{flex-direction:column;gap:16px;padding:20px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:16px 20px;display:flex}.modal-alert{border-radius:6px;margin:16px 20px 0;padding:10px 14px;font-size:12px}.modal-alert--error{color:var(--red);background:#de89901a;border:1px solid #de899040}.modal-alert--success{color:var(--green);background:#94daa91a;border:1px solid #94daa940}.form-label{color:var(--muted);letter-spacing:.3px;flex-direction:column;gap:6px;font-size:12px;display:flex}.form-input{color:var(--fg);background:#0003;border:1px solid #eff0eb1a;border-radius:6px;outline:none;padding:10px 14px;font-family:inherit;font-size:13px;transition:border-color .15s}.form-input:focus{border-color:var(--blue)}.form-input:disabled{opacity:.5}.btn-add-service{color:var(--blue);cursor:pointer;background:#9cdbdf14;border:1px solid #9cdbdf4d;border-radius:6px;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:12px;transition:background .15s;display:inline-flex}.btn-add-service:hover{background:#9cdbdf29}.placeholder-page{color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;display:flex}.placeholder-page h2{color:var(--fg);margin:0;font-size:18px;font-weight:500}.placeholder-page p{margin:0;font-size:13px}@media (width<=768px){.sidebar{width:56px}.sidebar-logo,.sidebar-item span{display:none}.sidebar-item{justify-content:center;padding:10px}}.swal2-custom-popup{border:1px solid var(--border)!important;border-radius:12px!important;padding:24px!important;box-shadow:0 20px 40px #0006!important}.swal2-title{font-family:inherit!important;font-size:20px!important;font-weight:600!important}.swal2-html-container{color:var(--muted)!important;margin-top:12px!important;font-family:inherit!important;font-size:14px!important}.swal2-actions{gap:12px!important;margin-top:24px!important}.swal2-styled{letter-spacing:.3px!important;border-radius:8px!important;padding:10px 24px!important;font-size:13px!important;font-weight:600!important;transition:all .2s!important}.swal2-confirm{box-shadow:none!important}.swal2-cancel{border:1px solid var(--border)!important;color:var(--muted)!important;background:#ffffff0d!important}.swal2-cancel:hover{color:var(--fg)!important;background:#ffffff1a!important}.swal2-icon{margin-bottom:12px!important}.billing-table{border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:10px;width:100%;font-size:13px;overflow:hidden}.billing-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;background:var(--surface2);border-bottom:1px solid var(--border);padding:12px 16px;font-size:11px;font-weight:600}.billing-table td{border-bottom:1px solid var(--border);padding:10px 16px}.billing-table tr:last-child td{border-bottom:none}.billing-table tr:hover td{background:#eff0eb08}
