/* ============================================================
   app-admin-custom.css — PARTE 1: BASE
   ============================================================
   Sistema de diseño OPENYM, compartido con el Chat Center
   (mismas variables --oc-* que assets/css/app-chat-custom.css)
   para que admin y chat se sientan como un solo producto.

   Estructura del archivo (se completa por partes):
   1. Variables --oc-* (idénticas al chat)
   2. Tipografía y reset base
   3. Mapeo --oc-* → variables de Bootstrap (--bs-*)
   4. [Pendiente] Botones e inputs
   5. [Pendiente] Menú lateral y navbar
   6. [Pendiente] Tablas y badges/estados
   ============================================================ */

/* ---------- 1. Variables (idénticas a app-chat-custom.css) ---------- */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --oc-bg:    #f5f7fb;
  --oc-bg2:   #ffffff;
  --oc-bg3:   #eef1f7;
  --oc-bg4:   #e4e9f2;
  --oc-line:  #e2e7f0;
  --oc-line2: #d0d7e6;
  --oc-line3: #b8c2d6;
  --oc-txt:   #0f1923;
  --oc-txt2:  #3d4f61;
  --oc-txt3:  #7a8aaa;
  --oc-txt4:  #b0bcce;
  --oc-blue:  #2563eb;
  --oc-blue2: #dbeafe;
  --oc-blue3: #eff6ff;
  --oc-teal:  #0d9488;
  --oc-teal2: #ccfbf1;
  --oc-grn:   #16a34a;
  --oc-grn2:  #dcfce7;
  --oc-grn3:  #f0fdf4;
  --oc-amb:   #d97706;
  --oc-amb2:  #fef3c7;
  --oc-amb3:  #fffbeb;
  --oc-red:   #dc2626;
  --oc-red2:  #fee2e2;
  --oc-red3:  #fff5f5;
  --oc-pur:   #7c3aed;
  --oc-pur2:  #ede9fe;
  --oc-pur3:  #f5f3ff;
  --oc-rail:  #ffffff;
  --oc-shadow: rgba(15, 25, 35, .12);
  --oc-r:     12px;
  --oc-r2:    8px;
  --oc-font:  'Inter', sans-serif;
  --oc-mono:  'JetBrains Mono', monospace;
  color-scheme: light;

  /* Variables extendidas (cards, hover, rail) */
  --oc-card: #ffffff;
  --oc-card2: #f8fbff;
  --oc-input-bg: #ffffff;
  --oc-hover: #f1f5f9;
  --oc-footer-bg: #ffffff;
  --oc-footer-txt: #334155;
  --oc-footer-muted: #7a8aaa;
  --oc-rail-line: #e2e7f0;
  --oc-rail-icon: #64748b;
  --oc-rail-icon-hover: #2563eb;
  --oc-rail-active-bg: #2563eb;
  --oc-rail-active-txt: #ffffff;
  --oc-page-gradient: linear-gradient(180deg, #f8fbff 0%, #f5f7fb 100%);
}

/* Modo oscuro: valores REALES tomados de app-chat-custom.css (html[data-theme="dark"]),
   mapeados a la convención .dark-style que usa el admin (main.js / Helpers.isDarkStyle). */
.dark-style {
  --oc-bg:    #0b1220;
  --oc-bg2:   #111827;
  --oc-bg3:   #182235;
  --oc-bg4:   #223047;
  --oc-line:  #263244;
  --oc-line2: #334155;
  --oc-line3: #475569;
  --oc-txt:   #f8fafc;
  --oc-txt2:  #cbd5e1;
  --oc-txt3:  #94a3b8;
  --oc-txt4:  #64748b;
  --oc-blue:  #3b82f6;
  --oc-blue2: rgba(59, 130, 246, .20);
  --oc-blue3: rgba(59, 130, 246, .10);
  --oc-teal:  #2dd4bf;
  --oc-teal2: rgba(45, 212, 191, .16);
  --oc-grn:   #22c55e;
  --oc-grn2:  rgba(34, 197, 94, .16);
  --oc-grn3:  rgba(34, 197, 94, .08);
  --oc-amb:   #f59e0b;
  --oc-amb2:  rgba(245, 158, 11, .17);
  --oc-amb3:  rgba(245, 158, 11, .08);
  --oc-red:   #ef4444;
  --oc-red2:  rgba(239, 68, 68, .17);
  --oc-red3:  rgba(239, 68, 68, .08);
  --oc-pur:   #a78bfa;
  --oc-pur2:  rgba(167, 139, 250, .18);
  --oc-pur3:  rgba(167, 139, 250, .09);
  --oc-rail:  #020617;
  --oc-shadow: rgba(0, 0, 0, .34);
  color-scheme: dark;

  /* Variables extendidas (cards, hover, rail) */
  --oc-card: #111827;
  --oc-card2: #0f172a;
  --oc-input-bg: #0f172a;
  --oc-hover: #182235;
  --oc-footer-bg: linear-gradient(180deg, #101b27 0%, #0b1420 100%);
  --oc-footer-txt: #e5edf8;
  --oc-footer-muted: #94a3b8;
  --oc-rail-line: #182235;
  --oc-rail-icon: #8aa0bd;
  --oc-rail-icon-hover: #93c5fd;
  --oc-rail-active-bg: #2563eb;
  --oc-rail-active-txt: #ffffff;
  --oc-page-gradient: linear-gradient(180deg, #0b1220 0%, #0f172a 100%);
}

/* ---------- 2. Tipografía y reset base ---------- */

body {
  font-family: var(--oc-font);
  font-size: 13px;
  color: var(--oc-txt2);
  background-color: var(--oc-bg);
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: var(--oc-font);
  color: var(--oc-txt);
  font-weight: 600;
}

code, pre, kbd, samp {
  font-family: var(--oc-mono);
}

a {
  color: var(--oc-blue);
}

a:hover {
  color: #1d4ed8;
}

/* Scrollbar consistente con el chat (Webkit) */
*::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
*::-webkit-scrollbar-track {
  background: transparent;
}
*::-webkit-scrollbar-thumb {
  background: var(--oc-line2);
  border-radius: 8px;
}
*::-webkit-scrollbar-thumb:hover {
  background: var(--oc-line3);
}

/* ---------- 3. Mapeo a variables de Bootstrap ----------
   Esto hace que componentes nativos de Bootstrap (.btn-primary,
   .alert-danger, .form-control:focus, etc.) usen la paleta OC
   automáticamente, sin tener que sobreescribir cada clase a mano. */

:root {
  --bs-body-font-family: var(--oc-font);
  --bs-body-bg: var(--oc-bg);
  --bs-body-color: var(--oc-txt2);
  --bs-border-color: var(--oc-line);
  --bs-border-radius: var(--oc-r2);
  --bs-border-radius-lg: var(--oc-r);

  --bs-primary: var(--oc-blue);
  --bs-primary-rgb: 37, 99, 235;   /* #2563eb */
  --bs-success: var(--oc-grn);
  --bs-success-rgb: 22, 163, 74;   /* #16a34a */
  --bs-warning: var(--oc-amb);
  --bs-warning-rgb: 217, 119, 6;   /* #d97706 */
  --bs-danger: var(--oc-red);
  --bs-danger-rgb: 220, 38, 38;    /* #dc2626 */
  --bs-info: var(--oc-teal);
  --bs-info-rgb: 13, 148, 136;     /* #0d9488 */

  --bs-pagination-active-bg: var(--oc-blue);
  --bs-pagination-active-border-color: var(--oc-blue);
}

.dark-style {
  --bs-body-font-family: var(--oc-font);
  --bs-body-bg: var(--oc-bg);
  --bs-body-color: var(--oc-txt2);
  --bs-border-color: var(--oc-line);
  --bs-border-radius: var(--oc-r2);
  --bs-border-radius-lg: var(--oc-r);

  --bs-primary: var(--oc-blue);
  --bs-primary-rgb: 59, 130, 246;  /* #3b82f6 (azul de modo oscuro, distinto del claro) */
  --bs-success: var(--oc-grn);
  --bs-success-rgb: 34, 197, 94;   /* #22c55e */
  --bs-warning: var(--oc-amb);
  --bs-warning-rgb: 245, 158, 11;  /* #f59e0b */
  --bs-danger: var(--oc-red);
  --bs-danger-rgb: 239, 68, 68;    /* #ef4444 */
  --bs-info: var(--oc-teal);
  --bs-info-rgb: 45, 212, 191;     /* #2dd4bf */

  --bs-pagination-active-bg: var(--oc-blue);
  --bs-pagination-active-border-color: var(--oc-blue);
}

/* ---------- 4. Contenedores principales: menú, navbar, fondo de página ----------
   Sobrescribe color residual de Sneat (morado) en las clases base del layout. */

body, .layout-page, .content-wrapper {
  background-color: var(--oc-bg) !important;
}

#layout-menu,
.bg-menu-theme {
  background-color: var(--oc-bg2) !important;
  border-right: 1px solid var(--oc-line);
}

.menu-vertical .menu-link {
  color: var(--oc-txt2);
}

.menu-vertical .menu-link i,
.menu-vertical .menu-link .menu-icon {
  color: var(--oc-txt3);
}

/* Hijo activo real (la página en la que estás): azul sólido + texto blanco */
.menu-vertical .menu-item.active > .menu-link:not(.menu-toggle) {
  background: var(--oc-blue);
  color: #fff;
  box-shadow: 0 4px 12px rgba(37, 99, 235, .35);
}

.menu-vertical .menu-item.active > .menu-link:not(.menu-toggle) i,
.menu-vertical .menu-item.active > .menu-link:not(.menu-toggle) .menu-icon {
  color: #fff;
}

/* Padre expandido que contiene al hijo activo: celeste tenue + texto azul,
   para que se note "abierto" sin competir visualmente con el hijo real */
.menu-vertical .menu-item.active > .menu-link.menu-toggle {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}

.menu-vertical .menu-item.active > .menu-link.menu-toggle i,
.menu-vertical .menu-item.active > .menu-link.menu-toggle .menu-icon {
  color: var(--oc-blue);
}

.menu-vertical .menu-item:not(.active) > .menu-link:hover {
  background-color: var(--oc-hover);
}

.menu-vertical .menu-header {
  color: var(--oc-txt4) !important;
}

.bg-navbar-theme {
  background-color: var(--oc-bg2) !important;
  box-shadow: 0 2px 8px var(--oc-shadow);
}

.layout-menu-toggle .nav-link {
  color: #fff;
  background-color: var(--oc-blue);
  border-radius: var(--oc-r2);
  padding: 0.5rem !important;
  transition: background-color 0.15s ease;
}

.layout-menu-toggle .nav-link:hover {
  background-color: #1d4ed8;
}

/* ---------- 5. Header del menú: logo / isotipo ---------- */

.menu-brand {
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1rem;
  background-color: var(--oc-bg2);
  border-bottom: 1px solid var(--oc-line);
}

.menu-brand-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.menu-brand-full {
  max-height: 36px;
  max-width: 100%;
  object-fit: contain;
}

.menu-brand-iso {
  display: none;
  max-height: 36px;
  max-width: 36px;
  object-fit: contain;
}

/* Menú colapsado: mostrar solo el isotipo */
.layout-menu-collapsed .menu-brand-full {
  display: none;
}

.layout-menu-collapsed .menu-brand-iso {
  display: block;
}

.layout-menu-collapsed .menu-brand {
  padding: 0 0.5rem;
}

/* ---------- 6. Info de usuario debajo del logo ---------- */

.menu-user-info {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--oc-line);
}

.menu-user-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--oc-blue);
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.menu-user-text {
  overflow: hidden;
  white-space: nowrap;
}

