/* 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 .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 .3s ease;
   overflow: hidden;
   position: relative;
   top: 5px;
   padding: 0;
}

:is(.avatar-delete-icon, .cita-delete-icon) {
   width: 12px;
   transition: transform .3s ease, width .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 .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: .65rem;
   transition:
      width var(--login-btn-ms) var(--login-btn-ease),
      border-radius var(--login-btn-ms) var(--login-btn-ease),
      transform .18s ease, box-shadow .18s ease, background-position .6s ease;
   background-image:
      radial-gradient(120% 120% at 80% -20%, rgba(255, 255, 255, .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, .35) 30%, transparent 60%);
   transform: translateX(-140%);
}

.btn-login:hover::before {
   transition: transform .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 .22s ease, transform .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(.65);
   transition: opacity .2s ease, transform .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, .95) 0turn .12turn,
         transparent .12turn 1turn);
   -webkit-mask: radial-gradient(farthest-side, transparent 62%, #000 63%);
   mask: radial-gradient(farthest-side, transparent 62%, #000 63%);
   animation: ring-rot .9s linear infinite;
}

.btn-login .progress::after {
   box-shadow: 0 0 0 0 rgba(255, 255, 255, .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(.55);
   transition: opacity .22s ease, transform .32s cubic-bezier(.2, .8, .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, .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, .25), 0 0 0 2px rgba(255, 255, 255, .08) inset;
   animation: circle-pop .5s var(--login-btn-ease) both;
}

@keyframes circle-pop {
   0% {
      transform: scale(1);
   }

   55% {
      transform: scale(.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 .42s cubic-bezier(.2, .8, .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(.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, .55);
   animation: blast 620ms ease-out forwards;
}

@keyframes blast {
   0% {
      transform: scale(1);
      opacity: .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: .65rem;
}

/* Disabled (para <a>) */
.ao-pay-btn.is-disabled,
.ao-pay-btn[aria-disabled="true"] {
   opacity: .45;
   cursor: default;
   pointer-events: none;
   box-shadow: none;
   transform: none;
   filter: saturate(.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: .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 .3s ease;
}

.ao-pay-btn:active .ao-pay-btn__check-icon {
   animation: aoPayCheckmarkAppear .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(.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(.5)
   }

   100% {
      opacity: 0;
      visibility: hidden;
      transform: translateY(-10px) scale(.5)
   }
}

@keyframes aoPayCheckmarkAppear {
   0% {
      opacity: 0;
      transform: scale(.5) rotate(-45deg)
   }

   50% {
      opacity: .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: .9rem;

   background: #ffffff;
   color: var(--ink, #0f172a);
   border: 1px solid rgba(15, 23, 42, .9);
   box-shadow:
      0 0 0 1px rgba(15, 23, 42, .08),
      0 2px 6px rgba(15, 23, 42, .16);

   position: relative;
   top: 0;
   transition:
      transform .14s ease,
      box-shadow .14s ease,
      background-color .14s ease,
      border-color .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, .9);
   transform: translateY(-1px);
   box-shadow:
      0 0 0 1px rgba(15, 23, 42, .14),
      0 6px 16px rgba(15, 23, 42, .25);
}

.btn-icon:active {
   transform: translateY(0);
   box-shadow:
      0 0 0 1px rgba(15, 23, 42, .1),
      0 2px 6px rgba(15, 23, 42, .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, .10),
      0 6px 16px rgba(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: .45rem;

   padding: .28rem .85rem;
   /* compacto tipo btn-sm */
   border-radius: 10px;
   line-height: 1;
   font-size: .85rem;
   font-weight: 600;
   white-space: nowrap;

   background: #ffffff;
   color: var(--ink, #0f172a);
   border: 1px solid rgba(15, 23, 42, .9);
   box-shadow:
      0 0 0 1px rgba(15, 23, 42, .08),
      0 2px 6px rgba(15, 23, 42, .16);

   position: relative;
   top: 0;
   transition:
      transform .14s ease,
      box-shadow .14s ease,
      background-color .14s ease,
      border-color .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, .9);
   transform: translateY(-1px);
   box-shadow:
      0 0 0 1px rgba(15, 23, 42, .14),
      0 6px 16px rgba(15, 23, 42, .25);
}

.btn-action:active {
   transform: translateY(0);
   box-shadow:
      0 0 0 1px rgba(15, 23, 42, .10),
      0 2px 6px rgba(15, 23, 42, .18);
}

/* Disabled */
.btn-action:disabled,
.btn-action.disabled,
.btn-action[aria-disabled="true"] {
   opacity: .45;
   cursor: default;
   pointer-events: none;
   transform: none;
   box-shadow:
      0 0 0 1px rgba(15, 23, 42, .06),
      0 2px 6px rgba(15, 23, 42, .10);
}

/* 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, .10),
      0 6px 16px rgba(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: .80rem;
   --bs-btn-padding-y: .25rem;
   --bs-btn-padding-x: .50rem;
   border-radius: var(--rad-sm)
}

.sidebar .switch-company-full .btn-compact i {
   margin-right: .25rem
}

.sidebar .switch-company-compact .sb-icon {
   width: 32px;
   height: 32px
}

.switch-company {
   margin-top: .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: .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: .35rem;
   padding: .18rem .6rem;
   border-radius: 999px;
   font-weight: 600;
   font-size: .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: .35rem !important;
   padding: .18rem .6rem !important;
   border-radius: 999px !important;
   font-weight: 600 !important;
   font-size: .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: .4rem;
   font-size: .75rem;
   line-height: 1;
   padding: .35rem .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: .15rem .4rem;
   border-radius: .5rem;
   background: rgba(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, .06);
   border-color: rgba(255, 255, 255, .18);
   color: #fff;
}

:where(body.dark-mode, [data-bs-theme="dark"]) .chip .chip-val {
   background: rgba(255, 255, 255, .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 .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: .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, .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 .14s ease,
      box-shadow .14s ease,
      background-color .14s ease,
      border-color .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, .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, .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(.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, .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, .75);
   background: var(--card, #fff);
   color: var(--bs-primary, #0d6efd);
   display: inline-flex;
   align-items: center;
   justify-content: center;
   padding: 0;
   transition: transform .12s ease, background .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, .08);
   transform: translateY(-1px);
}

body.dark-mode .modal-x {
   background: var(--card, #0b1620);
}