:root {
    --color-fondo-claro: #EDEDED;
    --color-fondo2: #ffffff;
    
    --color1: #014175;
    --color2: #151515;
    --color3: #012F53;
    --color4: #FF0000;
    --color5: #F95903;


    --color-letra1: #3c3c3c;
    --color-letra2: #28292A;
    
        --paddmin: Calc(100% * 0.010183295); 
        --padd1: Calc(100% * 0.02036659); /*10px*/
        --padd2: Calc(100% * 0.04073318); 
    
        --spaceicon1: 1.018329%;
        --spaceicon2: 2.036659%;
    
        --radius1: 5px;
        --radius2: 10px;
    }
    @import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
    
    html {
        height: -webkit-fill-available;
    }
    
    body {
        font-family: 'Montserrat', Arial, Helvetica, sans-serif;
        padding: 0;
        margin: 0;
        color: var(--color-letra2);
        font-size: 100%;
        height: 100vh;
        height: -webkit-fill-available;
        
    }
    div::-webkit-scrollbar{
        display: none;
      }
      div::-webkit-scrollbar {
        width: 0 !important
        }
    textarea {
        font-family: 'Quicksand', Arial, Helvetica, sans-serif;
        color: var(--color5);
        font-size: 100%;
        height: auto;
    }
    
    div {
        -webkit-touch-callout: none;
        -webkit-user-select: none;
        -khtml-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        font-weight: normal;
        font-size: 100%;
    }
    table, th, tr, td {
        font-size: 100%;
        color: white;
    
    }
    .input1{
        font-size: 120%;
        padding: var(--padd2);
        border: thin solid var(--color3);
        border-radius: var(--radius2);
        width: 100%;
        background-color: var(white);
        margin: var(--padd1) 0px;
        color:#240D5A;
    }
    
    input[type='radio']:after {
        width: 15px;
        height: 15px;
        border-radius: 15px;
        top: -2px;
        left: -1px;
        position: relative;
        background-color: #d1d3d1;
        content: '';
        display: inline-block;
        visibility: visible;
        border: 2px solid white;
    }
    
    input[type='radio']:checked:after {
        width: 15px;
        height: 15px;
        border-radius: 15px;
        top: -2px;
        left: -1px;
        position: relative;
        background-color: var(--color2);
        content: '';
        display: inline-block;
        visibility: visible;
        border: 2px solid white;
    }
    input[type='checkbox']:after {
        width: 15px;
        height: 15px;
        border-radius: 3px;
        top: -2px;
        left: -1px;
        position: relative;
        background-color: #d1d3d1;
        content: '';
        display: inline-block;
        visibility: visible;
        border: 2px solid white;
    }
    
    input[type='checkbox']:checked:after {
        width: 15px;
        height: 15px;
        border-radius: 3px;
        top: -2px;
        left: -1px;
        position: relative;
        background-color: var(--color2);
        content: '';
        display: inline-block;
        visibility: visible;
        border: 2px solid white;
    }

    .divClick{
        padding: var(--padd1) var(--padd2);
        padding-left: var(--padd1);
        font-size: 110%;
        border-radius: var(--radius1);
    }
        .divClick:active{
            
            background-color: rgba(50, 50, 50, 0.10);
        }
    
        .IcoClick:active{
            
            background-color: rgba(50, 50, 50, 0.10);
        }