.menu-user-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--oc-txt);
  overflow: hidden;
  text-overflow: ellipsis;
}

.menu-user-role {
  font-size: 11px;
  color: var(--oc-txt3);
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Menú colapsado: solo el avatar, sin nombre/rol */
.layout-menu-collapsed .menu-user-info {
  justify-content: center;
  padding: 14px 8px;
}

.layout-menu-collapsed .menu-user-text {
  display: none;
}

/* ---------- 7. Tablas: badges de estado, canales, avatares, utilidades de texto ---------- */

/* Badges de estado (soft badge), mismo patrón que .oc-tag del chat center */
.oc-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11.5px;
  font-weight: 500;
  border: 1px solid;
  white-space: nowrap;
}
.oc-tag--blue { background: var(--oc-blue3); color: var(--oc-blue); border-color: var(--oc-blue2); }
.oc-tag--grn  { background: var(--oc-grn3);  color: var(--oc-grn);  border-color: var(--oc-grn2); }
.oc-tag--amb  { background: var(--oc-amb3);  color: var(--oc-amb);  border-color: var(--oc-amb2); }
.oc-tag--red  { background: var(--oc-red3);  color: var(--oc-red);  border-color: var(--oc-red2); }
.oc-tag--pur  { background: var(--oc-pur3);  color: var(--oc-pur);  border-color: var(--oc-pur2); }
.oc-tag--gray { background: var(--oc-bg3);   color: var(--oc-txt3); border-color: var(--oc-line); }

/* Colores de canal: mismos valores que assets/css/app-chat-custom.css, para consistencia */
.oc-channel--whatsapp  { color: var(--oc-grn); font-weight: 500; }
.oc-channel--instagram { color: #db2777; font-weight: 500; }
.oc-channel--facebook  { color: var(--oc-blue); font-weight: 500; }
.oc-channel--webchat   { color: var(--oc-pur); font-weight: 500; }
.oc-channel--gray      { color: var(--oc-txt3); font-weight: 500; }

/* Avatar con iniciales, color determinístico según el contacto (ver crc32 en el blade) */
.oc-avatar-initials {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  flex-shrink: 0;
}
.oc-avatar-img {
  width: 40px;
  height: 40px;
  object-fit: cover;
}
.oc-avatar--blue { background: var(--oc-blue3); color: var(--oc-blue); }
.oc-avatar--grn  { background: var(--oc-grn3);  color: var(--oc-grn); }
.oc-avatar--amb  { background: var(--oc-amb3);  color: var(--oc-amb); }
.oc-avatar--red  { background: var(--oc-red3);  color: var(--oc-red); }
.oc-avatar--pur  { background: var(--oc-pur3);  color: var(--oc-pur); }
.oc-avatar--teal { background: var(--oc-teal2); color: var(--oc-teal); }

/* Utilidades de texto que la tabla necesitaba y no existían en core.css */
.oc-text-muted   { color: var(--oc-txt3); }
.oc-text-primary-data { color: var(--oc-txt); font-weight: 500; }

/* Tabla estilo "filas tarjeta": cada fila separada con espacio y bordes redondeados,
   en vez de líneas divisorias tradicionales. */

.table.datatables {
  border-collapse: separate;
  border-spacing: 0 8px;
}

.table.datatables thead th {
  color: var(--oc-txt4);
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  border-bottom: none;
  padding-bottom: 12px;
}

.table.datatables tbody tr {
  background-color: var(--oc-bg2);
  box-shadow: 0 1px 2px var(--oc-shadow);
  transition: box-shadow .15s ease, transform .1s ease;
}

.table.datatables tbody tr:hover {
  box-shadow: 0 4px 12px var(--oc-shadow);
  transform: translateY(-1px);
}

.table.datatables td {
  border-top: 1px solid var(--oc-line);
  border-bottom: 1px solid var(--oc-line);
  border-left: none;
  border-right: none;
  color: var(--oc-txt2);
  padding-top: 14px;
  padding-bottom: 14px;
}

/* Bordes redondeados solo en la primera y última celda de cada fila */
.table.datatables td:first-child {
  border-left: 1px solid var(--oc-line);
  border-top-left-radius: var(--oc-r2);
  border-bottom-left-radius: var(--oc-r2);
}

.table.datatables td:last-child {
  border-right: 1px solid var(--oc-line);
  border-top-right-radius: var(--oc-r2);
  border-bottom-right-radius: var(--oc-r2);
}

/* ---------- 8. Botones e inputs (mismo patrón que .oc-btn / .oc-input del chat) ---------- */

.btn-primary {
  background-color: var(--oc-blue);
  border-color: var(--oc-blue);
  color: #fff;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
  background-color: #1d4ed8;
  border-color: #1d4ed8;
  color: #fff;
}

.btn-outline-primary {
  color: var(--oc-blue);
  border-color: var(--oc-line2);
  background-color: transparent;
}
.btn-outline-primary:hover {
  background-color: var(--oc-bg3);
  color: var(--oc-blue);
  border-color: var(--oc-line2);
}

.form-control,
.form-select {
  background-color: var(--oc-bg2);
  border-color: var(--oc-line);
  color: var(--oc-txt);
  border-radius: var(--oc-r2);
}
.form-control:focus,
.form-select:focus {
  border-color: var(--oc-blue);
  box-shadow: 0 0 0 3px var(--oc-blue3);
}

.dropdown-menu {
  border-color: var(--oc-line);
  border-radius: var(--oc-r2);
  box-shadow: 0 4px 16px var(--oc-shadow);
}
.dropdown-item:hover,
.dropdown-item:focus {
  background-color: var(--oc-hover);
  color: var(--oc-txt);
}

/* ---------- 9. Subtítulo descriptivo de cards (patrón "Contacts List" + descripción) ---------- */

.oc-card-subtitle {
  font-size: 12px;
  color: var(--oc-txt3);
  margin-top: 2px;
}

/* ---------- 10. Botones de acción en tablas (editar/borrar) ---------- */

.oc-action-btn {
  width: 32px;
  height: 32px;
  border-radius: var(--oc-r2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color .15s ease, transform .1s ease;
}
.oc-action-btn--edit {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}
.oc-action-btn--edit:hover {
  background: var(--oc-blue);
  color: #fff;
}
.oc-action-btn--delete {
  background: var(--oc-red3);
  color: var(--oc-red);
}
.oc-action-btn--delete:hover {
  background: var(--oc-red);
  color: #fff;
}
.oc-action-btn:active {
  transform: scale(0.94);
}

/* ---------- 11. Profundidad sutil ("3D") en cards y tabla ---------- */

.card {
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  box-shadow: 0 1px 3px var(--oc-shadow), 0 8px 24px -8px var(--oc-shadow);
}

.card-header {
  background: var(--oc-bg2);
  border-color: var(--oc-line) !important;
}

/* ---------- 12. Espaciado del contenedor de la tabla (no pegado a los bordes) ---------- */

.card-datatable {
  padding: 0 20px 12px;
}

.card-datatable .table-responsive {
  overflow-x: auto;
}

/* ---------- 12b. Controles nativos del plugin DataTables ----------
   El plugin (jQuery DataTables + integración Bootstrap 5) inyecta su
   propio HTML para "Show entries", "Search", el resumen "Showing X to
   Y of Z" y la paginación. Esas piezas no usan clases oc-/rc-, así
   que sin estas reglas se ven con el estilo genérico de Bootstrap,
   desentonando con el resto de la tabla (que sí está migrada). */

.dataTables_wrapper {
  padding: 14px 20px 4px;
  color: var(--oc-txt2);
  font-size: 12.5px;
}

.dataTables_length,
.dataTables_filter {
  margin-bottom: 14px;
}

.dataTables_length label,
.dataTables_filter label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--oc-txt3);
  font-size: 12.5px;
  margin: 0;
  white-space: nowrap;
}

.dataTables_length select,
.dataTables_filter input {
  background-color: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  color: var(--oc-txt);
  padding: 5px 10px;
}

.dataTables_length select {
  width: auto;
  min-width: 64px;
  flex-shrink: 0;
  padding-right: 28px;
}

.dataTables_filter input {
  width: 200px;
}

.dataTables_filter input:focus,
.dataTables_length select:focus {
  outline: none;
  border-color: var(--oc-blue);
  box-shadow: 0 0 0 3px var(--oc-blue3);
}

.dataTables_info {
  color: var(--oc-txt3);
  font-size: 12px;
  padding-top: 4px;
}

.dataTables_paginate {
  padding-top: 4px;
}

.dataTables_paginate .pagination {
  margin: 0;
}

.dataTables_paginate .page-link {
  background-color: var(--oc-bg2);
  border-color: var(--oc-line);
  color: var(--oc-txt2);
  border-radius: var(--oc-r2);
  margin-left: 4px;
}

.dataTables_paginate .page-item.active .page-link {
  background-color: var(--oc-blue);
  border-color: var(--oc-blue);
  color: #fff;
}

.dataTables_paginate .page-item.disabled .page-link {
  background-color: var(--oc-bg3);
  color: var(--oc-txt4);
}

.dataTables_paginate .page-link:hover {
  background-color: var(--oc-hover);
}

.oc-page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 18px;
}

.oc-eyebrow {
  font-size: 11px;
  font-weight: 700;
  color: var(--oc-blue);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.oc-page-title {
  margin: 4px 0 2px;
  color: var(--oc-txt);
  font-weight: 700;
}

.oc-page-subtitle {
  margin: 0;
  color: var(--oc-txt3);
}

.oc-page-actions {
  display: flex;
  gap: 10px;
}

.oc-contact-stats {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.oc-stat-card {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 14px 16px;
  box-shadow: 0 1px 3px var(--oc-shadow);
}

.oc-stat-card span {
  display: block;
  font-size: 12px;
  color: var(--oc-txt3);
  margin-bottom: 6px;
}

.oc-stat-card strong {
  font-size: 22px;
  color: var(--oc-txt);
}

.oc-stat-card--amb {
  background: var(--oc-amb3);
}

.oc-stat-card--blue {
  background: var(--oc-blue3);
}

.oc-stat-card--grn {
  background: var(--oc-grn3);
}

.oc-contact-card {
  overflow: hidden;
}

.oc-contact-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}

.oc-search-box {
  position: relative;
  flex: 1;
}

.oc-search-box i {
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--oc-txt3);
}

