/* FORM CONTROLS */
.form-control,
.form-select,
.form-check-input,
.form-control[disabled] {
  --bs-border-color: var(--color-primary-3);
  background-color: var(--color-primary-1);
}

.form-control:focus,
.form-select:focus,
.form-check-input:focus {
  border-color: var(--color-primary-accent);
  box-shadow: none;
}

/* style disabled and readonly controls */
.form-control:read-only,
.form-control:disabled {
  opacity: 0.5;
}

.form-control:disabled:focus {
  border-color: var(--bs-border-color);
  box-shadow: none;
}

.form-floating > .form-control:disabled ~ label::after,
.form-floating > :disabled ~ label::after {
  background-color: transparent;
}

.form-control:read-only:focus {
  border-color: var(--bs-border-color);
  box-shadow: none;
}

/* BUTTONS */
.btn {
  border-radius: var(--bs-border-radius);
}

.btn-primary {
  --bs-btn-color: var(--color-primary-2);
  --bs-btn-bg: var(--color-primary-accent);
  --bs-btn-border-color: var(--color-primary-accent);

  --bs-btn-hover-color: var(--color-primary-accent);
  --bs-btn-hover-bg: var(--color-primary-2);
  --bs-btn-hover-border-color: var(--color-primary-accent);

  --bs-btn-active-color: var(--color-primary-accent);
  --bs-btn-active-bg: var(--color-primary-3);
  --bs-btn-active-border-color: var(--color-primary-accent);

  --bs-btn-disabled-color: var(--color-primary-2);
  --bs-btn-disabled-bg: var(--color-primary-accent);
  --bs-btn-disabled-border-color: var(--color-primary-accent);
}

.btn-outline-primary {
  --bs-btn-color: var(--color-primary-accent);
  --bs-btn-border-color: var(--color-primary-accent);
  --bs-btn-bg: var(--color-primary-2);

  --bs-btn-hover-color: var(--color-primary-2);
  --bs-btn-hover-border-color: var(--color-primary-accent);
  --bs-btn-hover-bg: var(--color-primary-accent);

  --bs-btn-active-color: var(--color-primary-accent);
  --bs-btn-active-bg: var(--color-primary-3);
  --bs-btn-active-border-color: var(--color-primary-accent);

  --bs-btn-disabled-color: var(--color-primary-accent);
  --bs-btn-disabled-border-color: var(--color-primary-accent);
  --bs-btn-disabled-bg: var(--color-primary-2);
}

.btn-secondary {
  --bs-btn-bg: var(--color-primary-3);
  --bs-btn-border-color: var(--color-primary-3);

  --bs-btn-hover-bg: var(--color-primary-1);
  --bs-btn-hover-border-color: var(--color-primary-3);

  --bs-btn-active-bg: var(--color-primary-2);
  --bs-btn-active-border-color: var(--color-primary-3);

  --bs-btn-disabled-bg: var(--color-primary-3);
  --bs-btn-disabled-border-color: var(--color-primary-3);
}

/* BTN GROUP - used for switch list / overview on history messages page */
.btn-group label.btn-outline-primary {
  --bs-btn-color: var(--color-primary-accent);
  --bs-btn-bg: var(--color-primary-1);
  --bs-btn-border-color: var(--color-primary-3);

  --bs-btn-hover-color: var(--color-primary-2);
  --bs-btn-hover-bg: var(--color-primary-accent);
  --bs-btn-hover-border-color: var(--color-primary-3);

  --bs-btn-active-color: var(--color-primary-1);
  --bs-btn-active-bg: var(--color-primary-accent);
  --bs-btn-active-border-color: var(--color-primary-3);
}

