: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}}.shell{display:grid;grid-template-columns:var(--sb, 264px) 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:.4rem;padding:1rem .8rem;background:var(--surface);border-right:1px solid var(--border)}.sb-brand{display:flex;align-items:center;gap:.7rem;padding:.5rem .55rem 1rem}.sb-brand .mark{display:grid;place-items:center;width:2.4rem;height:2.4rem;flex:none;border-radius:var(--r-md);color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:var(--shadow-sm)}.sb-brand .mark svg{width:1.35rem;height:1.35rem}.sb-brand .t{line-height:1.15;overflow:hidden}.sb-brand strong{font-family:var(--font-display);font-size:.98rem;display:block;white-space:nowrap}.sb-brand small{color:var(--muted);font-size:.7rem;white-space:nowrap}.sb-section{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);padding:.4rem .7rem;margin-top:.4rem}.nav-item{display:flex;align-items:center;gap:.7rem;width:100%;padding:.62rem .7rem;border:none;background:none;cursor:pointer;border-radius:var(--r-md);color:var(--text-2);font-size:.92rem;font-weight:600;text-align:left;position:relative;transition:background .15s var(--ease),color .15s var(--ease)}.nav-item svg{width:1.2rem;height:1.2rem;flex:none;color:var(--muted);transition:color .15s var(--ease)}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--primary-soft);color:var(--primary)}.nav-item.active svg{color:var(--primary)}.nav-item.active:before{content:"";position:absolute;left:-.8rem;top:50%;transform:translateY(-50%);width:3px;height:1.4rem;border-radius:var(--r-pill);background:var(--primary)}.sb-foot{margin-top:auto;display:flex;flex-direction:column;gap:.5rem;padding-top:.6rem;border-top:1px solid var(--border)}.sb-user{display:flex;align-items:center;gap:.6rem;padding:.35rem .4rem}.sb-user .initials{display:grid;place-items:center;width:2.1rem;height:2.1rem;flex:none;border-radius:50%;font-size:.78rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent))}.sb-user .t{line-height:1.2;overflow:hidden}.sb-user .t strong{font-family:var(--font-ui);font-size:.86rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user .t small{font-size:.72rem}.sb-foot .row{display:flex;align-items:center;gap:.4rem}.badge.super{color:var(--accent);background:var(--accent-soft);padding:.05rem .45rem;font-size:.68rem}.main{min-width:0;display:flex;flex-direction:column}.topbar-m{display:none}.page{padding:clamp(1.2rem,3vw,2.2rem) clamp(1rem,3.5vw,2.6rem);max-width:1200px;width:100%;margin:0 auto}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}.page-head .titles h1{font-size:clamp(1.4rem,3vw,1.9rem);font-weight:800}.page-head .titles p{color:var(--muted);margin-top:.35rem;max-width:60ch;font-size:.95rem}.refresh-pill{display:inline-flex;align-items:center;gap:.45rem;font-size:.76rem;color:var(--muted)}.refresh-pill .live{width:.5rem;height:.5rem;border-radius:50%;background:var(--success);box-shadow:0 0 0 3px var(--success-soft);animation:pulse 1.8s var(--ease) infinite}.panel{padding:clamp(1.2rem,2.5vw,1.8rem)}.panel+.panel{margin-top:1.4rem}.panel-head{display:flex;align-items:center;gap:.6rem;margin-bottom:1.2rem}.panel-head .ic{display:grid;place-items:center;width:2.4rem;height:2.4rem;border-radius:var(--r-md);background:var(--primary-soft);color:var(--primary);flex:none}.panel-head .ic svg{width:1.25rem;height:1.25rem}.panel-head h2{font-size:1.15rem}.panel-head p{font-size:.85rem;color:var(--muted);margin-top:.15rem}.form{display:grid;gap:1.1rem;max-width:720px}.form .grid2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}.callout{display:flex;gap:.6rem;padding:.85rem 1rem;border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border);font-size:.86rem;color:var(--text-2)}.callout svg{width:1.15rem;height:1.15rem;color:var(--primary);flex:none;margin-top:1px}.callout code{font-family:var(--font-mono);background:var(--surface-3);padding:.05rem .35rem;border-radius:5px;font-size:.85em}.form-actions{display:flex;align-items:center;gap:1rem}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface)}.table{width:100%;border-collapse:collapse;font-size:.88rem}.table th{position:sticky;top:0;z-index:1;text-align:left;white-space:nowrap;padding:.75rem .9rem;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);background:var(--surface-2);border-bottom:1px solid var(--border)}.table td{padding:.8rem .9rem;border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr{transition:background .12s var(--ease)}.table tbody tr:hover{background:var(--surface-2)}.table tbody tr:last-child td{border-bottom:none}.table .t-title{font-weight:600;color:var(--text)}.table .sub{display:block;color:var(--muted);font-size:.78rem;margin-top:.15rem}.table .center{text-align:center}.row-actions{display:flex;gap:.3rem;justify-content:flex-end}.fail-detail{font-size:.74rem;color:var(--danger);max-width:240px;margin-top:.3rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.disabled-row{opacity:.5}.t-empty{padding:3rem 1rem;text-align:center;color:var(--muted)}.t-empty .ic{display:grid;place-items:center;width:3rem;height:3rem;margin:0 auto .8rem;border-radius:var(--r-lg);background:var(--surface-2);color:var(--faint)}.t-empty .ic svg{width:1.5rem;height:1.5rem}.t-empty strong{display:block;color:var(--text);font-family:var(--font-display)}.adduser{display:grid;grid-template-columns:1.3fr 1fr auto;gap:.7rem;align-items:end;margin-bottom:1.3rem}.role-pills{display:flex;flex-wrap:wrap;gap:.4rem}.role-pill{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;padding:.32rem .7rem;border-radius:var(--r-pill);font-size:.78rem;font-weight:600;border:1px solid var(--border-strong);background:var(--surface);color:var(--muted);transition:all .15s var(--ease)}.role-pill:hover{border-color:var(--primary);color:var(--text)}.role-pill.on{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.role-pill svg{width:.85rem;height:.85rem}.role-pill.compact{padding:.25rem .6rem}.notice{text-align:center;max-width:460px;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}@media (max-width: 900px){.shell{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;z-index:80;width:264px;transform:translate(-100%);transition:transform .25s var(--ease);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#0b0f1780;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.topbar-m{display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}.topbar-m .brand-mini{display:flex;align-items:center;gap:.55rem;font-family:var(--font-display);font-weight:700}.topbar-m .brand-mini .mark{display:grid;place-items:center;width:1.9rem;height:1.9rem;border-radius:var(--r-sm);color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent))}.topbar-m .brand-mini .mark svg{width:1.05rem;height:1.05rem}.form .grid2,.adduser{grid-template-columns:1fr}}
