/* ======================================================
   modales.css — Estilos unificados de modales
   Sistema neumórfico pearl-blue (variables --mr-*)
====================================================== */

/* =========================
   VARIABLES
========================= */
:root {
  --mr-bg: oklch(0.938 0.016 235);
  --mr-surface: oklch(0.948 0.016 235);
  --mr-surface2: oklch(0.938 0.018 235);
  --mr-border: oklch(0.896 0.022 235);
  --mr-sd: oklch(0.760 0.032 235 / 0.55);
  --mr-sl: oklch(1 0 0 / 0.82);
  --mr-sd-sm: oklch(0.760 0.032 235 / 0.42);
  --mr-sl-sm: oklch(1 0 0 / 0.76);
  --mr-ink-0: oklch(0.30 0.040 250);
  --mr-ink-1: oklch(0.42 0.035 250);
  --mr-ink-2: oklch(0.58 0.028 250);
  --mr-ink-3: oklch(0.72 0.022 250);
  --mr-accent: oklch(0.58 0.12 245);
  --mr-good: oklch(0.56 0.14 165);
  --mr-danger: oklch(0.55 0.18 25);
}

/* Variables blanco-neutro scoped dentro de cualquier modal */
.modal-overlay,
.sr-modal {
  --mr-bg: oklch(0.958 0.002 220);
  --mr-surface: oklch(0.974 0.002 220);
  --mr-surface2: oklch(0.961 0.002 220);
  --mr-border: oklch(0.906 0.004 220);
  --mr-sd: oklch(0.688 0.012 220 / 0.32);
  --mr-sl: oklch(1 0 0 / 0.92);
  --mr-sd-sm: oklch(0.688 0.012 220 / 0.22);
  --mr-sl-sm: oklch(1 0 0 / 0.88);
}

/* =========================
   OVERLAY / BACKDROP
========================= */
.modal-overlay {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: -1;
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
  background: oklch(0.15 0.04 245 / 0.62) !important;
  backdrop-filter: blur(4px) !important;
}

.modal-overlay::before {
  content: none !important;
}

.modal-overlay.active {
  opacity: 1;
  pointer-events: auto;
  z-index: 9999;
}

.modal-overlay .modal-content {
  position: relative;
  width: min(520px, 92vw);
  animation: mrModalIn .18s ease;
}

@keyframes mrModalIn {
  from {
    transform: translateY(10px) scale(.97);
    opacity: 0;
  }

  to {
    transform: none;
    opacity: 1;
  }
}

/* =========================
   TARJETA DE FORMULARIO
========================= */
.modal-overlay .form-card,
.modal-overlay .form-card.form-card-lg {
  background: var(--mr-surface) !important;
  border-radius: 22px !important;
  border: 1px solid var(--mr-border) !important;
  box-shadow:
    14px 14px 32px var(--mr-sd),
    -6px -6px 18px oklch(1 0 0 / 0.45) !important;
  padding: 26px 26px 20px !important;
  backdrop-filter: none !important;
  color: var(--mr-ink-0) !important;
}

.modal-overlay .form-card h3,
.modal-overlay .form-card>h3 {
  font-size: 17px !important;
  font-weight: 800 !important;
  color: var(--mr-ink-0) !important;
  text-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 20px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--mr-border) !important;
}

.modal-overlay .form-card h3 i,
.modal-overlay .form-card>h3 i {
  color: var(--mr-accent) !important;
}

/* =========================
   GRUPOS DE FORMULARIO
========================= */
.modal-overlay .form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}

.modal-overlay .form-group label {
  font-size: 11.5px !important;
  font-weight: 700 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  color: var(--mr-ink-2) !important;
  text-shadow: none !important;
}

.modal-overlay .form-group input,
.modal-overlay .form-group select,
.modal-overlay .form-group textarea,
.modal-overlay .form-inline input,
.modal-overlay .form-inline select {
  width: 100%;
  padding: 11px 14px !important;
  border-radius: 13px !important;
  border: 1px solid var(--mr-border) !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--mr-ink-0) !important;
  outline: none !important;
  background: var(--mr-surface2) !important;
  backdrop-filter: none !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm) !important;
  transition: box-shadow .14s ease;
  color-scheme: light;
}

.modal-overlay .form-group input:focus,
.modal-overlay .form-group select:focus,
.modal-overlay .form-group textarea:focus {
  border-color: oklch(0.72 0.08 245) !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm),
    0 0 0 3px oklch(0.86 0.06 245 / 0.5) !important;
}

