@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap";:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg:#02040a;--border-soft:#ffffff14;--border-strong:#ffffff40;--text-muted:#ffffffa6;font-family:Space Grotesk,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box;min-width:0}body{background:var(--bg);color:#f5f7ff;width:100%;min-height:100dvh;padding:env(safe-area-inset-top)env(safe-area-inset-right)env(safe-area-inset-bottom)env(safe-area-inset-left);margin:0}#root{width:100%;min-height:100dvh}button,input,textarea{font:inherit}.app-shell{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:radial-gradient(circle at 20% -10%,#709aff40,transparent 45%),radial-gradient(circle at 80% 0%,#ff6f9e4d,transparent 50%),var(--bg,#02040a);color:#f5f7ff;grid-template-columns:240px 1fr;width:100%;min-height:100vh;display:grid;overflow-x:hidden}h1,h2,h3,p{margin:0}h1{font-size:clamp(2rem,4vw,3rem);line-height:1.2}h2{font-size:clamp(1.4rem,3vw,2rem)}h3{font-size:clamp(1.05rem,2.6vw,1.4rem)}.login-shell{background:radial-gradient(circle at 10% 20%,#5c8dff40,transparent 45%),radial-gradient(circle at 90% 10%,#ff7eb340,transparent 50%),var(--bg,#02040a);justify-content:center;align-items:center;min-height:100vh;padding:48px 16px;display:flex}.login-card{border:1px solid var(--border-soft);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#050814d9;border-radius:28px;width:min(440px,100%);padding:40px;box-shadow:0 50px 120px #0000008c}.login-secondary{justify-content:center;align-items:center;width:100%;margin-top:10px;display:flex}.host-page-shell{background:radial-gradient(circle at 10% 20%,#5c8dff40,transparent 45%),radial-gradient(circle at 90% 10%,#ff7eb340,transparent 50%),var(--bg,#02040a);color:#f5f7ff;flex-direction:column;align-items:center;gap:24px;width:100%;min-height:100vh;padding:56px 32px 72px;display:flex;overflow-x:hidden}.host-page-header,.host-status-section{width:100%;margin:0}.host-page-header{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.host-back-button{align-self:flex-start;padding:10px 16px}.host-page-shell .host-status-section{max-height:none}.login-layout{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:start;gap:32px;width:min(1120px,100%);display:grid}.host-status-section{border:1px solid var(--border-soft);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#030614e0;border-radius:28px;flex-direction:column;flex:1;gap:20px;min-height:0;padding:32px;display:flex;box-shadow:0 50px 120px #00000073}.host-status-header{justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.host-status-subhead{color:var(--text-muted);max-width:420px;margin:12px 0 0}.host-status-panel{background:#050918e6;border:1px solid #ffffff14;border-radius:18px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.host-status-pill{align-items:center;gap:10px;font-size:14px;display:flex}.host-status-timestamp{color:var(--text-muted);margin:0;font-size:12px}.host-status-list{flex:1;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;width:100%;min-height:0;display:grid;overflow:hidden auto}.host-status-error,.host-status-empty{color:var(--text-muted);margin:0;font-size:14px}.host-card{border:1px solid var(--border-soft);background:#090c1ee6;border-radius:18px;flex-direction:column;gap:12px;padding:16px;display:flex}.host-card header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.host-card-label{letter-spacing:.3em;text-transform:uppercase;color:var(--text-muted);margin:0 0 6px;font-size:12px}.host-card-status{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:inline-flex}.host-card-status .status-dot{width:8px;height:8px;box-shadow:0 0 8px #4cff9c99}.host-card-meta{color:var(--text-muted);flex-wrap:wrap;gap:10px;font-size:12px;display:flex}.host-card-domains{color:#f5f7ff;margin:0;font-size:13px}.host-status-panel.state-loading .status-dot{background:#ffb347;box-shadow:0 0 10px #ffb347b3}.host-status-panel.state-error .status-dot{background:#ff5f6d;box-shadow:0 0 10px #ff5f6db3}.table-sort-button{color:inherit;font:inherit;cursor:pointer;text-transform:uppercase;letter-spacing:inherit;background:0 0;border:none;align-items:center;gap:6px;padding:0;transition:color .2s;display:inline-flex}.table-sort-button:hover{color:#f5f7ff}.sort-indicator{font-size:14px;line-height:1}.host-filter-wrapper{margin:0;padding:0}.host-filter-input{border:1px solid var(--border-strong);color:#f5f7ff;background:#050918e6;border-radius:16px;outline:none;width:100%;padding:14px 18px;font-family:inherit;font-size:14px;transition:all .2s}.host-filter-input::placeholder{color:var(--text-muted);opacity:.7}.host-filter-input:focus{background:#050918f2;border-color:#709aff99;box-shadow:0 0 0 3px #709aff1f}.verify-page-shell{background:radial-gradient(circle at 20% 20%,#709aff40,transparent 45%),radial-gradient(circle at 80% 20%,#ff6f9e4d,transparent 55%),var(--bg,#02040a);justify-content:center;align-items:center;min-height:100vh;padding:48px 16px;display:flex}.verify-card{border:1px solid var(--border-soft);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);text-align:center;background:#050814d9;border-radius:28px;flex-direction:column;gap:16px;width:min(420px,100%);padding:40px;display:flex;box-shadow:0 50px 120px #0000008c}.verify-status{color:#f5f7ff;margin:0;font-size:15px}.verify-status-success{color:#4cff9c}.verify-status-error{color:#ff5f6d}.host-filter-input:hover:not(:focus){border-color:#ffffff26}.host-status-table-wrapper{border:1px solid var(--border-soft);background:#090c1ed9;border-radius:20px;width:100%;height:60vh;overflow:auto}.host-status-table{border-collapse:collapse;width:100%;min-width:640px}.host-status-table thead th{letter-spacing:.25em;text-transform:uppercase;color:var(--text-muted);text-align:left;z-index:1;background:#090c1ef2;border-bottom:1px solid #ffffff14;padding:12px 16px;font-size:12px;position:sticky;top:0}.host-status-table tbody td{color:#f5f7ff;vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:14px 16px;font-size:14px}.host-status-table tbody tr:hover{background:#ffffff05}.host-name-cell{flex-direction:column;gap:4px;display:flex}.host-type-pill{text-transform:uppercase;letter-spacing:.3em;color:var(--text-muted);font-size:11px}.host-name{font-size:15px;font-weight:600}.status-chip{text-transform:uppercase;letter-spacing:.25em;background:#ffffff14;border-radius:999px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;display:inline-flex}.status-chip.online{color:#4cff9c}.status-chip.offline{color:#ff5f6d}.host-status-empty-cell{text-align:center;color:var(--text-muted);padding:32px 16px}.login-eyebrow{text-transform:uppercase;letter-spacing:.4em;color:var(--text-muted);margin-bottom:12px;font-size:11px}.login-subhead{color:var(--text-muted);margin:12px 0 24px}.login-form{flex-direction:column;gap:16px;display:flex}.input-field{flex-direction:column;gap:6px;font-size:14px;display:flex}.input-field span{color:var(--text-muted);letter-spacing:.08em}.input-field input{border:1px solid var(--border-strong);color:#f5f7ff;background:#01050fe6;border-radius:14px;padding:14px 16px}.login-button{justify-content:center;width:100%;margin-top:8px}.primary-button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#ff6b81;margin:0;font-size:14px}.login-info{text-align:center;color:#f5f7ff;margin:0;font-size:14px}.login-info-neutral{color:#f5f7ff}.login-info-warning{color:#ffb347}.login-info-success{color:#4cff9c}.login-verify-button{justify-content:center;width:100%}.login-hint{color:var(--text-muted);text-align:center;margin-top:8px;font-size:13px}.login-modal-overlay{z-index:1200;background:#02040ab8;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.login-modal{border:1px solid var(--border-soft);background:#080d21f5;border-radius:20px;flex-direction:column;gap:12px;width:min(460px,100%);padding:24px;display:flex;box-shadow:0 32px 80px #00000080}.login-modal h3{margin:0;font-size:20px}.login-modal p{color:var(--text-muted);margin:0;font-size:14px}.login-modal-input-field{flex-direction:column;gap:6px;margin-top:4px;display:flex}.login-modal-input-field span{color:var(--text-muted);letter-spacing:.06em;font-size:13px}.login-modal-input-field input{border:1px solid var(--border-strong);color:#f5f7ff;background:#01050fe6;border-radius:12px;padding:12px 14px}.login-modal-error{color:#ff6b81;margin:0;font-size:13px}.login-modal-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.login-modal-actions .ghost-button,.login-modal-actions .primary-button{justify-content:center;min-width:112px}.ghost-button:disabled{opacity:.6;cursor:not-allowed}.sidebar{border-right:1px solid var(--border-soft);background:#060914b3;flex-direction:column;gap:32px;padding:32px 28px 24px;display:flex}.brand{align-items:center;gap:12px;display:flex}.brand-pill{letter-spacing:.08em;background:linear-gradient(135deg,#5dc9ff,#4a5bff);border-radius:16px;place-items:center;width:48px;height:48px;font-weight:700;display:grid}.brand-eyebrow{text-transform:uppercase;letter-spacing:.3em;color:var(--text-muted);margin:0;font-size:11px}.brand-title{letter-spacing:.06em;margin:2px 0 0;font-size:18px;font-weight:600}.nav-stack{flex-direction:column;gap:8px;display:flex}.nav-item{color:inherit;font:inherit;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:12px;align-items:center;gap:10px;padding:12px 14px;transition:background .2s,border .2s;display:flex}.nav-item .icon{font-size:14px}.nav-item.active,.nav-item:hover{border-color:var(--border-soft);background:#ffffff0a}.sidebar-footer{border:1px solid var(--border-soft);background:#0c1020b3;border-radius:18px;margin-top:auto;padding:16px}.foot-label{color:var(--text-muted);margin:0 0 6px;font-size:12px}.foot-meter{background:#ffffff14;border-radius:999px;height:6px;overflow:hidden}.signal-fill{border-radius:inherit;background:linear-gradient(90deg,#5df4ff,#5bdc7b);width:70%;height:100%;animation:2s ease-in-out infinite pulse;display:block}.foot-note{color:var(--text-muted);margin:8px 0 0;font-size:12px}body.no-scroll{overflow:hidden}.mobile-nav-toggle,.sidebar-close{border:1px solid var(--border-soft);color:inherit;cursor:pointer;background:#ffffff0a;border-radius:12px;padding:8px 12px;font-size:18px;transition:background .2s,border .2s}.mobile-nav-toggle{z-index:35;display:none;position:fixed;top:20px;left:20px;box-shadow:0 12px 40px #00000040}.sidebar-close{align-self:flex-end;line-height:1;display:none}.mobile-overlay{opacity:0;pointer-events:none;z-index:15;background:#02040abf;transition:opacity .25s;position:fixed;inset:0}.mobile-overlay.visible{opacity:1;pointer-events:auto}.main-panel{flex-direction:column;gap:32px;width:min(1200px,100%);margin:0 auto;padding:40px 48px 48px;display:flex}.top-bar{justify-content:space-between;align-items:center;gap:32px;display:flex}.eyebrow{letter-spacing:.3em;text-transform:uppercase;color:var(--text-muted);margin:0 0 10px;font-size:12px}.subhead{color:var(--text-muted);max-width:520px;margin:8px 0 0}.user-pill{border:1px solid var(--border-soft);background:#111935a6;border-radius:18px;align-items:center;gap:12px;padding:16px 20px;display:flex}.status-dot{background:#4cff9c;border-radius:999px;width:10px;height:10px;box-shadow:0 0 10px #4cff9cb3}.status-dot.offline{background:#ff5f6d;box-shadow:0 0 10px #ff5f6db3}.user-label{margin:0;font-weight:600}.user-note{color:var(--text-muted);margin:4px 0 0;font-size:13px}.composer{border:1px solid var(--border-soft);background:#101426cc;border-radius:26px;padding:32px;box-shadow:0 40px 120px #06071373}.composer-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.ghost-button{border:1px solid var(--border-soft);color:inherit;cursor:pointer;background:#ffffff05;border-radius:14px;padding:10px 16px;font-weight:500}.composer-body{flex-direction:column;gap:18px;margin-top:24px;display:flex}.composer-input{border:1px solid var(--border-strong);color:inherit;resize:none;background:#010511e6;border-radius:18px;padding:18px;font-family:JetBrains Mono,Space Grotesk,sans-serif;font-size:14px}.chip-row{flex-wrap:wrap;gap:10px;display:flex}.chip{border:1px solid var(--border-soft);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;display:inline-flex}.chip input{accent-color:#7afcff}.composer-actions{flex-wrap:wrap;justify-content:space-between;gap:16px;display:flex}.quick-grid{flex:1;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.quick-action{border:1px solid var(--border-soft);color:inherit;text-align:left;cursor:pointer;background:#ffffff05;border-radius:16px;padding:12px 14px;transition:border .2s,transform .2s}.quick-action span{color:var(--text-muted);font-size:12px}.quick-action:hover{border-color:#7afcffb3;transform:translateY(-2px)}.primary-button{color:#050505;cursor:pointer;background:linear-gradient(135deg,#7c5dff,#5ce1ff);border:none;border-radius:18px;padding:16px 28px;font-weight:600;box-shadow:0 20px 40px #645cff59}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.stat-card{border:1px solid var(--border-soft);background:#0c1224b3;border-radius:20px;padding:18px 20px}.stat-value{letter-spacing:-.02em;margin:6px 0 4px;font-size:32px}.stat-delta{color:var(--text-muted);margin:0}.download-board{border:1px solid var(--border-soft);background:#070916d9;border-radius:26px;padding:28px}.api-panel{background:#050918d9;border:1px solid #ffffff14;border-radius:18px;max-height:240px;margin-top:16px;padding:14px 16px;overflow-y:auto}.api-panel-head{color:var(--text-muted);align-items:center;gap:10px;margin-bottom:10px;font-size:14px;display:flex}.api-panel pre{color:#f5f7ff;white-space:pre-wrap;word-break:break-word;margin:0;font-family:JetBrains Mono,monospace;font-size:12px}.api-panel.status-loading .status-dot{background:#ffb347;box-shadow:0 0 10px #ffb347b3}.api-panel.status-error .status-dot{background:#ff5f6d;box-shadow:0 0 10px #ff5f6db3}.board-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.tab-row{scrollbar-width:thin;flex-wrap:wrap;gap:6px;padding-bottom:6px;display:flex;overflow-x:auto}.tab-row::-webkit-scrollbar{height:4px}.tab-row::-webkit-scrollbar-thumb{background:#fff3;border-radius:999px}.tab{color:inherit;cursor:pointer;background:#ffffff08;border:1px solid #0000;border-radius:999px;padding:8px 16px}.tab.active{background:#7ed6ff1f;border-color:#7ed6ffcc}.download-list{flex-direction:column;gap:16px;margin-top:24px;display:flex}.download-card{border:1px solid var(--border-soft);background:#0c1023cc;border-radius:20px;padding:18px 20px;position:relative;overflow:hidden}.download-card header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.download-id{letter-spacing:.2em;color:var(--text-muted);margin:0 0 6px;font-size:12px}.download-card h3{margin:0;font-size:clamp(1rem,2.8vw,18px)}.icon-button{border:1px solid var(--border-soft);color:inherit;cursor:pointer;background:0 0;border-radius:12px;padding:4px 10px}.meta-row{color:var(--text-muted);flex-wrap:wrap;gap:12px;margin:14px 0 12px;font-size:13px;display:flex}.progress-track{background:#ffffff14;border-radius:999px;height:8px;overflow:hidden}.progress-track span{border-radius:inherit;background:linear-gradient(90deg,#6bffcb,#5cd4ff);height:100%;transition:width .4s;display:block}.download-card.status-completed .progress-track span{background:linear-gradient(90deg,#7afc9f,#42ffdd)}.download-card.status-queued{opacity:.8;border-style:dashed}.download-card.status-errored{border-color:#ff638499}@keyframes pulse{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}@media (max-width:1180px){.main-panel{padding:32px 28px 40px}.top-bar{gap:20px}}@media (max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:30;border-right:1px solid var(--border-soft);border-bottom:none;width:min(320px,80vw);padding-top:48px;transition:transform .3s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:0 30px 80px #00000080}.sidebar-close,.mobile-nav-toggle{display:inline-flex}.main-panel{padding:88px 20px 40px}.nav-stack{flex-direction:column}}@media (max-width:720px){.login-layout{grid-template-columns:1fr;gap:24px}.host-status-section{max-height:none;padding:24px}.host-status-header{flex-direction:column}.host-status-list{max-height:360px}.host-page-shell{padding:36px 16px 52px}.host-page-header{flex-direction:column;align-items:stretch}.top-bar{flex-direction:column;align-items:flex-start}.user-pill{width:100%}.composer{padding:24px}.composer-header{flex-direction:column;align-items:flex-start}.composer-actions{flex-direction:column}.quick-grid{width:100%}.primary-button{justify-content:center;width:100%}.stats-grid{grid-template-columns:1fr}.board-header,.download-card header{flex-direction:column;align-items:flex-start}}@media (max-width:540px){.main-panel{padding:72px 16px 32px}.composer{border-radius:18px}.download-board{padding:20px}.download-card{padding:16px}.tab{padding:6px 12px}.meta-row{flex-direction:column;gap:6px}.host-status-section{border-radius:20px;padding:20px}.host-status-list{grid-template-columns:1fr}.host-page-shell{padding:32px 12px 44px}}@media (max-width:400px){.composer,.download-board,.stat-card{border-radius:14px}.primary-button{padding:14px 20px}}.topup-overlay{z-index:1000;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.topup-modal{background:#1e1e2e;border-radius:12px;width:90%;min-width:320px;max-width:420px;padding:28px 24px;box-shadow:0 8px 32px #00000080}.topup-modal h3{margin-top:0;margin-bottom:16px}.topup-input{color:#fff;box-sizing:border-box;background:#2a2a3e;border:1px solid #444;border-radius:8px;width:100%;padding:10px 12px;font-size:14px}.topup-error{color:#f87171;margin-top:8px;margin-bottom:0;font-size:13px}.topup-success-text{color:#34d399;margin-top:8px;margin-bottom:0;font-size:13px}.topup-actions{gap:12px;margin-top:20px;display:flex}.topup-actions .primary-button{flex:1}.topup-cancel-button{color:#ccc;cursor:pointer;background:0 0;border:1px solid #444;border-radius:8px;flex:1;padding:10px;font-size:14px}.topup-stat-row{align-items:center;gap:8px;display:flex}.topup-stat-button{padding:4px 10px;font-size:12px}.topup-success-toast{color:#fff;z-index:1001;background:#22c55e;border-radius:10px;padding:14px 20px;font-size:14px;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #00000059}.topup-result-modal{text-align:center}.topup-result-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:28px;font-weight:700;display:flex}.topup-result-icon--success{color:#fff;background:#16a34a}.topup-result-icon--error{color:#fff;background:#dc2626}.topup-result-title{margin:0 0 10px;font-size:18px}.topup-result-message{color:#aaa;margin:0 0 20px;font-size:14px;line-height:1.5}.topup-result-close{width:100%}.register-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.register-card{background:#fff;border-radius:8px;width:100%;max-width:400px;padding:40px;box-shadow:0 10px 25px #0003}.register-card h1{text-align:center;color:#333;margin-bottom:30px;font-size:28px}.error-message{color:#c33;background-color:#fee;border:1px solid #fcc;border-radius:4px;margin-bottom:20px;padding:12px;font-size:14px}.success-message{color:#3c3;background-color:#efe;border:1px solid #cfc;border-radius:4px;margin-bottom:20px;padding:12px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{color:#555;margin-bottom:8px;font-size:14px;font-weight:500;display:block}.form-group input{box-sizing:border-box;border:1px solid #ddd;border-radius:4px;width:100%;padding:12px;font-size:14px;transition:border-color .3s}.form-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{color:#999;cursor:not-allowed;background-color:#f5f5f5}.submit-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:4px;width:100%;margin-top:10px;padding:12px;font-size:16px;font-weight:600;transition:transform .2s,box-shadow .2s}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.submit-button:disabled{opacity:.7;cursor:not-allowed}.login-link{text-align:center;color:#666;margin-top:20px;font-size:14px}.login-link a{color:#667eea;font-weight:600;text-decoration:none;transition:color .3s}.login-link a:hover{color:#764ba2;text-decoration:underline}
