:root{--bg: oklch(14% .012 270);--bg-2: oklch(11% .01 270);--surface: oklch(18% .014 270);--surface-2: oklch(22% .016 270);--surface-hi: oklch(26% .018 270);--border: oklch(28% .014 270);--border-strong:oklch(38% .018 270);--hairline: oklch(22% .012 270);--fg: oklch(96% .005 270);--fg-2: oklch(82% .008 270);--muted: oklch(64% .012 270);--subtle: oklch(48% .012 270);--faint: oklch(36% .012 270);--accent: oklch(64% .18 285);--accent-2: oklch(72% .16 285);--accent-dim: oklch(54% .16 285);--accent-soft: oklch(64% .18 285 / .16);--accent-line: oklch(64% .18 285 / .45);--ring: oklch(64% .18 285 / .5);--st-draft: oklch(82% .14 95);--st-queued: oklch(70% .12 235);--st-running: oklch(72% .16 230);--st-success: oklch(74% .16 152);--st-failed: oklch(68% .22 25);--st-tokens: oklch(80% .16 80);--ds-font-serif: "Noto Serif SC", "Source Han Serif SC", "Source Han Serif", "Songti SC", "STSong", Georgia, serif;--ds-font-sans: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", system-ui, sans-serif;--ds-font-mono: "JetBrains Mono", "SF Mono", ui-monospace, "IBM Plex Mono", Menlo, Consolas, monospace;--ds-radius-sm: 6px;--ds-radius: 8px;--ds-radius-md: 10px;--ds-radius-lg: 14px;--ds-radius-xl: 18px}.ds-root{background:var(--bg);color:var(--fg);font-family:var(--ds-font-sans);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv01" 1,"cv02" 1,"cv03" 1,"cv04" 1;min-height:100vh}.ds-root ::-moz-selection{background:var(--accent-soft);color:var(--fg)}.ds-root ::selection{background:var(--accent-soft);color:var(--fg)}.ds-root :focus-visible{outline:2px solid var(--ring);outline-offset:2px;border-radius:4px}.ds-container{max-width:1280px;margin:0 auto;padding:0 32px}.ds-container-narrow{max-width:1080px;margin:0 auto;padding:0 32px}@media(max-width:1024px){.ds-container,.ds-container-narrow{padding:0 24px}}@media(max-width:640px){.ds-container,.ds-container-narrow{padding:0 16px}}.serif{font-family:var(--ds-font-serif)}.mono{font-family:var(--ds-font-mono)}.tnum{font-variant-numeric:tabular-nums}.ds-muted{color:var(--muted)}.ds-subtle{color:var(--subtle)}.ds-uppercase{text-transform:uppercase;letter-spacing:.08em}.app-shell{display:flex;min-height:100vh}.app-shell .app-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;height:100vh}.sidebar{width:260px;flex-shrink:0;height:100vh;position:sticky;top:0;display:flex;flex-direction:column;background:var(--bg-2);border-right:1px solid var(--border)}@media(max-width:768px){.sidebar{width:220px}}.sidebar-head{padding:14px 16px 12px;border-bottom:1px solid var(--hairline)}.sidebar-head .brand{display:flex;align-items:center;gap:10px;color:var(--fg)}.sidebar-head .brand-mark{position:relative;width:24px;height:24px;border-radius:6px;background:linear-gradient(135deg,var(--accent) 0%,oklch(54% .22 320) 100%);display:grid;place-items:center;box-shadow:0 0 0 1px #8477f359,0 6px 18px -8px #8477f399}.sidebar-head .brand-mark:after{content:"";width:9px;height:9px;background:var(--bg-2);clip-path:polygon(15% 0,100% 50%,15% 100%)}.sidebar-head .brand-name{font-family:var(--ds-font-serif);font-weight:600;font-size:16px;letter-spacing:0;color:var(--fg)}.sidebar-head .brand-sub{color:var(--subtle);font-size:11px;letter-spacing:.04em;font-family:var(--ds-font-mono);text-transform:uppercase;margin-left:4px}.sidebar-section-label{padding:14px 18px 6px;font-size:10.5px;font-family:var(--ds-font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--subtle);font-weight:500}.sidebar-list{flex:1;overflow-y:auto;padding:0 8px 8px;display:flex;flex-direction:column;gap:2px;min-height:0}.sidebar-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:7px;text-decoration:none;color:var(--fg-2);font-size:13px;line-height:1.35;cursor:pointer;transition:background .15s,color .15s;border:1px solid transparent;min-width:0}.sidebar-item:hover{background:var(--surface);color:var(--fg)}.sidebar-item.active{background:var(--surface-2);color:var(--fg);border-color:var(--border-strong);box-shadow:inset 2px 0 0 0 var(--accent)}.sidebar-item .dot{width:8px;height:8px;flex-shrink:0;border-radius:2px;box-shadow:0 0 0 1px #0006}.sidebar-item .title{flex:1;min-width:0;font-family:var(--ds-font-serif);font-weight:500;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.005em}.sidebar-item .count{font-family:var(--ds-font-mono);font-size:10.5px;color:var(--subtle);letter-spacing:.04em;flex-shrink:0}.sidebar-item.active .count{color:var(--fg-2)}.sidebar-empty{padding:14px 18px;color:var(--subtle);font-size:12.5px;line-height:1.5;font-style:italic}.sidebar-foot{padding:10px 10px 14px;border-top:1px solid var(--hairline);display:flex;flex-direction:column;gap:6px}.sidebar-add{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;font-family:inherit;font-size:13px;color:var(--muted);background:transparent;border:1px dashed var(--border-strong);cursor:pointer;transition:color .15s,background .15s,border-color .15s;width:100%;text-align:left}.sidebar-add:hover{color:var(--fg);background:#1413274d;border-color:var(--accent-line)}.sidebar-add .plus{width:22px;height:22px;border-radius:50%;border:1px dashed var(--border-strong);display:grid;place-items:center;flex-shrink:0;color:var(--muted);transition:color .15s,border-color .15s}.sidebar-add:hover .plus{color:var(--accent-2);border-color:var(--accent-line)}.sidebar-create-form{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px}.sidebar-create-form h5{font-family:var(--ds-font-serif);font-weight:500;font-size:13px;margin:0;color:var(--fg)}.sidebar-create-form .actions{display:flex;gap:6px;justify-content:flex-end}.sidebar-icon-row{display:flex;align-items:center;gap:4px;padding:0 4px}.sidebar-icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:6px;color:var(--muted);cursor:pointer;background:transparent;border:0;transition:background .15s,color .15s}.sidebar-icon-btn:hover{background:var(--surface);color:var(--fg)}.sidebar-icon-btn.active{background:var(--surface-2);color:var(--fg)}.shots-sidebar{width:240px;flex-shrink:0;height:100vh;position:sticky;top:0;display:flex;flex-direction:column;background:var(--bg);border-right:1px solid var(--border)}@media(max-width:1180px){.shots-sidebar{width:220px}}@media(max-width:920px){.shots-sidebar{display:none}}.shots-sidebar-head{padding:14px 16px 10px;border-bottom:1px solid var(--hairline)}.shots-sidebar-title{font-family:var(--ds-font-serif);font-weight:500;font-size:15px;color:var(--fg);letter-spacing:-.005em;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shots-sidebar-meta{font-family:var(--ds-font-mono);font-size:10.5px;letter-spacing:.08em;color:var(--subtle);text-transform:uppercase;margin-top:3px}.shots-sidebar-list{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:2px;min-height:0}.shot-row{display:flex;align-items:flex-start;gap:10px;padding:9px 10px;border-radius:7px;text-decoration:none;color:var(--fg-2);cursor:pointer;transition:background .15s,color .15s;border:1px solid transparent;min-width:0}.shot-row:hover{background:var(--surface);color:var(--fg)}.shot-row.active{background:var(--surface-2);color:var(--fg);border-color:var(--border-strong);box-shadow:inset 2px 0 0 0 var(--accent)}.shot-row .index{font-family:var(--ds-font-mono);font-size:10.5px;color:var(--subtle);letter-spacing:.04em;flex-shrink:0;width:26px;padding-top:2px;text-align:right}.shot-row.active .index{color:var(--fg-2)}.shot-row .body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.shot-row .prompt{font-size:12.5px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;color:var(--fg-2)}.shot-row.placeholder .prompt{color:var(--subtle);font-style:italic}.shot-row .meta{font-family:var(--ds-font-mono);font-size:10.5px;color:var(--subtle);letter-spacing:.02em;display:flex;align-items:center;gap:6px}.shot-row .status-dot{width:6px;height:6px;border-radius:50%;background:var(--faint);flex-shrink:0}.shot-row .status-dot.draft{background:var(--st-draft)}.shot-row .status-dot.queued{background:var(--st-queued)}.shot-row .status-dot.running{background:var(--st-running);animation:pulse-dot 1.6s ease-in-out infinite}.shot-row .status-dot.success{background:var(--st-success)}.shot-row .status-dot.failed{background:var(--st-failed)}.shots-sidebar-empty{padding:12px 16px;color:var(--subtle);font-size:12.5px;font-style:italic;line-height:1.5}.shots-sidebar-foot{padding:10px;border-top:1px solid var(--hairline)}.page-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 32px;border-bottom:1px solid var(--hairline);background:#07090ed9;position:sticky;top:0;z-index:30;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}@media(max-width:640px){.page-bar{padding:14px 16px}}.page-bar .left{display:flex;align-items:center;gap:12px;min-width:0}.page-bar .right{display:flex;align-items:center;gap:8px}.main-content{padding:32px}@media(max-width:640px){.main-content{padding:20px 16px 80px}}.composer{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px;transition:border-color .15s}.composer:focus-within{border-color:var(--accent-line)}.composer.readonly{background:var(--bg-2);border-color:var(--hairline)}.composer-attachments{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-height:0}.composer-attachments:empty{display:none}.composer-attach{position:relative;width:64px;height:64px;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:#07090e;cursor:pointer;flex-shrink:0;transition:border-color .15s,transform .15s}.composer-attach.draggable{cursor:grab}.composer-attach.draggable:active{cursor:grabbing}.composer-attach:hover{border-color:var(--border-strong)}.composer-attach.dragging{opacity:.35}.composer-attach.drag-over{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft);transform:scale(1.04)}.composer-attach img,.composer-attach video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.composer-attach .role-badge{position:absolute;top:4px;left:4px;font-family:var(--ds-font-mono);font-size:9.5px;font-weight:600;letter-spacing:.06em;padding:2px 5px;border-radius:3px;color:#f7f8fc;pointer-events:none}.composer-attach .role-badge.image{background:#3b4668d9}.composer-attach .role-badge.first{background:#005729d9;background:oklch(40% .16 152 / .85)}.composer-attach .role-badge.last{background:#8a0314d9}.composer-attach .role-badge.video{background:#004e6fd9;background:oklch(40% .12 235 / .85)}.composer-attach .role-badge.audio{background:#5f4200d9;background:oklch(40% .12 80 / .85)}.composer-attach .order-badge{position:absolute;bottom:4px;left:4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#030303bf;color:#f7f8fc;font-family:var(--ds-font-mono);font-size:10px;font-weight:700;line-height:16px;text-align:center;letter-spacing:.02em;border:1px solid oklch(100% 0 0 / .14);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);pointer-events:none;z-index:2}.composer-attach .remove{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:#07090ee6;color:var(--fg);display:grid;place-items:center;cursor:pointer;opacity:0;transition:opacity .15s,background .15s;border:0;z-index:2}.composer-attach:hover .remove{opacity:1}.composer-attach .remove:hover{background:var(--st-failed)}.composer-attach.audio{width:auto;min-width:140px;padding:0 12px 0 8px;display:flex;align-items:center;gap:6px;background:#0f1118;font-family:var(--ds-font-mono);font-size:11px;color:var(--fg-2);letter-spacing:.02em}.composer-attach.audio .icon{color:var(--st-tokens)}.composer-attach.audio .label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.composer-attach.audio .role-badge{position:static;margin-left:auto}.composer-attach.audio .remove{position:static;opacity:.6}.composer-attach.audio:hover .remove{opacity:1}.composer-attach.pending{background:#19182c;border:1px solid var(--accent);position:relative;cursor:default;overflow:hidden;display:grid;place-items:center;animation:pending-pulse 1.4s ease-in-out infinite}@keyframes pending-pulse{0%,to{box-shadow:0 0 0 0 var(--accent-soft)}50%{box-shadow:0 0 0 4px var(--accent-soft)}}.composer-attach.pending:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 25%,color-mix(in oklch,var(--accent) 55%,transparent) 50%,transparent 75%);animation:shimmer-sweep 1.4s linear infinite;z-index:1;pointer-events:none}.composer-attach.pending .spinner-wrap{position:relative;z-index:2;display:grid;place-items:center;color:var(--accent-2)}.composer-attach.pending .filename{position:absolute;left:4px;right:4px;bottom:4px;z-index:3;font-family:var(--ds-font-mono);font-size:9.5px;color:#eaebefd9;background:#07090eb3;padding:2px 4px;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.composer-attach.pending.audio{width:auto;min-width:140px;padding:0 12px 0 8px;display:flex;align-items:center;gap:6px;font-family:var(--ds-font-mono);font-size:11px;color:var(--fg-2)}.composer-attach.pending.audio .filename{position:static;background:transparent;padding:0;flex:1}.composer-attach-add{width:64px;height:64px;border-radius:10px;border:1px dashed var(--border-strong);background:transparent;display:grid;place-items:center;color:var(--muted);cursor:pointer;transition:border-color .15s,background .15s,color .15s;flex-shrink:0}.composer-attach-add:hover{border-color:var(--accent-line);background:#1413274d;color:var(--accent-2)}.composer-textarea{width:100%;background:transparent;border:0;resize:none;min-height:96px;max-height:360px;font:inherit;color:var(--fg);font-size:14.5px;line-height:1.65;outline:none;padding:4px 2px}.composer-textarea::-moz-placeholder{color:var(--faint)}.composer-textarea::placeholder{color:var(--faint)}.composer-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:4px;border-top:1px solid var(--hairline);margin-top:4px;position:relative}.composer-bar .spacer{flex:1}.composer-chip{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:999px;border:1px solid var(--border-strong);background:var(--surface-2);font-family:inherit;font-size:12.5px;color:var(--fg-2);cursor:pointer;transition:border-color .15s,background .15s,color .15s;white-space:nowrap}.composer-chip:hover{border-color:var(--accent-line);color:var(--fg)}.composer-chip.open{background:color-mix(in oklch,var(--accent) 18%,var(--surface));border-color:var(--accent-line);color:var(--fg)}.composer-chip .ic{width:14px;height:14px;opacity:.85}.composer-chip .caret{width:12px;height:12px;opacity:.6}.composer-chip:disabled{opacity:.5;pointer-events:none}.composer-fab{width:36px;height:36px;border-radius:50%;border:0;background:linear-gradient(135deg,var(--accent) 0%,oklch(54% .22 320) 100%);color:#fbfbff;color:oklch(99% .01 285);display:grid;place-items:center;cursor:pointer;box-shadow:0 6px 22px -10px #8477f3b3;transition:filter .15s,transform .05s}.composer-fab:hover{filter:brightness(1.08)}.composer-fab:active{transform:translateY(1px)}.composer-fab:disabled{opacity:.4;pointer-events:none}.popover{position:absolute;bottom:calc(100% + 8px);left:0;z-index:50;min-width:200px;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:12px;padding:6px;display:flex;flex-direction:column;gap:2px;box-shadow:0 24px 64px -16px #00000073,0 0 0 1px #0000000d;animation:pop-in .15s ease}.popover[data-side=right]{left:auto;right:0}@keyframes pop-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.popover-title{font-size:11px;font-family:var(--ds-font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--subtle);padding:8px 12px 4px}.popover-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;font-size:13px;color:var(--fg-2);cursor:pointer;text-align:left;background:none;border:0;width:100%;font-family:inherit}.popover-item:hover{background:var(--surface-hi);color:var(--fg)}.popover-item.selected{background:color-mix(in oklch,var(--accent) 18%,var(--surface-hi));color:var(--fg)}.popover-item .check{margin-left:auto;color:var(--accent-2);opacity:0}.popover-item.selected .check{opacity:1}.popover-item .ic{width:14px;height:14px;opacity:.8;flex-shrink:0}.popover-item .danger{color:var(--st-failed)}.composer-file-pick{display:none}.composer-mention{position:relative}.mention-pop{position:absolute;top:100%;left:0;z-index:60;margin-top:6px;width:320px;max-height:360px;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:12px;display:flex;flex-direction:column;box-shadow:0 24px 64px -16px #00000080,0 0 0 1px #0000000d;overflow:hidden;animation:pop-in .15s ease}.mention-pop-head{padding:10px 14px 8px;display:flex;align-items:center;justify-content:space-between;gap:8px;border-bottom:1px solid var(--hairline)}.mention-pop-title{font-size:11px;font-family:var(--ds-font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--subtle)}.mention-pop-new{display:inline-flex;align-items:center;gap:4px;height:24px;padding:0 8px;border-radius:6px;background:var(--surface-hi);border:1px solid var(--border-strong);font-size:11px;color:var(--fg-2);cursor:pointer;font-family:inherit;white-space:nowrap}.mention-pop-new:hover{background:#14132780;border-color:var(--accent-line);color:var(--fg)}.mention-pop-list{flex:1;overflow-y:auto;padding:6px;display:flex;flex-direction:column;gap:2px}.mention-empty{padding:24px 12px;text-align:center;color:var(--subtle);font-size:12.5px;line-height:1.6}.mention-empty .icon-wrap{width:44px;height:44px;margin:0 auto 10px;border-radius:50%;background:var(--surface-hi);display:grid;place-items:center;color:var(--muted)}.mention-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px;cursor:pointer;text-align:left;background:none;border:0;width:100%;font-family:inherit;transition:background .12s}.mention-item:hover,.mention-item.focused{background:var(--surface-hi)}.mention-item .thumb{width:36px;height:36px;border-radius:6px;flex-shrink:0;overflow:hidden;background:#07090e;display:grid;place-items:center;color:var(--muted)}.mention-item .thumb img,.mention-item .thumb video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.mention-item .meta{flex:1;min-width:0}.mention-item .name{font-size:13px;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.mention-item .kind-tag{font-family:var(--ds-font-mono);font-size:10.5px;color:var(--subtle);letter-spacing:.04em;text-transform:uppercase;display:block;margin-top:1px}.composer-attach.from-mention{outline:1px dashed var(--accent-line)}.editor-with-chat{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:24px;align-items:flex-start;transition:grid-template-columns .25s ease}.editor-with-chat.collapsed{grid-template-columns:minmax(0,1fr) 0;gap:0}.editor-with-chat .editor-chat-col{position:sticky;top:24px;max-height:calc(100vh - 48px);overflow:hidden;transition:opacity .2s ease,transform .25s ease}.editor-with-chat.collapsed .editor-chat-col{opacity:0;transform:translate(40px);pointer-events:none}@media(max-width:1180px){.editor-with-chat,.editor-with-chat.collapsed{grid-template-columns:1fr}.editor-with-chat .editor-chat-col{position:static;max-height:none}}.chat-fab{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;background:var(--surface);border:1px solid var(--border-strong);border-radius:999px;font-family:var(--ds-font-mono);font-size:11.5px;letter-spacing:.04em;color:var(--fg-2);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.chat-fab:hover{background:var(--surface-2);border-color:var(--accent-line);color:var(--fg)}.chat-fab.active{background:color-mix(in oklch,var(--accent) 18%,var(--surface));border-color:var(--accent-line);color:var(--fg)}.chat-fab .sparkle{color:var(--accent-2);width:14px;height:14px}.topnav{position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 32px;border-bottom:1px solid var(--border);background:#07090ec7;backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px)}@media(max-width:640px){.topnav{padding:0 16px}}.topnav .brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.005em;color:var(--fg)}.topnav .brand-mark{position:relative;width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,var(--accent) 0%,oklch(54% .22 320) 100%);display:grid;place-items:center;box-shadow:0 0 0 1px #8477f359,0 6px 18px -8px #8477f399}.topnav .brand-mark:after{content:"";width:8px;height:8px;background:var(--bg);clip-path:polygon(15% 0,100% 50%,15% 100%)}.topnav .brand-name{font-family:var(--ds-font-serif);font-weight:600;font-size:15px;letter-spacing:0}.topnav .brand-sub{color:var(--subtle);font-size:12px;margin-left:6px;letter-spacing:.02em}.topnav-right{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--muted)}.topnav-right kbd{font-family:var(--ds-font-mono);font-size:11px;padding:2px 6px;border-radius:4px;border:1px solid var(--border);background:var(--surface);color:var(--fg-2)}.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:34px;padding:0 14px;border-radius:var(--ds-radius);font-size:13px;font-weight:500;border:1px solid transparent;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .05s ease;font-family:inherit;white-space:nowrap;color:var(--fg);letter-spacing:-.005em;cursor:pointer;background:none}.ds-btn:active{transform:translateY(1px)}.ds-btn:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.ds-btn:disabled{opacity:.4;pointer-events:none}.ds-btn-primary{background:var(--accent);color:#fbfbff;color:oklch(99% .01 285);box-shadow:0 1px #ffffff0f inset,0 6px 16px -10px #8477f399}.ds-btn-primary:hover{background:var(--accent-2)}.ds-btn-secondary{background:var(--surface);border-color:var(--border-strong);color:var(--fg-2)}.ds-btn-secondary:hover{background:var(--surface-2);border-color:#595d69;color:var(--fg)}.ds-btn-ghost{background:transparent;color:var(--muted)}.ds-btn-ghost:hover{background:var(--surface);color:var(--fg-2)}.ds-btn-danger{background:#560004;background:oklch(28% .14 25);color:#ffd0cb;color:oklch(90% .1 25);border-color:#7c2524}.ds-btn-danger:hover{background:#6f000b;background:oklch(34% .16 25);color:#ffebe8;color:oklch(96% .06 25)}.ds-btn-danger-ghost{background:transparent;color:#ff716b;color:oklch(72% .18 25);border-color:#5c1717}.ds-btn-danger-ghost:hover{background:#430004;background:oklch(24% .1 25);color:#ffbeb8;color:oklch(86% .14 25);border-color:#902828}.ds-btn-sm{height:28px;padding:0 10px;font-size:12px;gap:4px;border-radius:6px}.ds-btn-lg{height:40px;padding:0 18px;font-size:14px}.ds-btn .ic{width:14px;height:14px;flex:0 0 14px}.ds-btn-sm .ic{width:12px;height:12px;flex-basis:12px}.slate{display:inline-flex;align-items:stretch;height:22px;font-family:var(--ds-font-mono);font-size:11px;font-weight:500;letter-spacing:.04em;color:var(--fg);background:#101115;border-radius:5px;overflow:hidden;border:1px solid oklch(34% .012 270);box-shadow:0 1px #ffffff0a inset}.slate-stripes{width:24px;background-image:repeating-linear-gradient(135deg,#f0f2f5,#f0f2f5 6px,#707175,#38393d,#08090c 6px,#08090c 12px);border-right:1px solid oklch(34% .012 270)}.slate-text{display:inline-flex;align-items:center;padding:0 9px;white-space:nowrap;letter-spacing:.06em;color:#e9ebef}.slate-lg{height:28px;font-size:12px}.slate-lg .slate-stripes{width:30px}.slate-lg .slate-text{padding:0 12px}.pill{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 9px;border-radius:999px;font-size:11px;font-weight:500;font-family:var(--ds-font-mono);letter-spacing:.03em;border:1px solid;white-space:nowrap}.pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex:0 0 6px}.pill-draft{color:var(--st-draft);border-color:color-mix(in oklch,var(--st-draft) 40%,transparent);background:color-mix(in oklch,var(--st-draft) 8%,transparent)}.pill-queued{color:var(--st-queued);border-color:color-mix(in oklch,var(--st-queued) 40%,transparent);background:color-mix(in oklch,var(--st-queued) 8%,transparent)}.pill-running{color:var(--st-running);border-color:color-mix(in oklch,var(--st-running) 40%,transparent);background:color-mix(in oklch,var(--st-running) 8%,transparent)}.pill-running:before{animation:pulse-dot 1.6s ease-in-out infinite}.pill-success{color:var(--st-success);border-color:color-mix(in oklch,var(--st-success) 40%,transparent);background:color-mix(in oklch,var(--st-success) 8%,transparent)}.pill-failed{color:var(--st-failed);border-color:color-mix(in oklch,var(--st-failed) 40%,transparent);background:color-mix(in oklch,var(--st-failed) 10%,transparent)}.pill-neutral{color:var(--muted);border-color:var(--border-strong);background:var(--surface)}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.ds-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--ds-radius-lg);transition:border-color .18s ease,background .18s ease,transform .18s ease}.ds-card-hover{cursor:pointer}.ds-card-hover:hover{border-color:var(--border-strong);background:var(--surface-2)}.ds-input,.ds-select,.ds-textarea{width:100%;background:var(--surface);border:1px solid var(--border-strong);color:var(--fg);border-radius:var(--ds-radius);padding:10px 12px;font:inherit;font-size:13.5px;line-height:1.55;transition:border-color .15s ease,background .15s ease}.ds-input::-moz-placeholder,.ds-textarea::-moz-placeholder{color:var(--faint)}.ds-input::placeholder,.ds-textarea::placeholder{color:var(--faint)}.ds-input:hover,.ds-select:hover,.ds-textarea:hover{border-color:#515561}.ds-input:focus,.ds-select:focus,.ds-textarea:focus{outline:none;border-color:var(--accent);background:var(--surface-2);box-shadow:0 0 0 3px var(--accent-soft)}.ds-textarea{resize:vertical;min-height:140px;line-height:1.7;font-size:14px}.ds-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.ds-field-label{display:block;font-size:12px;letter-spacing:.02em;color:var(--muted);margin-bottom:6px;font-weight:500}.frame{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:var(--ds-radius-md);overflow:hidden;background:#010202;isolation:isolate}.frame[data-hue=cool]{background:radial-gradient(120% 90% at 25% 30%,#002e41,#010813 60%,#010203);background:radial-gradient(120% 90% at 25% 30%,color(xyz 0.019 0.023 0.055),#010813 60%,#010203)}.frame[data-hue=ember]{background:radial-gradient(120% 90% at 70% 30%,#522400,#351300,#1c0300 55%,#050100);background:radial-gradient(120% 90% at 70% 30%,color(xyz 0.044 0.03 -0.001),color(xyz 0.018 0.012 0),#1c0300 55%,#050100)}.frame[data-hue=violet]{background:radial-gradient(120% 90% at 60% 65%,#29144e,#08051c 60%,#010105)}.frame[data-hue=emerald]{background:radial-gradient(120% 90% at 35% 65%,#002a1b,#000906 60%,#010202);background:radial-gradient(120% 90% at 35% 65%,color(xyz 0.008 0.018 0.011),color(xyz 0.001 0.002 0.002) 60%,#010202)}.frame[data-hue=rose]{background:radial-gradient(120% 90% at 50% 40%,#4e091b,#190106 60%,#040101)}.frame[data-hue=silver]{background:radial-gradient(120% 90% at 50% 30%,#343843,#101116 60%,#030304)}.frame[data-hue=mustard]{background:radial-gradient(120% 90% at 30% 45%,#403000,#150700 60%,#030100);background:radial-gradient(120% 90% at 30% 45%,color(xyz 0.033 0.032 -0.003),color(xyz 0.004 0.003 -0) 60%,#030100)}.frame[data-hue=indigo]{background:radial-gradient(120% 90% at 65% 35%,#0c1c45,#030617 60%,#010105)}.frame[data-hue=teal]{background:radial-gradient(120% 90% at 40% 55%,#002a2e,#000c10 60%,#000403);background:radial-gradient(120% 90% at 40% 55%,color(xyz 0.011 0.019 0.038),color(xyz 0.002 0.003 0.006) 60%,color(xyz 0 0.001 0.001))}.frame[data-hue=ash]{background:radial-gradient(120% 90% at 50% 50%,#1e1f22,#050607 70%,#010101)}.frame:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 38%,oklch(0% 0 0 / .55) 100%),repeating-linear-gradient(0deg,oklch(100% 0 0 / .012) 0 1px,transparent 1px 3px);pointer-events:none;z-index:1}.frame:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(oklch(100% 0 0 / .04) 1px,transparent 1px);background-size:3px 3px;mix-blend-mode:overlay;opacity:.45;pointer-events:none;z-index:2}.frame>.frame-content{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.frame>.frame-content video,.frame>.frame-content img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.frame>.frame-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;pointer-events:none}.frame-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:#ffffffe6;display:grid;place-items:center;z-index:3;box-shadow:0 8px 22px -8px #000000b3;opacity:0;transition:opacity .2s ease}.frame:hover .frame-play{opacity:1}.frame-play:after{content:"";width:0;height:0;margin-left:3px;border-left:11px solid oklch(10% 0 0);border-top:7px solid transparent;border-bottom:7px solid transparent}.frame-meta{position:absolute;left:10px;right:10px;bottom:8px;display:flex;justify-content:space-between;font-family:var(--ds-font-mono);font-size:10.5px;letter-spacing:.08em;color:#e3e4e8d9;text-transform:uppercase;z-index:3;pointer-events:none}.frame-meta-tl{position:absolute;top:9px;left:10px;font-family:var(--ds-font-mono);font-size:10.5px;letter-spacing:.08em;color:#f0f2f5d9;text-transform:uppercase;z-index:3;pointer-events:none}.frame-corner{position:absolute;width:14px;height:14px;border-color:#f0f2f580;z-index:3}.frame-corner.tl{top:8px;left:8px;border-top:1px solid;border-left:1px solid}.frame-corner.tr{top:8px;right:8px;border-top:1px solid;border-right:1px solid}.frame-corner.bl{bottom:8px;left:8px;border-bottom:1px solid;border-left:1px solid}.frame-corner.br{bottom:8px;right:8px;border-bottom:1px solid;border-right:1px solid}.frame-shimmer{background:#0b0d13}.frame-shimmer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 35%,color-mix(in oklch,var(--st-running) 28%,transparent) 50%,transparent 65%);animation:shimmer-sweep 2.4s linear infinite;z-index:2;opacity:1;mix-blend-mode:normal;background-size:auto}@keyframes shimmer-sweep{0%{transform:translate(-110%)}to{transform:translate(110%)}}.frame-draft .frame-content{filter:blur(14px) saturate(.85) brightness(.65);transform:scale(1.08)}.frame-draft-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:3;color:#c1c4cbc7;font-family:var(--ds-font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}.draft-stamp{padding:4px 10px;border:1px solid color-mix(in oklch,var(--st-draft) 50%,transparent);border-radius:4px;background:#1c160080;background:oklch(20% .05 95 / .5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--st-draft)}.frame-empty{background:repeating-linear-gradient(45deg,#0c0d11,#0c0d11 8px,#0a0b0e 8px,#0a0b0e 16px);border:1px dashed oklch(30% .012 270)}.frame-empty:before,.frame-empty:after{content:none}.frame-empty-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--subtle);font-family:var(--ds-font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;z-index:2}.ds-spinner{width:44px;height:44px;border-radius:50%;border:2px solid color-mix(in oklch,var(--st-running) 25%,transparent);border-top-color:var(--st-running);animation:ds-spin 1s linear infinite}@keyframes ds-spin{to{transform:rotate(360deg)}}.progress-ring{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:4}.progress-ring .ring{width:56px;height:56px;position:relative}.progress-ring .ring svg{transform:rotate(-90deg)}.progress-ring .ring circle.track{fill:none;stroke:#2e4b6066;stroke-width:3}.progress-ring .ring circle.fill{fill:none;stroke:var(--st-running);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .6s}.progress-ring .pct{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-family:var(--ds-font-mono);font-size:11px;font-weight:500;color:var(--st-running);letter-spacing:.04em}.stat{display:flex;flex-direction:column;gap:4px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--ds-radius-md);min-width:0}.stat-label{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--subtle);font-weight:500}.stat-value{font-family:var(--ds-font-serif);font-size:24px;line-height:1;color:var(--fg);font-variant-numeric:tabular-nums;font-weight:500;letter-spacing:-.01em}.stat-suffix{font-family:var(--ds-font-sans);font-size:12px;color:var(--muted);margin-left:4px;font-weight:400}.bars{display:flex;align-items:flex-end;gap:3px;height:28px;margin-top:2px}.bars .bar{flex:1 1 0;background:color-mix(in oklch,var(--st-tokens) 35%,transparent);border-radius:2px 2px 0 0;min-height:4px;transition:background .15s ease}.bars .bar.hi{background:var(--st-tokens)}.bars .bar.zero{background:#27292d}.crumbs{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:12.5px;color:var(--muted);font-family:var(--ds-font-mono);letter-spacing:.02em}.crumbs a{color:var(--muted);transition:color .15s}.crumbs a:hover{color:var(--fg-2)}.crumbs .sep{color:var(--faint);-webkit-user-select:none;-moz-user-select:none;user-select:none}.crumbs .here{color:var(--fg-2)}.ds-empty{display:grid;place-items:center;text-align:center;padding:80px 40px;border:1px dashed var(--border-strong);border-radius:var(--ds-radius-lg);background:repeating-linear-gradient(45deg,oklch(16% .008 270 / .4) 0 12px,transparent 12px 24px)}.ds-empty h3{font-family:var(--ds-font-serif);font-size:22px;font-weight:500;margin:12px 0 4px;letter-spacing:-.01em}.ds-empty p{color:var(--muted);max-width:360px;margin:0 auto 22px;font-size:13.5px}.ic{width:16px;height:16px;flex:0 0 16px;stroke-width:1.6}.ic-xs{width:12px;height:12px;flex-basis:12px}.ic-lg{width:20px;height:20px;flex-basis:20px}.polling{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 8px;border-radius:999px;font-size:11.5px;font-family:var(--ds-font-mono);color:var(--st-running);background:color-mix(in oklch,var(--st-running) 8%,transparent);border:1px solid color-mix(in oklch,var(--st-running) 25%,transparent);letter-spacing:.02em}.polling:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--st-running);animation:pulse-dot 1.6s ease-in-out infinite}.ds-divider-v{width:1px;align-self:stretch;background:var(--border)}.ds-line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.ds-line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:36px}.page-header h1{font-family:var(--ds-font-serif);font-weight:600;font-size:clamp(34px,4.4vw,48px);letter-spacing:-.02em;line-height:1.05;margin:0}.page-header .eyebrow{font-family:var(--ds-font-mono);font-size:11px;letter-spacing:.16em;color:var(--subtle);text-transform:uppercase;margin-bottom:12px}.page-header .sub{color:var(--muted);font-size:14px;margin-top:10px;max-width:520px}.page-header .right{display:flex;align-items:center;gap:10px}@media(max-width:720px){.page-header{flex-direction:column;align-items:flex-start}}.filter-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:18px;margin-bottom:24px;border-bottom:1px solid var(--hairline)}.chips{display:flex;gap:6px;flex-wrap:wrap}.chip{height:28px;padding:0 12px;display:inline-flex;align-items:center;gap:6px;border-radius:999px;font-size:12px;font-weight:500;color:var(--muted);border:1px solid transparent;transition:color .15s,background .15s,border-color .15s;cursor:pointer;background:none;font-family:inherit}.chip:hover{color:var(--fg-2);background:var(--surface)}.chip.active{color:var(--fg);background:var(--surface-2);border-color:var(--border-strong)}.chip .count{font-family:var(--ds-font-mono);font-size:11px;color:var(--subtle)}.series-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}@media(max-width:720px){.series-grid{grid-template-columns:1fr;gap:16px}}.series-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--ds-radius-lg);overflow:hidden;transition:border-color .18s,background .18s,transform .18s;cursor:pointer;text-decoration:none;color:inherit}.series-card:hover{border-color:var(--border-strong);transform:translateY(-1px)}.series-card:hover .series-cover .frame-play{opacity:1}.series-cover{position:relative;border-bottom:1px solid var(--border)}.series-cover .slate{position:absolute;top:12px;left:12px;z-index:4;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#07090e99}.status-strip{position:absolute;left:12px;bottom:12px;display:flex;gap:4px;z-index:4}.status-strip .dot{width:8px;height:8px;border-radius:2px;background:var(--faint);box-shadow:0 0 0 1px #0006}.status-strip .dot.draft{background:var(--st-draft)}.status-strip .dot.queued{background:var(--st-queued)}.status-strip .dot.running{background:var(--st-running);animation:pulse-dot 1.6s ease-in-out infinite}.status-strip .dot.success{background:var(--st-success)}.status-strip .dot.failed{background:var(--st-failed)}.series-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:14px;flex:1}.series-title{font-family:var(--ds-font-serif);font-size:22px;font-weight:500;letter-spacing:-.01em;line-height:1.25;color:var(--fg)}.series-tagline{color:var(--muted);font-size:13px;line-height:1.55}.series-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;font-family:var(--ds-font-mono);font-size:11.5px;color:var(--subtle);padding-top:12px;border-top:1px solid var(--hairline);margin-top:auto;letter-spacing:.02em}.series-meta .tokens{color:var(--st-tokens)}.series-new{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:36px 24px;background:transparent;border:1px dashed var(--border-strong);border-radius:var(--ds-radius-lg);color:var(--muted);transition:border-color .18s,background .18s,color .18s;cursor:pointer;text-align:center;gap:12px;font-family:inherit}.series-new:hover{border-color:var(--accent-line);background:#14132766;color:var(--fg-2)}.series-new .plus{width:38px;height:38px;border-radius:50%;border:1px dashed var(--border-strong);display:grid;place-items:center;color:var(--muted);transition:border-color .18s,color .18s}.series-new:hover .plus{border-color:var(--accent-line);color:var(--accent-2)}.series-new .label{font-family:var(--ds-font-serif);font-size:16px;color:inherit}.series-new .hint{font-size:12px;color:var(--subtle);letter-spacing:.04em;font-family:var(--ds-font-mono);text-transform:uppercase}.series-new.open{background:var(--surface);border-style:solid;border-color:var(--border-strong);cursor:default;padding:24px}.series-new.open .plus,.series-new.open .hint,.series-new.open .label{display:none}.series-create-form{display:flex;width:100%;flex-direction:column;gap:12px}.series-create-form .actions{display:flex;gap:8px;justify-content:flex-end}.series-create-form h4{font-family:var(--ds-font-serif);margin:0 0 4px;font-size:16px;color:var(--fg);font-weight:500;letter-spacing:-.005em}.series-create-form p{margin:0 0 8px;font-size:12.5px;color:var(--muted)}.crumbs-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px}.title-block{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:flex-start;margin-bottom:14px}.title-block h1{font-family:var(--ds-font-serif);font-size:clamp(36px,5vw,56px);font-weight:600;letter-spacing:-.02em;line-height:1.04;margin:0;color:var(--fg);position:relative;display:inline-flex;align-items:center;gap:14px;cursor:text}.token-card{align-self:flex-start;display:flex;flex-direction:column;gap:6px;min-width:220px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--ds-radius-md)}.token-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.token-card-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--subtle);font-weight:500}.token-card-trend{font-family:var(--ds-font-mono);font-size:11px;color:var(--st-success)}.token-card-value{font-family:var(--ds-font-serif);font-size:26px;font-weight:500;color:var(--st-tokens);letter-spacing:-.005em;font-variant-numeric:tabular-nums;line-height:1}.token-card-value .unit{font-family:var(--ds-font-mono);font-size:12px;color:var(--muted);margin-left:4px;font-weight:400}.token-card-bars{display:flex;align-items:flex-end;gap:3px;height:36px;margin-top:4px}.token-card-bars .b{flex:1 1 0;background:color-mix(in oklch,var(--st-tokens) 30%,transparent);border-radius:2px 2px 0 0;min-height:4px;position:relative}.token-card-bars .b.hi{background:var(--st-tokens)}.token-card-bars .b.zero{background:#27292d;min-height:3px}.token-card-foot{display:flex;justify-content:space-between;font-family:var(--ds-font-mono);font-size:10px;color:var(--subtle);letter-spacing:.04em;margin-top:2px}.meta-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px}.meta-row .left{color:var(--muted);font-size:14px;max-width:720px;line-height:1.6}.meta-row .meta-bits{display:flex;gap:16px;align-items:center;flex-wrap:wrap;font-family:var(--ds-font-mono);font-size:11.5px;color:var(--subtle);margin-top:8px;letter-spacing:.02em}.meta-row .right{flex-shrink:0}.stats{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:36px;padding:4px 0;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}@media(max-width:1024px){.stats{grid-template-columns:repeat(3,1fr)}}@media(max-width:540px){.stats{grid-template-columns:repeat(2,1fr)}}.stats .stat{background:transparent;border:0;padding:16px 8px;border-radius:0}.stats .stat+.stat{border-left:1px solid var(--hairline)}@media(max-width:1024px){.stats .stat+.stat{border-left:0}.stats .stat{border-bottom:1px solid var(--hairline)}}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:16px}.section-head h2{font-family:var(--ds-font-serif);font-size:18px;font-weight:600;margin:0;letter-spacing:-.005em;color:var(--fg)}.section-head .count{font-family:var(--ds-font-mono);color:var(--subtle);font-size:12px;margin-left:8px}.section-head .right{display:flex;align-items:center;gap:12px}.storyboard{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}@media(max-width:1024px){.storyboard{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.storyboard{grid-template-columns:1fr;gap:14px}}.shot{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--ds-radius-lg);overflow:hidden;text-decoration:none;color:inherit;transition:border-color .18s,background .18s,transform .18s;cursor:pointer;position:relative}.shot:hover{border-color:var(--border-strong);transform:translateY(-1px)}.shot .preview{position:relative}.shot .preview .slate{position:absolute;top:12px;left:12px;z-index:4;background:#07090e9e;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.shot .preview .pill{position:absolute;top:12px;right:12px;z-index:4;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.shot-body{padding:14px 16px 8px;display:flex;flex-direction:column;gap:10px;flex:1}.shot-prompt{margin:0;font-size:13.5px;line-height:1.55;color:var(--fg-2)}.shot-meta{font-family:var(--ds-font-mono);font-size:11px;color:var(--subtle);letter-spacing:.02em;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.shot-meta .dot-sep{color:var(--faint)}.shot-foot{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--hairline);font-family:var(--ds-font-mono);font-size:11px;color:var(--subtle);letter-spacing:.02em}.shot-foot .tokens{color:var(--st-tokens)}.shot.failed .preview .frame{background:radial-gradient(120% 90% at 50% 40%,#490308,#170002 60%,#050101)}.shot-error{display:flex;gap:10px;padding:12px 16px;background:#43000459;background:oklch(24% .1 25 / .35);border-top:1px solid oklch(40% .14 25 / .45);color:#ffbeb8;color:oklch(86% .1 25);font-size:12.5px;line-height:1.45}.shot-error .ic{color:#ff958d;color:oklch(78% .18 25);margin-top:1px}.shot-error .code{font-family:var(--ds-font-mono);font-size:10.5px;color:#d6857f;letter-spacing:.04em;display:block;margin-top:3px}.shot.running .running-meta{display:block;margin-top:-2px;font-family:var(--ds-font-mono);font-size:11px;color:var(--st-running);letter-spacing:.02em}.shot.draft .preview .frame{background:#0f1117}.shot-new{background:transparent;border:1px dashed var(--border-strong);border-radius:var(--ds-radius-lg);display:flex;flex-direction:column;cursor:pointer;transition:border-color .18s,background .18s,transform .18s;overflow:hidden;min-height:100%;font-family:inherit;color:inherit}.shot-new:hover{border-color:var(--accent-line);background:#1413274d;transform:translateY(-1px)}.shot-new .preview-placeholder{aspect-ratio:16 / 9;display:grid;place-items:center;border-bottom:1px dashed var(--border-strong);position:relative}.shot-new:hover .preview-placeholder{border-bottom-color:var(--accent-line)}.shot-new .plus-circle{width:44px;height:44px;border-radius:50%;border:1px dashed var(--border-strong);display:grid;place-items:center;color:var(--muted);transition:border-color .18s,color .18s}.shot-new:hover .plus-circle{border-color:var(--accent-line);color:var(--accent-2)}.shot-new .new-body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:6px}.shot-new-title{font-family:var(--ds-font-serif);font-size:16px;color:var(--fg-2);font-weight:500}.shot-new-hint{font-family:var(--ds-font-mono);font-size:11px;color:var(--subtle);letter-spacing:.06em}.footer-note{margin-top:32px;padding:16px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--ds-radius-md);display:flex;gap:12px;align-items:center;color:var(--muted);font-size:12.5px}.footer-note .ic{color:var(--st-running)}.editor{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:24px;align-items:flex-start}@media(max-width:1180px){.editor{grid-template-columns:1fr}}.editor-main{min-width:0;display:flex;flex-direction:column;gap:24px}.editor-side{position:sticky;top:80px;max-height:calc(100vh - 96px)}.position{display:inline-flex;align-items:center;gap:4px;padding:4px 4px 4px 12px;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-family:var(--ds-font-mono);font-size:11.5px;color:var(--muted);letter-spacing:.02em}.position .seq{color:var(--fg-2);font-weight:500}.position .navbtn{width:22px;height:22px;display:grid;place-items:center;border-radius:50%;color:var(--muted);transition:background .15s,color .15s;cursor:pointer;background:none;border:0}.position .navbtn:hover{background:var(--surface-2);color:var(--fg)}.shot-header{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.shot-header .slate{transform:scale(1.05);transform-origin:left center}.player{position:relative;background:#010202;border:1px solid var(--border);border-radius:var(--ds-radius-lg);overflow:hidden}.player .video-wrap{position:relative;aspect-ratio:16 / 9;background:radial-gradient(120% 90% at 25% 30%,#002e41,#010813 60%,#010203);background:radial-gradient(120% 90% at 25% 30%,color(xyz 0.019 0.023 0.055),#010813 60%,#010203)}.player video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.player .vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 38%,oklch(0% 0 0 / .6) 100%),repeating-linear-gradient(0deg,oklch(100% 0 0 / .012) 0 1px,transparent 1px 3px);pointer-events:none}.player-meta{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:var(--bg-2);border-top:1px solid var(--border);font-family:var(--ds-font-mono);font-size:11.5px;color:var(--muted);letter-spacing:.02em}.player-meta .left{display:flex;gap:12px;flex-wrap:wrap}.player-meta .left span{display:inline-flex;align-items:center;gap:6px}.player-meta .left .label{color:var(--subtle)}.player-meta .left .tokens{color:var(--st-tokens)}.player-meta .right{display:flex;gap:6px}.player-meta .right .ds-btn{height:28px;padding:0 12px;font-size:11.5px}.progress-card{padding:28px;background:var(--surface);border:1px solid color-mix(in oklch,var(--st-running) 35%,var(--border));border-radius:var(--ds-radius-lg);display:flex;flex-direction:column;gap:18px;position:relative;overflow:hidden}.progress-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,color-mix(in oklch,var(--st-running) 8%,transparent) 0%,transparent 60%);pointer-events:none}.progress-card-head{display:flex;align-items:center;gap:14px;position:relative}.progress-card-head .ds-spinner{flex-shrink:0}.progress-card-head h3{font-family:var(--ds-font-serif);font-weight:500;font-size:20px;margin:0;color:var(--fg);letter-spacing:-.005em}.progress-card-head .meta{color:var(--muted);font-size:12.5px;margin-top:4px;font-family:var(--ds-font-mono);letter-spacing:.02em}.progress-bar{position:relative;height:6px;background:var(--border);border-radius:999px;overflow:hidden}.progress-bar .fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--st-running) 0%,oklch(82% .14 240) 100%);border-radius:999px}.progress-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 35%,oklch(100% 0 0 / .2) 50%,transparent 65%);animation:shimmer-sweep 2.4s linear infinite}.error-card{padding:22px 26px;background:#32000359;border:1px solid color-mix(in oklch,var(--st-failed) 40%,transparent);border-radius:var(--ds-radius-lg);display:flex;gap:16px}.error-card .icon{width:40px;height:40px;flex-shrink:0;border-radius:50%;background:#56000499;background:oklch(28% .14 25 / .6);display:grid;place-items:center;color:#ffaba3;color:oklch(82% .16 25)}.error-card h3{font-family:var(--ds-font-serif);font-weight:500;font-size:18px;margin:0 0 6px;color:#ffe2de;color:oklch(94% .08 25);letter-spacing:-.005em}.error-card p{margin:0 0 12px;color:#ffbeb8;color:oklch(86% .08 25);font-size:13.5px;line-height:1.55}.error-card .code{font-family:var(--ds-font-mono);font-size:11px;color:#cc8b85;letter-spacing:.04em;display:inline-block;padding:2px 8px;background:#1f000180;border-radius:4px;margin-bottom:14px}.form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--ds-radius-lg);padding:28px;display:flex;flex-direction:column;gap:24px}@media(max-width:640px){.form-section{padding:20px 16px}}.form-section.readonly{background:var(--bg-2);border-color:var(--hairline)}.form-section.readonly .ds-textarea,.form-section.readonly .ds-input,.form-section.readonly .ds-select{pointer-events:none;background:transparent;border-color:var(--hairline);color:var(--fg-2)}.field-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media(max-width:720px){.field-grid-4{grid-template-columns:repeat(2,1fr)}}.prompt-textarea{position:relative}.prompt-textarea .ds-textarea{padding-bottom:36px}.prompt-count{position:absolute;right:14px;bottom:12px;font-family:var(--ds-font-mono);font-size:11px;color:var(--subtle);letter-spacing:.02em;pointer-events:none}.media-field{display:flex;flex-direction:column;gap:12px}.media-field-head{display:flex;align-items:baseline;justify-content:space-between}.media-field-head .field-label{font-size:13px;color:var(--fg-2);font-weight:500}.media-field-head .hint{font-size:11.5px;color:var(--subtle);font-family:var(--ds-font-mono);letter-spacing:.02em}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.media-tile{position:relative;aspect-ratio:1 / 1;border-radius:var(--ds-radius-sm);overflow:hidden;border:1px solid var(--border);background:#07090e;transition:border-color .15s,transform .15s}.media-tile:hover{border-color:var(--border-strong)}.media-tile img,.media-tile video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.media-tile.draggable{cursor:grab}.media-tile.draggable:active{cursor:grabbing}.media-tile.dragging{opacity:.35}.media-tile.drag-over{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft),inset 0 0 0 2px var(--accent-line);transform:scale(1.02)}.media-tile .seq{position:absolute;top:6px;left:6px;z-index:2;font-family:var(--ds-font-mono);font-size:10px;letter-spacing:.06em;color:#eaebefe6;background:#07090ea6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:2px 6px;border-radius:4px;pointer-events:none;opacity:0;transition:opacity .15s}.media-tile.draggable .seq{opacity:1}.media-tile .remove{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:#07090ecc;color:var(--fg);display:grid;place-items:center;cursor:pointer;opacity:0;transition:opacity .15s,background .15s;border:0}.media-tile:hover .remove{opacity:1}.media-tile .remove:hover{background:var(--st-failed)}.media-drop{aspect-ratio:1 / 1;border:1px dashed var(--border-strong);border-radius:var(--ds-radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--muted);cursor:pointer;transition:border-color .15s,background .15s,color .15s;text-align:center;background:none;font-family:inherit}.media-drop:hover{border-color:var(--accent-line);background:#1413274d;color:var(--fg-2)}.media-drop .plus-circ{width:32px;height:32px;border-radius:50%;border:1px dashed var(--border-strong);display:grid;place-items:center}.media-drop:hover .plus-circ{border-color:var(--accent-line);color:var(--accent-2)}.media-drop .hint-text{font-size:11px;font-family:var(--ds-font-mono);letter-spacing:.02em}.media-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--ds-radius);overflow:hidden;background:var(--bg-2)}.audio-row{display:flex;align-items:center;gap:12px;padding:10px 14px;transition:background .15s}.audio-row+.audio-row{border-top:1px solid var(--hairline)}.audio-row:hover{background:var(--surface)}.audio-row audio{flex:1;height:30px}.audio-row .remove{width:22px;height:22px;border-radius:50%;color:var(--subtle);display:grid;place-items:center;transition:color .15s,background .15s;cursor:pointer;background:none;border:0}.audio-row .remove:hover{color:var(--st-failed);background:var(--surface-2)}.audio-add{padding:12px 14px;display:flex;gap:12px;align-items:center;color:var(--muted);border-top:1px dashed var(--border-strong);cursor:pointer;transition:background .15s,color .15s;background:none;border-left:0;border-right:0;border-bottom:0;width:100%;font-family:inherit}.audio-add:hover{background:var(--surface);color:var(--fg-2)}.audio-add .plus-circ{width:28px;height:28px;border-radius:50%;border:1px dashed var(--border-strong);display:grid;place-items:center}.audio-add .hint-text{font-size:12px}.action-bar{display:flex;justify-content:space-between;align-items:center;padding-top:4px}.action-bar .right{display:flex;gap:8px}.save-generate{background:linear-gradient(135deg,var(--accent) 0%,oklch(54% .22 320) 100%);color:#fbfbff;color:oklch(99% .01 285);border:1px solid oklch(64% .18 285 / .4);box-shadow:0 6px 22px -10px #8477f3b3}.save-generate:hover{filter:brightness(1.08)}.assistant-frame{background:var(--surface);border:1px solid var(--border);border-radius:var(--ds-radius-lg);display:flex;flex-direction:column;overflow:hidden;max-height:calc(100vh - 96px)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,-apple-system,BlinkMacSystemFont,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 0 0% 100%;--foreground: 240 10% 3.9%;--card: 0 0% 100%;--card-foreground: 240 10% 3.9%;--primary: 240 5.9% 10%;--primary-foreground: 0 0% 98%;--secondary: 240 4.8% 95.9%;--secondary-foreground: 240 5.9% 10%;--muted: 240 4.8% 95.9%;--muted-foreground: 240 3.8% 46.1%;--accent: 240 4.8% 95.9%;--accent-foreground: 240 5.9% 10%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 0 0% 98%;--border: 240 5.9% 90%;--input: 240 5.9% 90%;--ring: 240 5.9% 10%;--radius: .75rem}.dark{--background: 240 10% 3.9%;--foreground: 0 0% 98%;--card: 240 6% 7%;--card-foreground: 0 0% 98%;--primary: 0 0% 98%;--primary-foreground: 240 5.9% 10%;--secondary: 240 3.7% 14%;--secondary-foreground: 0 0% 98%;--muted: 240 3.7% 14%;--muted-foreground: 240 5% 64.9%;--accent: 240 3.7% 14%;--accent-foreground: 0 0% 98%;--destructive: 0 62.8% 50%;--destructive-foreground: 0 0% 98%;--border: 240 3.7% 18%;--input: 240 3.7% 18%;--ring: 240 4.9% 83.9%}*{border-color:hsl(var(--border))}html,body,#root{height:100%}body{background:var(--bg);color:var(--fg);font-family:var(--ds-font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv01" 1,"cv02" 1,"cv03" 1,"cv04" 1,"cv11","ss01"}.dark{color-scheme:dark}.dark option{background-color:hsl(var(--card));color:hsl(var(--foreground))}.pointer-events-none{pointer-events:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.left-3{left:.75rem}.right-3{right:.75rem}.top-1\/2{top:50%}.z-50{z-index:50}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.size-10{width:2.5rem;height:2.5rem}.size-12{width:3rem;height:3rem}.size-2\.5{width:.625rem;height:.625rem}.size-3{width:.75rem;height:.75rem}.size-3\.5{width:.875rem;height:.875rem}.size-4{width:1rem;height:1rem}.size-6{width:1.5rem;height:1.5rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-14{height:3.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.min-h-0{min-height:0px}.min-h-\[96px\]{min-height:96px}.min-h-full{min-height:100%}.w-10{width:2.5rem}.w-full{width:100%}.min-w-0{min-width:0px}.max-w-5xl{max-width:64rem}.max-w-\[85\%\]{max-width:85%}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.resize-none{resize:none}.resize{resize:both}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-6{gap:1.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-all{word-break:break-all}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-destructive\/40{border-color:hsl(var(--destructive) / .4)}.border-foreground\/10{border-color:hsl(var(--foreground) / .1)}.border-input{border-color:hsl(var(--input))}.border-primary\/60{border-color:hsl(var(--primary) / .6)}.border-transparent{border-color:transparent}.bg-accent{background-color:hsl(var(--accent))}.bg-amber-500\/15{background-color:#f59e0b26}.bg-background{background-color:hsl(var(--background))}.bg-background\/60{background-color:hsl(var(--background) / .6)}.bg-background\/70{background-color:hsl(var(--background) / .7)}.bg-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-card\/60{background-color:hsl(var(--card) / .6)}.bg-card\/70{background-color:hsl(var(--card) / .7)}.bg-destructive{background-color:hsl(var(--destructive))}.bg-destructive\/10{background-color:hsl(var(--destructive) / .1)}.bg-emerald-500\/15{background-color:#10b98126}.bg-primary{background-color:hsl(var(--primary))}.bg-primary\/10{background-color:hsl(var(--primary) / .1)}.bg-red-500\/15{background-color:#ef444426}.bg-secondary{background-color:hsl(var(--secondary))}.bg-secondary\/40{background-color:hsl(var(--secondary) / .4)}.bg-sky-500\/15{background-color:#0ea5e926}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-3{padding-bottom:.75rem}.pl-9{padding-left:2.25rem}.pr-9{padding-right:2.25rem}.pt-0{padding-top:0}.pt-2{padding-top:.5rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-\[13px\]{font-size:13px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.tracking-tight{letter-spacing:-.025em}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.text-card-foreground{color:hsl(var(--card-foreground))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-foreground{color:hsl(var(--foreground))}.text-foreground\/80{color:hsl(var(--foreground) / .8)}.text-foreground\/90{color:hsl(var(--foreground) / .9)}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-sky-400{--tw-text-opacity: 1;color:rgb(56 189 248 / var(--tw-text-opacity, 1))}.underline-offset-4{text-underline-offset:4px}.opacity-40{opacity:.4}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-xl{--tw-backdrop-blur: blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.running{animation-play-state:running}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-accent\/50:hover{background-color:hsl(var(--accent) / .5)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:underline:hover{text-decoration-line:underline}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}@media(min-width:768px){.md\:grid-cols-\[1fr_1fr_140px_120px\]{grid-template-columns:1fr 1fr 140px 120px}.md\:grid-cols-\[260px_1fr\]{grid-template-columns:260px 1fr}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}
