:root {
  --cat-yellow: #ffcd00;
  --cat-yellow-dark: #e6b800;
  --cat-yellow-tint: #fff9e6;
  --cat-black: #000000;
  --cat-text: #1a1a1a;
  --cat-surface: #ffffff;
  --cat-surface-muted: #f8f9fa;
  --cat-border: rgba(0, 0, 0, 0.125);
  --cat-muted: #6c757d;
  --cat-radius: 8px;
  --cat-radius-login: 15px;
  --cat-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --cat-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --cat-shadow-btn-hover: 0 4px 8px rgba(0, 0, 0, 0.2);
  --cat-focus-ring: 0 0 0 0.25rem rgba(255, 205, 0, 0.25);
  --cat-space-1: 0.25rem;
  --cat-space-2: 0.5rem;
  --cat-space-3: 1rem;
  --cat-space-4: 1.5rem;
  --cat-space-5: 2rem;
  --cat-space-6: 3rem;
  --bs-primary: #ffcd00;
  --bs-primary-rgb: 255, 205, 0;
  --bs-link-color: #000000;
  --bs-link-hover-color: #e6b800;
  --bs-body-font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --bs-body-color: #1a1a1a;
  --bs-body-bg: #ffffff;
  --bs-border-radius: 0.5rem;
  --bs-border-radius-lg: 0.5rem;
  --bs-border-radius-sm: 0.375rem;
}

html {
  font-size: 16px;
}

body.fondo-app {
  min-height: 100vh;
  color: var(--cat-text);
  background: var(--cat-surface);
  font-family: var(--bs-body-font-family);
}

a {
  color: var(--cat-black);
}

a:hover {
  color: var(--cat-yellow-dark);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--cat-black);
  font-weight: 700;
}

.app-shell {
  min-height: 100vh;
}

.app-main {
  padding-top: var(--cat-space-4);
  padding-bottom: var(--cat-space-5);
}

.app-page {
  margin-top: var(--cat-space-4);
}

.rp-page-header {
  display: flex;
  flex-direction: column;
  gap: var(--cat-space-3);
  margin-bottom: var(--cat-space-4);
}

.rp-page-header__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cat-space-2);
}

.rp-page-header__eyebrow {
  margin-bottom: 0.5rem;
}

.app-flashes {
  margin-top: var(--cat-space-3);
}

.navbar-dark.bg-primary,
.app-navbar {
  background: var(--cat-yellow) !important;
  border-bottom: 3px solid var(--cat-black);
}

.navbar-dark .navbar-brand,
.navbar-dark .navbar-nav .nav-link,
.navbar-dark .navbar-toggler,
.app-navbar .navbar-brand,
.app-navbar .nav-link {
  color: var(--cat-black) !important;
  font-weight: 600;
}

.navbar-brand {
  font-size: 1.25rem;
}

.navbar-brand img {
  height: 35px;
  width: auto;
  transition: transform 0.3s ease;
}

.navbar-brand:hover img {
  transform: scale(1.05);
}

.navbar-toggler {
  border-color: var(--cat-black);
}

.navbar-dark .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(0, 0, 0, 1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.navbar-toggler:focus {
  box-shadow: var(--cat-focus-ring);
}

.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link:focus,
.app-navbar .nav-link:hover,
.app-navbar .nav-link:focus {
  color: var(--cat-text) !important;
  background-color: var(--cat-yellow-dark);
  border-radius: 5px;
}

.navbar-dark .navbar-nav .nav-link.active,
.app-navbar .nav-link.active {
  font-weight: 700;
}

.dropdown-menu {
  border: 2px solid var(--cat-yellow);
  border-radius: var(--cat-radius);
  box-shadow: var(--cat-shadow-sm);
}

.dropdown-item {
  color: var(--cat-text);
}

.dropdown-item:hover,
.dropdown-item:focus {
  background-color: var(--cat-yellow);
  color: var(--cat-black);
}

.btn {
  border-radius: var(--cat-radius);
  font-weight: 600;
  border-width: 1px;
}

.rp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
}