/*DIVS - CONTENEDORES */
/* SLIDER */
.slide-wrap-item {margin: 0px; padding: 0px; }
.slider-item { padding-top:0px; width: 100%; height: auto; display: flex; overflow: hidden; overflow-x: auto; -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory;   }
.slide-item { flex-shrink: 0; height: auto; display: inline-block; padding: 10px 10px; color: #424242; text-align: center; }
.slide-item-seleccion { padding: 10px 10px;  background-color: var(--color-controles-base-medium); color:white; }
/* END SLIDER */

@keyframes placeHolderShimmer{
    0%{
        background-position: -468px 0
    }
    100%{
        background-position: 468px 0
    }
}

.animated-background {
    animation-duration: 1.25s;
    animation-fill-mode: forwards;
    animation-iteration-count: infinite;
    animation-name: placeHolderShimmer;
    animation-timing-function: linear;
    background: var(--color4);
    background: linear-gradient(to right, var(--color3) 10%, var(--color1) 18%, var(--color3) 33%);
    background-size: 800px 104px;
    height: 100%;
    position: relative;
}

.icono-badge {
    position: relative;
    display: inline-block;
    font-size: 24px;
}

.badge {
    position: absolute;
    top: -5px;
    right: -8px;
    background: red;
    color: white;
    font-size: 12px;
    padding: 2px 6px;
    border-radius: 50%;
}


.divProfileImage{
    border: 2px solid #FFFFFF; border-radius:50%; 
    -webkit-box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
    -moz-box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
    box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
}

.divContenedorResultado{
    margin: var(--padd1) var(--padd2); padding: var(--padd1) var(--padd2); border: 1px solid var(--color-letra1);  border-radius: var(--radius2); background: linear-gradient(to bottom, var(--color2), var(--color3));
    -webkit-box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
    -moz-box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
    box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
}
    .divContenedorResultadoChico{
        margin: var(--paddmin) var(--padd1); padding: var(--paddmin) var(--padd1); border: 1px solid var(--color-letra1);  border-radius: var(--radius2); background: linear-gradient(to bottom, var(--color-letra2), var(--color2));
        -webkit-box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
        -moz-box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
        box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
    }

.divSelectorOn{
    height: 2px;
    width: 100%;
    padding-bottom: var(--paddmin);
    border-bottom: 3px solid var(--color1);
    border-bottom-left-radius: 3px;
    border-bottom-right-radius: 3px;
}
.divSelectorOff{
    height: 2px;
    width: 100%;
    padding-bottom: calc(var(--paddmin) + 3px);
    
    
}

.divSeparador{
    height: 2px;
    background-color: var(--color4);
    width: 100%;
    margin: var(--padd1) 0px;
}
.divSeparadorLeve{
    height: 1px;
    background-color: white;
    width: 100%;
    margin: calc(var(--padd1) / 2) 0px;
    opacity: 0.3;
}

/* ------------  DIVS MOVIMIENTOS   ------------------ */
.DivMov_Menu{
    height: 0px;
    width: 100%;
    background: rgba(255,255,255,1);
    color: var(--color-separadores);
    top: 0;
    position:absolute;
    transition: height 0.3s ease-in-out;
    z-index: 9999;
    
}
    .DivMov_Menu_Mostrar{
        height: 5%;
        transition: height 0.2s ease-in-out;
    }
  
    .DivMov_Menu_Ocultar{
        height: 0px;
        transition: height 0.2s ease-in-out;
    }
/* ------------  DIVS MOVIMIENTOS --------------------- */
/* ------------  TITULOS --------------------- */
.divTitulo{
    font-size: 150%;
    letter-spacing: -1px;
    font-weight:600;
}

.divTituloMedio{
    font-size: 120%;
    letter-spacing: -1px;
    font-weight:600;
}
    .divTituloMedioBoton{
        font-size: 100%;
        letter-spacing: -1px;
        font-weight:600;
         background-color: var(--color1);
        display: inline-block;
        padding: var(--paddmin);
        border-radius: var(--radius1);
        color: white;
        text-transform: uppercase;
    }

.divTituloChico{
    font-size: 100%;
    letter-spacing: -1px;
    font-weight:600;
}
    .divTituloChicoBoton{
        font-size: 85%;
        letter-spacing: -1px;
        font-weight:600;
        background-color: var(--color1);
        display: inline-block;
        padding: calc(var(--paddmin)/2);
        border-radius: var(--radius1);
        color: white;
    }

.divTituloMini{
    font-size: 80%;
    letter-spacing: -0.5px;
    font-weight:500;
    opacity: 0.8;
}
.divTituloMiniB{
    font-size: 80%;
    letter-spacing: -1px;
    font-weight:600;
}

.divMarcadorGde{
    font-size: 180%;
    letter-spacing: -1px;
    font-weight:600;
}
/* ESTILOS TEXTOS */

.divTitulo_Grande {
    font-size: 190%;
    font-weight:400;
    letter-spacing: -0.8px;
    font-family: 'Unbounded', Arial, Helvetica, sans-serif;
}
.divTitulo_Seccion {
    font-size: 160%;
    font-weight: 500;
    letter-spacing: -0.8px;
}

.divSubTitulo_Seccion {
    font-size: 150%;
    font-weight: 500;
    letter-spacing: -0.8px;
}

.divTitulo_Subcate {
    font-size: 140%;
    font-weight: 600;
    letter-spacing: -0.8px;
    margin-bottom: 15px;
}
.divTitulo_Desc {
    font-size: 110%;
    font-weight: 400;
    letter-spacing: -0.8px;
    opacity: 0.60;
}
.divTitulo_Txt{
    color: var(--color2); opacity: 0.90;
    font-size: 110%;
    font-weight: 400;
    letter-spacing: -0.8px;
}


.divBoton1 {
    background-color: var(--color5);
    padding: var(--padd2) var(--padd2);
    color: #FFFFFF;
    font-size: 110%;
    text-align: center;
    font-weight: 500;
    letter-spacing: -0.5px;
    border-radius: var(--radius2);
}
.divBoton1:active{
    background-color: var(--color1);
}
.divBoton1Deshab {
    background-color: var(--color-letra2);
    padding: var(--padd2) var(--padd2);
    color: var(--color6);
    font-size: 110%;
    text-align: center;
    font-weight: 500;
    letter-spacing: -0.5px;
    opacity: 0.7;
    border-radius: var(--radius2);
}
.divLink{
    color: var(--color2);
    letter-spacing: -0.5px;
}
.divLink:active{
    color: var(--color4);
}

.divProfileImage{
    border: 2px solid #FFFFFF; border-radius:50%; 
    -webkit-box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
    -moz-box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
    box-shadow: 0px 1px 3px rgba(50, 50, 50, 0.75);
}

.divImagenEquipoSombra{
    filter: drop-shadow(10px 10px 5px rgba(0, 0, 0, 0.5)); -webkit-filter: drop-shadow(10px 10px 5px rgba(0, 0, 0, 0.5));
}

@keyframes firework {
    0% { transform: translate(var(--x), var(--initialY)); width: var(--initialSize); opacity: 1; }
    50% { width: 0.5vmin; opacity: 1; }
    100% { width: var(--finalSize); opacity: 0; }
  }
  
  /* @keyframes fireworkPseudo {
    0% { transform: translate(-50%, -50%); width: var(--initialSize); opacity: 1; }
    50% { width: 0.5vmin; opacity: 1; }
    100% { width: var(--finalSize); opacity: 0; }
  }
   */
  .firework,
  .firework::before,
  .firework::after
  {
    --initialSize: 0.5vmin;
    --finalSize: 45vmin;
    --particleSize: 0.2vmin;
    --color1: yellow;
    --color2: khaki;
    --color3: white;
    --color4: lime;
    --color5: gold;
    --color6: mediumseagreen;
    --y: -30vmin;
    --x: -50%;
    --initialY: 60vmin;
    content: "";
    animation: firework 2s infinite;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, var(--y));
    width: var(--initialSize);
    aspect-ratio: 1;
    background: 
      /*
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 0% 0%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 100% 0%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 100% 100%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 0% 100%,
      */
      
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 50% 0%,
      radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 100% 50%,
      radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 50% 100%,
      radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 0% 50%,
      
      /* bottom right */
      radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 80% 90%,
      radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 95% 90%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 90% 70%,
      radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 100% 60%,
      radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 55% 80%,
      radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 70% 77%,
      
      /* bottom left */
      radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 22% 90%,
      radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 45% 90%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 33% 70%,
      radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 10% 60%,
      radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 31% 80%,
      radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 28% 77%,
      radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 13% 72%,
      
      /* top left */
      radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 80% 10%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 95% 14%,
      radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 90% 23%,
      radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 100% 43%,
      radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 85% 27%,
      radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 77% 37%,
      radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 60% 7%,
      
      /* top right */
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 22% 14%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 45% 20%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 33% 34%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 10% 29%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 31% 37%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 28% 7%,
      radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 13% 42%
      ;
    background-size: var(--initialSize) var(--initialSize);
    background-repeat: no-repeat;
  }
  
  .firework::before {
    --x: -50%;
    --y: -50%;
    --initialY: -50%;
  /*   transform: translate(-20vmin, -2vmin) rotate(40deg) scale(1.3) rotateY(40deg); */
    transform: translate(-50%, -50%) rotate(40deg) scale(1.3) rotateY(40deg);
  /*   animation: fireworkPseudo 2s infinite; */
  }
  
  .firework::after {
    --x: -50%;
    --y: -50%;
    --initialY: -50%;
  /*   transform: translate(44vmin, -50%) rotate(170deg) scale(1.15) rotateY(-30deg); */
    transform: translate(-50%, -50%) rotate(170deg) scale(1.15) rotateY(-30deg);
  /*   animation: fireworkPseudo 2s infinite; */
  }
  
  .firework:nth-child(2) {
    --x: 30vmin;
  }
  
  .firework:nth-child(2),
  .firework:nth-child(2)::before,
  .firework:nth-child(2)::after {
    --color1: pink;
    --color2: violet;
    --color3: fuchsia;
    --color4: orchid;
    --color5: plum;
    --color6: lavender;  
    --finalSize: 40vmin;
    left: 30%;
    top: 60%;
    animation-delay: -0.25s;
  }
  
  .firework:nth-child(3) {
    --x: -30vmin;
    --y: -50vmin;
  }
  
  .firework:nth-child(3),
  .firework:nth-child(3)::before,
  .firework:nth-child(3)::after {
    --color1: cyan;
    --color2: lightcyan;
    --color3: lightblue;
    --color4: PaleTurquoise;
    --color5: SkyBlue;
    --color6: lavender;
    --finalSize: 35vmin;
    left: 70%;
    top: 60%;
    animation-delay: -0.4s;
  }

