*,:before,:after{box-sizing:border-box}html,body{color:#2a1e5c;overscroll-behavior:none;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;height:100%;margin:0;padding:0;font-family:Fredoka,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:500;overflow-x:hidden}body{background-color:#fef3c7;background-image:radial-gradient(circle at 20% 10%,#ffd166 0%,#0000 35%),radial-gradient(circle at 80% 20%,#ff6b6b 0%,#0000 30%),radial-gradient(circle at 90% 80%,#4ecdc4 0%,#0000 35%),radial-gradient(circle at 10% 90%,#a78bfa 0%,#0000 35%),linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);background-position:0 0,0 0,0 0,0 0,0 0;background-repeat:repeat,repeat,repeat,repeat,repeat;background-size:auto,auto,auto,auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box,border-box;min-height:100dvh}#root{width:100%;min-height:100dvh}button{cursor:pointer;color:inherit;-webkit-user-select:none;user-select:none;background:0 0;border:none;font-family:inherit}h1,h2,h3,h4,p{margin:0}img,svg{max-width:100%;display:block}.app{min-height:100dvh;padding-bottom:env(safe-area-inset-bottom)}.home{max-width:720px;padding:24px 20px 40px;padding-top:max(24px, env(safe-area-inset-top));margin:0 auto}.home-header{text-align:center;padding:16px 0 28px;position:relative}.header-stars{justify-content:center;gap:8px;margin-bottom:8px;font-size:24px;animation:4s ease-in-out infinite wobble;display:flex}.header-stars span:nth-child(odd){animation:2s ease-in-out infinite bounce}.header-stars span:nth-child(2){animation-delay:.3s}.header-stars span:nth-child(3){animation-delay:.6s}.header-stars span:nth-child(4){animation-delay:.9s}.header-stars span:nth-child(5){animation-delay:1.2s}@keyframes bounce{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-8px)rotate(15deg)}}@keyframes wobble{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}.home-title{color:#ff3d6e;text-shadow:3px 3px #ffd166,6px 6px #4ecdc4,9px 9px 20px #2a1e5c33;letter-spacing:1px;margin-bottom:12px;font-family:Bungee,Fredoka,sans-serif;font-size:clamp(2rem,8vw,3rem);line-height:1.1}.home-subtitle{color:#2a1e5c;background:#fff;border:3px solid #2a1e5c;border-radius:999px;padding:6px 16px;font-size:18px;font-weight:600;display:inline-block;box-shadow:4px 4px #2a1e5c}.book-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width>=540px){.book-grid{grid-template-columns:repeat(3,1fr);gap:20px}}.book-card{--book-color:#4ecdc4;text-align:left;font-family:inherit;font-size:inherit;color:inherit;background:#fff;border:4px solid #2a1e5c;border-radius:24px;flex-direction:column;gap:10px;width:100%;padding:12px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:6px 6px #2a1e5c}.book-card:active{transform:translate(4px,4px);box-shadow:2px 2px #2a1e5c}@media (hover:hover){.book-card:hover{transform:translate(-2px,-2px)rotate(-1deg);box-shadow:8px 8px #2a1e5c}}.book-cover{background:var(--book-color);aspect-ratio:1;border:3px solid #2a1e5c;border-radius:16px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.book-cover:before{content:"";pointer-events:none;background:radial-gradient(circle at 30% 30%,#fff6,#0000 60%);position:absolute;inset:0}.book-emoji{filter:drop-shadow(2px 2px #0003);font-size:clamp(3rem,14vw,4.5rem);transform:rotate(-5deg)}.audio-badge{color:#fff;letter-spacing:.5px;background:#2a1e5c;border-radius:999px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:700;display:flex;position:absolute;top:8px;right:8px}.book-info{padding:0 4px 4px}.book-title{color:#2a1e5c;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px;font-size:15px;font-weight:700;line-height:1.2;display:-webkit-box;overflow:hidden}.book-author{color:#6b6193;font-size:13px;font-weight:500}@media (width>=540px){.book-title{font-size:17px}}.home-footer{text-align:center;color:#6b6193;margin-top:32px;padding:16px;font-size:16px;font-weight:600}.reader{--book-color:#4ecdc4;max-width:720px;min-height:100dvh;padding:max(16px, env(safe-area-inset-top)) 20px 24px;flex-direction:column;margin:0 auto;display:flex}.reader-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.back-button{color:#2a1e5c;background:#fff;border:3px solid #2a1e5c;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:3px 3px #2a1e5c}.back-button:active{transform:translate(2px,2px);box-shadow:1px 1px #2a1e5c}.reader-title{color:#2a1e5c;flex:1;font-family:Bungee,Fredoka,sans-serif;font-size:clamp(1.1rem,4.5vw,1.5rem);line-height:1.1}.reader-content{flex-direction:column;flex:1;justify-content:center;display:flex}.page{text-align:center;background:#fff;border:4px solid #2a1e5c;border-radius:28px;padding:24px 20px 28px;position:relative;box-shadow:6px 6px #2a1e5c}.page-illustration{filter:drop-shadow(3px 3px #0000001a);margin-bottom:16px;font-size:clamp(4rem,22vw,7rem);line-height:1;animation:3s ease-in-out infinite gentle-float}@keyframes gentle-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.page-text{color:#2a1e5c;font-size:clamp(1.1rem,4.5vw,1.4rem);font-weight:600;line-height:1.4}.page-dots{justify-content:center;gap:8px;margin:20px 0 16px;display:flex}.page-dot{background:#fff;border:2px solid #2a1e5c;border-radius:50%;width:12px;height:12px;transition:background .2s}.page-dot.active{background:var(--book-color)}.reader-nav{gap:12px;margin-top:12px;display:flex}.nav-button{color:#2a1e5c;background:#fff;border:4px solid #2a1e5c;border-radius:999px;flex:1;min-height:56px;padding:14px 16px;font-family:inherit;font-size:16px;font-weight:700;transition:transform .15s,box-shadow .15s;box-shadow:4px 4px #2a1e5c}.nav-button.primary{color:#fff;background:#34d399}.nav-button:active:not(:disabled){transform:translate(2px,2px);box-shadow:2px 2px #2a1e5c}.nav-button:disabled{opacity:.4;box-shadow:2px 2px #2a1e5c}.audio-player{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:24px 16px;display:flex}.audio-cover{background:var(--book-color);border:5px solid #2a1e5c;border-radius:50%;justify-content:center;align-items:center;width:clamp(180px,60vw,240px);height:clamp(180px,60vw,240px);animation:20s linear infinite spin-slow;display:flex;box-shadow:8px 8px #2a1e5c}@keyframes spin-slow{to{transform:rotate(360deg)}}.audio-emoji{font-size:clamp(4rem,18vw,6rem);animation:20s linear infinite reverse spin-slow}.audio-title{color:#2a1e5c;margin-top:8px;font-family:Bungee,Fredoka,sans-serif;font-size:clamp(1.2rem,5vw,1.6rem)}.audio-description{color:#6b6193;max-width:400px;font-size:16px;font-weight:500}.play-button{background:var(--book-color);color:#fff;border:5px solid #2a1e5c;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;padding-left:6px;font-size:32px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:6px 6px #2a1e5c}.play-button:active{transform:translate(3px,3px);box-shadow:3px 3px #2a1e5c}.audio-duration{color:#2a1e5c;background:#fff;border:2px solid #2a1e5c;border-radius:999px;padding:4px 14px;font-size:14px;font-weight:700}.audio-note{color:#6b6193;font-size:14px;font-style:italic;font-weight:500}.search-bar{background:#fff;border:4px solid #2a1e5c;border-radius:999px;align-items:center;gap:10px;margin-bottom:24px;padding:4px 18px;display:flex;box-shadow:4px 4px #2a1e5c}.search-icon{font-size:20px;line-height:1}.search-input{color:#2a1e5c;appearance:none;background:0 0;border:none;outline:none;flex:1;min-width:0;padding:12px 0;font-family:inherit;font-size:16px;font-weight:600}.search-input::placeholder{color:#9d96bc;font-weight:500}.search-input::-webkit-search-cancel-button{-webkit-appearance:none;display:none}.search-input::-webkit-search-decoration{-webkit-appearance:none;display:none}.search-clear{color:#fff;background:#2a1e5c;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;font-weight:700;transition:transform .1s;display:flex}.search-clear:active{transform:scale(.9)}.no-results{text-align:center;color:#6b6193;background:#fff;border:4px dashed #2a1e5c;border-radius:24px;grid-column:1/-1;padding:40px 20px}.no-results-emoji{margin-bottom:12px;font-size:60px;animation:3s ease-in-out infinite gentle-float;display:block}.no-results p{color:#2a1e5c;font-size:18px;font-weight:600}.book-card{position:relative}.owned-badge{color:#fff;z-index:3;background:#34d399;border:4px solid #2a1e5c;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:24px;font-weight:900;line-height:1;animation:.4s ease-out badge-pop;display:flex;position:absolute;top:-12px;right:-12px;transform:rotate(10deg);box-shadow:3px 3px #2a1e5c}@keyframes badge-pop{0%{transform:rotate(10deg)scale(0)}60%{transform:rotate(10deg)scale(1.15)}to{transform:rotate(10deg)scale(1)}}.book-card.owned .book-cover{background:linear-gradient(135deg, var(--book-color) 0%, color-mix(in srgb, var(--book-color) 70%, white) 100%)}.buy-screen{--book-color:#4ecdc4;max-width:720px;min-height:100dvh;padding:max(16px, env(safe-area-inset-top)) 20px 24px;flex-direction:column;margin:0 auto;display:flex;position:relative;overflow:hidden}.buy-content{text-align:center;flex-direction:column;flex:1;align-items:center;gap:14px;padding:12px 0 24px;display:flex}.buy-cover{background:var(--book-color);border:5px solid #2a1e5c;border-radius:32px;justify-content:center;align-items:center;width:clamp(180px,50vw,220px);height:clamp(180px,50vw,220px);margin-bottom:4px;animation:3s ease-in-out infinite cover-float;display:flex;position:relative;box-shadow:8px 8px #2a1e5c}@keyframes cover-float{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-8px)rotate(2deg)}}.buy-emoji{filter:drop-shadow(3px 3px #0003);font-size:clamp(5rem,20vw,7rem)}.buy-audio-badge{top:12px;right:12px}.buy-title{color:#2a1e5c;max-width:520px;padding:0 8px;font-family:Bungee,Fredoka,sans-serif;font-size:clamp(1.4rem,5.5vw,1.9rem);line-height:1.1}.buy-author{color:#6b6193;margin-top:-4px;font-size:16px;font-weight:600}.buy-description{color:#2a1e5c;background:#fff;border:3px solid #2a1e5c;border-radius:20px;max-width:500px;padding:14px 20px;font-size:16px;font-weight:500;line-height:1.4;box-shadow:3px 3px #2a1e5c}.price-tag{background:#ffd166;border:4px solid #2a1e5c;border-radius:20px;align-items:center;gap:10px;margin:4px 0;padding:10px 22px;display:inline-flex;transform:rotate(-3deg);box-shadow:4px 4px #2a1e5c}.price-amount{color:#2a1e5c;font-family:Bungee,sans-serif;font-size:32px;line-height:1}.price-coins{color:#2a1e5c;align-items:center;gap:4px;font-size:15px;font-weight:700;display:inline-flex}.buy-button{color:#fff;letter-spacing:1px;background:#34d399;border:5px solid #2a1e5c;border-radius:999px;min-width:220px;margin-top:4px;padding:18px 40px;font-family:Bungee,sans-serif;font-size:22px;transition:transform .15s,box-shadow .15s;box-shadow:6px 6px #2a1e5c}.buy-button:active:not(:disabled){transform:translate(3px,3px);box-shadow:3px 3px #2a1e5c}.buy-button.celebrating{cursor:default;background:#ff3d6e;animation:.4s ease-in-out infinite buy-shake}@keyframes buy-shake{0%,to{transform:rotate(-2deg)scale(1.05)}50%{transform:rotate(2deg)scale(1.1)}}.confetti{pointer-events:none;z-index:20;position:fixed;inset:0;overflow:hidden}.confetti-piece{animation:1.6s ease-in forwards confetti-fall;position:absolute;top:-60px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:.8;transform:translateY(110vh)rotate(720deg)}}.banner{border:3px solid #2a1e5c;border-radius:16px;align-items:center;gap:10px;margin:0 0 16px;padding:12px 16px;font-size:15px;font-weight:600;display:flex;box-shadow:3px 3px #2a1e5c}.banner-error{color:#b91c1c;background:#ffe2e2}.loading-state{text-align:center;color:#2a1e5c;grid-column:1/-1;padding:60px 20px}.loading-emoji{margin-bottom:12px;font-size:60px;animation:2s ease-in-out infinite gentle-float;display:block}.loading-state p{font-size:18px;font-weight:600}.create-button-banner{color:#fff;letter-spacing:1px;text-shadow:2px 2px #2a1e5c59;background:linear-gradient(135deg,#ff6b6b 0%,#a78bfa 50%,#5b6cff 100%) 0 0/200% 200%;border:4px solid #2a1e5c;border-radius:999px;justify-content:center;align-items:center;gap:12px;width:100%;margin-bottom:24px;padding:14px 20px;font-family:Bungee,Fredoka,sans-serif;font-size:clamp(1rem,4vw,1.25rem);transition:transform .15s,box-shadow .15s;animation:6s ease-in-out infinite banner-gradient;display:flex;position:relative;overflow:hidden;box-shadow:6px 6px #2a1e5c}@keyframes banner-gradient{0%,to{background-position:0%}50%{background-position:100%}}.create-button-banner:before{content:"";pointer-events:none;background:radial-gradient(circle at 30% 30%,#ffffff59 0%,#0000 40%);position:absolute;inset:0}.create-button-banner:active{transform:translate(3px,3px);box-shadow:3px 3px #2a1e5c}@media (hover:hover){.create-button-banner:hover{transform:translate(-1px,-1px)rotate(-.5deg);box-shadow:7px 7px #2a1e5c}}.create-banner-icon{font-size:1.4em;line-height:1;animation:1.8s ease-in-out infinite spinner-bounce}.create-banner-icon-right{animation-delay:.4s}.create-banner-label{white-space:nowrap}.ai-badge{color:#fff;z-index:3;background:linear-gradient(135deg,#ff6b6b,#a78bfa);border:3px solid #2a1e5c;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;animation:2.5s ease-in-out infinite ai-sparkle;display:flex;position:absolute;top:-10px;left:-10px;box-shadow:2px 2px #2a1e5c}@keyframes ai-sparkle{0%,to{transform:scale(1)rotate(-10deg)}50%{transform:scale(1.15)rotate(10deg)}}.page-image{aspect-ratio:1;object-fit:cover;border:4px solid #2a1e5c;border-radius:20px;width:100%;max-width:380px;margin:0 auto 16px;animation:3s ease-in-out infinite gentle-float;display:block;box-shadow:4px 4px #2a1e5c}.create-screen{max-width:720px;min-height:100dvh;padding:max(16px, env(safe-area-inset-top)) 20px 24px;flex-direction:column;margin:0 auto;display:flex}.create-content{text-align:center;flex-direction:column;flex:1;align-items:center;padding:8px 0 24px;display:flex}.create-mic-hero{flex-direction:column;align-items:center;gap:14px;margin:8px 0 24px;display:flex}.create-mic-button{background:linear-gradient(135deg,#ff6b6b 0%,#a78bfa 50%,#5b6cff 100%);border:5px solid #2a1e5c;border-radius:50%;justify-content:center;align-items:center;width:140px;height:140px;transition:transform .15s,box-shadow .15s;animation:3s ease-in-out infinite cover-float;display:flex;box-shadow:8px 8px #2a1e5c}.create-mic-button:active:not(:disabled){transform:translate(4px,4px);box-shadow:4px 4px #2a1e5c}.create-mic-button:disabled{opacity:.7}.create-mic-emoji{filter:drop-shadow(2px 2px #00000040);font-size:64px;line-height:1}.create-mic-recording .create-mic-button{background:#ff3d6e;animation:1s ease-in-out infinite mic-pulse-big}.create-mic-transcribing .create-mic-button{background:#ffd166;animation:none}@keyframes mic-pulse-big{0%,to{box-shadow:8px 8px #2a1e5c,0 0 #ff3d6e8c}50%{box-shadow:8px 8px #2a1e5c,0 0 0 22px #ff3d6e00}}.create-mic-label{color:#2a1e5c;text-align:center;font-family:Bungee,Fredoka,sans-serif;font-size:clamp(1.2rem,4.5vw,1.5rem);line-height:1.1}.create-or{color:#6b6193;letter-spacing:2px;text-transform:uppercase;margin:0 0 16px;font-size:15px;font-weight:700;position:relative}.create-or:before,.create-or:after{content:"";vertical-align:middle;background:#6b6193;border-radius:2px;width:40px;height:3px;margin:0 10px;display:inline-block}.topic-grid{grid-template-columns:repeat(3,1fr);gap:12px;width:100%;max-width:500px;margin-bottom:24px;display:grid}@media (width>=540px){.topic-grid{grid-template-columns:repeat(4,1fr)}}.topic-tile{color:#2a1e5c;-webkit-tap-highlight-color:transparent;background:#fff;border:4px solid #2a1e5c;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:12px 8px;font-family:inherit;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:4px 4px #2a1e5c}.topic-tile:active:not(:disabled){transform:translate(2px,2px);box-shadow:2px 2px #2a1e5c}.topic-tile:disabled{opacity:.5}@media (hover:hover){.topic-tile:hover:not(:disabled){transform:translate(-1px,-1px)rotate(-1deg);box-shadow:5px 5px #2a1e5c}}.topic-emoji{filter:drop-shadow(2px 2px #00000026);font-size:clamp(2.2rem,9vw,3rem);line-height:1}.topic-label{letter-spacing:.3px;font-family:Bungee,Fredoka,sans-serif;font-size:13px;line-height:1}.create-grownup{text-align:left;width:100%;max-width:500px;margin-top:4px}.create-grownup summary{color:#6b6193;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 0;font-size:13px;font-weight:600;list-style:none}.create-grownup summary::-webkit-details-marker{display:none}.create-grownup summary:before{content:"▸ ";margin-right:4px;transition:transform .15s;display:inline-block}.create-grownup[open] summary:before{transform:rotate(90deg)}.create-form{flex-direction:column;gap:16px;width:100%;max-width:500px;display:flex}.create-textarea{color:#2a1e5c;resize:none;background:#fff;border:4px solid #2a1e5c;border-radius:20px;outline:none;width:100%;padding:16px 20px;font-family:inherit;font-size:17px;font-weight:500;line-height:1.4;box-shadow:4px 4px #2a1e5c}.create-textarea::placeholder{color:#9d96bc}.create-button{color:#fff;letter-spacing:1px;background:linear-gradient(135deg,#ff6b6b 0%,#a78bfa 100%);border:5px solid #2a1e5c;border-radius:999px;margin-top:8px;padding:16px 24px;font-family:Bungee,sans-serif;font-size:18px;transition:transform .15s,box-shadow .15s;box-shadow:6px 6px #2a1e5c}.create-button:active:not(:disabled){transform:translate(3px,3px);box-shadow:3px 3px #2a1e5c}.create-button:disabled{opacity:.4}.create-loading{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;min-height:100dvh;padding:20px;display:flex}.magic-spinner{gap:12px;font-size:50px;display:flex}.magic-spinner span{animation:1s ease-in-out infinite spinner-bounce}.magic-spinner span:nth-child(2){animation-delay:.15s}.magic-spinner span:nth-child(3){animation-delay:.3s}.magic-spinner span:nth-child(4){animation-delay:.45s}@keyframes spinner-bounce{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-20px)scale(1.1)}}.create-loading-title{color:#2a1e5c;font-family:Bungee,sans-serif;font-size:clamp(1.5rem,6vw,2rem)}.create-loading-message{color:#ff3d6e;max-width:320px;min-height:1.4em;font-size:18px;font-weight:600}.create-loading-note{color:#6b6193;max-width:320px;font-size:14px;font-style:italic;font-weight:500}.login-screen{min-height:100dvh;padding:max(40px, env(safe-area-inset-top)) 20px 40px;flex-direction:column;justify-content:flex-start;align-items:center;gap:24px;max-width:460px;margin:0 auto;display:flex}.login-header{text-align:center}.login-card{background:#fff;border:4px solid #2a1e5c;border-radius:28px;width:100%;padding:28px 24px 24px;box-shadow:6px 6px #2a1e5c}.login-form{text-align:center;flex-direction:column;gap:16px;display:flex}.login-emoji{font-size:56px;line-height:1;animation:3s ease-in-out infinite gentle-float}.login-prompt{color:#2a1e5c;font-family:Bungee,Fredoka,sans-serif;font-size:clamp(1.3rem,5vw,1.6rem);line-height:1.1}.login-help{color:#6b6193;margin-top:-4px;font-size:15px;font-weight:500}.login-input{color:#2a1e5c;text-align:center;background:#fefce8;border:4px solid #2a1e5c;border-radius:16px;outline:none;width:100%;padding:14px 18px;font-family:inherit;font-size:18px;font-weight:600;box-shadow:3px 3px #2a1e5c}.login-input::placeholder{color:#9d96bc;font-weight:500}.login-input:focus{background:#fff;box-shadow:4px 4px #2a1e5c}.login-button{color:#fff;letter-spacing:1px;background:linear-gradient(135deg,#ff6b6b 0%,#a78bfa 100%);border:4px solid #2a1e5c;border-radius:999px;margin-top:4px;padding:14px 22px;font-family:Bungee,sans-serif;font-size:18px;transition:transform .15s,box-shadow .15s;box-shadow:5px 5px #2a1e5c}.login-button:active:not(:disabled){transform:translate(3px,3px);box-shadow:2px 2px #2a1e5c}.login-button:disabled{opacity:.4}.logout-button{color:#2a1e5c;letter-spacing:.5px;background:#fff;border:3px solid #2a1e5c;border-radius:999px;margin-top:8px;padding:6px 16px;font-family:inherit;font-size:13px;font-weight:700;transition:transform .15s,box-shadow .15s;box-shadow:2px 2px #2a1e5c}.logout-button:active{transform:translate(1px,1px);box-shadow:1px 1px #2a1e5c}.full-screen-loader{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;display:flex}.speakable-text{color:#2a1e5c;margin:0;font-size:clamp(1.1rem,4.5vw,1.4rem);font-weight:600;line-height:1.6}.speakable-word{font:inherit;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;margin:0;padding:2px 4px;transition:background .15s,color .15s,transform .15s;display:inline}.speakable-word:active{background:var(--book-color);color:#fff}.speakable-word.is-active{background:var(--book-color);color:#fff;transform:scale(1.08)}.page-tap-hint{color:#6b6193;align-items:center;gap:6px;margin:16px 0 0;font-size:13px;font-weight:600;display:inline-flex}.page-tap-hint span{font-size:16px;animation:1.6s ease-in-out infinite bounce}.read-badge{color:#2a1e5c;z-index:3;background:#ffd166;border:4px solid #2a1e5c;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:22px;line-height:1;animation:.45s ease-out badge-pop;display:flex;position:absolute;top:-12px;right:-12px;transform:rotate(12deg);box-shadow:3px 3px #2a1e5c}.book-card.read .book-cover{background:linear-gradient(135deg, var(--book-color) 0%, color-mix(in srgb, var(--book-color) 60%, white) 100%)}.sticker-counter{color:#2a1e5c;letter-spacing:.3px;background:#ffd166;border:3px solid #2a1e5c;border-radius:999px;align-items:center;gap:8px;margin-top:12px;padding:6px 16px;font-size:14px;font-weight:700;display:inline-flex;box-shadow:3px 3px #2a1e5c}.sticker-counter-icon{font-size:18px;line-height:1;animation:1.6s ease-in-out infinite bounce}.finished-overlay{z-index:30;-webkit-backdrop-filter:blur(6px);background:#2a1e5c99;justify-content:center;align-items:center;padding:20px;animation:.25s ease-out overlay-fade-in;display:flex;position:fixed;inset:0}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.finished-card{text-align:center;z-index:2;background:#fff;border:5px solid #2a1e5c;border-radius:32px;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:420px;padding:32px 26px 28px;animation:.45s cubic-bezier(.34,1.56,.64,1) finished-pop;display:flex;position:relative;box-shadow:8px 8px #2a1e5c}@keyframes finished-pop{0%{opacity:0;transform:scale(.6)rotate(-4deg)}to{opacity:1;transform:scale(1)rotate(0)}}.finished-sticker{background:#ffd166;border:5px solid #2a1e5c;border-radius:50%;justify-content:center;align-items:center;width:130px;height:130px;margin-top:-70px;margin-bottom:4px;animation:2.4s ease-in-out infinite cover-float;display:flex;box-shadow:5px 5px #2a1e5c}.finished-sticker-burst{filter:drop-shadow(2px 2px #2a1e5c33);align-items:center;gap:4px;font-size:44px;display:inline-flex}.finished-title{color:#2a1e5c;font-family:Bungee,Fredoka,sans-serif;font-size:clamp(1.6rem,6vw,2rem);line-height:1.1}.finished-subtitle{color:#2a1e5c;font-size:16px;font-weight:500;line-height:1.3}.finished-subtitle strong{font-weight:700}.finished-prize{color:#fff;background:#34d399;border:3px solid #2a1e5c;border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:15px;font-weight:700;display:inline-flex;box-shadow:2px 2px #2a1e5c}.finished-count{color:#6b6193;font-size:15px;font-weight:600}.finished-count strong{color:#ff3d6e;margin:0 2px;font-family:Bungee,sans-serif;font-size:22px;display:inline-block}.finished-button{color:#fff;letter-spacing:.5px;background:#34d399;border:4px solid #2a1e5c;border-radius:999px;margin-top:8px;padding:14px 26px;font-family:Bungee,sans-serif;font-size:16px;transition:transform .15s,box-shadow .15s;box-shadow:5px 5px #2a1e5c}.finished-button:active{transform:translate(3px,3px);box-shadow:2px 2px #2a1e5c}