.rp-btn-primary {
  background-color: var(--cat-yellow) !important;
  border-color: var(--cat-black) !important;
  color: var(--cat-black) !important;
}

.rp-btn-outline {
  background-color: transparent;
  border-color: var(--cat-black);
  color: var(--cat-black);
}

.rp-btn-secondary {
  font-weight: 600;
}

.btn-primary {
  background-color: var(--cat-yellow) !important;
  border-color: var(--cat-black) !important;
  color: var(--cat-black) !important;
  transition: background-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}

.btn-primary:hover {
  background-color: var(--cat-yellow-dark) !important;
  border-color: var(--cat-black) !important;
  color: var(--cat-black) !important;
  transform: translateY(-2px);
  box-shadow: var(--cat-shadow-btn-hover);
}

.btn-primary:focus-visible {
  background-color: var(--cat-yellow) !important;
  border-color: var(--cat-black) !important;
  color: var(--cat-black) !important;
  box-shadow: var(--cat-focus-ring);
}

.btn-primary:focus,
.btn-primary:active:focus {
  box-shadow: var(--cat-focus-ring);
}

.btn-primary:active {
  background-color: var(--cat-yellow-dark) !important;
  border-color: var(--cat-black) !important;
  color: var(--cat-black) !important;
  transform: translateY(0);
}

.btn-dark {
  background-color: var(--cat-yellow) !important;
  border-color: var(--cat-black) !important;
  color: var(--cat-black) !important;
  font-weight: 600;
  transition: background-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}

.btn-dark:hover,
.btn-dark:active,
.btn-dark:focus-visible {
  background-color: var(--cat-yellow-dark) !important;
  border-color: var(--cat-black) !important;
  color: var(--cat-black) !important;
}

.btn-dark:hover {
  transform: translateY(-2px);
  box-shadow: var(--cat-shadow-btn-hover);
}

.btn-dark:focus,
.btn-dark:active:focus {
  box-shadow: var(--cat-focus-ring);
}

.btn-outline-dark,
.btn-outline-primary {
  background-color: transparent;
  border-color: var(--cat-black);
  color: var(--cat-black);
  font-weight: 600;
}

.btn-outline-dark:hover,
.btn-outline-dark:focus-visible,
.btn-outline-primary:hover,
.btn-outline-primary:focus-visible {
  background-color: var(--cat-black);
  border-color: var(--cat-black);
  color: var(--cat-surface);
}

.btn-outline-secondary {
  font-weight: 600;
}

.btn-lg {
  min-height: 48px;
}

.btn-sm {
  min-height: 31px;
}

.card {
  background: var(--cat-surface);
  border: 1px solid var(--cat-border);
  border-radius: var(--cat-radius);
  overflow: hidden;
}

.rp-card {
  background: var(--cat-surface);
  border-radius: var(--cat-radius);
}

.rp-card--flat {
  border: none !important;
}

.rp-card--table .rp-card-body {
  padding: 0 !important;
}

.rp-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--cat-space-2);
  background-color: var(--cat-yellow);
  color: var(--cat-black);
  border-bottom: 2px solid var(--cat-black);
  padding: 0.75rem 1.25rem;
}

.rp-card-title {
  margin-bottom: 0;
  color: var(--cat-black);
  font-weight: 600;
}

.rp-card-body {
  padding: var(--cat-space-4);
}

.rp-card-body--compact {
  padding: var(--cat-space-3);
}

/* ── Semáforo KPI cards ───────────────────────────────────────────── */
.rp-kpi--success {
  background: #6ee7b7 !important;
}
.rp-kpi--success .rp-kpi-label,
.rp-kpi--success .rp-kpi-value,
.rp-kpi--success .rp-kpi-icon {
  color: #065f46 !important;
}

.rp-kpi--warning {
  background: #fcd34d !important;
}
.rp-kpi--warning .rp-kpi-label,
.rp-kpi--warning .rp-kpi-value,
.rp-kpi--warning .rp-kpi-icon {
  color: #713f12 !important;
}

