/*! tailwindcss v4.2.4 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.start{inset-inline-start:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.grid{display:grid}.hidden{display:none}.inline{display:inline}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}@font-face{font-family:Fredoka;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(/fonts/fredoka-400-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Fredoka;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(/fonts/fredoka-400-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Fredoka;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(/fonts/fredoka-500-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Fredoka;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(/fonts/fredoka-500-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Fredoka;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(/fonts/fredoka-600-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Fredoka;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(/fonts/fredoka-600-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Fredoka;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(/fonts/fredoka-700-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Fredoka;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(/fonts/fredoka-700-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/jetbrains-mono-400-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/jetbrains-mono-400-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/jetbrains-mono-500-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/jetbrains-mono-500-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Nunito;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/nunito-400-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Nunito;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/nunito-400-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Nunito;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/nunito-500-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Nunito;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/nunito-500-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Nunito;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/nunito-600-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Nunito;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/nunito-600-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Nunito;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/nunito-700-latin-ext.woff2)format("woff2");unicode-range:u+100-2ba,u+2bd-2c5,u+2c7-2cc,u+2ce-2d7,u+2dd-2ff,u+304,u+308,u+329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Nunito;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/nunito-700-latin.woff2)format("woff2");unicode-range:u+??,u+131,u+152-153,u+2bb-2bc,u+2c6,u+2da,u+2dc,u+304,u+308,u+329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}:root{color-scheme:light;--bg:#f8effb;--bg-2:#ede8f5;--ink:#2f2452;--ink-soft:#6b5f8a;--ink-muted:#a094bb;--border:#ddd1e8;--outline:#ddd1e8;--sun:#f9a8d4;--sun-deep:#ec4899;--coral:#f472b6;--coral-deep:#db2777;--pink:#fbb6ce;--sky:#bae6fd;--sky-deep:#60a5fa;--teal:#7c3aed;--violet:#c4b5fd;--lime:#86efac;--cream:#f3eefb;--paper:#fff;--ease-back:cubic-bezier(.34,1.56,.64,1);--shadow-pop:0 2px 12px #2f24521a,0 1px 4px #2f24520f;--pink-soft:#fce7f3;--teal-soft:#ede9fe;--sky-soft:#e0f2fe;--violet-soft:#ede9fe;--sun-soft:#fdf2f8;--sidebar-w:320px;--topbar-h:122px;--studio-col-max:880px;--content-w:calc(var(--sidebar-w) + var(--studio-col-max) + 2rem)}@media (prefers-reduced-motion:reduce){*,:after,:before{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:after,:before{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}body{background:var(--bg);min-height:100dvh;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);-webkit-text-size-adjust:100%;font-family:Nunito,sans-serif;line-height:1.5;overflow-x:hidden}::selection{background:var(--pink);color:var(--ink)}.help{background:var(--cream);border:1px solid var(--border);width:14px;height:14px;color:var(--ink-muted);cursor:help;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-family:Fredoka,sans-serif;font-size:9px;font-weight:700;line-height:1;display:inline-flex;position:relative}.help:hover{background:var(--pink-soft);border-color:var(--coral);color:var(--ink)}.help:before{content:"";width:44px;height:44px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.tip-floater{z-index:1000;pointer-events:none;background:var(--ink);color:var(--paper);text-align:center;opacity:0;border-radius:8px;max-width:min(260px,100vw - 24px);padding:.5rem .75rem;font-family:Fredoka,sans-serif;font-size:.74rem;font-weight:500;line-height:1.4;transition:opacity .12s,transform .12s;position:fixed;top:0;left:0;transform:translateY(2px);box-shadow:0 4px 12px #2f245226}.tip-floater.show{opacity:1;transform:translateY(0)}.tip-arrow{border-left:6px solid #0000;border-right:6px solid #0000;width:0;height:0;margin-left:-6px;position:absolute}.tip-floater[data-placement=top] .tip-arrow{border-top:6px solid var(--ink);bottom:-6px}.tip-floater[data-placement=bottom] .tip-arrow{border-bottom:6px solid var(--ink);top:-6px}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--coral)}::-webkit-scrollbar-corner{background:0 0}.sidebar{scrollbar-color:transparent transparent}.sidebar:hover{scrollbar-color:var(--border) transparent}.sidebar::-webkit-scrollbar{width:5px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:0 0;border-radius:999px}.sidebar:hover::-webkit-scrollbar-thumb{background:var(--border)}.sidebar:hover::-webkit-scrollbar-thumb:hover{background:var(--coral)}.topbar{z-index:200}.topbar-inner{max-width:var(--content-w);height:100%;margin:0 auto;padding:.52rem 1rem}.topbar-brand{letter-spacing:-.01em;color:var(--ink);-webkit-tap-highlight-color:transparent;outline:none;align-items:center;gap:.5rem;font-family:Fredoka,sans-serif;font-size:1.05rem;font-weight:700;display:flex}.topbar-brand,.topbar-brand:hover{text-decoration:none}.topbar-logo{object-fit:contain;width:auto;max-width:min(60vw,260px);height:30px;display:block}.topbar-nav{align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;display:flex}.topbar-nav-link{letter-spacing:.01em;padding:.3rem .7rem;font-size:.78rem}.topbar-brand,.topbar-nav,.topbar-nav-link{white-space:nowrap}.app{grid-template-columns:var(--sidebar-w) 1fr;min-height:calc(100vh - var(--topbar-h));min-height:calc(100dvh - var(--topbar-h));max-width:var(--content-w);margin:0 auto;display:grid}.sb-extras{display:contents}.sb-extras-toggle{display:none}.sb-extras-body{display:contents}.sidebar{background:var(--paper);border-right:1px solid var(--border);max-height:calc(100vh - var(--topbar-h));max-height:calc(100dvh - var(--topbar-h));gap:.9rem;padding:1rem;position:sticky;top:0;overflow:hidden auto}.sb-section,.sidebar{flex-direction:column;min-width:0;display:flex}.sb-section{gap:.5rem}.sb-heading{color:var(--ink-muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:.4rem;font-family:Fredoka,sans-serif;font-size:.72rem;font-weight:700;display:flex}.sb-heading-ico{filter:grayscale(.1);flex-shrink:0;font-size:.95rem;line-height:1}.main{--studio-col:min(100%,max(calc(100dvh - 240px),380px),880px);flex-direction:column;gap:.9rem;min-width:0;padding:0 1rem;display:flex}.main>.ad-slot,.main>.canvas-meta,.main>.card,.main>.stage-toolbar,.main>.stage-wrap{width:100%;max-width:var(--studio-col);margin-left:auto;margin-right:auto}.stage-toolbar{background:var(--paper);border:1px solid var(--border);border-radius:14px;justify-content:space-between;align-items:center;gap:.5rem;padding:.4rem .5rem;display:flex;box-shadow:0 1px 3px #2f24520f}.stage-toolbar-left{align-items:center;gap:.4rem;display:flex}.canvas-meta{background:var(--cream);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;align-items:center;gap:.35rem;padding:.55rem .75rem;display:flex;box-shadow:0 1px 3px #2f24520f}.wh-recipe,.wh-stats{scrollbar-width:none;touch-action:pan-x;overscroll-behavior:contain;flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:.4rem;display:flex;overflow:auto hidden}.wh-recipe::-webkit-scrollbar,.wh-stats::-webkit-scrollbar{display:none}.wh-stat{color:var(--ink-soft);white-space:nowrap;font-family:Fredoka,sans-serif;font-size:.82rem}.wh-stat b{color:var(--ink);font-size:.92rem}.wh-stat b,.wh-stat-sep{font-family:Fredoka,sans-serif;font-weight:700}.wh-stat-sep{color:var(--ink-muted)}.wh-chip{color:var(--ink-soft);background:var(--cream);border:1px solid var(--border);white-space:nowrap;border-radius:100px;align-items:baseline;gap:.3rem;padding:.22rem .65rem;font-size:.78rem;display:inline-flex}.wh-chip,.wh-chip b{font-family:Fredoka,sans-serif}.wh-chip b{color:var(--ink);font-size:.84rem;font-weight:700}.wh-chip.accent,.wh-help{background:var(--paper)}.wh-help{margin-left:.1rem}.stage-wrap{width:var(--studio-col,min(100%,calc(100vh - 240px),880px));aspect-ratio:1;flex-direction:column;flex:none;margin:0 auto;display:flex;position:relative}.stage{background:var(--cream);border:1px solid var(--border);text-align:center;box-shadow:inset 0 0 0 2px var(--paper);touch-action:auto;-webkit-overflow-scrolling:touch;border-radius:14px;flex:1;width:100%;min-height:0;padding:.75rem;display:block;overflow:hidden}.stage.zoomed{touch-action:pan-x pan-y;cursor:grab}.stage.panning{cursor:grabbing;-webkit-user-select:none;user-select:none}.stage.panning .canvas-holder{pointer-events:none}.zoom-ctrls{gap:.25rem;padding:.2rem .35rem}.zoom-ctrls,.zoom-ctrls button{border:1px solid var(--border);border-radius:100px;align-items:center;font-family:Fredoka,sans-serif;display:inline-flex}.zoom-ctrls button{background:var(--cream);cursor:pointer;min-width:28px;height:28px;color:var(--ink);justify-content:center;padding:0 .35rem;font-size:1rem;font-weight:700;line-height:1;transition:background .12s}.zoom-ctrls button:hover{background:var(--pink-soft);border-color:var(--coral)}.zoom-ctrls button:active{background:var(--cream)}.download-cluster{flex-shrink:0;position:relative}.download-overlay{white-space:nowrap;background-color:var(--coral);color:#fff;cursor:pointer;border:none;border-radius:100px;align-items:center;gap:.45rem;padding:.55rem 1rem;font-family:Fredoka,sans-serif;font-size:.95rem;font-weight:700;transition:background-color .15s,transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 2px 8px #db27774d}.download-overlay:hover,.download-overlay[aria-expanded=true]{background-color:var(--coral-deep);transform:translateY(-1px);box-shadow:0 4px 12px #db277759}.download-overlay:active{transform:translateY(0);box-shadow:0 1px 4px #db277733}.download-overlay .download-ico{font-size:1.05rem;line-height:1}.download-overlay .download-caret{margin-left:.15rem;font-size:.75rem;line-height:1;transition:transform .15s}.download-overlay[aria-expanded=true] .download-caret{transform:rotate(180deg)}.download-menu{background:var(--paper);border:1px solid var(--border);opacity:0;visibility:hidden;pointer-events:none;z-index:50;border-radius:14px;flex-direction:column;gap:.25rem;min-width:420px;padding:.35rem;transition:opacity .14s,transform .14s,visibility .14s;display:flex;position:absolute;top:calc(100% + .5rem);right:0;transform:translateY(-4px);box-shadow:0 4px 16px #2f24521f}.dl-menu-row{grid-template-columns:1fr 1fr;gap:.2rem;display:grid}.dl-menu-item--wide{grid-column:1/-1}@media (max-width:480px){.download-menu{min-width:min(280px,100vw - 2rem)}.dl-menu-row{grid-template-columns:1fr}}.download-menu:before{content:"";height:calc(.5rem + 4px);position:absolute;bottom:100%;left:0;right:0}.download-cluster:focus-within .download-menu,.download-cluster:hover .download-menu,.download-overlay[aria-expanded=true]+.download-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}.download-menu-item{text-align:left;color:var(--ink);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;flex-direction:column;align-items:flex-start;gap:.1rem;padding:.55rem .7rem;font-family:Fredoka,sans-serif;transition:background .1s,border-color .1s;display:flex}.download-menu-item:focus-visible,.download-menu-item:hover{background:var(--cream);border-color:var(--border);outline:none}.dl-menu-title{font-size:.92rem;font-weight:700;line-height:1.1}.dl-menu-sub{color:var(--ink-soft);font-family:Nunito,sans-serif;font-size:.72rem;font-weight:500}.download-menu-item.is-disabled{opacity:.4;cursor:not-allowed}.download-menu-item.is-disabled:focus-visible,.download-menu-item.is-disabled:hover{background:0 0;border-color:#0000}.toggle.is-disabled{opacity:.4;cursor:not-allowed}.zoom-ctrls #zoom-reset{background:var(--cream);min-width:46px;font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:600}.canvas-holder{border-radius:6px;display:inline-block;position:relative;overflow:hidden}canvas{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;display:block}.highlight-layer{image-rendering:pixelated;top:0;left:0}.drop-hint,.highlight-layer{pointer-events:none;position:absolute}.drop-hint{z-index:5;border:2px dashed var(--coral-deep);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);color:var(--ink);background:#f9a8d480;border-radius:12px;justify-content:center;align-items:center;display:none;inset:.75rem}.drop-hint-inner{background:var(--paper);border:1px solid var(--border);border-radius:100px;align-items:center;gap:.6rem;padding:.75rem 1.1rem;font-family:Fredoka,sans-serif;font-size:1rem;font-weight:700;display:inline-flex;box-shadow:0 2px 8px #2f24521a}.drop-hint-emoji{font-size:1.2rem}.stage.dragging .drop-hint{display:flex}.stage.dragging .canvas-holder{opacity:.35;transition:opacity .15s}.card{background:var(--paper);border:1px solid var(--border);border-radius:16px;padding:.9rem 1rem;box-shadow:0 1px 3px #2f24520f}.card-head{justify-content:space-between;margin-bottom:.6rem}.card-head,.card-title{align-items:center;display:flex}.card-title{color:var(--ink);gap:.35rem;font-size:1rem;font-weight:700}.ad-slot,.card-title{font-family:Fredoka,sans-serif}.ad-slot{border:1px dashed var(--border);background:var(--paper);min-height:90px;color:var(--ink-muted);text-align:center;border-radius:12px;justify-content:center;align-items:center;font-size:.75rem;display:none}body[data-ads=on] .ad-slot{display:flex}.footer-info{margin-top:1.5rem;padding:2rem 1.5rem 3rem}.view-studio .footer-info{display:none}.footer-info h2{color:var(--ink);margin-bottom:.5rem;font-size:1.35rem;font-weight:700}.footer-info h2,.footer-info>p{text-align:center;font-family:Fredoka,sans-serif}.footer-info>p{color:var(--ink-soft);margin-bottom:1.25rem;font-size:.85rem;font-weight:500}.faq{background:var(--paper);border:1px solid var(--border);border-radius:12px;margin-bottom:.5rem;overflow:hidden;box-shadow:0 1px 3px #2f24520d}.faq summary{cursor:pointer;color:var(--ink);justify-content:space-between;align-items:center;padding:.65rem 1rem;font-family:Fredoka,sans-serif;font-size:.88rem;font-weight:600;list-style:none;display:flex}.faq summary::-webkit-details-marker{display:none}.faq summary:after{content:"+";color:var(--coral);font-size:1.2rem;font-weight:600;transition:transform .2s}.faq[open] summary:after{transform:rotate(45deg)}.faq-body{color:var(--ink-soft);border-top:1px solid var(--border);padding:.5rem 1rem .75rem;font-size:.82rem;line-height:1.5}.contact-card{text-align:center;background:var(--cream);border:1px solid var(--border);max-width:480px;box-shadow:var(--shadow-pop);border-radius:16px;margin:2rem auto 0;padding:1.1rem 1.4rem 1.3rem}.contact-title{color:var(--ink);margin:0 0 .35rem;font-family:Fredoka,sans-serif;font-size:1.05rem;font-weight:700}.contact-body{color:var(--ink-soft);margin:0 0 .9rem;font-family:Nunito,sans-serif;font-size:.9rem;line-height:1.5}.contact-btn{background:var(--coral);color:#fff;border:none;border-radius:999px;align-items:center;gap:.5rem;padding:.55rem 1.1rem;font-family:Fredoka,sans-serif;font-weight:600;text-decoration:none;transition:background .15s,transform .15s;display:inline-flex;box-shadow:0 2px 8px #db277740}.contact-btn:hover{background:var(--coral-deep);transform:translateY(-1px)}.foot-credit{text-align:center;max-width:var(--content-w);padding:0 1rem calc(2rem + env(safe-area-inset-bottom));color:var(--ink-muted);margin:1.5rem auto 0;font-family:Fredoka,sans-serif;font-size:.72rem}.foot-version{color:var(--ink-muted);text-underline-offset:2px;cursor:pointer;opacity:.7;background:0 0;border:none;margin-left:.5rem;padding:0;font-family:JetBrains Mono,monospace;font-size:.68rem;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;display:inline-block}.foot-version:hover{opacity:1;color:var(--ink)}.foot-link{color:var(--ink-muted);text-underline-offset:2px;text-decoration:underline}.foot-link:hover{color:var(--ink)}.foot-credit>span[aria-hidden]{opacity:.5;margin:0 .3rem}.foot-legal{margin-top:.6rem;font-size:.72rem;display:block}.foot-legal a{color:var(--ink-muted);text-underline-offset:2px;text-decoration:underline}.foot-legal a:hover{color:var(--ink)}.foot-legal a[aria-current=page]{color:var(--coral)}.foot-legal span{opacity:.5;margin:0 .4rem}.toast{background:var(--ink);color:var(--paper);opacity:0;pointer-events:none;z-index:400;border-radius:100px;padding:.55rem 1rem;font-family:Fredoka,sans-serif;font-size:.82rem;font-weight:500;transition:opacity .25s,transform .25s;position:fixed;bottom:1rem;left:50%;transform:translate(-50%,20px);box-shadow:0 4px 16px #2f245233}.toast.show{opacity:1;transform:translate(-50%)}.upload-btn{background-color:var(--coral);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.4rem;width:100%;padding:.6rem .9rem;font-family:Fredoka,sans-serif;font-size:.9rem;font-weight:600;transition:background-color .15s,transform .12s;display:inline-flex;box-shadow:0 2px 8px #db277740}.upload-btn:hover{background-color:var(--coral-deep);transform:translateY(-1px)}.upload-btn:active{transform:translateY(0)}.upload-filename{color:var(--ink-muted);text-align:center;white-space:nowrap;text-overflow:ellipsis;font-family:Fredoka,sans-serif;font-size:.72rem;overflow:hidden}.slider-group{flex-direction:column;gap:.3rem;display:flex}.slider-label{color:var(--ink-soft);justify-content:space-between;align-items:center;font-family:Fredoka,sans-serif;font-size:.78rem;display:flex}.slider-label-name{align-items:center;gap:.3rem;font-weight:500;display:inline-flex}.slider-val{color:#fff;text-align:center;background:#fb923c;border-radius:6px;min-width:32px;padding:1px 7px;font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:700}input[type=range]{appearance:none;cursor:pointer;background:0 0;width:100%;height:24px;padding:0}input[type=range]::-webkit-slider-runnable-track{background:var(--cream);border:1px solid var(--border);border-radius:100px;height:5px}input[type=range]::-moz-range-track{background:var(--cream);border:1px solid var(--border);border-radius:100px;height:5px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--coral);cursor:grab;border:2px solid #fff;border-radius:50%;width:18px;height:18px;margin-top:-7px;box-shadow:0 1px 4px #db27774d}input[type=range]::-moz-range-thumb{background:var(--coral);cursor:grab;border:2px solid #fff;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 4px #db27774d}@media (pointer:coarse){input[type=range]{height:32px}input[type=range]::-webkit-slider-thumb{width:28px;height:28px;margin-top:-12px}input[type=range]::-moz-range-thumb{width:28px;height:28px}}.toggles{flex-wrap:wrap;gap:.3rem;display:flex}.toggle{background:var(--paper);border:1px solid var(--border);color:var(--ink-soft);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:100px;align-items:center;gap:.3rem;padding:.28rem .55rem;font-family:Fredoka,sans-serif;font-size:.73rem;font-weight:500;transition:all .12s;display:inline-flex}.toggle input{display:none}.toggle .tgl-dot{border:1.5px solid var(--border);background:var(--cream);border-radius:3px;flex-shrink:0;width:10px;height:10px;transition:background .12s,border-color .12s}.toggle.on{background:var(--pink-soft);border-color:var(--coral);color:var(--ink)}.toggle.on .tgl-dot{background:var(--coral);border-color:var(--coral)}.toggle-grid{gap:.35rem;padding-right:.35rem}.grid-col-picker{background:var(--paper);border:1px solid var(--border);border-radius:100px;align-items:center;gap:2px;margin-left:.15rem;padding:2px;display:inline-flex}.grid-col{border:1px solid var(--border);cursor:pointer;width:14px;height:14px;box-shadow:none;border-radius:50%;padding:0;transition:transform .1s}.grid-col-dark{background:var(--ink)}.grid-col-light{border-color:var(--border);background:#fff}.grid-col:hover{transform:scale(1.1)}.grid-col.active{box-shadow:0 0 0 2px var(--coral-deep)}.toggle:not(.on) .grid-col-picker{opacity:.45;pointer-events:none}.brush-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.35rem;min-width:0;display:grid}.brush-btn{aspect-ratio:1;background:var(--paper);border:1px solid var(--border);cursor:pointer;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;min-width:0;padding:0;font-family:Fredoka,sans-serif;font-weight:600;transition:border-color .12s,background .12s;display:flex;position:relative;box-shadow:0 1px 3px #2f24520f}.brush-btn:hover{border-color:var(--coral);background:var(--pink-soft)}.brush-btn.active{background:var(--coral);border-color:var(--coral);color:#fff;box-shadow:0 2px 8px #db277740}.brush-dot{background:currentColor;border-radius:2px;flex-shrink:0}.brush-px{color:var(--ink-muted);margin-top:.15rem;font-size:.6rem;line-height:1}.brush-btn.active .brush-px{color:#ffffffd9;font-weight:700}.brush-btn.active .brush-dot{background:#fff}.brush-meta{color:var(--ink-soft);background:var(--cream);border:1px dashed var(--border);border-radius:8px;padding:.28rem .5rem;font-size:.72rem}.brush-hint,.brush-meta{text-align:center;font-family:Fredoka,sans-serif}.brush-hint{color:var(--ink-muted);letter-spacing:.02em;margin-top:-.1rem;font-size:.66rem;font-weight:500}.preset-row{flex-wrap:wrap;gap:.3rem;display:flex}.card-actions{gap:.35rem;display:flex}.action-btn{background:var(--paper);color:var(--ink-soft);border:1px solid var(--border);cursor:pointer;border-radius:100px;align-items:center;gap:.3rem;padding:.3rem .6rem;font-family:Fredoka,sans-serif;font-size:.74rem;font-weight:600;transition:border-color .12s,color .12s,background .12s;display:inline-flex}.action-btn:hover{border-color:var(--coral);color:var(--ink);background:var(--pink-soft)}.action-btn .action-ico{font-size:.9rem;line-height:1}.preset-btn{background:var(--paper);border:1px solid var(--border);cursor:pointer;color:var(--ink-soft);border-radius:100px;padding:.28rem .65rem;font-family:Fredoka,sans-serif;font-size:.73rem;font-weight:500;transition:all .12s}.preset-btn:hover{background:var(--cream);border-color:var(--coral);color:var(--ink)}.preset-btn.active{background:var(--violet);color:var(--ink);border-color:#0000}#brush-mode-row .preset-btn.active{background:var(--sky);color:var(--ink);border-color:#0000}.hex-lookup-row{align-items:center;gap:.4rem;display:flex}.hex-lookup-picker{background:var(--paper);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex-shrink:0;width:2rem;height:2rem;padding:0}.hex-lookup-picker::-webkit-color-swatch-wrapper{padding:2px}.hex-lookup-picker::-webkit-color-swatch{border:none;border-radius:4px}.hex-lookup-picker::-moz-color-swatch{border:none;border-radius:4px}.hex-lookup-input{background:var(--paper);min-width:0;color:var(--ink);border:1px solid var(--border);text-transform:uppercase;border-radius:6px;flex:1;padding:.35rem .55rem;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:600}.hex-lookup-input.invalid{border-color:var(--coral-deep);background:#f472b614}.hex-lookup-readout{background:var(--cream);border:1px dashed var(--border);color:var(--ink);text-align:center;border-radius:6px;padding:.35rem .55rem;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:700}.hex-lookup-hint{color:var(--ink-muted);text-align:center;font-size:.68rem}.canvas-preset-grid{flex-direction:column;gap:.3rem;display:flex}.canvas-preset{background:var(--paper);color:var(--ink);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:12px;flex-direction:row;align-items:flex-start;gap:.7rem;min-width:0;padding:.65rem .85rem;font-family:Fredoka,sans-serif;line-height:1.1;display:flex;position:relative}.canvas-preset,.canvas-preset:before{transition:border-color .12s,background .12s}.canvas-preset:before{content:"";border:1.5px solid var(--border);border-radius:50%;flex-shrink:0;width:17px;height:17px;margin-top:.1rem}.canvas-preset:hover{background:var(--cream)}.canvas-preset:hover,.canvas-preset:hover:before{border-color:var(--coral)}.canvas-preset.active{background:var(--sky-soft,#e0f2fe);border-color:var(--sky-deep)}.canvas-preset.active:before{background:var(--sky-deep);border-color:var(--sky-deep)}.canvas-preset-aspect{display:none}.canvas-preset-label{color:var(--ink);font-size:.82rem;font-weight:700}.canvas-preset-sub{color:var(--ink-muted);margin-top:.15rem;font-size:.68rem;font-weight:500;display:block}.canvas-preset.active .canvas-preset-label{color:var(--ink)}.canvas-preset.active .canvas-preset-sub{color:var(--ink-soft)}.adj-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.25rem;margin-top:.1rem;display:grid}.adj-btn{background:var(--paper);color:var(--ink-soft);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:.35rem .1rem;font-family:Fredoka,sans-serif;font-size:.72rem;font-weight:600;line-height:1;transition:border-color .12s,background .12s}.adj-btn:hover{background:var(--cream);border-color:var(--coral);color:var(--ink)}.adj-btn.active{background:var(--lime);color:var(--ink);border-color:#0000}.adj-slider{margin-top:.1rem}.adj-reset{color:var(--ink-soft);border:1px dashed var(--border);cursor:pointer;background:0 0;border-radius:100px;align-self:flex-end;align-items:center;gap:.35rem;padding:.3rem .65rem;font-family:Fredoka,sans-serif;font-size:.7rem;font-weight:500;transition:color .1s,border-color .1s;display:inline-flex}.adj-reset:hover{color:var(--ink);border-color:var(--coral)}.upload-replace-wrap{border-top:1px dashed var(--border);flex-direction:column;gap:.3rem;margin-top:.5rem;padding-top:.55rem;display:flex}.upload-replace{background:var(--cream);color:var(--ink-soft);border:1px dashed var(--border);cursor:pointer;border-radius:100px;justify-content:center;align-items:center;gap:.4rem;padding:.4rem .75rem;font-family:Fredoka,sans-serif;font-size:.78rem;font-weight:600;transition:color .12s,border-color .12s,background .12s;display:inline-flex}.upload-replace:hover{color:var(--ink);border-color:var(--coral);background:var(--pink-soft);border-style:solid}.upload-replace span{font-size:.95rem;line-height:1}.pal-ban{background:var(--coral-deep);color:#fff;pointer-events:none;z-index:4;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:44%;height:44%;font-family:Fredoka,sans-serif;font-size:.7em;font-weight:700;display:none;position:absolute;bottom:-6%;left:-6%;box-shadow:0 1px 3px #2f245233}.pal-cell.excluded .pal-ban{display:flex}.pal-cell.excluded{filter:grayscale(.8);opacity:.55}.pal-cell.excluded .pal-blob{opacity:.5}.swatch.excluded{opacity:.55;filter:grayscale(.6)}.swatch .swatch-box{position:relative}.swatch-ban{color:#fff;border:1px solid var(--coral-deep);pointer-events:none;background:#db2777d9;border-radius:8px;justify-content:center;align-items:center;font-family:Fredoka,sans-serif;font-size:1.2rem;font-weight:800;display:none;position:absolute;inset:-4px}.swatch.excluded .swatch-ban{display:flex}.excluded-strip{background:var(--pink-soft);border:1px dashed var(--coral);border-radius:10px;flex-wrap:wrap;flex-basis:100%;align-items:center;gap:.35rem;margin-bottom:.6rem;padding:.5rem .6rem;display:flex}.excluded-strip-title{color:var(--ink);letter-spacing:.02em;font-family:Fredoka,sans-serif;font-size:.72rem;font-weight:700}.excluded-chip{background:var(--paper);border:1px solid var(--border);cursor:pointer;color:var(--ink);border-radius:100px;align-items:center;gap:.3rem;padding:.2rem .5rem;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:600;transition:border-color .12s,background .12s;display:inline-flex}.excluded-chip:hover{background:var(--pink-soft);border-color:var(--coral)}.excluded-chip-dot{border:1px solid var(--border);border-radius:3px;width:12px;height:12px}.excluded-chip-x{color:var(--coral-deep)}.excluded-chip-x,.excluded-clear{font-family:Fredoka,sans-serif;font-weight:700}.excluded-clear{background:var(--coral-deep);color:#fff;cursor:pointer;border:none;border-radius:100px;margin-left:auto;padding:.2rem .6rem;font-size:.7rem}.excluded-clear:hover{background:#be185d}.pal-cell.completed:not(.excluded){opacity:.45;filter:saturate(.6)}.pal-cell.completed:not(.excluded) .pal-blob{opacity:.7}.swatch.completed:not(.excluded){opacity:.5;filter:saturate(.6)}.swatch.completed:not(.excluded) .swatch-box:after{content:"";background:linear-gradient(to top right,transparent calc(50% - 1.5px),var(--ink) calc(50% - 1.5px),var(--ink) calc(50% + 1.5px),transparent calc(50% + 1.5px));pointer-events:none;position:absolute;inset:0}.swatch.completed:not(.excluded) .swatch-hex{text-decoration:line-through}.swatch-menu{z-index:1200;background:var(--paper);border:1px solid var(--border);border-radius:10px;min-width:180px;padding:.35rem;font-family:Fredoka,sans-serif;display:none;position:fixed;box-shadow:0 4px 16px #2f24521f}.swatch-menu.show{display:block}.swatch-menu-head{border-bottom:1px dashed var(--border);align-items:center;gap:.4rem;margin-bottom:.3rem;padding:.25rem .5rem .35rem;display:flex}.swatch-menu-dot{border:1px solid var(--border);border-radius:3px;width:14px;height:14px}.swatch-menu-hex{color:var(--ink);font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:600}.swatch-menu-item{text-align:left;width:100%;color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .55rem;font-family:Fredoka,sans-serif;font-size:.8rem;font-weight:600;display:block}.swatch-menu-item:hover{background:var(--cream)}.modal-backdrop{z-index:1100;opacity:0;visibility:hidden;pointer-events:none;background:#2f245266;justify-content:center;align-items:center;padding:1rem;transition:opacity .15s,visibility .15s;display:flex;position:fixed;inset:0}.modal-backdrop.show{opacity:1;visibility:visible;pointer-events:auto}.modal-card{background:var(--paper);border:1px solid var(--border);width:100%;max-width:560px;max-height:calc(100dvh - 2rem);transition:transform .32s var(--ease-back);border-radius:16px;padding:1.3rem 1.4rem 1.4rem;position:relative;overflow:auto;transform:translateY(10px)scale(.96);box-shadow:0 8px 32px #2f245226}.modal-backdrop.show .modal-card{transform:translateY(0)scale(1)}.modal-close{background:var(--cream);width:30px;height:30px;color:var(--ink);border:1px solid var(--border);cursor:pointer;transition:transform .3s var(--ease-back),background .15s ease;border-radius:100px;justify-content:center;align-items:center;padding:0;font-family:Fredoka,sans-serif;font-size:.85rem;font-weight:700;display:inline-flex;position:absolute;top:.6rem;right:.6rem}.modal-close:hover{background:var(--pink-soft);transform:rotate(90deg)}.modal-card h2{color:var(--ink);margin:0 0 .35rem;font-family:Fredoka,sans-serif;font-size:1.3rem;font-weight:700}.modal-sub{color:var(--ink-soft);margin:0 0 1rem;font-family:Nunito,sans-serif;font-size:.85rem;line-height:1.45}.shortcuts-group{margin-bottom:.9rem}.shortcuts-group h3{color:var(--ink-muted);text-transform:uppercase;letter-spacing:.1em;margin:0 0 .4rem;font-family:Fredoka,sans-serif;font-size:.7rem;font-weight:700}.shortcuts-group dl{grid-template-columns:1fr;gap:.25rem;margin:0;display:grid}.shortcuts-group dl>div{border-bottom:1px dashed var(--border);grid-template-columns:max-content 1fr;align-items:baseline;column-gap:.9rem;padding:.3rem 0;display:grid}.shortcuts-group dl>div:last-child{border-bottom:none}.shortcuts-group dt{margin:0}.shortcuts-group dd{color:var(--ink);margin:0;font-family:Fredoka,sans-serif;font-size:.84rem;line-height:1.35}.shortcuts-group kbd{background:var(--cream);color:var(--ink);border:1px solid var(--border);white-space:nowrap;border-radius:6px;padding:.15rem .45rem;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:600;display:inline-block}@media (max-width:520px){.adj-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.shortcuts-group dl>div{grid-template-columns:1fr;row-gap:.15rem}.shortcuts-group dt{margin-bottom:.1rem}}.hsb-modal{z-index:1000;justify-content:center;align-items:center;padding:1rem;display:none;position:fixed;inset:0}.hsb-modal.show{display:flex}.hsb-modal-backdrop{-webkit-backdrop-filter:blur(3px);cursor:pointer;background:#2f245266;position:absolute;inset:0}.hsb-modal-card{background:var(--paper);border:1px solid var(--border);border-radius:16px;outline:none;width:100%;max-width:540px;max-height:calc(100vh - 2rem);padding:1.4rem 1.4rem 1.2rem;position:relative;overflow-y:auto;box-shadow:0 8px 32px #2f245226}.hsb-modal-close{cursor:pointer;width:2rem;height:2rem;color:var(--ink);background:0 0;border:none;font-family:Fredoka,sans-serif;font-size:1.6rem;font-weight:500;line-height:1;position:absolute;top:.5rem;right:.7rem}.hsb-modal-close:hover{transition:transform .2s;transform:rotate(90deg)}.hsb-modal-title{color:var(--ink);margin:0 0 .25rem;padding-right:2rem;font-family:Fredoka,sans-serif;font-size:1.25rem;font-weight:700}.hsb-modal-sub{color:var(--ink-soft);margin:0 0 1rem;font-size:.85rem}.hsb-modal-steps{counter-reset:hsb-step;flex-direction:column;gap:.7rem;margin:0 0 1rem;padding:0;list-style:none;display:flex}.hsb-modal-steps li{counter-increment:hsb-step;background:var(--cream);border:1px solid var(--border);color:var(--ink);border-radius:10px;padding:.55rem .7rem .55rem 2.4rem;font-size:.88rem;line-height:1.45;position:relative}.hsb-modal-steps li:before{content:counter(hsb-step);background:var(--coral);color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-family:Fredoka,sans-serif;font-size:.85rem;font-weight:700;display:flex;position:absolute;top:.5rem;left:.5rem}.hsb-modal-steps b{font-weight:700}.hsb-modal-steps i{color:var(--ink-soft);font-style:italic}.hsb-modal-callout{border:1px dashed var(--border);color:var(--ink);background:#86efac33;border-radius:10px;margin-bottom:1rem;padding:.6rem .8rem;font-size:.85rem}.hsb-modal-warn{background:var(--pink-soft);border-style:solid;border-color:var(--coral)}.hsb-modal-credit{border:1px dashed var(--border);color:var(--ink-soft);background:0 0;font-size:.78rem;font-style:italic}.hsb-modal-credit b{color:var(--ink);font-style:normal}.hsb-modal-ok{background:var(--coral);color:#fff;cursor:pointer;border:none;border-radius:100px;width:100%;padding:.6rem 1rem;font-family:Fredoka,sans-serif;font-size:.95rem;font-weight:600;transition:background .15s;display:block}.hsb-modal-ok:hover{background:var(--coral-deep)}body.hsb-modal-open{overflow:hidden}.changelog-modal{z-index:1000;justify-content:center;align-items:center;padding:1rem;display:none;position:fixed;inset:0}.changelog-modal.show{display:flex}.changelog-modal-backdrop{-webkit-backdrop-filter:blur(3px);cursor:pointer;background:#2f245266;position:absolute;inset:0}.changelog-modal-card{background:var(--paper);border:1px solid var(--border);border-radius:16px;outline:none;width:100%;max-width:620px;max-height:calc(100vh - 2rem);padding:1.4rem 1.4rem 1.2rem;position:relative;overflow-y:auto;box-shadow:0 8px 32px #2f245226}.changelog-modal-close{cursor:pointer;width:2rem;height:2rem;color:var(--ink);background:0 0;border:none;font-family:Fredoka,sans-serif;font-size:1.6rem;font-weight:500;line-height:1;position:absolute;top:.5rem;right:.7rem}.changelog-modal-close:hover{transition:transform .2s;transform:rotate(90deg)}.changelog-modal-title{color:var(--ink);margin:0 0 .25rem;padding-right:2rem;font-family:Fredoka,sans-serif;font-size:1.25rem;font-weight:700}.changelog-modal-sub{color:var(--ink-soft);margin:0 0 1.1rem;font-size:.85rem}.changelog-list{flex-direction:column;gap:1rem;margin-bottom:1.1rem;display:flex}.cl-entry{border:1px solid var(--border);background:var(--paper);border-radius:10px;padding:.75rem .9rem .85rem}.cl-entry-current{background:var(--pink-soft)}.cl-entry-head{flex-wrap:wrap;align-items:baseline;gap:.4rem .55rem;margin-bottom:.55rem;display:flex}.cl-entry-version{font-size:1rem;font-weight:700}.cl-entry-title,.cl-entry-version{color:var(--ink);font-family:Fredoka,sans-serif}.cl-entry-title{font-size:.95rem;font-weight:600}.cl-entry-date{color:var(--ink-muted);margin-left:auto;font-family:JetBrains Mono,monospace;font-size:.72rem}.cl-current{text-transform:uppercase;letter-spacing:.06em;color:#fff;background:var(--coral);border:none;border-radius:100px;padding:.05rem .5rem;font-family:Fredoka,sans-serif;font-size:.7rem;font-weight:600}.cl-entry-changes{color:var(--ink);flex-direction:column;gap:.3rem;margin:0;padding-left:1.1rem;font-size:.85rem;line-height:1.5;display:flex}.cl-entry-changes li::marker{color:var(--ink-muted)}.changelog-modal-ok{background:var(--coral);color:#fff;cursor:pointer;border:none;border-radius:100px;width:100%;padding:.6rem 1rem;font-family:Fredoka,sans-serif;font-size:.95rem;font-weight:600;transition:background .15s;display:block}.changelog-modal-ok:hover{background:var(--coral-deep)}body.changelog-modal-open{overflow:hidden}.hsb-guide-btn{background:var(--cream);color:var(--ink-soft);border:1px solid var(--border);cursor:pointer;border-radius:100px;align-items:center;gap:.4rem;margin-left:.5rem;padding:.3rem .7rem .3rem .5rem;font-family:Fredoka,sans-serif;font-size:.78rem;font-weight:600;transition:border-color .12s,background .12s,color .12s;display:inline-flex}.hsb-guide-btn:hover{border-color:var(--coral);background:var(--pink-soft);color:var(--ink)}.hsb-guide-ico{background:var(--paper);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;font-weight:700;display:inline-flex}body[data-palette-mode=game] .hsb-guide-btn{display:none}@media (max-width:520px){.hsb-guide-text{display:none}.hsb-guide-btn{padding:.3rem .5rem}}.frame-modal{z-index:1000;justify-content:center;align-items:center;padding:1rem;display:none;position:fixed;inset:0}.frame-modal.show{display:flex}.frame-modal-backdrop{-webkit-backdrop-filter:blur(3px);cursor:pointer;background:#2f245280;position:absolute;inset:0}.frame-modal-card{background:var(--paper);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:100%;max-width:min(900px,100vw - 2rem);max-height:calc(100vh - 2rem);display:flex;position:relative;box-shadow:0 8px 32px #2f245226}.frame-modal-head{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:.7rem 1rem;display:flex}.frame-modal-title{color:var(--ink);font-family:Fredoka,sans-serif;font-size:1.05rem;font-weight:700}.frame-modal-readout{min-width:0;color:var(--ink-muted);text-align:center;white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:JetBrains Mono,monospace;font-size:.7rem;overflow:hidden}.frame-modal-close{cursor:pointer;color:var(--ink);background:0 0;border:none;width:2rem;height:2rem;font-family:Fredoka,sans-serif;font-size:1.6rem;font-weight:500;line-height:1}.frame-modal-close:hover{transition:transform .2s;transform:rotate(90deg)}.frame-modal-stage{border-bottom:1px solid var(--border);background:#1a1308;flex:1;min-height:280px;position:relative}.frame-modal-canvas{touch-action:none;cursor:grab;width:100%;height:100%;position:absolute;inset:0}.frame-modal-canvas:active{cursor:grabbing}.frame-modal-tools{border-bottom:1px dashed var(--border);flex-wrap:wrap;gap:.4rem;padding:.6rem 1rem;display:flex}.frame-tool{background:var(--paper);color:var(--ink-soft);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:.35rem .7rem;font-family:Fredoka,sans-serif;font-size:.78rem;font-weight:600;transition:border-color .12s,background .12s}.frame-tool:hover{background:var(--cream);border-color:var(--coral);color:var(--ink)}.frame-modal-foot{justify-content:flex-end;gap:.5rem;padding:.7rem 1rem;display:flex}.frame-modal-btn{border:1px solid var(--border);cursor:pointer;border-radius:100px;padding:.5rem 1.2rem;font-family:Fredoka,sans-serif;font-size:.88rem;font-weight:700;transition:background .12s}.frame-modal-cancel{background:var(--paper);color:var(--ink)}.frame-modal-cancel:hover{background:var(--cream)}.frame-modal-save{background:var(--coral);color:#fff;border-color:#0000}.frame-modal-save:hover{background:var(--coral-deep)}body.frame-modal-open{overflow:hidden}.frame-overlay{white-space:nowrap;color:var(--ink);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:.45rem;padding:.35rem .8rem .35rem .6rem;font-family:Fredoka,sans-serif;font-size:.82rem;font-weight:600;transition:border-color .12s,background .12s,color .12s;display:inline-flex}.frame-overlay:hover{background:var(--cream);border-color:var(--coral)}.frame-overlay-ico{flex-shrink:0;width:18px;height:18px}@media (max-height:680px),(max-width:840px){.frame-overlay-label{display:none}.frame-overlay{padding:.35rem .65rem}}.frame-modal-hint{background:var(--cream);border-top:1px solid var(--border);color:var(--ink-muted);text-align:center;letter-spacing:.01em;padding:.35rem .85rem;font-family:Fredoka,sans-serif;font-size:.72rem;font-weight:500}.frame-modal-hint-short{display:none}@media (max-width:600px){.frame-modal-hint-full{display:none}.frame-modal-hint-short{display:inline}}@media (max-height:560px){.frame-modal-hint{display:none}}.palette-display.pal-focused .pal-cell,.palette-display.pal-focused .swatch{transition:opacity .12s,filter .12s}.palette-display.pal-focused .pal-cell:not(.is-focused),.palette-display.pal-focused .swatch:not(.is-focused){opacity:.55;filter:grayscale(.3)drop-shadow(0 1px 1px #2f245214)}.palette-display.pal-focused .pal-cell.is-focused{z-index:5;filter:brightness(1.05)drop-shadow(0 3px 5px #2f24524d)}.palette-display.pal-focused .swatch.is-focused{background:var(--pink-soft);box-shadow:0 2px 8px #db277726}.palette-display{flex-wrap:wrap;gap:.4rem;display:flex}.palette-display:not(.pal-game-wrap){grid-template-columns:repeat(auto-fill,minmax(168px,1fr));display:grid}.pal-game{flex-wrap:nowrap;align-items:stretch;gap:10px;width:100%;display:flex}.pal-main{grid-template-columns:repeat(11,minmax(0,1fr));width:calc(91.6667% - 20.1667px)}.pal-main,.pal-side{flex:none;gap:6px;min-width:0;display:grid}.pal-side{border-left:1px dashed var(--border);box-sizing:content-box;grid-template-rows:repeat(7,1fr);grid-template-columns:minmax(0,1fr);width:calc(8.33333% - 1.83333px);padding-left:10px}.pal-cell{aspect-ratio:1;cursor:pointer;filter:drop-shadow(0 1px 1px #2f245214);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:0 0;border:none;width:100%;padding:0;position:relative}.pal-cell .pal-svg{width:100%;height:100%;display:block;overflow:visible}.pal-cell .pal-plate{fill:#fff8f0;stroke:#2f24522e;stroke-width:2px}.pal-cell .pal-blob{fill:var(--chip)}.pal-cell:hover{z-index:2;filter:brightness(1.08)drop-shadow(0 2px 3px #2f245240)}.pal-cell.used{z-index:3;filter:drop-shadow(0 2px 3px #2f245233)}.pal-cell.used .pal-blob,.pal-cell.used .pal-plate{stroke:var(--coral);stroke-width:2.5px}.pal-cell.used .pal-blob{stroke-linejoin:round}.pal-rc{color:var(--ink);text-shadow:0 0 2px #fff8f0,0 0 2px #fff8f0,1px 0 #fff8f0,-1px 0 #fff8f0,0 1px #fff8f0,0 -1px #fff8f0;pointer-events:none;z-index:3;letter-spacing:-.02em;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:.62rem;font-weight:600;display:none;position:absolute;inset:0}.pal-cell.used .pal-rc{display:flex}.pal-num{background:var(--coral);color:#fff;pointer-events:none;z-index:4;border:none;border-radius:100px;justify-content:center;align-items:center;min-width:44%;height:44%;padding:0 4px;font-family:JetBrains Mono,monospace;font-size:.6rem;font-weight:700;line-height:1;display:none;position:absolute;top:-4%;left:-4%}.palette-display.show-numbers .pal-cell.used .pal-num{display:flex}.pal-check{background:var(--coral-deep);pointer-events:none;z-index:4;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:44%;height:44%;display:none;position:absolute;bottom:-6%;right:-6%;box-shadow:0 1px 3px #2f245233}.pal-check svg{width:62%;height:62%;display:block}.pal-cell.used .pal-check,.pal-legend{display:flex}.pal-legend{color:var(--ink-muted);flex-basis:100%;align-items:center;gap:.5rem;margin-top:.7rem;font-family:Fredoka,sans-serif;font-size:.72rem}.pal-legend-chip{flex-shrink:0;width:24px;height:24px;position:relative}.pal-legend-svg{width:100%;height:100%;display:block;overflow:visible}.pal-legend-plate{fill:#fff8f0}.pal-legend-blob,.pal-legend-plate{stroke:var(--coral);stroke-width:3.5px}.pal-legend-blob{fill:var(--teal);stroke-linejoin:round}.pal-legend-check{background:var(--coral-deep);border:1.5px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:50%;height:50%;display:flex;position:absolute;bottom:-8%;right:-8%}.pal-legend-check svg{width:65%;height:65%;display:block}.swatch{cursor:pointer;background:var(--paper);border:1px solid var(--border);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation;border-radius:14px;flex-direction:column;align-items:center;gap:3px;min-width:112px;padding:.4rem .4rem .35rem;transition:box-shadow .15s,border-color .15s;display:flex;box-shadow:0 1px 3px #2f24520f}.swatch:hover{border-color:var(--coral);box-shadow:0 2px 8px #2f24521a}.swatch-head{gap:4px;width:100%;display:flex}.swatch-head,.swatch-num{justify-content:center;align-items:center}.swatch-num{color:#fff;background:var(--coral);border:none;border-radius:100px;min-width:16px;height:16px;padding:0 4px;font-family:JetBrains Mono,monospace;font-size:.58rem;font-weight:700;line-height:1;display:inline-flex}.swatch-box{border:1px solid var(--border);border-radius:8px;width:32px;height:32px;box-shadow:inset 0 3px #ffffff40,inset 0 -2px #2f24521a}.swatch-hex{color:var(--ink);font-size:.6rem;font-weight:600}.swatch-hex,.swatch-hsb{font-family:JetBrains Mono,monospace}.swatch-hsb{color:var(--ink-muted);font-size:.54rem;line-height:1}.swatch-presses{grid-template-columns:repeat(3,1fr);align-items:center;gap:.2rem;width:100%;margin-top:2px;display:grid}.swatch-press{color:var(--ink);justify-self:start;gap:2px;min-width:0;font-family:JetBrains Mono,monospace}.kcap,.swatch-press{align-items:center;font-size:.62rem;font-weight:700;display:inline-flex}.kcap{background:var(--ink);color:#fff;border-radius:5px;flex-shrink:0;justify-content:center;width:22px;height:16px;font-family:Fredoka,sans-serif;line-height:1;box-shadow:inset 0 -1.5px #0000004d}.kcap-zr{letter-spacing:.02em}.kcap-arrow{padding-bottom:1px;font-size:.78rem}.kcap-count{color:var(--ink)}.swatch-picker{border:1px solid var(--border);background:var(--paper);border-radius:4px;width:100px;height:72px;display:block;overflow:visible}.landing{display:none}.view-landing .landing{display:block}.view-landing .app,.view-studio .landing{display:none}.landing{max-width:1120px;margin:0 auto;padding:1.4rem 1.1rem 2.4rem}.landing-inner{gap:1.1rem;display:grid}.lt-grid{letter-spacing:.01em;gap:.05em;font-family:Fredoka,sans-serif;line-height:.95;display:inline-flex}.lt-grid>span{color:var(--ink)}.lt-grid>span[data-c=coral]{color:#e16759}.lt-grid>span[data-c=teal]{color:#247f80}.lt-grid>span[data-c=violet]{color:#4460b0}.lt-grid>span[data-c=sun]{color:#cb8d2e}.lt-grid-tiny{gap:0;font-size:1.5rem;line-height:1}.landing-hero{background:var(--paper);border:1px solid var(--border);border-radius:24px;grid-template-columns:minmax(0,1fr) minmax(280px,460px);align-items:center;gap:1rem;display:grid;overflow:hidden;box-shadow:0 1px 3px #2f24520f}.landing-copy{gap:.85rem;padding:clamp(1.25rem,2vw,1.75rem);display:grid}.landing-eyebrow{border:1px solid var(--border);background:var(--cream);letter-spacing:.06em;text-transform:uppercase;width:fit-content;color:var(--ink-soft);border-radius:999px;align-items:center;margin:0;padding:.28rem .75rem;font:600 .7rem JetBrains Mono,monospace;display:inline-flex}.landing-title{color:var(--ink);margin:0;font-family:Fredoka,sans-serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700;line-height:.92}.landing-slogan{color:var(--ink);max-width:52ch;margin:0;font:700 clamp(1rem,1.8vw,1.18rem)/1.35 Nunito,sans-serif}.landing-slogan-desc{color:var(--ink-soft);max-width:58ch;margin:0;font:500 .85rem/1.5 Nunito,sans-serif}.landing-action-panel{gap:.6rem;display:grid}.landing-drop{border:2px dashed var(--border);background:var(--cream);cursor:pointer;border-radius:14px;justify-items:center;gap:.4rem;width:100%;padding:1.2rem 1rem;transition:border-color .15s,background .15s;display:grid}.landing-drop:hover{border-color:var(--coral);background:var(--pink-soft)}.landing-drop.is-dragging{background:var(--pink-soft);border-style:solid;border-color:var(--coral-deep)}.landing-drop-ico{width:1.75rem;height:1.75rem;color:var(--ink-soft)}.landing-drop-title{color:var(--ink);font:700 1.05rem Fredoka,sans-serif}.landing-drop-hint{color:var(--ink-muted);font:500 .73rem JetBrains Mono,monospace}.landing-demo{background:var(--coral);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.4rem;width:100%;padding:.72rem 1rem;font:700 .92rem Fredoka,sans-serif;transition:background .15s,transform .12s;display:inline-flex}.landing-demo:hover{background:var(--coral-deep);transform:translateY(-1px)}.landing-privacy{color:#166534;align-items:center;gap:.45rem;margin:0;font:600 .78rem Nunito,sans-serif;display:inline-flex}.landing-privacy:before{content:"";background:#16a34a url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23fff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3.5 8.5l3 3 6-6'/%3E%3C/svg%3E") 0 0/cover;border-radius:50%;flex-shrink:0;width:16px;height:16px;display:inline-block}.landing-proof{flex-wrap:wrap;gap:.45rem;margin:0;padding:0;list-style:none;display:flex}.landing-proof li{background:var(--paper);border:1px solid var(--border);color:var(--ink-soft);border-radius:999px;padding:.3rem .7rem;font:600 .76rem Nunito,sans-serif}.landing-hero-media{background:var(--cream);align-self:stretch;height:100%;min-height:260px;margin:0;position:relative}.landing-hero-image{object-fit:cover;width:100%;height:100%;min-height:260px;display:block}.landing-intro{grid-template-columns:repeat(3,minmax(0,1fr));gap:.7rem;display:grid}.landing-intro-head{grid-column:1/-1;margin-bottom:.1rem}.landing-intro-kicker{border:1px solid var(--border);background:var(--cream);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);border-radius:999px;align-items:center;margin:0;padding:.22rem .65rem;font:600 .68rem JetBrains Mono,monospace;display:inline-flex}.landing-intro-title{color:var(--ink);margin:.45rem 0 0;font:700 clamp(1.1rem,2vw,1.4rem) Fredoka,sans-serif}.landing-intro-card{border:1px solid var(--border);background:var(--paper);border-radius:16px;padding:1rem;box-shadow:0 1px 3px #2f24520d}.landing-intro-card-icon{width:28px;height:28px;color:var(--ink-soft);margin-bottom:.6rem}.landing-intro-card h3{color:var(--ink);margin:0;font:700 .95rem Fredoka,sans-serif}.landing-intro-card p{color:var(--ink-soft);margin:.35rem 0 0;font:500 .8rem/1.45 Nunito,sans-serif}.landing-howto{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.7rem;display:grid}.landing-howto-card{border:1px solid var(--border);background:var(--paper);border-radius:16px;padding:1.1rem 1.2rem;box-shadow:0 1px 3px #2f24520d}.landing-howto-kicker{border:1px solid var(--border);background:var(--cream);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);border-radius:999px;align-items:center;margin-bottom:.65rem;padding:.22rem .65rem;font:600 .68rem JetBrains Mono,monospace;display:inline-flex}.landing-howto-title{color:var(--ink);margin:0 0 .75rem;font:700 clamp(1.05rem,1.8vw,1.25rem) Fredoka,sans-serif}.landing-howto-steps{counter-reset:step;flex-direction:column;gap:.6rem;margin:0;padding:0;list-style:none;display:flex}.landing-howto-steps li{counter-increment:step;color:var(--ink-soft);align-items:flex-start;gap:.65rem;font:500 .83rem/1.45 Nunito,sans-serif;display:flex}.landing-howto-steps li:before{content:counter(step);background:var(--coral);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:.05rem;font:700 .75rem Fredoka,sans-serif;display:inline-flex}.landing-howto-steps li b{color:var(--ink);margin-bottom:.1rem;font-weight:700;display:block}.landing-howto-desc{color:var(--ink-soft);margin:0;font:500 .85rem/1.5 Nunito,sans-serif}@media (max-width:840px){.landing-hero{grid-template-columns:1fr}.landing-copy{padding:1rem}.landing-title{font-size:clamp(2rem,9vw,2.8rem)}.landing-hero-media{min-height:200px}.landing-hero-image{min-height:200px;max-height:320px}.landing-howto,.landing-intro{grid-template-columns:1fr}}@media (max-width:520px){.landing{padding:.9rem .75rem 1.8rem}.landing-drop{padding:1rem .75rem}.landing-drop-title{font-size:.95rem}.landing-proof li{font-size:.72rem}}@media (max-width:840px){:root{--sidebar-w:100%}.app{grid-template-columns:1fr}.topbar-nav{gap:.2rem;font-size:.78rem}}@media (max-width:480px){.topbar-help{min-width:1.8rem;padding:0 10px;font-size:.78rem}.topbar-nav-link{padding:0 10px;font-size:.72rem}}@media (max-width:840px){.sidebar{border-right:none;border-bottom:1px solid var(--border);gap:.55rem;max-height:none;padding:.6rem .75rem .5rem;position:static}.brush-btn{aspect-ratio:auto;height:56px}.sb-extras{flex-direction:column;gap:.5rem;display:flex}.sb-extras-toggle{background:var(--paper);width:100%;color:var(--ink-soft);border:1px solid var(--border);cursor:pointer;border-radius:12px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-family:Fredoka,sans-serif;font-size:.82rem;font-weight:600;transition:background .12s,border-color .12s;display:inline-flex}.sb-extras-toggle:hover{background:var(--cream);border-color:var(--coral)}.sb-extras-label{font-weight:700}.sb-extras-hint{color:var(--ink-muted);letter-spacing:.02em;font-size:.7rem;font-weight:500}.sb-extras-caret{margin-left:auto;font-size:.75rem;transition:transform .18s}.sb-extras-toggle[aria-expanded=true] .sb-extras-caret{transform:rotate(180deg)}.sb-extras-body{flex-direction:column;gap:.75rem;padding:.15rem .1rem .25rem;display:none}.sb-extras-toggle[aria-expanded=true]+.sb-extras-body{display:flex}.main{gap:.75rem;padding:.75rem}.workshop-header{gap:.5rem;padding:.5rem .6rem}.wh-recipe,.wh-stats{flex-shrink:1;min-width:0}.workshop-header>.wh-recipe{margin-left:0}.wh-chip b{font-size:.8rem}.canvas-meta,.stage-toolbar,.stage-wrap{width:min(100%,max(55dvh,380px))}.stage{padding:.4rem}}@media (max-width:380px){.topbar-logo{max-width:min(60vw,180px);height:26px}.swatch-box{width:28px;height:28px}}.legal-shell{min-height:calc(100vh - var(--topbar-h));min-height:calc(100dvh - var(--topbar-h));padding:1.4rem 1rem 2.2rem}.legal-main{background:var(--paper);border:1px solid var(--border);border-radius:18px;width:min(900px,94vw);margin:0 auto;padding:1.2rem 1.2rem 1.4rem;box-shadow:0 2px 12px #2f245214}.legal-eyebrow{border:1px solid var(--border);background:var(--cream);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted);border-radius:999px;margin-bottom:.5rem;padding:.2rem .65rem;font:600 .72rem JetBrains Mono,monospace;display:inline-block}.legal-main h1{color:var(--ink);margin-bottom:.25rem;font:800 clamp(1.35rem,2.8vw,1.9rem) Fredoka,sans-serif}.legal-meta{color:var(--ink-muted);margin-bottom:1rem;font:600 .9rem Nunito,sans-serif}.legal-main h2{color:var(--ink);margin:1.15rem 0 .35rem;font:700 1.03rem Fredoka,sans-serif}.legal-main li,.legal-main p{color:var(--ink-soft);font:600 .95rem/1.6 Nunito,sans-serif}.legal-main ul{padding-left:1.1rem}.legal-main a{color:var(--coral);text-underline-offset:2px;text-decoration:underline}.legal-main a:hover{color:var(--coral-deep)}.legal-actions{flex-wrap:wrap;gap:.55rem;margin-top:1.3rem;display:flex}.legal-btn{border:1px solid var(--border);color:var(--ink-soft);background:var(--paper);border-radius:999px;align-items:center;gap:.35rem;padding:.38rem .8rem;font:700 .8rem Fredoka,sans-serif;text-decoration:none;transition:border-color .12s,color .12s,background .12s;display:inline-flex}.legal-btn:hover{border-color:var(--coral);color:var(--ink);background:var(--cream)}.legal-btn.primary{background:var(--coral);color:#fff;border-color:#0000}.legal-btn.primary:hover{background:var(--coral-deep)}@media (max-width:520px){.legal-shell{padding:.85rem .7rem 1.6rem}.legal-main{border-radius:14px;padding:.95rem .85rem 1.05rem}}body,html{min-height:100%}body{color:var(--ink);background-image:linear-gradient(#f8effb,#f4eefa 62%,#eef2ff);background-attachment:fixed;margin:0}.app,.foot-credit,.footer-info,.landing,.legal-shell,.topbar{width:min(1120px,100% - 24px);margin-left:auto;margin-right:auto}.topbar{border:1px solid var(--border);background:var(--paper);border-radius:26px;height:auto;margin-top:14px;margin-bottom:10px;padding:7px;position:static;box-shadow:0 1px 4px #2f24520f}.topbar-inner{border:1px solid var(--border);border-radius:20px;justify-content:space-between;align-items:center;gap:.5rem;min-height:62px;padding:10px 16px;display:flex}.topbar-logo{max-width:min(58vw,300px);height:36px}.topbar-nav-link{border:1px solid var(--border);height:34px;color:var(--ink-soft);background:0 0;border-radius:999px;align-items:center;padding:0 14px;font-family:Fredoka,sans-serif;font-size:.8rem;font-weight:600;text-decoration:none;transition:border-color .12s,color .12s,background .12s;display:inline-flex}.topbar-nav-link:hover{border-color:var(--coral);color:var(--ink);background:var(--pink-soft)}.topbar-help{border:1px solid var(--border);min-width:34px;height:34px;color:var(--ink-soft);cursor:pointer;background:0 0;border-radius:999px;align-items:center;padding:0 14px;font-family:Fredoka,sans-serif;font-size:.8rem;font-weight:600;transition:border-color .12s,color .12s,background .12s;display:inline-flex}.topbar-help:hover{border-color:var(--coral);color:var(--ink);background:var(--pink-soft)}.footer-info,.landing{border:1px solid var(--border);background:var(--paper);border-radius:24px;box-shadow:0 1px 3px #2f24520f}.view-landing .app,.view-studio .footer-info,.view-studio .landing{display:none}@media (max-width:1024px){.app,.foot-credit,.footer-info,.landing,.legal-shell,.topbar{width:min(1120px,100% - 16px)}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}