:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#333;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f0e8;font-family:Georgia,serif;font-weight:400;line-height:1.6}body{min-width:320px;min-height:100vh;margin:0}*{box-sizing:border-box;scrollbar-width:none;-ms-overflow-style:none;margin:0;padding:0}::-webkit-scrollbar{width:0;height:0;display:none}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar{width:0;height:0;display:none}body{scrollbar-width:none;-ms-overflow-style:none;width:100%;min-height:100vh;margin:0;padding:0;font-family:Cormorant Garamond,serif}body::-webkit-scrollbar{width:0;height:0;display:none}.container{background-image:var(--bg-desktop);background-position:50%;background-repeat:no-repeat;background-size:cover;background-attachment:fixed;justify-content:center;align-items:center;min-height:100vh;padding:0;display:flex;position:relative;inset:0;overflow:hidden}@media (max-width:768px){.container{background-image:var(--bg-mobile)}}.container:before{content:"";pointer-events:none;background:#ffffff26;position:absolute;inset:0}.card-wrapper{pointer-events:none;width:calc(100% - 2rem);max-width:900px;height:80vh;max-height:850px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.decorations{display:none}.shell{opacity:.15;position:absolute}.shell-1{width:120px;height:120px;animation:6s ease-in-out infinite float;top:10%;left:15%}.shell-2{width:100px;height:100px;animation:8s ease-in-out 2s infinite float;bottom:15%;right:20%}.shell-3{width:90px;height:90px;animation:7s ease-in-out 1s infinite float;top:60%;left:10%}@keyframes float{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-20px)rotate(5deg)}}.invitation-card{perspective:2000px;cursor:pointer;pointer-events:auto;width:100%;height:100%;transform-style:preserve-3d;position:absolute;top:0;left:0}.card-front,.card-inside{backface-visibility:hidden;scrollbar-width:none;-ms-overflow-style:none;border-radius:15px;width:100%;height:100%;transition:transform 1s ease-in-out;position:absolute;overflow:hidden;box-shadow:0 10px 40px #0000004d}.card-front::-webkit-scrollbar{width:0;height:0;display:none}.card-inside::-webkit-scrollbar{width:0;height:0;display:none}.card-front,.card-inside{background:#ffffff73}.card-front{z-index:2;flex-direction:column;justify-content:center;align-items:center;display:flex;transform:rotateY(0)}.card-front>*{z-index:1;position:relative}.front-title{color:#3d6fa3;letter-spacing:1px;text-shadow:1px 1px 2px #fffc;margin-bottom:1rem;font-family:Great Vibes,cursive;font-size:4.5rem;font-weight:700}.front-subtitle{color:#3d6fa3;text-shadow:1px 1px 2px #fffc;font-family:Cormorant Garamond,serif;font-size:1.8rem;font-style:italic;font-weight:700}.card-inside{-webkit-overflow-scrolling:touch;z-index:1;padding:2rem;overflow:hidden auto;transform:rotateY(180deg)}.invitation-card.open .card-front{pointer-events:none;transform:rotateY(-180deg)}.invitation-card.open .card-inside{transform:rotateY(0)}.card-content{text-align:center;color:#333;z-index:1;font-family:Cormorant Garamond,serif;position:relative}.welcome-message{color:#3d6fa3;text-shadow:1px 1px 2px #fffc;margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:2.8rem;font-style:italic;font-weight:700}.subtitle{color:#3d6fa3;text-shadow:1px 1px 2px #fffc;margin-bottom:2rem;font-size:1.7rem;font-weight:700}.couple-names{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin:2rem 0;display:flex}.couple-names h3{color:#3d6fa3;text-shadow:1px 1px 3px #ffffffe6;font-family:Great Vibes,cursive;font-size:3.5rem;font-weight:700}.heart{color:#3d6fa3;text-shadow:1px 1px 2px #fffc;font-size:2rem;font-weight:700}.wedding-date{cursor:pointer;background:#fff6;border:none;border-radius:12px;width:100%;margin:2rem 0;padding:2rem;font-family:Playfair Display,serif;font-style:italic;font-weight:700;transition:all .3s;display:block;box-shadow:0 6px 12px #00000026,0 2px 4px #0000001a,inset 0 2px 4px #fff6,inset 0 -2px 4px #0000000d}.wedding-date:hover{background:#ffffff80;transform:translateY(2px);box-shadow:0 3px 6px #0000001f,0 1px 2px #00000014,inset 0 1px 2px #ffffff4d,inset 0 -1px 2px #0000001a}.calendar-button-wrapper{width:100%;max-width:500px;margin:0 auto;position:relative}.calendar-menu{z-index:100;background:#ffffffbf;border-radius:12px;width:90%;max-width:400px;margin-top:10px;animation:.3s ease-out slideDown;position:absolute;top:100%;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 4px 20px #0003}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.calendar-option{color:#3d6fa3;text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #1a3a5c0f;align-items:center;gap:14px;width:100%;padding:18px 24px;font-family:Cormorant Garamond,serif;font-size:1.35rem;font-weight:700;transition:all .15s;display:flex}.calendar-option:last-child{border-bottom:none}.calendar-option:hover{background:#1a3a5c0f;transform:translate(2px)}.calendar-option svg{flex:0 0 1.9em;width:1.9em;height:1.9em}.icon-svg{color:#3d6fa3;vertical-align:middle;flex:none;width:1.2em;height:1.2em;margin-right:8px;display:inline-block}.venue-icon{width:1.4em;height:1.4em;margin-right:6px;display:inline-block}.google-g{flex:0 0 1.5em;width:1.5em;height:1.5em;margin-right:12px}.apple-g{flex:0 0 1.3em;width:1.3em;height:1.3em;margin-right:10px}.outlook-g{flex:0 0 1.5em;width:1.5em;height:1.5em;margin-right:10px}.date-label{color:#3d6fa3;text-shadow:1px 1px 2px #fffc;margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.8rem;font-weight:700}.date{color:#3d6fa3;text-shadow:1px 1px 2px #fffc;font-family:Playfair Display,serif;font-size:3.2rem;font-weight:700}.links-section{flex-direction:column;align-items:center;gap:1rem;margin:2rem 0;display:flex}.link-button{color:#3d6fa3;cursor:pointer;text-align:center;text-shadow:1px 1px 2px #fffc;background:#fff6;border:none;border-radius:12px;justify-content:center;align-items:center;width:100%;max-width:500px;padding:1.8rem 2.5rem;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;text-decoration:none;transition:all .3s;display:flex;box-shadow:0 6px 12px #00000026,0 2px 4px #0000001a,inset 0 2px 4px #fff6,inset 0 -2px 4px #0000000d}.link-button.venue-link{flex-direction:column;justify-content:center;align-items:center;display:flex}.venue-row{order:1;justify-content:center;align-items:center;gap:12px;width:100%;display:flex}.venue-note{text-align:center;order:2;width:100%;max-width:80%;margin:.25rem auto 0;display:block}.venue-name{margin-right:0;display:inline-block}.venue-content{display:block}.venue-inline{white-space:nowrap;align-items:center;gap:10px;display:inline-flex}.venue-text{flex-direction:column;flex-basis:100%;align-items:center;width:100%;display:flex}.venue-name{margin:0;font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700;line-height:1}.venue-note{opacity:.85;white-space:normal;margin-top:4px;font-size:1rem}.venue-text .venue-note{text-align:center;width:100%;margin:.15rem 0 0;display:block}.venue-location{display:none}.link-button:hover{color:#1e3a70;background:#ffffff80;transform:translateY(2px);box-shadow:0 3px 6px #0000001f,0 1px 2px #00000014,inset 0 1px 2px #ffffff4d,inset 0 -1px 2px #0000001a}.photo-link--disabled{opacity:.45;cursor:not-allowed}.photo-link--disabled:hover{background:#ffffffb3;transform:none;box-shadow:0 6px 12px #00000026,0 2px 4px #0000001a,inset 0 2px 4px #fff6,inset 0 -2px 4px #0000000d}.iban-section{background:#fff6;border-radius:10px;margin-top:.5rem;padding:1.8rem;animation:.3s ease-out slideDown}.iban-label{color:#2d5080;text-shadow:2px 2px 4px #ffffffe6,-1px -1px 3px #fffc;margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.6rem;font-style:italic;font-weight:900}.iban-prefix{color:#3d6fa3;text-shadow:1px 1px 2px #fffc;margin:.5rem 0 .1rem;font-family:Playfair Display,serif;font-size:1.3rem;font-weight:700}.iban-code{color:#3d6fa3;word-break:break-all;text-shadow:1px 1px 2px #fffc;margin:0 0 .5rem;font-family:Arial,sans-serif;font-size:1.6rem;font-weight:700}.iban-note{color:#2d5080;text-shadow:2px 2px 4px #ffffffe6,-1px -1px 3px #fffc;font-family:Playfair Display,serif;font-size:1.6rem;font-style:italic;font-weight:900}.iban-br{display:none}@media (max-width:480px){.iban-br{display:inline}}.footer-message{color:#3d6fa3;text-shadow:2px 2px 6px #fff,-1px -1px 4px #fff;background:0 0;max-width:90%;margin-top:2rem;margin-left:auto;margin-right:auto;font-family:Playfair Display,serif;font-size:2.2rem;font-style:italic;font-weight:800;line-height:1.4}.footer-rsvp{color:#3d6fa3;text-shadow:1px 1px 4px #fff;background:0 0;max-width:90%;margin-top:.5rem;margin-left:auto;margin-right:auto;font-family:Playfair Display,serif;font-size:1.1rem;font-style:italic;line-height:1.4}@media (max-width:768px){.container{padding:0}.container:before{background:#fff3}.card-wrapper{width:calc(100% - 2rem);height:75vh;max-height:600px}.card-front:before,.card-inside:before{background:#ffffff80}.front-title{font-size:4rem}.welcome-message{font-size:2.5rem}.subtitle{font-size:2rem}.couple-names h3{font-size:3.5rem}.date{font-family:Playfair Display,serif;font-size:2.8rem;font-weight:700}.date-label{font-family:Playfair Display,serif;font-size:1.8rem;font-weight:700}.link-button{padding:1.5rem 2rem;font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700}.footer-message{font-family:Playfair Display,serif;font-size:2.4rem;font-weight:800}.footer-rsvp{font-size:1rem}.shell-1,.shell-2,.shell-3{display:none}.card-inside{padding:1.5rem 1.2rem}.wedding-date{padding:1rem}}@media (max-width:480px){.container{justify-content:center;align-items:center;padding:0;display:flex}.container:before{background:#ffffff26}.card-wrapper{width:calc(100% - 1.5rem);height:85vh;max-height:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.card-front:before,.card-inside:before{background:#ffffffb3}.card-inside{padding:1.2rem 1rem}.couple-names{flex-direction:column;gap:.3rem}.couple-names h3{font-size:3.2rem}.front-title{font-size:3.5rem}.front-subtitle{font-size:1.8rem}.welcome-message{font-size:2.3rem}.subtitle{font-size:1.8rem}.date{font-family:Playfair Display,serif;font-size:2.5rem;font-weight:700}.date-label{font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700}.link-button{color:#254a78;background:#fff6;padding:1.1rem 1.2rem;font-family:Playfair Display,serif;font-size:1.15rem;font-weight:700}.venue-content{flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.venue-name{font-size:1.15rem}.venue-location{opacity:.95;font-size:.95rem}.venue-note{text-align:center;margin-top:.15rem}.wedding-date{background:#fff6}.iban-section{background:#fff6;padding:.8rem}.iban-label{color:#2d5080;text-shadow:2px 2px 4px #ffffffe6,-1px -1px 3px #fffc;font-family:Playfair Display,serif;font-size:1.1rem;font-style:italic;font-weight:900}.iban-prefix{color:#3d6fa3;text-shadow:1px 1px 2px #fffc;margin:.4rem 0 .1rem;font-family:Playfair Display,serif;font-size:1rem;font-weight:700}.iban-code{color:#3d6fa3;word-break:break-all;white-space:normal;letter-spacing:0;text-shadow:1px 1px 2px #fffc;margin:0 0 .4rem;font-family:Arial,sans-serif;font-size:1.2rem;font-weight:700}.iban-note{color:#2d5080;text-shadow:2px 2px 4px #ffffffe6,-1px -1px 3px #fffc;font-family:Playfair Display,serif;font-size:1.1rem;font-style:italic;font-weight:900}.footer-message{text-shadow:2px 2px 6px #fff,-1px -1px 4px #fff;background:0 0;font-family:Playfair Display,serif;font-size:2.2rem;font-weight:800}.footer-rsvp{font-size:.85rem}.shell-1,.shell-2,.shell-3{display:none}}@media (max-width:380px){.card-wrapper{height:95vh}.card-inside{padding:1rem .8rem}.front-title{font-size:1.6rem}.couple-names h3{font-size:2rem}.welcome-message,.date{font-size:1.6rem}.link-button{font-size:1.1rem}}
