/* Gravity Forms – modern base styling aligned with Citim 2026 */

.gform_wrapper {
  font-family: var(--citim-typo-paragraph-font-family, "Roboto", sans-serif) !important;
  color: var(--citim-color-noir, #000) !important;
  border: 1px solid #eee;
  padding: 30px !important;
  border-radius: 20px !important;
}

.gform_wrapper .gform_heading {
  margin-bottom: var(--citim-spacing-md, 1.5rem) !important;
}

.gform_wrapper .gform_title {
  font-family: var(--citim-h1-font-family, "ES Build", system-ui, sans-serif) !important;
  font-size: var(--citim-typo-h2-font-size, 1.3125rem) !important;
  line-height: var(--citim-typo-h2-line-height, 1.2) !important;
  font-weight: 400 !important;
  margin: 0 0 0.5rem !important;
}

.gform_wrapper .gform_description {
  font-size: var(--citim-typo-paragraph-font-size, 1rem) !important;
  opacity: 0.9 !important;
}

.gform_wrapper .gform_body .gform_fields {
  display: grid !important;
  gap: var(--citim-spacing-md, 1.5rem) !important;
}

.gform_wrapper .gfield_label {
  display: block !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  margin-bottom: 0.4rem !important;
}

.gform_wrapper .gfield_required {
  color: var(--citim-color-cta-bg, #5f5f5f) !important;
  margin-left: 0.25rem !important;
}

.gform_wrapper .gfield_description,
.gform_wrapper .gfield_description *,
.gform_wrapper .instruction {
  font-size: 0.8125rem !important;
  opacity: 0.8 !important;
  margin-top: 0.35rem !important;
}

.gform_wrapper .gfield input[type="text"],
.gform_wrapper .gfield input[type="email"],
.gform_wrapper .gfield input[type="tel"],
.gform_wrapper .gfield input[type="url"],
.gform_wrapper .gfield input[type="number"],
.gform_wrapper .gfield input[type="password"],
.gform_wrapper .gfield input[type="search"],
.gform_wrapper .gfield input[type="date"],
.gform_wrapper .gfield select,
.gform_wrapper .gfield textarea {
  width: 100% !important;
  font: inherit !important;
  padding: 0.75rem 0.9rem !important;
  border-radius: 999px !important;
  border: 1px solid rgba(0, 0, 0, 0.16) !important;
  background-color: var(--citim-color-blanc, #fff) !important;
  color: inherit !important;
  outline: none !important;
  transition:
    border-color 150ms ease,
    box-shadow 150ms ease,
    background-color 150ms ease,
    transform 120ms ease !important;
  -webkit-appearance: none !important;
}

.gform_wrapper .gfield textarea {
  border-radius: 1rem !important;
  min-height: 120px !important;
  resize: vertical !important;
}

.gform_wrapper .gfield input::placeholder,
.gform_wrapper .gfield textarea::placeholder {
  color: rgba(0, 0, 0, 0.45) !important;
}

.gform_wrapper .gfield input:focus,
.gform_wrapper .gfield select:focus,
.gform_wrapper .gfield textarea:focus {
  border-color: var(--citim-color-cta-bg, #5f5f5f) !important;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.08) !important;
  background-color: #fff !important;
}

.gform_wrapper .gfield input:hover,
.gform_wrapper .gfield select:hover,
.gform_wrapper .gfield textarea:hover {
  border-color: rgba(0, 0, 0, 0.22) !important;
}

.gform_wrapper .gfield select {
  background-image:
    linear-gradient(45deg, transparent 50%, #000 50%),
    linear-gradient(135deg, #000 50%, transparent 50%) !important;
  background-position:
    calc(100% - 14px) 50%,
    calc(100% - 9px) 50% !important;
  background-size: 6px 6px, 6px 6px !important;
  background-repeat: no-repeat !important;
  padding-right: 2.25rem !important;
}

.gform_wrapper .gfield_checkbox,
.gform_wrapper .gfield_radio {
  display: grid !important;
  gap: 0.4rem !important;
}

.gform_wrapper .gfield_checkbox li,
.gform_wrapper .gfield_radio li {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
}

.gform_wrapper .gfield_checkbox input[type="checkbox"],
.gform_wrapper .gfield_radio input[type="radio"] {
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  accent-color: var(--citim-color-cta-bg, #5f5f5f) !important;
  cursor: pointer !important;
}

.gform_wrapper .gfield_checkbox label,
.gform_wrapper .gfield_radio label {
  font-size: 0.9rem !important;
  cursor: pointer !important;
}

.gform_wrapper .gform_footer,
.gform_wrapper .gform_page_footer {
  margin-top: var(--citim-spacing-md, 1.5rem) !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.75rem !important;
  align-items: center !important;
}

.gform_wrapper .gform_button,
.gform_wrapper .gform_next_button,
.gform_wrapper .gform_previous_button,
.gform_wrapper .gform_save_link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.4rem !important;
  padding: 0.7rem 1.6rem !important;
  border-radius: 999px !important;
  border: none !important;
  font-family: var(--citim-font-primary, "ES Build", sans-serif) !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  background-color: var(--citim-color-emeraude, #3A9980) !important;
  color: var(--citim-color-blanc, #fff) !important;
  transition:
    background-color 150ms ease,
    transform 120ms ease,
    box-shadow 150ms ease !important;
}

.gform_wrapper .gform_button:hover,
.gform_wrapper .gform_next_button:hover,
.gform_wrapper .gform_previous_button:hover,
.gform_wrapper .gform_save_link:hover {
  background-color: var(--citim-color-cta-bg-hover, #3d3d3d) !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.16) !important;
  transform: translateY(-1px) !important;
}

.gform_wrapper .gform_button:active,
.gform_wrapper .gform_next_button:active,
.gform_wrapper .gform_previous_button:active,
.gform_wrapper .gform_save_link:active {
  transform: translateY(0) !important;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.16) !important;
}

.gform_wrapper .gform_previous_button {
  background-color: transparent !important;
  color: var(--citim-color-noir, #000) !important;
  border: 1px solid rgba(0, 0, 0, 0.16) !important;
  box-shadow: none !important;
}

.gform_wrapper .gform_previous_button:hover {
  background-color: rgba(0, 0, 0, 0.04) !important;
  border-color: rgba(0, 0, 0, 0.28) !important;
}

.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="url"],
.gform_wrapper .gfield_error input[type="number"],
.gform_wrapper .gfield_error input[type="password"],
.gform_wrapper .gfield_error input[type="search"],
.gform_wrapper .gfield_error input[type="date"],
.gform_wrapper .gfield_error select,
.gform_wrapper .gfield_error textarea {
  border-color: #d93025 !important;
  box-shadow: 0 0 0 1px rgba(217, 48, 37, 0.22) !important;
}

.gform_wrapper .gfield_validation_message,
.gform_wrapper .validation_message {
  margin-top: 0.35rem !important;
  font-size: 0.8rem !important;
  color: #d93025 !important;
}

.gform_wrapper .validation_error {
  border-radius: 0.75rem !important;
  padding: 0.85rem 1rem !important;
  margin-bottom: var(--citim-spacing-md, 1.5rem) !important;
  background-color: #fef3f2 !important;
  color: #b42318 !important;
  font-size: 0.9rem !important;
}

.gform_confirmation_message {
  border-radius: 0.75rem !important;
  padding: 0.9rem 1.1rem !important;
  background-color: #ecfdf3 !important;
  color: #027a48 !important;
  font-size: 0.95rem !important;
  margin-top: var(--citim-spacing-md, 1.5rem) !important;
}

