*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--surface:oklch(14% .005 260);--surface-raised:oklch(18% .008 260);--surface-hover:oklch(22% .01 260);--border:oklch(24% .01 260);--text-primary:oklch(92% .01 260);--text-secondary:oklch(58% .02 260);--text-dim:oklch(42% .015 260);--accent:oklch(65% .15 260);--accent-dim:oklch(45% .1 260);--panel-width:300px;--topbar-height:48px;--radius-sm:6px;--radius-md:10px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-micro:cubic-bezier(.25, .46, .45, .94)}body{color:var(--text-primary);-webkit-font-smoothing:antialiased;background:oklch(8% .005 260);font-family:DM Sans,system-ui,sans-serif;overflow:hidden}#canvas-container{z-index:0;position:fixed;inset:0}#canvas-container canvas{display:block;width:100%!important;height:100%!important}.topbar{height:var(--topbar-height);z-index:20;-webkit-backdrop-filter:blur(20px)saturate(1.4);border-bottom:1px solid var(--border);background:oklch(10% .005 260/.8);justify-content:space-between;align-items:center;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-left{align-items:center;gap:10px;min-width:0;display:flex}.topbar-logo{color:var(--accent);flex-shrink:0;font-size:14px}.topbar-title{letter-spacing:.02em;white-space:nowrap;font-size:13px;font-weight:500}.topbar-tabs{background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);gap:2px;padding:2px;display:flex}.tab{height:28px;color:var(--text-secondary);cursor:pointer;transition:color .15s var(--ease-micro), background-color .15s var(--ease-micro);background:0 0;border:none;border-radius:4px;padding:0 14px;font-family:DM Sans,system-ui,sans-serif;font-size:12px;font-weight:400}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--surface-hover);color:var(--text-primary);font-weight:500}.topbar-right{align-items:center;gap:12px;display:flex}.export-btn{border:1px solid var(--accent-dim);border-radius:var(--radius-sm);height:28px;color:var(--accent);cursor:pointer;transition:background-color .15s var(--ease-micro), color .15s var(--ease-micro);letter-spacing:.02em;background:0 0;padding:0 14px;font-family:DM Sans,system-ui,sans-serif;font-size:12px;font-weight:500}.export-btn:hover{background:var(--accent-dim);color:var(--text-primary)}.export-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:oklch(5% .005 260/.85);place-items:center;display:none;position:fixed;inset:0}.export-overlay.open{display:grid}.export-dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;width:min(720px,90vw);max-height:85vh;display:flex;overflow:hidden;box-shadow:0 24px 80px oklch(0% 0 0/.5),0 2px 12px oklch(0% 0 0/.3)}.export-header{justify-content:space-between;align-items:center;padding:18px 20px 0;display:flex}.export-title{letter-spacing:.01em;font-size:14px;font-weight:500}.export-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:background-color .15s var(--ease-micro), color .15s var(--ease-micro);background:0 0;border:none;place-items:center;display:grid}.export-close:hover{background:var(--surface-hover);color:var(--text-primary)}.export-desc{color:var(--text-secondary);padding:8px 20px 14px;font-size:12px;font-weight:300}.export-code{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);white-space:pre;tab-size:2;background:oklch(8% .004 260);flex:1;max-height:55vh;margin:0 12px;padding:14px;font-family:DM Mono,monospace;font-size:11px;line-height:1.6;overflow:auto}.export-code::-webkit-scrollbar{width:4px;height:4px}.export-code::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.export-actions{justify-content:flex-end;gap:8px;padding:14px 20px 18px;display:flex}.export-copy,.export-download{border-radius:var(--radius-sm);cursor:pointer;height:34px;transition:background-color .15s var(--ease-micro), color .15s var(--ease-micro), filter .15s var(--ease-micro);padding:0 18px;font-family:DM Sans,system-ui,sans-serif;font-size:12px;font-weight:500}.export-copy{background:var(--accent);color:oklch(10% 0 0);border:none}.export-copy:hover{filter:brightness(1.15)}.export-download{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.export-download:hover{background:var(--surface-hover);color:var(--text-primary)}.topbar-fps{color:var(--text-dim);letter-spacing:.04em;text-align:right;min-width:48px;font-family:DM Mono,monospace;font-size:11px;font-weight:300}.panel{top:var(--topbar-height);width:var(--panel-width);z-index:10;-webkit-backdrop-filter:blur(24px)saturate(1.3);border-left:1px solid var(--border);transition:transform .4s var(--ease-out);contain:layout style;will-change:transform;background:oklch(12% .006 260/.85);padding:20px 18px 32px;position:fixed;bottom:0;right:0;overflow:hidden auto}.panel.collapsed{transform:translateX(var(--panel-width))}.panel::-webkit-scrollbar{width:4px}.panel::-webkit-scrollbar-track{background:0 0}.panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.panel-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:background-color .15s var(--ease-micro), color .15s var(--ease-micro);place-items:center;display:grid;position:absolute;top:16px;left:-36px}.panel-toggle:hover{background:var(--surface-hover);color:var(--text-primary)}.panel.collapsed .panel-toggle svg{transform:rotate(180deg)}.panel-toggle svg{transition:transform .3s var(--ease-out)}.panel-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:14px;font-size:10px;font-weight:500}.panel-section{margin-bottom:4px}.panel-divider{background:var(--border);height:1px;margin:16px -18px}.preset-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.preset-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);height:30px;color:var(--text-secondary);cursor:pointer;transition:background-color .15s var(--ease-micro), color .15s var(--ease-micro), border-color .15s var(--ease-micro);white-space:nowrap;padding:0 12px;font-family:DM Sans,system-ui,sans-serif;font-size:11px;font-weight:400}.preset-btn:hover{background:var(--surface-hover);color:var(--text-primary);border-color:oklch(32% .015 260)}.preset-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--text-primary)}.preset-btn--custom{border-style:dashed}.preset-btn--custom.active{border-style:solid}.preset-btn--save{width:30px;color:var(--text-dim);border-style:dashed;padding:0;font-size:16px;font-weight:300}.preset-btn--save:hover{color:var(--accent);border-color:var(--accent-dim)}.preset-wrap{display:inline-flex;position:relative}.preset-wrap--custom:hover .preset-delete{opacity:1}.preset-delete{border:1px solid var(--border);background:var(--surface);width:16px;height:16px;color:var(--text-dim);cursor:pointer;opacity:0;transition:opacity .15s var(--ease-micro), color .15s var(--ease-micro);z-index:1;border-radius:50%;place-items:center;padding:0;font-size:11px;line-height:1;display:grid;position:absolute;top:-6px;right:-6px}.preset-delete:hover{color:oklch(70% .15 25);background:var(--surface-raised);border-color:oklch(50% .1 25)}.preset-name-input{border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--surface);width:80px;height:30px;color:var(--text-primary);outline:none;padding:0 8px;font-family:DM Sans,system-ui,sans-serif;font-size:11px}.preset-name-input::placeholder{color:var(--text-dim)}.control-group{flex-direction:column;gap:10px;display:flex}.control{cursor:default;grid-template-columns:90px 1fr 42px;align-items:center;gap:10px;display:grid}.control--color{grid-template-columns:90px 1fr}.control-name{color:var(--text-secondary);-webkit-user-select:none;user-select:none;font-size:12px;font-weight:400}.control-value{color:var(--text-dim);text-align:right;-webkit-user-select:none;user-select:none;letter-spacing:.02em;font-family:DM Mono,monospace;font-size:11px;font-weight:300}input[type=range]{appearance:none;background:var(--surface-raised);cursor:pointer;border-radius:2px;outline:none;width:100%;height:4px;position:relative}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--text-primary);cursor:grab;width:14px;height:14px;transition:transform .15s var(--ease-micro), box-shadow .15s var(--ease-micro);border:none;border-radius:50%;box-shadow:0 1px 4px oklch(0% 0 0/.4)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px oklch(92% .01 260/.1),0 1px 4px oklch(0% 0 0/.4)}input[type=range]::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.1)}input[type=range]::-moz-range-thumb{background:var(--text-primary);cursor:grab;border:none;border-radius:50%;width:14px;height:14px}input[type=range]::-moz-range-track{background:var(--surface-raised);border-radius:2px;height:4px}.color-swatch-wrap{justify-content:flex-end;align-items:center;display:flex;position:relative}.color-input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.color-swatch{border-radius:var(--radius-sm);pointer-events:none;width:28px;height:28px;transition:transform .15s var(--ease-micro);border:1px solid oklch(100% 0 0/.08)}.color-swatch-wrap:hover .color-swatch{transform:scale(1.08)}:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input[type=range]:focus-visible{outline:none}input[type=range]:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 3px var(--accent), 0 1px 4px oklch(0% 0 0/.4)}input[type=color]:focus-visible+.color-swatch{outline:2px solid var(--accent);outline-offset:2px}.preset-name-input:focus-visible{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px oklch(65% .15 260/.25)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}.panel{transition:none!important}}@media (width<=640px){.topbar{gap:8px;padding:0 12px}.topbar-title{display:none}.tab,.export-btn{padding:0 10px;font-size:11px}.topbar-fps{display:none}.panel{--panel-width:100vw;border-left:none;border-top:1px solid var(--border);border-radius:16px 16px 0 0;width:100%;height:50vh;inset:auto 0 0;transform:translateY(0)}.panel.collapsed{transform:translateY(calc(100% - 40px))}.panel-toggle{top:-36px;left:50%;transform:translate(-50%)}.panel.collapsed .panel-toggle svg{transform:rotate(-90deg)}.panel-toggle svg{transform:rotate(90deg)}.export-dialog{width:95vw;max-height:90vh}}
