html {
  font-size: 100%;
  box-sizing: border-box;
  scroll-behavior: smooth;
}

*, *::before, *::after {
  box-sizing: inherit;
}

body {
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  background-color: var(--background-color);
  color: var(--color-gray-base) !important;
  margin: 0;
  padding: 0;
  line-height: 1.5;
  height: 100%;
}

/* Botones */
.button, .btn-primary {
  background-color: var(--primary-color);
  color: white;
  padding: var(--space-xs) var(--space-sm);
  border: none;
  border-radius: var(--border-radius);
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.button:hover, .btn-primary:hover {
  background-color: #0056b3;
}


/* Enlaces */
a, .btn-link {
  text-decoration: none;
}
a:hover, .btn-link:hover {
  text-decoration:  none;
}

/* Enfoque */
.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem var(--focus-ring-color);
  outline: none;
}

.nav-link{
  display: flex;
  align-items: center;
  flex-direction: column;
}

/* Validaciones */
.valid.modified:not([type=checkbox]) {
  outline: 1px solid var(--success-color);
}
.invalid {
  outline: 1px solid var(--error-color);
}
.validation-message {
  color: var(--error-color);
}

/* Errores de Blazor */
.blazor-error-boundary {
  background: url('data:image/svg+xml;base64,...') no-repeat 1rem/1.8rem, #b32121;
  padding: 1rem 1rem 1rem 3.7rem;
  color: white;
}
.blazor-error-boundary::after {
  content: "An error has occurred.";
}

