@import "https://fonts.googleapis.com/css?family=Roboto:100,300,400,700,900|Barlow:100,300,400,700,900|Arial:100,300,400,700,900&display=swap";html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{font-size:100%;font:inherit;vertical-align:baseline;border:0;margin:0;padding:0}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}table{border-collapse:collapse;border-spacing:0}@font-face{font-family:UTM-Azkia;src:url(https://statics.pancake.vn/web-media/35/7a/ab/a5/2bcc8b3414fa20782f68d8d552b13313f2a24e5b267a97b3cf3a5ec3.ttf)format("truetype");font-display:swap}@font-face{font-family:UTM-Cafeta;src:url(https://statics.pancake.vn/web-media/04/eb/01/7a/e19221a44fabb6fd54c6339fd43b1c25ebbe20e97f6633beed4cbc79.ttf)format("truetype");font-display:swap}@font-face{font-family:Ephesis-Regular;src:url(https://statics.pancake.vn/web-media/65/48/68/4f/ca5a0c732f276b6fef504eddf0e2d6cdf65cf198b0440dde6d90c5a8.ttf)format("truetype");font-display:swap}:root{--font-roboto:"Roboto",sans-serif;--font-barlow:"Barlow",sans-serif;--font-arial:"Arial",sans-serif;--font-utm-azkia:"UTM-Azkia",serif;--font-utm-cafeta:"UTM-Cafeta",serif;--font-ephesis:"Ephesis-Regular",cursive}body{font-family:var(--font-roboto);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}.welcome-screen{z-index:9999;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.welcome-screen.exiting{opacity:0;pointer-events:none;transform:scale(1.05)}.welcome-screen:before{content:"";opacity:.5;background:url("data:image/svg+xml,%3Csvg width=%2760%27 height=%2760%27 viewBox=%270 0 60 60%27 xmlns=%27http://www.w3.org/2000/svg%27%3E%3Cg fill=%27none%27 fill-rule=%27evenodd%27%3E%3Cg fill=%27%23ffffff%27 fill-opacity=%270.03%27%3E%3Cpath d=%27M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z%27/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;top:0;bottom:0;left:0;right:0}.welcome-screen .welcome-content{text-align:center;color:#fff;z-index:1;padding:2rem;animation:.8s slideUp;position:relative}.welcome-screen .welcome-ornament{margin-bottom:1rem;font-size:4rem;animation:2s infinite pulse}.welcome-screen .welcome-subtitle{font-family:var(--font-utm-cafeta),serif;letter-spacing:3px;text-transform:uppercase;color:#ffffffb3;margin-bottom:.5rem;font-size:1rem}.welcome-screen .welcome-title{font-family:var(--font-great-vibes),cursive;-webkit-text-fill-color:#0000;text-shadow:none;background:linear-gradient(135deg,#f5d5c8 0%,#e8b4a8 50%,#d4a088 100%);-webkit-background-clip:text;background-clip:text;margin:0 0 1rem;font-size:2rem;font-weight:400}.welcome-screen .welcome-date{font-family:var(--font-barlow),sans-serif;letter-spacing:2px;color:#fffc;margin-bottom:2rem;font-size:1.1rem}.welcome-screen .welcome-button{font-family:var(--font-barlow),sans-serif;color:#1a1a2e;cursor:pointer;background:linear-gradient(135deg,#e8b4a8 0%,#d4a088 100%);border:none;border-radius:50px;align-items:center;gap:.5rem;padding:1rem 2.5rem;font-size:1rem;font-weight:600;transition:all .3s;display:inline-flex;box-shadow:0 4px 20px #e8b4a866}.welcome-screen .welcome-button:hover{transform:translateY(-2px);box-shadow:0 6px 30px #e8b4a899}.welcome-screen .welcome-button:active{transform:translateY(0)}.welcome-screen .welcome-button .button-icon{font-size:1.2rem;animation:1s infinite bounce}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.page-view{z-index:1;opacity:0;max-width:420px;margin:0 auto;transition:opacity .6s .2s,transform .6s .2s;position:relative;overflow:hidden;transform:translateY(20px)}.page-view.visible{opacity:1;transform:translateY(0)}.music-control{z-index:1000;pointer-events:none;opacity:0;transition:opacity .5s .3s;position:fixed;top:20px;right:20px}.music-control.visible{opacity:1}.music-control .music-control-container{-webkit-backdrop-filter:blur(20px);pointer-events:auto;opacity:.9;background:#0009;border:1px solid #ffffff1a;border-radius:50px;align-items:center;gap:0;width:40px;padding:8px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 2px 10px #0000004d}.music-control .music-control-container:hover{opacity:1;background:#000000b3;box-shadow:0 4px 15px #0006}.music-control .music-control-container.expanded{background:#000000bf;gap:12px;width:180px;padding:8px 12px}.music-control .music-control-container .music-icon-button{cursor:pointer;color:#fff;filter:drop-shadow(0 1px 2px #0000004d);background:#ffffff26;border:1px solid #fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;min-width:32px;height:32px;transition:all .2s;display:flex}.music-control .music-control-container .music-icon-button svg{fill:currentColor;width:18px;height:18px}.music-control .music-control-container .music-icon-button:hover{background:#ffffff40;border-color:#ffffff4d;transform:scale(1.05)}.music-control .music-control-container .music-icon-button:active{transform:scale(.95)}.music-control .music-control-container .volume-slider-wrapper{opacity:0;flex:1;justify-content:center;align-items:center;width:0;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.music-control .music-control-container.expanded .volume-slider-wrapper{opacity:1;width:100%}.music-control .music-control-container .volume-slider{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:0 0;border-radius:2px;outline:none;align-self:center;width:100%;height:16px;margin:0;position:relative}.music-control .music-control-container .volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background:#fff;border:none;border-radius:50%;width:12px;height:12px;margin-top:-4.5px;transition:all .2s;box-shadow:0 2px 6px #00000080}.music-control .music-control-container .volume-slider::-webkit-slider-thumb:hover{transform:scale(1.3);box-shadow:0 3px 10px #0009}.music-control .music-control-container .volume-slider::-moz-range-thumb{cursor:pointer;background:#fff;border:none;border-radius:50%;width:12px;height:12px;transition:all .2s;box-shadow:0 2px 6px #00000080}.music-control .music-control-container .volume-slider::-moz-range-thumb:hover{transform:scale(1.3);box-shadow:0 3px 10px #0009}.music-control .music-control-container .volume-slider::-webkit-slider-runnable-track{background:#ffffff4d;border-radius:2px;height:4px}.music-control .music-control-container .volume-slider::-moz-range-track{background:#ffffff4d;border-radius:2px;height:3px}.music-control .music-control-container .volume-slider::-ms-thumb{cursor:pointer;background:#fff;border:none;border-radius:50%;width:12px;height:12px;box-shadow:0 2px 6px #00000080}.music-control .music-control-container .volume-slider::-ms-track{background:#ffffff4d;border-radius:2px;height:3px}@media (max-width:480px){.music-control .music-control-container{width:36px;padding:6px;top:15px;right:15px}.music-control .music-control-container.expanded{width:160px;padding:6px 10px}.music-control .music-control-container .music-icon-button{width:28px;height:28px;font-size:14px}}.floating-button{z-index:999;pointer-events:none;opacity:0;transition:opacity .5s .4s,transform .5s .4s;position:fixed;bottom:20px;left:20px;transform:translateY(20px)}.floating-button.visible{opacity:1;transform:translateY(0)}.floating-button button{color:#fff;cursor:pointer;pointer-events:auto;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);opacity:.8;background:#005fbc78;border:none;border-radius:50px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .3s;display:flex}.floating-button button:before{content:"💝";font-size:16px}.floating-button button:hover{opacity:1;background:#005fbcc9}.floating-button button:active{transform:scale(.95)}.thank-you-section{text-align:center;margin-top:1rem;padding:.5rem 0}.thank-you-section h2{font-family:var(--font-barlow);color:#374151;text-transform:uppercase;letter-spacing:2px;margin:0 0 .5rem;font-size:1.8rem;font-weight:400}.thank-you-section p{font-family:var(--font-utm-cafeta);color:#4b5563;margin:0 0 1rem;font-size:1.2rem}.thank-you-section hr{border:none;border-top:1px solid #d1d5db;width:60px;margin:0 auto}.wedding-invitation{background-image:url(/static/image/TUAN6732.f629b219.webp);background-position:50%;background-size:cover;height:90vh;position:relative}.wedding-invitation .title{color:#000;width:100%;font-family:var(--font-utm-azkia);text-align:center;text-shadow:0 4px 4px #fff;margin:0;font-size:3.25rem;position:absolute;top:2%;transform:rotate(358deg)perspective(1044px)}.wedding-invitation .invitation-content{position:absolute;bottom:10%;left:5%}.wedding-invitation .invitation-content .divider{border:.5px solid #000;margin:5px 0}.wedding-invitation .invitation-content .sub-title,.wedding-invitation .invitation-content .time,.wedding-invitation .invitation-content .date{text-align:center;font-size:1.25rem}.wedding-invitation .invitation-content .sub-title{font-family:var(--font-barlow)}.wedding-invitation .invitation-content .time,.wedding-invitation .invitation-content .date{font-size:1.325rem}.wedding-invitation-card{text-align:center;max-width:1200px;padding:0 20px}.wedding-invitation-card .line-container{border:1px solid #536077;width:130px}.wedding-invitation-card .invitation-header{flex-direction:column;align-items:center;margin-bottom:24px;display:flex}.wedding-invitation-card .invitation-header .title{font-family:var(--font-ephesis);color:#000;font-size:36px;font-weight:400}.wedding-invitation-card .invitation-header .subtitle{letter-spacing:1px;text-align:center;border-style:solid;border-color:#e5e7eb;margin-top:-10px;font-family:Arial,sans-serif;font-size:13px}.wedding-invitation-card .invitation-footer{justify-content:center;width:100%;margin-top:24px;display:flex}.wedding-invitation-card .photo-gallery{grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;gap:10px;max-width:900px;margin:0 auto;display:grid}.wedding-invitation-card .photo-gallery .photo-item{aspect-ratio:3/5;border-radius:4px;width:100%;position:relative;overflow:hidden}.wedding-invitation-card .photo-gallery .photo-item:nth-child(2){aspect-ratio:2/4}.wedding-invitation-card .photo-gallery .photo-item img{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.wedding-invitation-card .photo-gallery .photo-item:hover img{transform:scale(1.05)}.wedding-party{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#f5e6d346 0%,#f5e6d38f 100%);border-radius:20px;max-width:500px;margin:2rem auto;padding:32px;box-shadow:0 4px 4px #00000014}.wedding-party .title{text-transform:uppercase;letter-spacing:1.5px;color:#000;margin:0 0 16px;font-size:20px;font-weight:700}.wedding-party .time{color:#4a5568;font-size:18px;font-weight:600}.wedding-party .date{color:#2d3748;letter-spacing:1px;font-size:26px;font-weight:700}.wedding-party .lunar-date{color:#718096;margin-bottom:24px;font-size:12px;font-style:italic}.wedding-party .location{margin-bottom:12px}.wedding-party .location .address{color:#4a5568;background:#fffc;border:1px solid #eaecf0cc;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin:0 auto;padding:6px;font-size:14px;font-style:normal;line-height:1.4;display:flex}.wedding-party .location .address:before{content:"📍";font-size:16px}.wedding-party .map-container{border-radius:16px;height:250px;margin-bottom:16px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.wedding-party .map-container iframe{border:none;border-radius:16px;width:100%;height:100%}.wedding-party .location-action{justify-content:center;gap:12px;display:flex}.wedding-party .confirm-button{color:#fff;cursor:pointer;background:#005fbcc9;border:none;border-radius:12px;min-width:180px;padding:12px 24px;font-size:16px;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #7ac1424d}.wedding-party .confirm-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.wedding-party .confirm-button:active{transform:translateY(0)}.wedding-party .map-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);border:none;border-radius:12px;justify-content:center;align-items:center;min-width:180px;padding:12px 24px;font-size:16px;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex;box-shadow:0 4px 15px #f093fb4d}.wedding-party .map-button:hover{color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 6px 20px #f093fb66}.wedding-party .map-button:active{transform:translateY(0)}@media (max-width:768px){.wedding-party{margin:1rem 16px;padding:24px 20px}.wedding-party .title{font-size:18px}.wedding-party .date{font-size:22px}.wedding-party .confirm-button,.wedding-party .map-button{min-width:140px;padding:10px 20px;font-size:14px}.wedding-party .location-action{flex-direction:column;gap:8px}}.wedding-family{text-align:center;font-family:var(--font-playfair);color:#2e2e2e;background:#fff;padding:1rem 1.25rem}.wedding-family .quote{font-style:italic;font-family:var(--font-ephesis);text-align:center;margin-bottom:30px;font-size:26px;line-height:1}.wedding-family .families{flex-direction:row;justify-content:space-around;gap:5.25rem;margin-bottom:10px;display:flex}.wedding-family .families .family{width:50%}.wedding-family .families .family h4{font-weight:600;font-family:var(--font-utm-cafeta);text-align:center;margin-bottom:10px;font-size:20px}.wedding-family .families .family p{font-size:.95rem;line-height:1.4;font-family:var(--font-utm-cafeta);text-align:center;margin:0;font-size:16px}.wedding-family .heart{background-image:url(https://content.pancake.vn/1/s546x546/fwebp/9f/06/d9/3a/4f89683f3c43ed295fd5da05de67d0db47eb178a7d68b96e19166749.png);background-size:cover;width:140px;height:140px;margin:-2.875rem auto 0}.wedding-family .couple{flex-wrap:wrap;justify-content:space-around;margin-top:-2.5rem;display:flex}.wedding-family .couple .groom h5,.wedding-family .couple .bride h5{font-weight:500;font-family:var(--font-utm-cafeta);text-align:center;margin-bottom:0;font-size:20px}.wedding-family .couple .groom h3,.wedding-family .couple .bride h3{font-family:var(--font-ephesis);color:#2c2c2c;margin-bottom:.938rem;font-size:2.4rem}.wedding-family .couple .couple-image{box-sizing:border-box;background:#e2ecff;border-style:solid;border-color:#e5e7eb;border-radius:.375rem;justify-content:center;gap:.625rem;width:100%;padding:.625rem;display:flex}.wedding-family .couple .couple-image .image-wrapper{box-sizing:border-box;background-color:#f0f0f080;border-radius:6px;flex-grow:0;flex-shrink:0;width:calc(50% - .3125rem);min-width:calc(50% - .3125rem);max-width:calc(50% - .3125rem);height:309px;min-height:309px;max-height:309px;position:relative;overflow:hidden}.wedding-family .couple .couple-image img{object-fit:cover;border-radius:6px;width:100%;height:100%;display:block}.wedding-album{max-width:1200px;padding:0 1.25rem}.wedding-album .album-header{justify-content:flex-start;align-items:center;margin-bottom:.625rem;display:flex}.wedding-album .album-header .title{font-family:var(--font-ephesis);white-space:nowrap;color:#111;margin:0;font-size:2rem}.wedding-album .album-header .line-right{background:#cfcfcf;flex:1;height:1px;margin-left:.75rem}.wedding-album .album-grid{column-count:2;column-gap:.6rem;max-width:900px;margin:-1rem auto}.wedding-album .album-grid.offset-right:before{content:"";width:100%;height:2.5rem;display:block}.wedding-album .album-grid .album-item{break-inside:avoid;border-radius:.375rem;width:100%;margin:0;display:inline-block;overflow:hidden;box-shadow:0 2px 8px #0000000f}.wedding-album .album-grid .album-item img{width:100%;height:auto;transition:transform .3s;display:block}.wedding-album .album-grid .album-item:hover img{transform:scale(1.03)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background-color:#00000080;justify-content:center;align-items:flex-end;padding:0;animation:.25s ease-out fadeIn;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal-container{transform-origin:bottom;background:#fffffffa;border-radius:20px 20px 0 0;flex-direction:column;align-items:center;width:100%;height:70vh;padding:25px 20px;animation:.3s cubic-bezier(.4,0,.2,1) slideUpIn;display:flex;position:relative;box-shadow:0 -4px 20px #00000026}.modal-container::-webkit-scrollbar{width:5px}.modal-container::-webkit-scrollbar-track{background:0 0}.modal-container::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}@media (min-width:768px){.modal-container{max-width:600px;margin:0 auto}}.modal-title{color:#333;text-align:center;margin:5px 0 15px;font-size:1.5em;font-weight:600}.modal-description{color:#666;text-align:center;max-width:400px;margin-bottom:14px;font-size:.95em;line-height:1.5}.close-button{cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border:none;border-radius:50%;justify-content:center;width:32px;height:32px;padding:5px;font-size:1.4em;transition:all .2s;display:flex;position:absolute;top:-40px;right:10px}.close-button:hover{background:#ffffff4d;transform:scale(1.1)}.close-button:active{background:#ffffff40;transform:scale(.95)}@media (min-width:768px){.close-button{right:0}}.close-button-top{cursor:pointer;color:#666;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:5px;font-size:1.4em;transition:all .2s;display:flex;position:absolute;top:10px;right:10px}.close-button-top:hover{color:#333;background:#0000000d}.close-button-top:active{background:#0000001a;transform:scale(.95)}.modal-content{width:100%;padding:0 5px}@keyframes slideUpIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}.confirmation-form{width:100%;margin:0 auto}.confirmation-form .form-group{margin-bottom:1rem}.confirmation-form .form-group label{color:#444;margin-bottom:8px;font-size:1em;font-weight:500;display:block}.confirmation-form .form-group label.required:after{content:"*";color:#ff4d4f;margin-left:4px}.confirmation-form .form-group input,.confirmation-form .form-group textarea,.confirmation-form .form-group select{box-sizing:border-box;background:#ffffffe6;border:1px solid #537ec46b;border-radius:8px;width:100%;padding:12px;font-size:1em;transition:all .3s}.confirmation-form .form-group input:hover,.confirmation-form .form-group textarea:hover,.confirmation-form .form-group select:hover{background:#fff;border-color:#bbb}.confirmation-form .form-group input:focus,.confirmation-form .form-group textarea:focus,.confirmation-form .form-group select:focus{background:#fff;border-color:#537ec46b;outline:none}.confirmation-form .form-group textarea{resize:vertical;min-height:120px}.confirmation-form .form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27currentColor%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27%3e%3cpolyline points=%276 9 12 15 18 9%27%3e%3c/polyline%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:1em;padding-right:40px}.confirmation-form .form-row{gap:12px;margin-bottom:20px;display:flex}.confirmation-form .form-row .flex-1{flex:1}.confirmation-form .submit-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#005fbcc9 0% 100%);border:none;border-radius:8px;width:100%;margin-top:15px;padding:12px 24px;font-size:1.1em;transition:all .3s;box-shadow:0 2px 8px #69a53933}.confirmation-form .submit-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #69a5394d}.confirmation-form .submit-button:active{transform:translateY(1px)}.wish-form{padding:20px}.wish-form .form-group{margin-bottom:20px}.wish-form .form-group label{color:#333;margin-bottom:8px;font-weight:500;display:block}.wish-form .form-group input,.wish-form .form-group textarea{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fffc;border:1px solid #537ec46b;border-radius:8px;width:100%;padding:12px;font-size:16px;transition:all .3s}.wish-form .form-group input:focus,.wish-form .form-group textarea:focus{border-color:#537ec46b;outline:none}.wish-form .form-group input::placeholder,.wish-form .form-group textarea::placeholder{color:#999}.wish-form .form-group textarea{resize:vertical;min-height:100px}.wish-form .submit-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#005fbcc9 0% 100%);border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:all .3s;display:flex}.wish-form .submit-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #005fbcc9}.wish-form .submit-button:active{transform:translateY(0)}