@import"https://fonts.googleapis.com/css2?family=Fraunces:wght@600;700;800&family=JetBrains+Mono:wght@400;600&family=Space+Grotesk:wght@400;500;600;700&display=swap";.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04060ab3;display:flex;justify-content:flex-end;z-index:50}.drawer{width:min(420px,90vw);height:100%;background:var(--surface);border-left:1px solid var(--stroke-soft);padding:24px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-xl)}.drawer-header{display:flex;justify-content:space-between;align-items:center}.drawer-body{display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding-right:4px}.drawer-body .button.full{align-self:stretch}.drawer-row{border:1px solid transparent;background:#0a0c1299;padding:12px;border-radius:16px;display:flex;justify-content:space-between;gap:12px;color:inherit;text-align:left;cursor:pointer}.drawer-row.selected{border-color:#ffc36db3}.drawer-title{display:flex;gap:8px;align-items:center;font-weight:600}.drawer-meta{font-size:.85rem;color:var(--muted)}.drawer-date{font-size:.8rem;color:var(--muted);white-space:nowrap}.log-drawer{width:min(640px,96vw)}:root{--bg: #0b0d12;--surface: #151924;--surface-strong: #11141c;--stroke: rgba(255, 255, 255, .2);--stroke-soft: rgba(255, 255, 255, .1);--text: #f3f4f8;--muted: #b7bcc9;--accent: #ffc36d;--accent-soft: rgba(255, 195, 109, .2);--accent-dark: #2b1d00;--success: #7dffb1;--shadow-md: 0 16px 40px rgba(7, 9, 14, .4);--shadow-lg: 0 24px 48px rgba(7, 9, 14, .55);--shadow-xl: 0 30px 60px rgba(7, 9, 14, .6);--font-body: "Space Grotesk", sans-serif;--font-display: "Fraunces", serif;--font-mono: "JetBrains Mono", monospace}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% 10%,rgba(52,91,255,.25),transparent 45%),radial-gradient(circle at 85% 15%,rgba(255,174,76,.2),transparent 40%),radial-gradient(circle at 20% 80%,rgba(68,214,255,.18),transparent 45%),var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.5}#root{min-height:100vh}a{color:inherit}button,input,select,textarea{font-family:inherit}@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}.app{display:flex;flex-direction:column;gap:32px;padding:48px clamp(20px,4vw,64px) 64px}.top{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:32px;align-items:stretch}.brand{background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 60%),var(--surface);border-radius:28px;padding:32px;box-shadow:var(--shadow-xl);border:1px solid var(--stroke-soft)}.brand h1{font-family:var(--font-display);font-size:clamp(2.4rem,4vw,3.6rem);margin:16px 0 12px}.brand p{font-size:1.05rem;color:var(--muted);max-width:38ch}.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;background:#ffffff24;color:var(--accent);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.7rem}.meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-top:24px}.meta-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:6px}.meta-value{font-weight:600;font-size:.95rem}.status-panel{background:radial-gradient(circle at top left,rgba(251,195,93,.2),transparent 55%),var(--surface-strong);border-radius:28px;padding:32px;border:1px solid var(--stroke);display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-lg)}.status-header{display:flex;align-items:center;gap:10px;color:var(--muted);font-weight:600;letter-spacing:.02em}.status-dot{width:10px;height:10px;background:var(--success);border-radius:50%;box-shadow:0 0 12px #6dff9899}.status-panel h2{font-family:var(--font-display);font-size:2rem;margin:0}.status-panel p{margin:0;color:var(--muted)}.status-actions{display:flex;gap:12px;flex-wrap:wrap}.connectivity{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;border-radius:16px;border:1px solid var(--stroke-soft);background:#0c0e14a6}.connectivity-meta{display:grid;gap:4px;font-size:.75rem;color:var(--muted);margin-top:4px}.safe-mode{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;border-radius:16px;background:#0c0e14a6;border:1px solid var(--stroke-soft)}.safe-label{text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;color:var(--muted)}.safe-value{font-weight:600}.status-bar{display:flex;align-items:center;gap:12px;font-size:.85rem;color:var(--muted)}.status-bar-fill{flex:1;height:8px;border-radius:999px;background:linear-gradient(90deg,var(--accent),#ffc684);box-shadow:0 0 16px #ffc88480}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.grid.wide{grid-template-columns:minmax(0,1fr)}.card{background:var(--surface);border-radius:24px;padding:24px;border:1px solid var(--stroke-soft);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:16px;animation:rise .6s ease forwards;opacity:0;transform:translateY(16px);animation-delay:var(--delay, 0ms)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.card h3{margin:0;font-size:1.25rem}.tag{background:#ffffff1a;padding:4px 12px;border-radius:999px;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.form-row{display:flex;flex-direction:column;gap:8px}.form-row label{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.form-row.split{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}input,select{background:#0e1118b3;border:1px solid transparent;border-radius:14px;padding:12px 14px;color:var(--text);font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease}input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #ffc88433}.hint{font-size:.8rem;color:var(--muted)}.form-row .hint{line-height:1.4}.segmented{display:flex;gap:8px}.segmented-button{flex:1;padding:10px 12px;border-radius:999px;border:1px solid var(--stroke-soft);background:transparent;color:var(--text);font-weight:600;cursor:pointer;transition:all .2s ease}.segmented-button.active{background:var(--accent-soft);border-color:transparent;color:var(--accent-dark)}.button{border-radius:14px;padding:12px 18px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:transform .2s ease,box-shadow .2s ease}.button:disabled,.segmented-button:disabled{opacity:.6;cursor:not-allowed}.button.primary{background:linear-gradient(135deg,var(--accent),#ffd6a3);color:#151515;box-shadow:0 12px 28px #ffc15d59}.button.primary:hover{transform:translateY(-1px)}.button.ghost{background:transparent;border-color:var(--stroke);color:var(--text);text-decoration:none;display:inline-flex;justify-content:center;align-items:center}.button.full{width:100%}.job-list{display:flex;flex-direction:column;gap:12px}.placeholder{color:var(--muted);font-size:.9rem}.error{color:#ffb3b3;font-size:.9rem}.job-row{display:flex;justify-content:space-between;gap:16px;padding:12px;border-radius:16px;background:#0a0c1299;cursor:pointer;border:1px solid transparent;transition:border-color .2s ease,box-shadow .2s ease}.job-row.selected{border-color:#ffc36db3;box-shadow:0 0 18px #ffc36d33}.job-title{display:flex;gap:8px;align-items:center;font-weight:600}.job-meta{color:var(--muted);font-size:.85rem}.job-eta{color:var(--muted);font-size:.85rem;text-align:right}.chip{padding:2px 10px;border-radius:999px;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.chip.running{background:#6dff9833;color:#7dffb1}.chip.queued{background:#ffd69433;color:#ffd694}.chip.succeeded{background:#80c4ff33;color:#93c8ff}.storage-grid{display:grid;gap:12px}.storage-row{display:flex;justify-content:space-between;align-items:center;padding:14px;border-radius:16px;background:#0a0c128c}.storage-label{font-weight:600}.storage-hint{font-size:.8rem;color:var(--muted)}.storage-value{font-family:var(--font-mono);font-size:1rem}.log-window{background:#080a0ee6;border-radius:18px;padding:16px;font-family:var(--font-mono);font-size:.85rem;color:#c9d6f2;display:grid;gap:8px;min-height:180px}.log-line{opacity:.85}.log-line.muted{color:var(--muted)}.log-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px}.log-meta{font-size:.85rem;color:var(--muted)}.log-meta .muted{color:var(--muted)}.log-actions{display:flex;align-items:center;gap:12px}.log-hint{font-size:.75rem;color:var(--muted)}.toggle{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;color:var(--muted)}.toggle input{accent-color:var(--accent)}.note{font-size:.85rem;color:var(--muted)}.banner{display:flex;align-items:center;justify-content:space-between;gap:24px;background:linear-gradient(120deg,#50a0ff2e,#10121ae6)}.details-card{background:var(--surface);border-radius:24px;padding:24px;border:1px solid var(--stroke-soft);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:16px}.details-header{display:flex;justify-content:space-between;align-items:center}.details-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.details-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}.details-value{font-weight:600;word-break:break-word}.details-value.small{font-size:.75rem;font-family:var(--font-mono)}.banner ul{margin:12px 0 0;padding-left:18px;color:var(--muted)}.banner-actions{display:flex;gap:12px;flex-wrap:wrap}.footer{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.85rem;color:var(--muted)}.auth-screen{min-height:80vh;display:grid;place-items:center}.auth-card{background:var(--surface);border-radius:24px;padding:32px;border:1px solid var(--stroke-soft);box-shadow:var(--shadow-lg);max-width:420px;display:grid;gap:16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#06080cbf;display:grid;place-items:center;z-index:40}.modal-card{background:var(--surface);border-radius:24px;padding:28px;border:1px solid var(--stroke-soft);box-shadow:var(--shadow-xl);max-width:420px;display:grid;gap:16px}.modal-card h3{margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:12px}@keyframes rise{to{opacity:1;transform:translateY(0)}}@media (max-width: 960px){.top{grid-template-columns:1fr}.status-panel h2{font-size:1.6rem}}@media (max-width: 720px){.status-actions{flex-direction:column}.job-row,.banner{flex-direction:column;align-items:flex-start}}
