/* El contenedor que vamos a resetear */
.reset-container {
  all: initial;
}

/* Es buena práctica volver a declarar lo mínimo indispensable */
.reset-container * {
  all: revert; /* Revertimos los descendientes a los estilos del navegador */
}

.reset-before::before {
  display: none;
}

:root {

  --bs-border-radius: 1.5rem;
  --bs-border-radius-lg: 1.5rem;
  --modal-icon-size: 74px;

}

.no-seleccionable {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

html,
body {
  height: 100%;
  margin: 0;
}

.wrapper {
  height: 100%;
  display: flex;
  flex-direction: column;
}

.content {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  /*
  background-image: url("data:image/svg+xml,<svg id='patternId' width='100%' height='100%' xmlns='http://www.w3.org/2000/svg'><defs><pattern id='a' patternUnits='userSpaceOnUse' width='40' height='23' patternTransform='scale(5) rotate(150)'><rect x='0' y='0' width='100%' height='100%' fill='%238e9ea900'/><path d='M-4.798 13.573C-3.149 12.533-1.446 11.306 0 10c2.812-2.758 6.18-4.974 10-5 4.183.336 7.193 2.456 10 5 2.86 2.687 6.216 4.952 10 5 4.185-.315 7.35-2.48 10-5 1.452-1.386 3.107-3.085 4.793-4.176'  stroke-width='5' stroke='%23343a40ff' fill='none'/></pattern></defs><rect width='800%' height='800%' transform='translate(-310,-165)' fill='url(%23a)'/></svg>");
  */
  background-image: url("data:image/svg+xml,<svg id='patternId' width='100%' height='100%' xmlns='http://www.w3.org/2000/svg'><defs><pattern id='a' patternUnits='userSpaceOnUse' width='40' height='59.428' patternTransform='scale(2) rotate(35)'><rect x='0' y='0' width='100%' height='100%' fill='%23ffffff00'/><path d='M0 70.975V47.881m20-1.692L8.535 52.808v13.239L20 72.667l11.465-6.62V52.808zm0-32.95l11.465-6.62V-6.619L20-13.24 8.535-6.619V6.619L20 13.24m8.535 4.927v13.238L40 38.024l11.465-6.62V18.166L40 11.546zM20 36.333L0 47.88m0 0v23.094m0 0l20 11.548 20-11.548V47.88m0 0L20 36.333m0 0l20 11.549M0 11.547l-11.465 6.619v13.239L0 38.025l11.465-6.62v-13.24L0 11.548v-23.094l20-11.547 20 11.547v23.094M20 36.333V13.24'  stroke-linecap='square' stroke-width='2' stroke='%23343a40ff' fill='none'/></pattern></defs><rect width='800%' height='800%' transform='translate(-22,-84)' fill='url(%23a)'/></svg>");
}

.header .navbar,
footer {
  background-color: var(--bg-color1) !important;
  color: var(--tx-color1);
  z-index: 1035;
  /*
  -webkit-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.75);
  */
}

.navbar .toolbar {
  font-size: x-large;
}

.navbar .toolbar .hide {
  display: none;
}

.icon-badge-group {}

.icon-badge-group a {
  color: inherit;
  /* blue colors for links too */
  text-decoration: inherit;
  /* no underline */
}

.icon-badge-group .icon-badge-container {
  display: inline-block;
  margin-left: 15px;
}

.icon-badge-group .icon-badge-container:first-child {
  margin-left: 0
}

.icon-badge-container {
  /*margin-top: 20px;*/
  position: relative;
}

.icon-badge-icon {
  font-size: 24px;
  position: relative;
}

.icon-badge {
  display: flex;
  align-content: center;
  justify-content: center;
  font-size: 9px;
  color: white;
  text-align: center;
  width: 14px;
  height: 14px;
  border-radius: 35%;
  position: absolute;
  /* changed */
  top: -5px;
  /* changed */
  left: 18px;
  /* changed */
}

.icon-badge.red {
  background-color: red;
}

.icon-badge.green {
  background-color: green;
}

.bs-icon {
  background-color: var(--bg-color2) !important;
}

.brand {
  color: var(--tx-color1) !important;
  font-size: 16px !important;
  font-family: 'IBM Plex Sans';
}

.hamburger {
  width: 32px;
  height: 32px;
  color: var(--tx-color1);
}

.menu-navbar {
  display: flex;
  justify-content: flex-end;
}

.menu-close {
  width: 32px;
  height: 32px;
  color: var(--tx-color2);
  margin: 1rem;
}

body {
  background: var(--bg-color2) !important;
  color: white;
}

.modal-body h5 {
  font-size: 1rem;
}

.modal-body {
  color: var(--tx-color2);
  font-size: 0.8rem;
}

.bnt-2 {
  color: var(--tx-color1) !important;
  height: 100%;
  border: none;
  background: transparent;
  font-weight: 700;
  font-size: .875rem;
}

.modal .btn.btn-primary,
.offcanvas .btn.btn-primary {
  height: 55px;
  border-radius: 22px;
  font-weight: 700;
  font-size: .875rem;
}

.modal .btn.btn-primary.left,
.offcanvas .btn.btn-primary.left {
  -webkit-border-radius: 22px;
  -webkit-border-top-right-radius: 0px;
  -webkit-border-bottom-right-radius: 0px;
  -moz-border-radius: 22px;
  -moz-border-radius-topright: 0px;
  -moz-border-radius-bottomright: 0px;
  border-radius: 22px;
  border-top-right-radius: 0px;
  border-bottom-right-radius: 0px;
}

.modal .btn.btn-primary.center,
.offcanvas .btn.btn-primary.center {
  -webkit-border-radius: 0px;
  -webkit-border-top-right-radius: 0px;
  -webkit-border-bottom-right-radius: 0px;
  -moz-border-radius: 0px;
  -moz-border-radius-topright: 0px;
  -moz-border-radius-bottomright: 0px;
  border-radius: 0px;
  border-top-right-radius: 0px;
  border-bottom-right-radius: 0px;
}

.modal .btn.btn-primary.right,
.offcanvas .btn.btn-primary.right {
  -webkit-border-radius: 0px;
  -webkit-border-top-right-radius: 22px;
  -webkit-border-bottom-right-radius: 22px;
  -moz-border-radius: 0px;
  -moz-border-radius-topright: 22px;
  -moz-border-radius-bottomright: 22px;
  border-radius: 0px;
  border-top-right-radius: 22px;
  border-bottom-right-radius: 22px;
}

.modal .btn.btn-primary,
.offcanvas .btn.btn-primary {
  background-color: var(--bg-color3);
  border-color: var(--bg-color3);
  /*box-shadow: rgba(0, 0, 0, 0.4) 0px 2px 4px, rgba(0, 0, 0, 0.3) 0px 7px 13px -3px, rgba(0, 0, 0, 0.2) 0px -3px 0px inset;*/
}

.modal .btn.btn-primary:hover,
.offcanvas .btn.btn-primary:hover {
  background-color: var(--bg-color3);
  border-color: var(--bg-color4);
  /*box-shadow: rgba(0, 0, 0, 0.4) 0px 2px 4px, rgba(0, 0, 0, 0.3) 0px 7px 13px -3px, rgba(0, 0, 0, 0.2) 0px -3px 0px inset;*/
}

#modal-text {
  text-align: justify;
  margin: 2vw;
}

