/*
Theme Name: Divi Child
Theme URI: http://www.elegantthemes.com/gallery/divi/
Template: Divi
Author: Elegant Themes
Author URI: http://www.elegantthemes.com
Description: Smart. Flexible. Beautiful. Divi is the most powerful theme in our collection.
Version: 5.0.0-public-beta.1.1779488563
Updated: 2026-05-22 18:22:43

*/

.gform_wrapper {
 --grove-red: #C20809; --grove-red-dark: #8B0506; --grove-red-light: #FDF3F3; --grove-red-border: #F0BABA; --grove-black: #1A1A1A; --grove-gray-700: #444444; --grove-gray-500: #666666; --grove-gray-400: #999999; --grove-gray-200: #E0E0E0; --grove-gray-100: #F5F5F5; --grove-white: #ffffff; --grove-radius: 6px; --grove-radius-lg: 8px; --grove-transition: 0.15s ease;}



.gform_wrapper {
 font-family: inherit; color: var(--grove-black);}

.gform_wrapper .gform_body {
 padding: 0;}



.gform_wrapper .gsection {
 border-bottom: 2px solid var(--grove-red); padding-bottom: 10px; margin-bottom: 24px; margin-top: 32px;}

.gform_wrapper .gsection:first-child {
 margin-top: 0;}

.gform_wrapper .gsection_title {
 font-size: 16px; font-weight: 600; color: var(--grove-black); letter-spacing: 0.01em; margin: 0 0 4px;}

.gform_wrapper .gsection_description {
 font-size: 13px; color: var(--grove-gray-500); margin: 0; line-height: 1.5;}



.gform_wrapper .gfield_label {
 font-size: 13px; font-weight: 500; color: var(--grove-gray-700); margin-bottom: 5px; display: block;}

.gform_wrapper .gfield_required {
 color: var(--grove-red); font-weight: 600; margin-left: 2px;}


.gform_wrapper .ginput_complex .ginput_full label,
.gform_wrapper .ginput_complex .ginput_left label,
.gform_wrapper .ginput_complex .ginput_right label {
 font-size: 11px; color: var(--grove-gray-400); font-weight: 400; text-transform: uppercase; letter-spacing: 0.06em; margin-top: 4px;}



.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="number"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="date"],
.gform_wrapper select,
.gform_wrapper textarea {
 width: 100%; font-size: 14px; color: var(--grove-black); background: var(--grove-white); border: 1.5px solid var(--grove-gray-200); border-radius: var(--grove-radius); padding: 9px 12px; line-height: 1.5; transition: border-color var(--grove-transition), box-shadow var(--grove-transition); appearance: none; -webkit-appearance: none; outline: none; box-sizing: border-box;}

.gform_wrapper select {
 background-image: url("data:image/svg+xml,svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'polyline points='6 9 12 15 18 9'/polyline/svg"); background-repeat: no-repeat; background-position: right 10px center; padding-right: 32px; cursor: pointer;}

.gform_wrapper textarea {
 min-height: 90px; resize: vertical;}


.gform_wrapper input::placeholder,
.gform_wrapper textarea::placeholder {
 color: var(--grove-gray-400); font-weight: 400;}


