
.img-logo{
   width: 100% !important; 
   max-width: 150PX;
   max-height: 70px;


}

.select2 {
  width:100%!important;
  }


  .select2-selection{
    box-shadow: none !important;
  }


footer{
  background-color: rgba(8, 134, 165, 0.78);
  color: white;
  text-decoration: none;
}

footer a{
  
  color: white;
  text-decoration: none;
}


@keyframes blink {
  0%, 100% {
    opacity: 1; /* Totalmente visible */
  }
  50% {
    opacity: 0.5; /* Totalmente invisible */
  }
}

.parpadeo {
  animation: blink 2s infinite; /* Animación de 2 segundos en bucle */
}




li{
    list-style-type: none;
}


/*cookies*/

.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: #333;
    color: #fff;
    padding: 15px;
    text-align: center;
    box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.3);
    z-index: 1000;
    display: none; /* Oculto por defecto */
}

.cookie-banner p {
    margin: 0;
    font-size: 14px;
}

.cookie-banner a {
    color: #4CAF50;
    text-decoration: underline;
}

.cookie-banner button {
    background-color: #4CAF50;
    color: white;
    border: none;
    padding: 10px 20px;
    margin-left: 10px;
    cursor: pointer;
    font-size: 14px;
    border-radius: 5px;
}

.cookie-banner button:hover {
    background-color: #45a049;
}





@media (min-width: 992px) {
  .col-lg-1-5 {
      flex: 0 0 auto;
      width: 10.9%;
  }
}


@media (min-width: 992px) {

}

@media (max-width: 858px) {

.title-page{
    font-size: 1.2rem;
   /* display: none;*/
}

.img-logo{
    /*width: 50% !important; */
}

.title-login{
    font-size: 1.0rem;
    display: block;
}


#page-login{
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    
}





}


@media (max-width: 576px) {
    
    .title-login {
        font-size: 1rem;
       
    }

    .btn-fichajes{
      font-size: 0.60rem !important;
    }


    #page-login{
        padding: 0rem 1.5rem 1.5rem 1.5rem;
    }
    
}


@media only screen and (max-width: 600px) {
  .table-none-mobile{
    display:none;
}

.text-start-sm{
  text-align: start;
}






.td-limitado {
  display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
   
}


}



@media only screen and (min-width: 600px) {
  .table-none-desktop{
    display:none;
}
}



html {
    height: 100%;
  }
  
  .login-box {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 400px;
    padding: 40px;
    transform: translate(-50%, -50%);
    background: rgba(0,0,0,.5);
    box-sizing: border-box;
    box-shadow: 0 15px 25px rgba(0,0,0,.6);
    border-radius: 10px;
  }
  
  .login-box h2 {
    margin: 0 0 30px;
    padding: 0;
    color: #fff;
    text-align: center;
  }
  
  .login-box .user-box {
    position: relative;
  }
  
  .login-box .user-box input {
    width: 100%;
    padding: 10px 0;
    font-size: 16px;
    color: #fff;
    margin-bottom: 30px;
    border: none;
    border-bottom: 1px solid #fff;
    outline: none;
    background: transparent;
  }
  .login-box .user-box label {
    position: absolute;
    top:0;
    left: 0;
    padding: 10px 0;
    font-size: 16px;
    color: #fff;
    pointer-events: none;
    transition: .5s;
  }
  
  .login-box .user-box input:focus ~ label,
  .login-box .user-box input:valid ~ label {
    top: -20px;
    left: 0;
    color: #03e9f4;
    font-size: 12px;
  }
  
  .login-box form a {
    position: relative;
    display: inline-block;
    padding: 10px 20px;
    color: #03e9f4;
    font-size: 16px;
    text-decoration: none;
    text-transform: uppercase;
    overflow: hidden;
    transition: .5s;
    margin-top: 40px;
    letter-spacing: 4px
  }
  





/*para el footer responsive*/


.shfooter .collapse {
  display: inherit;
}
@media (max-width:767px) {
  .shfooter ul {
    margin-bottom: 0;
  }

  .shfooter .collapse {
    display: none;
  }

  .shfooter .collapse.show {
    display: block;
  }

  .shfooter .title .bi-chevron-compact-up,
  .shfooter .title[aria-expanded=true] .bi-chevron-compact-down {
    display: none;
  }

  .shfooter .title[aria-expanded=true] .bi-chevron-compact-up {
    display: block;
  }

  .shfooter .navbar-toggler {
    display: inline-block;
    padding: 0;
  }

}

.resize {
  text-align: center;
}
.resize {
  margin-top: 3rem;
  font-size: 1.25rem;
}
/*RESIZESCREEN ANIMATION*/
.bi-chevron-compact-double-right {
  animation: rightanime 1s linear infinite;
}

.bi-chevron-compact-double-left {
  animation: leftanime 1s linear infinite;
}
@keyframes rightanime {
  50% {
    transform: translateX(10px);
    opacity: 0.5;
  }
  100% {
    transform: translateX(10px);
    opacity: 0;
  }
}
@keyframes leftanime {
  50% {
    transform: translateX(-10px);
    opacity: 0.5;
  }
  100% {
    transform: translateX(-10px);
    opacity: 0;
  }
}