.oc-search-box .form-control {
  padding-left: 38px;
}

.oc-filter-group {
  display: flex;
  gap: 10px;
}

.oc-filter-group .form-select {
  min-width: 160px;
}

.oc-contact-user {
  display: flex;
  align-items: center;
  gap: 12px;
}

.oc-contact-name {
  font-weight: 600;
  color: var(--oc-txt);
}

.oc-contact-meta {
  font-size: 12px;
  color: var(--oc-txt3);
}

.oc-channel-pill {
  display: inline-flex;
  align-items: center;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--oc-bg3);
  font-size: 12px;
  font-weight: 600;
}

.oc-contact-data {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.oc-contact-data strong {
  color: var(--oc-txt);
  font-size: 13px;
}

.oc-contact-data span,
.oc-date {
  color: var(--oc-txt3);
  font-size: 12px;
}

@media (max-width: 992px) {
  .oc-page-header,
  .oc-contact-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .oc-contact-stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .oc-page-actions,
  .oc-filter-group {
    width: 100%;
    flex-wrap: wrap;
  }
}

/* ============================================================
   Relationship Center
   Overview / Prospects / Customers / Follow-up / Calendar
   ============================================================ */

.rc-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.rc-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}

.rc-title {
  margin: 0;
  font-size: 23px;
  font-weight: 700;
  color: var(--oc-txt);
  line-height: 1.15;
}

.rc-subtitle {
  margin: 6px 0 0;
  color: var(--oc-txt3);
  font-size: 12.5px;
}

/* ---------- KPI Cards ---------- */

.rc-kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 12px;
}

.rc-kpi-grid-secondary {
  grid-template-columns: repeat(4, minmax(180px, 1fr));
}

.rc-kpi,
.rc-card {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 14px 16px;
  box-shadow: 0 1px 3px var(--oc-shadow), 0 8px 24px -10px var(--oc-shadow);
  height: 100%;
  box-sizing: border-box;
}

.rc-kpi-icon {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
}

.rc-kpi-icon.blue { background: var(--oc-blue3); color: var(--oc-blue); }
.rc-kpi-icon.green { background: var(--oc-grn3); color: var(--oc-grn); }
.rc-kpi-icon.orange { background: var(--oc-amb3); color: var(--oc-amb); }
.rc-kpi-icon.red { background: var(--oc-red3); color: var(--oc-red); }
.rc-kpi-icon.purple { background: var(--oc-pur3); color: var(--oc-pur); }

.rc-kpi-label {
  color: var(--oc-txt3);
  font-size: 11.5px;
  font-weight: 600;
}

.rc-kpi-value,
.rc-metric-value {
  margin-top: 4px;
  font-size: 24px;
  color: var(--oc-txt);
  font-weight: 700;
  line-height: 1.05;
}

.rc-kpi-change {
  margin-top: 8px;
  font-size: 11.5px;
  font-weight: 600;
}

.rc-kpi-change.up { color: var(--oc-grn); }
.rc-kpi-change.down { color: var(--oc-red); }

.rc-progress {
  height: 5px;
  background: var(--oc-bg3);
  border-radius: 999px;
  overflow: hidden;
  margin-top: 12px;
}

.rc-progress span {
  display: block;
  height: 100%;
  border-radius: 999px;
  max-width: 100%;
}

.rc-progress .blue { background: var(--oc-blue); }
.rc-progress .green { background: var(--oc-grn); }
.rc-progress .orange { background: var(--oc-amb); }
.rc-progress .red { background: var(--oc-red); }
.rc-progress .purple { background: var(--oc-pur); }

/* ============================================================
   MAIN OVERVIEW LAYOUT
   Performance Over Time (col-md-6) | Channel Performance (col-md-3)
   | Top Agents (col-md-3) — plain Bootstrap row/col, no custom grid.
   ============================================================ */

.rc-card h5 {
  font-size: 15px;
  font-weight: 700;
  color: var(--oc-txt);
}

.rc-card h6 {
  font-size: 13px;
  font-weight: 700;
  color: var(--oc-txt);
}

.oc-link-sm {
  font-size: 12px;
  font-weight: 600;
  color: var(--oc-blue);
  text-decoration: none;
  white-space: nowrap;
}

.oc-link-sm:hover {
  text-decoration: underline;
}

/* ---------- Charts ---------- */

.rc-chart-area {
  min-height: 200px;
}

.rc-mini-chart {
  width: 82px;
  height: 82px;
  flex: 0 0 82px;
}

.rc-spark-chart {
  width: 110px;
  height: 62px;
  flex: 0 0 110px;
}

/* ============================================================
   PERFORMANCE OVER TIME
   Compact 2x2 metric grid above the chart, sized to sit
   comfortably as one of three equal-width columns.
   ============================================================ */

.rc-perf-mini-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}

.rc-metric-value-sm {
  margin-top: 2px;
  font-size: 18px;
  color: var(--oc-txt);
  font-weight: 700;
  line-height: 1.1;
}

/* ============================================================
   CHANNEL PERFORMANCE
   Donut + channel list side by side, totals row below.
   Donut sized to exactly match the chart's own render size
   (120x120) with overflow visible, so ApexCharts never clips
   a segment against the box edge.
   ============================================================ */

.rc-channel-card-body {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}

.rc-donut-chart {
  flex: 0 0 120px;
  width: 120px;
  height: 120px;
  min-height: 120px;
  max-height: 120px;
  overflow: visible;
}

.rc-channel-list {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 9px;
  min-width: 0;
}

.rc-channel-row {
  display: grid;
  grid-template-columns: 8px 1fr auto;
  align-items: center;
  gap: 8px;
  color: var(--oc-txt2);
  font-size: 12px;
}

.rc-channel-row strong {
  color: var(--oc-txt);
  font-weight: 700;
}

.rc-channel-row span {
  color: var(--oc-txt3);
  font-size: 11.5px;
  text-align: right;
}

.rc-channel-totals {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  border-top: 1px solid var(--oc-line);
  padding-top: 14px;
}

.rc-channel-totals div {
  text-align: center;
  background: var(--oc-bg3);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  padding: 10px 8px;
}

.rc-channel-totals span {
  display: block;
  font-size: 10.5px;
  color: var(--oc-txt3);
  margin-bottom: 3px;
}

.rc-channel-totals strong {
  display: block;
  font-size: 15px;
  font-weight: 700;
  color: var(--oc-txt);
}

.rc-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.rc-dot.green { background: var(--oc-grn); }
.rc-dot.red { background: var(--oc-red); }
.rc-dot.purple { background: var(--oc-pur); }
.rc-dot.blue { background: var(--oc-blue); }
.rc-dot.orange { background: var(--oc-amb); }
.rc-dot.gray { background: var(--oc-line3); }

.rc-channel-highlight {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 14px;
  padding: 12px 14px;
  background: var(--oc-grn3);
  border: 1px solid var(--oc-grn2);
  border-radius: var(--oc-r2);
}