.gform_wrapper input[type="text"]:hover,
.gform_wrapper input[type="email"]:hover,
.gform_wrapper input[type="tel"]:hover,
.gform_wrapper input[type="number"]:hover,
.gform_wrapper input[type="url"]:hover,
.gform_wrapper select:hover,
.gform_wrapper textarea:hover {
 border-color: #BBBBBB;}


.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper input[type="number"]:focus,
.gform_wrapper input[type="url"]:focus,
.gform_wrapper select:focus,
.gform_wrapper textarea:focus {
 border-color: var(--grove-red); box-shadow: 0 0 0 3px rgba(194, 8, 9, 0.12);}



/* ── Radio buttons as cards ────────────────────────────────── */
.gform_wrapper .gfield_radio {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 0;
  margin: 0;
}

.gform_wrapper .gfield_radio .gchoice {
  position: relative;
}

/* Hide native radio input */
.gform_wrapper .gfield_radio .gchoice input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* Card label */
.gform_wrapper .gfield_radio .gchoice label {
  display: block;
  cursor: pointer;
  border: 1.5px solid var(--grove-gray-200);
  border-radius: var(--grove-radius-lg);
  padding: 1rem 1rem 0.9rem;
  background: var(--grove-white);
  transition: border-color var(--grove-transition), background var(--grove-transition);
  font-size: 14px;
  font-weight: 400;
  color: var(--grove-black);
  line-height: 1.4;
  margin: 0;
}

.gform_wrapper .gfield_radio .gchoice label:hover {
  border-color: var(--grove-red);
}

/* Selected state */
.gform_wrapper .gfield_radio .gchoice:has(input:checked) label {
  border: 2px solid var(--grove-red);
  background: var(--grove-red-light);
}

/* Custom radio indicator */
.gform_wrapper .gfield_radio .gchoice label::before {
  content: "";
  position: absolute;
  top: 12px;
  right: 12px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--grove-gray-200);
  background: var(--grove-white);
  transition: all var(--grove-transition);
}

.gform_wrapper .gfield_radio .gchoice:has(input:checked) label::before {
  background: var(--grove-red);
  border-color: var(--grove-red);
  box-shadow: inset 0 0 0 4px var(--grove-white);
}

/* Stack on mobile */
@media (max-width: 560px) {
  .gform_wrapper .gfield_radio {
    grid-template-columns: 1fr;
  }
}

/* ── List field (wall dimensions) ────────────────────────── */
.gform_wrapper .gfield_list_container .gform-grid-row {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
}

.gform_wrapper .gfield_list_container .gform-grid-col {
  flex: 1;
  min-width: 0;
}

/* Fixed width for the add/remove button column */
.gform_wrapper .gfield_list_icons.gform-grid-col {
  flex: 0 0 70px;
  display: flex;
  gap: 4px;
  align-items: center;
}