.rp-kpi--danger {
  background: #fca5a5 !important;
}
.rp-kpi--danger .rp-kpi-label,
.rp-kpi--danger .rp-kpi-value,
.rp-kpi--danger .rp-kpi-icon {
  color: #7f1d1d !important;
}

.rp-stack > * + * {
  margin-top: var(--cat-space-3);
}

.rp-detail-list {
  margin-bottom: 0;
}

.rp-detail-list dt {
  color: var(--cat-text);
  font-weight: 600;
}

.rp-detail-list dd {
  color: var(--cat-text);
}

.card.shadow-sm,
.shadow-sm.card,
.card.shadow-sm.border-0 {
  box-shadow: var(--cat-shadow-sm) !important;
}

.card.shadow,
.shadow.card {
  box-shadow: var(--cat-shadow) !important;
}

.card-header {
  background-color: var(--cat-yellow) !important;
  color: var(--cat-black) !important;
  font-weight: 600;
  border-bottom: 2px solid var(--cat-black);
  padding: 0.75rem 1.25rem;
}

.card-header h1,
.card-header h2,
.card-header h3,
.card-header h4,
.card-header h5,
.card-header h6,
.card-header .h1,
.card-header .h2,
.card-header .h3,
.card-header .h4,
.card-header .h5,
.card-header .h6 {
  color: var(--cat-black);
}

.card-body {
  padding: var(--cat-space-3);
}

.card.border-0 {
  border: none !important;
}

.card.h-100 {
  height: 100%;
}

.card .table-responsive:last-child {
  margin-bottom: 0;
}

.card-body.p-4 {
  padding: var(--cat-space-4) !important;
}

.card-body.p-0 {
  padding: 0 !important;
}

.hero-remprotec {
  background: var(--cat-surface);
  border: 1px solid var(--cat-border);
  border-radius: var(--cat-radius);
  box-shadow: var(--cat-shadow-sm);
}

.panel-resumen {
  background: var(--cat-surface-muted);
  border: 1px solid var(--cat-border);
  border-radius: var(--cat-radius);
}

.etiqueta {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.65rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--cat-black);
  background: var(--cat-yellow);
}

.lead {
  color: var(--cat-text);
}

.text-uppercase {
  text-transform: none !important;
}

.form-label,
label {
  color: var(--cat-text);
}

.form-control,
.form-select,
.form-check-input {
  color: var(--cat-text);
  border-color: #ced4da;
  border-radius: 0.375rem;
}

.form-control,
.form-select,
textarea.form-control {
  padding: 0.375rem 0.75rem;
}

.form-control::placeholder,
.form-select:invalid,
textarea.form-control::placeholder {
  color: var(--cat-muted);
  opacity: 1;
}

.form-control:focus,
.form-select:focus,
.form-check-input:focus {
  border-color: var(--cat-yellow);
  box-shadow: var(--cat-focus-ring);
}

.form-check {
  margin-bottom: 0;
}

.form-check-label {
  color: var(--cat-text);
}

.rp-form {
  display: grid;
  gap: var(--cat-space-3);
}

.rp-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cat-space-2);
  padding-top: var(--cat-space-1);
}

.rp-filter-grid {
  display: grid;
  gap: var(--cat-space-3);
}

.rp-filter-grid__row {
  display: grid;
  gap: 0.5rem;
}

.rp-filter-meta {
  color: var(--cat-muted);
  font-size: 0.875rem;
}

.rp-inline-form {
  display: inline-flex;
}

.rp-table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: flex-end;
}

.rp-table-primary {
  color: var(--cat-text);
  font-weight: 600;
}

.rp-table-secondary {
  color: var(--cat-muted);
  font-size: 0.875rem;
}

.rp-status-stack {
  display: grid;
  gap: 0.375rem;
}

.rp-score {
  color: var(--cat-text);
  font-weight: 700;
}

.rp-score-meta {
  color: var(--cat-muted);
  font-size: 0.875rem;
}

.rp-state-alert__title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.rp-fieldset-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1rem;
}

