/* =============================================
   SELECT2 ORANGE OVERRIDES (SISFIC BRAND #d65a1f)
   ============================================= */

/* =============================================
   CUSTOM TABS MEDICUX CYAN
   ============================================= */
.medicux-blocked-panel {
  opacity: 0.4;
  pointer-events: none;
  filter: grayscale(0.5);
  transition: all 0.3s ease;
  user-select: none;
}

.custom-tabs .nav-link {
  color: #64748b !important;
  font-weight: 600 !important;
  border: none !important;
  border-bottom: 3px solid transparent !important;
  padding: 0.6rem 1.2rem !important;
  transition: all 0.2s ease !important;
}

.custom-tabs .nav-link:hover {
  color: var(--medicux-cyan) !important;
  background-color: rgba(0, 200, 224, 0.05) !important;
}

.custom-tabs .nav-link.active {
  color: var(--medicux-cyan) !important;
  background-color: transparent !important;
  border-bottom-color: var(--medicux-cyan) !important;
}

.custom-tabs .nav-link i {
  margin-right: 6px;
}

/* =============================================
   JOXCO TAGSINPUT MEDICUX BRANDING
   ============================================= */
div.tagsinput {
  border: 1px solid #cbd5e1 !important;
  border-radius: var(--radius-sm) !important;
  padding: 5px !important;
  background: #ffffff !important;
  font-family: 'Inter', sans-serif !important;
}

div.tagsinput span.tag {
  background: var(--medicux-cyan) !important;
  color: #ffffff !important;
  border: none !important;
  padding: 3px 8px !important;
  border-radius: 4px !important;
  font-size: 0.75rem !important;
  font-weight: 500 !important;
  margin-bottom: 5px !important;
  margin-right: 5px !important;
}

div.tagsinput span.tag a {
  color: #ffffff !important;
  font-weight: bold !important;
  text-decoration: none !important;
  font-size: 11px !important;
}

div.tagsinput input {
  color: #1e293b !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.8125rem !important;
}

div.tagsinput .not_valid {
  background: #ef4444 !important;
  color: #ffffff !important;
}

/* Focus Border - Container (TODOS LOS ESTADOS) */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--single:focus,
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--single {
  border-color: #00C8E0 !important;
}

.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple {
  border-color: #00C8E0 !important;
  box-shadow: 0 0 0 0.2rem rgba(0, 200, 224, 0.25) !important;
}

/* Select2 Search Input Field - CRITICAL FIX */
.select2-search__field,
.select2-search__field:focus,
.select2-container--default .select2-search--dropdown .select2-search__field {
  border-color: #00C8E0 !important;
  outline: none !important;
}

.select2-search__field:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 200, 224, 0.25) !important;
}

/* Dropdown Highlighted Option (Hover/Keyboard Navigation) */
.select2-container--default .select2-results__option--highlighted,
.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: #00C8E0 !important;
  color: white !important;
}

/* Selected Option in Multiple (if used) */
.select2-container--default .select2-results__option[aria-selected=true] {
  background-color: #e0f7fa !important;
  /* Very Light Cyan */
  color: #343a40 !important;
}

/* =============================================
   SELECT2 IN MODALS FIX - Z-INDEX
   ============================================= */
/* Fix para Select2 en modales de Bootstrap - dropdown debe aparecer encima del modal */
.modal .select2-dropdown {
  z-index: 99999 !important;
  /* Valor extremadamente alto para asegurar que aparezca encima */
}

.select2-container--open {
  z-index: 99999 !important;
}

/* Fix para Select2 en dropdowns del navbar */
.dropdown-menu .select2-dropdown {
  z-index: 99999 !important;
}

/* Maximized card fix (AdminLTE) */
.maximized-card .select2-dropdown {
  z-index: 99999 !important;
}

/* =============================================
   SWEETALERT OVER BOOTSTRAP MODAL - Z-INDEX FIX
   ============================================= */
.modalControlsSweetAlertZIndex {
  z-index: 99999 !important;
}

