/* Agend One — botones.css
   Extraído de app.css manteniendo el orden original.
*/

/* FC: “más” con el mismo look que el botón gris superior */
#agenda-root .fc-daygrid-more-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.5rem;
  /* igual a btn-sm */
  border-radius: 10px;
  /* igual a la toolbar */
  /* el color/borde/fondo los aporta .btn-outline-secondary */
}

/* Botón eliminar “pill + icon” reutilizable */
:is(.avatar-delete-btn, .cita-delete-btn) {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #dc3545;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.16);
  cursor: pointer;
  transition: all 0.3s ease;
  overflow: hidden;
  position: relative;
  top: 5px;
  padding: 0;
}

:is(.avatar-delete-icon, .cita-delete-icon) {
  width: 12px;
  transition:
    transform 0.3s ease,
    width 0.3s ease;
}

:is(.avatar-delete-icon, .cita-delete-icon) path {
  fill: #fff;
}

:is(.avatar-delete-btn, .cita-delete-btn)::before {
  position: absolute;
  top: -20px;
  content: attr(data-label);
  color: #fff;
  font-size: 2px;
  opacity: 0;
  transition: all 0.3s ease;
}

/* Hover: se estira y aparece el texto */
:is(.avatar-delete-btn, .cita-delete-btn):hover {
  width: 100px;
  border-radius: 50px;
  background-color: #ff4545;
}

:is(.avatar-delete-btn, .cita-delete-btn):hover
  :is(.avatar-delete-icon, .cita-delete-icon) {
  width: 24px;
  transform: translateY(60%);
}

:is(.avatar-delete-btn, .cita-delete-btn):hover::before {
  font-size: 13px;
  opacity: 1;
  transform: translateY(24px);
}

/* ========= BOTÓN LOGIN “PREMIUM” ========= */
.btn-login {
  position: relative;
  overflow: hidden;
  border-radius: 0.65rem;
  transition:
    width var(--login-btn-ms) var(--login-btn-ease),
    border-radius var(--login-btn-ms) var(--login-btn-ease),
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background-position 0.6s ease;
  background-image:
    radial-gradient(
      120% 120% at 80% -20%,
      rgba(255, 255, 255, 0.22),
      transparent 60%
    ),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--brand-1, #4f46e5) 92%, #000 8%),
      color-mix(in srgb, var(--brand-1, #4f46e5) 60%, #000 40%)
    );
  background-size: 200% 200%;
  color: #fff;
  will-change: width, border-radius;
}

.btn-login:hover {
  transform: translateY(-1px);
  background-position: 20% 0;
}

.btn-login:active {
  transform: translateY(0);
}

.btn-login::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255, 255, 255, 0.35) 30%,
    transparent 60%
  );
  transform: translateX(-140%);
}

.btn-login:hover::before {
  transition: transform 0.9s var(--login-btn-ease);
  transform: translateX(140%);
}

.btn-login .btn-contents {
  display: inline-grid;
  place-items: center;
  width: 100%;
}

.btn-login .label {
  transition:
    opacity 0.22s ease,
    transform 0.22s ease;
}

.btn-login .progress {
  position: absolute;
  inset: 0;
  margin: auto;
  width: calc(var(--btn-h, 2.9rem) - 4px);
  height: calc(var(--btn-h, 2.9rem) - 4px);
  border-radius: 50%;
  opacity: 0;
  transform: scale(0.65);
  transition:
    opacity 0.2s ease,
    transform 0.28s ease;
  pointer-events: none;
}

.btn-login .progress::before,
.btn-login .progress::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
}