.modal-icon {
  width: var(--modal-icon-size);
  height: var(--modal-icon-size);
}

#modal-buttons {
  display: flex;
}

.modal-button {
  text-wrap: nowrap;
  text-overflow: ellipsis;
  margin: 1px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-color: var(--bg-color3);
  background-color: var(--bg-color3);
}

#modal-menu {
  background-color: var(--bg-color1);
}

#modal-menu .modal-content {
  height: 95vh;
}

#modal-message {}

.list-unstyled {

  font-size: small;

}

footer .container {

  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 1vw;
}

/**
 * https://codepen.io/Elvira-Ho/pen/jvmRNK
 */

input[type=checkbox] {
  margin: 1rem;
}

input[type=checkbox] {
  accent-color: var(--bg-color3);
  width: 24px;
  height: 24px;
}

.table>:not(caption)>*>* {

  /*padding: 1rem 0.5rem 1rem 0rem !important;*/

}

caption {
  caption-side: top;
  padding: 8px;
}

.input-icons {
  height: 55px;
  border-radius: 22px;
  font-weight: 700;
  font-size: .875rem;
  border: 3px solid var(--bg-color3);
  display: flex;
  align-items: center;
  padding-left: 10px;
  padding-right: 10px;
}

.input-icons input {
  margin-left: 10px;
  width: 100%;
}

.input-icons i {
  font-size: 24px;
}

textarea,
input[type="text"],
input[type="password"],
input[type="datetime"],
input[type="datetime-local"],
input[type="date"],
input[type="month"],
input[type="time"],
input[type="week"],
input[type="number"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="tel"],
input[type="color"],
.uneditable-input {
  /*border-color: var(--bg-color3);*/
  /*box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px var(--bg-color3);*/
  height: 49px;
  border-radius: 22px;
  font-weight: 700;
  font-size: .875rem;
  border-style: none;
}

