/* Buttons */
.btn-primary {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-text);
  transition: all 0.2s ease-in-out;
}

.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus,
.btn-primary.active {
  background-color: var(--btn-bg-hover)!important;
  border-color: var(--btn-bg-hover)!important;
  color: var(--color-text)!important;
}

.btn-secondary {
  background-color: var(--color-surface-hover);
  border-color: var(--color-surface-hover);
  color: var(--color-text);
}

.btn-secondary:hover,
.btn-secondary:focus {
  background-color: var(--btn-secondary-hover);
  border-color: var(--btn-secondary-hover);
  color: var(--color-text);
}

.btn-outline-primary {
  background-color: transparent;
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.btn-outline-primary:hover {
  background-color: var(--btn-bg-hover);
  border-color: var(--btn-bg-hover);
  color: var(--color-text);
}

.btn-danger {
  background-color: var(--color-danger, #dc3545);
  border: none;
  color: var(--color-text)!important;
  transition: background-color 0.2s ease, box-shadow 0.2s ease;
}

.btn-danger:hover,
.btn-danger:active,
.btn-danger:focus {
  background-color: var(--color-danger-hover, #ff6b6b)!important;
  color: var(--color-text)!important;
  box-shadow: 0 0 0 0.2rem rgba(255, 107, 107, 0.25);
}

.btn-danger:disabled,
.btn-danger.disabled {
  background-color: #5a2e30;
  color: #aaa;
  opacity: 0.6;
}


/* ========== TABLES ========== */
table {
  width: 100%;
  border-collapse: collapse;
  background-color: var(--color-surface);
  color: var(--color-text);
  font-size: 0.95rem;
  border-radius: 0.5rem;
  overflow: hidden;
  --bs-table-color: var(--color-text);
  --bs-table-bg: var(--color-surface);
  --bs-table-border-color: var(--color-border);
  --bs-table-striped-color: var(--color-text);
  --bs-table-striped-bg: var(--color-surface-alt);
  --bs-table-hover-color: var(--color-text);
  --bs-table-hover-bg: var(--color-surface-hover);
  --bs-table-active-color: var(--color-text);
  --bs-table-active-bg: var(--color-surface-hover);
}

.table > :not(caption) > * > * {
  padding: 0.75rem 1rem;
  color: var(--color-text);
  background-color: transparent;
  box-shadow: none;
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}

thead {
  background-color: var(--color-header);
}

table thead th {
  color: var(--color-primary);
  font-weight: 600;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--color-border);
}

tbody tr {
  border-bottom: 1px solid var(--color-border);
  transition: background-color 0.2s ease;
}

tbody tr:nth-child(even) {
  background-color: var(--color-surface-alt);
}

tbody tr.table-row-link:hover {
  cursor: pointer;
  background-color: var(--color-surface-hover);
}


/* Form fields */
.form-floating .form-control {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

.form-floating .form-control::placeholder {
  color: transparent;
}

.form-floating .form-control:focus {
  border-color: var(--color-primary);
  box-shadow: var(--box-shadow);
  background-color: var(--color-surface);
  color: var(--color-text);
}

.form-floating select.form-select {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23EAE6F2' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
}

.form-floating select.form-select:focus {
  border-color: var(--color-primary);
  box-shadow: var(--box-shadow);
  background-color: var(--color-surface);
  color: var(--color-text);
}

.form-floating label {
  color: var(--color-primary-hover)!important;
  transition: color 0.2s ease;
}

.form-floating label::after {
  background-color: var(--color-surface)!important;
}

.form-floating .form-control:focus + label,
.form-floating .form-control:not(:placeholder-shown) + label {
    color: var(--color-primary);
}



/* Dropdown */
.dropdown-menu {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  box-shadow: none;
  padding: 0;
}

.dropdown-item {
  padding: .5rem .7rem;
  color: var(--color-text);
  border-left: 3px solid transparent;
  transition: all 0.2s ease;
}

.dropdown-menu li:first-child .dropdown-item {
  border-radius:0.25rem 0.25rem 0 0;
}

.dropdown-menu li:last-child .dropdown-item {
  border-radius:0 0 0.25rem 0.25rem;
}

.dropdown-item:hover,
.dropdown-item:focus,
.dropdown-item.active,
.dropdown-item:active {
  background-color: var(--color-surface-hover);
  border-left-color: var(--color-primary);
  text-decoration: none;
  color: var(--color-text);
}

.dropdown-divider {
  border-color: var(--color-border);
}

.dropdown-menu .dropdown-item.active {
  background-color: var(--color-surface-hover);
  border-left-color: var(--color-primary);
  font-weight: 500;
}

.dropdown-menu .dropdown-item.text-danger {
  color: var(--color-danger) !important;
}

.dropdown-menu .dropdown-item.text-danger:hover {
  background-color: var(--color-danger-bg-hover);
  border-left-color: var(--color-danger-hover);
  color: var(--color-danger-hover) !important;
}

.dropdown-toggle {
  color: var(--color-text-muted);
  background-color: transparent;
  border: none;
  font-weight: normal;
  text-decoration: none;
  transition: color 0.2s ease;
}

.dropdown-toggle:hover,
.dropdown-toggle:focus {
  color: var(--color-primary-hover);
  background-color: transparent;
}

.dropdown-toggle.show {
  color: var(--color-primary-hover);
  background-color: transparent;
}

.nav-item .dropdown-toggle::after {
  display: none;
}


/* Language picker */

/* Only 2 languages */
.language-picker a.active {
  background-color: var(--color-surface-hover);
}

/* If more than 3 languages */
.language-picker-dropdown + .dropdown-menu {
  min-width: 50px;
}

.language-picker-dropdown + .dropdown-menu .dropdown-item {
  padding-top: .5rem;
  padding-bottom: .6rem;
}

/* Breadcrumb */
.breadcrumb-item+.breadcrumb-item::before {
    color: var(--color-text-muted);
}


/* Accordions */
.accordion {
  background-color: transparent;
}

.accordion-item {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

.accordion-button {
  background-color: var(--color-surface);
  color: var(--color-text);
  box-shadow: none;
  border: none;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.accordion-button:hover {
  background-color: var(--color-surface-hover);
}

.accordion-button:not(.collapsed) {
  background-color: var(--color-surface-hover);
  color: var(--color-text);
}

.accordion-button::after {
  filter: brightness(0.8) saturate(1.5);
}

/* Contenu */
.accordion-body {
  background-color: var(--color-surface);
  color: var(--color-text);
}

/* Flèche pliée (état collapsed) */
.accordion-button::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23EAE6F2' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
}

/* Flèche dépliée (état ouvert = .not(.collapsed)) */
.accordion-button:not(.collapsed)::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23EAE6F2' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
}

.accordion-button:focus {
  box-shadow: var(--box-shadow);
  border-color: var(--color-border);
}

input[type="date"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="month"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator {
  filter: brightness(2.5) invert(100%) sepia(4%) saturate(250%) hue-rotate(265deg);
  opacity: 1;
}

/* Side Menu */
.side-menu {
  background-color:#1E1A29;
}

.side-menu .nav-item:first-child .nav-link {
  border-radius:0.25rem 0.25rem 0 0;
}

.side-menu .nav-item:last-child .nav-link {
  border-radius:0 0 0.25rem 0.25rem;
}
  
.side-menu .nav-link {
  padding: 0.6rem 1rem;
  color: var(--color-text);
  border-left: 3px solid transparent;
  transition: all 0.2s ease;
}

.side-menu .nav-link:hover,
.side-menu .nav-link.active {
  background-color: var(--color-surface-hover);
  border-left-color: var(--color-primary);
  text-decoration: none;
}

.side-menu .nav-link.text-danger:hover {
  background-color: var(--color-danger-bg-hover);
  border-left-color: var(--color-danger-hover);
  color: var(--color-danger-hover) !important;
}

.side-menu .text-danger {
  color: var(--color-danger) !important;
}

/* Modal */
.modal-backdrop.show {
  opacity: 0.7;
  background-color: #000;
  transition: opacity 0.4s ease-in-out;
}

.modal-header {
  background-color: var(--color-header);
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
  padding: 1rem;
  border-radius: .5rem .5rem 0 0;
}

.modal-header .modal-title {
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.05em;
  font-size: 1.1rem;
  color: var(--color-text);
}

.modal-content {
    background-color: var(--color-surface);
    color: var(--color-text);
    border: 0;
    border-radius: .5rem;
    overflow: hidden;
}