:root{--bg: #f7f8fa;--bg-tint: #eef1f8;--surface: #ffffff;--surface-2: #f1f3f7;--surface-3: #e9edf3;--border: #e4e7ec;--border-strong: #d3d8e0;--text: #101828;--text-2: #344054;--muted: #667085;--faint: #98a2b3;--primary: #4f46e5;--primary-hover: #4338ca;--primary-soft: #eef0fe;--primary-contrast: #ffffff;--accent: #0d9488;--accent-soft: #d8f3ef;--success: #16a34a;--success-soft: #e7f6ec;--warning: #b45309;--warning-soft: #fdf0dc;--danger: #dc2626;--danger-soft: #fde8e8;--favorite: #f59e0b;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 24px;--r-pill: 999px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .05);--shadow-md: 0 4px 8px -2px rgba(16, 24, 40, .08), 0 2px 4px -2px rgba(16, 24, 40, .05);--shadow-lg: 0 12px 28px -8px rgba(16, 24, 40, .16), 0 6px 12px -6px rgba(16, 24, 40, .08);--shadow-pop: 0 24px 48px -12px rgba(16, 24, 40, .28);--font-display: "Bricolage Grotesque", "Hanken Grotesk", system-ui, sans-serif;--font-ui: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;--ring: 0 0 0 3px color-mix(in srgb, var(--primary) 38%, transparent);--ease: cubic-bezier(.22, .61, .36, 1)}[data-theme=dark]{--bg: #0b0f17;--bg-tint: #0f1626;--surface: #121826;--surface-2: #1a2233;--surface-3: #222c40;--border: #232c3d;--border-strong: #303b50;--text: #e6e9ef;--text-2: #c2c9d6;--muted: #94a3b8;--faint: #6b7689;--primary: #818cf8;--primary-hover: #a5b0ff;--primary-soft: #1c2340;--primary-contrast: #0b0f17;--accent: #2dd4bf;--accent-soft: #10322f;--success: #4ade80;--success-soft: #11271a;--warning: #fbbf24;--warning-soft: #2c2110;--danger: #f87171;--danger-soft: #2e1517;--favorite: #fbbf24;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 10px -2px rgba(0, 0, 0, .5);--shadow-lg: 0 16px 32px -10px rgba(0, 0, 0, .6);--shadow-pop: 0 28px 56px -16px rgba(0, 0, 0, .7)}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-ui);font-size:15px;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background .3s var(--ease),color .3s var(--ease)}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:0}p{margin:0}a{color:inherit}button{font-family:inherit}::selection{background:color-mix(in srgb,var(--primary) 28%,transparent)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-pill);border:3px solid transparent;background-clip:content-box}*::-webkit-scrollbar-thumb:hover{background:var(--faint);background-clip:content-box}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--r-sm)}.btn{--btn-bg: var(--surface);--btn-fg: var(--text);--btn-bd: var(--border-strong);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;font-size:.9rem;font-weight:600;border-radius:var(--r-md);border:1px solid var(--btn-bd);background:var(--btn-bg);color:var(--btn-fg);cursor:pointer;white-space:nowrap;transition:transform .12s var(--ease),background .15s var(--ease),border-color .15s var(--ease),box-shadow .15s var(--ease),filter .15s var(--ease)}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn svg{width:1.05em;height:1.05em}.btn.primary{--btn-bg: var(--primary);--btn-fg: var(--primary-contrast);--btn-bd: transparent;background:linear-gradient(180deg,color-mix(in srgb,var(--primary) 92%,#fff) 0%,var(--primary) 100%);box-shadow:0 1px 2px #1018281f,inset 0 1px #ffffff2e}.btn.primary:hover{filter:brightness(1.05);box-shadow:var(--shadow-md)}.btn.ghost{--btn-bg: transparent;--btn-bd: transparent}.btn.ghost:hover{--btn-bg: var(--surface-2);box-shadow:none}.btn.subtle{--btn-bg: var(--surface-2);--btn-bd: transparent}.btn.danger{--btn-fg: var(--danger);--btn-bd: color-mix(in srgb, var(--danger) 40%, var(--border))}.btn.danger:hover{--btn-bg: var(--danger-soft)}.btn.sm{padding:.4rem .7rem;font-size:.82rem;border-radius:var(--r-sm)}.btn.block{width:100%}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2.3rem;height:2.3rem;border-radius:var(--r-md);border:1px solid transparent;background:transparent;color:var(--muted);cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease),transform .12s var(--ease)}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn:active{transform:scale(.94)}.icon-btn svg{width:1.15rem;height:1.15rem}.field{display:flex;flex-direction:column;gap:.4rem}.field>.label{font-size:.82rem;font-weight:600;color:var(--text-2)}.field .hint{font-size:.78rem;color:var(--muted)}input,textarea,select{width:100%;padding:.62rem .8rem;font:inherit;font-size:.9rem;color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-md);transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}input::placeholder,textarea::placeholder{color:var(--faint)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}textarea{resize:vertical;min-height:4.5rem}select[multiple]{padding:.3rem}select[multiple] option{padding:.35rem .5rem;border-radius:var(--r-sm)}.input-icon{position:relative;display:flex;align-items:center}.input-icon>svg{position:absolute;left:.8rem;width:1.05rem;height:1.05rem;color:var(--faint);pointer-events:none}.input-icon>input{padding-left:2.4rem}.switch{position:relative;display:inline-flex;cursor:pointer}.switch input{position:absolute;opacity:0;top:0;right:0;bottom:0;left:0;margin:0;cursor:pointer}.switch .track{width:2.5rem;height:1.4rem;border-radius:var(--r-pill);background:var(--surface-3);transition:background .2s var(--ease);position:relative}.switch .track:after{content:"";position:absolute;top:2px;left:2px;width:1rem;height:1rem;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease)}.switch input:checked+.track{background:var(--success)}.switch input:checked+.track:after{transform:translate(1.1rem)}.switch input:focus-visible+.track{box-shadow:var(--ring)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.18rem .55rem;border-radius:var(--r-pill);font-size:.76rem;font-weight:600;color:var(--muted);background:var(--surface-2)}.chip svg{width:.85rem;height:.85rem}.chip.mono{font-family:var(--font-mono);font-weight:500;letter-spacing:-.02em}.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.22rem .6rem;border-radius:var(--r-pill);font-size:.76rem;font-weight:600;white-space:nowrap}.badge .dot{width:.5rem;height:.5rem;border-radius:50%;background:currentColor;flex:none}.badge.running{color:var(--success);background:var(--success-soft)}.badge.building,.badge.pending{color:var(--warning);background:var(--warning-soft)}.badge.failed{color:var(--danger);background:var(--danger-soft)}.badge.stopped{color:var(--muted);background:var(--surface-2)}.badge.pending .dot,.badge.building .dot{animation:pulse 1.4s var(--ease) infinite}@keyframes pulse{50%{opacity:.35}}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 37%,var(--surface-2) 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;border-radius:var(--r-sm)}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid var(--surface-3);border-top-color:var(--primary);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-stack{position:fixed;bottom:1.25rem;right:1.25rem;z-index:200;display:flex;flex-direction:column;gap:.6rem;max-width:min(92vw,380px)}.toast{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem .9rem;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);font-size:.88rem;color:var(--text);animation:toast-in .28s var(--ease)}.toast svg{width:1.15rem;height:1.15rem;flex:none;margin-top:1px}.toast.ok svg{color:var(--success)}.toast.err svg{color:var(--danger)}.toast .close{margin-left:auto;cursor:pointer;color:var(--faint);background:none;border:none;padding:0}@keyframes toast-in{0%{opacity:0;transform:translateY(12px) scale(.96)}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:color-mix(in srgb,#0b0f17 55%,transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fade .2s var(--ease)}@keyframes fade{0%{opacity:0}}.dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);width:100%;max-width:420px;padding:1.5rem;animation:pop .25s var(--ease)}@keyframes pop{0%{opacity:0;transform:translateY(14px) scale(.97)}}.dialog h3{font-size:1.15rem;margin-bottom:.4rem}.dialog p{color:var(--muted);font-size:.9rem}.dialog .row{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1.3rem}.muted{color:var(--muted)}.mono{font-family:var(--font-mono)}.center-screen{min-height:100vh;display:grid;place-items:center;padding:2rem}.alert{display:flex;align-items:center;gap:.55rem;padding:.75rem .95rem;border-radius:var(--r-md);font-size:.88rem;font-weight:500}.alert svg{width:1.1rem;height:1.1rem;flex:none}.alert.err{color:var(--danger);background:var(--danger-soft)}.alert.ok{color:var(--success);background:var(--success-soft)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}.app{min-height:100vh;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:1rem;padding:.7rem clamp(1rem,4vw,2.5rem);background:color-mix(in srgb,var(--surface) 80%,transparent);-webkit-backdrop-filter:saturate(1.4) blur(12px);backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:.7rem;flex:none}.brand .mark{display:grid;place-items:center;width:2.3rem;height:2.3rem;border-radius:var(--r-md);color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:var(--shadow-sm)}.brand .mark svg{width:1.3rem;height:1.3rem}.brand-text{line-height:1.1}.brand-text strong{font-family:var(--font-display);font-size:1rem;font-weight:700;letter-spacing:-.02em;display:block}.brand-text small{color:var(--muted);font-size:.72rem}.topbar .searchbar{margin:0 auto;width:min(440px,42vw)}.topbar-right{display:flex;align-items:center;gap:.5rem;flex:none}.searchbar{position:relative;display:flex;align-items:center}.searchbar svg{position:absolute;left:.85rem;width:1.05rem;height:1.05rem;color:var(--faint);pointer-events:none}.searchbar input{padding-left:2.5rem;border-radius:var(--r-pill);background:var(--surface-2);border-color:transparent}.searchbar input:focus{background:var(--surface);border-color:var(--primary)}.usermenu{position:relative}.avatar{display:inline-flex;align-items:center;gap:.55rem;padding:.3rem .55rem .3rem .3rem;border-radius:var(--r-pill);border:1px solid var(--border);background:var(--surface-2);cursor:pointer;transition:border-color .15s var(--ease)}.avatar:hover{border-color:var(--border-strong)}.avatar .initials{display:grid;place-items:center;width:1.9rem;height:1.9rem;flex:none;border-radius:50%;font-size:.78rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent))}.avatar .uname{font-size:.85rem;font-weight:600;max-width:9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-pop{position:absolute;right:0;top:calc(100% + .5rem);min-width:220px;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:.4rem;animation:pop .18s var(--ease)}.menu-pop .who{padding:.55rem .6rem}.menu-pop .who strong{display:block;font-family:var(--font-ui);font-size:.9rem}.menu-pop .who small{color:var(--muted);font-size:.78rem}.menu-pop hr{border:none;border-top:1px solid var(--border);margin:.35rem 0}.menu-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.55rem .6rem;border:none;background:none;cursor:pointer;border-radius:var(--r-sm);color:var(--text);font-size:.88rem;text-align:left}.menu-item:hover{background:var(--surface-2)}.menu-item svg{width:1.05rem;height:1.05rem;color:var(--muted)}.hero{position:relative;overflow:hidden;padding:clamp(2rem,5vw,3.4rem) clamp(1rem,4vw,2.5rem) clamp(1.5rem,3vw,2.2rem);border-bottom:1px solid var(--border)}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(60% 120% at 12% 0%,color-mix(in srgb,var(--primary) 22%,transparent),transparent 60%),radial-gradient(50% 120% at 92% 10%,color-mix(in srgb,var(--accent) 20%,transparent),transparent 55%)}.hero-inner{position:relative;z-index:1;max-width:1180px;margin:0 auto}.hero .eyebrow{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:.9rem;padding:.3rem .7rem;border-radius:var(--r-pill);font-size:.76rem;font-weight:600;color:var(--accent);background:var(--accent-soft)}.hero .eyebrow svg{width:.9rem;height:.9rem}.hero h1{font-size:clamp(1.7rem,4vw,2.6rem);font-weight:800}.hero h1 .accent{background:linear-gradient(120deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}.hero p{margin-top:.7rem;max-width:54ch;color:var(--text-2);font-size:1.02rem}.hero-stats{display:flex;gap:.7rem;margin-top:1.5rem;flex-wrap:wrap}.stat{display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;border-radius:var(--r-md);background:color-mix(in srgb,var(--surface) 70%,transparent);border:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.stat .ic{display:grid;place-items:center;width:2.2rem;height:2.2rem;border-radius:var(--r-sm);background:var(--primary-soft);color:var(--primary)}.stat .ic.fav{background:color-mix(in srgb,var(--favorite) 18%,transparent);color:var(--favorite)}.stat .ic svg{width:1.2rem;height:1.2rem}.stat .n{font-family:var(--font-display);font-size:1.4rem;font-weight:700;line-height:1}.stat .k{font-size:.76rem;color:var(--muted)}.content{width:100%;max-width:1180px;margin:0 auto;padding:1.6rem clamp(1rem,4vw,2.5rem) 4rem;flex:1}.toolbar{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:1.4rem}.toolbar .searchbar.mobile{display:none;flex:1;min-width:180px}.segmented{display:inline-flex;padding:.25rem;gap:.2rem;background:var(--surface-2);border-radius:var(--r-pill);border:1px solid var(--border)}.segmented button{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border:none;background:none;cursor:pointer;border-radius:var(--r-pill);font-size:.85rem;font-weight:600;color:var(--muted);transition:color .15s var(--ease),background .15s var(--ease)}.segmented button svg{width:.95rem;height:.95rem}.segmented button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.segmented .count{font-size:.72rem;color:var(--faint)}.section-title{display:flex;align-items:center;gap:.55rem;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:1.8rem 0 1rem}.section-title:first-of-type{margin-top:0}.section-title svg{width:1rem;height:1rem;color:var(--favorite)}.grid{display:grid;gap:1.1rem;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.dcard{position:relative;display:flex;flex-direction:column;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:transform .18s var(--ease),box-shadow .18s var(--ease),border-color .18s var(--ease)}.dcard:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:0;transition:opacity .18s var(--ease)}.dcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}.dcard:hover:before{opacity:1}.dcard-body{padding:1.2rem 1.2rem 0;display:flex;flex-direction:column;gap:.6rem;flex:1}.dcard-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.6rem}.dcard-head h3{font-size:1.12rem;font-weight:700}.dcard .desc{color:var(--muted);font-size:.9rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.star{color:var(--faint);background:none;border:none;cursor:pointer;padding:.25rem;border-radius:var(--r-sm);flex:none;transition:color .15s var(--ease),transform .15s var(--ease)}.star:hover{color:var(--favorite);transform:scale(1.12)}.star.on{color:var(--favorite)}.star svg{width:1.3rem;height:1.3rem}.star.on svg{fill:currentColor}.dcard-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:auto}.owner{display:inline-flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--text-2)}.owner .mini{display:grid;place-items:center;width:1.5rem;height:1.5rem;border-radius:50%;font-size:.65rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--primary))}.dcard-foot{padding:1rem 1.2rem 1.2rem}.dcard .open{width:100%}.viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;background:color-mix(in srgb,#0b0f17 60%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;padding:clamp(.5rem,2vw,1.5rem);animation:fade .2s var(--ease)}.viewer{margin:auto;width:100%;height:100%;max-width:1500px;display:flex;flex-direction:column;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);animation:pop .25s var(--ease)}.viewer-bar{display:flex;align-items:center;gap:.8rem;padding:.7rem 1rem;border-bottom:1px solid var(--border)}.viewer-bar .vtitle{display:flex;align-items:center;gap:.6rem;min-width:0}.viewer-bar .vtitle .dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--success);flex:none;box-shadow:0 0 0 3px var(--success-soft)}.viewer-bar h2{font-size:1.02rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.viewer-actions{display:flex;align-items:center;gap:.4rem;margin-left:auto}.frame-wrap{position:relative;flex:1;background:var(--bg)}.frame-wrap iframe{width:100%;height:100%;border:none}.frame-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--bg);transition:opacity .3s var(--ease)}.frame-loading.hide{opacity:0;pointer-events:none}.notice{text-align:center;max-width:440px;padding:2.6rem 2.2rem}.notice .ic{display:grid;place-items:center;width:4rem;height:4rem;margin:0 auto 1.2rem;border-radius:var(--r-xl);background:var(--primary-soft);color:var(--primary)}.notice .ic svg{width:2rem;height:2rem}.notice h2{font-size:1.4rem;margin-bottom:.6rem}.notice p{color:var(--muted);margin-bottom:1.5rem}.empty{text-align:center;padding:3.5rem 1rem;color:var(--muted);border:1.5px dashed var(--border-strong);border-radius:var(--r-lg)}.empty .ic{display:grid;place-items:center;width:3.2rem;height:3.2rem;margin:0 auto 1rem;border-radius:var(--r-lg);background:var(--surface-2);color:var(--faint)}.empty .ic svg{width:1.6rem;height:1.6rem}.empty strong{display:block;color:var(--text);font-family:var(--font-display);font-size:1.05rem;margin-bottom:.3rem}.sk-card{border:1px solid var(--border);border-radius:var(--r-lg);padding:1.2rem;background:var(--surface)}.sk-line{height:.85rem;margin-bottom:.6rem}@media (max-width: 720px){.topbar .searchbar{display:none}.toolbar .searchbar.mobile{display:flex}.brand-text small,.avatar .uname{display:none}}.platform-badge{display:inline-flex;align-items:center;align-self:flex-start;margin-bottom:4px;padding:.1rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:600;letter-spacing:.03em;color:var(--badge-color, #6366f1);background:color-mix(in srgb,var(--badge-color, #6366f1) 14%,transparent)}
