*{margin:0;padding:0;box-sizing:border-box}:root{--bg-color: #FFF8F0;--primary-accent: #FF8C69;--secondary-accent: #A8D8EA;--success-color: #B5EAD7;--warning-color: #FFD6BA;--text-color: #3D2B1F;--card-bg: #FFFFFF;--pearl-purple: #9B59B6;--pearl-dark: #7D3C98}body{font-family:Nunito,sans-serif;background-color:var(--bg-color);color:var(--text-color);min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}.app-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:20px}.card{background:var(--card-bg);border-radius:20px;padding:24px;box-shadow:0 4px 20px #3d2b1f1a}.btn{font-family:Nunito,sans-serif;font-weight:700;font-size:18px;padding:16px 32px;border:none;border-radius:50px;cursor:pointer;transition:all .2s ease;min-width:48px;min-height:48px}.btn:hover{transform:scale(1.05)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--primary-accent);color:#fff}.btn-primary:hover{background:#ff7a52}.btn-secondary{background:var(--secondary-accent);color:var(--text-color)}.btn-success{background:var(--success-color);color:var(--text-color)}.btn-back{background:transparent;color:var(--text-color);padding:12px 20px;font-size:16px}.text-input{font-family:Nunito,sans-serif;font-size:20px;padding:16px 24px;border:3px solid var(--secondary-accent);border-radius:15px;width:100%;max-width:300px;text-align:center;outline:none;transition:border-color .2s}.text-input:focus{border-color:var(--primary-accent)}.puppy-composite{position:relative;image-rendering:pixelated}.puppy-composite img{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.mood-sad{animation:sadDroop .5s ease-in-out}.mood-eating{animation:eating .3s ease-in-out infinite}@keyframes happyBounce{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.1) translateY(-10px)}}@keyframes sadDroop{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}@keyframes eating{0%,to{transform:rotate(0) scale(1)}25%{transform:rotate(-3deg) scale(1.02)}75%{transform:rotate(3deg) scale(1.02)}}@keyframes excited{0%,to{transform:scale(1) translateY(0)}25%{transform:scale(1.05) translateY(-5px)}50%{transform:scale(1) translateY(0)}75%{transform:scale(1.05) translateY(-5px)}}.tail-wag{animation:tailWag .35s ease-in-out infinite;transform-origin:40% 60%}@keyframes tailWag{0%,to{transform:rotate(0)}25%{transform:rotate(10deg)}75%{transform:rotate(-10deg)}}.pearl-container{position:fixed;right:-200px;bottom:100px;transition:right .5s ease-in-out;z-index:100}.pearl-container.visible{right:20px}.pearl-sprite{width:180px;height:auto}.pearl-fallback{width:180px;height:220px;background:linear-gradient(135deg,var(--pearl-purple),var(--pearl-dark));border-radius:50% 50% 40% 40%;position:relative;display:flex;align-items:center;justify-content:center}.pearl-badge{font-size:40px}.pearl-dialogue{position:absolute;bottom:100%;right:0;background:#fff;padding:16px 20px;border-radius:20px;box-shadow:0 4px 15px #00000026;max-width:280px;margin-bottom:10px;font-size:16px;line-height:1.4}.pearl-dialogue:after{content:"";position:absolute;bottom:-10px;right:30px;width:20px;height:20px;background:#fff;transform:rotate(45deg)}.threat-meter{display:flex;gap:20px;padding:15px 25px;background:var(--card-bg);border-radius:50px;box-shadow:0 2px 10px #0000001a}.meter-section{display:flex;align-items:center;gap:8px}.meter-label{font-weight:600;font-size:14px}.meter-icons{display:flex;gap:4px}.paw-icon,.bone-icon{font-size:20px;transition:transform .2s,opacity .2s}.paw-icon.filled{animation:pawPop .3s ease-out}.bone-icon.filled{animation:bonePop .3s ease-out}.paw-icon.empty,.bone-icon.empty{opacity:.3}@keyframes pawPop{0%{transform:scale(.5)}50%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes bonePop{0%{transform:scale(.5)}50%{transform:scale(1.3)}to{transform:scale(1)}}.welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:40px 20px}.welcome-title{font-size:42px;font-weight:800;color:var(--primary-accent);margin-bottom:20px}.welcome-subtitle{font-size:24px;margin-bottom:40px}.welcome-puppies{display:flex;gap:20px;margin-bottom:40px;flex-wrap:wrap;justify-content:center}.module-select{display:flex;flex-direction:column;align-items:center;padding:40px 20px;min-height:100vh}.module-select h1{font-size:32px;margin-bottom:30px;color:var(--primary-accent)}.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1200px;width:100%}.module-card{background:var(--card-bg);border-radius:20px;padding:24px;box-shadow:0 4px 20px #3d2b1f1a;cursor:pointer;transition:transform .2s,box-shadow .2s;text-align:center}.module-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #3d2b1f26}.module-card h2{font-size:22px;margin:15px 0 10px;color:var(--text-color)}.module-card p{font-size:14px;color:#666;margin-bottom:15px}.star-display{display:flex;justify-content:center;gap:5px}.star{font-size:24px}.star.filled{color:gold}.star.empty{color:#ddd}.naming-flow{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px;text-align:center}.naming-flow h1{font-size:32px;color:var(--primary-accent);margin-bottom:20px}.naming-flow p{font-size:20px;margin-bottom:30px}.naming-input-container{margin:30px 0}.naming-error{color:#e74c3c;margin-top:10px;font-size:14px}.game-screen{min-height:100vh;padding:20px;display:flex;flex-direction:column}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.game-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.question-text{font-size:24px;text-align:center;margin-bottom:30px;max-width:600px}.question-highlight{color:var(--primary-accent);font-weight:700}.number-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:300px;margin:20px auto}.number-pad-btn{font-family:Nunito,sans-serif;font-size:28px;font-weight:700;padding:20px;border:none;border-radius:15px;background:var(--secondary-accent);color:var(--text-color);cursor:pointer;transition:all .15s;min-width:70px;min-height:70px}.number-pad-btn:hover{background:var(--primary-accent);color:#fff}.number-pad-btn:active{transform:scale(.95)}.number-pad-btn.clear{background:var(--warning-color)}.number-pad-btn.submit{background:var(--success-color)}.answer-display{font-size:48px;font-weight:700;min-height:70px;padding:15px 30px;background:var(--card-bg);border-radius:15px;border:3px solid var(--secondary-accent);margin-bottom:20px;min-width:150px;text-align:center}.bowl-container{width:200px;height:120px;position:relative;margin:20px auto}.bowl{width:100%;height:100%;background:linear-gradient(to bottom,#8b4513,sienna);border-radius:0 0 100px 100px;overflow:hidden;position:relative;border:4px solid #5D3A1A}.bowl-fill{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,#d4a574,#e8c9a0);transition:height .3s ease}.bowl-label{text-align:center;font-size:24px;font-weight:700;margin-top:10px}.fraction-slider{width:100%;max-width:300px;height:20px;-webkit-appearance:none;background:var(--secondary-accent);border-radius:10px;outline:none;margin:20px 0}.fraction-slider::-webkit-slider-thumb{-webkit-appearance:none;width:40px;height:40px;background:var(--primary-accent);border-radius:50%;cursor:pointer;border:4px solid white;box-shadow:0 2px 10px #0003}.puppies-row{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin:20px 0}.puppy-group{background:#a8d8ea4d;padding:15px;border-radius:20px;border:3px dashed var(--secondary-accent)}.treats-pile{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:20px 0;max-width:400px}.treat{width:40px;height:20px;background:linear-gradient(to bottom,#d4a574,#8b4513);border-radius:10px;border:2px solid #5D3A1A}.scale-container{display:flex;flex-direction:column;align-items:center;margin:20px 0}.scale{width:200px;height:30px;background:linear-gradient(to right,#ccc,#999);border-radius:5px;position:relative}.scale-display{font-size:36px;font-weight:700;padding:15px 30px;background:#333;color:#0f0;font-family:Courier New,monospace;border-radius:10px;margin-bottom:15px}.difficulty-selector{display:flex;gap:10px;margin-bottom:20px}.difficulty-btn{padding:10px 20px;border:2px solid var(--secondary-accent);border-radius:25px;background:transparent;font-family:Nunito,sans-serif;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.difficulty-btn.active{background:var(--primary-accent);color:#fff;border-color:var(--primary-accent)}.result-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px;text-align:center}.result-screen h1{font-size:36px;color:var(--primary-accent);margin-bottom:20px}.result-stars{font-size:60px;margin:20px 0}.result-score{font-size:24px;margin-bottom:30px}.result-buttons{display:flex;gap:15px;flex-wrap:wrap;justify-content:center}.shelter-screen{padding:40px 20px;min-height:100vh}.shelter-screen h1{font-size:32px;color:var(--primary-accent);text-align:center;margin-bottom:30px}.shelter-section{margin-bottom:40px}.shelter-section h2{font-size:24px;margin-bottom:20px;display:flex;align-items:center;gap:10px}.shelter-section.pound h2{color:var(--pearl-purple)}.puppies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.puppy-card{background:var(--card-bg);border-radius:20px;padding:20px;text-align:center;box-shadow:0 4px 15px #0000001a;position:relative}.puppy-card.at-pound{filter:saturate(.5);background:#f0f0f0}.pound-badge{position:absolute;top:10px;right:10px;background:var(--pearl-purple);color:#fff;padding:5px 10px;border-radius:15px;font-size:12px;font-weight:700}.puppy-name{font-size:18px;font-weight:700;margin-top:10px}.pearl-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pearl-overlay-content{background:var(--card-bg);padding:40px;border-radius:30px;text-align:center;max-width:500px;animation:slideUp .4s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.pearl-overlay h2{font-size:28px;margin-bottom:20px}.pearl-overlay p{font-size:18px;margin-bottom:25px}.sound-toggle{position:fixed;top:20px;right:20px;width:48px;height:48px;border-radius:50%;background:var(--card-bg);border:none;font-size:24px;cursor:pointer;box-shadow:0 2px 10px #0000001a;z-index:50}.new-puppy-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}.new-puppy-content{background:var(--card-bg);padding:40px;border-radius:30px;text-align:center;max-width:400px;animation:celebrateBounce .6s ease}@keyframes celebrateBounce{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.new-puppy-content h2{font-size:28px;color:var(--primary-accent);margin-bottom:20px}.streak-celebration{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;font-weight:800;color:var(--primary-accent);text-shadow:0 4px 20px rgba(255,140,105,.5);animation:streakPop 1s ease forwards;z-index:500;pointer-events:none}@keyframes streakPop{0%{transform:translate(-50%,-50%) scale(0);opacity:0}30%{transform:translate(-50%,-50%) scale(1.2);opacity:1}to{transform:translate(-50%,-50%) scale(1);opacity:0}}.progress-container{width:100%;max-width:400px;margin:10px 0}.progress-bar{height:20px;background:#eee;border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(to right,var(--secondary-accent),var(--primary-accent));transition:width .3s ease;border-radius:10px}.progress-text{text-align:center;font-size:14px;margin-top:5px}.feedback-correct{animation:correctFlash .5s ease}.feedback-wrong{animation:wrongShake .5s ease}@keyframes correctFlash{0%,to{background:transparent}50%{background:#b5ead780}}@keyframes wrongShake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(10px)}60%{transform:translate(-10px)}80%{transform:translate(10px)}}.reset-container{position:fixed;bottom:20px;left:20px;opacity:.3}.reset-container:hover{opacity:1}.reset-btn{font-size:12px;padding:8px 12px;background:#ccc;border:none;border-radius:5px;cursor:pointer}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.05)}}.polaroid.bounced{animation:polaroidBounce .4s cubic-bezier(.34,1.56,.64,1)}@keyframes polaroidBounce{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}@media (max-width: 768px){.welcome-title{font-size:32px}.module-grid{grid-template-columns:1fr}.question-text{font-size:20px}.threat-meter{flex-direction:column;gap:10px}}
