@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800&family=Noto+Sans+KR:wght@400;500;700&display=swap";@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--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-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{:root,:host{--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);--color-brown-dark:#2a2e35;--color-accent-yellow:#f4c84a}}@layer base{*,:after,:before,::backdrop{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}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;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,samp,pre{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}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,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}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::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{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.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}}.block{display:block}.flex{display:flex}.grid{display:grid}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.grayscale{--tw-grayscale:grayscale(100%);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,)}.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,)}}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none;margin:0;padding:0}html,body,#root{touch-action:none;overscroll-behavior:none;-webkit-overflow-scrolling:none;width:100%;height:100%;color:var(--color-brown-dark);background:#fffcf3;font-family:Nunito,Noto Sans KR,Apple SD Gothic Neo,sans-serif;overflow:hidden}button:focus-visible{outline:3px solid var(--color-accent-yellow);outline-offset:2px}@keyframes toolBounce{0%{transform:scale(1)}40%{transform:scale(1.15)}70%{transform:scale(.96)}to{transform:scale(1.1)}}@keyframes panelSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes galleryFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes toolPop{0%{transform:scale(1)}40%{transform:scale(1.25)}70%{transform:scale(.95)}to{transform:scale(1)}}@keyframes colorPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1.15)}}.animate-tool-pop{animation:.3s ease-out toolPop}.animate-color-pop{animation:.25s ease-out forwards colorPop}@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-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}.app-shell{position:relative;width:100%;height:100%;background:linear-gradient(180deg,#fffcf3,#fff8e7);overflow:hidden;display:flex;flex-direction:column}.top-bar{position:fixed;top:env(safe-area-inset-top,0px);left:0;right:0;height:56px;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:4px 12px}.top-bar-left,.top-bar-right{display:flex;gap:12px}.top-bar-btn.shield-active{background:#2ea76b40;border-color:#2ea76b99}.top-bar-btn{width:48px;height:48px;border-radius:24px;background:#fff;border:1.5px solid rgba(90,71,50,.12);box-shadow:0 2px 6px #5a473226,0 1px 2px #5a473214;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s ease}.top-bar-btn:hover{transform:scale(1.1);background:#ffffffe6}.top-bar-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.top-bar-btn.save-btn{background:#f4c84a40;border:2px solid rgba(244,200,74,.5)!important}.gallery-card:active:not(:disabled){transform:scale(.97);transition:transform 80ms ease}.top-bar-btn:active:not(:disabled){transform:scale(.95)}.canvas-area{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:calc(56px + env(safe-area-inset-top,0px)) 6px 4px 6px;min-height:0;position:relative;overflow:hidden}.canvas-wrapper{position:relative;aspect-ratio:1 / 1;max-height:100%;max-width:100%;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px #5a47321f;transition:transform .2s ease;will-change:transform}.canvas-element{display:block;width:100%;height:100%}.canvas-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fffcf399;pointer-events:none;z-index:2}.canvas-empty-hint{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;gap:12px}.empty-hint-finger{animation:hintBounce 2s ease-in-out infinite}.empty-hint-text{font-size:16px;font-weight:700;color:#8b7b6b;text-align:center}@keyframes hintBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.rainbow-line{height:4px;border-radius:2px;background:linear-gradient(90deg,#ff6b6b,#ff9f43 17%,#feca57 33%,#48dbfb,#0abde3 67%,#a29bfe 83%,#ff6b6b);background-size:200% 100%;animation:rainbowShift 8s linear infinite;flex-shrink:0;box-shadow:0 1px 4px #00000014}@keyframes rainbowShift{0%{background-position:0% 0}to{background-position:200% 0}}.bottom-section{flex-shrink:0;position:relative;z-index:10}.bottom-toolbar{background:#fff3e0}.toolbar-tools-row{display:flex;align-items:center;justify-content:center;gap:20px;padding:8px 24px}.color-btn{width:56px;height:56px;border-radius:28px;border:4px solid #FFFFFF;border-bottom:5px solid rgba(0,0,0,.18);box-shadow:0 3px 10px #00000026,inset 0 -2px 4px #00000014;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.color-btn:active{transform:translateY(2px);border-bottom-width:2px}.color-btn.active{transform:scale(1.12) translateY(-3px);box-shadow:0 0 0 3px #fff,0 0 0 6px #f4c84a,0 6px 20px #5a473240}.color-panel-backdrop{position:fixed;inset:0;z-index:30;background:#0003;animation:backdropFadeIn .2s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.color-panel{position:absolute;bottom:100%;left:0;right:0;z-index:31;background:#fffaf0;border-radius:24px 24px 0 0;box-shadow:0 -4px 24px #0000001a;animation:panelSlideUp .25s cubic-bezier(.22,1,.36,1);padding-bottom:8px;max-height:45vh;overflow-y:auto}@keyframes panelSlideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.color-panel-handle{width:48px;height:5px;border-radius:3px;background:linear-gradient(90deg,#ff6b6b,#feca57,#48dbfb,#a29bfe);opacity:.6;margin:12px auto 8px}.color-panel-grid-wrap{padding:4px 16px;max-width:480px;margin:0 auto}.color-panel-divider{height:1px;margin:8px 20px;background:#5a47321a}.color-panel-sizes{display:flex;align-items:center;justify-content:center;gap:16px;padding:4px 24px 8px}.toolbar-btn{width:56px;height:56px;border-radius:28px;background:var(--btn-bg, #ccc);border:none;border-bottom:4px solid var(--btn-border, #999);box-shadow:0 3px 10px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;position:relative}.toolbar-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.toolbar-btn:active{transform:translateY(2px);border-bottom-width:2px}.toolbar-btn.active{transform:scale(1.12) translateY(-3px);box-shadow:0 0 0 3px #fff,0 0 0 6px #f4c84a,0 6px 20px #5a473240;border-bottom-width:5px;animation:toolBounce .3s ease-out}.toolbar-tool-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;min-height:72px}.toolbar-tool-label{font-size:13px;font-weight:800;color:#5a4732;white-space:nowrap;letter-spacing:-.02em;transition:opacity .15s ease}.toolbar-tool-label.dimmed{opacity:.5}.color-grid{display:grid;grid-template-columns:repeat(9,minmax(0,44px));justify-content:center;gap:8px}.color-grid-dot{width:100%;aspect-ratio:1;max-width:44px;border-radius:50%;cursor:pointer;transition:all .15s ease;border:2.5px solid rgba(255,255,255,.8);box-shadow:0 1px 3px #0000001a;position:relative;display:flex;align-items:center;justify-content:center}.color-grid-dot:after{content:"";position:absolute;top:2px;left:4px;width:10px;height:5px;border-radius:50%;background:#ffffff59}.color-check{position:relative;z-index:1}.color-grid-dot:hover{transform:scale(1.15)}.color-grid-dot.selected{transform:scale(1.2);border-color:#fff;box-shadow:0 0 0 3px #f4c84a99,0 3px 8px #5a473226;animation:colorPop .25s ease-out}.color-grid-dot.light-color{border-color:#e0e0e0}.color-grid-dot.light-color.selected{border-color:#fff}.size-row{display:flex;align-items:center;justify-content:center;gap:20px}.size-btn{border-radius:50%;cursor:pointer;transition:all .18s ease;border:2px solid rgba(90,71,50,.25);background:transparent;display:flex;align-items:center;justify-content:center;padding:0}.size-btn:hover{transform:scale(1.15)}.size-btn.selected{border-color:#f4c84a;border-width:3px;box-shadow:0 0 0 3px #f4c84a59}.size-btn-inner{border-radius:50%}.gallery-overlay{position:fixed;inset:0;z-index:50;background:#fffcf3;display:flex;align-items:center;justify-content:center;animation:galleryFadeIn .3s ease-out}.gallery-overlay.gallery-closing{animation:galleryFadeOut .25s ease-in forwards;pointer-events:none}@keyframes galleryFadeOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}.gallery-content{width:100%;max-width:500px;max-height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:24px 16px;padding-top:calc(24px + env(safe-area-inset-top,0px));padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}@media(min-width:600px){.gallery-content{max-width:100%;padding:32px;padding-top:calc(32px + env(safe-area-inset-top,0px));padding-bottom:calc(32px + env(safe-area-inset-bottom,0px))}.gallery-grid{gap:16px}.canvas-area{padding:calc(56px + env(safe-area-inset-top,0px)) 16px 8px 16px;background:linear-gradient(180deg,#fff9ee,#fff3e0);align-items:center}.canvas-wrapper{width:auto;height:100%;max-width:100%;border-radius:12px;box-shadow:0 2px 16px #5a47321a;aspect-ratio:1 / 1}.canvas-element{width:auto;height:100%;max-width:100%;margin:0 auto}.top-bar-btn{width:52px;height:52px;border-radius:26px}.color-grid{grid-template-columns:repeat(9,44px);gap:10px}}@media(max-width:420px){.color-grid{grid-template-columns:repeat(7,minmax(0,40px));gap:7px}}@media(max-width:360px){.color-grid{grid-template-columns:repeat(6,minmax(0,38px));gap:6px}}.gallery-header{display:flex;align-items:center;gap:8px;margin-bottom:24px}.gallery-header .gallery-title{margin-bottom:0;flex:1;text-align:center;padding-right:40px}.gallery-back-btn{width:40px;height:40px;border-radius:50%;border:none;background:#ffffffb3;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s ease}.gallery-back-btn:active{transform:scale(.9);background:#ffffffe6}.gallery-title-wrap{text-align:center;margin-bottom:24px}.gallery-title{text-align:center;font-size:24px;font-weight:800;color:#5a4732;margin-bottom:4px}.gallery-subtitle{text-align:center;font-size:15px;font-weight:600;color:#7a6b5b}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.gallery-card{aspect-ratio:1 / 1;background:#fff;border-radius:20px;border:3px solid rgba(244,200,74,.35);box-shadow:0 4px 12px #00000014;overflow:hidden;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:0}.gallery-card:hover:not(:disabled){transform:scale(1.03);box-shadow:0 6px 20px #0000001f}.gallery-card.selected{border-width:4px;border-color:#f4c84a;box-shadow:0 0 0 4px #f4c84a66,0 4px 16px #5a47321f}.gallery-card.locked{cursor:not-allowed;position:relative}.gallery-card.locked.unlockable{cursor:pointer}.gallery-card.locked.unlockable:hover{transform:scale(1.03);box-shadow:0 6px 20px #0000001f}.gallery-card.locked:not(.unlockable):hover{transform:none}.gallery-card-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;background:linear-gradient(90deg,#f0ebe3 25%,#faf5eb,#f0ebe3 75%);background-size:200% 100%;animation:shimmer 1.2s ease-in-out infinite}.gallery-card-img.loaded{background:#fff;animation:none}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.gallery-card-img.locked-preview{filter:blur(3px) grayscale(.3);opacity:.6}.gallery-card-lock-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.gallery-card-name{font-size:14px;font-weight:700;color:#5a4732;margin-top:4px}.category-grid{gap:14px}.category-card{aspect-ratio:auto;height:130px;background:#fff;flex-direction:column;gap:6px;border-width:2px;padding:16px 12px}.category-icon{font-size:40px;line-height:1}.category-card .gallery-card-name{font-size:16px}.gallery-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 0;gap:16px}.gallery-spinner{width:48px;height:48px;border:5px solid rgba(244,200,74,.3);border-top-color:#d9a92d;border-radius:50%;animation:gallerySpin .8s linear infinite}@keyframes gallerySpin{to{transform:rotate(360deg)}}.gallery-loading-text{font-size:16px;font-weight:700;color:#5a4732}.gallery-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 0;gap:16px}.gallery-error-text{font-size:15px;font-weight:600;color:#e56a61;text-align:center}.gallery-retry-btn{padding:10px 28px;font-size:15px;font-weight:700;color:#5a4732;background:#f4c84a;border:none;border-radius:999px;border-bottom:3px solid #D9A92D;cursor:pointer;transition:all .15s ease}.gallery-retry-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.gallery-retry-btn:active{transform:translateY(1px);border-bottom-width:1px}.save-toast{position:fixed;top:calc(16px + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);z-index:100;padding:10px 24px;background:#f4c84a;color:#5a4732;font-size:15px;font-weight:800;border-radius:999px;border:2px solid #D9A92D;box-shadow:0 4px 16px #f4c84a66;animation:toastBounceIn .4s cubic-bezier(.34,1.56,.64,1)}@keyframes toastBounceIn{0%{opacity:0;transform:translate(-50%) scale(.5) translateY(-20px)}60%{opacity:1;transform:translate(-50%) scale(1.1) translateY(0)}80%{transform:translate(-50%) scale(.95) translateY(0)}to{transform:translate(-50%) scale(1) translateY(0)}}.zoom-indicator{position:absolute;bottom:12px;right:12px;z-index:15;padding:4px 10px;font-size:13px;font-weight:800;color:#5a4732;background:#ffffffd9;border:2px solid rgba(244,200,74,.6);border-radius:999px;box-shadow:0 2px 8px #5a47321f;cursor:pointer;transition:all .18s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:zoomBadgeIn .2s ease-out}.zoom-indicator:active{transform:scale(.9);background:#fffffff2}@keyframes zoomBadgeIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.reset-zoom-btn{background:#f4c84a4d!important;border:2px solid rgba(244,200,74,.6)!important}.reset-zoom-label{font-size:14px;font-weight:800;color:#5a4732;line-height:1}.safe-area-bottom{padding-bottom:env(safe-area-inset-bottom,0px)}.heart-balance{display:inline-flex;align-items:center;gap:4px;margin-left:12px;padding:4px 14px;font-size:16px;font-weight:800;color:#ff6b8a;background:#ff6b8a1a;border-radius:999px;vertical-align:middle}.heart-cost-badge{position:absolute;bottom:8px;right:8px;padding:2px 8px;font-size:12px;font-weight:800;color:#fff;background:#ff6b8ad9;border-radius:999px;box-shadow:0 2px 6px #00000026;pointer-events:none}.unlock-dialog-overlay{position:fixed;inset:0;z-index:60;background:#0006;display:flex;align-items:center;justify-content:center;animation:backdropFadeIn .2s ease-out}.unlock-dialog{background:#fffcf3;border-radius:20px;padding:28px 24px 24px;width:280px;max-width:90vw;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 8px 40px #0003;animation:panelSlideUp .25s cubic-bezier(.22,1,.36,1)}.unlock-dialog-preview{width:100px;height:100px;border-radius:16px;display:flex;align-items:center;justify-content:center;opacity:.8}.unlock-dialog-title{font-size:18px;font-weight:800;color:#5a4732;text-align:center}.unlock-dialog-error{font-size:14px;font-weight:600;color:#e56a61;text-align:center}.heart-insufficient{font-size:14px;font-weight:700;color:#ff6b8a;text-align:center;padding:8px 16px;background:#ff6b8a14;border-radius:12px}.unlock-btn-primary{width:100%;padding:14px 24px;font-size:16px;font-weight:800;color:#5a4732;background:#f4c84a;border:none;border-radius:999px;border-bottom:3px solid #D9A92D;cursor:pointer;transition:all .15s ease}.unlock-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f4c84a66}.unlock-btn-primary:active:not(:disabled){transform:translateY(1px);border-bottom-width:1px}.unlock-btn-primary:disabled{opacity:.4;cursor:not-allowed}.unlock-btn-secondary{width:100%;padding:12px 24px;font-size:15px;font-weight:700;color:#8b7b6b;background:transparent;border:2px solid rgba(90,71,50,.15);border-radius:999px;cursor:pointer;transition:all .15s ease}.unlock-btn-secondary:hover:not(:disabled){background:#5a47320d}.unlock-btn-secondary:active:not(:disabled){transform:scale(.97)}.unlock-btn-secondary:disabled{opacity:.4;cursor:not-allowed}.dressup-overlay{position:fixed;inset:0;z-index:50;background:linear-gradient(180deg,#fff5fb,#fff0f8);display:flex;flex-direction:column;animation:gallerySlideIn .3s cubic-bezier(.22,1,.36,1)}.dressup-closing{animation:gallerySlideOut .25s cubic-bezier(.36,0,1,.36) forwards}.dressup-content{display:flex;flex-direction:column;height:100%;padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,0px) 0;overflow:hidden}.dressup-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;flex-shrink:0}.dressup-title{font-size:20px;font-weight:800;color:#5a4732}.dressup-header-actions{display:flex;gap:8px;align-items:center}.dressup-action-btn{height:36px;padding:0 12px;border-radius:18px;border:1.5px solid rgba(90,71,50,.15);background:#fff;font-size:14px;font-weight:700;color:#5a4732;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .15s ease;box-shadow:0 2px 6px #5a47321a}.dressup-action-btn:hover{transform:scale(1.05)}.dressup-action-btn:active:not(:disabled){transform:scale(.95)}.dressup-action-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.dressup-save-btn{background:#f4c84a40;border-color:#f4c84a99}.dressup-save-toast{position:absolute;top:64px;left:50%;transform:translate(-50%);background:#5a4732;color:#fff;font-size:14px;font-weight:700;padding:8px 20px;border-radius:20px;z-index:60;animation:toastFadeIn .3s ease}@keyframes toastFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.dressup-preview{flex-shrink:0;display:flex;justify-content:center;align-items:center;padding:4px 16px;position:relative}.dressup-canvas{width:200px;height:200px;border-radius:16px;background:#fff;box-shadow:0 4px 20px #5a47321f;-o-object-fit:contain;object-fit:contain}.dressup-preview-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fff5fbb3}.dressup-category-tabs{display:flex;overflow-x:auto;gap:8px;padding:10px 16px;flex-shrink:0;scrollbar-width:none}.dressup-category-tabs::-webkit-scrollbar{display:none}.dressup-category-tab{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 12px;border-radius:14px;border:1.5px solid rgba(90,71,50,.12);background:#fff;cursor:pointer;flex-shrink:0;transition:all .15s ease;box-shadow:0 1px 4px #5a473214}.dressup-category-tab.active{background:#f4c84a;border-color:#e8b730;box-shadow:0 2px 8px #f4c84a66}.dressup-category-tab:active{transform:scale(.93)}.dressup-tab-icon{font-size:20px;line-height:1}.dressup-tab-label{font-size:11px;font-weight:700;color:#5a4732;white-space:nowrap}.dressup-item-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:4px 16px 16px;overflow-y:auto;flex:1;min-height:0}.dressup-item-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;border-radius:14px;border:2px solid rgba(90,71,50,.1);background:#fff;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 4px #5a473214}.dressup-item-card.equipped{border-color:#f4c84a;background:#f4c84a1a;box-shadow:0 2px 10px #f4c84a59}.dressup-item-card:active{transform:scale(.95)}.dressup-item-thumb{width:100%;aspect-ratio:1 / 1;-o-object-fit:contain;object-fit:contain;border-radius:8px}.dressup-item-check{position:absolute;top:6px;right:6px}.dressup-item-name{font-size:11px;font-weight:600;color:#5a4732;text-align:center;width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dressup-item-empty{padding:40px;text-align:center;font-size:15px;font-weight:600;color:#8b7b6b}
