/* ============================================================================
   qsalud-patient-app · app-fixes.css
   Overrides puntuales que antes vivían en wp_add_inline_style('qsalud-app-fixes').
   Migrados a archivo aparte para reducir HTML servido y permitir cache HTTP.
   Reescritos con los tokens del rediseño V2 (#2e5c90 sustituye al Wave Teal).
   ============================================================================ */

/* BUG-012: tabbar siempre por encima del FAB del chatbot AI Engine */
.qs-tabbar { z-index: 10001 !important; }

/* FAB Urgencias: por encima del contenido pero debajo del tabbar.
   Cuando hay sticky CTA activo, sube por encima del sticky para no quedar tapado. */
.qs-fab { z-index: 9999 !important; bottom: 110px !important; transition: bottom 200ms ease, transform 200ms ease; }
body.qs-has-sticky-cta .qs-fab { bottom: 184px !important; }

/* FAB IA central (rediseño V2) — mismo override que .qs-tabbar para mantenerse encima */
.qs-tab-fab { z-index: 10002 !important; }

/* Bottom sheet "Más": al abrirse debe cubrir tabbar y sticky CTA */
.qs-sheet-backdrop { z-index: 10100 !important; }
.qs-sheet          { z-index: 10110 !important; }

/* Respiración inferior para que el FAB no tape el último card */
main#qs-main-content { padding-bottom: 130px !important; }

/* Eyebrows / section titles más respirables, sentence-case */
.qs-section-title {
  text-transform: none !important;
  letter-spacing: 0.2px !important;
  font-weight: 800 !important;
}

/* Visual rec V2: ocultar el FAB del chatbot AI Engine encima del tabbar móvil */
@media (max-width: 720px) {
  .mwai-chatbot,
  .aiengine-chatbot,
  [class*='ai-engine'] { z-index: 9998 !important; }
}

/* Marcar la gateway DEV con un badge visual claro cuando exista */
li.payment_method_qs_local_test label::after,
li.payment_method_local_test_gateway label::after {
  content: 'DEV';
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 900;
  background: #FEF3C7;
  color: #B45309;
  border-radius: 999px;
  letter-spacing: 0.5px;
}

/* Sticky CTA: barra inferior fija con botón principal — evita scroll hasta el
   fondo para confirmar selección. Se ancla justo encima del tabbar móvil. */
.qs-cta-sticky {
  position: fixed;
  left: 0; right: 0;
  bottom: calc(108px + env(safe-area-inset-bottom));
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, rgba(246,244,239,0) 0%, rgba(246,244,239,.96) 30%, rgba(246,244,239,1) 100%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 10000;
  transform: translateY(120%);
  transition: transform 240ms cubic-bezier(.22,1,.36,1), opacity 240ms;
  opacity: 0;
  pointer-events: none;
}
.qs-cta-sticky.visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.qs-cta-sticky .qs-btn,
.qs-cta-sticky #qs-sticky-cta-btn {
  background: linear-gradient(135deg, var(--qs-brand, #2e5c90), var(--qs-brand-2, #1c3d66)) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 16px !important;
  padding: 14px 18px !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  width: 100% !important;
  box-shadow: 0 12px 32px -8px rgba(46,92,144,.45);
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}
.qs-cta-sticky #qs-sticky-cta-btn:disabled {
  opacity: .85;
  cursor: progress;
}
body.qs-has-sticky-cta main#qs-main-content { padding-bottom: 220px !important; }
@media (prefers-reduced-motion: reduce) {
  .qs-cta-sticky { transition: none; }
}

/* Stripe checkout integration — evitar overflows en el iframe */
.StripeElement,
.wc-stripe-card-element,
.payment_box,
#wc-stripe-payment-element,
.stripe-link-button { max-width: 100%; min-width: 0; }
#payment .payment_method_stripe .payment_box { overflow-x: hidden; }

/* Skeleton shimmer (loading states de listas) */
.qs-skel {
  background: linear-gradient(90deg, #eef2f7 0%, #f7fafc 50%, #eef2f7 100%);
  background-size: 200% 100%;
  animation: qs-skel-shimmer 1.4s ease-in-out infinite;
}
@keyframes qs-skel-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
@media (prefers-reduced-motion: reduce) {
  .qs-skel { animation: none; }
}
