*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f2f3f5;--surface: #ffffff;--nav: #1a1a2e;--nav-text: #ffffff;--accent: #e94560;--text: #1a1a2e;--text-sub: #6b7280;--border: #e5e7eb;--radius: 16px;--shadow: 0 2px 12px rgba(0,0,0,.08);--safe-top: env(safe-area-inset-top, 0px);--safe-bot: 0px;--tab-bar-h: 56px}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior:none}.app-shell{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.header{display:flex;align-items:center;gap:10px;padding:calc(var(--safe-top) + 12px) 20px 12px;background:var(--nav);color:var(--nav-text);flex-shrink:0;position:sticky;top:0;z-index:10}.header-logo{font-size:24px;line-height:1}.header-title{font-size:20px;font-weight:700;letter-spacing:-.3px;flex:1}.header-settings{margin-left:auto;font-size:20px;background:none;border:none;cursor:pointer}.main{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 16px calc(var(--safe-bot) + var(--tab-bar-h) + 72px)}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}@media (min-width: 500px){.grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 750px){.grid{grid-template-columns:repeat(5,1fr)}}@media (min-width: 1000px){.grid{grid-template-columns:repeat(6,1fr)}}.card{background:var(--surface);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;aspect-ratio:3 / 4;animation:card-in .25s ease}@keyframes card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card-image-wrap{position:relative;flex:1;min-height:0;cursor:pointer;background-color:#fff;display:flex;align-items:center;justify-content:center}.card-image-wrap:active{opacity:.85}.card-image{width:100%;height:100%;object-fit:contain;display:block}.card-wishlist-badge{position:absolute;top:6px;left:6px;background:#f59e0b;color:#fff;font-size:11px;line-height:1;padding:3px 5px;border-radius:6px;pointer-events:none;box-shadow:0 1px 3px #0003}.card-color-dot{position:absolute;bottom:5px;right:5px;width:10px;height:10px;border-radius:50%;border:1.5px solid rgba(255,255,255,.8);box-shadow:0 1px 3px #0003}.card-body{padding:6px 8px 8px;display:flex;flex-direction:column;gap:4px}.card-type{display:flex;align-items:center;gap:4px}.card-type-label{font-size:10px;font-weight:700;text-transform:capitalize;color:var(--accent);letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-actions{display:flex;align-items:center;gap:3px;margin-top:2px}.zoom-backdrop{position:fixed;inset:0;background:#000000d1;z-index:200;display:flex;align-items:center;justify-content:center;animation:fade-in .18s ease}.zoom-content{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;max-width:min(92vw,500px);max-height:calc(96dvh - var(--safe-top) - var(--safe-bot))}.zoom-image{max-width:100%;max-height:78vh;width:auto;height:auto;object-fit:contain;border-radius:12px;display:block}.zoom-info{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.zoom-type{color:#fff;font-size:15px;font-weight:700;text-transform:capitalize}.zoom-desc{color:#ffffffa6;font-size:13px}.zoom-close{position:fixed;top:calc(var(--safe-top) + 12px);right:16px;width:36px;height:36px;border-radius:50%;background:#fff3;color:#fff;border:none;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:10px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;padding:8px 16px;transition:opacity .15s,transform .1s;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.96);opacity:.85}.btn--primary{background:var(--accent);color:#fff}.btn--ghost{background:transparent;color:var(--text-sub);border:1.5px solid var(--border)}.btn--danger{background:#fee2e2;color:#dc2626;font-size:12px;padding:6px 10px}.btn--danger-ghost{background:transparent;color:#dc2626}.btn--icon{background:var(--bg);padding:6px 10px;font-size:15px;border-radius:8px}.btn--full{width:100%}.fab{position:fixed;bottom:calc(var(--safe-bot) + var(--tab-bar-h) + 16px);right:24px;width:58px;height:58px;border-radius:50%;background:var(--accent);color:#fff;font-size:32px;line-height:1;border:none;cursor:pointer;box-shadow:0 4px 20px #e9456073;display:flex;align-items:center;justify-content:center;z-index:20;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.fab:active{transform:scale(.92);box-shadow:0 2px 10px #e945604d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:60vh;text-align:center;padding:24px}.empty-icon{font-size:64px}.empty-title{font-size:20px;font-weight:700}.empty-sub{color:var(--text-sub);font-size:15px;max-width:260px}.sheet-backdrop{position:fixed;inset:0;background:#0006;z-index:50;display:flex;align-items:flex-end;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.sheet{background:var(--surface);border-radius:20px 20px 0 0;padding:12px 20px calc(var(--safe-bot) + 20px);width:100%;animation:slide-up .25s ease;display:flex;flex-direction:column;gap:8px}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 12px}.sheet-title{font-size:18px;font-weight:700;margin-bottom:4px}.sheet-option{display:flex;align-items:center;gap:14px;background:var(--bg);border:none;border-radius:14px;padding:16px 18px;font-size:16px;font-family:inherit;font-weight:500;cursor:pointer;width:100%;text-align:left;-webkit-tap-highlight-color:transparent;transition:background .15s}.sheet-option:active{background:var(--border)}.sheet-option-icon{font-size:22px}.sheet-cancel{margin-top:4px}.sheet-row{display:flex;gap:10px;margin-top:12px}.sheet-option--hint{opacity:.5;cursor:not-allowed}.sheet-option--hint small{font-size:11px;margin-left:4px;opacity:.8}.sheet-error{font-size:13px;color:#e05252;margin:4px 0 0;padding:0 4px}.clipboard-fallback{margin-top:12px;display:flex;flex-direction:column;gap:8px}.clipboard-fallback-hint{font-size:13px;color:var(--text-sub);text-align:center;padding:0 4px}.clipboard-fallback-target{min-height:72px;border-radius:12px;border:2px dashed var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);display:flex;align-items:center;justify-content:center;cursor:text;outline:none;caret-color:transparent}.clipboard-fallback-target:focus{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}.field-label{display:block;font-size:14px;font-weight:600;margin-bottom:6px}.field-input{width:100%;border:1.5px solid var(--border);border-radius:12px;padding:12px 14px;font-size:16px;font-family:inherit;background:var(--bg);color:var(--text);outline:none;transition:border-color .15s}.field-input:focus{border-color:var(--accent)}.field-input--error{border-color:#dc2626}.field-error{font-size:12px;color:#dc2626;display:block;margin-top:4px}.setup-screen{min-height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#1a1a2e,#16213e 60%,#0f3460);padding:24px}.setup-card{background:#fffffff7;border-radius:24px;padding:36px 28px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;text-align:center}.setup-logo{font-size:56px;margin-bottom:8px}.setup-title{font-size:28px;font-weight:800;letter-spacing:-.5px}.setup-subtitle{color:var(--text-sub);margin-bottom:28px;margin-top:6px}.setup-form{display:flex;flex-direction:column;gap:10px;text-align:left}.setup-hint{font-size:12px;color:var(--text-sub);line-height:1.5;text-align:center}.setup-link{color:var(--accent);text-decoration:none;font-weight:600}.setup-link:hover{text-decoration:underline}.settings-current{font-size:12px;color:var(--text-sub);margin-bottom:8px}.settings-current code{font-family:monospace;font-size:11px;background:var(--bg);padding:2px 6px;border-radius:4px}.settings-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.settings-status{font-size:12px;color:var(--text-sub);margin-top:8px;text-align:center}.settings-microcopy{font-size:11px;color:var(--text-sub);text-align:center;line-height:1.45;margin-top:4px}.vs-backdrop{position:fixed;inset:0;background:#0000009e;z-index:60;display:flex;align-items:center;justify-content:center;padding:calc(var(--safe-top) + 20px) 16px calc(var(--safe-bot) + 20px);animation:fade-in .2s ease}.vs-modal{background:var(--surface);border-radius:24px;width:100%;max-width:400px;height:min(calc(96dvh - var(--safe-top) - var(--safe-bot)),780px);display:flex;flex-direction:column;overflow:hidden;animation:vs-in .22s ease}@keyframes vs-in{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.vs-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;flex-shrink:0;border-bottom:1px solid var(--border)}.vs-title{font-size:18px;font-weight:700}.vs-close{color:var(--text-sub);font-size:14px}.vs-portrait{flex:1;min-height:0;position:relative;background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.vs-zoom-inner{width:100%;height:100%;transform-origin:0 0;will-change:transform;display:flex;align-items:center;justify-content:center}.vs-portrait-img{width:100%;height:100%;object-fit:contain;display:block;user-select:none;-webkit-user-drag:none}.vs-zoom-controls{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:6px;z-index:2}.vs-zoom-btn{width:36px;height:36px;border-radius:50%;border:none;background:#00000073;color:#fff;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:background .15s,opacity .15s;touch-action:manipulation}.vs-zoom-btn:disabled{opacity:.3;cursor:default}.vs-zoom-btn:not(:disabled):active{background:#000000b3}.vs-zoom-btn--reset{font-size:11px;font-weight:700;background:#0009;border-radius:12px;height:28px;width:36px}.vs-mannequin{width:auto;height:100%;max-height:100%;max-width:60%;display:block;opacity:.55}.vs-processing-overlay{position:absolute;inset:0;background:#ffffffd1;backdrop-filter:blur(3px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.vs-processing-label{font-size:14px;font-weight:600;color:var(--text)}.vs-error{margin:0;padding:8px 16px;flex-shrink:0}.vs-actions{display:flex;flex-direction:column;gap:8px;padding:14px 16px calc(var(--safe-bot) + 14px);border-top:1px solid var(--border);flex-shrink:0}.fitme-prompt{width:100%;resize:none;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:13px;font-family:inherit;color:var(--text);background:var(--bg);line-height:1.5;outline:none}.fitme-prompt:focus{border-color:var(--accent)}.fitme-prompt:disabled{opacity:.5}.fitme-prompt::placeholder{color:var(--text-sub)}.vs-microcopy{font-size:11px;color:var(--text-sub);text-align:center;line-height:1.45;margin-top:2px}.overlay{position:fixed;inset:0;background:#1a1a2ee0;backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center}.overlay-card{background:var(--surface);border-radius:20px;padding:36px 28px;text-align:center;width:min(340px,90vw);display:flex;flex-direction:column;align-items:center;gap:14px}.spinner{width:44px;height:44px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.overlay-step{font-size:16px;font-weight:600}.overlay-steps{display:flex;gap:8px}.overlay-step-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .3s}.overlay-step-dot--active{background:var(--accent)}.overlay-step-dot--done{background:#22c55e}.overlay-note{font-size:11px;color:var(--text-sub);max-width:240px;line-height:1.4}.debug-dialog{background:var(--surface);border-radius:20px 20px 0 0;padding:16px 16px calc(var(--safe-bot) + 20px);width:100%;max-height:calc(96dvh - var(--safe-top));overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:12px;animation:slide-up .25s ease}.debug-title{font-size:17px;font-weight:700}.debug-image-wrap{border-radius:12px;overflow:hidden;background:#000;flex-shrink:0}.debug-image{width:100%;display:block}.debug-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media (min-width: 480px){.debug-tiles{grid-template-columns:repeat(3,1fr)}}.debug-tile{background:var(--bg);border:2.5px solid transparent;border-radius:14px;padding:0;cursor:pointer;text-align:left;font-family:inherit;overflow:hidden;display:flex;flex-direction:column;transition:border-color .15s,transform .1s;-webkit-tap-highlight-color:transparent}.debug-tile--on{border-color:var(--tile-color, var(--accent))}.debug-tile:active{transform:scale(.96)}.debug-tile-img-wrap{position:relative;background:#e5e7eb}.debug-tile-img{width:100%;height:auto;display:block}.debug-tile-badge{position:absolute;top:6px;left:6px;width:22px;height:22px;border-radius:50%;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px #0000004d}.debug-tile-check{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:#0000008c;color:#fff;font-size:13px;display:flex;align-items:center;justify-content:center}.debug-tile-label{padding:8px 10px;display:flex;flex-direction:column;gap:2px}.debug-tile-type{font-size:12px;font-weight:700;text-transform:capitalize}.debug-tile-color{font-size:11px;color:var(--text-sub)}.debug-actions{display:flex;flex-direction:column;gap:8px}.gd-backdrop{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;animation:fade-in .2s ease}.gd-sheet{background:var(--surface);border-radius:24px 24px 0 0;padding:12px 0 calc(var(--safe-bot) + 24px);width:100%;max-height:calc(96dvh - var(--safe-top));overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:0;animation:slide-up .28s ease}.gd-handle{padding:12px 20px;margin:-12px 0 0;cursor:grab;touch-action:none;display:flex;justify-content:center}.gd-handle:before{content:"";display:block;width:40px;height:4px;background:var(--border);border-radius:2px}.gd-handle:active{cursor:grabbing}.gd-carousel{overflow:hidden;width:100%;height:60vw;max-height:360px;border-bottom:1px solid var(--border);user-select:none;touch-action:pan-y;flex-shrink:0}.gd-carousel-track{display:flex;height:100%;transition:transform .25s ease;will-change:transform}.gd-carousel-slide{min-width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff}.gd-carousel-img{display:block;width:100%;height:100%;object-fit:contain;pointer-events:none}.gd-dots{display:flex;justify-content:center;align-items:center;gap:20px;padding:12px 20px 4px}.gd-dot-btn{display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px 6px;-webkit-tap-highlight-color:transparent}.gd-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s,transform .2s}.gd-dot--active{background:var(--accent);transform:scale(1.3)}.gd-dot-label{font-size:11px;font-weight:600;color:var(--text-sub);transition:color .2s}.gd-dot-btn--active .gd-dot-label{color:var(--accent)}.gd-details{display:flex;flex-direction:column;padding:4px 20px 0}.gd-detail-row{display:flex;align-items:baseline;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}.gd-detail-row:last-child{border-bottom:none}.gd-detail-row--desc{align-items:flex-start}.gd-detail-row--wishlist{align-items:center}.gd-wishlist-label{display:flex;align-items:center;gap:12px;width:100%;cursor:pointer}.gd-wishlist-checkbox{display:none}.gd-wishlist-toggle{position:relative;width:42px;height:24px;border-radius:12px;background:var(--border);transition:background .2s;flex-shrink:0;margin-left:auto}.gd-wishlist-toggle:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.gd-wishlist-checkbox:checked+.gd-wishlist-toggle{background:#f59e0b}.gd-wishlist-checkbox:checked+.gd-wishlist-toggle:after{transform:translate(18px)}.gd-detail-label{font-size:12px;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.4px;min-width:88px;flex-shrink:0}.gd-detail-value{font-size:14px;font-weight:500;color:var(--text);display:flex;align-items:center;gap:7px;text-transform:capitalize}.gd-detail-type{font-weight:600}.gd-detail-desc{text-transform:none;line-height:1.5;color:var(--text-sub);font-weight:400}.gd-detail-tag{display:inline-block;padding:1px 8px;border-radius:10px;background:var(--bg-card, #f0f0f0);font-size:12px;font-weight:600;text-transform:capitalize}.gd-layer-label{font-size:12px;color:var(--text-sub);margin-left:4px}.gd-color-swatch{display:inline-block;width:14px;height:14px;border-radius:50%;border:1.5px solid rgba(0,0,0,.12);flex-shrink:0}.gd-actions{display:flex;flex-direction:column;gap:10px;padding:16px 20px 0}.gd-action-btn{width:100%}.gd-delete-confirm{display:flex;gap:10px}.gd-delete-confirm .btn{flex:1}.refine-dialog{background:var(--surface);border-radius:20px 20px 0 0;padding:16px 16px calc(var(--safe-bot) + 20px);width:100%;height:92vh;overflow:hidden;display:flex;flex-direction:column;gap:14px;animation:slide-up .25s ease}.refine-header{display:flex;align-items:center;gap:10px;flex-shrink:0}.refine-counter{font-size:12px;font-weight:700;color:var(--text-sub);background:var(--bg);padding:3px 10px;border-radius:20px;flex-shrink:0}.refine-type{font-size:16px;font-weight:700;flex:1;text-transform:capitalize;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.refine-close{background:none;border:none;font-size:16px;color:var(--text-sub);cursor:pointer;padding:4px 8px;border-radius:8px;flex-shrink:0;-webkit-tap-highlight-color:transparent}.refine-subtitle{font-size:13px;line-height:1.45;text-align:center;flex-shrink:0;transition:color .3s}.refine-subtitle--loading{color:var(--text-sub)}.refine-subtitle--done{color:#16a34a;font-weight:600}.refine-subtitle--error{color:#dc2626}.refine-compare{flex:1;min-height:0;display:flex;flex-direction:column}.refine-panel{flex:1;min-height:0;display:flex;flex-direction:column;gap:6px}.refine-panel-img-wrap{flex:1;min-height:0;width:100%;border-radius:12px;overflow:hidden;background:var(--bg);position:relative}.refine-panel-img{width:100%;height:100%;object-fit:contain;display:block}.refine-panel-placeholder{width:100%;height:100%}.refine-processing-overlay{border-radius:12px;font-size:13px}.refine-panel-label{font-size:11px;font-weight:700;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px}.refine-arrow-col{flex-shrink:0;display:flex;justify-content:center;padding:6px 0;color:var(--border);transition:color .3s}.refine-arrow-col--active{color:var(--accent)}.refine-arrow-svg{width:16px;height:40px;overflow:visible}@keyframes refine-arrow-flow{0%,to{opacity:.5;transform:translateY(0)}50%{opacity:1;transform:translateY(4px)}}.refine-arrow-col--active .refine-arrow-svg{animation:refine-arrow-flow 1.3s ease-in-out infinite}.refine-actions{display:flex;gap:10px;flex-shrink:0}.refine-actions .btn{flex:1}.looks-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.look-card{background:var(--surface);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;animation:card-in .25s ease}.look-preview-wrap{aspect-ratio:2 / 3;overflow:hidden;background:#fafafa;display:block;width:100%;border:none;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent}.look-preview-wrap:active{opacity:.85}.look-preview{width:100%;height:100%;object-fit:contain;display:block}.look-footer{padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:6px}.look-date{font-size:11px;font-weight:600;color:var(--text-sub)}.look-delete-btn{font-size:13px;padding:4px 6px;line-height:1}.look-confirm{display:flex;gap:4px}.toast{position:fixed;bottom:calc(var(--safe-bot) + var(--tab-bar-h) + 16px);left:16px;right:16px;background:#1a1a2e;color:#fff;border-radius:14px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px;z-index:200;animation:slide-up .2s ease;cursor:pointer;box-shadow:0 4px 20px #0000004d}.toast-close{background:none;border:none;color:#aaa;font-size:16px;cursor:pointer}.app-root{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.screen-wrap{flex:1;min-height:0;flex-direction:column;overflow:hidden}.tab-bar{display:flex;height:calc(var(--tab-bar-h) + var(--safe-bot));padding-bottom:var(--safe-bot);background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;z-index:50}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;color:var(--text-sub);-webkit-tap-highlight-color:transparent;transition:color .15s}.tab-btn--active{color:var(--accent)}.tab-icon{font-size:20px;line-height:1;display:block}.tab-label{font-size:10px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.studio-shell{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden;background:var(--bg)}.studio-header{display:flex;align-items:center;justify-content:space-between;padding:calc(var(--safe-top) + 12px) 20px 12px;background:var(--nav);color:var(--nav-text);flex-shrink:0}.studio-title{font-size:20px;font-weight:700;letter-spacing:-.3px}.studio-actions{display:flex;gap:8px;align-items:center}.studio-btn-ghost{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:20px;padding:5px 14px;font-size:13px;font-weight:500;cursor:pointer}.studio-btn-primary{background:var(--accent);border:none;color:#fff;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600;cursor:pointer}.studio-canvas{flex:1;position:relative;min-height:0;overflow:hidden;background:#fafafa;background-image:radial-gradient(circle,#d1d5db 1px,transparent 1px);background-size:24px 24px}.studio-hint{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-sub);font-size:14px;pointer-events:none;user-select:none}.studio-hint-icon{font-size:28px;opacity:.35}.ci{position:absolute;transform:translate(-50%,-50%);cursor:grab;-webkit-tap-highlight-color:transparent;touch-action:none}.ci:active{cursor:grabbing}.ci--selected{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.ci-img{height:100%;width:auto;display:block;filter:drop-shadow(0 6px 18px rgba(0,0,0,.18)) drop-shadow(0 1px 4px rgba(0,0,0,.1));pointer-events:none;user-select:none;-webkit-user-drag:none}.ci-remove{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;border:1.5px solid #fff;font-size:10px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;touch-action:none;box-shadow:0 1px 4px #00000040;-webkit-tap-highlight-color:transparent}.ci-resize-handle{position:absolute;bottom:2px;right:2px;width:18px;height:18px;border-radius:4px;background:#fff;border:2px solid var(--accent);cursor:nwse-resize;touch-action:none;z-index:10;box-shadow:0 1px 4px #0003;background-image:linear-gradient(135deg,transparent 40%,var(--accent) 40%,var(--accent) 55%,transparent 55%),linear-gradient(135deg,transparent 60%,var(--accent) 60%,var(--accent) 75%,transparent 75%)}.studio-toast{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:var(--nav);color:#fff;border-radius:20px;padding:8px 20px;font-size:13px;font-weight:600;z-index:100;pointer-events:none;animation:slide-up .2s ease}.studio-filters{display:flex;gap:6px;padding:8px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0;background:var(--surface);border-top:1px solid var(--border);scrollbar-width:none}.studio-filters::-webkit-scrollbar{display:none}.studio-chip{flex-shrink:0;background:var(--bg);border:1.5px solid var(--border);color:var(--text-sub);border-radius:20px;padding:4px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s;-webkit-tap-highlight-color:transparent}.studio-chip--active{background:var(--nav);color:#fff;border-color:var(--nav)}.filter-divider{width:1px;height:20px;background:var(--border);flex-shrink:0;align-self:center;margin:0 2px}.tag-group{margin-bottom:14px}.tag-group-label{font-size:11px;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px;margin:0 0 7px}.tag-group-pills{display:flex;flex-wrap:wrap;gap:6px}.look-tags{display:flex;flex-wrap:wrap;gap:4px;padding:4px 8px 0}.look-tag{font-size:10px;font-weight:600;color:var(--text-sub);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:2px 7px}.studio-browser{display:flex;gap:8px;padding:10px 12px calc(10px + var(--safe-bot));overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0;background:var(--surface);min-height:120px;align-items:flex-start;scrollbar-width:none}.studio-browser::-webkit-scrollbar{display:none}.studio-browser-empty{width:100%;text-align:center;font-size:13px;color:var(--text-sub);padding:16px 0;align-self:center}.bi{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:2px solid var(--border);border-radius:12px;padding:6px;width:76px;cursor:pointer;transition:border-color .12s,background .12s;-webkit-tap-highlight-color:transparent}.bi--placed{border-color:var(--accent);background:#e945600d}.bi-img-wrap{position:relative;width:56px;height:70px;display:flex;align-items:center;justify-content:center}.bi-img{max-width:100%;max-height:100%;object-fit:contain;display:block}.bi-check{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--accent);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}.bi-wishlist-badge{position:absolute;top:-4px;left:-4px;background:#f59e0b;color:#fff;font-size:9px;line-height:1;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.bi-label{font-size:10px;font-weight:500;color:var(--text-sub);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;text-transform:capitalize}.fitme-elapsed{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.5px;margin-top:2px}.fitme-preview{position:absolute;bottom:14px;right:10px;height:37%;border-radius:0;background:transparent;border:none;box-shadow:none;cursor:pointer;padding:0;overflow:visible;z-index:50;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.fitme-preview-img{height:100%;width:auto;display:block;pointer-events:none;user-select:none}.processing-pill{position:fixed;left:16px;bottom:calc(var(--safe-bot) + var(--tab-bar-h) + 12px);z-index:40;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;color:var(--text);box-shadow:0 2px 8px #0000002e;cursor:pointer;-webkit-tap-highlight-color:transparent}.job-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:12px}.job-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px}.job-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.job-id{font-size:13px;font-family:inherit;color:var(--text-primary, #222);font-weight:500;flex:1;display:flex;align-items:center;gap:6px}.job-id-color{display:inline-block;width:10px;height:10px;border-radius:50%;border:1.5px solid rgba(0,0,0,.12);flex-shrink:0}.job-status{font-size:12px;font-weight:600;padding:2px 8px;border-radius:999px}.job-status--scanning{background:#f0e6ff;color:#7c3aed}.job-status--processing{background:#fff3cd;color:#856404}.job-status--completed{background:#d1fae5;color:#065f46}.job-status--failed{background:#fee2e2;color:#991b1b}.job-remove{background:none;border:none;cursor:pointer;color:var(--text-secondary, #888);font-size:14px;padding:0 2px;line-height:1}.job-progress-wrap{position:relative;height:6px;background:var(--border);border-radius:999px;overflow:hidden;margin-bottom:6px}.job-progress-bar{height:100%;background:var(--accent, #7c3aed);border-radius:999px;transition:width .4s ease}.job-progress-bar--indeterminate{width:40%;animation:progress-slide 1.4s ease-in-out infinite}@keyframes progress-slide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.job-progress-label{font-size:11px;color:var(--text-secondary, #888)}.job-date{font-size:11px;color:var(--text-secondary, #888);margin:4px 0 0}.sheet--tall{min-height:60vh;max-height:85vh;overflow-y:auto}
