@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500;1,600&family=Inter:wght@300;400;500;600&family=Caveat:wght@400;500;600;700&display=swap";:root{--pink-100:#fff0f5;--pink-200:#ffd6e7;--pink-300:#ff9ec8;--pink-400:#ff69a5;--pink-500:#e91e8c;--pink-600:#b5006a;--rose:#ffc2d4;--gold:#ffd97d;--bg-dark:#180010;--bg-mid:#250018;--glass:#ffc8dc12;--glass-border:#ffb4d238;--font-display:"Playfair Display", Georgia, serif;--font-script:"Caveat", cursive;--font-body:"Inter", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{min-height:100vh;color:var(--pink-200);font-family:var(--font-body);background:radial-gradient(at 30% 0,#3a0028 0%,#180010 50%,#0d000a 100%);font-weight:300;overflow-x:hidden}.petal{pointer-events:none;z-index:0;opacity:.65;filter:drop-shadow(0 0 4px #ff96c866);animation:linear infinite petalFall;position:fixed;top:-60px}@keyframes petalFall{0%{opacity:0;transform:translateY(-60px)rotate(0)}10%{opacity:.7}90%{opacity:.5}to{opacity:0;transform:translateY(110vh)rotate(600deg)}}.app-wrapper{flex-direction:column;min-height:100vh;display:flex;position:relative}.scene-container{z-index:1;flex:1;justify-content:center;display:flex;position:relative;overflow:hidden}.fairy-lights-bar{z-index:100;pointer-events:none;justify-content:space-around;align-items:flex-start;width:100%;display:flex;position:fixed;top:0;left:0;overflow:hidden}.bulb-wrap{flex-direction:column;align-items:center;display:flex}.wire{background:#ffb6c14d;width:2px}.bulb{border-radius:50% 50% 60% 60%;width:11px;height:15px;animation:ease-in-out infinite alternate bulbFlicker}.bulb.pink{background:#ff85c0;box-shadow:0 0 10px 4px #ff64aacc}.bulb.gold{background:#ffd97d;box-shadow:0 0 10px 4px #ffc850b3}.bulb.white{background:#fff5f8;box-shadow:0 0 8px 3px #fff0f899}.bulb.rose{background:#ff6b9d;box-shadow:0 0 10px 4px #ff5a8cb3}@keyframes bulbFlicker{0%{opacity:1}40%{opacity:.55}60%{opacity:1}80%{opacity:.35}to{opacity:1}}.ribbon{background:linear-gradient(135deg, var(--pink-500), #c2185b);color:#fff;font-family:var(--font-body);letter-spacing:.14em;text-transform:uppercase;border-radius:30px;padding:.28rem 1rem;font-size:.68rem;font-weight:600;display:inline-block;box-shadow:0 2px 14px #e91e8c66}.btn-pink{background:linear-gradient(135deg, var(--pink-500) 0%, #c2185b 100%);color:#fff;font-family:var(--font-body);cursor:pointer;letter-spacing:.03em;border:none;border-radius:50px;padding:.8rem 2.2rem;font-size:1rem;font-weight:500;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 22px #e91e8c73}.btn-pink:hover{transform:translateY(-2px)scale(1.03);box-shadow:0 8px 30px #e91e8c99}.btn-pink:active{transform:scale(.97)}.btn-ghost{color:var(--pink-400);font-family:var(--font-body);cursor:pointer;background:0 0;border:1px solid #ff69a566;border-radius:30px;padding:.45rem 1.2rem;font-size:.88rem;transition:background .2s,border-color .2s}.btn-ghost:hover{border-color:var(--pink-400);background:#e91e8c1a}.welcome-screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:600px;min-height:100vh;margin:0 auto;padding:7rem 1.5rem 3rem;display:flex}.welcome-title{font-family:var(--font-display);color:var(--pink-200);text-shadow:0 0 50px #e91e8c59;margin:1rem 0 .5rem;font-size:clamp(3rem,10vw,5.5rem);font-style:italic;font-weight:300;line-height:1.1}.welcome-name{font-family:var(--font-script);color:var(--pink-300);text-shadow:0 0 30px #ff64aa80;margin-top:-.2rem;font-size:clamp(3rem,10vw,5rem);display:block}.welcome-subtitle{font-family:var(--font-display);color:var(--pink-400);opacity:.85;margin:1rem 0 1.8rem;font-size:1.15rem;font-style:italic}.welcome-card{background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);text-align:left;color:var(--pink-200);border-radius:20px;margin-bottom:2rem;padding:1.8rem 2rem;font-size:1.05rem;line-height:1.9}.welcome-card em{color:var(--pink-300);font-style:italic}.welcome-note{color:#ffb6c159;margin-top:2rem;font-size:.78rem;font-style:italic}.story-wrapper{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:6rem 1.5rem 2rem;display:flex;position:relative;overflow:hidden}.story-dots{z-index:50;gap:.5rem;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.dot{background:#ffb6c140;border-radius:50%;width:8px;height:8px;transition:background .3s,transform .3s}.dot.active{background:var(--pink-400);box-shadow:0 0 8px var(--pink-400);transform:scale(1.4)}.dot.done{background:#ff69a580}.story-card-container{width:100%;max-width:620px;position:relative}.story-card{-webkit-backdrop-filter:blur(18px);text-align:center;background:linear-gradient(145deg,#ffd2e61a 0%,#ffb4d70f 100%);border:1px solid #ffb4d238;border-radius:28px;padding:2.5rem 2.5rem 3rem;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000059,inset 0 0 0 1px #ffffff0a}.story-card:before{content:"";background:linear-gradient(90deg,#0000,#ffb6c180,#0000);height:1px;position:absolute;top:0;left:0;right:0}.card-enter-right{animation:.55s cubic-bezier(.22,1,.36,1) forwards enterFromRight}.card-enter-left{animation:.55s cubic-bezier(.22,1,.36,1) forwards enterFromLeft}.card-enter-up{animation:.55s cubic-bezier(.22,1,.36,1) forwards enterFromUp}.card-enter-down{animation:.55s cubic-bezier(.22,1,.36,1) forwards enterFromDown}.card-exit-left{animation:.35s ease-in forwards exitToLeft}.card-exit-right{animation:.35s ease-in forwards exitToRight}@keyframes enterFromRight{0%{opacity:0;transform:translate(80px)scale(.96)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes enterFromLeft{0%{opacity:0;transform:translate(-80px)scale(.96)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes enterFromUp{0%{opacity:0;transform:translateY(-60px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes enterFromDown{0%{opacity:0;transform:translateY(60px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes exitToLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-80px)}}@keyframes exitToRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(80px)}}.card-number{font-family:var(--font-body);letter-spacing:.16em;text-transform:uppercase;color:var(--pink-400);margin-bottom:1rem;font-size:.65rem;font-weight:600}.card-emoji{filter:drop-shadow(0 4px 12px #e91e8c4d);margin:0 auto .8rem;font-size:3.2rem;animation:3s ease-in-out infinite floatEmoji;display:block}@keyframes floatEmoji{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.card-title{font-family:var(--font-display);color:var(--pink-200);margin-bottom:1.2rem;font-size:clamp(1.8rem,5vw,2.6rem);font-style:italic;font-weight:400;line-height:1.15}.card-body{font-family:var(--font-display);color:#ffd6e7e6;text-align:left;font-size:1.1rem;font-weight:300;line-height:1.85}.card-body em{color:var(--pink-300);font-style:italic}.card-body strong{color:var(--pink-200);font-weight:600}.card-body .quote{border-left:2px solid var(--pink-500);color:var(--pink-300);margin:1rem 0;padding-left:1rem;font-size:1.05rem;font-style:italic;display:block}.card-actions{justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;display:flex}.card-nav-btn{color:var(--pink-300);font-family:var(--font-body);cursor:pointer;background:#ff69a51a;border:1px solid #ff69a54d;border-radius:30px;align-items:center;gap:.4rem;padding:.6rem 1.4rem;font-size:.9rem;transition:all .2s;display:flex}.card-nav-btn:hover{border-color:var(--pink-400);background:#ff69a533;transform:translateY(-1px)}.card-nav-btn.primary{background:linear-gradient(135deg, var(--pink-500), #c2185b);color:#fff;border-color:#0000;font-weight:500;box-shadow:0 4px 18px #e91e8c66}.card-nav-btn.primary:hover{background:linear-gradient(135deg,#f02595,#b5006a);box-shadow:0 6px 26px #e91e8c99}.card-count{font-family:var(--font-body);color:#ffb6c166;letter-spacing:.05em;font-size:.78rem}.swipe-hint{color:#ffb6c14d;font-size:.75rem;font-style:italic;font-family:var(--font-body);pointer-events:none;position:fixed;bottom:4.5rem;left:50%;transform:translate(-50%)}.unlock-screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100vh;padding:6rem 1.5rem 3rem;animation:.6s forwards fadeUp;display:flex}.unlock-screen .big-emoji{font-size:4rem;animation:.6s popIn}.unlock-title{font-family:var(--font-display);color:var(--pink-200);font-size:clamp(2rem,7vw,3.5rem);font-style:italic;font-weight:300}.unlock-sub{font-family:var(--font-display);color:var(--pink-400);font-size:1.1rem;font-style:italic}.letter-screen{flex-direction:column;align-items:center;width:100%;max-width:720px;margin:0 auto;padding:6rem 1.5rem 5rem;animation:.7s forwards fadeUp;display:flex}.letter-header-row{text-align:center;margin-bottom:1.8rem}.letter-paper{color:#2a0010;background:linear-gradient(160deg,#fff8f0 0%,#fff0f5 60%,#fdf0f8 100%);border-radius:4px;padding:3rem 3.5rem;position:relative;box-shadow:0 12px 50px #00000073,0 0 0 1px #ffb4d21a}.letter-paper:before{content:"";background:linear-gradient(90deg, transparent, var(--pink-400), var(--rose), var(--pink-400), transparent);height:3px;position:absolute;top:0;left:0;right:0}.letter-date{font-family:var(--font-body);color:#2a001061;text-align:right;margin-bottom:1rem;font-size:.78rem;font-style:italic}.letter-to{font-family:var(--font-script);color:#c2185b;margin-bottom:1.5rem;font-size:2rem}.letter-body p{font-family:var(--font-display);color:#2a0010;margin-bottom:1.3rem;font-size:1.08rem;line-height:2}.letter-body em{color:#a0003a;font-style:italic}.letter-body strong{color:#6b0030;font-weight:600}.letter-sign{font-family:var(--font-body);color:#2a001073;margin-top:2.5rem;font-size:.9rem;font-style:italic}.signature{font-family:var(--font-script);color:#c2185b;margin-top:.3rem;font-size:2.8rem;display:block}.letter-ps{font-family:var(--font-display);color:#2a001080;margin-top:1rem;font-size:.92rem;font-style:italic;line-height:1.8}.letter-seal{text-align:center;letter-spacing:.3rem;margin-top:1.8rem;font-size:1.4rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.4)}70%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--pink-500);border-radius:10px}.welcome-tab-screen{color:#2a0010;background:#fdfbf7;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.side-flower-left{pointer-events:none;opacity:.85;position:absolute;bottom:0;left:20px}.side-flower-right{pointer-events:none;opacity:.85;position:absolute;bottom:0;right:20px}.welcome-main-content{text-align:center;z-index:5;max-width:500px}.kitten-container{margin-bottom:1.5rem;display:inline-block;position:relative}.floating-heart{font-size:1.5rem;animation:2s ease-in-out infinite floatHeart;position:absolute;top:-15px;left:50%;transform:translate(-50%)}@keyframes floatHeart{0%,to{opacity:.8;transform:translate(-50%)scale(1)}50%{opacity:1;transform:translate(-50%,-15px)scale(1.2)}}.kitten-head{transform-origin:50% 55px;animation:2s ease-in-out infinite alternate bobHead}.kitten-head-elem{transform-origin:50px 45px;animation:2s ease-in-out infinite alternate bobHead}.kitten-tail{transform-origin:28px 75px;animation:1.5s ease-in-out infinite alternate wagTail}.kitten-paw-l{transform-origin:35px 74px;animation:.8s ease-in-out infinite alternate pawTapL}.kitten-paw-r{transform-origin:65px 74px;animation:.8s ease-in-out infinite alternate pawTapR}@keyframes bobHead{0%{transform:rotate(-5deg)}to{transform:rotate(5deg)}}@keyframes wagTail{0%{transform:rotate(-10deg)}to{transform:rotate(15deg)}}@keyframes pawTapL{0%{transform:translateY(0)}to{transform:translateY(-3px)}}@keyframes pawTapR{0%{transform:translateY(-3px)}to{transform:translateY(0)}}.welcome-greeting-title{font-family:var(--font-display);margin-bottom:.5rem;font-size:2.8rem;font-weight:400}.welcome-greeting-subtitle{font-family:var(--font-body);color:#c2185b;letter-spacing:.05em;margin-bottom:2rem;font-size:1rem}.greeting-buttons-container{justify-content:center;gap:1.2rem;min-height:50px;display:flex;position:relative}.story-journey-screen{color:#2a0010;background:#fcfaf6;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:6rem 1.5rem 4rem;display:flex}.story-journey-header{margin-bottom:2rem}.story-journey-main-title{font-family:var(--font-display);color:#8a0f25;font-size:1.8rem;font-style:italic;font-weight:500}.vintage-story-card{background:#fefdfb;border:3px solid #8a0f25;border-radius:12px;width:100%;max-width:600px;padding:2.5rem;box-shadow:0 10px 30px #8a0f2514}.vintage-story-card .card-title{color:#8a0f25;font-family:var(--font-display);margin-bottom:1.5rem;font-size:2.2rem;font-weight:400}.vintage-story-card .card-body{color:#2a0010;font-size:1.05rem;line-height:1.8}.vintage-story-card .card-body .quote{color:#c2185b;background:#fff0f3;border-left:3px solid #8a0f25;border-radius:4px;margin:1.2rem 0;padding:.8rem 1.2rem}.story-back-arrow{color:#c2185b;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;margin-top:1.5rem;font-size:.85rem;text-decoration:underline}.vintage-nav-bar{z-index:1000;background:#fff;border:2px solid #8a0f25;border-radius:50px;padding:.3rem;display:flex;position:fixed;top:1.5rem;left:50%;transform:translate(-50%);box-shadow:0 8px 25px #8a0f251f}.vintage-nav-tab{font-family:var(--font-body);color:#8a0f25;cursor:pointer;letter-spacing:.05em;text-transform:lowercase;background:0 0;border:none;border-radius:25px;padding:.5rem 1.2rem;font-size:.82rem;font-weight:500;transition:all .2s}.vintage-nav-tab:hover{background:#fff0f3}.vintage-nav-tab.active{color:#fff;background:#8a0f25}.btn-vintage{color:#8a0f25;font-family:var(--font-body);cursor:pointer;letter-spacing:.05em;background:#fff;border:2px solid #8a0f25;border-radius:4px;padding:.6rem 1.6rem;font-size:.85rem;font-weight:600;transition:all .2s}.btn-vintage:hover,.primary-vintage{color:#fff;background:#8a0f25}.primary-vintage:hover{background:#b51c37}.pictures-tab-screen{color:#2a0010;background:#fdfbf7;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:6.5rem 1.5rem 3rem;display:flex}.pictures-header{border-bottom:2px solid #8a0f2526;justify-content:space-between;align-items:center;width:100%;max-width:600px;margin-bottom:2rem;padding-bottom:1rem;display:flex}.header-number{font-family:var(--font-body);color:#8a0f25;opacity:.45;font-size:1.5rem;font-weight:600}.pictures-title{text-align:center;font-family:var(--font-display);font-size:1.8rem;font-weight:500;line-height:1.25}.devine-script{font-family:var(--font-script);color:#c2185b;font-size:2.5rem}.mine-bracket{color:#8a0f25;font-weight:600}.polaroid-container{flex-wrap:wrap;justify-content:center;align-items:center;gap:2rem;width:100%;max-width:900px;min-height:380px;margin-bottom:2.5rem;transition:all .3s ease-in-out;display:flex}.polaroid-card{width:240px;transform:rotate(var(--rotation));background:#fffdfa;border:1px solid #8a0f251a;padding:1.1rem 1.1rem 2.2rem;transition:all .4s cubic-bezier(.165,.84,.44,1);position:relative;box-shadow:0 10px 25px #8a0f2512}.polaroid-card:hover{z-index:10;transform:scale(1.06)rotate(0)translateY(-5px);box-shadow:0 20px 40px #8a0f2529}.polaroid-card:before{content:"";z-index:5;background-color:#f5e6c8a6;border-left:1px dashed #0000001a;border-right:1px dashed #0000001a;width:70px;height:22px;position:absolute;top:-12px;left:50%;transform:translate(-50%)rotate(-2deg);box-shadow:0 1px 3px #0000000d}.polaroid-img-wrapper{background:#eee;border-radius:2px;width:100%;height:200px;position:relative;overflow:hidden;box-shadow:inset 0 0 10px #0000001a}.polaroid-img{object-fit:cover;width:100%;height:100%}.polaroid-overlay{pointer-events:none;background:radial-gradient(circle,#0000 40%,#0000001a 100%);position:absolute;inset:0}.polaroid-label{font-family:var(--font-script);text-align:center;color:#c2185b;margin-top:1.2rem;font-size:1.6rem}.pictures-footer{justify-content:center;align-items:center;gap:2rem;margin-top:1rem;display:flex}.nav-arrow{font-family:var(--font-body);color:#8a0f25;cursor:pointer;background:0 0;border:none;font-size:.9rem}.nav-arrow:disabled{opacity:.3;cursor:not-allowed}.page-indicator{font-family:var(--font-body);color:#2a001080;font-size:.8rem}.gallery-creator{font-family:var(--font-body);color:#2a001059;letter-spacing:.05em;text-transform:uppercase;margin-top:2rem;font-size:.72rem}.flowers-tab-screen{color:#fdfbf7;background:#610013;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:6.5rem 1.5rem 3rem;display:flex;position:relative;overflow:hidden}.flowers-main-container{z-index:5;justify-content:center;align-items:center;gap:3.5rem;width:100%;max-width:1100px;display:flex}.gold-frame-outer{background:#110004;border:15px solid #d4af37;outline:4px solid #aa8a22;justify-content:center;align-items:center;width:320px;height:380px;padding:.5rem;display:flex;position:relative;box-shadow:0 25px 60px #000000a6,inset 0 0 15px #000c}.gold-frame-border{background:#2a0006;width:100%;height:100%;position:relative}.gold-corner{z-index:2;border:4px solid #f3e5ab;width:20px;height:20px;position:absolute}.top-left{border-bottom:none;border-right:none;top:-8px;left:-8px}.top-right{border-bottom:none;border-left:none;top:-8px;right:-8px}.bottom-left{border-top:none;border-right:none;bottom:-8px;left:-8px}.bottom-right{border-top:none;border-left:none;bottom:-8px;right:-8px}.gold-canvas{background:radial-gradient(circle,#38000b 0%,#150004 100%);border:2px solid #5a0211;justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.canvas-bouquet{width:85%;height:85%}.book-spread-container{background:#fefdfb;border:12px solid #3c000c;border-radius:4px;outline:2px solid #8a0f25;width:600px;height:430px;display:flex;box-shadow:0 20px 50px #00000080}.book-page{color:#2a0010;flex-direction:column;flex:1;padding:2rem;display:flex}.left-page{background:linear-gradient(90deg,#fffdfb 94%,#f4eae1 100%);border-right:1px solid #8a0f2526}.right-page{background:linear-gradient(270deg,#fffdfb 94%,#f4eae1 100%)}.page-header{font-family:var(--font-body);letter-spacing:.12em;text-transform:uppercase;color:#c2185b;margin-bottom:1.5rem;font-size:.68rem;font-weight:600}.tictactoe-grid{flex:1;grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr);gap:.4rem;margin-bottom:1rem;display:grid}.ttt-cell{font-family:var(--font-display);border:1.5px solid #8a0f252e;flex-direction:column;justify-content:center;align-items:center;padding:.2rem;font-size:.95rem;font-weight:500;display:flex}.ttt-cell.special-text{text-align:center;color:#8a0f25;background:#fff0f3;font-size:.65rem;font-weight:600;line-height:1.2}.heart-cell{background:#fff0f3}.heart-icon{font-size:1.1rem}.cell-sub{color:#8a0f25b3;font-size:.58rem;font-family:var(--font-body)}.page-date{font-family:var(--font-script);text-align:right;color:#c2185b;font-size:1.2rem}.book-title{font-family:var(--font-display);color:#8a0f25;letter-spacing:.02em;margin-bottom:1rem;font-size:1.4rem;font-weight:500}.map-circle-container{justify-content:center;margin-bottom:1rem;display:flex}.map-radar{background:#fffafb;border:1.5px solid #8a0f2540;border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;display:flex;position:relative;overflow:hidden}.radar-grid{background-image:radial-gradient(circle,#0000 20%,#8a0f250f 21%,#0000 22%),radial-gradient(circle,#0000 50%,#8a0f250f 51%,#0000 52%);width:100%;height:100%;position:absolute}.radar-pulse{background:conic-gradient(#8a0f251a 0deg,#0000 90deg);width:100%;height:100%;animation:3s linear infinite radarRotate;position:absolute}@keyframes radarRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.radar-pin{z-index:2;font-size:1.1rem;animation:1.5s ease-in-out infinite alternate bouncePin}@keyframes bouncePin{0%{transform:translateY(0)}to{transform:translateY(-5px)}}.radar-label{font-size:.52rem;font-family:var(--font-body);color:#8a0f25;background:#8a0f2514;border-radius:4px;padding:1px 4px;position:absolute;bottom:4px}.book-story-text{font-family:var(--font-display);color:#2a0010d9;font-size:.8rem;line-height:1.6}.clouds-container{pointer-events:none;width:100%;height:80px;position:absolute;bottom:0;left:0}.cloud{filter:blur(10px);background:#ffffff26;border-radius:50px;position:absolute}.cloud-1{width:200px;height:40px;animation:45s linear infinite driftRight;bottom:20px;left:10%}.cloud-2{width:300px;height:50px;animation:50s linear infinite driftLeft;bottom:10px;right:15%}.cloud-3{width:150px;height:35px;animation:38s linear infinite driftRight;bottom:30px;left:60%}@keyframes driftRight{0%{transform:translate(-150px)}to{transform:translate(100vw)}}@keyframes driftLeft{0%{transform:translate(150px)}to{transform:translate(-100vw)}}.song-tab-screen{color:#2a0010;background:#fcf9f2;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:6.5rem 1.5rem 3rem;display:flex}.song-header{border-bottom:2px solid #8a0f2526;justify-content:space-between;align-items:center;width:100%;max-width:600px;margin-bottom:1.5rem;padding-bottom:.6rem;display:flex}.song-sub{font-family:var(--font-body);letter-spacing:.12em;text-transform:uppercase;color:#c2185b;font-size:.75rem}.song-main-title{font-family:var(--font-display);font-size:1.3rem;font-weight:500}.calligraphy-container{text-align:center;margin-bottom:2rem}.ribbon-bow-wrapper{justify-content:center;margin-bottom:.5rem;display:flex}.ribbon-bow-svg{width:90px;height:35px}.calligraphy-text{font-family:var(--font-script);color:#8a0f25;font-size:3.2rem;line-height:1}.vinyls-container{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:2.5rem;width:100%;max-width:900px;margin-bottom:2rem;display:flex}.vinyl-player-card{cursor:pointer;background:#fff;border:1px solid #0000000d;border-radius:8px;width:250px;padding:1.2rem;transition:transform .2s;position:relative;box-shadow:0 10px 25px #0000000d}.vinyl-player-card:hover{transform:translateY(-4px)}.album-sleeve{border-radius:4px;width:100%;height:180px;position:relative;overflow:hidden}.sleeve-art{width:100%;height:100%}.sleeve-hole{background:#fff;border:1px solid #0000000d;border-radius:50%;width:45px;height:45px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.vinyl-disk-wrapper{z-index:1;pointer-events:none;width:216px;height:180px;position:absolute;top:1.2rem;left:1.2rem;overflow:hidden}.vinyl-disk{background:repeating-radial-gradient(circle,#242424,#121212 3px,#242424 6px);border-radius:50%;width:180px;height:180px;transition:transform .4s ease-out;position:absolute;top:0;right:-90px;box-shadow:0 4px 15px #00000059}.vinyl-grooves{background:radial-gradient(circle,#0000 35%,#ffffff0d 36%,#0000 40%);border-radius:50%;width:100%;height:100%;position:absolute}.vinyl-label{border-radius:50%;width:55px;height:55px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.vinyl-label-center{background:#fff;border-radius:50%;width:14px;height:14px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.vinyl-player-card.is-playing .vinyl-disk{animation:4s linear .4s infinite spinRecord;transform:translate(-35px)}@keyframes spinRecord{0%{transform:translate(-35px)rotate(0)}to{transform:translate(-35px)rotate(360deg)}}.tonearm-container{transform-origin:10px 5px;z-index:2;pointer-events:none;width:40px;height:110px;transition:transform .4s ease-in-out;position:absolute;top:8px;right:12px;transform:rotate(-30deg)}.tonearm-svg{width:100%;height:100%}.vinyl-player-card.is-playing .tonearm-container{transform:rotate(-5deg)}.song-info{text-align:center;margin-top:1.2rem}.song-title{font-family:var(--font-display);color:#8a0f25;font-size:1.1rem;font-weight:600}.song-artist{font-family:var(--font-body);color:#2a0010a6;margin-top:.2rem;font-size:.75rem}.song-quote{font-family:var(--font-script);color:#c2185b;margin-top:.6rem;font-size:1.1rem}.lyrics-player-viewport{text-align:center;background:#fff;border:2px dashed #8a0f254d;border-radius:8px;justify-content:center;align-items:center;width:100%;max-width:600px;min-height:180px;padding:1.5rem 2rem;display:flex}.lyrics-placeholder{font-family:var(--font-display);color:#2a001073;font-size:.95rem;font-style:italic}.lyrics-now-playing{font-family:var(--font-body);text-transform:uppercase;color:#c2185b;letter-spacing:.05em;margin-bottom:1rem;font-size:.72rem}.lyrics-lines{flex-direction:column;gap:.55rem;display:flex}.lyric-line{font-family:var(--font-display);color:#2a0010;opacity:0;font-size:1.05rem;animation:.8s forwards lyricFadeIn}@keyframes lyricFadeIn{to{opacity:1}}.fade-out-photos{opacity:0;transform:scale(.95)}.fade-in-photos{opacity:1;transform:scale(1)}.animate-left{animation:.6s cubic-bezier(.22,1,.36,1) forwards enterFromLeft}.animate-right{animation:.6s cubic-bezier(.22,1,.36,1) forwards enterFromRight}.animate-up{animation:.6s cubic-bezier(.22,1,.36,1) forwards enterFromUp}.animate-down{animation:.6s cubic-bezier(.22,1,.36,1) forwards enterFromDown}@media (width<=900px){.flowers-main-container{flex-direction:column;gap:2rem}}@media (width<=600px){.welcome-tab-screen{padding-bottom:120px}.side-flower-left,.side-flower-right{display:none}.book-spread-container{flex-direction:column;width:320px;height:auto}.left-page{border-bottom:1px solid #8a0f2526;border-right:none}.vintage-nav-bar{justify-content:flex-start;width:90%;padding:.2rem .5rem;overflow-x:auto}.vintage-nav-tab{white-space:nowrap;padding:.4rem .8rem;font-size:.75rem}}.envelope-container{perspective:1200px;justify-content:center;align-items:center;width:100%;margin:2rem 0;display:flex}.envelope-wrapper{cursor:pointer;background-color:#0000;width:420px;height:280px;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);position:relative}.envelope-wrapper:hover{transform:translateY(-8px)rotateX(5deg)}.envelope{width:100%;height:100%;transform-style:preserve-3d;background-color:#f6ebd8;border-radius:8px;transition:all .5s;position:relative;box-shadow:0 8px 25px #00000040,0 20px 45px #8a0f2526}.envelope-back{z-index:1;background:#ecdcb9;border-radius:8px;position:absolute;inset:0;overflow:hidden}.envelope-paper-preview{z-index:2;box-sizing:border-box;background:linear-gradient(#fff 0%,#fffbf2 100%);border-radius:4px;height:200px;padding:1.5rem;transition:transform .7s cubic-bezier(.25,1,.5,1) .3s;position:absolute;top:15px;left:20px;right:20px;transform:translateY(0);box-shadow:0 2px 10px #0000001a}.envelope-paper-preview:before{content:"";background:#8a0f2526;border-radius:3px;height:6px;position:absolute;top:15px;left:15px;right:15px}.envelope-paper-preview:after{content:"";background:#8a0f2514;border-radius:3px;height:6px;position:absolute;top:30px;left:15px;right:40px}.envelope-container.is-opening .envelope-paper-preview{transform:translateY(-130px)scale(.98)}.envelope-flap{clip-path:polygon(0 0,50% 100%,100% 0);transform-origin:top;z-index:5;background:#ecdcb9;width:100%;height:50%;transition:transform .5s,z-index 0s .25s;position:absolute;top:0;left:0}.envelope-container.is-opening .envelope-flap{z-index:1;transform:rotateX(180deg)}.envelope-pockets{z-index:3;pointer-events:none;position:absolute;inset:0}.envelope-pockets:before{content:"";clip-path:polygon(0 100%,50% 0,100% 100%);background:#f6ebd8;border-bottom-right-radius:8px;border-bottom-left-radius:8px;height:60%;position:absolute;bottom:0;left:0;right:0}.envelope-pockets:after{content:"";clip-path:polygon(0 0,100% 50%,0 100%);background:#ebdcb9;border-top-left-radius:8px;border-bottom-left-radius:8px;width:50%;position:absolute;top:0;bottom:0;left:0}.envelope-right-pocket{clip-path:polygon(100% 0,0 50%,100% 100%);z-index:3;pointer-events:none;background:#ebdcb9;border-top-right-radius:8px;border-bottom-right-radius:8px;width:50%;position:absolute;top:0;bottom:0;right:0}.wax-seal-btn{z-index:6;cursor:pointer;width:80px;height:80px;transition:all .3s cubic-bezier(.175,.885,.32,1.275);position:absolute;top:50%;left:50%;transform:translate(-50%,-20%)scale(1)}.wax-seal-btn:hover{filter:drop-shadow(0 0 10px #8a0f25b3);transform:translate(-50%,-20%)scale(1.15)}.wax-seal-btn:active{transform:translate(-50%,-20%)scale(.95)}.envelope-container.is-opening .wax-seal-btn{opacity:0;pointer-events:none;transform:translate(-50%,-20%)scale(.5)}.letter-paper.crumpled{background:#faf6eb url(/crumpled-paper.png) 50%/cover no-repeat;border:1px solid #8a0f2514;transition:all .5s;position:relative;box-shadow:0 15px 35px #00000040,inset 0 0 40px #0000000d}.letter-prompt-text{font-family:var(--font-display);color:var(--pink-300);margin-top:.5rem;font-size:1rem;font-style:italic;animation:2s ease-in-out infinite pulseOpacity}@keyframes pulseOpacity{0%,to{opacity:.6}50%{opacity:1}}@keyframes floatUp{0%{opacity:0;transform:translate(-50%,-50%)scale(0)translateY(0)}15%{opacity:1;transform:translate(-50%,-50%)scale(1.2)translateY(-10px)}to{opacity:0;transform:translate(-50%,-50%)scale(.4)translateY(-100px)rotate(45deg)}}.sparkle-particle{pointer-events:none;z-index:100;animation:1.2s cubic-bezier(.16,1,.3,1) forwards floatUp;position:absolute}.fold-back-btn{color:#8a0f25;font-family:var(--font-body);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#8a0f2514;border:1px solid #8a0f2533;border-radius:20px;margin-bottom:2rem;padding:.5rem 1rem;font-size:.8rem;transition:all .3s}.fold-back-btn:hover{background:#8a0f2526;border-color:#8a0f25;transform:translateY(-2px)}.no-option-screen{color:#2a0010;text-align:center;background:#fdfbf7;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:6.5rem 1.5rem 3rem;display:flex;position:relative;overflow:hidden}.no-option-content{z-index:5;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:500px;animation:.6s forwards fadeUp;display:flex}.kitty-holder{margin-bottom:.5rem;display:inline-block;position:relative}.crying-kitty{animation:4s ease-in-out infinite sadShake}@keyframes sadShake{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-3px)rotate(-1deg)}75%{transform:translateY(1px)rotate(1deg)}}.tear-drop{transform-origin:50%;animation:1.8s ease-in infinite tearFall}@keyframes tearFall{0%{opacity:0;transform:translateY(0)scale(.5)}20%{opacity:1;transform:translateY(0)scale(1)}80%{opacity:.8;transform:translateY(18px)scale(.8)}to{opacity:0;transform:translateY(24px)scale(.3)}}.no-option-title{font-family:var(--font-display);color:#8a0f25;margin:0;font-size:clamp(2rem,6vw,3rem)}.no-option-text{font-family:var(--font-display);color:#2a0010;opacity:.9;margin:0;font-size:1.1rem;line-height:1.8}.btn-gallery-nav{color:#8a0f25;font-family:var(--font-body);cursor:pointer;background:#fff;border:2px solid #8a0f25;border-radius:30px;align-items:center;gap:.6rem;padding:.6rem 1.4rem;font-size:.85rem;font-weight:600;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;box-shadow:0 4px 10px #8a0f250d}.btn-gallery-nav:hover:not(:disabled){color:#fff;background:#8a0f25;transform:translateY(-2px);box-shadow:0 8px 20px #8a0f2526}.btn-gallery-nav:disabled{opacity:.35;cursor:not-allowed;color:#d1b8bc;border-color:#d1b8bc}.canvas-bouquet-img{object-fit:contain;filter:drop-shadow(0 12px 24px #0006);z-index:2;width:90%;height:90%;animation:5s ease-in-out infinite floatBouquet}@keyframes floatBouquet{0%,to{transform:translateY(0)rotate(0)scale(1)}50%{transform:translateY(-6px)rotate(1.5deg)scale(1.02)}}
