/* CSS Document */

#owner-form .form-error.visited:not(:focus),
#owner-form .form-error.visited:not(:focus) + .select2-container > .selection > .select2-selection { background: var(--field-error-background-color) !important; }
#owner-form .select2-container.error { background: none !important; }
#owner-form .select2-container--dvcrequest-grey.error .select2-selection--single { background: #f4f4f4; }
#owner-form .control-group.error div.alert.alert-danger { display: none; }
#owner-form section.box .select2-container { width: 100% !important; }

#instructions-section { width: 750px; max-width: 90vw; margin: 30px auto 0; }
#owner-information-section { width: 750px; max-width: 90vw; margin: 30px auto; }


section.box { background: #fff; border-radius: 8px; padding: 28px 50px; box-shadow: 0 10px 20px rgba(0, 0, 0, 0.05); }
section.box input { background: #f5f5f5; border-radius: 12px; border: 0; width: 100%; padding: 14px 16px; margin-bottom: 12px; }

section.box p:has(small) { line-height: 1; font-size: 14px; color: #000; font-weight: 300; font-style: italic; margin-bottom: 2rem; }

#owner-details-section { width: 600px; max-width: 90vw; margin: 30px auto; }
#owner-details-section .control-group.checkbox { text-align: center; }
#owner-details-section .control-group.checkbox label { display: block; }

#emergency-contact-section { width: 750px; max-width: 90vw; margin: 30px auto; }
#emergency-contact-section label[for="emergency-contact-first-name"] { margin-bottom: 10px; }

#listing-points-header-section { width: 750px; max-width: 90vw; margin: 30px auto; text-align: center; }
#listing-points-header-section label { display: block; }
#listing-points-header-section .radio-toggle { margin-top: 0; width: 300px; height: 52px; }
#listing-points-header-section #home-resorts { width: 300px; }

#confirmed-reservations-header-section { width: 750px; max-width: 90vw; margin: 30px auto; text-align: center; }
#confirmed-reservations-header-section label { display: block; }
#confirmed-reservations-header-section .radio-toggle { margin-top: 0; width: 300px; height: 52px; }
#confirmed-reservations-header-section #existing-reservations { width: 300px; }

.listing-points-section,
.confirmed-reservations-section { width: 600px; max-width: 90vw; margin: 30px auto; }
.listing-points-section .select2-container,
.confirmed-reservations-section .select2-container { display: block; }
.listing-points-section label { line-height: 1.2; }
.listing-points-section label div { line-height: 1; }
.listing-points-section p { line-height: 1; }
body.fixed-form .listing-points-section .radio-toggle,
body.fixed-form .confirmed-reservations-section .radio-toggle { height: 50px; margin-top: 0; margin-bottom: 12px; }
body.fixed-form .listing-points-section label,
body.fixed-form .confirmed-reservations-section label { line-height: 1.2; }
body.fixed-form .listing-points-section label small,
body.fixed-form .confirmed-reservations-section label small { display: block; line-height: 1.1; color: #717171; font-weight: 300; }

#referrer-section,
#additional-comments,
#recaptcha-section { width: 600px; max-width: 90vw; margin: 0 auto; }

#referrer-section { text-align: center; }
#referrer-section select { width: 300px; }
#referrer-section textarea,
#additional-comments textarea { width: 500px; max-width: 100%; border: 0; background: #f5f5f5; border-radius: 12px; padding: 12px 15px; }

#referrer-comments label { display: block; }
#referrer-section + h2,
#additional-comments + h2 { margin-top: 50px; }

#recaptcha-section .g-recaptcha > div { margin: 0 auto; }


@media ( max-width: 767px ) {
	.select2-container--dvcrequest-grey { margin-bottom: 12px; }
	#owner-information-section .row + label { margin-top: 12px; }
}
@media ( max-width: 440px ) {
	section.box { padding-left: 20px; padding-right: 20px; }
}

/*

#accordionOwnerSignup h2 { letter-spacing: 0.01em; margin-bottom: 25px; border-radius: 16px; }
#accordionOwnerSignup .accordion-item { box-shadow: 0 10px 40px rgba(0,0,0,0.05); border: none; margin-bottom: 100px; border-radius: 16px; }

#accordionOwnerSignup button.accordion-button { color: #1E3A74; font-size: 24px; border-radius: 16px; height: 80px; padding-left: 40px; padding-right: 30px; }
#accordionOwnerSignup button.accordion-button span.status { position: absolute; right: 100px; font-style: italic; color: #1E3A74; font-weight: 300; letter-spacing: 0.01em; }
#accordionOwnerSignup button.accordion-button::after { width: 40px; height: 40px; background-size: 40px; background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%238E4199' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M2 5L8 11L14 5'/%3e%3c/svg%3e")}

#accordionOwnerSignup button.accordion-button:focus { box-shadow: none; }
#accordionOwnerSignup button.accordion-button:not(.collapsed) { background-color: transparent; box-shadow: none; }
#accordionOwnerSignup button.accordion-button[aria-expanded="true"] > span { display: none; }

#accordionOwnerSignup .accordion-collapse { position: relative; top: -50px; }
#accordionOwnerSignup .accordion-body { padding: 0 125px 20px; font-size: 18px; }
#accordionOwnerSignup .accordion-body p { color: #1f1f1f; margin-bottom: 15px; line-height: 1.25; }
#accordionOwnerSignup .accordion-body p small { display: inline-block; font-size: 12px; font-style: italic; }
#accordionOwnerSignup .accordion-body p.required { color: #1E3A74; font-size: 14px; font-style: italic; }

#accordionOwnerSignup label { margin-bottom: 10px; }
#accordionOwnerSignup input,
#accordionOwnerSignup select,
#accordionOwnerSignup textarea { background: #f5f5f5; border-radius: 12px; color: #1f1f1f; border: none; width: 100%; height: 50px; padding-left: 20px; padding-right: 20px; font-size: 14px; margin-bottom: 16px; }
#accordionOwnerSignup input::placeholder,
#accordionOwnerSignup select::placeholder,
#accordionOwnerSignup textarea::placeholder,
#accordionOwnerSignup .select2-container--dvcrequest-grey .select2-selection--single .select2-selection__placeholder { color: #717171; }
#accordionOwnerSignup textarea { height: 150px; }
#accordionOwnerSignup input:focus-visible { outline-color: #8E4199; }

#accordionOwnerSignup label { display: block; }
#accordionOwnerSignup label small { display: block; font-size: 14px; font-style: italic; }
#accordionOwnerSignup .control-group.checkbox { margin-bottom: 5px; }
#accordionOwnerSignup .control-group.checkbox label { display: inline-block; margin-right: 20px; margin-bottom: 0; }
#accordionOwnerSignup .control-group.checkbox .btn-group.yesnoblank { margin-top: -2px; margin-bottom: 2px; }

#accordionOwnerSignup .select2-container { width: 100% !important; }
#accordionOwnerSignup .select2-container--dvcrequest-grey .select2-selection--single .select2-selection__rendered { font-size: 14px; color: #1f1f1f; }

#accordionOwnerSignup p a.btn + a.btn { margin-left: 10px; }
*/