.rc-channel-highlight-info {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.rc-channel-highlight-info .rc-dot {
  flex-shrink: 0;
}

/* ============================================================
   TOP AGENTS
   Compact rows sized to fit a narrower third-column width.
   ============================================================ */

.rc-agent-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rc-card--scroll-host {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.rc-card--scroll-host > .d-flex:first-child {
  flex: 0 0 auto;
}

.rc-agent-list--scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding-right: 4px;
}

.rc-agent-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.rc-agent-row > .d-flex {
  flex: 1;
  min-width: 0;
}

.rc-agent-row .oc-avatar-initials {
  width: 32px;
  height: 32px;
  font-size: 11px;
  flex-shrink: 0;
}

.rc-agent-score {
  flex: 0 0 auto;
  display: grid;
  grid-template-columns: 60px 32px;
  align-items: center;
  gap: 8px;
}

.rc-agent-score .rc-progress {
  margin-top: 0;
}

.rc-agent-score strong {
  color: var(--oc-txt);
  font-size: 12px;
  text-align: right;
}

/* ============================================================
   RELATIONSHIP HEALTH + RECENT ACTIVITY
   Second row below the 3-column overview. Health uses 4 large
   stat cards in a row; Activity is a simple timeline list.
   ============================================================ */

.rc-health-grid-main {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.rc-health-grid-main > .rc-card {
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
}

.rc-health-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.rc-health-card {
  background: var(--oc-bg3);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 16px;
  text-align: left;
}

.rc-health-icon {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  margin-bottom: 10px;
}

.rc-health-icon.red { background: var(--oc-red2); color: var(--oc-red); }
.rc-health-icon.orange { background: var(--oc-amb2); color: var(--oc-amb); }
.rc-health-icon.purple { background: var(--oc-pur2); color: var(--oc-pur); }
.rc-health-icon.blue { background: var(--oc-blue2); color: var(--oc-blue); }

.rc-health-value {
  font-size: 26px;
  font-weight: 700;
  color: var(--oc-txt);
  line-height: 1.1;
  margin-bottom: 2px;
}

/* ---------- Recent Activity ---------- */

.rc-activity-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.rc-activity-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.rc-activity-icon {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}

.rc-activity-icon.green { background: var(--oc-grn3); color: var(--oc-grn); }
.rc-activity-icon.orange { background: var(--oc-amb3); color: var(--oc-amb); }
.rc-activity-icon.blue { background: var(--oc-blue3); color: var(--oc-blue); }
.rc-activity-icon.purple { background: var(--oc-pur3); color: var(--oc-pur); }

.rc-activity-time {
  font-size: 11px;
  color: var(--oc-txt3);
  flex-shrink: 0;
  white-space: nowrap;
}

/* ---------- Responsive ---------- */

@media (max-width: 1400px) {
  .rc-kpi-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .rc-kpi-grid-secondary {
    grid-template-columns: repeat(2, 1fr);
  }

  .rc-health-grid-main {
    grid-template-columns: 1fr;
  }

  .rc-health-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 992px) {
  .rc-channel-card-body {
    flex-direction: column;
  }

  .rc-donut-chart {
    align-self: center;
  }
}

@media (max-width: 768px) {
  .rc-header {
    flex-direction: column;
  }

  .rc-kpi-grid,
  .rc-kpi-grid-secondary {
    grid-template-columns: 1fr;
  }

  .rc-perf-mini-stats {
    grid-template-columns: 1fr 1fr;
  }

  .rc-agent-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .rc-agent-score {
    width: 100%;
    grid-template-columns: 1fr 32px;
  }

  .rc-health-grid {
    grid-template-columns: 1fr;
  }

  .rc-channel-totals {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   Prospects Board
   ============================================================ */

.rc-prospect-board {
  display: grid;
  grid-template-columns: repeat(4, minmax(260px, 1fr));
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.rc-prospect-column {
  background: var(--oc-bg3);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 12px;
  min-width: 260px;
}

.rc-prospect-column-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
}

.rc-prospect-column-header h6 {
  margin: 0;
  font-size: 13px;
  color: var(--oc-txt);
  font-weight: 700;
}

.rc-prospect-column-header span {
  display: block;
  font-size: 11.5px;
  color: var(--oc-txt3);
  margin-top: 2px;
}

.rc-prospect-column-header strong {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  color: var(--oc-txt);
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 12px;
}

.rc-prospect-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 620px;
  overflow-y: auto;
  padding-right: 3px;
}

.rc-prospect-card {
  width: 100%;
  text-align: left;
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 12px;
  box-shadow: 0 1px 2px var(--oc-shadow);
  color: var(--oc-txt2);
  transition: .15s ease;
}

.rc-prospect-card:hover {
  border-color: var(--oc-blue2);
  box-shadow: 0 6px 18px var(--oc-shadow);
  transform: translateY(-1px);
}

.rc-prospect-card-active {
  border-color: var(--oc-grn2);
  background: var(--oc-grn3);
}

.rc-prospect-meta {
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.rc-prospect-meta span,
.rc-prospect-footer span {
  font-size: 11.5px;
  color: var(--oc-txt3);
}

.rc-prospect-meta strong,
.rc-prospect-footer strong {
  font-size: 12px;
  color: var(--oc-txt);
}

.rc-prospect-footer {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--oc-line);
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.rc-prospect-offcanvas {
  width: 460px !important;
  background: var(--oc-bg);
  color: var(--oc-txt2);
}

.rc-detail-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rc-detail-list > div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--oc-line);
}

.rc-detail-list > div:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.rc-detail-list span {
  color: var(--oc-txt3);
  font-size: 12px;
}

.rc-detail-list strong {
  color: var(--oc-txt);
  font-size: 12.5px;
  text-align: right;
}

@media (max-width: 1200px) {
  .rc-prospect-board {
    grid-template-columns: repeat(4, 280px);
  }
}

@media (max-width: 768px) {
  .rc-prospect-offcanvas {
    width: 100% !important;
  }
}

.oc-tag--gray {
  background: var(--oc-blue3);
  color: var(--oc-blue);
  border-color: var(--oc-blue2);
}

/* ============================================================
   Customer Show - Relationship Center
   ============================================================ */

.rc-customer-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 14px;
  align-items: stretch;
}

.rc-customer-main-card {
  display: grid;
  grid-template-columns: 110px 1fr 1fr;
  gap: 24px;
  align-items: center;
  min-height: 170px;
}

.rc-customer-avatar-lg {
  width: 82px;
  height: 82px;
  border-radius: 50%;
  background: var(--oc-blue);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  font-weight: 700;
}

.rc-customer-contact-list {
  display: flex;
  flex-direction: column;
  gap: 13px;
}

.rc-customer-contact-item {
  display: grid;
  grid-template-columns: 22px 1fr;
  align-items: center;
  gap: 10px;
  color: var(--oc-txt2);
}

.rc-customer-contact-item i {
  color: var(--oc-blue);
  font-size: 17px;
}

.rc-customer-info-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px 34px;
}

.rc-customer-info-box span {
  display: block;
  color: var(--oc-txt3);
  font-size: 11.5px;
  margin-bottom: 5px;
}

.rc-customer-info-box strong {
  color: var(--oc-txt);
  font-size: 13px;
}

.rc-health-breakdown {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 18px;
  align-items: center;
}

.rc-health-circle {
  width: 92px;
  height: 92px;
  border-radius: 50%;
  border: 9px solid var(--oc-grn);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  color: var(--oc-txt);
  font-size: 26px;
  font-weight: 700;
}

.rc-health-circle span {
  font-size: 11px;
  color: var(--oc-txt3);
  font-weight: 500;
}

.rc-health-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.rc-health-list-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
}

.rc-health-list-row span {
  color: var(--oc-txt3);
}

.rc-health-list-row strong {
  color: var(--oc-txt);
}

.rc-customer-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 14px;
  align-items: start;
}

.rc-customer-tabs .nav-tabs {
  border-bottom: 1px solid var(--oc-line);
}

.rc-customer-tabs .nav-link {
  border: 0;
  color: var(--oc-txt3);
  font-weight: 600;
  padding: 12px 16px;
}

.rc-customer-tabs .nav-link.active {
  color: var(--oc-blue);
  background: transparent;
  border-bottom: 3px solid var(--oc-blue);
}

.rc-customer-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.rc-customer-metric {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 18px;
}

.rc-customer-metric-icon {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  font-size: 18px;
}

.rc-customer-metric-icon.green { background: var(--oc-grn3); color: var(--oc-grn); }
.rc-customer-metric-icon.blue { background: var(--oc-blue3); color: var(--oc-blue); }
.rc-customer-metric-icon.purple { background: var(--oc-pur3); color: var(--oc-pur); }
.rc-customer-metric-icon.orange { background: var(--oc-amb3); color: var(--oc-amb); }

.rc-customer-metric-value {
  font-size: 28px;
  color: var(--oc-txt);
  font-weight: 700;
  line-height: 1;
}

.rc-side-stack {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.rc-action-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

@media (max-width: 1400px) {
  .rc-customer-top,
  .rc-customer-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 992px) {
  .rc-customer-main-card {
    grid-template-columns: 1fr;
  }

  .rc-customer-metrics {
    grid-template-columns: repeat(2, 1fr);
  }

  .rc-customer-info-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .rc-customer-metrics,
  .rc-action-grid {
    grid-template-columns: 1fr;
  }
}

.rc-customer-compact-profile {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 26px;
  align-items: center;
}

.rc-customer-identity {
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
}

.rc-customer-compact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(160px, 1fr));
  gap: 14px;
}

.rc-customer-compact-grid > div {
  background: var(--oc-bg3);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  padding: 10px 12px;
}

.rc-customer-compact-grid span {
  display: block;
  color: var(--oc-txt3);
  font-size: 11px;
  margin-bottom: 4px;
}

.rc-customer-compact-grid strong {
  color: var(--oc-txt);
  font-size: 12.5px;
}

@media (max-width: 1200px) {
  .rc-customer-compact-profile {
    grid-template-columns: 1fr;
  }

  .rc-customer-compact-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .rc-customer-compact-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   Follow-up Center
   ============================================================ */

.rc-followup-tabs .nav-tabs {
  border-bottom: 1px solid var(--oc-line);
}

.rc-followup-tabs .nav-link {
  border: 0;
  color: var(--oc-txt3);
  font-weight: 600;
  padding: 12px 14px;
}

.rc-followup-tabs .nav-link.active {
  color: var(--oc-blue);
  background: transparent;
  border-bottom: 3px solid var(--oc-blue);
}

.rc-followup-detail {
  position: sticky;
  top: 90px;
}

.rc-followup-table .table td,
.rc-followup-table .table th {
  vertical-align: middle;
}

.oc-avatar--gray {
  background: var(--oc-bg3);
  color: var(--oc-txt3);
}

.oc-tag--orange {
  background: var(--oc-amb3);
  color: var(--oc-amb);
  border-color: var(--oc-amb2);
}

.rc-followup-work-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 14px;
  align-items: start;
}

.rc-followup-main {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

.rc-followup-two-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: stretch;
}

.rc-followup-side {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.rc-compact-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rc-compact-row {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 42px;
}

.rc-followup-check-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--oc-line);
}

.rc-followup-check-row:last-child {
  border-bottom: 0;
}

.rc-followup-check-row .form-check-input {
  margin-top: 4px;
}

.rc-followup-info-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rc-followup-info-list > div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.rc-followup-info-list span {
  color: var(--oc-txt3);
  font-size: 12px;
}

.rc-followup-info-list strong {
  color: var(--oc-txt);
  font-size: 12.5px;
  text-align: right;
}

@media (max-width: 1400px) {
  .rc-followup-work-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 992px) {
  .rc-followup-two-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   Calendar V2 - Stable isolated design
   ============================================================ */

.rc-cal-shell {
  width: 100%;
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  box-shadow: 0 1px 3px var(--oc-shadow), 0 8px 24px -10px var(--oc-shadow);
  overflow: hidden;
}

.rc-cal-sidebar {
  background: var(--oc-bg);
  border-right: 1px solid var(--oc-line);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

.rc-cal-main {
  min-width: 0;
  background: var(--oc-bg2);
  padding: 16px;
  overflow: hidden;
}

.rc-cal-panel {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 14px 16px;
  box-shadow: 0 1px 3px var(--oc-shadow);
}

.rc-cal-panel-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 14px;
}

.rc-cal-panel-icon {
  width: 30px;
  height: 30px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.rc-cal-panel-icon.blue {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}

.rc-cal-panel-head h6 {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--oc-txt);
}

.rc-cal-panel-head p {
  margin: 4px 0 0;
  font-size: 11.5px;
  color: var(--oc-txt3);
}

.rc-cal-stats {
  display: grid;
  gap: 10px;
}

.rc-cal-stats > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.rc-cal-stats span {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--oc-txt2);
  font-size: 12.5px;
}

.rc-cal-stats strong {
  color: var(--oc-txt);
  font-size: 12.5px;
}