.mobile-datepicker-field-container {
        padding: 0px;
    }

.mobile-datepicker {
    width: 100%;
    padding: 12px;
    border: thin solid var(--color3);
    border-radius: 8px;
    font-size: 16px; /* Evita el zoom automático en iOS */
    color: var(--color-letra2);
    appearance: none;
    -webkit-appearance: none;
    outline: none;
    transition: border-color 0.3s;
}

.mobile-datepicker:focus {
    border-color: var(--color4);
}


/* overlay instrucciones */
.icon-wrapper {
    position: relative;
    display: inline-block;
}

.icon {
    font-size: 100%;
    cursor: pointer;
    z-index: 10; /* Asegura que el icono se vea */
    position: relative;
    color: var(--color2);
}

.overlay {
    position: fixed; /* Cubre toda la pantalla */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8); /* Fondo negro con 80% opacidad */
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    opacity: 0; /* Invisible al inicio */
    visibility: hidden;
    transition: opacity 0.3s ease; /* Efecto suave */
    z-index: 5;
}

/* Clase que activaremos con JS */
.overlay.active {
    opacity: 1;
    visibility: visible;
}



.panel {
  position: fixed;
  top: 0;
  right: -100%; /* Escondido totalmente a la derecha */
  width: 100%;
  height: 100vh;
  background-color: #333;
  color: white;
  padding: 0px;
  box-shadow: -2px 0 5px rgba(0,0,0,0.5);
  
  /* Animación: propiedad, duración, curva de velocidad */
  transition: right 0.35s ease-in-out;
}

/* Esta clase se añade con JS para mostrar el div */
.panel.active {
  right: 0; 
}


.contenedor-marquesina {
    font-size: 90%;
    letter-spacing: -0.5px;
    width: 100%;
    overflow: hidden; /* Oculta lo que sale del recuadro */
    background: var(--color3);
    color: white;
    padding: 10px 0;
    white-space: nowrap; /* Evita que el texto salte de línea */
}

.contenido-movil {
    display: inline-block;
    padding-left: 100%; /* Inicia fuera de la pantalla */
    animation: movimiento-marquesina 15s linear infinite;
}

@keyframes movimiento-marquesina {
    0% { transform: translateX(0); }
    100% { transform: translateX(-100%); }
}

/* Pausar al pasar el mouse */
.contenedor-marquesina:hover .contenido-movil {
    animation-play-state: paused;
}