| |
| *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } |
|
|
| :root { |
| --bg: #0d0f14; |
| --surface: #161b25; |
| --surface2: #1e2533; |
| --border: #2a3347; |
| --accent: #00c4cc; |
| --accent-dk: #009ba1; |
| --text: #e2e8f0; |
| --muted: #8896ab; |
| --error: #ff5f6d; |
| --success: #4ade80; |
| --warning: #facc15; |
| --radius: 12px; |
| --radius-sm: 8px; |
| --font-mono: 'Cascadia Code', 'Fira Code', 'Courier New', Courier, monospace; |
| } |
|
|
| html, body { |
| height: 100%; |
| background: var(--bg); |
| color: var(--text); |
| font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, sans-serif; |
| font-size: 15px; |
| line-height: 1.6; |
| -webkit-font-smoothing: antialiased; |
| } |
|
|
| |
| .page { min-height: 100vh; } |
| .hidden { display: none !important; } |
|
|
| |
| #login-page { |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| padding: 24px; |
| background: |
| radial-gradient(ellipse at 20% 60%, rgba(0,196,204,.08) 0%, transparent 60%), |
| radial-gradient(ellipse at 80% 20%, rgba(0,196,204,.05) 0%, transparent 50%), |
| var(--bg); |
| } |
|
|
| .login-card { |
| background: var(--surface); |
| border: 1px solid var(--border); |
| border-radius: var(--radius); |
| padding: 40px 36px; |
| width: 100%; |
| max-width: 400px; |
| box-shadow: 0 24px 64px rgba(0,0,0,.5); |
| } |
|
|
| .brand { |
| display: flex; |
| align-items: center; |
| gap: 12px; |
| margin-bottom: 8px; |
| } |
|
|
| .brand h1 { |
| font-size: 24px; |
| font-weight: 700; |
| letter-spacing: -0.5px; |
| } |
|
|
| .brand-icon { |
| width: 40px; |
| height: 40px; |
| border-radius: 10px; |
| flex-shrink: 0; |
| } |
| .brand-icon.small { width: 28px; height: 28px; border-radius: 7px; } |
|
|
| .tagline { |
| color: var(--muted); |
| font-size: 13.5px; |
| margin-bottom: 28px; |
| } |
|
|
| |
| .field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; } |
|
|
| .field label { |
| font-size: 13px; |
| font-weight: 500; |
| color: var(--muted); |
| letter-spacing: .4px; |
| text-transform: uppercase; |
| } |
|
|
| .input-wrap { position: relative; display: flex; } |
|
|
| .input-wrap input { |
| width: 100%; |
| background: var(--surface2); |
| border: 1px solid var(--border); |
| border-radius: var(--radius-sm); |
| color: var(--text); |
| font-size: 15px; |
| padding: 11px 44px 11px 14px; |
| outline: none; |
| transition: border-color .15s, box-shadow .15s; |
| } |
|
|
| .input-wrap input:focus { |
| border-color: var(--accent); |
| box-shadow: 0 0 0 3px rgba(0,196,204,.15); |
| } |
|
|
| .input-wrap input::placeholder { color: var(--muted); opacity: .6; } |
|
|
| .eye-btn { |
| position: absolute; |
| right: 10px; |
| top: 50%; |
| transform: translateY(-50%); |
| background: none; |
| border: none; |
| cursor: pointer; |
| color: var(--muted); |
| display: flex; |
| align-items: center; |
| padding: 4px; |
| border-radius: 4px; |
| transition: color .15s; |
| } |
| .eye-btn:hover { color: var(--text); } |
| .eye-btn svg { width: 18px; height: 18px; } |
|
|
| |
| .btn { |
| display: inline-flex; |
| align-items: center; |
| justify-content: center; |
| gap: 6px; |
| border: none; |
| border-radius: var(--radius-sm); |
| cursor: pointer; |
| font-size: 14px; |
| font-weight: 600; |
| padding: 10px 18px; |
| transition: background .15s, opacity .15s, transform .1s; |
| white-space: nowrap; |
| text-decoration: none; |
| } |
| .btn:active { transform: scale(.97); } |
| .btn:disabled { opacity: .5; cursor: not-allowed; } |
|
|
| .btn-primary, #login-btn { |
| background: var(--accent); |
| color: #0d0f14; |
| width: 100%; |
| padding: 12px; |
| font-size: 15px; |
| margin-top: 8px; |
| border: none; |
| border-radius: var(--radius-sm); |
| cursor: pointer; |
| font-weight: 700; |
| transition: background .15s, transform .1s; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| gap: 8px; |
| } |
| .btn-primary:hover, #login-btn:hover { background: var(--accent-dk); } |
| .btn-primary:active, #login-btn:active { transform: scale(.98); } |
| .btn-primary:disabled, #login-btn:disabled { opacity: .5; cursor: not-allowed; } |
|
|
| .btn-secondary { |
| background: var(--surface2); |
| color: var(--text); |
| border: 1px solid var(--border); |
| } |
| .btn-secondary:hover { background: var(--border); } |
|
|
| .btn-ghost { |
| background: transparent; |
| color: var(--muted); |
| border: none; |
| padding: 8px 12px; |
| } |
| .btn-ghost:hover { color: var(--text); background: var(--surface2); } |
| .btn-ghost.small { font-size: 12px; padding: 4px 10px; } |
|
|
| .error-msg { |
| color: var(--error); |
| font-size: 13px; |
| margin-top: 10px; |
| text-align: center; |
| min-height: 20px; |
| } |
|
|
| |
| .spinner { |
| width: 16px; |
| height: 16px; |
| border: 2px solid rgba(0,0,0,.25); |
| border-top-color: #0d0f14; |
| border-radius: 50%; |
| animation: spin .7s linear infinite; |
| flex-shrink: 0; |
| } |
| @keyframes spin { to { transform: rotate(360deg); } } |
|
|
| |
| .topbar { |
| display: flex; |
| align-items: center; |
| justify-content: space-between; |
| padding: 14px 24px; |
| background: var(--surface); |
| border-bottom: 1px solid var(--border); |
| position: sticky; |
| top: 0; |
| z-index: 10; |
| } |
|
|
| .topbar-brand { |
| display: flex; |
| align-items: center; |
| gap: 10px; |
| font-weight: 700; |
| font-size: 16px; |
| letter-spacing: -0.3px; |
| } |
|
|
| .topbar-actions { display: flex; align-items: center; gap: 10px; } |
|
|
| |
| .badge { |
| font-size: 12px; |
| font-weight: 600; |
| padding: 3px 10px; |
| border-radius: 20px; |
| letter-spacing: .3px; |
| text-transform: uppercase; |
| } |
| .badge-running { background: rgba(74,222,128,.15); color: var(--success); } |
| .badge-starting { background: rgba(250,204,21,.15); color: var(--warning); } |
| .badge-retrying { background: rgba(250,204,21,.15); color: var(--warning); } |
| .badge-stopped { background: rgba(255,95,109,.12); color: var(--error); } |
| .badge-error { background: rgba(255,95,109,.12); color: var(--error); } |
|
|
| |
| .dashboard { |
| display: grid; |
| grid-template-columns: 1fr 1fr; |
| gap: 20px; |
| padding: 24px; |
| max-width: 1100px; |
| margin: 0 auto; |
| } |
|
|
| @media (max-width: 720px) { |
| .dashboard { grid-template-columns: 1fr; } |
| } |
|
|
| |
| .setup-card { grid-column: 1 / -1; } |
|
|
| |
| .card { |
| background: var(--surface); |
| border: 1px solid var(--border); |
| border-radius: var(--radius); |
| overflow: hidden; |
| display: flex; |
| flex-direction: column; |
| } |
|
|
| .card-header { |
| display: flex; |
| align-items: baseline; |
| justify-content: space-between; |
| padding: 18px 20px 12px; |
| border-bottom: 1px solid var(--border); |
| } |
|
|
| .card-header h2 { |
| font-size: 16px; |
| font-weight: 700; |
| } |
|
|
| .card-header p { |
| font-size: 13px; |
| color: var(--muted); |
| margin-top: 2px; |
| } |
|
|
| |
| .qr-area { |
| flex: 1; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| padding: 28px 20px; |
| min-height: 300px; |
| } |
|
|
| .qr-state { |
| display: flex; |
| flex-direction: column; |
| align-items: center; |
| gap: 14px; |
| text-align: center; |
| } |
|
|
| .qr-state p { color: var(--muted); font-size: 14px; } |
|
|
| |
| .loader { |
| width: 44px; |
| height: 44px; |
| border: 3px solid var(--border); |
| border-top-color: var(--accent); |
| border-radius: 50%; |
| animation: spin .9s linear infinite; |
| } |
|
|
| |
| .qr-frame { |
| background: #ffffff; |
| border-radius: 10px; |
| padding: 16px; |
| box-shadow: 0 0 0 4px rgba(255,255,255,.06); |
| display: inline-block; |
| } |
|
|
| |
| #qr-pre { |
| font-family: var(--font-mono); |
| font-size: 7px; |
| line-height: 1; |
| color: #000000; |
| background: transparent; |
| white-space: pre; |
| display: block; |
| letter-spacing: 0; |
| } |
|
|
| .qr-hint { |
| font-size: 12px !important; |
| color: var(--muted) !important; |
| } |
|
|
| .error-icon { |
| font-size: 36px; |
| color: var(--error) !important; |
| } |
|
|
| |
| .manual-card { grid-column: 1 / -1; border-color: rgba(250,204,21,.3); } |
|
|
| .manual-body { padding: 16px 20px 22px; display: flex; flex-direction: column; gap: 18px; } |
|
|
| .manual-intro { font-size: 13.5px; color: var(--muted); line-height: 1.6; } |
|
|
| .manual-step { |
| display: flex; |
| gap: 14px; |
| align-items: flex-start; |
| } |
| .manual-step > div { display: flex; flex-direction: column; gap: 8px; flex: 1; } |
| .manual-step p { font-size: 13.5px; color: var(--muted); line-height: 1.6; } |
|
|
| .step-num { |
| width: 26px; height: 26px; |
| border-radius: 50%; |
| background: var(--accent); |
| color: #0d0f14; |
| font-size: 13px; |
| font-weight: 700; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| flex-shrink: 0; |
| margin-top: 2px; |
| } |
|
|
| .code-block { |
| display: flex; |
| align-items: center; |
| gap: 10px; |
| background: var(--bg); |
| border: 1px solid var(--border); |
| border-radius: var(--radius-sm); |
| padding: 10px 14px; |
| flex-wrap: wrap; |
| } |
| .code-block code { |
| font-family: var(--font-mono); |
| font-size: 12px; |
| color: var(--text); |
| flex: 1; |
| word-break: break-all; |
| } |
|
|
| .inline-code { |
| font-family: var(--font-mono); |
| font-size: 12px; |
| background: var(--surface2); |
| border: 1px solid var(--border); |
| border-radius: 4px; |
| padding: 1px 5px; |
| } |
|
|
| .manual-input-row { |
| display: flex; |
| gap: 10px; |
| align-items: center; |
| flex-wrap: wrap; |
| } |
| .manual-input-row input { |
| flex: 1; |
| min-width: 180px; |
| background: var(--surface2); |
| border: 1px solid var(--border); |
| border-radius: var(--radius-sm); |
| color: var(--text); |
| font-family: var(--font-mono); |
| font-size: 14px; |
| padding: 9px 12px; |
| outline: none; |
| transition: border-color .15s; |
| } |
| .manual-input-row input:focus { border-color: var(--accent); } |
| .manual-btn { padding: 9px 20px; } |
|
|
| |
| .setup-body { padding: 16px 20px 20px; display: flex; flex-direction: column; gap: 14px; } |
|
|
| .setup-intro { font-size: 13.5px; color: var(--muted); line-height: 1.6; } |
|
|
| .setup-link { color: var(--accent); text-decoration: none; } |
| .setup-link:hover { text-decoration: underline; } |
|
|
| .secret-row { |
| display: flex; |
| align-items: center; |
| gap: 10px; |
| background: var(--bg); |
| border: 1px solid var(--border); |
| border-radius: var(--radius-sm); |
| padding: 10px 14px; |
| flex-wrap: wrap; |
| } |
|
|
| .secret-name { |
| font-family: var(--font-mono); |
| font-size: 12px; |
| color: var(--accent); |
| min-width: 200px; |
| font-weight: 600; |
| } |
|
|
| .secret-val { |
| font-family: var(--font-mono); |
| font-size: 12px; |
| color: var(--text); |
| flex: 1; |
| word-break: break-all; |
| min-width: 0; |
| } |
|
|
| .btn-copy { |
| background: var(--surface2); |
| border: 1px solid var(--border); |
| border-radius: 6px; |
| color: var(--muted); |
| cursor: pointer; |
| font-size: 12px; |
| font-weight: 600; |
| padding: 4px 12px; |
| white-space: nowrap; |
| transition: background .15s, color .15s; |
| flex-shrink: 0; |
| } |
| .btn-copy:hover { background: var(--border); color: var(--text); } |
| .btn-copy.copied { color: var(--success); border-color: var(--success); } |
|
|
| .setup-note { font-size: 12px; color: var(--muted); font-style: italic; } |
|
|
| |
| .log-card { min-height: 300px; } |
|
|
| .log-pre { |
| flex: 1; |
| font-family: var(--font-mono); |
| font-size: 12px; |
| color: var(--muted); |
| background: var(--bg); |
| padding: 16px; |
| overflow-y: auto; |
| max-height: 480px; |
| white-space: pre-wrap; |
| word-break: break-word; |
| line-height: 1.5; |
| } |
|
|
| |
| .log-pre::-webkit-scrollbar { width: 6px; } |
| .log-pre::-webkit-scrollbar-track { background: transparent; } |
| .log-pre::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; } |
|
|