@import "https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{background-color:#036;font-family:"Press Start 2P",cursive}html,body{overscroll-behavior:none;height:100%;margin:0;padding:0;overflow:hidden}.nyan-scene{width:100vw;height:100vh;background:linear-gradient(#036 0%,#003 100%);height:100dvh;position:relative;overflow:hidden}.star{animation:.5s infinite alternate twinkle;position:absolute}.star.circle{background:#fff;border-radius:50%}.star.circle.small{width:4px;height:4px}.star.circle.medium{width:6px;height:6px}.star.circle.large{width:8px;height:8px}.star.cross{background:0 0}.star.cross:before,.star.cross:after{content:"";background:#fff;position:absolute}.star.cross:before{width:100%;height:2px;top:50%;left:0;transform:translateY(-50%)}.star.cross:after{width:2px;height:100%;top:0;left:50%;transform:translate(-50%)}.star.cross.small{width:6px;height:6px}.star.cross.medium{width:10px;height:10px}.star.cross.large{width:14px;height:14px}@keyframes twinkle{0%{opacity:.3}to{opacity:1}}.moving-star{background:0 0;width:10px;height:10px;animation:.5s linear infinite moveLeft;position:absolute}.moving-star:before,.moving-star:after{content:"";background:#fff;position:absolute}.moving-star:before{width:100%;height:2px;top:50%;left:0;transform:translateY(-50%)}.moving-star:after{width:2px;height:100%;top:0;left:50%;transform:translate(-50%)}@keyframes moveLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-30px)}}.nyan-cat{transform-origin:50%;position:absolute}.nyan-cat.departing{animation:3s linear forwards departUp!important}@keyframes departUp{0%{transform:translate(0)}to{transform:translate(200vw)}}.rainbow-trail{flex-direction:column;width:35vw;display:flex;position:absolute;top:50%;right:100%;transform:translateY(-50%)}.rainbow-stripe{height:8px;animation:.2s infinite rainbowWave}.rainbow-stripe:first-child{background-color:red;animation-delay:0s}.rainbow-stripe:nth-child(2){background-color:#f90;animation-delay:30ms}.rainbow-stripe:nth-child(3){background-color:#ff0;animation-delay:60ms}.rainbow-stripe:nth-child(4){background-color:#3f0;animation-delay:90ms}.rainbow-stripe:nth-child(5){background-color:#09f;animation-delay:.12s}.rainbow-stripe:nth-child(6){background-color:#63f;animation-delay:.15s}@keyframes rainbowWave{0%,to{transform:scaleY(1)}50%{transform:scaleY(.8)}}.cat-body{width:70px;height:50px;position:relative}.poptart{background-color:#fc9;border:3px solid #c96;border-radius:8px;width:60px;height:40px;position:absolute;top:5px;left:5px}.poptart-frosting{background-color:#f9c;border-radius:5px;width:50px;height:30px;position:absolute;top:10px;left:10px}.sprinkle{border-radius:50%;width:4px;height:4px;position:absolute}.cat-head{z-index:2;background-color:#999;border-radius:5px;width:30px;height:25px;position:absolute;top:10px;right:-15px}.cat-ear{border-bottom:10px solid #999;border-left:6px solid #0000;border-right:6px solid #0000;width:0;height:0;position:absolute;top:-8px}.cat-ear.left{left:2px}.cat-ear.right{right:2px}.cat-ear-inner{border-bottom:5px solid #f99;border-left:3px solid #0000;border-right:3px solid #0000;width:0;height:0;position:absolute;top:-5px}.cat-ear-inner.left{left:5px}.cat-ear-inner.right{right:5px}.cat-eye{background-color:#000;border-radius:50%;width:6px;height:8px;position:absolute;top:8px}.cat-eye.left{left:6px}.cat-eye.right{right:6px}.cat-cheek{background-color:#f69;border-radius:50%;width:6px;height:4px;position:absolute;top:14px}.cat-cheek.left{left:2px}.cat-cheek.right{right:2px}.cat-mouth{border:2px solid #000;border-top:none;border-left:none;width:4px;height:4px;position:absolute;bottom:4px;left:50%;transform:translate(-50%)rotate(45deg)}.cat-legs{gap:8px;display:flex;position:absolute;bottom:-8px;left:10px}.cat-leg{background-color:#999;border-radius:0 0 3px 3px;width:8px;height:10px;animation:.2s infinite alternate legMove}.cat-leg:first-child{animation-delay:0s}.cat-leg:nth-child(2){animation-delay:.1s}.cat-leg:nth-child(3){animation-delay:0s}.cat-leg:nth-child(4){animation-delay:.1s}@keyframes legMove{0%{transform:translateY(0)}to{transform:translateY(3px)}}.cat-tail{transform-origin:100%;background-color:#999;border-radius:4px;width:20px;height:8px;animation:.3s infinite alternate tailWag;position:absolute;top:20px;left:-15px}@keyframes tailWag{0%{transform:rotate(-10deg)}to{transform:rotate(10deg)}}.cat-container{animation:.2s infinite alternate bob}@keyframes bob{0%{transform:translateY(0)}to{transform:translateY(-5px)}}.memorial-text{text-align:center;color:#fff;opacity:0;z-index:500;font-family:"Press Start 2P",cursive;animation:2s ease-in forwards fadeInText;position:absolute;top:55%;left:0;right:0}.memorial-title{text-shadow:3px 3px red,-1px -1px #f90,1px -1px #ff0,-1px 1px #3f0,0 3px #09f;margin-bottom:.5em;font-size:2rem}.memorial-name{text-shadow:3px 3px red,-1px -1px #f90,1px -1px #ff0,-1px 1px #3f0,0 3px #09f;font-size:2.5rem}@keyframes fadeInText{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.play-overlay{width:100vw;height:100vh;z-index:1000;cursor:pointer;background:#000c;flex-direction:column;justify-content:center;align-items:center;height:100dvh;display:flex;position:fixed;top:0;left:0}.play-button{color:#fff;cursor:pointer;background:linear-gradient(#f9c 0%,#f69 100%);border:4px solid #fff;padding:20px 40px;font-family:"Press Start 2P",cursive;font-size:1.5rem;animation:1s infinite alternate pulse}.play-button:hover{background:linear-gradient(#fad 0%,#f7a 100%)}@keyframes pulse{0%{transform:scale(1)}to{transform:scale(1.05)}}.play-overlay-text{color:#fc0;text-align:center;margin-top:20px;font-family:"Press Start 2P",cursive;font-size:.8rem;line-height:1.8}.nyan-cat.entering{animation:4s ease-out forwards enterFromLeft}.nyan-cat.entry-complete{transform:translate(0)}@keyframes enterFromLeft{0%{transform:translate(-200px)}to{transform:translate(0)}}.portrait-overlay{width:100vw;height:100vh;z-index:2000;color:#fff;text-align:center;box-sizing:border-box;background:linear-gradient(#036 0%,#003 100%);flex-direction:column;justify-content:center;align-items:center;height:100dvh;padding:20px;font-family:"Press Start 2P",cursive;display:flex;position:fixed;top:0;left:0}.rotate-icon{margin-bottom:20px;font-size:4rem;animation:2s ease-in-out infinite rotatePhone}@keyframes rotatePhone{0%,to{transform:rotate(0)}50%{transform:rotate(90deg)}}.rotate-message{text-shadow:2px 2px red,-1px -1px #f90;max-width:280px;font-size:1rem;line-height:1.8}.rotate-arrow{color:#fc0;margin-top:30px;font-size:3rem;animation:1s infinite alternate pulse}@media screen and (max-height:500px) and (orientation:landscape){.cat-body{width:50px;height:36px}.poptart{width:43px;height:29px}.poptart-frosting{width:36px;height:21px}.cat-head{width:21px;height:18px;top:7px;right:-10px}.cat-ear{border-bottom:7px solid #999;border-left:4px solid #0000;border-right:4px solid #0000;top:-5px}.cat-ear-inner{border-bottom:4px solid #f99;border-left:2px solid #0000;border-right:2px solid #0000;top:-3px}.cat-eye{width:4px;height:6px;top:5px}.cat-eye.left{left:4px}.cat-eye.right{right:4px}.cat-cheek{width:4px;height:3px;top:10px}.cat-cheek.left{left:1px}.cat-cheek.right{right:1px}.cat-mouth{width:3px;height:3px;bottom:3px}.cat-legs{gap:5px;bottom:-6px;left:7px}.cat-leg{width:6px;height:7px}.cat-tail{width:14px;height:6px;top:14px;left:-10px}.rainbow-trail{width:25vw}.rainbow-stripe{height:5px}.memorial-title{font-size:1rem}.memorial-name{font-size:1.2rem}.play-button{padding:12px 24px;font-size:1rem}.play-overlay-text{margin-top:10px;font-size:.6rem}}