/* Column header labels */
.gform_wrapper .gfield_header_item {
  font-size: 11px;
  font-weight: 500;
  color: var(--grove-gray-500);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Keep icons header column from stretching */
.gform_wrapper .gfield_header_item--icons.gform-grid-col,
.gform_wrapper .gfield_list_icons.gform-grid-col {
  flex: 0 0 70px;
}

/* Inputs fill their cell */
.gform_wrapper .gfield_list_group_item input {
  width: 100%;
}

/* Add / Remove buttons */
.gform_wrapper .add_list_item,
.gform_wrapper .delete_list_item {
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  background: none;
  border: 1px solid var(--grove-gray-200);
  border-radius: var(--grove-radius);
  padding: 4px 8px;
  color: var(--grove-gray-500);
  font-family: inherit;
  transition: all var(--grove-transition);
}

.gform_wrapper .add_list_item:hover {
  border-color: var(--grove-red);
  color: var(--grove-red);
}

.gform_wrapper .delete_list_item:hover {
  border-color: var(--grove-red);
  color: var(--grove-red);
}
.gform_wrapper .gfield_header_item.gform-grid-col {
  padding-left: 1px;
}
.gform_wrapper .gfield_checkbox {
 list-style: none; padding: 0; margin: 0;}

.gform_wrapper .gfield_checkbox li {
 display: flex; align-items: center; gap: 8px; padding: 4px 0;}

.gform_wrapper .gfield_checkbox li input[type="checkbox"] {
 width: 16px; height: 16px; min-width: 16px; border: 1.5px solid var(--grove-gray-200); border-radius: 3px; background: var(--grove-white); appearance: none; -webkit-appearance: none; cursor: pointer; transition: all var(--grove-transition); padding: 0;}

.gform_wrapper .gfield_checkbox li input[type="checkbox"]:checked {
 background: var(--grove-red); border-color: var(--grove-red); background-image: url("data:image/svg+xml,svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'path fill='none' stroke='fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M2 6l3 3 5-5'//svg"); background-size: 10px; background-position: center; background-repeat: no-repeat;}

.gform_wrapper .gfield_checkbox li label {
 font-size: 14px; color: var(--grove-gray-700); cursor: pointer; margin: 0;}



.gform_wrapper .gfield {
 margin-bottom: 16px;}

.gform_wrapper .gfield:last-child {
 margin-bottom: 0;}



@media (min-width: 561px) {
 .gform_wrapper .gf_left_half,
 .gform_wrapper .gf_right_half {
 width: calc(50% - 6px) !important; float: left; clear: none; }

 .gform_wrapper .gf_left_half {
 margin-right: 12px; }

 .gform_wrapper .gf_right_half {
 margin-right: 0; }

 
 .gform_wrapper .gf_right_half + .gfield,
 .gform_wrapper .gf_right_half + .gsection {
 clear: both; }
}



.gform_wrapper .gfield_error .gfield_label {
 color: var(--grove-red);}

.gform_wrapper .gfield_error input[type="text"],
.gform_wrapper .gfield_error input[type="email"],
.gform_wrapper .gfield_error input[type="tel"],
.gform_wrapper .gfield_error input[type="number"],
.gform_wrapper .gfield_error select,
.gform_wrapper .gfield_error textarea {
 border-color: var(--grove-red); background: var(--grove-red-light);}

.gform_wrapper .gfield_error input:focus,
.gform_wrapper .gfield_error select:focus,
.gform_wrapper .gfield_error textarea:focus {
 box-shadow: 0 0 0 3px rgba(194, 8, 9, 0.12);}

.gform_wrapper .validation_message {
 font-size: 12px; color: var(--grove-red); margin-top: 4px; display: block;}


.gform_wrapper .gform_validation_errors {
 border: 1.5px solid var(--grove-red-border); background: var(--grove-red-light); border-radius: var(--grove-radius-lg); padding: 12px 16px; margin-bottom: 20px;}

.gform_wrapper .gform_validation_errors > h2 {
 font-size: 14px; font-weight: 600; color: var(--grove-red-dark); margin: 0;}



.gform_wrapper .gform_footer,
.gform_wrapper .gform_page_footer {
 margin-top: 24px; padding-top: 0; border-top: none;}

.gform_wrapper .gform_button,
.gform_wrapper .gform_next_button,
.gform_wrapper .gform_previous_button {
 width: 100%; padding: 13px 24px; font-size: 15px; font-weight: 600; letter-spacing: 0.01em; background: var(--grove-red); color: var(--grove-white); border: none; border-radius: var(--grove-radius-lg); cursor: pointer; transition: background var(--grove-transition), transform var(--grove-transition); display: block; text-align: center; line-height: 1.4;}

.gform_wrapper .gform_button:hover,
.gform_wrapper .gform_next_button:hover {
 background: var(--grove-red-dark);}

.gform_wrapper .gform_button:active,
.gform_wrapper .gform_next_button:active {
 transform: scale(0.99);}

.gform_wrapper .gform_previous_button {
 background: var(--grove-gray-100); color: var(--grove-black); border: 1.5px solid var(--grove-gray-200); margin-bottom: 10px;}

.gform_wrapper .gform_previous_button:hover {
 background: var(--grove-gray-200);}



.gform_confirmation_message {
 background: var(--grove-red-light); border: 1.5px solid var(--grove-red-border); border-left: 4px solid var(--grove-red); border-radius: var(--grove-radius-lg); padding: 16px 20px; font-size: 15px; color: var(--grove-black); line-height: 1.6;}



.gform_wrapper .gform_footer .gform_ajax_spinner {
 margin-left: 10px; vertical-align: middle;}


.grove-form-note {
 text-align: center; font-size: 12px; color: var(--grove-gray-400); margin-top: 10px; line-height: 1.5;}