.rc-cal-upcoming {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.rc-cal-upcoming-row {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
}

.rc-cal-upcoming-row strong {
  display: block;
  color: var(--oc-txt);
  font-size: 12.5px;
  line-height: 1.2;
}

.rc-cal-upcoming-row span:not(.oc-tag) {
  display: block;
  color: var(--oc-txt3);
  font-size: 11.5px;
  margin-top: 3px;
}

.rc-cal-filters {
  display: grid;
  gap: 9px;
}

.rc-cal-filters label {
  display: flex;
  align-items: center;
  gap: 9px;
  min-height: 28px;
  margin: 0;
  color: var(--oc-txt2);
  font-size: 12.5px;
}

.rc-cal-filters .form-check-input {
  margin: 0;
  flex-shrink: 0;
}

/* FullCalendar isolated */
.rc-cal-main .fc {
  width: 100% !important;
  color: var(--oc-txt2);
  background: var(--oc-bg2);
}

.rc-cal-main .fc-header-toolbar {
  margin: 0 0 14px 0 !important;
}

.rc-cal-main .fc-toolbar-title {
  color: var(--oc-txt);
  font-size: 22px;
  font-weight: 700;
}

.rc-cal-main .fc-toolbar-chunk {
  display: flex;
  align-items: center;
  gap: 8px;
}

.rc-cal-main .fc-button-group {
  gap: 6px;
}

.rc-cal-main .fc-button {
  height: 38px;
  padding: 0 15px !important;
  border-radius: var(--oc-r2) !important;
  border: 1px solid var(--oc-line2) !important;
  background: var(--oc-bg2) !important;
  color: var(--oc-txt2) !important;
  box-shadow: none !important;
  text-transform: capitalize;
  font-weight: 500;
}

.rc-cal-main .fc-prev-button,
.rc-cal-main .fc-next-button {
  width: 38px;
  padding: 0 !important;
}

.rc-cal-main .fc-button:hover,
.rc-cal-main .fc-button-active {
  background: var(--oc-blue) !important;
  border-color: var(--oc-blue) !important;
  color: #fff !important;
}

.rc-cal-main .fc-view-harness,
.rc-cal-main .fc-view {
  width: 100% !important;
}

.rc-cal-main .fc-scrollgrid {
  width: 100%;
  border: 1px solid var(--oc-line) !important;
  border-radius: var(--oc-r);
  overflow: hidden;
}

/* Fix real del desbalance de borde/columnas: el header de FullCalendar
   usa overflow:hidden (nunca reserva scrollbar) pero el body usa
   overflow:hidden auto (SÍ reserva espacio de scrollbar vertical en
   cuanto el contenido excede el alto del contenedor). Esa reserva
   asimétrica es lo que desalinea "Sun" (con más aire a la izquierda)
   contra "Sat" (pegado al borde derecho). Forzamos que el body
   siempre reserve ese espacio, esté o no visible la scrollbar, para
   que su ancho real coincida siempre con el del header. */
.rc-cal-main .fc-scroller {
  scrollbar-gutter: stable;
}

.rc-cal-main .fc-daygrid-body {
  width: 100% !important;
}

.rc-cal-main .fc-theme-standard td,
.rc-cal-main .fc-theme-standard th {
  border-color: var(--oc-line) !important;
}

.rc-cal-main .fc-col-header-cell {
  background: var(--oc-bg3);
  padding: 10px 0;
}

.rc-cal-main .fc-col-header-cell-cushion {
  color: var(--oc-txt2);
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
}

.rc-cal-main .fc-daygrid-day {
  background: var(--oc-bg2);
}

.rc-cal-main .fc-daygrid-day-frame {
  padding: 8px;
}

.rc-cal-main .fc-daygrid-day-number {
  color: var(--oc-txt2);
  font-size: 12px;
  text-decoration: none;
}

.rc-cal-main .fc-day-other .fc-daygrid-day-number {
  color: var(--oc-txt4);
}

.rc-cal-main .fc-day-today {
  background: var(--oc-blue3) !important;
}

.rc-cal-main .fc-daygrid-event {
  margin-top: 6px;
}

.rc-cal-main .fc-event {
  border: 0 !important;
  border-radius: 8px;
  padding: 4px 7px;
  font-size: 11.5px;
  font-weight: 700;
  overflow: hidden;
}

/* Event colors */
.rc-cal-main .fc-event-primary {
  background: var(--oc-blue3) !important;
  color: var(--oc-blue) !important;
}

.rc-cal-main .fc-event-success {
  background: var(--oc-grn3) !important;
  color: var(--oc-grn) !important;
}

.rc-cal-main .fc-event-info {
  background: var(--oc-teal2) !important;
  color: var(--oc-teal) !important;
}

.rc-cal-main .fc-event-warning {
  background: var(--oc-amb3) !important;
  color: var(--oc-amb) !important;
}

.rc-cal-main .fc-event-danger {
  background: var(--oc-red3) !important;
  color: var(--oc-red) !important;
}

.rc-cal-main .fc-event-secondary {
  background: var(--oc-bg3) !important;
  color: var(--oc-txt2) !important;
}

@media (max-width: 1200px) {
  .rc-cal-shell {
    grid-template-columns: 1fr;
  }

  .rc-cal-sidebar {
    border-right: 0;
    border-bottom: 1px solid var(--oc-line);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 992px) {
  .rc-cal-sidebar {
    grid-template-columns: 1fr;
  }

  .rc-cal-main .fc-header-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
}

@media (max-width: 768px) {
  .rc-cal-main {
    padding: 10px;
  }
}

/* ============================================================
   FLOW TEMPLATES
   ============================================================ */

.rc-flow-layout {
  display: grid;
  grid-template-columns: 330px minmax(0, 1fr) 300px;
  gap: 14px;
  align-items: start;
}

.rc-flow-sidebar,
.rc-flow-canvas-card,
.rc-flow-details {
  min-width: 0;
}

.rc-flow-filter-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.rc-flow-filter-row button {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg3);
  color: var(--oc-txt2);
  border-radius: 10px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 600;
}

.rc-flow-filter-row button.active {
  background: var(--oc-blue3);
  color: var(--oc-blue);
  border-color: var(--oc-blue2);
}

.rc-flow-filter-row button span {
  margin-left: 4px;
}

.rc-flow-list {
  display: grid;
  gap: 10px;
}

.rc-flow-list-item {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  border-radius: var(--oc-r2);
  padding: 12px;
  color: var(--oc-txt2);
  transition: .15s ease;
}

.rc-flow-list-item:hover,
.rc-flow-list-item.active {
  border-color: var(--oc-blue);
  background: var(--oc-blue3);
}

.rc-flow-list-icon,
.rc-flow-detail-icon {
  width: 42px;
  height: 42px;
  border-radius: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 18px;
}

.rc-flow-list-icon.blue,
.rc-flow-detail-icon {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}

.rc-flow-list-icon.purple {
  background: var(--oc-pur3);
  color: var(--oc-pur);
}

.rc-flow-canvas {
  position: relative;
  min-height: 720px;
  overflow: auto;
  border-radius: var(--oc-r);
  background-image: radial-gradient(var(--oc-line) 1px, transparent 1px);
  background-size: 18px 18px;
  background-color: var(--oc-bg2);
  padding: 34px;
}

.rc-flow-root {
  display: flex;
  justify-content: center;
}

.rc-flow-main-node {
  width: 340px;
  background: var(--oc-bg2);
  border: 2px solid var(--oc-pur2);
  border-radius: var(--oc-r);
  box-shadow: 0 8px 24px -12px var(--oc-shadow);
  padding: 20px;
}

.rc-flow-connector-vertical {
  width: 2px;
  height: 34px;
  background: var(--oc-line2);
  margin: 18px auto 0;
}

.rc-flow-connector-horizontal {
  height: 2px;
  width: 74%;
  background: var(--oc-line2);
  margin: 0 auto 26px;
}

.rc-flow-options-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(180px, 1fr));
  gap: 18px;
  align-items: start;
}

.rc-flow-branch {
  min-width: 0;
}

.rc-flow-node {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-top: 3px solid var(--oc-blue);
  border-radius: var(--oc-r);
  padding: 18px;
  min-height: 220px;
  box-shadow: 0 8px 20px -14px var(--oc-shadow);
}

.rc-flow-node--blue { border-color: var(--oc-blue2); border-top-color: var(--oc-blue); }
.rc-flow-node--teal { border-color: var(--oc-teal2); border-top-color: var(--oc-teal); }
.rc-flow-node--orange { border-color: var(--oc-amb2); border-top-color: var(--oc-amb); }
.rc-flow-node--red { border-color: var(--oc-red2); border-top-color: var(--oc-red); }
.rc-flow-node--gray { border-color: var(--oc-line); border-top-color: var(--oc-txt3); }

.rc-flow-step-number {
  width: 25px;
  height: 25px;
  border-radius: 50%;
  background: var(--oc-blue3);
  color: var(--oc-blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
}

.rc-flow-node h6 {
  font-size: 15px;
  font-weight: 700;
  color: var(--oc-txt);
  margin-bottom: 8px;
}

.rc-flow-node p {
  color: var(--oc-txt3);
  font-size: 12px;
  min-height: 44px;
  margin-bottom: 14px;
}

.rc-flow-action-line {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--oc-bg3);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  padding: 10px;
}

.rc-flow-action-line i {
  color: var(--oc-blue);
  font-size: 18px;
}

.rc-flow-action-line span {
  display: block;
  font-size: 11px;
  color: var(--oc-txt3);
}

.rc-flow-action-line strong {
  display: block;
  color: var(--oc-txt);
  font-size: 12px;
}

.rc-flow-action-line.muted i {
  color: var(--oc-txt3);
}

.rc-flow-child-list {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.rc-flow-child-card {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  box-shadow: 0 4px 14px -12px var(--oc-shadow);
}

.rc-flow-child-card strong {
  display: block;
  color: var(--oc-txt);
  font-size: 12px;
}

.rc-flow-child-card span:not(.oc-tag) {
  display: block;
  color: var(--oc-txt3);
  font-size: 11px;
  margin-top: 2px;
}

.rc-flow-legend {
  position: sticky;
  bottom: 0;
  margin-top: 26px;
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  padding: 10px 14px;
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  width: fit-content;
}

.rc-flow-legend span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  color: var(--oc-txt2);
}

.rc-flow-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  overflow: hidden;
}

.rc-flow-detail-grid > div {
  padding: 14px;
  text-align: center;
  border-right: 1px solid var(--oc-line);
  border-bottom: 1px solid var(--oc-line);
}

.rc-flow-detail-grid > div:nth-child(2n) {
  border-right: 0;
}

.rc-flow-detail-grid > div:nth-last-child(-n + 2) {
  border-bottom: 0;
}

.rc-flow-detail-grid strong {
  display: block;
  color: var(--oc-txt);
  font-size: 20px;
  line-height: 1.1;
}

.rc-flow-detail-grid span {
  display: block;
  color: var(--oc-txt3);
  font-size: 11px;
  margin-top: 5px;
}

.min-w-0 {
  min-width: 0;
}

/* Tags extra usados en Flow */
.oc-tag--teal {
  color: var(--oc-teal);
  background: var(--oc-teal2);
}

@media (max-width: 1500px) {
  .rc-flow-layout {
    grid-template-columns: 310px minmax(0, 1fr);
  }

  .rc-flow-details {
    grid-column: 1 / -1;
  }

  .rc-flow-options-grid {
    grid-template-columns: repeat(3, minmax(180px, 1fr));
  }
}

@media (max-width: 992px) {
  .rc-flow-layout {
    grid-template-columns: 1fr;
  }

  .rc-flow-options-grid {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }
}

@media (max-width: 576px) {
  .rc-flow-options-grid {
    grid-template-columns: 1fr;
  }

  .rc-flow-canvas {
    padding: 18px;
  }

  .rc-flow-main-node {
    width: 100%;
  }
}

