:root {
    --color-fondo-claro: #EDEDED;
    --color-fondo-claro2: #f2f2f2;
    
    --color1: #00785f;
    --color2: #00968d;
        --color2_1: #C0E4E2;
    --color3: #034234;
    --color4: #fbba07;
    --color5: #ff7e9c;
    --color6: #FFFFFF;
    --color7: #EC1017;
        --color7_1: #FAC4C5;
    --color8: #BFBF90;
        --color8_1: #FFF0C0;

    --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=Quicksand:wght@300;400;500;600;700&display=swap);
    @import url(https://fonts.googleapis.com/css2?family=Unbounded:wght@200;300;400;500;600;700;800;900&display=swap);
    html {
        height: -webkit-fill-available;
    }
    
    body {
        font-family: 'Quicksand', 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%;
        
    }
    .input1{
        font-size: 120%;
        padding: var(--padd2);
        border: thin solid var(--color3);
        border-radius: var(--radius2);
        width: 100%;
        background-color: var(--color-fondo-claro2);
        margin: var(--padd1) 0px;
    }
    
    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(--color-fondo-claro) 10%, #FFFFFF 18%, var(--color-fondo-claro) 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);
}

.divSeparador{
    height: 2px;
    background-color: var(--color4);
    width: 100%;
    margin: var(--padd1) 0px;
}

/* ------------  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:300;
}
.divTitulo2{
    font-size: 120%;
    letter-spacing: 0.25px;
    color: var(--color1);
}


/* 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(--color1);
    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(--color4);
}
.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);
}

@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;
}