.elementor-5736 .elementor-element.elementor-element-284ee87{--display:flex;--min-height:100vh;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-5736 .elementor-element.elementor-element-284ee87:not(.elementor-motion-effects-element-type-background), .elementor-5736 .elementor-element.elementor-element-284ee87 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-position:top center;background-repeat:no-repeat;background-size:cover;}.elementor-5736 .elementor-element.elementor-element-284ee87.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-5736 .elementor-element.elementor-element-1baeaac{--display:flex;border-style:solid;--border-style:solid;border-width:1px 1px 1px 1px;--border-top-width:1px;--border-right-width:1px;--border-bottom-width:1px;--border-left-width:1px;border-color:#BC5A5A;--border-color:#BC5A5A;--border-radius:20px 20px 20px 20px;--margin-top:50px;--margin-bottom:50px;--margin-left:0px;--margin-right:0px;}.elementor-5736 .elementor-element.elementor-element-1baeaac.e-con{--align-self:center;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:23px;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-23px;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group.recaptcha_v3-bottomleft, .elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}body.rtl .elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-labels-inline .elementor-field-group > label{padding-left:0px;}body:not(.rtl) .elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-labels-inline .elementor-field-group > label{padding-right:0px;}body .elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-labels-above .elementor-field-group > label{padding-bottom:0px;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group > label{font-family:"Amiri", Sans-serif;font-size:19px;font-weight:400;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-type-html{padding-bottom:0px;font-family:"Amiri", Sans-serif;font-size:58px;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group .elementor-field{color:#000000;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group .elementor-field, .elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-subgroup label{font-family:"Cormorant Garamond", Sans-serif;font-size:19px;font-weight:500;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#FFFFFF00;border-color:#00000030;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group .elementor-select-wrapper select{background-color:#FFFFFF00;border-color:#00000030;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group .elementor-select-wrapper::before{color:#00000030;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-button{font-family:"Amiri", Sans-serif;font-size:18px;text-transform:capitalize;border-style:none;}.elementor-5736 .elementor-element.elementor-element-2abf463 .e-form__buttons__wrapper__button-next{color:#FFFFFF;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-button[type="submit"]{color:#FFFFFF;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-button[type="submit"] svg *{fill:#FFFFFF;}.elementor-5736 .elementor-element.elementor-element-2abf463 .e-form__buttons__wrapper__button-previous{color:#FFFFFF;}.elementor-5736 .elementor-element.elementor-element-2abf463 .e-form__buttons__wrapper__button-next:hover{color:#ffffff;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-button[type="submit"]:hover{color:#ffffff;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-5736 .elementor-element.elementor-element-2abf463 .e-form__buttons__wrapper__button-previous:hover{color:#ffffff;}.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-message{font-family:"Cormorant Garamond", Sans-serif;}.elementor-5736 .elementor-element.elementor-element-2abf463{--e-form-steps-indicators-spacing:20px;--e-form-steps-indicator-padding:30px;--e-form-steps-indicator-inactive-secondary-color:#ffffff;--e-form-steps-indicator-active-secondary-color:#ffffff;--e-form-steps-indicator-completed-secondary-color:#ffffff;--e-form-steps-divider-width:1px;--e-form-steps-divider-gap:10px;}@media(min-width:768px){.elementor-5736 .elementor-element.elementor-element-284ee87{--content-width:100%;}.elementor-5736 .elementor-element.elementor-element-1baeaac{--width:50%;}}@media(max-width:1550px) and (min-width:768px){.elementor-5736 .elementor-element.elementor-element-1baeaac{--width:65%;}}@media(max-width:1199px) and (min-width:768px){.elementor-5736 .elementor-element.elementor-element-1baeaac{--width:70%;}}@media(max-width:1199px){.elementor-5736 .elementor-element.elementor-element-1baeaac{--margin-top:50px;--margin-bottom:50px;--margin-left:0px;--margin-right:0px;}}@media(max-width:767px){.elementor-5736 .elementor-element.elementor-element-1baeaac{--margin-top:45px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}}/* Start custom CSS for form, class: .elementor-element-2abf463 *//* Main form container */
.wedding-rsvp-form {
    background-color: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(5px);
    /*border-radius: 12px;*/
    padding: 40px;
    /*box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.6);*/
    max-width: 800px;
    margin: 0 auto;
    position: relative;
}

/* Input fields */
.wedding-rsvp-form .elementor-field-textual {
    border: 2px solid rgba(188, 90, 90, 0.4);
    border-radius: 8px;
    padding: 14px 18px;
    background-color: rgba(255, 255, 255, 0.9);
    transition: all 0.3s ease;
    font-family: 'Cormorant Garamond', serif;
    font-size: 16px;
}

.wedding-rsvp-form .elementor-field-textual:focus {
    border-color: #bc5a5a;
    background-color: white;
    box-shadow: 0 0 0 4px rgba(188, 90, 90, 0.1);
}

/* Select fields */
.wedding-rsvp-form select.elementor-field-textual {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23bc5a5a' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: calc(100% - 15px) center;
    padding-right: 40px;
}

/* Radio buttons and checkboxes */
.wedding-rsvp-form .elementor-field-type-radio .elementor-field-subgroup,
.wedding-rsvp-form .elementor-field-type-checkbox .elementor-field-subgroup {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin-top: 5px;
}

.wedding-rsvp-form .elementor-field-option {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}

.wedding-rsvp-form .elementor-field-option input[type="radio"],
.wedding-rsvp-form .elementor-field-option input[type="checkbox"] {
    appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(188, 90, 90, 0.4);
    border-radius: 100%;
    margin-right: 8px;
    position: relative;
    transition: all 0.2s ease;
}

.wedding-rsvp-form .elementor-field-option input[type="checkbox"] {
    border-radius: 4px;
}

.wedding-rsvp-form .elementor-field-option input[type="radio"]:checked,
.wedding-rsvp-form .elementor-field-option input[type="checkbox"]:checked {
    border-color: #bc5a5a;
    background-color: #bc5a5a;
}

.wedding-rsvp-form .elementor-field-option input[type="radio"]:checked::after,
.wedding-rsvp-form .elementor-field-option input[type="checkbox"]:checked::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: white;
}

