/* ============================================
   AgeCheck Pro - Bootstrap 5 Custom Theme
   Colors: Negro, Grises, Azul, Verde, Rojo, Amarillo pasteles
   Style: Dashboard minimal, sin animaciones de movimiento
   ============================================ */

/* ===== IMPORTAR FUENTE INTER ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ===== VARIABLES DE COLORES PASTELES ===== */
:root {
  /* Base colors */
  --primary-black: #000000;
  --primary-white: #ffffff;
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-500: #6b7280;
  --gray-600: #4b5563;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --gray-900: #111827;

  /* True Pasteles - Based on reference design */
  --pastel-blue: #e0f2fe;
  --pastel-blue-hover: #b3e5fc;
  --pastel-blue-dark: #0288d1;

  --pastel-green: #e8f5e8;
  --pastel-green-hover: #c8e6c9;
  --pastel-green-dark: #2e7d32;

  --pastel-red: #ffebee;
  --pastel-red-hover: #ffcdd2;
  --pastel-red-dark: #d32f2f;

  --pastel-yellow: #fffbf0;
  --pastel-yellow-hover: #fff3e0;
  --pastel-yellow-dark: #f57c00;

  --pastel-pink: #fce4ec;
  --pastel-pink-hover: #f8bbd9;
  --pastel-pink-dark: #c2185b;

  --pastel-orange: #fff3e0;
  --pastel-orange-hover: #ffcc80;
  --pastel-orange-dark: #f57c00;

  /* Bootstrap color overrides COMPLETOS */
  --bs-primary-rgb: 2, 136, 209;
  --bs-primary-bg-subtle: var(--pastel-blue);
  --bs-primary-border-subtle: var(--pastel-blue-hover);
  --bs-primary-text-emphasis: var(--pastel-blue-dark);

  --bs-secondary: var(--gray-600);
  --bs-secondary-rgb: 75, 85, 99;
  --bs-secondary-bg-subtle: var(--gray-100);
  --bs-secondary-border-subtle: var(--gray-300);
  --bs-secondary-text-emphasis: var(--gray-700);

  --bs-success: var(--pastel-green-dark);
  --bs-success-rgb: 46, 125, 50;
  --bs-success-bg-subtle: var(--pastel-green);
  --bs-success-border-subtle: var(--pastel-green-hover);
  --bs-success-text-emphasis: var(--pastel-green-dark);

  --bs-info: var(--pastel-blue-dark);
  --bs-info-rgb: 2, 136, 209;
  --bs-info-bg-subtle: var(--pastel-blue);
  --bs-info-border-subtle: var(--pastel-blue-hover);
  --bs-info-text-emphasis: var(--pastel-blue-dark);

  --bs-warning: var(--pastel-yellow-dark);
  --bs-warning-rgb: 245, 124, 0;
  --bs-warning-bg-subtle: var(--pastel-yellow);
  --bs-warning-border-subtle: var(--pastel-yellow-hover);
  --bs-warning-text-emphasis: var(--pastel-yellow-dark);

  --bs-danger: var(--pastel-red-dark);
  --bs-danger-rgb: 211, 47, 47;
  --bs-danger-bg-subtle: var(--pastel-red);
  --bs-danger-border-subtle: var(--pastel-red-hover);
  --bs-danger-text-emphasis: var(--pastel-red-dark);

  --bs-light: var(--gray-100);
  --bs-light-rgb: 243, 244, 246;
  --bs-light-bg-subtle: var(--gray-50);
  --bs-light-border-subtle: var(--gray-200);
  --bs-light-text-emphasis: var(--gray-800);

  --bs-dark: var(--primary-black);
  --bs-dark-rgb: 0, 0, 0;
  --bs-dark-bg-subtle: var(--gray-800);
  --bs-dark-border-subtle: var(--gray-700);
  --bs-dark-text-emphasis: var(--primary-black);

  /* Body and text colors */
  --bs-body-color: var(--primary-black);
  --bs-body-bg: var(--primary-white);
  --bs-emphasis-color: var(--primary-black);
  --bs-secondary-color: var(--gray-600);
  --bs-tertiary-color: var(--gray-500);

  /* Border colors */
  --bs-border-color: var(--gray-300);
  --bs-border-color-translucent: rgba(0, 0, 0, 0.175);

  /* Sidebar y navbar */
  --sidebar-bg: var(--gray-50);
  --navbar-bg: var(--gray-900);
  --sidebar-border: var(--gray-200);
}