.modalControlsSweetAlertZIndex .swal2-container {
  z-index: 99999 !important;
}

:root {
  --medicux-cyan: #00C8E0;
  --medicux-green: #4CB050;
  --medicux-blue: #1565C0;
  --medicux-dark: #1a1a2e;
  --medicux-light: #f4f6f9;
  --medicux-bg: #f8fafc;
  /* Clinical Background */
  --radius-md: 10px;
  --radius-sm: 5px;

  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.05);
  --shadow-premium: 0 10px 15px -3px rgba(0, 0, 0, 0.05);
}

/* Gender Badge Premium Colors */
.bg-pink {
  background-color: #f472b6 !important;
  /* Premium Pink */
  color: #fff !important;
}

.bg-purple {
  background-color: #a855f7 !important;
  /* Premium Purple */
  color: #fff !important;
}

/* Premium Dropdown Hover */
.dropdown-item:hover {
  background-color: var(--medicux-cyan) !important;
  color: #fff !important;
}

/* Base Body Styles */
body {
  background-color: var(--medicux-bg);
  color: var(--medicux-dark);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 0.8125rem;
  /* Standard Small Size */
}

/* Professional Clinical Light Background for Auth */
.login-bg-premium {
  background-color: #f1f5f9 !important;
  /* Bright Clinical Gray */
  background-image:
    radial-gradient(at 0% 0%, rgba(0, 200, 224, 0.03) 0, transparent 50%),
    radial-gradient(at 100% 100%, rgba(76, 176, 80, 0.03) 0, transparent 50%) !important;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Single clean login card - MEDICAL STANDARD */
.login-card-premium {
  background: #ffffff;
  width: 100%;
  max-width: 340px;
  padding: 20px;
  border-radius: var(--radius-md);
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.05), 0 8px 10px -6px rgba(0, 0, 0, 0.05);
  border: 1px solid #e2e8f0;
}

.login-logo-img {
  width: 300px;
  margin-bottom: 20px;
}

/* Form Overrides - STRICT GOLD STANDARD SM */
.form-control,
.form-select {
  border-radius: var(--radius-sm) !important;
  border: 1px solid #cbd5e1 !important;
  padding: 0.25rem 0.5rem;
  /* TRUE SM Padding - !important removed to prevent ITI overlap */
  font-size: 0.8125rem !important;
  /* Standard Small Size */
  height: auto !important;
  font-family: 'Inter', sans-serif !important;
  color: #1e293b !important;
}

.form-control:focus {
  border-color: var(--medicux-cyan) !important;
  box-shadow: 0 0 0 3px rgba(0, 200, 224, 0.1) !important;
}

/* JQuery Validate Error State - MEDICUX PREMIUM RED */
.form-control.is-invalid,
.form-select.is-invalid,
.select2-container--default.is-invalid .select2-selection--single {
  border-color: #ef4444 !important;
  /* Premium Red */
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23ef4444'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23ef4444' stroke='none'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right calc(0.375em + 0.1875rem) center !important;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem) !important;
  padding-right: calc(1.5em + 0.75rem) !important;
}

.input-group.is-invalid .input-group-text {
  border-color: #ef4444 !important;
  color: #ef4444 !important;
}

/* Custom Checkbox & Radio Branding */
.form-check-input:checked {
  background-color: var(--medicux-cyan) !important;
  border-color: var(--medicux-cyan) !important;
}

.form-check-input:focus {
  border-color: var(--medicux-cyan) !important;
  box-shadow: 0 0 0 0.25rem rgba(0, 200, 224, 0.1) !important;
}

.form-switch .form-check-input:checked {
  background-color: var(--medicux-cyan) !important;
  border-color: var(--medicux-cyan) !important;
}

.input-group-text {
  background-color: #f8fafc !important;
  border-color: #cbd5e1 !important;
  color: #64748b !important;
  border-radius: var(--radius-sm) !important;
  padding: 0.25rem 0.5rem !important;
  font-size: 0.8125rem !important;
}