.wedding-rsvp-form .elementor-field-option input[type="checkbox"]:checked::after {
    width: 10px;
    height: 6px;
    border-radius: 0;
    border-left: 2px solid white;
    border-bottom: 2px solid white;
    transform: translate(-50%, -60%) rotate(-45deg);
}

/* Field labels */
.wedding-rsvp-form .elementor-field-label {
    color: #333;
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 8px;
}

/* Required indicator */
.wedding-rsvp-form .elementor-field-required:after {
    color: #bc5a5a;
}

/* Form title */
.wedding-form-title {
    font-family: 'Cormorant Garamond', serif;
    color: #bc5a5a;
    font-size: 32px;
    text-align: center;
    margin-bottom: 20px;
    font-weight: 600;
    letter-spacing: 1px;
}

/* Form description */
.wedding-form-description {
    font-family: 'Cormorant Garamond', serif;
    color: #555;
    font-size: 18px;
    text-align: center;
    margin-bottom: 30px;
    line-height: 1.5;
}

/* Section titles */
.wedding-section-title {
    font-family: 'Cormorant Garamond', serif;
    color: #bc5a5a;
    font-size: 22px;
    margin-top: 30px;
    margin-bottom: 15px;
    font-weight: 600;
    border-bottom: 1px solid rgba(188, 90, 90, 0.2);
    padding-bottom: 8px;
}

/*Removing surrounding padding from field entry*/
.elementor-kit-5322 input:not([type="button"]):not([type="submit"]), .elementor-kit-5322 textarea, .elementor-kit-5322 .elementor-field-textual {
    padding: 0px 0px 0px 0px;
}

/*Removing bottom margin from field's label*/
.elementor-form .elementor-field-group-full_name label {
    margin-bottom: 1px;
}

.elementor-form .elementor-field-group-meal_preference label {
    margin-bottom: 3px;
}

.elementor-form .elementor-field-group-kids_meals label {
    margin-bottom: 3px;
}

.elementor-form .elementor-field-group-baby_chairs label {
    margin-bottom: 3px;
}

.elementor-form .elementor-field-group-message label {
    margin-bottom: 8px;
}

.elementor-form .elementor-field-group-morning_ceremony_guests label {
    margin-bottom: 1px;
}

.elementor-form .elementor-field-group-evening_reception_guests label {
    margin-bottom: 1px;
}

.elementor-form .elementor-field-group-meal_preference_number label {
    margin-bottom: 1px;
}

.elementor-form .elementor-field-group-kids_meals_number label {
    margin-bottom: 1px;
}

.elementor-form .elementor-field-group-baby_chairs_number label {
    margin-bottom: 1px;
}