/* ===== TIPOGRAFÍA GLOBAL - NEGRO NÍTIDO ===== */
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-weight: 300;
  color: var(--primary-black);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  color: var(--primary-black);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

p,
span,
div,
label,
a {
  color: var(--primary-black);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


a:hover {
  text-decoration: none !important;
}

.text-muted {
  color: var(--gray-600) !important;
  font-weight: 300;
}

.font-weight-medium {
  font-weight: 500;
}

.font-weight-semibold {
  font-weight: 600;
}

.font-weight-bold {
  font-weight: 700;
}

/* ===== LAYOUT PRINCIPAL - 100% HEIGHT ===== */
html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
}

.main-container {
  height: 100vh;
  display: flex;
  flex-direction: column;
}

.content-wrapper {
  flex: 1;
  display: flex;
  overflow: hidden;
}

/* ===== NAVBAR SUPERIOR FIJO ===== */
.navbar-custom {
  background-color: white;
  border-bottom: 1px solid var(--gray-300);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  min-height: 64px;
}

.navbar-brand {
  font-size: 1.75rem;
  color: var(--primary-black) !important;
  font-weight: 800;
  text-transform: lowercase;
  -webkit-font-smoothing: antialiased;
  line-height: 1.2;
  letter-spacing: -1px;
}

.navbar-nav .nav-link {
  color: var(--primary-black) !important;
  font-weight: 500;
  transition: color 0.2s ease;
}

.navbar-nav .nav-link:hover {
  color: var(--primary-black) !important;
}

a {
  color: var(--primary-black);
  text-decoration: none;
}

/* ===== SIDEBAR FIJO CON 100% HEIGHT - NEGRO ===== */
.sidebar {
  background-color: white;
  border-right: 1px solid var(--gray-300);
  width: 260px;
  height: 100vh;
  position: fixed;
  top: 64px;
  left: 0;
  overflow-y: auto;
  z-index: 100;
  text-decoration: none;

}

.sidebar .nav-link {
  color: #000000;
  font-weight: 400;
  padding: 0.75rem 1rem;
  margin: 0.125rem 0.5rem;
  border-radius: 0.5rem;
  transition: background-color 0.2s ease, color 0.2s ease;
  display: flex;
  align-items: center;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-decoration: none;
}

.sidebar .nav-link:hover {
  background-color: #e5e5e5 !important;
  color: #000000;
  text-decoration: none;
}

.sidebar .nav-link.active {
  font-weight: 300;
}

.sidebar .nav-link i {
  width: 20px;
  margin-right: 0.75rem;
  text-align: center;
  font-size: 14px;
}

/* ===== SUBMENU SERVICIOS - SIMPLE ===== */
.sidebar .nav-submenu {
  margin-left: 1rem;
  padding-left: 0;
}

.sidebar .nav-submenu .nav-link {
  padding-left: 2.5rem;
  font-size: 0.875rem;
  margin-left: 0.5rem;
  margin-right: 0.5rem;
}

/* Icono de flecha para submenu */
.sidebar .nav-link[data-submenu] {
  position: relative;
}

.sidebar .nav-link[data-submenu] .fa-chevron-down,
.sidebar .nav-link[data-submenu] .fa-chevron-up {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.75rem;
  transition: transform 0.2s ease;
}

/* ===== MAIN CONTENT AREA - 100% ===== */
.main-content {
  margin-left: 260px;
  padding-top: 64px;
  min-height: 100vh;
  width: calc(100% - 260px);
  background-color: var(--gray-100);
  overflow-y: auto;
}

.main-content .container-fluid {
  padding: 2rem;
}

/* ===== CARDS CON BORDER SIEMPRE ===== */
.card {
  border: 1px solid var(--gray-300) !important;
  border-radius: 0.75rem !important;
  background-color: var(--primary-white) !important;
  box-shadow: none !important;
  transition: box-shadow 0.2s ease, border-color 0.2s ease !important;
  overflow: auto;
}

.card:hover {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06) !important;
  border-color: var(--primary-black) !important;
}

.card-header {
  background-color:transparent !important;
  border: none !important;
  border-bottom: 0 !important;
  border-radius: 0 !important;
  font-weight: 600 !important;
  color: var(--gray-800) !important;
  padding: 1.25rem 1.25rem !important;
}