/* RESPONSIVE: convertir filas en tarjetas solo en móvil */
@media (max-width: 768px) {
  .tabla-responsive-card thead {
    display: none;
  }

  .tabla-responsive-card,
  .tabla-responsive-card tbody,
  .tabla-responsive-card tr,
  .tabla-responsive-card td {
    display: block;
    width: 100%;
  }

  .tabla-responsive-card tr {
    margin-bottom: 1rem;
    background: #f9f9f9;
    border: 1px solid #ccc;
    border-radius: 5px;
    padding: 10px;
    box-sizing: border-box;
  }

  .tabla-responsive-card td {
    text-align: right;
    padding-left: 40%;
    position: relative;
    border: none;
    border-bottom: 1px solid #b3b3b3;
    overflow-wrap: break-word;
    word-wrap: break-word;
    white-space: normal;
    box-sizing: border-box;
  }

  .tabla-responsive-card td::before {
    content: attr(data-cell);
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 45%;
    font-weight: bold;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .tabla-responsive-card td:last-child {
    border-bottom: none;
  }
}



/*calendario*/




.calendar-container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.month-calendar {
  background-color: white;
  border-radius: 8px;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
  padding: 5px;
  text-align: center;
}

.month-title {
  font-size: 1.2em;
  font-weight: bold;
  margin-bottom: 10px;
  color: #333;
}

.weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  font-weight: bold;
  margin-bottom: 5px;
  color: #666;
}

.days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  text-align: center;
}

.day {
  padding: 5px;
  border: 1px solid #eee;
}

.day.today {
  background-color: #007bff;
  color: white;
  border-radius: 50%;
}

@media (max-width: 1024px) {
  .calendar-container {
      grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .calendar-container {
      grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .calendar-container {
      grid-template-columns: 1fr;
  }
}









.no-laborable{
  color:white;
  background-color: red;
  
}

.laborable{
  color:white;
  background-color: rgb(193 193 193);
  
}



.dia-vacaciones{
   color:black ;
  background-color: rgb(251, 255, 6)!important;
  font-weight: bold;
}

.recuperacion{
  color:white;
  background-color: rgb(163 59 150) !important;
}



.dia-vacaciones.dia-no-recuperable{
 color: black;
  background: linear-gradient(to bottom right, rgb(251, 255, 6) 50%, green 50%);
}

.dia-vacaciones.dia-no-recuperable-parcialmente{
  color:black;
  /*background-color: rgb(163 59 150) !important;*/
  background: linear-gradient(to bottom right, rgb(251, 255, 6)50%, #6ab1ff 50% ) !important;
}

.dia-vacaciones.recuperacionTrabajadores{
   color:black;
  /*background-color: rgb(163 59 150) !important;*/
  background: linear-gradient(to bottom right, rgb(251, 255, 6)50%, rgb(163 59 150) 50% ) !important;
}

.recuperacionTrabajadores{
  color:white;
  /*background-color: rgb(163 59 150) !important;*/
  background: linear-gradient(to bottom right, red 50%, rgb(163 59 150) 50% ) !important;
}





/*Ultimo*/
.asusenciasAprobadas {
    position: relative; /* necesario para posicionar el icono */
}

.asusenciasAprobadas::before {
    content: "▾";
    position: absolute;
    left: -5px;
    top: -12px;
    font-size: 20px;
    color: rgb(0, 0, 0);
    pointer-events: auto;
    font-weight: lighter;
}






.dia-no-recuperable-parcialmente {
  color: white;
  background-color: #6ab1ff;
}


.no-laborable.dia-no-recuperable-parcialmente {
  color: white;
  background:linear-gradient(to bottom right, red 50%, #6ab1ff 50%) ;
}


.no-laborable.dia-vacaciones{
  background: linear-gradient(to bottom right, red 50%, rgb(251, 255, 6) 50%);
}

.no-laborable.dia-no-recuperable {
background: linear-gradient(to bottom right, red 50%, green 50%);
}


.no-laborable.dia-recuperable {
background: linear-gradient(to bottom right, red 50%, rgb(160, 151, 22) 50%);
}

.dia-no-recuperable{
  background-color:  green ;
}

.dia-recuperable{
  background-color: rgb(160, 151, 22);
;
}



    .simple-keyboard {
     /* display: none;
      max-width: 600px;
      width: 100%;*/
    }

    .simple-keyboard.active {
      display: block;
    }


/*

body{
  font-family: 'Poppins', sans-serif;
  background: #fff;
  font-size: 14px;
  color: lighten(black, 22%);
}
.container{
  padding-bottom: 200px;
}
.form-group{
  position: relative;
  margin: 40px auto;
}
.form-control{
  position: relative;
  z-index: 1;
  width: 100%;
  height: 35px;
  border-radius:1;
  font-size: 16px;
  box-shadow: none;
  border: none;
  border: 1px solid #cccccc;
  background-color: transparent;
  
    & + label{
    position: absolute;
    top: 10px;
    left: 3px;
    font-size: 16px;
    color: #cccccc;
    transition: all 0.4s ease-out;
  }
  &:focus{
    box-shadow: none;
    outline: none;
    border-width: 2px;
    
  }
  &:focus + label,
  &.has-value + label {
    top: -15px;
    
    font-size: 12px;
  }
}
.form-group select, .mob, .det{
  margin-bottom: 15px;
  width: 40%;
}
.input-group-addon {
    padding: 0;
    font-size: 14px;
    font-weight: 400;
    line-height: 1;
    color: #fff;
    text-align: center;
    background-color: transparent;
    border: none;
    border-radius: 0;
  }
@media screen and (max-width: 768px){
  .form-group select,  .mob{
    min-width: 100%;
  }
}*/