/*Adding bottom margin below each field*/
/*.elementor-5736 .elementor-element.elementor-element-2abf463 .elementor-field-group {
    margin-bottom: 23px;
}


/* Hide reCAPTCHA badge */
.grecaptcha-badge {
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Add disclosure text below Send button with proper spacing */
.wedding-rsvp-form .elementor-field-type-submit::after {
    content: "This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.";
    display: block;
    font-family: 'Amiri', serif;
    font-size: 10px;
    color: rgba(0, 0, 0, 0.15);
    line-height: 1.4;
    margin-top: 30px;
    text-align: left;
    width: 100%;
    clear: both;
    position: relative;
}

/* Alternative with clickable links - requires HTML approach */
.recaptcha-disclosure {
    font-family: 'Amiri', serif;
    font-size: 13px;
    color: rgba(0, 0, 0, 0.35);
    line-height: 1.4;
    margin-top: 20px;
    text-align: left;
    max-width: 100%;
}

.recaptcha-disclosure a {
    color: rgba(188, 90, 90, 0.7);
    text-decoration: none;
}

.recaptcha-disclosure a:hover {
    color: rgba(188, 90, 90, 0.9);
    text-decoration: underline;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-1baeaac */.elementor-5736 .elementor-element.elementor-element-1baeaac {
    max-height: 90vh; /* Adjust this value as needed */
    overflow-y: auto;
    /*padding-right: 10px; /* Prevents content from touching scrollbar */
}

@media screen and (max-width: 480px){
.elementor-5736 .elementor-element.elementor-element-1baeaac {
    max-height: 75vh; /* Adjust this value as needed */
    overflow-y: auto;
    /*padding-right: 10px; /* Prevents content from touching scrollbar */
}
}/* End custom CSS */
/* Start custom CSS */body, html {
    height: 100vh !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Comprehensive fix for oval radio buttons */
body .elementor-field-type-radio input[type="radio"],
body .elementor-form-field-type-radio input[type="radio"],
body form input[type="radio"],
body .elementor input[type="radio"] {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    width: 20px !important;
    height: 20px !important;
    border: 2px solid rgba(188, 90, 90, 0.4) !important;
    border-radius: 50% !important;
    margin: 0 8px 0 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    display: inline-block !important;
    vertical-align: middle !important;
    transform: none !important;
    outline: none !important;
    overflow: hidden !important;
    position: relative !important;
    flex: 0 0 20px !important;
    min-width: 20px !important;
    max-width: 20px !important;
    min-height: 20px !important;
    max-height: 20px !important;
}

body .elementor-field-type-radio input[type="radio"]:checked,
body .elementor-form-field-type-radio input[type="radio"]:checked,
body form input[type="radio"]:checked,
body .elementor input[type="radio"]:checked {
    border-color: #bc5a5a !important;
    background-color: white !important;
}

body .elementor-field-type-radio input[type="radio"]:checked::after,
body .elementor-form-field-type-radio input[type="radio"]:checked::after,
body form input[type="radio"]:checked::after,
body .elementor input[type="radio"]:checked::after {
    content: "" !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 10px !important;
    height: 10px !important;
    border-radius: 50% !important;
    background-color: #bc5a5a !important;
}

/* Fix for radio button container */
body .elementor-field-option {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
}

body .elementor-field-option label {
    display: flex !important;
    align-items: center !important;
    line-height: normal !important;
}

/* Submit button - Your original custom styling */
.wedding-rsvp-form .elementor-button {
    background-color: #bc5a5a;
    color: white;
    border-radius: 8px;
    padding: 15px 35px;
    font-family: 'Cormorant Garamond', serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 1px;
    box-shadow: 0 4px 10px rgba(188, 90, 90, 0.2);
    transition: all 0.3s ease;
    text-transform: uppercase;
}

.wedding-rsvp-form .elementor-button:hover {
    background-color: #a34545;
    transform: translateY(-2px);
    box-shadow: 0 6px 15px rgba(188, 90, 90, 0.3);
}

/* Button wrapper for centering */
.wedding-rsvp-form .elementor-field-type-submit {
    margin-top: 30px;
    text-align: center;
}

/* Hide Elementor's built-in spinner completely */
.elementor-form-spinner,
.elementor-button .elementor-form-spinner,
.elementor-form .elementor-form-spinner {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
}

/* Loading spinner styles - Shows spinner next to text */
.wedding-rsvp-form .elementor-button.loading,
.elementor-form .elementor-button.loading,
body .elementor-button.loading,
.elementor-button.loading {
    pointer-events: none !important;
    opacity: 0.8 !important;
    position: relative !important;
    /* Maintain your custom color during loading */
    background-color: #bc5a5a !important;
}

/* Keep the text visible and add spinner before it */
.wedding-rsvp-form .elementor-button.loading .elementor-button-text,
.elementor-form .elementor-button.loading .elementor-button-text,
body .elementor-button.loading .elementor-button-text,
.elementor-button.loading .elementor-button-text {
    opacity: 1 !important;
    visibility: visible !important;
}

/* Add our custom spinning icon before the text - single spinner only */
.wedding-rsvp-form .elementor-button.loading .elementor-button-text::before,
.elementor-form .elementor-button.loading .elementor-button-text::before,
body .elementor-button.loading .elementor-button-text::before,
.elementor-button.loading .elementor-button-text::before {
    content: '' !important;
    display: inline-block !important;
    width: 16px !important;
    height: 16px !important;
    margin-right: 8px !important;
    border: 2px solid rgba(255,255,255,0.3) !important;
    border-top: 2px solid white !important;
    border-radius: 50% !important;
    animation: elementor-loading-spin 1s linear infinite !important;
    vertical-align: middle !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Keyframe animation for our custom spinner */
@keyframes elementor-loading-spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}/* End custom CSS */