/**
 * Forminator form overrides
 * Matches Artimed design system
 */

/* ── Reset Forminator defaults ── */
.forminator-ui.forminator-custom-form[data-design="default"] {
  margin-bottom: 0 !important;
}

.forminator-custom-form {
  font-family: var(--font-primary) !important;
}

/* ── Row / Grid ── */
.forminator-custom-form .forminator-row {
  display: flex !important;
  flex-wrap: wrap;
  gap: 0 14px;
  margin: 0 !important;
  padding: 0 !important;
}

.forminator-custom-form .forminator-col {
  padding: 0 !important;
  margin-bottom: 10px !important;
}

.forminator-custom-form .forminator-col-6 {
  flex: 1 1 calc(50% - 7px) !important;
  max-width: calc(50% - 7px) !important;
}

.forminator-custom-form .forminator-col-12 {
  flex: 0 0 100% !important;
  max-width: 100% !important;
}

/* ── Field wrapper ── */
.forminator-custom-form .forminator-field {
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Labels ── */
.forminator-custom-form .forminator-label {
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-sm) !important;
  font-weight: 600 !important;
  color: var(--color-black) !important;
  margin: 0 0 4px !important;
  padding: 0 !important;
  display: block;
  line-height: 1.3 !important;
}

.forminator-custom-form .forminator-required {
  color: var(--color-action) !important;
}

/* ── Inputs & Textareas ── */
.forminator-custom-form .forminator-input,
.forminator-custom-form .forminator-textarea {
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-sm) !important;
  color: var(--color-black) !important;
  background: var(--color-white) !important;
  border: 1.5px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 10px 14px !important;
  height: 42px !important;
  width: 100% !important;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
  outline: none !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.forminator-custom-form .forminator-textarea {
  height: auto !important;
  min-height: 100px;
  resize: vertical;
}

.forminator-custom-form .forminator-input::placeholder,
.forminator-custom-form .forminator-textarea::placeholder {
  color: var(--color-text-light) !important;
  opacity: 1 !important;
}

.forminator-custom-form .forminator-input:focus,
.forminator-custom-form .forminator-textarea:focus {
  border-color: var(--color-brand) !important;
  box-shadow: 0 0 0 3px rgba(0, 91, 83, 0.08) !important;
}

/* Larger textarea on contact page */
.kontakt-form-right .forminator-custom-form .forminator-textarea {
  min-height: 140px;
}

/* ── Select / Dropdown (Select2) ── */
.forminator-custom-form .forminator-select--field {
  display: none !important;
}

.forminator-custom-form .select2-container {
  width: 100% !important;
}

.forminator-custom-form .select2-container .select2-selection--single {
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-sm) !important;
  color: var(--color-black) !important;
  background: var(--color-white) !important;
  border: 1.5px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 0 14px !important;
  height: 42px !important;
  display: flex !important;
  align-items: center !important;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
  outline: none !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
}

.forminator-custom-form .select2-container--open .select2-selection--single {
  border-color: var(--color-brand) !important;
  box-shadow: 0 0 0 3px rgba(0, 91, 83, 0.08) !important;
}

.forminator-custom-form .select2-container .select2-selection__rendered {
  padding: 0 !important;
  margin: 0 !important;
  line-height: 42px !important;
  color: var(--color-black) !important;
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-sm) !important;
}

.forminator-custom-form .select2-container .select2-selection__placeholder {
  color: var(--color-text-light) !important;
}

.forminator-custom-form .select2-container .select2-selection__arrow {
  height: 42px !important;
  top: 0 !important;
  right: 10px !important;
  width: 24px !important;
  transform: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.forminator-custom-form .select2-container .select2-selection__arrow b {
  border-color: var(--color-text-muted) transparent transparent transparent !important;
  border-width: 5px 4px 0 4px !important;
  margin: 0 !important;
  left: auto !important;
  top: auto !important;
}

.forminator-custom-form .select2-container--open .select2-selection__arrow b {
  border-color: transparent transparent var(--color-text-muted) transparent !important;
  border-width: 0 4px 5px 4px !important;
}

/* Select2 / Forminator dropdown panel */
.select2-container--open .select2-dropdown,
.forminator-select-dropdown {
  border: 1.5px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.1) !important;
  overflow: hidden !important;
  z-index: 99999 !important;
  background: var(--color-white) !important;
  margin-top: var(--space-xs) !important;
  padding: var(--space-xs) !important;
}