.btn-login .progress::before {
  background: conic-gradient(
    from var(--ang, 0turn),
    rgba(255, 255, 255, 0.95) 0turn 0.12turn,
    transparent 0.12turn 1turn
  );
  -webkit-mask: radial-gradient(farthest-side, transparent 62%, #000 63%);
  mask: radial-gradient(farthest-side, transparent 62%, #000 63%);
  animation: ring-rot 0.9s linear infinite;
}

.btn-login .progress::after {
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.38);
  animation: btn-pulse 1.2s ease-out infinite;
}

.btn-login .check {
  position: absolute;
  inset: 0;
  margin: auto;
  display: grid;
  place-items: center;
  opacity: 0;
  transform: scale(0.55);
  transition:
    opacity 0.22s ease,
    transform 0.32s cubic-bezier(0.2, 0.8, 0.2, 1);
}

body:not(.dark-mode) .btn.btn-primary.btn-login {
  color: #fff;
}

@keyframes ring-rot {
  to {
    --ang: 1turn;
  }
}

@keyframes btn-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.36);
  }

  100% {
    box-shadow: 0 0 0 16px rgba(255, 255, 255, 0);
  }
}

.btn-login.is-loading {
  pointer-events: none;
  border-radius: 999px;
  width: var(--btn-h, 2.9rem) !important;
  box-shadow:
    0 10px 30px rgba(2, 6, 23, 0.25),
    0 0 0 2px rgba(255, 255, 255, 0.08) inset;
  animation: circle-pop 0.5s var(--login-btn-ease) both;
}

@keyframes circle-pop {
  0% {
    transform: scale(1);
  }

  55% {
    transform: scale(0.94);
  }

  100% {
    transform: scale(1);
  }
}

.btn-login.is-loading .label {
  opacity: 0;
  transform: translateY(-6px);
}

.btn-login.is-loading .progress {
  opacity: 1;
  transform: scale(1);
}

.btn-login.is-done {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, #22c55e 92%, #000 8%),
    color-mix(in srgb, #22c55e 70%, #000 30%)
  );
  animation: done-pop 0.42s cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

@keyframes done-pop {
  0% {
    transform: scale(1);
  }

  70% {
    transform: scale(1.08);
  }

  100% {
    transform: scale(1);
  }
}

.btn-login.is-done .progress {
  opacity: 0;
  transform: scale(0.9);
}

.btn-login.is-done .check {
  opacity: 1;
  transform: scale(1);
}

.btn-login .blast {
  position: absolute;
  inset: 0;
  margin: auto;
  border-radius: 50%;
  width: var(--btn-h, 2.9rem);
  height: var(--btn-h, 2.9rem);
  box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.55);
  animation: blast 620ms ease-out forwards;
}

@keyframes blast {
  0% {
    transform: scale(1);
    opacity: 0.9;
  }

  100% {
    transform: scale(7);
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .btn-login,
  .btn-login::before,
  .btn-login .progress::before,
  .btn-login .progress::after {
    transition: none !important;
    animation: none !important;
  }
}

/* ===== AO PAY (addon): mantiene animación, el look lo pone .btn-action ===== */

/* Solo cuando el botón lleva el estilo de clientes */
.btn-action.ao-pay-btn {
  min-height: var(--foot-btn-h, 38px);
  position: relative;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
}

/* AO PAY (listado): misma idea pero en versión icon-only (.btn-icon) */
.btn-icon.ao-pay-btn {
  position: relative;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
}

/* Si el texto es largo, compacta un poco el padding del componente base */
.btn-action.ao-pay-btn.is-long {
  padding-inline: 0.65rem;
}

/* Disabled (para <a>) */
.ao-pay-btn.is-disabled,
.ao-pay-btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: default;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: saturate(0.7);
}

/* Texto */
.ao-pay-btn__text {
  font-weight: 600;
  font-family:
    system-ui,
    -apple-system,
    sans-serif;
  white-space: nowrap;
}

/* Iconos */
.ao-pay-btn__icon-container {
  position: relative;
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
}

.ao-pay-btn__icon {
  position: absolute;
  inset: 0;
  width: 24px;
  height: 24px;
  color: currentColor;
  opacity: 0;
  visibility: hidden;
}

.ao-pay-btn__default-icon {
  opacity: 1;
  visibility: visible;
}

/* Hover animations */
.ao-pay-btn:hover .ao-pay-btn__icon {
  animation: none;
}

