@import "https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap";:root{--accent:#5b54f0;--accent-press:color-mix(in oklab, var(--accent), #000 14%);--accent-soft:color-mix(in oklab, var(--accent), #fff 88%);--accent-ring:color-mix(in oklab, var(--accent), transparent 64%);--on-accent:#fff;--ok:#16a36a;--ok-soft:#def0e6;--warn:#d98a16;--bad:#e0524d;--bad-soft:#fbe4e3;--bg:#f4f4f6;--bg-sunken:#ececf0;--panel:#fff;--panel-2:#fbfbfc;--elev:#fff;--line:#e6e6eb;--line-strong:#d6d6de;--line-soft:#efeff3;--ink:#1b1b22;--ink-2:#56565f;--ink-3:#86868f;--ink-4:#a9a9b2;--canvas-bg:#e9e9ef;--canvas-dot:#d3d3dc;--r-xs:4px;--r-sm:6px;--r-md:8px;--r-lg:11px;--r-xl:16px;--sh-1:0 1px 2px #1414200f, 0 1px 1px #1414200a;--sh-2:0 4px 14px #1414201a, 0 1px 3px #1414200f;--sh-3:0 16px 44px #1414202e, 0 4px 12px #1414201a;--sh-pop:0 10px 30px #14142029, 0 2px 6px #14142014;--row-h:30px;--tool-h:52px;--field-h:30px;--pad:12px;--gap:8px;--mono:"IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--sans:"Hanken Grotesk", system-ui, -apple-system, sans-serif}[data-theme=dark]{--accent:#7b74ff;--accent-press:color-mix(in oklab, var(--accent), #fff 12%);--accent-soft:color-mix(in oklab, var(--accent), #000 74%);--accent-ring:color-mix(in oklab, var(--accent), transparent 60%);--on-accent:#fff;--ok:#3ec78a;--ok-soft:#14271d;--warn:#e0a93f;--bad:#f0726c;--bad-soft:#2c1817;--bg:#0d0d10;--bg-sunken:#08080a;--panel:#16161b;--panel-2:#131318;--elev:#1c1c22;--line:#26262e;--line-strong:#34343d;--line-soft:#1e1e24;--ink:#ededf1;--ink-2:#a6a6b0;--ink-3:#74747e;--ink-4:#54545d;--canvas-bg:#08080b;--canvas-dot:#1c1c23;--sh-1:0 1px 2px #0006;--sh-2:0 4px 14px #00000073, 0 1px 3px #0006;--sh-3:0 18px 48px #0009, 0 6px 16px #00000080;--sh-pop:0 12px 34px #0000008c, 0 2px 8px #00000080}[data-density=compact]{--row-h:26px;--tool-h:46px;--field-h:27px;--pad:9px;--gap:6px}*{box-sizing:border-box}html,body{height:100%;margin:0}body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-size:13px;line-height:1.45;overflow:hidden}#root{height:100vh}button{cursor:pointer;color:inherit;font-family:inherit}input,select,textarea{font-family:inherit}::selection{background:var(--accent-ring)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line-strong);background-clip:content-box;border:3px solid #0000;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--ink-4);background-clip:content-box}::-webkit-scrollbar-track{background:0 0}.app{grid-template-rows:var(--tool-h) 1fr;background:var(--bg);height:100vh;color:var(--ink);display:grid}.body{grid-template-columns:248px 1fr var(--right-w,320px);min-height:0;display:grid;position:relative}[data-left-collapsed=true] .body{grid-template-columns:0px 1fr var(--right-w,320px)}.panel{background:var(--panel);flex-direction:column;min-height:0;display:flex;position:relative}.panel.left{border-right:1px solid var(--line)}.panel.right{border-left:1px solid var(--line)}.toolbar{background:var(--panel);border-bottom:1px solid var(--line);z-index:30;align-items:center;gap:10px;padding:0 12px;display:flex}.tb-group{align-items:center;gap:4px;display:flex}.tb-sep{background:var(--line);width:1px;height:22px;margin:0 4px}.spacer{flex:1}.brand{align-items:center;gap:9px;padding-right:4px;display:flex}.brand-mark{background:linear-gradient(150deg, var(--accent), color-mix(in oklab, var(--accent), #000 22%));color:#fff;width:26px;height:26px;box-shadow:var(--sh-1);border-radius:7px;flex:none;place-items:center;display:grid}.brand-mark svg{width:15px;height:15px}.crumb{align-items:center;gap:7px;min-width:0;display:flex}.crumb .unit{color:var(--ink-3);white-space:nowrap;font-weight:500}.crumb .slash{color:var(--ink-4)}.crumb .act{color:var(--ink);white-space:nowrap;border-radius:var(--r-sm);border:1px solid #0000;padding:3px 7px;font-weight:600}.crumb .act:hover{background:var(--bg-sunken)}.type-chip{background:var(--accent-soft);height:22px;color:var(--accent);border:1px solid color-mix(in oklab, var(--accent), transparent 78%);border-radius:999px;align-items:center;gap:5px;padding:0 8px;font-size:11.5px;font-weight:600;display:inline-flex}.type-chip svg{width:12px;height:12px}.save-state{color:var(--ink-3);align-items:center;gap:5px;font-size:11.5px;display:flex}.save-state .dot{background:var(--ok);border-radius:50%;width:6px;height:6px}.btn{border-radius:var(--r-md);border:1px solid var(--line-strong);background:var(--panel-2);height:30px;color:var(--ink);white-space:nowrap;align-items:center;gap:6px;padding:0 11px;font-size:12.5px;font-weight:600;transition:background .12s,border-color .12s,box-shadow .12s;display:inline-flex}.btn:hover{background:var(--bg-sunken);border-color:var(--line-strong)}.btn:active{transform:translateY(.5px)}.btn svg{width:14px;height:14px}.btn.primary{background:var(--accent);color:var(--on-accent);box-shadow:var(--sh-1);border-color:#0000}.btn.primary:hover{background:var(--accent-press)}.btn.ghost{background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--bg-sunken)}.btn.sm{height:26px;padding:0 9px;font-size:12px}.icon-btn{border-radius:var(--r-md);width:30px;height:30px;color:var(--ink-2);background:0 0;border:1px solid #0000;place-items:center;transition:background .12s,color .12s;display:grid}.icon-btn:hover{background:var(--bg-sunken);color:var(--ink)}.icon-btn.on{background:var(--accent-soft);color:var(--accent)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn svg{width:16px;height:16px}.seg{background:var(--bg-sunken);border-radius:var(--r-md);gap:2px;padding:2px;display:inline-flex}.seg button{height:24px;color:var(--ink-2);border-radius:var(--r-sm);background:0 0;border:none;align-items:center;gap:5px;padding:0 9px;font-size:12px;font-weight:600;display:inline-flex}.seg button.on{background:var(--panel);color:var(--ink);box-shadow:var(--sh-1)}.seg button svg{width:14px;height:14px}.zoomctl{background:var(--bg-sunken);border-radius:var(--r-md);align-items:center;gap:2px;padding:2px;display:inline-flex}.zoomctl button{width:24px;height:24px;color:var(--ink-2);border-radius:var(--r-sm);background:0 0;border:none;place-items:center;display:grid}.zoomctl button:hover{background:var(--panel);color:var(--ink)}.zoomctl .val{text-align:center;min-width:50px;font-family:var(--mono);color:var(--ink);font-size:11.5px;font-weight:500}.panel-head{flex-direction:column;gap:9px;padding:11px 12px 8px;display:flex}.panel-title{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);font-size:11px;font-weight:700}.search{background:var(--bg-sunken);border-radius:var(--r-md);height:32px;color:var(--ink-2);border:1px solid #0000;align-items:center;gap:7px;padding:0 9px;display:flex}.search:focus-within{border-color:var(--accent);background:var(--panel);box-shadow:0 0 0 3px var(--accent-ring)}.search svg{flex:none;width:14px;height:14px}.search input{color:var(--ink);background:0 0;border:none;outline:none;width:100%;font-size:12.5px}.search input::placeholder{color:var(--ink-4)}.kbd{font-family:var(--mono);color:var(--ink-4);border:1px solid var(--line);border-radius:4px;padding:1px 4px;font-size:10px}.type-scroll{flex:1;padding:2px 8px 14px;overflow-y:auto}.type-group{margin-top:8px}.type-group-h{color:var(--ink-3);letter-spacing:.05em;text-transform:uppercase;cursor:default;align-items:center;gap:6px;padding:6px 6px 4px;font-size:10.5px;font-weight:700;display:flex}.type-group-h .cnt{color:var(--ink-4);margin-left:auto;font-weight:600}.type-item{border-radius:var(--r-md);color:var(--ink);cursor:pointer;border:1px solid #0000;align-items:center;gap:10px;padding:7px 8px;display:flex;position:relative}.type-item:hover{background:var(--bg-sunken)}.type-item.on{background:var(--accent-soft);border-color:color-mix(in oklab, var(--accent), transparent 80%)}.type-item.on .ti-ico{color:var(--accent);border-color:color-mix(in oklab, var(--accent), transparent 65%);background:color-mix(in oklab, var(--accent), transparent 88%)}.ti-ico{background:var(--bg-sunken);width:28px;height:28px;color:var(--ink-2);border:1px solid var(--line);border-radius:7px;flex:none;place-items:center;display:grid}.ti-ico svg{width:15px;height:15px}.ti-text{flex-direction:column;min-width:0;display:flex}.ti-name{white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.ti-desc{color:var(--ink-3);white-space:nowrap;text-overflow:ellipsis;font-size:10.5px;overflow:hidden}.ti-on-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;position:absolute;right:9px}.type-item.locked{opacity:.42;cursor:not-allowed}.type-item.locked:hover{background:0 0}.type-item.locked .ti-ico{filter:grayscale()}.ti-soon,.pick-soon{letter-spacing:.2px;color:var(--ink-3);background:var(--bg-sunken);border:1px solid var(--line);white-space:nowrap;border-radius:999px;flex:none;padding:1px 7px;font-size:9.5px;font-weight:700}.ti-soon{position:absolute;right:8px}.pick-soon{position:absolute;top:10px;right:10px}.canvas-wrap{background:var(--canvas-bg);flex-direction:column;min-width:0;display:flex;position:relative}.issue-tabs{background:var(--panel);border-bottom:1px solid var(--line);z-index:5;align-items:center;gap:2px;min-height:42px;padding:6px 10px;display:flex;overflow-x:auto}.issue-tab{border-radius:var(--r-md);height:30px;color:var(--ink-2);white-space:nowrap;background:0 0;border:1px solid #0000;align-items:center;gap:8px;padding:0 11px 0 9px;font-size:12.5px;font-weight:600;transition:background .12s;display:inline-flex}.issue-tab:hover{background:var(--bg-sunken)}.issue-tab.on{background:var(--bg-sunken);color:var(--ink);border-color:var(--line);box-shadow:var(--sh-1)}.issue-tab .num{background:var(--line);width:18px;height:18px;color:var(--ink-2);font-size:11px;font-family:var(--mono);border-radius:5px;place-items:center;display:grid}.issue-tab.on .num{background:var(--accent);color:#fff}.issue-tab .ans-pill{color:var(--ok);background:var(--ok-soft);border-radius:4px;align-items:center;height:15px;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.issue-tab .x{width:16px;height:16px;color:var(--ink-4);border-radius:4px;place-items:center;margin-left:2px;display:grid}.issue-tab .x:hover{background:var(--line-strong);color:var(--ink)}.tab-add{border-radius:var(--r-md);border:1px dashed var(--line-strong);width:28px;height:28px;color:var(--ink-3);background:0 0;flex:none;place-items:center;display:grid}.tab-add:hover{color:var(--accent);border-color:var(--accent)}.viewport{cursor:default;flex:1;min-height:0;position:relative;overflow:hidden}.viewport.panning{cursor:grab}.viewport.panning.active{cursor:grabbing}.viewport.tool-shape{cursor:crosshair}.dotgrid{background-image:radial-gradient(var(--canvas-dot) 1.3px, transparent 1.3px);opacity:.8;pointer-events:none;background-size:22px 22px;position:absolute;inset:0}.scene-host{transform-origin:0 0;position:absolute;top:0;left:0}.scene{width:1920px;height:1080px;box-shadow:0 0 0 1px #00000014, var(--sh-3);background:#fff;border-radius:2px;position:relative;overflow:hidden}.scene img.bg{object-fit:cover;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:100%;position:absolute;inset:0}.scene-grid{pointer-events:none;background-image:linear-gradient(var(--canvas-dot) 1px, transparent 1px), linear-gradient(90deg, var(--canvas-dot) 1px, transparent 1px);opacity:.25;background-size:40px 40px;position:absolute;inset:0}.shape{box-sizing:border-box;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;display:flex;position:absolute}.zone{border:2.5px dashed color-mix(in oklab, var(--shape-c,#5b54f0), transparent 25%);background:color-mix(in oklab, var(--shape-c,#5b54f0), transparent 86%);color:color-mix(in oklab, var(--shape-c,#5b54f0), #000 18%);border-radius:12px;font-size:26px;font-weight:700}.zone .ans-badge{background:var(--ok);color:#fff;border-radius:50%;place-items:center;width:26px;height:26px;display:grid;position:absolute;top:8px;right:8px;box-shadow:0 2px 6px #0003}.zone .ans-badge svg{width:16px;height:16px}.label-card{border:2px solid color-mix(in oklab, var(--shape-c,#5b54f0), transparent 40%);color:#2a2a33;background:#fff;border-radius:14px;padding:0 26px;font-size:30px;font-weight:700;box-shadow:0 6px 16px #00000029}.shape.selected{outline:none}.shape .hit{position:absolute;inset:0}.sel-box{border:1.5px solid var(--accent);pointer-events:none;position:absolute;box-shadow:0 0 0 1px #ffffff80}.handle{border:1.5px solid var(--accent);pointer-events:all;background:#fff;border-radius:2px;width:11px;height:11px;position:absolute;box-shadow:0 1px 2px #0003}.handle.round{border-radius:50%}.dim-badge{background:var(--accent);color:#fff;font-family:var(--mono);white-space:nowrap;pointer-events:none;border-radius:5px;align-items:center;height:20px;padding:0 7px;font-size:11px;font-weight:500;display:inline-flex;position:absolute;transform:translate(-50%)}.guide{pointer-events:none;z-index:9;background:#ff3d8b;position:absolute}.guide.v{width:1px}.guide.h{height:1px}.marquee{border:1px solid var(--accent);background:var(--accent-ring);pointer-events:none;position:absolute}.canvas-tools{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-2);z-index:8;flex-direction:column;gap:3px;padding:4px;display:flex;position:absolute;top:14px;left:14px}.canvas-tools .icon-btn{width:32px;height:32px}.canvas-tools .sep{background:var(--line);height:1px;margin:3px 4px}.canvas-zoom{z-index:8;align-items:center;gap:6px;display:flex;position:absolute;bottom:14px;right:14px}.minimap{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);width:150px;height:86px;box-shadow:var(--sh-2);position:relative;overflow:hidden}.minimap .mm-scene{background:var(--bg-sunken);border:1px solid var(--line-strong);position:absolute}.minimap .mm-view{border:1.5px solid var(--accent);background:var(--accent-ring);border-radius:2px;position:absolute}.pill-ctl{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-2)}.empty-stage{place-items:center;padding:40px;display:grid;position:absolute;inset:0}.empty-card{text-align:center;width:min(560px,90%)}.empty-drop{border:2px dashed var(--line-strong);border-radius:var(--r-xl);background:var(--panel);box-shadow:var(--sh-1);flex-direction:column;align-items:center;gap:14px;padding:48px 40px;display:flex}.empty-drop .ico{background:var(--accent-soft);width:56px;height:56px;color:var(--accent);border-radius:16px;place-items:center;display:grid}.empty-drop .ico svg{width:28px;height:28px}.empty-drop h2{margin:0;font-size:18px}.empty-drop p{color:var(--ink-3);max-width:360px;margin:0;font-size:13px}.empty-steps{justify-content:center;gap:10px;margin-top:20px;display:flex}.empty-steps .step{color:var(--ink-3);align-items:center;gap:8px;font-size:12px;display:flex}.empty-steps .n{background:var(--bg-sunken);width:20px;height:20px;color:var(--ink-2);border-radius:50%;place-items:center;font-size:11px;font-weight:700;display:grid}.insp{flex:1;overflow-y:auto}.insp-head{border-bottom:1px solid var(--line);background:var(--panel);z-index:2;align-items:center;gap:10px;padding:12px;display:flex;position:sticky;top:0}.insp-head .ico{background:var(--accent-soft);width:30px;height:30px;color:var(--accent);border-radius:8px;flex:none;place-items:center;display:grid}.insp-head .ico svg{width:16px;height:16px}.insp-head .meta{min-width:0}.insp-head .t{white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:700;overflow:hidden}.insp-head .s{color:var(--ink-3);font-size:11px}.sect{border-bottom:1px solid var(--line);padding:12px}.sect-h{letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);align-items:center;gap:7px;margin-bottom:11px;font-size:11px;font-weight:700;display:flex}.sect-h .chev{color:var(--ink-4);margin-left:auto}.field{flex-direction:column;gap:5px;margin-bottom:10px;display:flex}.field:last-child{margin-bottom:0}.field>label{color:var(--ink-2);font-size:11.5px;font-weight:600}.row2,.row4{grid-template-columns:1fr 1fr;gap:8px;display:grid}.inp{height:var(--field-h);background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);color:var(--ink);align-items:center;gap:6px;padding:0 8px;display:flex}.inp:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.inp .k{color:var(--ink-4);font-size:11px;font-weight:600;font-family:var(--mono)}.inp input{color:var(--ink);background:0 0;border:none;outline:none;width:100%;min-width:0;font-size:12.5px}.inp input.mono{font-family:var(--mono)}.inp.text input{font-size:12.5px}textarea.inp{resize:vertical;height:auto;min-height:56px;padding:7px 9px;font-size:12.5px;line-height:1.5}.selectbox{position:relative}.selectbox select{appearance:none;width:100%;height:var(--field-h);background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);color:var(--ink);padding:0 28px 0 9px;font-size:12.5px}.selectbox select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.selectbox .chev{pointer-events:none;color:var(--ink-3);position:absolute;top:50%;right:8px;transform:translateY(-50%)}.swatches{flex-wrap:wrap;gap:6px;display:flex}.swatch{border:2px solid var(--panel);width:26px;height:26px;box-shadow:0 0 0 1px var(--line-strong);cursor:pointer;border-radius:7px;position:relative}.swatch.on{box-shadow:0 0 0 2px var(--accent)}.swatch.on:after{content:"";border:2px solid #fff;border-radius:5px;position:absolute;inset:0}.media-pick{background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-md);align-items:center;gap:9px;padding:8px;display:flex}.media-pick .thumb{background:var(--bg-sunken);width:40px;height:40px;color:var(--ink-3);border-radius:6px;flex:none;place-items:center;display:grid;overflow:hidden}.media-pick .thumb img{object-fit:cover;width:100%;height:100%}.media-pick .mm{flex:1;min-width:0}.media-pick .mm .nm{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.media-pick .mm .sz{color:var(--ink-3);font-size:10.5px}.audio-chip{background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-md);align-items:center;gap:8px;padding:7px 9px;display:flex}.audio-chip .play{background:var(--accent);color:#fff;border:none;border-radius:50%;flex:none;place-items:center;width:24px;height:24px;display:grid}.audio-chip .play svg{width:12px;height:12px}.wave{flex:1;align-items:center;gap:2px;height:20px;display:flex}.wave i{background:var(--accent);opacity:.55;border-radius:2px;width:2.5px}.toggle-row{justify-content:space-between;align-items:center;gap:10px;padding:9px 0;display:flex}.toggle-row .tl{flex-direction:column;gap:1px;display:flex}.toggle-row .tl .nm{font-size:12.5px;font-weight:600}.toggle-row .tl .ds{color:var(--ink-3);font-size:11px}.switch{background:var(--line-strong);border:none;border-radius:999px;flex:none;width:36px;height:21px;transition:background .15s;position:relative}.switch:after{content:"";width:17px;height:17px;box-shadow:var(--sh-1);background:#fff;border-radius:50%;transition:transform .15s;position:absolute;top:2px;left:2px}.switch.on{background:var(--accent)}.switch.on:after{transform:translate(15px)}.answer-card{background:var(--ok-soft);border:1px solid color-mix(in oklab, var(--ok), transparent 70%);border-radius:var(--r-md);gap:9px;padding:10px 11px;display:flex}.answer-card .ai{color:var(--ok);flex:none}.answer-card .at{font-size:12px}.answer-card .at b{margin-bottom:2px;display:block}.layer{border-radius:var(--r-sm);color:var(--ink-2);cursor:pointer;align-items:center;gap:8px;padding:6px 8px;display:flex}.layer:hover{background:var(--bg-sunken)}.layer.on{background:var(--accent-soft);color:var(--ink)}.layer .sw{border:1px solid #0000001f;border-radius:4px;flex:none;width:14px;height:14px}.layer .nm{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:12px;font-weight:600;overflow:hidden}.layer .vis{color:var(--ink-4);width:14px;height:14px}.insp-empty{text-align:center;color:var(--ink-3);flex-direction:column;align-items:center;gap:12px;padding:40px 24px;display:flex}.insp-empty .ic{background:var(--bg-sunken);width:46px;height:46px;color:var(--ink-4);border-radius:12px;place-items:center;display:grid}.insp-empty h4{color:var(--ink-2);margin:4px 0 0;font-size:13px}.insp-empty p{max-width:200px;margin:0;font-size:12px}.scrim{z-index:90;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0a0a1080;animation:.15s fade;position:fixed;inset:0}@keyframes fade{0%{opacity:0}}@keyframes slidein{0%{opacity:0;transform:translate(30px)}}@keyframes pop{0%{opacity:0;transform:scale(.97)}}.preview-over{background:var(--bg);border-left:1px solid var(--line);z-index:91;width:min(720px,60vw);box-shadow:var(--sh-3);flex-direction:column;animation:.22s cubic-bezier(.2,.7,.2,1) slidein;display:flex;position:fixed;top:0;bottom:0;right:0}.preview-head{border-bottom:1px solid var(--line);background:var(--panel);align-items:center;gap:10px;height:52px;padding:0 14px;display:flex}.preview-head .live{color:var(--bad);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:6px;font-size:11px;font-weight:700;display:inline-flex}.preview-head .live .d{background:var(--bad);width:7px;height:7px;box-shadow:0 0 0 0 var(--bad);border-radius:50%;animation:1.6s infinite pulse}@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in oklab, var(--bad), transparent 40%)}70%{box-shadow:0 0 0 7px #0000}}.preview-body{flex-direction:column;flex:1;gap:16px;min-height:0;padding:20px;display:flex;overflow:auto}.book-frame{border-radius:var(--r-lg);box-shadow:var(--sh-2);border:1px solid var(--line);background:#fff;overflow:hidden}[data-theme=dark] .book-frame{background:#fff}.play-scene{aspect-ratio:16/9;background:#fff;width:100%;position:relative;overflow:hidden}.play-scene img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.play-zone{box-sizing:border-box;background:#5b54f014;border:3px dashed #5b54f08c;border-radius:10px;place-items:center;display:grid;position:absolute}.play-zone.filled{border-style:solid;border-color:var(--ok);background:#fff;box-shadow:0 4px 12px #00000024}.play-zone .pl{color:#2a2a33;font-size:clamp(11px,1.6vw,20px);font-weight:700}.play-tray{background:var(--panel);border-top:1px solid var(--line);flex-wrap:wrap;justify-content:center;gap:10px;padding:14px;display:flex}.tray-card{background:var(--panel-2);border:2px solid var(--line-strong);color:var(--ink);box-shadow:var(--sh-1);cursor:grab;border-radius:12px;padding:8px 16px;font-size:14px;font-weight:700}.preview-q{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);align-items:center;gap:10px;padding:12px 14px;display:flex}.preview-q .qn{background:var(--accent);color:#fff;border-radius:8px;flex:none;place-items:center;width:28px;height:28px;font-weight:700;display:grid}.preview-foot{border-top:1px solid var(--line);background:var(--panel);align-items:center;gap:10px;padding:12px 14px;display:flex}.dots{gap:6px;display:flex}.dots i{background:var(--line-strong);border-radius:50%;width:8px;height:8px}.dots i.on{background:var(--accent);border-radius:5px;width:20px}.modal-scrim{z-index:100;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0a0a1080;place-items:center;padding:5vh 24px;animation:.15s fade;display:grid;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);width:min(960px,96vw);max-height:90vh;box-shadow:var(--sh-3);flex-direction:column;animation:.18s cubic-bezier(.2,.7,.2,1) pop;display:flex;overflow:hidden}.modal-head{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:18px 20px;display:flex}.modal-head h2{margin:0;font-size:17px}.modal-head p{color:var(--ink-3);margin:2px 0 0;font-size:12.5px}.modal-body{padding:16px 20px 22px;overflow-y:auto}.pick-search{max-width:320px;margin-bottom:16px}.pick-group-h{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin:16px 2px 10px;font-size:11px;font-weight:700}.pick-grid{grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:10px;display:grid}.pick-card{border:1px solid var(--line);border-radius:var(--r-lg);cursor:pointer;background:var(--panel-2);flex-direction:column;gap:9px;padding:13px;transition:border-color .12s,box-shadow .12s,transform 80ms;display:flex}.pick-card:hover{border-color:var(--accent);box-shadow:var(--sh-2);transform:translateY(-1px)}.pick-card.on{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.pick-ico{background:var(--accent-soft);width:38px;height:38px;color:var(--accent);border-radius:10px;place-items:center;display:grid}.pick-ico svg{width:20px;height:20px}.pick-card .pn{font-size:13px;font-weight:700}.pick-card .pd{color:var(--ink-3);font-size:11.5px;line-height:1.4}.pick-card{position:relative}.pick-card.locked{opacity:.42;cursor:not-allowed}.pick-card.locked:hover{border-color:var(--line);box-shadow:none;transform:none}.pick-card.locked .pick-ico{filter:grayscale()}.flash{background:var(--ink);color:var(--bg);z-index:200;box-shadow:var(--sh-3);border-radius:999px;align-items:center;gap:8px;padding:9px 16px;font-size:12.5px;font-weight:600;animation:.18s pop;display:flex;position:fixed;bottom:18px;left:50%;transform:translate(-50%)}.flash svg{width:15px;height:15px;color:var(--ok)}.hint-bar{background:color-mix(in oklab, var(--panel), transparent 8%);border:1px solid var(--line);box-shadow:var(--sh-2);z-index:7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;gap:14px;padding:6px 14px;display:flex;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.hint-bar span{color:var(--ink-3);align-items:center;gap:5px;font-size:11px;display:inline-flex}.hint-bar .kbd{font-size:9.5px}@keyframes shakeX{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(7px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.proj-shell{background:var(--bg);height:100vh;color:var(--ink);flex-direction:column;display:flex}.proj-top{background:var(--panel);border-bottom:1px solid var(--line);flex:none;align-items:center;gap:12px;height:56px;padding:0 18px;display:flex}.proj-switch{position:relative}.proj-switch-btn{border-radius:var(--r-md);background:0 0;border:1px solid #0000;align-items:center;gap:9px;height:38px;padding:0 10px 0 8px;display:flex}.proj-switch-btn:hover{background:var(--bg-sunken)}.proj-switch-btn .pico{color:#fff;border-radius:8px;flex:none;place-items:center;width:28px;height:28px;display:grid}.proj-switch-btn .pm{text-align:left;min-width:0}.proj-switch-btn .pm .nm{white-space:nowrap;font-size:13.5px;font-weight:700}.proj-switch-btn .pm .sb{color:var(--ink-3);font-size:11px}.proj-switch-btn .chev{color:var(--ink-3)}.menu{z-index:60;background:var(--elev);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-pop);min-width:280px;padding:6px;animation:.14s pop;position:absolute}.menu-lbl{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);padding:8px 10px 4px;font-size:10.5px;font-weight:700}.menu-item{border-radius:var(--r-sm);cursor:pointer;color:var(--ink);align-items:center;gap:10px;padding:8px 10px;display:flex}.menu-item:hover{background:var(--bg-sunken)}.menu-item .pico{color:#fff;border-radius:7px;flex:none;place-items:center;width:26px;height:26px;font-size:11px;display:grid}.menu-item .mm{flex:1;min-width:0}.menu-item .mm .nm{font-size:12.5px;font-weight:600}.menu-item .mm .sb{color:var(--ink-3);font-size:11px}.menu-item.on{background:var(--accent-soft)}.menu-item.add{color:var(--accent);font-weight:600}.menu-sep{background:var(--line);height:1px;margin:6px 4px}.proj-main{flex:1;overflow-y:auto}.proj-wrap{max-width:1180px;margin:0 auto;padding:30px 28px 60px}.proj-hero{align-items:flex-start;gap:20px;margin-bottom:24px;display:flex}.proj-hero .ph-ico{color:#fff;width:56px;height:56px;box-shadow:var(--sh-2);border-radius:15px;flex:none;place-items:center;display:grid}.proj-hero .ph-ico svg{width:28px;height:28px}.proj-hero h1{letter-spacing:-.01em;margin:0;font-size:25px;font-weight:800}.proj-hero h1:hover{color:var(--ink)}.proj-meta{flex-wrap:wrap;gap:8px;margin-top:9px;display:flex}.meta-chip{background:var(--panel);border:1px solid var(--line);height:26px;color:var(--ink-2);border-radius:999px;align-items:center;gap:6px;padding:0 10px;font-size:12px;font-weight:500;display:inline-flex}.meta-chip svg{width:13px;height:13px;color:var(--ink-3)}.proj-bar{border-bottom:1px solid var(--line);align-items:center;gap:10px;margin-bottom:18px;padding-bottom:16px;display:flex}.proj-bar h3{margin:0;font-size:14px;font-weight:700}.proj-bar h3 .cnt{color:var(--ink-3);margin-left:6px;font-weight:600}.activity-grid{grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:16px;display:grid}.act-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);cursor:pointer;transition:border-color .14s,box-shadow .14s,transform 80ms;position:relative;overflow:hidden}.act-card:hover{border-color:var(--line-strong);box-shadow:var(--sh-2);transform:translateY(-2px)}.act-card.dragging{opacity:.4}.act-card.drag-over{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.act-thumb{aspect-ratio:16/10;border-bottom:1px solid var(--line);background:#eef3f6;position:relative;overflow:hidden}.act-thumb img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.act-thumb .tz{box-sizing:border-box;border:2px dashed #ffffffd9;border-radius:5px;position:absolute;box-shadow:0 1px 3px #0003}.act-order{color:#fff;width:24px;height:24px;font-size:12px;font-weight:700;font-family:var(--mono);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2;background:#14141e9e;border-radius:7px;place-items:center;display:grid;position:absolute;top:9px;left:9px}.act-status{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2;border-radius:999px;align-items:center;gap:5px;height:22px;padding:0 9px;font-size:11px;font-weight:700;display:inline-flex;position:absolute;top:9px;right:9px}.act-status.ready{background:color-mix(in oklab, var(--ok), transparent 80%);color:var(--ok)}.act-status.draft{color:#fff;background:#14141e8c}.act-status .d{background:currentColor;border-radius:50%;width:6px;height:6px}.act-card .drag-handle{color:#fff;opacity:0;cursor:grab;z-index:3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14141e8c;border-radius:7px;place-items:center;width:26px;height:26px;transition:opacity .12s;display:grid;position:absolute;bottom:9px;right:9px}.act-card:hover .drag-handle{opacity:1}.act-body{align-items:flex-start;gap:8px;padding:11px 12px 12px;display:flex}.act-body .ab-ico{background:var(--accent-soft);width:30px;height:30px;color:var(--accent);border-radius:8px;flex:none;place-items:center;display:grid}.act-body .ab-ico svg{width:16px;height:16px}.act-body .ab-meta{flex:1;min-width:0}.act-body .ab-name{white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:700;overflow:hidden}.act-body .ab-sub{color:var(--ink-3);align-items:center;gap:5px;margin-top:1px;font-size:11.5px;display:flex}.act-menu-btn{width:26px;height:26px;color:var(--ink-3);opacity:0;background:0 0;border:none;border-radius:7px;flex:none;place-items:center;transition:opacity .12s,background .12s;display:grid}.act-card:hover .act-menu-btn{opacity:1}.act-menu-btn:hover{background:var(--bg-sunken);color:var(--ink)}.act-add{border:2px dashed var(--line-strong);border-radius:var(--r-lg);color:var(--ink-3);cursor:pointer;background:0 0;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:210px;transition:border-color .14s,color .14s,background .14s;display:flex}.act-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.act-add .plus{background:var(--bg-sunken);border-radius:12px;place-items:center;width:44px;height:44px;display:grid}.act-add:hover .plus{background:var(--panel);color:var(--accent)}.rename-inp{font:inherit;border:1px solid var(--accent);background:var(--panel);color:var(--ink);width:100%;box-shadow:0 0 0 3px var(--accent-ring);border-radius:5px;outline:none;padding:1px 5px;font-size:13.5px;font-weight:700}.back-btn{border-radius:var(--r-md);height:30px;color:var(--ink-2);background:0 0;border:1px solid #0000;align-items:center;gap:6px;padding:0 10px 0 7px;font-size:12.5px;font-weight:600;display:inline-flex}.back-btn:hover{background:var(--bg-sunken);color:var(--ink)}.scorm-list{flex-direction:column;gap:6px;max-height:230px;margin:4px 0 6px;display:flex;overflow-y:auto}.scorm-row{border:1px solid var(--line);border-radius:var(--r-md);background:var(--panel-2);align-items:center;gap:10px;padding:8px 10px;display:flex}.scorm-row .sn{background:var(--accent-soft);width:22px;height:22px;color:var(--accent);font-size:11px;font-weight:700;font-family:var(--mono);border-radius:6px;flex:none;place-items:center;display:grid}.scorm-row .nm{flex:1;font-size:12.5px;font-weight:600}.scorm-opt{gap:8px;display:flex}.scorm-opt button{border:1px solid var(--line-strong);border-radius:var(--r-md);background:var(--panel-2);text-align:left;flex:1;padding:10px}.scorm-opt button.on{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 2px var(--accent-ring)}.scorm-opt .ot{font-size:12.5px;font-weight:700}.scorm-opt .od{color:var(--ink-3);font-size:11px}.export-overlay{z-index:60;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f0f196b;place-items:center;display:grid;position:fixed;inset:0}.export-modal{background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-lg);flex-direction:column;width:min(820px,92vw);max-height:88vh;display:flex;overflow:hidden;box-shadow:0 24px 64px #0f0f1952}.export-head{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:14px 16px;display:flex}.export-meta{flex:1;min-width:0}.export-meta .t{color:var(--ink);font-size:14px;font-weight:700}.export-meta .s{color:var(--ink-3);align-items:center;gap:8px;margin-top:3px;font-size:11.5px;display:flex}.export-meta .s code{font-family:var(--mono);color:var(--ink-2)}.export-chip{background:var(--accent-soft);color:var(--accent);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700}.export-xml{resize:none;border:none;border-bottom:1px solid var(--line);min-height:320px;font-family:var(--mono);color:var(--ink-2);background:var(--panel-2);white-space:pre;outline:none;flex:1;padding:14px 16px;font-size:11.5px;line-height:1.55;overflow:auto}.export-actions{justify-content:flex-end;gap:8px;padding:12px 16px;display:flex}.dds-wrap{background:var(--bg-sunken);flex-direction:column;min-width:0;min-height:0;display:flex}.hs-col{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.hs-col .dds-wrap{flex:1}.dds-bar{border-bottom:1px solid var(--line);background:var(--panel);flex-wrap:wrap;flex:none;align-items:center;gap:6px 8px;min-height:46px;padding:7px 14px;display:flex}.dds-btn{border-radius:var(--r-md);border:1px solid var(--line-strong);background:var(--panel-2);height:30px;color:var(--ink);font:inherit;white-space:nowrap;cursor:pointer;align-items:center;gap:6px;padding:0 11px;font-size:12.5px;font-weight:600;transition:background .12s,border-color .12s;display:inline-flex}.dds-btn:hover{background:var(--bg-sunken);border-color:#64748b}.dds-switch{border-radius:var(--r-md);border:1px solid var(--line-strong);background:var(--panel-2);height:30px;color:var(--ink-2);font:inherit;white-space:nowrap;cursor:pointer;align-items:center;gap:8px;padding:0 11px 0 9px;font-size:12.5px;font-weight:600;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.dds-switch:hover{background:var(--bg-sunken)}.dds-switch.on{color:var(--accent);border-color:color-mix(in oklab, var(--accent), transparent 65%);background:color-mix(in oklab, var(--accent), transparent 92%)}.dds-switch-track{background:var(--line-strong);border-radius:999px;flex:none;width:30px;height:17px;transition:background .15s;position:relative}.dds-switch.on .dds-switch-track{background:var(--accent)}.dds-switch-thumb{background:#fff;border-radius:50%;width:13px;height:13px;transition:left .15s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0000004d}.dds-switch.on .dds-switch-thumb{left:15px}.dds-bar-sep{background:var(--line-strong);align-self:stretch;width:1px;min-height:22px;margin:0 2px}.dds-group{flex-direction:column;gap:2px;display:flex}.dds-group-label{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);padding-left:2px;font-size:9.5px;font-weight:700}.dds-group-btns{align-items:center;gap:6px;display:flex}.dds-stat{color:var(--ink-3);font-size:11.5px;font-family:var(--mono);white-space:nowrap;flex:none}.dds-subtype{color:#475569;font-size:11px;font-weight:700;font-family:var(--mono);letter-spacing:.02em;white-space:nowrap;background:oklab(55.4391% -.00887066 -.039739/.14);border-radius:999px;flex:none;margin-left:auto;padding:3px 10px}[data-theme=dark] .dds-subtype{color:#94a3b8}.dds-scroll{flex:1;place-items:center;min-height:0;padding:24px;display:grid;overflow:auto}.dds-stage{border:1px solid var(--line-strong);-webkit-user-select:none;user-select:none;touch-action:none;background-color:#fff;background-position:50%;background-size:cover;border-radius:6px;flex:none;position:relative;box-shadow:0 10px 40px #1414202e}.dds-coach{z-index:4;pointer-events:none;text-align:center;background:color-mix(in oklab, var(--panel), transparent 8%);width:min(440px,70%);color:var(--ink-2);border:1.5px dashed oklab(55.4391% -.00887066 -.039739/.6);border-radius:16px;padding:26px 30px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 28px #1414201f}.dds-coach>svg{color:var(--accent,#2563eb);margin-bottom:8px}.dds-coach-t{color:var(--ink);margin-bottom:6px;font-size:16px;font-weight:800}.dds-coach-s{color:var(--ink-2);font-size:13px;line-height:1.55}.dds-coach-s b{color:var(--ink)}.dds-hint{z-index:6;pointer-events:none;background:color-mix(in oklab, var(--panel), transparent 4%);border:1px solid var(--line-strong);max-width:80%;color:var(--ink-2);border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:12.5px;display:inline-flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #14142029}.dds-hint>svg{color:var(--accent,#2563eb);flex:none}.dds-hint b{color:var(--ink)}.dds-lines{pointer-events:none;z-index:5;position:absolute;inset:0;overflow:visible}.dds-line{stroke:#64748b;stroke-width:3px;fill:none}.dds-line-hit{stroke:#0000;stroke-width:16px;fill:none;pointer-events:stroke;cursor:pointer}.dds-link:hover .dds-line{stroke:#e0524d}.dds-line-rubber{stroke:#64748b;stroke-dasharray:7 6;opacity:.85}.dds-target{z-index:8;cursor:move;box-sizing:border-box;background:0 0;border:1.5px dashed oklab(55.4391% -.00887066 -.039739/.52);border-radius:8px;place-items:center;display:grid;position:absolute}.dds-del{color:#fff;text-align:center;cursor:pointer;z-index:14;opacity:0;background:#e0524d;border:2px solid #fff;border-radius:50%;width:18px;height:18px;font-size:14px;line-height:15px;transition:opacity .1s;position:absolute;top:-9px;right:-9px;box-shadow:0 1px 3px #14142059}.dds-source:hover .dds-del,.dds-target:hover .dds-del,.dds-flyto-marker:hover .dds-del,.dds-source.sel .dds-del,.dds-target.sel .dds-del{opacity:1}.dds-del:hover{background:#c0392b}.dds-order{color:#fff;text-align:center;cursor:pointer;z-index:14;box-sizing:border-box;background:#64748b;border:2px solid #fff;border-radius:9px;min-width:18px;height:18px;padding:0 4px;font-size:11px;font-weight:700;line-height:18px;position:absolute;top:-9px;left:-9px;box-shadow:0 1px 3px #14142059}.dds-order:hover{background:#475569}.dds-target:hover{border-color:oklab(55.4391% -.00887066 -.039739/.65)}.dds-target.sel{border:2px solid #64748b;box-shadow:0 0 0 3px oklab(55.4391% -.00887066 -.039739/.22)}.dds-target .dds-tag{opacity:.55;transition:opacity .1s}.dds-target:hover .dds-tag,.dds-target.sel .dds-tag{opacity:1}.dds-tag{color:#fff;pointer-events:none;background:#64748b;border-radius:5px;padding:1px 7px;font-size:10.5px;font-weight:700;position:absolute;top:-10px;left:8px}.dds-flyto-marker{z-index:9;box-sizing:border-box;cursor:move;touch-action:none;background:oklab(69.918% .0546504 .137531/.08);border:2px dashed #d98a16;border-radius:8px;place-items:center;display:grid;position:absolute}.dds-flyto-marker:hover{background:oklab(69.918% .0546504 .137531/.14)}.dds-flyto-marker.sel{box-shadow:0 0 0 3px oklab(69.918% .0546504 .137531/.28)}.dds-flyto-marker .dds-handle{border-color:#d98a16}.dds-flyto-marker .dds-handle:after{background:#d98a16}.dds-flyto-tag{color:#fff;pointer-events:none;background:#d98a16;border-radius:5px;padding:1px 7px;font-size:10.5px;font-weight:700;position:absolute;top:-10px;left:8px}.dds-flyto-cross{opacity:.7;pointer-events:none;background:linear-gradient(#d98a16,#d98a16) 50%/2px 16px no-repeat,linear-gradient(#d98a16,#d98a16) 50%/16px 2px no-repeat;width:16px;height:16px}.dds-flyto-line{stroke:#d98a16;stroke-dasharray:6 5;opacity:.8}.dds-source{z-index:10;color:var(--ink);cursor:move;box-sizing:border-box;background:0 0;border:1.5px dashed oklab(44.5533% -.00824478 -.0365278/.52);border-radius:10px;place-items:center;display:grid;position:absolute}.dds-source:hover{border-color:oklab(44.5533% -.00824478 -.0365278/.65)}.dds-source.sel{border:2px solid oklab(44.5533% -.00824478 -.0365278/.7);box-shadow:0 0 0 3px oklab(44.5533% -.00824478 -.0365278/.22)}.dds-text{text-align:center;pointer-events:none;color:inherit;text-shadow:0 1px 2px #ffffffb3;padding:4px 12px;font-size:16px;font-weight:700}.dds-glyph{stroke:#475569;stroke-width:2.5px;fill:none;pointer-events:none}.dds-source.vis,.dds-target.vis{box-shadow:none}.dds-source.vis.sel,.dds-target.vis.sel{box-shadow:0 0 0 3px oklab(44.5533% -.00824478 -.0365278/.3)}.dds-node{cursor:crosshair;z-index:12;background:#64748b;border:2px solid #fff;border-radius:50%;width:15px;height:15px;transition:transform .12s,background .12s;position:absolute;box-shadow:0 1px 3px #14142059}.dds-node:hover{background:#475569;transform:scale(1.3)}.dds-node.top{top:-9px;left:50%;transform:translate(-50%)}.dds-node.top:hover{transform:translate(-50%)scale(1.3)}.dds-node.bottom{bottom:-9px;left:50%;transform:translate(-50%)}.dds-node.bottom:hover{transform:translate(-50%)scale(1.3)}.dds-node.left{top:50%;left:-9px;transform:translateY(-50%)}.dds-node.left:hover{transform:translateY(-50%)scale(1.3)}.dds-node.right{top:50%;right:-9px;transform:translateY(-50%)}.dds-node.right:hover{transform:translateY(-50%)scale(1.3)}@keyframes dds-node-pulse{0%{box-shadow:0 1px 3px #14142059, 0 0 0 0 color-mix(in oklab, var(--accent,#2563eb), transparent 30%)}70%{box-shadow:0 1px 3px #14142059, 0 0 0 7px color-mix(in oklab, var(--accent,#2563eb), transparent 100%)}to{box-shadow:0 1px 3px #14142059, 0 0 0 0 color-mix(in oklab, var(--accent,#2563eb), transparent 100%)}}.dds-source:hover .dds-node,.dds-source.sel .dds-node,.dds-target.flyto:hover .dds-node,.dds-target.flyto.sel .dds-node{background:var(--accent,#2563eb);animation:1.6s ease-out infinite dds-node-pulse}@media (prefers-reduced-motion:reduce){.dds-source:hover .dds-node,.dds-source.sel .dds-node,.dds-target.flyto:hover .dds-node,.dds-target.flyto.sel .dds-node{animation:none}}.hs-spot .dds-node{opacity:.35}.hs-spot:hover .dds-node,.hs-spot.sel .dds-node{opacity:1;background:var(--accent,#2563eb);animation:1.6s ease-out infinite dds-node-pulse}@media (prefers-reduced-motion:reduce){.hs-spot:hover .dds-node,.hs-spot.sel .dds-node{animation:none}}.dds-handle{background:var(--panel);cursor:nwse-resize;z-index:13;border:2px solid #475569;border-radius:3px;width:14px;height:14px;position:absolute;bottom:-7px;right:-7px}.dds-handle:after{content:"";opacity:.35;background:#475569;border-radius:1px;position:absolute;inset:2px}.dds-rotate{z-index:14;cursor:grab;touch-action:none;width:16px;height:26px;margin-left:-8px;position:absolute;top:-26px;left:50%}.dds-rotate:active{cursor:grabbing}.dds-rotate-stem{background:var(--accent,#2563eb);opacity:.55;pointer-events:none;width:2px;height:18px;margin-left:-1px;position:absolute;top:8px;left:50%}.dds-rotate-dot{background:var(--panel);border:2px solid var(--accent,#2563eb);pointer-events:none;border-radius:50%;width:12px;height:12px;margin-left:-6px;position:absolute;top:0;left:50%}.dds-angle{background:var(--accent,#2563eb);color:#fff;white-space:nowrap;pointer-events:none;z-index:16;border-radius:8px;padding:1px 6px;font-size:10.5px;font-weight:700;line-height:16px;position:absolute;top:-46px;left:50%;transform:translate(-50%)}.dds-hidden-badge{color:#fff;letter-spacing:.02em;pointer-events:none;z-index:11;background:#475569;border-radius:8px;height:16px;padding:0 6px;font-size:9.5px;font-weight:700;line-height:16px;position:absolute;top:-9px;right:-6px}.dds-guide{z-index:7;pointer-events:none;position:absolute}.dds-guide.v{background:#e0524d;width:1px;top:0;bottom:0}.dds-guide.h{background:#e0524d;height:1px;left:0;right:0}.dds-marquee{z-index:15;pointer-events:none;box-sizing:border-box;border:2px dashed var(--accent,#2563eb);background:color-mix(in oklab, var(--accent,#2563eb), transparent 92%);border-radius:6px;position:absolute}.dds-cc-backdrop{z-index:92;background:0 0;position:fixed;inset:0}.dds-cc-pop{z-index:93;background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-lg);-webkit-user-select:none;user-select:none;flex-direction:column;gap:6px;padding:10px;display:flex;position:fixed;box-shadow:0 12px 32px #14142038}.dds-cc-head{align-items:center;gap:7px;display:flex}.dds-cc-title{color:var(--ink);flex:1;font-size:13px;font-weight:700}.dds-cc-x{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--panel-2);width:22px;height:22px;color:var(--ink-2);cursor:pointer;place-items:center;display:grid}.dds-cc-x:hover{background:var(--bg-sunken);color:var(--ink)}.dds-cc-group-label{letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);margin-top:2px;font-size:10.5px;font-weight:700}.dds-cc-row{grid-auto-columns:1fr;grid-auto-flow:column;gap:6px;display:grid}.dds-cc-btn{border:1px solid var(--line);border-radius:var(--r-md);background:var(--panel-2);color:var(--ink-2);cursor:pointer;flex-direction:column;align-items:center;gap:4px;padding:9px 6px;font-size:11.5px;font-weight:600;transition:border-color .12s,background .12s,color .12s;display:flex}.dds-cc-btn:hover{border-color:var(--accent,#2563eb);background:color-mix(in oklab, var(--accent,#2563eb), transparent 90%);color:var(--ink)}.dds-cc-btn>svg{color:var(--accent,#2563eb)}.dds-help{color:var(--ink-2);flex-direction:column;gap:7px;margin:0;padding-left:18px;font-size:12px;line-height:1.5;display:flex}.dds-help b{color:var(--ink)}.dds-btn.on{color:#475569;background:oklab(55.4391% -.00887066 -.039739/.16);border-color:#64748b}[data-theme=dark] .dds-btn.on{color:#cbd5e1}.dds-ord-backdrop{z-index:90;background:0 0;position:fixed;inset:0}.dds-ord-pop{z-index:91;background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-lg);-webkit-user-select:none;user-select:none;flex-direction:column;gap:8px;padding:10px;display:flex;position:fixed;box-shadow:0 12px 32px #14142038}.dds-ord-head{color:var(--ink-2);align-items:center;gap:7px;display:flex}.dds-ord-title{color:var(--ink);flex:1;font-size:13px;font-weight:700}.dds-ord-x{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--panel-2);width:24px;height:24px;color:var(--ink-2);cursor:pointer;place-items:center;display:grid}.dds-ord-x:hover{background:var(--bg-sunken);color:var(--ink)}.dds-ord-hint{color:var(--ink-3);font-size:11px;line-height:1.4}.dds-ord-list{flex-direction:column;gap:6px;max-height:320px;display:flex;overflow-y:auto}.dds-ord-row{border:1px solid var(--line);border-radius:var(--r-md);background:var(--panel-2);cursor:grab;touch-action:none;align-items:center;gap:8px;padding:7px 8px;display:flex}.dds-ord-row:hover{border-color:var(--line-strong);background:var(--panel)}.dds-ord-row.dragging{cursor:grabbing;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-ring);background:var(--panel)}.dds-ord-num{background:var(--bg-sunken);width:20px;height:20px;color:var(--ink-2);font-size:11px;font-weight:700;font-family:var(--mono);border-radius:6px;flex:none;place-items:center;display:grid}.dds-ord-grip{color:var(--ink-4);flex:none;place-items:center;display:grid}.dds-ord-prev{flex:1;min-width:0}.dds-ord-text{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:12.5px;font-weight:600;display:block;overflow:hidden}.dds-ord-img{color:var(--ink-2);align-items:center;gap:6px;min-width:0;display:flex}.dds-ord-fname{font-size:11.5px;font-family:var(--mono);color:var(--ink-2);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dds-target.hs-correct{border-color:color-mix(in oklab, var(--ok), transparent 35%)}.dds-target.hs-correct.sel{border-color:var(--ok);box-shadow:0 0 0 3px color-mix(in oklab, var(--ok), transparent 78%)}.hs-flag{background:var(--panel);border:2px solid var(--line-strong);color:#fff;cursor:pointer;z-index:12;place-items:center;width:22px;height:22px;padding:0;transition:background .12s,border-color .12s;display:grid;position:absolute;top:-10px;right:-10px}.hs-flag.chk{border-radius:6px}.hs-flag.radio{border-radius:50%}.hs-flag:hover{border-color:var(--ok)}.hs-flag.on{background:var(--ok);border-color:var(--ok)}.hs-flag svg{width:13px;height:13px}.hs-radio-row{cursor:pointer;align-items:center;gap:10px;padding:9px 0;display:flex}.hs-radio-row .hs-flag{flex:none;width:22px;height:22px;position:static}.hs-radio-row .tl{flex-direction:column;gap:1px;display:flex}.hs-radio-row .tl .nm{font-size:12.5px;font-weight:600}.hs-radio-row .tl .ds{color:var(--ink-3);font-size:11px}.answer-card.warn{background:var(--warn-soft,oklab(69.918% .0546504 .137531/.12));border-color:oklab(69.918% .0546504 .137531/.35)}.answer-card.warn .ai{color:#d98a16}.hs-auto-badge{color:var(--accent);background:color-mix(in oklab, var(--accent), transparent 88%);border:1px solid color-mix(in oklab, var(--accent), transparent 70%);align-items:center;gap:5px;display:inline-flex}.hs-auto-badge svg{width:12px;height:12px}.hs-spot.hs-grouped{border-style:solid}.hs-spot.hs-g0{border-color:oklab(54.9526% .0311552 -.223562/.7)}.hs-spot.hs-g1{border-color:oklab(65.4175% -.106662 -.026645/.7)}.hs-spot.hs-g2{border-color:oklab(62.8626% .160723 .0770849/.7)}.hs-spot.hs-g3{border-color:oklab(69.918% .0546504 .137531/.7)}.hs-spot.hs-g4{border-color:oklab(54.1337% .0963843 -.226968/.7)}.hs-spot.hs-g5{border-color:oklab(59.1646% .217973 .00222325/.7)}.hs-spot.hs-grouped.hs-correct{border-color:color-mix(in oklab, var(--ok), transparent 35%)}.hs-group-badge{color:#fff;background:var(--accent);z-index:11;min-width:18px;height:18px;box-shadow:var(--sh-1);pointer-events:none;border-radius:5px;place-items:center;padding:0 4px;font-size:10px;font-weight:800;display:grid;position:absolute;bottom:-8px;left:-8px}.hs-link-line{stroke:color-mix(in oklab, var(--accent), #64748b 30%)}.dds-link:hover .hs-link-line{stroke:#e0524d}.hs-orphan-warn{color:#b45309;background:oklab(69.918% .0546504 .137531/.14);border:1px solid oklab(69.918% .0546504 .137531/.4);border-radius:999px;align-items:center;gap:5px;margin-left:auto;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.hs-orphan-warn+.hs-auto-badge{margin-left:8px}.hs-orphan-warn svg{width:12px;height:12px}.dds-source.multi,.dds-target.multi,.dds-flyto-marker.multi{outline-offset:1px;outline:2px solid #2563eb}.dds-align-bar{border-bottom:1px solid var(--line);background:var(--panel-2);flex:none;align-items:center;gap:6px;height:40px;padding:0 14px;display:flex}.dds-align-count{color:var(--ink-2);margin-right:4px;font-size:11.5px;font-weight:600}.dds-align-btn{border:1px solid var(--line-strong);border-radius:var(--r-md);background:var(--panel);width:30px;height:28px;color:var(--ink-2);cursor:pointer;place-items:center;display:grid}.dds-align-btn:hover{background:var(--bg-sunken);color:#2563eb;border-color:#2563eb}.dds-align-mode{border:1px solid var(--line-strong);border-radius:var(--r-md);background:var(--panel);height:28px;color:var(--ink-2);font:inherit;cursor:pointer;padding:0 11px;font-size:11.5px;font-weight:600}.dds-align-mode.on{color:#2563eb;background:oklab(54.615% -.026671 -.213549/.14);border-color:#2563eb}.dds-img-ph{width:100%;height:100%;color:var(--ink-4);place-items:center;display:grid}.dds-img-ph.aspect{width:auto;height:auto}.dds-bg-image{pointer-events:none;z-index:0;background:repeating-linear-gradient(45deg,oklab(69.918% .0546504 .137531/.2) 0 6px,#0000 6px 12px);border-radius:8px;position:absolute;inset:0}.dds-img-fill{pointer-events:none;z-index:1;border-radius:8px;position:absolute;inset:0}.dds-ghost-img{opacity:.45;pointer-events:none;z-index:0;background-repeat:no-repeat;border-radius:8px;position:absolute;inset:0;overflow:hidden}.dds-ghost-text{opacity:.45;text-align:center;color:var(--ink);pointer-events:none;z-index:0;place-items:center;padding:4px 12px;font-size:16px;font-weight:700;display:grid;position:absolute;inset:0;overflow:hidden}.dds-ghost-plus{color:#fff;pointer-events:none;z-index:2;background:oklab(55.4391% -.00887066 -.039739/.75);border-radius:7px;height:15px;padding:0 5px;font-size:10px;font-weight:700;line-height:15px;position:absolute;bottom:3px;right:5px}.sx-box{box-sizing:border-box;position:absolute}.sx-del-badge{color:#fff;cursor:pointer;z-index:14;opacity:0;background:#e0524d;border-radius:50%;place-items:center;width:18px;height:18px;transition:opacity .1s,transform .1s;display:grid;position:absolute;top:-9px;right:-9px;box-shadow:0 1px 3px #14142059}.sx-box:hover .sx-del-badge,.sx-box.sel .sx-del-badge{opacity:1}.sx-del-badge:hover{background:#c93b36;transform:scale(1.18)}.sx-order-badge{color:#fff;min-width:18px;height:18px;font-size:10.5px;font-weight:700;font-family:var(--mono);cursor:pointer;z-index:11;background:#2563eb;border-radius:9px;place-items:center;padding:0 4px;display:grid;position:absolute;top:-9px;left:-9px;box-shadow:0 1px 3px #1414204d}.sx-order-badge:hover{background:#1d4ed8;transform:scale(1.1)}.dds-source.vis,.dds-target.vis,.hs-spot.vis{border-style:solid}.mb-btn{z-index:11;background:color-mix(in oklab, var(--accent), #fff 12%);color:#fff;cursor:move;box-sizing:border-box;touch-action:none;border:2px solid #fff;border-radius:50%;place-items:center;transition:transform .1s,box-shadow .1s;display:grid;position:absolute;box-shadow:0 2px 7px #14142052}.mb-btn:hover{transform:scale(1.04);box-shadow:0 3px 11px #14142066}.mb-btn.sel{box-shadow:0 0 0 3px color-mix(in oklab, var(--accent), transparent 60%), 0 2px 7px #14142052}.mb-btn svg{pointer-events:none}.mb-tag{background:var(--accent);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;border-radius:5px;padding:1px 7px;font-size:10px;font-weight:700;transition:opacity .1s;position:absolute;top:-11px;left:50%;transform:translate(-50%)}.mb-btn:hover .mb-tag,.mb-btn.sel .mb-tag{opacity:1}.mb-btn{overflow:hidden}.mb-btn.drop{box-shadow:0 0 0 3px #2563eb,0 2px 7px #14142066}.mb-drop{border:1.5px dashed var(--line-strong);border-radius:var(--r-md);background:var(--panel-2);cursor:pointer;place-items:center;min-height:76px;padding:12px;transition:border-color .12s,background .12s;display:grid}.mb-drop:hover{border-color:var(--accent)}.mb-drop.over{background:oklab(54.615% -.026671 -.213549/.1);border-color:#2563eb}.mb-drop-empty{color:var(--ink-3);text-align:center;flex-direction:column;align-items:center;gap:6px;font-size:11.5px;display:flex}.mb-thumb{border-radius:var(--r-sm);max-width:100%;max-height:140px;display:block}.mb-preview{place-items:center;width:100%;display:grid}.mb-preview audio{width:100%}.mb-preview video{border-radius:var(--r-sm);max-width:100%;max-height:160px}.fdrop{flex-direction:column;gap:6px;display:flex}.fdrop-foot{align-items:center;gap:6px;display:flex}.fdrop-path{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--ink-3);background:var(--panel-2);border-radius:var(--r-sm);flex:1;padding:3px 7px;font-size:11px;overflow:hidden}.fdrop-chip{color:var(--ink-2);align-items:center;gap:6px;font-size:12px;display:inline-flex}.fsg{flex-direction:column;gap:8px;display:flex}.fsg-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.fsg-card{border:1.5px solid var(--line);border-radius:var(--r-md);background:var(--panel-2);cursor:pointer;flex-direction:column;gap:6px;padding:8px;transition:border-color .12s,background .12s,box-shadow .12s;display:flex}.fsg-card:hover{border-color:var(--accent)}.fsg-card:focus-visible{outline:2px solid var(--accent-ring);outline-offset:1px}.fsg-card.on{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent) inset}.fsg-card-head{justify-content:space-between;align-items:center;gap:4px;display:flex}.fsg-name{color:var(--ink);align-items:center;gap:4px;font-size:12px;font-weight:600;display:inline-flex}.fsg-card.on .fsg-card-head{color:var(--accent)}.fsg-prev-row{gap:5px;display:flex}.fsg-prev{border:1px solid var(--line);background:var(--panel);border-radius:var(--r-sm);color:var(--ink-2);cursor:pointer;flex:1;justify-content:center;align-items:center;gap:4px;padding:4px 6px;font-size:10.5px;font-weight:600;display:inline-flex}.fsg-prev:hover:not(:disabled){background:var(--panel-2)}.fsg-prev:disabled{opacity:.45;cursor:default}.fsg-prev.ok{color:var(--ok)}.fsg-prev.bad{color:var(--bad)}.fsg-prev.ok.playing{background:var(--ok-soft)}.fsg-prev.bad.playing{background:var(--bad-soft)}.fsg-custom{border-style:dashed;border-color:var(--line-strong)}.fsg-custom.over{background:oklab(54.615% -.026671 -.213549/.1);border-color:#2563eb}.fsg-custom-hint{color:var(--ink-3);text-align:center;padding:4px 0;font-size:11px}.fsg-custom-body{flex-direction:column;gap:6px;display:flex}.fsg-custom-name{align-items:center;gap:6px;display:flex}.fsg-custom-name code{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--ink-3);flex:1;font-size:10.5px;overflow:hidden}.fsg-assign{gap:5px;display:flex}.fsg-assign-btn{border:1px solid var(--line);background:var(--panel);border-radius:var(--r-sm);cursor:pointer;color:var(--ink-2);flex:1;padding:3px 4px;font-size:10.5px;font-weight:600}.fsg-assign-btn.ok.on{background:var(--ok);border-color:var(--ok);color:#fff}.fsg-assign-btn.bad.on{background:var(--bad);border-color:var(--bad);color:#fff}.fsg-paths{color:var(--ink-3);flex-direction:column;gap:2px;font-size:10.5px;display:flex}.fsg-paths code{color:var(--ink-2)}.fig-slot{cursor:default}.fig-preview{background:repeating-conic-gradient(var(--bg-sunken) 0% 25%, transparent 0% 50%) 0 / 10px 10px;border-radius:var(--r-sm);justify-content:center;align-items:center;height:44px;display:flex;overflow:hidden}.fig-thumb{object-fit:contain;border-radius:var(--r-xs);width:40px;height:40px}.fig-path-label{color:var(--ink-3);text-align:center;padding:2px 4px;font-size:10px}.bsg{flex-direction:column;gap:8px;display:flex}.bsg-grid{grid-template-columns:1fr 1fr 1fr;gap:6px;display:grid}.bsg-card{border:1.5px solid var(--line);border-radius:var(--r-md);background:var(--panel-2);cursor:pointer;flex-direction:column;gap:5px;padding:7px 6px;transition:border-color .12s,background .12s,box-shadow .12s;display:flex}.bsg-card:hover{border-color:var(--accent)}.bsg-card:focus-visible{outline:2px solid var(--accent-ring);outline-offset:1px}.bsg-card.on{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent) inset}.bsg-preview-wrap{background:repeating-conic-gradient(var(--bg-sunken) 0% 25%, transparent 0% 50%) 0 / 12px 12px;border-radius:var(--r-sm);justify-content:center;align-items:center;height:40px;display:flex}.bsg-preview{box-sizing:border-box;width:64%;height:60%;color:var(--ink-2);justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.bsg-card-head{justify-content:space-between;align-items:center;gap:4px;display:flex}.bsg-name{color:var(--ink);font-size:11px;font-weight:600;line-height:1.2}.bsg-card.on .bsg-card-head{color:var(--accent)}.bsg-note{color:var(--ink-3);align-items:center;gap:5px;font-size:10.5px;display:flex}.fsg-preview{border-radius:var(--r-sm);justify-content:center;align-items:center;width:100%;height:100%;font-size:18px;font-weight:700;display:flex}.fsg-tint-ok{color:#16a36a;background:#d1fae5}.fsg-tint-icon{color:#7c3aed;background:#ede9fe;font-size:22px}.img-fit{flex-direction:column;gap:8px;margin-top:6px;display:flex}.img-fit-head{letter-spacing:.02em;text-transform:uppercase;color:var(--ink-3);align-items:center;gap:5px;font-size:11px;font-weight:600;display:flex}.fit-row{background:var(--bg-sunken);border-radius:var(--r-md);gap:3px;padding:3px;display:flex}.fit-btn{aspect-ratio:1;background:var(--panel);border-radius:var(--r-sm);min-width:0;color:var(--ink-2);cursor:pointer;box-shadow:var(--sh-1);border:none;flex:1;place-items:center;display:grid}.fit-btn:hover{background:var(--panel-2);color:var(--ink)}.fit-btn.on{background:var(--accent);color:#fff}.anchor-grid{background:var(--bg-sunken);border-radius:var(--r-md);grid-template-columns:repeat(3,1fr);gap:3px;width:84px;padding:3px;display:grid}.anchor-cell{aspect-ratio:1;background:var(--panel);border-radius:var(--r-sm);cursor:pointer;width:100%;box-shadow:var(--sh-1);border:none;place-items:center;display:grid}.anchor-cell:hover{background:var(--panel-2)}.anchor-cell .anchor-dot{background:var(--ink-3);border-radius:50%;width:6px;height:6px}.anchor-cell.on{background:var(--accent)}.anchor-cell.on .anchor-dot{background:#fff}.img-fit-preview{border-radius:var(--r-md);border:1px solid var(--border);background-color:var(--bg-sunken);width:100%;height:88px}.test-player-scrim{z-index:120;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0a0a109e;place-items:center;padding:3vh 3vw;animation:.15s fade;display:grid;position:fixed;inset:0}.test-player{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);width:100%;max-width:1600px;height:100%;box-shadow:var(--sh-2);flex-direction:column;display:flex;overflow:hidden}.test-player-head{border-bottom:1px solid var(--line);background:var(--panel);flex:none;align-items:center;gap:12px;padding:10px 14px;display:flex}.tp-live{color:var(--ink);align-items:center;gap:7px;font-size:13px;font-weight:700;display:inline-flex}.tp-live .d{background:var(--ok);width:8px;height:8px;box-shadow:0 0 0 3px color-mix(in srgb, var(--ok) 22%, transparent);border-radius:50%}.tp-sub{color:var(--ink-3);font-size:12px}.test-player-stage{background:radial-gradient(120% 120% at 50% 0,#20222b 0%,#15161c 60%,#101116 100%);flex:1;place-items:center;min-height:0;display:grid;position:relative;overflow:hidden}.test-player-host{background-color:#fff;border-radius:4px;position:relative;overflow:hidden;box-shadow:0 10px 40px #00000073}.tp-status{color:#fff;background:#0000008c;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex;position:absolute;inset:auto auto 16px 50%;transform:translate(-50%)}.tp-status.tp-error{background:#b3261e}.tp-activity-toolbar{z-index:30;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffeb;border-radius:14px;flex-direction:column;gap:8px;padding:8px;display:flex;position:absolute;top:50%;right:18px;transform:translateY(-50%);box-shadow:0 6px 22px #00000047}.tp-tb-btn{cursor:pointer;color:#44464f;background:#f1f2f6;border:none;border-radius:11px;place-items:center;width:44px;height:44px;display:grid}.tp-tb-btn:hover{color:#1b1b22;background:#e6e7ee}.ndr-center{color:#475569;justify-content:center;align-items:center;min-height:100vh;font:500 15px/1.4 system-ui,sans-serif;display:flex}.ndr-auth-wrap{background:linear-gradient(135deg,#eef2ff 0%,#f8fafc 60%,#ecfeff 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.ndr-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 10px 30px -12px #1e293b40}.ndr-auth-card{flex-direction:column;gap:14px;width:100%;max-width:380px;padding:32px 28px;display:flex}.ndr-auth-title{color:#1e293b;margin:0;font:700 24px/1 system-ui,sans-serif}.ndr-auth-title span{color:#6366f1}.ndr-auth-sub{color:#64748b;margin:-6px 0 8px;font-size:13px}.ndr-field{color:#334155;flex-direction:column;gap:5px;font-size:13px;display:flex}.ndr-field input{border:1px solid #cbd5e1;border-radius:9px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.ndr-field input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.ndr-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:8px 10px;font-size:13px}.ndr-btn-primary{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:9px;margin-top:4px;padding:11px 14px;font:600 14px/1 system-ui,sans-serif;transition:background .15s}.ndr-btn-primary:hover:not(:disabled){background:#4f46e5}.ndr-btn-primary:disabled{opacity:.6;cursor:default}.ndr-shell{background:#f8fafc;min-height:100vh}.ndr-topbar{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:12px 22px;display:flex}.ndr-brand{color:#1e293b;font:700 18px/1 system-ui,sans-serif}.ndr-brand span{color:#6366f1}.ndr-user{color:#334155;align-items:center;gap:12px;font-size:14px;display:flex}.ndr-role-badge{color:#4f46e5;background:#eef2ff;border:1px solid #e0e7ff;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600}.ndr-btn-ghost{cursor:pointer;color:#475569;background:0 0;border:1px solid #cbd5e1;border-radius:8px;padding:6px 12px;font-size:13px}.ndr-btn-ghost:hover{background:#f1f5f9}.ndr-main{max-width:980px;margin:0 auto;padding:32px 22px}.ndr-main h2{color:#1e293b;margin:0 0 6px}.ndr-muted{color:#64748b;margin:0 0 22px}.ndr-card-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.ndr-tile{color:inherit;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:18px;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .1s;display:block}.ndr-tile:hover{border-color:#c7d2fe;transform:translateY(-1px);box-shadow:0 8px 20px -14px #1e293b4d}.ndr-tile h3{color:#1e293b;margin:0 0 6px;font-size:15px}.ndr-tile p{color:#64748b;margin:0;font-size:13px}.ndr-tile-disabled{opacity:.55;pointer-events:none}.ndr-row-between{justify-content:space-between;align-items:center;gap:12px;display:flex}.ndr-row-end{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.ndr-btn-sm{padding:7px 12px;font-size:13px}.ndr-back{color:#6366f1;margin-bottom:10px;font-size:13px;text-decoration:none;display:inline-block}.ndr-back:hover{text-decoration:underline}.ndr-tile-btn{text-align:left;cursor:pointer;width:100%;font:inherit;background:#fff;border:1px solid #e2e8f0}.ndr-tile-meta{color:#94a3b8;margin-top:10px;font-size:12px}.ndr-status{white-space:nowrap;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600}.ndr-status-draft{color:#64748b;background:#f1f5f9}.ndr-status-active{color:#16a34a;background:#dcfce7}.ndr-status-archived{color:#b45309;background:#fef3c7}.ndr-section{background:#fff;border:1px solid #e2e8f0;border-radius:14px;margin-top:16px;padding:18px 20px}.ndr-section h3{color:#1e293b;margin:0 0 12px;font-size:15px}.ndr-section .ndr-btn-primary,.ndr-section .ndr-btn-ghost{margin-right:8px}.ndr-link-list,.ndr-member-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.ndr-link-list a{color:#4f46e5;font-size:14px}.ndr-member{align-items:center;gap:10px;display:flex}.ndr-member>span:first-child{flex:1;font-size:14px}.ndr-x{color:#b91c1c;cursor:pointer;background:#fef2f2;border:none;border-radius:6px;width:22px;height:22px;line-height:1}.ndr-assign{flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;display:flex}.ndr-assign select{border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px;font-size:13px}.ndr-error-inline{color:#b91c1c;font-size:12px}.ndr-modal-back{z-index:100;background:#0f172a59;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.ndr-modal{flex-direction:column;gap:12px;width:100%;max-width:460px;padding:24px;display:flex}.ndr-modal h3{margin:0}.ndr-link-row{gap:8px;margin-bottom:6px;display:flex}.ndr-link-row input:first-child{flex:0 0 110px}.ndr-link-row input{border:1px solid #cbd5e1;border-radius:8px;flex:1;padding:8px 10px;font-size:13px}.ndr-pageno{border:1px solid #cbd5e1;border-radius:8px;width:90px;padding:8px 10px;font-size:13px}.ndr-page-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:12px;display:grid}.ndr-page{cursor:pointer;text-align:left;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:0;overflow:hidden}.ndr-page:hover{border-color:#c7d2fe}.ndr-page-img{aspect-ratio:3/4;background:#f1f5f9;justify-content:center;align-items:center;display:flex;overflow:hidden}.ndr-page-img img{object-fit:cover;width:100%;height:100%}.ndr-page-foot{color:#475569;justify-content:space-between;align-items:center;padding:6px 8px;font-size:12px;display:flex}.ndr-pstatus{border-radius:999px;padding:2px 7px;font-size:11px;font-weight:600}.ndr-pstatus-pending{color:#64748b;background:#f1f5f9}.ndr-pstatus-produced{color:#2563eb;background:#dbeafe}.ndr-pstatus-review{color:#b45309;background:#fef3c7}.ndr-pstatus-approved{color:#16a34a;background:#dcfce7}.ndr-pstatus-rework{color:#dc2626;background:#fee2e2}.ndr-ok{color:#15803d;background:#dcfce7;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:8px;padding:8px 10px;font-size:13px}.ndr-act-list{flex-direction:column;gap:6px;margin:8px 0 0;padding:0;list-style:none;display:flex}.ndr-act{border:1px solid #e2e8f0;border-radius:9px;align-items:center;gap:10px;padding:8px 10px;font-size:14px;display:flex}.ndr-act-type{text-transform:uppercase;color:#4f46e5;letter-spacing:.03em;background:#eef2ff;border-radius:6px;padding:2px 7px;font-size:11px;font-weight:700}.ndr-act-title{color:#1e293b;flex:1}.ndr-act-by{font-size:12px}.ndr-bell{position:relative}.ndr-bell-btn{cursor:pointer;background:0 0;border:none;padding:4px;font-size:18px;line-height:1;position:relative}.ndr-bell-badge{color:#fff;background:#dc2626;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-2px;right:-4px}.ndr-bell-pop{z-index:200;background:#fff;border:1px solid #e2e8f0;border-radius:12px;width:320px;max-height:420px;position:absolute;top:34px;right:0;overflow:auto;box-shadow:0 12px 30px -12px #1e293b4d}.ndr-bell-head{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.ndr-link-btn{color:#6366f1;cursor:pointer;background:0 0;border:none;font-size:12px}.ndr-bell-empty{color:#94a3b8;text-align:center;padding:16px;font-size:13px}.ndr-bell-list{margin:0;padding:0;list-style:none}.ndr-bell-item{cursor:pointer;border-bottom:1px solid #f8fafc;padding:10px 14px}.ndr-bell-item:hover{background:#f8fafc}.ndr-bell-item.unread{background:#eef2ff}.ndr-bell-item.unread:hover{background:#e0e7ff}.ndr-bell-label{color:#1e293b;font-size:13px;font-weight:500}.ndr-bell-sub{color:#94a3b8;margin-top:2px;font-size:11px}.ndr-page-modal{flex-direction:column;width:min(94vw,1000px);max-height:92vh;padding:18px 20px;display:flex}.ndr-page-modal-body{gap:16px;min-height:0;display:flex}.ndr-page-canvas{cursor:crosshair;background:#f1f5f9;border-radius:10px;flex:1;justify-content:center;align-items:flex-start;min-width:0;max-height:78vh;display:flex;position:relative;overflow:auto}.ndr-page-canvas img{max-width:100%;display:block}.ndr-pin{color:#fff;background:#dc2626;border:2px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 1px 4px #0006}.ndr-pin.done{background:#16a34a}.ndr-pin.draft{background:#6366f1}.ndr-page-side{flex-direction:column;flex-shrink:0;gap:10px;width:280px;display:flex;overflow:auto}.ndr-rework-btn{background:#ea580c;border-color:#ea580c}.ndr-draft textarea{width:100%;min-height:60px;font:inherit;resize:vertical;border:1px solid #cbd5e1;border-radius:8px;padding:8px;font-size:13px}.ndr-note-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.ndr-note{border:1px solid #e2e8f0;border-radius:9px;align-items:flex-start;gap:8px;padding:8px;font-size:13px;display:flex}.ndr-note.done{opacity:.6}.ndr-note-no{color:#dc2626;background:#fee2e2;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:flex}.ndr-note-body{flex:1}.ndr-note-meta{color:#94a3b8;margin-top:3px;font-size:11px}
