/* ================================
   GRAVITY FORMS BOILERPLATE
   framework/styles/gravity-forms.css
   ================================ */

/* ================================
   THEME TOKENS
   Defaults = light background.
   Add class "gf-dark" to the Bricks
   section/container wrapping the form
   to switch to the dark variant.
   ================================ */

.gform_wrapper {
  /* Text */
  --gf-label: var(--dark);
  --gf-label-soft: var(--dark-t-7);
  --gf-description: var(--dark-t-7); /* 55% — readable but secondary */
  --gf-check-label: var(--dark);

  /* Inputs — always light-backgrounded in both themes */
  --gf-input-bg: var(--light);
  --gf-input-border: var(--dark-t-3); /* 15% — close to #ddd */
  --gf-input-color: var(--dark);
  --gf-placeholder: var(--dark-t-6); /* 44% — close to #999 */

  --gf-error-text: var(--error-d-1);
}

/* Dark background override — apply "gf-dark" to the wrapping Bricks element */
.gf-dark .gform_wrapper {
  --gf-label: var(--light);
  --gf-label-soft: var(--light-t-9);
  --gf-description: var(--light-t-7); /* 64% — soft white, clearly secondary */
  --gf-check-label: var(--light);
  --gf-error-text: var(--error-l-1);
  --gf-placeholder: var(--light-t-8);
  /* Input tokens unchanged — inputs stay on a light background */
}

/* ================================
   RESETS
   ================================ */

/* --- Fieldset --- */
.gform_wrapper fieldset {
  border: none;
  padding: 0;
  margin: 0;
  min-width: 0; /* prevents overflow in flex/grid containers */
}

/* --- Required Legend --- */
.gform_required_legend {
  display: none;
}

/* ================================
   STRUCTURE & SPACING
   ================================ */

/* --- Field Spacing --- */
.gform_fields .gfield {
  margin-bottom: var(--space-m);
}

/* ================================
   LABELS & DESCRIPTIONS
   ================================ */

/* --- Default Field Description --- */
.gfield_description {
  font-size: var(--text-xs);
  color: var(--gf-label-soft);
}

/* --- Field Labels --- */
.gform_wrapper .gfield_label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--gf-label);
}

/* --- Required Asterisk --- */
.gform_wrapper.gravity-theme .gfield_required,
.gfield_required_asterisk {
  color: var(--error);
  font-size: 14px;
}

/* --- Field Descriptions --- */
.gform_wrapper.gravity-theme .gfield_description {
  font-size: var(--text-s);
  font-style: italic;
  color: var(--gf-description);
}

/* --- Address field labels like Street, City, Postal--- */
.gform-field-label {
  font-size: var(--text-2xs);
  color: var(--gf-label);
}

/* ================================
   TEXT INPUTS
   ================================ */

/* --- Text, Email, Phone, Number, URL --- */
.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"] {
  width: 100%;
  padding: var(--space-xs);
  border-radius: var(--radius-xs);
  font-size: var(--text-s);
  font-weight: 500;
  color: var(--gf-input-color);
  line-height: 1;
  border: 1px solid var(--gf-input-border);
  background: var(--gf-input-bg);
}

.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 {
  outline: 0;
  border-color: var(--action);
  box-shadow: 0 0 0 3px rgba(253, 182, 131, 0.5);
}

/* --- Textarea --- */
.gform_wrapper textarea {
  width: 100%;
  padding: var(--space-xs);
  border-radius: var(--radius-xs);
  font-size: var(--text-s);
  font-weight: 500;
  color: var(--gf-input-color);
  line-height: 1.5;
  border: 1px solid var(--gf-input-border);
  background: var(--gf-input-bg);
}

.gform_wrapper textarea:focus {
  outline: 0;
  border-color: var(--action);
  box-shadow: 0 0 0 3px rgba(253, 182, 131, 0.5);
}