.actions-dropdown-toggle,
.actions-dropdown-toggle:hover,
.actions-dropdown-toggle:focus,
.actions-dropdown-toggle:active,
.actions-dropdown-toggle.show,
.actions-dropdown-toggle[aria-expanded="true"],
.actions-dropdown-toggle-split-main,
.actions-dropdown-toggle-split-main:hover,
.actions-dropdown-toggle-split-main:focus,
.actions-dropdown-toggle-split-main:active,
.actions-dropdown-toggle-split,
.actions-dropdown-toggle-split:hover,
.actions-dropdown-toggle-split:focus,
.actions-dropdown-toggle-split:active,
.actions-dropdown-toggle-split.show,
.actions-dropdown-toggle-split[aria-expanded="true"] {
  color: var(--color-primary-accent) !important;
}

.btn-group .btn-outline-primary:hover,
.btn-group .btn-outline-primary:focus {
  background-color: var(--color-primary-3);
  border-color: var(--color-primary-3);
}

.btn-check:checked + .btn-outline-primary:hover,
.btn-check:checked + .btn-outline-primary:focus {
  color: var(--color-primary-1);
  background-color: var(--color-primary-accent);
}

/* DROPDOWN ACTION BUTTON */
.actions-dropdown-toggle + .dropdown-menu,
.actions-dropdown-toggle-split + .dropdown-menu {
  --bs-dropdown-bg: var(--color-primary-3);
  --bs-dropdown-border-color: var(--color-primary-3);
  --bs-dropdown-link-color: var(--color-primary-accent);
  --bs-dropdown-link-hover-color: var(--bs-body-color);
  --bs-dropdown-link-hover-bg: var(--color-primary-2);
}

.actions-dropdown-toggle,
.actions-dropdown-toggle-split-main,
.actions-dropdown-toggle-split {
  border: 1px solid var(--color-primary-3);
  box-shadow: none;
}

/* Actions dropdown button – zelfde look als desktop sidebar nav */
.actions-dropdown-toggle,
.actions-dropdown-toggle-split-main,
.actions-dropdown-toggle-split {
  background-color: transparent;
  color: var(--color-primary-accent);
  border-color: var(--color-primary-accent);
  font-size: 1rem;
  padding-inline: 1rem;
}

/* Split caret: compactere padding, zelfde kleuren als actions-dropdown-toggle */
.actions-dropdown-toggle-split.dropdown-toggle-split {
  padding-inline: 0.65rem;
}

.actions-dropdown-toggle:hover,
.actions-dropdown-toggle:focus,
.actions-dropdown-toggle:active,
.actions-dropdown-toggle.show,
.actions-dropdown-toggle-split-main:hover,
.actions-dropdown-toggle-split-main:focus,
.actions-dropdown-toggle-split-main:active,
.actions-dropdown-toggle-split:hover,
.actions-dropdown-toggle-split:focus,
.actions-dropdown-toggle-split:active,
.actions-dropdown-toggle-split.show {
  background-color: var(--color-primary-3); /* zelfde als nav.sidebar .nav-link:hover */
  color: var(--bs-body-color);
  border-color: transparent;
  box-shadow: none;
}

/* Split actions: hover op main óf caret = beide segmenten zelfde hover (body-kleur i.v.m. !important hierboven) */
.actions-dropdown-split-group:hover .actions-dropdown-toggle-split-main,
.actions-dropdown-split-group:hover .actions-dropdown-toggle-split {
  background-color: var(--color-primary-3);
  color: var(--bs-body-color) !important;
  border-color: transparent;
  box-shadow: none;
}

/* Menu open: beide segmenten blijven “actief” ook als de muis in het menu staat */
.actions-dropdown-split-group:has(.actions-dropdown-toggle-split.show) .actions-dropdown-toggle-split-main,
.actions-dropdown-split-group:has(.actions-dropdown-toggle-split.show) .actions-dropdown-toggle-split {
  background-color: var(--color-primary-3);
  color: var(--bs-body-color) !important;
  border-color: transparent;
  box-shadow: none;
}

