*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}.panel{background:var(--frosted-white);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:24px;border:3px solid var(--frosted-border);box-shadow:var(--shadow-soft),inset 0 1px #fffc;padding:16px;height:fit-content;max-height:calc(100vh - 140px);display:flex;flex-direction:column}@media(max-width:900px){.panel{max-height:none;width:100%}.left-panel{flex:0 0 auto;max-height:32vh;min-height:0}.left-panel .panel-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;gap:10px;padding-bottom:8px;padding-right:8px;flex:0 0 auto;min-height:0;grid-template-columns:unset;scrollbar-width:thin}.left-panel .panel-grid::-webkit-scrollbar{height:6px}.left-panel .panel-grid::-webkit-scrollbar-thumb{background:var(--pastel-pink);border-radius:3px}.left-panel .holder-preview{flex:0 0 auto;width:72px;min-width:72px;aspect-ratio:2 / 3;min-height:0}.left-panel .sticker-item{flex:0 0 auto;width:56px;min-width:56px;height:56px;min-height:56px;font-size:1.5rem}.left-panel .panel-grid.letters-wrap{flex:0 0 auto;overflow:visible;min-height:0}.left-panel .panel-grid.letters{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;gap:6px;padding-bottom:6px;flex:0 0 auto;grid-template-columns:unset}.left-panel .letter-tile{flex:0 0 auto;width:40px;min-width:40px;height:40px;min-height:40px;font-size:.9rem}.left-panel .letter-tile-white{flex:0 0 auto}.left-panel .letters-row-label{flex-shrink:0;margin-bottom:4px}}@media(max-width:600px){.panel{padding:12px;border-radius:20px}.panel-title{font-size:1.1rem;margin-bottom:10px}.tabs{gap:4px;margin-bottom:10px}.tab{padding:10px 12px;font-size:.9rem;min-height:44px}.panel-grid{gap:8px}.btn-bubble{min-height:44px;padding:10px 16px;font-size:.95rem}.tools-section-title{font-size:.9rem}.left-panel{max-height:30vh}.left-panel .holder-preview{width:64px;min-width:64px}.left-panel .sticker-item{width:48px;min-width:48px;height:48px;min-height:48px;font-size:1.35rem}.left-panel .letter-tile{width:36px;min-width:36px;height:36px;min-height:36px;font-size:.8rem}}@media(max-width:480px){.panel{padding:10px;border-radius:16px}.panel-title{font-size:1rem}.panel-grid{grid-template-columns:repeat(3,1fr);gap:6px}.panel-grid.letters{grid-template-columns:repeat(5,1fr)}.letter-tile,.sticker-item,.holder-preview{min-height:44px}.btn-bubble{min-height:44px;padding:12px 18px}.left-panel{max-height:28vh}.left-panel .holder-preview{width:60px;min-width:60px}.left-panel .sticker-item{width:44px;min-width:44px;height:44px;min-height:44px;font-size:1.25rem}.left-panel .letter-tile{width:34px;min-width:34px;height:34px;min-height:34px;font-size:.75rem}}.panel-title{font-family:var(--font-bubble);font-size:1.2rem;color:#5a4a6a;margin:0 0 12px;text-align:center}.tabs{display:flex;gap:6px;margin-bottom:12px;flex-shrink:0}.tab{flex:1;padding:8px 10px;border:none;border-radius:999px;font-family:var(--font-bubble);font-size:.85rem;background:#fff9;color:#5a4a6a;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000000f}.tab:hover{background:var(--pastel-pink);color:#fff;box-shadow:0 4px 12px #ffb6c180;transform:translateY(-1px)}.tab.active{background:linear-gradient(135deg,var(--pastel-pink),var(--pastel-lavender));color:#fff;box-shadow:0 4px 14px #ffb6c199}.panel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;overflow-y:auto;padding-right:4px;flex:1;min-height:0}.panel-grid.letters-wrap{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;min-height:0}.letters-row-label{font-size:.75rem;font-weight:600;color:var(--pastel-lavender);margin:0 0 2px;text-transform:uppercase;letter-spacing:.05em}.panel-grid.letters{grid-template-columns:repeat(5,1fr)}.holder-preview{aspect-ratio:2/3;border-radius:12px;cursor:pointer;transition:all .25s ease;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border:2px solid transparent}.holder-preview:hover{transform:scale(1.05);box-shadow:0 8px 24px #0000001f}.holder-preview.active{border-color:var(--pastel-pink);box-shadow:0 0 0 3px #ffb6c166}.holder-preview.plain{background:linear-gradient(145deg,#ffffffe6,#c8dcff66);border:2px solid rgba(255,255,255,.95)}.holder-preview.pink-glitter{background:linear-gradient(135deg,#ffb6c199,#ff69b466);border:2px solid rgba(255,182,193,.9);box-shadow:inset 0 0 20px #ffffff80}.holder-preview.pink-glitter:after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Ccircle fill='%23fff' opacity='0.4' cx='10' cy='10' r='1'/%3E%3C/svg%3E");pointer-events:none}.holder-preview.holographic{background:linear-gradient(124deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3,#54a0ff);background-size:400% 400%;animation:holographic 3s ease infinite;border:2px solid rgba(255,255,255,.7)}@keyframes holographic{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.holder-preview.purple-stars{background:linear-gradient(145deg,#e6d5f5e6,#b4a0dc80);border:2px solid rgba(150,100,200,.8)}.holder-preview.purple-stars:before,.holder-preview.purple-stars:after{content:"★";position:absolute;font-size:14px;color:#9664c8e6}.holder-preview.purple-stars:before{top:4px;left:4px}.holder-preview.purple-stars:after{bottom:4px;right:4px;transform:rotate(180deg)}.holder-preview.sky-gems{background:linear-gradient(135deg,#aadcffe6,#50a0ff8c);border:2px solid rgba(170,220,255,.95);box-shadow:inset 0 0 20px #ffffff73}.holder-preview.mint-hearts{background:linear-gradient(135deg,#c5f5e6e6,#78dcc38c);border:2px solid rgba(160,230,210,.95)}.holder-preview.mint-hearts:after{content:"💚";position:absolute;inset:0;display:grid;place-items:center;opacity:.55;font-size:18px}.holder-preview.peach-lace{background:repeating-linear-gradient(45deg,#fff6 0 6px,#fff0 6px 12px),linear-gradient(135deg,#ffdab9f2,#ffb7c5a6);border:2px solid rgba(255,183,197,.9)}.holder-preview.silver-chrome{background:linear-gradient(135deg,#f5f5fff2,#bec8e6d9,#fffffff2);border:2px solid rgba(255,255,255,.85)}.holder-preview.coral-sunset{background:linear-gradient(135deg,#ff9a8b,#ff6b6b,#ffa07a);border:2px solid rgba(255,180,160,.95);box-shadow:inset 0 0 16px #ffffff4d}.holder-preview.lavender-dream{background:linear-gradient(145deg,#e6e0f5,#c9b8e8);border:2px solid rgba(200,180,230,.95);box-shadow:inset 0 0 20px #ffffff59}.holder-preview.gold-glitter{background:linear-gradient(135deg,#f5e6a3,#e8c547,#d4a84b);border:2px solid rgba(230,200,100,.95);box-shadow:inset 0 0 24px #fff6}.holder-preview.ocean-wave{background:linear-gradient(135deg,#7dd3fc,#0ea5e9,#06b6d4);border:2px solid rgba(100,200,255,.95);box-shadow:inset 0 0 20px #ffffff59}.sticker-item{aspect-ratio:1;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;cursor:pointer;background:#ffffff80;border:2px solid rgba(255,255,255,.8);transition:all .2s ease;box-shadow:0 2px 8px #0000000f}.sticker-item:hover{background:var(--pastel-pink);transform:scale(1.08);box-shadow:0 6px 16px #ffb6c180}.letter-tile{aspect-ratio:1;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:var(--font-bubble);font-size:1.2rem;font-weight:700;color:#5a4a6a;cursor:pointer;border:2px solid rgba(255,255,255,.8);transition:all .2s ease;box-shadow:0 2px 8px #0000000f;background:linear-gradient(145deg,var(--pastel-yellow),var(--pastel-peach))}.letter-tile:nth-child(4n){background:linear-gradient(145deg,var(--pastel-mint),var(--pastel-blue))}.letter-tile:nth-child(4n+1){background:linear-gradient(145deg,var(--pastel-pink),var(--pastel-peach))}.letter-tile:nth-child(4n+2){background:linear-gradient(145deg,var(--pastel-lavender),#e6d5f5)}.letter-tile:nth-child(4n+3){background:linear-gradient(145deg,var(--pastel-blue),var(--pastel-mint))}.letter-tile:hover{transform:scale(1.08);box-shadow:0 6px 16px #0000001f;border-color:var(--pastel-pink)}.letter-tile-white{color:#fff!important;background:linear-gradient(145deg,#5a4a6a,#3d3248)!important;border-color:#ffffff40;text-shadow:0 1px 2px rgba(0,0,0,.4)}.letter-tile-white:nth-child(4n),.letter-tile-white:nth-child(4n+1),.letter-tile-white:nth-child(4n+2),.letter-tile-white:nth-child(4n+3){background:linear-gradient(145deg,#5a4a6a,#3d3248)!important}.letter-tile-white:hover{border-color:#ffffff80;box-shadow:0 6px 16px #0000004d}.tools-section{margin-bottom:20px}.tools-section:last-child{margin-bottom:0}.tools-section-title{font-family:var(--font-bubble);font-size:.95rem;color:#5a4a6a;margin:0 0 10px;padding-bottom:4px;border-bottom:2px dashed rgba(90,74,106,.2)}.btn-bubble{width:100%;padding:12px 16px;border:none;border-radius:999px;font-family:var(--font-bubble);font-size:1rem;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 12px #0000001a;margin-bottom:8px}.btn-bubble:last-child{margin-bottom:0}.btn-bubble:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffb6c180}.btn-bubble.upload{background:linear-gradient(135deg,var(--pastel-pink),var(--pastel-peach));color:#fff}.btn-bubble.save{background:linear-gradient(135deg,var(--pastel-mint),var(--pastel-blue));color:#5a4a6a}.btn-bubble.clear{background:linear-gradient(135deg,#ffb7c5,#ff9a9e);color:#5a4a6a}.btn-bubble.undo{background:linear-gradient(135deg,var(--pastel-lavender),var(--pastel-blue));color:#5a4a6a}.btn-bubble.delete{background:linear-gradient(135deg,#ff9a9e,#fecfef);color:#5a4a6a}.btn-bubble.small{padding:8px 12px;font-size:.9rem;margin-right:6px;width:auto;display:inline-block}.slider-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.slider-row label{font-family:var(--font-bubble);font-size:.9rem;color:#5a4a6a;min-width:70px}.slider-row input[type=range]{flex:1;height:8px;border-radius:4px;background:linear-gradient(90deg,var(--pastel-lavender),var(--pastel-pink));-webkit-appearance:none;appearance:none}.slider-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--pastel-pink);border:2px solid #fff;box-shadow:0 2px 8px #0003;cursor:pointer}.toggle-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.toggle-row label{font-family:var(--font-bubble);font-size:.9rem;color:#5a4a6a}.flip-btn{padding:8px 14px;border-radius:999px;border:2px solid var(--pastel-pink);background:#ffffffb3;font-family:var(--font-bubble);font-size:.85rem;cursor:pointer;transition:all .2s ease}.flip-btn:hover{background:var(--pastel-pink);color:#fff}.z-buttons{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.hidden-input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.photo-zoom-row{display:flex;align-items:center;gap:8px}.icon-pill{width:40px;height:36px;border-radius:999px;border:2px solid rgba(255,182,193,.7);background:#ffffffbf;font-family:var(--font-bubble);font-size:1.2rem;line-height:1;color:#5a4a6a;cursor:pointer;transition:all .2s ease;box-shadow:0 3px 10px #00000014}.icon-pill:hover{background:var(--pastel-pink);color:#fff;transform:translateY(-1px);box-shadow:0 6px 16px #ffb6c173}.photo-hint{margin:10px 0 0;font-family:var(--font-pixel);font-size:.95rem;color:#5a4a6acc}.sticker-element-wrap{position:absolute;cursor:move;touch-action:none;z-index:30;pointer-events:auto}.sticker-element-wrap.selected{outline:2px dashed var(--pastel-pink);outline-offset:2px;border-radius:4px}.sticker-element-inner{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;transform-origin:center center;-webkit-user-select:none;user-select:none;pointer-events:none}.sticker-element-inner .emoji,.sticker-element-inner .letter-char{pointer-events:none;font-size:inherit}.sticker-element-inner.emoji-type{font-size:2rem}.sticker-element-inner.letter-type{font-family:var(--font-bubble);font-weight:700;color:#5a4a6a}.sticker-element-inner.letter-type.letter-white{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.rotate-handle{position:absolute;left:50%;bottom:100%;transform:translate(-50%,-8px);width:24px;height:24px;border-radius:50%;background:var(--pastel-pink);border:2px solid #fff;box-shadow:0 2px 8px #0003;cursor:grab;pointer-events:auto;display:none}.sticker-element-wrap.selected .rotate-handle{display:block}.rotate-handle:active{cursor:grabbing}.rotate-handle:after{content:"↻";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff}.resize-handle{position:absolute;right:-8px;bottom:-8px;width:28px;height:28px;border-radius:8px;background:var(--pastel-blue);border:2px solid #fff;box-shadow:0 2px 8px #00000040;cursor:nwse-resize;pointer-events:auto;display:none;z-index:10;padding:0}.resize-handle:after{content:"";position:absolute;right:4px;bottom:4px;width:10px;height:10px;border-right:2px solid #fff;border-bottom:2px solid #fff;border-radius:0 0 2px}.sticker-element-wrap.selected .resize-handle{display:block}.delete-handle{position:absolute;top:-10px;right:-10px;width:24px;height:24px;border-radius:50%;background:#ff9a9e;border:2px solid #fff;color:#fff;font-size:14px;font-weight:700;cursor:pointer;pointer-events:auto;display:none;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 8px #0003;transition:transform .2s ease}.sticker-element-wrap.selected .delete-handle{display:flex}.delete-handle:hover{background:#ff6b6b;transform:scale(1.1)}.canvas-wrap{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:20px 0;position:relative}@media(max-width:600px){.canvas-wrap{padding:12px 0}}@media(max-width:480px){.canvas-wrap{padding:10px 0}}.canvas-container{width:min(390px,90vw);aspect-ratio:39 / 57;position:relative;border-radius:16px;box-shadow:0 8px 32px #00000026,inset 0 0 0 1px #ffffff80;overflow:hidden;flex-shrink:0;background:linear-gradient(145deg,#fff6,#e6dcff4d)}@media(max-width:900px){.canvas-container{width:100%;max-width:min(390px,90vw)}}@media(max-width:480px){.canvas-container{border-radius:12px}}.canvas-container.has-photo{background:transparent}.canvas-photo-layer{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;overflow:hidden;z-index:1;pointer-events:auto;touch-action:none;cursor:grab}.canvas-photo-layer img{position:absolute;left:50%;top:50%;width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none;pointer-events:none;will-change:transform}.canvas-holder-layer{position:absolute;inset:0;pointer-events:none;z-index:10;border-radius:16px;--frame: 52px;--frame-shadow: none;-webkit-mask-image:linear-gradient(#fff,#fff),linear-gradient(#fff,#fff);mask-image:linear-gradient(#fff,#fff),linear-gradient(#fff,#fff);-webkit-mask-size:100% 100%,calc(100% - 2 * var(--frame)) calc(100% - 2 * var(--frame));mask-size:100% 100%,calc(100% - 2 * var(--frame)) calc(100% - 2 * var(--frame));-webkit-mask-position:0 0,var(--frame) var(--frame);mask-position:0 0,var(--frame) var(--frame);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-composite:xor;mask-composite:exclude;background-image:linear-gradient(145deg,#fff,#d4dcf5);background-origin:border-box;background-clip:border-box;box-shadow:var(--frame-shadow)}.canvas-holder-layer.plain{background-image:linear-gradient(145deg,#fff,#d4dcf5);--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 20px rgba(180, 220, 255, .4)}.canvas-holder-layer.pink-glitter{background-image:linear-gradient(135deg,pink,#ff69b4),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28'%3E%3Ccircle fill='%23fff' opacity='0.5' cx='7' cy='9' r='1.2'/%3E%3Ccircle fill='%23fff' opacity='0.35' cx='18' cy='15' r='1'/%3E%3Ccircle fill='%23fff' opacity='0.45' cx='22' cy='7' r='0.9'/%3E%3C/svg%3E");background-size:auto,28px 28px;--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 26px rgba(255,110,180,.4)}.canvas-holder-layer.holographic{background-image:linear-gradient(124deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3,#54a0ff);background-size:400% 400%;animation:holographic 3s ease infinite;--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 26px rgba(200, 220, 255, .4)}.canvas-holder-layer.purple-stars{background-image:linear-gradient(145deg,#e6d5f5,#b4a0dc),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='120' viewBox='0 0 80 120'%3E%3Ctext x='8' y='18' font-size='14' fill='%239664c8'%3E%E2%98%85%3C/text%3E%3Ctext x='62' y='18' font-size='14' fill='%239664c8'%3E%E2%98%85%3C/text%3E%3Ctext x='8' y='112' font-size='14' fill='%239664c8'%3E%E2%98%85%3C/text%3E%3Ctext x='62' y='112' font-size='14' fill='%239664c8'%3E%E2%98%85%3C/text%3E%3C/svg%3E");background-size:auto,80px 120px;background-repeat:no-repeat,repeat;--frame-shadow: 0 0 0 2px rgba(255,255,255,.8) inset, 0 0 22px rgba(170, 120, 220, .4)}.canvas-holder-layer.sky-gems{background-image:linear-gradient(135deg,#aadcff,#50a0ff);--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 26px rgba(90, 170, 255, .4)}.canvas-holder-layer.mint-hearts{background-image:linear-gradient(135deg,#c5f5e6,#78dcc3),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34'%3E%3Ctext x='7' y='22' font-size='16'%3E%F0%9F%92%9A%3C/text%3E%3C/svg%3E");background-size:auto,34px 34px;--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 22px rgba(120, 220, 195, .4)}.canvas-holder-layer.peach-lace{background-image:linear-gradient(135deg,#ffdab9,#ffb7c5),repeating-linear-gradient(45deg,rgba(255,255,255,.6) 0 6px,transparent 6px 12px);--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 22px rgba(255, 183, 197, .4)}.canvas-holder-layer.silver-chrome{background-image:linear-gradient(135deg,#f5f5ff,#bec8e6,#fff);--frame-shadow: 0 0 0 2px rgba(255,255,255,.95) inset, 0 0 18px rgba(180, 190, 220, .4)}.canvas-holder-layer.coral-sunset{background-image:linear-gradient(135deg,#ff9a8b,#ff6b6b,#ffa07a);--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 22px rgba(255, 140, 120, .4)}.canvas-holder-layer.lavender-dream{background-image:linear-gradient(145deg,#e6e0f5,#c9b8e8),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Ccircle fill='%23fff' opacity='0.3' cx='6' cy='6' r='1'/%3E%3Ccircle fill='%23fff' opacity='0.25' cx='18' cy='12' r='0.8'/%3E%3C/svg%3E");background-size:auto,24px 24px;--frame-shadow: 0 0 0 2px rgba(255,255,255,.85) inset, 0 0 20px rgba(180, 150, 220, .35)}.canvas-holder-layer.gold-glitter{background-image:linear-gradient(135deg,#f5e6a3,#e8c547,#d4a84b),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Ccircle fill='%23fff' opacity='0.5' cx='5' cy='5' r='0.8'/%3E%3Ccircle fill='%23fff' opacity='0.35' cx='14' cy='12' r='0.6'/%3E%3C/svg%3E");background-size:auto,20px 20px;--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 24px rgba(220, 180, 80, .45)}.canvas-holder-layer.ocean-wave{background-image:linear-gradient(135deg,#7dd3fc,#0ea5e9,#06b6d4);--frame-shadow: 0 0 0 2px rgba(255,255,255,.9) inset, 0 0 24px rgba(14, 165, 233, .4)}.upload-error{margin-top:10px;padding:10px 12px;border-radius:14px;background:#ffffffb3;border:2px dashed rgba(255,105,180,.55);box-shadow:0 8px 20px #ffb6c140;color:#5a4a6af2;font-family:var(--font-bubble);font-size:.95rem;max-width:300px}.canvas-stickers-layer{position:absolute;inset:0;z-index:20;cursor:default;pointer-events:none}.canvas-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;text-align:center;border:3px dashed rgba(255,182,193,.6);border-radius:16px;margin:8px;background:#fff3;z-index:40;pointer-events:auto}.canvas-empty-text{font-family:var(--font-bubble);font-size:1.3rem;color:#5a4a6a;margin:0;animation:sparkle-text 2s ease-in-out infinite}@keyframes sparkle-text{0%,to{opacity:.9}50%{opacity:1;text-shadow:0 0 12px rgba(255,182,193,.6)}}.canvas-empty-icon{font-size:3rem;margin-bottom:12px;opacity:.8}.canvas-upload-btn{margin-top:14px;padding:10px 18px;border:none;border-radius:999px;font-family:var(--font-bubble);font-size:1rem;cursor:pointer;background:linear-gradient(135deg,var(--pastel-pink),var(--pastel-peach));color:#fff;box-shadow:0 6px 18px #ffb6c173;transition:transform .2s ease,box-shadow .2s ease}.canvas-upload-btn:hover{transform:translateY(-2px);box-shadow:0 10px 26px #ffb6c18c}.canvas-photo-controls{margin-top:10px;display:flex;flex-direction:column;align-items:center;gap:6px}.canvas-photo-hint{margin:2px 0 0;font-family:var(--font-bubble);font-size:.9rem;color:#5a4a6acc}.canvas-reset-btn{padding:8px 16px;border-radius:999px;border:none;font-family:var(--font-bubble);font-size:.9rem;background:#fffc;box-shadow:0 3px 10px #00000014;cursor:pointer;transition:all .2s ease}.canvas-reset-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0000001f}@media(max-width:600px){.photo-zoom-row{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap}.icon-pill,.canvas-reset-btn{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.canvas-photo-hint{font-size:.8rem;text-align:center}.upload-error{font-size:.9rem;padding:10px;max-width:100%}}@media(max-width:480px){.upload-error{font-size:.85rem;padding:8px 10px}}:root{--pastel-pink: #ffb7c5;--pastel-blue: #b5d8eb;--pastel-lavender: #e6d5f5;--pastel-mint: #c5f5e6;--pastel-yellow: #fff9b0;--pastel-peach: #ffdab9;--frosted-white: rgba(255, 255, 255, .75);--frosted-border: rgba(255, 255, 255, .9);--shadow-soft: 0 4px 20px rgba(255, 182, 193, .35);--font-bubble: "Bubblegum Sans", cursive;--font-pixel: "VT323", monospace}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-bubble);background:linear-gradient(160deg,var(--pastel-lavender) 0%,var(--pastel-pink) 35%,var(--pastel-blue) 100%);background-attachment:fixed;color:#5a4a6a;overflow-x:hidden}.app-wrapper{position:relative;min-height:100vh;overflow-x:hidden}.sparkle{position:fixed;width:8px;height:8px;background:radial-gradient(circle,#fff 30%,transparent 70%);border-radius:50%;pointer-events:none;animation:sparkle-float 4s ease-in-out infinite;z-index:0}.sparkle:nth-child(1){left:10%;top:20%;animation-delay:0s}.sparkle:nth-child(2){left:85%;top:15%;animation-delay:.5s}.sparkle:nth-child(3){left:70%;top:60%;animation-delay:1s}.sparkle:nth-child(4){left:20%;top:70%;animation-delay:1.5s}.sparkle:nth-child(5){left:50%;top:10%;animation-delay:2s}.sparkle:nth-child(6){left:90%;top:80%;animation-delay:2.5s}.sparkle:nth-child(7){left:5%;top:50%;animation-delay:3s}.sparkle:nth-child(8){left:60%;top:85%;animation-delay:3.5s}@keyframes sparkle-float{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.app-header{text-align:center;padding:16px;position:relative;z-index:1}.app-title{font-family:var(--font-bubble);font-size:2.2rem;color:#5a4a6a;text-shadow:2px 2px 0 rgba(255,255,255,.9);margin:0;letter-spacing:1px}.layout{display:grid;grid-template-columns:240px 1fr 260px;gap:20px;max-width:1200px;margin:0 auto 24px;padding:0 20px;position:relative;z-index:1;min-height:calc(100vh - 100px);align-items:start}@media(max-width:900px){.app-header{width:100%;max-width:min(390px,90vw);margin:0 auto;padding-left:12px;padding-right:12px}.layout{grid-template-columns:1fr;grid-template-rows:auto auto auto;gap:16px;margin-left:auto;margin-right:auto;margin-bottom:20px;padding:0 12px;width:100%;max-width:min(390px,90vw);min-width:0;overflow-x:hidden}.layout .canvas-wrap{order:-1;width:100%;min-width:0}.layout .left-panel{order:0;width:100%;min-width:0;overflow-x:hidden}.layout .right-panel{order:1;width:100%;min-width:0;overflow-x:hidden}}@media(max-width:600px){.app-header{padding:12px 10px;max-width:min(390px,90vw)}.app-title{font-size:1.6rem}.layout{padding:0 10px;gap:12px;margin-bottom:16px;max-width:min(390px,90vw)}}@media(max-width:480px){.app-header{padding:10px 8px;max-width:min(390px,90vw)}.app-title{font-size:1.4rem}.layout{padding:0 8px;gap:10px;max-width:min(390px,90vw)}}.confirm-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;background:#5a4a6a66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:confirm-fade .2s ease}@keyframes confirm-fade{0%{opacity:0}to{opacity:1}}.confirm-modal{background:linear-gradient(145deg,var(--frosted-white),rgba(255,255,255,.9));backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:3px solid var(--frosted-border);border-radius:24px;box-shadow:var(--shadow-soft),0 12px 40px #ffb6c166,inset 0 1px #ffffffe6;padding:28px 32px;max-width:360px;width:100%;text-align:center;animation:confirm-pop .25s ease}@keyframes confirm-pop{0%{opacity:0;transform:scale(.92) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-text{font-family:var(--font-bubble);font-size:1.2rem;color:#5a4a6a;margin:0 0 24px;line-height:1.45}.confirm-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.confirm-btn{font-family:var(--font-bubble);font-size:1rem;padding:12px 24px;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;min-width:100px}.confirm-btn.cancel{background:linear-gradient(135deg,var(--pastel-blue),#9ec9e0);color:#5a4a6a;border-color:#fffc;box-shadow:0 4px 12px #b5d8eb80}.confirm-btn.cancel:hover{transform:translateY(-2px);box-shadow:0 6px 18px #b5d8eb99}.confirm-btn.confirm{background:linear-gradient(135deg,var(--pastel-pink),var(--pastel-peach));color:#fff;border-color:#ffffffb3;box-shadow:0 4px 14px #ffb6c180}.confirm-btn.confirm:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffb6c199}