/* --- Textarea Size Classes (set in GF field settings) --- */
.ginput_container_textarea textarea.small {
  height: 80px;
}
.ginput_container_textarea textarea.medium {
  height: 150px;
}
.ginput_container_textarea textarea.large {
  height: 300px;
}

/* --- Select --- */
/* .gform_wrapper select {
  width: 100%;
  padding: var(--space-xs);
  border-radius: var(--radius-xs);
  font-size: var(--text-s);
  font-weight: 500;
  color: var(--gf-input-color);
  background: var(--gf-input-bg);
  border: 1px solid var(--gf-input-border);
} */

/* --- Select --- */
.gform_wrapper select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 100%;
  padding: var(--space-xs);
  padding-right: 2.25em; /* room for custom arrow */
  border-radius: var(--radius-xs);
  font-size: var(--text-s);
  font-weight: 500;
  line-height: 1;
  color: var(--gf-input-color);
  background-color: var(--gf-input-bg);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75em center;
  background-size: 14px;
  border: 1px solid var(--gf-input-border);
  cursor: pointer;
}
.gform_wrapper select::-ms-expand {
  display: none;
}
.gform_wrapper select:focus {
  outline: 0;
  border-color: var(--action);
  box-shadow: 0 0 0 3px rgba(253, 182, 131, 0.5);
}
.gform_wrapper select:required:invalid {
  color: var(--gf-placeholder);
}
.gform_wrapper select option {
  color: var(--gf-input-color);
}

/* --- Placeholder --- */
.gform_wrapper input::placeholder,
.gform_wrapper textarea::placeholder {
  color: var(--gf-placeholder);
}

/* ================================
   CHECKBOXES & RADIO BUTTONS
   ================================ */

/* --- List reset --- */
.gform_wrapper .gfield_checkbox li,
.gform_wrapper .gfield_radio li {
  list-style-type: none;
  padding: 0;
}

/* --- Choice row layout: checkbox/radio left, label right --- */
.gform_wrapper .gfield_checkbox .gchoice,
.gform_wrapper .gfield_radio .gchoice {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  margin-bottom: var(--space-xs);
  margin-top: var(--space-xs);
  cursor: pointer;
}

/* --- Label --- */
.gform_wrapper .gfield_checkbox label,
.gform_wrapper .gfield_radio label {
  font-size: var(--text-s);
  font-weight: 500;
  color: var(--gf-check-label);
  cursor: pointer;
  line-height: 1.3;
  padding-top: 4px;
}

/* --- Custom Checkbox --- */
.gform_wrapper input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  min-width: 18px;
  padding: 0 0;
  border: 2px solid var(--gf-input-border);
  border-radius: 4px;
  background: var(--gf-input-bg);
  cursor: pointer;
  position: relative;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.gform_wrapper input[type="checkbox"]:checked {
  background: var(--success);
  border-color: var(--success-d-1);
}

/* --- Checkbox Checked on Dark Background --- */
.gf-dark .gform_wrapper input[type="checkbox"]:checked {
  background: var(--success);
  border-color: var(--success-d-1);
}

.gform_wrapper input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 6px;
  height: 10px;
  border: 2px solid var(--light);
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}

/* --- Custom Radio --- */
.gform_wrapper input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  padding: 0;
  min-width: 18px;
  border: 2px solid var(--gf-input-border);
  border-radius: 50%;
  background: var(--gf-input-bg);
  cursor: pointer;
  position: relative;
  transition: border-color 0.15s ease;
}

.gform_wrapper input[type="radio"]:checked {
  border-color: var(--success);
}

.gf-dark .gform_wrapper input[type="radio"]:checked {
  border-color: var(--success);
}

.gform_wrapper input[type="radio"]:checked::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--success);
}

/* ================================
   SUBMIT BUTTON
   ================================ */

.gform_wrapper .gform_submit_button,
.gform_wrapper input[type="submit"] {
  width: 100%;
  padding: var(--space-s);
  background: var(--action);
  color: var(--light);
  font-size: var(--text-s);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.5;
  border: none;
  border-radius: var(--radius-xs);
  text-align: center;
  cursor: pointer;
  transition: background 0.2s ease;
}