textarea:focus,
input[type="text"]:focus,
input[type="password"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="time"]:focus,
input[type="week"]:focus,
input[type="number"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="color"]:focus,
.uneditable-input:focus {
  /*border-color: var(--bg-color3);*/
  /*box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px var(--bg-color3);*/
  height: 49px;
  border-radius: 22px;
  font-weight: 700;
  font-size: .875rem;
}

/* Change the white to any color */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px white inset !important;
}

.marquee-container {
  background: transparent;
  /*
  border-radius: 10px 10px 10px 10px;
  -moz-border-radius: 10px 10px 10px 10px;
  -webkit-border-radius: 10px 10px 10px 10px;
  border: 2px solid;
  */
  font-size: small;
  color: #FF5B5A;
}

marquee {
  font-size: small;
  color: #FF5B5A;
}

.blink {
  animation: animate 1.0s linear infinite;
}

@keyframes animate {
  0% {
    opacity: 0;
  }

  50% {
    opacity: 0.7;
  }

  100% {
    opacity: 0;
  }
}

.flip-card {
  background-color: transparent;
  perspective: 1000px;
  -webkit-perspective: 1000px;
  /* Compatibilidad con iOS */
}

.flip-card {
  background-color: transparent;
  perspective: 1000px;
  -webkit-perspective: 1000px;
  /* Compatibilidad con iOS */
}

.flip-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  text-align: center;
  transition: transform 0.6s;
  -webkit-transition: transform 0.6s;
  /* Compatibilidad con iOS */
  transform-style: preserve-3d;
}

.flip-card.flipped .flip-card-inner {
  transform: rotateY(180deg);
  -webkit-transform: rotateY(180deg);
  /* Compatibilidad con iOS */
}

.flip-card-front,
.flip-card-back {
  position: absolute;
  /* Cambiado a absolute */
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  /* Compatibilidad con iOS */
}

.flip-card-front {
  /* Puedes añadir estilos adicionales aquí */
}

.flip-card-back {
  transform: rotateY(180deg);
  -webkit-transform: rotateY(180deg);
  /* Compatibilidad con iOS */
}

.row {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1* var(--bs-gutter-y));
  margin-right: calc(-.5* var(--bs-gutter-x));
  margin-left: calc(-.5* var(--bs-gutter-x));
  align-content: center;
  flex-direction: column;
  align-items: center;
}

.table {
  text-align: left;
  font-size: small;
}

.table-tr {
  border-style: none !important;
}

.table-cell {
  text-align: center;
}

/* Estilos para el Offcanvas personalizado */
.offcanvas.offcanvas-bottom.h-75-offcanvas {
  height: 75vh !important;
  /* Altura del 75% de la ventana */
  border-top-left-radius: 20px;
  /* Bordes superiores redondeados */
  border-top-right-radius: 20px;
  /* Bootstrap offcanvas ya maneja overflow y otros detalles base */
}

/* El .modal-content se reutiliza como el contenedor principal dentro del offcanvas */
.offcanvas.h-75-offcanvas .offcanvas-content-custom {
  border-top-left-radius: 20px;
  /* Asegurar que los bordes redondeados se apliquen */
  border-top-right-radius: 20px;
  height: 100%;
  /* El contenido debe llenar la altura del offcanvas */
  display: flex;
  flex-direction: column;
  position: relative;
  /* Para el posicionamiento absoluto del botón de cierre */
}

/* El .modal-body se reutiliza para el contenido desplazable */
.offcanvas.h-75-offcanvas .offcanvas-content-custom .modal-body {
  overflow-y: auto;
  /* Permitir scroll si el contenido es largo */
  flex-grow: 1;
  /* Ocupar el espacio restante */
  padding-top: 45px;
  /* Espacio para el botón de cierre X que está arriba */
  text-align: center;
  /* Mantener el centrado original si se desea */
}

/* Botón de cierre para el offcanvas */
.btn-close-offcanvas-custom {
  position: absolute;
  top: 15px;
  right: 15px;
  /* Asegurar que esté por encima del contenido del offcanvas (z-index de offcanvas es 1045, header 1050) */
  z-index: 1056;
}

/* Asegurar que la imagen dentro del offcanvas se comporte bien */
.offcanvas.h-75-offcanvas .modal-icon {
  /* Puedes añadir estilos específicos para la imagen en modo offcanvas si es necesario */
  max-width: 100px;
  /* Ejemplo, ajusta según tus necesidades */
  max-height: 100px;
  /* Ejemplo */
  margin-bottom: 15px;
}

/**/
