/******************** JetFormBuilder Styles ********************/

/********** Menu **********/

/* 1. Text Feild */
/* 2. Number Field */
/* 3. Calculated Field */
/* 4. Select Field */
/* 5. Text Area Field */
/* 6. Wysiwyg Field */
/* 7. Checkbox Field */
/* 8. Radio Field */
/* 9. Range Field */
/* 10. Date Field */
/* 11. Time Field */
/* 12. DateTime Field */
/* 13. Media Field */
/* 14. Switcher Field */
/* 15. Repeater Field */
/* 16. Action Buttons */
/* 17. Required Icon */
/* 18. Validation Message */
/* 19. Progress Bar */

/********** Global Styling **********/

.jet-form-builder-row {
  flex-wrap: nowrap !important;
}

/* Label styling */
.jet-form-builder__label-text {
  color: inherit !important;
  font-weight: 600;
  margin-bottom: 0.5rem;
  display: inline-block;
}

/* Checkbox and radio spacing */
.jet-form-builder__fields-group {
  gap: 0rem;
}

/* Removes unnessary fieldset border style */
fieldset {
  border-style: none !important;
}

/* Styling for Success message */

.jet-form-builder-message--success {
  border: 1px solid #a3cfbb !important;
  border-radius: 0.375rem;
  color: #0a3622 !important;
  background-color: #d1e7dd !important;
  padding: 1rem;
}

/* Styling for Error Message */

.jet-form-builder-message--error {
  border: 1px solid #f1c0c0;
  border-radius: 0.375rem;
  color: #cf2e2e !important;
  background-color: #f8e0e0 !important;
  padding: 1rem;
}

/********** 1. Text Field **********/

/* Apply Bootstrap form-control style to text fields only */
.jet-form-builder__field.text-field,
.jet-form-builder__field.textarea-field {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem; /* Standard padding for text fields */
  font-size: 1rem;
  font-weight: 400;
  font-family: inherit;
  line-height: 1.5;
  color: var(--wp--preset--color--contrast);
  background-color: var(--wp--preset--color--base);
  border: 1px solid var(--wp--preset--color--borderline);
  border-radius: 0.25rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

/* Mimic Bootstrap's focus state for text fields */
.jet-form-builder__field.text-field:focus,
.jet-form-builder__field.textarea-field:focus,
.jet-form-builder__field.select-field:focus {
  color: var(--wp--preset--color--contrast) !important;
  background-color: var(--wp--preset--color--base);
  border-color: var(--wp--preset--color--accent); /* Customize as needed */
}

/********** 2. Number Field **********/

/* No CSS but needs arrow  fixed */

/********** 3. Calculated Field **********/

/* Looks ok for now */

/********** 4. Select Field **********/

.jet-form-builder__field.select-field {
  display: block;
  width: 100%;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem; /* Adjust padding for custom dropdown arrow */
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--wp--preset--color--contrast);
  background-color: var(--wp--preset--color--base);
  background-repeat: no-repeat;
  background-position: right 0.75rem center; /* Position for the dropdown arrow */
  background-size: 16px 12px !important; /* Size of the dropdown arrow */
  border: 1px solid var(--wp--preset--color--borderline);
  border-radius: 0.25rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
}

.jet--ua-safari .jet-form-builder__field-wrap select.select-field {
  -webkit-appearance: none;
  background-position: right 0.75rem center !important; /* Position for the dropdown arrow */
  background-size: 16px 12px !important; /* Size of the dropdown arrow */
}

.jet-form-builder__field.select-field::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 0.75rem;
  width: 12px;
  height: 12px;
  background-color: var(--wp--preset--color--contrast); /* Arrow color */
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='black' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='black' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  transform: translateY(-50%);
  pointer-events: none;
}

/********** 5. Text Area Field **********/

/* CSS class included in text field */

/********** 6. Wysiwyg Field **********/

:root {
  --jfb-wysiwyg-toolbar-bg: var(--wp--preset--color--base);
  --jfb-wysiwyg-buttons-bg: var(--wp--preset--color--borderline);
  --jfb-wysiwyg-buttons-text: var(--wp--preset--color--contrast);
  --jfb-wysiwyg-statusbar-bg: var(--wp--preset--color--base);
  --jfb-wysiwyg-statusbar-text: var(--wp--preset--color--contrast);
  --jfb-wysiwyg-container-bg: var(--wp--preset--color--base);
  --jfb-wysiwyg-container-text: var(--wp--preset--color--contrast);
}

/* Container */

.wp-editor-container {
  background-color: var(--jfb-wysiwyg-container-bg) !important;
  clear: both;
  border: 1px solid var(--wp--preset--color--borderline) !important;
}

.jet-form-builder-row.field-type-wysiwyg-field.wp-block-jet-forms-wysiwyg-field
  .mce-toolbar-grp {
  background-color: var(--wp--preset--color--base) !important;
  border: 0px !important;
  border-bottom: none !important;
}