.modal-overlay .form-group input::placeholder,
.modal-overlay input::placeholder {
  color: var(--mr-ink-3) !important;
}

.modal-overlay .form-group select option {
  background: #fff;
  color: #0b2d4f;
}

/* =========================
   ACCIONES (BOTONES)
========================= */
.modal-overlay .form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--mr-border);
}

/* =========================
   BOTONES COMPARTIDOS
========================= */
.btn-secondary {
  padding: 10px 18px;
  border-radius: 13px;
  border: 1px solid var(--mr-border);
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  color: var(--mr-ink-1);
  background: var(--mr-surface);
  box-shadow:
    3px 3px 8px var(--mr-sd-sm),
    -2px -2px 6px var(--mr-sl-sm);
  transition: box-shadow .14s ease, transform .12s ease;
}

.btn-secondary:hover {
  box-shadow:
    1px 1px 5px var(--mr-sd-sm),
    -1px -1px 4px var(--mr-sl-sm);
  transform: translateY(-1px);
}

.btn-secondary:active {
  transform: translateY(0);
}

.btn-primary,
.modal-overlay .btn-primary {
  padding: 10px 22px;
  border-radius: 13px;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  background: var(--mr-accent);
  box-shadow:
    4px 4px 12px oklch(0.62 0.10 245 / 0.45),
    -2px -2px 8px oklch(1 0 0 / 0.6);
  transition: box-shadow .14s ease, transform .12s ease, filter .12s ease;
}

.btn-primary:hover,
.modal-overlay .btn-primary:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
}

.btn-primary:active,
.modal-overlay .btn-primary:active {
  transform: translateY(0);
}

.btn-primary:disabled,
.modal-overlay .btn-primary:disabled {
  background: #d1d5db;
  color: #9ca3af;
  box-shadow: none;
  cursor: not-allowed;
  filter: none;
  transform: none;
}

/* =========================================================
   MODALES COMPLEJOS — patrón sin .form-card
   (.modal-content > .modal-header + .modal-body + .modal-footer)
   Usados en: recibos, entrada, compra, salida, devolucion,
              notacredito, traspaso, salidaDocumento
========================================================= */
.modal-overlay .modal-content:not(:has(.form-card)) {
  background: var(--mr-surface) !important;
  border: 1px solid var(--mr-border) !important;
  border-radius: 22px !important;
  box-shadow:
    14px 14px 32px var(--mr-sd),
    -6px -6px 18px oklch(1 0 0 / 0.45) !important;
  backdrop-filter: none !important;
  color: var(--mr-ink-0) !important;
  overflow: hidden !important;
}

/* Cabecera — todas las variantes de nombre */
.modal-overlay .modal-content .modal-header,
.modal-overlay .modal-content .modal-head,
.modal-overlay .modal-content .modal-top {
  background: var(--mr-surface2) !important;
  border-bottom: 1px solid var(--mr-border) !important;
  padding: 16px 22px !important;
  backdrop-filter: none !important;
}

.modal-overlay .modal-content .modal-header h3,
.modal-overlay .modal-content .modal-header h4,
.modal-overlay .modal-content .modal-head h3,
.modal-overlay .modal-content .modal-head h4,
.modal-overlay .modal-content .modal-top h3,
.modal-overlay .modal-content .modal-top h4 {
  font-size: 17px !important;
  font-weight: 800 !important;
  color: var(--mr-ink-0) !important;
  text-shadow: none !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.modal-overlay .modal-content .modal-header h3 i,
.modal-overlay .modal-content .modal-header h4 i,
.modal-overlay .modal-content .modal-head h3 i,
.modal-overlay .modal-content .modal-head h4 i,
.modal-overlay .modal-content .modal-top h3 i,
.modal-overlay .modal-content .modal-top h4 i {
  color: var(--mr-accent) !important;
}

/* Cuerpo */
.modal-overlay .modal-content .modal-body,
.modal-overlay .modal-content .modal-body-custom {
  color: var(--mr-ink-0) !important;
}

/* Pie */
.modal-overlay .modal-content .modal-footer,
.modal-overlay .modal-content .modal-footer-salida,
.modal-overlay .modal-content .modal-footer-custom {
  background: var(--mr-surface2) !important;
  border-top: 1px solid var(--mr-border) !important;
  padding: 14px 22px !important;
  backdrop-filter: none !important;
}

/* Filas de formulario en modales complejos */
.modal-overlay .form-row,
.modal-overlay .liq-form-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 14px;
}