form.d-grid.gap-3 > .row.g-2,
form.d-grid.gap-3 > .row.g-3,
form.d-grid.gap-3 > .row.g-4,
form.d-grid.gap-3 > .form-check,
form.d-grid.gap-3 > .form-control,
form.d-grid.gap-3 > .form-select,
form.d-grid.gap-3 > textarea.form-control,
form.d-grid.gap-3 > button.btn {
  margin-bottom: 0;
}

form .row.g-2 {
  --bs-gutter-x: 0.5rem;
  --bs-gutter-y: 0.5rem;
}

.form-check-input:checked {
  background-color: var(--cat-yellow);
  border-color: var(--cat-yellow);
}

.form-text,
.text-secondary,
.text-muted,
small.text-muted {
  color: var(--cat-muted) !important;
}

.alert {
  border-width: 1px;
  border-radius: var(--cat-radius);
}

.alert-success,
.alert-danger,
.alert-warning,
.alert-secondary {
  box-shadow: none;
}

.rp-alert {
  border-radius: var(--cat-radius);
}

.alert-info {
  background-color: var(--cat-yellow-tint);
  border-color: var(--cat-yellow);
  color: var(--cat-text);
}

.alert-warning {
  color: #212529;
}

.btn-close:focus {
  box-shadow: var(--cat-focus-ring);
}

.table {
  margin-bottom: 0;
}

.table-responsive {
  margin-bottom: 0;
}

.rp-table-wrap {
  margin-bottom: 0;
}

.rp-table {
  margin-bottom: 0;
}

.table > :not(caption) > * > * {
  padding: 0.75rem 1rem;
  vertical-align: middle;
}

.table-light thead th,
.table > thead > tr > th {
  background-color: var(--cat-yellow) !important;
  color: var(--cat-black) !important;
  font-weight: 600;
}

.table > :not(:first-child) {
  border-top: 0;
}

.table > tbody > tr > td,
.table > tbody > tr > th {
  color: var(--cat-text);
}

.table > tbody > tr:hover > * {
  background-color: var(--cat-yellow-tint);
}

.rp-table-empty {
  color: var(--cat-muted);
  text-align: center;
}

.table .text-end {
  text-align: right !important;
}

.table-hover > tbody > tr:hover > * {
  background-color: var(--cat-yellow-tint);
}

.badge.bg-primary,
.badge.bg-warning,
.text-bg-primary,
.text-bg-warning {
  background-color: var(--cat-yellow) !important;
  color: var(--cat-black) !important;
}

.badge.bg-dark,
.text-bg-dark {
  background-color: var(--cat-black) !important;
  color: var(--cat-yellow) !important;
}

.badge.bg-secondary,
.text-bg-secondary {
  background-color: #6c757d !important;
  color: #ffffff !important;
}

.badge.bg-info,
.text-bg-info {
  color: var(--cat-black) !important;
}

.badge {
  font-weight: 700;
}

.rp-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  font-weight: 700;
}

.rp-badge-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.dropdown-toggle::after {
  vertical-align: 0.15em;
}

.dropdown-divider {
  border-top-color: var(--cat-border);
}

.list-group-item {
  background: transparent;
  border-color: var(--cat-border);
  color: var(--cat-text);
}

.rounded-4 {
  border-radius: var(--cat-radius) !important;
}

.gap-2 {
  gap: var(--cat-space-2) !important;
}

.gap-3 {
  gap: var(--cat-space-3) !important;
}

.g-4,
.gx-4,
.gy-4 {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 1.5rem;
}

.mb-4 {
  margin-bottom: var(--cat-space-4) !important;
}

.mt-4 {
  margin-top: var(--cat-space-4) !important;
}

.py-5 {
  padding-top: var(--cat-space-5) !important;
  padding-bottom: var(--cat-space-5) !important;
}

.footer.bg-light,
.app-footer {
  background: var(--cat-surface-muted) !important;
  border-top: 3px solid var(--cat-yellow);
  margin-top: var(--cat-space-6);
}

.app-footer .text-muted {
  color: var(--cat-muted) !important;
}

