@import url(https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400;500;600;700&family=Montserrat:wght@300;400;500&family=Great+Vibes&display=block);body{font-family:Montserrat,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Montserrat,sans-serif}.intro-screen{align-items:center;cursor:pointer;display:flex;height:100%;justify-content:center;width:100%}.envelope-container{height:auto;max-width:100%;padding-bottom:80px;perspective:1000px;position:relative;transition:transform .3s ease;width:min(400px,90vw)}.envelope-container:hover{transform:scale(1.05)}.envelope{filter:drop-shadow(0 20px 50px rgba(0,0,0,.5));height:min(240px,54.88vw);margin:0 auto;position:relative;transform-style:preserve-3d;width:min(350px,80vw)}.envelope-body{background:linear-gradient(145deg,#ffffff4d,#0000 50%,#0000001a),repeating-linear-gradient(0deg,#fdfbf7,#fdfbf7 1px,#f9f6f0 0,#f9f6f0 2px),linear-gradient(135deg,#faf8f3,#f5f0e8);border:3px solid #d4af37;border-radius:12px;box-shadow:0 25px 60px #0006,0 10px 20px #0003,inset 0 1px 0 #fffc,inset 0 -1px 0 #0000001a,inset -2px 0 8px #d4af3733,inset 2px 0 8px #d4af3733;height:100%;overflow:hidden;position:absolute;position:relative;width:100%}.envelope-body:before{background:radial-gradient(circle at center,#d4af3714 0,#d4af370a 50%,#0000 70%);border:1px solid #d4af3726;border-radius:50%;height:120px;left:50%;top:50%;transform:translate(-50%,-50%);width:120px}.envelope-body:after,.envelope-body:before{content:"";pointer-events:none;position:absolute}.envelope-body:after{border:1px solid #d4af3740;border-radius:8px;bottom:12px;box-shadow:0 0 0 1px #ffffff80,inset 0 2px 4px #0000000d,inset 0 0 30px #d4af3714;left:12px;right:12px;top:12px}.envelope-flap{background:linear-gradient(145deg,#fff6,#0000 40%,#0000000d),repeating-linear-gradient(0deg,#f5ede0,#f5ede0 1px,#f0e6d5 0,#f0e6d5 2px),linear-gradient(180deg,#f8f3ea,#ebe2d1);border:3px solid #d4af37;border-bottom:none;border-radius:12px 12px 0 0;box-shadow:0 15px 45px #00000059,0 5px 15px #0003,inset 0 2px 0 #fffc,inset 0 -8px 15px #00000014,inset -2px 0 10px #d4af3726,inset 2px 0 10px #d4af3726;-webkit-clip-path:polygon(0 0,100% 0,50% 65%);clip-path:polygon(0 0,100% 0,50% 65%);height:100%;position:absolute;transform-origin:top;transition:transform 1.8s cubic-bezier(.4,0,.2,1);width:100%;z-index:2}.envelope-flap:before{background:linear-gradient(90deg,#0000,#d4af374d 15%,#d4af37b3 50%,#d4af374d 85%,#0000);box-shadow:0 1px 0 #fffc,0 0 10px #d4af374d;height:1px;top:12%;width:75%}.envelope-flap:after,.envelope-flap:before{content:"";left:50%;position:absolute;transform:translateX(-50%)}.envelope-flap:after{background:radial-gradient(circle,#d4af3726 0,#0000 70%);border-radius:50%;height:40px;top:10%;width:40px}.envelope-seal{align-items:center;border-radius:50%;display:flex;height:min(90px,20vw);justify-content:center;left:50%;overflow:hidden;position:absolute;top:55%;transform:translate(-50%,-50%);transition:transform 1.8s cubic-bezier(.4,0,.2,1),opacity 1.2s ease;width:min(90px,20vw);z-index:3}.envelope-seal:before{animation:rotate 10s linear infinite;border-radius:50%;bottom:-5px;content:"";left:-5px;pointer-events:none;position:absolute;right:-5px;top:-5px}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.envelope-signature{bottom:18px;color:#3d3227;filter:contrast(1.1);font-family:Great Vibes,cursive;font-size:min(2.2rem,5.5vw);font-weight:400;left:60%;letter-spacing:1px;opacity:.85;position:absolute;text-shadow:0 1px 1px #0003,0 0 8px #d4af3733;transform:translateX(-10px) rotate(-3deg);z-index:1}.seal-image{border-radius:50%;display:block;height:100%;object-fit:cover;object-position:center;width:100%}.invitation-preview{align-items:center;background:linear-gradient(180deg,#fff 0,#fdfcfa);border:1px solid #d4af3733;border-radius:8px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;height:0;justify-content:center;left:50%;opacity:0;overflow:hidden;padding:0 min(25px,5vw);position:absolute;text-align:center;top:100%;transform:translate(-50%,-50%);transition:all 2s cubic-bezier(.4,0,.2,1);width:min(280px,70vw);z-index:1}.invitation-preview .elegant-title{font-size:min(1.8rem,5vw);margin-bottom:8px}.preview-text{color:#666;font-family:Cormorant Garamond,serif;font-size:min(1.2rem,4vw)}.click-hint{animation:pulse 2s infinite;bottom:-50px;color:#f4e4b8;font-size:1rem;left:50%;position:absolute;text-align:center;transform:translateX(-50%)}@keyframes pulse{0%,to{opacity:.6;transform:translateX(-50%) translateY(0)}50%{opacity:1;transform:translateX(-50%) translateY(-5px)}}.envelope-container.opening .envelope-flap{transform:rotateX(-180deg)}.envelope-container.opening .envelope-seal{opacity:0;transform:translate(-50%,-50%) scale(0)}.envelope-container.opening .invitation-preview{animation:slideUp 2s cubic-bezier(.4,0,.2,1) forwards;height:min(200px,50vw);opacity:1;padding:min(25px,5vw);top:-20%;z-index:4}@keyframes slideUp{0%{height:0;opacity:0;padding-bottom:0;padding-top:0;top:100%}30%{opacity:1}to{height:min(200px,50vw);opacity:1;padding:min(25px,5vw);top:-20%}}.envelope-container.opening .click-hint{opacity:0}.App{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:0;position:relative}.App:before{background-image:radial-gradient(circle at 20% 50%,#ffd7001a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffd7001a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.invitation-card{animation:fadeIn .8s ease-out;background:linear-gradient(145deg,#fff,#e8eaec);border-radius:20px;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffd70033;display:flex;flex-direction:column;justify-content:center;max-width:100%;min-height:100vh;padding:60px 80px;position:relative;text-align:center;width:100%;z-index:1}.success-card{padding:80px 40px;text-align:center}.ornament-bottom,.ornament-top{background:linear-gradient(90deg,#0000,#d4af37 20%,#f4e4b8 50%,#d4af37 80%,#0000);height:2px;margin:0 auto 30px;width:100%}.ornament-bottom{margin:30px auto 0}.birthday-number{animation:shimmer 3s ease-in-out infinite;border-radius:10px;color:#d4af37;display:inline-block;font-family:Cormorant Garamond,serif;font-size:5.5rem;font-weight:300;letter-spacing:8px;line-height:.9;margin:-10px auto 15px;overflow:visible;padding:15px 40px;position:relative;text-align:center;text-shadow:0 2px 10px #d4af3780,1px 1px 2px #0000001a,-1px -1px 2px #ffffff80}@keyframes shimmer{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}.elegant-title{color:#1a1a2e;font-family:Cormorant Garamond,serif;font-size:3.5rem;font-weight:300;letter-spacing:3px;margin-bottom:20px;text-align:center;text-transform:uppercase}.divider{background:linear-gradient(90deg,#d4af37,#f4e4b8,#d4af37);border-radius:2px;height:3px;margin:30px auto;width:60px}.event-details{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr;margin:40px 0}.event-occasion{color:#2c3e50;font-family:Cormorant Garamond,serif;font-size:1.8rem;font-weight:500;margin-bottom:10px;text-align:center}.detail-item{align-items:center;background:linear-gradient(135deg,#e8eaec,#fff);border-left:4px solid #d4af37;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:20px;margin:0;padding:25px;position:relative;transition:transform .3s ease,box-shadow .3s ease}.detail-item:hover{box-shadow:0 4px 12px #d4af3726;transform:translateY(-2px)}.detail-item.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.detail-item.clickable:hover{background:linear-gradient(135deg,#fffef8,#fff);border-left-color:#f4e4b8;box-shadow:0 6px 20px #d4af374d;transform:translateY(-3px)}.detail-item.clickable:hover .detail-arrow{color:#f4e4b8;opacity:1;transform:translateX(5px)}.detail-item.clickable:active{background:linear-gradient(135deg,#fffef8,#fff);box-shadow:0 2px 8px #d4af3733;transform:scale(.98)}.detail-item.clickable:active .detail-arrow{color:#f4e4b8;transform:translateX(3px)}@keyframes subtle-pulse{0%,to{opacity:.9}50%{opacity:1}}.detail-item.clickable .detail-arrow{animation:subtle-pulse 2s ease-in-out infinite}.detail-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:2.5rem;left:25px;min-width:50px;position:absolute;text-align:center}.detail-content{flex:1 1;margin:0 70px;text-align:center}.detail-arrow{color:#d4af37;font-size:3rem;font-weight:300;opacity:.9;position:absolute;right:25px;transition:transform .3s ease,color .3s ease}.detail-label{color:#7f8c8d;font-size:.8rem;font-weight:600;letter-spacing:1.5px;margin-bottom:8px;text-transform:uppercase}.detail-value{color:#1a1a2e;font-family:Cormorant Garamond,serif;font-size:1.7rem;font-weight:600;line-height:1.2;margin-bottom:3px}.detail-subvalue{color:#5a6c7d;font-size:1.05rem;font-style:italic;margin-top:2px}.rsvp-form{margin-top:40px}.form-title{color:#1a1a2e;font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:600;margin-bottom:10px;text-align:center}.form-subtitle{color:#7f8c8d;font-size:.95rem;font-style:italic;margin-bottom:30px;text-align:center}.plusone-section{background:linear-gradient(135deg,#d4af3708,#d4af3714);border:2px solid #d4af3733;border-radius:12px;box-shadow:0 2px 8px #d4af371a;margin:20px 0;padding:20px}.plusone-section:before{border-bottom:1px solid #d4af3733;color:#d4af37;content:"👥 Informazioni +1";display:block;font-size:.85rem;font-weight:600;letter-spacing:1px;margin-bottom:15px;padding-bottom:10px;text-transform:uppercase}.form-group{margin-bottom:25px}.form-group label{color:#2c3e50;display:block;font-size:.9rem;font-weight:500;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.form-group input[type=text]{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-family:Montserrat,sans-serif;font-size:1rem;padding:14px 18px;transition:all .3s ease;width:100%}.form-group input[type=text]#cognome,.form-group input[type=text]#cognomePlusOne,.form-group input[type=text]#nome,.form-group input[type=text]#nomePlusOne{color:#1a1a2e;font-family:Great Vibes,cursive;font-size:1.5rem;padding:16px 18px}.form-group input[type=text]#cognome::placeholder,.form-group input[type=text]#cognomePlusOne::placeholder,.form-group input[type=text]#nome::placeholder,.form-group input[type=text]#nomePlusOne::placeholder{font-family:Montserrat,sans-serif;font-size:1rem}.form-group input[type=text]:focus{border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a;outline:none}.form-select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-family:Montserrat,sans-serif;font-size:1rem;padding:14px 18px;transition:all .3s ease;width:100%}.form-select:focus{border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a;outline:none}.checkbox-group{margin:30px 0;text-align:left}.checkbox-label{align-items:center;background:#f8f9fa;border-radius:8px;color:#2c3e50;cursor:pointer;display:flex;font-size:1rem;gap:15px;justify-content:flex-start;padding:15px;text-align:left;transition:all .3s ease}.checkbox-label:hover{background:#eff1f3}.checkbox-label input[type=checkbox]{accent-color:#d4af37;cursor:pointer;flex-shrink:0;height:20px;margin:0;vertical-align:middle;width:20px}.checkbox-label span{display:inline-block;line-height:1;vertical-align:middle}.intolleranze-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:10px;text-align:left}.intolleranza-item{align-items:center;background:#f8f9fa;border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;gap:10px;justify-content:flex-start;padding:10px 12px;text-align:left;transition:all .2s ease}.intolleranza-item:hover{background:#eff1f3;border-color:#d4af37}.intolleranza-item input[type=checkbox]{accent-color:#d4af37;cursor:pointer;flex-shrink:0;height:18px;margin:0;width:18px}.intolleranza-item span{color:#2c3e50;font-size:.95rem;line-height:1.2}.submit-button{background:linear-gradient(135deg,#d4af37,#f4e4b8);border:none;border-radius:10px;box-shadow:0 4px 15px #d4af3766;color:#1a1a2e;cursor:pointer;font-family:Montserrat,sans-serif;font-size:1.1rem;font-weight:600;letter-spacing:2px;margin-top:20px;padding:16px;text-transform:uppercase;transition:all .3s ease;-webkit-user-select:none;user-select:none;width:100%}.submit-button:hover:not(:disabled){box-shadow:0 6px 20px #d4af3799;transform:translateY(-2px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{cursor:not-allowed;opacity:.6}.error-message{background:#fee;border-left:3px solid #c33;border-radius:8px;color:#c33;font-size:.9rem;margin-bottom:20px;padding:12px}.confirmation-text{color:#1a1a2e;font-family:Cormorant Garamond,serif;font-size:1.8rem;font-weight:500;margin:30px 0 15px}.confirmation-subtext{color:#7f8c8d;font-size:1.1rem;margin-bottom:30px}.calendar-button{align-items:center;background:linear-gradient(135deg,#d4af37,#f4e4b8);border:none;border-radius:10px;box-shadow:0 4px 15px #d4af3766;color:#1a1a2e;cursor:pointer;display:inline-flex;font-family:Montserrat,sans-serif;font-size:1rem;font-weight:600;gap:8px;margin:20px 0;padding:14px 28px;transition:all .3s ease;-webkit-user-select:none;user-select:none}.calendar-button:hover{box-shadow:0 6px 20px #d4af3799;transform:translateY(-2px)}.calendar-button:active{transform:translateY(0)}.modal-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{-ms-overflow-style:none;animation:slideIn .3s ease;background:linear-gradient(135deg,#fff,#f8f9fa);border:3px solid #d4af37;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:700px;overflow-y:auto;padding:40px;position:relative;scrollbar-width:none;width:100%}.modal-content::-webkit-scrollbar{display:none}@keyframes slideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#7f8c8d;cursor:pointer;display:flex;font-size:2.5rem;height:40px;justify-content:center;line-height:1;position:absolute;right:15px;top:15px;transition:all .3s ease;width:40px}.modal-close:hover{background:#d4af371a;color:#d4af37;transform:rotate(90deg)}.modal-title{color:#1a1a2e;font-family:Cormorant Garamond,serif;font-size:2.5rem;font-weight:600;margin:20px 0;text-align:center}.modal-body{margin:30px 0}.modal-text{color:#2c3e50;font-size:1.1rem;line-height:1.8;margin-bottom:20px;text-align:center}.modal-text strong{color:#d4af37;font-weight:600}.dress-code-suggestions,.dress-suggestions{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:30px 0}.dress-category,.suggestion-box{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #d4af37;border-radius:15px;box-shadow:0 4px 15px #d4af3733;padding:25px;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.dress-category:hover,.suggestion-box:hover{box-shadow:0 8px 25px #d4af374d;transform:translateY(-5px)}.suggestion-icon{display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:3rem;margin-bottom:15px}.dress-category h3,.suggestion-box h3{color:#1a1a2e;font-family:Cormorant Garamond,serif;font-size:1.8rem;font-weight:600;margin-bottom:15px}.dress-category p,.dress-category ul,.suggestion-box p{color:#5a6c7d;font-size:1rem;line-height:1.6}.dress-category ul,.suggestion-box ul{list-style:none;margin:0;padding:0;text-align:left}.dress-category li,.suggestion-box li{padding:8px 0 8px 20px;position:relative}.dress-category li:before,.suggestion-box li:before{color:#d4af37;content:"•";font-size:1.2rem;font-weight:700;left:0;position:absolute}.modal-note{background:#d4af370d;border-left:3px solid #d4af37;border-radius:10px;color:#5a6c7d;font-size:.95rem;margin-top:25px;padding:15px;text-align:center}.modal-note em{color:#7f8c8d;font-style:italic}.modal-footer-text{color:#d4af37;font-family:Great Vibes,cursive;font-size:1.8rem;margin-top:30px;text-align:center}@media (min-width:769px){.App{padding:40px 0}.invitation-card{margin:0 auto;max-width:900px;min-height:calc(100vh - 80px)}.event-details{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(3,1fr);margin:50px 0}.event-occasion{font-size:2.2rem;grid-column:1/-1;margin-bottom:20px}.detail-item{align-items:center;flex-direction:column;justify-content:center;min-height:180px;overflow:visible;padding:35px 25px;position:relative;text-align:center}.detail-item:hover{transform:translateY(-5px)}.detail-item.clickable:hover{transform:translateY(-8px)}.detail-icon{font-size:3rem;left:auto;margin-bottom:15px;position:static}.detail-content{margin:0;width:100%}}@media (max-width:768px){.App{padding:20px}.invitation-card{border-radius:20px;max-width:600px;min-height:auto;padding:40px 25px}.elegant-title{font-size:2.5rem;letter-spacing:2px}.event-occasion{font-size:1.5rem}.detail-value{font-size:1.3rem}.form-title{font-size:1.6rem}}@media (max-width:480px){.App{padding:10px}.invitation-card{padding:30px 20px}.elegant-title{font-size:2rem}.detail-item{height:100px;padding:15px}.detail-icon{font-size:1.5rem;min-width:30px}}.cancellation-banner{align-items:center;background:#0000;border:1px solid #ddd;border-radius:8px;cursor:pointer;display:flex;justify-content:center;margin:20px 0;opacity:.7;padding:10px 15px;transition:all .3s ease}.cancellation-banner:hover{background:#00000005;border-color:#bbb;opacity:1}.cancellation-banner:active{transform:scale(.98)}.banner-icon{flex-shrink:0;font-size:.9rem;line-height:1;margin-right:8px;vertical-align:middle}.banner-text{color:#666;font-family:Montserrat,sans-serif;font-size:.85rem;font-weight:400;line-height:1}.banner-arrow{align-items:center;color:#999;display:flex;flex-shrink:0;font-size:1rem;font-weight:300;margin-left:8px}.cancellation-modal .modal-body{padding:20px 0}.cancellation-modal .form-group{margin-bottom:20px}.cancellation-modal .form-group label{color:#2c3e50;display:block;font-size:.9rem;font-weight:500;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.cancellation-modal .form-group input[type=text]{border:2px solid #e0e0e0;border-radius:10px;font-family:Montserrat,sans-serif;font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.cancellation-modal .form-group input[type=text]#cancel-cognome,.cancellation-modal .form-group input[type=text]#cancel-cognomePlusOne,.cancellation-modal .form-group input[type=text]#cancel-nome,.cancellation-modal .form-group input[type=text]#cancel-nomePlusOne{color:#1a1a2e;font-family:Great Vibes,cursive;font-size:1.5rem;padding:16px 18px}.cancellation-modal .form-group input[type=text]#cancel-cognome::placeholder,.cancellation-modal .form-group input[type=text]#cancel-cognomePlusOne::placeholder,.cancellation-modal .form-group input[type=text]#cancel-nome::placeholder,.cancellation-modal .form-group input[type=text]#cancel-nomePlusOne::placeholder{font-family:Montserrat,sans-serif;font-size:1rem}.cancellation-modal .form-group input[type=text]:focus{border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a;outline:none}@media (max-width:768px){.cancellation-banner{margin:15px 0;padding:8px 12px}.banner-icon{font-size:.85rem}.banner-text{font-size:.8rem}.banner-arrow{font-size:.9rem}}@media (max-width:480px){.cancellation-banner{padding:8px 10px}.banner-text{font-size:.75rem}}
/*# sourceMappingURL=main.c1ed1096.css.map*/