.modal-overlay .form-row .form-group,
.modal-overlay .liq-form-row .form-group {
  flex: 1;
  min-width: 0;
  margin-bottom: 0;
}

/* btn-cancel / btn-save — alias usados en liquidacionCobranza */
.modal-overlay .btn-cancel,
.modal-overlay .btn-save {
  padding: 10px 18px;
  border-radius: 13px;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  transition: box-shadow .14s ease, transform .12s ease;
}

.modal-overlay .btn-cancel {
  border: 1px solid var(--mr-border);
  color: var(--mr-ink-1);
  background: var(--mr-surface);
  box-shadow: 3px 3px 8px var(--mr-sd-sm), -2px -2px 6px var(--mr-sl-sm);
}

.modal-overlay .btn-cancel:hover {
  transform: translateY(-1px);
}

.modal-overlay .btn-save {
  border: none;
  color: #fff;
  background: var(--mr-accent);
  box-shadow: 4px 4px 12px oklch(0.62 0.10 245 / 0.45), -2px -2px 8px oklch(1 0 0 / 0.6);
}

.modal-overlay .btn-save:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
}

/* =========================================================
   MODAL REPORTE — diseño neumórfico pearl-blue
========================================================= */
.sr-modal .modal-dialog {
  max-width: 900px !important;
  width: 100%;
  margin: 1.75rem auto !important;
}

.sr-modal-content {
  border-radius: 22px !important;
  border: 1px solid var(--mr-border) !important;
  background: var(--mr-surface) !important;
  box-shadow:
    14px 14px 32px var(--mr-sd),
    -6px -6px 18px oklch(1 0 0 / 0.45) !important;
}

.sr-modal-header {
  background: var(--mr-surface2) !important;
  border-bottom: 1px solid var(--mr-border) !important;
  padding: 16px 22px !important;
  border-radius: 22px 22px 0 0 !important;
}

.sr-modal-header .modal-title {
  margin: 0 !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  color: var(--mr-ink-0) !important;
  text-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.sr-modal-header .modal-title i {
  color: var(--mr-accent) !important;
}

.sr-btn-close {
  filter: none !important;
  opacity: 0.45 !important;
}

.sr-btn-close:hover {
  opacity: 1 !important;
}

.sr-modal-body {
  background: var(--mr-surface) !important;
  color: var(--mr-ink-0) !important;
  padding: 20px 22px !important;
}

.sr-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.sr-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sr-form-group label {
  font-size: 11.5px !important;
  font-weight: 700 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  color: var(--mr-ink-2) !important;
}

.sr-input {
  width: 100%;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 13px !important;
  border: 1px solid var(--mr-border) !important;
  background: var(--mr-surface2) !important;
  color: var(--mr-ink-0) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  outline: none;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm) !important;
  color-scheme: light;
}

.sr-input:focus {
  border-color: oklch(0.72 0.08 245) !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm),
    0 0 0 3px oklch(0.86 0.06 245 / 0.5) !important;
}

.sr-input::placeholder {
  color: var(--mr-ink-3) !important;
}

.sr-input option {
  background: #fff;
  color: #0b2d4f;
}

input[type="number"].sr-input::-webkit-inner-spin-button,
input[type="number"].sr-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"].sr-input {
  -moz-appearance: textfield;
}

.sr-sep {
  height: 1px;
  margin: 18px 0 16px;
  background: var(--mr-border);
}

.sr-block {
  margin-top: 18px;
}

.sr-block-label {
  display: block;
  margin-bottom: 10px;
  font-size: 11.5px !important;
  font-weight: 700 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  color: var(--mr-ink-2) !important;
}

.sr-radio-group {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.sr-radio-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 13px !important;
  background: var(--mr-surface2) !important;
  border: 1px solid var(--mr-border) !important;
  color: var(--mr-ink-0) !important;
  font-weight: 700 !important;
  box-shadow:
    inset 1px 1px 4px var(--mr-sd-sm),
    inset -1px -1px 3px var(--mr-sl-sm) !important;
  cursor: pointer;
}

.sr-radio-item input[type="radio"] {
  accent-color: var(--mr-accent) !important;
}