.card-body {
  color: var(--gray-600) !important;
  background-color:transparent !important;
  padding: 1.25rem !important;
}

.card-footer {
  background-color: var(--gray-50) !important;
  border: none !important;
  border-top: 1px solid var(--gray-100) !important;
  border-radius: 0 !important;
  padding: 1.25rem !important;
}

/* ===== CARDS CON COLORES PASTELES ===== */
.card-blue {
  background-color: var(--pastel-blue);
  border-left: 4px solid var(--pastel-blue-dark);
}

.card-green {
  background-color: var(--pastel-green);
  border-left: 4px solid var(--pastel-green-dark);
}

.card-red {
  background-color: var(--pastel-red);
  border-left: 4px solid var(--pastel-red-dark);
}

.card-yellow {
  background-color: var(--pastel-yellow);
  border-left: 4px solid var(--pastel-yellow-dark);
}

/* ===== TÍTULOS SIN BORDES ===== */
h1,
h2,
h3,
h4,
h5,
h6 {
  border: none !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

.page-header h1,
.page-header h2,
.page-header h3,
.page-header h4,
.page-header h5,
.page-header h6 {
  border: none !important;
  border-bottom: none !important;
}

/* ===== BOTONES MODERNOS CON ICONOS ===== */
.btn {
  font-weight: 300 ;
  border-radius: 0.5rem ;
  padding: 0.5rem 1rem ;
  font-size: 0.875rem ;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
  align-items: center ;
  gap: 0.375rem ;
  line-height: 1.5 ;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}

.btn i {
  font-size: 0.875rem;
  margin-right: 0.25rem;
}

/* Asegurar que todos los botones tengan espaciado para iconos */
.btn:not(.btn-close) {
  min-height: 38px;
}

.btn-sm i {
  font-size: 0.75rem;
  margin-right: 0.125rem;
}

.btn-lg i {
  font-size: 1rem;
  margin-right: 0.375rem;
}

/* ===== ALERTS CON PASTELES ===== */
.alert-info {
  background-color: var(--pastel-blue);
  border-color: var(--pastel-blue-hover);
  color: var(--pastel-blue-dark);
}

.alert-success {
  background-color: var(--pastel-green);
  border-color: var(--pastel-green-hover);
  color: var(--pastel-green-dark);
}

.alert-danger {
  background-color: var(--pastel-red);
  border-color: var(--pastel-red-hover);
  color: var(--pastel-red-dark);
}

.alert-warning {
  background-color: var(--pastel-yellow);
  border-color: var(--pastel-yellow-hover);
  color: var(--pastel-yellow-dark);
}

/* ===== BADGES BOOTSTRAP 5 OVERRIDE ===== */
.badge {
  font-weight: 600 !important;
  border-radius: 0.5rem !important;
  border: 1px solid transparent !important;
  font-size: 0.75rem !important;
  padding: 0.375rem 0.75rem !important;
}

.badge.text-bg-primary,
.badge.bg-primary {
  background-color: var(--pastel-blue) !important;
  border-color: var(--pastel-blue-hover) !important;
  color: var(--pastel-blue-dark) !important;
}

.badge.text-bg-secondary,
.badge.bg-secondary {
  background-color: var(--gray-100) !important;
  border-color: var(--gray-300) !important;
  color: var(--gray-700) !important;
}

.badge.text-bg-success,
.badge.bg-success {
  background-color: var(--pastel-green) !important;
  border-color: var(--pastel-green-hover) !important;
  color: var(--pastel-green-dark) !important;
}

.badge.text-bg-danger,
.badge.bg-danger {
  background-color: var(--pastel-red) !important;
  border-color: var(--pastel-red-hover) !important;
  color: var(--pastel-red-dark) !important;
}

.badge.text-bg-warning,
.badge.bg-warning {
  background-color: var(--pastel-yellow) !important;
  border-color: var(--pastel-yellow-hover) !important;
  color: var(--pastel-yellow-dark) !important;
}

.badge.text-bg-info,
.badge.bg-info {
  background-color: var(--pastel-blue) !important;
  border-color: var(--pastel-blue-hover) !important;
  color: var(--pastel-blue-dark) !important;
}

.badge.text-bg-light,
.badge.bg-light {
  background-color: var(--gray-50) !important;
  border-color: var(--gray-200) !important;
  color: var(--gray-800) !important;
}

.badge.text-bg-dark,
.badge.bg-dark {
  background-color: var(--gray-800) !important;
  border-color: var(--gray-700) !important;
  color: var(--primary-white) !important;
}

/* Custom pastel badges */
.badge-pastel-blue {
  background-color: var(--pastel-blue) !important;
  border-color: var(--pastel-blue-hover) !important;
  color: var(--pastel-blue-dark) !important;
}

.badge-pastel-green {
  background-color: var(--pastel-green) !important;
  border-color: var(--pastel-green-hover) !important;
  color: var(--pastel-green-dark) !important;
}

.badge-pastel-red {
  background-color: var(--pastel-red) !important;
  border-color: var(--pastel-red-hover) !important;
  color: var(--pastel-red-dark) !important;
}

.badge-pastel-yellow {
  background-color: var(--pastel-yellow) !important;
  border-color: var(--pastel-yellow-hover) !important;
  color: var(--pastel-yellow-dark) !important;
}

.badge-pastel-pink {
  background-color: var(--pastel-pink) !important;
  border-color: var(--pastel-pink-hover) !important;
  color: var(--pastel-pink-dark) !important;
}

.badge-pastel-orange {
  background-color: var(--pastel-orange) !important;
  border-color: var(--pastel-orange-hover) !important;
  color: var(--pastel-orange-dark) !important;
}

/* ===== FORMULARIOS PERSONALIZADOS ===== */
.form-control {
  border: 1px solid var(--bs-border-color) !important;
  border-radius: 0.5rem !important;
  font-size: 1rem !important;
  padding: 0.5rem 0.75rem !important;
  background-color: var(--bs-body-bg) !important;
  color: var(--bs-body-color) !important;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out !important;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075) !important;
  font-weight: 400 !important;
}

