/* =====================================================================
   contact-custom — page-builder component for the Custom Rings template
   All overrides are scoped under .contact_custom_pagebuilder so they
   don't leak into the regular contact-us component.
   ===================================================================== */

section.contact_custom_pagebuilder {
	padding: 60px 0;
	border: 0;
}
.contact_custom_pagebuilder .contact_header {
	margin-bottom: 40px;
}
.contact_custom_pagebuilder .contact_header h2 {
	font-size: 56px;
	margin-bottom: 12px;
}
.contact_custom_pagebuilder .contact_header p {
	font-size: 18px;
	margin-bottom: 0;
}

/* ---- Form column ---- */
.contact_custom_pagebuilder .contact_form {
	background: #fff;
	padding: 1px 40px;
	border-radius: 6px;
}

/* GForms label-above scoped overrides */
.contact_custom_pagebuilder .gform_wrapper .gfield_label {
	display: block !important;
	font-family: 'FoundersGrotesk', sans-serif;
	font-size: 15px;
	font-weight: 500;
	margin-bottom: 8px;
	color: var(--onyx);
	visibility: visible;
}
.contact_custom_pagebuilder .gform_wrapper .gfield_required {
	color: #c0392b;
	margin-left: 2px;
}
.contact_custom_pagebuilder .gform_wrapper .ginput_container input[type="text"],
.contact_custom_pagebuilder .gform_wrapper .ginput_container input[type="email"],
.contact_custom_pagebuilder .gform_wrapper .ginput_container input[type="tel"],
.contact_custom_pagebuilder .gform_wrapper .ginput_container textarea {
	background: var(--pearl-dark);
	border: 0;
	border-radius: 4px;
	padding: 14px 16px;
	font-family: 'FoundersGrotesk', sans-serif;
	font-size: 15px;
	width: 100% !important;
}
.contact_custom_pagebuilder .gform_wrapper .ginput_container textarea {
	min-height: 120px;
	resize: vertical;
}
.contact_custom_pagebuilder .gform_wrapper .gform_fields {
	display: flex;
	flex-wrap: wrap;
	gap: 14px 20px;
}
.contact_custom_pagebuilder .gform_wrapper .gform_fields .gfield {
	flex: 1 1 100%;
	max-width: 100%;
	padding: 0;
	margin: 0;
}

/* Email + Phone two-column on desktop. Targets gf_left_half / gf_right_half
   if set on the form, with a fallback for forms that don't use those classes. */
@media (min-width: 768px) {
	.contact_custom_pagebuilder .gform_wrapper .gform_fields .gfield.gf_left_half,
	.contact_custom_pagebuilder .gform_wrapper .gform_fields .gfield.gf_right_half {
		flex: 1 1 calc(50% - 10px);
		max-width: calc(50% - 10px);
	}
	.gfield--type-phone{
		padding-right: 0px !important;
	}
}

/* Attachment / file-upload area — style only the outer multifile wrapper.
   GForms nests .gform_drop_area inside .gform_fileupload_multifile, so we
   reset the inner element and decorate only the outer to avoid duplicates. */
.contact_custom_pagebuilder .gform_fileupload_multifile {
	position: relative;
	background: var(--pearl-dark);
	border: 1px dashed var(--onyx);
	border-radius: 4px;
	min-height: 140px;
	padding: 64px 20px 24px;
	text-align: center;
	background-image: none;
}
.contact_custom_pagebuilder .gform_fileupload_multifile .gform_drop_area,
.contact_custom_pagebuilder .gform_fileupload_multifile div[id^="gform_drag_drop_area_"] {
	background: transparent;
	border: 0;
	border-radius: 0;
	padding: 0;
	min-height: 0;
	background-image: none;
}
.contact_custom_pagebuilder .gform_fileupload_multifile::before {
	content: "";
	position: absolute;
	top: 22px;
	left: 50%;
	transform: translateX(-50%);
	width: 28px;
	height: 28px;
	background-image: url(/wp-content/themes/doamoreproject/assets/media/icons/plus-icon.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}
.contact_custom_pagebuilder .gform_wrapper span.gform_drop_instructions,
.contact_custom_pagebuilder .gform_wrapper.gf_browser_chrome input.button.gform_button_select_files,
.contact_custom_pagebuilder .gform_wrapper.gf_browser_safari input.button.gform_button_select_files {
	opacity: 0;
}
.contact_custom_pagebuilder li.gf_custom_submit button {
	opacity: 0;
	position: absolute !important;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.contact_custom_pagebuilder span[id^="gfield_upload_rules_"] {
	display: none;
}
.contact_custom_pagebuilder .gform_fileupload_multifile::after {
	content: "Upload photos, screenshots, or sketches";
	display: block;
	font-family: 'FoundersGrotesk', sans-serif;
	font-size: 15px;
	color: var(--onyx);
	margin-top: -30px;
}

/* Submit button — chamfered (8-point clip-path), inline + centered on desktop */
.contact_custom_pagebuilder .gform_footer {
	display: flex;
	justify-content: center;
	padding-top: 8px;
}
.contact_custom_pagebuilder input#gform_submit_button_1 {
	width: auto;
	min-width: 280px;
	color: var(--pearl);
	background: var(--onyx);
	font-family: 'FoundersGrotesk', sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 18px 40px;
	border: 0;
	border-radius: 0;
	clip-path: polygon(
		12px 0,
		calc(100% - 12px) 0,
		100% 12px,
		100% calc(100% - 12px),
		calc(100% - 12px) 100%,
		12px 100%,
		0 calc(100% - 12px),
		0 12px
	);
}
@media only screen and (min-width: 641px) {
    .contact_custom_pagebuilder .gform_legacy_markup_wrapper textarea.medium {
        height: 100px;
    }
}
@media (max-width: 767.98px) {
	.contact_custom_pagebuilder input#gform_submit_button_1 {
		width: 100%;
		min-width: 0;
	}
}

