/* Agend One – app.css

Fondo de login igual al dashboard (usa --bg)

Transición de ruta: salida izquierda (login) y entrada derecha (dashboard) con llegada descompasada

Estilos de la intro (#entryIntro) trasladados desde el JS

Respeta prefers-reduced-motion
*/

:root {
  /* Pilas de fuentes */
  --font-sans:
    Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, sans-serif;
  --font-serif: ui-serif, Georgia, "Times New Roman", Times, serif;

  /* Fuente base de la UI (cámbiala a serif/sans según quieras) */
  --font-ui: var(--font-serif);
  /* global en serif */
  /* Si quieres volver a sans global: 
      --font-ui: var(--font-sans);
   */

  /* Mover “Agend One” (sidebar expandida) */
  --sb-brand-full-nudge-x: -6px;
  /* + derecha | - izquierda */
  --sb-brand-full-nudge-y: 4px;
  /* + abajo   | - arriba   */
}

:root {
  /* Radios globales */
  --rad-xs: 6px;
  --rad-sm: 10px;
  --rad-md: 14px;
  --rad-lg: 18px;

  /* === PRESET DE TEMA (EDITA SOLO ESTAS 5 PARA CAMBIAR EL LOOK) === */

  /* Preset (claro) */
  --theme-bg: #ffffff;
  --theme-card: #ffffff;
  --theme-ink: #111827;
  --theme-border: #d2d2d7;

  /* ===== Marca (nuevo) =====
   Importante:
   - --theme-brand / --brand-1 deben ser COLOR (no gradiente) porque se usan en color/border/focus.
   - --brand-grad es el gradiente para fondos.
*/
  --theme-brand-start: #141c61;
  --theme-brand-mid: #285bb0;
  --theme-brand-end: #0eb2ed;

  /* “Sólido” pastel (por si lo necesitas explícito) */
  --theme-brand-solid: var(--theme-brand-start);

  /* Sólido de marca usable en borders/text/focus (un pelín más “serio” para contraste) */
  --theme-brand: color-mix(in oklab, var(--theme-brand-solid) 62%, #0b1220 38%);

  /* Gradiente de marca para fondos */
  --brand-grad: linear-gradient(
    135deg,
    var(--theme-brand-start) 0%,
    var(--theme-brand-mid) 50%,
    var(--theme-brand-end) 100%
  );

  /* Color de texto encima de superficies con gradiente (modo claro) */
  --on-brand: #ffffff;

  /* Derivados que usa el resto de la app */
  --bg: var(--theme-bg);
  --card: var(--theme-card);
  --ink: var(--theme-ink);
  --border: var(--theme-border);
  --brand-1: var(--theme-brand);
  --bs-primary: var(--brand-1);

  /* Colores de sidebar + tonos “muted” en modo claro */
  --muted: #4b5563;

  /* Halo de foco accesible */
  --focus: 0 0 0 0.12rem
    color-mix(in srgb, var(--brand-1, #0d6efd) 35%, transparent 65%);
}

:root {
  /* Duración global para las animaciones de labels flotantes */
  --float-label-ms: 0.35s;

  --flip-ms: 1350ms;
  --flip-ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --toggle-ms: 750ms;

  /* Colores card + inputs (modo claro):
            - bordes azules como el título
            - fondo igual al de la card */
  --auth-card-bg-top: color-mix(in srgb, var(--bg, #f9fafb) 88%, #000 12%);
  --auth-card-bg-bottom: color-mix(in srgb, var(--bg, #f9fafb) 96%, #000 4%);
  --light-inp-bg: #ffffff;
  --light-inp-bg-hover: #ffffff;
  --light-inp-ink: #0f172a;
  --light-inp-bd: var(--brand-1, #4f46e5);
  --light-inp-bd-hover: color-mix(
    in srgb,
    var(--brand-1, #4f46e5) 85%,
    #000 15%
  );
  --light-ph: #5b6b82;

  --pw-pop-ms: 380ms;
  --pw-pop-ease: cubic-bezier(0.2, 0.8, 0.2, 1);
  --login-btn-ms: 680ms;
  --login-btn-ease: cubic-bezier(0.22, 0.61, 0.36, 1);

  /* Offsets ajustables del hero */
  --hero-top-x: 30px;
  --hero-top-y: -20px;
  --hero-list-x: 30px;
  --hero-list-y: 0px;

  /* Espacio horizontal del label flotante (a ambos lados del texto) */
  --float-label-pad-x: 0.35rem;

  /* ERROR */
  --ao-alert-danger-bg: #fee2e2;
  /* fondo */
  --ao-alert-danger-border: #ef4444;
  /* borde */
  --ao-alert-danger-text: #7f1d1d;
  /* texto */

  /* WARNING */
  --ao-alert-warning-bg: #fef3c7;
  --ao-alert-warning-border: #f59e0b;
  --ao-alert-warning-text: #78350f;

  /* SUCCESS */
  --ao-alert-success-bg: #dcfce7;
  --ao-alert-success-border: #22c55e;
  --ao-alert-success-text: #14532d;

  --ao-top-modal-z: 3200;
  /* por encima de popovers/menus (y de la vida misma) */
}

/* Defaults altos para modales (Bootstrap 5.3 usa vars internas) */
.modal {
  --bs-modal-zindex: var(--ao-top-modal-z, 3200);
  z-index: var(--bs-modal-zindex, var(--ao-top-modal-z, 3200));
}

.modal-backdrop {
  --bs-backdrop-zindex: calc(var(--ao-top-modal-z, 3200) - 10);
  z-index: var(--bs-backdrop-zindex, calc(var(--ao-top-modal-z, 3200) - 10));
}

/* === Fondo autenticación igual al dashboard === */
body.auth-page {
  background-color: var(--bg) !important;

  /* fija los 3 stops del gradiente */
  --brand-2: var(--theme-brand-start) !important;
  --brand-1: var(--theme-brand-solid) !important;
  --brand-4: var(--theme-brand-end) !important;
  --brand-3: var(--theme-brand-start) !important;

  /* gradiente real */
  --brand-grad: linear-gradient(
    135deg,
    var(--theme-brand-start) 0%,
    var(--theme-brand-mid) 50%,
    var(--theme-brand-end) 100%
  ) !important;

  /* bootstrap primary coherente (bordes/focus) */
  --bs-primary: var(--brand-1) !important;
}

/* === Intro “signup” (#entryIntro) — consolidado (SIN duplicados) === */
#entryIntro {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

#entryIntro.is-open {
  opacity: 1;
  pointer-events: auto;
}

/* Fondo con máscara vertical: revela de abajo→arriba */
#entryIntro .bg {
  position: absolute;
  inset: 0;
  -webkit-mask-image: linear-gradient(
    to top,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 1) 18%,
    rgba(0, 0, 0, 1) 100%
  );
  mask-image: linear-gradient(
    to top,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 1) 18%,
    rgba(0, 0, 0, 1) 100%
  );
  -webkit-mask-size: 100% 300%;
  mask-size: 100% 300%;
  -webkit-mask-position: 0% 200%;
  mask-position: 0% 200%;
  will-change: -webkit-mask-position, mask-position, opacity;
}

#entryIntro .stage {
  position: relative;
  width: min(92vw, 1100px);
  height: min(64vh, 600px);
  display: grid;
  place-items: center;
  perspective: 1100px;
}

/* Grupo completo (bola + texto + eslogan) — centrado real */
#entryIntro .group {
  position: relative;
  display: grid;
  justify-items: center;
  align-items: center;
  gap: clamp(14px, 2.6vh, 24px);
  text-align: center;
  will-change: transform, opacity;
  transform: translateY(0) scale(1);
}

/* Bola arriba + texto debajo, centrado */
#entryIntro .brandRow {
  display: grid;
  justify-items: center;
  align-items: center;
  gap: clamp(8px, 2vh, 16px);
  width: auto;
}

/* Marco circular */
#entryIntro .symbolWrap {
  width: min(40vw, 210px);
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 50%;
  clip-path: circle(50% at 50% 50%);
  isolation: isolate;
}

#entryIntro .symbol {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  backface-visibility: hidden;
}

