@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700&family=Fredoka:wght@400;600;700&family=Comic+Neue:wght@400;700&family=Poppins:wght@400;600;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-meadow-light) 0%,var(--studio-wall) 100%);position:relative;overflow:hidden}.login-container{padding:48px;max-width:480px;width:90%;animation:float-in .6s var(--ease-bounce);z-index:1}.login-header{text-align:center;margin-bottom:36px}.login-header h1{font-family:var(--font-heading);font-size:36px;font-weight:700;color:var(--violet-vivid);margin-bottom:12px;text-shadow:2px 2px 0px rgba(139,92,246,.1);letter-spacing:-.5px}.tagline{font-family:var(--font-violet-voice);color:var(--color-text);font-size:18px;line-height:1.4}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-family:var(--font-body);font-weight:700;color:var(--color-text);font-size:15px}.form-group input{padding:16px;font-family:var(--font-body);font-size:16px;border:3px solid var(--sketch-line);border-radius:12px;box-shadow:2px 2px #6b728026;transition:all var(--duration-normal) var(--ease-bounce)}.form-group input:focus{border-color:var(--violet-vivid);box-shadow:3px 3px #8b5cf633,0 0 0 4px var(--violet-glow);transform:translateY(-2px)}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.error-message{background:#fff5f5;border:2px solid var(--color-error);color:var(--color-error);padding:12px;border-radius:8px;font-size:14px;animation:shake .3s var(--ease-smooth)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.login-button{background:var(--violet-vivid);color:#fff;padding:18px;border-radius:14px;border:3px solid var(--violet-deep);font-family:var(--font-body);font-size:18px;font-weight:700;cursor:pointer;box-shadow:4px 4px #7c3aed4d,0 6px 20px var(--shadow-medium);transition:all var(--duration-normal) var(--ease-bounce)}.login-button:hover:not(:disabled){background:var(--violet-deep);transform:translateY(-4px);box-shadow:5px 5px #7c3aed66,0 10px 28px var(--shadow-bold)}.login-button:active:not(:disabled){transform:translateY(-1px);box-shadow:3px 3px #7c3aed4d,0 4px 16px var(--shadow-medium)}.login-button:disabled{background:#ccc;border-color:#aaa;cursor:not-allowed;opacity:.6}.login-footer{margin-top:28px;padding-top:28px;border-top:2px dashed var(--violet-bright);text-align:center}.login-footer p{font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--color-text-light);background:var(--studio-floor);padding:10px 16px;border-radius:10px;display:inline-block}@media(max-width:600px){.login-container{padding:32px 24px;margin:20px}}.violet-character{display:flex;align-items:center;justify-content:center;position:relative}.violet-svg{width:100%;height:100%;object-fit:contain}@keyframes violet-breathe{0%{transform:scaleY(1) translateY(0)}40%{transform:scaleY(1.015) translateY(-1px)}to{transform:scaleY(1) translateY(0)}}.violet-character.breathing .violet-svg{animation:violet-breathe 3s ease-in-out infinite;transform-origin:center 70%;will-change:transform}@keyframes thinking-sway{0%,to{transform:rotate(0)}50%{transform:rotate(2deg)}}@keyframes thinking-finger-tap{0%,90%,to{transform:translateY(0)}95%{transform:translateY(-1px)}}.violet-character.pose-thinking .violet-svg{animation:violet-breathe 3s ease-in-out infinite,thinking-sway 4s ease-in-out infinite}.violet-character.pose-thinking .thinking-hand{animation:thinking-finger-tap 2s ease-in-out infinite}.violet-character.is-thinking:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(139,107,168,.3);animation:thinking-pulse 2s ease-in-out infinite;pointer-events:none}@keyframes thinking-pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(1.05)}}@keyframes encouraging-hand-reach{0%,to{transform:translate(0) translateY(0)}50%{transform:translate(2px) translateY(-1px)}}@keyframes encouraging-nod{0%,to{transform:rotate(0)}50%{transform:rotate(1deg)}}@keyframes encouraging-heart-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.violet-character.pose-encouraging .violet-svg{animation:violet-breathe 3.5s ease-in-out infinite}.violet-character.pose-encouraging .encouraging-hand{animation:encouraging-hand-reach 2.5s ease-in-out infinite;transform-origin:left center}.violet-character.pose-encouraging .violet-head{animation:encouraging-nod 4s ease-in-out infinite}.violet-character.pose-encouraging .encouraging-heart{animation:encouraging-heart-pulse 3s ease-in-out infinite}@keyframes drawing-stroke{0%,85%,to{transform:translate(0) translateY(0)}90%{transform:translate(2px) translateY(1px)}95%{transform:translate(-1px) translateY(-1px)}}@keyframes drawing-crayon-wiggle{0%,80%,to{transform:rotate(-25deg)}90%{transform:rotate(-23deg)}}.violet-character.pose-drawing .violet-svg{animation:violet-breathe 4s ease-in-out infinite}.violet-character.pose-drawing .drawing-arm{animation:drawing-stroke 5s ease-in-out infinite;transform-origin:top center}.violet-character.pose-drawing .crayon{animation:drawing-crayon-wiggle 5s ease-in-out infinite;transform-origin:center center}@keyframes surprised-entrance{0%{transform:scale(.95) translateY(5px);opacity:.8}50%{transform:scale(1.02) translateY(-2px)}to{transform:scale(1) translateY(0);opacity:1}}@keyframes surprised-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes sparkle-twinkle{0%,to{opacity:.8;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}@keyframes reaching-gesture{0%,to{transform:translate(0) translateY(0)}50%{transform:translate(3px) translateY(-2px)}}.violet-character.pose-surprised .violet-svg{animation:violet-breathe 2.5s ease-in-out infinite,surprised-bounce 1.8s ease-in-out infinite}.violet-character.pose-surprised .sparkle{animation:sparkle-twinkle 1.5s ease-in-out infinite}.violet-character.pose-surprised .sparkle-1{animation-delay:0s}.violet-character.pose-surprised .sparkle-2{animation-delay:.5s}.violet-character.pose-surprised .sparkle-3{animation-delay:1s}.violet-character.pose-surprised .reaching-arm{animation:reaching-gesture 2s ease-in-out infinite;transform-origin:left center}@keyframes excited-bounce{0%,to{transform:translateY(0) scale(1)}25%{transform:translateY(-3px) scale(1.02)}50%{transform:translateY(0) scale(1)}75%{transform:translateY(-2px) scale(1.01)}}.violet-character.pose-excited .violet-svg{animation:excited-bounce .8s ease-out}.violet-character:hover .violet-svg{transform:scale(1.05);transition:transform .2s ease-out}.violet-character .violet-svg{transition:opacity .3s ease-in-out}@media(prefers-reduced-motion:reduce){.violet-character.breathing .violet-svg,.violet-character.pose-thinking .violet-svg,.violet-character.pose-excited .violet-svg,.violet-character.pose-encouraging .violet-svg,.violet-character.pose-drawing .violet-svg,.violet-character.pose-surprised .violet-svg{animation:none}.violet-character.is-thinking:after,.violet-character.pose-encouraging .encouraging-hand,.violet-character.pose-encouraging .violet-head,.violet-character.pose-encouraging .encouraging-heart,.violet-character.pose-drawing .drawing-arm,.violet-character.pose-drawing .crayon,.violet-character.pose-surprised .sparkle,.violet-character.pose-surprised .reaching-arm{animation:none;opacity:.5}.violet-character:hover .violet-svg{transform:none}}.home-page{min-height:100vh;padding:24px;background:linear-gradient(180deg,var(--color-meadow-light) 0%,var(--color-bg) 100%);position:relative;overflow-x:hidden}.home-header{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto 40px;padding:0 16px;position:relative;z-index:1}.home-header h1{font-family:var(--font-heading);font-size:36px;font-weight:700;color:var(--violet-vivid);animation:fadeIn .5s var(--ease-bounce);text-shadow:2px 2px 0px rgba(139,92,246,.1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.logout-button{background:var(--canvas-white);color:var(--violet-vivid);padding:12px 24px;border:2px solid var(--violet-vivid);border-radius:16px;font-weight:600;font-family:var(--font-body);box-shadow:3px 3px #8b5cf633;transition:all var(--duration-normal) var(--ease-bounce)}.logout-button:hover{background:var(--violet-vivid);color:#fff;transform:translateY(-3px);box-shadow:4px 4px #8b5cf64d}.violet-greeting{display:flex;align-items:flex-start;gap:20px;max-width:800px;margin:0 auto 48px;padding:0 16px;animation:slideInLeft .6s var(--ease-bounce);position:relative;z-index:1}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.greeting-bubble{background:var(--canvas-white);padding:20px 24px;border-radius:20px;border:3px solid var(--violet-bright);box-shadow:4px 4px #8b5cf626,0 8px 24px var(--shadow-soft);flex:1;position:relative;transform:rotate(-.5deg);transition:all var(--duration-normal) var(--ease-bounce)}.greeting-bubble:hover{transform:rotate(0) translateY(-3px);box-shadow:5px 5px #8b5cf633,0 12px 32px var(--shadow-medium)}.greeting-bubble:before{content:"";position:absolute;left:-12px;top:24px;width:0;height:0;border-style:solid;border-width:10px 12px 10px 0;border-color:transparent var(--violet-bright) transparent transparent}.greeting-bubble p{font-family:var(--font-violet-voice);font-size:20px;color:var(--color-text);margin:0;line-height:1.4}.activities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px;max-width:1200px;margin:0 auto;padding:0 16px;position:relative;z-index:1}.activity-card{padding:32px;cursor:pointer;position:relative;overflow:visible}.activity-card.disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.3)}.activity-card.disabled:hover{transform:rotate(-.5deg)!important;box-shadow:4px 4px #0000001a,0 8px 24px var(--shadow-soft)!important}.activity-icon{font-size:72px;margin-bottom:16px;display:block;transition:transform var(--duration-normal) var(--ease-bounce)}.activity-card:hover:not(.disabled) .activity-icon{transform:scale(1.1) rotate(5deg)}.activity-card h2{font-family:var(--font-heading);font-size:26px;font-weight:700;color:var(--violet-vivid);margin-bottom:12px}.activity-card p{font-family:var(--font-body);color:var(--color-text-light);font-size:16px;line-height:1.6}.coming-soon{position:absolute;top:-8px;right:-8px;background:var(--creative-yellow);color:var(--color-text);padding:8px 16px;border-radius:16px;border:3px solid var(--sketch-line);font-family:var(--font-heading);font-size:13px;font-weight:700;box-shadow:3px 3px #0000001a,0 4px 12px #fbbf244d;transform:rotate(8deg);animation:wiggle 3s ease-in-out infinite}@media(max-width:768px){.home-header{flex-direction:column;gap:16px;text-align:center}.home-header h1{font-size:24px}.violet-greeting{flex-direction:column;align-items:center;text-align:center}.greeting-bubble:before{display:none}.activities-grid{grid-template-columns:1fr}}.drawing-canvas-container{background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);padding:20px;display:flex;gap:20px;max-width:1200px;animation:fadeIn .5s var(--ease-smooth)}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.toolbar{display:flex;flex-direction:column;gap:24px;width:fit-content;max-width:250px;padding:16px;background:var(--color-bg);border-radius:12px}.tool-section{display:flex;flex-direction:column;gap:12px;transition:all var(--duration-normal) var(--ease-smooth)}.tool-section.collapsed{gap:0}.section-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 0}.section-header:hover{opacity:.8}.tool-section h4{font-size:14px;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px;margin:0}.tool-buttons{display:flex;flex-direction:column;gap:8px}.tool-button{background:#fff;padding:12px;border-radius:8px;border:2px solid var(--color-border);font-size:14px;font-weight:600;text-align:left;transition:all var(--duration-normal) var(--ease-smooth);cursor:pointer}.tool-button:hover{border-color:var(--color-primary);transform:translate(4px)}.tool-button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.color-palette{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.color-swatch{width:32px;height:32px;border-radius:8px;border:2px solid var(--color-border);cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth)}.color-swatch:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.color-swatch.active{border:3px solid var(--color-primary);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--color-primary)}.size-buttons{display:flex;flex-direction:column;gap:8px}.size-button{background:#fff;padding:12px;border-radius:8px;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);min-height:44px}.size-button:hover{border-color:var(--color-primary);transform:translate(4px)}.size-button.active{border-color:var(--color-primary);background:var(--color-accent)}.size-preview{border-radius:50%;transition:all var(--duration-normal) var(--ease-smooth)}.action-buttons{display:flex;flex-direction:column;gap:8px}.action-button{background:#fff;padding:12px;border-radius:8px;border:2px solid var(--color-border);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth)}.action-button:hover:not(:disabled){border-color:var(--color-primary);transform:translate(4px)}.action-button:disabled{opacity:.4;cursor:not-allowed}.action-button.danger{color:var(--color-error);border-color:var(--color-error)}.action-button.danger:hover:not(:disabled){background:var(--color-error);color:#fff}.canvas-wrapper{flex:1;display:flex;justify-content:center;align-items:flex-start;min-width:0}.canvas-stage{background:#fff;border:2px solid var(--color-border);border-radius:12px;cursor:crosshair;box-shadow:var(--shadow-sm);touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@media(max-width:1024px){.drawing-canvas-container{flex-direction:column}.toolbar{flex-direction:row;min-width:auto;overflow-x:auto}.tool-section{min-width:150px}.canvas-wrapper{overflow-x:auto}}@media(max-width:768px){.drawing-canvas-container{padding:12px}.toolbar{padding:12px;gap:16px}.color-palette{grid-template-columns:repeat(5,1fr);gap:6px}.color-swatch{width:28px;height:28px}.canvas-stage{max-width:100%}}.reference-gallery-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}.reference-gallery{background:#fff;border-radius:16px;max-width:700px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 50px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gallery-header{padding:1.25rem 1.5rem;background:linear-gradient(135deg,#8b6ba8,#a78bba);color:#fff;position:relative}.gallery-header h3{margin:0 0 .25rem;font-size:1.5rem;font-weight:600}.gallery-subtitle{margin:0;font-size:.9rem;opacity:.9}.gallery-close-btn{position:absolute;top:1rem;right:1rem;background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.gallery-close-btn:hover{background:#ffffff4d}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;padding:1.25rem;overflow-y:auto;max-height:400px}@media(max-width:600px){.gallery-grid{grid-template-columns:repeat(2,1fr);max-height:300px}}.gallery-image-btn{position:relative;aspect-ratio:1;border:3px solid transparent;border-radius:12px;overflow:hidden;cursor:pointer;padding:0;background:#f0f0f0;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.gallery-image-btn:hover{transform:scale(1.03);box-shadow:0 4px 12px #00000026}.gallery-image-btn:focus{outline:none;box-shadow:0 0 0 3px #8b6ba880}.gallery-image-btn.selected{border-color:#8b6ba8;box-shadow:0 4px 16px #8b6ba866}.gallery-image-btn img{width:100%;height:100%;object-fit:cover}.selection-indicator{position:absolute;inset:0;background:#8b6ba84d;display:flex;align-items:center;justify-content:center;animation:pulseIn .2s ease-out}@keyframes pulseIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.checkmark{background:#8b6ba8;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;box-shadow:0 4px 12px #0003}.gallery-footer{padding:1rem 1.5rem;background:#f8f8f8;border-top:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.attribution{margin:0;font-size:.8rem;color:#666}.gallery-actions{display:flex;gap:.75rem}.gallery-btn{padding:.6rem 1.25rem;border-radius:20px;font-size:1rem;font-weight:500;cursor:pointer;border:none;transition:transform .1s ease,opacity .15s ease}.gallery-btn:active{transform:scale(.97)}.gallery-btn-secondary{background:#e0e0e0;color:#333}.gallery-btn-secondary:hover{background:#d0d0d0}.gallery-btn-primary{background:linear-gradient(135deg,#8b6ba8,#a78bba);color:#fff}.gallery-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#7b5b98,#9778aa)}.gallery-btn-primary:disabled{opacity:.5;cursor:not-allowed}@media(prefers-reduced-motion:reduce){.reference-gallery-overlay,.reference-gallery,.gallery-image-btn,.selection-indicator{animation:none}.gallery-image-btn:hover{transform:none}}.violet-chat{background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-header{background:var(--color-violet);color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px;border-radius:20px 20px 0 0}.chat-header .violet-character{flex-shrink:0;background:#ffffff26;border-radius:50%;padding:4px}.chat-header h3{flex:1;margin:0;font-size:18px}.close-button{background:#fff3;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth)}.close-button:hover{background:#ffffff4d;transform:rotate(90deg)}.messages-container{flex:1 1 auto;min-height:0;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;background:linear-gradient(180deg,#faf8ff,#fff)}.message{display:flex;animation:messageIn .3s var(--ease-smooth)}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{justify-content:flex-end}.message.violet{justify-content:flex-start}.message-bubble{max-width:75%;padding:12px 16px;border-radius:16px;word-wrap:break-word;line-height:1.5}.message.user .message-bubble{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.message.violet .message-bubble{background:var(--color-accent);color:var(--color-text);border-bottom-left-radius:4px}.message.streaming .message-bubble{position:relative}.cursor{display:inline-block;width:2px;height:1em;background:var(--color-violet);margin-left:2px;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.message.thinking-state .message-bubble{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.thinking-text{color:var(--color-text);font-style:italic;animation:thinkingTextFade 2s ease-in-out infinite}@keyframes thinkingTextFade{0%,to{opacity:.8}50%{opacity:1}}.thinking-dots{display:inline-flex;gap:6px;font-size:16px}.thinking-dots span{display:inline-block;animation:thinkingEmoji 1.4s ease-in-out infinite}.thinking-dots span:nth-child(1){animation-delay:0s}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes thinkingEmoji{0%,to{transform:translateY(0) scale(1);opacity:.7}50%{transform:translateY(-4px) scale(1.1);opacity:1}}.message.error-state .error-bubble{display:flex;flex-direction:column;align-items:center;gap:12px;background:linear-gradient(135deg,#fff5f7,#ffeef2);border:2px dashed var(--color-violet);text-align:center;animation:gentleWobble .6s var(--ease-smooth)}@keyframes gentleWobble{0%,to{transform:rotate(0)}25%{transform:rotate(-1deg)}75%{transform:rotate(1deg)}}.error-emoji{font-size:32px;animation:emojiPop .4s var(--ease-smooth)}@keyframes emojiPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.error-text{color:var(--color-text);font-size:14px;line-height:1.5}.retry-button{background:var(--color-violet);color:#fff;padding:10px 20px;border-radius:20px;font-weight:600;font-size:14px;transition:all var(--duration-normal) var(--ease-smooth);animation:pulseGlow 2s ease-in-out infinite}.retry-button:hover{background:var(--color-primary);transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #9370db4d}@keyframes pulseGlow{0%,to{box-shadow:0 0 #9370db66}50%{box-shadow:0 0 0 8px #9370db00}}.error-message{background:#fff5f5;border:2px solid var(--color-error);border-radius:12px;padding:16px;text-align:center}.error-message p{color:var(--color-error);margin-bottom:12px}.error-message button{background:var(--color-error);color:#fff;padding:8px 16px;border-radius:8px;font-weight:600}.error-message button:hover{background:#d32f2f}.detail-level-control{flex-shrink:0;padding:12px 16px;background:linear-gradient(180deg,#faf8ff,#fff);border-top:1px solid var(--color-border);display:flex;align-items:center;gap:12px}.detail-level-control label{font-size:13px;font-weight:600;color:var(--color-text);white-space:nowrap}.detail-buttons{display:flex;gap:8px;flex:1}.detail-button{flex:1;padding:10px 16px;border-radius:12px;font-size:13px;font-weight:600;background:#fff;border:2px solid var(--color-border);color:var(--color-text);cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);white-space:nowrap}.detail-button:hover:not(:disabled){border-color:var(--color-violet);transform:translateY(-2px);box-shadow:0 4px 8px #9370db26}.detail-button.active{background:var(--color-violet);border-color:var(--color-violet);color:#fff;box-shadow:0 2px 8px #9370db4d}.detail-button:disabled{opacity:.5;cursor:not-allowed}.chat-input{flex-shrink:0;padding:16px;display:flex;gap:12px;border-top:1px solid var(--color-border);background:#fff}.chat-input input{flex:1;padding:12px 16px;border:2px solid var(--color-border);border-radius:12px;font-size:14px;transition:all var(--duration-normal) var(--ease-smooth)}.chat-input input:focus{border-color:var(--color-violet);box-shadow:0 0 0 3px #9370db1a}.chat-input input:disabled{background:#f5f5f5;cursor:not-allowed}.chat-input button{background:var(--color-violet);color:#fff;padding:12px 24px;border-radius:12px;font-weight:600;transition:all var(--duration-normal) var(--ease-smooth)}.chat-input button:hover:not(:disabled){background:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.chat-input button:disabled{background:#ccc;cursor:not-allowed;transform:none}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:transparent}.messages-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}.free-draw-page{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column}.draw-header{background:#fff;padding:16px 24px;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.draw-header h1{font-size:24px;color:var(--color-primary);margin:0}.back-button{background:var(--color-border);color:var(--color-text);padding:10px 20px;border-radius:8px;font-weight:600;transition:all var(--duration-normal) var(--ease-smooth)}.back-button:hover{background:var(--color-accent);transform:translate(-4px)}.header-actions{display:flex;gap:12px;align-items:center}.load-button{background:var(--color-primary);color:#fff;padding:10px 20px;border-radius:8px;font-weight:600;transition:all var(--duration-normal) var(--ease-smooth)}.load-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.save-button{background:var(--color-success);color:#fff;padding:10px 20px;border-radius:8px;font-weight:600;transition:all var(--duration-normal) var(--ease-smooth)}.save-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.logout-button{background:#fff;color:var(--color-primary);padding:10px 20px;border-radius:8px;font-weight:600;border:2px solid var(--color-primary);transition:all var(--duration-normal) var(--ease-smooth)}.logout-button:hover{background:var(--color-primary);color:#fff}.draw-container{flex:1;position:relative;display:flex;padding:24px;gap:24px}.canvas-section{flex:1;display:flex;justify-content:center;align-items:flex-start}.violet-toggle.open{background:var(--color-primary);animation:none}@media(max-width:768px){.draw-header{flex-direction:column;gap:12px}.draw-header h1{font-size:20px}.draw-container{padding:12px}.violet-toggle{bottom:16px;right:16px;padding:12px 20px;font-size:14px}.chat-panel{position:fixed;right:0;bottom:0;width:100%;height:70vh;border-radius:20px 20px 0 0}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s var(--ease-smooth)}.modal-content{background:#fff;border-radius:16px;max-width:800px;width:90%;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .3s var(--ease-bounce)}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:20px 24px;border-bottom:2px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;color:var(--color-primary);font-size:24px}.modal-close{background:none;border:none;font-size:28px;color:var(--color-text-light);cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-quick) var(--ease-smooth)}.modal-close:hover{background:var(--color-border);color:var(--color-text)}.modal-body{padding:24px;overflow-y:auto;flex:1}.empty-state p:first-child{font-size:18px;font-weight:600;color:var(--color-text)}.drawings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.drawing-card{background:#fff;border:2px solid var(--color-border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth)}.drawing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.drawing-thumbnail{width:100%;height:150px;object-fit:cover;background:var(--color-bg)}.drawing-thumbnail-placeholder{width:100%;height:150px;background:var(--color-bg);display:flex;align-items:center;justify-content:center;font-size:48px}.drawing-info{padding:12px}.drawing-info h3{margin:0 0 4px;font-size:14px;color:var(--color-text)}.drawing-date{margin:0;font-size:12px;color:var(--color-text-light)}@media(max-width:768px){.modal-content{width:95%;max-height:85vh}.drawings-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.drawing-thumbnail{height:120px}}.save-modal{max-width:450px}.save-prompt{font-size:16px;color:var(--color-text);margin-bottom:16px;text-align:center}.title-input{width:100%;padding:14px 16px;font-size:18px;border:2px solid var(--color-border);border-radius:12px;transition:all var(--duration-normal) var(--ease-smooth);box-sizing:border-box}.title-input:focus{border-color:var(--color-violet);box-shadow:0 0 0 3px #9370db33;outline:none}.title-input::placeholder{color:var(--color-text-light)}.save-error{background:#fff5f5;border:2px solid var(--color-error);border-radius:8px;padding:12px 16px;margin-top:12px;color:var(--color-error);font-size:14px;text-align:center}.save-actions{display:flex;gap:12px;margin-top:20px;justify-content:flex-end}.cancel-button{background:var(--color-border);color:var(--color-text);padding:12px 24px;border-radius:8px;font-weight:600;transition:all var(--duration-normal) var(--ease-smooth)}.cancel-button:hover:not(:disabled){background:var(--color-accent)}.confirm-save-button{background:var(--color-success);color:#fff;padding:12px 24px;border-radius:8px;font-weight:600;transition:all var(--duration-normal) var(--ease-smooth)}.confirm-save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.confirm-save-button:disabled,.cancel-button:disabled{opacity:.6;cursor:not-allowed}.coloring-page{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column;position:relative;overflow-x:hidden}.coloring-header{background:var(--canvas-white);padding:20px 32px;box-shadow:0 4px #8b5cf61a,0 6px 20px var(--shadow-soft);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100;border-bottom:3px solid var(--violet-bright)}.coloring-header h1{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--violet-vivid);margin:0;text-shadow:2px 2px 0px rgba(139,92,246,.1)}.back-button{background:var(--canvas-white);color:var(--violet-vivid);padding:12px 24px;border:2px solid var(--violet-vivid);border-radius:12px;font-family:var(--font-body);font-weight:600;box-shadow:2px 2px #8b5cf626;transition:all var(--duration-normal) var(--ease-bounce)}.back-button:hover{background:var(--violet-vivid);color:#fff;transform:translate(-6px);box-shadow:3px 3px #8b5cf640}.header-actions{display:flex;gap:16px;align-items:center}.logout-button{background:var(--canvas-white);color:var(--violet-vivid);padding:12px 24px;border-radius:12px;font-family:var(--font-body);font-weight:600;border:2px solid var(--violet-vivid);box-shadow:2px 2px #8b5cf626;transition:all var(--duration-normal) var(--ease-bounce)}.logout-button:hover{background:var(--violet-vivid);color:#fff;transform:translateY(-3px);box-shadow:3px 3px #8b5cf640}.progress-indicator{background:var(--color-success);color:#fff;padding:10px 20px;border-radius:8px;font-weight:600}.complete-button{background:var(--color-violet);color:#fff;padding:10px 20px;border-radius:8px;font-weight:600;transition:all var(--duration-normal) var(--ease-smooth)}.complete-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.complete-button:disabled{opacity:.5;cursor:not-allowed}.coloring-container{flex:1;position:relative;display:flex;padding:24px;gap:24px}.library-section{flex:1;position:relative;z-index:1}.library-title{font-family:var(--font-heading);font-size:26px;font-weight:700;color:var(--violet-vivid);margin-top:16px;margin-bottom:32px;text-align:center}.pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:28px;padding:0 8px}.page-card{cursor:pointer;overflow:visible}.page-thumbnail{width:100%;height:180px;background:linear-gradient(135deg,var(--studio-floor) 0%,var(--violet-glow) 100%);display:flex;align-items:center;justify-content:center;border-radius:12px 12px 0 0;transition:all var(--duration-normal) var(--ease-bounce)}.page-card:hover .page-thumbnail{background:linear-gradient(135deg,var(--violet-glow) 0%,var(--creative-pink) 20%)}.thumbnail-placeholder{font-size:64px;transition:transform var(--duration-normal) var(--ease-bounce)}.page-card:hover .thumbnail-placeholder{transform:scale(1.15) rotate(8deg)}.svg-thumbnail-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:12px;transition:transform var(--duration-normal) var(--ease-bounce)}.svg-thumbnail-preview svg{max-width:100%;max-height:100%;width:auto;height:auto}.page-card:hover .svg-thumbnail-preview{transform:scale(1.05)}.page-info{padding:16px;background:var(--canvas-white);border-radius:0 0 12px 12px}.page-info h3{margin:0 0 10px;font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--color-text)}.page-meta{display:flex;gap:8px;align-items:center;font-family:var(--font-body);font-size:14px;color:var(--color-text-light)}.page-difficulty{margin:0;padding:4px 10px;background:var(--creative-teal);color:#fff;border-radius:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.page-colors{margin:0;font-size:13px;font-weight:600;color:var(--color-text-light)}.page-progress{margin:0;font-size:13px;font-weight:700;color:var(--color-success)}.canvas-section{flex:1;display:flex;gap:32px;align-items:flex-start}.canvas-section>.color-palette{background:#fff;padding:20px;border-radius:12px;box-shadow:var(--shadow-sm);width:fit-content;max-width:200px;flex-shrink:0;height:fit-content;transition:all var(--duration-normal) var(--ease-smooth);display:flex;flex-direction:column;align-items:flex-start}.color-palette.collapsed{width:auto;min-width:auto;padding:12px 16px}.palette-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.palette-header:hover{opacity:.8}.collapse-icon{font-size:12px;color:var(--color-primary);margin-left:8px}.color-palette h3{margin:0 0 16px;font-size:16px;color:var(--color-text)}.color-palette.collapsed h3{margin:0}.color-swatch{width:60px;height:60px;border-radius:8px;margin-bottom:12px;cursor:pointer;border:3px solid transparent;transition:border-color .15s ease,box-shadow .15s ease;position:relative;display:flex;align-items:center;justify-content:center}.color-swatch:hover{box-shadow:var(--shadow-md);border-color:var(--color-border)}.color-swatch.selected{border-color:var(--color-primary);box-shadow:0 0 0 4px #4a90e24d,var(--shadow-md)}.color-number{background:#fff;color:var(--color-text);font-weight:700;font-size:16px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.svg-canvas{flex:1;background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);padding:24px;display:flex;align-items:center;justify-content:center;overflow:auto}.svg-container{width:100%;max-width:600px;cursor:pointer}.svg-container svg{width:100%;height:auto}.svg-container svg [id^=region-]{cursor:pointer;transition:opacity .1s ease}.svg-container svg [id^=region-]:hover{opacity:.8}.svg-container svg text{pointer-events:none;-webkit-user-select:none;user-select:none}.svg-placeholder{text-align:center;color:var(--color-text-light)}.svg-placeholder p{margin:8px 0}.loading-state,.empty-state{text-align:center;padding:60px 20px;color:var(--color-text-light)}.empty-state p{margin:8px 0;font-size:16px}.retry-button{margin-top:16px;background:var(--color-primary);color:#fff;padding:12px 24px;border-radius:8px;font-weight:600;transition:all var(--duration-normal) var(--ease-smooth)}.retry-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.violet-toggle{position:fixed;bottom:24px;right:24px;background:var(--color-violet);color:#fff;padding:16px 24px;border-radius:50px;font-size:16px;font-weight:600;box-shadow:var(--shadow-lg);z-index:50;transition:all var(--duration-normal) var(--ease-bounce)}.violet-toggle:hover{transform:scale(1.1);box-shadow:0 8px 24px #9370db66}.violet-toggle.open{background:var(--color-primary);animation:none;right:100px}.chat-panel{position:fixed;right:24px;bottom:100px;width:400px;height:600px;max-height:calc(100vh - 120px);animation:slideInRight .4s var(--ease-bounce);z-index:200}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media(max-width:1200px){.chat-panel{width:350px;height:500px}}@media(max-width:768px){.coloring-header{flex-direction:column;gap:12px}.coloring-header h1{font-size:20px}.coloring-container{padding:12px}.canvas-section{flex-direction:column}.color-palette{width:100%;display:flex;gap:8px;overflow-x:auto}.color-swatch{width:50px;height:50px;margin:0}.violet-toggle{bottom:16px;right:16px;padding:12px 20px;font-size:14px}.chat-panel{position:fixed;right:0;bottom:0;width:100%;height:70vh;border-radius:20px 20px 0 0}}.find-difference-page{min-height:100vh;background:linear-gradient(135deg,#f5f3ff,#ede9fe);font-family:Nunito,sans-serif}.page-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:#fff;box-shadow:0 2px 8px #8b5cf61a}.header-left{display:flex;align-items:center;gap:1rem}.header-left h1{font-family:Fredoka,sans-serif;font-size:2rem;color:var(--violet-vivid, #8B5CF6);margin:0}.back-button{padding:.5rem 1rem;background:var(--violet-vivid, #8B5CF6);color:#fff;border:none;border-radius:8px;font-family:Nunito,sans-serif;font-weight:600;cursor:pointer;transition:transform .2s,background-color .2s}.back-button:hover{background:var(--violet-deep, #7C3AED);transform:translateY(-2px)}.header-right{display:flex;align-items:center;gap:1rem}.user-name{font-weight:600;color:#333}.logout-button{padding:.5rem 1rem;background:#f3f4f6;color:#333;border:none;border-radius:8px;font-family:Nunito,sans-serif;cursor:pointer;transition:background .2s}.logout-button:hover{background:#e5e7eb}.violet-message{margin:2rem auto;max-width:800px;padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 12px #8b5cf626;display:flex;align-items:center;gap:1rem;animation:slideIn .3s ease-out}.violet-message.completion{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.violet-avatar{font-size:3rem;flex-shrink:0}.violet-text{font-family:Comic Neue,cursive;font-size:1.25rem;line-height:1.6}.violet-message.completion .violet-text{color:#fff}.main-content{padding:2rem;max-width:1400px;margin:0 auto}.loading,.error{text-align:center;padding:2rem;font-size:1.25rem;color:#666}.error{color:#dc2626}.puzzle-gallery h2{font-family:Fredoka,sans-serif;font-size:2rem;color:var(--violet-vivid, #8B5CF6);text-align:center;margin-bottom:2rem}.puzzle-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;margin-top:2rem}.puzzle-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 12px #8b5cf61a;cursor:pointer;transition:transform .2s,box-shadow .2s;text-align:center}.puzzle-card:hover{transform:translateY(-8px);box-shadow:0 8px 24px #8b5cf633}.puzzle-icon{font-size:4rem;margin-bottom:1rem}.puzzle-card h3{font-family:Fredoka,sans-serif;font-size:1.5rem;color:#333;margin:.5rem 0}.puzzle-info{display:flex;justify-content:space-around;margin-top:1rem;font-size:.9rem;color:#666}.difficulty{font-weight:600;text-transform:capitalize}.puzzle-container{max-width:1200px;margin:0 auto}.progress-bar{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #8b5cf61a;margin-bottom:2rem;text-align:center}.progress-text{font-family:Fredoka,sans-serif;font-size:1.5rem;color:var(--violet-vivid, #8B5CF6);display:block;margin-bottom:1rem}.progress-dots{display:flex;justify-content:center;gap:1rem;font-size:1.5rem}.dot{width:2.5rem;height:2.5rem;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:#f3f4f6;color:#999;transition:all .3s}.dot.found{background:var(--violet-vivid, #8B5CF6);color:#fff;animation:popIn .3s ease-out}@keyframes popIn{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.images-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.image-wrapper{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 12px #8b5cf61a;position:relative}.image-wrapper h3{font-family:Fredoka,sans-serif;font-size:1.25rem;color:#333;text-align:center;margin:0 0 1rem}.svg-container{width:100%;border:3px solid var(--violet-vivid, #8B5CF6);border-radius:12px;overflow:hidden;cursor:pointer;background:#fff;transition:transform .1s;position:relative}.svg-container:hover{transform:scale(1.02)}.svg-container svg{width:100%;height:auto;display:block}.svg-container.shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-8px)}20%,40%,60%,80%{transform:translate(8px)}}.difference-marker{position:absolute;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:markerAppear .5s ease-out}.checkmark{font-size:3rem;color:var(--violet-vivid, #8B5CF6);background:#fffffff2;border-radius:50%;width:4rem;height:4rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #8b5cf64d;animation:checkmarkPop .5s ease-out}@keyframes markerAppear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}@keyframes checkmarkPop{0%{transform:scale(0) rotate(-45deg)}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}.completion-actions{text-align:center;margin:2rem 0}.try-another-button{padding:1rem 2rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;border:none;border-radius:12px;font-family:Fredoka,sans-serif;font-size:1.25rem;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #8b5cf64d}.try-another-button:hover{transform:translateY(-4px);box-shadow:0 8px 24px #8b5cf666}.back-to-gallery-button{display:block;margin:2rem auto 0;padding:.75rem 1.5rem;background:#f3f4f6;color:#333;border:none;border-radius:8px;font-family:Nunito,sans-serif;font-weight:600;cursor:pointer;transition:background .2s}.back-to-gallery-button:hover{background:#e5e7eb}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.images-container{grid-template-columns:1fr}.page-header{flex-direction:column;gap:1rem}.header-left h1{font-size:1.5rem}.puzzle-cards{grid-template-columns:1fr}.progress-dots{flex-wrap:wrap}.checkmark{font-size:2rem;width:3rem;height:3rem}}.feedback-float-button{position:fixed;bottom:20px;left:20px;width:56px;height:56px;border-radius:50%;background:var(--color-primary);color:#fff;border:none;box-shadow:var(--shadow-lg);cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center;font-size:24px;transition:transform var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth)}.feedback-float-button:hover{transform:scale(1.1);box-shadow:0 12px 24px #8b7bb866}.feedback-float-button:active{transform:scale(.95)}.feedback-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001;padding:16px;animation:fadeIn var(--duration-normal) var(--ease-smooth)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.feedback-modal{background:#fff;border-radius:20px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:scaleIn var(--duration-normal) var(--ease-bounce)}@keyframes scaleIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.feedback-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border)}.feedback-header h2{font-size:20px;color:var(--color-text);margin:0}.feedback-close-x{width:32px;height:32px;border-radius:50%;background:var(--color-bg);border:none;font-size:16px;color:var(--color-text-light);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-quick) var(--ease-smooth)}.feedback-close-x:hover{background:var(--color-border);color:var(--color-text)}.feedback-form{padding:24px;display:flex;flex-direction:column;gap:20px}.feedback-type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:12px}.type-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;border:2px solid var(--color-border);border-radius:12px;background:#fff;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth)}.type-btn:hover{border-color:var(--color-primary);background:var(--color-bg)}.type-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.type-icon{font-size:28px}.type-label{font-size:13px;font-weight:600;text-align:center;line-height:1.3}.feedback-field{display:flex;flex-direction:column;gap:8px}.feedback-field label{font-size:14px;font-weight:600;color:var(--color-text)}.feedback-field input,.feedback-field textarea{padding:12px 16px;border:2px solid var(--color-border);border-radius:12px;font-size:15px;font-family:inherit;transition:border-color var(--duration-quick) var(--ease-smooth);resize:vertical}.feedback-field input:focus,.feedback-field textarea:focus{outline:none;border-color:var(--color-primary)}.feedback-field input::placeholder,.feedback-field textarea::placeholder{color:var(--color-text-light);opacity:.7}.feedback-error{background:#ffebee;color:var(--color-error);padding:12px 16px;border-radius:8px;font-size:14px;text-align:center}.feedback-submit-btn{background:var(--color-primary);color:#fff;padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth)}.feedback-submit-btn:hover:not(:disabled){background:var(--color-violet);transform:translateY(-2px);box-shadow:var(--shadow-md)}.feedback-submit-btn:disabled{opacity:.7;cursor:not-allowed}.feedback-success{padding:48px 24px;text-align:center}.success-icons{font-size:36px;margin-bottom:16px}.feedback-success h2{font-size:22px;color:var(--color-text);margin-bottom:12px}.feedback-success p{color:var(--color-text-light);margin-bottom:24px}.feedback-error-state{padding:48px 24px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.feedback-error-state h2{font-size:20px;color:var(--color-text);margin-bottom:12px}.feedback-error-state p{color:var(--color-text-light);margin-bottom:24px}.error-actions{display:flex;gap:12px;justify-content:center}.feedback-close-btn,.feedback-retry-btn{padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all var(--duration-quick) var(--ease-smooth)}.feedback-close-btn{background:var(--color-bg);border:2px solid var(--color-border);color:var(--color-text)}.feedback-close-btn:hover{background:var(--color-border)}.feedback-retry-btn{background:var(--color-primary);border:none;color:#fff}.feedback-retry-btn:hover{background:var(--color-violet)}@media(max-width:480px){.feedback-float-button{bottom:16px;left:16px;width:52px;height:52px}.feedback-modal{max-height:85vh;border-radius:16px}.feedback-header{padding:16px 20px}.feedback-form{padding:20px}.type-btn{padding:12px 8px}.type-label{font-size:12px}}:root{--violet-vivid: #8B5CF6;--violet-deep: #7C3AED;--violet-bright: #A78BFA;--violet-glow: rgba(139, 92, 246, .2);--creative-pink: #F472B6;--creative-teal: #14B8A6;--creative-orange: #FB923C;--creative-yellow: #FBBF24;--studio-wall: #FAF5FF;--studio-floor: #F3E8FF;--canvas-white: #FFFFFF;--sketch-line: #6B7280;--color-meadow-light: #E8F5E9;--color-meadow-dark: #C8E6C9;--color-text: #2D2D2D;--color-text-light: #666666;--color-border: #E0D8F0;--color-error: #E57373;--color-success: #81C784;--color-primary: var(--violet-vivid);--color-secondary: var(--violet-bright);--color-accent: var(--studio-floor);--color-violet: var(--violet-vivid);--color-bg: var(--studio-wall);--font-violet-voice: "Comic Neue", "Segoe Print", "Bradley Hand", cursive;--font-body: "Nunito", "Quicksand", "Varela Round", sans-serif;--font-heading: "Fredoka", "Baloo 2", "Righteous", sans-serif;--font-numbers: "Poppins", "Inter", sans-serif;--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--duration-quick: .15s;--duration-normal: .3s;--duration-slow: .5s;--shadow-soft: rgba(139, 92, 246, .1);--shadow-medium: rgba(139, 92, 246, .15);--shadow-bold: rgba(139, 92, 246, .25);--shadow-sm: 0 2px 4px var(--shadow-soft);--shadow-md: 0 4px 8px var(--shadow-medium);--shadow-lg: 0 8px 16px var(--shadow-bold)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text)}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;color:var(--color-text)}#root{min-height:100vh}button{cursor:pointer;border:none;background:none;font-family:inherit;transition:all var(--duration-normal) var(--ease-smooth)}button:disabled{opacity:.5;cursor:not-allowed}button:hover:not(:disabled){transform:scale(1.05)}button:active:not(:disabled){transform:scale(.95)}input,textarea{font-family:inherit;border:2px solid var(--color-border);border-radius:8px;padding:12px;transition:border-color var(--duration-normal) var(--ease-smooth)}input:focus,textarea:focus{outline:none;border-color:var(--color-primary)}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.paint-splash{position:absolute;opacity:.15;filter:blur(80px);pointer-events:none;border-radius:50%;z-index:0}.splash-pink{background:var(--creative-pink)}.splash-teal{background:var(--creative-teal)}.splash-orange{background:var(--creative-orange)}.splash-yellow{background:var(--creative-yellow)}.splash-violet{background:var(--violet-vivid)}.sketchbook-card{background:var(--canvas-white);border:3px solid var(--sketch-line);border-radius:16px;box-shadow:4px 4px #0000001a,0 8px 24px var(--shadow-soft);position:relative;transition:all var(--duration-normal) var(--ease-bounce)}.sketchbook-card:nth-child(odd){transform:rotate(-.5deg)}.sketchbook-card:nth-child(2n){transform:rotate(.5deg)}.sketchbook-card:hover{transform:translateY(-8px) rotate(0) scale(1.02);box-shadow:6px 6px #00000026,0 12px 32px var(--shadow-bold)}@keyframes float-in{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.card-enter{animation:float-in .5s var(--ease-bounce) forwards}.card-enter:nth-child(1){animation-delay:.1s}.card-enter:nth-child(2){animation-delay:.2s}.card-enter:nth-child(3){animation-delay:.3s}.card-enter:nth-child(4){animation-delay:.4s}.card-enter:nth-child(5){animation-delay:.5s}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}.playful-button:hover{animation:wiggle .5s ease-in-out}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1.2)}}.sparkle{animation:sparkle .6s var(--ease-bounce) infinite}