.ao-pay-btn:hover .ao-pay-btn__wallet-icon {
  opacity: 0;
  visibility: hidden;
}

.ao-pay-btn:hover .ao-pay-btn__card-icon {
  animation: aoPayIconRotate 2.5s infinite;
  animation-delay: 0s;
}

.ao-pay-btn:hover .ao-pay-btn__payment-icon {
  animation: aoPayIconRotate 2.5s infinite;
  animation-delay: 0.5s;
}

.ao-pay-btn:hover .ao-pay-btn__dollar-icon {
  animation: aoPayIconRotate 2.5s infinite;
  animation-delay: 1s;
}

.ao-pay-btn:hover .ao-pay-btn__check-icon {
  animation: aoPayIconRotate 2.5s infinite;
  animation-delay: 1.5s;
}

/* Active state - solo check mientras pulsas */
.ao-pay-btn:active .ao-pay-btn__icon {
  animation: none;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.ao-pay-btn:active .ao-pay-btn__check-icon {
  animation: aoPayCheckmarkAppear 0.6s ease forwards;
  visibility: visible;
}

/* Si el texto es largo */
.ao-pay-btn.is-long {
  padding-inline: 18px;
}

@keyframes aoPayIconRotate {
  0% {
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px) scale(0.5);
  }

  5% {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
  }

  15% {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
  }

  20% {
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px) scale(0.5);
  }

  100% {
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px) scale(0.5);
  }
}

@keyframes aoPayCheckmarkAppear {
  0% {
    opacity: 0;
    transform: scale(0.5) rotate(-45deg);
  }

  50% {
    opacity: 0.5;
    transform: scale(1.2) rotate(0deg);
  }

  100% {
    opacity: 1;
    transform: scale(1) rotate(0deg);
  }
}

/* =========================================================
   AO — Botones de acciones (estilo Clientes)
   Uso: class="btn btn-sm btn-icon"
   ========================================================= */

.btn-icon {
  --size: 30px;
  width: var(--size);
  height: var(--size);
  display: inline-grid;
  place-items: center;
  padding: 0;
  border-radius: 10px;
  line-height: 1;
  font-size: 0.9rem;

  background: #ffffff;
  color: var(--ink, #0f172a);
  border: 1px solid rgba(15, 23, 42, 0.9);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.08),
    0 2px 6px rgba(15, 23, 42, 0.16);

  position: relative;
  top: 0;
  transition:
    transform 0.14s ease,
    box-shadow 0.14s ease,
    background-color 0.14s ease,
    border-color 0.14s ease;
  will-change: transform, box-shadow;
}

.btn-icon i {
  color: inherit;
}

.btn-icon:hover,
.btn-icon:focus-visible {
  background: #ffffff;
  color: var(--ink, #0f172a);
  border-color: rgba(15, 23, 42, 0.9);
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.14),
    0 6px 16px rgba(15, 23, 42, 0.25);
}

.btn-icon:active {
  transform: translateY(0);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.1),
    0 2px 6px rgba(15, 23, 42, 0.18);
}

