*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--deep-red: #8B0000;--soft-red: #C41E3A;--gold: #B8860B;--gold-light: #D4A853;--white: #FFFFFF;--off-white: #FAFAF8;--text-dark: #2A2A2A;--text-medium: #555;--text-light: #888;--border: #E8E4E0;--serif: "Cormorant Garamond", "Playfair Display", Georgia, serif;--display: "Cinzel", "Cormorant Garamond", Georgia, serif;--script: "Pinyon Script", "Great Vibes", "Dancing Script", cursive;--body: "Lora", Georgia, serif;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quint: cubic-bezier(.22, 1, .36, 1)}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;background:#f5f0e8}body{font-family:var(--body);color:var(--text-dark);-webkit-font-smoothing:antialiased}#root{width:100%;height:100%;position:relative}#scroller{position:fixed;inset:0;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;scroll-behavior:auto;background:var(--white);z-index:1}.card-wrapper{position:fixed;inset:0;z-index:9999;cursor:pointer;overflow:hidden}.card-wrapper.hidden{pointer-events:none;visibility:hidden}.card-bg{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.card-bg-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0000004d}.card-door{position:absolute;top:0;bottom:0;width:50%;background:#f5f0e8 url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");transition:transform 2.2s var(--ease-out-expo);display:flex;align-items:center;overflow:hidden;box-shadow:0 0 40px #00000026;z-index:2}.card-door-left{left:0;justify-content:flex-end;border-right:1px solid #e8e0d4}.card-door-right{right:0;justify-content:flex-start;border-left:1px solid #e8e0d4}.card-wrapper.opening .card-door-left{transform:translate(-100%)}.card-wrapper.opening .card-door-right{transform:translate(100%)}.card-door-inner{padding:1.5rem;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem}.card-door-line{width:1px;height:50px;background:#c4b5a4}.card-door-script{font-family:var(--script);font-size:clamp(1.8rem,6vw,2.5rem);color:var(--deep-red);line-height:.9;text-align:center}.card-door-script span{font-size:.5em;display:block;margin:.15em 0}.card-door-names{display:flex;flex-direction:column;align-items:center;gap:.1rem}.card-door-name{font-family:var(--script);font-size:clamp(1.3rem,4.5vw,1.8rem);color:var(--text-dark);line-height:1.2}.card-door-heart{width:1rem;height:1rem;color:var(--deep-red);margin:.2rem 0}.card-door-date{font-family:var(--display);font-size:clamp(.55rem,1.8vw,.7rem);letter-spacing:3px;color:var(--text-medium)}.card-seal-wrap{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;transition:all 1s var(--ease-out-expo)}.card-wrapper.opening .card-seal-wrap{opacity:0;transform:translate(-50%,-50%) scale(.5)}.card-seal{width:56px;height:56px;background:var(--deep-red);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 15px #0003}.card-seal-heart{width:22px;height:22px;color:#fff}.card-tap-hint{position:absolute;bottom:calc(3.5vh + env(safe-area-inset-bottom,0px));left:0;width:100%;text-align:center;font-family:Lora,Georgia,serif;font-size:.8rem;font-style:italic;color:var(--text-dark);letter-spacing:.5px;z-index:4;animation:pulse-tap 2.5s ease-in-out infinite}@keyframes pulse-tap{0%,to{opacity:.3}50%{opacity:1}}.hero{position:relative;width:100%;height:100vh;height:var(--real-vh, 100vh);height:100dvh;overflow:hidden;background:#2a1a1a}.hero-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.15);filter:blur(8px);transition:transform 2s var(--ease-out-expo),filter 1.5s ease-out}.hero-img.hero-img-active{transform:scale(1);filter:blur(0);animation:ken-burns 25s ease-out forwards;animation-delay:1.5s}@keyframes ken-burns{0%{transform:scale(1)}to{transform:scale(1.05)}}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,#0000,#00000014 30%,#00000073 75%,#000000a6);display:flex;align-items:flex-end;justify-content:center;padding-bottom:calc(10vh + env(safe-area-inset-bottom,0px))}.hero-content{text-align:center;color:#fff}.hero-label-top{font-family:var(--display);font-size:clamp(.75rem,2.5vw,1rem);letter-spacing:6px;text-transform:uppercase;opacity:0;transform:translateY(12px);transition:all 1.4s var(--ease-out-expo) .1s;margin-bottom:.6rem;color:#ffffffd9}.hero-names{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;opacity:0;transform:translateY(18px);transition:all 1.4s var(--ease-out-expo) .3s}.hero-name{font-family:var(--script);font-size:clamp(2.4rem,9vw,4rem);font-weight:400;letter-spacing:1px;line-height:1.15;text-shadow:0 2px 30px rgba(0,0,0,.4)}.hero-amp{font-family:var(--display);font-size:clamp(.6rem,1.8vw,.8rem);letter-spacing:6px;text-transform:uppercase;opacity:.5;margin:.15rem 0}.hero-date{font-family:var(--display);font-size:clamp(.7rem,2.5vw,1rem);font-weight:400;letter-spacing:6px;margin-top:1.2rem;opacity:0;transform:translateY(14px);transition:all 1.4s var(--ease-out-expo) .55s;color:#fffc}.hero-overlay.hero-active .hero-label-top,.hero-overlay.hero-active .hero-names,.hero-overlay.hero-active .hero-date,.hero-label-top.animate-in,.hero-names.animate-in,.hero-date.animate-in{opacity:1;transform:translateY(0)}.ornament{display:flex;justify-content:center;padding:.4rem 0;color:var(--gold-light)}.ornament svg{width:120px;height:12px}.invitation-formal{text-align:center;padding:2.5rem 1.5rem;background:var(--white)}.invite-label{font-family:var(--script);font-size:clamp(1.1rem,3.5vw,1.5rem);color:var(--text-medium);margin:.8rem 0 .2rem}.invite-title{font-family:var(--script);font-size:clamp(2.2rem,7vw,3.2rem);color:var(--deep-red);font-weight:400;margin-bottom:.8rem}.invite-body{font-family:var(--body);font-size:.85rem;line-height:2;color:var(--text-medium);margin-bottom:.8rem}.couple-section{background:var(--white);padding:0 0 1.5rem}.couple-photo{width:100%;overflow:hidden}.couple-photo img{width:100%;display:block;object-fit:cover;max-height:55vh}.couple-names{display:flex;padding:1.5rem 1rem 0;gap:.4rem;align-items:flex-start}.family-col{flex:1;display:flex;flex-direction:column;text-align:center;gap:.25rem}.family-label{font-family:var(--serif);font-size:.75rem;letter-spacing:3px;text-transform:uppercase;color:var(--text-light);padding-bottom:.5rem;border-bottom:1px solid var(--border);margin-bottom:.4rem}.parent-name{font-family:var(--body);font-size:.72rem;line-height:1.6;color:var(--text-medium)}.child-name{font-family:var(--script);font-size:clamp(1.2rem,4vw,1.6rem);color:var(--deep-red);margin-top:.4rem}.couple-heart{display:flex;align-items:center;padding-top:2.5rem;font-size:1rem;color:var(--soft-red)}.event-section{background:var(--off-white);text-align:center;padding:2rem 1.5rem;position:relative}.event-card{max-width:380px;margin:0 auto}.event-type{font-family:var(--display);font-size:clamp(.8rem,2.8vw,1rem);letter-spacing:3px;text-transform:uppercase;color:var(--text-dark);margin-bottom:.2rem}.event-time{font-family:var(--display);font-size:clamp(.8rem,2.8vw,1rem);letter-spacing:3px;text-transform:uppercase;color:var(--text-dark);margin-bottom:1.2rem}.event-date-big{font-family:var(--display);font-size:clamp(2.8rem,10vw,4rem);font-weight:600;color:var(--deep-red);line-height:1;margin-bottom:.8rem}.event-lunar{font-family:var(--body);font-size:clamp(.85rem,2.8vw,1rem);font-style:italic;color:var(--text-medium);margin-bottom:1.5rem}.event-at{font-family:var(--serif);font-size:.85rem;letter-spacing:4px;color:var(--text-medium);margin-bottom:.3rem}.event-venue{font-family:var(--serif);font-size:clamp(1.1rem,4vw,1.4rem);font-weight:700;letter-spacing:2px;color:var(--text-dark);margin-bottom:.5rem}.event-address{font-family:var(--body);font-size:.85rem;line-height:1.8;color:var(--text-medium);margin-bottom:1.5rem}.event-directions{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.8rem;border:1.5px solid var(--text-dark);border-radius:50px;color:var(--text-dark);text-decoration:none;font-family:var(--serif);font-size:.85rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;transition:background .3s ease,color .3s ease,transform .3s ease;animation:btn-pulse 2s ease-in-out infinite}@keyframes btn-pulse{0%,to{box-shadow:0 0 #c41e3a66}50%{box-shadow:0 0 0 10px #c41e3a00}}.event-directions:hover{background:var(--deep-red);border-color:var(--deep-red);color:#fff;animation:none}.event-directions svg{width:18px;height:18px}.date-section{background:var(--off-white);text-align:center;padding:2rem 1.5rem 3rem}.calendar-mini{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:1.2rem;max-width:320px;margin:0 auto}.cal-month{font-family:var(--serif);font-size:.9rem;letter-spacing:2px;text-align:center;margin-bottom:.8rem;color:var(--text-dark)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;text-align:center;font-family:var(--serif);font-size:.78rem}.cal-h{font-size:.65rem;font-weight:600;color:var(--text-light);padding:5px 0}.cal-d{padding:6px 0;border-radius:50%;color:var(--text-medium);transition:all .3s ease}.cal-d.active{background:var(--deep-red);color:#fff;font-weight:600;box-shadow:0 2px 8px #8b00004d}.countdown-section{background:var(--deep-red);text-align:center;padding:2.5rem 1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center}.countdown-label{font-family:var(--body);font-size:clamp(.85rem,2.5vw,1rem);font-style:italic;color:#fffc;margin-bottom:1.5rem}.countdown{display:flex;justify-content:center;align-items:center;gap:.3rem;width:100%;text-align:center}.cd-item{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:58px}.cd-num{font-family:var(--display);font-size:2rem;font-weight:600;color:#fff;line-height:1}.cd-lbl{font-family:var(--body);font-size:.6rem;letter-spacing:1.5px;color:#ffffffb3;margin-top:4px;text-transform:lowercase}.cd-sep{font-family:var(--serif);font-size:1.5rem;color:#fff6;padding:0 .1rem;margin-bottom:1rem}.text-divider{display:flex;align-items:center;justify-content:center;gap:.6em;padding:1.2rem 2rem;font-family:var(--serif);font-size:1.1rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-dark);border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--white)}.story-section{text-align:center;padding:2rem 1.5rem;background:var(--white)}.story-poem{font-family:var(--body);font-size:.88rem;line-height:2.2;color:var(--text-dark);font-style:italic;margin-bottom:1.5rem}.story-note{font-family:var(--body);font-size:.85rem;line-height:2;color:var(--text-medium);margin-bottom:1.5rem}.story-cta{font-family:var(--script);font-size:clamp(1.1rem,3.5vw,1.4rem);color:var(--deep-red)}.photo-feature{background:var(--white)}.photo-frame-elegant{position:relative;overflow:hidden;border-radius:2px;box-shadow:0 8px 40px #00000014}.photo-frame-elegant img{width:100%;display:block}.frame-caption{position:absolute;bottom:1rem;right:1.2rem;font-family:var(--script);font-size:clamp(1.5rem,5vw,2.2rem);color:#ffffffe6;text-shadow:0 2px 12px rgba(0,0,0,.3)}.poem-block{text-align:center;padding:2rem 1.5rem;background:var(--off-white)}.poem-block p{font-family:var(--body);font-size:.88rem;line-height:2.2;color:var(--text-dark);font-style:italic}.photo-duo{display:grid;grid-template-columns:1fr 1fr;overflow:hidden}.photo-duo>div{overflow:hidden}.photo-duo img{width:100%;height:300px;object-fit:cover}.dearest-section{position:relative;width:100%;min-height:400px;max-height:65vh;overflow:hidden}.dearest-section>div:first-child{width:100%;height:100%;position:absolute;top:0;left:0}.dearest-img{width:100%;display:block;min-height:400px;max-height:65vh;object-fit:cover}.dearest-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(transparent 40%,#00000080);display:flex;align-items:flex-end;justify-content:center;padding-bottom:2rem}.dearest-text{font-family:var(--script);font-size:clamp(2rem,7vw,3.5rem);color:#fff;text-align:center;line-height:1.3;text-shadow:0 3px 20px rgba(0,0,0,.3)}.quote-block{text-align:center;padding:2rem;background:var(--white)}.quote-block blockquote{font-family:var(--body);font-size:.9rem;line-height:2.2;color:var(--text-dark);font-style:italic;border:none;margin:0;padding:0}.forever-block{padding:1.5rem 1rem;background:var(--off-white)}.forever-wrap{display:flex;gap:1rem;align-items:center}.forever-wrap img{flex:1;min-width:0;height:380px;object-fit:cover;border-radius:2px}.forever-text{writing-mode:vertical-rl;display:flex;flex-direction:column;align-items:center;gap:.3rem;font-family:var(--serif);font-size:1rem;letter-spacing:6px;text-transform:uppercase;color:var(--text-dark);line-height:2}.gallery-section{padding:1.5rem 0;background:var(--white)}.section-heading{font-family:var(--serif);font-size:1.1rem;font-weight:400;letter-spacing:2px;text-transform:uppercase;text-align:center;color:var(--text-dark);margin-bottom:1.5rem;padding:0 1rem}.album-row{display:flex;gap:4px;margin-bottom:4px}.album-row>div{flex:1;min-width:0;overflow:hidden}.album-row img{object-fit:cover;display:block;width:100%;height:100%}.album-row.full>div{width:100%}.album-row.full img{height:280px}.album-row.duo img{height:250px}.album-row.featured>div:first-child{flex:1.5}.album-row.featured>div:last-child{flex:1}.album-row.featured img{height:320px}.album-row.featured-reverse>div:first-child{flex:1}.album-row.featured-reverse>div:last-child{flex:1.5}.album-row.featured-reverse img{height:320px}.sunshine-section{position:relative;width:100%;height:65vh;min-height:400px;overflow:hidden}.sunshine-section>div:first-child{width:100%;height:100%;position:absolute;top:0;left:0}.sunshine-section img{width:100%;height:100%;object-fit:cover}.sunshine-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(#00000026,#0006);display:flex;align-items:center;justify-content:center}.sunshine-text{font-family:var(--body);font-size:clamp(1.2rem,4vw,1.8rem);color:#fff;text-align:center;line-height:1.8;font-style:italic;letter-spacing:.5px;text-shadow:1px 2px 15px rgba(0,0,0,.4);padding:0 2rem}.gift-section{text-align:center;padding:3rem 1.5rem;background:var(--off-white)}.gift-title{font-family:var(--body);font-size:1.4rem;letter-spacing:.15em;color:var(--text-dark);margin-bottom:.3rem;text-transform:uppercase}.gift-subtitle{font-family:var(--body);font-style:italic;font-size:.95rem;color:var(--text-medium);margin-bottom:1.5rem}.gift-qr-wrap{display:inline-block;background:#fff;border-radius:16px;padding:1rem;box-shadow:0 4px 24px #00000014;margin-bottom:1.2rem}.gift-qr{width:200px;height:200px;display:block}.gift-info{margin-bottom:1.2rem}.gift-bank{font-family:var(--display);font-size:.85rem;letter-spacing:.15em;color:var(--soft-red);font-weight:600;margin-bottom:.15rem}.gift-account{font-family:var(--display);font-size:1.3rem;letter-spacing:.1em;color:var(--text-dark);font-weight:600;margin-bottom:.15rem}.gift-name{font-family:var(--body);font-size:.9rem;color:var(--text-medium);letter-spacing:.05em}.gift-note{font-family:var(--body);font-style:italic;font-size:.85rem;line-height:1.7;color:var(--text-light);max-width:320px;margin:0 auto}.final-footer{text-align:center;padding:2rem 1rem calc(1.5rem + env(safe-area-inset-bottom,0px));background:var(--off-white)}.footer-names{font-family:var(--script);font-size:clamp(1.8rem,6vw,2.5rem);color:var(--text-dark)}.footer-names .heart{display:inline-block;vertical-align:middle;margin:0 .3rem;animation:heartbeat 2s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.25)}28%{transform:scale(1)}42%{transform:scale(1.18)}56%{transform:scale(1)}}.footer-date{font-size:.9rem;letter-spacing:6px;color:var(--text-medium);margin-top:.3rem}.footer-thanks{font-family:var(--body);font-size:.7rem;color:var(--text-light);margin-top:1.5rem;font-style:italic}.heart-pulse{animation:heart-pulse 1.5s ease-in-out infinite}@keyframes heart-pulse{0%,to{transform:scale(1)}15%{transform:scale(1.25)}30%{transform:scale(1)}45%{transform:scale(1.15)}60%{transform:scale(1)}}.animate-scale{animation:scale-in .8s var(--ease-out-expo) forwards}@keyframes scale-in{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.photo-duo img,.album-row img{cursor:pointer;transition:transform .4s var(--ease-out-expo)}.photo-duo img:hover,.album-row img:hover{transform:scale(1.03)}.section-heading-wrap{padding:0 1rem}.invite-title,.event-date-big{background:linear-gradient(105deg,var(--deep-red) 0%,var(--deep-red) 40%,#d4a853 50%,var(--deep-red) 60%,var(--deep-red) 100%);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{background-position:100% 0}50%{background-position:-100% 0}}.event-section:before,.event-section:after{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:var(--gold-light);opacity:.3;animation:float-particle 4s ease-in-out infinite}.event-section:before{top:15%;left:12%;animation-delay:0s}.event-section:after{bottom:18%;right:10%;animation-delay:2s;width:4px;height:4px}@keyframes float-particle{0%,to{transform:translateY(0) scale(1);opacity:.2}50%{transform:translateY(-12px) scale(1.3);opacity:.5}}.music-btn{position:fixed;bottom:calc(1.5rem + env(safe-area-inset-bottom,0px));right:1.5rem;width:46px;height:46px;border-radius:50%;background:#8b0000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:1.5px solid rgba(255,255,255,.2);cursor:pointer;z-index:200;font-size:1.2rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0003;transition:transform .3s var(--ease-out-expo),box-shadow .3s ease}.music-btn:hover{transform:scale(1.1)}.music-btn.playing{animation:spin-disc 4s linear infinite;box-shadow:0 4px 20px #8b000066,0 0 #8b00004d}@keyframes spin-disc{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(min-width:768px){html{background:#e8e0d4}body{background:transparent}#scroller{left:50%;right:auto;transform:translate(-50%);width:480px;max-width:100vw;box-shadow:0 0 80px #0006}.card-wrapper{left:50%;right:auto;transform:translate(-50%);width:480px;max-width:100vw}.music-btn{right:calc(50% - 240px + 1.5rem);bottom:1.5rem}}