.gform_wrapper .gform_submit_button:hover,
.gform_wrapper input[type="submit"]:hover {
  background: color-mix(in srgb, var(--action-hover) 90%, white 15%);
}

/* ================================
   VALIDATION & ERRORS
   ================================ */

/* --- Validation Error Banner --- */
.gform_wrapper .gform_validation_errors {
  font-size: 13px;
  font-weight: 700;
  color: var(--light);
  background: var(--error-l-1);
  padding: var(--space-xs);
  border: 1px solid var(--error);
  border-radius: var(--radius-xs);
  margin-bottom: var(--space-s);
}

/* --- Main Error Message at Top of Form --- */
h2.gform_submission_error {
  font-size: var(--text-xs);
  color: var(--error-d-1);
  margin-bottom: 0;
  text-wrap: pretty;
  line-height: 1.4;
}

/* --- Field-Level Error --- */
.gform_wrapper .gfield_error input,
.gform_wrapper .gfield_error textarea,
.gform_wrapper .gfield_error select {
  border: 1px solid var(--error);
  background: #f3dfe0;
}

/* --- Inline Validation Message --- */
.gform_wrapper .gfield_description.validation_message {
  font-size: 13px;
  color: var(--gf-error-text);
  font-weight: 600;
}

/* ================================
   MISC FIELD TYPES
   ================================ */

/* --- Phone Instruction (redundant, hide) --- */
.gform_wrapper .ginput_container_phone .instruction {
  display: none;
}

/* --- Complex Fields (Name, Address) --- */
.gform_wrapper .ginput_complex {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-m);
}

/* Full-width rows (e.g. street address line) */
.gform_wrapper .ginput_complex .ginput_full {
  flex: 0 0 100%;
}

/* Half-width columns (e.g. city + postal code) */
.gform_wrapper .ginput_complex .ginput_left,
.gform_wrapper .ginput_complex .ginput_right {
  flex: 1;
  min-width: 120px; /* wraps to full width on very narrow screens */
}

/* This fixes an issue where the right postal code field width was too short*/
.gform_wrapper .ginput_complex .gf_clear {
  display: none;
}

/* ================================
   FILE UPLOAD
   ================================ */

.gform_wrapper .gform_drop_area {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: var(--space-m);
  border: 2px dashed var(--gf-input-border);
  border-radius: var(--radius-xs);
  background: var(--gf-input-bg);
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.gform_wrapper .gform_drop_area:hover {
  border-color: var(--brand);
}

/* Upload icon */
.gform_wrapper .gform_drop_area::before {
  content: "";
  display: block;
  width: 44px;
  height: 44px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23aaa' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' y1='3' x2='12' y2='15'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
}

.gform_wrapper .gform_drop_instructions {
  font-size: var(--text-s);
  color: var(--gf-placeholder);
}

.gform_wrapper .gform_button_select_files {
  background: transparent;
  border: 1px solid var(--accent-l-1);
  border-radius: var(--radius-xs);
  padding: 6px var(--space-s);
  font-size: var(--text-s);
  font-weight: 600;
  color: var(--accent-l-1);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}

.gform_wrapper .gform_button_select_files:hover {
  background: var(--accent-l-1);
  color: var(--light);
}

.gform_wrapper .gform_fileupload_rules {
  font-size: var(--text-xs);
  color: var(--gf-placeholder);
  margin-top: 4px;
}

/* ================================
   FORM-SPECIFIC OVERRIDES
   ================================ */

/* Blog Archive — Form #3 for CB ONLY */
/* #gform_3 .gfield_label.gform-field-label {
  color: var(--dark-t-5);
  display: none;
} */

/* Uncomment and update form ID to override submit button color per form:
#gform_submit_button_3 {
  background: var(--brand);
}
#gform_submit_button_3:hover {
  background: var(--brand-l-1);
} */
