:root{color-scheme:light;--bg:#f5f5f7;--bg-grad-a:#fbfbfd;--bg-grad-b:#f2f2f5;--surface:#ffffff;--surface-2:#f5f5f7;--surface-hover:#fafafa;--border:#e8e8ed;--border-strong:#d2d2d7;--text:#1d1d1f;--text-muted:#6e6e73;--text-subtle:#86868b;--on-accent:#ffffff;--swatch-ring:rgba(0,0,0,0.10);--primary:#16a34a;--primary-hover:#15803d;--primary-soft:#dcfce7;--primary-ring:rgba(22,163,74,0.32);--accent:#22c55e;--info:#0071e3;--info-soft:#e8f1fd;--danger:#d70015;--danger-hover:#b8000f;--danger-soft:#fdecec;--warn:#b45309;--warn-soft:#fef3c7;--ink:#1d1d1f;--radius-sm:9px;--radius:14px;--radius-lg:20px;--radius-pill:999px;--shadow-xs:0 1px 2px rgba(0,0,0,0.04);--shadow-sm:0 1px 3px rgba(0,0,0,0.06);--shadow:0 4px 16px rgba(0,0,0,0.06);--shadow-md:0 12px 34px rgba(0,0,0,0.10);--ease:cubic-bezier(0.4,0,0.2,1);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Plus Jakarta Sans,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}:root[data-theme=dark]{color-scheme:dark;--bg:#0a0a0c;--bg-grad-a:#161618;--bg-grad-b:#0a0a0c;--surface:#1c1c1e;--surface-2:#2c2c2e;--surface-hover:#242426;--border:#38383a;--border-strong:#48484a;--text:#f5f5f7;--text-muted:#aeaeb2;--text-subtle:#8e8e93;--on-accent:#06140b;--swatch-ring:rgba(255,255,255,0.16);--primary:#30d158;--primary-hover:#4ade80;--primary-soft:#0f2c1c;--primary-ring:rgba(48,209,88,0.4);--accent:#30d158;--info:#0a84ff;--info-soft:#0a2540;--danger:#ff453a;--danger-hover:#ff6961;--danger-soft:#2c1518;--warn:#ffd60a;--warn-soft:#2a2310;--ink:#f5f5f7;--shadow-xs:0 1px 2px rgba(0,0,0,0.5);--shadow-sm:0 1px 3px rgba(0,0,0,0.5);--shadow:0 6px 18px rgba(0,0,0,0.55);--shadow-md:0 16px 36px rgba(0,0,0,0.6)}*,:after,:before{box-sizing:border-box}*{margin:0}html{-webkit-text-size-adjust:100%}body{min-height:100dvh;background:radial-gradient(1200px 600px at 100% -10%,var(--bg-grad-a),transparent 60%),var(--bg-grad-b);line-height:1.6;font-size:16px;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body,h1,h2,h3,h4{color:var(--text)}h1,h2,h3,h4{line-height:1.25;font-weight:700;letter-spacing:-.01em}p{margin:0}a{color:var(--info);text-decoration:none;transition:color .15s var(--ease)}a:hover{color:var(--primary)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}::selection{background:var(--primary-soft);color:var(--text)}.page{max-width:980px;margin:0 auto;padding:32px 20px 80px}.page--narrow{max-width:720px}.page--wide{max-width:1100px}.page--runner{max-width:1240px}.stack{display:grid;gap:14px}.stack-lg{display:grid;gap:28px}.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;margin-bottom:28px}.topbar__left{justify-self:start;display:flex;align-items:center;gap:10px;min-width:0}.topbar__center{justify-self:center}.topbar--nav{position:sticky;top:0;z-index:30;grid-template-columns:1fr auto;margin:-32px -20px 24px;padding:13px 20px;background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--border)}.topbar__back{margin-left:4px}.topbar__actions,.topbar__right{justify-self:end;display:flex;align-items:center;gap:12px;min-width:0}.brand--logo{padding:7px 14px;border-radius:12px}.brandlogo__img{height:54px}:root[data-theme=dark] .brand--logo{background:#fff;box-shadow:var(--shadow-sm)}@media (max-width:960px){.topbar--nav .topbar__actions .btn,.topbar--nav .topbar__right .btn{width:36px;padding:0;gap:0;font-size:0;justify-content:center}}@media (max-width:720px){.topbar{display:flex;flex-direction:column;gap:12px}.topbar__left:empty{display:none}.topbar__actions,.topbar__right{justify-self:auto;flex-wrap:wrap;justify-content:center}.topbar__left{justify-self:auto}.runner-bar__title{display:none}.topbar--nav .brandlogo__img{height:42px}}.brand{display:flex;align-items:center;gap:12px;min-width:0;text-decoration:none;color:inherit;border-radius:12px;transition:opacity .15s var(--ease)}a.brand:hover{opacity:.82;color:inherit}a.brand:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.brand__mark{width:38px;height:38px;flex:none;display:grid;place-items:center;border-radius:11px;color:#fff;background:linear-gradient(135deg,#16a34a,#0ea5e9);box-shadow:var(--shadow-sm)}.brand__mark--bare{width:auto;height:auto;background:none;box-shadow:none;border-radius:0}.brand__title{display:block;font-size:18px;font-weight:700;letter-spacing:-.02em;line-height:1.2}.brand__sub{display:block;font-size:12px;color:var(--text-subtle);font-weight:500}.crumb{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:14px;transition:color .15s var(--ease),gap .15s var(--ease)}.crumb:hover{color:var(--text);gap:8px}.head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.head__title{font-size:26px}.head__meta{margin-top:4px;font-size:13px;color:var(--text-subtle);font-weight:500}.btn{--btn-bg:var(--surface);--btn-fg:var(--text);--btn-bd:var(--border-strong);display:inline-flex;align-items:center;justify-content:center;gap:7px;height:40px;padding:0 16px;font-family:inherit;font-size:14px;font-weight:600;line-height:1;color:var(--btn-fg);background:var(--btn-bg);border:1px solid var(--btn-bd);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background .15s var(--ease),border-color .15s var(--ease),transform .12s var(--ease),box-shadow .15s var(--ease),color .15s var(--ease)}.btn:hover{--btn-bg:var(--surface-2);border-color:var(--text-subtle)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn--primary{--btn-bg:var(--primary);--btn-fg:var(--on-accent);--btn-bd:transparent;box-shadow:var(--shadow-sm),inset 0 1px 0 rgba(255,255,255,.15)}.btn--primary:hover{--btn-bg:var(--primary-hover);border-color:transparent}.btn--ghost{--btn-bg:transparent;--btn-bd:transparent}.btn--ghost:hover{--btn-bg:var(--surface-2);border-color:var(--border)}.btn--sm{height:32px;padding:0 12px;font-size:13px}.btn--lg{height:48px;padding:0 22px;font-size:15px;border-radius:var(--radius)}.linkbtn{font-family:inherit;font-size:13px;font-weight:600;color:var(--info);background:none;border:none;padding:4px 6px;border-radius:6px;cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease)}.linkbtn:hover{background:var(--info-soft)}.linkbtn--danger{color:var(--danger)}.linkbtn--danger:hover{background:var(--danger-soft)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card--pad{padding:20px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}.section-title{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px}.section-title svg{color:var(--text-subtle)}.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.tile{position:relative;height:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .16s var(--ease),box-shadow .16s var(--ease),border-color .16s var(--ease),opacity .16s var(--ease)}.tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.tile--dragging{opacity:.5}.tile__link{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;padding:22px 18px;text-decoration:none;color:inherit;height:100%}.tile__sub{font-size:12.5px;line-height:1.4;color:var(--text-muted)}.tile>.tile__status{position:absolute;top:8px;left:8px;z-index:2}.status-pill{display:inline-flex;align-items:center;height:22px;border-radius:var(--radius-pill);background:var(--surface);border:1px solid var(--primary);color:var(--primary);overflow:hidden;transition:padding .16s var(--ease)}.status-pill__i{flex:none;width:20px;height:20px;display:grid;place-items:center;font-size:12px;font-weight:700;font-style:italic;font-family:Georgia,Times New Roman,serif}.status-pill__text{max-width:0;opacity:0;white-space:nowrap;font-size:11.5px;font-weight:600;text-transform:capitalize;transition:max-width .2s var(--ease),opacity .15s var(--ease)}.status-pill:focus-within .status-pill__text,.status-pill:hover .status-pill__text{max-width:80px;opacity:1;padding-right:8px}.status-pill--draft{border-color:var(--warn);color:var(--warn)}.status-pill--off{border-color:var(--text-subtle);color:var(--text-subtle)}.tile__open-btn{display:inline-flex;align-items:center;gap:4px;height:30px;padding:0 15px;font-size:13.5px;font-weight:600;color:var(--primary-hover);background:var(--primary-soft);border-radius:var(--radius-pill);transition:background .15s var(--ease)}.tile:hover .tile__open-btn{background:color-mix(in srgb,var(--primary) 18%,var(--primary-soft))}.tile__grip{position:absolute;top:8px;right:8px;z-index:2;display:grid;place-items:center;width:28px;height:28px;padding:0;color:var(--text-subtle);background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:grab;opacity:0;transition:opacity .15s var(--ease),background .15s var(--ease),color .15s var(--ease)}.tile:hover .tile__grip,.tile__grip:focus-visible{opacity:1}.tile__grip:hover{color:var(--text);background:var(--surface-2)}.tile__grip:active{cursor:grabbing}@media (hover:none){.tile__grip{opacity:1}}.tile__icon--img{background:var(--surface-2);padding:0;overflow:hidden}.dot.tile__icon--img img,.tile__icon--img img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.tile__top{display:flex;align-items:center;justify-content:center}.tile__icon{width:60px;height:60px;flex:none;display:grid;place-items:center;border-radius:14px;font-size:24px;font-weight:700;color:#fff;background:var(--tile-accent,var(--primary));box-shadow:0 3px 8px color-mix(in srgb,var(--text) 14%,transparent),inset 0 0 0 1px color-mix(in srgb,var(--text) 7%,transparent)}.tile__open{color:var(--text-subtle);opacity:0;transform:translateX(-4px);transition:opacity .16s var(--ease),transform .16s var(--ease)}.tile__name{font-size:16px;font-weight:700;letter-spacing:-.01em;line-height:1.3;color:var(--text)}.tile__foot{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;margin-top:4px}.rows{display:grid;gap:8px;list-style:none;padding:0}.row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background .15s var(--ease),border-color .15s var(--ease),transform .15s var(--ease)}.row:hover{background:var(--surface-hover);border-color:var(--border-strong)}.row__main{display:flex;align-items:center;gap:11px;min-width:0;text-decoration:none;color:inherit}.row__name{font-weight:650;color:var(--text)}.row--compact{padding:9px 12px;font-size:13px}.dot{width:30px;height:30px;flex:none;display:grid;place-items:center;border-radius:9px;font-size:13px;font-weight:700;color:#fff;background:var(--tile-accent,var(--primary))}.badge{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 9px;font-size:11.5px;font-weight:600;letter-spacing:.01em;border-radius:var(--radius-pill);color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border);text-transform:capitalize}.badge--live{color:var(--primary);background:var(--primary-soft);border-color:transparent}.badge--live .badge__dot{background:var(--primary)}.badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge--draft{color:var(--warn);background:var(--warn-soft);border-color:transparent}.field{display:grid;gap:6px}.label{font-size:13px;font-weight:600;color:var(--text)}.help{font-size:12px;color:var(--text-subtle);line-height:1.5}.input,.select,.textarea{width:100%;font-family:inherit;font-size:14px;color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}.input,.select{height:40px;padding:0 12px}.input::placeholder{color:var(--text-muted)}:root[data-theme=dark] .input::placeholder{color:var(--text-subtle)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a94a3' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.textarea{padding:12px;font-family:var(--font-mono);font-size:13px;line-height:1.6;resize:vertical;min-height:200px;tab-size:2}.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.inline-form .input{flex:1 1 220px;min-width:0}.inline-form .select{flex:0 0 auto;width:auto;min-width:0;padding-right:30px;background-position:right 9px center}.editor{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:18px;align-items:start}.editor__col{gap:14px}.editor__col,.preview-resize{display:flex;flex-direction:column}.preview-resize{resize:vertical;overflow:hidden;height:520px;min-height:260px}.preview-resize>.mini-host{flex:1;min-height:0}.preview-resize .mini-frame--preview{flex:1;height:auto;min-height:0}.preview-pane{background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:var(--radius);padding:14px}.preview-empty{display:grid;gap:6px;place-items:center;text-align:center;min-height:220px;color:var(--text-subtle);font-size:13px}.frame-chrome{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.frame-chrome__title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frame-chrome__actions{margin-left:auto;gap:6px;flex:none}.frame-chrome__actions,.lock-pill{display:inline-flex;align-items:center}.lock-pill{gap:5px;height:22px;padding:0 9px;font-size:11.5px;font-weight:600;border-radius:var(--radius-pill);color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border)}.mini-host{display:flex;flex-direction:column;gap:8px}.mini-host--full{flex:1;min-height:0;gap:0}.mini-frame{width:100%;height:min(78vh,880px);min-height:420px;border:1px solid var(--border-strong);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow)}.mini-frame--preview{height:380px}.mini-frame--full{flex:1;min-height:0;height:auto;border:none;border-radius:0;box-shadow:none}.runner-full{display:flex;flex-direction:column;height:100dvh}.runner-bar{flex:none;min-height:58px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:6px 16px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-xs)}.runner-bar__title{justify-self:start;display:flex;align-items:center;gap:9px;font-size:14px;font-weight:700;min-width:0}.runner-bar__title .row__name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.runner-bar__left{display:flex;align-items:center;gap:12px;min-width:0}.runner-bar__left .brand__title{font-size:14px}.runner-bar__sep{color:var(--border-strong);font-weight:400}.runner-bar--nav{grid-template-columns:1fr auto}.runner-bar--nav .brandlogo__img{height:34px}.grid-hint{margin-left:auto;font-size:12px;font-weight:500;color:var(--text-subtle)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto}.tab{display:inline-flex;align-items:center;gap:7px;padding:10px 14px;font-family:inherit;font-size:14px;font-weight:600;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;white-space:nowrap;transition:color .15s var(--ease),border-color .15s var(--ease)}.tab:hover{color:var(--text)}.tab--active{color:var(--primary);border-bottom-color:var(--primary)}.tab__count{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;border-radius:var(--radius-pill);color:var(--text-muted);background:var(--surface-2)}.tab--active .tab__count{color:var(--primary);background:var(--primary-soft)}.tabs__action{margin-left:auto;align-self:center;margin-bottom:6px;flex:none}.tab-panel{animation:tab-in .16s var(--ease)}@keyframes tab-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}.version__info{display:flex;flex-direction:column;gap:3px;min-width:0}.version__head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.version__time{font-size:12px;color:var(--text-muted)}.version__note{font-size:13px;color:var(--text-muted);overflow-wrap:anywhere}.appearance-preview{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.swatches{display:flex;flex-wrap:wrap;gap:8px}.swatch{width:30px;height:30px;display:grid;place-items:center;padding:0;border-radius:9px;border:1px solid var(--swatch-ring);color:#fff;cursor:pointer;transition:transform .12s var(--ease),box-shadow .12s var(--ease)}.swatch:hover{transform:translateY(-1px)}.swatch.is-selected{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--primary)}.swatch--default{background:var(--surface);color:var(--text-muted);font-size:12px;font-weight:700;border-color:var(--border-strong)}.swatch--custom{position:relative;overflow:hidden;background:conic-gradient(from 0deg,#f87171,#fbbf24,#34d399,#60a5fa,#a78bfa,#f87171)}.swatch--custom input[type=color]{position:absolute;inset:-6px;width:calc(100% + 12px);height:calc(100% + 12px);padding:0;border:none;background:none;cursor:pointer;opacity:0}.logo-row{display:flex;align-items:center;gap:14px}.logo-row__actions{display:flex;gap:8px;flex-wrap:wrap}.toast{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;padding:9px 12px;border-radius:var(--radius-sm);background:var(--info-soft);color:var(--info);border:1px solid transparent;animation:toast-in .2s var(--ease)}.toast--error{background:var(--danger-soft);color:var(--danger)}@keyframes toast-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.empty{display:grid;place-items:center;gap:12px;text-align:center;padding:48px 24px;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius)}.empty__icon{width:48px;height:48px;display:grid;place-items:center;border-radius:14px;color:var(--text-subtle);background:var(--surface-2)}.empty__title{font-size:16px;font-weight:700}.empty__text{font-size:14px;color:var(--text-muted);max-width:42ch}.auth{min-height:100dvh;display:grid;place-items:center;padding:24px}.auth__inner{display:grid;gap:22px;justify-items:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.muted{color:var(--text-muted)}.subtle{color:var(--text-subtle)}.mono{font-family:var(--font-mono)}.text-sm{font-size:13px}.text-xs{font-size:12px}@media (max-width:720px){.page{padding:22px 16px 64px}.editor{grid-template-columns:1fr}.head__title{font-size:22px}.tile-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.dash-section{display:grid;gap:14px}.dash-section+.dash-section{margin-top:32px}.dash-section__head{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}.dash-section__title{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.01em}.dash-section__count{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 6px;font-size:11.5px;font-weight:700;border-radius:var(--radius-pill);color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border)}.dash-section__hint{margin-left:auto;font-size:12px;font-weight:500;color:var(--text-subtle)}.empty--inline{margin-top:24px;padding:28px 20px}.granter{display:inline-flex;align-items:center;gap:5px;margin-top:8px;max-width:100%;height:22px;padding:0 9px;font-size:11.5px;font-weight:600;border-radius:var(--radius-pill);color:var(--info);background:var(--info-soft);border:1px solid transparent}.granter--muted{color:var(--text-muted);background:var(--surface-2);border-color:var(--border)}.granter__email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-row{justify-content:space-between;gap:12px;padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.member-row,.member-row__id{display:flex;align-items:center}.member-row__id{gap:10px;min-width:0}.member-row__email{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis}.role-seg{display:inline-flex;padding:3px;gap:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill)}.role-seg__opt{appearance:none;border:none;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600;padding:5px 12px;border-radius:var(--radius-pill);color:var(--text-muted);background:transparent;transition:background .15s var(--ease),color .15s var(--ease)}.role-seg__opt:hover{color:var(--text)}.role-seg__opt.is-active{color:var(--on-accent);background:var(--primary);box-shadow:var(--shadow-xs)}.role-chip{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 9px;font-size:11.5px;font-weight:600;text-transform:capitalize;border-radius:var(--radius-pill);color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border)}.role-chip--edit{color:var(--primary);background:var(--primary-soft);border-color:transparent}.landing{min-height:100dvh;display:flex;flex-direction:column}.landing main{flex:1 0 auto}.lnav{position:sticky;top:14px;z-index:20;width:100%;max-width:1080px;margin:14px auto 0;padding:0 16px}.lnav__inner{gap:24px;padding:8px 14px 8px 16px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--surface) 62%,transparent);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border:1px solid color-mix(in srgb,var(--border-strong) 55%,transparent);box-shadow:var(--shadow),inset 0 1px 0 color-mix(in srgb,#fff 35%,transparent)}.lnav__inner,.lnav__links{display:flex;align-items:center}.lnav__links{gap:6px;margin-left:8px;margin-right:auto}.lnav__link{padding:8px 12px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:color .15s var(--ease),background .15s var(--ease)}.lnav__link:hover{color:var(--text);background:var(--surface-2)}.lnav__actions{display:flex;align-items:center;gap:10px}.hero{max-width:1120px;margin:0 auto;padding:clamp(48px,8vw,96px) 24px 32px;text-align:center}.hero__eyebrow{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:var(--radius-pill);background:var(--primary-soft);color:var(--primary-hover);border:1px solid color-mix(in srgb,var(--primary) 22%,transparent);font-size:13px;font-weight:700}.hero__title{margin:22px 0 0;font-size:clamp(2.4rem,6vw,4rem);line-height:1.05;letter-spacing:-.02em;font-weight:800;color:var(--ink)}.hero__lede{max-width:620px;margin:20px auto 0;font-size:clamp(1.05rem,2vw,1.2rem);line-height:1.6;color:var(--text-muted)}.hero__cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:30px}.hero__panel{max-width:760px;margin:56px auto 0;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-md);overflow:hidden}.hero__panelbar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.hero__dot{width:11px;height:11px;border-radius:50%;background:var(--border-strong)}.hero__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:22px}.hero__tile{display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:18px;border-radius:var(--radius);background:var(--bg);border:1px solid var(--border);text-align:left;animation:tilein .52s var(--ease) both;animation-delay:calc(var(--i) * 70ms)}.hero__tileicon{width:38px;height:38px;display:grid;place-items:center;border-radius:11px;background:var(--primary-soft);color:var(--primary-hover)}.hero__tilename{font-weight:700;font-size:14px;color:var(--text)}@keyframes tilein{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.lsection{max-width:1120px;margin:0 auto;padding:clamp(56px,9vw,96px) 24px}.lsection--alt{max-width:none;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.lsection--alt>*{max-width:1120px;margin-left:auto;margin-right:auto}.lsection__head{text-align:center;max-width:640px;margin:0 auto 44px}.lsection__title{font-size:clamp(1.7rem,4vw,2.4rem);line-height:1.15;letter-spacing:-.015em;font-weight:800;color:var(--ink);margin:0}.lsection__sub{margin:14px 0 0;font-size:1.05rem;line-height:1.6;color:var(--text-muted)}.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.fcard{padding:26px 24px;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-xs);transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease)}.fcard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--border-strong)}.fcard__icon{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--primary-soft);color:var(--primary-hover);margin-bottom:16px}.fcard__title{margin:0 0 8px;font-size:1.15rem;font-weight:700;color:var(--text)}.fcard__body{margin:0;font-size:.96rem;line-height:1.6;color:var(--text-muted)}.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:step}.step{text-align:center;padding:0 8px}.step__n{display:grid;place-items:center;width:46px;height:46px;margin:0 auto 16px;border-radius:50%;background:var(--primary);color:var(--on-accent);font-weight:800;font-size:1.1rem;box-shadow:var(--shadow-sm)}.step__title{margin:0 0 8px;font-size:1.1rem;font-weight:700;color:var(--text)}.step__body{margin:0;font-size:.96rem;line-height:1.6;color:var(--text-muted)}.cta{padding:clamp(56px,9vw,88px) 24px}.cta__inner{max-width:880px;margin:0 auto;text-align:center;padding:clamp(40px,6vw,64px) 32px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary),var(--primary-hover));color:var(--on-accent);box-shadow:var(--shadow-md)}.cta__title{margin:0;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800;letter-spacing:-.015em}.cta__sub{margin:12px 0 0;font-size:1.05rem;opacity:.92}.btn--oncta{--btn-bg:#fff;--btn-fg:#15803d;--btn-bd:transparent;font-weight:700}.btn--oncta:hover{--btn-bg:#f3fbf5;border-color:transparent}.lfooter{flex:none;border-top:1px solid var(--border);background:var(--surface)}.lfooter__inner{max-width:1120px;margin:0 auto;padding:24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.lfooter__copy{font-size:.9rem;color:var(--text-subtle)}@media (max-width:860px){.fgrid,.hero__grid,.steps{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.lnav__links{display:none}.fgrid,.hero__grid,.steps{grid-template-columns:1fr}}.id-cluster{display:inline-flex;align-items:center;gap:8px;padding:4px 8px;background:color-mix(in srgb,var(--surface) 86%,transparent);border:1px solid var(--border);border-radius:var(--radius-pill);box-shadow:var(--shadow-xs)}.spinner{width:18px;height:18px;border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;flex:none}@keyframes spin{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.spinner{animation-duration:1.4s}}.route-loading{display:grid;place-items:center;align-content:center;gap:14px;min-height:55vh;color:var(--text-muted);font-size:14px;font-weight:500}.route-loading .spinner{width:30px;height:30px;border-width:3px}.route-loading__bar{position:fixed;top:0;left:0;right:0;height:3px;z-index:50;background:linear-gradient(90deg,transparent,var(--primary),transparent);background-size:50% 100%;background-repeat:no-repeat;animation:slidebar 1.1s ease-in-out infinite}@keyframes slidebar{0%{background-position:-50% 0}to{background-position:150% 0}}.tile-new{display:grid;place-items:center;align-content:center;gap:10px;width:100%;min-height:100%;padding:24px;font:inherit;font-weight:600;font-size:14px;color:var(--text-subtle);background:color-mix(in srgb,var(--surface-2) 70%,transparent);border:1.5px dashed var(--border-strong);border-radius:var(--radius);cursor:pointer;transition:color .16s var(--ease),border-color .16s var(--ease),background .16s var(--ease),transform .16s var(--ease)}.tile-new:hover{color:var(--primary);border-color:var(--primary);background:var(--surface-hover);transform:translateY(-3px)}.tile-new:disabled{opacity:.6;cursor:progress;transform:none}.tile-new__plus{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;background:var(--surface);border:1px solid var(--border);color:currentColor}.danger-zone{margin-top:28px;padding:18px 20px;border:1px solid color-mix(in srgb,var(--danger) 35%,var(--border));border-radius:var(--radius);background:color-mix(in srgb,var(--danger-soft) 55%,var(--surface))}.danger-zone__title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--danger);margin-bottom:4px}.danger-zone__text{font-size:13px;color:var(--text-muted);margin-bottom:14px}.delete-confirm{display:grid;gap:10px;max-width:380px}.delete-confirm__label{font-size:12.5px;color:var(--text-muted)}.delete-confirm__label code{font-family:var(--font-mono);font-weight:700;color:var(--danger);background:var(--danger-soft);padding:1px 6px;border-radius:5px}.btn--danger{--btn-bg:var(--danger);--btn-fg:#fff;--btn-bd:transparent}.btn--danger:hover{--btn-bg:var(--danger-hover);border-color:transparent}.btn--danger:disabled{--btn-bg:var(--danger)}:root[data-theme=dark] .btn--danger{--btn-bg:#b91c1c}:root[data-theme=dark] .btn--danger:hover{--btn-bg:#991b1b}:root[data-theme=dark] .btn--danger:disabled{--btn-bg:#b91c1c}.vis-panel{display:grid;gap:14px;margin:0 0 22px;padding:16px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xs)}.vis-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.vis-row+.vis-row{padding-top:14px;border-top:1px solid var(--border)}.vis-row__main{min-width:0}.vis-row__title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}.vis-row__title svg{color:var(--text-subtle)}.vis-row__desc{font-size:12.5px;line-height:1.5;color:var(--text-muted);max-width:62ch}.tile--unavailable{opacity:.6;filter:grayscale(.65)}.tile--unavailable:hover{transform:none;box-shadow:var(--shadow-sm);border-color:var(--border)}.tile--unavailable .tile__link{cursor:not-allowed}.crumbs{display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0;font-size:14.5px;font-weight:600}.crumbs__sep{color:var(--text-subtle);font-weight:400}.crumbs__link{color:var(--text-muted);text-decoration:none;padding:3px 7px;border-radius:var(--radius-sm);transition:color .15s var(--ease),background .15s var(--ease);white-space:nowrap}.crumbs__link:hover{color:var(--text);background:var(--surface-2)}.crumbs__current{color:var(--text);padding:3px 7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:30ch}.view-toggle{display:inline-flex;padding:3px;gap:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.view-toggle__btn{display:grid;place-items:center;width:30px;height:28px;border-radius:5px;color:var(--text-subtle);appearance:none;font:inherit;cursor:pointer;background:transparent;border:1px solid transparent;transition:color .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease)}.view-toggle__btn:hover{color:var(--text)}.view-toggle__btn.is-active{color:var(--primary);background:var(--surface);border-color:var(--border-strong);box-shadow:var(--shadow-xs)}.mini-rows{display:grid;gap:8px;max-width:680px}.mini-row{position:relative;display:flex;align-items:center;gap:8px;padding:0 10px 0 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xs);overflow:hidden;transition:border-color .16s var(--ease),box-shadow .16s var(--ease),opacity .16s var(--ease)}.mini-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--tile-accent,var(--primary));opacity:.9}.mini-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.mini-row--dragging{opacity:.5}.mini-row__main{display:flex;align-items:center;gap:11px;flex:1;min-width:0;padding:11px 8px 11px 14px;text-decoration:none;color:inherit}.mini-row__main .tile__icon{width:34px;height:34px;border-radius:9px;font-size:13px;flex:none}.mini-row__name{font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-row__shared{font-size:12px;color:var(--text-subtle);white-space:nowrap}.mini-row__actions{display:flex;align-items:center;gap:6px;flex:none}.mini-row__gear,.mini-row__open{display:grid;place-items:center;width:30px;height:30px;color:var(--text-muted);background:transparent;border:1px solid transparent;border-radius:8px;transition:color .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease)}.mini-row__gear{cursor:pointer}.mini-row__gear:hover{color:var(--text);background:var(--surface-2);border-color:var(--border-strong)}.mini-row--dragging .mini-row__gear,.mini-row__gear:active{cursor:grabbing}.mini-row__open:hover{color:var(--primary);background:var(--surface-2);border-color:var(--border-strong)}.mini-row--unavailable{opacity:.78}.mini-row--unavailable .tile__icon{filter:grayscale(.7)}.mini-row--unavailable:before{background:var(--text-subtle);opacity:.5}.mini-row--unavailable .mini-row__main{cursor:not-allowed}.mini-row--unavailable .mini-row__shared{color:var(--text-muted)}.mini-row--new{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;font:inherit;font-weight:600;font-size:14px;color:var(--text-subtle);background:color-mix(in srgb,var(--surface-2) 70%,transparent);border:1.5px dashed var(--border-strong);border-radius:var(--radius);cursor:pointer;transition:color .16s var(--ease),border-color .16s var(--ease),background .16s var(--ease)}.mini-row--new:hover{color:var(--primary);border-color:var(--primary);background:var(--surface-hover)}.mini-row--new:disabled{opacity:.6;cursor:progress}.mini-row--new .tile-new__plus{width:30px;height:30px}.rename{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.rename__input{font-family:inherit;font-size:clamp(1.3rem,3vw,1.6rem);font-weight:700;letter-spacing:-.01em;color:var(--text);background:transparent;border:none;border-bottom:1.5px dashed var(--border-strong);padding:2px 2px 3px;min-width:0;width:100%;max-width:28ch;border-radius:4px;transition:border-color .15s var(--ease),background .15s var(--ease)}.rename__input::placeholder{color:var(--text-subtle)}.rename__input:hover{border-bottom-color:var(--text-subtle)}.rename__input:focus{outline:none;border-bottom-color:var(--primary);background:var(--surface-2)}.icon-btn{display:grid;place-items:center;width:34px;height:34px;flex:none;appearance:none;font:inherit;cursor:pointer;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);box-shadow:var(--shadow-xs);transition:color .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease)}.icon-btn:hover{color:var(--text);background:var(--surface-2);border-color:var(--border-strong)}.searchbar{position:relative;display:flex;align-items:center;max-width:460px;margin:0 0 22px}.searchbar__icon{position:absolute;left:13px;color:var(--text-subtle);pointer-events:none}.searchbar__input{width:100%;height:40px;padding:0 14px 0 38px;font-family:inherit;font-size:15px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);box-shadow:var(--shadow-xs);transition:background .15s var(--ease),border-color .15s var(--ease),box-shadow .15s var(--ease)}.searchbar__input::placeholder{color:var(--text-subtle)}.searchbar__input:focus{outline:none;background:var(--surface);border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.searchbar__input::-webkit-search-cancel-button,.searchbar__input::-webkit-search-decoration{-webkit-appearance:none;appearance:none}.tile__icon{border-radius:22%}.tile__icon,.tile__icon--img{box-shadow:inset 0 0 0 1px var(--swatch-ring)}.dash-section__title{font-size:17px;letter-spacing:-.02em}.lnav{-webkit-backdrop-filter:saturate(150%) blur(12px)}@media (max-width:720px){.topbar--nav{margin:-22px -16px 20px;padding:13px 16px}}.tile>.tile__corner{position:absolute;top:8px;right:8px;z-index:2;display:flex;align-items:center;gap:6px}.tile__corner .tile__grip,.tile__corner .tile__share{position:static;opacity:0;pointer-events:none;transition:opacity .15s var(--ease),background .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease)}.tile:hover .tile__grip,.tile:hover .tile__share,.tile__corner:focus-within .tile__grip,.tile__corner:focus-within .tile__share{opacity:1;pointer-events:auto}@media (hover:none){.tile__corner .tile__grip,.tile__corner .tile__share{opacity:1;pointer-events:auto}}.tile__corner .tile__grip,.tile__share{display:grid;place-items:center;width:28px;height:28px;padding:0;color:var(--text-subtle);background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease)}.tile__share:hover{color:var(--primary);background:var(--surface-2);border-color:var(--border-strong)}.mini-row__share{display:grid;place-items:center;width:30px;height:30px;color:var(--text-muted);background:transparent;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:color .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease)}.mini-row__share:hover{color:var(--primary);background:var(--surface-2);border-color:var(--border-strong)}.modal-overlay{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:20px;background:rgba(0,0,0,.45);backdrop-filter:saturate(140%) blur(3px);-webkit-backdrop-filter:saturate(140%) blur(3px);animation:modal-fade .16s var(--ease)}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:460px;max-height:min(86vh,680px);overflow-y:auto;padding:20px 22px 22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);animation:modal-pop .2s var(--ease)}@keyframes modal-pop{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){.modal,.modal-overlay{animation:none}}.modal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.modal__title{font-size:17px;font-weight:700;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal__close{flex:none;width:30px;height:30px;display:grid;place-items:center;font-size:22px;line-height:1;color:var(--text-subtle);background:transparent;border:none;border-radius:8px;cursor:pointer;transition:color .15s var(--ease),background .15s var(--ease)}.modal__close:hover{color:var(--text);background:var(--surface-2)}.modal__more{display:inline-block;margin-top:16px;font-size:13px;font-weight:600}.glow-card{position:relative;isolation:isolate}.glow-card:after{content:"";position:absolute;inset:0;border-radius:inherit;z-index:0;pointer-events:none;background:radial-gradient(110px circle at var(--gx,50%) var(--gy,50%),color-mix(in srgb,var(--primary) 14%,transparent),transparent 60%);opacity:calc(var(--glow, 0) * .6);transition:opacity .12s linear}.glow-card>*{position:relative;z-index:1}@media (prefers-reduced-motion:reduce){.glow-card:after{transition:none}}.hero__accent{background:linear-gradient(120deg,#16a34a,#0ea5e9 70%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.hero{position:relative}.hero__glows{position:absolute;inset:-40px 0 0;z-index:-1;pointer-events:none;overflow:hidden}.hero__glow{position:absolute;border-radius:50%;filter:blur(46px);background:radial-gradient(circle,color-mix(in srgb,var(--primary) 26%,transparent),transparent 70%);animation:glow-breathe 7s ease-in-out infinite}.hero__glow--1{width:300px;height:300px;top:2%;left:30%;animation-delay:0s}.hero__glow--2{width:240px;height:240px;top:16%;left:56%;animation-delay:2.3s;background:radial-gradient(circle,color-mix(in srgb,#0ea5e9 24%,transparent),transparent 70%)}.hero__glow--3{width:210px;height:210px;top:30%;left:42%;animation-delay:4.4s}@keyframes glow-breathe{0%,to{transform:scale(.82);opacity:.45}50%{transform:scale(1.18);opacity:.85}}@media (prefers-reduced-motion:reduce){.hero__glow{animation:none}}.lnav__link{font-size:15px}.lnav .btn{font-size:14px;height:36px}.lnav .btn,.lnav .icon-btn{box-shadow:inset 0 0 0 1px color-mix(in srgb,#fff 32%,transparent),0 0 12px color-mix(in srgb,#b6bdca 40%,transparent)}.lnav .btn:hover,.lnav .icon-btn:hover{box-shadow:inset 0 0 0 1px color-mix(in srgb,#fff 45%,transparent),0 0 16px color-mix(in srgb,#c2c9d6 60%,transparent)}:root[data-theme=dark] .lnav .btn,:root[data-theme=dark] .lnav .icon-btn{box-shadow:inset 0 0 0 1px color-mix(in srgb,#fff 14%,transparent),0 0 14px color-mix(in srgb,#aeb6c4 22%,transparent)}.btn--lg.btn--oncta:hover,.btn--lg.btn--primary:hover{box-shadow:var(--shadow),0 10px 30px color-mix(in srgb,var(--primary) 28%,transparent)}