*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f1a;--surface: #1a1a2e;--accent: #7c6af5;--accent-light: #a89ef8;--text: #f0eeff;--text-muted: #8888aa;--error: #ff6b6b;font-family:system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}body{background:var(--bg);color:var(--text);min-height:100vh;display:flex;align-items:center;justify-content:center}.app{width:100%;max-width:420px;min-height:100vh;display:flex;flex-direction:column;padding:0 24px}.screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;text-align:center;padding:40px 0}.magic-icon{font-size:64px;line-height:1}h1{font-size:2rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.5rem;font-weight:600}p{color:var(--text-muted);line-height:1.6}.subtitle{font-size:1.1rem;color:var(--text-muted)}form{width:100%;display:flex;flex-direction:column;gap:12px}input[type=text]{width:100%;padding:14px 16px;background:var(--surface);border:1px solid #2a2a44;border-radius:12px;color:var(--text);font-size:1rem;font-family:inherit;outline:none;transition:border-color .2s}input[type=text]:focus{border-color:var(--accent)}input[type=text]::placeholder{color:var(--text-muted)}button{width:100%;padding:14px 20px;border-radius:12px;border:none;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .15s,transform .1s}button:active{transform:scale(.98)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);color:#fff}button.primary:hover:not(:disabled){background:var(--accent-light)}button.secondary{background:var(--surface);color:var(--text-muted);border:1px solid #2a2a44}button.secondary:hover{color:var(--text)}.error{color:var(--error);font-size:.9rem}.error-banner{width:100%;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:8px;padding:10px 14px;color:var(--error);font-size:.9rem}.progress{font-size:.85rem;color:var(--text-muted);background:var(--surface);padding:4px 12px;border-radius:20px}.question{font-size:1.3rem;color:var(--text);line-height:1.4}.mood-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%}.mood-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 12px;background:var(--surface);border:1px solid #2a2a44;border-radius:16px;cursor:pointer;transition:border-color .2s,transform .1s;width:auto}.mood-card:hover{border-color:var(--accent)}.mood-card:active{transform:scale(.96)}.mood-emoji{font-size:2rem}.mood-label{font-size:.95rem;font-weight:600;color:var(--text)}.mood-desc{font-size:.75rem;color:var(--text-muted)}.story-text{flex:1;overflow-y:auto;padding:32px 0 120px;display:flex;flex-direction:column;gap:16px}.story-text p{color:var(--text);line-height:1.8;font-size:1.05rem}.audio-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:420px;background:var(--bg);border-top:1px solid #2a2a44;padding:16px 24px;display:flex;gap:10px}.audio-bar button{flex:1}.fallback-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.fallback-content{background:var(--surface);border-radius:20px;padding:32px 24px;max-width:360px;width:100%;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.fallback-content h2{font-size:1.2rem}.fallback-content p{font-size:.9rem}.small{font-size:.8rem;color:var(--text-muted);word-break:break-all}code{background:#ffffff14;padding:2px 6px;border-radius:4px;font-size:.85em}button.link-button{width:auto;background:none;border:none;padding:8px 0;color:var(--text-muted);font-size:.85rem;font-weight:400;text-decoration:underline;cursor:pointer}button.link-button:hover:not(:disabled){color:var(--text);background:none}button.link-button:active{transform:scale(.98)}.dot-progress{display:flex;flex-direction:row;gap:8px;align-items:center;justify-content:center;padding:4px 12px;background:var(--surface);border-radius:20px;width:auto;align-self:center}.dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);opacity:.4;transition:background-color .25s ease,opacity .25s ease,box-shadow .25s ease}.dot.completed{background:var(--accent);opacity:1}.dot.current{background:var(--accent);opacity:1;box-shadow:0 0 6px var(--accent)}.sparkle-container{position:relative;display:inline-flex;align-items:center;justify-content:center}.sparkle-particle{position:absolute;top:50%;left:50%;width:6px;height:6px;margin:-3px 0 0 -3px;border-radius:50%;background:var(--accent);pointer-events:none;animation-name:float-sparkle;animation-timing-function:ease-out;animation-fill-mode:both}@keyframes float-sparkle{0%{opacity:0;transform:translate(0) scale(.5)}30%{opacity:1}to{opacity:0;transform:translate(var(--dx),var(--dy)) scale(1.2)}}.photo-capture-label{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;padding:14px 16px;background:var(--surface);border:1px solid #2a2a44;border-radius:12px;color:var(--text);font-size:1rem;cursor:pointer;transition:border-color .2s}.photo-capture-label:hover{border-color:var(--accent)}.dimension-row{width:100%;display:flex;flex-direction:column;gap:8px}.dimension-label{font-size:.875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;text-align:left;margin:0}.mood-card.selected{border-color:var(--accent);border-width:2px;background:#7c6af51f}.walking-loader{display:flex;flex-direction:column;align-items:center;gap:12px}.pixel-walker{font-size:2.5rem;display:inline-block;animation:walk-bounce .5s steps(2) infinite}@keyframes walk-bounce{0%{transform:translateY(0)}50%{transform:translateY(-4px)}to{transform:translateY(0)}}.dot-pulse{display:flex;gap:8px}.dot-pulse span{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse-dot 1.2s ease-in-out infinite}.dot-pulse span:nth-child(2){animation-delay:.2s}.dot-pulse span:nth-child(3){animation-delay:.4s}@keyframes pulse-dot{0%,80%,to{transform:scale(.7);opacity:.5}40%{transform:scale(1);opacity:1}}#root{width:100%;min-height:100vh;display:flex;justify-content:center}
