:root{--accent: #0e9f6e;--accent-700: #0b7e57;--accent-50: #e7f6f0;--bg: #f4f6f8;--surface: #ffffff;--surface-2: #f9fafb;--border: #e4e8ec;--border-strong: #d4dade;--text: #14201b;--text-2: #5b6b66;--muted: #8a9893;--s-success: #16a34a;--s-failed: #dc2626;--s-running: #2563eb;--s-queued: #94a3b8;--s-upstream: #f59e0b;--s-skipped: #cbd5e1;--s-none: #eef1f3;--radius: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 2px rgba(16, 32, 27, .06);--shadow: 0 4px 18px rgba(16, 32, 27, .08);--font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}code{font-family:var(--mono);font-size:.86em}h1,h2,h3{margin:0}.muted{color:var(--muted);font-size:13px}.mono{font-family:var(--mono)}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.splash{display:grid;place-items:center;height:100vh;color:var(--text-2)}.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:8px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,box-shadow .15s,opacity .15s}.btn:hover{background:var(--surface-2)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-700);border-color:var(--accent-700)}.btn--ghost{background:transparent;border-color:var(--border)}.btn--ghost:hover{background:var(--surface-2)}.btn--ghost.danger{color:var(--s-failed)}.btn--danger{background:var(--s-failed);border-color:var(--s-failed);color:#fff}.btn--danger:hover{background:#b91c1c;border-color:#b91c1c}.btn--block{width:100%;justify-content:center}.btn--sm{padding:5px 10px;font-size:12.5px}.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer}.iconbtn:hover{background:var(--surface-2);color:var(--text)}.iconbtn.danger:hover{color:var(--s-failed);border-color:#f6c9c9}.link-btn{background:none;border:none;color:var(--accent-700);font-weight:600;cursor:pointer;font-size:13px;padding:4px}.link-btn:hover{text-decoration:underline}.field{display:flex;flex-direction:column;gap:6px}.field>span{font-size:13px;font-weight:600;color:var(--text-2)}.field .hint{font-size:12px;color:var(--muted);font-weight:500}input,select,textarea{font:inherit;font-size:14px;padding:9px 11px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);width:100%}textarea{resize:vertical;min-height:64px;font-family:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50)}.input-wrap{display:flex;align-items:center;gap:8px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:0 11px;background:var(--surface);color:var(--muted)}.input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50)}.input-wrap input{border:none;padding:9px 0;box-shadow:none}.input-wrap input:focus{box-shadow:none}.input-wrap--search{max-width:360px;flex:1}.form{display:flex;flex-direction:column;gap:16px}.form-error{background:#fdecec;color:#a11;border:1px solid #f6c9c9;padding:9px 12px;border-radius:var(--radius-sm);font-size:13px}.form-note{background:var(--accent-50);color:var(--accent-700);padding:9px 12px;border-radius:var(--radius-sm);font-size:13px}.form-grid{display:flex;flex-wrap:wrap;gap:14px;align-items:end}.form-grid .field{flex:1 1 200px;min-width:0}.form-grid .field--wide{flex-grow:3}.form-grid .toggle-field,.form-grid .checkbox-field{flex:0 0 auto}.form-grid .btn{flex:0 0 auto;height:40px;justify-content:center}.checkbox-field{display:flex;align-items:center;gap:8px;height:40px;font-size:13px;font-weight:600;color:var(--text-2)}.checkbox-field input{width:auto}.auth-page{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 500px at 50% -10%,#e9f6f0,var(--bg))}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}.auth-brand strong{display:block;font-size:16px}.auth-brand__sub{font-size:12.5px;color:var(--muted)}.auth-title{font-size:20px;margin-bottom:4px}.shell{display:flex;min-height:100%}.sidebar{width:248px;flex-shrink:0;background:#0f1c17;color:#cfe3da;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;transition:width .2s}.sidebar__brand{display:flex;align-items:center;gap:11px;padding:0 18px;height:56px;flex-shrink:0;width:100%;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.08);color:inherit;font:inherit;text-align:left;cursor:pointer;transition:padding .2s ease}.sidebar__brand:hover .sidebar__logo{background:var(--accent-700)}.sidebar__logo{width:39px;height:39px;border-radius:10px;background:var(--accent);color:#fff;font-weight:800;display:grid;place-items:center;font-size:20px;flex-shrink:0}.sidebar svg{flex-shrink:0}.sidebar__brand strong{color:#fff;display:block;line-height:1.1}.sidebar__sub{font-size:12px;color:#7fa595}.sidebar__nav{display:flex;flex-direction:column;gap:3px;padding:8px 12px;flex:1}.navitem{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);color:#b8cfc5;font-weight:600;font-size:14px;transition:padding .2s ease}.navitem:hover{background:#ffffff0f;color:#fff}.navitem.active{background:var(--accent);color:#fff}.sidebar__foot{padding:14px;border-top:1px solid rgba(255,255,255,.08)}.sidebar__user{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:7px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:padding .2s ease}.sidebar__user:hover{background:#ffffff0f}.sidebar__user.active{background:#ffffff1a}.avatar{width:36px;height:36px;border-radius:50%;background:#21443a;color:#fff;display:grid;place-items:center;font-weight:700;text-transform:uppercase;flex-shrink:0}.sidebar__userinfo{min-width:0}.sidebar__userinfo strong{display:block;color:#fff;font-size:13.5px;overflow:hidden;text-overflow:ellipsis}.sidebar__foot .btn--ghost{color:#cfe3da;border-color:#ffffff2e}.sidebar__foot .btn--ghost:hover{background:#ffffff14;color:#fff}.navitem__label,.sidebar__brand div,.sidebar__userinfo,.sidebar__foot .btn--ghost span{overflow:hidden;white-space:nowrap;max-width:160px;opacity:1;transition:max-width .2s ease,opacity .2s ease}.sidebar--collapsed{width:72px}.sidebar--collapsed .navitem__label,.sidebar--collapsed .sidebar__brand div,.sidebar--collapsed .sidebar__userinfo,.sidebar--collapsed .sidebar__foot .btn--ghost span{max-width:0;opacity:0}.sidebar--collapsed .sidebar__brand{padding-left:16px}.sidebar--collapsed .navitem{padding-left:15px}.sidebar--collapsed .sidebar__user{padding-left:4px}.sidebar--collapsed .sidebar__foot .btn{gap:0}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:56px;display:flex;align-items:center;gap:12px;padding:0 22px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}.topbar__menu{display:none}.topbar__spacer{flex:1}.topbar__live{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:var(--text-2)}.topbar__live .dot{width:8px;height:8px;border-radius:50%;background:var(--s-skipped)}.topbar__live.is-live{color:var(--accent-700)}.topbar__live.is-live .dot{background:var(--s-success);animation:pulse 1.6s ease-in-out infinite}.content{padding:26px;max-width:1280px;width:100%;margin:0 auto}.page{display:flex;flex-direction:column;gap:18px}.page__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page__head-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.page__title{font-size:23px;font-weight:750;letter-spacing:-.01em}.page__sub{color:var(--muted);margin:4px 0 0;font-size:13.5px}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-2);font-weight:600;font-size:13px}.back-link:hover{color:var(--accent-700)}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.seg button{border:none;background:transparent;padding:6px 14px;border-radius:6px;font-weight:600;font-size:13px;color:var(--text-2);cursor:pointer}.seg button.is-active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.meta-chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:8px}.chip{font-size:12px;font-weight:600;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);padding:3px 9px;border-radius:999px}.chip--accent{color:var(--accent-700);background:var(--accent-50);border-color:#cbeada}.chip--mono{font-family:var(--mono)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}.card__title{font-size:15px;font-weight:700;display:inline-flex;align-items:center;gap:8px}.card__actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.card__body{padding:18px}.card__hint{margin:-4px 0 14px;color:var(--muted);font-size:13px}.dagid{background:var(--surface-2);border:1px solid var(--border);padding:1px 7px;border-radius:6px;margin-left:10px;color:var(--text-2)}.row-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:18px}.tab{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border:none;background:none;cursor:pointer;font-size:14px;font-weight:600;color:var(--text-2);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.tab:hover{color:var(--text)}.tab--active{color:var(--accent-700);border-bottom-color:var(--accent)}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;padding:10px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.row-link{cursor:pointer;transition:background .12s}.row-link:hover{background:var(--surface-2)}.row-chevron{color:var(--muted);text-align:right}.cellstack{display:flex;flex-direction:column;gap:2px}.cellstack strong{font-weight:650}.dot-flag{font-size:12.5px;font-weight:700;display:inline-flex;align-items:center;gap:6px}.dot-flag:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--s-skipped)}.dot-flag.on{color:var(--accent-700)}.dot-flag.on:before{background:var(--s-success)}.dot-flag.off{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:650;padding:3px 9px;border-radius:999px;border:1px solid var(--border)}.badge--sm{font-size:11.5px;padding:2px 8px}.badge__dot{width:7px;height:7px;border-radius:50%;background:currentColor}.badge--success{color:var(--s-success);background:#eafaf0;border-color:#c7eed5}.badge--failed{color:var(--s-failed);background:#fdecec;border-color:#f6c9c9}.badge--running{color:var(--s-running);background:#eaf1fe;border-color:#d3e2fd}.badge--queued{color:#475569;background:#eef2f6;border-color:#dde5ec}.badge--upstream_failed{color:#b45309;background:#fef4e6;border-color:#fbe2bd}.badge--skipped{color:#64748b;background:#f1f5f9;border-color:#e2e8f0}.badge--no_status{color:var(--muted);background:var(--surface-2)}.run-grid{display:inline-flex;gap:8px;align-items:flex-start}.run-grid__labels{display:flex;flex-direction:column;gap:3px}.run-grid__corner{height:16px;font-size:10px;color:var(--muted);font-weight:700}.run-grid__rowlabel{height:14px;font-size:11px;color:var(--text-2);font-family:var(--mono);line-height:14px;white-space:nowrap}.run-grid__cols{display:flex;gap:3px;overflow-x:auto}.run-grid__col{display:flex;flex-direction:column;gap:3px;padding:2px;border:1px solid transparent;border-radius:5px;background:none;cursor:pointer}.run-grid__col:hover{background:var(--surface-2);border-color:var(--border)}.run-grid__col.is-selected{border-color:var(--accent);background:var(--accent-50)}.cell{width:14px;height:14px;border-radius:3px;display:block;background:var(--s-none);border:1px solid rgba(0,0,0,.05)}.cell--head{height:16px;border-radius:4px}.cell--success{background:var(--s-success)}.cell--failed{background:var(--s-failed)}.cell--running{background:var(--s-running);animation:pulse 1.1s ease-in-out infinite}.cell--queued{background:var(--s-queued)}.cell--upstream_failed{background:var(--s-upstream)}.cell--skipped{background:var(--s-skipped)}.cell--no_status{background:var(--s-none)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.run-grid--compact .cell{width:11px;height:11px;border-radius:2px}.run-grid--compact .cell--head{height:12px}.run-grid--compact .run-grid__col{gap:2px;padding:1px}.grid-empty{color:var(--muted);font-size:13px;padding:6px 0}.grid-legend{display:flex;gap:14px;flex-wrap:wrap}.grid-legend__item{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2)}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.autotoggle{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;background:var(--surface-2)}.autotoggle strong{display:block;font-size:14px}.autotoggle .muted{font-size:12px}.config-note{margin:12px 0 0}.switch{width:46px;height:26px;border-radius:999px;border:none;cursor:pointer;background:var(--s-skipped);position:relative;transition:background .18s;flex-shrink:0}.switch.on{background:var(--accent)}.switch:disabled{opacity:.5;cursor:not-allowed}.switch__knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .18s}.switch.on .switch__knob{transform:translate(20px)}.toggle-field{display:flex;align-items:center;gap:10px;height:40px}.toggle-field__label{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-2)}.tip{position:relative;display:inline-flex;align-items:center}.tip__icon{color:var(--muted);cursor:help;transition:color .15s}.tip:hover .tip__icon,.tip:focus-visible .tip__icon{color:var(--accent-700)}.tip__pop{position:absolute;bottom:calc(100% + 9px);left:50%;transform:translate(-50%) translateY(4px);width:max-content;max-width:240px;padding:8px 11px;background:var(--text);color:#fff;border-radius:var(--radius-sm);font-size:12px;font-weight:500;line-height:1.45;text-align:left;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:60}.tip:hover .tip__pop,.tip:focus-within .tip__pop{opacity:1;transform:translate(-50%) translateY(0)}.tip__pop:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--text)}.stepper{display:inline-flex;align-items:stretch;height:40px;width:max-content;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);overflow:hidden}.stepper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50)}.stepper__btn{display:inline-flex;align-items:center;justify-content:center;width:36px;border:none;background:var(--surface-2);color:var(--text-2);cursor:pointer;transition:background .15s,color .15s}.stepper__btn:hover:not(:disabled){background:var(--accent-50);color:var(--accent-700)}.stepper__btn:disabled{opacity:.4;cursor:not-allowed}.stepper__input{width:52px;padding:0;text-align:center;font-weight:600;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);border-radius:0;background:var(--surface)}.stepper__input:focus{outline:none;box-shadow:none}.rundetail{margin-top:18px;border-top:1px dashed var(--border);padding-top:16px}.rundetail__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.steps{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}.step{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px;background:var(--surface-2);transition:border-color .12s,background .12s;font:inherit;color:inherit}.step:hover{border-color:var(--border-strong)}.step.is-selected{border-color:var(--accent);background:var(--accent-50)}.step strong{font-size:13px;font-weight:600}.logs{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.logs__head{padding:8px 12px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:12px;font-weight:700;color:var(--text-2);display:flex;justify-content:space-between}.logs__body{margin:0;padding:12px;background:#0f1c17;color:#d6e7df;font-family:var(--mono);font-size:12px;line-height:1.6;max-height:360px;overflow:auto;white-space:pre-wrap;word-break:break-word}.step-editor{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin-bottom:12px;background:var(--surface-2)}.step-editor--dragging{opacity:.5}.step-editor--over{border-color:var(--accent);box-shadow:inset 0 2px 0 0 var(--accent)}.step-editor__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.step-editor__head--collapsed{margin-bottom:0}.step-editor__head-left{display:flex;align-items:center;gap:8px;min-width:0}.step-editor__grip{display:inline-flex;align-items:center;color:var(--text-2);cursor:grab}.step-editor__grip:hover{color:var(--accent)}.step-editor__grip:active{cursor:grabbing}.step-editor__toggle{display:inline-flex;align-items:center;gap:8px;min-width:0;background:none;border:0;padding:4px 0;cursor:pointer;color:var(--text-2);text-align:left}.step-editor__toggle:hover,.step-editor__toggle:hover .step-editor__idx{color:var(--accent)}.step-editor__idx{font-weight:700;color:var(--text-2);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.editor-row:last-child{margin-bottom:0}.stack{display:flex;flex-direction:column;gap:14px}.role{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:capitalize}.role--admin{color:var(--accent-700);background:var(--accent-50)}.role--user{color:#475569;background:#eef2f6}.ustatus{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:capitalize}.ustatus--active{color:var(--s-success);background:#eafaf0}.ustatus--pending{color:#b45309;background:#fef4e6}.profile-hero{display:flex;align-items:center;gap:18px;padding:18px;flex-wrap:wrap}.avatar--lg{width:56px;height:56px;font-size:22px}.profile-hero__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.profile-hero__name{font-size:18px;font-weight:700;line-height:1.1}.profile-hero__badges{display:flex;gap:8px;margin-top:4px}.profile-hero__meta{display:flex;flex-direction:column;gap:2px;text-align:right;font-size:13px}.profile-hero__meta strong{font-weight:650}.state-block{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px;color:var(--text-2);text-align:center}.state-block--error{color:var(--s-failed)}.toast-stack{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:100}.toast{display:flex;align-items:center;gap:10px;min-width:260px;max-width:380px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--muted);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:12px 14px;font-size:13.5px;animation:toast-in .18s ease-out}.toast--success{border-left-color:var(--s-success);color:var(--s-success)}.toast--error{border-left-color:var(--s-failed);color:var(--s-failed)}.toast--info{border-left-color:var(--s-running);color:var(--s-running)}.toast span{color:var(--text);flex:1}.toast__close{background:none;border:none;cursor:pointer;color:var(--muted);display:inline-flex}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}}.cron-desc{font-size:12.5px;font-weight:600;color:var(--accent-700)}.cron-desc--bad{color:var(--s-failed)}.scripts-grid{display:grid;grid-template-columns:280px 1fr;gap:16px;align-items:stretch}.scripts-grid>.card:first-child{display:flex;flex-direction:column}.scripts-grid>.card:first-child .card__body{flex:1;min-height:0;overflow-y:auto}.scripts-list{list-style:none;display:flex;flex-direction:column;gap:4px}.scripts-list__item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 10px;border:1px solid transparent;border-radius:var(--radius-sm);background:none;cursor:pointer;color:var(--text);font-size:13.5px}.scripts-list__item:hover{background:var(--surface-2)}.scripts-list__item.active{background:var(--accent-50);border-color:var(--accent)}.scripts-list__name{flex:1;font-family:var(--mono);font-size:12.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.code-editor{border:1px solid var(--border-strong);border-radius:var(--radius-sm);overflow:hidden}.code-editor:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50)}.pkg-install{display:flex;gap:10px;align-items:center}.pkg-install input{flex:1}.pkg-install .btn{white-space:nowrap}@media (max-width: 880px){.scripts-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;padding:20px;background:#10201b73;display:grid;place-items:center;animation:overlay-in .15s ease-out}.modal{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;animation:modal-in .18s ease-out}.modal__head{display:flex;align-items:center;gap:12px;padding:18px 18px 6px}.modal__icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;flex-shrink:0;background:var(--accent-50);color:var(--accent-700)}.modal__icon--danger{background:#fdecec;color:var(--s-failed)}.modal__title{font-size:16px;font-weight:700;flex:1}.modal__close{background:none;border:none;cursor:pointer;color:var(--muted);display:inline-flex;padding:4px}.modal__close:hover{color:var(--text)}.modal__body{padding:6px 18px 18px;color:var(--text-2);font-size:14px;line-height:1.55}.modal__body strong{color:var(--text);font-weight:650}.modal__body p{margin:0}.modal__body p+p{margin-top:6px}.modal__foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;background:var(--surface-2);border-top:1px solid var(--border)}@keyframes overlay-in{0%{opacity:0}}@keyframes modal-in{0%{opacity:0;transform:translateY(10px) scale(.98)}}@media (max-width: 880px){.sidebar,.sidebar--collapsed{position:fixed;left:0;top:0;z-index:30;width:248px;transform:translate(-100%);transition:transform .2s}.shell--open .sidebar{transform:translate(0);box-shadow:var(--shadow)}.sidebar--collapsed .navitem__label,.sidebar--collapsed .sidebar__brand div,.sidebar--collapsed .sidebar__userinfo,.sidebar--collapsed .sidebar__foot .btn--ghost span{max-width:160px;opacity:1}.sidebar--collapsed .sidebar__brand{padding-left:18px}.sidebar--collapsed .navitem{padding-left:12px}.sidebar--collapsed .sidebar__user{padding-left:8px}.sidebar--collapsed .sidebar__foot .btn{gap:7px}.topbar__menu{display:inline-flex}.config-grid,.editor-row{grid-template-columns:1fr}}
