:root{color-scheme:dark;--accent: #326ce5;--accent-strong: #2856b7;--accent-soft: rgba(50, 108, 229, .14);--bg: #0d0f17;--bg-soft: #14161f;--surface: #1a1d29;--surface-hover: #232735;--border: #2a2e3d;--text: #e7e8ea;--muted: #9ba1ad;--success: #34d399;--success-soft: rgba(52, 211, 153, .14);--warn: #fbbf24;--warn-soft: rgba(251, 191, 36, .14);--danger: #f87171;--danger-soft: rgba(248, 113, 113, .14);--nav-bg: rgba(13, 15, 23, .8);--gradient: linear-gradient(135deg, #2856b7 0%, #326ce5 100%);--radius-sm: .25rem;--radius: .5rem;--radius-pill: 99rem;--shadow-sm: 0px 1px 1px hsla(0, 0%, 0%, .12), 0px 2px 1px hsla(0, 0%, 0%, .24);--shadow-md: 0px 8px 4px hsla(0, 0%, 0%, .08), 0px 5px 2px hsla(0, 0%, 0%, .08), 0px 3px 2px hsla(0, 0%, 0%, .12), 0px 1px 1px hsla(0, 0%, 0%, .15);--shadow-lg: 0px 25px 7px hsla(0, 0%, 0%, .03), 0px 16px 6px hsla(0, 0%, 0%, .1), 0px 9px 5px hsla(223, 13%, 10%, .33), 0px 4px 4px hsla(0, 0%, 0%, .75), 0px 4px 2px hsla(0, 0%, 0%, .25);--container: 1100px;--nav-h: 4rem;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}:root[data-theme=light]{color-scheme:light;--accent: #2856b7;--accent-strong: #1d4297;--accent-soft: rgba(50, 108, 229, .1);--bg: #ffffff;--bg-soft: #f6f7f9;--surface: #ffffff;--surface-hover: #f1f2f5;--border: #e2e4ea;--text: #1f2430;--muted: #5c6370;--success: #16a34a;--success-soft: rgba(22, 163, 74, .1);--warn: #d97706;--warn-soft: rgba(217, 119, 6, .12);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .1);--nav-bg: rgba(255, 255, 255, .82);--shadow-sm: 0px 1px 1px hsla(0, 0%, 0%, .06), 0px 2px 1px hsla(0, 0%, 0%, .06);--shadow-md: 0px 8px 4px hsla(0, 0%, 0%, .03), 0px 5px 2px hsla(0, 0%, 0%, .03), 0px 3px 2px hsla(0, 0%, 0%, .06), 0px 1px 1px hsla(0, 0%, 0%, .06);--shadow-lg: 0px 25px 7px rgba(0, 0, 0, .01), 0px 16px 6px hsla(0, 0%, 0%, .03), 0px 9px 5px hsla(223, 13%, 10%, .08), 0px 4px 4px hsla(0, 0%, 0%, .16), 0px 4px 2px hsla(0, 0%, 0%, .04)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}a{color:inherit}[hidden]{display:none!important}body[data-route=run] .navbar,body[data-route=login] .navbar{display:none}.container{max-width:var(--container);margin:0 auto;padding:0 1.5rem}.navbar{position:sticky;top:0;z-index:50;background:var(--nav-bg);border-bottom:1px solid var(--border);backdrop-filter:blur(12px)}.nav-inner{max-width:var(--container);margin:0 auto;height:var(--nav-h);padding:0 1.5rem;display:flex;align-items:center;gap:1rem}.brand{display:inline-flex;align-items:center;gap:.6rem;font-size:1.35rem;font-weight:700;text-decoration:none}.brand img{width:28px;height:28px;display:block}.brand span{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.nav-links{display:flex;align-items:center;gap:.25rem;margin-left:1rem}.nav-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .85rem;border-radius:var(--radius);color:var(--muted);text-decoration:none;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.nav-link:hover{color:var(--text);background:var(--surface-hover)}.nav-link.active{color:var(--accent);background:var(--accent-soft)}.nav-actions{margin-left:auto;display:flex;align-items:center;gap:.75rem}.user-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .85rem;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:.85rem;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1.1rem;border:1px solid transparent;border-radius:var(--radius);font:inherit;font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s,box-shadow .15s,transform .15s}.btn-primary{background:var(--gradient);color:#fff}.btn-primary:hover{box-shadow:var(--shadow-md)}.btn-ghost{background:transparent;border-color:var(--border);color:var(--muted)}.btn-ghost:hover{color:var(--text);background:var(--surface-hover)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-icon:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.btn-icon.danger:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-soft)}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.hero{text-align:center;padding:2.5rem 0 1.5rem}.hero h1{font-size:2.25rem;font-weight:800;letter-spacing:-.02em;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero p{margin-top:.5rem;color:var(--muted)}.section{margin:2rem 0 3rem}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.section-head h2{font-size:1.6rem;font-weight:700}.section-head p{color:var(--muted);font-size:.95rem}.head-actions{display:flex;align-items:center;gap:.75rem}.counter{display:inline-flex;align-items:center;gap:.4rem;height:38px;padding:0 .85rem;box-sizing:border-box;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:.9rem;color:var(--muted)}.counter b{font-size:1.05rem;color:var(--accent)}.tabs{display:inline-flex;gap:.25rem;padding:.25rem;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius)}.tabs .tab{appearance:none;background:transparent;border:0;padding:.4rem .95rem;font:inherit;font-size:.88rem;font-weight:500;color:var(--muted);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s,color .12s}.tabs .tab:hover{color:var(--text)}.tabs .tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.kube-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.kube-table{width:100%;border-collapse:collapse;font-size:.88rem}.kube-table thead th{position:sticky;top:0;background:var(--bg-soft);color:var(--muted);font-weight:600;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;text-align:left;padding:.6rem .85rem;border-bottom:1px solid var(--border)}.kube-table tbody td{padding:.55rem .85rem;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}.kube-table tbody tr:last-child td{border-bottom:0}.kube-table tbody tr:hover{background:var(--surface-hover)}.kube-table code{font-family:var(--mono);font-size:.85rem}.kube-table .url-cell{max-width:28rem;overflow:hidden;text-overflow:ellipsis}.kube-table .url-cell a{color:var(--accent);text-decoration:none}.kube-table .url-cell a:hover{text-decoration:underline}.kube-table .muted{color:var(--muted)}.env-list{display:flex;flex-direction:column;gap:.75rem}.env-item{display:flex;align-items:center;gap:1.25rem;padding:1.1rem 1.35rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}.env-item:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.env-emoji{font-size:1.9rem;line-height:1}.env-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.4rem}.env-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.env-name{font-size:1.05rem;font-weight:700}.env-url{font-size:.85rem;color:var(--accent);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.env-url:hover{text-decoration:underline}.env-cmd{display:block;font-family:var(--mono);font-size:.82rem;color:var(--text);background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.2rem .45rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.env-meta{display:flex;gap:.5rem;flex-wrap:wrap}.env-actions{display:flex;gap:.5rem;flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .55rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-soft);color:var(--muted);font-size:.75rem;font-weight:600}.badge.accent{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.badge.success{background:var(--success-soft);border-color:var(--success);color:var(--success)}.status{display:inline-flex;align-items:center;padding:.25rem .7rem;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.status.healthy{background:var(--success-soft);color:var(--success);border-color:var(--success)}.status.progressing,.status.pending{background:var(--warn-soft);color:var(--warn);border-color:var(--warn)}.status.degraded,.status.error{background:var(--danger-soft);color:var(--danger);border-color:var(--danger)}.status.deleting,.status.unknown,.status.missing{background:var(--bg-soft);color:var(--muted);border-color:var(--border)}.catalog-layout{display:flex;gap:2rem;align-items:flex-start}.toc{position:sticky;top:calc(var(--nav-h) + 1rem);width:200px;flex-shrink:0}.toc-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:.75rem}.toc a{display:block;padding:.35rem .6rem;border-radius:var(--radius-sm);color:var(--text);text-decoration:none;font-size:.9rem;font-weight:600}.toc a.sub{margin-left:.75rem;font-weight:500;font-size:.85rem;color:var(--muted)}.toc a:hover{background:var(--surface-hover);color:var(--accent)}.catalog-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2.25rem}.cat-section{display:flex;flex-direction:column;gap:1.1rem}.cat-title{font-size:1.35rem;font-weight:700;padding-bottom:.6rem;border-bottom:1px solid var(--border)}.sub-title{font-size:1rem;font-weight:600;color:var(--muted)}.card-grid{display:flex;flex-direction:column;gap:.75rem}.card{display:flex;align-items:center;gap:1.1rem;padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}.card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.card-icon{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;background:var(--bg-soft);border-radius:var(--radius)}.card-body{flex:1;min-width:0}.card-body .name{font-size:1.05rem;font-weight:700}.card-body .desc{color:var(--muted);font-size:.9rem}.card-badges{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.6rem}.state{text-align:center;padding:3rem 1.5rem;border:2px dashed var(--border);border-radius:var(--radius);color:var(--muted)}.state.error{color:var(--danger);border-color:var(--danger)}.login{display:flex;align-items:center;justify-content:center;min-height:70vh;padding:2rem}.login-card{width:100%;max-width:420px;text-align:center;padding:2.5rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg)}.login-card .brand{justify-content:center;font-size:1.5rem;margin-bottom:1.25rem}.login-card .icon{font-size:2.5rem}.login-card h2{margin:.75rem 0 .5rem;font-size:1.5rem}.login-card p{color:var(--muted);margin-bottom:1.5rem}.run{display:flex;justify-content:center;padding:4rem 1.5rem}.run-card{width:100%;max-width:560px;text-align:center;padding:2.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg)}.run-card .brand{justify-content:center;font-size:1.6rem;margin-bottom:1.25rem}.run-card .brand img{width:32px;height:32px}.run-env{margin:0 0 1.5rem;padding:1.1rem 1.25rem;text-align:left;background:var(--bg-soft);border-left:4px solid var(--accent);border-radius:var(--radius)}.run-env .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.run-env .name{font-size:1.4rem;font-weight:700;color:var(--accent)}.spinner{width:46px;height:46px;margin:1.5rem auto;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-text{color:var(--muted);font-size:1.05rem}.status-text small{display:block;margin-top:.35rem;font-family:var(--mono);font-size:.8rem;opacity:.8}.conn-cmd{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.6rem .85rem;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius)}.conn-cmd code{flex:1;font-family:var(--mono);font-size:.9rem;color:var(--text);text-align:left;overflow-x:auto;white-space:nowrap}.progress{height:4px;margin-top:1.5rem;background:var(--border);border-radius:var(--radius-pill);overflow:hidden}.progress-fill{height:100%;background:var(--gradient);animation:progress 2s ease-in-out infinite}@keyframes progress{0%{width:0%}50%{width:70%}to{width:100%}}.error-box{margin:1.25rem 0;padding:1rem;color:var(--danger);background:var(--danger-soft);border:1px solid var(--danger);border-radius:var(--radius)}.toasts{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:100}.toast{padding:.9rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);font-weight:500;max-width:360px;animation:toast-in .25s ease}.toast.success{border-color:var(--success);color:var(--success)}.toast.error{border-color:var(--danger);color:var(--danger)}@keyframes toast-in{0%{transform:translate(120%)}to{transform:translate(0)}}@media(max-width:860px){.toc{display:none}}@media(max-width:640px){.nav-links{display:none}.env-item{flex-direction:column;align-items:flex-start}.env-actions{width:100%;justify-content:flex-end}.card{flex-direction:column;text-align:center}}