.sr-info-box {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--mr-surface2) !important;
  border: 1px solid var(--mr-border) !important;
  color: var(--mr-ink-0) !important;
  font-size: 13px;
  font-weight: 600;
}

.sr-modal-footer {
  background: var(--mr-surface2) !important;
  border-top: 1px solid var(--mr-border) !important;
  padding: 14px 22px !important;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  border-radius: 0 0 22px 22px !important;
}

.sr-btn {
  border-radius: 13px;
  padding: 10px 18px;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}

.sr-btn:hover {
  transform: translateY(-1px);
}

.sr-btn:active {
  transform: translateY(0);
}

.sr-btn-soft,
.sr-btn-cancel {
  border: 1px solid var(--mr-border) !important;
  color: var(--mr-ink-1) !important;
  background: oklch(0.985 0.008 235) !important;
  box-shadow:
    3px 3px 8px oklch(0.780 0.030 235 / 0.45),
    -2px -2px 6px oklch(1 0 0 / 0.80) !important;
}

.sr-btn-soft:hover,
.sr-btn-cancel:hover {
  background: oklch(0.930 0.028 235) !important;
  box-shadow:
    4px 4px 10px oklch(0.720 0.035 235 / 0.55),
    -2px -2px 6px oklch(1 0 0 / 0.40) !important;
  transform: translateY(-1px) !important;
}

.sr-btn-primary {
  border: none !important;
  color: #fff !important;
  background: var(--mr-accent) !important;
  box-shadow:
    4px 4px 12px oklch(0.62 0.10 245 / 0.45),
    -2px -2px 8px oklch(1 0 0 / 0.6) !important;
}

.sr-btn-primary:hover {
  filter: brightness(1.08);
}

/* preview card (reportes) */
#rmVistaPreviaWrap .card {
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--mr-border);
  background: var(--mr-surface2);
  box-shadow: none;
}

#rmVistaPreviaWrap .card-header {
  background: var(--mr-surface);
  color: var(--mr-ink-0);
  font-weight: 900;
  border-bottom: 1px solid var(--mr-border);
}

#rmVistaPreviaWrap .table {
  margin-bottom: 0;
}

#rmVistaPreviaWrap .table th {
  background: var(--mr-surface);
  color: var(--mr-ink-0);
  font-weight: 900;
  text-align: center;
  border-color: var(--mr-border);
}

#rmVistaPreviaWrap .table td {
  background: var(--mr-surface2);
  color: var(--mr-ink-1);
  text-align: center;
  border-color: var(--mr-border);
}

/* responsive */
@media (max-width: 768px) {
  .sr-grid-2 {
    grid-template-columns: 1fr;
  }

  .sr-modal-body,
  .sr-modal-header,
  .sr-modal-footer {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .sr-radio-group {
    flex-direction: column;
  }
}

/* NeuSelect dentro de modales Bootstrap — z-index sobre backdrop */
.sr-modal .ns-opts,
.modal .ns-opts {
  z-index: 9999;
}

/* NeuSelect dentro de .modal-overlay — igualar color al de los inputs */
.modal-overlay .ns-trigger {
  background: var(--mr-surface2) !important;
  border-color: var(--mr-border) !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm) !important;
}

.modal-overlay .ns-wrap.open .ns-trigger {
  border-color: oklch(0.72 0.08 245) !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm),
    0 0 0 3px oklch(0.86 0.06 245 / 0.5) !important;
}

.modal-overlay .ns-opts {
  background: var(--mr-surface) !important;
  border-color: var(--mr-border) !important;
  box-shadow: 8px 8px 22px var(--mr-sd), -4px -4px 14px var(--mr-sl) !important;
}

.modal-overlay .ns-opt {
  border-bottom-color: var(--mr-border) !important;
}

.modal-overlay .ns-opt:hover,
.modal-overlay .ns-opt.ns-focused {
  background: var(--mr-surface2) !important;
}

/* NeuSelect dentro de .sr-modal — mismo tratamiento */
.sr-modal .ns-trigger {
  background: var(--mr-surface2) !important;
  border-color: var(--mr-border) !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm) !important;
}

.sr-modal .ns-wrap.open .ns-trigger {
  border-color: oklch(0.72 0.08 245) !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm),
    0 0 0 3px oklch(0.86 0.06 245 / 0.5) !important;
}

.sr-modal .ns-opts {
  background: var(--mr-surface) !important;
  border-color: var(--mr-border) !important;
  box-shadow: 8px 8px 22px var(--mr-sd), -4px -4px 14px var(--mr-sl) !important;
}