.select2-container--open .select2-dropdown--above,
.forminator-select-dropdown--above {
  margin-top: 0 !important;
  margin-bottom: var(--space-xs) !important;
}

.select2-container--open .select2-dropdown .select2-results__options,
.forminator-select-dropdown .select2-results__options {
  max-height: 220px !important;
  overflow-y: auto !important;
  padding: 0 !important;
}

.select2-results__option {
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-xs) !important;
  font-weight: 500 !important;
  padding: var(--space-sm) var(--space-md) !important;
  color: var(--color-black) !important;
  border-radius: var(--radius-md) !important;
  transition: background var(--transition-fast) !important;
  cursor: pointer !important;
  line-height: 1.4 !important;
}

.select2-results__option + .select2-results__option {
  margin-top: 2px !important;
}

.select2-results__option--highlighted,
.select2-results__option--highlighted.select2-results__option--selectable {
  background: var(--color-hero-bg) !important;
  color: var(--color-brand) !important;
}

.select2-results__option--selected,
.select2-results__option[aria-selected="true"] {
  background: var(--color-brand) !important;
  color: var(--color-white) !important;
}

/* Hide search in dropdown */
.select2-container .select2-search--dropdown {
  display: none !important;
}

/* ── File Upload ── */
.forminator-custom-form .forminator-file-upload {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.forminator-custom-form .forminator-button-upload,
.forminator-custom-form .forminator-button.forminator-button-upload {
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-xs) !important;
  font-weight: 600 !important;
  color: var(--color-brand) !important;
  background: var(--color-white) !important;
  border: 1.5px solid var(--color-brand) !important;
  border-radius: var(--radius-lg) !important;
  padding: 8px 16px !important;
  cursor: pointer !important;
  transition: background var(--transition-fast), color var(--transition-fast) !important;
  white-space: nowrap;
  line-height: 1.4 !important;
  height: auto !important;
}

.forminator-custom-form .forminator-button-upload:hover,
.forminator-custom-form .forminator-button.forminator-button-upload:hover {
  background: var(--color-brand) !important;
  color: var(--color-white) !important;
}

.forminator-custom-form .forminator-file-upload .forminator-input-file-required,
.forminator-custom-form .forminator-file-upload input[type="text"] {
  border: none !important;
  background: none !important;
  font-size: var(--font-size-xs) !important;
  color: var(--color-text-muted) !important;
  padding: 0 !important;
  height: auto !important;
  pointer-events: none;
}

/* ── Consent / Checkbox ── */
.forminator-custom-form .forminator-checkbox {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  cursor: pointer !important;
}

.forminator-custom-form .forminator-checkbox__wrapper {
  margin: 0 !important;
  padding: 0 !important;
}

.forminator-custom-form .forminator-checkbox-box {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  border: 1.5px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  background: var(--color-white) !important;
  transition: all var(--transition-fast) !important;
  margin-top: 2px !important;
  flex-shrink: 0;
}

.forminator-custom-form .forminator-checkbox input:checked + .forminator-checkbox-box,
.forminator-custom-form .forminator-is_checked .forminator-checkbox-box {
  background: var(--color-brand) !important;
  border-color: var(--color-brand) !important;
}

.forminator-custom-form .forminator-checkbox__label,
.forminator-custom-form .forminator-consent__label {
  font-size: var(--font-size-xs) !important;
  color: var(--color-text-muted) !important;
  line-height: 1.5 !important;
  font-family: var(--font-primary) !important;
}

.forminator-custom-form .forminator-consent__label a {
  color: var(--color-brand) !important;
  text-decoration: underline !important;
  font-weight: 600 !important;
}

.forminator-custom-form .forminator-consent__label a:hover {
  color: var(--color-brand-light) !important;
}

/* ── Submit Button ── */
.forminator-custom-form .forminator-button-submit,
.forminator-custom-form .forminator-button.forminator-button-submit {
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-base) !important;
  font-weight: 700 !important;
  color: var(--color-white) !important;
  background: var(--color-brand) !important;
  border: none !important;
  border-radius: var(--radius-lg) !important;
  padding: 14px 32px !important;
  cursor: pointer !important;
  transition: background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast) !important;
  width: 100% !important;
  display: block !important;
  margin-top: 4px !important;
  letter-spacing: 0.01em;
  line-height: 1.4 !important;
  text-align: center !important;
}