/* Texto grande centrado bajo la bola */
#entryIntro .wordmark {
  font-family: Garamond, "Times New Roman", Times, serif;
  font-weight: 600;
  letter-spacing: 0.02em;
  font-size: clamp(52px, 11vw, 110px);
  color: var(--brand-1);
  opacity: 0;
  transform: translateY(8px);
  display: block;
  text-align: center;
}

@supports (-webkit-background-clip: text) or (background-clip: text) {
  #entryIntro .wordmark {
    background: var(--brand-grad);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }
}

/* Eslogan */
#entryIntro .slogan {
  font-family:
    Inter,
    system-ui,
    -apple-system,
    "Segoe UI",
    Roboto,
    Arial,
    sans-serif;
  letter-spacing: 0.34em;
  font-size: clamp(16px, 4.2vw, 22px);
  color: #334155;
  opacity: 0;
  transform: translateY(6px);
  text-transform: uppercase;
  text-align: center;
  max-width: min(80vw, 900px);
  margin-top: clamp(6px, 1.6vh, 18px);
}

@media (prefers-color-scheme: dark) {
  #entryIntro .slogan {
    color: #d0d6de;
  }
}

/* Keyframes intro (UNA sola vez) */
@keyframes dropInGroup {
  from {
    opacity: 0;
    transform: translateY(-40px) scale(0.96);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Dos vueltas, linear (estaba en el bloque duplicado; se conserva aquí) */
@keyframes spinY2full {
  0% {
    transform: translateY(0) rotateY(0deg) scale(1);
  }

  100% {
    transform: translateY(0) rotateY(720deg) scale(1.02);
  }
}

/* === Accesibilidad: reduce motion (intro) === */
@media (prefers-reduced-motion: reduce) {
  #entryIntro .group,
  #entryIntro .wordmark,
  #entryIntro .slogan {
    animation: none !important;
    transform: none !important;
  }
}

/* Opcional: estilo del grupo teléfono si no existe en tu UI */
.phone-menu {
  background: var(--card);
  color: var(--ink);
  border: 1px solid var(--border);
  border-radius: 16px;
}

html,
body,
.content,
#pageRoot {
  max-width: 100%;
  overflow-x: hidden;
}

/* Indicador En vivo: visible por defecto */
.live-dot {
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 50%;
  background: #6c757d;
  display: inline-block;
  box-shadow: 0 0 0 0 rgba(25, 135, 84, 0.7);
  transition: background 0.2s;
}

.live-dot.ok {
  background: #198754;
  animation: pulse 1.4s infinite;
}

@media (prefers-reduced-motion: reduce) {
  .live-dot.ok {
    animation: none !important;
  }
}

@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(25, 135, 84, 0.6);
  }

  70% {
    box-shadow: 0 0 0 10px rgba(25, 135, 84, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(25, 135, 84, 0);
  }
}

/* Agenda */
#calendar,
#fc,
.agenda-calendar {
  min-height: 70vh;
}

/* En páginas de autenticación también debe poder hacerse scroll */
body.auth-page {
  overflow-y: auto !important;
}

/* El contenedor principal no debe cortar el contenido vertical */
#pageRoot,
.content,
main {
  min-height: 100vh;
  overflow-y: visible !important;
  /* nunca hidden aquí */
}

/* Nunca recortes menús dentro de tarjetas o formularios */
.card,
.card-body,
form {
  overflow: visible;
}

/* Popover siempre por encima */
#agenda-root .fc .fc-popover {
  z-index: 2100;
}

#agenda-root .fc .fc-popover .fc-popover-body {
  max-height: 320px;
  overflow: auto;
}

/* Por si algún contenedor intenta recortar el popover */
#agenda-root .fc .fc-daygrid-body {
  overflow: visible !important;
}

/* Popover “Más”: ocultar el día en el header, mantener el botón cerrar */
#agenda-root .fc .fc-popover .fc-popover-header .fc-popover-title {
  display: none !important;
}

#agenda-root .fc .fc-popover .fc-popover-header {
  justify-content: flex-end;
  /* alinea la X a la derecha */
  padding: 0.25rem 0.35rem;
  /* header compacto */
}