/* Buttons - CRISP BRAND COLORS SM */
.btn {
  font-weight: 500 !important;
  padding: 0.25rem 0.75rem !important;
  /* btn-sm standard */
  border-radius: var(--radius-sm) !important;
  font-size: 0.8125rem !important;
  transition: all 0.2s ease !important;
}

.btn-info,
.btn-primary {
  background-color: var(--medicux-cyan) !important;
  border: none !important;
  color: #ffffff !important;
}

/* Ensure outline buttons have white text when checked/active */
.btn-check:checked+.btn-outline-info,
.btn-outline-info.active,
.btn-outline-info:active,
.btn-outline-info:hover,
.btn-outline-primary:hover,
.btn-outline-primary:active,
.btn-outline-primary.active {
  background-color: var(--medicux-cyan) !important;
  border-color: var(--medicux-cyan) !important;
  color: #ffffff !important;
}

/* Custom MediCux Button Classes */
.btn-medicux {
  background-color: var(--medicux-cyan) !important;
  border-color: var(--medicux-cyan) !important;
  color: #ffffff !important;
}

.btn-medicux:hover {
  background-color: #00acc1 !important;
  /* Darker Cyan */
  border-color: #00acc1 !important;
  color: #ffffff !important;
}

.btn-outline-medicux {
  border-color: var(--medicux-cyan) !important;
  color: #008CA0 !important;
  background-color: transparent !important;
}

.btn-outline-medicux:hover {
  background-color: var(--medicux-cyan) !important;
  color: #ffffff !important;
  border-color: var(--medicux-cyan) !important;
}

.btn-xs {
  padding: 0.125rem 0.4rem !important;
  font-size: 0.75rem !important;
  line-height: 1.5 !important;
  border-radius: 3px !important;
}

.text-xs {
  font-size: 0.8rem !important;
}

.text-sm {
  font-size: 0.9rem !important;
}

.text-muted {
  color: #94a3b8 !important;
}

.text-secondary {
  color: #64748b !important;
}

.text-cyan {
  color: var(--medicux-cyan) !important;
}

/* Dashboard UI Polish */
.content-wrapper {
  background-color: #f8fafc !important;
}

.card {
  border-radius: var(--radius-md) !important;
  border: 1px solid #e2e8f0 !important;
  box-shadow: var(--shadow-sm) !important;
  transition: all 0.2s ease;
}

.card:hover {
  box-shadow: var(--shadow-premium) !important;
}

.app-sidebar {
  background-color: #ffffff !important;
  border-right: 1px solid #e2e8f0 !important;
}

.app-header {
  border-bottom: 2px solid var(--medicux-cyan) !important;
  background-color: rgba(255, 255, 255, 0.95) !important;
}

.glass-effect {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.shadow-premium {
  box-shadow: var(--shadow-premium) !important;
}

.app-sidebar .nav-link {
  color: #64748b !important;
  font-weight: 500;
}

.app-sidebar .nav-link:hover {
  background-color: #f8fafc !important;
  color: var(--medicux-cyan) !important;
}

.app-sidebar .nav-link.active {
  background-color: var(--medicux-cyan) !important;
  color: white !important;
  box-shadow: 0 4px 6px -1px rgba(0, 200, 224, 0.2);
}

.app-footer {
  background-color: #ffffff !important;
  border-top: 1px solid #e2e8f0 !important;
  padding: 0.75rem 1rem !important;
}

/* Dashboard Premium Stat Cards - CLEAN SAAS DESIGN */
.card-premium-stat {
  background: #ffffff;
  border-radius: var(--radius-md);
  padding: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid #e2e8f0;
  margin-bottom: 1.5rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.card-premium-stat:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 20px -5px rgba(0, 0, 0, 0.05);
  border-color: var(--medicux-cyan);
}

.card-premium-stat .meta-info h3 {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0;
  color: var(--medicux-dark);
}

.card-premium-stat .meta-info p {
  font-size: 0.6875rem;
  /* 11px */
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
  margin: 0.25rem 0 0 0;
}

.stat-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
}