/* Formularios flotantes */
.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
  color: var(--secondary-color);
  text-align: end;
}
.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
  text-align: start;
}
.darker-border-checkbox.form-check-input {
  border-color: #929292;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}


input[type=number] {
    -moz-appearance: textfield;
}


/* Tipografía adaptativa */
h1 {
  font-size: var(--font-size-xl);
  margin-bottom: var(--space-sm);
}
p {
  font-size: var(--font-size-base);
  margin-bottom: var(--space-sm);
}

/* Scroll */
::-webkit-scrollbar {
  width: 8px;             
  height: 8px;             
}

::-webkit-scrollbar-track {
  background: #f0f0f0;       
  border-radius: 4px;       
}

::-webkit-scrollbar-thumb {
  background: #b6b6b6;       
  border-radius: 4px;       
}

::-webkit-scrollbar-thumb:hover {
  background: #8c8c8c;      
}

/* Login */
.title-login{
  font-family: Ubuntu-Bold, sans-serif;
  font-size: var(--font-size-xl);
  text-align: center;
  width: 100% !important;
  margin: 10% 0;
  color: var(--text-color-dark-login);
  font-weight: 550;
}


.btn-login{
  width: 70%;
  background: linear-gradient(#7FEFF5, #00AAB7);
  height: 6.5vh;
  border: none !important;
  margin: 20% 15% 0 15%;
  border-radius: 15px;
  box-shadow: rgba(0, 81, 116, 0.25) 0px -50px 36px -28px inset;
  font-family: Ubuntu-Medium, sans-serif !important;
}

.btn-logout{
  background-color: #ffffff;
  color:  var(--color-basic);
  border: 1px solid var(--color-basic);
  padding: 0.5rem 1rem;
  border-radius: 1000px;
    font-size: 0.9rem;
}

.input-login{
  border: none !important;
  background:#E8F0FE !important;
  border-radius: var(--border-radius);
}

.carousel-login{
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  -webkit-mask-size: cover;
  mask-size: cover;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  opacity: 0.9;
}

.slide {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  animation: background-login 30s infinite cubic-bezier(0.42, 0, 0.58, 1);
  transition: opacity 1s cubic-bezier(0.42, 0, 0.58, 1);
  aspect-ratio: 16 / 9;
}

.slide1 {
  /*background-image: url('/images/auth/backgroundlogin1.jpg');*/
  animation-delay: 0s;
  height: 110%;
  width: 110%;
  transform: translateY(0);
}
.slide2 {
  /*background-image: url('/images/auth/backgroundlogin2.jpg');*/
  animation-delay: 10s;
  height: 110%;
  width: 110%;
}
.slide3 {
  /*background-image: url('/images/auth/backgroundlogin3.jpg');*/
  animation-delay: 20s;
  height: 110%;
  width: 110%;
}

@keyframes background-login {
  0% {
    opacity: 0;
    transform: translate(0, -30px) rotate(-2deg) scale(1);
  }
  10% {
    opacity: 1;
    transform: translate(-5px, -25px) rotate(-1deg);
  }
  25% {
    opacity: 1;
    transform: translate(5px, -15px) rotate(0deg);
  }
  35% {
    opacity: 0.5;
    transform: translate(5px, -10px) rotate(0deg);
  }
  45% {
    opacity: 0;
    transform: translate(5px, -5px) rotate(0deg) scale(1.05);
  }
  55% {
    opacity: 0;
    transform: translate(3px, -2px) rotate(0deg) scale(1.05);
  }
  60% {
    opacity: 0;
    transform: translate(0px, 0px) rotate(0deg) scale(1);
  }
  100% {
    opacity: 0;
    transform: translate(0px, 0px) rotate(0deg) scale(1);
  }
}


.container-image{
  display: none;
  justify-content: flex-end;
  position: absolute;
  top: 12%;
  right:0;
  z-index: 3;
  background-color: rgba(255, 255, 255, 0.22);
  padding: 1% 4%;
  width: 50%;
  backdrop-filter: blur(20px);
  min-height: 130px;
  align-items: center;
}

.navbar-gradient {
  background: linear-gradient(210deg, #005CB9 33%, #009ADC 75%, #00D9FF 100%);
  color: white;
  padding: 1rem;
  display: flex;
  flex-direction: column;
}

.navbar-left,
.navbar-right {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.navbar-logo img {
  max-height: 1.9rem;
}

.navbar-vinc img {
  max-height: 2.3rem;
}

.nav-item {
  text-align: center;
  font-size: 0.7rem;
  text-decoration: none;
  color: white;
  transition: opacity 0.2s;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 0.5rem 0;
  width: 7.5rem;
  min-width: 6rem;
  border: 0.8px solid transparent;
  position: relative;
}

.nav-item i {
  font-size: 1.2rem;
  display: block;
  margin-bottom: 0.3rem;
}


.nav-item:hover {
  border: 0.8px solid rgba(255, 255, 255, 0.8);
  border-radius: 8px;
  background: linear-gradient(45deg, rgb(255 255 255 / 18%) 0%, #021f5524 100%);
}

.nav-item-disabled{
  border-radius: 8px;
  background: linear-gradient(45deg, rgb(255 255 255 / 18%) 0%, #021f5524 100%);
  cursor: default;
  pointer-events: none;
  opacity: 0.8;
}

.navbar-right .user-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.user-info img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
}

.user-info small {
  font-size: 0.7rem;
  color: #e0e0e0;
}

.avatar-img {
  width: 35px;
  height: 35px;
  border-radius: 50%;
  object-fit: cover;
}

.avatar-initials {
  width: 35px !important;
  height: 35px !important;
  background-color: #cce5ff;
  color: #12487E;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  user-select: none;
}

.name-user{
  font-family: var(--font-family-base);
  font-size: 0.8rem;
  font-weight: 600;
  max-width: 15rem;
  white-space: nowrap;   
  overflow: hidden;        
  text-overflow: ellipsis;
}

.name-branch{
  font-family: var(--font-family-base);
  font-size: 0.75rem;
  font-style: italic;
}

.item-category-profile{
  font-size: 0.8rem;
}

.user-toggle{
  margin-right: -6%;
}

.button-gds{
  border: none;
  background: none;
  width: auto;
  border-radius: 1000px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.button-gds img{
  border-radius: 1000px;
}

.button-gds img:hover {
  transform: scale(1.2);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.button-primary-green{
  background: linear-gradient(180deg, #38d7df, #00AAB7);
  color: white;
  border-radius: 20px;
  font-size: 0.9rem;
  padding: 0.5rem 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border: none;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.button-primary-green:hover{
  background: linear-gradient(180deg, #00AAB7, #00AAB7);
  color: white;
  border: none;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
}

.button-blue-control{
    background: linear-gradient(180deg, #edbbfd, #762499);
    color: white;
    border-radius: 20px;
    font-size: 0.7rem;
    padding: 0.3rem 1rem;
    display: inline-flex
;
    align-items: center;
    gap: 0.5rem;
    border: none;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.button-blue-control:hover{
    background: linear-gradient(180deg, #80529e, #762499);
    color: white;
    border: none;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
}

.button-secondary-green{
  border: 1px solid #00AAB7;
  background-color: white;
  color: #00AAB7;
  border-radius: 20px;
  font-size: 0.9rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  padding: 0.5rem 1rem;
}

.button-secondary-green:hover{
    border: 1px solid #00AAB7;
    background-color: #23c3cf;
    color: #ffffff;
}

.button-primary-blue{
  background: linear-gradient(180deg, #96EFFF, #0086B7);
  color: white;
  border-radius: 50px;
  font-size: 0.85rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border: none;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  padding: 0.5rem 1rem;
}

.button-primary-blue:hover{
  background: linear-gradient(180deg, #96EFFF, #0086B7);
  color: white;
  border: none;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
}

.currency-name{
  font-size: 0.75rem !important;
  color: var(--color-basic);
  font-weight: lighter;
}

.currency-value{
  font-size: 0.95rem;
  color: var(--color-basic);
  font-weight: 600;
}

.container-tabs-group{
  display: flex;
  gap: 0.5rem;
  justify-content: flex-start; 
  align-items: end;
  white-space: nowrap;
  flex-wrap: nowrap;
  overflow-x: auto;
}

.button-tab{
  padding: 0.3rem 0.8rem;
  min-width: 8rem;
  text-align: center;
  border: 1px solid #D9D9D9;
  border-bottom: none;
  border-radius: 1rem 1rem 0 0;
  background: #fff;
  color: #6c757d;
  font-weight: 500;
  transition: all 0.2s ease;
  flex: 0 0 auto;
  white-space: nowrap;
  cursor: default !important;
  font-size: 16px;
}

.button-tab.active-tab {
  color: var(--color-basic);
  border-top: 3px solid var(--color-basic);
  font-weight: 600;
}

.button-tab:hover:not(.active-tab) {
  background: #f8f9fa;
  cursor: pointer !important;
}

.btn-tab-profile{
  padding: 0.9rem 1.3rem;
  text-align: center;
  background: #fff;
  color: #6c757d;
  font-weight: 500;
  transition: all 0.2s ease;
  flex: 0 0 auto;
  white-space: nowrap;
  cursor: default !important;
  font-size: 0.9rem;
  border-radius: 6px;
  min-width: 13vw;
  justify-content: center;
}

.btn-tab-profile.active-tab {
  color: var(--color-basic);
  border-top: 3px solid var(--color-basic);
  font-weight: 600;
}

.btn-tab-profile:hover:not(.active-tab) {
  background: #f8f9fa;
  cursor: pointer !important;
}

.item-main-profile{
  background-color: #ffffff;
  width: 100%;
  display: inline-flex;
  justify-content: space-between;
  padding: 0.85rem 1rem 0.85rem 1.5rem;
  align-items: center;
  border-radius: 4px;
  font-size: 0.9rem;
}

.item-main-profile.active-tab{
  color: var(--color-basic);
  border-left: 3px solid var(--color-basic);
  font-weight: 600;
}

.item-main-profile:hover:not(.active-tab) {
  background: #f8f9fa;
  cursor: pointer !important;
}

.divider-profile{
  margin: 0 0.1rem 0 0.5rem;
  height: 1px;
  background-color: rgb(201 201 201);
}

.container-not-found{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100vh;
}

.container-grey-base{
  border: 1px solid #D9D9D9;
  background-color: var(--color-grey);
  border-radius: 0 0.5rem 0.5rem 0.5rem;
  padding: 1rem;
  pointer-events: auto !important;
  min-height: calc(100vh - 14rem);
  height: auto;
}

.container-basic{
  border: 1px solid #D9D9D9;
  background-color: var(--background-color);
  border-radius: 0 0.5rem 0.5rem 0.5rem;
  padding: 1rem 1rem 0.5rem 1rem;
  min-height: 76vh;
  pointer-events: auto !important;
}

.container-grey{
  background-color: var(--color-grey);
  padding: 2rem 10rem;
  min-height: calc(100vh - 8rem);
  height: auto;
}

.container-main-profile{
  width: fit-content;
  background-color: #ffffff;
  box-shadow: rgba(42, 165, 251, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 1px 3px 1px;
  border-radius: 6px;
  min-width: 16rem;
}

.container-commision{
    width: 100%;
    background-color: #ffffff;
    box-shadow: rgba(42, 165, 251, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 1px 3px 1px;
    border-radius: 6px;
}

.container-profile{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem 2rem;
  margin-top: 1.5rem;
}

.info-item-profile{
  display: flex;
  flex-direction: column;
}

.label-profile{
  color: var(--color-grey-darker);
  font-size: 0.85rem;
}

.value-profile{
  color: var(--color-gray-base);
  font-size: 0.85rem;
}

.title-primary{
  color: var(--color-basic);
  font-size: var(--font-size-md-lg);
  font-weight: 600;
  text-transform: capitalize !important;
}

.subtitle-primary{
  font-family: var(--font-family-base);
  font-size: var( --font-size-xs-sm);
  font-style: italic;
  color: var(--color-basic);
}

.subtitle-second{
  font-family: var(--font-family-base);
  font-size: 0.9rem;
  font-style: italic;
  color: var(--color-basic);
}

.subtitle-third{
  color: var(--color-blue-dark);
  font-size:var(--font-size-xs);
  font-weight: 600;
}

.subtitle-fourth{
  font-size: 0.9rem;
  font-style: italic;
}

.subtitle-profile{
  color: var(--color-basic);
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.icon-info{
  width: 1.05rem !important;
  height: 1.05rem;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-ico-xs);
  color: var(--color-basic);
  padding: 0.25rem;
  border: 1px solid var(--color-basic);
  border-radius: 1rem;
  background-color: transparent;
}

.icon-info:hover{
  background-color: var(--color-basic);
  color: #ffffff;
  opacity: 0.7;
}

.card-dashboard{
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 1rem 1.2rem;
  box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
  background-color: #ffffff;
  border-radius: 6px;
}

.card-dashboard-graphs{
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
    padding: 1.15rem 1.2rem;
  box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
  background-color: #ffffff;
  border-radius: 6px;
    width: 100%;
  min-height: calc(100vh - 27rem);
  height: auto;
}

.card-dashboard-aside{
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 1rem 1.2rem;
  box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
  background-color: #ffffff;
  border-radius: 6px;
}

.icon-card-dashboard{
  width: 2rem !important;
  height: 2rem;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  border-radius: 50%;
  padding: 0.5rem;
}

.icon-card-dashboard-second{
  width: 2rem !important;
  height: 2rem;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  border-radius: 50%;
  padding: 0.5rem;
  background-color: var(--color-basic-rgba);
  color: var(--color-basic);
}

.icon-card-dashboard-primary{
  width: 2rem;
  height: 2rem;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-sm);
  border-radius: 50%;
  padding: 0.5rem;
  color: var(--color-gray-second);
}

.icon-card-dashboard-primary:hover{
  color: var(--color-basic);
  cursor: pointer;
}

.title-card-dashboard{
  color: var(--color-gray-base) !important;
}

.list-group-news{
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  margin: 0;
  overflow-y: auto;
  height: 26vh;
  padding: 0;
}

.list-group-favorites{
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  margin: 0;
  padding: 0;
  color: var(--color-gray-base) !important;
  overflow: hidden;
  height: 25vh;
}
.list-item-favorite{
  border-bottom: 1px solid var(--bs-border-color);
  font-size: 0.93rem;
  color: var(--color-gray-base) !important;
}

.list-item-favorite:hover{
  cursor: pointer;
  background-color: var(--color-grey-item-rgba);
}

.list-item-news{
  display: flex;
  justify-content: flex-start;
  align-items: center;
  border: 1px solid var(--bs-border-color);
  border-radius:8px;
}

.title-news{
  font-size: 0.9rem !important;
  line-height: 1.15rem;
  font-weight: bold;
  overflow: hidden;
  display: -webkit-box;      
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;       
}

.date-news{
  font-size: 0.89rem;
}

.button-details{
  background-color: var(--color-grey-second);
  font-size: 0.8rem;
  color: var(--secondary-color);
  border: none;
  border-radius: 4px;
}

.border-news{
  width: 0.35rem;
  height: 100%;
  border-top-left-radius: 8px;
  border-bottom-left-radius: 8px;
}

.border-news-orange{
  background-color: var(--color-orange-second) !important;
}

.border-news-yellow{
  background-color: var(--color-yellow-second)!important;
}

.border-news-blue{
  background-color: var(--color-blue-second)!important;
}

.border-news-green{
  background-color: var(--color-green-second)!important;
}

.border-news-gray{
  background-color: var(--color-gray-second)!important;
}

.color-news-yellow{
  color: var(--color-yellow-second);
}

.color-news-orange{
  color: var(--color-orange-second);
}

.color-news-blue{
  color: var(--color-blue-second);
}

.color-news-green{
  color: var(--color-green-second);
}

.color-news-green{
  color: var(--color-green-second);
}

.color-news-gray{
  color: var(--color-gray-second);
}

.input-icon-text {
  border: 1px solid rgba(0, 92, 185, 0.3);
  border-right: none;
  border-radius: 0.375rem 0 0 0.375rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0 0 0.5rem;
  height: 1.8rem;
  background-color: #fff; 
}

.input-icon {
  font-size: 0.9rem;
  color: var(--color-blue-basic-rgba);
}

.label-form-basic{
  font-size: 0.86rem;
}

.form-input-basic {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: 1px solid rgba(0, 92, 185, 0.3);
  border-radius: 0.375rem;
  min-width: 11rem;
  font-size: 0.875rem;
  padding: 0.25rem 2rem 0.25rem 0.5rem;
  background-color: #fff;
  color: #333;
  height: 1.8rem;
  outline: none;
}

.form-select-input {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: 1px solid rgba(0, 92, 185, 0.3);
  border-left: none;
  border-radius: 0 0.375rem 0.375rem 0;
  width: 11rem;
  font-size: 0.86rem;
  padding: 0.25rem 2rem 0.25rem 0.5rem;
  background-color: #fff;
  color: #333;
  height: 1.8rem;
  outline: none;
}

.form-select-input-modal{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: 1px solid rgba(0, 92, 185, 0.3);
  border-left: none;
  width: 100%;
  border-radius: 0 0.375rem 0.375rem 0;
  font-size: 0.86rem;
  padding: 0.25rem 2rem 0.25rem 0.5rem;
  background-color: #fff;
  color: #333;
  height: 1.8rem;
  outline: none;
}

.form-button-basic {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: 1px solid rgba(0, 92, 185, 0.3);
  border-radius: 0.375rem;
  min-width: 9rem;
  font-size: 0.86rem;
  background-color: #fff;
  color: #333;
  height: 1.8rem;
  outline: none;
}

.button-filter-basic {
  background: linear-gradient(180deg, #7FEFF5, #00AAB7);
  color: #ffffff;
  border-radius: 3rem;
  border: none;
  padding: 0.25rem 1rem;
  font-size: 0.9rem;
}

.service-active-details {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border: 1px solid rgba(0, 92, 185, 0.3);
    border-radius: 10px 50px 50px 50px;
    min-width: 9rem;
    font-size: 0.86rem;
    background-color: var(--color-blue-dark);
    color: #ffffff;
    height: 1.8rem;
    outline: none;
    box-shadow: rgba(0, 0, 0, 0.25) 0px 0.0625em 0.0625em, rgba(0, 0, 0, 0.25) 0px 0.125em 0.5em, rgba(255, 255, 255, 0.1) 0px 0px 0px 1px inset;
}

.service-basic-details {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border-radius: 0.375rem;
    min-width: 9rem;
    font-size: 0.9rem;
    background-color: #ffffff;
    color: var(--secondary-color);
    height: 1.8rem;
    outline: none;
    border: 1px solid rgba(0, 92, 185, 0.3);
}

.service-basic-details:hover {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border-radius: 0.375rem;
    min-width: 9rem;
    background-color: #f1f1f1;
    color: var(--secondary-color);
    height: 1.8rem;
    outline: none;
    border: none;
}

.subtitle-field{
  font-size: 0.8rem;
}

.select-wrapper {
  position: relative;
  width: 100%;
}

.select-wrapper::after {
  font-family: "Font Awesome 6 Free";
  content: "\f078"; /* fa-chevron-down */
  font-weight: 900;
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  color: #005CB9;
  font-size: 0.75rem;
}

.label-form {
  font-size: 0.75rem;
  font-weight: 500;
}

.container-total{
  z-index: -1;
  position: absolute;
  text-align: center;
}

.subtitle-total{
  color: var(--color-basic);
  font-size: 0.9rem;
}

.button-assistant{
  background-color: var(--color-orange-primary);
  position: relative;
  height: 3.3rem;
  width: 3.3rem;
  border-radius: 1000px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 20px 25px -5px, rgba(0, 0, 0, 0.04) 0px 10px 10px -5px;
  transition: background-color 0.3s ease, transform 0.3s ease;
}

.button-assistant:hover{
  background-color: #ff8260;
  transform: scale(1.1)
}

.ico-assistant{
  height: 2.3rem;
}

.card-assistant{
  box-shadow: rgba(0, 0, 0, 0.16) 0px 10px 36px 0px, rgba(0, 0, 0, 0.06) 0px 0px 0px 1px;
  width: 22rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  background-color: white;
  border-radius: 6px;
}

.card-header-assistant{
  display: inline-flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  text-align: center;
  padding: 0.55rem 0.55rem 0.3rem 0.55rem;
  border-bottom: 1px solid var(--bs-border-color);
}

.title-card-assistant{
  color: var(--color-grey-darker);
  font-size: 1rem;
}

.button-close-assistant{
  border: none;
  background-color: transparent;
  color: var(--color-grey-darker);
}

.card-body-assistant{
  padding: 0.8rem;
  min-height: 20vh;
  overflow-y: auto;
}

.card-footer-assistant{
  width: 100%;
  display: inline-flex;
  padding: 0.8rem;
}

.message-assistant{
  background-color: var(--color-blue-aux);
  font-size: var( --font-size-xs-sm);
  max-width: 80%;
  border-radius: 0.6rem;
  padding: 2%;
}

.message-user{
  background-color: var( --color-grey-second);
  font-size: var( --font-size-xs-sm);
  max-width: 80%;
  border-radius: 0.6rem;
  padding: 2%;
}

.button-send{
  background-color: var(--color-grey);
  border-radius: 1000px;
  outline: none;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border: none;
}

.button-send i{
 color: var(--color-basic);
}

.button-send:hover{
  cursor: pointer;
}


.form-check-input:checked {
  background-color: var(--color-basic) !important;
  border-color: var(--color-basic) !important;
}

.form-check-label{
  font-size: var( --font-size-xs-sm) !important;
}

.table-details{
  table-layout: fixed;
  width: 100%;
}

.header-table tr th{
  background-color: var(--background-table);
  color: var(--color-grey-darker);
  font-size: 0.9rem;
}

.body-table tr td{
  font-size: 0.8rem;
  align-items: center;
  vertical-align: middle;
  text-transform: capitalize;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.box-actions{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}

.icon-actions{
  color: var(--color-grey-darker);
}

.icon-table{
  color: var(--secondary-color);
}

.icon-bar{
  height: 1rem;
  margin-right: 5px ;
  filter: brightness(0) invert(1);
}

.bg-status-primary{
  background-color: var(--background-status-primary);  
  color: var(--color-status-primary);
  border-radius: 4px;
  font-weight: 500;
  padding: 0.38rem 0.5rem;
  font-size: 0.75rem;
  text-transform: capitalize;
  width: 95%;
  display: flex;
  text-align: center;
  justify-content: center;
}

.bg-status-second{
  background-color: var(--background-status-second);
  color: var(--color-status-second);
  border-radius: 4px;
  font-weight: 500;
  padding: 0.38rem 0.5rem;
  font-size: 0.75rem;
  text-transform: capitalize;
  width: 95%;
  display: inline-block;
  text-align: center;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bg-status-three{
  background-color: var(--background-status-three);
  color: var(--color-status-three);
  border-radius: 4px;
  font-weight: 500;
  padding: 0.38rem 0.5rem;
  font-size: 0.75rem;
  width: 95%;
  text-transform: capitalize;
  display: inline-block;
  text-align: center;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bg-status-four{
  background-color: var(--background-status-four);
  color: var(--color-status-four);
  border-radius: 4px;
  font-weight: 500;
  padding: 0.38rem 0.5rem;
  font-size: 0.75rem;
  text-transform: capitalize;
  width: 95%;
  display: inline-block;
  text-align: center;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bg-status-five{
  background-color: var(--background-status-five);
  color: var(--color-status-five);
  border-radius: 4px;
  font-weight: 500;
  padding: 0.38rem 0.5rem;
  font-size: 0.75rem;
  text-transform: capitalize;
  width: 95%;
  display: inline-block;
  text-align: center;
  justify-content: center;
  white-space: nowrap;     
  overflow: hidden;   
  text-overflow: ellipsis;
}

.bg-status-six{
  background-color: var(--background-status-six);
  color: var(--color-status-six);
  border-radius: 4px;
  font-weight: 500;
  padding: 0.38rem 0.5rem;
  font-size: 0.75rem;
  text-transform: capitalize;
  width: 95%;
  display: inline-block;
  text-align: center;
  justify-content: center;
  white-space: nowrap;    
  overflow: hidden;        
  text-overflow: ellipsis;
}

.bg-status-seven{
  background-color: var(--background-status-seven);
  color: var(--color-status-seven);
  border-radius: 4px;
  font-weight: 500;
  padding: 0.38rem 0.5rem;
  font-size: 0.75rem;
  text-transform: capitalize;
  width: 95%;
  display: inline-block;
  text-align: center;
  justify-content: center;
  white-space: nowrap;  
  overflow: hidden;        
  text-overflow: ellipsis;
}

 .bg-status-eight{
   background-color: var(--background-status-eight);
   color: var(--color-status-eight);
   border-radius: 4px;
   font-weight: 500;
   padding: 0.38rem 0.5rem;
   font-size: 0.75rem;
   text-transform: capitalize;
   width: 95%;
   display: inline-block;
   text-align: center;
   justify-content: center;
   white-space: nowrap;
   overflow: hidden;
   text-overflow: ellipsis;
 }

.bg-status-nine{
  background-color: var(--background-status-nine);
  color: var(--color-status-nine);
  border-radius: 4px;
  font-weight: 500;
  padding: 0.38rem 0.5rem;
  font-size: 0.75rem;
  text-transform: capitalize;
  width: 95%;
  display: inline-block;
  text-align: center;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tag-details{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 8rem;
  border-radius: 0.6rem;
  text-align: center;
}

.button-action{
  width: 80%;
}

.button-info-details{
  background-color: transparent;
  border-radius: 6px;
  padding: 0.2rem 0.3rem;
  min-width: clamp(6rem, 25vw, 8rem);
  font-size:0.75rem;
  display: inline-flex;
  justify-content: center;
  align-items: center;
}

.button-info-details.complete{
  color: var(--success-color);
  border: 1px solid var(--success-color);
}

.button-info-details.partial{
  color: var(--partial-color);
  border: 1px solid var(--partial-color);
}

.button-info-details.incomplete{
  color: var(--error-color);
  border: 1px solid var(--error-color);
}

.icon-info-details{
  width: 1.05rem;
  height: 1.05rem;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  padding: 0.25rem;
  border-radius: 1rem;
  background-color: transparent;
}

.icon-info-details.complete{
  color: var(--success-color);
  margin-top: 0.03rem;
}

.icon-info-details.partial{
  color: var(--partial-color);
  margin-top: 0.03rem;
}

.icon-info-details.incomplete{
  color: var(--error-color);
  margin-top: 0.03rem;
}

.container-section{
  border: 1px solid var(--color-blue-basic-rgba);
  border-radius: 10px;
  padding: 0.8rem;
  font-size: 0.8rem;
}

.container-labels{
  background-color: var(--color-grey);
  font-weight: 600;
  color: var(--color-grey-darker);
  padding: 0.8rem;
  border-radius: 4px;
}

.container-pagination{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  justify-content: center;
  align-items: center;
}

.title-pagination{
  color: var(--color-basic);
  font-size: var( --font-size-xs);
  font-weight: 600;
}

.pagination {
  --bs-pagination-color: var(--color-gray-base) !important;
  --bs-pagination-active-bg: var( --color-basic-rgba) !important;
  --bs-pagination-active-color: var( --color-basic) !important;
  --bs-pagination-active-border-color: rgba(13, 110, 253, 0) !important;
  --bs-pagination-border-color:none !important;
}

.page-item{
  margin-right: 5px !important;
  display: flex;
  justify-content: center;
  align-items: center;
}

.page-link{
  clip-path: circle(50% at 50% 50%) !important;
  width: 2rem !important;
  font-size: 0.85rem !important;
}

.accordion {
  --bs-accordion-color: var(--color-gray-base)!important;
  --bs-accordion-bg: var(--bs-body-bg);
  --bs-accordion-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, border-radius 0.15s ease;
  --bs-accordion-border-color: var(--bs-border-color);
  --bs-accordion-border-width: var(--bs-border-width);
  --bs-accordion-border-radius: var(--bs-border-radius);
  --bs-accordion-inner-border-radius: calc(var(--bs-border-radius) - (var(--bs-border-width)));
  --bs-accordion-btn-padding-x: 1.25rem;
  --bs-accordion-btn-padding-y: 1rem;
  --bs-accordion-btn-color: var(--bs-body-color);
  --bs-accordion-btn-bg: var(--bs-accordion-bg);
  --bs-accordion-btn-icon-width: 1.25rem;
  --bs-accordion-btn-icon-transform: rotate(-180deg);
  --bs-accordion-btn-icon-transition: transform 0.2s ease-in-out;
  --bs-accordion-btn-focus-box-shadow: none !important;
  --bs-accordion-body-padding-x: 1.25rem;
  --bs-accordion-body-padding-y: 1rem;
  --bs-accordion-active-color: var(--color-grey-darker)!important;
  --bs-accordion-active-bg: var(--color-grey)!important;
}

.accordion-button {
  font-size: 0.87rem !important;
  padding: 0.5rem 1rem !important;
}

.accordion-button:not(.collapsed) {
  font-weight: 600!important;
}

.accordion-button.collapsed {
  border-radius: 0.5rem;
}

.item-category-accordion{
  color: var(--color-grey-darker);
  font-weight: 600;
}
td.item-tax-accordion {
    color: var(--color-grey-darker);
    font-weight: 600;
    font-size: 0.95em;
    padding-left: 2rem;
}

.spinner-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(38, 131, 207, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(1px);
  z-index: 3000;
  opacity: 1;
  transition: opacity 0.3s ease-in-out;
}

.spinner-container {
  text-align: center;
  background-color: #ffffff;
  color: var(--color-grey-darker);
  border-radius: 8px;
  padding: 1.1rem 2rem 1rem 2rem;
  min-width: 15vw;
  width:auto;
  height: auto;
  min-height: 18vh;
}

.spinner-gif {
  height:15vh;
  background-image: url("/images/context/spinner.gif");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 80%;
}

.spinner-message{
  font-size: var(--font-size-xs);
}

.custom-modal-accordion-item {
    border-radius: 8px;
    margin-bottom: 8px;
    overflow: hidden;
    border: 1.5px solid var(--color-blue-basic-rgba) !important;
}

.custom-accordion-item {
  border-radius: 8px;
  margin-bottom: 8px;
  overflow: hidden;
}

.custom-accordion-header {
  background-color: #ffffff;
  padding: 12px 16px;
  cursor: pointer;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  user-select: none;
  transition: background 0.2s ease;
  background-image: url("/images/context/tag-category.png");
  background-repeat: no-repeat;
  background-position: right;
  color: #ffffff;
  font-size: 1rem;
}

.card-accordion-title{
  color: var(--color-blue-dark);
  padding: 0.8rem 1rem;
  display: inline-flex;
  justify-content:space-between;
  font-weight: 600;
  font-size: 0.9rem;
}

.custom-accordion-header:hover {
  /*background-color: #ececec;*/
}

.custom-accordion-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
  padding: 0 16px;
}

.custom-accordion-body.show {
  max-height: max-content;
  padding: 16px 0;
}

.arrow {
  transition: transform 0.3s ease;
}

.arrow.open {
  transform: rotate(180deg);
}

.button-section-collapse {
  border: var(--color-basic) 1px solid;
  color: var(--color-basic);
  align-self: flex-end;
  background-color: #ffffff;
  border-radius: 6px;
  width: 12vw;
  max-width: max-content;
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.3rem 0.8rem;
    font-size: 0.8rem;
}

.subtitle-accordion {
  color: var(--color-blue-dark);
  font-size: 0.75rem;
  font-style: italic;
}

.image-accordion{
  height: 4vh;
  border-radius: 10px;
}

.container-details-accodion{
  background-color: var(--color-grey);
  font-size: 0.8rem;
  padding: 0.5rem;
    border-radius: 0 0.6rem 0.6rem 0.6rem;
}

.no-caret::after {
  display: none !important;
}

.button-header{
  background: transparent;
  border-radius: 1000px;
  border: none;
  padding: 0.2rem 0.5rem;
}

.button-header:hover{
  background-color: #05559b;
}

.dropdown-item.active,
.dropdown-item:active,
.dropdown-item:focus {
  background-color: var(--color-blue-aux) !important;
  color: #05559b !important;
}

.footer-not-found {
  position: relative; 
  width: 100%;
  height: 35vh;      
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.subtitle-not-found{
  font-family: cursive, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-gray-base);
}

.footer-404 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  filter: blur(60px);
}

.logo-404 {
  position: relative;
  height: 5vh;
  margin-right: 3.5%;
  z-index: 2;
}

.image-404{
  height: 35vh;
  margin-top: 10vh;
}


.divider-section{
  width: 2px;
  background-color: var(--color-basic-rgba);
  margin: 2% 0 2% 0;
  border-radius: 50px;
}


.dropdown-with-backdrop:has(.dropdown-menu.show)::after {
  content: "";
  position: fixed;
  top: 7rem;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(38, 131, 207, 0.15);
  backdrop-filter: blur(1px);
  z-index: 40;
}

.item-submain{
  font-size: 0.85rem;
}

.ico-submain-header{
  font-size: 2vh !important;
  color: var(--color-blue-basic-rgba);
  margin: 0 !important;
  padding: 0.5rem 0;
}

.dropdown-menu-header {
  min-width: 21rem !important;
}

.dropdown-item.active,
.dropdown-item:active {
  background-color: transparent !important;
  color: inherit !important;
}
.no-scroll {
    position: fixed; /* bloquea la página para que no se mueva */
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
}
.modal-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1040;
    width: 100vw;
    height: 100vh;
    background-color: #000;
    opacity: .5;
}
.dropdown-menu a:not([href]).dropdown-item:not(.disabled) {
   cursor: inherit !important; 
}

.divider-submain{
  border-bottom: 1px solid var(--bs-dropdown-divider-bg);
  margin: 0 0.6rem;
}

.modal-overlay {
  position: fixed;
  top: 0; left: 0;
  width: 100vw; height: 100vh;
  background-color: rgba(38, 131, 207, 0.21);
  display: flex; justify-content: center; align-items: center;
  z-index: 2000 !important;
}

.modal-content {
  background: white;
  border-radius: 10px;
  padding: 0.8rem 1.1rem 1.1rem 1.1rem;
  min-width: 30rem;
  max-width: 40rem;
  width: auto;
  box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}
#ajusteGeneralModal-@air.Reservation .modal-content {
    width: 600px !important;
    max-width: 100% !important;
}

#ajusteGeneralModal-@air.Reservation .modal-dialog {
    max-width: 600px !important;
    width: 100% !important;
}

.title-modal{
  font-size: 1.2rem;
  color: var(--color-blue-dark);
  font-weight: 600;
}

.subtitle-modal{
  font-size: 0.85rem;
}

.btn-modal-close{
  border: none;
  background-color: transparent;
}
.btn-modal-close i{
  color: var(--secondary-color);
  font-size: 1.5rem;
}

.message-info{
  padding: 0.5rem;
  display: flex;
  justify-content: flex-start;
  border: 1px solid var(--color-blue-basic-rgba);
  border-radius: 10px;
  font-size: 0.8rem;
  align-items: center;
  width: 80%;
  align-self: center;
  background-color: var(--color-blue-info);
}

.message-info i{
  color: var(--color-blue-basic-rgba);
  font-size: 1.2rem;
}

.container-result-modal{
  display: flex; 
  justify-content: center;
  align-items: center;
  border: 2px dashed var(--color-blue-dark);
  padding: 1rem 0.5rem;
  background: #ffffff;
  border-radius: 15px;
}

.title-result-modal{
  color: var(--color-blue-dark);
  font-weight: 600;
  text-align: center;
}

.menu-container {
  display: flex;
  align-items: center;
  position: relative;
  width: 100%;
  padding: 5px 0;
  justify-content: center;
}

.menu-scroll {
  display: flex;
  gap: 20px;
  /*overflow-x: auto; */
  overflow-x: visible;  
  overflow-y: visible;
  scroll-behavior: smooth;
  scrollbar-width: none;
}
.menu-scroll::-webkit-scrollbar {
  display: none;
}

.scroll-btn {
  background: rgba(255, 255, 255, 0.2);
  border: none;
  color: white;
  font-size: 24px;
  font-weight: bold;
  cursor: pointer;
  padding: 5px 10px;
  width: 3rem;
  border-radius: 50%;
  z-index: 5;
  transition: background 0.3s;
}
.scroll-btn:hover {
  background: rgba(255, 255, 255, 0.4);
}

.scroll-btn.left {
  position: absolute;
  left: 5px;
}
.scroll-btn.right {
  position: absolute;
  right: 5px;
}

.table-responsive-custom {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch; 
}

.table-responsive-custom table {
  min-width: 900px; 
  border-collapse: collapse;
}

.table-details th,
.table-details td {
  white-space: nowrap; 
}

.subtitle-details-profile{
    color: var(--color-gray-base);
    font-size: 0.9rem;
}

.table-commision{
    height: 38vh;
    overflow-y: auto;
}

.pie-chart-size {
    width: auto;
    height: auto;
    max-width: 19rem ;
    max-height: 19rem ;
}

.subtitle-filters-modal{
    font-size: 0.8rem;
    width: 70%;
    text-align: end;
    line-height: 1.2;
}

.btn-filter{
    background: #ffffff;
    min-width: 13rem;
    border: none;
    border-radius: 0.4rem;
    padding: 0.3rem 1rem;
    display: flex;
    color: var(--color-grey-darker);
    align-items: center;
    justify-content: flex-start;
    font-size: 0.85rem;
    outline: none;
    box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}


.btn-filter:focus,
.btn-filter:active {
  outline: none !important;
  box-shadow: none !important;
}


.btn-filter-active{
    background: var(--color-grey);
    border: 1px solid var(--color-blue-basic-rgba);
    border-radius: 0.4rem;
    padding: 0.3rem 1rem;
    display: flex;
    color: var(--color-blue-dark);
    align-items: center;
    justify-content: space-between;
    font-size: 0.9rem;
    box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
}

.btn-filter:hover {
  color: var(--color-basic);
  cursor: pointer;
}

.form-filters{
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border: 1px solid rgba(0, 92, 185, 0.3);
    border-radius: 0.375rem;
    width: 100%;
    font-size: 0.85rem;
    padding: 0.25rem 0.5rem 0.25rem 0.5rem;
    background-color: #fff;
    color: #333;
    height: 1.8rem;
    outline: none;
}

.label-filter{
    font-size: 0.8rem !important;
    margin-bottom: 0.1rem !important;
}

@keyframes modal-zoomout {
    from { opacity: 1; transform: scale(1); }
    to { opacity: 0; transform: scale(0.95); }
}

.modal:not(.show) {
    display: none ;
    animation: modal-zoomout 0.3s ease-out !important;
}

.btn-clean-filters{
  border: none;
  border-radius: 1000px;
  background: transparent;
  margin-top: -2vh;
  color: var(--error-color);
}

.active-filter{
  background-color: var(--color-blue-aux);
}

.container-charges{
  background-color: var(--color-grey);
    border-radius: 10px;
}

.divider-passenger{
    border-right: 1.5px solid var(--color-blue-dark);
    padding: 0 1rem;
    font-size: 0.9rem;
}

.footer-charges{
  font-size: 1rem;
  color: var(--color-basic);
  padding: 0 1rem;
}

.footer-charges-general{
    font-size: 1rem;
    color: var(--color-blue-dark);
    padding: 0 1rem;
}

.title-section-charges{
  padding: 1rem 1rem 1rem 0;
  color: var(--color-basic)
}

.ico-details{
  height: 2.5vh;
  border-right: 1.5px solid var(--color-blue-dark);
}

.title-journey{
  background-color: var(--color-grey-darker);
  color: white;
  padding: 0.2rem 1.5rem;
  margin-left: -0.5vw;
  border-top-left-radius: 0.6rem;
  border-top-right-radius: 0.6rem;
}

.wrap-text-control {
    white-space: normal !important; 
    word-wrap: break-word;
    font-size: 0.8rem !important;
    vertical-align: middle;
}

.header-table-tax{
    font-weight: 500;
    background-color: var(--color-blue-info)!important;
    color: var(--color-blue-dark) !important;
}

.title-ticket{
  color: var(--color-blue-dark);
  font-size: 0.9rem;
  font-weight: 600;
}

.cod-origin{
  color: var(--color-grey-darker);
  font-weight: 700;
}

.input-group-text {
  cursor: pointer;
}

input[type="date"]::-webkit-calendar-picker-indicator {
  opacity: 0;
}

.border-date{
  border: 1px solid rgba(0, 92, 185, 0.3);
}

input:focus, .form-control:focus {
  outline: none !important;
  box-shadow: none !important;
  border-color: #ccc !important;
}

.btn-states-disabled{
  background-color: var(--bs-secondary-bg);
  opacity: 1;
}


.toast-container {
  top: 1rem;
  right: 1rem;
}

.toast-custom {
  border-radius: 0.6rem;
  background: white;
  padding: 0.75rem;
  width: 20rem;
  box-shadow: rgba(0, 0, 0, 0.25) 0px 54px 55px, rgba(0, 0, 0, 0.12) 0px -12px 30px, rgba(0, 0, 0, 0.12) 0px 4px 6px, rgba(0, 0, 0, 0.17) 0px 12px 13px, rgba(0, 0, 0, 0.09) 0px -3px 5px;
  color: var(--color-gray-base);
  animation: fadeInDown 0.4s ease;
  font-weight: 400;
  font-style: italic;
  font-size: 0.8rem;
}

.toast-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
}

.toast-info {
  font-size: 1rem;
  color: #249cdc;
  opacity: 0.8;
}

.toast-success {
  font-size: 1rem;
  color: #4dcc97;
  opacity: 0.8;
}

.toast-warning {
  color: #e3c05b;
  font-size: 1rem;
  opacity: 0.8;
}

.toast-error {
  color: #e85766;
  font-size: 1rem;
  opacity: 0.8;
}

.toast-custom,
.toast-body {
  pointer-events: auto !important;
}

.tour-code-selected{
  color: var(--color-blue-dark);
  padding: 0.25rem 0.5rem 0.25rem 0.5rem;
  border: dashed var(--color-blue-dark) 1px;
  border-radius: 0.6rem;
}

.btn-primary-additional{
  background-color: transparent;
  color: var(--color-gray-base);
  border: 1px solid transparent;
  box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 1px 3px 1px;
  text-transform: capitalize;
  border-radius: 0.4rem;
  font-size: 0.83rem;
  padding: 0.4rem 1rem;
}

.btn-primary-additional:hover{
  border: 1px solid var(--color-grey-darker);
}

.required-btn{
  background-color: #E6F4FF;
  color: var(--color-blue-dark);
}

.field-required{
  width: 1vw;
  height: 2vh;
  border-radius: 1000px;
  background-color: #E6F4FF;
  box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px;
}

.field-optional{
  width: 1vw;
  height: 2vh;
  border-radius: 1000px;
  box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px;
}

.detail-container-additional{
  border-radius: 0.4rem;
  padding: 0.2rem;
  max-height: 30vh;
  overflow-y: auto;
}

.detail-container-select{
  border-radius: 0.4rem;
  padding: 0.2rem;
  max-height: 32vh;
  overflow-y: auto;
}

.row-detail-additional{
  background-color: #ffffff;
  box-shadow: rgba(9, 30, 66, 0.25) 0px 4px 8px -2px, rgba(9, 30, 66, 0.08) 0px 0px 0px 1px;
  font-size: 0.85rem;
}

.row-detail-additional:hover{
  cursor: pointer;
}

.selected-additional{
  background-color: #E8F7F0;
}

.active-btn-category{
  background-color: var(--background-tab-blue);
  clip-path: polygon(95% 0, 100% 50%, 95% 100%, 0% 100%, 3% 50%, 0% 0%);
  color: #ffffff;
  border-radius: 0;
}

.detalle-item-additional{
  padding: 0.3rem 0.5rem 0.3rem 1.3rem;
  border: 1px solid var(--color-message-primary-rgba);
  border-radius: 3rem;
  line-height: 1rem;
  font-size: 0.95rem;

}

.item-additional-subtitle{
  font-size: 0.7rem;
  font-style: italic;
}

.message-info-additional{
  padding: 0.5rem;
  display: flex;
  border: 1px solid var(--color-blue-basic-rgba);
  border-radius: 10px;
  font-size: 0.71rem;
  max-width: 100%;
  /*background-color: var(--color-blue-info);*/
  color: #1574AC;
}

.encabezado-additional{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr ;
  color: var(--color-grey-darker);
}

.text-ellipsis {
  white-space: nowrap;       
  overflow: hidden;          
  text-overflow: ellipsis;   
  max-width: 12rem;
  display: block;
  padding: 0 0.5rem;
}

.message-error-additional{
  padding: 0.2rem 0.5rem;
  display: flex;
  border: 1px solid var(--color-message-error-rgba);
  border-radius: 10px;
  font-size: 0.71rem;
  width: fit-content;
  background-color: var(--background-status-three);
  color: var(--error-color);
  justify-content: flex-end;
}

.message-success-additional{
  padding: 0.5rem;
  display: flex;
  border: 1px solid var(--color-message-info);
  border-radius: 10px;
  font-size: 0.71rem;
  width: fit-content;
  background-color: #E8F7F0;
  color: var(--success-color);
  justify-content: flex-end;
}

.iframe-wrapper {
  position: relative;
  flex: 1;
  display: flex;
  align-items: flex-end;
}

.iframe-product {
  width: 100%;
  min-height: calc(100vh - 7.65rem);
  height: auto;
  overflow-y: hidden;
  border: none;
  opacity: 0;
  transition: opacity 0.2s ease-in-out;
}

.iframe-visible {
  opacity: 1;
}

.container-fluid{
  height: 100%;
}

.nav-item-vu {
  transition: all 0.2s ease-in-out;
}

.nav-item-active {
  border: 0.8px solid rgba(255, 255, 255, 0.8);
  border-radius: 8px;
}

.nav-item-active:hover {
  background: none;
}

.loader-overlay-iframe{
  position: absolute;
  inset: 0;
  z-index: 10;
  background: rgba(255, 255, 255, 0.9);
}

.btn-logo-company{
  box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
  padding: 0.5rem;
  border: none;
  background-color: white;
  border-radius: 0.4rem;
  height: 5.5rem;
  width: 7rem;
}

.name-btn-company{
  font-size: 0.8rem;
}

.container-main-preferences{
  width: fit-content;
  background-color: #ffffff;
  box-shadow: rgba(42, 165, 251, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 1px 3px 1px;
  border-radius: 6px;
  min-width: 20rem;
}

.btn-background{
  background: linear-gradient(50deg, var(--color-blue-dark) 41%, rgb(0 120 223) 94%);
  padding: 0.5rem 1rem;
  display: flex !important;
  justify-content: center;
  border-radius: 0.3rem;
  color: white;
  opacity: 0.8;
}

.btn-logo-company-active{
  border: 1.5px solid var(--color-basic) !important;
}

.ico-check-company{
  color: var(--color-basic);
}

.btn-logo-company:hover{
  transform: scale(1.08);
  transition: all 0.2s ease-in-out;
  background: #F9FAFB;
}

.divider-preferences{
  width: 100%;
  height: 2px;
  background-color: #dadada;
  border-radius: 0.2rem;
}

.logo-color-btn{
  color: var(--color-blue-dark);
  font-size: 1.5rem;
}

.palette-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0.8rem;
  border-radius: 12px;
  border: 2px solid #E5E7EB;
  cursor: pointer;
  transition: all .2s ease;
  position: relative;
  background-color: #ffffff;
}

.palette-card:hover {
  background: #F9FAFB;
}

.palette-card.active {
  border-color: #2563EB;
  background: #EFF6FF;
}

.palette-colors {
  display: flex;
  align-items: center;
  gap: 6px;
}

.color-box {
  width: 1rem;
  height: 1rem;
  border-radius: 4px;
}

.radio-indicator {
  width: 20px;
  height: 20px;
  border: 2px solid #D1D5DB;
  border-radius: 50%;
  margin-left: 8px;
}

.palette-info p {
  margin: 4px 0 0;
  font-size: 14px;
  color: #6B7280;
}

.check-icon {
  position: absolute;
  right: 16px;
  color: #2563EB;
  font-size: 18px;
}

.image-reference {
  height: 12vh;
}

.image-reference-wrapper {
  position: relative;
  background: linear-gradient(
          210deg,
          var(--g-color-1) 33%,
          var(--g-color-2) 75%,
          var(--g-color-3) 100%
  );
  transition: background 0.35s ease-in-out;
}

.image-reference-white{
  position: relative;
  background: linear-gradient(
          280deg,
          var(--g-color-1) 13%,
          var(--g-color-2) 30%,
          var(--g-color-3) 70%
  );
  transition: background 0.35s ease-in-out;
}


.logo-view-preview {
  position: absolute;
  z-index: 20;
  height: 3vh;
  margin-top: 1vh;
  left: 1vw;
  align-self: flex-start;
}

.transition-loading-init{
  opacity: 0;
  transition: opacity 0.2s ease-in-out;
}

.transition-loading-end{
  opacity: 1;
}

/* Fecha publicacion 28/01/2025*/
 
/* Responsive avanzado */
@media (max-width: 576px) {
  /* Celulares pequeños */
  body {
    font-size: 0.9rem;
  }
  .container {
    padding: var(--space-xs);
  }
  .button {
    width: 100%;
    padding: 0.75rem;
    font-size: var(--font-size-sm);
  }
  .button-tab {
    font-size: 0.9rem;
    padding: 0.3rem 0.6rem;
    flex: 1 1 100%;
  }

  .menu-scroll {
    overflow-x: auto !important;
    overflow-y:hidden;
  }

  .nav-item {
    position: static !important;
  }

    .container-grey {
        padding: 1rem !important;
    }

  .btn-filter{
    height: 3rem !important;
  }

  .form-filters{
    height: 2.5rem !important;
  }
  
  .input-login{
    height: 3rem !important;
  }

  .container-profile{
    grid-template-columns: repeat(2, 1fr)!important;
  }
  
  .navbar-logo img{
    max-height: 1.2rem !important;
  }

}

@media (min-width: 577px) and (max-width: 768px) {
  /* Celulares grandes y tablets */
  .container {
    padding: var(--space-sm);
  }
  .button-tab {
    font-size: 0.95rem;
    padding: 0.4rem 0.8rem;
  }

  .menu-scroll {
    overflow-x: auto !important;
    overflow-y:hidden;
  }

  .nav-item {
    position: static !important;
  }

  .container-grey {
    padding: 1rem !important;
  }

  .btn-filter{
    height: 3rem !important;
  }
  
  .form-filters{
    height: 2.5rem !important;
  }

  .container-profile{
    grid-template-columns: repeat(2, 1fr)!important;
  }

  .navbar-logo img{
    max-height: 1.2rem !important;
  }

}

@media (min-width: 769px) and (max-width: 1024px) {
  /* Tablets y laptops pequeñas */
  .container {
    padding: var(--space-md);
  }
    .container-grey {
        padding: 2rem 3rem !important;
    }

  .menu-scroll {
    overflow-x: auto !important;
    overflow-y:hidden;
  }

  .nav-item {
    position: static !important;
  }

  .container-grey {
    padding: 1rem !important;
  }
}

@media (min-width: 1025px) and (max-width: 1440px) {
  /* Escritorios comunes */
  .container {
    padding: var(--space-md);
  }
}

@media (min-width: 1441px) {
  /* Pantallas grandes y televisores */
  html {
    font-size: 1.125rem;
  }
  .container {
    max-width: 1600px;
    padding: var(--space-lg);
  }
}
