:root{--bg-base: #0f172a;--bg-deep: #1e293b;--bg-surface: #1e293b;--bg-glass: rgba(255, 255, 255, .06);--bg-glass-hover: rgba(255, 255, 255, .1);--bg-elevated: #334155;--bg-hover: rgba(255, 255, 255, .09);--bg-overlay: rgba(0, 0, 0, .75);--bg-scrim: rgba(15, 23, 42, .92);--fg: #ededef;--fg-secondary: #c4c6ca;--fg-muted: #8a8f98;--fg-dim: #555962;--accent: #22c55e;--accent-hover: #16a34a;--accent-light: rgba(34, 197, 94, .12);--accent-glow: rgba(34, 197, 94, .25);--cta: #22c55e;--cta-hover: #16a34a;--cta-active: #15803d;--cta-disabled: #166534;--cta-disabled-fg: #4ade80;--cta-subtle: rgba(34, 197, 94, .12);--cta-ring: rgba(34, 197, 94, .4);--color-success: #10b981;--color-success-bg: rgba(16, 185, 129, .1);--color-success-border: rgba(16, 185, 129, .25);--color-success-fg: #6ee7b7;--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .1);--color-warning-border: rgba(245, 158, 11, .25);--color-warning-fg: #fcd34d;--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .1);--color-error-border: rgba(239, 68, 68, .25);--color-error-fg: #fca5a5;--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .1);--color-info-border: rgba(59, 130, 246, .25);--color-info-fg: #93c5fd;--border: rgba(255, 255, 255, .1);--border-hover: rgba(255, 255, 255, .18);--border-strong: rgba(255, 255, 255, .25);--border-focus: var(--accent);--font-heading: "Space Grotesk", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--leading-tight: 1.2;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--font-regular: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--z-base: 0;--z-raised: 10;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--z-tooltip: 600;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 8px 24px rgba(0, 0, 0, .4);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .5);--shadow-xl: 0 32px 80px rgba(0, 0, 0, .6);--shadow-glow: 0 0 0 3px var(--accent-glow);--dur-micro: .15s;--dur-std: .25s;--dur-complex: .4s;--dur-page: .5s;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--transition-fast: var(--dur-micro) var(--ease-out);--transition-base: var(--dur-std) var(--ease-default);--transition-spring: var(--dur-std) var(--ease-spring);--focus-ring: 0 0 0 2px var(--bg-base), 0 0 0 4px var(--accent);--min-tap-target: 44px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{background:#0b1121;color:var(--fg);font-family:var(--font-body);font-size:14px;line-height:1.5;display:flex;align-items:center;justify-content:center;padding:32px}.modal-shell{aspect-ratio:16 / 9;height:min(85vh,100%);max-width:100%;background:var(--bg-surface);border:2px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl),0 0 0 1px #ffffff0d,0 0 80px #22c55e14;overflow:hidden;display:flex;flex-direction:column;position:relative}.modal-close{position:absolute;top:12px;right:12px;z-index:var(--z-overlay);width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border);color:var(--fg-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-glass-hover);color:var(--fg)}.app{flex:1;display:grid;grid-template-columns:160px 1fr 360px;min-height:0;overflow:hidden}.rail{background:var(--bg-deep);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:stretch;padding:12px 8px;gap:2px;min-height:0;overflow:hidden}.rail-brand{font-family:var(--font-heading);font-size:13px;font-weight:700;color:var(--fg);display:flex;align-items:center;gap:8px;padding:0 10px;margin-bottom:12px;letter-spacing:-.01em}.rail-brand .rail-logo{width:24px;height:24px;flex-shrink:0}.rail-btn{width:100%;height:36px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--fg-muted);cursor:pointer;display:flex;align-items:center;gap:10px;padding:0 10px;font-size:18px;transition:all var(--transition-fast);position:relative}.rail-btn .rail-label{font-size:13px;font-weight:500;white-space:nowrap}.rail-btn:hover{background:var(--bg-glass);color:var(--fg)}.rail-btn.active{background:var(--accent-light);color:var(--accent-hover)}.rail-btn.active:before{content:"";position:absolute;left:-8px;top:6px;bottom:6px;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.rail-divider{height:1px;background:var(--border);margin:6px 8px}.rail-bottom{margin-top:auto}.stage{background:var(--bg-base);position:relative;overflow:hidden;display:flex;flex-direction:column}.stage-header{height:44px;padding:0 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.stage-title{font-family:var(--font-heading);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-secondary)}.stage-actions{display:flex;gap:6px}.stage-body{flex:1;overflow:hidden;min-height:0;display:flex;flex-direction:column}.mode{display:none;height:100%}.mode.active{display:flex;flex-direction:column}.mode-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--fg-dim)}.mode-placeholder i{font-size:48px;opacity:.3}.mode-placeholder span{font-size:13px;text-transform:uppercase;letter-spacing:.08em}.right-panel{background:var(--bg-deep);border-left:1px solid var(--border);display:flex;flex-direction:column;min-height:0;overflow:hidden}.rp-tabs{display:flex;padding:0 12px;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto}.rp-tab{height:40px;padding:0 14px;background:none;border:none;border-bottom:2px solid transparent;color:var(--fg-muted);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:color var(--transition-fast)}.rp-tab:hover{color:var(--fg)}.rp-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.rp-tab[hidden]{display:none}.rp-body{flex:1;overflow-y:auto;min-height:0}.rp-panel{display:none;padding:16px}.rp-panel.active{display:block}.rp-wf{display:flex;gap:6px}.rp-wf-col{flex:1;display:flex;flex-direction:column;gap:6px}.rp-wf-item{border-radius:6px;overflow:hidden;cursor:pointer;position:relative}.rp-wf-item img{width:100%;display:block;border-radius:6px}.rp-wf-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;gap:8px;opacity:0;transition:opacity var(--transition-fast);border-radius:6px}.rp-wf-item:hover .rp-wf-overlay{opacity:1}.rp-wf-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-elevated);color:var(--fg);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.rp-wf-btn:hover{background:var(--accent);color:#fff}.rp-wf-sentinel{height:40px;display:flex;align-items:center;justify-content:center}.create-body{padding:16px;display:flex;flex-direction:column;gap:12px;height:100%}.dialog-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;display:grid;grid-template-columns:120px 1fr 120px;gap:12px;align-items:stretch}.dialog-slot{aspect-ratio:1;background:var(--bg-elevated);border:1px dashed var(--border-hover);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--fg-muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;position:relative;overflow:hidden}.dialog-slot i{font-size:24px}.dialog-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:inherit}.dialog-slot img.hidden{display:none}.dialog-center{display:flex;flex-direction:column;gap:8px}.dialog-input-row{flex:1;display:flex;gap:8px;align-items:stretch}.upload-btn{width:40px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all var(--transition-fast)}.upload-btn:hover{border-color:var(--accent);color:var(--accent-hover)}.prompt-input{flex:1;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;color:var(--fg);font-family:var(--font-body);font-size:14px;resize:none;outline:none;transition:border-color var(--transition-fast)}.prompt-input:focus{border-color:var(--accent)}.prompt-input::placeholder{color:var(--fg-dim)}.generate-btn{width:48px;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:22px;transition:background var(--transition-fast)}.generate-btn:hover{background:var(--accent-hover)}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.dialog-controls{display:flex;gap:8px;align-items:center}.pill-btn{height:28px;padding:0 10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;color:var(--fg-secondary);font-size:12px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all var(--transition-fast)}.pill-btn:hover{border-color:var(--border-hover);color:var(--fg)}.pill-btn.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent-hover)}.pill-badge{font-size:9px;font-weight:700;padding:1px 5px;background:var(--accent);color:#fff;border-radius:4px;letter-spacing:.05em}.cards-area{flex:1;min-height:0;display:flex;gap:10px;overflow:hidden}.cards-col{position:relative;overflow:visible}.cards-col-side{width:270px;flex-shrink:0}.cards-col-center{flex:1;min-width:0}.loading-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.aspect-dropdown{position:absolute;bottom:calc(100% + 4px);left:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px;z-index:var(--z-dropdown, 100);min-width:120px}.aspect-dropdown.hidden{display:none}.aspect-item{padding:6px 10px;font-size:12px;color:var(--fg-secondary);cursor:pointer;border-radius:var(--radius-xs, 4px)}.aspect-item:hover{background:var(--bg-glass-hover);color:var(--fg)}.aspect-item.active{color:var(--accent)}.model-dropdown{position:absolute;bottom:calc(100% + 4px);left:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px;z-index:var(--z-dropdown, 100);min-width:160px}.model-dropdown.hidden{display:none}.model-item{padding:6px 10px;font-size:12px;color:var(--fg-secondary);cursor:pointer;border-radius:var(--radius-xs, 4px)}.model-item:hover{background:var(--bg-glass-hover);color:var(--fg)}.model-item.active{color:var(--accent)}.lightbox{position:fixed;inset:0;z-index:var(--z-modal, 200);display:flex;align-items:center;justify-content:center;background:#000000d9}.lightbox.hidden{display:none}.lightbox img{max-width:90%;max-height:90%;border-radius:var(--radius-md)}.lightbox-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--bg-glass);border:1px solid var(--border);color:var(--fg);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px}.rp-body::-webkit-scrollbar{width:6px}.rp-body::-webkit-scrollbar-track{background:transparent}.rp-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.rp-body::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.stage-action-btn{width:32px;height:32px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition-fast)}.stage-action-btn:hover{border-color:var(--accent);color:var(--accent-hover);background:var(--accent-light)}.ws-credits-bar{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--fg-secondary);margin-right:8px}.ws-credits-free{color:var(--fg-muted)}.ws-credits-divider{color:var(--border);font-size:10px}.ws-credits-balance{font-weight:600;color:var(--accent)}.ws-credits-streak{font-size:11px;color:var(--color-warning, #f59e0b)}.ws-daily-claim-btn{height:24px;padding:0 8px;background:var(--accent);border:none;border-radius:12px;color:#fff;font-size:11px;font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.ws-daily-claim-btn:hover{background:var(--accent-hover)}.ws-daily-claim-btn:disabled{opacity:.5;cursor:not-allowed}.ws-upload-queue{position:fixed;bottom:16px;right:16px;width:320px;z-index:var(--z-toast, 300);display:flex;flex-direction:column;gap:6px}.ws-upload-queue.hidden{display:none}.queue-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.queue-preview{width:36px;height:36px;border-radius:6px;object-fit:cover}.queue-info{flex:1;min-width:0}.queue-name{font-size:12px;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-progress-row{display:flex;align-items:center;gap:8px;margin-top:4px}.queue-progress{flex:1;height:3px;background:var(--border);border-radius:2px;overflow:hidden}.queue-progress-bar{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.queue-status{font-size:11px;font-weight:600;white-space:nowrap}.queue-status.uploading{color:var(--accent)}.queue-status.success{color:var(--color-success, #10b981)}.queue-status.error{color:var(--color-error, #ef4444)}.me-container{padding:24px;display:flex;flex-direction:column;gap:24px;overflow-y:auto;height:100%}.me-profile{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.me-profile--guest{flex-direction:column;text-align:center;gap:12px}.me-profile__avatar img{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.me-profile__name{font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--fg)}.me-profile__email{font-size:12px;color:var(--fg-muted);margin-top:2px}.me-profile__credits{font-size:13px;color:var(--accent);font-weight:600;margin-top:4px}.me-profile__sub{font-size:12px;color:var(--fg-dim);max-width:280px}.me-login-btn{height:36px;padding:0 20px;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.me-login-btn:hover{background:var(--accent-hover)}.me-section{display:flex;flex-direction:column;gap:12px}.me-section__title{font-family:var(--font-heading);font-size:13px;font-weight:600;color:var(--fg-secondary);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:8px}.me-section__count{font-size:11px;font-weight:500;color:var(--fg-dim);background:var(--bg-elevated);padding:1px 6px;border-radius:10px}.me-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 16px;color:var(--fg-dim);font-size:13px;text-align:center}.me-fav-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.me-fav-item{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-elevated);border:1px solid var(--border)}.me-fav-item img{width:100%;height:100%;object-fit:cover}.me-fav-placeholder{width:100%;height:100%;background:var(--bg-surface)}.me-history-list{display:flex;flex-direction:column;gap:8px}.me-history-item{display:flex;gap:12px;align-items:center;padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.me-history-thumb{width:44px;height:44px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--bg-elevated)}.me-history-thumb img{width:100%;height:100%;object-fit:cover}.me-history-placeholder{width:100%;height:100%;background:var(--bg-surface)}.me-history-info{flex:1;min-width:0}.me-history-prompt{font-size:12px;color:var(--fg-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.me-loading{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 16px;color:var(--fg-dim);font-size:13px}.ws-gallery__grid{flex:1;overflow-y:auto;padding:12px;align-content:start}.ws-gallery__header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border)}.ws-gallery__tabs{display:flex;gap:4px}.ws-gallery__tab{background:none;border:none;color:var(--fg-muted);font-size:12px;font-family:var(--font-body);padding:4px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.ws-gallery__tab:hover{color:var(--fg);background:var(--bg-surface)}.ws-gallery__tab.active{color:var(--fg);background:var(--bg-elevated);font-weight:500}.ws-gallery__count{font-size:11px;color:var(--fg-dim)}.ws-gallery__waterfall{display:flex;gap:12px;align-items:flex-start}.ws-gallery__column{flex:1;display:flex;flex-direction:column;gap:12px}.ws-gallery__item{border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .15s ease;position:relative;background:var(--bg-surface);width:100%}.ws-gallery__item:hover{border-color:var(--cta);transform:translateY(-2px)}.ws-gallery__item--reference{border-color:var(--cta)}.ws-gallery__item img{width:100%;height:auto;display:block}.ws-gallery__item-actions{position:absolute;inset:0;opacity:0;transition:opacity .15s ease;z-index:2;pointer-events:none}.ws-gallery__item:hover .ws-gallery__item-actions{opacity:1;pointer-events:auto}.ws-gallery__action-group{position:absolute;right:12px;display:flex;gap:8px}.ws-gallery__action-group--top{top:61.8%;transform:translateY(-50%);flex-direction:column}.ws-gallery__action-group--bottom{bottom:12px}.ws-gallery__action-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(8px);border:none;border-radius:8px;color:#fff;cursor:pointer;transition:all .15s ease;pointer-events:auto;position:relative}.ws-gallery__action-btn:hover{transform:scale(1.1)}.ws-gallery__action-btn svg{width:20px;height:20px;color:#fff}.ws-gallery__action-btn--inspiration:hover{background:#22c55e}.ws-gallery__action-btn--design:hover{background:#ec4899}.ws-gallery__action-btn--studio:hover{background:#8b5cf6}.ws-gallery__action-btn--favorite:hover{background:#f59e0b}.ws-gallery__action-btn--like:hover,.ws-gallery__action-btn--like.active{background:#ef4444}.ws-gallery__action-btn--like.active svg{fill:currentColor}.ws-gallery__action-btn--share:hover{background:#3b82f6}.ws-gallery__btn-label{position:absolute;bottom:-28px;left:50%;transform:translate(-50%);background:#000000d9;color:#fff;font-size:11px;padding:4px 8px;border-radius:4px;white-space:nowrap;opacity:0;transition:opacity .15s ease;pointer-events:none}.ws-gallery__action-btn:hover .ws-gallery__btn-label{opacity:1}.ws-gallery__action-btn--favorite.active{background:#f59e0b;color:#fff;opacity:1}.ws-gallery__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:64px 32px;gap:16px;color:var(--fg-muted);font-size:14px}.ws-gallery__empty .empty-icon{width:64px;height:64px;border-radius:20px;background:#ffffff0f;display:flex;align-items:center;justify-content:center;font-size:28px;border:1px solid rgba(255,255,255,.07)}.ws-gallery__empty .empty-title{font-family:var(--font-heading);font-size:15px;font-weight:600;color:var(--fg);margin:0}.ws-gallery__empty .empty-desc{font-size:13px;color:var(--fg-muted);margin:0;max-width:240px;line-height:1.5}.ws-gallery__empty .empty-cta{margin-top:4px;padding:8px 18px;background:var(--cta);border:none;border-radius:var(--radius-sm);color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background var(--dur-micro) ease}.ws-gallery__empty .empty-cta:hover{background:var(--cta-hover)}.ws-gallery__load-more{display:flex;justify-content:center;padding:24px;width:100%}.ws-gallery__spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--cta);border-radius:50%;animation:ws-gallery-spin .8s linear infinite}.ws-gallery__skeleton{pointer-events:none}.ws-gallery__skeleton-image{width:100%;background:linear-gradient(90deg,#ffffff0f 25%,#ffffff17,#ffffff0f 75%);background-size:800px 100%;animation:ws-gallery-shimmer 1.6s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes ws-gallery-spin{to{transform:rotate(360deg)}}@keyframes ws-gallery-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@media (max-width: 600px){.ws-gallery__waterfall{flex-direction:column}.ws-gallery__column{width:100%}.ws-gallery__action-btn{min-width:44px;min-height:44px}.ws-gallery__grid{padding:8px}}.loading-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--cta);border-radius:50%;animation:ws-spin .6s linear infinite}@keyframes ws-spin{to{transform:rotate(360deg)}}.card-toggle-top{position:absolute;top:10px;right:10px;z-index:2;display:inline-flex;align-items:center;width:36px;height:20px;cursor:pointer}.card-toggle-top input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;transition:all .15s ease}.toggle-slider:before{content:"";position:absolute;height:12px;width:12px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all .15s ease}.card-toggle-top input:checked+.toggle-slider{background:var(--cta);border-color:var(--cta)}.card-toggle-top input:checked+.toggle-slider:before{transform:translate(16px)}.intent-cards-section{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;padding:8px 0}.intent-cards-header{display:flex;align-items:center;justify-content:space-between;padding:0 12px 8px;flex-shrink:0}.intent-cards-label{font-size:10px;font-weight:700;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.08em}.intent-cards-coverflow{flex:1;position:relative;overflow:hidden;perspective:800px;perspective-origin:center center;display:flex;align-items:center;justify-content:center;min-height:0}.intent-cards-track{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.intent-card{position:absolute;left:12px;right:12px;height:56px;display:flex;align-items:center;gap:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;cursor:pointer;overflow:hidden;transform-origin:center center;transition:transform .4s cubic-bezier(.25,.46,.45,.94),opacity .4s cubic-bezier(.25,.46,.45,.94),border-color .3s ease,box-shadow .3s ease;will-change:transform,opacity;user-select:none}.intent-card:hover{border-color:var(--border-active)}.intent-card--selected{border-color:var(--cta);box-shadow:0 0 0 1px var(--cta)}.intent-card-icon{width:36px;height:36px;border-radius:8px;background:var(--bg-muted);display:flex;align-items:center;justify-content:center;margin:0 10px 0 12px;flex-shrink:0;font-size:15px;color:var(--fg-muted);transition:background .25s,color .25s}.intent-card--selected .intent-card-icon{background:color-mix(in srgb,var(--cta) 15%,var(--bg-elevated));color:var(--cta)}.intent-card-main{flex:1;display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0;padding-right:10px}.intent-card-text{display:flex;flex-direction:column;gap:2px;min-width:0}.intent-card-title{font-size:14px;font-weight:600;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.intent-card-desc{font-size:11px;color:var(--fg-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-height:0;opacity:0;transition:max-height .3s ease,opacity .3s ease}.intent-card--selected .intent-card-desc{max-height:18px;opacity:1}.intent-card-badge{flex-shrink:0;font-size:10px;font-weight:700;padding:2px 6px;border-radius:var(--radius-full, 999px);letter-spacing:.04em;text-transform:uppercase}.intent-card-badge--basic{background:var(--bg-elevated);color:var(--fg-dim)}.intent-card-badge--kontext{background:color-mix(in srgb,var(--cta) 15%,transparent);color:var(--cta)}.intent-card-badge--tool{background:#06b6d41f;color:#06b6d4}.intent-cards-nav{display:flex;justify-content:center;gap:8px;padding:6px 0;flex-shrink:0}.intent-nav-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--fg-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.intent-nav-btn:hover{background:var(--bg-hover);color:var(--fg)}.intent-tool-controls{display:flex;align-items:center;gap:8px;padding-top:4px;border-top:1px solid var(--border-light, var(--border))}.intent-tool-label{font-size:11px;color:var(--fg-dim)}.intent-tool-scale-group{display:flex;gap:4px}.intent-scale-btn{padding:2px 8px;font-size:11px;font-weight:600;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xs, 4px);color:var(--fg-muted);cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.intent-scale-btn:hover,.intent-scale-btn.active{background:var(--cta-light, color-mix(in srgb, var(--cta) 12%, transparent));border-color:var(--cta);color:var(--cta)}.intent-confirm-btn{padding:4px 12px;font-size:11px;font-weight:600;background:var(--cta-light, color-mix(in srgb, var(--cta) 12%, transparent));border:1px solid var(--cta);border-radius:var(--radius-xs, 4px);color:var(--cta);cursor:pointer;transition:background .12s ease}.intent-confirm-btn:hover{background:var(--cta);color:#fff}.intent-model-hint{font-size:11px;color:#a259ff;background:#a259ff14;border:1px solid rgba(162,89,255,.2);border-radius:var(--radius-xs, 4px);padding:3px 8px}.intent-second-img{padding-top:6px;border-top:1px solid var(--border-light, var(--border))}.intent-second-img-upload{display:flex;align-items:center;gap:6px;padding:6px 10px;border:1px dashed var(--border-hover, var(--border));border-radius:var(--radius-xs, 4px);color:var(--fg-muted);font-size:11px;cursor:pointer;transition:border-color .14s ease,color .14s ease}.intent-second-img-upload:hover{border-color:var(--cta);color:var(--cta)}.intent-second-img-preview{position:relative;display:inline-flex}.intent-second-img-preview img{width:48px;height:48px;object-fit:cover;border-radius:var(--radius-xs, 4px);border:1px solid var(--border)}.intent-second-img-clear{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border);color:var(--fg-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s ease,color .12s ease}.intent-second-img-clear:hover{background:var(--error-bg, rgba(239,68,68,.1));color:var(--error, #ef4444)}.intent-second-img-uploading{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;font-size:11px;color:var(--fg-muted);border:1px dashed var(--border);border-radius:6px}.intent-tool-note{font-size:12px;color:var(--fg-muted);text-align:center;padding:8px 12px;margin:0}.inspiration-workspace{display:flex;flex-direction:column;flex:1;height:100%;padding:12px 16px 14px}.inspiration-carousel{position:relative;width:100%;height:320px;display:flex;align-items:center;justify-content:center;perspective:1200px;overflow:visible}.inspiration-card{position:absolute;width:240px;height:290px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);transition:transform .42s cubic-bezier(.34,1.28,.64,1),opacity .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;will-change:transform,opacity;cursor:pointer;overflow:hidden;display:flex;flex-direction:column;transform-style:preserve-3d;backface-visibility:hidden;transform:translate(0) rotateY(0) scale(1)}.inspiration-card.active{cursor:default;box-shadow:0 4px 24px #00000059,0 24px 64px #00000073,0 0 0 1.5px var(--cta)}.inspiration-card:not(.active):hover{opacity:.85!important}.card-main{flex:1;display:flex;flex-direction:column;padding:12px 12px 10px;min-height:0}.card-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.card-category{font-size:10px;font-weight:700;color:var(--cta);text-transform:uppercase;letter-spacing:.06em}.card-thumb{width:32px;height:32px;object-fit:cover;border-radius:var(--radius-sm, 6px);border:1px solid var(--border)}.card-content-box{flex:1;display:flex;flex-direction:column;gap:6px}.card-content-title{font-size:14px;font-weight:600;color:var(--fg);line-height:1.25}.card-content-desc{font-size:12px;color:var(--fg-secondary, var(--fg-muted));line-height:1.55;overflow-y:auto;flex:1}.card-content-desc--solo{font-size:14px;font-weight:600;color:var(--fg);line-height:1.4}.card-footer{display:flex;align-items:center;padding:8px 12px;border-top:1px solid var(--border);flex-shrink:0}.card-usage{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--fg-muted)}.iw-card-nav{display:flex;align-items:center;justify-content:center;padding-top:12px;flex-shrink:0}.carousel-dots{display:flex;gap:5px;align-items:center}.carousel-dot{width:7px;height:7px;border-radius:50%;background:var(--border);cursor:pointer;transition:width .18s ease,background .18s ease,border-radius .18s ease;flex-shrink:0}.carousel-dot.active{background:var(--cta);width:22px;border-radius:3.5px}.carousel-dot:hover{background:var(--cta);opacity:.7}.pane-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--fg-muted);font-size:13px;text-align:center;gap:0;padding:24px}.iw-custom-card-textarea{width:100%;background:var(--bg-muted);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:12px;color:var(--fg);font-family:inherit;resize:none;outline:none;line-height:1.5;margin-top:4px}.iw-custom-card-textarea:focus{border-color:var(--cta)}.iw-custom-card-textarea::placeholder{color:var(--fg-dim)}.neg-cards-section{display:flex;flex-direction:column;flex:1;min-height:0;padding:8px 0}.neg-cards-coverflow{flex:1;position:relative;perspective:800px;overflow:hidden;min-height:0}.neg-cards-track{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.neg-card{position:absolute;width:calc(100% - 24px);min-height:56px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;flex-direction:column;padding:0 14px;cursor:pointer;transition:transform .4s cubic-bezier(.25,.46,.45,.94),opacity .4s cubic-bezier(.25,.46,.45,.94),border-color .3s;will-change:transform,opacity;overflow:hidden}.neg-card:hover{border-color:var(--border-active, var(--border))}.neg-card--on{border-color:var(--cta);box-shadow:0 0 0 1px var(--cta)}.neg-card-main{display:flex;align-items:center;justify-content:space-between;height:56px;flex-shrink:0}.neg-card-text{display:flex;flex-direction:column;gap:2px}.neg-card-title{font-size:13px;font-weight:500;color:var(--fg)}.neg-card-desc{font-size:11px;color:var(--fg-dim)}.neg-card-badge{font-size:10px;font-weight:700;letter-spacing:.06em;padding:2px 7px;border-radius:10px;background:var(--bg-muted);border:1px solid var(--border);color:var(--fg-muted)}.neg-card-badge--on{background:#22c55e1f;border-color:var(--cta);color:var(--cta)}.neg-custom-textarea{width:100%;background:var(--bg-muted);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:12px;color:var(--fg);font-family:inherit;resize:none;outline:none;line-height:1.5;margin-bottom:10px}.neg-custom-textarea:focus{border-color:var(--cta)}.neg-custom-textarea::placeholder{color:var(--fg-dim)}.neg-cards-nav{display:flex;justify-content:center;gap:8px;padding:6px 0;flex-shrink:0}.neg-nav-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--fg-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.neg-nav-btn:hover{background:var(--bg-hover);color:var(--fg)}#sds-container{display:none;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;position:relative;background:var(--bg-surface, #1E293B);overflow:hidden}#designer-container{width:min(420px,calc(100% - 48px));height:min(420px,calc(100% - 48px));max-width:100%;max-height:100%;aspect-ratio:1;border:1px solid var(--border, rgba(248,250,252,.08));position:relative;box-shadow:0 0 0 8px #ffffff08}#previewBox{position:absolute;bottom:12px;right:12px;width:120px;height:120px;background:var(--bg-base, #0F172A);border:1px solid var(--border, rgba(248,250,252,.08));border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;z-index:10}#previewBoxContent{width:100%;height:100%;display:flex;align-items:center;justify-content:center}#previewBoxContent img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.design-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;gap:8px}.design-loading-text{font-size:13px;color:var(--fg-dim, #94A3B8);text-align:center}.design-start-btn{margin-top:12px;padding:8px 20px;background:var(--accent, #334155);color:var(--fg, #F8FAFC);border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease}.design-start-btn:hover{background:var(--accent-light, #475569)}.spinner{display:inline-block;width:40px;height:40px;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIiB3aWR0aD0iMTAwIiBoZWlnaHQ9IjEwMCI+PHN0eWxlPkBrZXlmcmFtZXMgc3Bpbntmcm9te3RyYW5zZm9ybTpyb3RhdGUoOTBkZWcpfXRve3RyYW5zZm9ybTpyb3RhdGUoNDUwZGVnKX19LnJ7YW5pbWF0aW9uOnNwaW4gM3MgbGluZWFyIGluZmluaXRlO3RyYW5zZm9ybS1vcmlnaW46NTBweCA1MHB4fTwvc3R5bGU+PGcgY2xhc3M9InIiPjxwYXRoIGQ9Ik0xMi42IDUyLjZMNTAgOTAgOTAgNTAgNTIuNiAxMi42IiBmaWxsPSJub25lIiBzdHJva2U9IiM5Y2EzYWYiIHN0cm9rZS13aWR0aD0iMSIgc3Ryb2tlLWxpbmVjYXA9ImJ1dHQiIHN0cm9rZS1saW5lam9pbj0ibWl0ZXIiLz48bGluZSB4MT0iMTAiIHkxPSI1MCIgeDI9IjUwIiB5Mj0iMTAiIHN0cm9rZT0iI2RjMjYyNiIgc3Ryb2tlLXdpZHRoPSIxIiBzdHJva2UtbGluZWNhcD0iYnV0dCIvPjxsaW5lIHgxPSIxMS4xNCIgeTE9IjUxLjE0IiB4Mj0iNTEuMTQiIHkyPSIxMS4xNCIgc3Ryb2tlPSIjZGMyNjI2IiBzdHJva2Utd2lkdGg9IjEiIHN0cm9rZS1saW5lY2FwPSJidXR0Ii8+PGxpbmUgeDE9IjEyLjI5IiB5MT0iNTIuMjkiIHgyPSI1Mi4yOSIgeTI9IjEyLjI5IiBzdHJva2U9IiNkYzI2MjYiIHN0cm9rZS13aWR0aD0iMSIgc3Ryb2tlLWxpbmVjYXA9ImJ1dHQiLz48bGluZSB4MT0iOS42MiIgeTE9IjQ5LjYyIiB4Mj0iMTIuNjciIHkyPSI1Mi42NyIgc3Ryb2tlPSIjZGMyNjI2IiBzdHJva2Utd2lkdGg9IjEiIHN0cm9rZS1saW5lY2FwPSJidXR0Ii8+PGxpbmUgeDE9IjQ5LjYyIiB5MT0iOS42MiIgeDI9IjUyLjY3IiB5Mj0iMTIuNjciIHN0cm9rZT0iI2RjMjYyNiIgc3Ryb2tlLXdpZHRoPSIxIiBzdHJva2UtbGluZWNhcD0iYnV0dCIvPjwvZz48L3N2Zz4=);background-size:contain;background-repeat:no-repeat;background-position:center}.face-item{width:48px;height:48px;border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid transparent;position:relative;transition:border-color .15s ease}.face-item.active{border-color:var(--cta-bg, #22C55E)}.face-item img{width:100%;height:100%;object-fit:cover}.ws-products__header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border, rgba(248,250,252,.08))}.ws-products__title{font-size:14px;font-weight:600;color:var(--fg, #F8FAFC);letter-spacing:.02em}.ws-products__grid{flex:1;overflow-y:auto;padding:12px}.ws-products__sentinel{height:1px;width:100%}.waterfall-container{display:flex;gap:8px;align-items:flex-start}.waterfall-column{flex:1;display:flex;flex-direction:column;gap:8px}.product-item{border-radius:6px;overflow:hidden;cursor:pointer;border:1px solid transparent;transition:border-color .15s ease,transform .15s ease;position:relative;background:var(--bg-surface, #1E293B);width:100%;break-inside:avoid}.product-item:hover{border-color:var(--cta-bg, #22C55E);transform:translateY(-2px)}.product-item.active{border-color:var(--cta-bg, #22C55E);border-width:2px}.product-item img{width:100%;height:auto;display:block;object-fit:cover;background:var(--bg-base, #0F172A)}.rec-badge{position:absolute;top:8px;left:8px;padding:4px 8px;background:var(--cta-bg, #22C55E);border-radius:4px;font-size:10px;font-weight:600;color:var(--cta-fg, #000);z-index:10;pointer-events:none;letter-spacing:.05em}.material-item{border-radius:6px;overflow:hidden;cursor:pointer;border:1px solid transparent;transition:border-color .15s ease,transform .15s ease;position:relative;background:var(--bg-surface, #1E293B);width:100%;break-inside:avoid}.material-item:hover{border-color:var(--cta-bg, #22C55E);transform:translateY(-2px)}.material-item img{width:100%;height:auto;display:block;object-fit:cover;background:var(--bg-base, #0F172A)}.fav-toggle-btn{position:absolute;top:50%;right:8px;transform:translateY(-50%);width:32px;height:32px;border:none;border-radius:50%;background:#ffffffe6;backdrop-filter:blur(4px);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg-dim, #94A3B8);transition:all .2s ease;z-index:10;box-shadow:0 1px 3px #0003;opacity:0;pointer-events:none}.material-item:hover .fav-toggle-btn{opacity:1;pointer-events:auto}.fav-toggle-btn.active{opacity:1;pointer-events:auto;background:var(--error, #EF4444);color:#fff}.fav-toggle-btn:hover{background:#fff;color:var(--error, #EF4444);transform:translateY(-50%) scale(1.1)}.fav-toggle-btn.active:hover{background:#dc2626}.variant-options{display:flex;flex-wrap:wrap;gap:6px}.variant-option{padding:6px 12px;border:1px solid var(--border, rgba(248,250,252,.08));border-radius:4px;font-size:13px;cursor:pointer;transition:border-color .15s ease,color .15s ease;background:transparent;color:var(--fg, #F8FAFC);display:inline-flex;align-items:center}.variant-option:hover{border-color:var(--cta-bg, #22C55E);color:var(--cta-bg, #22C55E)}.variant-option.active{border-color:var(--cta-bg, #22C55E);border-width:2px;color:var(--cta-bg, #22C55E)}.loading-indicator{text-align:center;padding:20px;color:var(--fg-dim, #94A3B8);font-size:13px}.placeholder-text{text-align:center;color:var(--fg-dim, #94A3B8);padding:24px;font-size:13px}.skeleton-container{background:var(--bg-surface, #1E293B);border-radius:6px;overflow:hidden;border:1px solid var(--border, rgba(248,250,252,.08))}.skeleton-product,.skeleton-material{width:100%;border-radius:6px;overflow:hidden;background:var(--bg-surface, #1E293B);border:1px solid var(--border, rgba(248,250,252,.08))}.skeleton-image{width:100%;aspect-ratio:3/4;background:linear-gradient(90deg,var(--bg-base, #0F172A) 25%,var(--border, rgba(248,250,252,.08)) 50%,var(--bg-base, #0F172A) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-text{height:16px;margin:8px;background:linear-gradient(90deg,var(--bg-base, #0F172A) 25%,var(--border, rgba(248,250,252,.08)) 50%,var(--bg-base, #0F172A) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.opacity-slider-panel{position:fixed;bottom:120px;left:50%;transform:translate(-50%);background:var(--bg-surface, #1E293B);padding:16px;border:1px solid var(--border, rgba(248,250,252,.08));border-radius:6px;box-shadow:0 4px 12px #0006;z-index:1000;min-width:200px}.opacity-slider-label{font-size:12px;color:var(--fg-dim, #94A3B8);text-transform:uppercase;letter-spacing:.05em}.opacity-slider-input{flex:1;height:4px;background:var(--border, rgba(248,250,252,.08));outline:none;-webkit-appearance:none;accent-color:var(--cta-bg, #22C55E)}.opacity-slider-value{font-size:14px;color:var(--fg, #F8FAFC);font-weight:600;min-width:40px}.opacity-slider-close{border:none;background:transparent;cursor:pointer;padding:4px;color:var(--fg-dim, #94A3B8)}:root{--ws-mobile-toolbar-height: 48px;--ws-mobile-touch-target: 44px;--ws-mobile-fab-size: 44px;--ws-mobile-sheet-radius: 16px}@media (max-width: 767px){html,body{height:100dvh;width:100%;overflow:hidden;overscroll-behavior:none}.app{grid-template-columns:1fr!important;grid-template-rows:1fr auto!important}.rail,.right-panel{display:none!important}.modal-shell{position:static!important;width:100%!important;height:100dvh!important;border-radius:0!important;box-shadow:none!important;max-width:none!important;max-height:none!important}.modal-close{display:none!important}.stage{width:100%;height:100%;overflow:hidden}.stage-header{height:36px;min-height:36px;padding:0 12px}.stage-title{font-size:14px}.stage-body{flex:1;overflow:hidden;min-height:0}.ws-mobile-nav{display:flex;align-items:center;justify-content:space-around;height:52px;background:var(--bg-elevated, #1e1e2e);border-top:1px solid var(--border, rgba(255,255,255,.08));padding-bottom:env(safe-area-inset-bottom,0)}.ws-mobile-nav-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:var(--ws-mobile-touch-target);height:var(--ws-mobile-touch-target);background:transparent;border:none;color:var(--fg-dim, #94A3B8);font-size:9px;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.ws-mobile-nav-btn.active{color:var(--accent, #22c55e)}.ws-mobile-nav-btn i{font-size:20px;margin-bottom:2px}#sds-container{width:100%;height:100%}#designer-container{width:calc(100vw - 8px);height:calc(100vw - 8px);max-width:calc(100dvh - 36px - var(--ws-mobile-toolbar-height) - 16px);max-height:calc(100dvh - 36px - var(--ws-mobile-toolbar-height) - 16px);aspect-ratio:1;touch-action:none;margin:auto}.ws-mobile-fab-group{position:absolute;top:8px;right:8px;z-index:100;display:flex;flex-direction:column;gap:8px}.ws-mobile-fab-btn{width:var(--ws-mobile-fab-size);height:var(--ws-mobile-fab-size);min-width:var(--ws-mobile-fab-size);min-height:var(--ws-mobile-fab-size);border-radius:12px;border:1px solid var(--border, rgba(255, 255, 255, .15));background:var(--bg-elevated, rgba(30, 30, 46, .9));color:var(--fg, #e4e4e7);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:background .15s ease,transform .15s ease;box-shadow:0 2px 8px #0000004d}.ws-mobile-fab-btn svg{width:20px;height:20px}.ws-mobile-fab-btn:active{transform:scale(.9)}.ws-mobile-fab-btn.active{background:var(--accent, #22c55e);color:#fff;border-color:var(--accent, #22c55e)}.ws-mobile-sheet-overlay{position:fixed;inset:0;z-index:1000;display:none;background:#0006;opacity:0;transition:opacity .25s ease}.ws-mobile-sheet-overlay.active{display:block;opacity:1}.ws-mobile-sheet{position:fixed;left:0;right:0;bottom:0;z-index:1001;background:var(--bg-surface, #1e1e2e);border-radius:var(--ws-mobile-sheet-radius) var(--ws-mobile-sheet-radius) 0 0;box-shadow:0 -4px 20px #00000040;will-change:transform;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;max-height:90dvh;overflow:hidden}.ws-mobile-sheet.open{transform:translateY(0)}.ws-mobile-sheet.peek{transform:translateY(70%)}.ws-mobile-sheet.half{transform:translateY(50%)}.ws-mobile-sheet-handle{display:flex;align-items:center;justify-content:center;padding:10px 0 6px;flex-shrink:0;cursor:grab;touch-action:none}.ws-mobile-sheet-handle:before{content:"";width:36px;height:4px;background:var(--border, rgba(255,255,255,.15));border-radius:2px}.ws-mobile-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px 12px;flex-shrink:0}.ws-mobile-sheet-title{font-size:16px;font-weight:600;color:var(--fg, #e4e4e7)}.ws-mobile-sheet-close{width:var(--ws-mobile-touch-target);height:var(--ws-mobile-touch-target);display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--fg-dim, #94A3B8);cursor:pointer;border-radius:50%;-webkit-tap-highlight-color:transparent}.ws-mobile-sheet-close:active{background:var(--bg-elevated, rgba(255,255,255,.05))}.ws-mobile-sheet-close svg{width:18px;height:18px}.ws-mobile-sheet-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 12px 16px;-webkit-overflow-scrolling:touch;min-height:0}.ws-mobile-sheet-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.ws-mobile-material-item,.ws-mobile-product-item{border-radius:8px;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent}.ws-mobile-material-item img,.ws-mobile-product-item img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.ws-mobile-material-item:active,.ws-mobile-product-item:active{transform:scale(.96)}.ws-mobile-product-item.active{outline:2px solid var(--accent, #22c55e);outline-offset:-2px}.ws-mobile-sheet-preview .preview-image{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;background:var(--bg-elevated, #2a2a3a);margin-bottom:12px}.ws-mobile-sheet-preview .preview-image img,.ws-mobile-sheet-preview .preview-image canvas{width:100%;height:100%;object-fit:contain}.ws-mobile-sheet-preview .preview-product-name{font-size:16px;font-weight:600;color:var(--fg, #e4e4e7);margin-bottom:4px}.ws-mobile-sheet-preview .preview-product-price{font-size:18px;font-weight:700;color:var(--accent, #22c55e);margin-bottom:12px}.ws-mobile-skeleton{background:linear-gradient(90deg,var(--bg-elevated, #2a2a3a) 25%,var(--bg-surface, #1e1e2e) 50%,var(--bg-elevated, #2a2a3a) 75%);background-size:200% 100%;animation:wsMobileShimmer 1.5s infinite;border-radius:8px}.ws-mobile-skeleton-card{aspect-ratio:1}@keyframes wsMobileShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.ws-mobile-toolbar{position:absolute;bottom:0;left:0;right:0;background:var(--bg-surface, #1e1e2e);border-top:1px solid var(--border, rgba(255,255,255,.08));z-index:50;flex-shrink:0}.ws-mobile-toolbar-primary{display:flex;align-items:center;justify-content:space-around;height:var(--ws-mobile-toolbar-height);padding:0 4px;gap:2px}.ws-mobile-tool-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:var(--ws-mobile-touch-target);height:var(--ws-mobile-touch-target);min-width:var(--ws-mobile-touch-target);min-height:var(--ws-mobile-touch-target);background:transparent;border:none;border-radius:8px;color:var(--fg, #e4e4e7);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:background .15s ease;flex-shrink:0;padding:0}.ws-mobile-tool-btn svg{width:20px;height:20px}.ws-mobile-tool-label{font-size:9px;margin-top:1px;color:var(--fg-dim, #94A3B8);line-height:1}.ws-mobile-tool-btn:active{background:var(--bg-elevated, rgba(255,255,255,.05));transform:scale(.92)}.ws-mobile-buy-btn{background:var(--accent, #22c55e)!important;color:#fff!important;border-radius:10px;width:auto;padding:0 12px;font-size:12px;font-weight:600}.ws-mobile-toolbar-secondary{display:flex;align-items:center;justify-content:center;height:0;overflow:hidden;gap:4px;padding:0 8px;transition:height .2s ease}.ws-mobile-toolbar-secondary.expanded{height:var(--ws-mobile-touch-target);padding:4px 8px}.ws-mobile-toolbar-secondary .ws-mobile-tool-btn{width:36px;height:36px;min-width:36px;background:var(--bg-elevated, rgba(255,255,255,.05));border-radius:8px}.ws-mobile-toolbar-secondary .ws-mobile-tool-btn svg{width:16px;height:16px}.designer-share-overlay .designer-share-modal{position:fixed;bottom:0;left:0;right:0;max-width:100%;max-height:85vh;border-radius:16px 16px 0 0;animation:wsSlideUp .25s ease}@keyframes wsSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.dshare-buynow{position:sticky;bottom:0;background:var(--bg-surface, #1e1e2e);z-index:1}input,textarea,select{font-size:16px!important}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}input,textarea,[contenteditable]{-webkit-user-select:text;user-select:text}button,.ws-mobile-tool-btn,.ws-mobile-fab-btn,.ws-mobile-material-item,.ws-mobile-product-item{-webkit-user-select:none;user-select:none}@supports (padding: env(safe-area-inset-bottom)){.ws-mobile-toolbar,.ws-mobile-sheet,.ws-mobile-toolbar-primary{padding-bottom:env(safe-area-inset-bottom)}}@media (orientation: landscape){.stage-header{height:28px;min-height:28px}#designer-container{width:min(60dvh,90vw);height:min(60dvh,90vw);max-width:none;max-height:calc(100dvh - 28px - var(--ws-mobile-toolbar-height) - 16px)}.ws-mobile-sheet{max-height:85dvh}.ws-mobile-fab-group{top:4px;right:4px;gap:4px}.ws-mobile-fab-btn{width:36px;height:36px;min-width:36px;min-height:36px}}}@media (min-width: 768px) and (max-width: 1023px){.right-panel{display:none!important}.app{grid-template-columns:56px 1fr!important}.ws-tablet-slide-over-backdrop{position:fixed;inset:0;z-index:999;background:#0000004d;opacity:0;pointer-events:none;transition:opacity .25s ease}.ws-tablet-slide-over-backdrop.active{opacity:1;pointer-events:auto}.ws-tablet-slide-over{position:fixed;top:0;right:0;bottom:0;width:320px;max-width:80vw;z-index:1000;background:var(--bg-surface, #1e1e2e);border-left:1px solid var(--border, rgba(255,255,255,.08));transform:translate(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column}.ws-tablet-slide-over.active{transform:translate(0)}.ws-tablet-slide-over-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border, rgba(255,255,255,.08))}.ws-tablet-slide-over-body{flex:1;overflow-y:auto;padding:12px}.ws-tablet-fab-group{position:absolute;top:12px;right:12px;z-index:100;display:flex;flex-direction:column;gap:8px}.ws-tablet-fab{width:44px;height:44px;border-radius:12px;border:1px solid var(--border, rgba(255,255,255,.15));background:var(--bg-elevated, rgba(30, 30, 46, .9));color:var(--fg, #e4e4e7);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0003;transition:background .15s ease}.ws-tablet-fab:hover{background:var(--bg-elevated-hover, rgba(255,255,255,.08))}.ws-tablet-fab svg{width:18px;height:18px}}@media (min-width: 769px){.ws-mobile-fab-group,.ws-mobile-sheet-overlay,.ws-mobile-sheet,.ws-mobile-toolbar,.ws-mobile-nav{display:none!important}}@media (min-width: 1024px){.ws-tablet-slide-over-backdrop,.ws-tablet-slide-over,.ws-tablet-fab-group{display:none!important}}@media (prefers-reduced-motion: reduce){.ws-mobile-sheet,.ws-mobile-sheet-overlay,.ws-mobile-fab-btn,.ws-mobile-tool-btn,.ws-tablet-slide-over{transition:none!important;animation:none!important}}