@media (min-width: 992px) {
  .rp-page-header {
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
  }

  .rp-page-header__content {
    min-width: 0;
  }

  .rp-page-header__actions {
    justify-content: flex-end;
  }

  .rp-filter-grid__row {
    grid-template-columns: minmax(0, 1.4fr) repeat(4, minmax(0, 1fr));
  }
}

.login-page {
  background: var(--cat-black) !important;
}

.login-page .card {
  border: none;
  border-radius: var(--cat-radius-login);
  box-shadow: var(--cat-shadow) !important;
}


/* ── Módulo de Calendario Comercial ───────────────────────────────────────── */
.rp-calendar-day {
  background-color: var(--cat-surface);
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  position: relative;
  border-bottom: 1px solid var(--cat-border);
}

.rp-calendar-day:hover {
  background-color: var(--cat-yellow-tint) !important;
  transform: scale(1.01);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
  z-index: 1;
}

/* Día de Hoy */
.rp-calendar-day--today {
  background-color: #fffbeb !important;
  border: 1.5px solid var(--cat-yellow) !important;
}

/* Día de Otro Mes */
.rp-calendar-day--muted {
  background-color: var(--cat-surface-muted) !important;
  opacity: 0.65;
}

/* Día Seleccionado / Activo */
.rp-calendar-day--active {
  background-color: var(--cat-yellow-tint) !important;
  border: 2px solid var(--cat-black) !important;
  box-shadow: inset 0 0 0 1px var(--cat-yellow) !important;
  z-index: 2;
}

/* Pills de Actividades dentro de las celdas */
.rp-calendar-pill {
  font-size: 0.7rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  max-width: 100%;
  display: block;
}

/* Colores para cada tipo de actividad */
.rp-calendar-pill--llamada {
  background-color: #e6f0fa;
  color: #0d6efd;
  border: 1px solid rgba(13, 110, 253, 0.15);
}

.rp-calendar-pill--visita_comercial {
  background-color: #e8f5e9;
  color: #198754;
  border: 1px solid rgba(25, 135, 84, 0.15);
}

.rp-calendar-pill--visita_tecnica {
  background-color: #e0f2f1;
  color: #00796b;
  border: 1px solid rgba(0, 150, 136, 0.15);
}

.rp-calendar-pill--reunion {
  background-color: #e0f7fa;
  color: #00838f;
  border: 1px solid rgba(0, 188, 212, 0.15);
}

.rp-calendar-pill--correo {
  background-color: #f5f5f5;
  color: #616161;
  border: 1px solid rgba(158, 158, 158, 0.15);
}

.rp-calendar-pill--whatsapp {
  background-color: #e8f5e9;
  color: #2e7d32;
  border: 1px solid rgba(76, 175, 80, 0.15);
}

.rp-calendar-pill--tarea {
  background-color: #fffde7;
  color: #b78103;
  border: 1px solid rgba(253, 216, 53, 0.25);
}

.rp-calendar-pill--seguimiento {
  background-color: #fff3e0;
  color: #e65100;
  border: 1px solid rgba(255, 152, 0, 0.15);
}

/* Badges en la vista lateral de agenda */
.rp-badge-tipo {
  font-weight: 700;
  color: #ffffff !important;
}

.rp-badge-tipo--llamada {
  background-color: #0d6efd !important;
}

.rp-badge-tipo--visita_comercial {
  background-color: #198754 !important;
}

.rp-badge-tipo--visita_tecnica {
  background-color: #009688 !important;
}

.rp-badge-tipo--reunion {
  background-color: #00bcd4 !important;
  color: #000000 !important;
}

.rp-badge-tipo--correo {
  background-color: #757575 !important;
}

.rp-badge-tipo--whatsapp {
  background-color: #4caf50 !important;
}

.rp-badge-tipo--tarea {
  background-color: #ffc107 !important;
  color: #000000 !important;
}

.rp-badge-tipo--seguimiento {
  background-color: #ff9800 !important;
}

.hover-yellow:hover {
  color: var(--cat-yellow-dark) !important;
}

