@font-face{font-family:DancingScript;src:url(/fonts/DancingScript.ttf)format("truetype");font-weight:400 700}html,body{background:#fff;width:100%;min-height:100dvh;margin:0;padding:0;font-family:Inter,sans-serif}:root{--envelope-scale:1;--envelope-y-offset:200px;--app-easing:cubic-bezier(.4, 0, .2, 1);--lift-dist:-200px}@media (max-width:600px){:root{--envelope-scale:.85;--card-open-scale:1.35;--envelope-y-offset:280px}}@media (min-width:1024px){:root{--envelope-scale:1.8;--card-open-scale:1.6;--envelope-y-offset:300px}.envelope-wrapper.open .invitation-card{transition:z-index 0s 2.8s!important}}.invitation-container{scroll-behavior:smooth;background:#fff;flex-direction:column;align-items:center;width:100%;display:flex;position:relative}.envelope-hero-section{perspective:2000px;flex-shrink:0;justify-content:center;align-items:center;width:100%;height:100dvh;display:flex}.envelope-wrapper{perspective:2000px;width:320px;height:318px;transform-style:preserve-3d;transform:scale(var(--envelope-scale));transition:transform 1.2s var(--app-easing);position:relative}.envelope-back,.envelope-front{z-index:1;transform-origin:50% 223px;width:100%;height:538px;position:absolute;top:-220px;left:0}.envelope-front{z-index:8;pointer-events:none;transform-origin:50% 223px;filter:drop-shadow(0 4px 10px #00000014)}.envelope-flap{z-index:15;transform-origin:50% 223px;width:100%;height:538px;transform-style:preserve-3d;transition:transform 1.5s var(--app-easing);position:absolute;top:-223px;left:0;transform:rotateX(0)}.envelope-flap-outside,.envelope-flap-inside{backface-visibility:hidden;width:100%;height:100%;position:absolute;top:0;left:0}.envelope-flap-outside{transform-origin:50% 223px;transform:rotateX(0)}.envelope-flap-inside{transform-origin:50% 223px;transform:rotateX(180deg)}.envelope-wrapper.open .envelope-flap{animation:flap-open 4s var(--app-easing) forwards, flap-z-index 4s var(--app-easing) forwards}@keyframes flap-open{0%{transform:translateY(0)rotateX(0)}30%{transform:translateY(var(--lift-dist)) rotateX(180deg)}to{transform:translateY(var(--envelope-y-offset)) rotateX(180deg)}}@keyframes flap-z-index{0%,29%{z-index:15}30%,to{z-index:2}}.envelope-wrapper.open .envelope-back,.envelope-wrapper.open .envelope-front{animation:envelope-open 4s var(--app-easing) forwards}@keyframes envelope-open{0%{transform:translateY(0)rotateX(0)}30%{transform:translateY(var(--lift-dist)) rotateX(0deg)}to{transform:translateY(var(--envelope-y-offset)) rotateX(0deg)}}.invitation-card{z-index:5;justify-content:center;align-items:center;width:100%;height:538px;transition:z-index .5s step-end;display:flex;position:absolute;top:-210px;left:0}.card-inner{width:310px;height:310px;transition:transform 1.5s var(--app-easing), box-shadow .8s ease-out;background:#fff;border-radius:4px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden;transform:translateY(100px);box-shadow:0 0 #0000}.card-custom-body{background-color:#fff;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.card-texture-overlay{opacity:.55;mix-blend-mode:multiply;pointer-events:none;background-image:url(/textures/card_texture.jpg);background-size:cover;position:absolute;inset:0}.gold-ink{background:linear-gradient(135deg,#bf953f 0%,#fcf6ba 25%,#b38728 50%,#fbf5b7 75%,#aa771c 100%) 0 0/200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;background-position:var(--shimmer-pos,50%) center;filter:drop-shadow(0 1px 1px #0000004d);transition:background-position .15s ease-out}.khaki-gradient-ink{background:linear-gradient(135deg,#fff 0%,#f2e9e1 35%,#d6c5af 70%,#c3b091 100%) 0 0/200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;background-position:var(--shimmer-pos,50%) center;filter:drop-shadow(0 1px 1px #0003);transition:background-position .15s ease-out}.card-frame-border{pointer-events:none;border:1px solid #d4af37;position:absolute;inset:15px}.card-frame-inner{border:.5px solid #d4af3766;position:absolute;inset:3px}.card-ornament{pointer-events:none;width:40px;height:40px;position:absolute}.card-ornament.top-left{top:15px;left:15px}.card-ornament.top-right{top:15px;right:15px}.card-ornament.bottom-left{bottom:15px;left:15px}.card-ornament.bottom-right{bottom:15px;right:15px}.card-ornament svg{opacity:.9;width:100%;height:100%}.card-content-redesign{box-sizing:border-box;text-align:center;z-index:2;color:#5d4037;flex-direction:column;justify-content:space-between;height:100%;padding:12px;display:flex;position:relative}.card-top-guest{flex-direction:column;align-items:flex-start;gap:1px;margin-bottom:0;display:flex}.guest-label-center{color:#8d6e63;opacity:.8;margin:0;font-family:DancingScript,cursive;font-size:16px}.guest-name-center{letter-spacing:2px;text-transform:uppercase;color:#8d6e63;margin:2px 0;font-family:EB Garamond,serif;font-size:14px;font-weight:500}.intro-text-center{letter-spacing:2.5px;color:#8d6e63;opacity:.8;margin:5px 0 15px;font-family:EB Garamond,serif;font-size:7px;line-height:1}.card-main-heading{flex-direction:column;align-items:center;gap:0;margin-top:5px;display:flex}.names-script-dusty{color:#8d6e63;text-shadow:-.5px -.5px 1px #0000001f,.8px .8px #fff;margin:0;font-family:DancingScript,cursive;font-size:36px;font-weight:500;line-height:.9}.getting-text-serif{letter-spacing:4px;opacity:.8;text-shadow:-.2px -.2px .5px #0000001a,.5px .5px #fff;margin:8px 0;font-family:EB Garamond,serif;font-size:10px;font-weight:600}.engaged-heading-script{color:#8d6e63;text-shadow:-.5px -.5px 1px #0000001f,.8px .8px #fff;margin:0;padding-bottom:8px;font-family:DancingScript,cursive;font-size:36px;font-weight:500;line-height:.8}.card-bottom-details{text-align:left;justify-content:space-between;align-items:flex-end;width:100%;padding-top:15px;display:flex}.details-col{flex-direction:column;gap:4px;display:flex}.details-col.right{text-align:right}.serif-detail-bold{letter-spacing:1.5px;margin:0;font-family:EB Garamond,serif;font-size:7px;font-weight:700}.serif-detail-light{letter-spacing:.5px;opacity:.8;margin:0;font-family:EB Garamond,serif;font-size:7px;line-height:1.3}.address-small{max-width:none;margin-left:auto;font-size:7px}.card-inner img{object-fit:cover;width:100%;height:100%}.envelope-wrapper.open .invitation-card{z-index:30;transition:z-index 0s 3.2s}.envelope-wrapper.open .card-inner{animation:card-open 4s var(--app-easing) forwards}@keyframes card-open{0%{transform:translateY(100px)scale(1);box-shadow:0 0 #0000}30%{transform:translateY(calc(var(--lift-dist) + 100px)) scale(1);box-shadow:0 2px 5px #0000001a}72.5%{transform:translateY(10px)scale(1);box-shadow:0 4px 10px #0000004d}to{transform:translateY(0) scale(var(--card-open-scale));box-shadow:0 5px 15px #0009}}@keyframes float{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(-8px)}}.animation-control-btn{color:#4b443a;letter-spacing:2px;text-transform:uppercase;cursor:pointer;z-index:1000;transition:all .4s var(--app-easing);background:#fff;border:none;border-radius:50px;outline:none;align-items:center;gap:10px;padding:12px 28px;font-size:11px;font-weight:700;display:flex;position:absolute;bottom:50px;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #0000001a}.animation-control-btn svg{transition:transform .6s var(--app-easing)}.animation-control-btn:hover{color:#fff;background:#4b443a;transform:translate(-50%)translateY(-3px);box-shadow:0 15px 40px #4b443a40}.animation-control-btn:hover svg{transform:rotate(-180deg)}.animation-control-btn.is-open{opacity:.9;padding:10px 20px;font-size:10px;bottom:30px}.animation-control-btn:not(.is-open){animation:2.4s ease-in-out infinite float}.invitation-details{opacity:0;width:100%;transition:all 1s var(--app-easing) 3s;text-align:center;box-sizing:border-box;background:#fff;margin:0 auto;padding:60px 20px 150px;transform:translateY(30px)}.invitation-details.visible{opacity:1;transform:translateY(0)}.details-inner{flex-direction:column;align-items:center;gap:48px;max-width:600px;margin:0 auto;display:flex}.engagement-title{color:#4b443a;letter-spacing:1px;text-transform:uppercase;margin-bottom:20px;font-size:22px;font-weight:600;line-height:1.3}.rsvp-buttons{gap:15px;width:100%;max-width:400px;margin-bottom:20px;display:flex}.rsvp-btn{color:#4b443a;letter-spacing:1.5px;cursor:pointer;background:0 0;border:1.5px solid #4b443a;flex:1;padding:18px 10px;font-size:11px;font-weight:700;transition:all .3s}.rsvp-btn:hover{color:#fff;background:#4b443a}.info-block{flex-direction:column;align-items:center;gap:6px;display:flex}.label{color:#8d6e63;letter-spacing:2px;font-size:11px;font-weight:700}.value{color:#4b443a;letter-spacing:.5px;margin:0;font-size:18px;line-height:1.5}.value.underlined{padding-bottom:4px;line-height:1.5;display:inline-block}.action-link{color:#8d6e63;letter-spacing:.5px;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-top:8px;padding:4px 0;font-size:12px;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.action-link:hover{color:#4b443a}.calendar-wrapper{flex-direction:column;align-items:center;display:flex;position:relative}.drawer-handle{background:#d9d0c4;border-radius:2px;width:36px;height:4px;margin:12px auto 4px}.calendar-popup-title{letter-spacing:1px;color:#8d6e63;text-align:center;border-bottom:1px solid #f0ebe3;margin:0;padding:10px 16px;font-size:11px;font-weight:700}.calendar-option{color:#4b443a;text-align:center;border-bottom:1px solid #f0ebe3;padding:16px 20px;font-size:16px;text-decoration:none;transition:background .15s;display:block}.calendar-option:last-child{border-bottom:none}.calendar-option:hover{background:#f5f0e8}.date-time,.address-lines{flex-direction:column;gap:4px;display:flex}.icon-divider{color:#4b443a;margin-top:10px}.dress-code-grid{align-items:flex-start;gap:0;width:100%;max-width:300px;margin-top:0;display:flex}.dress-code-col{flex-direction:column;flex:1;align-items:center;gap:16px;padding:10px 16px;display:flex}.dress-code-col.left-align{text-align:left;flex:1.5;align-items:flex-start}.dress-code-gender{letter-spacing:1px;color:#4b443a;text-transform:uppercase;margin:0;font-size:13px;font-weight:700}.dress-code-divider{background:#d9d0c4;align-self:stretch;width:1px}.color-swatches{flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex}.color-swatch{border-radius:50%;flex-shrink:0;width:15px;height:15px;display:inline-block;box-shadow:0 1px 3px #0000001a}.dress-code-note{flex-direction:column;gap:8px;margin-top:15px;margin-bottom:24px;display:flex}.dress-code-note p{margin:0}.request-text-style{color:#4b443a;letter-spacing:1.5px;margin:6px 0;font-size:11px;font-weight:300}.request-text-style-bold{color:#4b443a;letter-spacing:1.5px;text-transform:uppercase;margin:6px 0;font-size:13px;font-weight:700}.color-popup-drawer{z-index:2001;width:260px;animation:drawer-fade-up .3s var(--app-easing);background:#fff;border-radius:12px;flex-direction:column;align-items:center;gap:20px;padding:30px 20px;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 10px 40px #0003}.color-preview-large{border-radius:50%;width:80px;height:80px;box-shadow:0 4px 12px #0000001a}.color-preview-info{text-align:center}.color-preview-label{color:#888;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:500}.color-preview-value{color:#4b443a;letter-spacing:1px;text-transform:uppercase;font-size:16px;font-weight:600}.color-popup-close{color:#666;cursor:pointer;background:#f8f8f8;border:1px solid #eee;border-radius:20px;margin-top:10px;padding:8px 24px;font-size:12px;font-weight:600;transition:all .2s}.color-popup-close:active{background:#eee;transform:scale(.95)}.rsvp-drawer{z-index:3000;padding:0 24px calc(24px + env(safe-area-inset-bottom,20px));background:#fff;border-top-left-radius:20px;border-top-right-radius:20px;max-height:90vh;animation:.3s cubic-bezier(.32,.72,0,1) slide-up;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -4px 30px #0000001f}.rsvp-form{flex-direction:column;gap:16px;margin-top:16px;display:flex}.rsvp-form-title{text-align:center;color:#4b443a;letter-spacing:2px;margin:0 0 16px;font-size:16px;font-weight:700}.rsvp-field{flex-direction:column;gap:6px;display:flex}.rsvp-label{letter-spacing:1px;color:#8d6e63;font-size:10px;font-weight:700}.rsvp-row{align-items:flex-end;gap:16px;display:flex}.guest-count-field{flex-shrink:0;width:100px}.rsvp-input,.rsvp-textarea{color:#1a1a1a;box-sizing:border-box;background:#f5f0e8;border:none;outline:none;width:100%;font-family:inherit;font-size:14px;transition:box-shadow .2s,background .2s;box-shadow:inset 0 2px 4px #4b443a1a}.rsvp-input:focus,.rsvp-textarea:focus{background:#f0ebe3;box-shadow:inset 0 2px 6px #4b443a26}.rsvp-input{border-radius:50px;height:40px;padding:10px 16px}.rsvp-textarea{resize:vertical;border-radius:12px;padding:12px 16px}.guest-stepper{justify-content:space-between;align-items:center;height:40px;display:flex}.stepper-btn{cursor:pointer;color:#1a1a1a;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:transform .1s,box-shadow .1s;display:flex;box-shadow:0 2px 8px #4b443a1f}.stepper-btn:active{transform:scale(.95);box-shadow:0 1px 4px #4b443a1a}.stepper-value{text-align:center;width:20px;font-size:16px;font-weight:600}.rsvp-submit{color:#fff;letter-spacing:1px;cursor:pointer;background:#4b443a;border:none;border-radius:4px;margin-top:8px;padding:14px;font-size:14px;font-weight:600;transition:opacity .2s}.rsvp-submit:disabled{opacity:.5;cursor:not-allowed}.rsvp-success{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:40px 0;animation:.3s fade-in;display:flex}.rsvp-success-icon{color:#fff;background:#4b443a;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:12px;font-size:24px;display:flex}.rsvp-success-title{color:#1a1a1a;margin:0;font-size:18px;font-weight:700}.rsvp-success-sub{color:#666;margin:0;font-size:14px}.guest-messages-section{border-top:1px dashed #d9d0c4;flex-direction:column;gap:16px;width:100%;margin-top:24px;padding-top:24px;display:flex}.messages-list{flex-direction:column;gap:12px;max-height:400px;padding-right:4px;display:flex;overflow-y:auto}.ig-comment{align-items:flex-start;gap:12px;padding:8px 0;display:flex}.ig-avatar{color:#4b443a;background:#ebe5d9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.ig-body{color:#1a1a1a;text-align:left;flex:1;font-size:13px;line-height:1.4}.ig-author{margin-right:6px;font-weight:700}.ig-text{color:#333}.ig-actions{color:#8e8e8e;gap:12px;margin-top:4px;font-size:11px;font-weight:600;display:flex}.ig-like{color:#bebebe;flex-direction:column;flex-shrink:0;align-items:center;gap:2px;padding-top:2px;transition:color .2s;display:flex}.ig-like:active{transform:scale(.9)}.ig-reply-container{align-items:flex-start;gap:10px;margin-top:4px;margin-bottom:12px;margin-left:44px;display:flex}.ig-reply-avatar{color:#fff;background:#4b443a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.ig-reply-body{text-align:left;flex-direction:column;align-items:flex-start;gap:2px;display:flex}.ig-reply-header{align-items:center;gap:6px;display:flex}.reply-author{color:#1a1a1a;font-size:13px;font-weight:700}.start-overlay{z-index:5000;color:#fff;text-align:center;background-color:#000;flex-direction:column;justify-content:center;align-items:center;padding:20px;transition:opacity .8s,visibility .8s;display:flex;position:fixed;inset:0}.start-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.start-overlay-bg{opacity:.15;filter:blur(5px);background-image:url(/textures/card_texture.jpg);background-size:cover;position:absolute;inset:0}.start-content{z-index:1;position:relative}.start-couple-names{color:#dfc48c;margin-bottom:8px;font-family:Great Vibes,cursive;font-size:42px}.start-invitation-text{letter-spacing:3px;text-transform:uppercase;color:#fff9;margin-bottom:40px;font-size:12px}.start-btn{color:#1a1a1a;letter-spacing:2px;text-transform:uppercase;cursor:pointer;background:linear-gradient(135deg,#bf953f,#fcf6ba,#b38728,#fbf5b7,#aa771c);border:none;border-radius:50px;padding:14px 36px;font-size:13px;font-weight:700;transition:transform .3s,box-shadow .3s;box-shadow:0 10px 25px #b5934c4d}.start-btn:active{transform:scale(.95)}.drawer-backdrop{z-index:2000;background:#0006;animation:.3s backdrop-fade;position:fixed;inset:0}@keyframes backdrop-fade{0%{opacity:0}to{opacity:1}}.calendar-drawer{padding:24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));z-index:2001;background:#fff;border-radius:24px 24px 0 0;flex-direction:column;align-items:center;gap:10px;animation:.4s cubic-bezier(.32,.72,0,1) drawer-slide-up;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -10px 40px #0003}@keyframes drawer-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.calendar-popup-title{color:#1a1a1a;text-align:center;margin-bottom:24px;font-size:17px;font-weight:700;border:none!important}.calendar-option{color:#1a1a1a;text-align:center;cursor:pointer;-webkit-tap-highlight-color:transparent;box-sizing:border-box;background:#f8f7f5;border-radius:14px;width:calc(100% - 48px);max-width:400px;padding:18px;font-size:15px;font-weight:600;text-decoration:none;transition:background .2s;display:block;border:none!important}.calendar-option:active{background:#efeee8}.ig-reply-text{color:#333;text-align:left;font-size:14px;line-height:1.4}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ig-comment,.ig-reply-container{animation:.3s forwards fadeInSlide}.like-count{color:#8e8e8e;font-size:10px;font-weight:600}@media (max-width:600px){.engagement-title{font-size:18px}.animation-control-btn{bottom:40px}}