.form-control:hover {
  border-color: var(--primary-black) !important;
}

.form-control:focus {
  border-color: var(--primary-black) !important;
  background-color: var(--bs-body-bg) !important;
  outline: none !important;
  color: var(--bs-body-color) !important;
}

.form-control:active,
.form-control.is-valid:focus,
.form-control.was-validated:valid:focus {
  border-color: var(--primary-black) !important;
}

.form-control:disabled {
  background-color: var(--bs-secondary-bg) !important;
  border-color: var(--bs-border-color) !important;
  color: var(--bs-secondary-color) !important;
  cursor: not-allowed !important;
  opacity: 0.65 !important;
}



.form-control::placeholder {
  color: var(--bs-secondary-color) !important;
  opacity: 0.65 !important;
}

.form-label {
  color: var(--bs-body-color) !important;
  margin-bottom: 0.5rem !important;
  font-size: 0.875rem !important;
}

.form-select {
  border: 1px solid var(--bs-border-color) !important;
  border-radius: 0.5rem !important;
  font-size: 1rem !important;
  padding: 0.5rem 2.25rem 0.5rem 0.75rem !important;
  background-color: var(--bs-body-bg) !important;
  color: var(--bs-body-color) !important;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out !important;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075) !important;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m1 6 7 7 7-7'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 0.75rem center !important;
  background-size: 16px 12px !important;
}

.form-select:hover {
  border-color: var(-primary-black) !important;
}

.form-select:focus {
  border-color: var(-primary-black) !important;
  outline: none !important;
}

.form-select:disabled {
  background-color: var(--bs-secondary-bg) !important;
  border-color: var(--bs-border-color) !important;
  color: var(--bs-secondary-color) !important;
  opacity: 0.65 !important;
}

.form-check-input {
  border: 1px solid var(--bs-border-color) !important;
  background-color: var(--bs-body-bg) !important;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out !important;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075) !important;
  border-radius: 0.25em !important;
}

.form-check-input:hover {
  border-color: var(--bs-primary) !important;
}

.form-check-input:checked {
  background-color: var(--primary-black) !important;
  border-color: var(--primary-black) !important;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075) !important;
}

.form-check-input:focus {
  outline: none !important;
  border-color: var(--primary-black) !important;
}

.form-check-input:disabled {
  background-color: var(--bs-secondary-bg) !important;
  border-color: var(--bs-border-color) !important;
  opacity: 0.5 !important;
  cursor: not-allowed !important;
}

