*{margin:0;padding:0;box-sizing:border-box}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#a8c8e8,#6b9bd2,#b8d4f0);min-height:100vh;overflow-x:hidden}.app{width:100%;min-height:100vh;display:flex;flex-direction:column;scroll-behavior:smooth}section{min-height:100vh;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem 1.5rem;scroll-snap-align:start}.valentine-section{text-align:center;color:#2c5f8d;display:flex;justify-content:center;align-items:center}.valentine-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;padding:3rem 2rem;box-shadow:0 20px 60px #2c5f8d33,0 0 0 1px #ffffff80;max-width:500px;width:100%;margin:2rem;animation:fadeIn .5s ease}.valentine-gif{max-width:100%;width:100%;max-width:300px;height:auto;border-radius:20px;box-shadow:0 8px 30px #2c5f8d33;animation:fadeIn .5s ease;margin-bottom:2rem}.valentine-question{font-family:Playfair Display,serif;font-size:2rem;font-weight:600;margin-bottom:3rem;line-height:1.4;color:#2c5f8d}.valentine-buttons{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:300px;margin:0 auto}.valentine-button{padding:1rem 2rem;font-size:1.2rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003;min-height:56px;width:100%}.yes-button{background:linear-gradient(135deg,#a8e6cf,#88d8a3);color:#2c5f8d;font-family:Poppins,sans-serif;font-weight:600}.yes-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #88d8a366;background:linear-gradient(135deg,#b8f0d8,#98e8b3)}.yes-button:active{transform:translateY(0)}.no-button{background:linear-gradient(135deg,#ffb6c1,#ffa4b5);color:#2c5f8d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-family:Poppins,sans-serif;font-weight:600;border:2px solid rgba(255,182,193,.3)}.no-button:hover{background:linear-gradient(135deg,#ffc6d1,#ffb4c5);transform:translateY(-2px);border-color:#ffa4b580;box-shadow:0 4px 15px #ffb6c14d}.no-button:active{transform:translateY(0)}.banana-cat-gif-container{width:100%;min-height:56px;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.banana-cat-gif{border-radius:10px;pointer-events:none}.funny-message{margin-top:2rem;font-size:1.1rem;font-weight:500;color:#2c5f8d;min-height:2rem;animation:fadeIn .3s ease;font-family:Poppins,sans-serif}.celebration-gif{max-width:100%;width:100%;max-width:400px;height:auto;border-radius:20px;box-shadow:0 8px 30px #0000004d;animation:fadeIn .5s ease;margin-bottom:2rem}.success-message{margin-top:1rem;font-size:1.5rem;font-weight:600;color:#2c5f8d;text-shadow:1px 1px 2px rgba(255,255,255,.5);animation:fadeIn .5s ease;text-align:center;padding:0 1rem;margin-bottom:2rem;font-family:Cormorant Garamond,serif}.secret-door-button{margin-top:2rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,#6b9bd2,#4a7ba7);color:#fff;border:2px solid rgba(255,255,255,.4);border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2c5f8d4d;animation:fadeIn .5s ease;font-family:Poppins,sans-serif}.secret-door-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0006;border-color:#ffffff80}.secret-door-button:active{transform:translateY(0)}.password-section{text-align:center;color:#2c5f8d;display:flex;justify-content:center;align-items:center}.password-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;padding:3rem 2rem;box-shadow:0 20px 60px #2c5f8d33,0 0 0 1px #ffffff80;max-width:500px;width:100%;margin:2rem;animation:fadeIn .5s ease}.password-container{width:100%;max-width:500px;margin:0 auto}.password-question{font-family:Playfair Display,serif;font-size:2rem;font-weight:600;margin-bottom:2rem;line-height:1.4;color:#2c5f8d}.password-form{display:flex;flex-direction:column;gap:1rem;width:100%}.password-input{padding:1rem 1.5rem;font-size:1.1rem;border:2px solid rgba(107,155,210,.3);border-radius:50px;background:#ffffffe6;color:#2c5f8d;outline:none;transition:all .3s ease;text-align:center;font-family:Poppins,sans-serif;box-shadow:0 2px 8px #2c5f8d1a}.password-input::placeholder{color:#2c5f8d80}.password-input:focus{border-color:#6b9bd2;background:#fff;box-shadow:0 4px 15px #6b9bd24d}.password-submit-button{padding:1rem 2rem;font-size:1.2rem;font-weight:600;background:linear-gradient(135deg,#6b9bd2,#4a7ba7);color:#fff;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2c5f8d4d;font-family:Poppins,sans-serif}.password-submit-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.password-submit-button:active{transform:translateY(0)}.password-error{margin-top:1rem;font-size:1rem;color:#2c5f8d;animation:fadeIn .3s ease;min-height:1.5rem;font-family:Poppins,sans-serif;font-weight:500}.hint-button{margin:1.5rem 0;padding:.8rem 1.5rem;font-size:1rem;font-weight:600;background:#6b9bd21a;color:#2c5f8d;border:2px solid rgba(107,155,210,.3);border-radius:50px;cursor:pointer;transition:all .3s ease;font-family:Poppins,sans-serif}.hint-button:hover{background:#6b9bd226;transform:translateY(-2px);box-shadow:0 4px 15px #6b9bd233;border-color:#6b9bd280}.hint-button:active{transform:translateY(0)}.hint-section{width:100%;max-width:400px;margin:1.5rem auto;animation:fadeIn .5s ease}.camera-container{width:100%;border-radius:20px;overflow:hidden;box-shadow:0 8px 30px #2c5f8d33;border:2px solid rgba(107,155,210,.3);background:#0000001a}.camera-video{width:100%;height:auto;display:block;transform:scaleX(-1)}.timeline-section{text-align:center;color:#2c5f8d;padding:4rem 1.5rem;min-height:100vh;scroll-behavior:smooth;overflow-y:auto}.timeline-container{width:100%;max-width:1200px;margin:0 auto}.timeline-title{font-family:Playfair Display,serif;font-size:2.5rem;font-weight:600;margin-bottom:4rem;text-shadow:2px 2px 4px rgba(0,0,0,.15);animation:fadeIn .5s ease;color:#2c5f8d}.timeline-content{position:relative;padding:2rem 0;animation:fadeIn .5s ease}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#6b9bd266,#6b9bd2b3,#6b9bd266);transform:translate(-50%);border-radius:2px;box-shadow:0 0 20px #6b9bd24d}.timeline-item{position:relative;margin-bottom:4rem;opacity:0;transform:translateY(50px);transition:all .8s cubic-bezier(.4,0,.2,1)}.timeline-item-visible{opacity:1;transform:translateY(0)}.timeline-item-left{padding-right:55%;text-align:right}.timeline-item-right{padding-left:55%;text-align:left}.timeline-dot{position:absolute;left:50%;top:2rem;width:20px;height:20px;background:linear-gradient(135deg,#6b9bd2,#4a7ba7);border-radius:50%;transform:translate(-50%);box-shadow:0 0 20px #6b9bd299,0 0 40px #4a7ba766;z-index:2;border:3px solid rgba(255,255,255,.8)}.timeline-card{background:#ffffff40;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;padding:1.5rem;border:2px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #2c5f8d33;transition:all .3s ease;overflow:hidden}.timeline-item:hover .timeline-card{transform:scale(1.02);box-shadow:0 12px 40px #2c5f8d4d;border-color:#6b9bd280}.timeline-image-container{width:100%;height:250px;border-radius:15px;overflow:hidden;margin-bottom:1rem;box-shadow:0 4px 15px #0003}.timeline-image{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.timeline-item:hover .timeline-image{transform:scale(1.05)}.timeline-info{padding:.5rem 0}.timeline-date{font-family:Cormorant Garamond,serif;font-size:1.3rem;font-weight:700;color:#2c5f8d;text-shadow:1px 1px 2px rgba(255,255,255,.5);margin-bottom:.8rem}.timeline-description{font-size:1rem;line-height:1.6;color:#2c5f8d;margin:0;font-family:Poppins,sans-serif}.letter-section{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1.5rem;background:linear-gradient(135deg,#a8c8e8,#6b9bd2,#b8d4f0)}.letter-container{width:100%;max-width:800px;display:flex;flex-direction:column;align-items:center;gap:2rem}.letter-paper{width:100%;max-width:700px;background:#f8fafc;padding:3rem 2.5rem;border-radius:5px;box-shadow:0 0 0 1px #6b9bd233,0 10px 40px #2c5f8d33,inset 0 0 0 1px #ffffff80;position:relative;animation:fadeIn .8s ease;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(107,155,210,.05) 2px,rgba(107,155,210,.05) 4px)}.letter-paper:before{content:"";position:absolute;left:60px;top:0;bottom:0;width:2px;background:#6b9bd24d;opacity:.4}.letter-content{position:relative;z-index:1;color:#2c5f8d;font-family:Caveat,Dancing Script,Kalam,cursive;line-height:1.8}.letter-date{text-align:right;font-size:1.1rem;color:#6b9bd2;margin-bottom:2rem;font-style:italic;font-family:Caveat,Dancing Script,cursive}.letter-greeting{font-family:Caveat,Dancing Script,cursive;font-size:1.6rem;margin-bottom:1.5rem;color:#2c5f8d;font-weight:600}.letter-body{font-size:1.2rem;margin-bottom:2rem;text-align:justify;font-family:Caveat,Dancing Script,cursive}.letter-body p{margin-bottom:1.2rem;color:#2c5f8d;letter-spacing:.3px}.letter-body p:last-child{margin-bottom:0}.letter-closing{margin-top:2.5rem;text-align:right}.letter-closing p{margin-bottom:.5rem;color:#2c5f8d;font-size:1.2rem;font-family:Caveat,Dancing Script,cursive}.letter-signature{font-size:1.8rem;font-weight:600;color:#2c5f8d;margin-top:1rem;font-family:Dancing Script,Kalam,cursive,sans-serif;transform:rotate(-1deg);display:inline-block}.letter-timeline-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,#6b9bd2,#4a7ba7);color:#fff;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2c5f8d4d;animation:fadeIn .8s ease .3s both;font-family:Poppins,sans-serif}.letter-timeline-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0006}.letter-timeline-button:active{transform:translateY(0)}.letter-kiss-counter-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,#ffb6c1,#ffa4b5);color:#2c5f8d;border:2px solid rgba(255,182,193,.3);border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ffb6c14d;animation:fadeIn .8s ease .3s both;font-family:Poppins,sans-serif}.letter-kiss-counter-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffb6c166;border-color:#ffa4b580;background:linear-gradient(135deg,#ffc6d1,#ffb4c5)}.letter-kiss-counter-button:active{transform:translateY(0)}.landing-section{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1.5rem;text-align:center}.landing-container{width:100%;max-width:1200px;margin:0 auto;animation:fadeIn .8s ease}.landing-title{font-family:Playfair Display,serif;font-size:3rem;font-weight:700;color:#2c5f8d;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.15)}.landing-subtitle{font-family:Poppins,sans-serif;font-size:1.3rem;color:#2c5f8d;margin-bottom:3rem;opacity:.9}.landing-cards{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:2rem}.landing-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;padding:3rem 2rem;box-shadow:0 20px 60px #2c5f8d33,0 0 0 1px #ffffff80;cursor:pointer;transition:all .3s ease;animation:fadeIn .8s ease;border:2px solid rgba(255,255,255,.3)}.landing-card:hover{transform:translateY(-8px);box-shadow:0 25px 70px #2c5f8d4d,0 0 0 1px #fff9;border-color:#6b9bd280}.landing-card:active{transform:translateY(-4px)}.landing-card-icon{font-size:4rem;margin-bottom:1.5rem;animation:float 3s ease-in-out infinite}.landing-card:nth-child(2) .landing-card-icon{animation-delay:.3s}.landing-card:nth-child(3) .landing-card-icon{animation-delay:.6s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.landing-card-title{font-family:Playfair Display,serif;font-size:2rem;font-weight:600;color:#2c5f8d;margin-bottom:1rem}.landing-card-description{font-family:Poppins,sans-serif;font-size:1.1rem;color:#2c5f8d;opacity:.8;line-height:1.6}.kiss-counter-section{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1.5rem;background:linear-gradient(135deg,#a8c8e8,#6b9bd2,#b8d4f0);text-align:center}.kiss-counter-container{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;padding:4rem 3rem;box-shadow:0 20px 60px #2c5f8d33,0 0 0 1px #ffffff80;max-width:600px;width:100%;margin:2rem;animation:fadeIn .5s ease}.kiss-counter-title{font-family:Playfair Display,serif;font-size:2.5rem;font-weight:600;margin-bottom:2rem;color:#2c5f8d;text-shadow:1px 1px 2px rgba(255,255,255,.5)}.kiss-counter-number{font-family:Poppins,sans-serif;font-size:4rem;font-weight:700;color:#ff6b9d;text-shadow:2px 2px 4px rgba(0,0,0,.1);letter-spacing:2px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.reset-kiss-button{margin-top:2rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,#6b9bd2,#4a7ba7);color:#fff;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2c5f8d4d;font-family:Poppins,sans-serif;animation:fadeIn .5s ease}.reset-kiss-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0006}.reset-kiss-button:active{transform:translateY(0)}.gif-container{margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem;animation:fadeIn .5s ease}.reset-gif{max-width:100%;width:100%;max-width:400px;height:auto;border-radius:20px;box-shadow:0 8px 30px #2c5f8d33}.baka-text{font-family:Poppins,sans-serif;font-size:1.3rem;font-weight:600;color:#2c5f8d;text-shadow:1px 1px 2px rgba(255,255,255,.5);margin:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 768px){section{padding:3rem 2rem}.valentine-question{font-size:3rem;margin-bottom:4rem}.valentine-buttons{flex-direction:row;max-width:500px;gap:2rem}.valentine-button{flex:1;font-size:1.3rem;padding:1.2rem 2.5rem}.funny-message{font-size:1.3rem}.success-message{font-size:2rem}.celebration-gif{max-width:500px}.valentine-gif{max-width:400px}.valentine-card{padding:4rem 3rem;max-width:600px}.password-question{font-size:2.5rem}.password-card{padding:4rem 3rem;max-width:600px}.password-input{font-size:1.2rem}.password-submit-button{font-size:1.3rem}.timeline-title{font-size:3rem}.timeline-item-left{padding-right:52%}.timeline-item-right{padding-left:52%}.timeline-image-container{height:300px}.timeline-date{font-size:1.5rem}.timeline-description{font-size:1.1rem}.kiss-counter-title{font-size:3rem}.kiss-counter-number{font-size:5rem}.kiss-counter-container{padding:5rem 4rem;max-width:700px}.landing-title{font-size:4rem}.landing-subtitle{font-size:1.5rem}.landing-cards{grid-template-columns:repeat(3,1fr);gap:2.5rem}.landing-card{padding:4rem 2.5rem}.landing-card-icon{font-size:5rem}.landing-card-title{font-size:2.5rem}.landing-card-description{font-size:1.2rem}}@media (max-width: 767px){.valentine-card,.password-card{padding:2rem 1.5rem;margin:1rem;border-radius:20px}.letter-paper{padding:2rem 1.5rem}.letter-paper:before{left:40px}.letter-greeting{font-size:1.2rem}.letter-body{font-size:1rem}.letter-signature{font-size:1.5rem}.timeline-line{left:2rem}.timeline-item{padding-left:4rem!important;padding-right:0!important;text-align:left!important}.timeline-dot{left:2rem}.timeline-image-container{height:200px}.timeline-date{font-size:1.1rem}.timeline-description{font-size:.95rem}.kiss-counter-container{padding:3rem 2rem;margin:1rem;border-radius:20px}.kiss-counter-title{font-size:2rem;margin-bottom:1.5rem}.kiss-counter-number{font-size:3rem}.reset-kiss-button{font-size:1rem;padding:.9rem 1.8rem}.reset-gif{max-width:300px}.baka-text{font-size:1.1rem}.landing-title{font-size:2.5rem}.landing-subtitle{font-size:1.1rem;margin-bottom:2rem}.landing-card{padding:2.5rem 1.5rem}.landing-card-icon{font-size:3.5rem}.landing-card-title{font-size:1.8rem}.landing-card-description{font-size:1rem}}@media (min-width: 1024px){.valentine-question{font-size:3.5rem}.valentine-button{font-size:1.4rem;padding:1.3rem 3rem}}