/* Icon Variants */
.stat-icon.cyan {
  background: rgba(0, 200, 224, 0.1);
  color: #00C8E0;
}

.stat-icon.blue {
  background: rgba(21, 101, 192, 0.1);
  color: #1565C0;
}

.stat-icon.green {
  background: rgba(76, 176, 80, 0.1);
  color: #4CB050;
}

.stat-icon.red {
  background: rgba(220, 53, 69, 0.1);
  color: #dc3545;
}

.stat-icon.orange {
  background: rgba(255, 152, 0, 0.1);
  color: #ff9800;
}

.stat-icon.purple {
  background: rgba(103, 58, 183, 0.1);
  color: #673ab7;
}

.stat-icon.gray {
  background: rgba(100, 116, 139, 0.1);
  color: #64748b;
}

/* Dashboard Cards Overrides (Bootstrap 5 / AdminLTE 4) */
.card-row {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

.card-row .card-header {
  border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
  padding: 0.75rem 1rem !important;
}

.card-row .card-title {
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

/* Breadcrumb Branding */
.breadcrumb-item a,
.breadcrumb-item.active {
  color: var(--medicux-cyan) !important;
}

.breadcrumb-item+.breadcrumb-item::before {
  color: #cbd5e1 !important;
}

/* Modal Headers - Text White on Brand Colors */
.modal-header.bg-info,
.modal-header.bg-primary,
.modal-header[style*='background-color: var(--medicux-cyan)'],
.modal-header[style*='background: var(--medicux-cyan)'] {
  color: #ffffff !important;
}

.modal-header.bg-info .modal-title,
.modal-header.bg-primary .modal-title,
.modal-header[style*='background-color: var(--medicux-cyan)'] .modal-title,
.modal-header[style*='background: var(--medicux-cyan)'] .modal-title {
  color: #ffffff !important;
}

.modal-header.bg-info .btn-close,
.modal-header.bg-primary .btn-close,
.modal-header[style*='background-color: var(--medicux-cyan)'] .btn-close,
.modal-header[style*='background: var(--medicux-cyan)'] .btn-close {
  filter: brightness(0) invert(1);
  /* Make close button white */
}

/* DataTables UI Standardization - MEDICUX GOLD STANDARD (COMPACT) */
.dataTables_wrapper,
table.dataTable,
.dataTables_wrapper .dt-buttons,
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_info {
  font-size: 0.775rem !important;
}

/* Pagination Compact & Brand Color */
.dataTables_wrapper .pagination .page-link {
  color: #64748b !important;
  padding: 0.25rem 0.6rem !important;
  font-size: 0.75rem !important;
  background-color: #ffffff !important;
  border: 1px solid #dee2e6 !important;
}

.dataTables_wrapper .pagination .page-item.active .page-link {
  background-color: var(--medicux-cyan) !important;
  border-color: var(--medicux-cyan) !important;
  color: #ffffff !important;
  box-shadow: 0 4px 6px -1px rgba(0, 200, 224, 0.2) !important;
}

.dataTables_wrapper .pagination .page-item:not(.active) .page-link:hover {
  background-color: #f8fafc !important;
  color: var(--medicux-cyan) !important;
  border-color: #cbd5e1 !important;
}

/* DataTables Button Style Normalization (Clean Bootstrap Look) */
.dataTables_wrapper .dt-buttons {
  float: left;
  margin-left: 10px !important;
  margin-bottom: 5px !important;
}

/* Target both .btn and .dt-button to ensure override */
.dataTables_wrapper .dt-buttons .btn,
.dataTables_wrapper .dt-button {
  background: #ffffff !important;
  background-image: none !important;
  /* Kill DataTables default gradient */
  border: 1px solid #cbd5e1 !important;
  color: #64748b !important;
  padding: 0.3rem 0.6rem !important;
  margin-right: 0.35rem !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.2s ease !important;
}

.dataTables_wrapper .dt-buttons .btn:hover,
.dataTables_wrapper .dt-button:hover:not(.disabled) {
  background-color: #f8fafc !important;
  border-color: var(--medicux-cyan) !important;
  color: var(--medicux-cyan) !important;
  background-image: none !important;
}

/* Fix Colvis dropdown indicator */
.buttons-colvis::after {
  margin-left: 0.5rem !important;
}

/* TABLE BASE STYLES */
table.dataTable {
  border-collapse: collapse !important;
  border-spacing: 0 !important;
  width: 100% !important;
  margin-bottom: 0 !important;
  border-bottom: none !important;
  border-color: #dee2e6 !important;
}

table.dataTable.no-footer {
  border-bottom: 1px solid #dee2e6 !important;
}

/* Ghost Row / Sizing Row Fix */
.dataTables_scrollBody thead tr,
.dataTables_scrollBody thead th,
.dataTables_scrollBody thead td,
table.dataTable thead th[style*="height: 0px"],
table.dataTable thead tr[style*="height: 0px"] {
  height: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  border-top-width: 0 !important;
  border-bottom-width: 0 !important;
  overflow: hidden !important;
  visibility: collapse !important;
  line-height: 0 !important;
  display: none !important;
}

/* Layout - Floats */
.dataTables_wrapper .dataTables_length {
  float: left;
  margin-bottom: 10px;
}

.dataTables_wrapper .dt-buttons {
  float: left;
  margin-left: 10px;
  margin-bottom: 10px;
  background: transparent !important;
}

/* Clearfix */
.dataTables_wrapper .row:first-child::after {
  content: "";
  clear: both;
  display: table;
}

/* Header - White Background, Dark Text, MediCux Cyan Bottom Border */
table.dataTable thead th,
table.dataTable thead td {
  background-color: #ffffff !important;
  color: #343a40 !important;
  font-weight: 600;
  text-align: center;
  border-bottom: 2px solid var(--medicux-cyan) !important;
  padding: 0.25rem !important;
}

/* SEARCH BOX CUSTOMIZATION */
.dataTables_filter input {
  margin-left: 10px;
  width: 250px !important;
  border: 1px solid #dee2e6 !important;
  border-radius: var(--radius-sm) !important;
  padding: 0.2rem 0.6rem !important;
  transition: all 0.3s ease-in-out !important;
  background-color: #ffffff !important;
}

.dataTables_filter input:focus {
  width: 320px !important;
  border-color: var(--medicux-cyan) !important;
  box-shadow: 0 0 0 3px rgba(0, 200, 224, 0.15) !important;
  outline: none !important;
}

/* CUSTOM LOADING SPINNER (MediCux Cyan) */
.dataTables_wrapper .dataTables_processing {
  position: absolute;
  top: 50%;
  left: 50%;
  width: auto !important;
  height: auto !important;
  margin-left: -70px;
  margin-top: -20px;
  padding: 10px 20px !important;
  background: #ffffff !important;
  border: 1px solid var(--medicux-cyan) !important;
  border-radius: var(--radius-md) !important;
  color: var(--medicux-cyan) !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

/* Hide original processing dots/text */
.dataTables_wrapper .dataTables_processing {
  color: transparent !important;
  text-shadow: none !important;
}

.dataTables_wrapper .dataTables_processing::before {
  content: "Procesando...";
  color: var(--medicux-cyan) !important;
  position: relative !important;
  text-indent: 0 !important;
  font-weight: 600 !important;
}

/* HIDE ADMINLTE 3-DOTS LOADER */
.dataTables_wrapper .dataTables_processing>div {
  display: none !important;
}

.dataTables_wrapper .dataTables_processing::after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  margin-left: 10px;
  border: 3px solid rgba(0, 200, 224, 0.2);
  border-top-color: var(--medicux-cyan);
  border-radius: 50%;
  animation: dt-spin 0.8s linear infinite;
  vertical-align: middle;
}

@keyframes dt-spin {
  to {
    transform: rotate(360deg);
  }
}

/* Body Cells Vertical Alignment */
table.dataTable tbody td {
  vertical-align: middle !important;
  padding: 0.25rem !important;
}

/* SELECT2 MEDICUX CYAN THEME */
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
  background-color: var(--medicux-cyan) !important;
  color: white !important;
}

.select2-container--default .select2-selection--single:focus,
.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--focus .select2-selection--single {
  border-color: var(--medicux-cyan) !important;
  box-shadow: 0 0 0 0.2rem rgba(0, 200, 224, 0.25) !important;
}

/* =============================================
   LOGO VIEWER PREMIUM UI
   ============================================= */
.logo-viewer-modal .modal-backdrop {
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  background-color: rgba(0, 0, 0, 0.7) !important;
}

.logo-viewer-img {
  max-width: 90vw;
  max-height: 80vh;
  border-radius: 12px;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
  background: white;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.logo-viewer-modal.fade .modal-dialog {
  transform: scale(0.8) !important;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

.logo-viewer-modal.show .modal-dialog {
  transform: scale(1) !important;
}

.btn-close-viewer {
  position: absolute;
  top: -15px;
  right: -15px;
  background-color: white !important;
  opacity: 1 !important;
  border-radius: 50% !important;
  padding: 0.6rem !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  z-index: 1060;
  border: none !important;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
}

.btn-close-viewer:hover {
  transform: scale(1.1);
  background-color: #f1f5f9 !important;
}

/* =============================================
   INTL TEL INPUT GLOBAL FIX (NO INLINE CSS)
   ============================================= */
.iti {
  width: 100% !important;
}

.iti__country-list {
  z-index: 2000 !important;
}

/* Ensure padding-left is NOT overridden by global form-control when ITI is present */
.iti--separate-dial-code input.form-control {
  padding-left: 95px !important;
  text-align: right;
  /* Alignment for phone numbers as requested */
}

.iti--separate-dial-code .iti__selected-dial-code {
  padding-right: 6px !important;
}

/* =============================================
   PREMIUM GENDER BADGES
   ============================================= */
.bg-pink {
  background-color: #f472b6 !important;
  /* Soft Premium Pink */
  color: #ffffff !important;
}

.bg-purple {
  background-color: #a78bfa !important;
  /* Soft Premium Purple */
  color: #ffffff !important;
}

/* =============================================
   CALENDAR PRINT STYLES (Citas)
   ============================================= */
@media print {
  /* Ocultar elementos del sistema */
  .app-sidebar,
  .app-header,
  .breadcrumb,
  .custom-tabs,
  .app-content-header,
  .app-footer,
  .main-footer,
  .modal,
  #btn_bulk_delete,
  .card-header,
  .nav-tabs {
    display: none !important;
  }

  /* Ajustar contenedor principal */
  .app-main,
  .app-content,
  .container-fluid,
  .tab-content,
  .tab-pane,
  .card,
  .card-body {
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    box-shadow: none !important;
    width: 100% !important;
  }

  /* Asegurar que el calendario ocupe todo el espacio */
  #calendar_citas {
    min-height: auto !important;
    height: auto !important;
  }

  /* Estilos específicos para FullCalendar en impresión */
  .fc .fc-toolbar {
    margin-bottom: 1rem !important;
  }

  .fc-toolbar-chunk:nth-child(1),
  .fc-toolbar-chunk:nth-child(3) {
    display: none !important;
  }

  /* Forzar fondo blanco y texto negro */
  body {
    background: white !important;
    color: black !important;
  }
}

/* Estilo del botón de impresión en la cabecera del calendario */
.fc-print-button::before {
  content: "\f02f";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

/* =============================================
   MODAL XXL & HIGH DENSITY UI UTILITIES
   ============================================= */
@media (min-width: 1400px) {
  .modal-xxl {
    max-width: 1320px !important;
  }
}

@media (min-width: 1600px) {
  .modal-xxl {
    max-width: 95% !important;
  }
}

.bg-light-soft {
  background-color: #fafafe !important;
}

.fw-600 {
  font-weight: 600 !important;
}

.ls-1 {
  letter-spacing: 1px !important;
}