.form-check-label {
  font-weight: 400 !important;
  color: var(--bs-body-color) !important;
  font-size: 1rem !important;
  cursor: pointer !important;
}

.input-group-text {
  background-color: var(--gray-50) !important;
  border: 2px solid var(--gray-300) !important;
  color: var(--gray-600) !important;
  font-size: 0.875rem !important;
  transition: all 0.2s ease !important;
  border-radius: 0.75rem !important;
}

.input-group:hover .input-group-text {
  border-color: var(--gray-400) !important;
}

.form-floating>label {
  color: var(--gray-500) !important;
  font-size: 0.875rem !important;
}

.form-floating>.form-control:focus~label,
.form-floating>.form-control:not(:placeholder-shown)~label {
  color: var(--bs-primary) !important;
  font-size: 0.75rem !important;
}

/* Override Bootstrap validation styles */
.was-validated .form-control:valid,
.form-control.is-valid {
  border-color: var(--bs-success) !important;
  box-shadow: 0 0 0 0.2rem var(--bs-success-bg-subtle) !important;
}

.was-validated .form-control:invalid,
.form-control.is-invalid {
  border-color: var(--bs-danger) !important;
  box-shadow: 0 0 0 0.2rem var(--bs-danger-bg-subtle) !important;
}

.valid-feedback {
  color: var(--bs-success) !important;
}

.invalid-feedback {
  color: var(--bs-danger) !important;
}

/* ===== DROPDOWN MENUS COMO CARDS ===== */
.dropdown-menu {
  border: 1px solid var(--gray-300) !important;
  border-radius: 0.75rem !important;
  box-shadow: none !important;
  z-index: 1050 !important;
  background-color: var(--primary-white) !important;
  padding: 0.75rem !important;
  margin-top: 0.5rem !important;
  overflow: hidden !important;
  transition: box-shadow 0.2s ease, border-color 0.2s ease !important;
}

.dropdown-menu.show {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06) !important;
  border-color: var(--gray-400) !important;
}

/* Centrado automático de dropdowns */
.dropdown-center .dropdown-menu,
.btn-group .dropdown-menu {
  transform: translateX(-50%);
  left: 50% !important;
  right: auto !important;
}

.navbar .dropdown-menu {
  transform: translateX(-50%);
  left: 50% !important;
  right: auto !important;
}

.dropdown-item {
  font-size: 0.875rem !important;
  color: var(--primary-black) !important;
  padding: 0.75rem 1rem !important;
  border-radius: 0.5rem !important;
  transition: all 0.2s ease !important;
  font-weight: 300 !important;
  border: none !important;
  background: none !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  margin: 0.125rem 0 !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background-color: #e5e5e5 !important;
  color: #000000;
  text-decoration: none !important;
}

.dropdown-item:active {
  background-color: #e5e5e5 !important;
  color: #000000;
}

.dropdown-item.active {
  background-color: var(--pastel-blue-dark) !important;
  color: var(--primary-white) !important;
}

.dropdown-item:disabled,
.dropdown-item.disabled {
  color: var(--gray-400) !important;
  background-color: transparent !important;
  cursor: not-allowed !important;
  opacity: 0.5 !important;
}

.dropdown-divider {
  border-top: 1px solid var(--gray-300) !important;
  margin: 0.5rem 0 !important;
}

.dropdown-header {
  color: var(--gray-600) !important;
  font-size: 0.75rem !important;
  font-weight: 400 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  padding: 0.5rem 1rem 0.25rem !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}

