@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{cursor:pointer}.envelope-container{height:400px;perspective:1000px;position:relative;transition:transform .3s ease;width:400px}.envelope-container:hover{transform:scale(1.05)}.envelope{filter:drop-shadow(0 20px 50px rgba(0,0,0,.5));height:240px;margin:0 auto;position:relative;transform-style:preserve-3d;width:350px}.envelope-body{background:repeating-linear-gradient(45deg,#f8f2e3,#f8f2e3 2px,#f4e4b8 0,#f4e4b8 4px),linear-gradient(135deg,#e8d7a8,#d4af37);border:4px double #8b7355;border-radius:10px;box-shadow:0 20px 50px #00000080,inset 0 -3px 15px #0003,inset 0 3px 15px #fff6;height:100%;position:absolute;width:100%}.envelope-body:before{color:#8b735526;content:"✦";font-size:4rem;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%)}.envelope-body:after{border:2px solid #8b735566;border-radius:6px;bottom:15px;box-shadow:inset 0 0 20px #d4af3733;content:"";left:15px;pointer-events:none;position:absolute;right:15px;top:15px}.envelope-flap{background:repeating-linear-gradient(-45deg,#d4af37,#d4af37 3px,#c9a332 0,#c9a332 6px),linear-gradient(135deg,#e8d7a8,#b8941f);border:4px double #8b7355;border-bottom:none;border-radius:10px 10px 0 0;box-shadow:0 10px 30px #0006,inset 0 3px 12px #ffffff80,inset 0 -2px 8px #0003;-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,#8b735599 10%,#fffc 50%,#8b735599 90%,#0000);box-shadow:0 1px 4px #fff9,0 -1px 2px #0000004d;content:"";height:3px;top:8%;width:70%}.envelope-flap:after,.envelope-flap:before{left:50%;position:absolute;transform:translateX(-50%)}.envelope-flap:after{color:#8b735566;content:"❖";font-size:1.2rem;text-shadow:0 1px 2px #ffffff80;top:12%}.envelope-seal{align-items:center;background:radial-gradient(circle at 35% 35%,#f4e4b8 0,#d4af37 40%,#b8941f 70%,#8b7355 100%);border:3px ridge #8b7355cc;border-radius:50%;box-shadow:0 0 40px #d4af37,0 8px 20px #00000080,inset 0 3px 10px #fff9,inset 0 -3px 10px #0000004d;display:flex;height:85px;justify-content:center;left:50%;overflow:hidden;position:absolute;top:32%;transform:translate(-50%,-50%);transition:transform 1.8s cubic-bezier(.4,0,.2,1),opacity 1.2s ease;width:85px;z-index:3}.envelope-seal:before{animation:rotate 10s linear infinite;background:conic-gradient(from 0deg,#0000 0deg,#fff6 90deg,#0000 180deg,#0003 270deg,#0000 1turn);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:15px;color:#5a4a3a;font-family:Great Vibes,cursive;font-size:2rem;font-weight:400;left:60%;letter-spacing:2px;opacity:.75;position:absolute;text-shadow:1px 1px 2px #0000001a,0 0 3px #ffffff4d;transform:translateX(-10px) rotate(-5deg);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:#fff;border-radius:8px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;height:180px;justify-content:center;left:50%;opacity:0;padding:25px;position:absolute;text-align:center;top:48%;transform:translate(-50%) scale(.8);transition:all 1.8s cubic-bezier(.4,0,.2,1);width:280px;z-index:1}.invitation-preview .elegant-title{font-size:1.8rem;margin-bottom:8px}.preview-text{color:#666;font-family:Cormorant Garamond,serif;font-size:1.2rem}.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{opacity:1;top:15%;transform:translate(-50%) scale(1);transform:translate(-50%,-50%) scale(1);z-index:4}.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,#f8f9fa);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,#f8f9fa,#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}.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-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:.7;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}.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]: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;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}.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{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:30px 0}.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}.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}.suggestion-box h3{color:#1a1a2e;font-family:Cormorant Garamond,serif;font-size:1.8rem;font-weight:600;margin-bottom:15px}.suggestion-box p{color:#5a6c7d;font-size:1rem;line-height:1.6}.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{padding:15px}.detail-icon{font-size:1.5rem;min-width:30px}}
/*# sourceMappingURL=main.91664d69.css.map*/