@charset "UTF-8";
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

*, *:before, *:after {
  box-sizing: inherit;
}

html {
  font-size: 62.5%;
  box-sizing: border-box;
  height: 100%;
}

body {
  font-family: "Open Sans", sans-serif;
  font-size: 1.6rem;
  min-height: 100%;
}

.contenedor {
  width: 95%;
  max-width: 1200px;
  margin: 0 auto;
}

.contenedor-sm {
  max-width: 70rem;
  margin: 0 auto;
}

a {
  text-decoration: none;
}

img {
  max-width: 100%;
}

h1, h2, h3 {
  font-family: "Inter", sans-serif;
  margin: 0 0 2.5rem 0;
  font-weight: 900;
}

h1 {
  font-size: 6rem;
}

h2 {
  font-size: 5rem;
}

h3 {
  font-size: 4rem;
}

p {
  font-size: 2rem;
  color: #6b7280;
  line-height: 1.8;
}

/** Media Queries **/
.login {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background: linear-gradient(135deg, #5500c5 0%, #1f1d20 100%);
}
.login__contenedor {
  background: linear-gradient(135deg, #000 0%, #5500c5 100%);
  padding: 4rem;
  border-radius: 1rem;
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.1);
  width: 95%;
  max-width: 50rem;
}
.login__heading {
  text-align: center;
  font-family: "Inter", sans-serif;
  font-size: 3rem;
  color: #FFFFFF;
  -webkit-text-stroke: 1px #5500c5;
  margin-bottom: 3rem;
}
.login__formulario {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.login__campo {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.login__label {
  font-family: "Inter", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #FFFFFF;
  text-transform: uppercase;
}
.login__input {
  padding: 1.2rem 1.5rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  font-size: 1.6rem;
  font-family: "Open Sans", sans-serif;
  color: #000;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.login__input::placeholder {
  color: #6b7280;
}
.login__input:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
}
.login__select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1.5rem center;
  padding-right: 3.5rem;
  cursor: pointer;
}
.login__checkboxes {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
  gap: 1rem;
  padding: 1.2rem 1.5rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  background-color: #FFFFFF;
  max-height: 20rem;
  overflow-y: auto;
}
.login__checkbox-item {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  font-family: "Open Sans", sans-serif;
  font-size: 1.4rem;
  color: #000;
  cursor: pointer;
}
.login__checkbox-item input[type=checkbox] {
  width: 1.8rem;
  height: 1.8rem;
  accent-color: #2563EB;
  cursor: pointer;
}
.login__checkbox-item span {
  user-select: none;
}
.login__hint {
  font-family: "Open Sans", sans-serif;
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.6);
  margin-top: 0.3rem;
}
.login__separador {
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  margin-bottom: 0.5rem;
}
.login__subtitulo {
  font-family: "Inter", sans-serif;
  font-size: 1.6rem;
  color: #FFFFFF;
  margin: 0 0 0.5rem;
}
.login__submit {
  background-color: #5500c5;
  padding: 1.5rem 4rem;
  color: #FFFFFF;
  font-size: 1.6rem;
  display: inline-block;
  font-weight: 700;
  border: none;
  transition-property: background-color;
  transition-duration: 0.3s;
  text-align: center;
  display: block;
  width: 100%;
}
@media (min-width: 768px) {
  .login__submit {
    width: auto;
  }
}
.login__submit:hover {
  background-color: rgb(62.9949238579, 0, 146);
  cursor: pointer;
}
.login__submit {
  margin-top: 1rem;
  padding: 1.5rem;
  border-radius: 0.5rem;
  font-size: 1.8rem;
  font-family: "Inter", sans-serif;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.login__enlace {
  margin-top: 2rem;
  text-align: center;
}
.login__enlace a {
  color: #FFFFFF;
  font-family: "Open Sans", sans-serif;
  font-size: 1.4rem;
  text-decoration: none;
}
.login__enlace a:hover {
  text-decoration: underline;
}
.login__enlace--rapida {
  margin-top: 1.5rem;
}
.login__btn-rapida {
  display: inline-block;
  background-color: #5500c5;
  color: #FFFFFF !important;
  padding: 1.2rem 3rem;
  border-radius: 0.5rem;
  font-family: "Inter", sans-serif;
  font-size: 1.5rem !important;
  font-weight: 700;
  text-decoration: none !important;
  transition: background-color 0.3s ease, transform 0.2s ease;
}
.login__btn-rapida:hover {
  background-color: rgb(62.9949238579, 0, 146);
  transform: translateY(-2px);
  text-decoration: none !important;
}

.alertas {
  margin-bottom: 2rem;
}

.alerta {
  padding: 1.2rem 1.5rem;
  border-radius: 0.5rem;
  font-size: 1.4rem;
  font-family: "Open Sans", sans-serif;
  margin-bottom: 1rem;
  text-align: center;
  font-weight: 700;
}
.alerta--error {
  background-color: rgb(241.2857142857, 172.7142857143, 172.7142857143);
  color: rgb(180, 30, 30);
  border: 1px solid rgb(180, 30, 30);
}
.alerta--exito {
  background-color: white;
  color: rgb(66.2426035503, 223.7573964497, 161.2721893491);
  border: 1px solid #6ee7b7;
}

.panel {
  min-height: 100vh;
  background: linear-gradient(135deg, #5500c5 0%, #000 100%);
  padding: 3rem 0;
}
.panel__header {
  background: linear-gradient(135deg, #5500c5 0%, #000 100%);
  padding: 3rem;
  border-radius: 1rem;
  margin-bottom: 3rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.1);
  flex-wrap: wrap;
  gap: 2rem;
}
.panel__usuario {
  flex: 1;
}
.panel__bienvenida {
  font-family: "Inter", sans-serif;
  font-size: 2.8rem;
  color: #FFFFFF;
  margin-bottom: 0.5rem;
}
.panel__bienvenida span {
  color: #6ee7b7;
  font-weight: 900;
}
.panel__cedula {
  font-size: 1.8rem;
  color: #FFFFFF;
  margin: 0;
  font-weight: bold;
}
.panel__cuenta {
  font-size: 1.8rem;
  color: #FFFFFF;
  margin: 0.3rem 0 0;
  font-weight: bold;
}
.panel__cuenta strong {
  font-weight: 800;
  color: #FFFFFF;
  letter-spacing: 0.03em;
}
.panel__asignacion {
  display: flex;
  gap: 2rem;
  margin-top: 0.8rem;
  flex-wrap: wrap;
  align-items: center;
}
.panel__marca, .panel__tiendas, .panel__punto-venta {
  font-size: 1.8rem;
  color: #FFFFFF;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  font-weight: bold;
}
.panel__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.3rem 0.8rem;
  border-radius: 2rem;
  font-size: 1.6rem;
  font-weight: bold;
}
.panel__badge--marca {
  background-color: #ede9fe;
  color: #6d28d9;
}
.panel__badge--marca[style*=background-color] {
  text-shadow: 0 3px 3px rgb(0, 0, 0);
}
.panel__badge--tienda {
  background-color: #e0e7ff;
  color: #3730a3;
}
.panel__badge--tienda[style*=background-color] {
  text-shadow: 0 3px 3px rgb(0, 0, 0);
}
.panel__badge--pdv {
  background-color: #fef3c7;
  color: #92400e;
  margin-left: 1rem;
}
.panel__badge-logo {
  width: 3rem;
  height: 3rem;
  object-fit: contain;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0);
  flex-shrink: 0;
}
.panel__sin-asignar {
  font-size: 1.1rem;
  color: #94a3b8;
  font-style: italic;
}
.panel__pdv-cambiar {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.4rem;
  padding: 0.2rem 0.4rem;
  border-radius: 0.3rem;
  transition: background-color 0.2s ease;
}
.panel__pdv-cambiar:hover {
  background-color: rgba(255, 255, 255, 0.15);
}
.panel__pdv-selector {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  margin-top: 0.5rem;
  max-width: 40rem;
}
.panel__pdv-checkboxes {
  max-height: 20rem;
  overflow-y: auto;
  background-color: rgba(255, 255, 255, 0.08);
  border-radius: 0.5rem;
  padding: 0.8rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.panel__pdv-grupo {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.panel__pdv-grupo strong {
  font-size: 1.2rem;
  color: #cbd5e1;
  margin-bottom: 0.2rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  padding-bottom: 0.2rem;
}
.panel__pdv-checkbox-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.3rem;
  cursor: pointer;
  padding: 0.2rem 0.4rem;
  border-radius: 0.3rem;
  transition: background-color 0.2s ease;
}
.panel__pdv-checkbox-item:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.panel__pdv-checkbox-item input[type=checkbox] {
  accent-color: #6ee7b7;
}
.panel__pdv-botones {
  display: flex;
  gap: 0.8rem;
}
.panel__pdv-guardar {
  padding: 0.5rem 1.2rem;
  background-color: #6ee7b7;
  color: #FFFFFF;
  border: none;
  border-radius: 0.4rem;
  font-size: 1.2rem;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.panel__pdv-guardar:hover {
  background-color: rgb(66.2426035503, 223.7573964497, 161.2721893491);
}
.panel__pdv-guardar:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.panel__pdv-cancelar-btn {
  padding: 0.5rem 1.2rem;
  background-color: transparent;
  color: #94a3b8;
  border: 1px solid #94a3b8;
  border-radius: 0.4rem;
  font-size: 1.2rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.panel__pdv-cancelar-btn:hover {
  color: #FFFFFF;
  border-color: #FFFFFF;
}
.panel__logout {
  background-color: #7400d3;
  padding: 1.5rem 4rem;
  color: #FFFFFF;
  font-size: 1.6rem;
  display: inline-block;
  font-weight: 700;
  border: none;
  transition-property: background-color;
  transition-duration: 0.3s;
  text-align: center;
  display: block;
  width: 100%;
}
@media (min-width: 768px) {
  .panel__logout {
    width: auto;
  }
}
.panel__logout:hover {
  background-color: rgb(87.9620853081, 0, 160);
  cursor: pointer;
}
.panel__logout {
  padding: 1rem 2.5rem;
  font-size: 1.8rem;
  border-radius: 0.5rem;
}
.panel__resumen {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-bottom: 3rem;
}
.panel__contenido {
  display: grid;
  gap: 3rem;
  margin-bottom: 3rem;
}
@media (min-width: 768px) {
  .panel__contenido {
    grid-template-columns: 1fr 1fr;
  }
}
.panel__card {
  background: linear-gradient(135deg, #5500c5 0%, #000 100%);
  padding: 3rem;
  border-radius: 1rem;
  box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.1);
}
.panel__card--pagadas {
  grid-column: 1/-1;
  border-top: 4px solid #10b981;
}
.panel__pagadas-resumen {
  font-size: 1.5rem;
  color: #334155;
  margin-bottom: 2rem;
  padding: 1.2rem 1.5rem;
  background-color: #f0fdf4;
  border-radius: 0.5rem;
  border-left: 4px solid #10b981;
}
.panel__pagadas-resumen strong {
  color: #047857;
}
.panel__titulo {
  font-family: "Inter", sans-serif;
  font-size: 2.2rem;
  color: #FFFFFF;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid #2563EB;
}
.panel__formulario {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.panel__campo {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.panel__label {
  font-family: "Inter", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #FFFFFF;
  text-transform: uppercase;
}
.panel__input, .panel__textarea {
  padding: 1.2rem 1.5rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  font-size: 1.6rem;
  font-family: "Open Sans", sans-serif;
  color: #000;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.panel__input:focus, .panel__textarea:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
}
.panel__input--tienda, .panel__textarea--tienda {
  font-weight: 700;
}
.panel__tienda-select-wrapper {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.panel__tienda-preview {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.panel__tienda-preview-logo {
  width: 3rem;
  height: 3rem;
  object-fit: contain;
  border-radius: 0.4rem;
  border: 1px solid #e2e8f0;
  background: #fff;
  padding: 0.2rem;
}
.panel__tienda-preview-color {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  border: 2px solid rgba(0, 0, 0, 0.15);
  flex-shrink: 0;
}
.panel__textarea {
  resize: vertical;
  min-height: 10rem;
}
.panel__file {
  padding: 1rem;
  border: 2px dashed #d1d5db;
  border-radius: 0.5rem;
  font-size: 1.4rem;
  cursor: pointer;
  transition: border-color 0.3s ease;
  color: #FFFFFF;
}
.panel__file:hover {
  border-color: #2563EB;
}
.panel__acciones {
  display: flex;
  gap: 1rem;
  align-items: center;
}
.panel__submit {
  background-color: #2563EB;
  padding: 1.5rem 4rem;
  color: #FFFFFF;
  font-size: 1.6rem;
  display: inline-block;
  font-weight: 700;
  border: none;
  transition-property: background-color;
  transition-duration: 0.3s;
  text-align: center;
  display: block;
  width: 100%;
}
@media (min-width: 768px) {
  .panel__submit {
    width: auto;
  }
}
.panel__submit:hover {
  background-color: rgb(18.5714285714, 76.1428571429, 202.4285714286);
  cursor: pointer;
}
.panel__submit {
  margin-top: 1rem;
  padding: 1.5rem;
  border-radius: 0.5rem;
  font-size: 1.8rem;
  flex: 1;
}
.panel__cancelar {
  background-color: #6b7280;
  padding: 1.5rem 4rem;
  color: #FFFFFF;
  font-size: 1.6rem;
  display: inline-block;
  font-weight: 700;
  border: none;
  transition-property: background-color;
  transition-duration: 0.3s;
  text-align: center;
  display: block;
  width: 100%;
}
@media (min-width: 768px) {
  .panel__cancelar {
    width: auto;
  }
}
.panel__cancelar:hover {
  background-color: rgb(83.7787234043, 89.2595744681, 100.2212765957);
  cursor: pointer;
}
.panel__cancelar {
  margin-top: 1rem;
  padding: 1.5rem;
  border-radius: 0.5rem;
  font-size: 1.8rem;
  cursor: pointer;
  border: none;
}
.panel__vacio {
  text-align: center;
  color: #6b7280;
  font-size: 1.6rem;
  padding: 3rem 0;
}
.panel__facturas {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  max-height: 60rem;
  overflow-y: auto;
}

.resumen-row {
  background: linear-gradient(135deg, rgba(85, 0, 197, 0.6) 0%, rgba(0, 0, 0, 0.8) 100%);
  border-radius: 1rem;
  padding: 2rem;
  border-left: 4px solid #6ee7b7;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.resumen-row:hover {
  transform: translateY(-2px);
  box-shadow: 0 0.8rem 2.5rem rgba(0, 0, 0, 0.3);
}
.resumen-row--sin-pagar {
  border-left-color: #2563EB;
}
.resumen-row--pagadas {
  border-left-color: #10b981;
}
.resumen-row__titulo {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.resumen-row__titulo h3 {
  font-family: "Inter", sans-serif;
  font-size: 1.8rem;
  color: #FFFFFF;
  margin: 0;
  font-weight: 700;
}
.resumen-row__icono {
  font-size: 2.2rem;
}
.resumen-row__mes {
  font-weight: 400;
  font-size: 1.4rem;
  color: rgba(255, 255, 255, 0.6);
  margin-left: 0.5rem;
}
.resumen-row__cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: 1.2rem;
}
@media (max-width: 600px) {
  .resumen-row__cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

.resumen-card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 1.5rem 1.2rem;
  border-radius: 0.8rem;
  text-align: center;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}
.resumen-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: rgba(255, 255, 255, 0.2);
  transition: background 0.3s ease;
}
.resumen-card:hover {
  background: rgba(255, 255, 255, 0.08);
  transform: translateY(-2px);
  box-shadow: 0 0.4rem 1.5rem rgba(0, 0, 0, 0.2);
}
.resumen-card--total::before {
  background: #2563EB;
}
.resumen-card--aprobada::before {
  background: #10b981;
}
.resumen-card--pendiente::before {
  background: #F59E0B;
}
.resumen-card--rechazada::before {
  background: rgb(180, 30, 30);
}
.resumen-card--ganado::before {
  background: linear-gradient(90deg, #2563EB, #10b981);
}
.resumen-card--pagado-total::before {
  background: #10b981;
}
.resumen-card--pagado-monto::before {
  background: linear-gradient(90deg, #10b981, #6ee7b7);
}
.resumen-card--familiar::before {
  background: #3b82f6;
}
.resumen-card--personal::before {
  background: #F59E0B;
}
.resumen-card__numero {
  font-family: "Inter", sans-serif;
  font-size: 2.8rem;
  font-weight: 900;
  color: #FFFFFF;
  margin: 0;
  opacity: 0.3;
  transition: opacity 0.5s ease, transform 0.5s ease;
  transform: translateY(5px);
}
.resumen-card__numero--loaded {
  opacity: 1;
  transform: translateY(0);
}
.resumen-card__label {
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.6);
  margin: 0.4rem 0 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 700;
}

.factura-item {
  background: linear-gradient(135deg, #5500c5 0%, #000 100%);
  display: flex;
  align-items: center;
  padding: 1.5rem;
  border: 1px solid #e5e7eb;
  border-radius: 0.5rem;
  transition: all 0.3s ease;
  gap: 1.5rem;
}
.factura-item:hover {
  box-shadow: 0 0.2rem 1rem rgba(0, 0, 0, 0.1);
  border-color: #2563EB;
}
.factura-item__miniatura {
  flex-shrink: 0;
  width: 6rem;
  height: 8rem;
  border-radius: 0.5rem;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  cursor: pointer;
}
.factura-item__miniatura:hover {
  border-color: #2563EB;
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
}
.factura-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  cursor: pointer;
  transition: transform 0.3s ease;
}
.factura-item__img:hover {
  transform: scale(1.05);
}
.factura-item__info {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  flex: 1;
}
.factura-item__numero {
  font-family: "Inter", sans-serif;
  font-size: 2rem;
  font-weight: bold;
  color: #FFFFFF;
  margin: 0;
}
.factura-item__fecha {
  font-size: 1.5rem;
  color: #FFFFFF;
  margin: 0;
}
.factura-item__monto {
  font-size: 2rem;
  font-weight: bold;
  color: #FFFFFF;
  margin: 0;
}
.factura-item__licencia {
  margin: 0;
}
.factura-item__badge {
  display: inline-block;
  padding: 0.2rem 0.8rem;
  border-radius: 1rem;
  font-size: 1.1rem;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.factura-item__badge--familiar {
  background-color: rgb(164.0355329949, 95, 255);
  color: #FFFFFF;
}
.factura-item__badge--personal {
  background-color: #F59E0B;
  color: #FFFFFF;
}
.factura-item__hora {
  font-size: 2rem;
  color: #FFFFFF;
  margin: 0;
}
.factura-item__acciones {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.8rem;
  flex-shrink: 0;
}
.factura-item__estado {
  padding: 0.5rem 1.2rem;
  border-radius: 2rem;
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.factura-item__estado--pendiente {
  background-color: rgb(40.9898477157, 0, 95);
  color: rgb(196.9291338583, 126.7125984252, 8.0708661417);
  border: #F59E0B 2px solid;
}
.factura-item__estado--aprobada {
  background-color: rgb(40.9898477157, 0, 95);
  color: rgb(66.2426035503, 223.7573964497, 161.2721893491);
  border: #6ee7b7 2px solid;
}
.factura-item__estado--rechazada {
  background-color: rgb(40.9898477157, 0, 95);
  color: rgb(180, 30, 30);
  border: rgb(180, 30, 30) 2px solid;
}
.factura-item__estado--pagada {
  background-color: rgb(40.9898477157, 0, 95);
  color: rgb(66.2426035503, 223.7573964497, 161.2721893491);
  border: #6ee7b7 2px solid;
}
.factura-item__tienda {
  font-size: 1.8rem;
  color: #FFFFFF;
  margin: 0;
  font-style: italic;
}
.factura-item--pagada {
  border-left: 3px solid #10b981;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.15) 0%, #000 100%);
  display: grid;
  grid-template-columns: auto 1fr 1fr auto;
  align-items: center;
  gap: 2rem;
  padding: 1.8rem 2rem;
}
@media (max-width: 600px) {
  .factura-item--pagada {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}
.factura-item__detalle-pago {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding-left: 1.5rem;
  border-left: 2px solid rgba(16, 185, 129, 0.3);
}
.factura-item__fecha-factura, .factura-item__fecha-pago {
  font-size: 1.4rem;
  color: rgba(255, 255, 255, 0.85);
  margin: 0;
}
.factura-item__fecha-pago {
  color: #6ee7b7;
  font-weight: 700;
}
.factura-item__label {
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: rgba(255, 255, 255, 0.5);
  margin-right: 0.4rem;
}
.factura-item__editar {
  background-color: #5500c5;
  color: #FFFFFF;
  border: none;
  padding: 0.5rem 1.2rem;
  border-radius: 2.5rem;
  font-size: 1.8rem;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.3s ease;
}
.factura-item__editar:hover {
  background-color: rgb(62.9949238579, 0, 146);
}
.factura-item__comentario {
  font-size: 1.2rem;
  color: rgb(180, 30, 30);
  margin: 0;
  padding: 0.5rem 0.8rem;
  background-color: rgb(242.7428571429, 181.4571428571, 181.4571428571);
  border-radius: 0.4rem;
  border-left: 3px solid rgb(180, 30, 30);
  max-width: 20rem;
  word-wrap: break-word;
}
.factura-item__comentario strong {
  font-weight: 700;
}
.factura-item--rechazada-movii {
  border: 2px solid #f59e0b !important;
  background: linear-gradient(135deg, #78350f 0%, #451a03 100%) !important;
  position: relative;
}
.factura-item__alerta-movii {
  display: flex;
  align-items: flex-start;
  gap: 0.8rem;
  width: 100%;
  background: rgba(245, 158, 11, 0.15);
  border: 1px solid rgba(245, 158, 11, 0.3);
  border-radius: 0.5rem;
  padding: 1rem 1.2rem;
  margin-top: 0.5rem;
}
.factura-item__alerta-movii-icono {
  font-size: 1.8rem;
  flex-shrink: 0;
}
.factura-item__alerta-movii-texto {
  font-size: 1.2rem;
  color: #fcd34d;
  line-height: 1.5;
}
.factura-item__alerta-movii-texto strong {
  display: block;
  font-size: 1.3rem;
  color: #fbbf24;
  margin-bottom: 0.3rem;
}
.factura-item__alerta-movii-texto p {
  margin: 0;
  color: #fde68a;
}
.factura-item__estado--rechazada-movii {
  background-color: #f59e0b !important;
  color: #78350f !important;
  font-weight: 700;
  padding: 0.3rem 0.8rem;
  border-radius: 0.3rem;
  font-size: 1.1rem;
}

.pagadas-alerta-movii {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.2), rgba(239, 68, 68, 0.15));
  border: 2px solid #f59e0b;
  border-radius: 0.8rem;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  grid-column: 1/-1;
}
.pagadas-alerta-movii__icono {
  font-size: 2.4rem;
  flex-shrink: 0;
}
.pagadas-alerta-movii__texto {
  color: #fde68a;
  font-size: 1.3rem;
  line-height: 1.6;
}
.pagadas-alerta-movii__texto strong {
  display: block;
  font-size: 1.5rem;
  color: #fbbf24;
  margin-bottom: 0.3rem;
}
.pagadas-alerta-movii__texto p {
  margin: 0;
  color: rgba(255, 255, 255, 0.85);
}

.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 1000;
  justify-content: center;
  align-items: center;
}
.modal--activo {
  display: flex;
}
.modal__contenido {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
}
.modal__cerrar {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  background-color: rgb(180, 30, 30);
  color: #FFFFFF;
  border: none;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  font-size: 2.4rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  z-index: 1001;
  transition: background-color 0.3s ease;
}
.modal__cerrar:hover {
  background-color: rgb(136.2857142857, 22.7142857143, 22.7142857143);
}
.modal__img {
  object-fit: contain;
  border-radius: 0.5rem;
  box-shadow: 0 1rem 4rem rgba(0, 0, 0, 0.5);
}

.panel__monto-display {
  background-color: #f8fafc;
  border: 2px dashed #cbd5e1;
  border-radius: 0.5rem;
  padding: 1.2rem 1.5rem;
  font-family: "Inter", sans-serif;
  font-size: 1.6rem;
  color: #64748b;
  text-align: center;
  transition: all 0.3s ease;
}
.panel__monto-display .panel__monto-valor--activo {
  color: #16a34a;
  font-weight: 900;
  font-size: 2rem;
}

.pagadas-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 2px solid rgba(16, 185, 129, 0.3);
}
.pagadas-nav__btn {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
  border: 1px solid rgba(16, 185, 129, 0.3);
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  font-size: 2rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}
.pagadas-nav__btn:hover {
  background: rgba(16, 185, 129, 0.3);
  color: #FFFFFF;
  transform: scale(1.1);
}
.pagadas-nav__titulo {
  font-family: "Inter", sans-serif;
  font-size: 2.4rem;
  color: #FFFFFF;
  margin: 0;
  text-align: center;
  min-width: 20rem;
}

.pagadas-resumen {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
@media (max-width: 600px) {
  .pagadas-resumen {
    grid-template-columns: 1fr;
  }
}
.pagadas-resumen__card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(16, 185, 129, 0.2);
  border-radius: 0.8rem;
  padding: 1.5rem;
  text-align: center;
  transition: transform 0.3s ease;
}
.pagadas-resumen__card:hover {
  transform: translateY(-2px);
}
.pagadas-resumen__card--total {
  border-color: #10b981;
  background: rgba(16, 185, 129, 0.1);
}
.pagadas-resumen__numero {
  display: block;
  font-family: "Inter", sans-serif;
  font-size: 2.4rem;
  font-weight: 900;
  color: #6ee7b7;
}
.pagadas-resumen__label {
  display: block;
  font-size: 1.2rem;
  color: #FFFFFF;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 0.3rem;
}

.semana-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 0.8rem;
  margin-bottom: 1.2rem;
  overflow: hidden;
  transition: border-color 0.3s ease;
}
.semana-card:hover {
  border-color: rgba(16, 185, 129, 0.3);
}
.semana-card--vacia {
  opacity: 0.5;
}
.semana-card--vacia:hover {
  border-color: rgba(255, 255, 255, 0.1);
}
.semana-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 2rem;
  gap: 1rem;
}
.semana-card__header--clickable {
  cursor: pointer;
  transition: background 0.3s ease;
}
.semana-card__header--clickable:hover {
  background: rgba(16, 185, 129, 0.08);
}
.semana-card__info {
  display: flex;
  align-items: center;
  gap: 1.2rem;
}
.semana-card__titulo {
  font-family: "Inter", sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: #FFFFFF;
  margin: 0;
}
.semana-card__rango {
  font-size: 1.3rem;
  color: rgba(255, 255, 255, 0.5);
  background: rgba(255, 255, 255, 0.06);
  padding: 0.3rem 0.8rem;
  border-radius: 1rem;
}
.semana-card__stats {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.semana-card__cantidad {
  font-size: 1.3rem;
  color: rgba(255, 255, 255, 0.6);
}
.semana-card__total {
  font-family: "Inter", sans-serif;
  font-size: 1.8rem;
  font-weight: 900;
  color: #6ee7b7;
}
.semana-card__sin-pagos {
  font-size: 1.3rem;
  color: rgba(255, 255, 255, 0.3);
  font-style: italic;
}
.semana-card__chevron {
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.4);
  transition: transform 0.3s ease;
  display: inline-block;
}
.semana-card__chevron--abierto {
  transform: rotate(180deg);
}
.semana-card__facturas {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0 1.5rem 1.5rem;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.panel__input--error {
  border-color: rgb(180, 30, 30) !important;
  box-shadow: 0 0 0 3px rgba(180, 30, 30, 0.25) !important;
}

.panel__input--valido {
  border-color: #16a34a !important;
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.25) !important;
}

.panel__factura-error {
  background: rgba(180, 30, 30, 0.15);
  border: 1px solid rgba(180, 30, 30, 0.4);
  color: #fca5a5;
  padding: 0.8rem 1.2rem;
  border-radius: 0.5rem;
  font-size: 1.3rem;
  margin-top: 0.5rem;
  animation: fadeInError 0.3s ease;
}

@keyframes fadeInError {
  from {
    opacity: 0;
    transform: translateY(-5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.panel__header-acciones {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.8rem;
}

.panel__btn-ver-cuenta {
  background: rgba(85, 0, 197, 0.25);
  border: 1px solid rgba(85, 0, 197, 0.45);
  color: #FFFFFF;
  padding: 1rem 2rem;
  border-radius: 0.5rem;
  cursor: pointer;
  font-size: 1.8rem;
  font-weight: 600;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.panel__btn-ver-cuenta:hover {
  background: rgba(85, 0, 197, 0.45);
}
.panel__btn-ver-cuenta--activo {
  background: rgba(85, 0, 197, 0.5);
  border-color: #5500c5;
}

.movii__dropdown {
  background: linear-gradient(135deg, rgba(85, 0, 197, 0.12) 0%, rgba(0, 0, 0, 0.25) 100%);
  border: 1px solid rgba(85, 0, 197, 0.3);
  border-radius: 1rem;
  padding: 2rem;
  margin-bottom: 2rem;
  animation: moviiSlideDown 0.25s ease;
}

@keyframes moviiSlideDown {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.movii__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  flex-wrap: wrap;
  gap: 1rem;
}
.movii__titulo {
  font-size: 1.7rem;
  color: #FFFFFF;
  margin: 0;
}
.movii__icono {
  font-size: 1.8rem;
  margin-right: 0.5rem;
}
.movii__header-btns {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.movii__btn-cerrar {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #FFFFFF;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}
.movii__btn-cerrar:hover {
  background: rgba(180, 30, 30, 0.3);
  border-color: rgba(180, 30, 30, 0.5);
}
.movii__btn-editar {
  background: rgba(85, 0, 197, 0.3);
  border: 1px solid rgba(85, 0, 197, 0.5);
  color: #FFFFFF;
  padding: 0.6rem 1.2rem;
  border-radius: 0.5rem;
  cursor: pointer;
  font-size: 1.3rem;
  transition: all 0.3s ease;
}
.movii__btn-editar:hover {
  background: rgba(85, 0, 197, 0.5);
}
.movii__aviso {
  background: rgba(245, 158, 11, 0.15);
  border: 1px solid rgba(245, 158, 11, 0.4);
  color: #fbbf24;
  padding: 1.2rem 1.5rem;
  border-radius: 0.8rem;
  font-size: 1.4rem;
  margin-bottom: 1.5rem;
}
.movii__aviso p {
  margin: 0;
}
.movii__datos {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 0.8rem;
  padding: 1.5rem 2rem;
}
.movii__info {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}
.movii__info p {
  color: #FFFFFF;
  font-size: 1.5rem;
  margin: 0;
}
.movii__info p strong {
  color: rgba(255, 255, 255, 0.7);
  font-weight: 600;
  margin-right: 0.5rem;
}
.movii__info p span {
  color: #6ee7b7;
  font-weight: 700;
}
.movii__hint {
  color: rgba(255, 255, 255, 0.6);
  font-size: 1.3rem;
  margin-bottom: 1.5rem;
}
.movii__form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.movii__campo {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.movii__label {
  color: #FFFFFF;
  font-size: 1.4rem;
  font-weight: 600;
}
.movii__input {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #FFFFFF;
  padding: 1rem 1.2rem;
  border-radius: 0.5rem;
  font-size: 1.4rem;
  transition: border-color 0.3s ease;
}
.movii__input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}
.movii__input:focus {
  outline: none;
  border-color: #5500c5;
  box-shadow: 0 0 0 3px rgba(85, 0, 197, 0.25);
}
.movii__acciones {
  display: flex;
  gap: 1rem;
  margin-top: 0.5rem;
}
.movii__guardar {
  background: #6ee7b7;
  color: #FFFFFF;
  border: none;
  padding: 1rem 2rem;
  border-radius: 0.5rem;
  cursor: pointer;
  font-size: 1.4rem;
  font-weight: 700;
  transition: background 0.3s ease;
}
.movii__guardar:hover {
  background: rgb(66.2426035503, 223.7573964497, 161.2721893491);
}
.movii__guardar:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.movii__cancelar {
  background: rgba(255, 255, 255, 0.1);
  color: #FFFFFF;
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 1rem 2rem;
  border-radius: 0.5rem;
  cursor: pointer;
  font-size: 1.4rem;
  transition: all 0.3s ease;
}
.movii__cancelar:hover {
  background: rgba(255, 255, 255, 0.2);
}
.movii__alertas {
  margin-top: 0.5rem;
}
.movii__alertas .alerta {
  padding: 0.8rem 1.2rem;
  border-radius: 0.5rem;
  font-size: 1.3rem;
  margin-top: 0.5rem;
}
.movii__alertas .alerta--exito {
  background: rgba(110, 231, 183, 0.15);
  border: 1px solid rgba(110, 231, 183, 0.4);
  color: #86efac;
}
.movii__alertas .alerta--error {
  background: rgba(180, 30, 30, 0.15);
  border: 1px solid rgba(180, 30, 30, 0.4);
  color: #fca5a5;
}

.resumen-row--bonos {
  border: 2px solid #f59e0b;
  border-radius: 1.2rem;
  background: linear-gradient(135deg, #fffbeb, #fef3c7);
  padding: 1.5rem 2rem;
}
.resumen-row--bonos .resumen-row__titulo h3 {
  color: #92400e;
}

.resumen-row__hint {
  font-size: 1.2rem;
  font-weight: 400;
  color: #b45309;
}

.bono-progreso__lista {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  margin-top: 1rem;
}

.bono-progreso__item {
  display: grid;
  grid-template-columns: 15rem 1fr 16rem;
  align-items: center;
  gap: 1.5rem;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 0.8rem;
  padding: 1.2rem 1.5rem;
  transition: all 0.3s ease;
}
.bono-progreso__item--alcanzado {
  border-color: #f59e0b;
  background: linear-gradient(135deg, #fef3c7, #fff);
  box-shadow: 0 2px 8px rgba(245, 158, 11, 0.15);
}
@media (max-width: 640px) {
  .bono-progreso__item {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
}

.bono-progreso__info {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.bono-progreso__tienda {
  font-size: 1.4rem;
  font-weight: 800;
  color: #1e293b;
}

.bono-progreso__tipo {
  font-size: 1.1rem;
  color: #64748b;
  text-transform: capitalize;
}

.bono-progreso__barra-container {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.bono-progreso__barra {
  flex: 1;
  height: 0.8rem;
  background: #e5e7eb;
  border-radius: 0.4rem;
  overflow: hidden;
}

.bono-progreso__barra-fill {
  height: 100%;
  background: linear-gradient(90deg, #60a5fa, #3b82f6);
  border-radius: 0.4rem;
  transition: width 0.5s ease;
}
.bono-progreso__barra-fill--alcanzado {
  background: linear-gradient(90deg, #fbbf24, #f59e0b);
}

.bono-progreso__conteo {
  font-size: 1.3rem;
  font-weight: 800;
  color: #334155;
  white-space: nowrap;
  min-width: 4rem;
  text-align: center;
}

.bono-progreso__valores {
  text-align: right;
}

.bono-progreso__valor-base {
  font-size: 1.2rem;
  color: #64748b;
}
.bono-progreso__valor-base strong {
  color: #f59e0b;
  font-size: 1.3rem;
}

.bono-progreso__valor-activo {
  font-size: 1.4rem;
  font-weight: 800;
  color: #d97706;
}

.panel__monto-bono-hint {
  display: inline-block;
  font-size: 1.1rem;
  color: #b45309;
  background: #fef3c7;
  padding: 0.2rem 0.6rem;
  border-radius: 0.4rem;
  margin-left: 0.5rem;
  font-weight: 600;
  vertical-align: middle;
}

.panel__toggle-seccion {
  display: none;
  width: 100%;
  padding: 1.4rem 2rem;
  border: 2px solid rgba(255, 255, 255, 0.2);
  border-radius: 0.8rem;
  background: linear-gradient(135deg, rgba(85, 0, 197, 0.4) 0%, rgba(0, 0, 0, 0.6) 100%);
  color: #FFFFFF;
  font-family: "Inter", sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  margin-bottom: 1rem;
}
.panel__toggle-seccion:hover {
  border-color: rgba(255, 255, 255, 0.4);
  background: linear-gradient(135deg, rgba(85, 0, 197, 0.6) 0%, rgba(0, 0, 0, 0.8) 100%);
}
.panel__toggle-seccion--pagadas {
  border-color: rgba(16, 185, 129, 0.4);
}
.panel__toggle-seccion--pagadas:hover {
  border-color: #10b981;
}

.panel__toggle-seccion-icono {
  font-size: 1.8rem;
}

.panel__toggle-seccion-chevron {
  margin-left: auto;
  transition: transform 0.3s ease;
  font-size: 1.2rem;
}
.panel__toggle-seccion-chevron--abierto {
  transform: rotate(180deg);
}

@media (max-width: 767px) {
  .panel {
    padding: 1.5rem 0;
  }
  .panel__header {
    flex-direction: column;
    align-items: stretch;
    padding: 2rem 1.5rem;
    gap: 1.5rem;
    margin-bottom: 2rem;
  }
  .panel__bienvenida {
    font-size: 2rem;
    text-align: center;
  }
  .panel__cedula {
    font-size: 1.4rem;
    text-align: center;
  }
  .panel__asignacion {
    flex-direction: column;
    gap: 1rem;
    align-items: flex-start;
  }
  .panel__marca,
  .panel__tiendas,
  .panel__punto-venta {
    font-size: 1.4rem;
    width: 100%;
  }
  .panel__badge {
    font-size: 1.3rem;
    padding: 0.2rem 0.6rem;
  }
  .panel__badge-logo {
    width: 2.2rem;
    height: 2.2rem;
  }
  .panel__header-acciones {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
  }
  .panel__btn-ver-cuenta {
    font-size: 1.4rem;
    padding: 0.8rem 1.5rem;
    flex: 1;
    text-align: center;
    min-width: 0;
  }
  .panel__logout {
    font-size: 1.4rem;
    padding: 0.8rem 1.5rem !important;
    width: auto !important;
    flex: 1;
    text-align: center;
  }
  .notif__btn {
    padding: 0.6rem;
  }
  .panel__toggle-seccion {
    display: flex;
  }
  .panel__resumen {
    display: none;
    margin-bottom: 2rem;
  }
  .panel__resumen--mobile-visible {
    display: flex;
  }
  .resumen-row {
    padding: 1.2rem;
  }
  .resumen-row__titulo h3 {
    font-size: 1.5rem;
  }
  .resumen-row__cards {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.8rem;
  }
  .resumen-card {
    padding: 1rem 0.8rem;
  }
  .resumen-card__numero {
    font-size: 1.8rem;
  }
  .resumen-card__label {
    font-size: 1rem;
  }
  .panel__contenido {
    gap: 2rem;
    margin-bottom: 2rem;
  }
  .panel__card {
    padding: 1.5rem;
    border-radius: 0.8rem;
  }
  .panel__titulo {
    font-size: 1.8rem;
    margin-bottom: 1.5rem;
  }
  .panel__formulario {
    gap: 1.2rem;
  }
  .panel__label {
    font-size: 1.2rem;
  }
  .panel__input,
  .panel__textarea {
    padding: 1rem 1.2rem;
    font-size: 1.4rem;
  }
  .panel__submit {
    font-size: 1.5rem;
    padding: 1.2rem !important;
  }
  .panel__monto-display {
    font-size: 1.4rem;
    padding: 1rem;
  }
  .panel__file {
    font-size: 1.2rem;
  }
  .factura-item {
    flex-direction: row;
    align-items: center;
    padding: 1rem 1.2rem;
    gap: 1rem;
  }
  .factura-item__miniatura {
    display: none;
  }
  .factura-item__info {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
  }
  .factura-item__numero {
    font-size: 1.4rem;
    margin-right: auto;
  }
  .factura-item__fecha,
  .factura-item__hora,
  .factura-item__monto {
    display: none;
  }
  .factura-item__licencia {
    margin: 0;
  }
  .factura-item__badge {
    font-size: 1rem;
    padding: 0.2rem 0.6rem;
  }
  .factura-item__acciones {
    flex-direction: row;
    align-items: center;
    gap: 0.5rem;
  }
  .factura-item__estado {
    font-size: 1rem;
    padding: 0.3rem 0.8rem;
  }
  .factura-item__editar {
    font-size: 1.2rem;
    padding: 0.3rem 0.8rem;
  }
  .factura-item__comentario {
    display: none;
  }
  .panel__facturas {
    gap: 0.8rem;
    max-height: 40rem;
  }
  .panel__card--pagadas {
    display: none;
    padding: 1.5rem;
  }
  .panel__card--pagadas.panel__card--mobile-visible {
    display: block;
  }
  .pagadas-nav {
    gap: 1rem;
    margin-bottom: 1.5rem;
  }
  .pagadas-nav__titulo {
    font-size: 1.6rem;
  }
  .pagadas-nav__btn {
    padding: 0.6rem 1.2rem;
    font-size: 1.4rem;
  }
  .pagadas-resumen {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.8rem;
    margin-bottom: 1.5rem;
  }
  .semana-card__header {
    padding: 1rem;
  }
  .semana-card__titulo {
    font-size: 1.3rem;
  }
  .bono-progreso__item {
    grid-template-columns: 1fr;
    gap: 0.8rem;
    padding: 1rem;
  }
  .bono-progreso__tienda {
    font-size: 1.2rem;
  }
  .bono-progreso__valor-activo {
    font-size: 1.2rem;
  }
  .movii__dropdown {
    padding: 1.5rem;
  }
}
.admin {
  display: flex;
  min-height: 100vh;
  background-color: #f3f4f6;
}

.admin__sidebar {
  width: 260px;
  background-color: #1e293b;
  color: #FFFFFF;
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  z-index: 100;
}

.admin__logo {
  padding: 2rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.admin__logo h2 {
  font-family: "Inter", sans-serif;
  font-size: 3rem;
  font-weight: 900;
  color: #FFFFFF;
  margin: 0;
}

.admin__nav {
  flex: 1;
  padding: 1rem 0;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.admin__enlace {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 1rem 2rem;
  color: #94a3b8;
  text-decoration: none;
  font-family: "Open Sans", sans-serif;
  font-size: 1.4rem;
  transition: all 0.3s ease;
}
.admin__enlace:hover {
  background-color: rgba(255, 255, 255, 0.05);
  color: #FFFFFF;
}
.admin__enlace--activo {
  background-color: rgba(255, 255, 255, 0.1);
  color: #FFFFFF;
  border-left: 3px solid #2563EB;
}
.admin__enlace svg {
  flex-shrink: 0;
}

.admin__usuario {
  padding: 1.5rem 2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}
.admin__usuario p {
  font-size: 2rem;
  color: #94a3b8;
  margin: 0;
}

.admin__logout {
  color: rgb(180, 30, 30);
  text-decoration: none;
  font-size: 2rem;
}
.admin__logout:hover {
  text-decoration: underline;
}

.admin__contenido {
  flex: 1;
  margin-left: 260px;
  padding: 3rem;
  background-color: #748297;
}

.admin__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem;
}

.admin__titulo {
  font-family: "Inter", sans-serif;
  font-size: 2.8rem;
  font-weight: 900;
  color: #FFFFFF;
  margin: 0;
}

.admin__filtros-container {
  margin-bottom: 2rem;
}

.admin__filtros {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
}

.admin__select {
  padding: 0.8rem 1.2rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  font-size: 1.4rem;
  font-family: "Open Sans", sans-serif;
  background: #FFFFFF;
  cursor: pointer;
}
.admin__select:focus {
  outline: none;
  border-color: #2563EB;
}

.admin__btn {
  padding: 0.8rem 1.6rem;
  border: none;
  border-radius: 0.5rem;
  font-size: 1.4rem;
  font-family: "Open Sans", sans-serif;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
}
.admin__btn--primary {
  background-color: #2563EB;
  color: #FFFFFF;
}
.admin__btn--primary:hover {
  background-color: rgb(18.5714285714, 76.1428571429, 202.4285714286);
}
.admin__btn--secondary {
  background-color: #e5e7eb;
  color: #374151;
}
.admin__btn--secondary:hover {
  background-color: #d1d5db;
}
.admin__btn--danger {
  background-color: rgb(180, 30, 30);
  color: #FFFFFF;
}
.admin__btn--danger:hover {
  background-color: rgb(136.2857142857, 22.7142857143, 22.7142857143);
}

.admin__btn-accion {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 0.4rem;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.admin__btn-accion--ver {
  color: #2563EB;
}
.admin__btn-accion--ver:hover {
  background-color: rgba(37, 99, 235, 0.1);
}
.admin__btn-accion--eliminar {
  color: rgb(180, 30, 30);
}
.admin__btn-accion--eliminar:hover {
  background-color: rgba(180, 30, 30, 0.1);
}
.admin__btn-accion--aprobar {
  color: #6ee7b7;
}
.admin__btn-accion--aprobar:hover {
  background-color: rgba(0, 180, 0, 0.1);
}
.admin__btn-accion--rechazar {
  color: rgb(180, 30, 30);
}
.admin__btn-accion--rechazar:hover {
  background-color: rgba(180, 30, 30, 0.1);
}
.admin__btn-accion--asignar {
  color: #6d28d9;
}
.admin__btn-accion--asignar:hover {
  background-color: rgba(109, 40, 217, 0.1);
}

.filtros-bar {
  background: #FFFFFF;
  border-radius: 1.2rem;
  padding: 2rem;
  margin-bottom: 2rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
  border: 1px solid #e2e8f0;
}
.filtros-bar__grupo {
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem;
  margin-bottom: 1.2rem;
}
.filtros-bar__acciones {
  display: flex;
  align-items: flex-end;
  gap: 1rem;
  border-top: 1px solid #f1f5f9;
  padding-top: 1.2rem;
}
.filtros-bar__campo {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  min-width: 15rem;
  flex: 1;
}
.filtros-bar__campo--buscar {
  flex: 2;
  min-width: 20rem;
}
.filtros-bar__label {
  font-size: 1.1rem;
  font-weight: 700;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-family: "Open Sans", sans-serif;
}
.filtros-bar__select, .filtros-bar__input {
  font-family: "Open Sans", sans-serif;
  font-size: 1.3rem;
  font-weight: 600;
  color: #1e293b;
  background: #f8fafc;
  border: 1.5px solid #e2e8f0;
  border-radius: 0.8rem;
  padding: 0.8rem 1.2rem;
  transition: all 0.2s ease;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
}
.filtros-bar__select:focus, .filtros-bar__input:focus {
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
  background: #FFFFFF;
}
.filtros-bar__select:hover, .filtros-bar__input:hover {
  border-color: #cbd5e1;
}
.filtros-bar__select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%2364748b'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 3rem;
  cursor: pointer;
}
.filtros-bar__input::placeholder {
  color: #94a3b8;
  font-weight: 400;
}
.filtros-bar__btn-limpiar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.8rem 1.5rem;
  border: 1.5px solid #e2e8f0;
  border-radius: 0.8rem;
  background: #f8fafc;
  color: #64748b;
  font-size: 1.2rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
  font-family: "Open Sans", sans-serif;
}
.filtros-bar__btn-limpiar:hover {
  background: #fee2e2;
  border-color: #fca5a5;
  color: #dc2626;
}
.filtros-bar__btn-limpiar svg {
  flex-shrink: 0;
}
@media (max-width: 768px) {
  .filtros-bar {
    padding: 1.5rem;
  }
  .filtros-bar__grupo {
    flex-direction: column;
    gap: 0.8rem;
  }
  .filtros-bar__campo {
    min-width: 100%;
  }
  .filtros-bar__acciones {
    flex-direction: column;
  }
  .filtros-bar__campo--buscar {
    min-width: 100%;
  }
}

.resumen-facturas {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-bottom: 2rem;
}
.resumen-facturas__card {
  background: #FFFFFF;
  border-radius: 1.2rem;
  padding: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.2rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
  border: 1px solid #e2e8f0;
  border-left: 4px solid transparent;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.resumen-facturas__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}
.resumen-facturas__card--total {
  border-left-color: #2563EB;
}
.resumen-facturas__card--valor {
  border-left-color: #10b981;
}
.resumen-facturas__card--marcas {
  border-left-color: #8b5cf6;
}
.resumen-facturas__card--tiendas {
  border-left-color: #f59e0b;
}
.resumen-facturas__icono {
  font-size: 2.4rem;
  flex-shrink: 0;
}
.resumen-facturas__datos {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  overflow: hidden;
}
.resumen-facturas__numero {
  font-size: 2rem;
  font-weight: 800;
  color: #1e293b;
  font-family: "Inter", sans-serif;
}
.resumen-facturas__etiqueta {
  font-size: 1.1rem;
  font-weight: 600;
  color: #94a3b8;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.resumen-facturas__mini-lista {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  max-height: 6rem;
  overflow-y: auto;
}
.resumen-facturas__mini-item {
  font-size: 1.15rem;
  color: #475569;
  line-height: 1.3;
}
.resumen-facturas__mini-item strong {
  color: #1e293b;
}
@media (max-width: 1024px) {
  .resumen-facturas {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 480px) {
  .resumen-facturas {
    grid-template-columns: 1fr;
  }
}

.admin__tabla-container {
  background: #FFFFFF;
  border-radius: 1rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.06);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid #e2e8f0;
  width: 100%;
}
.admin__tabla-container--especialistas {
  border-radius: 1.2rem;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 2px 4px -1px rgba(0, 0, 0, 0.04);
}

.admin__tabla {
  width: 100%;
  border-collapse: collapse;
  font-family: "Open Sans", sans-serif;
  table-layout: auto;
}
.admin__tabla th, .admin__tabla td {
  padding: 1rem 1rem;
  text-align: left;
  font-size: 1.5rem;
  font-weight: bold;
}
.admin__tabla th {
  background-color: #f8fafc;
  color: #4B5563;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  border-bottom: 2px solid #e2e8f0;
  position: sticky;
  top: 0;
  z-index: 1;
  white-space: nowrap;
}
.admin__tabla td {
  color: #334155;
  max-width: 18rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.admin__tabla tr:hover td {
  background-color: #f8fafc;
}
.admin__tabla--especialistas {
  table-layout: fixed;
}
.admin__tabla--especialistas col:nth-child(1) {
  width: 20%;
}
.admin__tabla--especialistas col:nth-child(2) {
  width: 11%;
}
.admin__tabla--especialistas col:nth-child(3) {
  width: 10%;
}
.admin__tabla--especialistas col:nth-child(4) {
  width: 17%;
}
.admin__tabla--especialistas col:nth-child(5) {
  width: 17%;
}
.admin__tabla--especialistas col:nth-child(6) {
  width: 13%;
}
.admin__tabla--especialistas col:nth-child(7) {
  width: 12%;
}
.admin__tabla--especialistas th {
  background: linear-gradient(180deg, #f1f5f9, #e8ecf1);
  color: #1e293b;
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  padding: 1.2rem 1.4rem;
  border-bottom: 2px solid #cbd5e1;
}
.admin__tabla--especialistas td {
  padding: 1.2rem 1.4rem;
  font-size: 1.35rem;
  font-weight: 500;
  vertical-align: middle;
  border-bottom: 1px solid #f1f5f9;
  overflow: hidden;
  text-overflow: ellipsis;
}
.admin__tabla--especialistas td:first-child {
  max-width: none;
  white-space: nowrap;
}
.admin__tabla--especialistas td:nth-child(2),
.admin__tabla--especialistas td:nth-child(3) {
  white-space: nowrap;
  text-align: center;
}
.admin__tabla--especialistas th:nth-child(2),
.admin__tabla--especialistas th:nth-child(3) {
  text-align: center;
}
.admin__tabla--especialistas td:last-child {
  overflow: visible;
  white-space: nowrap;
  text-align: center;
}
.admin__tabla--especialistas th:last-child {
  text-align: center;
}
.admin__tabla--especialistas tr {
  transition: background-color 0.15s ease;
}
.admin__tabla--especialistas tbody tr:nth-child(odd) td {
  background-color: #1e1e2f;
  color: #e2e8f0;
}
.admin__tabla--especialistas tbody tr:nth-child(even) td {
  background-color: #f8fafc;
  color: #1e293b;
}
.admin__tabla--especialistas tbody tr:nth-child(odd):hover td {
  background-color: #2a2a40;
}
.admin__tabla--especialistas tbody tr:nth-child(even):hover td {
  background-color: #eef2ff;
}
.admin__tabla--especialistas tbody tr:nth-child(odd) .admin__esp-nombre strong {
  color: #f1f5f9;
}
.admin__tabla--especialistas tbody tr:nth-child(odd) .admin__cedula {
  background: #2d2d44;
  border-color: #3f3f5c;
  color: #cbd5e1;
}
.admin__tabla--especialistas tr:last-child td {
  border-bottom: none;
}
@media (max-width: 1600px) {
  .admin__tabla th, .admin__tabla td {
    padding: 0.8rem 0.7rem;
    font-size: 1.15rem;
  }
  .admin__tabla th {
    font-size: 1.1rem;
  }
  .admin__tabla td {
    max-width: 14rem;
  }
}
@media (max-width: 1024px) {
  .admin__tabla th, .admin__tabla td {
    padding: 0.7rem 0.6rem;
    font-size: 1.1rem;
  }
  .admin__tabla th {
    font-size: 1.05rem;
  }
  .admin__tabla td {
    max-width: 12rem;
  }
}
@media (max-width: 768px) {
  .admin__tabla th, .admin__tabla td {
    padding: 0.6rem 0.5rem;
    font-size: 1rem;
  }
  .admin__tabla th {
    font-size: 1rem;
  }
  .admin__tabla td {
    max-width: 10rem;
  }
}

.admin__td-wrap {
  white-space: normal !important;
  max-width: 22rem !important;
  overflow: visible !important;
  line-height: 1.6;
}

.admin__esp-nombre {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  white-space: nowrap;
  max-width: 100%;
}
.admin__esp-nombre strong {
  font-weight: 700;
  color: #1e293b;
  font-size: 1.35rem;
}

.admin__esp-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 50%;
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  color: #FFFFFF;
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  flex-shrink: 0;
  text-transform: uppercase;
}

.admin__cedula {
  font-size: 1.3rem;
  font-weight: bold;
  color: #475569;
  background: #f1f5f9;
  padding: 0.25rem 0.6rem;
  border-radius: 0.4rem;
  border: 1px solid #e2e8f0;
  letter-spacing: 0.03em;
}

.admin__vacio {
  text-align: center !important;
  color: #94a3b8;
  padding: 3rem !important;
  font-style: italic;
}

.admin__acciones-celda {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
}

.admin__badge {
  display: inline-block;
  padding: 0.3rem 0.8rem;
  border-radius: 2rem;
  font-size: 1.4rem;
  font-weight: 700;
  text-transform: capitalize;
}
.admin__badge--familiar {
  background-color: #dbeafe;
  color: #1d4ed8;
}
.admin__badge--personal {
  background-color: #fef3c7;
  color: #b45309;
}
.admin__badge--tienda {
  background-color: #e0e7ff;
  color: #3730a3;
  margin: 0.1rem;
}
.admin__badge--tienda[style*=background] {
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}
.admin__badge--marca {
  background-color: #ede9fe;
  color: #6d28d9;
}
.admin__badge--marca[style*=background] {
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}
.admin__badge--modificada {
  background-color: #fff7ed;
  color: #c2410c;
  border: 1px solid #fb923c;
  font-size: 1rem;
  margin-left: 0.4rem;
}
.admin__badge--default {
  background-color: #f0fdf4;
  color: #166534;
  border: 1px dashed #86efac;
  font-size: 1.2rem;
}
.admin__badge--movii {
  background-color: #ecfdf5;
  color: #065f46;
  border: 1px solid #6ee7b7;
  font-size: 1.2rem;
  cursor: help;
  white-space: nowrap;
}
.admin__badge--pdv {
  background-color: #fef3c7;
  color: #92400e;
  border: 1px solid #fbbf24;
  font-size: 1.2rem;
  font-weight: 600;
  margin: 0.15rem;
  white-space: nowrap;
}

.admin__fila--marca-especifica {
  background-color: #faf5ff;
}

.admin__config-acciones {
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
}

.admin__estado {
  display: inline-block;
  padding: 0.3rem 0.8rem;
  border-radius: 2rem;
  font-size: 1.4rem;
  font-weight: 700;
  text-transform: capitalize;
}
.admin__estado--pendiente {
  background-color: #fef3c7;
  color: #b45309;
}
.admin__estado--aprobada {
  background-color: #d1fae5;
  color: #065f46;
}
.admin__estado--rechazada {
  background-color: #fee2e2;
  color: #991b1b;
}
.admin__estado--pagada {
  background-color: #d1fae5;
  color: #047857;
}

.admin__estado-texto {
  font-size: 1.1rem;
  font-style: italic;
  color: #64748b;
}

.admin__ver-archivo {
  color: #2563EB;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.2rem;
  background: none;
  border: 1px solid #2563EB;
  border-radius: 0.4rem;
  padding: 0.3rem 0.8rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.admin__ver-archivo:hover {
  background-color: #2563EB;
  color: #fff;
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 200;
}
.modal--activo {
  display: flex;
}

.modal__contenido {
  background: #FFFFFF;
  border-radius: 1rem;
  width: 90%;
  max-width: 500px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.modal__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 2rem;
  border-bottom: 1px solid #e5e7eb;
}

.modal__titulo {
  font-family: "Inter", sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: #1e293b;
}

.modal__cerrar {
  background: none;
  border: none;
  font-size: 3rem;
  color: #FFFFFF;
  cursor: pointer;
  line-height: 1;
}
.modal__cerrar:hover {
  color: #FFFFFF;
}

.modal__form {
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.modal__campo {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.modal__label {
  font-family: "Open Sans", sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: #374151;
}

.modal__input {
  padding: 0.8rem 1.2rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  font-size: 1.4rem;
  font-family: "Open Sans", sans-serif;
  transition: border-color 0.3s ease;
}
.modal__input:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.modal__textarea {
  padding: 0.8rem 1.2rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  font-size: 1.4rem;
  font-family: "Open Sans", sans-serif;
  resize: vertical;
  min-height: 80px;
}
.modal__textarea:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.modal__acciones {
  display: flex;
  justify-content: flex-end;
  gap: 1rem;
  padding-top: 1rem;
}

.modal__checkboxes {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.modal__checkbox-label {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 0.6rem 0.8rem;
  border-radius: 0.4rem;
  cursor: pointer;
  font-size: 1.3rem;
  font-family: "Open Sans", sans-serif;
  transition: background-color 0.2s ease;
}
.modal__checkbox-label:hover {
  background-color: #f1f5f9;
}
.modal__checkbox-label input[type=checkbox] {
  width: 1.6rem;
  height: 1.6rem;
  accent-color: #2563EB;
  cursor: pointer;
}
.modal__checkbox-label span {
  color: #334155;
}

.admin__sin-asignar {
  font-size: 1.1rem;
  color: #94a3b8;
  font-style: italic;
}

.admin__tabla--facturas th {
  background: linear-gradient(180deg, #f8fafc, #f1f5f9);
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  padding: 1.2rem 1.4rem;
  border-bottom: 2px solid #cbd5e1;
  user-select: none;
}
.admin__tabla--facturas td {
  padding: 1rem 1.4rem;
  font-size: 1.35rem;
  font-weight: 500;
  vertical-align: middle;
  border-bottom: 1px solid #f1f5f9;
}
.admin__tabla--facturas tbody tr {
  transition: background-color 0.15s ease;
}
.admin__tabla--facturas tbody tr:nth-child(even) td {
  background-color: #f8fafc;
}
.admin__tabla--facturas tbody tr:hover td {
  background-color: #eef2ff;
}
.admin__tabla--facturas tr:last-child td {
  border-bottom: none;
}

.admin__th-sortable {
  cursor: pointer;
  position: relative;
  transition: color 0.2s ease;
}
.admin__th-sortable:hover {
  color: #2563EB;
}
.admin__th-sortable--asc .admin__th-arrow, .admin__th-sortable--desc .admin__th-arrow {
  color: #2563EB;
}
.admin__th-sortable--asc .admin__th-arrow::after {
  content: "↑";
}
.admin__th-sortable--desc .admin__th-arrow::after {
  content: "↓";
}

.admin__th-arrow {
  font-size: 1rem;
  color: #94a3b8;
  margin-left: 0.3rem;
}
.admin__th-arrow::after {
  content: "↕";
}

.admin__th-sortable--asc .admin__th-arrow::after {
  content: "↑";
}

.admin__th-sortable--desc .admin__th-arrow::after {
  content: "↓";
}

.admin__tr-clickable {
  cursor: pointer;
  transition: background-color 0.15s ease, box-shadow 0.15s ease;
}
.admin__tr-clickable:hover {
  background-color: #eef2ff !important;
}
.admin__tr-clickable:active td {
  background-color: #dbeafe !important;
}

.admin__tr--modificada td:first-child {
  box-shadow: inset 3px 0 0 #f59e0b;
}

.admin__td-nombre {
  font-weight: 600;
  color: #1e293b;
  font-size: 1.3rem;
}

.admin__td-numero {
  font-family: "Courier New", monospace;
  font-weight: 700;
  color: #334155;
  font-size: 1.25rem;
  background: #f1f5f9;
  padding: 0.2rem 0.6rem;
  border-radius: 0.4rem;
}

.admin__td-semana {
  font-size: 1.15rem;
  color: #64748b;
  white-space: nowrap;
}

.admin__facturas-count {
  font-size: 1.3rem;
  font-weight: 600;
  color: #64748b;
  background: #f1f5f9;
  padding: 0.4rem 1.2rem;
  border-radius: 2rem;
  border: 1px solid #e2e8f0;
}

.modal__ver-factura-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.modal__ver-factura-grid .modal__ver-factura-row {
  border-bottom: 1px solid #f1f5f9;
  padding: 1rem 1.5rem;
}
.modal__ver-factura-grid .modal__ver-factura-row:nth-child(odd) {
  border-right: 1px solid #f1f5f9;
}
.modal__ver-factura-grid .modal__ver-factura-row:last-child, .modal__ver-factura-grid .modal__ver-factura-row:nth-last-child(2):nth-child(odd) {
  border-bottom: none;
}
@media (max-width: 768px) {
  .modal__ver-factura-grid {
    grid-template-columns: 1fr;
  }
  .modal__ver-factura-grid .modal__ver-factura-row {
    border-right: none !important;
  }
}

.modal__ver-factura-acciones {
  display: flex;
  gap: 1rem;
  padding: 1.5rem 2rem;
  border-top: 1px solid #e2e8f0;
  justify-content: flex-end;
}
.modal__ver-factura-acciones:empty {
  display: none;
}

.toast {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  padding: 1.2rem 2rem;
  border-radius: 0.5rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 300;
  animation: slideIn 0.3s ease;
}
.toast--oculto {
  display: none;
}
.toast--exito {
  background-color: #065f46;
  color: #FFFFFF;
}
.toast--error {
  background-color: rgb(180, 30, 30);
  color: #FFFFFF;
}

.toast__mensaje {
  font-family: "Open Sans", sans-serif;
  font-size: 1.4rem;
  margin: 0;
  color: #FFFFFF;
}

@keyframes slideIn {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}
@media (max-width: 1024px) {
  .admin__contenido {
    padding: 2rem;
  }
  .admin__filtros {
    flex-wrap: wrap;
    gap: 0.8rem;
  }
  .admin__select {
    font-size: 1.3rem;
    padding: 0.7rem 1rem;
    min-width: 0;
    flex: 1 1 auto;
  }
}
@media (max-width: 768px) {
  .admin__sidebar {
    width: 200px;
  }
  .admin__contenido {
    margin-left: 200px;
    padding: 1.5rem;
  }
  .admin__header {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
  .admin__titulo {
    font-size: 2.2rem;
  }
  .admin__filtros {
    width: 100%;
  }
  .admin__filtros .admin__select {
    flex: 1 1 45%;
    min-width: 12rem;
  }
  .admin__btn {
    font-size: 1.2rem;
    padding: 0.7rem 1.2rem;
  }
  .admin__acciones-celda,
  .admin__acciones-cell {
    flex-wrap: wrap;
  }
  .admin__pagos-resumen {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
  .admin__pagos-card-valor {
    font-size: 1.8rem;
  }
  .admin__pagos-card-label {
    font-size: 1.1rem;
  }
}
@media (max-width: 480px) {
  .admin {
    flex-direction: column;
  }
  .admin__sidebar {
    width: 100%;
    height: auto;
    position: relative;
  }
  .admin__contenido {
    margin-left: 0;
    padding: 1rem;
  }
  .admin__nav {
    flex-direction: row;
    padding: 0;
    overflow-x: auto;
  }
  .admin__enlace {
    padding: 0.8rem 1.5rem;
    font-size: 1.2rem;
    white-space: nowrap;
  }
  .admin__enlace svg {
    display: none;
  }
  .admin__usuario {
    display: none;
  }
  .admin__titulo {
    font-size: 1.8rem;
  }
  .admin__filtros {
    flex-direction: column;
  }
  .admin__filtros .admin__select {
    width: 100%;
    flex: 1 1 100%;
  }
  .admin__tabla-container {
    border-radius: 0.5rem;
    margin: 0 -0.5rem;
    width: calc(100% + 1rem);
  }
  .admin__pagos-resumen {
    grid-template-columns: 1fr 1fr;
  }
  .admin__pagos-detalle {
    padding: 1.5rem;
  }
  .admin__grid-dos {
    grid-template-columns: 1fr;
  }
  .admin__badge {
    font-size: 1rem;
    padding: 0.2rem 0.6rem;
  }
}
.admin__config-card {
  background-color: #fff;
  border-radius: 1rem;
  padding: 3rem;
  box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.08);
}

.admin__config-titulo {
  font-family: "Inter", sans-serif;
  font-size: 1.8rem;
  font-weight: 900;
  margin: 0 0 0.5rem;
  color: #1e293b;
}

.admin__config-desc {
  font-size: 1.3rem;
  color: #64748b;
  margin: 0 0 2.5rem;
  line-height: 1.6;
}

.admin__config-form {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.admin__config-campo {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.admin__config-label {
  font-size: 1.3rem;
  font-weight: 700;
  color: #334155;
}

.admin__config-input-group {
  display: flex;
  align-items: center;
  border: 1px solid #cbd5e1;
  border-radius: 0.5rem;
  overflow: hidden;
  transition: border-color 0.3s ease;
}
.admin__config-input-group:focus-within {
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.admin__config-prefix {
  background-color: #f1f5f9;
  padding: 1rem 1.2rem;
  font-size: 1.4rem;
  font-weight: 700;
  color: #64748b;
  border-right: 1px solid #cbd5e1;
}

.admin__config-input {
  flex: 1;
  border: none;
  padding: 1rem 1.2rem;
  font-size: 1.4rem;
  font-family: "Open Sans", sans-serif;
  outline: none;
  background: transparent;
}
.admin__config-input::placeholder {
  color: #94a3b8;
}

.admin__grid-dos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
@media (max-width: 768px) {
  .admin__grid-dos {
    grid-template-columns: 1fr;
  }
}

.admin__card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.admin__btn--sm {
  padding: 0.5rem 1.2rem;
  font-size: 1.2rem;
}

.admin__pagos-filtro {
  margin-bottom: 2rem;
}

.admin__pagos-resumen {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
@media (max-width: 768px) {
  .admin__pagos-resumen {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 480px) {
  .admin__pagos-resumen {
    grid-template-columns: 1fr;
  }
}

.admin__pagos-card {
  background: #FFFFFF;
  border-radius: 0.8rem;
  padding: 2rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  text-align: center;
  border-top: 4px solid transparent;
}
.admin__pagos-card--total {
  border-top-color: #10b981;
}
.admin__pagos-card--facturas {
  border-top-color: #2563EB;
}
.admin__pagos-card--especialistas {
  border-top-color: #8b5cf6;
}
.admin__pagos-card--fecha {
  border-top-color: #f59e0b;
}

.admin__pagos-card-label {
  display: block;
  font-size: 1.2rem;
  font-weight: 700;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
}

.admin__pagos-card-valor {
  display: block;
  font-family: "Inter", sans-serif;
  font-size: 2.2rem;
  font-weight: 900;
  color: #1e293b;
}

.admin__pagos-detalle {
  margin-top: 2rem;
  background: #FFFFFF;
  border-radius: 0.8rem;
  padding: 2rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  border-left: 4px solid #2563EB;
}

.admin__btn--success {
  background-color: #10b981;
  color: #fff;
  border: none;
  border-radius: 0.5rem;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.2s;
}
.admin__btn--success:hover {
  background-color: #059669;
}

.admin__th-sortable {
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  transition: color 0.2s;
}
.admin__th-sortable:hover {
  color: #2563EB;
}

.admin__acciones-cell {
  display: flex;
  gap: 0.5rem;
  flex-wrap: nowrap;
  align-items: center;
}

.admin__resumen-item {
  font-size: 1.5rem;
  padding: 0.3rem 0;
  color: #334155;
  border-bottom: 1px solid #f1f5f9;
}
.admin__resumen-item:last-child {
  border-bottom: none;
}
.admin__resumen-item strong {
  color: #1e293b;
}

.admin__toggle-label {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 1.8rem;
  color: #FFFFFF;
  cursor: pointer;
}
.admin__toggle-label input[type=checkbox] {
  width: 2rem;
  height: 2rem;
  cursor: pointer;
}
.admin__toggle-label span {
  font-weight: 700;
}

.admin__logo-mini {
  width: 3.6rem;
  height: 3.6rem;
  object-fit: contain;
  border-radius: 0.4rem;
  border: 1px solid #e2e8f0;
  background: #fff;
  padding: 0.2rem;
}

.admin__color-dot {
  display: inline-block;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 50%;
  border: 2px solid rgba(0, 0, 0, 0.15);
  vertical-align: middle;
  margin-right: 0.4rem;
}

.modal__input--color {
  height: 4rem;
  padding: 0.3rem;
  cursor: pointer;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
}

.modal__contenido--ver-factura {
  max-width: 650px;
  width: 95%;
}

.modal__ver-factura-body {
  padding: 2rem;
}

.modal__ver-factura-img-container {
  text-align: center;
  margin-bottom: 1rem;
  background: #f8fafc;
  border-radius: 0.6rem;
  padding: 1rem;
  border: 1px solid #e2e8f0;
  max-height: 50vh;
  overflow: hidden;
  cursor: zoom-in;
  position: relative;
}
.modal__ver-factura-img-container--zoomed {
  cursor: grab;
  overflow: hidden;
}
.modal__ver-factura-img-container--zoomed:active {
  cursor: grabbing;
}

.modal__ver-factura-img {
  max-width: 100%;
  max-height: 48vh;
  object-fit: contain;
  border-radius: 0.4rem;
  transition: transform 0.15s ease;
  transform-origin: center center;
  user-select: none;
  -webkit-user-drag: none;
}

.modal__ver-factura-zoom-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  margin-bottom: 1.5rem;
}

.modal__ver-factura-zoom-btn {
  width: 3.2rem;
  height: 3.2rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  background: #FFFFFF;
  font-size: 1.6rem;
  font-weight: 700;
  color: #374151;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  line-height: 1;
}
.modal__ver-factura-zoom-btn:hover {
  background-color: #f1f5f9;
  border-color: #2563EB;
  color: #2563EB;
}
.modal__ver-factura-zoom-btn--reset {
  font-size: 1.4rem;
  margin-left: 0.4rem;
}

.modal__ver-factura-zoom-level {
  font-size: 1.2rem;
  font-weight: 700;
  color: #64748b;
  min-width: 4rem;
  text-align: center;
  font-family: "Open Sans", sans-serif;
}

.modal__ver-factura-info {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.modal__ver-factura-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.8rem 1rem;
  border-radius: 0.4rem;
  font-size: 1.3rem;
}
.modal__ver-factura-row:nth-child(odd) {
  background-color: #f8fafc;
}

.modal__ver-factura-label {
  font-weight: 700;
  color: #64748b;
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.modal__ver-factura-value {
  color: #1e293b;
  font-weight: 600;
  font-size: 1.35rem;
}

.modal__logo-preview {
  min-height: 1rem;
}

.modal__logo-img {
  width: 8rem;
  height: 8rem;
  object-fit: contain;
  border-radius: 0.6rem;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  padding: 0.4rem;
  margin-bottom: 0.5rem;
}

.admin__validacion {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.admin__validacion-input-area {
  margin-top: 1rem;
}

.admin__validacion-textarea {
  width: 100%;
  padding: 1.2rem;
  border: 2px dashed #d1d5db;
  border-radius: 0.8rem;
  font-size: 1.4rem;
  font-family: "Courier New", monospace;
  line-height: 1.8;
  resize: vertical;
  min-height: 200px;
  background-color: #fafafa;
  transition: border-color 0.3s ease;
}
.admin__validacion-textarea:focus {
  outline: none;
  border-color: #2563EB;
  background-color: #FFFFFF;
}
.admin__validacion-textarea::placeholder {
  color: #94a3b8;
  font-family: "Open Sans", sans-serif;
}

.admin__validacion-stats {
  margin-top: 0.8rem;
  font-size: 1.3rem;
  color: #64748b;
  font-family: "Open Sans", sans-serif;
}

.admin__validacion-acciones {
  display: flex;
  gap: 1rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
  align-items: center;
}

.admin__validacion-subtitulo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-family: "Inter", sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 1rem;
  padding-bottom: 0.8rem;
  border-bottom: 2px solid #e5e7eb;
}
.admin__validacion-subtitulo--exito {
  color: #059669;
  border-bottom-color: #d1fae5;
}
.admin__validacion-subtitulo--error {
  color: #dc2626;
  border-bottom-color: #fee2e2;
}

.admin__validacion-no-encontradas {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  padding: 1.5rem;
  background: #fef2f2;
  border-radius: 0.8rem;
  border: 1px solid #fecaca;
}

.admin__validacion-chip {
  display: inline-block;
  padding: 0.4rem 1rem;
  border-radius: 2rem;
  font-size: 1.3rem;
  font-family: "Courier New", monospace;
  font-weight: 700;
}
.admin__validacion-chip--error {
  background-color: #fee2e2;
  color: #991b1b;
  border: 1px solid #fca5a5;
}
.admin__validacion-chip--exito {
  background-color: #d1fae5;
  color: #065f46;
  border: 1px solid #6ee7b7;
}

.admin__validacion-export-filtros {
  margin-top: 1rem;
}

.admin__fila--coincide {
  background-color: #f0fdf4 !important;
}
.admin__fila--coincide:hover td {
  background-color: #dcfce7 !important;
}

.admin__fila--ya-procesada {
  background-color: #fefce8 !important;
  opacity: 0.7;
}
.admin__fila--ya-procesada:hover td {
  background-color: #fef9c3 !important;
}

.admin__fila--fecha-no-coincide {
  background-color: #fef2f2 !important;
  opacity: 0.85;
}
.admin__fila--fecha-no-coincide:hover td {
  background-color: #fee2e2 !important;
}

@media (max-width: 768px) {
  .admin__validacion-textarea {
    min-height: 150px;
  }
  .admin__validacion-acciones {
    flex-direction: column;
  }
  .admin__validacion-acciones .admin__btn {
    width: 100%;
  }
}
.movii-rechazos {
  margin-top: 3rem;
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 50%, #fcd34d 100%);
  border: 2px solid #f59e0b;
  border-radius: 1rem;
  padding: 2rem;
}
.movii-rechazos__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}
.movii-rechazos__titulo {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  font-size: 1.6rem;
  font-weight: 700;
  color: #92400e;
}
.movii-rechazos__desc {
  font-size: 1.3rem;
  color: #78350f;
  margin-bottom: 1.5rem;
  line-height: 1.6;
}
.movii-rechazos__contenido {
  animation: fadeIn 0.3s ease;
}
.movii-rechazos__checkboxes {
  max-height: 300px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.movii-rechazos__hint {
  font-size: 1.2rem;
  color: #94a3b8;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.admin__btn--movii {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: linear-gradient(135deg, #7c3aed, #6d28d9);
  color: white;
  border: none;
  padding: 0.8rem 1.5rem;
  border-radius: 0.5rem;
  font-size: 1.3rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
}
.admin__btn--movii:hover {
  background: linear-gradient(135deg, #6d28d9, #5b21b6);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(109, 40, 217, 0.3);
}
.admin__btn--movii:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.admin__config-selects {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}
@media (max-width: 640px) {
  .admin__config-selects {
    grid-template-columns: 1fr;
  }
}

.admin__config-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem;
}
@media (max-width: 768px) {
  .admin__config-grid {
    grid-template-columns: 1fr;
  }
}

.admin__config-column {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.admin__config-column--bono {
  background: linear-gradient(135deg, #fef3c7, #fef9c3);
  border: 1px solid #f59e0b;
  border-radius: 1rem;
  padding: 1.5rem;
}

.admin__config-subtitle {
  font-size: 1.4rem;
  font-weight: 800;
  color: #1e293b;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.admin__config-bono-icon {
  font-size: 1.6rem;
}

.admin__config-bono-hint {
  font-size: 1.1rem;
  font-weight: 400;
  color: #92400e;
}

.admin__config-bono-desc {
  font-size: 1.2rem;
  color: #78350f;
  line-height: 1.5;
  margin: 0;
}

.admin__config-bono-row {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.admin__config-bono-label {
  font-size: 1.2rem;
  font-weight: 700;
  color: #92400e;
}

.admin__config-bono-inputs {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.admin__config-bono-arrow {
  font-size: 1.6rem;
  color: #b45309;
  font-weight: 700;
}

.admin__config-input-group--sm {
  max-width: 14rem;
}
.admin__config-input-group--sm .admin__config-input {
  padding: 0.8rem;
  font-size: 1.3rem;
}
.admin__config-input-group--sm .admin__config-prefix {
  padding: 0.8rem 1rem;
  font-size: 1.2rem;
}

.admin__bono-badge {
  display: inline-block;
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: #fff;
  padding: 0.3rem 0.8rem;
  border-radius: 0.4rem;
  font-size: 1.1rem;
  font-weight: 700;
  white-space: nowrap;
}

.admin__bono-indicador {
  font-size: 1.4rem;
  vertical-align: middle;
  cursor: help;
}

.admin__monto-bono {
  color: #d97706;
  font-weight: 800;
}

.admin__tabla--config {
  font-size: 1.25rem;
}
.admin__tabla--config th, .admin__tabla--config td {
  padding: 0.8rem 1rem;
}
.admin__tabla--config th:last-child,
.admin__tabla--config td:last-child {
  text-align: center;
  white-space: nowrap;
}

.admin__export-acciones {
  display: flex;
  gap: 1rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.admin__pdv-controles {
  display: flex;
  align-items: flex-end;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}

.admin__pdv-selector {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex: 1;
  min-width: 20rem;
}

.subida-rapida {
  min-height: 100vh;
  background: linear-gradient(135deg, #5500c5 0%, #1f1d20 100%);
  padding: 3rem 0;
}
.subida-rapida__header {
  background: linear-gradient(135deg, #1f1d20 0%, #5500c5 100%);
  padding: 2.5rem 3rem;
  border-radius: 1rem;
  margin-bottom: 3rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.1);
  flex-wrap: wrap;
  gap: 2rem;
}
.subida-rapida__branding {
  flex: 1;
}
.subida-rapida__titulo {
  font-family: "Inter", sans-serif;
  font-size: 3rem;
  color: #FFFFFF;
  -webkit-text-stroke: 1px #5500c5;
  margin: 0;
}
.subida-rapida__subtitulo {
  font-size: 1.6rem;
  color: #000;
  margin: 0.3rem 0 0;
  -webkit-text-stroke: 1px #FFFFFF;
}
.subida-rapida__login-btn {
  background-color: #5500c5;
  padding: 1.5rem 4rem;
  color: #FFFFFF;
  font-size: 1.6rem;
  display: inline-block;
  font-weight: 700;
  border: none;
  transition-property: background-color;
  transition-duration: 0.3s;
  text-align: center;
  display: block;
  width: 100%;
}
@media (min-width: 768px) {
  .subida-rapida__login-btn {
    width: auto;
  }
}
.subida-rapida__login-btn:hover {
  background-color: rgb(62.9949238579, 0, 146);
  cursor: pointer;
}
.subida-rapida__login-btn {
  padding: 1.5rem 4rem;
  font-size: 1.8rem;
  border-radius: 0.5rem;
  text-decoration: none;
  transition: background-color 0.3s ease, transform 0.2s ease;
}
.subida-rapida__login-btn:hover {
  background-color: rgb(62.9949238579, 0, 146);
  transform: translateY(-2px);
}
.subida-rapida__contenido {
  display: grid;
  gap: 3rem;
}
@media (min-width: 768px) {
  .subida-rapida__contenido {
    grid-template-columns: 1fr 1fr;
  }
}
.subida-rapida__card {
  background: linear-gradient(135deg, #1f1d20 0%, #5500c5 100%);
  padding: 3rem;
  border-radius: 1rem;
  box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.1);
}
.subida-rapida__card--formulario {
  border-top: 4px solid #2563EB;
}
.subida-rapida__card-titulo {
  font-family: "Inter", sans-serif;
  font-size: 2.2rem;
  color: #FFFFFF;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid #2563EB;
}
.subida-rapida__card-desc {
  font-size: 1.5rem;
  color: #FFFFFF;
  margin-bottom: 2rem;
  line-height: 1.6;
}
.subida-rapida__busqueda {
  margin-bottom: 2rem;
}
.subida-rapida__busqueda-wrapper {
  position: relative;
  margin-top: 1rem;
}
.subida-rapida__search-input {
  width: 100%;
  padding: 1.5rem 2rem;
  border: 2px solid #d1d5db;
  border-radius: 0.8rem;
  font-size: 1.8rem;
  font-family: "Open Sans", sans-serif;
  color: #000;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  box-sizing: border-box;
}
.subida-rapida__search-input:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.15);
}
.subida-rapida__search-input::placeholder {
  color: #94a3b8;
}
.subida-rapida__resultados {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background-color: #FFFFFF;
  border: 1px solid #e2e8f0;
  border-radius: 0 0 0.8rem 0.8rem;
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.15);
  z-index: 100;
  max-height: 30rem;
  overflow-y: auto;
}
.subida-rapida__resultado {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.2rem 2rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
  border-bottom: 1px solid #f1f5f9;
}
.subida-rapida__resultado:last-child {
  border-bottom: none;
}
.subida-rapida__resultado:hover {
  background-color: #eff6ff;
}
.subida-rapida__resultado--vacio {
  color: #6b7280;
  font-size: 1.4rem;
  text-align: center;
  cursor: default;
  padding: 2rem;
}
.subida-rapida__resultado--vacio:hover {
  background-color: transparent;
}
.subida-rapida__resultado-info {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.subida-rapida__resultado-nombre {
  font-family: "Inter", sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: #000;
}
.subida-rapida__resultado-cedula {
  font-size: 1.3rem;
  color: #6b7280;
}
.subida-rapida__resultado-marca {
  font-size: 1.2rem;
  color: #5500c5;
  font-weight: 700;
  background-color: #ede9fe;
  padding: 0.3rem 0.8rem;
  border-radius: 2rem;
}
.subida-rapida__especialista {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #6956cf;
  border: 2px solid #2563EB;
  border-radius: 0.8rem;
  padding: 2rem;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.subida-rapida__especialista-datos {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  flex: 1;
}
.subida-rapida__nombre {
  font-family: "Inter", sans-serif;
  font-size: 2rem;
  font-weight: 900;
  color: #FFFFFF;
  margin: 0;
}
.subida-rapida__cedula-info {
  font-size: 1.5rem;
  color: #FFFFFF;
  margin: 0;
  font-weight: 700;
}
.subida-rapida__marca-info {
  font-size: 1.4rem;
  color: #FFFFFF;
  margin: 0;
  font-weight: 700;
}
.subida-rapida__pdv-info {
  font-size: 1.3rem;
  color: #fef3c7;
  margin: 0;
  font-weight: 600;
}
.subida-rapida__tiendas-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.3rem;
  font-size: 1.4rem;
  color: #FFFFFF;
}
.subida-rapida__tiendas-label {
  font-weight: 700;
}
.subida-rapida__tienda-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.3rem 0.8rem;
  border-radius: 2rem;
  font-size: 1.2rem;
  font-weight: 700;
  background-color: #e0e7ff;
  color: #3730a3;
}
.subida-rapida__tienda-badge[style*=background-color] {
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}
.subida-rapida__tienda-badge-logo {
  width: 2rem;
  height: 2rem;
  object-fit: contain;
  border-radius: 50%;
}
.subida-rapida__cambiar {
  background-color: #5500c5;
  padding: 1.5rem 4rem;
  color: #FFFFFF;
  font-size: 1.6rem;
  display: inline-block;
  font-weight: 700;
  border: none;
  transition-property: background-color;
  transition-duration: 0.3s;
  text-align: center;
  display: block;
  width: 100%;
}
@media (min-width: 768px) {
  .subida-rapida__cambiar {
    width: auto;
  }
}
.subida-rapida__cambiar:hover {
  background-color: rgb(62.9949238579, 0, 146);
  cursor: pointer;
}
.subida-rapida__cambiar {
  padding: 1rem 2rem;
  font-size: 1.4rem;
  border-radius: 0.5rem;
  cursor: pointer;
  border: none;
  flex-shrink: 0;
}
.subida-rapida__formulario {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.subida-rapida__campo {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.subida-rapida__label {
  font-family: "Inter", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #FFFFFF;
  text-transform: uppercase;
}
.subida-rapida__input {
  padding: 1.2rem 1.5rem;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  font-size: 1.6rem;
  font-family: "Open Sans", sans-serif;
  color: #000;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.subida-rapida__input:focus {
  outline: none;
  border-color: #2563EB;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
}
.subida-rapida__input--error {
  border-color: #dc2626 !important;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.2) !important;
}
.subida-rapida__input--valido {
  border-color: #16a34a !important;
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.15) !important;
}
.subida-rapida__factura-error {
  color: #fca5a5;
  font-size: 1.3rem;
  font-weight: 700;
  margin-top: 0.5rem;
  padding: 0.8rem 1.2rem;
  background-color: rgba(220, 38, 38, 0.15);
  border: 1px solid rgba(220, 38, 38, 0.3);
  border-radius: 0.4rem;
}
.subida-rapida__file {
  padding: 1rem;
  border: 2px dashed #d1d5db;
  border-radius: 0.5rem;
  font-size: 1.4rem;
  cursor: pointer;
  transition: border-color 0.3s ease;
  color: #FFFFFF;
}
.subida-rapida__file:hover {
  border-color: #2563EB;
}
.subida-rapida__monto-display {
  background-color: #f8fafc;
  border: 2px dashed #cbd5e1;
  border-radius: 0.5rem;
  padding: 1.2rem 1.5rem;
  font-family: "Inter", sans-serif;
  font-size: 1.6rem;
  color: #64748b;
  text-align: center;
  transition: all 0.3s ease;
}
.subida-rapida__monto-activo {
  color: #16a34a;
  font-weight: 900;
  font-size: 2rem;
}
.subida-rapida__acciones {
  display: flex;
  gap: 1rem;
  align-items: center;
}
.subida-rapida__submit {
  background-color: #2563EB;
  padding: 1.5rem 4rem;
  color: #FFFFFF;
  font-size: 1.6rem;
  display: inline-block;
  font-weight: 700;
  border: none;
  transition-property: background-color;
  transition-duration: 0.3s;
  text-align: center;
  display: block;
  width: 100%;
}
@media (min-width: 768px) {
  .subida-rapida__submit {
    width: auto;
  }
}
.subida-rapida__submit:hover {
  background-color: rgb(18.5714285714, 76.1428571429, 202.4285714286);
  cursor: pointer;
}
.subida-rapida__submit {
  margin-top: 1rem;
  padding: 1.5rem;
  border-radius: 0.5rem;
  font-size: 1.8rem;
  flex: 1;
  cursor: pointer;
  transition: background-color 0.3s ease, transform 0.2s ease;
}
.subida-rapida__submit:hover {
  background-color: rgb(18.5714285714, 76.1428571429, 202.4285714286);
  transform: translateY(-1px);
}
.subida-rapida__submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

@media (max-width: 767px) {
  .subida-rapida {
    padding: 1.5rem 0;
  }
  .subida-rapida__header {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1.5rem;
    gap: 1.2rem;
    margin-bottom: 2rem;
  }
  .subida-rapida__branding {
    flex: none;
    width: 100%;
  }
  .subida-rapida__titulo {
    font-size: 2.2rem;
  }
  .subida-rapida__subtitulo {
    font-size: 1.3rem;
  }
  .subida-rapida__login-btn {
    font-size: 1.4rem;
    padding: 1rem 2.5rem !important;
    width: auto !important;
  }
  .subida-rapida__contenido {
    gap: 1.5rem;
  }
  .subida-rapida__card {
    padding: 1.5rem;
    border-radius: 0.8rem;
  }
  .subida-rapida__card-titulo {
    font-size: 1.8rem;
    margin-bottom: 0.8rem;
    padding-bottom: 0.8rem;
  }
  .subida-rapida__card-desc {
    font-size: 1.3rem;
    margin-bottom: 1.5rem;
  }
  .subida-rapida__search-input {
    padding: 1.2rem 1.5rem;
    font-size: 1.5rem;
  }
  .subida-rapida__resultado {
    padding: 1rem 1.5rem;
  }
  .subida-rapida__resultado-nombre {
    font-size: 1.4rem;
  }
  .subida-rapida__resultado-cedula {
    font-size: 1.2rem;
  }
  .subida-rapida__resultado-marca {
    font-size: 1.1rem;
    padding: 0.2rem 0.6rem;
  }
  .subida-rapida__especialista {
    flex-direction: column;
    align-items: stretch;
    padding: 1.2rem;
    gap: 1rem;
  }
  .subida-rapida__nombre {
    font-size: 1.6rem;
  }
  .subida-rapida__cedula-info {
    font-size: 1.3rem;
  }
  .subida-rapida__marca-info {
    font-size: 1.2rem;
  }
  .subida-rapida__pdv-info {
    font-size: 1.1rem;
  }
  .subida-rapida__tiendas-info {
    font-size: 1.2rem;
  }
  .subida-rapida__tienda-badge {
    font-size: 1.1rem;
    padding: 0.2rem 0.6rem;
  }
  .subida-rapida__tienda-badge-logo {
    width: 1.6rem;
    height: 1.6rem;
  }
  .subida-rapida__cambiar {
    width: 100%;
    text-align: center;
    padding: 0.8rem 1.5rem !important;
    font-size: 1.3rem;
  }
  .subida-rapida__formulario {
    gap: 1.2rem;
  }
  .subida-rapida__label {
    font-size: 1.2rem;
  }
  .subida-rapida__input {
    padding: 1rem 1.2rem;
    font-size: 1.4rem;
  }
  .subida-rapida__file {
    font-size: 1.2rem;
    padding: 0.8rem;
  }
  .subida-rapida__monto-display {
    font-size: 1.4rem;
    padding: 1rem;
  }
  .subida-rapida__submit {
    font-size: 1.5rem;
    padding: 1.2rem !important;
  }
  .subida-rapida__factura-error {
    font-size: 1.1rem;
    padding: 0.6rem 1rem;
  }
}
.notif {
  position: relative;
}
.notif--admin {
  margin-bottom: 1rem;
}
.notif__btn {
  position: relative;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #FFFFFF;
  border-radius: 50%;
  width: 4rem;
  height: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}
.notif__btn:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: scale(1.05);
}
.notif__btn--shake {
  animation: notifShake 0.6s ease;
}
.notif__badge {
  position: absolute;
  top: -0.4rem;
  right: -0.4rem;
  background: rgb(180, 30, 30);
  color: #FFFFFF;
  font-size: 1.1rem;
  font-weight: 700;
  min-width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.4rem;
  box-shadow: 0 2px 8px rgba(180, 30, 30, 0.5);
  animation: notifPulse 2s infinite;
}
.notif__dropdown {
  width: 36rem;
  max-height: 40rem;
  background: #1e1b4b;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 1rem;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
  z-index: 1000;
  overflow: hidden;
  animation: notifSlideDown 0.2s ease;
  margin-top: 2rem;
}
.notif__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.2rem 1.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
}
.notif__titulo {
  font-size: 1.4rem;
  color: #FFFFFF;
  margin: 0;
}
.notif__leer-todas {
  background: none;
  border: none;
  color: #6ee7b7;
  font-size: 1.2rem;
  cursor: pointer;
  padding: 0.4rem 0.8rem;
  border-radius: 0.5rem;
  transition: all 0.2s ease;
}
.notif__leer-todas:hover {
  background: rgba(110, 231, 183, 0.15);
}
.notif__lista {
  max-height: 32rem;
  overflow-y: auto;
  padding: 0.5rem;
}
.notif__vacio {
  text-align: center;
  color: rgba(255, 255, 255, 0.5);
  font-size: 1.3rem;
  padding: 2rem 1rem;
}
.notif__item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.2rem;
  border-radius: 0.8rem;
  cursor: pointer;
  transition: all 0.3s ease;
  border-left: 3px solid transparent;
  margin-bottom: 0.3rem;
}
.notif__item:hover {
  background: rgba(255, 255, 255, 0.08);
}
.notif__item--factura_rechazada {
  border-left-color: rgb(180, 30, 30);
  background: rgba(180, 30, 30, 0.08);
}
.notif__item--factura_rechazada:hover {
  background: rgba(180, 30, 30, 0.15);
}
.notif__item--factura_modificada {
  border-left-color: #F59E0B;
  background: rgba(245, 158, 11, 0.08);
}
.notif__item--factura_modificada:hover {
  background: rgba(245, 158, 11, 0.15);
}
.notif__item-icono {
  font-size: 2rem;
  flex-shrink: 0;
  line-height: 1;
}
.notif__item-contenido {
  flex: 1;
  min-width: 0;
}
.notif__item-mensaje {
  color: #FFFFFF;
  font-size: 1.3rem;
  line-height: 1.4;
  margin: 0 0 0.3rem;
  word-wrap: break-word;
}
.notif__item-tiempo {
  color: rgba(255, 255, 255, 0.4);
  font-size: 1.1rem;
}
.notif__item-cerrar {
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.4);
  font-size: 1.8rem;
  cursor: pointer;
  padding: 0 0.4rem;
  line-height: 1;
  flex-shrink: 0;
  transition: all 0.2s ease;
  border-radius: 0.3rem;
}
.notif__item-cerrar:hover {
  color: #FFFFFF;
  background: rgba(255, 255, 255, 0.1);
}

.admin__tr--highlight {
  animation: rowHighlight 5s ease;
}

@keyframes rowHighlight {
  0%, 30% {
    background: rgba(245, 158, 11, 0.25) !important;
    box-shadow: inset 0 0 0 2px #F59E0B;
  }
  100% {
    background: transparent;
    box-shadow: none;
  }
}
.factura-item--highlight {
  animation: facturaHighlight 3s ease;
  border-color: #F59E0B !important;
}

@keyframes facturaHighlight {
  0%, 40% {
    background: rgba(245, 158, 11, 0.2) !important;
    border-color: #F59E0B !important;
    box-shadow: 0 0 20px rgba(245, 158, 11, 0.3);
  }
  100% {
    background: inherit;
    box-shadow: none;
  }
}
@keyframes notifShake {
  0%, 100% {
    transform: rotate(0);
  }
  15% {
    transform: rotate(15deg);
  }
  30% {
    transform: rotate(-15deg);
  }
  45% {
    transform: rotate(10deg);
  }
  60% {
    transform: rotate(-10deg);
  }
  75% {
    transform: rotate(5deg);
  }
}
@keyframes notifPulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
}
@keyframes notifSlideDown {
  from {
    opacity: 0;
    transform: translateY(-1rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.toast--info {
  background: linear-gradient(135deg, #F59E0B, rgb(172.4330708661, 110.9507874016, 7.0669291339));
}

@media (max-width: 768px) {
  .notif__dropdown {
    width: 30rem;
    right: -5rem;
  }
}
@media (max-width: 480px) {
  .notif__dropdown {
    width: calc(100vw - 2rem);
    right: -2rem;
  }
  .notif__btn {
    width: 3.5rem;
    height: 3.5rem;
  }
}
/*# sourceMappingURL=app.css.map */