.forminator-custom-form .forminator-button-submit:hover,
.forminator-custom-form .forminator-button.forminator-button-submit:hover {
  background: var(--color-brand-light) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 91, 83, 0.25) !important;
}

.forminator-custom-form .forminator-button-submit:active,
.forminator-custom-form .forminator-button.forminator-button-submit:active {
  transform: translateY(0);
  box-shadow: none !important;
}

/* Last row (submit) — no extra spacing */
.forminator-custom-form .forminator-row-last {
  margin: 0 !important;
}

.forminator-custom-form .forminator-row-last .forminator-col {
  margin-bottom: 0 !important;
  flex: 0 0 100% !important;
  max-width: 100% !important;
}

/* ── Error states ── */
.forminator-custom-form .forminator-error-message {
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-xs) !important;
  color: #dc3545 !important;
  margin-top: 4px !important;
}

.forminator-custom-form .forminator-has_error .forminator-input,
.forminator-custom-form .forminator-has_error .forminator-textarea,
.forminator-custom-form .forminator-has_error .select2-selection--single {
  border-color: #dc3545 !important;
}

/* ── Success message ── */
.forminator-custom-form .forminator-response-message {
  font-family: var(--font-primary) !important;
  font-size: var(--font-size-base) !important;
  border-radius: var(--radius-lg) !important;
  padding: 14px 18px !important;
}

.forminator-custom-form .forminator-response-message.forminator-success {
  background: var(--color-hero-bg) !important;
  color: var(--color-brand) !important;
  border: 1px solid var(--color-brand) !important;
}

/* ── Modal-specific tweaks ── */
.modal-right .forminator-custom-form .forminator-textarea {
  min-height: 50px !important;
  max-height: 80px !important;
}

.modal-right .forminator-custom-form .forminator-col {
  margin-bottom: 8px !important;
}

.modal-right .forminator-custom-form .forminator-label {
  font-size: var(--font-size-xs) !important;
  margin-bottom: 3px !important;
}

.modal-right .forminator-custom-form .forminator-input,
.modal-right .forminator-custom-form .select2-container .select2-selection--single {
  height: 38px !important;
  padding: 8px 12px !important;
  font-size: var(--font-size-xs) !important;
}

.modal-right .forminator-custom-form .select2-container .select2-selection__rendered {
  line-height: 38px !important;
  font-size: var(--font-size-xs) !important;
}

.modal-right .forminator-custom-form .select2-container .select2-selection__arrow {
  height: 38px !important;
}

.modal-right .forminator-custom-form .forminator-button-submit {
  padding: 12px 24px !important;
  font-size: var(--font-size-sm) !important;
}

/* ── intlTelInput wrapper — force full width ── */
.forminator-custom-form .iti {
  width: 100% !important;
  display: block !important;
}

.forminator-custom-form .iti__tel-input {
  width: 100% !important;
}

/* ── Mobile ── */
@media (max-width: 640px) {
  .forminator-custom-form .forminator-col-6 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  .forminator-custom-form .forminator-row {
    gap: 0 !important;
  }

  .forminator-custom-form .forminator-button-submit {
    padding: 12px 24px !important;
  }

  .forminator-custom-form .forminator-input,
  .forminator-custom-form .select2-container .select2-selection--single {
    height: 48px !important;
    padding: 12px 14px !important;
  }

  .forminator-custom-form .select2-container .select2-selection__rendered {
    line-height: 48px !important;
  }

  .forminator-custom-form .select2-container .select2-selection__arrow {
    height: 48px !important;
  }

  .modal-right .forminator-custom-form .forminator-input,
  .modal-right .forminator-custom-form .select2-container .select2-selection--single {
    height: 44px !important;
    padding: 10px 12px !important;
  }

  .modal-right .forminator-custom-form .select2-container .select2-selection__rendered {
    line-height: 44px !important;
  }

  .modal-right .forminator-custom-form .select2-container .select2-selection__arrow {
    height: 44px !important;
  }
}