/* Popover “Más” con esquinas redondeadas */
#agenda-root .fc .fc-popover {
  border-radius: var(--cal-r, 12px);
  overflow: hidden;
  /* redondea header y body */
  border: 1px solid var(--border, #243047);
  background: var(--card, #0f172a);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35);
}

#agenda-root .fc .fc-popover .fc-popover-header {
  background: var(--card, #0f172a);
  border-bottom: 1px solid var(--border, #243047);
}

/* Eventos dentro del popover también redondeados */
#agenda-root .fc .fc-popover .fc-daygrid-event {
  border-radius: 8px;
}

#loginCard.tilt {
  transform: perspective(900px) rotateX(2.5deg) scale(0.996);
  transition: transform 0.18s ease;
}

.line-clamp-1 {
  display: -webkit-box;
  line-clamp: 1;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-width: 100%;
}

:where(
  html[data-bs-theme="dark"],
  body[data-bs-theme="dark"],
  .theme-dark,
  [data-theme="dark"]
) {
  --sc-track: #0b1620;
  --sc-thumb: #2b3947;
  --sc-thumb-h: #3b4c5e;

  /* Colores globales de alerts en modo oscuro */
  --ao-alert-danger-bg: rgba(248, 81, 73, 0.18);
  --ao-alert-danger-border: rgba(248, 81, 73, 0.55);
  --ao-alert-danger-text: #ffd1d1;

  --ao-alert-warning-bg: rgba(245, 188, 74, 0.18);
  --ao-alert-warning-border: rgba(245, 188, 74, 0.55);
  --ao-alert-warning-text: #ffe8a3;

  --ao-alert-success-bg: rgba(46, 160, 67, 0.18);
  --ao-alert-success-border: rgba(46, 160, 67, 0.65);
  --ao-alert-success-text: #b6f4c0;

  /* Marca en oscuro: oscurecemos el gradiente y ponemos texto blanco encima */
  --brand-grad: linear-gradient(
    135deg,
    color-mix(in oklab, var(--theme-brand-start), #000 55%) 0%,
    color-mix(in oklab, var(--theme-brand-mid), #000 55%) 50%,
    color-mix(in oklab, var(--theme-brand-end), #000 55%) 100%
  );
  --on-brand: #ffffff;
}

/* ==== Overrides globales de alerts Bootstrap ==== */

/* Estilo base de todas las alertas */
.alert {
  border-radius: 12px;
  padding: 0.75rem 1rem;
  font-weight: 500;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.14);
  border-width: 1px;
}

/* Error / peligro */
.alert-danger {
  background-color: var(--ao-alert-danger-bg, #f8d7da) !important;
  border-color: var(--ao-alert-danger-border, #f5c2c7) !important;
  color: var(--ao-alert-danger-text, #842029) !important;
}

/* Avisos tipo warning */
.alert-warning {
  background-color: var(--ao-alert-warning-bg, #fff3cd) !important;
  border-color: var(--ao-alert-warning-border, #ffecb5) !important;
  color: var(--ao-alert-warning-text, #664d03) !important;
}

/* Mensajes de éxito */
.alert-success {
  background-color: var(--ao-alert-success-bg, #d1e7dd) !important;
  border-color: var(--ao-alert-success-border, #badbcc) !important;
  color: var(--ao-alert-success-text, #0f5132) !important;
}

/* AO — alerta cerrable (reutilizable) */
.ao-alert {
  position: relative;
  padding-right: 2.6rem;
}

.ao-alert__close {
  position: absolute;
  top: 0.65rem;
  right: 0.75rem;
  opacity: 0.75;
}

.ao-alert__close:hover {
  opacity: 1;
}

/* === APPLE DARK (solo valores) === */
body.dark-mode {
  --bg: #000000;
  --ink: #f5f5f7;
  --muted: #a1a1a6;
  --card: #1c1c1e;
  --border: #2c2c2e;

  /* Sombras más finas pero muy contrastadas en oscuro, abajo/derecha */
  --sh-sm: 2px 3px 8px -4px rgba(0, 0, 0, 0.78);
  --sh-md: 4px 8px 20px -10px rgba(0, 0, 0, 0.92);
}

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-ui);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition:
    background 0.25s ease,
    color 0.25s ease;
  letter-spacing: 0.01em;
}

/* Card base casi plana */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--rad-lg);
  box-shadow: var(--sh-sm);
  /* sombra suave por defecto (o pon 'none' si la quieres totalmente plana) */
}

/* Cards elevadas: solo estas llevan la sombra grande */
.card.card-visual,
.card.shadow,
.card.shadow-sm {
  box-shadow: var(--sh-md) !important;
}

body.dark-mode .card {
  background-color: var(--card) !important;
  border-color: var(--border) !important;
  color: var(--ink) !important;
}

body.dark-mode
  .card
  :is(h1, h2, h3, h4, h5, h6, p, span, small, li, label, div) {
  color: var(--ink) !important;
}

body.dark-mode :is(.text-muted, .text-secondary, .form-text) {
  color: #a1a1a6 !important;
}

body.dark-mode .list-group-item {
  background-color: var(--card) !important;
  color: var(--ink) !important;
  border-color: var(--border) !important;
}

/* Transición login->dashboard — flip 3D (la de antes) */
[data-route-shell] {
  will-change: opacity;
  backface-visibility: hidden;
  transform-style: preserve-3d;
}

/* Solo durante la animación de rutas, permitimos transform */
[data-route-shell].rt-exit-left,
[data-route-shell].rt-enter-right {
  will-change: opacity, transform;
}

.rt-exit-left {
  animation: rtFlipOut 520ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}

.rt-enter-right {
  animation: rtFlipIn 620ms cubic-bezier(0.22, 0.61, 0.36, 1) both;
}

.rt-enter-right > * {
  animation: rtChild 0.7s cubic-bezier(0.16, 0.84, 0.44, 1) both;
}

.rt-enter-right > *:nth-child(1) {
  animation-delay: 40ms;
}

.rt-enter-right > *:nth-child(2) {
  animation-delay: 80ms;
}

.rt-enter-right > *:nth-child(3) {
  animation-delay: 120ms;
}

.rt-enter-right > *:nth-child(4) {
  animation-delay: 160ms;
}

.rt-enter-right > *:nth-child(5) {
  animation-delay: 200ms;
}

.rt-enter-right > *:nth-child(6) {
  animation-delay: 240ms;
}

.rt-enter-right > *:nth-child(7) {
  animation-delay: 280ms;
}

.rt-enter-right > *:nth-child(8) {
  animation-delay: 320ms;
}

@keyframes rtFlipOut {
  from {
    opacity: 1;
    transform: none;
    filter: none;
  }

  to {
    opacity: 0;
    transform: perspective(1100px) rotateY(-18deg) translateX(-64px) scale(0.98);
    filter: blur(1px);
  }
}

@keyframes rtFlipIn {
  from {
    opacity: 0;
    transform: perspective(1100px) rotateY(18deg) translateX(64px) scale(0.98);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

/* Stagger de hijos (queda igual) */
@keyframes rtChild {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

/* Respeto a reduced motion */
@media (prefers-reduced-motion: reduce) {
  .rt-exit-left,
  .rt-enter-right,
  .rt-enter-right > * {
    animation: none !important;
    transition: none !important;
  }
}

body.rt-animating {
  overflow-x: clip;
}

/* Animación mini-PJAX */
.slide-in {
  animation: slideIn 0.22s ease both;
}

.slide-out {
  animation: slideOut 0.18s ease both;
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes slideOut {
  from {
    opacity: 1;
    transform: none;
  }

  to {
    opacity: 0;
    transform: translateY(-8px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .slide-in,
  .slide-out {
    animation: none;
  }
}

/* =========================
   Topbar: reserva para FAB (Soporte)
   Evita que las tabs se metan debajo del botón flotante
   ========================= */
.ao-topbar-spacer {
  flex: 0 0 calc(var(--fab-btn, 3.5rem) + var(--fab-offset-right, 14px) + 10px);
  width: calc(var(--fab-btn, 3.5rem) + var(--fab-offset-right, 14px) + 10px);
  height: 1px;
  pointer-events: none;
}

/* =========================
   Perfil Topbar Tabs (ink)
   ========================= */
:root {
  --nav-inactive: var(--brand-1);
  --ink-ease: cubic-bezier(0.22, 0.9, 0.22, 1);
  --ink-ms: 360ms;
  --ink-radius: 0.375rem;
}

html[data-bs-theme="dark"] {
  /* versión más legible del brand en oscuro */
  --nav-inactive: color-mix(in srgb, var(--brand-1) 60%, #ffffff 40%);
}

#perfilTopNav[data-route-nav] {
  position: relative;
  isolation: isolate;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  overflow-y: hidden;
  min-width: 0;
  -webkit-overflow-scrolling: touch;
}

#perfilTopNav[data-route-nav] .btn {
  position: relative;
  z-index: 2;
  flex: 0 0 auto;
  white-space: nowrap;
}

/* Ink */
#perfilTopNav[data-route-nav] .nav-ink {
  position: absolute;
  left: 0;
  top: 0;
  height: 0;
  width: 0;
  background: var(--brand-grad);
  border-radius: var(--ink-radius);
  transform: translate3d(0, 0, 0);
  transition:
    transform var(--ink-ms) var(--ink-ease),
    width var(--ink-ms) var(--ink-ease);
  z-index: 1;
  will-change: transform, width;
  pointer-events: none;
}

#perfilTopNav:not(.ink-ready) .btn.btn-primary[aria-current="page"] {
  background: var(--brand-1) !important;
  border-color: var(--brand-1) !important;
  color: var(--on-brand) !important;
}

#perfilTopNav.ink-ready .btn.btn-primary[aria-current="page"] {
  background: transparent !important;
  border-color: transparent !important;
  color: var(--on-brand) !important;
}

/* Inactivos legibles */
#perfilTopNav .btn:not([aria-current="page"]),
#perfilTopNav .btn.btn-primary:not([aria-current="page"]) {
  background: transparent !important;
  color: var(--nav-inactive) !important;
  border-color: var(--nav-inactive) !important;
}

@media (prefers-reduced-motion: reduce) {
  #perfilTopNav[data-route-nav] .nav-ink {
    transition: none !important;
  }
}

/* Scroll horizontal SOLO móvil/tablet */
@media (max-width: 992px) {
  #perfilTopNav {
    touch-action: pan-x;
  }

  #perfilTopNav::-webkit-scrollbar {
    height: 6px;
  }
}

@media (max-width: 767.98px) {
  #perfilTopNav a.btn {
    padding: 0.5rem 0.55rem;
    line-height: 1;
  }

  #perfilTopNav .icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    width: 1.5rem;
  }
}

/* Runtime banner de horario (citas) */
#aoHorarioBanner.ao-alert {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

#aoHorarioBanner .ao-alert__msg {
  flex: 1;
}

#aoHorarioBanner .ao-alert__close {
  margin-left: auto;
}

/* =========================================================
   AO — Full-bleed util (global)
   ========================================================= */
.ao-fullbleed {
  --ao-bleed: 24px;
  margin-left: calc(-1 * var(--ao-bleed));
  margin-right: calc(-1 * var(--ao-bleed));
  padding-left: var(--ao-bleed);
  padding-right: var(--ao-bleed);
}

/* Compat temporal (para NO tocar templates hoy) */
.clientes-full {
  --ao-bleed: 24px;
  margin-left: calc(-1 * var(--ao-bleed));
  margin-right: calc(-1 * var(--ao-bleed));
  padding-left: var(--ao-bleed);
  padding-right: var(--ao-bleed);
}

/* =========================================================
   AO — Page wrap (utilidad global)
   ========================================================= */
.ao-wrap {
  max-width: var(--ao-wrap-w, 1100px);
  width: 100%;
}

/* Compat: Empresa (para no tocar templates aún) */
.empresa-page .empresa-wrap {
  max-width: var(--ao-wrap-w, 880px);
  width: 100%;
}

/* =========================================================
   AO — Toolbar base (global)
   Uso ideal: class="ao-toolbar"
   Compat temporal: .clientes-toolbar sin tocar HTML
   ========================================================= */
:where(
  .ao-toolbar,
  .clientes-toolbar,
  .productos-toolbar,
  .caja-toolbar,
  .empleados-toolbar,
  .categorias-toolbar,
  .servicios-toolbar,
  .bonos-toolbar,
  .usuarios-toolbar
) {
  --ao-toolbar-bg: var(--brand-1, #07689f);

  background: var(--ao-toolbar-bg);
  background-image: var(--brand-grad);

  color: var(--on-brand);
  border-radius: 1rem;
  padding: 0.75rem 1rem;
  box-shadow: var(--tbl-shadow, 0 18px 45px rgba(15, 23, 42, 0.16));
}

/* Dark mode: misma idea que tenías en Clientes, pero global */
body.dark-mode
  :where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  ) {
  background: color-mix(in oklab, var(--ao-toolbar-bg), #000000 35%);
}

:where(.ao-toolbar, .clientes-toolbar, .caja-toolbar) .btn-light {
  color: var(--ao-toolbar-bg);
}

/* =========================================================
   AO — Toolbar buttons: look “Agenda” (GLOBAL)
   Aplica a todas las *-toolbar sin tocar templates
   ========================================================= */
:where(
  .ao-toolbar,
  .clientes-toolbar,
  .productos-toolbar,
  .caja-toolbar,
  .empleados-toolbar,
  .categorias-toolbar,
  .servicios-toolbar,
  .bonos-toolbar,
  .usuarios-toolbar
) {
  --ao-toolbar-on: var(--on-brand, #ffffff);
  --ao-toolbar-pill-radius: var(--rad-sm, 10px);
  --ao-toolbar-grad: var(--brand-grad);
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )
  .btn:not(.btn-close) {
  border-radius: var(--ao-toolbar-pill-radius);
  font-weight: 600;
  padding-inline: 0.9rem;

  background-color: var(--ao-toolbar-bg, var(--brand-1, #0d6efd)) !important;
  background-image: var(--ao-toolbar-grad) !important;
  border-color: color-mix(
    in oklab,
    var(--ao-toolbar-bg, var(--brand-1, #0d6efd)) 85%,
    #000 15%
  ) !important;
  color: var(--ao-toolbar-on) !important;

  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.22);
  transition:
    box-shadow 0.16s ease,
    transform 0.08s ease,
    filter 0.16s ease;
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )
  .btn:not(.btn-close):hover,
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )
  .btn:not(.btn-close):focus-visible {
  filter: brightness(0.94) saturate(1.05);
  box-shadow:
    0 0 0 2px rgba(255, 255, 255, 0.22),
    0 8px 18px rgba(0, 0, 0, 0.4);
  transform: translateY(-1px);
}

@media (prefers-reduced-motion: reduce) {
  :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )
    .btn {
    transition: none !important;
  }
}

/* =========================================================
   AO — Actionbar (estilo Agenda) [GLOBAL]
   Uso:
     <div class="card ao-actionbar">
       <div class="card-body d-flex ...">...</div>
     </div>

   Tokens:
     --ao-actionbar-bg   (color sólido)
     --ao-actionbar-on   (texto sobre marca)
     --ao-actionbar-grad (gradiente o none)
     --ao-actionbar-pill-radius
   ========================================================= */

:where(.ao-actionbar) {
  --ao-actionbar-bg: var(--brand-1, var(--bs-primary, #0d6efd));
  --ao-actionbar-on: var(--on-brand, #ffffff);
  --ao-actionbar-grad: none;
  --ao-actionbar-pill-radius: var(--rad-sm, 10px);

  background-color: var(--ao-actionbar-bg) !important;
  background-image: var(--ao-actionbar-grad) !important;
  border-color: var(--ao-actionbar-bg) !important;

  color: var(--ao-actionbar-on) !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
}

/* Si el modo de marca es gradiente, lo activamos automáticamente */
:where(html[data-ao-brand-mode="gradient"], body.ao-brand-gradient)
  :where(.ao-actionbar) {
  --ao-actionbar-grad: var(--brand-grad);
}

:where(.ao-actionbar) .text-muted {
  color: color-mix(in srgb, var(--ao-actionbar-on) 72%, transparent) !important;
}

:where(.ao-actionbar) .card-body {
  padding-top: 0.45rem;
  padding-bottom: 0.45rem;
}

/* Botones dentro de la actionbar: TODOS con look “Agenda” */
:where(.ao-actionbar) .btn:not(.btn-close) {
  border-radius: var(--ao-actionbar-pill-radius);
  font-weight: 600;
  padding-inline: 0.9rem;

  background-color: var(--ao-actionbar-bg) !important;
  background-image: var(--ao-actionbar-grad) !important;
  border-color: color-mix(
    in oklab,
    var(--ao-actionbar-bg) 85%,
    #000 15%
  ) !important;
  color: var(--ao-actionbar-on) !important;

  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.22);
  transition:
    box-shadow 0.16s ease,
    transform 0.08s ease,
    filter 0.16s ease;
}

:where(.ao-actionbar) .btn:not(.btn-close):hover,
:where(.ao-actionbar) .btn:not(.btn-close):focus-visible {
  filter: brightness(0.94) saturate(1.05);
  box-shadow:
    0 0 0 2px rgba(255, 255, 255, 0.22),
    0 8px 18px rgba(0, 0, 0, 0.4);
  transform: translateY(-1px);
}

/* Dropdown “Más” legible sobre fondo claro */
:where(.ao-actionbar) .dropdown-menu {
  background-color: #ffffff;
  color: #111;
}

:where(.ao-actionbar) .dropdown-item {
  color: #111;
}

:where(.ao-actionbar) .dropdown-item:hover {
  background-color: rgba(0, 0, 0, 0.04);
}

/* En pantallas medianas: que envuelva y los botones llenen mejor */
@media (max-width: 768px) {
  :where(.ao-actionbar) .card-body {
    gap: 0.35rem;
  }

  :where(.ao-actionbar) .btn {
    flex: 1 1 auto;
    text-align: center;
  }
}

/* Móvil: scroller horizontal con máscara (igual que lo tenías en Agenda) */
@media (max-width: 576px) {
  :where(.ao-actionbar) {
    position: relative;
    overflow: hidden;
    isolation: isolate;
  }

  :where(.ao-actionbar) .card-body {
    position: relative;
    z-index: 1;

    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    gap: 0.5rem;
  }

  :where(.ao-actionbar)::before,
  :where(.ao-actionbar)::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 18px;
    pointer-events: none;
    z-index: 2;
  }

  :where(.ao-actionbar)::before {
    left: 0;
    background: linear-gradient(
      to right,
      var(--ao-actionbar-bg) 75%,
      rgba(0, 0, 0, 0)
    );
  }

  :where(.ao-actionbar)::after {
    right: 0;
    background: linear-gradient(
      to left,
      var(--ao-actionbar-bg) 75%,
      rgba(0, 0, 0, 0)
    );
  }

  /* Evita que el grupo derecho se vaya a “distancia social” */
  :where(.ao-actionbar) .card-body > .ms-auto {
    margin-left: 0 !important;
  }

  /* Que los grupos no partan */
  :where(.ao-actionbar) .card-body > .d-flex {
    flex-wrap: nowrap !important;
    flex: 0 0 auto;
  }

  :where(.ao-actionbar) :is(.btn, .card-body span) {
    flex: 0 0 auto;
    white-space: nowrap;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  :where(.ao-actionbar) .btn {
    transition: none !important;
  }
}

/* =========================================================
   AO — Table head: banda de marca (sticky-safe)
   Nota: en cabeceras sticky el fondo debe ir en los TH
   Para que el gradiente se vea continuo: background-attachment: fixed
   ========================================================= */

/* Base (modo sólido) */
:where(.aoTable) thead tr.sticky-th > th {
  background-color: var(--brand-1, #0d6efd) !important;
  background-image: none !important;
  color: var(--on-brand, #fff) !important;

  /* separador inferior */
  border-bottom-color: color-mix(in oklab, #ffffff 22%, transparent) !important;
}

/* Modo gradiente (continuo a lo largo de toda la fila) */
:where(html[data-ao-brand-mode="gradient"], body.ao-brand-gradient)
  :where(.aoTable)
  thead
  tr.sticky-th
  > th {
  background-image: var(--brand-grad) !important;

  /* Truco para que no “reinicie” por celda: se ancla al viewport */
  background-attachment: fixed;
  background-size: 100vw 100%;
  background-position: 0 0;
}

/* Redondeo de esquinas */
:where(.aoTable) thead tr.sticky-th > th:first-child {
  border-top-left-radius: 12px;
}

:where(.aoTable) thead tr.sticky-th > th:last-child {
  border-top-right-radius: 12px;
}

/* =========================================================
   AO — Tiles (compat: Caja)
   ========================================================= */

:where(.ao-tile-link, .caja-tile-link) {
  text-decoration: none;
  color: inherit;
  display: inline-flex;
  align-items: stretch;
  justify-content: stretch;
  width: auto;
  height: auto;
}

:where(.ao-tile, .caja-tile) {
  --ao-tile-w: 170px;
  --ao-tile-h: 110px;
  --ao-tile-accent: var(--brand-1, #07689f);

  border-radius: 0.75rem;
  border: 1px solid var(--border, rgba(148, 163, 184, 0.6));
  padding: 0.75rem 1rem;
  background: var(--card, #ffffff);

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 0.35rem;

  width: var(--ao-tile-w);
  min-width: var(--ao-tile-w);
  max-width: var(--ao-tile-w);
  min-height: var(--ao-tile-h);

  transition:
    transform 0.1s ease,
    box-shadow 0.1s ease,
    border-color 0.1s ease;
}

:where(.ao-tile, .caja-tile):hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
  border-color: var(--ao-tile-accent);
}

:where(.ao-tile--disabled, .caja-tile-disabled) {
  opacity: 0.6;
  cursor: default;
}

:where(.ao-tile__icon, .caja-tile-icon) {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(59, 130, 246, 0.12);
  margin-bottom: 0.25rem;
  font-size: 1.1rem;
}

:where(.ao-tile__label, .caja-tile-label) {
  font-weight: 600;
  font-size: 0.9rem;
  line-height: 1.2;
}

/* Fila horizontal tipo Koibox (compat Caja) */
:where(.ao-tile-row, .caja-quick-actions) {
  display: flex;
  flex-wrap: nowrap !important;
  gap: 1.25rem;
  margin-left: 0;
  margin-right: 0;
  overflow-x: auto;
}

:where(.ao-tile-row, .caja-quick-actions) > [class*="col-"] {
  flex: 0 0 auto;
  width: auto !important;
  max-width: none;
  display: flex;
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
}

/* Compat temporal (para NO tocar templates hoy) */
:where(.clientes-full, .productos-full) {
  --ao-bleed: 24px;
  margin-left: calc(-1 * var(--ao-bleed));
  margin-right: calc(-1 * var(--ao-bleed));
  padding-left: var(--ao-bleed);
  padding-right: var(--ao-bleed);
}

/* Buscador dentro de toolbars (global) */
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )
  input[type="search"] {
  min-width: 220px;
  background: #ffffff;
  border-color: transparent;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.18);
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )
  input[type="search"]::placeholder {
  color: color-mix(in oklab, var(--ink, #0f172a), transparent 35%);
}

body.dark-mode
  :where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )
  input[type="search"] {
  background: color-mix(in oklab, #ffffff, transparent 10%);
}

/* Buscador también dentro de actionbar (look consistente) */
:where(.ao-actionbar) input[type="search"] {
  min-width: 220px;
  background: #ffffff;
  border-color: transparent;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.18);
}

:where(.ao-actionbar) input[type="search"]::placeholder {
  color: color-mix(in oklab, var(--ink, #0f172a), transparent 35%);
}

body.dark-mode :where(.ao-actionbar) input[type="search"] {
  background: color-mix(in oklab, #ffffff, transparent 10%);
}

/* =========================================================
   AO — Auto HScroll (toolbars/actionbars)
   Activa scroll horizontal SOLO cuando de verdad hay overflow.
   Requiere el atributo: data-ao-hscroll="1" (lo pone app.js)
   ========================================================= */

/* --- Actionbar (.ao-actionbar) --- */
:where(.ao-actionbar)[data-ao-hscroll="1"] {
  position: relative;
  overflow: hidden;
  /* para que la máscara no se salga */
  isolation: isolate;
}

/* El “rail” scrolleable es el .card-body */
:where(.ao-actionbar)[data-ao-hscroll="1"] > .card-body {
  position: relative;
  z-index: 1;

  flex-wrap: nowrap !important;
  justify-content: flex-start !important;
  align-items: center;

  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  touch-action: pan-x;

  gap: 0.5rem;
  min-width: 0;
  scrollbar-width: thin;
}

/* En modo scroll: en desktop mantenemos ms-auto (para alinear a la derecha).
   En móvil sí lo anulamos para evitar huecos gigantes en el rail scrolleable. */
@media (max-width: 576px) {
  :where(.ao-actionbar)[data-ao-hscroll="1"] > .card-body > .ms-auto {
    margin-left: 0 !important;
  }

  :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )[data-ao-hscroll="1"]
    > .d-flex
    > .ms-auto {
    margin-left: 0 !important;
  }
}

/* En modo scroll: los hijos NO deben estirarse ni partir */
:where(.ao-actionbar)[data-ao-hscroll="1"] > .card-body > * {
  flex: 0 0 auto !important;
  white-space: nowrap;
}

/* El form interno no debe “crecer” y reventar el layout */
:where(.ao-actionbar)[data-ao-hscroll="1"] > .card-body > form {
  flex: 0 0 auto !important;
  flex-wrap: nowrap !important;
}

/* Asegura que los botones no entren en el “flex: 1” del breakpoint 768 */
:where(.ao-actionbar)[data-ao-hscroll="1"] .btn:not(.btn-close) {
  flex: 0 0 auto !important;
}

/* Buscador en scroll: que no se convierta en un píxel */
:where(.ao-actionbar)[data-ao-hscroll="1"] input[type="search"] {
  width: clamp(160px, 26vw, 280px);
  min-width: 160px;
}

/* Máscaras laterales: SOLO cuando hay scroll real (lo decide JS con data-ao-mask-*) */
:where(.ao-actionbar)[data-ao-hscroll="1"]::before,
:where(.ao-actionbar)[data-ao-hscroll="1"]::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 18px;
  pointer-events: none;
  z-index: 2;

  /* Clave: hereda el fondo real (gradiente incluido) para que no “cante” */
  background: inherit;

  opacity: 0;
  transition: opacity 0.12s ease;
}

:where(.ao-actionbar)[data-ao-hscroll="1"]::before {
  left: 0;
  -webkit-mask-image: linear-gradient(to right, #000 65%, transparent);
  mask-image: linear-gradient(to right, #000 65%, transparent);
}

:where(.ao-actionbar)[data-ao-hscroll="1"]::after {
  right: 0;
  -webkit-mask-image: linear-gradient(to left, #000 65%, transparent);
  mask-image: linear-gradient(to left, #000 65%, transparent);
}

/* Solo se muestran si JS dice que hay contenido “debajo” en ese lado */
:where(.ao-actionbar)[data-ao-hscroll="1"][data-ao-mask-left="1"]::before {
  opacity: 1;
}

:where(.ao-actionbar)[data-ao-hscroll="1"][data-ao-mask-right="1"]::after {
  opacity: 1;
}

/* --- Toolbars “clásicas” (*-toolbar / .ao-toolbar) --- */
:where(
  .ao-toolbar,
  .clientes-toolbar,
  .productos-toolbar,
  .caja-toolbar,
  .empleados-toolbar,
  .categorias-toolbar,
  .servicios-toolbar,
  .bonos-toolbar,
  .usuarios-toolbar
)[data-ao-hscroll="1"] {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

/* El rail scrolleable típico es el hijo directo .d-flex */
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"]
  > .d-flex {
  position: relative;
  z-index: 1;

  flex-wrap: nowrap !important;
  justify-content: flex-start !important;
  align-items: center;

  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  touch-action: pan-x;

  gap: 0.5rem;
  min-width: 0;
  scrollbar-width: thin;
}

/* Que los items no partan */
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"]
  > .d-flex
  > * {
  flex: 0 0 auto !important;
  white-space: nowrap;
}

/* Buscador en scroll */
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"]
  input[type="search"] {
  width: clamp(160px, 26vw, 280px);
  min-width: 160px;
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"]::before,
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"]::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 18px;
  pointer-events: none;
  z-index: 2;

  background: inherit;

  opacity: 0;
  transition: opacity 0.12s ease;
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"]::before {
  left: 0;
  -webkit-mask-image: linear-gradient(to right, #000 65%, transparent);
  mask-image: linear-gradient(to right, #000 65%, transparent);
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"]::after {
  right: 0;
  -webkit-mask-image: linear-gradient(to left, #000 65%, transparent);
  mask-image: linear-gradient(to left, #000 65%, transparent);
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"][data-ao-mask-left="1"]::before {
  opacity: 1;
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )[data-ao-hscroll="1"][data-ao-mask-right="1"]::after {
  opacity: 1;
}

/* Móvil: toolbar scroll + máscara (Clientes/Productos/Empleados) */
@media (max-width: 576px) {
  :where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  ) {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    padding: 0.6rem 0.75rem;
  }

  :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )
    > .d-flex {
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    align-items: center;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    gap: 0.5rem;
    position: relative;
    z-index: 1;
  }

  :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )
    > .d-flex
    > .ms-auto {
    margin-left: 0 !important;
  }

  :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )
    > .d-flex
    > form {
    flex: 0 0 auto !important;
    flex-wrap: nowrap !important;
  }

  :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )
    > .d-flex
    > :is(
      form,
      .btn,
      .ao-total-pill,
      .empleados-total-pill,
      .categorias-total-pill,
      .servicios-total-pill,
      .bonos-total-pill,
      .usuarios-total-pill
    ) {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )
    input[type="search"] {
    width: clamp(140px, 42vw, 200px);
    min-width: 140px;
  }

  :where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )::before,
  :where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 18px;
    pointer-events: none;
    z-index: 2;
  }

  :where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )::before {
    left: 0;
    background: linear-gradient(
      to right,
      var(--ao-toolbar-bg, var(--brand-1, #07689f)) 75%,
      rgba(0, 0, 0, 0)
    );
  }

  :where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  )::after {
    right: 0;
    background: linear-gradient(
      to left,
      var(--ao-toolbar-bg, var(--brand-1, #07689f)) 75%,
      rgba(0, 0, 0, 0)
    );
  }

  body.dark-mode
    :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )::before {
    background: linear-gradient(
      to right,
      color-mix(
          in oklab,
          var(--ao-toolbar-bg, var(--brand-1, #07689f)),
          #000000 35%
        )
        75%,
      rgba(0, 0, 0, 0)
    );
  }

  body.dark-mode
    :where(
      .ao-toolbar,
      .clientes-toolbar,
      .productos-toolbar,
      .caja-toolbar,
      .empleados-toolbar,
      .categorias-toolbar,
      .servicios-toolbar,
      .bonos-toolbar,
      .usuarios-toolbar
    )::after {
    background: linear-gradient(
      to left,
      color-mix(
          in oklab,
          var(--ao-toolbar-bg, var(--brand-1, #07689f)),
          #000000 35%
        )
        75%,
      rgba(0, 0, 0, 0)
    );
  }
}

/* =========================================================
   AO — Total pill (reutilizable)
   Compat: empleados-total-pill sin tocar templates
   ========================================================= */
:where(
  .ao-total-pill,
  .empleados-total-pill,
  .categorias-total-pill,
  .servicios-total-pill,
  .bonos-total-pill,
  .usuarios-total-pill
) {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.42rem 0.9rem;
  border-radius: 999px;
  background: #ffffff;
  color: var(--brand-1, #07689f);
  font-weight: 600;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.18);
  white-space: nowrap;
}

:where(
    .ao-total-pill,
    .empleados-total-pill,
    .categorias-total-pill,
    .servicios-total-pill,
    .bonos-total-pill,
    .usuarios-total-pill
  )
  strong {
  color: var(--brand-1, #07689f);
}

/* Utilidad: footer de card sin wrap (para quitar inline styles) */
.ao-card-footer {
  white-space: nowrap;
}

/* Utilidades / componentes AO */
.extra-small {
  font-size: 0.75rem;
}

/* =========================================================
   AO — Tab slide 2D (reutilizable)
   ========================================================= */
.tab-slide {
  --slide-duration: 420ms;
  --slide-ease: cubic-bezier(0.25, 0.8, 0.25, 1);
  overflow: hidden;
  position: relative;
  display: grid;
}

.tab-slide .tab-pane {
  grid-area: 1 / 1;
  position: relative;
}

.tab-slide .tab-pane.fade {
  transition: none !important;
  opacity: 1 !important;
}

.pane-slide {
  width: 100%;
  transform: translate3d(0, 0, 0);
  will-change: transform;
}

.tab-slide.is-animating {
  pointer-events: none;
}

/* =========================================================
   AO — KPI (compat: perfil)
   ========================================================= */
:where(.ao-kpi, .perfil-kpi) {
  padding: 0.5rem 0.75rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.25);
  background: rgba(148, 163, 184, 0.04);
}

:where(.ao-kpi--muted, .perfil-kpi-muted) {
  background: transparent;
}

:where(.ao-kpi__label, .perfil-kpi-label) {
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: #64748b;
}

:where(.ao-kpi__value, .perfil-kpi-value) {
  font-size: 1.1rem;
  font-weight: 600;
}

:where(body.dark-mode, [data-bs-theme="dark"]) :where(.ao-kpi, .perfil-kpi) {
  border-color: rgba(148, 163, 184, 0.4);
  background: rgba(15, 23, 42, 0.7);
}

/* =========================================================
   AO — Check/status icon (compat: perfil)
   ========================================================= */
:where(.ao-check-icon, .perfil-check-icon) {
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  margin-top: 0.1rem;
}

:where(.ao-check-icon--ok, .perfil-check-icon-ok) {
  background: rgba(34, 197, 94, 0.12);
  color: #16a34a;
}

:where(.ao-check-icon--pending, .perfil-check-icon-pending) {
  background: rgba(148, 163, 184, 0.16);
  color: #4b5563;
}

:where(body.dark-mode, [data-bs-theme="dark"])
  :where(.ao-check-icon--pending, .perfil-check-icon-pending) {
  background: rgba(148, 163, 184, 0.28);
  color: #e5e7eb;
}

/* =========================================================
   AO — Danger zone soft (compat: perfil)
   ========================================================= */
:where(.ao-danger-zone, .perfil-danger-zone) {
  background: rgba(248, 113, 113, 0.02);
}

.progress-thin {
  height: 0.4rem;
  border-radius: 999px;
  overflow: hidden;
}

.progress-thin .progress-bar {
  border-radius: 999px;
}

/* =========================================================
   AO — Marca (gradiente) en superficies primarias
   ========================================================= */

/* Botones primarios */
.btn-primary {
  background-image: var(--brand-grad);
  border-color: var(--brand-1) !important;
  color: var(--on-brand) !important;
}

/* Hover/active: ajuste suave (sin reinventar la rueda) */
.btn-primary:hover,
.btn-primary:focus {
  filter: brightness(0.98) saturate(1.03);
}

.btn-primary:active {
  filter: brightness(0.95) saturate(1.03);
}

.btn-primary:disabled,
.btn-primary.disabled {
  background-image: none;
  filter: none;
}

/* Utilidades Bootstrap típicas (si las usas) */
.bg-primary,
.text-bg-primary {
  background-image: var(--brand-grad);
}

/* ==== FORCE BRAND on primary buttons (wins against page CSS) ==== */
:where(#perfil-root, body)
  :where(
    .btn.btn-primary,
    button.btn-primary,
    a.btn-primary,
    input.btn-primary
  ) {
  background: var(--brand-grad) !important;
  border-color: var(--brand-1) !important;
  color: var(--on-brand) !important;
}

:where(#perfil-root, body) :where(.btn.btn-primary):hover,
:where(#perfil-root, body) :where(.btn.btn-primary):focus {
  filter: brightness(0.98) saturate(1.03);
}

:where(#perfil-root, body) :where(.btn.btn-primary):active {
  filter: brightness(0.95) saturate(1.03);
}
