:root,:root[data-theme=dark]{--bg:#0d0e11;--surface:#16181d;--surface-2:#1e2128;--surface-3:#282c35;--glass:#14161bb8;--viewport-inset:inset 0 2px 14px #00000059;--text:#f3f4f6;--text-dim:#a4a9b4;--text-mute:#6e7380;--border:#ffffff12;--border-strong:#ffffff24;--accent:#7e9cff;--accent-hover:#93acff;--accent-ink:#0b0e16;--accent-soft:#7e9cff26;--danger:#ff6b6b;--heart:#ff5d7d;--backdrop:#000;--ss-ink:#fff;--shadow-1:0 1px 2px #0006;--shadow-2:0 10px 30px #00000073;--shadow-pop:0 16px 44px #0009;--brand-grad:linear-gradient(140deg, #7e9cff, #b58bff)}:root[data-theme=light]{--bg:#f5f6f8;--surface:#fff;--surface-2:#f0f1f5;--surface-3:#e6e8ee;--glass:#ffffffc7;--viewport-inset:none;--text:#181a20;--text-dim:#565b68;--text-mute:#9398a6;--border:#10121b14;--border-strong:#10121b29;--accent:#4f6bff;--accent-hover:#3f5cff;--accent-ink:#fff;--accent-soft:#4f6bff1f;--danger:#e5484d;--heart:#ff4d6d;--backdrop:#fff;--ss-ink:#14161c;--shadow-1:0 1px 2px #10121b12;--shadow-2:0 10px 30px #10121b1a;--shadow-pop:0 16px 44px #10121b29;--brand-grad:linear-gradient(140deg, #4f6bff, #9b6bff)}:root{--s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s8:48px;--s10:72px;--s1h:6px;--s2h:10px;--s3h:14px;--icon-xs:14px;--icon-sm:22px;--icon-md:28px;--icon-lg:38px;--control-h:36px;--control-pad-x:var(--s3);--control-radius:var(--r-sm);--control-bg:var(--bg);--control-border:var(--border-strong);--topbar-h:58px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:22px;--r-pill:999px;--t-xs:11px;--t-sm:13px;--t-base:14px;--t-md:15px;--t-lg:17px;--t-xl:22px;--t-2xl:30px;--ease:cubic-bezier(.2, .7, .2, 1);--dur:.16s;--dur-slow:.32s;--font:-apple-system, BlinkMacSystemFont, "SF Pro Display", "Inter", "Segoe UI", system-ui, sans-serif;--rate-happy:#57c98b;--rate-neutral:#b9bcc6;--rate-sad:#ff6b6b}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:var(--t-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;margin:0;line-height:1.45}h1,h2,h3,h4,p{margin:0}button,input,select,textarea{font-family:inherit}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}:focus{outline:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}::selection{background:var(--accent-soft)}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{background:var(--surface-3);background-clip:padding-box;border:3px solid #0000;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}::-webkit-scrollbar-track{background:0 0}.app{flex-direction:column;min-height:100vh;display:flex}.topbar{align-items:center;gap:var(--s5);height:var(--topbar-h);padding:0 var(--s5);background:color-mix(in srgb, var(--surface) 84%, transparent);-webkit-backdrop-filter:blur(18px)saturate(1.4);border-bottom:1px solid var(--border);z-index:50;display:flex;position:sticky;top:0}.brand{align-items:center;gap:var(--s2);font-family:inherit;font-weight:500;font-size:var(--t-lg);letter-spacing:-.01em;color:inherit;background:0 0;border:0;padding:0;display:flex}.brand-mark{background:var(--brand-grad);width:22px;height:22px;box-shadow:var(--shadow-1);border-radius:7px}.nav{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-pill);gap:2px;padding:3px;display:flex}.nav-btn{appearance:none;cursor:pointer;color:var(--text-dim);font-weight:600;font-size:var(--t-sm);border-radius:var(--r-pill);white-space:nowrap;transition:color var(--dur) var(--ease), background var(--dur) var(--ease);background:0 0;border:0;padding:7px 16px}.nav-btn:hover{color:var(--text)}.nav-btn[aria-current=true]{background:var(--surface-3);color:var(--text);box-shadow:var(--shadow-1)}.spacer{margin-left:auto}.client-chip{align-items:center;gap:var(--s2);color:var(--text-dim);font-size:var(--t-sm);display:flex}.client-chip:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px}.icon-btn{appearance:none;background:var(--surface-2);width:34px;height:34px;color:var(--text-dim);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all var(--dur) var(--ease);place-items:center;font-size:15px;display:grid}.icon-btn:hover{color:var(--text);border-color:var(--border-strong);background:var(--surface-3)}.main{flex:1;min-height:0}.section{padding:var(--s6);max-width:1320px;margin:0 auto}.section--fill{height:calc(100dvh - var(--topbar-h));padding:var(--s4) var(--s6);flex-direction:column;display:flex;overflow:hidden}.section-head{align-items:center;gap:var(--s4);margin-bottom:var(--s3);display:flex}.section-title{font-size:var(--t-xl);letter-spacing:-.02em;align-items:center;gap:var(--s2);font-weight:700;display:flex}.section-meta{color:var(--text-mute);font-size:var(--t-sm)}.btn{appearance:none;cursor:pointer;font-weight:650;font-size:var(--t-sm);border-radius:var(--r-md);align-items:center;gap:var(--s2);transition:all var(--dur) var(--ease);border:1px solid #0000;padding:9px 16px;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-ink)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-2);transform:translateY(-1px)}.btn-soft{background:var(--surface-2);color:var(--text);border-color:var(--border)}.btn-soft:hover:not(:disabled){background:var(--surface-3);border-color:var(--border-strong)}.btn-ghost{color:var(--text-dim);border-color:var(--border);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border-strong)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.08);box-shadow:var(--shadow-2);transform:translateY(-1px)}.file-btn{position:relative;overflow:hidden}.file-btn input{opacity:0;cursor:pointer;position:absolute;inset:0}.ab-btn{appearance:none;cursor:pointer;font:inherit;font-size:var(--t-sm);align-items:center;gap:var(--s2);color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);transition:all var(--dur) var(--ease);padding:6px 12px;font-weight:600;display:inline-flex}.ab-btn:hover:not(:disabled){background:var(--surface-3);border-color:var(--border-strong);color:var(--text)}.ab-btn:disabled{opacity:.4;cursor:not-allowed}.photo-grid{gap:var(--s4);grid-template-columns:repeat(auto-fill,minmax(190px,1fr));display:grid}.photo-card{aspect-ratio:4/5;border-radius:var(--r-lg);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);position:relative;overflow:hidden}.photo-card:hover{box-shadow:var(--shadow-2);transform:translateY(-3px)}.photo-card canvas,.photo-card img,.photo-card .preview-state{object-fit:cover;width:100%;height:100%;display:block}.rendered-preview{width:100%;height:100%;position:relative}.rendered-preview>img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.rendered-preview .rp-master{transition:filter .28s}.rendered-preview .rp-master[data-stale=true]{filter:blur(10px)}@media (prefers-reduced-motion:reduce){.rendered-preview .rp-master{transition:none}}.rendered-preview .rp-fill{position:absolute;inset:0}@keyframes preview-breathe{0%,to{opacity:1}50%{opacity:.6}}@media (prefers-reduced-motion:reduce){.preview-pending{animation:none}}.photo-card:after{content:"";border-radius:inherit;box-shadow:inset 0 0 0 1px var(--border);pointer-events:none;position:absolute;inset:0}.trash-card{cursor:default}.trash-card:hover{box-shadow:none;transform:none}.trash-card img,.trash-card .preview-state{opacity:.45}.trash-card .ss-cover-play{display:none}.trash-restore{z-index:2;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.photo-fav{width:28px;height:28px;color:var(--heart);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000073;border-radius:50%;place-items:center;font-size:14px;display:grid;position:absolute;top:10px;right:10px}.dropzone{justify-content:center;align-items:center;gap:var(--s2);border:1.5px dashed var(--border-strong);border-radius:var(--r-xl);padding:var(--s10) var(--s5);text-align:center;cursor:pointer;color:var(--text-dim);transition:all var(--dur) var(--ease);appearance:none;font:inherit;background:0 0;flex-direction:column;width:100%;display:flex}.dropzone:hover{border-color:var(--accent);color:var(--text);background:var(--accent-soft)}.dropzone strong{color:var(--text);font-size:var(--t-md)}.dz-icon{opacity:.8;margin-bottom:var(--s1);font-size:30px}.empty{justify-content:center;align-items:center;gap:var(--s3);min-height:48vh;padding:var(--s10) var(--s5);text-align:center;color:var(--text-mute);flex-direction:column;display:flex}.empty-icon{opacity:.5;font-size:32px}.stage{flex:1;place-items:center;min-height:0;padding:0;display:grid;position:relative}.stage-zoom{width:100%;height:100%}.stage-canvas{filter:drop-shadow(0 1px 2px #00000059)drop-shadow(0 0 3px #0003);width:auto;max-width:100%;height:auto;max-height:100%}.zoom-viewport{touch-action:none;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);min-height:0;box-shadow:var(--viewport-inset);position:relative;overflow:hidden}.zoom-inner{transform-origin:50%;transition:transform 60ms linear;position:absolute;inset:0}.zoom-inner.panning{transition:none}.zoom-inner canvas,.zoom-inner img,.zoom-inner .preview-state{object-fit:scale-down;-webkit-user-drag:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}.zoom-inner canvas.stage-canvas{object-fit:contain;image-rendering:auto}.zoom-controls{top:var(--s3);right:var(--s3);padding:6px var(--s2);border-radius:var(--r-pill);background:var(--glass);border:1px solid var(--border-strong);-webkit-backdrop-filter:blur(20px)saturate(1.4);box-shadow:var(--shadow-pop);opacity:1;z-index:30;align-items:center;gap:5px;display:flex;position:absolute}.zoom-btn{color:var(--text-dim);border-radius:var(--r-pill);cursor:pointer;min-width:30px;height:30px;transition:background var(--dur) var(--ease), color var(--dur) var(--ease);background:0 0;border:none;justify-content:center;align-items:center;padding:0 9px;font-size:15px;font-weight:600;line-height:1;display:inline-flex}.zoom-btn:hover{background:var(--surface-3);color:var(--text)}.zoom-btn:disabled{opacity:.4;cursor:default}.zoom-btn.zoom-text{font-size:var(--t-sm)}.zoom-btn[data-active=true]{background:var(--accent-soft);color:var(--accent)}.zoom-sep{background:var(--border-strong);width:1px;height:20px;margin:0 2px}.zoom-range{width:84px;accent-color:var(--accent);cursor:pointer}.toolpill{background:var(--glass);-webkit-backdrop-filter:blur(22px)saturate(1.6);border:1px solid var(--border-strong);border-radius:var(--r-pill);box-shadow:var(--shadow-pop);animation:pill-in var(--dur-slow) var(--ease);align-items:center;gap:2px;padding:6px 10px;display:flex;position:absolute;bottom:22px;left:50%;transform:translate(-50%)}@keyframes pill-in{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.tool{appearance:none;cursor:pointer;border-radius:var(--r-md);color:var(--text-dim);font-size:var(--t-xs);transition:all var(--dur) var(--ease);background:0 0;border:0;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:7px 11px;font-weight:600;display:flex}.tool[class*=rate-]{min-width:64px}.tool:hover{color:var(--text);background:color-mix(in srgb, var(--text) 8%, transparent)}.tool[data-active=true]{color:var(--accent);background:color-mix(in srgb, var(--accent) 13%, transparent)}.tool-ic{font-size:16px;line-height:1}.toolpill .divider{background:var(--border-strong);align-self:stretch;width:1px;margin:5px 3px}.ratio-pop{background:var(--glass);-webkit-backdrop-filter:blur(22px)saturate(1.6);border:1px solid var(--border-strong);border-radius:var(--r-pill);box-shadow:var(--shadow-pop);animation:pill-in var(--dur) var(--ease);gap:2px;padding:4px;display:flex;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%)}.ratio-pop button{appearance:none;cursor:pointer;white-space:nowrap;color:var(--text-dim);font-size:var(--t-xs);border-radius:var(--r-pill);transition:all var(--dur) var(--ease);background:0 0;border:0;padding:6px 11px;font-weight:600}.ratio-pop button:hover{color:var(--text);background:color-mix(in srgb, var(--text) 8%, transparent)}.ratio-pop button[data-active=true]{color:var(--accent);background:var(--accent-soft)}.seg{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);gap:2px;padding:3px;display:inline-flex}.seg button{appearance:none;cursor:pointer;color:var(--text-dim);font-size:var(--t-sm);transition:all var(--dur) var(--ease);background:0 0;border:0;border-radius:8px;padding:6px 14px;font-weight:600}.seg button:hover{color:var(--text)}.seg button[data-active=true]{background:var(--surface-3);color:var(--text);box-shadow:var(--shadow-1)}.controls-bar{align-items:center;gap:var(--s3);margin-bottom:var(--s4);flex-wrap:wrap;display:flex}.stage-show{border:1px solid var(--border);border-radius:var(--r-xl);min-height:64vh;transition:background var(--dur-slow) var(--ease);place-items:center;display:grid;overflow:hidden}.stage-show canvas{border-radius:var(--r-sm);max-width:90%;max-height:86%;box-shadow:0 24px 70px #00000080}.order-chips{gap:var(--s2);margin-bottom:var(--s5);flex-wrap:wrap;display:flex}.chip-add{appearance:none;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:var(--r-pill);font-size:var(--t-sm);cursor:pointer;transition:all var(--dur) var(--ease);padding:6px 13px}.chip-add:hover{border-color:var(--accent);color:var(--text);transform:translateY(-1px)}.order-grid{gap:var(--s2);display:grid}.order-row{align-items:center;gap:var(--s3);padding:var(--s3) var(--s4);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);grid-template-columns:1.6fr .9fr .55fr .8fr .8fr 34px;display:grid}.order-row.head{padding:0 var(--s4);color:var(--text-mute);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.05em;background:0 0;border:0}.order-row .filename{color:var(--text);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.row-total{text-align:right;font-variant-numeric:tabular-nums;color:var(--text-dim)}.field{background:var(--surface-2);color:var(--text);border:1px solid var(--border);font-size:var(--t-sm);width:100%;transition:border-color var(--dur) var(--ease);border-radius:8px;padding:7px 10px}.field:focus{border-color:var(--accent)}.name-input{border:0;border-bottom:1.5px solid var(--border-strong);color:var(--text);font:inherit;font-size:var(--t-xl);letter-spacing:-.02em;min-width:180px;transition:border-color var(--dur) var(--ease);background:0 0;padding:2px 2px 4px;font-weight:700}.name-input:focus{border-color:var(--accent)}.name-input::placeholder{color:var(--text-mute)}.order-total{justify-content:flex-end;align-items:baseline;gap:var(--s4);margin-top:var(--s5);display:flex}.order-total b{font-size:var(--t-xl);font-variant-numeric:tabular-nums}.login{min-height:100vh;padding:var(--s5);place-items:center;display:grid}.login-card{gap:var(--s3);text-align:center;flex-direction:column;width:340px;max-width:100%;display:flex}.login-card h1{justify-content:center;align-items:center;gap:var(--s2);font-size:var(--t-2xl);letter-spacing:-.03em;margin-bottom:var(--s3);display:flex}.login-row{gap:var(--s2);display:flex}.login-err{color:var(--danger);font-size:var(--t-sm)}.login-divider{align-items:center;gap:var(--s2);color:var(--text-dim);font-size:var(--t-sm);display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.photo-card.selected{box-shadow:0 0 0 2.5px var(--accent)}.photo-card.selected:after{box-shadow:none}.card-select{cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;width:22px;height:22px;transition:opacity var(--dur) var(--ease);background:#00000073;border:1.5px solid #ffffff8c;border-radius:50%;place-items:center;padding:0;line-height:0;display:grid;position:absolute;top:10px;left:10px}.photo-card:hover .card-select,.photo-card.selected .card-select{opacity:1}.photo-card.selected .card-select{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.card-heart{cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#ffffffb3;opacity:0;width:28px;height:28px;transition:all var(--dur) var(--ease);background:#00000073;border:0;border-radius:50%;place-items:center;font-size:14px;display:grid;position:absolute;top:10px;right:10px}.photo-card:hover .card-heart{opacity:1}.card-heart[data-fav=true]{opacity:1;color:var(--heart)}.card-heart:hover{transform:scale(1.12)}.actionbar{max-width:calc(100vw - 2 * var(--s3));background:var(--glass);-webkit-backdrop-filter:blur(22px)saturate(1.6);border:1px solid var(--border-strong);border-radius:var(--r-pill);box-shadow:var(--shadow-pop);z-index:40;animation:pill-in var(--dur-slow) var(--ease);flex-wrap:wrap;justify-content:center;align-items:center;gap:3px;padding:7px 8px 7px 14px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.actionbar .count{font-weight:700;font-size:var(--t-sm);white-space:nowrap;margin-right:4px}.actionbar .ab-btn{appearance:none;cursor:pointer;border-radius:var(--r-pill);color:var(--text-dim);font-size:var(--t-sm);transition:all var(--dur) var(--ease);white-space:nowrap;background:0 0;border:0;flex-shrink:0;align-items:center;gap:5px;padding:7px 10px;font-weight:600;display:flex}.actionbar .ab-btn:hover:not(:disabled){color:var(--text);background:color-mix(in srgb, var(--text) 8%, transparent)}.actionbar .ab-btn:disabled{opacity:.35;cursor:not-allowed}.actionbar .ab-btn.danger:hover:not(:disabled){color:var(--danger);background:color-mix(in srgb, var(--danger) 14%, transparent)}.actionbar .ab-primary{background:var(--accent);color:var(--accent-ink)}.actionbar .ab-primary:hover:not(:disabled){background:var(--accent-hover);color:var(--accent-ink)}.actionbar .ab-primary:disabled{color:var(--text-dim);background:0 0}.actionbar .ab-div{background:var(--border-strong);align-self:stretch;width:1px;margin:4px 2px}.compare-head{align-items:center;gap:var(--s4);margin-bottom:var(--s3);display:flex}.compare-grid{gap:var(--s4);flex:1;min-height:0;display:grid}.compare-grid.n2{grid-template-rows:1fr;grid-template-columns:1fr 1fr}.compare-grid.n3{grid-template-rows:1fr;grid-template-columns:repeat(3,1fr)}.compare-grid.n4{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.compare-grid.n1{grid-template-rows:1fr;grid-template-columns:1fr}.compare-grid.n5,.compare-grid.n6{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(3,1fr)}.compare-grid.n7,.compare-grid.n8{grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(4,1fr)}.compare-section{grid-template-columns:var(--rail-w,160px) 6px 1fr;height:calc(100dvh - var(--topbar-h));grid-template-rows:auto 1fr;min-height:0;display:grid;overflow:hidden}.compare-resize-handle{cursor:col-resize;background:var(--border);opacity:.4;-webkit-user-select:none;user-select:none;touch-action:none;transition:opacity .12s,background-color .12s}.compare-resize-handle:hover,.compare-resize-handle:active{opacity:1;background:var(--accent)}.compare-header{align-items:center;gap:var(--s4);padding:var(--s3) var(--s4);border-bottom:1px solid var(--border);grid-column:1/-1;display:flex}.compare-rail{border-right:0;border-right:1px solid var(--border);padding:var(--s2);gap:var(--s2);flex-direction:column;display:flex;overflow-y:auto}.compare-rail .wall-tray-item{width:100%}.compare-rail .wall-tray-item[data-selected=true]{border-color:var(--accent)}.compare-rail .wall-tray-item[data-in-use=true]{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.compare-rail .wall-tray-thumb{position:relative}.compare-rail .wall-tray-item[data-in-use=true] .wall-tray-thumb:after{content:"";pointer-events:none;background:var(--accent);opacity:.18;position:absolute;inset:0}.compare-rail-pos{z-index:1;background:var(--accent);min-width:18px;height:18px;color:var(--accent-contrast,#fff);font-size:var(--t-xs);font-variant-numeric:tabular-nums;border-radius:999px;justify-content:center;align-items:center;padding:0 5px;font-weight:600;line-height:1;display:inline-flex;position:absolute;top:4px;left:4px;box-shadow:0 1px 2px #00000059}.compare-area{min-height:0;padding:var(--s4);flex-direction:column;display:flex}.compare-empty{color:var(--text-mute);text-align:center;flex:1;place-items:center;display:grid}.compare-cell-remove{top:var(--s2);right:var(--s2);opacity:0;color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;width:24px;height:24px;transition:opacity .1s;position:absolute}.compare-cell:hover .compare-cell-remove{opacity:1}.compare-area[data-drop-active=true]{outline:2px dashed var(--accent);outline-offset:-8px}.compare-cell[data-drop-active=true]{outline:2px solid var(--accent);outline-offset:-4px}.compare-cell{cursor:pointer;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);place-items:center;min-width:0;min-height:0;display:grid;position:relative;overflow:hidden}.compare-cell.selected:after{content:"";border-radius:inherit;box-shadow:inset 0 0 0 3px var(--accent);pointer-events:none;z-index:3;position:absolute;inset:0}.compare-cell .zoom-viewport{width:100%;height:100%}.compare-name{font-size:var(--t-xs);color:#fff;border-radius:var(--r-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2;background:#00000080;padding:2px 9px;position:absolute;bottom:8px;right:10px}.compare-cell .card-rating{z-index:2}.compare-stage{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.zoom-controls-head{position:static;top:auto;right:auto}.tool.rate-happy[data-active=true]{color:var(--rate-happy);background:color-mix(in srgb, var(--rate-happy) 13%, transparent)}.tool.rate-neutral[data-active=true]{color:var(--rate-neutral);background:color-mix(in srgb, var(--rate-neutral) 15%, transparent)}.tool.rate-sad[data-active=true]{color:var(--rate-sad);background:color-mix(in srgb, var(--rate-sad) 13%, transparent)}.actionbar .ab-btn.rate-happy{color:var(--rate-happy)}.actionbar .ab-btn.rate-neutral{color:var(--rate-neutral)}.actionbar .ab-btn.rate-sad{color:var(--rate-sad)}.actionbar .ab-btn[class*=rate-]{padding:6px;font-size:15px}.card-rating{border-radius:var(--r-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000073;align-items:center;gap:2px;padding:3px;display:flex;position:absolute;bottom:10px;left:10px}.card-rating .face{cursor:pointer;color:#ffffff8c;width:24px;height:24px;transition:background var(--dur) var(--ease), color var(--dur) var(--ease);background:0 0;border:0;border-radius:50%;place-items:center;padding:0;line-height:0;display:none}.card-rating .face[data-active=true],.photo-card:hover .card-rating .face,.compare-cell:hover .card-rating .face{display:grid}.card-rating .face:hover{color:#fff;background:#ffffff29}.face-happy[data-active=true]{color:var(--rate-happy)}.face-neutral[data-active=true]{color:var(--rate-neutral)}.face-sad[data-active=true]{color:var(--rate-sad)}.compare-cell .card-rating{left:10px}.settings-wrap{position:relative}.pop-scrim{z-index:40;position:fixed;inset:0}.settings-pop{z-index:50;gap:var(--s2);width:max-content;padding:var(--s3);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-md);box-shadow:var(--shadow-pop);flex-direction:column;display:flex;position:absolute;top:calc(100% + 10px);right:0}.settings-label{font-size:var(--t-xs);color:var(--text-mute);text-transform:uppercase;letter-spacing:.05em}.tool-ic{place-items:center;display:grid}.photo-card.cursor{box-shadow:0 0 0 2px var(--text)}.photo-card.selected.cursor{box-shadow:0 0 0 2.5px var(--accent), inset 0 0 0 2px #ffffffa6}.kbd-scrim{z-index:60;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fade-in var(--dur) var(--ease);background:#00000073;place-items:center;display:grid;position:fixed;inset:0}.kbd-modal{width:400px;max-width:92vw;padding:var(--s5);gap:var(--s2);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);animation:modal-in var(--dur-slow) var(--ease);flex-direction:column;display:flex}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.kbd-title{font-size:var(--t-lg);letter-spacing:-.01em;margin-bottom:var(--s2);font-weight:700}.kbd-row{justify-content:space-between;align-items:center;gap:var(--s4);color:var(--text-dim);font-size:var(--t-sm);display:flex}.kbd{font-family:var(--font);font-size:var(--t-xs);color:var(--text);background:var(--surface-2);border:1px solid var(--border-strong);white-space:nowrap;border-bottom-width:2px;border-radius:6px;padding:3px 8px}.edit-toolbar{gap:var(--s3);padding:var(--s3) var(--s4);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);flex-direction:column;display:flex}.edit-auto{align-items:center;gap:var(--s2);display:flex}.edit-slider{gap:var(--s1);flex-direction:column;padding:2px 0;display:flex}.edit-slider-head{justify-content:space-between;align-items:center;gap:var(--s2);display:flex}.edit-slider-label{font-size:var(--t-sm);color:var(--text);cursor:ew-resize;-webkit-user-select:none;user-select:none}.edit-slider-value{align-items:center;gap:4px;display:inline-flex}.edit-slider-track{align-items:center;width:100%;height:18px;display:flex;position:relative}.edit-slider-track input[type=range]{z-index:1;width:100%;accent-color:var(--accent);position:relative}.edit-slider-tick{background:var(--border-strong);pointer-events:none;z-index:0;width:2px;height:10px;position:absolute;top:50%;transform:translate(-1px,-50%)}.preview-state{position:relative;overflow:hidden}.preview-pending{background:#41485a linear-gradient(100deg,#ffffff0a 20%,#ffffff38 50%,#ffffff0a 80%) 0 0/200% 100%;animation:1.2s ease-in-out infinite preview-shimmer}.preview-img{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .2s var(--ease);display:block;position:absolute;inset:0}.preview-img.is-loaded{opacity:1}.preview-failed{background:var(--surface-2);color:var(--text-mute);place-items:center;display:grid}@keyframes preview-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.crop-container{pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;cursor:move;z-index:2;position:absolute;inset:0}.crop-container--ruler,.crop-container--ruler .crop-mask,.crop-container--ruler .crop-handle{cursor:crosshair}.crop-frame{pointer-events:none;outline:1px solid #fff;position:absolute;box-shadow:inset 0 0 0 1px #00000073}.crop-mask{cursor:grab;background:#00000080;position:absolute}.crop-mask:active{cursor:grabbing}.crop-grid{pointer-events:none;background-image:linear-gradient(#ffffff59 1px,#0000 1px),linear-gradient(90deg,#ffffff59 1px,#0000 1px);background-position:0 0;background-size:33.33% 33.33%;position:absolute;inset:0}.crop-handle{z-index:3;background:#fff;border:1px solid #00000080;border-radius:2px;width:12px;height:12px;position:absolute;transform:translate(-50%,-50%);box-shadow:0 1px 3px #0006}.crop-handle--n,.crop-handle--s{cursor:ns-resize}.crop-handle--e,.crop-handle--w{cursor:ew-resize}.crop-handle--nw,.crop-handle--se{cursor:nwse-resize}.crop-handle--ne,.crop-handle--sw{cursor:nesw-resize}.crop-ruler-toggle{top:var(--s3);left:var(--s3);z-index:4;align-items:center;gap:var(--s1);border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);font-size:var(--t-sm);cursor:pointer;padding:6px 10px;display:inline-flex;position:absolute}.crop-ruler-toggle:hover{background:var(--surface-3)}.crop-ruler-toggle.is-active{background:var(--accent);color:var(--accent-ink);border-color:#0000}.crop-controls{gap:var(--s3);padding:var(--s3) var(--s4);background:var(--surface);border-top:1px solid var(--border);z-index:2;flex-direction:column;flex-shrink:0;display:flex;position:relative}.crop-row{align-items:center;gap:var(--s3);flex-wrap:wrap;display:flex}.crop-field{align-items:center;gap:var(--s2);display:inline-flex}.crop-field__label{align-items:center;gap:var(--s1);color:var(--text-dim);font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.04em;font-weight:700;display:inline-flex}.crop-select{appearance:none;border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);font-size:var(--t-sm);cursor:pointer;background-image:linear-gradient(45deg, transparent 50%, var(--text-dim) 50%), linear-gradient(135deg, var(--text-dim) 50%, transparent 50%);background-position:calc(100% - 14px) 52%,calc(100% - 9px) 52%;background-repeat:no-repeat;background-size:5px 5px,5px 5px;padding:6px 26px 6px 10px}.crop-ratio{align-items:center;gap:var(--s1);display:inline-flex}.crop-ratio__sep{color:var(--text-dim)}.crop-num{border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface-2);width:56px;color:var(--text);font-size:var(--t-sm);font-variant-numeric:tabular-nums;text-align:right;padding:6px 8px}.crop-num:focus-visible{outline:2px solid var(--accent);outline-offset:0;border-color:#0000}.crop-num--angle{width:64px}.crop-anglewrap{align-items:center;display:inline-flex;position:relative}.crop-deg{color:var(--text-dim);font-size:var(--t-sm);margin-left:4px}.crop-iconbtn{border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface-2);width:32px;height:32px;color:var(--text);cursor:pointer;place-items:center;display:inline-grid}.crop-iconbtn:hover{background:var(--surface-3)}.crop-iconbtn.is-active{background:var(--accent);color:var(--accent-ink);border-color:#0000}.crop-flip-x{transform:scaleX(-1)}.crop-spacer{flex:1}.crop-textbtn{border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);font-size:var(--t-sm);cursor:pointer;padding:7px 16px;font-weight:600}.crop-textbtn:hover{background:var(--surface-3)}.crop-textbtn--primary{background:var(--accent);color:var(--accent-ink);border-color:#0000}.crop-textbtn--primary:hover{background:var(--accent-hover)}.crop-panel{gap:var(--s4);padding:var(--s2) var(--s2) var(--s4);flex-direction:column;display:flex}.crop-section{gap:var(--s2);flex-direction:column;display:flex}.crop-section-label{font-size:var(--t-xs);color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:6px;font-weight:600;display:inline-flex}.crop-panel .crop-select{width:100%}.crop-panel .crop-ratio{align-items:center;gap:var(--s1);display:flex}.crop-panel .crop-ratio .crop-num{text-align:center;flex:1;min-width:0}.crop-panel .crop-ratio__spacer{flex:0 0 4px}.crop-panel .crop-anglewrap{align-self:flex-start}.crop-rotate-row{gap:var(--s2);display:flex}.crop-done{margin-top:var(--s2);justify-content:center}.wm-overlay{object-fit:cover;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.wm-toggle{align-items:center;gap:var(--s2);cursor:pointer;display:inline-flex}.wm-toggle:has(.ui-switch:disabled){cursor:default}.wm-preview{border:1px solid var(--border,#d1d5db);background:linear-gradient(135deg,#4b5563,#1f2937);border-radius:8px;width:240px;height:160px;position:relative;overflow:hidden}.edit-slider-num{text-align:right;background:var(--surface-2);width:48px;color:var(--text);border:1px solid var(--border-strong);border-radius:var(--r-sm);font-variant-numeric:tabular-nums;font-size:var(--t-sm);padding:1px 6px}.edit-slider-num:focus{outline:1px solid var(--accent);outline-offset:1px}.edit-slider-unit{color:var(--text-mute);font-size:var(--t-xs);min-width:16px}.savestat{font-size:var(--t-sm);align-items:center;gap:5px;display:inline-flex}.savestat--idle{color:var(--text-dim)}.savestat--dirty{color:var(--text-mute)}.savestat--saving,.savestat--ok{color:var(--text-dim)}.savestat-dot{background:var(--text-dim);border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.savestat-dot--dirty{background:#d6a13a}.adjust-panel{gap:var(--s4);padding:var(--s2) var(--s2) var(--s4);flex-direction:column;display:flex}.adjust-auto{gap:var(--s2);padding-bottom:var(--s3);border-bottom:1px solid var(--border);display:flex}.adjust-auto-btn{font-size:var(--t-xs);flex:1;justify-content:center;padding:6px 10px}.adjust-auto-btn.is-active{background:color-mix(in srgb, var(--accent) 18%, var(--surface-2));border-color:color-mix(in srgb, var(--accent) 55%, var(--border));color:var(--text)}.adjust-auto-btn.is-active:hover:not(:disabled){background:color-mix(in srgb, var(--accent) 26%, var(--surface-2));border-color:color-mix(in srgb, var(--accent) 70%, var(--border))}.adjust-group{gap:var(--s2);flex-direction:column;display:flex}.adjust-group-label{font-size:var(--t-xs);color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em;margin:0;font-weight:600}.adjust-module{gap:var(--s1);flex-direction:column;display:flex}.adjust-module-label{font-size:var(--t-xs);color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;opacity:.75;padding-left:2px;font-weight:500}.editor-shell{height:calc(100dvh - var(--topbar-h));padding:var(--s4) var(--s6);flex-direction:column;display:flex;overflow:hidden}.editor-head{padding:0 0 var(--s3);align-items:center;gap:8px;display:flex}.editor-history{gap:2px;display:flex}.editor-commit{padding-left:var(--s2);border-left:1px solid var(--border);align-items:center;gap:8px;display:flex}.editor-body{gap:var(--s4);flex:1;min-height:0;display:flex}.editor-stage{flex:1;place-items:center;min-height:0;display:grid;position:relative}.tool-rail{background:var(--glass);-webkit-backdrop-filter:blur(22px)saturate(1.6);border:1px solid var(--border-strong);border-radius:var(--r-lg);width:280px;box-shadow:var(--shadow-pop);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.tool-rail-tabs{background:var(--surface-2);border-radius:var(--r-md);gap:4px;margin:8px 8px 0;padding:2px;display:flex}.tool-rail-tab{border-radius:calc(var(--r-md) - 2px);cursor:pointer;color:var(--text);font-size:var(--t-sm);background:0 0;border:0;flex:1;padding:4px 10px}.tool-rail-tab.is-active{background:var(--accent);color:var(--accent-text)}.tool-rail-panel{flex:1;padding:8px 10px;overflow-y:auto}.ss-stage{border:1px solid var(--border);border-radius:var(--r-xl);min-height:64vh;transition:background var(--dur-slow) var(--ease);position:relative;overflow:hidden}.ss-stage[data-backdrop=dark],.ss-stage[data-backdrop=light]{background:var(--backdrop)}.ss-stage.fs{z-index:200;border:0;border-radius:0;min-height:100vh;position:fixed;inset:0}.ss-immersive{z-index:200;border:0;border-radius:0;min-height:0;position:fixed;inset:0}.ss-immersive.hide-chrome{cursor:none}.ss-topbar{z-index:2;align-items:center;gap:var(--s3);padding:var(--s4) var(--s5);opacity:1;transition:opacity var(--dur-slow) var(--ease);background:linear-gradient(#0000008c,#0000);display:flex;position:absolute;top:0;left:0;right:0}.ss-immersive.hide-chrome .ss-topbar{opacity:0}.ss-stage[data-backdrop=light] .ss-topbar{background:linear-gradient(#00000047,#0000)}.ss-meta{flex-direction:column;line-height:1.2;display:flex}.ss-title{color:#fff;font-weight:650;font-size:var(--t-lg);letter-spacing:-.01em}.ss-sub{color:#ffffffb3;font-size:var(--t-xs);font-variant-numeric:tabular-nums}.ss-icon{appearance:none;cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:38px;height:38px;transition:background var(--dur) var(--ease);background:#ffffff24;border:0;border-radius:50%;flex:none;place-items:center;font-size:18px;line-height:1;display:grid}.ss-icon:hover{background:#ffffff47}.ss-layer{opacity:0;grid-template:100%/100%;place-items:center;display:grid;position:absolute;inset:0;overflow:hidden}.ss-img{will-change:transform, opacity}.ss-stage[data-fit=contain] .ss-img,.ss-stage:not([data-fit]) .ss-img{object-fit:contain;max-width:88%;max-height:88%;box-shadow:0 24px 70px #00000080}.ss-stage[data-backdrop=light][data-fit=contain] .ss-img{box-shadow:0 24px 70px #0000002e}.ss-stage[data-fit=cover] .ss-img{object-fit:cover;object-position:center;width:100%;height:100%}@keyframes ss-kenburns{0%{transform:scale(1.03)translate(0)}to{transform:scale(1.09)translate(-2.6%)}}.ss-img.kb{animation:ss-kenburns var(--kb-dur,4.8s) linear forwards}.ss-stage.paused .ss-img.kb{animation-play-state:paused}.ss-chrome{align-items:center;gap:var(--s2);padding:var(--s4) var(--s5) var(--s5);opacity:1;transition:opacity var(--dur-slow) var(--ease);background:linear-gradient(#0000,#00000080);flex-direction:column;display:flex;position:absolute;bottom:0;left:0;right:0}.ss-stage[data-backdrop=light] .ss-chrome{background:linear-gradient(#0000,#00000038)}.ss-stage.hide-chrome .ss-chrome{opacity:0}.ss-transport{align-items:center;gap:var(--s3);display:flex}.ss-transport button{appearance:none;cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:40px;height:40px;transition:all var(--dur) var(--ease);background:#ffffff24;border:0;border-radius:50%;place-items:center;font-size:14px;display:grid}.ss-transport button:hover{background:#ffffff42}.ss-transport .ss-exit{border-radius:var(--r-pill);width:auto;font-weight:600;font-size:var(--t-sm);padding:0 14px}.ss-progress{background:#ffffff38;border-radius:999px;width:min(560px,80%);height:3px;overflow:hidden}.ss-progress span{background:var(--ss-ink);border-radius:999px;width:0;height:100%;display:block}.ss-count{color:#fffc;font-size:var(--t-xs);font-variant-numeric:tabular-nums}.ss-branded{justify-content:center;align-items:center;gap:var(--s3);text-align:center;width:100%;height:100%;padding:var(--s8);flex-direction:column;display:flex}.ss-branded-title{letter-spacing:-.02em;font-size:clamp(28px,5vw,64px);font-weight:700;line-height:1.05}.ss-branded-sub{opacity:.72;font-size:clamp(15px,2vw,24px);font-weight:450}.ss-stage[data-backdrop=dark] .ss-branded,.ss-stage[data-backdrop=light] .ss-branded{color:var(--ss-ink)}.ss-stage .empty{z-index:1;position:relative}.ss-list{gap:var(--s4);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));display:grid}.ss-card{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);flex-direction:column;display:flex;overflow:hidden}.ss-card:hover{box-shadow:var(--shadow-2);border-color:var(--border-strong);transform:translateY(-3px)}.ss-cover{aspect-ratio:16/10;background:var(--surface-2);place-items:center;display:grid;position:relative;overflow:hidden}.ss-cover canvas,.ss-cover img,.ss-cover .preview-state{object-fit:cover;width:100%;height:100%;display:block}.ss-cover-empty{color:var(--text-mute);font-size:var(--t-sm)}.ss-cover-count{border-radius:var(--r-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;font-size:var(--t-xs);font-variant-numeric:tabular-nums;background:#0000008c;padding:2px 9px;position:absolute;bottom:8px;right:8px}.ss-cover-play{color:#fff;opacity:0;transition:opacity var(--dur) var(--ease);background:#00000047;place-items:center;padding-left:4px;font-size:30px;display:grid;position:absolute;inset:0}.ss-card:hover .ss-cover-play{opacity:1}.ss-card-body{padding:var(--s3) var(--s4) var(--s4);gap:var(--s3);flex-direction:column;display:flex}.ss-card-name{font-weight:650;font-size:var(--t-md);letter-spacing:-.01em}.ss-card-actions{gap:var(--s2);display:flex}.ss-card-actions .btn{flex:1;justify-content:center;padding:8px 12px}.ss-del:hover:not(:disabled){color:var(--danger);border-color:color-mix(in srgb, var(--danger) 45%, var(--border))}.ss-new{justify-content:center;align-items:center;gap:var(--s2);min-height:180px;color:var(--text-dim);background:0 0;border-style:dashed}.ss-new:hover{border-color:var(--accent);color:var(--text);background:var(--accent-soft)}.ss-new-plus{opacity:.8;font-size:28px}.ss-edit-head{align-items:center;gap:var(--s3);margin-bottom:var(--s3);display:flex}.ss-edit-head .rate-happy{color:var(--rate-happy)}.ss-edit-head .rate-neutral{color:var(--rate-neutral)}.ss-edit-head .rate-sad{color:var(--rate-sad)}.ss-name-field{flex:auto;min-width:0}.ss-name-field .formfield{border:0;padding:0;display:block}.ss-name-field .formfield-label{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.ss-name-field .ui-input{width:100%;font-size:var(--t-md);font-weight:650}.ss-config{align-items:center;gap:var(--s4);padding:var(--s3) var(--s4);margin-bottom:var(--s4);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);flex-wrap:wrap;display:flex}.ss-config-item{align-items:center;gap:var(--s2);display:flex}.ss-config-item>span{color:var(--text-dim);font-size:var(--t-sm);font-weight:600}.ss-config-item .ui-select-trigger{min-width:0}.ss-credit{color:#fff9;font-size:var(--t-xs);text-align:center;max-width:min(560px,80%)}.ss-slides{align-items:stretch;gap:var(--s3);min-height:124px;padding:var(--s2);border-radius:var(--r-lg);transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease);border:1px dashed #0000;flex-wrap:wrap;display:flex}.ss-slides.dropping{border-color:var(--border-strong);background:color-mix(in srgb, var(--accent) 6%, transparent)}.ss-slides-empty{width:100%;min-height:100px;color:var(--text-mute);font-size:var(--t-sm);place-items:center;display:grid}.ss-slide{aspect-ratio:4/3;border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border);cursor:grab;flex:none;width:156px;position:relative;overflow:hidden}.ss-slide:active{cursor:grabbing}.ss-slide.dragging{opacity:.35}.ss-drop-ind{background:var(--accent);width:3px;box-shadow:0 0 10px var(--accent);pointer-events:none;border-radius:2px;flex:none;align-self:stretch}.ss-slide canvas,.ss-slide img,.ss-slide .preview-state{object-fit:cover;width:100%;height:100%;display:block}.ss-slide-num{border-radius:var(--r-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;min-width:20px;height:20px;font-size:var(--t-xs);font-variant-numeric:tabular-nums;background:#0000008c;place-items:center;padding:0 5px;display:grid;position:absolute;top:6px;left:6px}.ss-slide-x{cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;opacity:0;width:22px;height:22px;transition:opacity var(--dur) var(--ease);background:#0000008c;border:0;border-radius:50%;place-items:center;display:grid;position:absolute;top:6px;right:6px}.ss-slide:hover .ss-slide-x{opacity:1}.ss-slide-x:hover{background:var(--danger)}.ss-pick-grid{gap:var(--s2);grid-template-columns:repeat(auto-fill,minmax(110px,1fr));display:grid}.ss-pick{aspect-ratio:4/3;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);cursor:grab;transition:border-color var(--dur) var(--ease), opacity var(--dur) var(--ease);padding:0;position:relative;overflow:hidden}.ss-pick:active{cursor:grabbing}.ss-pick canvas,.ss-pick img,.ss-pick .preview-state{object-fit:cover;width:100%;height:100%;display:block}.ss-pick:hover{border-color:var(--border-strong)}.ss-pick.in{border-color:var(--accent)}.ss-pick.in canvas,.ss-pick.in img{opacity:.55}.ss-pick-check{background:var(--accent);width:22px;height:22px;color:var(--accent-ink);border-radius:50%;place-items:center;font-size:12px;font-weight:700;display:grid;position:absolute;top:6px;right:6px}.ss-bookends{gap:var(--s4);margin-bottom:var(--s4);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.ss-bookend{gap:var(--s2);padding:var(--s4);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);flex-direction:column;display:flex}.ss-bookend-add{color:var(--text-dim);border-style:dashed;flex-direction:row;justify-content:space-between;align-items:center}.ss-bookend-label{font-weight:650}.ss-bookend-head{align-items:center;gap:var(--s2);display:flex}.ss-bookend-head .ui-select-trigger{min-width:140px}.ss-bookend-head .ab-btn{padding:5px 10px}.ss-bookend .formfield{border:0;padding:0;display:block}.ss-bookend .formfield-label{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.ss-bookend .ui-input{width:100%}.wall-layout{gap:var(--s4);height:calc(100dvh - var(--topbar-h));padding:var(--s4) var(--s6);grid-template-columns:200px 1fr;display:grid;overflow:hidden}.wall-tray-col{gap:var(--s2);flex-direction:column;min-height:0;display:flex}.wall-tray-filter{gap:var(--s1);flex-wrap:wrap;flex:none;display:flex}.wall-filter-btn{font-size:var(--t-xs);cursor:pointer;border:1px solid var(--border);border-radius:var(--r-pill);background:var(--surface-2);color:var(--text-dim);align-items:center;gap:4px;padding:3px 7px;display:inline-flex}.wall-filter-btn:hover{border-color:var(--border-strong);color:var(--text)}.wall-filter-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--text)}.wall-filter-count{opacity:.7;font-variant-numeric:tabular-nums}.wall-tray{gap:var(--s2);flex-direction:column;min-height:0;display:flex;overflow-y:auto}.wall-tray-empty{padding:var(--s3) 0;text-align:center}.wall-tray-item{border:1px solid var(--border);border-radius:var(--r-sm);cursor:grab;background:var(--surface-2);text-align:left;flex-direction:column;flex:none;padding:0;display:flex;overflow:hidden}.wall-tray-thumb{aspect-ratio:3/2;width:100%}.wall-tray-thumb canvas,.wall-tray-thumb img,.wall-tray-thumb .preview-state{object-fit:cover;width:100%;height:100%;display:block}.wall-tray-name{font-size:var(--t-xs);color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;padding:4px 6px;overflow:hidden}.wall-stage-wrap{flex-direction:column;min-width:0;display:flex}.wall-bar{align-items:center;gap:var(--s2);margin-bottom:var(--s3);display:flex}.wall-stage{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-2);touch-action:none;flex:1;min-height:0;position:relative;overflow:hidden}.wall-backdrop{width:100%;height:100%;display:block;position:absolute;inset:0}.wall-backdrop-skeleton{background:var(--surface-3);background-image:linear-gradient(100deg,#0000 30%,#ffffff14 50%,#0000 70%);background-size:200% 100%;animation:1.2s ease-in-out infinite preview-shimmer;position:absolute;inset:0}.wall-item{cursor:grab;position:absolute}.wall-item.dragging{cursor:grabbing}.wall-item canvas,.wall-item img,.wall-item .preview-state{object-fit:cover;width:100%;height:100%;display:block;box-shadow:0 6px 16px #00000073,0 1px 3px #0006}.wall-item .preview-state{box-sizing:border-box}.wall-item.selected{outline:2px solid var(--accent);outline-offset:2px}.wall-item .wm-overlay{box-shadow:none}.wall-handle{background:var(--accent);border:2px solid #fff;border-radius:50%;width:14px;height:14px;position:absolute;transform:translate(-50%,-50%)}.wall-handle.nw{cursor:nwse-resize;top:0;left:0}.wall-handle.ne{cursor:nesw-resize;top:0;left:100%}.wall-handle.sw{cursor:nesw-resize;top:100%;left:0}.wall-handle.se{cursor:nwse-resize;top:100%;left:100%}.wall-badge{background:var(--glass);color:var(--text);font-size:var(--t-xs);border-radius:var(--r-pill);white-space:nowrap;border:1px solid var(--border-strong);padding:2px 8px;position:absolute;top:-26px;left:50%;transform:translate(-50%)}.wall-marquee{pointer-events:none;border:1px solid var(--accent);background:var(--accent-soft);border-radius:2px;position:absolute}.wall-guides{pointer-events:none;position:absolute;inset:0}.wall-guides .guide{stroke:var(--accent);stroke-width:1px}.wall-guides .spacing{stroke:var(--heart);stroke-width:1px}.ss-cover-empty .icon,.ss-cover-empty svg{opacity:.5}.wall-picker-backdrop{z-index:150;padding:var(--s5);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000073;place-items:center;display:grid;position:fixed;inset:0}.wall-picker{gap:var(--s4);width:min(720px,100%);max-height:80vh;padding:var(--s5);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-2);flex-direction:column;display:flex;overflow:auto}.wall-picker-head{align-items:center;gap:var(--s3);display:flex}.wall-picker-grid{gap:var(--s4);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.wall-picker-item{text-align:left;gap:var(--s2);cursor:pointer;background:0 0;border:0;flex-direction:column;padding:0;display:flex}.wall-picker-item .ss-cover{border:1px solid var(--border);border-radius:var(--r-lg);transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease)}.wall-picker-item:hover .ss-cover{border-color:var(--accent);transform:translateY(-2px)}.wall-picker-name{font-size:var(--t-sm);color:var(--text-dim);font-weight:600}.wall-layout--fullscreen{z-index:50;background:var(--bg);grid-template-columns:1fr;position:fixed;inset:0}.wall-layout--fullscreen .wall-tray-col,.wall-layout--fullscreen .wall-bar>:not(.wall-fullscreen-btn){display:none}.wall-layout--fullscreen .wall-bar{justify-content:flex-end}.calib-backdrop{z-index:60;background:#00000080;place-items:center;display:grid;position:fixed;inset:0}.calib{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);padding:var(--s4);gap:var(--s3);flex-direction:column;width:min(680px,92vw);display:flex}.calib-head{flex-direction:column;gap:4px;display:flex}.calib-surface{border-radius:var(--r-md);cursor:crosshair;touch-action:none;background-position:50%;background-size:cover;width:100%;position:relative}.calib-line{width:100%;height:100%;position:absolute;inset:0}.calib-line line{stroke:var(--accent);stroke-width:3px}.calib-controls{align-items:center;gap:var(--s2);display:flex}.calib-controls label{font-size:var(--t-xs);color:var(--text-dim);flex-direction:column;display:inline-flex}.room-thumb{aspect-ratio:4/3;background:var(--surface-3);width:100%;position:relative;overflow:hidden}.wall-room-label{padding:0 var(--s2);white-space:nowrap}.calib-name{font-size:var(--t-xs);color:var(--text-dim);flex-direction:column;gap:4px;display:flex}.calib-name input{font-size:var(--t-sm)}.settings-topbar{align-items:center;gap:var(--s3);height:var(--topbar-h);padding:0 var(--s5);border-bottom:1px solid var(--border);background:var(--bg);z-index:20;display:flex;position:sticky;top:0}.settings-view{flex-direction:column;height:100dvh;display:flex}.settings-shell{flex:1;min-height:0;display:flex}.settings-nav{gap:var(--s2);width:220px;padding:var(--s4);border-right:1px solid var(--border);flex-direction:column;display:flex;overflow-y:auto}.settings-nav-group{text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);margin-top:var(--s3);font-size:12px}.settings-nav-btn{text-align:left;padding:var(--s2) var(--s3);border-radius:var(--r-md);color:inherit;cursor:pointer;background:0 0;border:0}.settings-nav-btn[aria-current=true]{background:var(--surface-2);font-weight:600}.settings-panel{min-width:0;padding:var(--s5);flex:1;overflow-y:auto}.settings-body{gap:var(--s4);flex-direction:column;max-width:520px;display:flex}.settings-field{gap:var(--s2);flex-direction:column;display:flex}.settings-note{color:var(--text-dim);font-size:13px}.perm-matrix{gap:var(--s4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.perm-group{border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s3);margin:0}.perm-group-legend{margin:0 0 var(--s2);text-transform:uppercase;letter-spacing:.04em;font-weight:700}.perm-item{padding:4px 0}.perm-item .formfield-label{flex:1}.perm-item[data-disabled=true]{opacity:.5}.perm-actions{align-items:center;gap:var(--s3);flex-wrap:wrap;display:flex}.member-list{gap:var(--s3);flex-direction:column;display:flex}.member-row{border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s3) var(--s4)}.member-row-main{align-items:center;gap:var(--s3);display:flex}.member-row-id{flex-direction:column;display:flex}.member-name{font-weight:600}.member-row-error{margin-top:var(--s2)}.member-status{font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.04em;border-radius:var(--r-pill);border:1px solid var(--border);padding:2px 9px;font-weight:700}.member-status--active{color:var(--accent)}.member-status--invited{color:var(--text-dim)}.member-status--disabled{color:var(--danger)}.member-role{color:var(--text-dim);font-size:var(--t-sm);text-transform:capitalize}.member-perms{gap:var(--s2);margin-top:var(--s2);flex-wrap:wrap;display:flex}.member-perm-tag{font-size:var(--t-xs);color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);padding:2px 9px}.member-perm-tag--all{color:var(--accent)}.perm-edit{margin-top:var(--s4);padding-top:var(--s4);border-top:1px solid var(--border);gap:var(--s4);flex-direction:column;display:flex}.savestat{align-items:center;gap:var(--s2);font-size:var(--t-sm);color:var(--text-mute);display:inline-flex}.savestat--saving,.savestat--ok{color:var(--text-dim)}.savestat--err{color:var(--danger)}.savestat-dot{background:var(--text-mute);border-radius:50%;width:6px;height:6px}.savestat-dot--ok{background:var(--rate-happy)}.savestat-retry{margin-left:var(--s2);color:var(--accent);cursor:pointer;background:0 0;border:0;font-weight:600}.formsection{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-lg);padding:var(--s5);margin-bottom:var(--s4);max-width:680px}.formsection-title{font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-mute);margin:0}.formsection-desc{font-size:var(--t-sm);color:var(--text-dim);margin:var(--s1) 0 0}.formsection-body{margin-top:var(--s4)}.formfield{gap:var(--s2) var(--s5);padding:var(--s4) 0;border-top:1px solid var(--border);grid-template-columns:220px 1fr;align-items:center;display:grid}.formsection-body>.formfield:first-child{border-top:0;padding-top:0}.formfield-label label{font-size:var(--t-sm);color:var(--text)}.formfield-help{font-size:var(--t-xs);color:var(--text-mute);margin-top:2px;display:block}.formfield-error{color:var(--danger);font-size:var(--t-xs);margin:var(--s1) 0 0}.ui-input{width:280px;max-width:100%;height:var(--control-h);padding:0 var(--control-pad-x);background:var(--control-bg);border:1px solid var(--control-border);border-radius:var(--control-radius);color:var(--text);font-size:var(--t-sm)}.ui-input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.ui-input--readonly{color:var(--text-dim);background:var(--surface-2);cursor:default}@media (width<=640px){.formfield{grid-template-columns:1fr}}.ui-seg{background:var(--control-bg);border:1px solid var(--control-border);border-radius:var(--control-radius);gap:var(--s1);padding:4px;display:inline-flex}.ui-seg-item{padding:var(--s2) var(--s3h);border-radius:var(--r-sm);font-size:var(--t-sm);color:var(--text-dim);cursor:pointer;transition:background var(--dur) var(--ease), color var(--dur) var(--ease);background:0 0;border:0;font-weight:500}.ui-seg-item:hover{color:var(--text)}.ui-seg-item[data-state=checked]{background:var(--surface-3);color:var(--text);box-shadow:var(--shadow-1)}.ui-switch{appearance:none;border-radius:var(--r-pill);background:var(--surface-3);cursor:pointer;border:0;width:40px;height:23px;padding:0;position:relative;overflow:hidden}.ui-switch[data-state=checked]{background:var(--accent)}.ui-switch-thumb{width:19px;height:19px;transition:transform var(--dur) var(--ease);background:#fff;border-radius:50%;display:block;position:absolute;top:2px;transform:translate(2px)}.ui-switch[data-state=checked] .ui-switch-thumb{transform:translate(19px)}.ui-select-trigger{align-items:center;gap:var(--s2);height:var(--control-h);padding:0 var(--control-pad-x);background:var(--control-bg);border:1px solid var(--control-border);border-radius:var(--control-radius);min-width:160px;color:var(--text);font-size:var(--t-sm);cursor:pointer;display:inline-flex}.ui-select-icon{color:var(--text-mute);margin-left:auto}.ui-select-content{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:var(--s1);z-index:80}.ui-select-item{padding:var(--s2) var(--s3);border-radius:var(--r-sm);font-size:var(--t-sm);color:var(--text);cursor:pointer;outline:none}.ui-select-item[data-highlighted]{background:var(--accent-soft)}.ui-sechead{align-items:baseline;gap:var(--s3);margin-bottom:var(--s4);display:flex}.ui-sechead-title{font-size:var(--t-xl);letter-spacing:-.02em;margin:0;font-weight:700}.ui-sechead-meta{font-size:var(--t-sm);color:var(--text-mute)}.ui-sechead-spacer{flex:1}.ui-empty{align-items:center;gap:var(--s2);text-align:center;padding:var(--s10) var(--s5);flex-direction:column;display:flex}.ui-empty-icon{width:var(--icon-lg);height:var(--icon-lg);color:var(--text-mute);justify-content:center;align-items:center;display:flex}.ui-empty-title{margin:0;font-weight:600}.ui-empty-desc{color:var(--text-dim);font-size:var(--t-sm);max-width:420px;margin:0}.ui-empty-action{margin-top:var(--s3)}.seg-checks{gap:var(--s1);background:var(--control-bg);border:1px solid var(--control-border);border-radius:var(--control-radius);padding:4px;display:inline-flex}.settings-sub{font-size:var(--t-xs);color:var(--text-mute);margin-top:2px;font-weight:400}.rating-filter{gap:var(--s1);background:var(--control-bg);border:1px solid var(--control-border);border-radius:var(--control-radius);padding:4px;display:inline-flex}.rating-chip{padding:var(--s2) var(--s3h);border-radius:var(--r-sm);cursor:pointer;color:var(--text-dim);font-size:var(--t-sm);font-variant-numeric:tabular-nums;transition:opacity var(--dur) var(--ease), background var(--dur) var(--ease);background:0 0;border:0;align-items:center;gap:6px;display:inline-flex}.rating-chip-face{display:inline-flex}.rating-chip[data-state=on]{background:var(--surface-3);box-shadow:var(--shadow-1);color:var(--text)}.rating-chip[data-state=off]{opacity:.45}.rating-chip[data-state=off]:hover{opacity:.8}.empty-rating-tally{gap:var(--s5);margin:var(--s1) 0 var(--s3);font-size:var(--t-md);font-variant-numeric:tabular-nums;display:flex}.empty-rating-tally-item{align-items:center;gap:6px;display:inline-flex}.dlg-scrim{z-index:60;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;position:fixed;inset:0}.dlg{z-index:61;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-xl);width:380px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-pop);padding:var(--s5);position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.dlg-title{font-size:var(--t-xl);letter-spacing:-.02em;margin:0;font-weight:700}.dlg-msg{color:var(--text-dim);font-size:var(--t-base);margin:var(--s3) 0 0;line-height:1.5}.dlg-actions{justify-content:flex-end;gap:var(--s2);margin-top:var(--s5);display:flex}.projects{min-height:100vh}.projects-head{align-items:center;gap:var(--s4);height:58px;padding:0 var(--s5);background:color-mix(in srgb, var(--surface) 84%, transparent);-webkit-backdrop-filter:blur(18px)saturate(1.4);border-bottom:1px solid var(--border);z-index:30;display:flex;position:sticky;top:0}.projects-title{font-size:var(--t-2xl);letter-spacing:-.03em;max-width:1320px;margin:var(--s6) auto var(--s5);padding:0 var(--s6);font-weight:700}.projects-grid{gap:var(--s4);max-width:1320px;padding:0 var(--s6) var(--s8);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin:0 auto;display:grid}.projects .dropzone{max-width:1320px;margin:0 auto}.shoot-card{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);cursor:pointer;transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);flex-direction:column;display:flex;position:relative;overflow:hidden}.shoot-card:hover{box-shadow:var(--shadow-2);transform:translateY(-3px)}.shoot-thumb{aspect-ratio:4/3;object-fit:cover;background:var(--surface-2);width:100%;display:block}.shoot-thumb--empty{color:var(--text-mute);opacity:.5;place-items:center;font-size:30px;display:grid}.shoot-meta{padding:var(--s3) var(--s4)}.shoot-name{font-weight:650;font-size:var(--t-md);letter-spacing:-.01em}.shoot-sub{color:var(--text-mute);font-size:var(--t-sm);margin-top:2px}.shoot-del{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;cursor:pointer;opacity:0;width:28px;height:28px;transition:opacity var(--dur) var(--ease);background:#00000073;border:0;border-radius:50%;place-items:center;display:grid;position:absolute;top:8px;right:8px}.shoot-card:hover .shoot-del{opacity:.85}.shoot-del:hover{opacity:1;background:var(--danger)}.modal-scrim{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:40;background:#00000080;position:fixed;inset:0}.modal{z-index:41;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-xl);width:380px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-pop);padding:var(--s5);position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.modal-title{font-size:var(--t-xl);letter-spacing:-.02em;margin-bottom:var(--s4);font-weight:700}.modal-field{margin-bottom:var(--s3);display:block}.modal-field span{font-size:var(--t-sm);color:var(--text-dim);margin-bottom:4px;display:block}.modal-field em{color:var(--text-mute);font-style:normal}.modal-actions{justify-content:flex-end;gap:var(--s2);margin-top:var(--s5);display:flex}