/* ==========================================
   FLOW TEMPLATES V2
   Reemplaza el CSS anterior completo
========================================== */

.rc-flow-layout-clean{
  display:grid;
  grid-template-columns:330px minmax(0,1fr);
  gap:20px;
  align-items:start;
}

/* ==========================
   SIDEBAR
========================== */

.rc-flow-sidebar{
  position:sticky;
  top:90px;
}

.rc-flow-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  max-height:650px;
  overflow:auto;
}

.rc-flow-list-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px;
  border:1px solid var(--bs-border-color);
  border-radius:14px;
  transition:.2s;
  background:#fff;
}

.rc-flow-list-item:hover{
  border-color:var(--oc-blue);
  transform:translateY(-1px);
}

.rc-flow-list-item.active{
  border-color:var(--oc-blue);
  background:rgba(59,130,246,.04);
}

.rc-flow-list-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.rc-flow-list-icon.blue{
  background:#eef4ff;
  color:#2563eb;
}

.rc-flow-list-icon.purple{
  background:#f5f3ff;
  color:#7c3aed;
}

/* ==========================
   FILTER BUTTONS
========================== */

.rc-flow-filter-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.rc-flow-filter-row button{
  border:none;
  background:#eef2f7;
  padding:8px 12px;
  border-radius:10px;
  font-size:.85rem;
}

.rc-flow-filter-row button.active{
  background:#e8f0ff;
  color:#2563eb;
}

.rc-flow-filter-row span{
  font-weight:600;
}

/* ==========================
   CANVAS
========================== */

.rc-flow-canvas-card{
  overflow:hidden;
}

.rc-flow-canvas{
  position:relative;
  min-height:700px;
  overflow:auto;
  padding:30px;
  background-image:
    radial-gradient(#d9e2f1 1px, transparent 1px);
  background-size:20px 20px;
  border-radius:14px;
}

.rc-flow-root{
  display:flex;
  justify-content:center;
}

.rc-flow-main-node{
  width:340px;
  background:#fff;
  border:2px solid #dbeafe;
  border-radius:18px;
  padding:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.04);
}

.rc-flow-main-node h5{
  margin-bottom:10px;
}

/* ==========================
   CONNECTORS
========================== */

.rc-flow-connector-vertical{
  width:2px;
  height:50px;
  background:#d7dfec;
  margin:0 auto;
}

.rc-flow-connector-horizontal{
  height:2px;
  background:#d7dfec;
  width:65%;
  margin:0 auto 30px;
}

/* ==========================
   OPTIONS GRID
========================== */

.rc-flow-options-grid{
  display:flex;
  gap:20px;
  justify-content:center;
  align-items:flex-start;
  min-width:max-content;
}

.rc-flow-branch{
  width:350px;
}

.rc-flow-node{
  background:#fff;
  border-radius:18px;
  padding:18px;
  border:2px solid #edf2f7;
  transition:.2s;
}

.rc-flow-node:hover{
  transform:translateY(-2px);
}

.rc-flow-node h6{
  font-size:1.15rem;
  margin-bottom:10px;
}

.rc-flow-node p{
  color:#72809d;
  min-height:44px;
  margin-bottom:16px;
}

.rc-flow-step-number{
  width:28px;
  height:28px;
  border-radius:50%;
  background:#eef2ff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.8rem;
  font-weight:700;
}

.rc-flow-node--blue{
  border-color:#bfd4ff;
}

.rc-flow-node--teal{
  border-color:#8ce6d6;
}

.rc-flow-node--orange{
  border-color:#ffd28a;
}

.rc-flow-node--red{
  border-color:#ffb6b6;
}

.rc-flow-node--gray{
  border-color:#dce2ea;
}

/* ==========================
   ACTION LINE
========================== */

.rc-flow-action-line{
  display:flex;
  gap:12px;
  align-items:center;
  padding:12px;
  background:#f8fafc;
  border-radius:12px;
}

.rc-flow-action-line i{
  font-size:18px;
  color:#2563eb;
}

.rc-flow-action-line span{
  display:block;
  font-size:.75rem;
  color:#7d8aa5;
}

.rc-flow-action-line strong{
  display:block;
  font-size:.9rem;
}

/* ==========================
   CHILD NODES
========================== */

.rc-flow-child-list{
  margin-top:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.rc-flow-child-card{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 14px;
  border:1px solid #e7edf6;
  border-radius:12px;
  background:#fff;
}

.rc-flow-child-card strong{
  display:block;
  font-size:.9rem;
}

.rc-flow-child-card span{
  font-size:.75rem;
  color:#7b879e;
}

/* ==========================
   LEGEND
========================== */

.rc-flow-legend{
  margin-top:35px;
  display:flex;
  gap:20px;
  justify-content:center;
  flex-wrap:wrap;
  padding:14px;
  background:#fff;
  border:1px solid #e8edf5;
  border-radius:14px;
}

.rc-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  display:inline-block;
  margin-right:6px;
}

.rc-dot.blue{background:#2563eb;}
.rc-dot.purple{background:#7c3aed;}
.rc-dot.teal{background:#14b8a6;}
.rc-dot.orange{background:#f59e0b;}
.rc-dot.red{background:#dc2626;}

/* ==========================
   OFFCANVAS
========================== */

.rc-flow-details-canvas{
  width:420px !important;
}

.rc-flow-detail-icon{
  width:58px;
  height:58px;
  border-radius:16px;
  background:#eef4ff;
  color:#2563eb;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
}

.rc-flow-detail-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  border:1px solid #e6ebf4;
  border-radius:14px;
  overflow:hidden;
}

.rc-flow-detail-grid > div{
  padding:16px;
  text-align:center;
  border-right:1px solid #e6ebf4;
  border-bottom:1px solid #e6ebf4;
}

.rc-flow-detail-grid strong{
  display:block;
  font-size:1.5rem;
}

.rc-flow-detail-grid span{
  color:#7a88a6;
  font-size:.85rem;
}

/* ==========================
   RESPONSIVE
========================== */

@media(max-width:1400px){

  .rc-flow-layout-clean{
    grid-template-columns:280px 1fr;
  }

  .rc-flow-branch{
    width:300px;
  }

}

@media(max-width:1200px){

  .rc-flow-layout-clean{
    grid-template-columns:1fr;
  }

  .rc-flow-sidebar{
    position:relative;
    top:auto;
  }

}

/* ============================================================
   Knowledge Source Create / Edit
   ============================================================ */

.rc-knowledge-main-card {
  padding: 0;
  overflow: hidden;
}

.rc-knowledge-step,
.rc-knowledge-section {
  padding: 24px;
  border-bottom: 1px solid var(--oc-line);
}

.rc-knowledge-step:last-child,
.rc-knowledge-section:last-child {
  border-bottom: 0;
}

.rc-knowledge-step-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 22px;
}

.rc-step-badge {
  width: 31px;
  height: 31px;
  border-radius: 50%;
  background: var(--oc-blue3);
  color: var(--oc-blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  flex-shrink: 0;
}

.rc-step-badge.purple {
  background: var(--oc-pur3);
  color: var(--oc-pur);
}

.rc-step-badge.green {
  background: var(--oc-grn3);
  color: var(--oc-grn);
}

/* Source type cards */
.rc-source-type-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.rc-source-type-card {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  border-radius: var(--oc-r);
  padding: 26px 18px;
  text-align: center;
  cursor: pointer;
  transition: .15s ease;
  min-height: 190px;
  color: var(--oc-txt2);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.rc-source-type-card:hover,
.rc-source-type-card.selected {
  border-color: var(--oc-blue);
  background: var(--oc-blue3);
  color: var(--oc-blue);
  box-shadow: inset 0 0 0 1px var(--oc-blue);
}

.rc-source-type-icon {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 25px;
  margin-bottom: 18px;
}

.rc-source-type-icon.blue {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}

.rc-source-type-icon.purple {
  background: var(--oc-pur3);
  color: var(--oc-pur);
}

.rc-source-type-icon.green {
  background: var(--oc-grn3);
  color: var(--oc-grn);
}

.rc-source-type-card strong {
  display: block;
  color: var(--oc-txt);
  font-size: 15px;
  margin-bottom: 8px;
}

.rc-source-type-card small {
  display: block;
  color: var(--oc-txt3);
  font-size: 12px;
  max-width: 150px;
}

/* Collapsible header */
.rc-knowledge-toggle-head {
  cursor: pointer;
  margin-bottom: 0;
}

.rc-knowledge-toggle-head + .rc-knowledge-collapsible {
  margin-top: 20px;
}

.rc-toggle-icon {
  color: var(--oc-blue);
  transition: .15s ease;
}

.rc-knowledge-toggle-head.is-collapsed .rc-toggle-icon {
  transform: rotate(-90deg);
}

/* FAQ / URL real table */
.rc-source-list-table {
  width: 100%;
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  overflow: hidden;
  background: var(--oc-bg2);
}

.rc-source-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  margin: 0;
}

.rc-source-table thead th {
  background: var(--oc-bg3);
  color: var(--oc-txt3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
  padding: 13px 16px;
  border-bottom: 1px solid var(--oc-line);
}

.rc-source-table tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--oc-line);
  vertical-align: middle;
}

.rc-source-table tbody tr:last-child td {
  border-bottom: 0;
}

.rc-source-table th:nth-child(1),
.rc-source-table td:nth-child(1) {
  width: 45%;
}

.rc-source-table th:nth-child(2),
.rc-source-table td:nth-child(2) {
  width: 45%;
}

.rc-source-table th:nth-child(3),
.rc-source-table td:nth-child(3) {
  width: 90px;
}

.rc-source-table textarea,
.rc-source-table input {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.rc-source-table textarea {
  min-height: 76px;
  resize: vertical;
}

.rc-source-table .btn-icon {
  width: 40px;
  height: 40px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Upload area */
.rc-upload-zone {
  border: 1px dashed var(--oc-line2);
  border-radius: var(--oc-r);
  padding: 36px 22px;
  text-align: center;
  background: var(--oc-bg3);
  cursor: pointer;
  transition: .15s ease;
}

.rc-upload-zone:hover,
.rc-upload-zone.active {
  border-color: var(--oc-blue);
  background: var(--oc-blue3);
}

.rc-upload-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: var(--oc-bg2);
  color: var(--oc-blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 27px;
  margin-bottom: 12px;
  box-shadow: 0 1px 3px var(--oc-shadow);
}

.rc-file-list {
  display: grid;
  gap: 8px;
}

.rc-file-item {
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  background: var(--oc-bg2);
  padding: 10px 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.rc-existing-documents {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg3);
  border-radius: var(--oc-r);
  padding: 16px;
}

.rc-existing-documents .rc-file-item {
  background: var(--oc-bg2);
}

/* Summary */
.rc-knowledge-summary {
  display: grid;
  gap: 18px;
}

.rc-knowledge-summary > div {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.rc-knowledge-summary strong {
  display: block;
  color: var(--oc-txt);
  font-size: 13px;
  margin-bottom: 2px;
}

.rc-knowledge-summary p {
  margin: 0;
  color: var(--oc-txt3);
  font-size: 12px;
}

/* Footer spacing safety */
.rc-page {
  padding-bottom: 28px;
}

/* Responsive */
@media (max-width: 992px) {
  .rc-source-type-grid {
    grid-template-columns: 1fr;
  }

  .rc-source-type-card {
    min-height: 140px;
  }
}

@media (max-width: 768px) {
  .rc-knowledge-step,
  .rc-knowledge-section {
    padding: 18px;
  }

  .rc-source-table,
  .rc-source-table thead,
  .rc-source-table tbody,
  .rc-source-table tr,
  .rc-source-table th,
  .rc-source-table td {
    display: block;
    width: 100%;
  }

  .rc-source-table thead {
    display: none;
  }

  .rc-source-table tbody tr {
    border-bottom: 1px solid var(--oc-line);
    padding: 10px 0;
  }

  .rc-source-table tbody tr:last-child {
    border-bottom: 0;
  }

  .rc-source-table tbody td {
    border-bottom: 0;
    padding: 8px 12px;
  }

  .rc-source-table tbody td:last-child {
    text-align: right;
  }
}

/* ============================================================
   AI Assistant Form
   ============================================================ */

#ai-assistant-form {
  position: relative;
  padding-bottom: 48px;
}

#ai-assistant-form .rc-card {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 24px;
  box-shadow: 0 8px 24px -18px var(--oc-shadow);
  overflow: hidden;
}

#ai-assistant-form .rc-card.mb-3 {
  margin-bottom: 16px !important;
}

#ai-assistant-form .form-label {
  color: var(--oc-txt);
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 8px;
}

#ai-assistant-form .form-control,
#ai-assistant-form .form-select {
  width: 100%;
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  color: var(--oc-txt);
  border-radius: var(--oc-r2);
  min-height: 44px;
}

#ai-assistant-form textarea.form-control {
  min-height: 110px;
  resize: vertical;
}