/* Menu dicht + muis-focus (geen :focus-visible): voorkom “blijft actief” na hover-close */
.actions-dropdown-toggle-split.dropdown-toggle-split:not(.show):focus:not(:focus-visible) {
  background-color: transparent;
  color: var(--color-primary-accent) !important;
  border-color: var(--color-primary-accent);
  box-shadow: none;
}

/* PAGINATION */

li.page-item.active > a.page-link {
  --bs-pagination-hover-color: var(--color-primary-1);
  --bs-pagination-hover-bg: var(--color-primary-accent);
  --bs-pagination-active-color: var(--color-primary-1);
  --bs-pagination-active-bg: var(--color-primary-accent);
  --bs-pagination-active-border-color: var(--color-primary-3);
}

li.page-item:hover > a.page-link {
  cursor: pointer;
  --bs-pagination-hover-bg: var(--color-primary-3);
  --bs-pagination-hover-color: var(--bs-primary-accent);
}

/* START SELECT2 */
.select2-container--bootstrap-5 .select2-selection {
  background-color: var(--color-primary-1);
  border: 1px solid var(--color-primary-3);
  border-radius: var(--bs-border-radius);
  color: var(--bs-body-color);
}

.select2-container--bootstrap-5 .select2-dropdown {
  background-color: var(--color-primary-3);
  border: 1px solid var(--color-primary-3);
  border-radius: var(--bs-border-radius);
  color: var(--bs-body-color);
}

.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection {
  box-shadow: none;
  border-color: var(--color-primary-accent);
}

/* Search field*/
.select2-container--bootstrap-5 .select2-dropdown .select2-search .select2-search__field,
span.select2-search input.select2-search__field .select2-container--bootstrap-5 .select2-dropdown .select2-search .select2-search__field,
span.select2-search input.select2-search__field {
  background-color: var(--color-primary-1);
  color: var(--bs-body-color);
}

.select2-container--bootstrap-5 .select2-dropdown .select2-search .select2-search__field:focus {
  border-color: var(--color-primary-accent);
  box-shadow: none;
}

/* Style the options */
.select2-container--bootstrap-5 .select2-results__option {
  padding: 0.5rem 1rem;
  color: var(--bs-body-color);
  background-color: var(--color-primary-1);
}

.select2-container--bootstrap-5 .select2-results__option--highlighted {
  background-color: var(--color-primary-1);
  color: var(--bs-body-color);
}

/* Selected option */
.select2-container--bootstrap-5 .select2-dropdown .select2-results__options .select2-results__option.select2-results__option--selected,
.select2-container--bootstrap-5 .select2-dropdown .select2-results__options .select2-results__option[aria-selected="true"]:not(.select2-results__option--highlighted) {
  color: var(--color-primary-1);
  background-color: var(--color-primary-accent);
}

/* Highlighted (hover) option */
.select2-container--bootstrap-5 .select2-dropdown .select2-results__options .select2-results__option.select2-results__option--highlighted {
  background-color: var(--color-primary-3);
  color: var(--bs-body-color);
}

.select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered {
  color: var(--bs-body-color);
}

/* Prevents putting button after selectbox on next line when large value is selected (flow-builder page) */
div.input-group span.select2 {
  max-width: calc(100% - 50px);
}

/* DATATABLE */
div.dt-container div.dt-search input.dt-input,
div.dt-container div.dt-length select.dt-input {
  background-color: var(--color-primary-1);
  border-radius: var(--bs-border-radius);
  border: 1px solid var(--color-primary-3);
  margin: 0px;
  padding: 0.5rem 0.75rem;
}

div.dt-container div.dt-search input.dt-input:focus,
div.dt-container div.dt-length select.dt-input:focus {
  border: 1px solid var(--color-primary-accent);
  box-shadow: none;
  outline: none;
}

div.dt-container div.dt-length select.dt-input {
  margin-left: 1rem;
}