/* Dark mode */
body.dark-mode .btn-icon {
  background: color-mix(in oklab, var(--card, #0f172a), #000000 25%) !important;
  color: #ffffff !important;
  border-color: color-mix(in oklab, #ffffff, transparent 45%) !important;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.1),
    0 6px 16px rgba(0, 0, 0, 0.35) !important;
}

body.dark-mode .btn-icon:hover,
body.dark-mode .btn-icon:focus-visible {
  background: color-mix(in oklab, var(--card, #0f172a), #000000 15%) !important;
  border-color: color-mix(in oklab, #ffffff, transparent 35%) !important;
}

body.dark-mode .btn-icon:active {
  background: color-mix(in oklab, var(--card, #0f172a), #000000 40%) !important;
}

/* =========================================================
   AO — Botón de acción con texto (mismo look que .btn-icon)
   Uso: class="btn btn-sm btn-action"
   ========================================================= */

.btn-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;

  padding: 0.28rem 0.85rem;
  /* compacto tipo btn-sm */
  border-radius: 10px;
  line-height: 1;
  font-size: 0.85rem;
  font-weight: 600;
  white-space: nowrap;

  background: #ffffff;
  color: var(--ink, #0f172a);
  border: 1px solid rgba(15, 23, 42, 0.9);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.08),
    0 2px 6px rgba(15, 23, 42, 0.16);

  position: relative;
  top: 0;
  transition:
    transform 0.14s ease,
    box-shadow 0.14s ease,
    background-color 0.14s ease,
    border-color 0.14s ease;
  will-change: transform, box-shadow;
}

.btn-action i {
  color: inherit;
}

.btn-action:hover,
.btn-action:focus-visible {
  background: #ffffff;
  color: var(--ink, #0f172a);
  border-color: rgba(15, 23, 42, 0.9);
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.14),
    0 6px 16px rgba(15, 23, 42, 0.25);
}

.btn-action:active {
  transform: translateY(0);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.1),
    0 2px 6px rgba(15, 23, 42, 0.18);
}

/* Disabled */
.btn-action:disabled,
.btn-action.disabled,
.btn-action[aria-disabled="true"] {
  opacity: 0.45;
  cursor: default;
  pointer-events: none;
  transform: none;
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.06),
    0 2px 6px rgba(15, 23, 42, 0.1);
}

/* Dark mode */
body.dark-mode .btn-action {
  background: color-mix(in oklab, var(--card, #0f172a), #000000 25%) !important;
  color: #ffffff !important;
  border-color: color-mix(in oklab, #ffffff, transparent 45%) !important;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.1),
    0 6px 16px rgba(0, 0, 0, 0.35) !important;
}

body.dark-mode .btn-action:hover,
body.dark-mode .btn-action:focus-visible {
  background: color-mix(in oklab, var(--card, #0f172a), #000000 15%) !important;
  border-color: color-mix(in oklab, #ffffff, transparent 35%) !important;
}

body.dark-mode .btn-action:active {
  background: color-mix(in oklab, var(--card, #0f172a), #000000 40%) !important;
}

/* Bootstrap: ajustes globales de botones */
.btn {
  border-radius: var(--rad-sm);
  font-weight: 600;
}

.btn-primary {
  background: var(--brand-1);
  border-color: var(--brand-1);
}

.btn-primary:focus {
  box-shadow: var(--focus);
}

.btn-outline-primary {
  border-color: var(--brand-1);
  color: var(--brand-1);
}

.btn-outline-primary:hover {
  background: var(--brand-1);
  color: #fff;
}

body.dark-mode .btn-light {
  background-color: #2c2c2e !important;
  color: var(--ink) !important;
  border-color: var(--border) !important;
}

/* Botón "Cambiar empresa" */
.sidebar .switch-company-full {
  display: flex;
}

.sidebar .switch-company-full .btn-compact {
  width: auto;
  margin: -0.4rem auto;
  --bs-btn-font-size: 0.8rem;
  --bs-btn-padding-y: 0.25rem;
  --bs-btn-padding-x: 0.5rem;
  border-radius: var(--rad-sm);
}

.sidebar .switch-company-full .btn-compact i {
  margin-right: 0.25rem;
}

.sidebar .switch-company-compact .sb-icon {
  width: 32px;
  height: 32px;
}

.switch-company {
  margin-top: 0.75rem;
}

:root[data-sidebar="collapsed"] .switch-company__label,
body.sb-collapsed .switch-company__label {
  display: none !important;
}

:root[data-sidebar="collapsed"] .switch-company .btn,
body.sb-collapsed .switch-company .btn {
  width: 2.25rem;
  padding-inline: 0.5rem;
  justify-content: center;
}

/* FIX: centrar el icono de teléfono en su circulito (vista de login) */
.auth-page a[href^="tel:"].rounded-circle,
.auth-page .btn-call.rounded-circle {
  width: 32px;
  /* ajusta si tu círculo es mayor/menor */
  height: 32px;
  padding: 0 !important;
  border-radius: 50%;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  /* evita que la tipografía desplace el icono */
}

.auth-page a[href^="tel:"].rounded-circle i,
.auth-page .btn-call.rounded-circle i {
  display: block;
  line-height: 1;
}

/* MÓVIL: centrar 100% el icono dentro del círculo */
@media (max-width: 576px) {
  .auth-page a[href^="tel:"].rounded-circle,
  .auth-page .btn-call.rounded-circle {
    width: 34px;
    height: 34px;
    padding: 0 !important;
    border-radius: 50%;
    display: grid !important;
    place-items: center !important;
    line-height: 0 !important;
    /* anula el line-height del botón */
  }

  .auth-page a[href^="tel:"].rounded-circle i,
  .auth-page .btn-call.rounded-circle i {
    display: block;
    line-height: 1 !important;
    margin: 0 !important;
    transform: translateY(0) !important;
  }

  /* por si ese <i> usa .fa-fw (anchura fija) */
  .auth-page a[href^="tel:"].rounded-circle i.fa-fw {
    width: auto;
  }
}

/* =========================================================
   AO — “Button-like”: elementos clicables que no son <button>
   (links, chips, avatares usados como acción)
   ========================================================= */

/* AO — Utilidades visuales reutilizables (Clientes) */
.avatar {
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--brand-1, #4f46e5);
  background-image: var(--brand-grad);
  color: #fff;
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  box-shadow: 0 0 0 1px var(--border, #e5e7eb) inset;
  flex: 0 0 auto;
  /* clave: que NO se encoja en flex */
  aspect-ratio: 1 / 1;
  /* clave: siempre círculo perfecto */
  vertical-align: middle;
  /* mejor alineado en tablas y texto */
  line-height: 1;
  /* evita “bailes” verticales */
  text-transform: uppercase;
  user-select: none;
}

.badge-soft,
.badge-soft-weak {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.18rem 0.6rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.78rem;
  line-height: 1.2;

  background: var(--badge-bg);
  color: var(--badge-fg);
  border: 1px solid var(--badge-bd);
}

.badge-soft {
  --badge-bg: color-mix(in oklab, var(--card, #fff) 75%, var(--ink, #0f172a));
  --badge-fg: var(--ink, #0f172a);
  --badge-bd: var(--border, #e5e7eb);
}

.badge-soft-weak {
  --badge-bg: color-mix(in oklab, var(--card, #fff) 85%, var(--ink, #0f172a));
  --badge-fg: var(--ink, #0f172a);
  --badge-bd: var(--border, #e5e7eb);
}

/* Blindaje: si alguien mezcla Bootstrap .badge con nuestros soft-badges */
.badge.badge-soft,
.badge.badge-soft-weak {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
  padding: 0.18rem 0.6rem !important;
  border-radius: 999px !important;
  font-weight: 600 !important;
  font-size: 0.78rem !important;
  line-height: 1.2 !important;

  background: var(--badge-bg) !important;
  color: var(--badge-fg) !important;
  border: 1px solid var(--badge-bd) !important;
  vertical-align: middle;
}

/* Variantes */
.badge-soft-brand {
  --badge-bg: color-mix(in oklab, var(--brand-1, #4f46e5), transparent 86%);
  --badge-fg: var(--brand-1, #4f46e5);
  --badge-bd: color-mix(in oklab, var(--brand-1, #4f46e5), transparent 70%);
}

.badge-soft-muted {
  --badge-bg: color-mix(in oklab, var(--muted, #6b7280), transparent 85%);
  --badge-fg: color-mix(in oklab, var(--muted, #6b7280), #000 12%);
  --badge-bd: color-mix(in oklab, var(--muted, #6b7280), transparent 70%);
}

.link-soft {
  text-decoration: none;
  color: inherit;
  border-bottom: 1px dotted
    color-mix(in oklab, var(--ink, #0f172a), transparent 70%);
}

.link-soft:hover {
  text-decoration: underline;
}

/* Opcional: marca explícita de “esto es clicable” */
.avatar.is-clickable,
.badge-soft.is-clickable,
.badge-soft-weak.is-clickable {
  cursor: pointer;
  user-select: none;
}

.avatar.is-clickable:focus-visible,
.badge-soft.is-clickable:focus-visible,
.badge-soft-weak.is-clickable:focus-visible {
  outline: none;
  box-shadow: var(--focus);
}

/* =========================================================
   AO — Chip (badge simple)
   ========================================================= */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.75rem;
  line-height: 1;
  padding: 0.35rem 0.5rem;
  border-radius: 10px;
  border: 1px solid var(--border, #e5e7eb);
  background: var(--card, #fff);
  color: var(--ink, #0f172a);
}

.chip .chip-val {
  display: inline-block;
  font-weight: 600;
  padding: 0.15rem 0.4rem;
  border-radius: 0.5rem;
  background: rgba(0, 0, 0, 0.06);
}

/* Dark mode real (tu sistema) + compat data-bs-theme */
:where(body.dark-mode, [data-bs-theme="dark"]) .chip {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.18);
  color: #fff;
}

:where(body.dark-mode, [data-bs-theme="dark"]) .chip .chip-val {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

/* Botón subir avatar (pill) */
.btn-avatar-upload {
  padding-inline: 1.4rem;
  padding-block: 0.4rem;
  font-size: 1rem;
  border-radius: 100px;
  position: relative;
  top: 5px;
}

/* Utilidad: botones con altura consistente (reutilizable) */
.btn-eq-h {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: calc(var(--field-h, 38px) - 10px);
  padding: 0 0.9rem;
  line-height: 1;
  white-space: nowrap;
  vertical-align: middle;
}

/* =========================================================
   AO — Botones unificados en toolbars (GLOBAL)
   Objetivo:
   - Todos los botones en barras azules: mismo look, misma “píldora”, misma marca.
   - .active y aria-current="page" = estado seleccionado (blanco + texto marca).
   ========================================================= */

:where(
  .ao-toolbar,
  .clientes-toolbar,
  .productos-toolbar,
  .caja-toolbar,
  .empleados-toolbar,
  .categorias-toolbar,
  .servicios-toolbar,
  .bonos-toolbar,
  .usuarios-toolbar
):where(.btn:not(.btn-icon):not(.btn-action)) {
  border-radius: 999px !important;
  font-size: 0.85rem;
  font-weight: 700;
  white-space: nowrap;

  /* look común */
  background: color-mix(in oklab, #ffffff, transparent 88%) !important;
  border: 1px solid color-mix(in oklab, #ffffff, transparent 55%) !important;
  color: #ffffff !important;
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  ):where(.btn:not(.btn-icon):not(.btn-action)):hover,
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  ):where(.btn:not(.btn-icon):not(.btn-action)):focus-visible {
  background: color-mix(in oklab, #ffffff, transparent 82%) !important;
  border-color: color-mix(in oklab, #ffffff, transparent 40%) !important;
}

/* Estado seleccionado (filtros activos, tabs activas, etc.) */
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  ):where(.btn:not(.btn-icon):not(.btn-action)).active,
:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  ):where(.btn:not(.btn-icon):not(.btn-action))[aria-current="page"] {
  background: #ffffff !important;
  border-color: #ffffff !important;
  color: var(--brand-1, #07689f) !important;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.18);
}

/* Acción principal “Nuevo” (siempre como seleccionado, para que destaque) */
:where(
  .ao-toolbar,
  .clientes-toolbar,
  .productos-toolbar,
  .caja-toolbar,
  .empleados-toolbar,
  .categorias-toolbar,
  .servicios-toolbar,
  .bonos-toolbar,
  .usuarios-toolbar
):is(
  .clientes-btn-nuevo,
  .productos-btn-nuevo,
  .empleados-btn-nuevo,
  .categorias-btn-nuevo,
  .servicios-btn-nuevo,
  .bonos-btn-nuevo,
  .usuarios-btn-nuevo
) {
  background: #ffffff !important;
  border-color: #ffffff !important;
  color: var(--brand-1, #07689f) !important;
  font-weight: 800;
}

/* =========================================================
   AO — Lift (hover “sale hacia arriba”) reutilizable
   ========================================================= */
:where(
  .btn-lift,
  .ao-toolbar .btn,
  .clientes-toolbar .btn,
  .productos-toolbar .btn,
  .caja-toolbar .btn,
  .empleados-toolbar .btn,
  .categorias-toolbar .btn,
  .servicios-toolbar .btn,
  .bonos-toolbar .btn,
  .usuarios-toolbar .btn
) {
  position: relative;
  top: 0;
  transition:
    transform 0.14s ease,
    box-shadow 0.14s ease,
    background-color 0.14s ease,
    border-color 0.14s ease;
  will-change: transform, box-shadow;
}

:where(
  .btn-lift,
  .ao-toolbar .btn,
  .clientes-toolbar .btn,
  .productos-toolbar .btn,
  .caja-toolbar .btn,
  .empleados-toolbar .btn,
  .categorias-toolbar .btn,
  .servicios-toolbar .btn,
  .bonos-toolbar .btn,
  .usuarios-toolbar .btn
):hover,
:where(
  .btn-lift,
  .ao-toolbar .btn,
  .clientes-toolbar .btn,
  .productos-toolbar .btn,
  .caja-toolbar .btn,
  .empleados-toolbar .btn,
  .categorias-toolbar .btn,
  .servicios-toolbar .btn,
  .bonos-toolbar .btn,
  .usuarios-toolbar .btn
):focus-visible {
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px color-mix(in oklab, #ffffff, transparent 30%),
    0 6px 16px rgba(15, 23, 42, 0.25);
}

:where(
  .btn-lift,
  .ao-toolbar .btn,
  .clientes-toolbar .btn,
  .productos-toolbar .btn,
  .caja-toolbar .btn,
  .empleados-toolbar .btn,
  .categorias-toolbar .btn,
  .servicios-toolbar .btn,
  .bonos-toolbar .btn,
  .usuarios-toolbar .btn
):active {
  transform: translateY(0);
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.22);
}

@media (prefers-reduced-motion: reduce) {
  :where(
    .btn-lift,
    .ao-toolbar .btn,
    .clientes-toolbar .btn,
    .productos-toolbar .btn,
    .caja-toolbar .btn,
    .empleados-toolbar .btn,
    .categorias-toolbar .btn,
    .servicios-toolbar .btn,
    .bonos-toolbar .btn,
    .usuarios-toolbar .btn
  ) {
    transition: none !important;
  }

  :where(
    .btn-lift,
    .ao-toolbar .btn,
    .clientes-toolbar .btn,
    .productos-toolbar .btn,
    .caja-toolbar .btn,
    .empleados-toolbar .btn,
    .categorias-toolbar .btn,
    .servicios-toolbar .btn,
    .bonos-toolbar .btn,
    .usuarios-toolbar .btn
  ):hover,
  :where(
    .btn-lift,
    .ao-toolbar .btn,
    .clientes-toolbar .btn,
    .productos-toolbar .btn,
    .caja-toolbar .btn,
    .empleados-toolbar .btn,
    .categorias-toolbar .btn,
    .servicios-toolbar .btn,
    .bonos-toolbar .btn,
    .usuarios-toolbar .btn
  ):focus-visible {
    transform: none !important;
  }
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  ):is(
    .categorias-btn-nuevo,
    .servicios-btn-nuevo,
    .bonos-btn-nuevo,
    .usuarios-btn-nuevo
  ):hover {
  filter: brightness(0.95);
}

:where(
    .ao-toolbar,
    .clientes-toolbar,
    .productos-toolbar,
    .caja-toolbar,
    .empleados-toolbar,
    .categorias-toolbar,
    .servicios-toolbar,
    .bonos-toolbar,
    .usuarios-toolbar
  ):is(
    .categorias-btn-importar,
    .servicios-btn-importar,
    .bonos-btn-export
  ):hover {
  background: color-mix(in oklab, #ffffff 12%, transparent);
}

/* =========================================================
   AO — Pills de toolbar (filtros tipo “pastilla”)
   ========================================================= */
:where(.btn-pill-toolbar, .clientes-filtros .clientes-filtro-btn) {
  border-radius: 999px;
  border: 0;
  background: color-mix(in oklab, transparent, #ffffff 12%);
  color: #ffffff;
  padding-inline: 1rem;
}

:where(.btn-pill-toolbar, .clientes-filtros .clientes-filtro-btn).active {
  background: #ffffff;
  color: var(--brand-1, #07689f);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.18);
}

/* =========================================================
   AO — Save button (Empresa) [componente reutilizable]
   Uso futuro recomendado: class="ao-save-btn"
   Compat actual: .empresa-save-btn (sin tocar HTML)
   ========================================================= */
:where(.ao-save-btn, .empresa-save-btn) {
  /* Tokens del componente (editables por página si quieres) */
  --ao-save-bg: color-mix(in oklab, #000 86%, var(--ink, #111827) 14%);
  --ao-save-ink: #fff;
  --ao-save-icon: var(--muted, rgb(155, 153, 153));
  --ao-save-hover-bg: var(--brand-2, #fedf15);
  --ao-save-hover-ink: #111827;
  --ao-save-hover-icon: var(--ao-save-hover-ink);

  font-family: inherit;
  font-size: 20px;
  background: var(--ao-save-bg);
  color: var(--ao-save-ink);
  padding: 0.7em 1em;
  padding-left: 0.9em;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  border: none;
  border-radius: 15px;
  font-weight: 1000;
}

:where(.ao-save-btn, .empresa-save-btn):focus-visible {
  outline: none;
  box-shadow: var(--focus);
}

/* Texto "Guardar Cambios" */
:where(.ao-save-btn, .empresa-save-btn) > span {
  display: block;
  margin-left: 0.3em;
  transition: all 0.3s ease-in-out;
}

/* Wrapper del icono */
:where(.ao-save-btn, .empresa-save-btn) > div:first-child {
  display: flex;
  align-items: center;
  transition: transform 0.5s linear;
}

/* Icono Font Awesome */
:where(.ao-save-btn, .empresa-save-btn) :is(.fas.fa-save, .fa-save) {
  display: block;
  transform-origin: center center;
  transition:
    transform 0.3s ease-in-out,
    color 0.2s ease-in-out;
  color: var(--ao-save-icon);
}

:where(.ao-save-btn, .empresa-save-btn):hover {
  background: var(--ao-save-hover-bg);
  color: var(--ao-save-hover-ink);
}

/* Escalado del wrapper del icono al hover */
:where(.ao-save-btn, .empresa-save-btn):hover > div:first-child {
  transform: scale(1.25);
}

/* Movimiento + escala del icono al hover */
:where(.ao-save-btn, .empresa-save-btn):hover :is(.fas.fa-save, .fa-save) {
  transform: translateX(1.2em) scale(1.1);
  color: var(--ao-save-hover-icon);
}

/* El texto se desvanece al hover */
:where(.ao-save-btn, .empresa-save-btn):hover span {
  opacity: 0;
  transition: 0.5s linear;
}

/* Efecto click */
:where(.ao-save-btn, .empresa-save-btn):active {
  transform: scale(0.95);
}

/* Botón X redondo (GLOBAL para todos los modales) */
.modal-x {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 2px solid rgba(13, 110, 253, 0.75);
  background: var(--card, #fff);
  color: var(--bs-primary, #0d6efd);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition:
    transform 0.12s ease,
    background 0.12s ease;
}

@supports (border: 2px solid color-mix(in srgb, #000 50%, #fff 50%)) {
  .modal-x {
    border: 2px solid
      color-mix(in srgb, var(--bs-primary, #0d6efd) 75%, #fff 25%);
  }
}

.modal-x:hover {
  background: rgba(13, 110, 253, 0.08);
  transform: translateY(-1px);
}

body.dark-mode .modal-x {
  background: var(--card, #0b1620);
}