.contact_custom_pagebuilder .gform_wrapper .ginput_container input[type="text"], .contact_custom_pagebuilder .gform_wrapper .ginput_container input[type="email"], .contact_custom_pagebuilder .gform_wrapper .ginput_container input[type="tel"], .contact_custom_pagebuilder .gform_wrapper .ginput_container textarea{
    padding: 5px 10px !important;
}

/* ---- Right-side info column ---- */
.contact_custom_pagebuilder .contact_info {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding-left: 20px;
}
.contact_custom_pagebuilder .contact_info h3 {
	text-transform: none;
	font-size: 32px;
}
.contact_custom_pagebuilder .contact_hours {
	font-size: 16px;
	color: var(--onyx-light);
	line-height: 1.5;
}

.contact_custom_pagebuilder .contact_info_row {
	display: flex;
	align-items: center;
	gap: 16px;
	background: transparent;
	border: 1px solid var(--pearl-dark);
	border-radius: 6px;
	padding: 14px 16px;
	text-decoration: none;
	color: var(--onyx);
	transition: background-color 0.15s ease, border-color 0.15s ease;
	margin-bottom: 0;
}
.contact_custom_pagebuilder .contact_info_row:hover,
.contact_custom_pagebuilder .contact_info_row:focus {
	background: var(--pearl-dark);
	border-color: var(--pearl-dark);
	color: var(--onyx);
	text-decoration: none;
}

.contact_custom_pagebuilder .contact_info_icon {
	flex: 0 0 auto;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: transparent;
}
.contact_custom_pagebuilder .contact_info_icon svg {
	width: 30px;
	height: 30px;
}

.contact_custom_pagebuilder .contact_info_text {
	flex: 1 1 auto;
	min-width: 0;
}
.contact_custom_pagebuilder .contact_info_text p {
	margin: 0;
	line-height: 1.35;
}
.contact_custom_pagebuilder .contact_info_title {
	font-size: 16px;
}
.contact_custom_pagebuilder .contact_info_subtitle {
	font-size: 14px;
	color: var(--onyx-light);
	margin-top: 2px !important;
}

.contact_custom_pagebuilder .contact_info_chevron {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
}
.contact_custom_pagebuilder .contact_info_chevron svg {
	width: 28px;
	height: 28px;
}

/* ---- Error states ---- */
/* Hide the top "There was a problem…" summary banner */
.contact_custom_pagebuilder .gform_wrapper .gform_validation_errors {
	display: none !important;
}

/* Strip the wrapping red top/bottom borders + tinted bg GF puts on errored fields */
.contact_custom_pagebuilder .gform_wrapper .gfield_error,
.contact_custom_pagebuilder .gform_wrapper .gfield--error {
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	box-shadow: none !important;
}

/* Thin red outline on the errored input itself */
.contact_custom_pagebuilder .gform_wrapper .gfield_error input[type="text"],
.contact_custom_pagebuilder .gform_wrapper .gfield_error input[type="email"],
.contact_custom_pagebuilder .gform_wrapper .gfield_error input[type="tel"],
.contact_custom_pagebuilder .gform_wrapper .gfield_error textarea,
.contact_custom_pagebuilder .gform_wrapper .gfield--error input[type="text"],
.contact_custom_pagebuilder .gform_wrapper .gfield--error input[type="email"],
.contact_custom_pagebuilder .gform_wrapper .gfield--error input[type="tel"],
.contact_custom_pagebuilder .gform_wrapper .gfield--error textarea {
	border: 1px solid #c0392b !important;
	background: var(--pearl-dark);
}

/* Plain red text under the field — no pink bar */
.contact_custom_pagebuilder .gform_wrapper .gfield_validation_message,
.contact_custom_pagebuilder .gform_wrapper .validation_message {
	background: transparent !important;
	border: 0 !important;
	padding: 4px 0 0 !important;
	margin: 0 !important;
	color: #c0392b;
	font-family: 'FoundersGrotesk', sans-serif;
	font-size: 13px;
	line-height: 1.4;
}

/* ---- Mobile: form first, info block stacked below ---- */
@media (max-width: 991.98px) {
	.contact_custom_pagebuilder {
		padding: 40px 0;
	}
	.contact_custom_pagebuilder .contact_header h2 {
		font-size: 36px;
		width: 320px;
		margin-left: auto;
		margin-right: auto;
	}
	.contact_custom_pagebuilder .contact_header p {
		font-size: 16px;
	    width: 320px;
	    margin: auto;
	}
	.contact_custom_pagebuilder .contact_form {
		padding: 24px;
	}
	.contact_custom_pagebuilder .contact_info {
		padding-left: 0;
		margin-top: 32px;
		text-align: center;
	}
	.contact_custom_pagebuilder .contact_info h3,
	.contact_custom_pagebuilder .contact_hours {
		text-align: center;
	}
	.contact_custom_pagebuilder .contact_info_row {
		text-align: left;
	}

}