.sr-modal .ns-opt {
  border-bottom-color: var(--mr-border) !important;
}

.sr-modal .ns-opt:hover,
.sr-modal .ns-opt.ns-focused {
  background: var(--mr-surface2) !important;
}

/* reporte producto — extras */
#modalReporteProducto .sr-info-box {
  padding: 16px 18px;
}

#modalReporteProducto .sr-info-box .sr-form-group {
  margin-bottom: 0;
}

#modalReporteProducto #wrapRpPrecios .sr-form-group:first-child {
  margin-bottom: 12px;
}

#modalReporteProducto #wrapRpPrecios .sr-grid-2 {
  gap: 14px;
}

#modalReporteProducto #wrapRpCostos,
#modalReporteProducto #wrapRpCantidades {
  gap: 14px;
}

#modalReporteProducto .d-none {
  display: none !important;
}

#wrapRpPrecios .sr-form-group:first-child {
  margin-bottom: 14px;
}

#wrapRpPrecios .sr-grid-2 {
  gap: 14px;
}

/* =========================================================
   FLATPICKR — tema neumórfico pearl-blue
========================================================= */

/* Ocultar el input nativo original; mostrar solo el altInput */
input[type="date"].flatpickr-input {
  display: none !important;
}

/* El altInput hereda estilos neumórficos */
.neu-date-input {
  width: 100%;
  padding: 11px 36px 11px 14px !important;
  border-radius: 13px !important;
  border: 1px solid var(--mr-border) !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--mr-ink-0) !important;
  background: var(--mr-surface2) !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm) !important;
  cursor: pointer;
  outline: none;
  color-scheme: light;
  box-sizing: border-box;
}

.neu-date-input:focus {
  border-color: oklch(0.72 0.08 245) !important;
  box-shadow:
    inset 2px 2px 6px var(--mr-sd-sm),
    inset -2px -2px 6px var(--mr-sl-sm),
    0 0 0 3px oklch(0.86 0.06 245 / 0.5) !important;
}

.neu-date-input[readonly] {
  cursor: default;
}

/* Popup calendario — self-contained vars porque appendTo:body lo saca del scope del modal */
.flatpickr-calendar {
  --mr-surface: oklch(0.934 0.007 220);
  --mr-surface2: oklch(0.921 0.008 220);
  --mr-border: oklch(0.874 0.010 220);
  --mr-sd: oklch(0.688 0.012 220 / 0.46);
  --mr-sl: oklch(1 0 0 / 0.86);
  --mr-sd-sm: oklch(0.688 0.012 220 / 0.34);
  --mr-sl-sm: oklch(1 0 0 / 0.80);
  --mr-ink-0: oklch(0.30 0.040 250);
  --mr-ink-1: oklch(0.42 0.035 250);
  --mr-ink-2: oklch(0.58 0.028 250);
  --mr-ink-3: oklch(0.72 0.022 250);
  --mr-accent: oklch(0.58 0.12 245);
  font-family: 'Manrope', 'Segoe UI', system-ui, sans-serif !important;
  background: var(--mr-surface) !important;
  border: 1px solid var(--mr-border) !important;
  border-radius: 18px !important;
  box-shadow:
    14px 14px 32px var(--mr-sd),
    -6px -6px 18px oklch(1 0 0 / 0.45) !important;
  padding: 10px !important;
  /* 307.875 (dayContainer fijo de flatpickr) + 20px padding = 328px mínimo */
  width: 332px !important;
  z-index: 99999 !important;
}

.flatpickr-calendar.arrowTop::before,
.flatpickr-calendar.arrowTop::after,
.flatpickr-calendar.arrowBottom::before,
.flatpickr-calendar.arrowBottom::after {
  display: none !important;
}

/* Área de mes/año — solo colores, sin tocar height/padding internos de flatpickr */
.flatpickr-months {
  background: var(--mr-surface2) !important;
  border-radius: 12px 12px 0 0 !important;
}

.flatpickr-month {
  background: transparent !important;
  color: var(--mr-ink-0) !important;
  /* SIN height/padding — flatpickr posiciona internamente con absolute */
}

.flatpickr-current-month {
  color: var(--mr-ink-0) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  /* SIN padding/height — no romper el layout interno */
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
  background: transparent !important;
  color: var(--mr-ink-0) !important;
  font-weight: 700 !important;
  border: none !important;
  outline: none !important;
  -webkit-appearance: none;
}

