:root,[data-theme=light]{color-scheme:light;--bg: #f5f3ef;--bg-subtle: #ebe8e2;--panel: rgba(255, 253, 250, .94);--panel-border: rgba(0, 0, 0, .07);--panel-hover: rgba(0, 0, 0, .03);--text: #1a1d24;--text-secondary: #5c6170;--muted: #8b8f9a;--accent: #c46a3d;--accent-hover: #d67a4d;--accent-dark: #a85530;--accent-soft: rgba(196, 106, 61, .1);--surface: rgba(255, 255, 255, .7);--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 4px 16px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .08);--focus-ring: 0 0 0 2px var(--accent-soft), 0 0 0 4px rgba(196, 106, 61, .2);--radius-xs: 6px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--header-bg: rgba(255, 253, 250, .88);--sidebar-bg: var(--panel);--canvas-bg: var(--bg-subtle);--toast-bg: #1a1d24;--toast-text: #fff;--scrollbar-thumb: rgba(0, 0, 0, .12);--scrollbar-track: transparent}[data-theme=dark]{color-scheme:dark;--bg: #111318;--bg-subtle: #181b22;--panel: rgba(24, 27, 36, .95);--panel-border: rgba(255, 255, 255, .07);--panel-hover: rgba(255, 255, 255, .04);--text: #e5e4e0;--text-secondary: #9a9ea8;--muted: #6a6e78;--accent: #e4845a;--accent-hover: #f0956a;--accent-dark: #c46a3d;--accent-soft: rgba(228, 132, 90, .12);--surface: rgba(30, 34, 44, .7);--shadow: 0 1px 3px rgba(0, 0, 0, .2), 0 4px 16px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .3);--focus-ring: 0 0 0 2px rgba(228, 132, 90, .2), 0 0 0 4px rgba(228, 132, 90, .15);--header-bg: rgba(17, 19, 24, .92);--sidebar-bg: var(--panel);--canvas-bg: var(--bg-subtle);--toast-bg: #e5e4e0;--toast-text: #1a1d24;--scrollbar-thumb: rgba(255, 255, 255, .1);--scrollbar-track: transparent}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;font-family:Space Grotesk,system-ui,-apple-system,sans-serif;font-size:14px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;transition:background-color .3s,color .3s}button,input,select{font:inherit}svg{vertical-align:middle}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}.skip-link{position:absolute;top:-100%;left:16px;padding:10px 18px;background:var(--accent);color:#fff;border-radius:var(--radius-sm);font-weight:600;z-index:1000;text-decoration:none;transition:top .2s}.skip-link:focus{top:12px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.icon{width:16px;height:16px;flex:0 0 auto;margin:0}.app-header{position:sticky;top:0;z-index:100;height:52px;backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);background:var(--header-bg);border-bottom:1px solid var(--panel-border)}.header-inner{display:flex;align-items:center;gap:16px;height:100%;padding:0 16px}.brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.brand-mark{width:30px;height:30px;display:block;flex-shrink:0;border-radius:8px;box-shadow:var(--shadow)}.brand-text{display:flex;flex-direction:column;line-height:1.1}.brand-name{font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.brand-tagline{font-size:.68rem;font-weight:500;color:var(--muted);letter-spacing:0}.header-status{flex:1;display:flex;align-items:center;gap:8px;min-width:0;justify-content:center}.status-text{font-size:.8rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-toggle{display:grid;place-items:center;width:34px;height:34px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;transition:transform .2s,box-shadow .2s;flex-shrink:0}.theme-toggle:hover{transform:scale(1.06);box-shadow:var(--shadow)}.theme-toggle:focus-visible{box-shadow:var(--focus-ring);outline:none}.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--panel-border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:grid;grid-template-columns:320px 1fr;height:calc(100dvh - 52px);overflow:hidden}.sidebar{display:flex;flex-direction:column;background:var(--sidebar-bg);border-right:1px solid var(--panel-border);overflow:hidden}.sidebar-tabs{display:flex;border-bottom:1px solid var(--panel-border);padding:0 4px;flex-shrink:0}.sidebar-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 4px 8px;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s;font-size:.7rem;font-weight:600}.sidebar-tab:hover{color:var(--text-secondary)}.sidebar-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.sidebar-tab .icon{width:18px;height:18px}.sidebar-tab-label{letter-spacing:.02em}.sidebar-content{flex:1;overflow-y:auto;padding:16px}.tab-panel{display:flex;flex-direction:column;gap:16px;animation:fadeSlide .2s ease}@keyframes fadeSlide{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.setting-group{display:flex;flex-direction:column;gap:8px}.setting-group-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.preset-bar{display:flex;gap:6px}.preset-pill{flex:1;padding:8px 0;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.preset-pill:hover:not(:disabled){border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.preset-pill:disabled{opacity:.4;cursor:not-allowed}.compact-sliders{display:flex;flex-direction:column;gap:8px}.compact-slider{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--surface);transition:border-color .15s;cursor:pointer}.compact-slider:hover{border-color:var(--accent)}.compact-slider-row{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--text-secondary);font-weight:500}.num-input{width:52px;border:1px solid var(--panel-border);background:var(--bg);color:var(--text);border-radius:var(--radius-xs);padding:4px 6px;text-align:center;font-size:.82rem}.compact-slider input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer;height:4px}.compact-slider input[type=range]:disabled{opacity:.35;cursor:not-allowed}.inline-check{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-secondary);cursor:pointer;padding:4px 0}.inline-check:has(input:disabled){opacity:.4;cursor:not-allowed}.inline-check input[type=checkbox]{accent-color:var(--accent)}.radio-row{display:flex;gap:6px}.radio-pill{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--surface);font-size:.82rem;cursor:pointer;transition:all .15s}.radio-pill:hover:not(:has(input:disabled)){border-color:var(--accent)}.radio-pill:has(input:checked){border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:600}.radio-pill:has(input:disabled){opacity:.4;cursor:not-allowed;background:var(--surface);border-color:var(--panel-border);color:var(--text-secondary);font-weight:400}.radio-pill input[type=radio]{display:none}.ghost-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-secondary);font-weight:600;font-size:.82rem;cursor:pointer;transition:all .15s}.ghost-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.ghost-btn:disabled{opacity:.4;cursor:not-allowed}.ghost-btn--sm{padding:6px 10px;font-size:.78rem}.source-thumb{border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--panel-border)}.source-thumb img{width:100%;display:block;max-height:160px;object-fit:cover}.sidebar-hint{margin:0;font-size:.78rem;color:var(--muted);line-height:1.5}.empty-tab{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;text-align:center;color:var(--muted)}.empty-tab .icon{width:28px;height:28px;opacity:.5}.empty-tab p{margin:0;font-size:.85rem;max-width:22ch;line-height:1.5}.palette-header{display:flex;align-items:center;justify-content:space-between}.palette-header-actions{display:flex;gap:4px}.swatch-list{display:flex;flex-direction:column;gap:4px}.swatch-item{display:flex;align-items:center;gap:6px;padding:4px;border-radius:var(--radius-sm);transition:background .15s,opacity .2s}.swatch-item:hover{background:var(--panel-hover)}.swatch-item--active{background:var(--accent-soft)}.swatch-item--dimmed{opacity:.3}.swatch-btn{flex:1;display:flex;align-items:center;gap:8px;min-width:0;padding:6px;border:none;background:none;color:inherit;cursor:pointer;text-align:left}.swatch-dot{width:20px;height:20px;border-radius:6px;border:1px solid rgba(0,0,0,.08);flex-shrink:0}[data-theme=dark] .swatch-dot{border-color:#ffffff1a}.swatch-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.swatch-name{font-size:.82rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.swatch-meta{font-size:.72rem;color:var(--muted)}.swatch-idx{width:22px;height:22px;display:grid;place-items:center;border-radius:6px;background:var(--panel-hover);font-size:.72rem;font-weight:700;color:var(--text-secondary);flex-shrink:0}.swatch-acts{display:flex;gap:2px;opacity:0;transition:opacity .15s}.swatch-item:hover .swatch-acts{opacity:1}.micro-btn{width:28px;height:28px;display:grid;place-items:center;border:1px solid transparent;border-radius:var(--radius-xs);background:none;color:var(--muted);cursor:pointer;transition:all .15s}.micro-btn:hover{background:var(--surface);border-color:var(--panel-border);color:var(--text)}.tiny-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;height:28px;padding:0 10px;border:1px solid var(--panel-border);border-radius:var(--radius-xs);background:var(--surface);color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.tiny-btn:hover{border-color:var(--accent);color:var(--accent)}.swatch-edit-form{display:flex;gap:6px;width:100%;padding:4px 6px}.swatch-edit-form input{flex:1;min-width:0;border:1px solid var(--panel-border);background:var(--bg);color:var(--text);border-radius:var(--radius-xs);padding:6px 8px;font-size:.82rem}.canvas-area{display:flex;flex-direction:column;overflow:hidden;background:var(--canvas-bg)}.canvas-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--panel-border);background:var(--panel);flex-shrink:0;gap:8px}.canvas-tabs{display:flex;gap:4px}.canvas-tab{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid transparent;border-radius:var(--radius-sm);background:none;color:var(--muted);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.canvas-tab:hover{background:var(--panel-hover);color:var(--text-secondary)}.canvas-tab--active{background:var(--accent-soft);color:var(--accent);border-color:#c46a3d26}.canvas-actions{display:flex;gap:6px}.canvas-viewport{flex:1;display:grid;place-items:center;overflow:auto;padding:24px;position:relative;background:repeating-linear-gradient(0deg,transparent,transparent 19px,rgba(0,0,0,.02) 19px,rgba(0,0,0,.02) 20px),repeating-linear-gradient(90deg,transparent,transparent 19px,rgba(0,0,0,.02) 19px,rgba(0,0,0,.02) 20px)}[data-theme=dark] .canvas-viewport{background:repeating-linear-gradient(0deg,transparent,transparent 19px,rgba(255,255,255,.015) 19px,rgba(255,255,255,.015) 20px),repeating-linear-gradient(90deg,transparent,transparent 19px,rgba(255,255,255,.015) 19px,rgba(255,255,255,.015) 20px)}.canvas-viewport--zoomed{place-items:start}.canvas-viewport--play{grid-template-rows:100%;grid-template-columns:100%;padding:16px}.preview-canvas{max-width:100%;height:auto;display:block;image-rendering:pixelated;border-radius:var(--radius-sm);box-shadow:var(--shadow)}.canvas-viewport--zoomed .preview-canvas{max-width:none}.preview-canvas--hidden{display:none}.original-img{image-rendering:auto;max-height:80vh}.canvas-empty{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;color:var(--muted);padding:40px}.canvas-empty-icon{width:64px;height:64px;display:grid;place-items:center;border-radius:50%;background:var(--accent-soft)}.canvas-empty-icon .icon{width:28px;height:28px;color:var(--accent)}.canvas-empty h2{margin:0;font-size:1.15rem;font-weight:600;color:var(--text)}.canvas-empty p{margin:0;max-width:38ch;line-height:1.55;font-size:.88rem}.canvas-empty-steps{list-style:none;margin:6px 0 4px;padding:0;display:flex;flex-direction:column;gap:10px;text-align:left;max-width:34ch}.canvas-empty-steps li{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.canvas-empty-steps .step-num{flex-shrink:0;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-size:.75rem;font-weight:700}.canvas-empty-steps strong{color:var(--text);font-weight:600}.canvas-empty-cta{margin-top:6px}.empty-demo{width:100%;max-width:200px;aspect-ratio:1 / 1;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--panel-border);background:var(--surface)}.empty-demo-svg{display:block;width:100%;height:100%}.empty-demo-photo{animation:demoPhoto 7s ease-in-out infinite}.empty-demo-grid{animation:demoGrid 7s ease-in-out infinite}.empty-demo-dots{animation:demoScan 7s ease-in-out infinite}@keyframes demoPhoto{0%,6%{opacity:1}16%,82%{opacity:0}92%,to{opacity:1}}@keyframes demoGrid{0%,6%{opacity:0}14%,84%{opacity:1}92%,to{opacity:0}}@keyframes demoScan{0%,14%{clip-path:inset(0 0 100% 0)}34%,to{clip-path:inset(0 0 0 0)}}@media (prefers-reduced-motion: reduce){.empty-demo-photo{animation:none;opacity:0}.empty-demo-grid{animation:none;opacity:1}.empty-demo-dots{animation:none;clip-path:none}}.export-stack{display:flex;flex-direction:column;gap:10px}.export-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-weight:600;font-size:.88rem;cursor:pointer;transition:all .15s}.export-btn:hover:not(:disabled){border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow)}.export-btn:active:not(:disabled){transform:translateY(0)}.export-btn:disabled{opacity:.4;cursor:not-allowed}.export-btn--primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;border-color:transparent}.export-btn--primary:hover:not(:disabled){border-color:transparent;box-shadow:0 4px 16px #c46a3d4d}.drop-zone{position:relative;display:flex;align-items:center;justify-content:center;min-height:110px;padding:20px;border:2px dashed var(--panel-border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;transition:border-color .2s,background .2s;outline:none}.drop-zone:hover,.drop-zone:focus-visible{border-color:var(--accent);background:var(--accent-soft)}.drop-zone:focus-visible{box-shadow:var(--focus-ring)}.drop-zone--active{border-color:var(--accent);background:var(--accent-soft);border-style:solid}.drop-zone--has-image{min-height:70px}.drop-zone-input{position:absolute;inset:0;opacity:0;cursor:pointer;pointer-events:none}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.drop-zone-icon .icon{width:22px;height:22px}.drop-zone-icon{color:var(--accent);margin-bottom:2px}.drop-zone-label{font-weight:600;font-size:.85rem}.drop-zone-hint{font-size:.74rem;color:var(--muted)}.drop-zone-error{position:absolute;bottom:-24px;left:0;margin:0;font-size:.78rem;color:#d44;font-weight:500}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%) translateY(16px);padding:10px 20px;background:var(--toast-bg);color:var(--toast-text);border-radius:999px;font-size:.82rem;font-weight:600;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:200;display:flex;align-items:center;gap:6px}.toast--visible{opacity:1;transform:translate(-50%) translateY(0)}.toast-icon{display:inline-flex;font-size:.95rem;color:#4ade80}[data-theme=dark] .toast-icon{color:#22c55e}.loading-shimmer{position:relative;overflow:hidden}.loading-shimmer:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transform:translate(-100%);animation:shimmer 1.5s infinite;pointer-events:none}@keyframes shimmer{to{transform:translate(100%)}}[data-theme=dark] .loading-shimmer:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent)}.modal-backdrop{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;background:#0009;backdrop-filter:blur(6px);z-index:1000}.modal-content{width:min(600px,100%);max-height:90vh;overflow:auto;padding:24px;background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.modal-header h2{margin:0;font-size:1.1rem}.section-kicker{margin:0 0 4px;color:var(--accent);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.modal-options{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.modal-options label{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--panel-border);border-radius:999px;background:var(--surface);font-size:.82rem;cursor:pointer;transition:all .15s}.modal-options label:hover{border-color:var(--accent)}.modal-options label:has(input:checked){border-color:var(--accent);background:var(--accent-soft)}.modal-preview-shell{display:grid;place-items:center;padding:20px;border-radius:var(--radius-md);background:var(--bg-subtle);margin-bottom:12px}.modal-paper{width:min(100%,280px);aspect-ratio:210 / 297;padding:12px;background:#fff;border-radius:8px;box-shadow:0 8px 24px #0000001a}.modal-preview-canvas{width:100%;height:100%;object-fit:contain}.modal-actions{display:flex;gap:8px;margin-top:16px}.modal-actions .export-btn{flex:1}.ghost-button{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-secondary);font-weight:600;font-size:.82rem;cursor:pointer;transition:all .15s}.ghost-button:hover{border-color:var(--accent);color:var(--accent)}.helper-text{font-size:.78rem;color:var(--muted);margin:0;line-height:1.5}.download-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-weight:600;font-size:.88rem;cursor:pointer;transition:all .15s}.download-button:not(.download-button--secondary){background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;border-color:transparent}.download-button--secondary{background:var(--surface)}.download-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow)}.download-button:disabled{opacity:.4;cursor:not-allowed}.error-boundary{display:grid;place-items:center;min-height:80vh;padding:32px}.error-boundary-content{text-align:center;max-width:380px;padding:24px;border-radius:var(--radius-lg)}.error-icon{display:inline-flex;font-size:2.5rem;margin-bottom:12px;color:var(--accent)}.error-boundary-content h2{margin:0 0 8px;font-size:1.3rem}.error-boundary-content p{color:var(--text-secondary);line-height:1.5;margin:0 0 20px}.error-reset-btn{padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:background .2s}.error-reset-btn:hover{background:var(--accent-hover)}.mobile-bar{display:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus-visible,.drop-zone:focus-visible,.theme-toggle:focus-visible{outline:none;box-shadow:var(--focus-ring)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.spinner{animation:none;border-color:var(--accent)}}@media (max-width: 768px){.app-layout{grid-template-columns:1fr;grid-template-rows:1fr auto;height:calc(100dvh - 52px)}.sidebar{order:2;border-right:none;border-top:1px solid var(--panel-border);max-height:45vh}.canvas-area{order:1}.sidebar-tab-label{display:none}.sidebar-tab .icon{width:20px;height:20px}.sidebar-tabs{justify-content:center;gap:4px}.sidebar-tab{padding:8px 16px}.canvas-viewport{padding:16px}.canvas-toolbar{flex-wrap:wrap}.canvas-tabs{width:100%;order:1}.canvas-tab{flex:1;justify-content:center}.canvas-actions{width:100%;order:2;flex-wrap:wrap;justify-content:flex-start}.mobile-bar{display:flex;position:fixed;bottom:0;left:0;right:0;padding:12px 16px;gap:8px;background:var(--header-bg);backdrop-filter:blur(12px);border-top:1px solid var(--panel-border);z-index:100}.mobile-bar .export-btn{flex:1}}@media (max-width: 480px){.header-status{display:none}.canvas-tab{white-space:nowrap;font-size:.75rem;padding:7px 6px}.brand-tagline{display:none}}.sidebar-tab-icon{position:relative;display:inline-flex}.tab-badge{position:absolute;top:-6px;right:-10px;min-width:15px;height:15px;padding:0 3px;display:grid;place-items:center;border-radius:999px;background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;line-height:1}.tab-badge--ok{background:#3a9d6a}.tab-badge .icon{width:10px;height:10px}.export-estimate{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:var(--panel-hover);font-size:.78rem;color:var(--text-secondary)}.export-estimate strong{color:var(--text)}.play{place-self:stretch;display:flex;flex-direction:column;gap:12px;width:100%;height:100%;min-height:0}.play-topbar{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.play-progress{flex:1;min-width:180px;display:flex;flex-direction:column;gap:4px}.play-progress-track{height:10px;border-radius:999px;background:var(--panel-hover);border:1px solid var(--panel-border);overflow:hidden}.play-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-dark) 100%);transition:width .35s cubic-bezier(.22,1,.36,1)}.play-progress-label{font-size:.74rem;font-weight:600;color:var(--text-secondary)}.play-tools{display:flex;gap:6px;flex-wrap:wrap}.play-stage{position:relative;flex:1;min-height:0;display:grid;place-items:center;overflow:auto}.play-canvas{max-width:100%;max-height:100%;height:auto;image-rendering:pixelated;background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);touch-action:none}.play-confetti{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.play-done{position:absolute;inset:0;display:grid;place-items:center;background:#00000073;backdrop-filter:blur(4px);border-radius:var(--radius-sm);animation:fadeSlide .25s ease}.play-done-card{text-align:center;padding:28px 26px;width:min(360px,90%);background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.play-done-emoji{font-size:2.6rem;line-height:1;animation:popIn .5s cubic-bezier(.22,1.4,.4,1) both}@keyframes popIn{0%{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}.play-done-card h3{margin:10px 0 4px;font-size:1.2rem}.play-done-card p{margin:0 0 16px;color:var(--text-secondary);font-size:.86rem}.play-done-actions{display:flex;flex-direction:column;gap:8px}.play-tray{display:flex;gap:8px;overflow-x:auto;padding:8px 2px 12px;flex-shrink:0;scrollbar-width:thin}.tray-chip{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm);transition:transform .12s}.tray-chip:hover{transform:translateY(-2px)}.tray-ring{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--accent) var(--pct),var(--panel-border) 0);padding:3px;box-sizing:border-box;transition:transform .12s}.tray-chip--active .tray-ring{transform:scale(1.08);box-shadow:var(--focus-ring)}.tray-swatch{width:100%;height:100%;border-radius:50%;display:grid;place-items:center;font-size:.82rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.45);border:2px solid var(--panel)}.tray-swatch .icon{width:16px;height:16px}.tray-chip--done .tray-swatch{color:#fff}.tray-chip--done{opacity:.55}.tray-left{font-size:.66rem;font-weight:700;color:var(--text-secondary)}@media (max-width: 768px){.tray-ring{width:42px;height:42px}}.micro-btn--active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.swatch-item--active .swatch-acts{opacity:1}.ghost-btn--on{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