#ai-assistant-form .form-control:focus,
#ai-assistant-form .form-select:focus {
  border-color: var(--oc-blue);
  box-shadow: 0 0 0 3px var(--oc-blue3);
}

/* evita que el footer del layout se monte */
.rc-page {
  position: relative;
  padding-bottom: 80px;
}

.content-wrapper,
.content-body,
.container-xxl {
  overflow: visible;
}

/* Check cards */
.rc-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.rc-check-card {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  border-radius: var(--oc-r2);
  padding: 13px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  min-height: 50px;
}

.rc-check-card:hover {
  border-color: var(--oc-blue);
  background: var(--oc-blue3);
}

.rc-check-card span {
  color: var(--oc-txt);
  font-size: 13px;
  font-weight: 600;
}

.rc-check-card .form-check-input {
  margin: 0;
}

/* Right column */
.rc-side-stack {
  display: grid;
  gap: 16px;
}

.rc-switch-list {
  display: grid;
  gap: 14px;
}

.rc-switch-item {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  border-radius: var(--oc-r2);
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
}

.rc-switch-item strong {
  display: block;
  color: var(--oc-txt);
  font-size: 13px;
  margin-bottom: 4px;
}

.rc-switch-item span {
  display: block;
  color: var(--oc-txt3);
  font-size: 12px;
  line-height: 1.35;
}

.rc-check-list {
  display: grid;
  gap: 10px;
}

.rc-check-line {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  border-radius: var(--oc-r2);
  padding: 12px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Detail list */
.rc-detail-list {
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  overflow: hidden;
}

.rc-detail-list > div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 14px;
  border-bottom: 1px solid var(--oc-line);
}

.rc-detail-list > div:last-child {
  border-bottom: 0;
}

.rc-detail-list span {
  color: var(--oc-txt3);
  font-size: 12px;
}

.rc-detail-list strong {
  color: var(--oc-txt);
  font-size: 13px;
}

/* Actions */
.rc-form-actions-card {
  padding: 0 !important;
}

.rc-form-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  padding: 22px;
}

@media (max-width: 768px) {
  .rc-check-grid {
    grid-template-columns: 1fr;
  }

  .rc-form-actions {
    flex-direction: column-reverse;
  }

  .rc-form-actions .btn {
    width: 100%;
  }
}

/* ============================================================
   Emoji Picker
   ============================================================ */

.oc-emoji-wrapper {
  position: relative;
  width: 100%;
}

.oc-emoji-wrapper .oc-emoji-enabled {
  padding-right: 48px;
}

.oc-emoji-trigger {
  position: absolute;
  right: 12px;
  top: auto !important;
  bottom: 12px !important;

  width: 30px;
  height: 30px;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;

  padding: 0;
  cursor: pointer;
  z-index: 2;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  font-size: 20px;
  line-height: 1;
}

.oc-emoji-trigger:hover {
  background: var(--oc-blue3);
  border-color: var(--oc-blue2);
}

.oc-emoji-picker {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  width: 320px;
  max-height: 360px;
  overflow-y: auto;
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  box-shadow: 0 12px 32px var(--oc-shadow);
  padding: 12px;
  z-index: 9999;
}

.oc-emoji-picker.is-open {
  display: block;
}

.oc-emoji-category {
  font-size: 11px;
  font-weight: 700;
  color: var(--oc-txt3);
  text-transform: uppercase;
  margin: 10px 0 8px;
}

.oc-emoji-group {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 6px;
}

.oc-emoji-btn {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  font-size: 20px;
  cursor: pointer;
}

.oc-emoji-btn:hover {
  background: var(--oc-blue3);
}

.oc-emoji-trigger:hover,
.oc-emoji-trigger:focus,
.oc-emoji-trigger:active {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

/* ============================================================
   ChatBot Flow Edit / Create Modern Layout
   ============================================================ */

.chatbot-flow-page {
  padding-bottom: 88px;
}

.chatbot-flow-form {
  position: relative;
}

.chatbot-flow-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 16px;
  align-items: start;
}

.chatbot-flow-main,
.chatbot-flow-side {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.chatbot-flow-side {
  position: sticky;
  top: 88px;
}

.chatbot-flow-card {
  padding: 22px;
}

.chatbot-section-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 20px;
}

.chatbot-section-head h5 {
  margin: 0 0 4px;
  color: var(--oc-txt);
  font-size: 16px;
  font-weight: 800;
}

.chatbot-section-head p {
  margin: 0;
  color: var(--oc-txt3);
  font-size: 12.5px;
}

.chatbot-section-head-between {
  justify-content: space-between;
}

.chatbot-options-list {
  display: grid;
  gap: 14px;
  overflow: visible !important;
  max-height: none !important;
}

.chatbot-options-list .option_block {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 18px;
  box-shadow: 0 4px 18px -14px var(--oc-shadow);
}

.chatbot-options-list .option_block + .option_block {
  margin-top: 0 !important;
}

.chatbot-fallback-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.oc-form-actionbar {
  position: sticky;
  bottom: 0;
  z-index: 50;
  margin-top: 18px;
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  box-shadow: 0 -8px 24px -18px var(--oc-shadow), 0 8px 24px -16px var(--oc-shadow);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.oc-form-actionbar  strong {
  display: block;
  color: var(--oc-txt);
  font-size: 13px;
  margin-bottom: 2px;
}

.oc-form-actionbar span {
  display: block;
  color: var(--oc-txt3);
  font-size: 12px;
}

.oc-form-actionbar-buttons {
  display: flex;
  align-items: center;
  gap: 10px;
}

.oc-form-actionbar .btn {
  min-width: 120px;
}

@media (max-width: 1400px) {
  .chatbot-flow-grid {
    grid-template-columns: minmax(0, 1fr) 340px;
  }
}

@media (max-width: 1200px) {
  .chatbot-flow-grid {
    grid-template-columns: 1fr;
  }

  .chatbot-flow-side {
    position: static;
  }
}

@media (max-width: 768px) {
  .chatbot-flow-card {
    padding: 18px;
  }

  .chatbot-section-head,
  .chatbot-section-head-between {
    flex-direction: column;
  }

  .chatbot-form-actionbar {
    flex-direction: column;
    align-items: stretch;
  }

  .chatbot-form-actionbar-buttons {
    flex-direction: column-reverse;
    width: 100%;
  }

  .chatbot-form-actionbar .btn {
    width: 100%;
  }
}

/* ============================================================
   AI Assistant Form
   ============================================================ */

.ai-assistant-page {
  padding-bottom: 56px;
}

#ai-assistant-form {
  position: relative;
}

.ai-card {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 24px;
  box-shadow: 0 8px 24px -18px var(--oc-shadow);
  margin-bottom: 16px;
  overflow: hidden;
}

.ai-card:last-child {
  margin-bottom: 0;
}

.ai-card-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 22px;
}

.ai-card-head h5 {
  margin: 0 0 4px;
  color: var(--oc-txt);
  font-size: 16px;
  font-weight: 800;
}

.ai-card-head p,
.ai-muted {
  margin: 0;
  color: var(--oc-txt3);
  font-size: 13px;
}

.ai-card-icon {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 18px;
}

.ai-card-icon.blue {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}

.ai-card-icon.green {
  background: var(--oc-grn3);
  color: var(--oc-grn);
}

.ai-card-icon.purple {
  background: var(--oc-pur3);
  color: var(--oc-pur);
}

#ai-assistant-form .form-label {
  color: var(--oc-txt);
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 8px;
}

#ai-assistant-form .form-control,
#ai-assistant-form .form-select {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  color: var(--oc-txt);
  border-radius: var(--oc-r2);
  font-size: 14px;
}

#ai-assistant-form textarea.form-control {
  resize: vertical;
  min-height: 110px;
}

#ai-assistant-form .form-control:focus,
#ai-assistant-form .form-select:focus {
  border-color: var(--oc-blue);
  box-shadow: 0 0 0 3px var(--oc-blue3);
}

.ai-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.ai-check-card {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  border-radius: var(--oc-r2);
  padding: 13px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 50px;
  cursor: pointer;
  transition: .15s ease;
}

.ai-check-card:hover {
  border-color: var(--oc-blue);
  background: var(--oc-blue3);
}

.ai-check-card .form-check-input {
  margin: 0;
  flex-shrink: 0;
}

.ai-check-card span {
  color: var(--oc-txt);
  font-size: 13px;
  font-weight: 600;
}

.ai-side-stack {
  display: grid;
  gap: 16px;
}