/* ===== MODALES ===== */
.modal-content {
  border: 1px solid var(--gray-200);
  border-radius: 0.75rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.modal-header {
  border-bottom: 1px solid var(--gray-200);
  padding: 1.5rem;
}

.modal-title {
  font-weight: 600;
  color: var(--gray-800);
}

.modal-body {
  padding: 1.5rem;
  color: var(--gray-600);
}

.modal-footer {
  border-top: 1px solid var(--gray-200);
  padding: 1.5rem;
}

/* ===== PAGINATION ===== */
.pagination .page-link {
  border: 1px solid var(--gray-300);
  color: var(--gray-600);
  font-weight: 500;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.pagination .page-link:hover {
  background-color: var(--gray-50);
  border-color: var(--gray-300);
  color: var(--gray-800);
}

.pagination .page-item.active .page-link {
  background-color: var(--primary-black);
  border-color: var(--primary-black);
  color: white;
}

#uploadPlaceholder {
  border: 2px dashed var(--gray-300);
  border-radius: 0.5rem;
  padding: 1.5rem;
  text-align: center;
  color: var(--gray-500);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

#uploadPlaceholder:hover {
  border: 2px dashed var(--primary-black);
  border-radius: 0.5rem;
  padding: 1.5rem;
  text-align: center;
  color: var(--gray-500);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

/* ===== BREADCRUMB ===== */
.breadcrumb {
  background-color: transparent;
  padding: 0;
  margin-bottom: 1rem;
}

.breadcrumb-item {
  font-size: 0.875rem;
}

.breadcrumb-item a {
  color: var(--gray-500);
  text-decoration: none;
  transition: color 0.2s ease;
}

.breadcrumb-item a:hover {
  color: var(--pastel-blue-dark);
}

.breadcrumb-item.active {
  color: var(--gray-700);
  font-weight: 500;
}

/* ===== PROGRESS BARS ===== */
.progress {
  height: 0.75rem;
  background-color: var(--gray-200);
  border-radius: 0.5rem;
}

.progress-bar {
  border-radius: 0.5rem;
  transition: width 0.3s ease;
}

/* ===== SPINNERS ===== */
.spinner-border {
  color: var(--pastel-blue-dark);
}

.spinner-grow {
  color: var(--pastel-blue-dark);
}

/* ===== TOOLTIPS ===== */
.tooltip-inner {
  background-color: var(--gray-800);
  color: white;
  font-size: 0.75rem;
  border-radius: 0.375rem;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .sidebar {
    transform: translateX(-100%);
    transition: transform 0.3s ease;
  }

  .sidebar.show {
    transform: translateX(0);
  }

  .main-content {
    margin-left: 0;
    width: 100%;
  }
}

/* ===== UTILIDADES ===== */
.text-pastel-blue {
  color: var(--pastel-blue-dark);
}

.text-pastel-green {
  color: var(--pastel-green-dark);
}

.text-pastel-red {
  color: var(--pastel-red-dark);
}

.text-pastel-yellow {
  color: var(--pastel-yellow-dark);
}

.bg-pastel-blue {
  background-color: var(--pastel-blue);
}

.bg-pastel-green {
  background-color: var(--pastel-green);
}

.bg-pastel-red {
  background-color: var(--pastel-red);
}

.bg-pastel-yellow {
  background-color: var(--pastel-yellow);
}

/* ===== WEBSITES TABLE LAYOUT ===== */
.websites-table .table {
  margin-bottom: 0;
}

.websites-table .table th {
  font-weight: 600;
  border-bottom: 2px solid var(--gray-300);
  padding: 1rem 0.75rem;
  vertical-align: middle;
}

.websites-table .table td {
  padding: 1rem 0.75rem;
  vertical-align: middle;
  border-bottom: 1px solid var(--gray-200);
}

.websites-table .table tbody tr:hover {
  background-color: var(--gray-50);
}

.websites-table .badge-sm {
  font-size: 0.7rem;
  padding: 0.25rem 0.5rem;
}

.websites-table code {
  font-family: 'Courier New', monospace;
  font-size: 0.85rem;
  background-color: var(--gray-100);
  padding: 0.25rem 0.5rem;
  border-radius: 0.25rem;
  border: 1px solid var(--gray-300);
}

/* ===== TABLE RESPONSIVE OVERFLOW FIX ===== */
.table-responsive {
  overflow-x: auto;
  overflow-y: visible;
}

.table-responsive .dropdown-menu {
  position: fixed !important;
}

/* Action buttons */
.websites-table .btn-dark:hover {
  background-color: var(--gray-700) !important;
  border-color: var(--gray-700) !important;
}

/* Table responsive enhancements */
@media (max-width: 992px) {

  .websites-table .table th:nth-child(n+6),
  .websites-table .table td:nth-child(n+6) {
    display: none;
  }
}

@media (max-width: 768px) {

  .websites-table .table th:nth-child(n+4),
  .websites-table .table td:nth-child(n+4) {
    display: none;
  }

  .main-content .container-fluid {
    padding: 1rem;
}


.main-content .container-help {
  padding: 0rem!important;
}

  .btn-fixed-bottom {
      position: fixed;
      top: auto;
      bottom: 0;
      left: 0;
      border-radius: 0;
      padding: 10px;
      font-size: 1rem;
      z-index: 1100 ;
  }
}



/* ===== PAGE HEADER SIN BORDER ===== */
.page-header {
  border-bottom: none;
  padding-bottom: 1rem;
  margin-bottom: 2rem;
}

.page-header h1 {
  font-weight: 700;
  color: var(--gray-900);
  margin: 0;
}

/* ===== TABLES ===== */
.table {
  border-radius: 0.75rem;
  overflow: hidden;
  color: var(--bs-body-color) !important;
}

.table thead th {
  background-color: var(--gray-50);
  border-bottom: 2px solid var(--gray-200);
  font-weight: 600;
  color: var(--bs-body-color) !important;
}

.table tbody tr {
  transition: background-color 0.2s ease;
  color: var(--bs-body-color) !important;
}

.table tbody tr:hover {
  background-color: var(--gray-50);
}

.table tbody td {
  color: var(--bs-body-color) !important;
  vertical-align: middle;
}

/* ===== BOOTSTRAP 5 COMPLETE COLOR OVERRIDES ===== */

/* Text colors */
.text-primary {
  color: var(--bs-primary) !important;
}

.text-secondary {
  color: var(--bs-secondary) !important;
}

.text-success {
  color: var(--bs-success) !important;
}

.text-info {
  color: var(--bs-info) !important;
}

.text-warning {
  color: var(--bs-warning) !important;
}

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

.text-light {
  color: var(--bs-light) !important;
}

.text-dark {
  color: var(--bs-dark) !important;
}

.text-body {
  color: var(--bs-body-color) !important;
}

.text-muted {
  color: var(--bs-secondary-color) !important;
}

.text-black-50 {
  color: rgba(0, 0, 0, 0.5) !important;
}

.text-white-50 {
  color: rgba(255, 255, 255, 0.5) !important;
}

/* Background colors */
.bg-primary {
  background-color: var(--bs-primary-bg-subtle) !important;
}

.bg-secondary {
  background-color: var(--bs-secondary-bg-subtle) !important;
}

.bg-success {
  background-color: var(--bs-success-bg-subtle) !important;
}

.bg-info {
  background-color: var(--bs-info-bg-subtle) !important;
}

.bg-warning {
  background-color: var(--bs-warning-bg-subtle) !important;
}



.bg-light {
  background-color: var(--bs-light) !important;
}

/* Border colors */
.border-primary {
  border-color: var(--bs-primary-border-subtle) !important;
}

.border-secondary {
  border-color: var(--bs-secondary-border-subtle) !important;
}

.border-success {
  border-color: var(--bs-success-border-subtle) !important;
}

.border-info {
  border-color: var(--bs-info-border-subtle) !important;
}



.border-danger {
  border-color: var(--bs-danger-border-subtle) !important;
}

.border-light {
  border-color: var(--bs-light) !important;
}

.border-dark {
  border-color: var(--bs-dark) !important;
}



/* List group */
.list-group-item {
  color: var(--bs-body-color) !important;
  background-color: var(--bs-body-bg) !important;
  border-color: var(--bs-border-color) !important;
}

.list-group-item:hover {
  background-color: var(--bs-light) !important;
}

.list-group-item.active {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  color: white !important;
}

/* Input group */
.input-group-text {
  background-color: var(--bs-light) !important;
  border: 1px solid var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
  font-size: 1rem !important;
  transition: all 0.15s ease-in-out !important;
  border-radius: 0.5rem !important;
}

.input-group:hover .input-group-text {
  border-color: var(--bs-primary) !important;
}

/* Close button */
.btn-close {
  background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='m.293.293.32.32L8 6.94l7.387-6.32.32-.32a1 1 0 0 1 1.415 1.414L9.414 8l7.708 7.708a1 1 0 0 1-1.415 1.414L8 9.414l-7.708 7.708a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 1.414-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat !important;
}

.btn-close-white {
  background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='m.293.293.32.32L8 6.94l7.387-6.32.32-.32a1 1 0 0 1 1.415 1.414L9.414 8l7.708 7.708a1 1 0 0 1-1.415 1.414L8 9.414l-7.708 7.708a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 1.414-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat !important;
}

/* ===== MOBILE MENU STYLES ===== */
.mobile-menu-btn {
  background: none;
  border: none;
  color: #000000;
  font-size: 1.2rem;
  padding: 0.5rem;
  transition: all 0.3s ease;
  cursor: pointer;
}

.mobile-menu-btn:hover {
  color: var(--pastel-blue);
}

.mobile-menu-btn i {
  transition: transform 0.3s ease;
}

.mobile-menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: white;
  z-index: 9999;
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.mobile-menu-overlay.active {
  opacity: 1;
}

.mobile-menu-content {
  display: flex;
  flex-direction: column;
  height: 100vh;
  width: 100vw;
  padding: 2rem;
  overflow-y: auto;
}

.mobile-user-info {
  display: flex;
  align-items: center;
  padding: 2rem 0;
  border-bottom: 1px solid var(--gray-300);
  margin-bottom: 2rem;
}

.user-avatar {
  margin-right: 1rem;
}

.user-avatar i {
  font-size: 3rem;
  color: #000000;
}

.user-details {
  flex: 1;
}

.user-email {
  color: #000000;
  font-size: 1.1rem;
  font-weight: 600;
  margin-bottom: 0.25rem;
}

.user-plan {
  color: #666666;
  font-size: 0.9rem;
}

.upgrade-link {
  color: var(--bs-primary) !important;
  text-decoration: none;
  margin-left: 0.5rem;
}

.upgrade-link:hover {
  color: var(--pastel-blue-hover);
  text-decoration: underline;
}

.mobile-nav {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.mobile-nav-item {
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
  color: #000000;
  text-decoration: none;
  border-radius: 0.5rem;
  transition: background-color 0.2s ease, color 0.2s ease;
  background: transparent;
  margin: 0.125rem 0.5rem;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.mobile-nav-item:hover {
  background-color: #e5e5e5 !important;
  color: #000000;
  text-decoration: none;
}

.mobile-nav-item.active {
  background-color: #e5e5e5;
  border: 2px solid #000000;
  font-weight: 300;
}

.mobile-nav-item.logout-item {
  margin-top: 2rem;
  color: #dc2626;
}


.mobile-nav-item.logout-item:hover {
  background: rgba(220, 38, 38, 0.2);
  color: #dc2626;
}

.mobile-nav-item i {
  width: 20px;
  margin-right: 0.75rem;
  text-align: center;
  font-size: 1rem;
}

.mobile-nav-item span {
  font-size: 1rem;
  font-weight: 300;
}

/* Mobile Navigation Sections */
.mobile-nav .nav-section {
  margin-bottom: 2rem;
}

.mobile-nav .account-section {
  border-top: 1px solid var(--gray-300);
  padding-top: 2rem;
  margin-top: auto;
}

/* Mobile Submenu Styles */
.mobile-submenu {
  margin-bottom: 0.5rem;
}

.mobile-submenu-header {
  cursor: pointer;
}

.mobile-submenu-header .mobile-nav-item {
  justify-content: space-between;
  margin-bottom: 0;
}

.mobile-submenu-header .mobile-nav-item .submenu-arrow {
  margin-left: auto;
  margin-right: 0;
  transition: transform 0.3s ease;
}

.mobile-submenu-items {
  display: none;
  margin-top: 0.5rem;
  margin-left: 1rem;
}

.mobile-submenu-items .mobile-nav-item.submenu-item {
  padding: 0.75rem 1rem;
  padding-left: 2.5rem;
  margin: 0.125rem 0.5rem;
  background: transparent;
  font-size: 0.875rem;
  border: none;
}

.mobile-submenu-items .mobile-nav-item.submenu-item:hover {
  background-color: #e5e5e5 !important;
  color: #000000;
}

.mobile-submenu-items .mobile-nav-item.submenu-item.active {
  background-color: #e5e5e5;
  border: 2px solid #000000;
  font-weight: 300;
}

.mobile-submenu-items .mobile-nav-item.submenu-item i {
  width: 20px;
  margin-right: 0.75rem;
  text-align: center;
  font-size: 0.875rem;
}

.mobile-submenu-items .mobile-nav-item.submenu-item span {
  font-size: 0.875rem;
  font-weight: 300;
}

/* Mobile animations */
@keyframes slideDown {
  from {
    transform: translateY(-100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.mobile-menu-content {
  animation: slideDown 0.3s ease;
}