.mce-panel {
  border: 0 solid var(--wp--preset--color--borderline) !important;
}

/* Toolbar button styling */
.wp-editor-container .mce-btn,
.wp-editor-container .mce-widget button {
  background-color: var(--wp--preset--color--borderline) !important;
  color: var(--wp--preset--color--contrast) !important;
  border: none !important;
}

.mce-btn-group:not(:first-child) {
  border-left: 1px solid var(--wp--preset--color--borderline) !important;
  padding-left: 0;
  margin-left: 2px;
}

.mce-container {
  color: black !important;
}

.wp-editor-container .mce-btn:hover,
.wp-editor-container .mce-widget button:hover,
.wp-editor-container .mce-btn:focus,
.wp-editor-container .mce-widget button:focus {
  background-color: var(--wp--preset--color--base-3) !important;
  color: var(--wp--preset--color--contrast) !important;
}

/* Icons within toolbar buttons */
.wp-editor-container .mce-ico {
  color: var(--wp--preset--color--contrast) !important;
}

/* Styling the content area of the TinyMCE editor */
.wp-editor-container iframe {
  border: none !important;
  background-color: var(--jfb-wysiwyg-container-bg) !important;
}

/* Set Arial font for WYSIWYG editor content */
.mce-content-body {
  font-family: Arial, sans-serif !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

/* TinyMCE iframe body content - more specific targeting */
iframe[id*='_ifr'] body,
iframe[id*='_ifr'] body *,
iframe[id*='_ifr'] body p,
iframe[id*='_ifr'] body div,
iframe[id*='_ifr'] body span {
  font-family: Arial, sans-serif !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

/* Additional TinyMCE content targeting */
.mce-content-body *,
.mce-content-body p,
.mce-content-body div,
.mce-content-body span,
.mce-content-body h1,
.mce-content-body h2,
.mce-content-body h3,
.mce-content-body h4,
.mce-content-body h5,
.mce-content-body h6 {
  font-family: Arial, sans-serif !important;
}

/* Status bar styling */
.wp-editor-container .mce-statusbar {
  background-color: var(--wp--preset--color--base-2) !important;
  color: var(--wp--preset--color--contrast) !important;
  border-top: 1px solid var(--wp--preset--color--borderline) !important;
  padding: 0.25rem 0.75rem !important;
}

/* Apply general font size and spacing */
.wp-editor-container .mce-container,
.wp-editor-container .mce-edit-area,
.wp-editor-container .mce-statusbar {
  font-size: 1rem !important;
}

/********** 7. Checkboxes **********/

.field-type-checkbox-field
  .jet-form-builder__field-label.for-checkbox
  > span::before {
  width: 22px !important;
  height: 22px !important;
  border: 1px solid var(--wp--preset--color--borderline) !important;
  background-color: var(--wp--preset--color--base) !important;
  border-radius: 4px !important;
  transition: all 0.2s ease;
}

/* Add primary colour variable to radio options */
.jet-form-builder__field-label.for-radio :checked + span::before,
.field-type-checkbox-field
  .jet-form-builder__field-label.for-checkbox
  :checked
  + span::before {
  border-color: var(--wp--preset--color--accent) !important;
  background-color: var(--wp--preset--color--accent) !important;
}

.field-type-checkbox-field
  .jet-form-builder__field-label.for-checkbox
  :not(:disabled):active
  + span::before {
  background-color: var(--wp--preset--color--accent) !important;
  border-color: var(--wp--preset--color--accent) !important;
}

.field-type-checkbox-field
  .jet-form-builder__field-label.for-checkbox
  :not(:disabled):not(:checked):hover
  + span::before {
  border-color: var(--wp--preset--color--accent) !important;
}

.field-type-checkbox-field
  .jet-form-builder__field-label.for-checkbox
  :not(:disabled):not(:checked):focus
  + span::before {
  border-color: var(--wp--preset--color--accent) !important;
}

.field-type-checkbox-field
  .jet-form-builder__field-label.for-checkbox
  :disabled
  + span::before {
  background-color: var(--wp--preset--color--accent) !important;
}

/********** 8. Radio **********/

.field-type-radio-field
  .jet-form-builder__field-label.for-radio
  > span::before {
  content: '';
  display: inline-block;
  width: 20px !important;
  height: 20px !important;
  border: 1px solid var(--wp--preset--color--borderline) !important;
  background-color: var(--wp--preset--color--base) !important;
  background-size: 16px 16px !important;
  transition: all 0.2s ease;
}

.field-type-radio-field
  .jet-form-builder__field-label.for-radio
  :not(:disabled):not(:checked):hover
  + span::before {
  border-color: var(--wp--preset--color--accent) !important;
}

.field-type-radio-field
  .jet-form-builder__field-label.for-radio
  :not(:disabled):active
  + span::before {
  background-color: var(--wp--preset--color--accent) !important;
  border-color: var(--wp--preset--color--accent) !important;
}

.field-type-radio-field
  .jet-form-builder__field-label.for-radio
  :focus:not(:checked)
  + span::before {
  border-color: var(--wp--preset--color--accent) !important;
}

.field-type-radio-field
  .jet-form-builder__field-label.for-radio
  :checked
  + span::before {
  border-color: var(--wp--preset--color--accent) !important;
  background-color: var(--wp--preset--color--accent) !important;
}

.field-type-radio-field
  .jet-form-builder__field-label.for-radio
  :disabled
  + span::before {
  background-color: var(--wp--preset--color--accent) !important;
}

/* Visual Radio - color */

.jet-color-image-list-wrapper fieldset {
  gap: 5px !important;
  display: flex;
  flex-direction: column;
}

.jet-color-image-list__item
  input:checked
  + .jet-color-image-list__button
  .jet-color-image-list__decorator
  > * {
  border-color: var(--wp--preset--color--borderline) !important;
}

.jet-color-image-list__decorator > * {
  border-radius: 4px !important;
  margin-right: 10px !important;
}

.jet-color-image-list__color {
  width: 22px !important;
  height: 22px !important;
}

/********** 9. Range **********/

input[type='range'].jet-form-builder__field.range-field::-webkit-slider-thumb {
  background: var(--wp--preset--color--accent) !important;
}

input[type='range'].jet-form-builder__field.range-field::-webkit-slider-runnable-track {
  height: var(--jet-fb__range-field-range--height, 4px);
  background: var(--wp--preset--color--base-2);
}

/********** 10. Date Field **********/

/* Date field container */
.jet-form-builder-row.field-type-date-field {
  color: var(--wp--preset--color--contrast) !important;
  margin-bottom: 1rem;
}

/* Date input field styling */
.jet-form-builder__field.date-field,
.jet-form-builder__field.time-field,
.jet-form-builder__field.datetime-field {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem;
  min-height: 30px;
  font-family: inherit;
  font-size: 1rem;
  text-align: left;
  font-weight: 400;
  color: var(--wp--preset--color--contrast) !important;
  background-color: var(--wp--preset--color--base) !important;
  border: 1px solid var(--wp--preset--color--borderline) !important;
  border-radius: 4px;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
}

/* Date input field focus state */
.jet-form-builder__field.date-field:focus,
.jet-form-builder__field.time-field:focus,
.jet-form-builder__field.datetime-field:focus {
  border-color: var(--wp--preset--color--accent) !important;
  outline: none;
  box-shadow: 0 0 0 0.2rem rgba(43, 110, 64, 0.25); /* Optional focus shadow */
}

/* Placeholder styling for browsers that support ::placeholder */
.jet-form-builder__field.date-field::placeholder {
  color: var(--wp--preset--color--borderline) !important;
  opacity: 0.8;
}

/********** 11. Time Field **********/

/* Added to the CSS for date field */

/********** 12. Date Time **********/

/* Added to the CSS for date field */

/********** 13. Media Field **********/

/* Custom styles for the file upload field */
.jet-form-builder__field-wrap.jet-form-builder-file-upload {
  background: var(--wp--preset--color--base) !important;
  border: 1px dashed var(--wp--preset--color--borderline) !important;
  padding: var(--wp--preset--spacing--10) !important;
  color: var(--wp--preset--color--contrast) !important;
  text-align: center;
  position: relative;
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 7px !important;
  transition: border-color 0.3s ease, background-color 0.3s ease;
}

/* Widrth settings */

.jet-form-builder__field-wrap:not(.checkradio-wrap) {
  width: inherit !important;
}

/* Styles for the image upload */
.jet-form-builder-file-upload__file img {
  display: block;
  width: 100%;
  height: 100% !important;
  padding: 0;
  margin: 0;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center center;
  object-position: center center;
  border-radius: 6px !important;
  box-shadow: 0 0 30px -8px rgba(0, 0, 0, 0.24) !important;
}

/* Styles for image content */
.jet-form-builder-file-upload__content {
  min-height: auto !important;
}

/* Styles for the custom "Choose File" and "File Uploaded" buttons */
.addfile {
  padding: 12px 24px !important;
  background-color: var(--wp--preset--color--accent) !important;
  color: var(--wp--preset--color--base) !important;
  border: none !important;
  font-size: var(--wp--preset--font-size--small) !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  border-radius: var(--button-border-radius) !important;
  margin-top: 10px; /* Space between button and label */
  transition: all 0.3s ease-in-out !important;
}

.addfile:hover {
  background-color: color-mix(
    in srgb,
    var(--wp--preset--color--accent) 90%,
    white
  ) !important;
  color: white !important;
  transition: all 0.3s ease-in-out !important;
}

/* Styles for the label that shows file upload status */
.labeladdfile {
  padding: 6px 12px;
  background-color: transparent; /* Default background is transparent */
  color: #000000 !important;
  font-size: 12px;
  font-weight: 400;
  display: block;
  margin-top: 10px;
  border-radius: 6px;
}

/* Class added when files are uploaded */
.files-uploaded {
  background-color: var(--wp--preset--color--base) !important;
  padding: 6px 12px;
  color: var(--wp--preset--color--contrast) !important;
  border-radius: 6px;
}

/* Hide the default file input visually */
.jet-form-builder-file-upload__input {
  display: none;
}

/* Drag and drop hover effect */
.jet-form-builder__field-wrap.jet-form-builder-file-upload.dragover {
  border-color: var(--wp--preset--color--accent) !important;
  background: rgba(255, 255, 255, 0.1) !important;
}

/* New styles for drag and drop text and icon */
.drag-drop-text {
  font-size: var(--wp--preset--font-size--large) !important;
  font-weight: 600;
  color: var(--wp--preset--color--contrast) !important;
  margin-bottom: 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  transition: opacity 0.3s ease, height 0.3s ease;
  height: auto;
}

.drag-drop-text.hidden {
  opacity: 0;
  height: 0;
  overflow: hidden;
}

.drag-drop-text .icon {
  font-size: 24px;
  margin-bottom: 10px;
}

.allowed-mime-types {
  font-size: 14px;
  color: var(--wp--preset--color--contrast) !important;
  margin-bottom: 10px;
  transition: opacity 0.3s ease, height 0.3s ease;
  height: auto;
}

.allowed-mime-types.hidden {
  opacity: 0;
  height: 0;
  overflow: hidden;
}

.allowed-mime-types .formats {
  font-weight: bold;
}

.or-text {
  font-size: 14px;
  color: var(--wp--preset--color--contrast) !important;
  margin-bottom: 10px;
  transition: opacity 0.3s ease, height 0.3s ease;
  height: auto;
}

.or-text.hidden {
  opacity: 0;
  height: 0;
  overflow: hidden;
}

/* Responsive adjustments */
@media (max-width: 767px) {
  .addfile,
  .labeladdfile {
    padding: 8px 16px;
    font-size: 12px;
  }
}

@media (max-width: 1024px) {
  .addfile,
  .labeladdfile {
    padding: 8px 16px;
    font-size: 12px;
  }
}

/********** 14. Switcher Field **********/

.field-type-switcher input.jet-form-builder__field {
  background: var(--wp--preset--color--base-2) !important;
}

.field-type-switcher input.jet-form-builder__field:checked {
  background: var(--wp--preset--color--accent) !important;
}

/********** Select 2 styling **********/

/* Main Select2 Container */
.select2-container {
  width: 100% !important;
  font-family: inherit !important;
}

.select2-container * {
  font-family: inherit !important;
  font-size: 1rem !important;
}

/* Remove dotted outlines from all Select2 elements */
.select2-container,
.select2-container *,
.select2-selection,
.select2-selection *,
.select2-dropdown,
.select2-dropdown * {
  outline: none !important;
  outline-offset: 0 !important;
}

.select2-container:focus,
.select2-container *:focus,
.select2-selection:focus,
.select2-selection *:focus,
.select2-dropdown:focus,
.select2-dropdown *:focus,
.select2-container:focus-visible,
.select2-container *:focus-visible,
.select2-selection:focus-visible,
.select2-selection *:focus-visible,
.select2-dropdown:focus-visible,
.select2-dropdown *:focus-visible {
  outline: none !important;
  outline-offset: 0 !important;
}

/* Single Selection Styling */
.select2-container--default .select2-selection--single {
  background-color: var(--wp--preset--color--base) !important;
  border: 1px solid var(--wp--preset--color--borderline) !important;
  border-radius: 0.25rem !important;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem !important;
  height: auto !important;
  min-height: 34px !important;
  display: flex !important;
  align-items: center !important;
  font-family: inherit !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: var(--wp--preset--color--contrast) !important;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out !important;
  box-sizing: border-box !important;
}

/* Selection Text */
.select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  color: var(--wp--preset--color--contrast) !important;
  padding: 0 !important;
  line-height: inherit !important;
  font-family: inherit !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
}

/* Placeholder Text */
.select2-container--default
  .select2-selection--single
  .select2-selection__placeholder {
  color: var(--wp--preset--color--contrast) !important;
  font-family: inherit !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  opacity: 1 !important;
  -webkit-text-fill-color: var(--wp--preset--color--contrast) !important;
  -webkit-opacity: 1 !important;
}

/* Force override for webkit and other browsers */
.select2-container--default
  .select2-selection--single
  .select2-selection__placeholder,
.select2-container--default
  .select2-selection--single
  .select2-selection__placeholder
  * {
  color: var(--wp--preset--color--contrast) !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  font-family: inherit !important;
  opacity: 1 !important;
  -webkit-text-fill-color: var(--wp--preset--color--contrast) !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}

/* Arrow Styling */
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow {
  height: 100% !important;
  position: absolute !important;
  top: 0 !important;
  right: 0.75rem !important;
  width: 16px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Completely hide default Select2 arrows */
.select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b,
.select2-container--classic
  .select2-selection--single
  .select2-selection__arrow
  b,
span.select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b,
span.select2-container--classic
  .select2-selection--single
  .select2-selection__arrow
  b {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

/* Higher specificity to override Select2 defaults */
span.select2-container--default
  .select2-selection--single
  .select2-selection__arrow::after,
.select2-container--default.select2-container
  .select2-selection--single
  .select2-selection__arrow::after {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 12px !important;
  height: 12px !important;
  background-color: var(--wp--preset--color--contrast) !important;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3E%3C/svg%3E") !important;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='black' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3E%3C/svg%3E") !important;
  mask-repeat: no-repeat !important;
  mask-position: center !important;
  mask-size: contain !important;
  -webkit-mask-size: contain !important;
  transform: translate(-50%, -50%) !important;
  pointer-events: none !important;
}

/* Focus State */
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
  border-color: var(--wp--preset--color--accent) !important;
  outline: 0 !important;
  color: var(--wp--preset--color--contrast) !important;
  background-color: var(--wp--preset--color--base);
}

/* Open State Arrow - Higher specificity */
span.select2-container--default.select2-container--open
  .select2-selection--single
  .select2-selection__arrow::after,
.select2-container--default.select2-container.select2-container--open
  .select2-selection--single
  .select2-selection__arrow::after {
  transform: translate(-50%, -50%) rotate(180deg) !important;
}

/* Dropdown Styling */
.select2-dropdown {
  background-color: var(--wp--preset--color--base) !important;
  border: 1px solid var(--wp--preset--color--borderline) !important;
  border-radius: 0.25rem !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  font-family: inherit !important;
  z-index: 1051 !important;
}

/* Dropdown Options */
.select2-results__options {
  max-height: 200px !important;
  overflow-y: auto !important;
}

.select2-results__option {
  padding: 0.5rem 0.75rem !important;
  color: var(--wp--preset--color--contrast) !important;
  background-color: var(--wp--preset--color--base) !important;
  cursor: pointer !important;
  transition: background-color 0.15s ease-in-out !important;
}

/* Highlighted/Hovered Option */
.select2-container--default
  .select2-results__option--highlighted[aria-selected] {
  background-color: var(--wp--preset--color--accent) !important;
  color: var(--wp--preset--color--base) !important;
}

/* Selected Option */
.select2-container--default .select2-results__option[aria-selected='true'] {
  background-color: var(--wp--preset--color--base-3) !important;
  color: var(--wp--preset--color--contrast) !important;
}

/* Multiple Selection Styling */
.select2-container--default .select2-selection--multiple {
  background-color: var(--wp--preset--color--base) !important;
  border: 1px solid var(--wp--preset--color--borderline) !important;
  border-radius: 0.25rem !important;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem;
  min-height: 38px !important;
  cursor: text !important;
}

.select2-container--default
  .select2-selection--multiple
  .select2-selection__rendered {
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.25rem !important;
}

/* Multiple Selection Choices */
.select2-container--default
  .select2-selection--multiple
  .select2-selection__choice {
  background-color: var(--wp--preset--color--base-2) !important;
  border: 1px solid var(--wp--preset--color--borderline) !important;
  border-radius: 0.25rem !important;
  color: var(--wp--preset--color--contrast) !important;
  cursor: default !important;
  font-size: 0.875rem !important;
  line-height: 1 !important;
  padding: 0.1rem 0.5rem !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.25rem !important;
}

/* Remove Button for Multiple Choices */
.select2-container--default
  .select2-selection--multiple
  .select2-selection__choice__remove {
  color: var(--wp--preset--color--contrast) !important;
  cursor: pointer !important;
  display: inline-block !important;
  font-weight: bold !important;
  line-height: 1 !important;
  margin-right: 0 !important;
  padding: 0 !important;
  transition: color 0.15s ease-in-out !important;
}

.select2-container--default
  .select2-selection--multiple
  .select2-selection__choice__remove:hover {
  color: #e74c3c !important;
}

/* Search Field in Multiple Selection */
.select2-container--default .select2-search--inline .select2-search__field {
  background: transparent !important;
  border: none !important;
  outline: 0 !important;
  box-shadow: none !important;
  color: var(--wp--preset--color--contrast) !important;
  font-size: 1rem !important;
  margin: 0 !important;
  padding: 0 !important;
  min-width: 5em !important;
  caret-color: transparent !important;
}

/* Placeholder for inline search field - Multiple specific selectors */
.select2-container--default
  .select2-search--inline
  .select2-search__field::placeholder,
.select2-container .select2-search--inline .select2-search__field::placeholder,
.select2-search--inline .select2-search__field::placeholder {
  font-size: 1rem !important;
  color: var(--wp--preset--color--contrast) !important;
  opacity: 1 !important;
}

/* Webkit specific placeholder styling */
.select2-container--default
  .select2-search--inline
  .select2-search__field::-webkit-input-placeholder,
.select2-container
  .select2-search--inline
  .select2-search__field::-webkit-input-placeholder {
  font-size: 1rem !important;
  color: var(--wp--preset--color--contrast) !important;
  opacity: 1 !important;
}

/* Mozilla specific placeholder styling */
.select2-container--default
  .select2-search--inline
  .select2-search__field::-moz-placeholder,
.select2-container
  .select2-search--inline
  .select2-search__field::-moz-placeholder {
  font-size: 1rem !important;
  color: var(--wp--preset--color--contrast) !important;
  opacity: 1 !important;
}

/* Show cursor only when actively focused and typing */
.select2-container--default
  .select2-search--inline
  .select2-search__field:focus {
  caret-color: var(--wp--preset--color--contrast) !important;
}

/* Disabled State */
.select2-container--default.select2-container--disabled
  .select2-selection--single,
.select2-container--default.select2-container--disabled
  .select2-selection--multiple {
  background-color: var(--wp--preset--color--base-2) !important;
  color: var(--wp--preset--color--base-3) !important;
  cursor: not-allowed !important;
}

/* Search Field in Dropdown */
.select2-search--dropdown {
  background-color: var(--wp--preset--color--base) !important;
  padding: 0.5rem !important;
  border-bottom: 1px solid var(--wp--preset--color--borderline) !important;
}

.select2-search--dropdown .select2-search__field {
  background-color: var(--wp--preset--color--base) !important;
  border: 1px solid var(--wp--preset--color--borderline) !important;
  border-radius: 0.25rem !important;
  color: var(--wp--preset--color--contrast) !important;
  font-size: 1rem !important;
  padding: 0.375rem 0.75rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Placeholder for dropdown search field - Multiple specific selectors */
.select2-search--dropdown .select2-search__field::placeholder,
.select2-dropdown .select2-search--dropdown .select2-search__field::placeholder,
span.select2-dropdown
  .select2-search--dropdown
  .select2-search__field::placeholder {
  font-size: 1rem !important;
  color: var(--wp--preset--color--contrast) !important;
  opacity: 1 !important;
}

/* Webkit specific placeholder styling for dropdown */
.select2-search--dropdown .select2-search__field::-webkit-input-placeholder,
.select2-dropdown
  .select2-search--dropdown
  .select2-search__field::-webkit-input-placeholder {
  font-size: 1rem !important;
  color: var(--wp--preset--color--contrast) !important;
  opacity: 1 !important;
}

/* Mozilla specific placeholder styling for dropdown */
.select2-search--dropdown .select2-search__field::-moz-placeholder,
.select2-dropdown
  .select2-search--dropdown
  .select2-search__field::-moz-placeholder {
  font-size: 1rem !important;
  color: var(--wp--preset--color--contrast) !important;
  opacity: 1 !important;
}

.select2-search--dropdown .select2-search__field:focus {
  border-color: var(--wp--preset--color--accent) !important;
  outline: 0 !important;
  color: var(--wp--preset--color--contrast) !important;
  background-color: var(--wp--preset--color--base);
}

/* No Results Message */
.select2-results__message {
  color: var(--wp--preset--color--contrast) !important;
  font-style: italic !important;
  padding: 1rem !important;
  text-align: center !important;
}

/* Loading State */
.select2-results__option[role='group'] {
  padding: 0 !important;
}

.select2-results__group {
  cursor: default !important;
  display: block !important;
  padding: 0.5rem 0.75rem !important;
  font-weight: bold !important;
  color: var(--wp--preset--color--accent) !important;
  background-color: var(--wp--preset--color--base-2) !important;
}

/* Clear Button */
.select2-container--default
  .select2-selection--single
  .select2-selection__clear {
  color: var(--wp--preset--color--contrast) !important;
  cursor: pointer !important;
  float: right !important;
  font-weight: bold !important;
  margin-right: 1.5rem !important;
  transition: color 0.15s ease-in-out !important;
}

.select2-container--default
  .select2-selection--single
  .select2-selection__clear:hover {
  color: #e74c3c !important;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .select2-dropdown {
    font-size: var(--wp--preset--font-size--medium) !important;
  }

  .select2-results__option {
    padding: 0.75rem !important;
  }
}

/********** Address Auto complete **********/

.jet-form-builder__field.jet-address-autocomplete {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #495057;
  background-color: transparent;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  border-radius: 0.25rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.jet-form-builder__field.jet-address-autocomplete::placeholder {
  color: #6c757d;
}

.jet-form-builder__field.jet-address-autocomplete:focus {
  border-color: var(--wp--preset--color--accent); /* Customize as needed */
  outline: 0;
  color: var(--wp--preset--color--contrast) !important;
  background-color: var(--wp--preset--color--base);
}

/* Placeholder styles to ensure consistency */
.jet-form-builder__field.jet-address-autocomplete:focus::placeholder {
  color: #6c757d;
}

/********** 15. Repeater Field **********/

/* Add more button styling */

.jet-form-builder-repeater__new {
  color: var(--wp--preset--color--base);
  background-color: var(--wp--preset--color--accent);
  border: 0px;
  border-radius: var(--button-border-radius);
  padding: 8px 16px 8px 16px;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 400;
  transition: all 0.3s ease;
  cursor: pointer;
}

.jet-form-builder-repeater__new:hover {
  background-color: color-mix(
    in srgb,
    var(--wp--preset--color--accent) 90%,
    white
  ) !important;
  transition: all 0.3s ease;
}

/* Remove button styling */

.jet-form-builder-repeater__remove {
  color: var(--wp--preset--color--contrast);
  background-color: var(--wp--preset--color--base-2);
  border: 0px;
  border-radius: 4px;
  transition: all 0.3s ease;
  cursor: pointer;
  height: 26px;
  width: 26px;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  padding: 0px !important;
  font-size: 22px;
  line-height: 1;
  font-family: system-ui;
  padding-top: 8px !important;
  padding-bottom: 10px !important;
}

.jet-form-builder-repeater__remove:hover {
  background-color: var(--wp--preset--color--base-3);
  transition: all 0.3s ease;
}

/********** 16. Action Buttons **********/

/* Remove button styling */

.jet-form-builder__prev-page {
  background-color: var(--wp--preset--color--base-2) !important;
  color: var(--wp--preset--color--contrast) !important;
}

.jet-form-builder__prev-page:hover {
  background-color: var(--wp--preset--color--base-3) !important;
  color: var(--wp--preset--color--contrast) !important;
}

.jet-form-builder__submit,
.jet-form-builder__prev-page,
.jet-form-builder__next-page {
  padding: var(--button-padding-y) var(--button-padding-x) !important;
  justify-content: center !important;
  border-radius: var(--button-border-radius) !important;
  border: 0px !important;
  font-size: var(--wp--preset--font-size--small) !important;
}

.jet-form-builder__submit {
  background-color: var(--wp--preset--color--accent) !important;
  color: var(--wp--preset--color--base) !important;
}

.jet-form-builder__prev-page {
  background-color: var(--wp--preset--color--base-2) !important;
  color: var(--wp--preset--color--contrast) !important;
}

.jet-form-builder__next-page {
  background-color: var(--wp--preset--color--accent) !important;
  color: var(--wp--preset--color--base) !important;
}

.jet-form-builder__prev-page:hover {
  background-color: var(--wp--preset--color--base-3) !important;
  color: var(--wp--preset--color--contrast) !important;
}

.jet-form-builder__next-page:hover {
  background-color: color-mix(
    in srgb,
    var(--wp--preset--color--accent) 90%,
    white
  ) !important;
  color: white !important;
}

/********** 17. Required Icon **********/

/* Style the required icon */

.jet-form-builder__required {
  color: var(--wp--preset--color--accent) !important;
}

/********** 18. Validation Message **********/

.jet-form-builder__next-page-msg {
  background-color: var(--wp--preset--color--base-2); /* Background color */
  color: var(--wp--preset--color--contrast); /* Text color */
  border: 1px solid var(--wp--preset--color--borderline); /* Border color */
  padding: 0.5rem 1rem; /* Padding for spacing */
  border-radius: 4px; /* Rounded corners for a softer look */
  font-weight: 500; /* Slightly bold for emphasis */
  margin-top: 1rem; /* Spacing above the message */
  text-align: center; /* Center the message */
  font-size: var(--wp--preset--font-size--small) !important;
}

/********** 19. Progress Bar Styling **********/

/* Remove progress bar on mobile */

@media (max-width: 600px) {
  /* Jet form builder progress pages */
  .jet-form-builder-progress-pages {
    display: none !important;
  }
}

/* Label for the progress bar */

.jet-form-builder-progress-pages__item--label {
  color: var(--wp--preset--color--contrast);
  font-weight: bold;
  font-size: 0.8rem;
  line-height: 1.1;
}

/* General styles for the progress bar container */
.jet-form-builder-progress-pages {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--wp--preset--spacing--10);
  background-color: var(--wp--preset--color--base); /* Container background */
  border: 1px;
  border-style: solid;
  border-radius: 7px;
  border-color: var(--wp--preset--color--borderline) !important;
  max-width: 100%;
  margin-bottom: 1rem;
  row-gap: 1rem;
}

.active-page .jet-form-builder-progress-pages__item--circle {
  border: 2px solid var(--wp--preset--color--accent) !important;
  background-color: var(--wp--preset--color--base) !important;
  color: var(--wp--preset--color--contrast) !important;
}

.active-page
  .jet-form-builder-progress-pages__item
  + .jet-form-builder-progress-pages__separator {
  background-color: var(--wp--preset--color--accent) !important;
  height: 2px !important;
}

.jfb-progress-type--default .jet-form-builder-progress-pages__item--wrapper {
  margin-bottom: 1em;
}

.passed-page .jet-form-builder-progress-pages__item--circle {
  border: 2px solid var(--wp--preset--color--accent) !important;
  color: #ffffff;
}

.passed-page
  .jet-form-builder-progress-pages__item
  + .jet-form-builder-progress-pages__separator {
  background-color: var(--wp--preset--color--accent) !important;
  height: 2px;
}

/* Circle for each step number */
.jet-form-builder-progress-pages__item--circle {
  width: 2rem;
  height: 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: var(--button-border-radius) !important;
  font-weight: bold;
  font-size: 0.8rem;
  color: var(--wp--preset--color--base-2);
}

/* Passed (completed) step */
.passed-page .jet-form-builder-progress-pages__item--circle {
  background-color: var(--wp--preset--color--accent);
  border: 2px solid var(--wp--preset--color--borderline);
}

.passed-page .jet-form-builder-progress-pages__item--label {
  color: var(--wp--preset--color--accent);
  font-weight: bold;
}

/* Active (current) step */
.active-page .jet-form-builder-progress-pages__item--circle {
  background-color: var(--wp--preset--color--contrast);
  border: 2px solid var(--wp--preset--color--borderline);
}

.active-page .jet-form-builder-progress-pages__item--label {
  color: var(--wp--preset--color--contrast);
  font-weight: bold;
}

/* Upcoming step */
.jet-form-builder-progress-pages__item--wrapper:not(.passed-page):not(
    .active-page
  )
  .jet-form-builder-progress-pages__item--circle {
  background-color: var(--wp--preset--color--base);
  border: 2px solid var(--wp--preset--color--contrast-3);
  color: var(--wp--preset--color--contrast-3);
}

.jet-form-builder-progress-pages__item--wrapper:not(.passed-page):not(
    .active-page
  )
  .jet-form-builder-progress-pages__item--label {
  color: var(--wp--preset--color--contrast-3);
}

/* Separator between each step */
.jet-form-builder-progress-pages__separator {
  flex-grow: 1;
  height: 4px;
  background-color: var(--wp--preset--color--borderline);
  margin: 0 0.5rem;
}

.passed-page + .jet-form-builder-progress-pages__separator,
.active-page + .jet-form-builder-progress-pages__separator {
  background-color: var(--wp--preset--color--accent);
}

/********** 20. Word Counter Styling **********/

/* Word counter display for textarea fields with word limits */
.jet-form-word-count {
  display: block;
  margin-top: 0.5rem;
  font-size: 12px !important;
  color: var(--wp--preset--color--contrast);
  font-weight: 400;
  line-height: 1.4;
  transition: color 0.2s ease, background-color 0.2s ease;
}

/* Error state when word limit is exceeded */
.jet-form-word-count.error {
  color: #cf2e2e !important;
}

/* Responsive adjustments for word counter */
@media (max-width: 767px) {
  .jet-form-word-count {
    font-size: 11px !important;
    margin-top: 0.375rem;
  }
}

/* Enhanced textarea styling when word limit is active */
textarea.jet-form-builder__field.textarea-field[data-word-limit] {
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  resize: vertical; /* Allow vertical resizing */
}

/* Optional: Add a subtle visual indicator for word-limited textareas */
textarea.jet-form-builder__field.textarea-field[data-word-limit]:focus {
  color: var(--wp--preset--color--contrast) !important;
  background-color: var(--wp--preset--color--base);
  border-color: var(--wp--preset--color--accent); /* Customize as needed */
}

/* JetFormBuilder Word Counter Styles */
.jet-form-word-count {
  font-size: 12px !important;
  color: var(--wp--preset--color--contrast);
  margin-top: 0.5rem;
  font-weight: 400;
  line-height: 1.4;
}

/* WYSIWYG Editor Word Counter */
.wp-editor-wrap .jet-form-word-count,
.jet-form-builder__field.wysiwyg-field .jet-form-word-count {
  margin-top: 0.5rem;
  padding: 0.25rem 0;
  border: 1px solid var(--wp--preset--color--borderline);
  background: var(--wp--preset--color--base-2);
  padding-left: 0.5rem;
  font-size: 11px !important;
}

/* Mobile responsiveness for word counter */
@media (max-width: 768px) {
  .jet-form-word-count {
    font-size: 11px !important;
  }

  .wp-editor-wrap .jet-form-word-count,
  .jet-form-builder__field.wysiwyg-field .jet-form-word-count {
    font-size: 10px !important;
  }
}