.ai-switch-list {
  display: grid;
  gap: 14px;
}

.ai-switch-item {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  border-radius: var(--oc-r2);
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  transition: .15s ease;
}

.ai-switch-item:hover {
  border-color: var(--oc-blue);
  background: var(--oc-blue3);
}

.ai-switch-item strong {
  display: block;
  color: var(--oc-txt);
  font-size: 13px;
  margin-bottom: 4px;
}

.ai-switch-item span {
  display: block;
  color: var(--oc-txt3);
  font-size: 12px;
  line-height: 1.35;
}

.ai-check-list {
  display: grid;
  gap: 10px;
}

.ai-check-line {
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  border-radius: var(--oc-r2);
  padding: 12px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  transition: .15s ease;
}

.ai-check-line:hover {
  border-color: var(--oc-blue);
  background: var(--oc-blue3);
}

.ai-check-line span {
  color: var(--oc-txt);
  font-size: 13px;
  font-weight: 600;
}

.ai-detail-list {
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  overflow: hidden;
}

.ai-detail-list > div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 14px;
  border-bottom: 1px solid var(--oc-line);
}

.ai-detail-list > div:last-child {
  border-bottom: 0;
}

.ai-detail-list span {
  color: var(--oc-txt3);
  font-size: 12px;
}

.ai-detail-list strong {
  color: var(--oc-txt);
  font-size: 13px;
  text-align: right;
}

.ai-form-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-top: 8px;
  padding: 24px 0 10px;
  clear: both;
}

@media (max-width: 768px) {
  .ai-card {
    padding: 18px;
  }

  .ai-check-grid {
    grid-template-columns: 1fr;
  }

  .ai-switch-item {
    align-items: flex-start;
  }

  .ai-form-actions {
    flex-direction: column-reverse;
  }

  .ai-form-actions .btn {
    width: 100%;
  }
}

.ai-guidance-card {
  background: linear-gradient(180deg, var(--oc-bg2) 0%, var(--oc-blue3) 100%);
}

.ai-guidance-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.ai-guidance-item {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 12px;
  align-items: flex-start;
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  padding: 14px;
}

.ai-guidance-icon {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
}

.ai-guidance-icon.green {
  background: var(--oc-grn3);
  color: var(--oc-grn);
}

.ai-guidance-icon.blue {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}

.ai-guidance-icon.orange {
  background: var(--oc-amb3);
  color: var(--oc-amb);
}

.ai-guidance-icon.purple {
  background: var(--oc-pur3);
  color: var(--oc-pur);
}

.ai-guidance-item strong {
  display: block;
  color: var(--oc-txt);
  font-size: 13px;
  margin-bottom: 3px;
}

.ai-guidance-item p {
  margin: 0;
  color: var(--oc-txt3);
  font-size: 12px;
  line-height: 1.35;
}

@media (max-width: 768px) {
  .ai-guidance-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   Employee Profile / Edit
   ============================================================ */

.employee-page {
  padding-bottom: 56px;
}

.employee-side-stack {
  display: grid;
  gap: 16px;
}

.employee-card {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 24px;
  box-shadow: 0 8px 24px -18px var(--oc-shadow);
  overflow: hidden;
}

.employee-card-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 22px;
}

.employee-card-head h5 {
  margin: 0 0 4px;
  color: var(--oc-txt);
  font-size: 16px;
  font-weight: 800;
}

.employee-card-head p,
.employee-muted {
  margin: 0;
  color: var(--oc-txt3);
  font-size: 13px;
}

.employee-icon {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 18px;
}

.employee-icon.blue {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}

.employee-icon.green {
  background: var(--oc-grn3);
  color: var(--oc-grn);
}

.employee-icon.purple {
  background: var(--oc-pur3);
  color: var(--oc-pur);
}

.employee-icon.orange {
  background: var(--oc-amb3);
  color: var(--oc-amb);
}

/* Profile card */
.employee-profile-card {
  text-align: center;
}

.employee-avatar-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 14px;
}

.employee-avatar {
  width: 112px;
  height: 112px;
  border-radius: 24px;
  object-fit: cover;
  border: 4px solid var(--oc-bg2);
  box-shadow: 0 10px 22px -14px var(--oc-shadow);
}

.employee-name {
  margin: 0;
  color: var(--oc-txt);
  font-size: 18px;
  font-weight: 800;
}

.employee-meta {
  color: var(--oc-txt3);
  font-size: 13px;
  margin-top: 4px;
}

.employee-profile-list {
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  overflow: hidden;
  text-align: left;
}

.employee-profile-list > div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 14px;
  border-bottom: 1px solid var(--oc-line);
}

.employee-profile-list > div:last-child {
  border-bottom: 0;
}

.employee-profile-list span {
  color: var(--oc-txt3);
  font-size: 12px;
}

.employee-profile-list strong {
  color: var(--oc-txt);
  font-size: 13px;
  text-align: right;
}

/* Forms */
.employee-page .form-label {
  color: var(--oc-txt);
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 8px;
}

.employee-page .form-control,
.employee-page .form-select {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  color: var(--oc-txt);
  border-radius: var(--oc-r2);
  font-size: 14px;
}

.employee-page .form-control:focus,
.employee-page .form-select:focus {
  border-color: var(--oc-blue);
  box-shadow: 0 0 0 3px var(--oc-blue3);
}

/* Security */
.employee-security-status {
  border-radius: var(--oc-r2);
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 800;
}

.employee-security-status.enabled {
  background: var(--oc-grn3);
  color: var(--oc-grn);
}

.employee-security-status.disabled {
  background: var(--oc-red3);
  color: var(--oc-red);
}

/* Detail list */
.employee-detail-list {
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  overflow: hidden;
}

.employee-detail-list > div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 14px;
  border-bottom: 1px solid var(--oc-line);
}

.employee-detail-list > div:last-child {
  border-bottom: 0;
}

.employee-detail-list span {
  color: var(--oc-txt3);
  font-size: 12px;
}

.employee-detail-list strong {
  color: var(--oc-txt);
  font-size: 13px;
  text-align: right;
}

/* Actions */
.employee-form-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-top: 8px;
  padding: 24px 0 10px;
}

/* Modal */
.employee-page-modal .modal-content,
.modal-content {
  border-radius: var(--oc-r);
}

/* Responsive */
@media (max-width: 768px) {
  .employee-card {
    padding: 18px;
  }

  .employee-profile-list > div,
  .employee-detail-list > div {
    flex-direction: column;
    gap: 4px;
  }

  .employee-profile-list strong,
  .employee-detail-list strong {
    text-align: left;
  }

  .employee-form-actions {
    flex-direction: column-reverse;
  }

  .employee-form-actions .btn {
    width: 100%;
  }
/* ============================================================
   Employee Profile / Edit
   ============================================================ */

.employee-page {
  padding-bottom: 56px;
}

.employee-side-stack {
  display: grid;
  gap: 16px;
}

.employee-card {
  background: var(--oc-bg2);
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r);
  padding: 24px;
  box-shadow: 0 8px 24px -18px var(--oc-shadow);
  overflow: hidden;
}

.employee-card-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 22px;
}

.employee-card-head h5 {
  margin: 0 0 4px;
  color: var(--oc-txt);
  font-size: 16px;
  font-weight: 800;
}

.employee-card-head p,
.employee-muted {
  margin: 0;
  color: var(--oc-txt3);
  font-size: 13px;
}

.employee-icon {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 18px;
}

.employee-icon.blue {
  background: var(--oc-blue3);
  color: var(--oc-blue);
}

.employee-icon.green {
  background: var(--oc-grn3);
  color: var(--oc-grn);
}

.employee-icon.purple {
  background: var(--oc-pur3);
  color: var(--oc-pur);
}

.employee-icon.orange {
  background: var(--oc-amb3);
  color: var(--oc-amb);
}

/* Profile card */
.employee-profile-card {
  text-align: center;
}

.employee-avatar-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 14px;
}

.employee-avatar {
  width: 112px;
  height: 112px;
  border-radius: 24px;
  object-fit: cover;
  border: 4px solid var(--oc-bg2);
  box-shadow: 0 10px 22px -14px var(--oc-shadow);
}

.employee-name {
  margin: 0;
  color: var(--oc-txt);
  font-size: 18px;
  font-weight: 800;
}

.employee-meta {
  color: var(--oc-txt3);
  font-size: 13px;
  margin-top: 4px;
}

.employee-profile-list {
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  overflow: hidden;
  text-align: left;
}

.employee-profile-list > div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 14px;
  border-bottom: 1px solid var(--oc-line);
}

.employee-profile-list > div:last-child {
  border-bottom: 0;
}

.employee-profile-list span {
  color: var(--oc-txt3);
  font-size: 12px;
}

.employee-profile-list strong {
  color: var(--oc-txt);
  font-size: 13px;
  text-align: right;
}

/* Forms */
.employee-page .form-label {
  color: var(--oc-txt);
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 8px;
}

.employee-page .form-control,
.employee-page .form-select {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--oc-line);
  background: var(--oc-bg2);
  color: var(--oc-txt);
  border-radius: var(--oc-r2);
  font-size: 14px;
}

.employee-page .form-control:focus,
.employee-page .form-select:focus {
  border-color: var(--oc-blue);
  box-shadow: 0 0 0 3px var(--oc-blue3);
}

/* Security */
.employee-security-status {
  border-radius: var(--oc-r2);
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 800;
}

.employee-security-status.enabled {
  background: var(--oc-grn3);
  color: var(--oc-grn);
}

.employee-security-status.disabled {
  background: var(--oc-red3);
  color: var(--oc-red);
}

/* Detail list */
.employee-detail-list {
  border: 1px solid var(--oc-line);
  border-radius: var(--oc-r2);
  overflow: hidden;
}

.employee-detail-list > div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 14px;
  border-bottom: 1px solid var(--oc-line);
}

.employee-detail-list > div:last-child {
  border-bottom: 0;
}

.employee-detail-list span {
  color: var(--oc-txt3);
  font-size: 12px;
}

.employee-detail-list strong {
  color: var(--oc-txt);
  font-size: 13px;
  text-align: right;
}

/* Actions */
.employee-form-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-top: 8px;
  padding: 24px 0 10px;
}

/* Modal */
.employee-page-modal .modal-content,
.modal-content {
  border-radius: var(--oc-r);
}

/* Responsive */
@media (max-width: 768px) {
  .employee-card {
    padding: 18px;
  }

  .employee-profile-list > div,
  .employee-detail-list > div {
    flex-direction: column;
    gap: 4px;
  }

  .employee-profile-list strong,
  .employee-detail-list strong {
    text-align: left;
  }

  .employee-form-actions {
    flex-direction: column-reverse;
  }

  .employee-form-actions .btn {
    width: 100%;
  }
}