div.dt-container div.dt-length select.dt-input {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23dee2e6' stroke-width='2' viewBox='0 0 16 16'%3e%3cpath stroke-linecap='round' stroke-linejoin='round' d='M3 6l5 5 5-5'/%3e%3c/svg%3e") no-repeat right 0.75rem center/1rem 1rem;
  padding-right: 2.5rem; /* ruimte voor je custom arrow */
  background-color: var(--color-primary-1);
}

div.dt-container .dt-paging .dt-paging-button:first-child {
  border-top-left-radius: 0.75rem;
  border-bottom-left-radius: 0.75rem;
}

div.dt-container .dt-paging .dt-paging-button:last-child {
  border-top-right-radius: 0.75rem;
  border-bottom-right-radius: 0.75rem;
  border-right: 1px solid var(--color-primary-3);
}

div.dt-container .dt-paging .dt-paging-button,
div.dt-container .dt-paging span.ellipsis,
div.dt-container .dt-paging .dt-paging-button.disabled,
div.dt-container .dt-paging .dt-paging-button.disabled:hover,
div.dt-container .dt-paging .dt-paging-button.disabled:active {
  color: var(--color-primary-accent) !important;
  border: 1px solid var(--color-primary-3);
  border-right: 0;
  background-color: var(--color-primary-1);
  margin: 0px;
}

div.dt-container .dt-paging .dt-paging-button.current,
div.dt-container .dt-paging .dt-paging-button.current:hover {
  border: 1px solid var(--color-primary-3);
  border-right: 0;
  background-color: var(--color-primary-accent);
  color: var(--color-primary-1) !important;
}

div.dt-container .dt-paging .dt-paging-button:hover,
div.dt-container .dt-paging .dt-paging-button:active {
  background: none;
  background-color: var(--color-primary-3);
  color: var(--bs-body-color) !important;
  border: 1px solid var(--color-primary-3);
}

div.dt-container .dt-paging .dt-paging-button:hover:not(:last-child),
div.dt-container .dt-paging .dt-paging-button:active:not(:last-child) {
  border-right: 0;
}

div.dt-container .dt-paging .dt-paging-button.disabled,
div.dt-container .dt-paging .dt-paging-button.disabled:hover,
div.dt-container .dt-paging .dt-paging-button.disabled:active {
  color: var(--bs-secondary-color) !important;
}

div.dt-container .dt-paging span.ellipsis {
  height: 42px;
  display: inline-block;
  line-height: 42px;
  vertical-align: middle;
  overflow: hidden;
  position: relative;
  top: -1px;
}

/* DROPDOWN MENU/BUTTON */
ul.dropdown-menu li a.dropdown-item {
  cursor: pointer;
}

/* ACE EDITOR*/
.ace-editor {
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
}

/* TABNAV */
ul.tab-nav.nav {
  border-bottom: 1px solid var(--color-primary-3);
}

ul.tab-nav.nav li.nav-item a {
  color: var(--bs-text-body);
}

ul.tab-nav.nav .nav-item .nav-link.active {
  color: var(--color-primary-accent);
}

ul.tab-nav.nav .nav-item .nav-link.active:after {
  content: "";
  background-color: var(--color-primary-accent);
  position: absolute;
  left: 0px;
  bottom: 0px;
  width: 100%;
  height: 2px;
}

ul.tab-nav.nav li {
  position: relative;
  display: inline-block;
}

ul.tab-nav.nav li a:hover {
  color: var(--color-primary-accent);
  transition: all 0.5s ease-in-out;
}

ul.tab-nav.nav li.active:after,
ul.tab-nav.nav li:hover:after {
  background-color: var(--color-primary-accent);
  position: absolute;
  width: 100%;
}

ul.tab-nav.nav li:after {
  content: "";
  transition: all 0.5s ease-in-out;
  left: 0px;
  bottom: 0px;
  width: 0px;
  height: 2px;
}