.flatpickr-current-month input.cur-year {
  color: var(--mr-ink-0) !important;
  font-weight: 700 !important;
}

.numInputWrapper span {
  border-color: var(--mr-border) !important;
}

.numInputWrapper span svg path {
  fill: var(--mr-ink-2) !important;
}

/* Flechas nav */
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
  color: var(--mr-ink-1) !important;
  fill: var(--mr-ink-1) !important;
}

.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
  fill: var(--mr-accent) !important;
}

.flatpickr-months .flatpickr-prev-month svg path,
.flatpickr-months .flatpickr-next-month svg path {
  fill: inherit !important;
}

/* Días de la semana */
.flatpickr-weekdays {
  background: var(--mr-surface2) !important;
}

.flatpickr-weekdaycontainer {
  background: transparent !important;
}

span.flatpickr-weekday {
  background: transparent !important;
  color: var(--mr-ink-2) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  text-transform: uppercase !important;
}

/* Días */
.flatpickr-days {
  border: none !important;
}

.dayContainer {
  padding: 4px 0 !important;
}

.flatpickr-day {
  border-radius: 9px !important;
  color: var(--mr-ink-1) !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  border: none !important;
  max-width: 34px !important;
  height: 34px !important;
  line-height: 34px !important;
}

.flatpickr-day:hover {
  background: oklch(0.950 0.008 220) !important;
  color: var(--mr-ink-0) !important;
  border: none !important;
  box-shadow: 2px 2px 6px var(--mr-sd-sm), -1px -1px 4px var(--mr-sl-sm) !important;
}

.flatpickr-day.today {
  color: var(--mr-accent) !important;
  font-weight: 800 !important;
  border: 1px solid var(--mr-border) !important;
  background: transparent !important;
}

.flatpickr-day.today:hover {
  background: oklch(0.950 0.008 220) !important;
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover {
  background: var(--mr-accent) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 3px 3px 8px oklch(0.62 0.10 245 / 0.45) !important;
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
  color: var(--mr-ink-3) !important;
  opacity: .45 !important;
}

/* Time picker (producto: txtFinVenta) */
.flatpickr-time {
  border-top: 1px solid var(--mr-border) !important;
  background: var(--mr-surface2) !important;
  border-radius: 0 0 14px 14px !important;
  margin-top: 6px !important;
}

.flatpickr-time input,
.flatpickr-time .flatpickr-time-separator {
  color: var(--mr-ink-0) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
}

.flatpickr-time input:focus {
  background: oklch(0.955 0.008 220) !important;
}

/* Dentro de sr-modal */
.sr-modal .neu-date-input {
  min-height: 42px;
}

.sr-multiselect {
  position: relative;
  width: 100%;
}

.sr-multiselect-toggle {
  width: 100%;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(11, 45, 79, .12);
  background: #eaf2f6;
  box-shadow:
    inset 3px 3px 7px rgba(11, 45, 79, .12),
    inset -3px -3px 7px rgba(255, 255, 255, .85);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  color: #263b50;
  font-weight: 600;
}

.sr-multiselect-toggle:hover {
  border-color: rgba(41, 128, 185, .35);
}

.sr-multiselect-toggle i {
  font-size: 12px;
  color: #6d8092;
}

.sr-multiselect-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 2000;
  padding: 12px;
  border-radius: 16px;
  background: #eef5f8;
  border: 1px solid rgba(11, 45, 79, .12);
  box-shadow: 0 14px 35px rgba(11, 45, 79, .22);
  max-height: 230px;
  overflow-y: auto;
}

.sr-multiselect-actions {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}

.sr-multiselect-actions button {
  border: 0;
  border-radius: 10px;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  background: #dce9ef;
  color: #18344f;
  box-shadow:
    3px 3px 7px rgba(11, 45, 79, .12),
    -3px -3px 7px rgba(255, 255, 255, .85);
}

.sr-multiselect-actions button:hover {
  background: #d2e3eb;
}

.sr-check-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 10px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 700;
  color: #617489;
  cursor: pointer;
}

.sr-check-item:hover {
  background: rgba(41, 128, 185, .08);
}

.sr-check-item input {
  width: 16px;
  height: 16px;
  accent-color: #2d86c9;
  cursor: pointer;
}

.sr-check-item label {
  margin: 0;
  cursor: pointer;
}