.memory-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:999;background:radial-gradient(circle at 30% 30%,rgba(255,182,193,.35),transparent 60%),radial-gradient(circle at 70% 70%,rgba(255,105,180,.25),transparent 60%),#ffc0cb40;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:memoryFogFade .5s ease}@keyframes memoryFogFade{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}}.memory-polaroid{position:relative;background:#fff;padding:14px 14px 60px;border-radius:8px;box-shadow:0 40px 80px #00000059,0 0 60px #ffb6c173,inset 0 0 30px #fff9;transform:scale(.75) rotate(-4deg);animation:memoryAppear .45s cubic-bezier(.2,.8,.2,1) forwards}@keyframes memoryAppear{to{transform:scale(1) rotate(0)}}.memory-polaroid img{display:block;border-radius:6px;object-fit:cover;max-width:min(80vw,520px);max-height:70vh;box-shadow:0 10px 30px #00000040}.memory-close{position:absolute;top:-18px;right:-18px;width:52px;height:52px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#ff8fab,#ff4d6d);color:#fff;font-size:18px;cursor:pointer;box-shadow:0 8px 22px #ff4d6d80,inset 0 2px 4px #ffffff80;transition:.25s}.memory-close:active{transform:scale(.9)}@media(max-width:768px){.memory-modal{padding:20px;align-items:center;justify-content:center}.memory-polaroid{height:40vh;width:60vw;padding:10px 10px 60px;transform:scale(.85) rotate(-2deg)}.memory-polaroid img{width:100%;height:40vh;object-fit:cover}.memory-close{width:44px;height:44px;font-size:14px;top:-14px;right:-14px}}body{margin:0;background:radial-gradient(circle at top,#ffd6e0,#ff8fab 60%,#ff4d6d);min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:Great Vibes,cursive;font-style:normal}.book-wrapper{position:relative;perspective:2000px;display:flex;align-items:center;justify-content:center;z-index:1}.book-cover{width:260px;height:360px;background:linear-gradient(145deg,#fff0f5,#ffc2d1);border-radius:8px 16px 16px 8px;box-shadow:0 20px 40px #00000040;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;border:3px solid #fff;text-align:center;padding:20px;position:relative}.book-cover:before{content:"";position:absolute;left:12px;top:0;bottom:0;width:6px;background:#fff9;border-radius:4px}.book-cover h1{font-size:40px;font-weight:700;color:#b03060;margin-bottom:10px;position:absolute;top:20px}.book{width:900px;max-width:95vw;height:520px;background:linear-gradient(145deg,#ffe0ec,#ffc2d1 40%,#ffb3c6);border-radius:14px;box-shadow:0 30px 60px #0000004d,inset 0 0 40px #fff6;display:flex;align-items:center;justify-content:center;position:relative;padding:60px 80px;overflow:hidden}.book:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:6px;background:linear-gradient(to bottom,#f8c8dc,#e5989b,#f8c8dc);transform:translate(-50%);box-shadow:inset 0 0 6px #0003}.page-container{width:100%;height:100%;position:relative}.page{width:100%;height:100%;background-color:#fff;background-image:url(https://www.transparenttextures.com/patterns/embossed-paper.png);border-radius:6px;box-shadow:inset 0 0 30px #0000000d;padding:10px 20px;display:flex}.page-inner{display:grid;grid-template-columns:1fr 43px 1fr;height:100%;gap:10px}.page-text{flex:1;font-size:20px;line-height:1.8;color:#5a3e4d;position:relative}.page-title{font-size:29px;margin-bottom:20px;color:#d63384;text-align:left;font-weight:700;letter-spacing:1px;position:relative;font-family:Playfair Display,serif}.page-title:after{content:"";display:block;width:60px;height:3px;margin-top:8px;background:linear-gradient(to right,#ff8fab,transparent);border-radius:4px}.page-text p{margin:0 0 10px}.dropcap{float:left;font-size:40px;line-height:.85;font-weight:700;color:#d63384;margin-right:8px;margin-top:4px}.page-divider{width:4px;background:linear-gradient(to bottom,transparent 0%,#f8c8dc 20%,#e5989b 50%,#f8c8dc 80%,transparent 100%);border-radius:4px;box-shadow:inset 0 0 6px #00000026,0 0 8px #e6989b66;position:relative}.page-images-wrapper{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:18px;align-content:center;justify-items:center;padding:10px 0}.page-image{width:100%;aspect-ratio:1 / 1;object-fit:cover;position:relative;overflow:hidden;background:#fff;padding:8px 8px 40px;box-shadow:0 8px 18px #0000002e,0 2px 4px #00000014;transition:transform .35s ease,box-shadow .35s ease}.page-image:after{content:"";position:absolute;inset:0;border-radius:10px;background:linear-gradient(135deg,#ffffff59,#ffffff0d 40%,#fff0 60%);pointer-events:none}.memory-0{transform:rotate(-6deg)}.memory-1{transform:rotate(4deg)}.memory-2{transform:rotate(-3deg)}.memory-3{transform:rotate(7deg)}@media(hover:hover)and (pointer:fine){.page-image:hover{transform:scale(1.08) rotate(0);z-index:2;box-shadow:0 18px 35px #00000040,0 6px 10px #0000001f}}@media(max-width:768px){.book{width:90vw;height:60vw;padding:40px 15px}.page-text{font-size:16px}.page-images-wrapper{gap:5px;grid-template-columns:repeat(1,.65fr)}.page-image{padding:5px 5px 23px}}.controls{position:absolute;bottom:20px;right:30px;display:flex;gap:12px}button{background:#ff8fab;border:none;color:#fff;font-size:18px;padding:8px 14px;border-radius:50px;cursor:pointer;box-shadow:0 5px 15px #00000026;transition:.3s}button:active{background:#ca223e;transform:translateY(-2px)}@media(hover:hover)and (pointer:fine){button:hover{background:#ff4d6d;transform:translateY(-2px)}.page-image:hover{transform:scale(1.05) rotate(0)}}button:disabled{opacity:.4;cursor:not-allowed;transform:none}.close-book{position:absolute;top:14px;right:14px;width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;background:linear-gradient(145deg,#ff8fab,#ff4d6d);box-shadow:0 6px 18px #ff4d6d66,inset 0 2px 4px #fff6;transition:all .25s ease}.close-book:before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.6),transparent 60%);opacity:.4;pointer-events:none}.close-book:active{transform:scale(.92);box-shadow:0 3px 10px #ff4d6d4d,inset 0 3px 6px #00000040}.loader{background-image:linear-gradient(90deg,#ff0037,#ff2c7d 10%);background-clip:text;-webkit-background-clip:text;color:transparent;font-size:2rem;text-align:center;position:relative}.loader:after{content:"";display:block;width:100%;height:2px;background-color:#ff2c7d;box-shadow:0 0 10px #e6a9a951;margin:1rem auto}.loader:before{content:"";display:block;width:100%;height:2px;background-color:#ff2c7d;box-shadow:0 0 10px #e6a9a951;margin:1rem auto}.Particle_heart{position:absolute;font-size:1.5rem;color:#ff2c7d;opacity:0;animation:floatHeart 5s linear infinite}.Particle_heart:nth-child(1){left:10%;animation-delay:.5s}.Particle_heart:nth-child(2){left:30%;animation-delay:2.5s}.Particle_heart:nth-child(3){left:50%;animation-delay:1.5s}.Particle_heart:nth-child(4){left:70%;animation-delay:1s}@keyframes floatHeart{0%{transform:translateY(0) translate(0);opacity:0}20%{opacity:1}80%{transform:translateY(-100px) translate(30px);opacity:1}to{transform:translateY(-150px) translate(60px);opacity:0}}.play-icon{font-size:3rem;color:#ff2c7d;cursor:pointer;position:relative;z-index:2;transition:transform .2s ease,color .3s ease;filter:drop-shadow(0 0 10px rgba(255,44,125,.6))}.play-icon:hover{transform:scale(1.2) rotate(-5deg);color:#ff69a3;filter:drop-shadow(0 0 20px rgba(255,105,180,.8))}.play-icon:active{animation:play-pop .5s forwards}@keyframes play-pop{0%{transform:scale(1) rotate(0);color:#ff2c7d;filter:drop-shadow(0 0 10px rgba(255,44,125,.6))}50%{transform:scale(1.6) rotate(10deg);color:#ff69a3;filter:drop-shadow(0 0 30px rgba(255,105,180,1))}to{transform:scale(1) rotate(0);color:#ff2c7d;filter:drop-shadow(0 0 10px rgba(255,44,125,.6))}}@keyframes floatPlay{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-5px) rotate(-3deg)}}.play-icon{animation:floatPlay 2s ease-in-out infinite}@media(max-width:900px){.app{padding:14px;align-items:flex-start}.book{width:75%;height:50vh;padding:22px 18px 70px;border-radius:18px;box-shadow:0 20px 60px #00000059,inset 0 0 25px #0000000d}.page{padding:10px 0 0 5px}.page-inner{display:grid;grid-template-columns:minmax(0,1fr) 43px minmax(0,1fr);height:100%;gap:10px}.page-text-wrapper,.page-images-wrapper{height:100%;min-height:0;padding:0}.page-title{font-size:15px}.page-text{font-size:12px;font-weight:700;line-height:1.2;text-align:left;will-change:transform}.dropcap{font-size:28px;margin-right:5px;margin-top:2px}.page-divider{width:10%;height:99%;background:linear-gradient(to right,transparent,#f4a6c1,transparent);margin:0 13px}.page-image{width:100%;max-height:240px;object-fit:cover;transform:none;box-shadow:0 12px 25px #0000002e}.controls{bottom:14px;right:14px}button{padding:8px 14px;font-size:14px}.page-image:active{transform:scale(1.08) rotate(0);z-index:2;box-shadow:0 18px 35px #00000040,0 6px 10px #0000001f}.memory-0{transform:rotate(-6deg)}.memory-1{transform:rotate(4deg)}.memory-2{transform:rotate(-3deg)}.memory-3{transform:rotate(7deg)}.close-book{width:30px;height:30px;font-size:10px;top:10px;right:10px}.page-text-wrapper{display:flex;flex-direction:column;overflow:hidden}.page-text{flex:1;overflow-y:auto;padding-right:6px}}#heartfall{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}.heart{position:absolute;top:-20px;color:#ff69b4cc;display:inline-block;filter:drop-shadow(0 0 2px rgba(255,105,180,.5));animation-name:fall;animation-timing-function:linear;animation-iteration-count:infinite}@keyframes fall{0%{transform:translateY(0) rotate(0)}to{transform:translateY(110vh) rotate(360deg)}}.intro-title{font-size:2rem;color:#d63384;margin-bottom:10px}.intro-sub{color:#ff4d6d;margin-bottom:30px}.date-inputs{display:flex;align-items:center;gap:8px;margin-bottom:20px}.date-inputs input{width:70px;padding:10px;font-size:18px;text-align:center;border:2px solid #ff85a2;border-radius:12px;outline:none;transition:.3s;background:#fff}.date-inputs input:focus{border-color:#ff4d6d;box-shadow:0 0 12px #ff4d6d66}.dot{font-size:20px;color:#ff4d6d}.unlock-btn{background:linear-gradient(135deg,#ff4d8d,#ff85a2);border:none;padding:12px 24px;border-radius:50px;color:#fff;font-size:16px;cursor:pointer;transition:.3s}.unlock-btn:hover{transform:scale(1.08)}.error-text{color:#c9184a;margin-bottom:10px}.shake{animation:shake .4s}@keyframes shake{0%{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-6px)}to{transform:translate(0)}}
