@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/65c558afe41e89d6-s.113htgw8u-emy.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/14e23f9b59180572-s.08.c8psu~gif9.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/b49b0d9b851e4899-s.0yfy_qj1.2qn0.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/2a65768255d6b625-s.p.14by5b4al-y~f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display Fallback;src:local(Times New Roman);ascent-override:97.25%;descent-override:22.56%;line-gap-override:0.0%;size-adjust:111.26%}.playfair_display_b8b06705-module__BCq1YG__className{font-family:Playfair Display,Playfair Display Fallback;font-style:normal}.playfair_display_b8b06705-module__BCq1YG__variable{--primary-font:"Playfair Display", "Playfair Display Fallback"}
@font-face{font-family:Montserrat;font-style:normal;font-weight:300;font-display:swap;src:url(../media/8298327da6d5bcce-s.132ro2ak-rvxq.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-weight:300;font-display:swap;src:url(../media/44fac91e6f2d2b1b-s.0f~sf101j6mzi.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-weight:300;font-display:swap;src:url(../media/2b402d8aebffd579-s.0dskwooysu3cf.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-weight:300;font-display:swap;src:url(../media/a88409fdd7dc121c-s.0ir_pxtv760h..woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-weight:300;font-display:swap;src:url(../media/e8f2fbee2754df70-s.p.0fzkl03jw-sdz.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Montserrat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/8298327da6d5bcce-s.132ro2ak-rvxq.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/44fac91e6f2d2b1b-s.0f~sf101j6mzi.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2b402d8aebffd579-s.0dskwooysu3cf.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/a88409fdd7dc121c-s.0ir_pxtv760h..woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e8f2fbee2754df70-s.p.0fzkl03jw-sdz.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Montserrat;font-style:normal;font-weight:600;font-display:swap;src:url(../media/8298327da6d5bcce-s.132ro2ak-rvxq.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-weight:600;font-display:swap;src:url(../media/44fac91e6f2d2b1b-s.0f~sf101j6mzi.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2b402d8aebffd579-s.0dskwooysu3cf.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-weight:600;font-display:swap;src:url(../media/a88409fdd7dc121c-s.0ir_pxtv760h..woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-weight:600;font-display:swap;src:url(../media/e8f2fbee2754df70-s.p.0fzkl03jw-sdz.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Montserrat Fallback;src:local(Arial);ascent-override:85.79%;descent-override:22.25%;line-gap-override:0.0%;size-adjust:112.83%}.montserrat_a3c3e04-module__NqlV8W__className{font-family:Montserrat,Montserrat Fallback;font-style:normal}.montserrat_a3c3e04-module__NqlV8W__variable{--secondary-font:"Montserrat", "Montserrat Fallback"}
@font-face{font-family:Italianno;font-style:normal;font-weight:400;font-display:swap;src:url(../media/f2ec43e23a8e6409-s.0ft5~-kx80ngq.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Italianno;font-style:normal;font-weight:400;font-display:swap;src:url(../media/1ae22edee2b2ce67-s.0.pw8kz1-6bwh.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Italianno;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2723dd1e6871fd18-s.p.10hb_mhorpudv.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Italianno Fallback;src:local(Arial);ascent-override:134.08%;descent-override:75.42%;line-gap-override:0.0%;size-adjust:59.67%}.italianno_67de889c-module__v10CaG__className{font-family:Italianno,Italianno Fallback;font-style:normal;font-weight:400}.italianno_67de889c-module__v10CaG__variable{--cursive-font:"Italianno", "Italianno Fallback"}
:root{--dark-blue:#142414;--gold:#ffc107;--light-slate:#e9eedf;--slate:#a3b395;--white:#fff}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--secondary-font);background-color:var(--dark-blue);color:var(--light-slate);overflow:hidden}.background-wrapper{z-index:-1;width:100%;height:100%;position:fixed;top:0;left:0}#firefly-container{background-image:url(/images/foto-background.jpeg);background-position:50%;background-size:cover;width:100%;height:100%;position:relative}#firefly-container:before{content:"";background:linear-gradient(#00000080,#000c);width:100%;height:100%;position:absolute;top:0;left:0}.firefly{background-color:var(--gold);width:5px;height:5px;box-shadow:0 0 10px var(--gold), 0 0 20px var(--gold);opacity:0;border-radius:50%;animation:20s linear infinite move;position:absolute}@keyframes move{0%{opacity:0;transform:translate(0)}10%{opacity:1}90%{opacity:1}to{transform:translate(var(--x), var(--y));opacity:0}}#main-content{opacity:0;z-index:10;transition:opacity 1.5s ease-in-out;position:relative}.selempang-decoration{z-index:5;opacity:.8;background-position:50%;background-repeat:no-repeat;background-size:contain;width:150px;height:100vh;position:fixed;top:0}.selempang-left{background-image:url(/images/selempang-kiri.png);left:0}.selempang-right{background-image:url(/images/selempang-kanan.png);right:0}@media (max-width:768px){.selempang-decoration{opacity:.6;width:80px}}@media (max-width:480px){.selempang-decoration{display:none}}.container{z-index:15;border-radius:15px;width:100%;max-width:800px;margin:auto;padding:1rem;position:relative;box-shadow:0 10px 30px #00000080}.reveal{opacity:0;transition:all 1s;position:relative;transform:translateY(100px)}.reveal.active{opacity:1;transform:translateY(0)}section{text-align:center;border-bottom:1px solid #ffc10733;padding:4rem 0}section:last-child{border-bottom:none}h2.section-title{font-family:var(--cursive-font);color:var(--gold);margin-bottom:.5rem;font-size:clamp(3rem,10vw,6rem);font-weight:400}p{color:var(--slate);line-height:1.8}.hero{z-index:15;flex-direction:column;justify-content:center;align-items:center;min-height:80vh;display:flex;position:relative}.hero .couple-names{font-family:var(--primary-font);color:var(--white);text-align:center;margin:1rem 0;font-size:clamp(3rem,12vw,3.7rem)}@media screen and (max-width:768px){.hero .couple-names{font-size:clamp(1.2rem,8vw,1.5rem)}}.hero .date{letter-spacing:3px;text-transform:uppercase;font-size:1.2rem}.quote{font-family:var(--primary-font);color:var(--light-slate);max-width:600px;margin:0 auto;font-size:1.5rem;font-style:italic}.event-details .events-container{flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:2rem;display:flex}.event-card{background:#1e321e99;border:1px solid #ffc1074d;border-radius:8px;width:300px;padding:2rem;transition:transform .3s,box-shadow .3s}.event-card:hover{transform:translateY(-10px);box-shadow:0 10px 20px #0006}.event-card h3{font-family:var(--primary-font);color:var(--gold);margin-bottom:1rem;font-size:2rem}.event-card p{color:var(--light-slate);margin-bottom:.5rem}.event-card i{color:var(--gold);margin-right:10px}.btn-map{background-color:var(--gold);color:var(--dark-blue);border-radius:5px;margin-top:1rem;padding:10px 20px;font-weight:700;text-decoration:none;transition:background-color .3s;display:inline-block}.btn-map:hover{background-color:#ffca2c}#countdown{flex-wrap:nowrap;justify-content:center;gap:clamp(.2rem,1.5vw,.8rem);margin-top:2rem;display:flex}.time-box{background:#1e321e99;border-radius:5px;flex:1 1 0;min-width:0;max-width:100px;padding:clamp(.3rem,1.5vw,.8rem)}.time-box span{color:var(--white);font-size:clamp(1rem,5vw,2.5rem);font-weight:700;display:block}.time-box p{color:var(--gold);font-size:clamp(.55rem,2.5vw,.9rem)}.gallery-grid{flex-wrap:wrap;gap:1rem;margin-top:2rem;padding:0 1rem;display:flex}.gallery-grid:after{content:"";flex-grow:10}.gallery-grid img{object-fit:cover;border:2px solid #ffc10780;border-radius:8px;flex-grow:1;width:auto;max-width:100%;height:280px;transition:transform .3s,filter .3s}@media (max-width:768px){.gallery-grid img{height:200px}}@media (max-width:480px){.gallery-grid img{height:150px}}.gallery-grid img:hover{filter:brightness(1.2);transform:scale(1.05)}#rsvp-form{flex-direction:column;gap:1rem;max-width:500px;margin:2rem auto 0;display:flex}.form-group{text-align:left}.form-group label{color:var(--light-slate);margin-bottom:5px;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--slate);width:100%;color:var(--white);font-family:var(--secondary-font);background-color:#142414e6;border-radius:5px;padding:12px}#rsvp-form button{background-color:var(--gold);color:var(--dark-blue);cursor:pointer;border:none;border-radius:5px;padding:12px 24px;font-size:1rem;font-weight:700;transition:background-color .3s}#rsvp-form button:hover{background-color:#ffca2c}#form-message{color:var(--gold);margin-top:1rem;font-weight:700}#music-control{width:50px;height:50px;color:var(--dark-blue);cursor:pointer;z-index:99;opacity:0;background-color:#ffc107cc;border-radius:50%;justify-content:center;align-items:center;transition:opacity 1.5s;display:flex;position:fixed;bottom:20px;right:20px}#music-control.show{opacity:1}#music-control i{font-size:1.2rem}footer{text-align:center;padding:2rem;font-size:.9rem}footer .love{color:var(--gold)}#cover{background-color:var(--dark-blue);text-align:center;z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-image:url(/images/foto-background.jpeg);background-position:50%;background-size:cover;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:2rem;transition:opacity 1.5s ease-in-out,visibility 1.5s;display:flex;position:fixed;top:0;left:0}#cover:before{content:"";z-index:1;background:linear-gradient(#00000080,#000c);width:100%;height:100%;position:absolute;top:0;left:0}#cover.hidden{opacity:0;visibility:hidden}.cover-content{z-index:2;position:relative}.graduation-sash{z-index:2;pointer-events:none;height:100%;position:absolute;top:0}.left-sash{left:0}.right-sash{right:0}.graduation-sash img{object-fit:contain;width:auto;height:100%}@media (max-width:768px){.graduation-sash{width:80px}.graduation-sash img{width:100%;height:auto;max-height:100vh}}@media (min-width:769px){.graduation-sash{width:120px}}.cover-title{font-family:var(--cursive-font);color:var(--gold);font-size:clamp(2.5rem,10vw,5rem);font-weight:400}.cover-names{font-family:var(--primary-font);color:var(--white);margin:1rem 0;font-size:clamp(2rem,8vw,4rem)}.cover-text{color:var(--light-slate);margin-bottom:2rem;font-size:1rem}#open-invitation-btn{font-family:var(--secondary-font);color:var(--gold);border:1px solid var(--gold);cursor:pointer;background-color:#0000;border-radius:50px;align-items:center;gap:10px;padding:12px 24px;font-size:1rem;transition:background-color .3s,color .3s;display:inline-flex}#open-invitation-btn:hover{background-color:var(--gold);color:var(--dark-blue)}.rsvp-list{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#ffffff14;border:1px solid #ffc10733;border-radius:15px;margin:3rem 0;padding:2rem}.rsvp-summary{flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-bottom:2rem;display:flex}.summary-item{text-align:center;border:1px solid #ffffff1a;border-radius:10px;min-width:80px;padding:1rem 1.5rem;transition:all .3s}.summary-item.attending{background-color:#4caf501a;border-color:#4caf504d}.summary-item.not-attending{background-color:#f443361a;border-color:#f443364d}.summary-item.total{background-color:#ffc1071a;border-color:#ffc1074d}.summary-count{color:var(--gold);font-size:1.8rem;font-weight:700;font-family:var(--font-primary);display:block}.summary-label{color:var(--light-slate);opacity:.8;margin-top:.3rem;font-size:.85rem;display:block}.rsvp-list-container{max-height:450px;margin-bottom:1rem;overflow-y:auto}.rsvp-card{background-color:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;margin-bottom:.75rem;padding:1rem 1.25rem;transition:all .3s;position:relative}.rsvp-card:hover{background-color:#ffffff14;border-color:#ffc1074d;transform:translateY(-1px)}.rsvp-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.rsvp-name-section{flex:1}.rsvp-name{color:var(--light-slate);margin:0 0 .25rem;font-size:1.1rem;font-weight:600;line-height:1.3}.rsvp-time{color:var(--slate);opacity:.7;font-size:.75rem}.rsvp-badge{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-left:1rem;font-size:.9rem;font-weight:700;display:flex}.badge-attending{color:#4caf50;background-color:#4caf5033;border:1px solid #4caf5066}.badge-not-attending{color:#f44336;background-color:#f4433633;border:1px solid #f4433666}.rsvp-message-content{border-top:1px solid #ffffff1a;margin-top:.75rem;padding-top:.75rem}.rsvp-message{color:var(--slate);margin:0;padding:.5rem 0;font-size:.95rem;font-style:italic;line-height:1.5}.show-more-button{color:var(--gold);border:1px solid var(--gold);cursor:pointer;background-color:#0000;border-radius:20px;margin:1.5rem auto 0;padding:.7rem 1.5rem;font-size:.9rem;font-weight:500;transition:all .3s;display:block}.show-more-button:hover{background-color:var(--gold);color:var(--dark-blue);transform:translateY(-1px);box-shadow:0 4px 12px #ffc1074d}.no-rsvps{text-align:center;color:var(--slate);padding:2rem;font-style:italic}.no-rsvps p{opacity:.7;margin:0}.rsvp-list-container::-webkit-scrollbar{width:6px}.rsvp-list-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.rsvp-list-container::-webkit-scrollbar-thumb{background:#ffc1074d;border-radius:10px}.rsvp-list-container::-webkit-scrollbar-thumb:hover{background:#ffc10780}@media (max-width:768px){.rsvp-summary{gap:1rem}.summary-item{min-width:70px;padding:.8rem 1rem}.summary-count{font-size:1.5rem}.rsvp-card{padding:.9rem 1rem}.rsvp-name{font-size:1rem}.rsvp-badge{width:24px;height:24px;margin-left:.75rem;font-size:.8rem}}@media (max-width:480px){.rsvp-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.rsvp-badge{align-self:flex-end;margin-left:0}.summary-item{min-width:60px;padding:.7rem .8rem}}.rsvp-entries::-webkit-scrollbar{width:8px}.rsvp-entries::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}.rsvp-entries::-webkit-scrollbar-thumb{background:var(--gold);border-radius:10px}.rsvp-entries::-webkit-scrollbar-thumb:hover{background:#d39e00}.loading-spinner{flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.spinner{border:4px solid #0000;border-bottom:4px solid var(--gold);border-radius:50%;width:40px;height:40px;animation:1.5s cubic-bezier(.68,-.55,.265,1.55) infinite smile-spin;position:relative}.spinner:before,.spinner:after{content:"";background-color:var(--gold);border-radius:50%;width:6px;height:6px;position:absolute;top:10px}.spinner:before{left:4px}.spinner:after{right:4px}@keyframes smile-spin{0%{opacity:.5;transform:rotate(0)}50%{opacity:1;transform:rotate(180deg)}to{opacity:.5;transform:rotate(360deg)}}.sparkle-hover{position:relative;overflow:hidden}.sparkle-hover:after{content:"";pointer-events:none;background:linear-gradient(90deg,#fff0 0%,#ffc1074d 50%,#fff0 100%);width:200%;height:200%;animation:6s cubic-bezier(.4,0,.2,1) infinite glint-sweep;position:absolute;top:-50%;left:-50%;transform:rotate(30deg)translateY(-50%)translate(-150%)}.sparkle-btn{position:relative;overflow:hidden}.sparkle-btn:before{content:"";background:linear-gradient(90deg,#0000,#fff9,#0000);width:50%;height:100%;animation:4s ease-in-out infinite button-shine;position:absolute;top:0;left:-100%;transform:skew(-20deg)}@keyframes glint-sweep{0%,70%{transform:rotate(30deg)translateY(-50%)translate(-150%)}to{transform:rotate(30deg)translateY(-50%)translate(150%)}}@keyframes button-shine{0%,60%{left:-100%}to{left:200%}}@media (max-width:768px){.rsvp-stats{gap:1.5rem}.stat-item{min-width:100px;padding:1rem}.stat-number{font-size:2rem}.rsvp-header{flex-direction:column;align-items:flex-start;gap:.5rem}.rsvp-name{font-size:1.1rem}}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 2px #ffc10733}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}#form-message{text-align:center;border-radius:8px;margin-top:1rem;padding:1rem;font-weight:700;transition:all .3s}#form-message.success{color:#4caf50;background-color:#4caf5033;border:1px solid #4caf50}#form-message.error{color:#f44336;background-color:#f4433633;border:1px solid #f44336}.floating-elements{pointer-events:none;z-index:1;width:100%;height:100%;position:fixed;top:0;left:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in-up{animation:.8s ease-out fadeInUp}button{cursor:pointer;transition:all .3s}button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ffc1074d}button:active{transform:translateY(0)}.quote{padding:2rem;font-style:italic;line-height:1.8;position:relative}.quote:before{color:var(--gold);opacity:.3;font-family:serif;font-size:4rem;position:absolute;top:0;left:0}.quote:after{color:var(--gold);opacity:.3;font-family:serif;font-size:4rem;position:absolute;bottom:0;right:0}.section-divider{background:linear-gradient(90deg, transparent, var(--gold), transparent);width:300px;height:2px;margin:3rem auto}@keyframes graduationFloat{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-10px)rotate(2deg)}}.graduation-cap{animation:3s ease-in-out infinite graduationFloat}.rsvp-list-compact{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#142414e6;border:1px solid #ffc10726;border-radius:20px;margin:3rem 0;padding:2rem;position:relative;overflow:hidden;box-shadow:0 8px 32px #0000004d}.rsvp-list-compact:before{content:"";background:linear-gradient(90deg, transparent, var(--gold), transparent);height:1px;position:absolute;top:0;left:0;right:0}.compact-stats{justify-content:center;gap:1rem;margin-bottom:2rem;display:flex}.stat-bubble{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;border:1px solid #ffffff1a;border-radius:50px;align-items:center;gap:.75rem;padding:1rem 1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.stat-bubble:before{content:"";-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:xor;-webkit-mask-composite:xor;opacity:0;background:linear-gradient(45deg,#0000,#ffc10733,#0000);border-radius:50px;padding:1px;transition:opacity .3s;position:absolute;inset:0}.stat-bubble:hover:before{opacity:1}.stat-bubble.attending{background:#4caf501a;border-color:#4caf5033}.stat-bubble.not-attending{background:#f443361a;border-color:#f4433633}.stat-bubble.total{background:#ffc1071a;border-color:#ffc10733}.stat-icon{background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;display:flex}.stat-info{flex-direction:column;align-items:flex-start;display:flex}.stat-number{color:var(--gold);font-size:1.4rem;font-weight:700;line-height:1}.stat-label{color:var(--slate);opacity:.8;margin-top:.15rem;font-size:.75rem}.compact-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.compact-card{will-change:transform;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff0d;border-radius:12px;padding:1.25rem;transition:transform .2s,border-color .2s;position:relative;overflow:hidden}.compact-card:before{display:none}.compact-card:hover:before{opacity:1}.compact-card:hover{background:#ffffff14;border-color:#ffc1074d;transform:translateY(-2px);box-shadow:0 4px 15px #0003}.card-header{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;position:relative;box-shadow:inset 0 0 5px #00000080}.status-dot:before{display:none}.status-dot.attending,.status-dot.attending:before{background:#4caf50}.status-dot.not-attending,.status-dot.not-attending:before{background:#f44336}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:0;transform:scale(1.5)}}.card-name{color:var(--light-slate);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:1rem;font-weight:600;overflow:hidden}.card-preview{border-left:3px solid var(--gold);background:#0003;border-radius:12px;margin-bottom:.5rem;padding:.75rem;position:relative}.quote-icon{color:var(--gold);opacity:.6;font-size:.7rem;position:absolute;top:.5rem;left:.75rem}.preview-text{color:var(--slate);margin-left:1rem;font-size:.85rem;font-style:italic;line-height:1.4;display:block}.expand-hint{color:var(--gold);opacity:.5;font-size:.7rem;transition:opacity .2s;position:absolute;bottom:.5rem;right:.75rem}.compact-card:hover .expand-hint{opacity:1}.card-time{color:var(--slate);opacity:.6;text-align:right;font-size:.7rem}.magic-show-more{color:var(--gold);cursor:pointer;background:0 0;border:1px solid #ffc1074d;border-radius:50px;margin:2rem auto 0;padding:.875rem 2rem;font-weight:500;transition:all .3s;display:block;position:relative;overflow:hidden}.magic-show-more:before{content:"";background:linear-gradient(45deg,#0000,#ffc1071a,#0000);transition:transform .6s;position:absolute;inset:0;transform:translate(-100%)}.magic-show-more:hover:before{transform:translate(100%)}.magic-show-more:hover{border-color:var(--gold);background:#ffc1070d;transform:translateY(-2px);box-shadow:0 8px 25px #ffc10726}.magic-text{z-index:2;align-items:center;gap:.5rem;display:flex;position:relative}.rsvp-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);contain:layout;isolation:isolate;padding:1rem;animation:.3s fadeIn;position:fixed;z-index:99999!important;justify-content:center!important;align-items:center!important;width:100vw!important;height:100vh!important;margin:0!important;display:flex!important;inset:0!important;transform:none!important}body.modal-open{overflow:hidden!important}.rsvp-modal-overlay *{box-sizing:border-box}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.rsvp-modal{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid #ffc1074d;border-radius:20px;flex-direction:column;width:90vw;max-width:500px;max-height:85vh;margin:0 auto;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;display:flex;position:relative;overflow:hidden;box-shadow:0 25px 80px #000000b3;background:#142414fa!important}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid #ffffff1a;align-items:flex-start;gap:1rem;padding:2rem 2rem 1rem;display:flex;position:relative}.modal-avatar{background:linear-gradient(135deg, var(--gold), #ffca2c);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex;box-shadow:0 4px 20px #ffc1074d}.avatar-text{color:var(--dark-blue);font-size:1.5rem;font-weight:700}.modal-info{flex:1}.modal-name{color:var(--white);margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.modal-status{flex-direction:column;gap:.25rem;display:flex}.status-badge{border-radius:50px;align-items:center;gap:.25rem;width:fit-content;padding:.25rem .75rem;font-size:.8rem;font-weight:500;display:inline-flex}.status-badge.attending{color:#4caf50;background:#4caf5033;border:1px solid #4caf504d}.status-badge.not-attending{color:#f44336;background:#f4433633;border:1px solid #f443364d}.modal-time{color:var(--slate);opacity:.7;font-size:.75rem}.modal-close{width:32px;height:32px;color:var(--slate);cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{color:#f44336;background:#f4433633}.modal-content{flex:1;min-height:0;padding:1.5rem 2rem 2rem;overflow-y:auto}.message-container{border-left:4px solid var(--gold);background:#0003;border-radius:16px;padding:1.5rem;position:relative}.quote-decoration{color:var(--gold);opacity:.3;font-size:1.5rem;position:absolute}.quote-decoration:first-child{top:.5rem;left:.75rem}.quote-decoration:last-child{bottom:.5rem;right:.75rem}.full-message{color:var(--light-slate);margin:0;padding:0 1rem;font-size:1rem;font-style:italic;line-height:1.6}.loading-shimmer{animation:2s infinite shimmer}.shimmer-stats{justify-content:center;gap:1rem;margin-bottom:2rem;display:flex}.shimmer-item{background:linear-gradient(90deg,#ffffff0d 25%,#ffffff1a 50%,#ffffff0d 75%) 0 0/200% 100%;border-radius:50px;width:120px;height:60px;animation:1.5s infinite loading}.shimmer-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.shimmer-card{background:linear-gradient(90deg,#ffffff0d 25%,#ffffff1a 50%,#ffffff0d 75%) 0 0/200% 100%;border-radius:16px;height:120px;animation:1.5s infinite loading}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;color:var(--slate);padding:3rem 1rem}.empty-icon{opacity:.5;margin-bottom:1rem;font-size:3rem}.empty-state p{opacity:.7;font-style:italic}@media (max-width:768px){.compact-stats{gap:.75rem}.stat-bubble{gap:.5rem;padding:.75rem 1rem}.stat-icon{width:28px;height:28px;font-size:1rem}.stat-number{font-size:1.2rem}.compact-grid{grid-template-columns:1fr;gap:.75rem}.compact-card{padding:1rem}.rsvp-modal{width:95vw!important;max-width:450px!important;max-height:90vh!important;margin:0!important}.modal-header{padding:1.5rem 1.5rem 1rem}.modal-content{padding:1rem 1.5rem 1.5rem}}@media (max-width:480px){.compact-stats{flex-wrap:wrap;gap:.5rem}.stat-bubble{flex:1;justify-content:center;min-width:100px;padding:.75rem}.stat-info{align-items:center}.rsvp-modal-overlay{padding:.5rem!important}.rsvp-modal{width:98vw!important;max-width:400px!important;max-height:85vh!important;margin:0!important}.modal-avatar{width:40px;height:40px}.avatar-text{font-size:1.2rem}.modal-name{font-size:1.1rem}}
