.form-input,.form-submit{font-family:'Cormorant Garamond',serif}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(39,39,42,.7);display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;visibility:hidden;transition:var(--transition)}.modal-overlay.active{opacity:1;visibility:visible}.modal-container{background-color:var(--light-color);border-radius:30px;padding:2.5rem;width:100%;max-width:500px;position:relative;transform:translateY(-20px);transition:transform .3s;box-shadow:0 10px 30px rgba(0,0,0,.1)}.form-input,.form-submit,.modal-close{transition:var(--transition)}.modal-overlay.active .modal-container{transform:translateY(0)}.modal-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background-color:var(--light-gray);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer}.form-submit,.modal-close:hover{background-color:var(--primary-color)}.modal-close:after,.modal-close:before{content:'';position:absolute;width:20px;height:2px;background-color:var(--dark-color)}.modal-close:before{transform:rotate(45deg)}.modal-close:after{transform:rotate(-45deg)}.modal-header{text-align:center;margin-bottom:1.5rem}.modal-title{color:var(--secondary-color);font-size:2rem;font-weight:400;margin-bottom:.5rem}.modal-description{color:var(--dark-color);opacity:.8}.modal-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:1.1rem;color:var(--dark-color)}.form-input{padding:.8rem 1.2rem;border:1px solid var(--primary-color);border-radius:15px;font-size:1rem}.form-input:focus{outline:0;border-color:var(--secondary-color);box-shadow:0 0 0 2px rgba(61,94,140,.2)}.form-error{color:#e53935;font-size:.85rem;margin-top:.3rem;min-height:1rem}#checkout-view-thank-you #close-thank-you-btn,.form-submit{margin-top:1rem}.form-input.error{border-color:#e53935}.form-submit{color:var(--dark-color);border:none;border-radius:15px;padding:1rem;font-size:1.1rem;cursor:pointer}.form-submit:hover{background-color:var(--secondary-color);color:var(--light-color)}.modal-loader{display:none;justify-content:center;align-items:center;padding:3rem 0;width:100%}.loader-spinner{width:50px;height:50px;border:4px solid var(--light-gray);border-top:4px solid var(--secondary-color);border-radius:50%;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.modal-message{text-align:center;padding:2rem;display:none}.modal-message.success{display:block}.modal-message.error{display:block;color:#e53935}@media (max-width:576px){.modal-container{padding:1.5rem;max-width:90%}.modal-title{font-size:1.8rem}}.checkout-items-summary-class ul.checkout-item-list{list-style:none;padding:.75rem;max-height:200px;overflow-y:auto;margin-bottom:1rem;border:1px solid var(--light-gray,#eee);border-radius:var(--border-radius,15px)}.checkout-item{display:flex;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--light-gray,#f0f0f0)}.checkout-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.checkout-item-image{width:60px;height:60px;object-fit:cover;margin-right:1rem;border-radius:var(--border-radius-small,8px);border:1px solid var(--light-gray,#eee)}.checkout-item-details{flex-grow:1;display:flex;justify-content:space-between;align-items:center;gap:.5rem}.checkout-item-name{font-size:.95em;color:var(--dark-color,#333);flex-basis:70%}.checkout-item-price{font-size:.95em;font-weight:600;color:var(--primary-color,#3d5e8c);white-space:nowrap;flex-basis:30%;text-align:right}.checkout-total-summary-class{text-align:right;font-size:1.3em;font-weight:700;margin:1rem 0 1.5rem;color:var(--secondary-color,#333)}.checkout-contact-title{font-size:1.2rem;color:var(--secondary-color,#333);margin-bottom:1rem;text-align:left;border-top:1px solid var(--light-gray,#eee);padding-top:1rem}#checkout-view-thank-you .modal-title{color:var(--success-color,#27ae60)}.checkout-modal-container{max-height:90vh;overflow-y:auto}.error-message{color:#e53935;font-size:.85rem;margin-top:.3rem;display:block;opacity:0;animation:.3s forwards errorFadeIn;font-weight:500}@keyframes errorFadeIn{to{opacity:1}}.form-input.shake{animation:.6s ease-in-out shake}@keyframes shake{0%,100%{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}.input-active{background-color:rgba(61,94,140,.05)!important;transform:scale(1.02)}