.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;position:relative;overflow:hidden;padding:20px}.floating-hearts{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden}.floating-hearts .heart{position:absolute;font-size:40px;opacity:.6;animation:float 10s infinite}.floating-hearts .heart:nth-child(1){left:10%;animation-delay:0s;animation-duration:8s}.floating-hearts .heart:nth-child(2){left:30%;animation-delay:2s;animation-duration:10s}.floating-hearts .heart:nth-child(3){left:50%;animation-delay:4s;animation-duration:12s}.floating-hearts .heart:nth-child(4){left:70%;animation-delay:1s;animation-duration:9s}.floating-hearts .heart:nth-child(5){left:90%;animation-delay:3s;animation-duration:11s}@keyframes float{0%{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:.6}90%{opacity:.6}to{transform:translateY(-100px) rotate(360deg);opacity:0}}.login-box{background:#fffffff2;padding:50px 40px;border-radius:30px;box-shadow:0 20px 60px #0000004d;max-width:450px;width:100%;position:relative;z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-title{font-size:36px;color:#d63384;text-align:center;margin-bottom:10px;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.login-subtitle{text-align:center;color:#666;margin-bottom:35px;font-size:16px}.form-group{margin-bottom:25px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:14px}.form-group input{width:100%;padding:15px 20px;border:2px solid #e0e0e0;border-radius:15px;font-size:16px;transition:all .3s ease;background:#fff}.form-group input:focus{outline:none;border-color:#d63384;box-shadow:0 0 0 4px #d633841a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:10px;margin-bottom:20px;font-size:14px;text-align:center;border:1px solid #ef9a9a}.login-button{width:100%;padding:16px;background:linear-gradient(135deg,#d63384,#f50057);color:#fff;border:none;border-radius:15px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #d6338466}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-hint{margin-top:25px;text-align:center}.login-hint p{font-size:12px;color:#999;font-style:italic}.heart-animation-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.heart-particle{position:absolute;font-size:30px;opacity:0;animation:floatUp 10s infinite;filter:drop-shadow(0 0 10px rgba(255,255,255,.5))}@keyframes floatUp{0%{transform:translateY(100vh) rotate(0) scale(.5);opacity:0}10%{opacity:.8}50%{opacity:.6}90%{opacity:.3}to{transform:translateY(-100px) rotate(360deg) scale(1);opacity:0}}.big-heart{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.15;pointer-events:none}.heart-shape{font-size:300px;animation:heartbeatBig 2s infinite;filter:drop-shadow(0 0 50px rgba(255,255,255,.3))}@keyframes heartbeatBig{0%,to{transform:scale(1)}10%{transform:scale(1.1)}20%{transform:scale(1)}30%{transform:scale(1.1)}40%,60%{transform:scale(1)}}.star-particle{position:absolute;font-size:25px;opacity:0;animation:twinkle 4s infinite;filter:drop-shadow(0 0 8px rgba(255,255,255,.8))}@keyframes twinkle{0%,to{opacity:0;transform:scale(.5) rotate(0)}50%{opacity:1;transform:scale(1.2) rotate(180deg)}}.sparkle-particle{position:absolute;font-size:28px;opacity:0;animation:floatSide 10s infinite;filter:drop-shadow(0 0 12px rgba(255,255,255,.6))}@keyframes floatSide{0%{transform:translateY(100vh) translate(0) rotate(0) scale(.3);opacity:0}10%{opacity:.9}50%{transform:translateY(50vh) translate(100px) rotate(180deg) scale(1);opacity:.7}90%{opacity:.4}to{transform:translateY(-50px) translate(-50px) rotate(360deg) scale(.5);opacity:0}}.rose-particle{position:absolute;font-size:35px;opacity:0;animation:floatSwing 12s infinite;filter:drop-shadow(0 0 15px rgba(255,100,150,.6))}@keyframes floatSwing{0%{transform:translateY(100vh) translate(0) rotate(0);opacity:0}10%{opacity:.8}25%{transform:translateY(75vh) translate(50px) rotate(45deg)}50%{transform:translateY(50vh) translate(-30px) rotate(-30deg);opacity:.6}75%{transform:translateY(25vh) translate(40px) rotate(60deg)}90%{opacity:.3}to{transform:translateY(-100px) translate(0) rotate(90deg);opacity:0}}.butterfly-particle{position:absolute;font-size:32px;opacity:0;animation:flyAround 15s infinite;filter:drop-shadow(0 0 10px rgba(255,255,255,.5))}@keyframes flyAround{0%{transform:translate(0) rotate(0);opacity:0}10%{opacity:.8}25%{transform:translate(200px,-100px) rotate(45deg) scale(1.1)}50%{transform:translate(-150px,-200px) rotate(-30deg) scale(.9);opacity:.7}75%{transform:translate(100px,-300px) rotate(60deg) scale(1.2)}90%{opacity:.5}to{transform:translateY(-500px) rotate(0) scale(.8);opacity:0}}.ribbon-particle{position:absolute;font-size:30px;opacity:0;animation:floatWave 10s infinite;filter:drop-shadow(0 0 10px rgba(255,192,203,.6))}@keyframes floatWave{0%{transform:translateY(100vh) translate(0) rotate(0);opacity:0}10%{opacity:.7}25%{transform:translateY(75vh) translate(80px) rotate(120deg)}50%{transform:translateY(50vh) translate(-60px) rotate(240deg);opacity:.5}75%{transform:translateY(25vh) translate(40px) rotate(360deg)}90%{opacity:.3}to{transform:translateY(-100px) translate(0) rotate(480deg);opacity:0}}.ring-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;pointer-events:none}.rotating-ring{position:absolute;font-size:40px;opacity:.3;filter:drop-shadow(0 0 20px rgba(255,215,0,.6))}.ring-1{top:50%;left:50%;animation:rotateRing1 20s linear infinite}.ring-2{top:50%;left:50%;animation:rotateRing2 15s linear infinite reverse}@keyframes rotateRing1{0%{transform:translate(-50%,-50%) rotate(0) translate(250px) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg) translate(250px) rotate(-360deg)}}@keyframes rotateRing2{0%{transform:translate(-50%,-50%) rotate(0) translate(200px) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg) translate(200px) rotate(-360deg)}}@media (max-width: 768px){.heart-shape{font-size:150px}.heart-particle{font-size:20px}.star-particle{font-size:18px}.sparkle-particle{font-size:20px}.rose-particle{font-size:25px}.butterfly-particle{font-size:24px}.ribbon-particle{font-size:22px}.ring-container{width:300px;height:300px}.rotating-ring{font-size:28px}@keyframes rotateRing1{0%{transform:translate(-50%,-50%) rotate(0) translate(120px) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg) translate(120px) rotate(-360deg)}}@keyframes rotateRing2{0%{transform:translate(-50%,-50%) rotate(0) translate(90px) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg) translate(90px) rotate(-360deg)}}}.memory-gallery{margin:60px 0;position:relative;z-index:1}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:50px;flex-wrap:wrap;gap:1rem;padding:0 20px}.section-title{text-align:center;font-size:42px;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3);font-weight:700;margin:0;flex:1}.header-buttons{display:flex;gap:1rem;flex-wrap:wrap}.add-memory-btn{background:#fffffff2;color:#ff1493;border:2px solid rgba(255,255,255,.4);padding:12px 24px;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 5px 20px #0003}.add-memory-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0000004d;background:#fff}.add-memory-form{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:20px;margin:0 20px 50px;box-shadow:0 10px 30px #0003;animation:slideDown .5s ease;border:1px solid rgba(255,255,255,.3)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:1.5rem;flex:1;min-width:200px}.form-group label{display:block;margin-bottom:.5rem;color:#fff;font-weight:600;font-size:.9rem;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.form-group input,.form-group textarea{width:100%;padding:.8rem;border:2px solid rgba(255,255,255,.3);border-radius:10px;font-size:1rem;transition:border-color .3s ease;font-family:inherit;background:#ffffffe6}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#fff9;background:#fff}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:flex;gap:1rem;flex-wrap:wrap}.submit-btn{background:linear-gradient(135deg,#ff1493,#ff69b4);color:#fff;border:none;padding:1rem 2rem;border-radius:25px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;box-shadow:0 4px 15px #ff14934d}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff149366}.memories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;padding:0 20px}.memory-card{background:#fff3;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px #0003;transition:all .3s ease;animation:slideInUp .8s ease backwards;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;border:1px solid rgba(255,255,255,.3)}.note-card{overflow:visible}.note-icon-badge{position:absolute;top:-15px;right:20px;background:linear-gradient(135deg,#ff69b4,#ff1493);width:55px;height:55px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 5px 20px #ff149366;z-index:10;animation:floatBadge 3s ease-in-out infinite;border:3px solid white}@keyframes floatBadge{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(5deg)}}.note-emoji{font-size:28px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.memory-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 15px 40px #0000004d;background:#ffffff40}.delete-btn{position:absolute;top:10px;right:10px;background:#ff3b30f2;color:#fff;border:none;width:35px;height:35px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .3s ease;opacity:0;box-shadow:0 2px 8px #0003}.memory-card:hover .delete-btn{opacity:1}.delete-btn:hover{transform:scale(1.15);background:#ff3b30;box-shadow:0 4px 12px #0000004d}.memory-image-container{width:100%;height:300px;position:relative;background:linear-gradient(135deg,#f093fb,#f5576c);overflow:hidden}.memory-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.memory-card:hover .memory-image{transform:scale(1.08)}.image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-align:center;padding:20px}.placeholder-icon{font-size:80px;margin-bottom:15px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.placeholder-text{font-size:16px;font-weight:600;text-shadow:2px 2px 4px rgba(0,0,0,.2);margin:0}.audio-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0000004d;display:flex;justify-content:center;align-items:center;opacity:0;transition:opacity .3s ease}.memory-image-container:hover .audio-overlay{opacity:1}.play-button{width:80px;height:80px;background:#fffffff2;border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:36px;box-shadow:0 5px 20px #0000004d;transition:all .3s ease}.play-button:hover{transform:scale(1.1);background:#fff}.audio-error-badge{position:absolute;top:10px;left:10px;background:#ff3b30f2;color:#fff;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:600;z-index:10;box-shadow:0 2px 8px #0003;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.memory-content{padding:30px}.memory-icon{font-size:48px;text-align:center;margin-bottom:20px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.memory-caption{color:#4a5568;font-size:20px;margin:0 0 15px;font-weight:700;text-align:center}.memory-text{color:#2d3748;font-size:18px;line-height:1.6;margin-bottom:15px;white-space:pre-wrap;text-align:center;font-weight:500}.memory-date{color:#718096;font-size:14px;text-align:center;font-style:italic;padding-top:15px;border-top:2px solid rgba(255,255,255,.2);margin-top:15px}.loading,.no-memories{text-align:center;padding:60px 20px;font-size:24px;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.floating-notes-container{position:fixed;bottom:30px;right:30px;display:flex;flex-direction:column;gap:15px;z-index:1000}.floating-note-icon{width:70px;height:70px;background:linear-gradient(135deg,#ff69b4,#ff1493);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 25px #ff149380;transition:all .3s cubic-bezier(.4,0,.2,1);animation:floatIn .6s ease backwards;border:3px solid white}@keyframes floatIn{0%{opacity:0;transform:translateY(20px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}.floating-note-icon:hover{transform:scale(1.1) rotate(5deg);box-shadow:0 10px 30px #ff149399}.floating-note-icon .note-emoji{font-size:35px;animation:pulse 2s ease-in-out infinite}.note-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:9998;animation:fadeIn .3s ease}.note-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:25px;padding:40px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;z-index:9999;animation:popIn .4s cubic-bezier(.4,0,.2,1);border:2px solid rgba(255,255,255,.5)}@keyframes popIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.note-close{position:absolute;top:15px;right:15px;background:#ff14931a;color:#ff1493;border:none;width:40px;height:40px;border-radius:50%;font-size:24px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.note-close:hover{background:#ff149333;transform:rotate(90deg)}.note-popup-content{text-align:center}.note-popup-icon{font-size:60px;margin-bottom:20px;animation:bounce 2s infinite}.note-popup-text{font-size:18px;line-height:1.8;color:#333;white-space:pre-wrap;font-weight:500}.slideshow-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#667eeafa,#764ba2fa);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10000;display:flex;justify-content:center;align-items:center;animation:fadeIn .4s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slideshow-container{position:relative;width:85%;max-width:900px;height:85vh;display:flex;align-items:center;justify-content:center}.close-slideshow{position:absolute;top:30px;right:30px;background:#ffffff26;color:#fff;border:2px solid rgba(255,255,255,.3);width:55px;height:55px;border-radius:50%;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1);z-index:100;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #0003}.close-slideshow:hover{background:#ffffff40;border-color:#ffffff80;transform:rotate(90deg) scale(1.1);box-shadow:0 6px 20px #0000004d}.close-icon{font-size:28px;font-weight:300;line-height:1}.slide-content{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.slide-image-wrapper{width:100%;flex:1;display:flex;align-items:center;justify-content:center;padding:20px;position:relative}.slide-image{max-width:100%;max-height:65vh;object-fit:contain;border-radius:16px;box-shadow:0 30px 90px #00000080,0 0 0 1px #ffffff1a;animation:slideZoom .6s cubic-bezier(.4,0,.2,1);background:#fff}@keyframes slideZoom{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.slide-info{padding:30px;display:flex;flex-direction:column;align-items:center;gap:20px}.slide-counter{background:#ffffff26;color:#fff;padding:14px 30px;border-radius:50px;font-size:18px;font-weight:400;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid rgba(255,255,255,.25);letter-spacing:2px;box-shadow:0 8px 25px #0003}.current-slide{font-weight:600;font-size:20px;color:#fffffff2}.slide-separator{margin:0 8px;opacity:.5}.total-slides{opacity:.7}.slide-dots{display:flex;gap:12px;align-items:center}.dot{width:8px;height:8px;border-radius:50%;background:#ffffff4d;border:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0}.dot:hover{background:#ffffff80;transform:scale(1.3)}.dot.active{width:28px;border-radius:4px;background:#fff;box-shadow:0 0 20px #fff9}.slide-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff26;color:#fff;border:2px solid rgba(255,255,255,.3);width:70px;height:70px;border-radius:50%;cursor:pointer;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #0003}.slide-nav:hover{background:#ffffff40;border-color:#ffffff80;transform:translateY(-50%) scale(1.15);box-shadow:0 6px 20px #0000004d}.slide-nav:active{transform:translateY(-50%) scale(.95)}.nav-arrow{font-size:48px;font-weight:300;line-height:1}.slide-nav.prev{left:30px}.slide-nav.next{right:30px}@media (max-width: 768px){.memories-grid{grid-template-columns:1fr;gap:20px}.section-title{font-size:32px}.gallery-header{flex-direction:column;align-items:stretch}.header-buttons{flex-direction:column}.add-memory-btn{width:100%;padding:10px 20px;font-size:14px}.floating-notes-container{bottom:20px;right:20px;gap:12px}.floating-note-icon{width:60px;height:60px}.floating-note-icon .note-emoji{font-size:30px}.note-popup{padding:30px;width:95%}.note-popup-icon{font-size:50px}.note-popup-text{font-size:16px}.form-row{flex-direction:column}.memory-card{padding:0}.memory-content{padding:25px}.memory-icon{font-size:40px}.memory-text{font-size:16px}.memory-image-container{height:250px}.slideshow-container{width:100%;height:100vh}.slide-image-wrapper{padding:20px}.slide-nav{width:50px;height:50px}.nav-arrow{font-size:36px}.slide-nav.prev{left:15px}.slide-nav.next{right:15px}.close-slideshow{width:45px;height:45px;top:20px;right:20px}.close-icon{font-size:24px}.slide-counter{font-size:14px;padding:10px 20px;letter-spacing:1px}.current-slide{font-size:18px}.slide-info{padding:20px;gap:15px}.slide-dots{gap:8px}.dot{width:6px;height:6px}.dot.active{width:18px}}.anniversary-container{min-height:100vh;position:relative;overflow-x:hidden;padding-bottom:50px}.logout-button{position:fixed;top:20px;right:20px;padding:12px 24px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.4);border-radius:25px;cursor:pointer;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;z-index:1000}.logout-button:hover{background:#ffffff4d;transform:translateY(-2px)}.content{max-width:1200px;margin:0 auto;padding:40px 20px;opacity:0;transform:translateY(30px);transition:all 1s ease}.content.show{opacity:1;transform:translateY(0)}.hero-section{text-align:center;margin-bottom:80px;padding:60px 20px;position:relative;z-index:1}.main-title{font-size:64px;color:#fff;margin-bottom:20px;text-shadow:3px 3px 6px rgba(0,0,0,.3);animation:fadeInScale 1.5s ease;font-weight:900}.anniversary-text{font-size:42px;color:#ffe0f0;margin-bottom:15px;text-shadow:2px 2px 4px rgba(0,0,0,.2);animation:fadeInScale 1.5s ease .3s backwards;font-weight:700}.tagline{font-size:20px;color:#ffffffe6;font-style:italic;animation:fadeInScale 1.5s ease .6s backwards}.footer-message{text-align:center;margin-top:80px;padding:40px 20px}.footer-message p{font-size:24px;color:#fff;margin:15px 0;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.signature{font-style:italic;font-size:28px!important;margin-top:20px!important}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.main-title{font-size:42px}.anniversary-text{font-size:32px}.tagline{font-size:16px}.logout-button{padding:10px 20px;font-size:14px}}.App{min-height:100vh}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh}.heart-loading{font-size:80px;animation:heartbeat 1s infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;overflow-x:hidden}#root{min-height:100vh}
