:root{--app-viewport-height: 100svh;color:#3d2740;background:#ffe24d;font-family:Inter,ui-rounded,Arial Rounded MT Bold,Trebuchet MS,system-ui,sans-serif;font-synthesis:none;line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;min-height:100svh;background:repeating-linear-gradient(135deg,#ffffff38 0,#ffffff38 14px,#fff0 14px,#fff0 28px),linear-gradient(180deg,#ff3fa4,#ffc83d 44%,#25d5ff)}body.is-finale-active{overflow:hidden}button,select{font:inherit}.app-shell{min-height:100vh;min-height:100svh;padding:12px 14px 16px}.app-shell.is-home-open{display:grid;padding:14px}.game-view.is-hidden{display:none}.title-screen{position:relative;display:grid;align-items:end;width:min(100%,1080px);min-height:calc(100svh - 28px);margin:0 auto;overflow:hidden;border:6px solid #3d1b5c;border-radius:28px;background:linear-gradient(180deg,#3d1b5c14,#3d1b5c33 48%,#ff3fa475),var(--title-background) center / cover no-repeat;box-shadow:0 0 0 5px #ffe24d,0 18px #3d1b5c3d,0 34px 56px #3d1b5c52;isolation:isolate}.title-screen:before{position:absolute;content:"";top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(circle at 48% 26%,rgba(255,255,255,.4),transparent 28%),linear-gradient(180deg,#ffffff05,#3d1b5c85)}.title-panel{display:grid;justify-items:center;gap:14px;width:min(100%,780px);margin:0 auto;padding:clamp(18px,4vw,34px) 16px clamp(22px,5vw,42px);text-align:center}.title-logo{font-size:clamp(3.2rem,11vw,7rem);line-height:.88}.title-actions,.title-audio-actions{display:flex;justify-content:center;gap:10px;max-width:100%;flex-wrap:wrap}.title-play-button{min-height:52px;padding:12px 34px;border:3px solid #3d1b5c;border-radius:999px;color:#331441;background:#38ff3f;box-shadow:inset 0 -5px #3d1b5c24,0 7px #3d1b5c3d,0 14px 24px #3d1b5c38;font-size:1.1rem;font-weight:900;cursor:pointer;transition:transform .16s ease,filter .16s ease}.title-play-button:hover{transform:translateY(-2px);filter:brightness(1.04)}.level-switcher{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;width:min(100%,900px);margin:0 auto 10px;padding:8px 10px;border:3px solid #3d1b5c;border-radius:999px;background:#ffffffc7;box-shadow:0 12px #3d1b5c29,0 18px 34px #3d1b5c38}.level-step-button,.audio-toggle,.current-level-pill{min-height:38px;border:3px solid #3d1b5c;border-radius:999px;color:#331441;background:#fff7d6;box-shadow:inset 0 -4px #3d1b5c24,0 5px #3d1b5c38;font-weight:900}.level-step-button,.audio-toggle{flex:0 0 auto;padding:8px 13px;cursor:pointer;transition:background .16s ease,transform .16s ease,box-shadow .16s ease}.home-button{background:linear-gradient(135deg,#ff4fb3,#ffe24d)}.home-icon-button{display:grid;place-items:center;width:46px;min-width:46px;padding:0}.home-icon-button svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.6}.level-step-button:hover:not(:disabled),.audio-toggle:hover{transform:translateY(-2px);box-shadow:inset 0 -4px #3d1b5c24,0 7px #3d1b5c38,0 13px 22px #3d1b5c38}.audio-toggle[aria-pressed=true]{background:linear-gradient(135deg,#20e6ff,#ffe24d)}.audio-toggle[aria-pressed=false]{color:#6b5d72;background:#fff2f7}.title-audio-toggle{min-height:32px;padding:6px 12px;border-width:2px;color:#2f133d;font-size:.82rem;background:#fff23d;box-shadow:inset 0 -3px #3d1b5c24,0 4px #3d1b5c33}.title-audio-actions .title-audio-toggle:nth-child(1){background:#00e8ff}.title-audio-actions .title-audio-toggle:nth-child(2){background:#ffe600}.title-audio-toggle[aria-pressed=false]{color:#fff;background:#ff2f9b}.level-step-button:disabled{cursor:not-allowed;opacity:.42}.current-level-pill{display:grid;place-items:center;align-items:center;flex:0 1 228px;min-width:0;padding:8px 14px;color:#331441;background:linear-gradient(135deg,#ffe24d,#ff4fb3 62%,#20e6ff);font-size:.9rem;font-weight:900;line-height:1.05;text-align:center}.game-layout{width:min(100%,980px);margin:0 auto;text-align:center}.game-header{display:grid;gap:4px;margin:0 0 9px}h1{margin:0;color:#fff;font-size:clamp(2.05rem,8.5vw,4.2rem);letter-spacing:0;line-height:.95;text-shadow:0 3px 0 #3d1b5c,0 6px 0 #ff3fa4,0 9px 18px rgba(61,27,92,.34)}.progress-card{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;width:min(100%,560px);margin:0 auto 9px;padding:8px 12px;border:3px solid #3d1b5c;border-radius:999px;background:#fff;box-shadow:inset 0 -5px #3d1b5c1a,0 7px #3d1b5c2e}.progress-copy{display:flex;align-items:baseline;gap:6px;min-width:max-content;color:#331441}.progress-label{color:#e51c8f;font-size:.82rem;font-weight:800;text-transform:uppercase}.progress-copy strong{font-size:1rem}.progress-track{height:16px;overflow:hidden;border:2px solid #ff4fb3;border-radius:999px;background:#fff3bf}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#ff2f9b,#ffe24d 48%,#20dfff);transition:width .22s ease}.game-tools{display:flex;align-items:center;justify-content:center;gap:10px;margin:0 0 9px;flex-wrap:wrap}.hint-button,.replay-button{position:relative;min-height:42px;padding:10px 20px;overflow:hidden;border:3px solid #3d1b5c;border-radius:999px;color:#331441;background:#fff7d6;box-shadow:inset 0 -4px #3d1b5c1f,0 6px #3d1b5c38;font-weight:900;cursor:pointer;transition:transform .16s ease,filter .16s ease,opacity .16s ease}.hint-button:before{position:absolute;content:"";inset:0 auto 0 0;width:var(--hint-fill, 100%);border-radius:inherit;background:linear-gradient(135deg,#ffe24d,#ff4fb3 58%,#20e6ff);transition:width 1s linear}.hint-button-label{position:relative;z-index:1}.hint-button:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.04)}.hint-button:active:not(:disabled),.replay-button:active{transform:translateY(1px)}.hint-button:disabled{cursor:not-allowed;opacity:.52}.replay-button{background:linear-gradient(135deg,#20e6ff,#9cff4f)}.replay-button:hover{transform:translateY(-2px);filter:brightness(1.04)}.hint-status{min-width:112px;color:#884b70;font-size:.88rem;font-weight:800}.game-message{display:inline-grid;place-items:center;min-height:30px;max-width:min(100%,560px);margin:0 auto 10px;padding:4px 16px;border:3px solid #3d1b5c;border-radius:999px;color:#331441;background:#ffffffe6;box-shadow:inset 0 -3px #3d1b5c1a,0 5px #3d1b5c2e;font-size:.98rem;font-weight:900;text-shadow:none}.game-message.is-complete{color:#331441;background:linear-gradient(135deg,#fff23d,#9cff4f)}.scene-frame{position:relative;width:min(100%,max(320px,calc((var(--app-viewport-height) - 380px) * 1.5)));margin:0 auto;aspect-ratio:3 / 2;min-height:180px;overflow:hidden;border:6px solid #3d1b5c;border-radius:18px;background:linear-gradient(135deg,#fff23d,#20e6ff),repeating-linear-gradient(45deg,#ff3fa42e 0,#ff3fa42e 10px,#20e6ff2e 10px,#20e6ff2e 20px);box-shadow:0 0 0 4px #ffe24d,0 12px #3d1b5c42,0 26px 44px #3d1b5c47,inset 0 0 0 4px #ffffff6b;cursor:pointer;isolation:isolate}.scene-viewport{width:100%}.scene-background{display:block;width:100%;height:auto;opacity:0;filter:var(--scene-background-filter, grayscale(1));transition:opacity .52s cubic-bezier(.33,1,.68,1),filter .7s ease,transform .7s ease;-webkit-user-select:none;user-select:none}.scene-frame.is-scene-loading .scene-background{opacity:0}.scene-frame.is-scene-revealing .scene-background,.scene-frame.is-scene-ready .scene-background{opacity:1}.scene-frame.is-complete .scene-background{filter:var(--scene-complete-background-filter, grayscale(0));transform:scale(1.01)}.scene-frame.is-complete{z-index:80}.scene-loading{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;color:#331441;background:radial-gradient(circle at 50% 35%,rgba(255,255,255,.8),transparent 24%),linear-gradient(135deg,#ff2f9bf0,#00e8ffe6),repeating-linear-gradient(45deg,#fff3 0,#fff3 12px,#fff0 12px,#fff0 24px);font-weight:900;opacity:1;transition:opacity .52s cubic-bezier(.33,1,.68,1);pointer-events:auto}.scene-loading.is-exiting{opacity:0}.scene-loading-panel{display:grid;justify-items:center;gap:10px;width:min(80%,380px);padding:20px 22px;border:4px solid #3d1b5c;border-radius:22px;background:#ffffffe0;box-shadow:inset 0 -7px #3d1b5c1f,0 10px #3d1b5c3d,0 22px 36px #3d1b5c3d}.scene-loading-title{color:#ff2f9b;font-size:clamp(1rem,3.5vw,1.35rem);line-height:1.05;text-align:center;text-shadow:0 2px 0 rgba(255,230,0,.5)}.scene-loading-label{color:#331441;letter-spacing:.06em;font-size:clamp(.92rem,2.8vw,1.05rem);text-transform:uppercase;animation:scene-loading-breathe 2s ease-in-out infinite}.scene-loading-meter{width:min(100%,260px);height:16px;overflow:hidden;border:3px solid #3d1b5c;border-radius:999px;background:#fff23d;box-shadow:inset 0 3px #ffffffa6}.scene-loading-meter span{display:block;width:48%;height:100%;border-radius:inherit;background:linear-gradient(90deg,#00e8ff,#38ff3f,#ff2f9b);animation:scene-loading-meter 1.05s ease-in-out infinite alternate}.scene-loading-dots{display:flex;gap:8px}.scene-loading-dots span{width:11px;height:11px;border:2px solid #3d1b5c;border-radius:50%;background:#ff2f9b;box-shadow:0 3px #3d1b5c38;animation:scene-loading-dot .9s ease-in-out infinite}.scene-loading-dots span:nth-child(2){background:#00e8ff;animation-delay:.12s}.scene-loading-dots span:nth-child(3){background:#38ff3f;animation-delay:.24s}@keyframes scene-loading-breathe{0%,to{opacity:.82;transform:scale(1)}50%{opacity:1;transform:scale(1.03)}}@keyframes scene-loading-meter{0%{transform:translate(-8%)}to{transform:translate(116%)}}@keyframes scene-loading-dot{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.kathleen-layer{animation:kathleen-layer-in .34s cubic-bezier(.33,1,.68,1) both}@keyframes kathleen-layer-in{0%{opacity:0}to{opacity:1}}@media(prefers-reduced-motion:reduce){.scene-background{transition-duration:.01ms;transition-delay:0s!important}.scene-loading{transition-duration:.01ms}.scene-loading-label{animation:none;opacity:1;transform:none}.scene-loading-meter span,.scene-loading-dots span,.kathleen-layer{animation:none}}.hint-area{position:absolute;z-index:1;aspect-ratio:1;border:3px solid rgba(255,216,95,.9);border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 42%),radial-gradient(circle,rgba(255,120,185,.16),transparent 64%);box-shadow:0 0 0 10px #ffd85f29,0 0 34px #ff78b9b8,inset 0 0 22px #ffffff73;transform:translate(-50%,-50%);animation:hint-pulse 1.25s ease-in-out infinite;pointer-events:none}.hint-area:before,.hint-area:after{position:absolute;content:"";top:12%;right:12%;bottom:12%;left:12%;border:2px dashed rgba(119,218,250,.75);border-radius:inherit;animation:hint-orbit 4.8s linear infinite}.hint-area:after{top:24%;right:24%;bottom:24%;left:24%;border-color:#ff78b9b8;animation-direction:reverse;animation-duration:3.6s}.kathleen-target{position:absolute;display:grid;place-items:center;min-width:24px;min-height:24px;padding:0;border:0;border-radius:50%;background:transparent;cursor:pointer;transform-origin:center;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.kathleen-target:focus-visible{outline:4px solid #20e6ff;outline-offset:5px}.kathleen-target img{display:block;width:100%;height:auto;opacity:var(--kathleen-hidden-opacity, 1);filter:var(--kathleen-hidden-filter, grayscale(1) contrast(1.05));transition:opacity .18s ease,filter .18s ease,drop-shadow .18s ease;-webkit-user-select:none;user-select:none;pointer-events:none}.kathleen-target.is-found{animation:kathleen-pop .52s cubic-bezier(.2,1.6,.36,1)}.kathleen-target.is-found img{opacity:1;filter:grayscale(0) drop-shadow(0 0 10px rgba(255,242,61,.95)) drop-shadow(0 0 14px rgba(255,63,164,.55))}.mini-sparkles{position:absolute;top:-30%;right:-30%;bottom:-30%;left:-30%;pointer-events:none}.mini-sparkles span{position:absolute;width:10px;height:10px;border-radius:50%;background:#fff23d;box-shadow:0 0 10px #fff;animation:mini-sparkle .78s ease-out forwards}.mini-sparkles span:nth-child(1){left:6%;top:12%}.mini-sparkles span:nth-child(2){right:4%;top:36%;background:#ff78b9;animation-delay:70ms}.mini-sparkles span:nth-child(3){left:46%;bottom:0;background:#20e6ff;animation-delay:.12s}.celebration{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;pointer-events:none}.celebration-glow{position:absolute;width:min(70%,520px);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.58),transparent 30%),radial-gradient(circle,rgba(255,216,95,.44),transparent 58%),radial-gradient(circle,rgba(255,120,185,.28),transparent 72%);animation:celebration-glow 1.5s ease-out both}.celebration-spark{position:absolute;width:13px;height:13px;border-radius:50%;background:#ffd85f;box-shadow:0 0 0 5px #ffd85f2e,0 0 18px #ffffffeb;transform:rotate(var(--angle)) translate(0);animation:celebration-burst 1.25s ease-out var(--delay) both}.celebration-confetti{position:absolute;top:-12%;left:var(--left);width:9px;height:18px;border-radius:3px;background:#ffd85f;box-shadow:0 0 8px #fffc;animation:confetti-fall 2.2s ease-in var(--delay) both}.celebration-confetti:nth-child(3n){background:#ff78b9}.celebration-confetti:nth-child(4n){background:#77dafa}.celebration-confetti:nth-child(5n){height:10px;border-radius:50%}.celebration-spark:nth-child(3n){background:#ff78b9}.celebration-spark:nth-child(4n){background:#77dafa}.celebration-star{position:absolute;color:#ffd85f;font-size:3rem;text-shadow:0 4px 0 #ff78b9,0 0 22px white;animation:star-dance 1.4s ease-in-out infinite}.celebration-star-one{left:18%;top:18%}.celebration-star-two{right:18%;top:25%;color:#77dafa;animation-delay:.13s}.celebration-star-three{bottom:16%;left:48%;color:#ff78b9;animation-delay:.26s}.celebration-star-four{right:42%;top:48%;color:#fff;font-size:4rem;animation-delay:.39s}.completion-actions{position:fixed;left:calc(var(--visible-viewport-left, 0px) + var(--visible-viewport-width, 100vw) / 2);bottom:max(18px,calc(100vh - var(--visible-viewport-top, 0px) - var(--visible-viewport-height, 100vh) + 18px));z-index:1020;display:flex;justify-content:center;gap:8px;width:max-content;max-width:calc(100% - 24px);margin:0;padding:8px;border:3px solid #3d1b5c;border-radius:999px;background:#ffffffe6;box-shadow:inset 0 -5px #3d1b5c1a,0 10px #3d1b5c38,0 18px 30px #3d1b5c47;flex-wrap:wrap;transform:translate(-50%)}.finale-kathleen{position:fixed;left:var(--visible-viewport-left, 0);top:var(--visible-viewport-top, 0);z-index:1000;display:grid;place-items:center;width:var(--visible-viewport-width, 100vw);height:var(--visible-viewport-height, 100vh);padding:0 12px;overflow:hidden;pointer-events:none}.finale-kathleen:before{position:absolute;content:"";top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 54%,rgba(255,255,255,.7),transparent 34%),linear-gradient(180deg,#fff6fb9e,#ffe8f4db);animation:finale-backdrop .62s ease-out both}.finale-kathleen img{position:relative;width:auto;height:min(142%,1260px);max-width:none;object-fit:contain;transform:translateY(3%);filter:drop-shadow(0 22px 34px rgba(93,49,92,.25));animation:finale-kathleen-pop .72s cubic-bezier(.2,1,.2,1) both}.next-level-button,.play-again-button{min-height:44px;padding:10px 18px;border:3px solid #3d1b5c;border-radius:999px;color:#331441;background:linear-gradient(135deg,#ffe24d,#ff4fb3);box-shadow:inset 0 -4px #3d1b5c24,0 6px #3d1b5c38;font-weight:900;cursor:pointer}.next-level-button{background:linear-gradient(135deg,#20e6ff,#ffe24d)}.next-level-button:hover,.play-again-button:hover{transform:translateY(-1px)}.next-level-button:active,.play-again-button:active{transform:translateY(1px)}@keyframes kathleen-pop{0%{scale:1}45%{scale:1.3}72%{scale:.92}to{scale:1}}@keyframes mini-sparkle{0%{opacity:0;transform:translate(0) scale(.4)}45%{opacity:1}to{opacity:0;transform:translate(10px,-18px) scale(1.5)}}@keyframes hint-pulse{0%,to{opacity:.68;scale:.96}50%{opacity:1;scale:1.08}}@keyframes hint-orbit{to{rotate:360deg}}@keyframes celebration-glow{0%{opacity:0;scale:.3}35%{opacity:1;scale:1.08}to{opacity:.62;scale:1}}@keyframes celebration-burst{0%{opacity:0;transform:rotate(var(--angle)) translate(0) scale(.4)}22%{opacity:1}to{opacity:0;transform:rotate(var(--angle)) translate(var(--distance)) scale(1.1)}}@keyframes confetti-fall{0%{opacity:0;transform:translateZ(0) rotate(0)}12%{opacity:1}to{opacity:0;transform:translate3d(calc(var(--sway) * 34px),calc(100vh + 120px),0) rotate(var(--spin))}}@keyframes star-dance{0%,to{transform:translateY(0) rotate(-8deg) scale(1)}50%{transform:translateY(-12px) rotate(8deg) scale(1.12)}}@keyframes finale-backdrop{0%{opacity:0}to{opacity:1}}@keyframes finale-kathleen-pop{0%{opacity:0;transform:translateY(22vh) scale(.52) rotate(-4deg)}18%{opacity:1;transform:translateY(0) scale(1.04) rotate(2deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}@media(max-height:850px)and (min-width:621px){.app-shell{padding-top:10px}.level-switcher{margin-bottom:10px;padding:6px 8px}.level-step-button,.audio-toggle,.current-level-pill{min-height:34px}.level-step-button,.audio-toggle{padding:6px 10px;font-size:.86rem}.current-level-pill{flex-basis:210px;padding:6px 12px;font-size:.84rem}.game-header{margin-bottom:8px}h1{font-size:clamp(2.2rem,7.2vw,4rem)}.progress-card{margin-bottom:8px;padding:7px 10px}.game-tools{margin-bottom:8px}.hint-button,.replay-button{min-height:38px;padding:8px 18px}.game-message{margin-bottom:10px;padding-block:4px}.scene-frame{width:min(100%,84vh,930px);max-width:100%;margin:0 auto}.scene-background{height:auto;object-fit:contain}}@media(max-width:620px){.app-shell{padding:10px 8px 22px;overflow-x:hidden}.app-shell.is-home-open{padding:8px}.title-screen{min-height:calc(100svh - 16px);border-width:4px;border-radius:22px}.title-panel{gap:10px;padding:18px 10px 24px}.title-logo{font-size:clamp(2.8rem,18vw,4.4rem)}.title-play-button{min-height:48px;padding:10px 22px;font-size:1rem}.level-switcher{gap:6px;margin-bottom:10px;padding:6px;border-width:2px;border-radius:22px}.level-step-button,.audio-toggle{min-height:36px;padding:7px 9px;font-size:.82rem}.home-icon-button{width:40px;min-width:40px;padding:0}.home-icon-button svg{width:20px;height:20px}.current-level-pill{min-height:36px;flex:1 1 154px;padding:7px 10px;font-size:.8rem}.game-header{gap:2px;margin-bottom:9px}h1{font-size:clamp(1.75rem,12vw,2.75rem)}.progress-card{grid-template-columns:1fr;gap:8px;border-radius:18px;margin-bottom:9px;padding:8px 10px}.progress-copy{justify-content:center}.game-tools{gap:8px}.hint-button,.replay-button{width:min(100%,180px)}.game-message{min-height:24px;margin-bottom:8px;font-size:.88rem}.scene-viewport{overflow:visible;padding:0}.scene-frame{width:100%;border-width:3px;border-radius:16px;min-height:0}.completion-actions{max-width:calc(100% - 18px);padding:7px}.next-level-button,.play-again-button{min-height:44px;padding:10px 16px}.finale-kathleen{place-items:center;padding:0 8px}.finale-kathleen img{height:min(150%,920px);max-width:none}}
