:root{--white:#fff;--paper:#fcfcfb;--paper-2:#f6f5f2;--paper-3:#efeeea;--ink:#131316;--ink-2:#2c2c31;--ink-3:#54545c;--ink-4:#86868f;--ink-5:#b6b6bd;--sp-rose:#ec5680;--sp-coral:#f2873c;--sp-gold:#f5c53d;--sp-green:#5cb85b;--sp-teal:#2faeb4;--sp-blue:#3c7ac9;--sp-violet:#8c5ca6;--sp-cream:#e9d8b0;--spectrum:linear-gradient(90deg,var(--sp-rose) 0%,var(--sp-coral) 17%,var(--sp-gold) 33%,var(--sp-green) 50%,var(--sp-teal) 65%,var(--sp-blue) 82%,var(--sp-violet) 100%);--bg:var(--paper);--bg-alt:var(--paper-2);--surface:var(--white);--surface-sunk:var(--paper-3);--fg:var(--ink);--fg-muted:var(--ink-3);--fg-subtle:var(--ink-4);--fg-onink:#f4f4f2;--fg-onink-muted:#a6a6ae;--border:#1313161a;--border-strong:#13131633;--border-onink:#f4f4f229;--accent:var(--ink);--accent-hover:#2c2c31;--accent-press:#000;--link:var(--sp-blue);--link-hover:#2d63b0;--ok:var(--sp-green);--glow-spectrum:0 0 0 1px #ffffff1a,0 18px 70px -10px #ec56804d,0 8px 40px -6px #3c7ac947;--font-sans:"Hanken Grotesk",system-ui,-apple-system,"Segoe UI",sans-serif;--font-mono:"DM Mono",ui-monospace,"SF Mono",Menlo,monospace;--font-display:"Hanken Grotesk",system-ui,sans-serif;--text-hero:clamp(2.9rem,6.4vw,5.5rem);--text-display:clamp(2.2rem,4.2vw,3.6rem);--text-h1:clamp(2rem,3.4vw,2.85rem);--text-h2:clamp(1.6rem,2.4vw,2.1rem);--text-h3:1.375rem;--text-h4:1.125rem;--text-lead:1.25rem;--text-body:1.0625rem;--text-small:1rem;--text-caption:.875rem;--text-eyebrow:.8125rem;--lh-tight:1.02;--lh-snug:1.16;--lh-normal:1.5;--lh-relaxed:1.62;--tracking-eyebrow:.18em;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;--space-10:128px;--radius-xs:8px;--radius-sm:12px;--radius-md:18px;--radius-lg:24px;--radius-xl:32px;--radius-pill:999px;--shadow-xs:0 1px 2px #1313160d;--shadow-sm:0 2px 8px #1313160f,0 1px 2px #1313160a;--shadow-md:0 10px 30px -8px #13131621,0 3px 8px -4px #13131612;--shadow-lg:0 26px 56px -16px #13131633,0 8px 18px -10px #1313161a;--shadow-xl:0 44px 90px -28px #13131647;--ease-out:cubic-bezier(.22,.61,.36,1);--ease-click:cubic-bezier(.34,1.25,.64,1);--dur-fast:.13s;--dur-base:.22s;--dur-slow:.38s;--container:1200px;--container-narrow:720px}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{background:var(--bg);min-height:100vh;color:var(--fg);font-family:var(--font-sans);font-size:var(--text-body);line-height:var(--lh-relaxed);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0}h1,h2,h3,h4{font-family:var(--font-display);color:var(--fg);text-wrap:balance;margin:0}.display{font-size:var(--text-hero);font-weight:800;line-height:var(--lh-tight);letter-spacing:-.035em}.h1{font-size:var(--text-h1);font-weight:800;line-height:var(--lh-snug);letter-spacing:-.03em}.h2{font-size:var(--text-h2);font-weight:800;line-height:var(--lh-snug);letter-spacing:-.025em}.h3{font-size:var(--text-h3);letter-spacing:-.015em;font-weight:700;line-height:1.22}.h4{font-size:var(--text-h4);letter-spacing:-.01em;font-weight:700;line-height:1.3}.lead{font-size:var(--text-lead);line-height:var(--lh-relaxed);color:var(--fg-muted);font-weight:400}p{margin:0}.small{font-size:var(--text-small)}.caption{font-size:var(--text-caption);color:var(--fg-subtle)}.muted{color:var(--fg-muted)}.pretty{text-wrap:pretty}.eyebrow{font-family:var(--font-mono);font-size:var(--text-eyebrow);text-transform:uppercase;letter-spacing:var(--tracking-eyebrow);color:var(--fg-subtle);white-space:nowrap;align-items:center;gap:9px;font-weight:500;display:inline-flex}.eyebrow .dot{background:var(--sp-rose);border-radius:50%;width:5px;height:5px}a{color:var(--link);text-decoration:none}a:hover{color:var(--link-hover)}img{max-width:100%}::selection{background:var(--sp-gold);color:var(--ink)}a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--sp-blue);outline-offset:2px;border-radius:4px}svg.lucide{stroke-width:1.75px;vertical-align:middle;width:20px;height:20px}.btn{font-family:var(--font-sans);font-size:var(--text-small);white-space:nowrap;border-radius:var(--radius-pill);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-click),box-shadow var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out);border:1.5px solid #0000;justify-content:center;align-items:center;gap:9px;padding:15px 24px;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn:active{transform:translateY(1.5px)}.btn svg{width:18px;height:18px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-md);color:#fff}.btn-primary:active{background:var(--accent-press);box-shadow:var(--shadow-xs)}.btn-secondary{background:var(--white);color:var(--ink);border-color:var(--border-strong)}.btn-secondary:hover{border-color:var(--ink);box-shadow:var(--shadow-sm)}.btn-secondary:active{background:var(--paper-2)}.btn-onink{color:var(--ink);background:#fff}.btn-onink:hover{color:var(--ink);background:#fff;box-shadow:0 8px 30px -8px #00000080}.btn-lg{font-size:var(--text-body);padding:18px 30px}.btn-sm{font-size:var(--text-caption);padding:10px 16px}.btn-block{width:100%}.btn[disabled],.btn:disabled{opacity:.5;cursor:not-allowed}.input{font-family:var(--font-sans);font-size:var(--text-body);color:var(--fg);background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);width:100%;padding:14px 16px}.input:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 3px #13131614}.wordmark-lockup{white-space:nowrap;align-items:center;gap:.3em;line-height:1;display:inline-flex}.wordmark-script{letter-spacing:.005em;padding:.04em .06em .08em 0;font-family:Grand Hotel,cursive;font-weight:400;line-height:.8}#app-root{flex-direction:column;min-height:100vh;display:flex}.appbar{background:var(--paper);border-bottom:1px solid var(--border);z-index:20;align-items:center;gap:18px;padding:15px 28px;display:flex;position:sticky;top:0}.appbar-logo{color:var(--ink);flex:none;align-items:center;padding-right:6px;text-decoration:none;display:flex}.appbar .order{font-family:var(--font-mono);color:var(--fg-subtle);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;border-left:1px solid var(--border);margin-left:6px;padding-left:20px;font-size:12px}.appbar .order b{color:var(--ink-2);font-weight:500}.appbar .spacer{flex:1}.appbar .help{color:var(--fg-muted);cursor:pointer;background:0 0;border:0;align-items:center;gap:7px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.appbar .help:hover{color:var(--ink)}.stage{flex:1;width:100%}.center{text-align:center;max-width:640px;margin:0 auto;padding:72px 24px}.center .eyebrow{margin-bottom:18px;display:inline-flex}.center h1{letter-spacing:-.03em;margin:0 0 16px}.center .lead{max-width:46ch;margin:0 auto 30px}.field-label{font-family:var(--font-mono);font-size:var(--text-eyebrow);text-transform:uppercase;letter-spacing:.1em;color:var(--fg-subtle);margin-bottom:8px;font-weight:500;display:block}.redeem .redeem-field{text-align:left;max-width:420px;margin:0 auto 26px}.code-input-wrap{background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);transition:border-color var(--dur-fast),box-shadow var(--dur-fast);align-items:center;gap:12px;padding:0 16px;display:flex}.code-input-wrap:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px #13131614}.code-input-wrap>svg{color:var(--ink-4);flex:none}.code-input{width:100%;font-family:var(--font-mono);letter-spacing:.08em;color:var(--ink);text-transform:uppercase;background:0 0;border:0;outline:0;flex:1;padding:16px 0;font-size:1.15rem}.code-input::placeholder{color:var(--ink-5);letter-spacing:.08em}.from-link{font-family:var(--font-mono);font-size:var(--text-caption);color:var(--sp-green);letter-spacing:.02em;align-items:center;gap:6px;margin-top:10px;display:inline-flex}.confirm-stage{text-align:center;max-width:560px;margin:0 auto;padding:88px 24px}.confirm-reel{width:92px;height:92px;margin:0 auto 30px;animation:11s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.pa-spin{animation:.8s linear infinite spin}.confirm-stage .eyebrow{margin-bottom:16px;display:inline-flex}.confirm-stage h1{letter-spacing:-.03em;margin:0 0 14px}.confirm-stage .lead{max-width:42ch;margin:0 auto 28px}.ship-row{font-family:var(--font-mono);color:var(--fg-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);align-items:center;gap:10px;padding:10px 18px;font-size:13px;display:inline-flex}.ship-row svg{color:var(--ink)}.subbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:18;align-items:center;gap:22px;padding:13px 28px;display:flex;position:sticky;top:56px}.subbar-title{flex-direction:column;gap:2px;min-width:0;display:flex}.subbar-title .eyebrow{color:var(--fg-subtle)}.subbar-h1{font-family:var(--font-display);letter-spacing:-.02em;white-space:nowrap;margin:0;font-size:1.12rem;font-weight:800;line-height:1.1}.subbar .spacer{flex:1}.hide-xs{display:inline}.bench{flex:1;grid-template-columns:312px 1fr;align-items:stretch;min-height:0;display:grid}.tray{border-right:1px solid var(--border);background:var(--paper-2);flex-direction:column;height:calc(100vh - 112px);min-height:0;display:flex;position:sticky;top:112px}.tray-dock-toggle{display:none}.tray-head{padding:20px 22px 12px}.tray-head h2{margin:0 0 3px}.tray-head p{color:var(--fg-muted);margin:0;font-size:13px;line-height:1.45}.tray-scroll{scrollbar-width:thin;flex:1;padding:4px 22px 26px;overflow-y:auto}.tray-sect{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-subtle);justify-content:space-between;align-items:center;margin:18px 0 11px;font-size:11px;font-weight:500;display:flex}.tray-sect:first-child{margin-top:6px}.tray-grid{grid-template-columns:1fr 1fr;gap:11px;display:grid}.upload-tile{aspect-ratio:1;border-radius:var(--radius-sm);border:1.5px dashed var(--border-strong);cursor:pointer;color:var(--fg-muted);background:var(--surface);transition:all var(--dur-fast) var(--ease-out);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:7px;padding:8px;display:flex}.upload-tile:hover{border-color:var(--ink);color:var(--ink);background:#fff}.upload-tile span{font-size:12px;font-weight:600}.upload-tile input{display:none}.tile{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border);transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);-webkit-user-select:none;user-select:none;background-position:50%;background-size:cover;position:relative;overflow:hidden}.tile:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.tile:active{cursor:grabbing}.tile-label{font-family:var(--font-mono);color:#ffffffeb;letter-spacing:.04em;text-shadow:0 1px 3px #0006;pointer-events:none;font-size:10px;position:absolute;bottom:7px;left:8px}.tile-add{color:#fff;opacity:0;transition:opacity var(--dur-fast);background:#13131657;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.tile:hover .tile-add{opacity:1}.tile-add .plus{width:34px;height:34px;color:var(--ink);box-shadow:var(--shadow-sm);background:#fffffff2;border-radius:50%;justify-content:center;align-items:center;display:flex}.tile-count{background:var(--ink);color:#fff;min-width:22px;height:22px;font-family:var(--font-mono);box-shadow:var(--shadow-sm);border-radius:11px;justify-content:center;align-items:center;padding:0 7px;font-size:11px;font-weight:500;display:flex;position:absolute;top:7px;right:7px}.tile-step{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);height:30px;box-shadow:var(--shadow-sm);background:#fcfcfbf0;border-radius:8px;justify-content:space-between;align-items:center;display:none;position:absolute;bottom:7px;left:7px;right:7px;overflow:hidden}.tile.placed .tile-step{display:flex}.tile.placed .tile-label{opacity:0}.tile-step button{cursor:pointer;width:30px;height:30px;color:var(--ink);background:0 0;border:0;flex:none;justify-content:center;align-items:center;display:flex}.tile-step button:hover{background:var(--paper-2)}.tile-step .n{font-family:var(--font-mono);color:var(--ink);font-size:12px}.bench-stage{flex-direction:column;min-width:0;display:flex}.stage-head{align-items:center;gap:12px;padding:20px 30px 0;display:flex}.stage-head-main{align-items:baseline;gap:12px;min-width:0;display:flex}.stage-head-main h2{white-space:nowrap}.stage-head .spacer{flex:1}.sh-sub{color:var(--fg-subtle);white-space:nowrap;font-size:13.5px}.stage-pips{padding:14px 30px 2px}.reel-pips{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.pip{flex-direction:column;gap:5px;min-width:66px;display:flex}.pip-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.pip-name{font-family:var(--font-mono);letter-spacing:.07em;text-transform:uppercase;color:var(--fg-subtle);white-space:nowrap;align-items:center;gap:5px;font-size:11px;display:inline-flex}.pip.active .pip-name{color:var(--ink)}.pip-count{font-family:var(--font-mono);color:var(--ink-4);font-variant-numeric:tabular-nums;font-size:11px}.pip.full .pip-count{color:var(--sp-green)}.pip-bar{background:var(--paper-3);border-radius:4px;height:5px;overflow:hidden}.pip-fill{background:var(--spectrum);height:100%;transition:width var(--dur-slow) var(--ease-out);border-radius:4px}.pip.locked{opacity:.42}.strip-wrap{flex:1;padding:16px 30px 48px;overflow-y:auto}.strip-help{color:var(--fg-muted);align-items:center;gap:9px;margin:6px 0 18px;font-size:13.5px;display:flex}.strip-help svg{color:var(--ink-4);flex:none}.reel{margin-bottom:26px}.reel-label{align-items:center;gap:12px;margin-bottom:10px;display:flex}.reel-label .name{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);white-space:nowrap;align-items:center;gap:6px;font-size:12px;font-weight:500;display:inline-flex}.reel-label .rule{background:var(--paper-3);border-radius:3px;flex:1;height:3px;overflow:hidden}.reel-label .rule i{background:var(--spectrum);height:100%;transition:width var(--dur-slow) var(--ease-out);display:block}.reel-label .frac{font-family:var(--font-mono);color:var(--ink-4);font-variant-numeric:tabular-nums;font-size:12px}.reel-label .frac.full{color:var(--sp-green)}.slot-grid{grid-template-columns:repeat(8,1fr);gap:10px;display:grid}.slot{aspect-ratio:1087/1005;border-radius:var(--radius-xs);justify-content:center;align-items:center;display:flex;position:relative}.slot.empty{background:var(--surface-sunk);border:1px solid var(--border);overflow:hidden}.slot.empty .slot-no{font-family:var(--font-mono);color:var(--ink-5);font-size:12px}.slot.empty.next-up{border:1.5px dashed var(--border-strong)}.slot.empty.add{cursor:pointer;transition:border-color var(--dur-fast),background var(--dur-fast)}.slot.empty.add:hover{border-color:var(--ink);background:var(--paper-2)}.slot.empty .slot-up{color:var(--ink-4);justify-content:center;align-items:center;display:none;position:absolute;inset:0}.slot.empty.add:hover .slot-up{display:flex}.slot.empty.add:hover .slot-no{opacity:0}.slot.empty.next-up .slot-up{color:var(--ink-3);display:flex}.slot.empty.next-up .slot-no{opacity:0}.slot.empty.locked{background:repeating-linear-gradient(45deg,var(--paper-3),var(--paper-3) 6px,var(--paper-2) 6px,var(--paper-2) 12px);border:1px dashed var(--border)}.slot.empty.dragover{outline:2px solid var(--ink);outline-offset:2px;background:var(--paper-2)}.slot.filled{cursor:grab}.slot.filled:active{cursor:grabbing}.slot.filled.active{outline:2.5px solid var(--ink);outline-offset:2px}.slot.filled.dragover{outline:2px solid var(--ink);outline-offset:2px}.slot-mask{border-radius:inherit;box-shadow:var(--shadow-xs);background-color:#0b0b0d;background-repeat:no-repeat;position:absolute;inset:0;overflow:hidden}.slot-edit-ic{color:#fff;opacity:0;transition:opacity var(--dur-fast);background:#13131652;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.slot.filled:hover .slot-edit-ic{opacity:1}.slot-rm{color:#fff;cursor:pointer;z-index:4;background:#131316d1;border:0;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;padding:0;display:none;position:absolute;top:3px;right:3px}.slot.filled:hover .slot-rm,.slot.filled.active .slot-rm{display:flex}.slot-rm:hover{background:var(--sp-rose)}.reel.locked-reel{opacity:.55}.reel.locked-reel .reel-lock-note{color:var(--fg-subtle);align-items:center;gap:7px;margin:-2px 0 10px;font-size:12.5px;display:flex}.editor-scrim{z-index:55;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity var(--dur-base);background:#0a0a0c80;position:fixed;inset:0}.editor-scrim.open{opacity:1;pointer-events:auto}.editor-wrap{z-index:56;pointer-events:none;justify-content:center;align-items:center;padding:32px;display:flex;position:fixed;inset:0}.editor-card{background:var(--ink);border-radius:var(--radius-xl);pointer-events:auto;opacity:0;width:min(540px,92vw);max-height:92vh;transition:transform var(--dur-base) var(--ease-out),opacity var(--dur-base);box-shadow:var(--shadow-xl);flex-direction:column;align-items:center;padding:24px;display:flex;position:relative;overflow-y:auto;transform:scale(.96)translateY(8px)}.editor-wrap.open .editor-card{opacity:1;transform:none}.editor-head{justify-content:space-between;align-items:center;gap:12px;width:100%;margin-bottom:18px;display:flex}.editor-tag{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-onink-muted);align-items:center;gap:8px;font-size:12px;display:inline-flex}.editor-tag b{color:#fff;font-weight:500}.editor-tag .dot{background:var(--sp-rose);border-radius:50%;width:6px;height:6px}.editor-head-actions{align-items:center;gap:8px;display:flex}.editor-reset,.editor-done{border-radius:var(--radius-pill);border:1px solid var(--border-onink);cursor:pointer;height:34px;font-family:var(--font-sans);transition:color var(--dur-fast),border-color var(--dur-fast),background var(--dur-fast);justify-content:center;align-items:center;gap:7px;padding:0 13px;font-size:13px;font-weight:600;display:inline-flex}.editor-reset{color:var(--fg-onink-muted);background:0 0}.editor-reset:hover:not(:disabled){color:#fff;background:#ffffff0f;border-color:#ffffff80}.editor-reset:disabled{opacity:.4;cursor:not-allowed}.editor-done{color:#fff;background:#ffffff14;padding:0 14px}.editor-done:hover{background:#ffffff2e}.mask-wrap{aspect-ratio:1087/1005;width:min(400px,52vh,80%);position:relative}.mask{cursor:grab;touch-action:none;background:#000;position:absolute;inset:0;overflow:hidden;box-shadow:0 0 0 1px #ffffff1a,0 18px 60px -12px #ec568047,0 8px 36px -8px #3c7ac942}.mask.grabbing{cursor:grabbing}.mask:after{content:"";pointer-events:none;position:absolute;inset:0;box-shadow:inset 0 0 50px #0006}.mask-empty{color:var(--fg-onink-muted);font-family:var(--font-mono);justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;inset:0}.mask-hint{z-index:3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;pointer-events:none;white-space:nowrap;background:#14131699;border-radius:20px;align-items:center;gap:6px;padding:5px 11px;font-size:11px;transition:opacity .2s;display:flex;position:absolute;top:9px;left:50%;transform:translate(-50%)}.mask.grabbing .mask-hint,.mask-wrap:hover .mask-hint{opacity:0}.zoom-row{align-items:center;gap:14px;width:min(400px,52vh,80%);margin-top:20px;display:flex}.zoom-btn{border:1px solid var(--border-onink);color:#fff;cursor:pointer;background:#ffffff14;border-radius:50%;flex:none;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.zoom-btn:hover{background:#ffffff2e}.zoom-slider{accent-color:var(--sp-gold);cursor:pointer;flex:1}.editor-card .shape-row{grid-template-columns:repeat(4,1fr);gap:6px 8px;width:min(400px,84%);margin-top:18px;display:grid}.shape-opt{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--dur-fast);background:0 0;border:0;flex-direction:column;align-items:center;gap:7px;padding:8px 6px;display:flex}.shape-opt:hover{background:#ffffff0f}.shape-opt.active{background:#ffffff1f}.shape-opt[disabled]{opacity:.4;cursor:not-allowed}.shape-swatch{background:var(--fg-onink-muted);width:26px;height:24px;transition:background var(--dur-fast);display:block}.shape-opt:hover .shape-swatch,.shape-opt.active .shape-swatch{background:#fff}.shape-lbl{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-onink-muted);font-size:10px}.shape-opt.active .shape-lbl{color:#fff}.frame-nav{justify-content:center;align-items:center;gap:20px;margin-top:20px;display:flex}.frame-nav button{border:1px solid var(--border-onink);color:#fff;cursor:pointer;background:#ffffff14;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.frame-nav button:hover{background:#ffffff2e}.frame-nav .count{font-family:var(--font-mono);letter-spacing:.1em;color:var(--sp-gold);text-transform:uppercase;text-align:center;min-width:116px;font-size:12px}.proj-overlay{z-index:60;opacity:0;pointer-events:none;transition:opacity var(--dur-base) var(--ease-out);background:radial-gradient(120% 80% at 50% 38%,#2a2520 0%,#1b1813 42%,#110f0c 100%),linear-gradient(#1d1a16,#0e0c09);flex-direction:column;display:flex;position:fixed;inset:0}.proj-overlay.open{opacity:1;pointer-events:auto}.proj-bar{z-index:4;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#100e0b8c;border-bottom:1px solid #ffffff14;flex:none;justify-content:space-between;align-items:center;gap:14px;height:66px;padding:0 22px;display:flex;position:relative}.proj-bar-title{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--fg-onink-muted);align-items:center;gap:8px;font-size:12px;display:inline-flex}.proj-bar-title .dot{background:var(--sp-gold);border-radius:50%;width:6px;height:6px}.proj-back{color:#fff;background:0 0;border:1.5px solid #ffffff47}.proj-back:hover{color:#fff;background:#ffffff14;border-color:#fff}.proj-room{z-index:1;flex-direction:column;flex:1;align-items:center;min-height:0;padding:14px 24px 20px;display:flex;position:relative;overflow:hidden}.room-glow{z-index:0;filter:blur(8px);pointer-events:none;background:radial-gradient(50% 50%,#f5e0b824,#ecb0780a 55%,#0000 72%);width:min(620px,80vw);height:min(420px,48vh);position:absolute;top:14%;left:50%;transform:translate(-50%)}.light-cone{z-index:0;pointer-events:none;opacity:.28;clip-path:polygon(42% 100%,58% 100%,96% 6%,4% 6%);filter:blur(6px);background:linear-gradient(#0000 28%,#f7ebcd0a 55%,#f7ebcd29);width:78%;height:100%;position:absolute;bottom:-10%;left:50%;transform:translate(-50%);-webkit-mask-image:radial-gradient(70% 80% at 50% 30%,#000 30%,#0000 78%);mask-image:radial-gradient(70% 80% at 50% 30%,#000 30%,#0000 78%)}.proj-intro{z-index:2;color:var(--fg-onink-muted);text-align:center;max-width:52ch;margin:2px 0 4px;font-size:13.5px;line-height:1.4;position:relative}.projection-area{z-index:5;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;width:100%;min-height:0;margin:6px 0;display:flex;position:relative}.projection-frame{z-index:1;aspect-ratio:1087/1005;width:min(520px,50vh,84vw);position:relative}.proj-spill{z-index:0;pointer-events:none;filter:blur(26px);background:radial-gradient(50% 50%,#f4eee229,#f4eee208 62%,#0000 75%);position:absolute;inset:-10%}.projection{z-index:1;cursor:grab;touch-action:none;filter:blur(.9px)brightness(1.08)contrast(.86)saturate(.9);background:#000;position:absolute;inset:0;overflow:hidden}.projection.grabbing{cursor:grabbing}.proj-warm{pointer-events:none;mix-blend-mode:screen;background:radial-gradient(72% 72% at 50% 42%,#ffeed221,#ffe4bc0d 55%,#0000 76%);position:absolute;inset:0}.proj-pan-hint{z-index:3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;pointer-events:none;white-space:nowrap;background:#1413168c;border-radius:20px;align-items:center;gap:6px;padding:5px 11px;font-size:11px;transition:opacity .2s;display:flex;position:absolute;top:14px;left:50%;transform:translate(-50%)}.projection-area:active .proj-pan-hint{opacity:0}.proj-vignette{pointer-events:none;background:radial-gradient(118% 118% at 50% 45%,#0000 48%,#08060480 100%);position:absolute;inset:0;box-shadow:inset 0 0 30px #00000047}.proj-grain{pointer-events:none;opacity:.13;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");position:absolute;inset:0}.proj-caption{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--sp-gold);white-space:nowrap;margin:0;font-size:12px}.proj-info{z-index:3;justify-content:center;display:flex;position:relative}.proj-info-btn{cursor:pointer;color:var(--fg-onink-muted);font-family:var(--font-sans);background:0 0;border:0;align-items:center;gap:6px;font-size:12.5px;display:inline-flex}.proj-info-btn:hover{color:#fff}.proj-info-card{border-radius:var(--radius-md);width:min(360px,86vw);max-height:min(52vh,440px);box-shadow:var(--shadow-xl);text-align:left;z-index:8;background:#1c1916fa;border:1px solid #ffffff24;padding:16px 18px 15px;position:absolute;bottom:calc(100% + 8px);left:50%;overflow-y:auto;transform:translate(-50%)}.proj-info-card .pic-close{width:26px;height:26px;color:var(--fg-onink-muted);cursor:pointer;background:0 0;border:0;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:8px;right:8px}.proj-info-card .pic-close:hover{color:#fff;background:#ffffff1a}.proj-info-card .pic-title{color:#fff;margin:0 0 6px;padding-right:20px;font-size:14px;font-weight:700}.proj-info-card .pic-subhead{color:#fff;margin:12px 0 0;font-size:13px;font-weight:700}.proj-info-card p{color:var(--fg-onink-muted);font-size:13px;line-height:1.5}.proj-info-card ul{flex-direction:column;gap:5px;margin:9px 0;padding-left:18px;display:flex}.proj-info-card li{color:var(--fg-onink-muted);font-size:13px;line-height:1.45}.proj-info-card li b,.proj-info-card p b{color:var(--fg-onink);font-weight:600}.proj-info-card .pic-foot{margin-top:10px;font-style:italic}.edit-dock{z-index:2;flex-direction:column;order:2;align-items:center;gap:14px;width:100%;margin-top:14px;display:flex;position:relative}.edit-nav{align-items:center;gap:16px;display:flex}.edit-dock .zoom-row{width:min(360px,46vw);margin-top:0}.edit-dock .shape-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 8px;width:min(640px,92%);margin-top:0;display:flex}.edit-dock .shape-opt{width:56px}.edit-dock .editor-reset{margin-left:6px}.proj-cbtn{color:#fff;cursor:pointer;width:46px;height:46px;transition:background var(--dur-fast);background:#ffffff12;border:1px solid #ffffff2e;border-radius:50%;flex:none;justify-content:center;align-items:center;display:flex}.proj-cbtn:hover{background:#ffffff29}.proj-filmstrip{z-index:2;scrollbar-width:thin;order:1;align-items:center;gap:7px;max-width:100%;margin-top:18px;padding:4px 6px 8px;display:flex;position:relative;overflow-x:auto}.fs-divider{background:#ffffff2e;flex:none;width:1px;height:30px;margin:0 6px 0 9px}.fs-reel-tag{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-onink-muted);flex:none;align-self:center;padding:0 5px 0 0;font-size:10px}.fs-thumb{cursor:grab;outline-offset:2px;width:46px;height:43px;transition:outline-color var(--dur-fast),transform var(--dur-fast);background-color:#0d0d0f;border:0;border-radius:5px;outline:2px solid #0000;flex:none;padding:0;position:relative;overflow:hidden}.fs-thumb:active{cursor:grabbing}.fs-thumb:hover{transform:translateY(-2px)}.fs-thumb.cur{outline-color:var(--sp-gold)}.fs-fill,.crop-pan{position:absolute;inset:0}.crop-img{background-position:50%;background-repeat:no-repeat;background-size:cover;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.shape-rounded{border-radius:7%}.shape-circle{clip-path:circle()}.shape-arch{border-radius:48% 48% 7% 7%/60% 60% 7% 7%}.shape-scallop{clip-path:url(#pg-scallop)}.shape-stamp{clip-path:url(#pg-stamp)}.shape-torn{clip-path:url(#pg-torn)}.shape-heart{clip-path:url(#pg-heart)}.shape-star{clip-path:url(#pg-star)}@media (max-width:1080px){.bench{grid-template-columns:264px 1fr}}@media (max-width:860px){.appbar{gap:12px;padding:12px 18px}.appbar .order{display:none}.subbar{gap:12px 18px;top:53px}.bench{grid-template-columns:1fr}.tray{border-right:0;border-bottom:1px solid var(--border);height:auto;max-height:none;position:static}.tray-dock-toggle{display:none}.tray-scroll{max-height:46vh}.tray-grid{grid-template-columns:repeat(3,1fr)}.strip-wrap{padding:14px 18px 40px}.slot-grid{grid-template-columns:repeat(4,1fr);gap:9px}.stage-head{padding:16px 18px 0}.stage-pips{padding:12px 18px 2px}.editor-wrap{padding:16px}.mask-wrap,.zoom-row,.editor-card .shape-row{width:min(360px,80vw)}.proj-bar{height:58px;padding:0 14px}.proj-bar-title{display:none}.proj-bloom,.projection{width:min(420px,44vh,88vw)}.proj-intro{display:none}}@media (max-width:480px){.hide-xs{display:none}}@media (prefers-reduced-motion:reduce){.confirm-reel{animation:none}.pip-fill,.reel-label .rule i{transition:none}}
