/*
********  barvy  *********
 tmavě modrá:  #2970a8
 světle modrá: #72acdc
 šedá: #dee2e6
*/

body{
  font-size: .9em !important;
}

input[type=checkbox] {
  transform: scale(1.5);
}

#busyIndicator{
  position:fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
  font-size: 32px;
  z-index: 999;
}

#busyLoadingElement {
    width: 5em;
    height: 5em;
    position: absolute;
    -webkit-border-radius: 50%;
    border-radius: 50%;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
    border: 0.5em solid #eaeaea;
    border-right-color: #384fd9;
    -webkit-animation: rotateloading linear 1s;
    -o-animation: rotateloading linear 1s;
    animation: rotateloading linear 1s;
    -webkit-animation-iteration-count: infinite;
    -o-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    -webkit-transform-origin: center center;
    -ms-transform-origin: center center;
    -o-transform-origin: center center;
    transform-origin: center center
}

@-webkit-keyframes rotateloading {
    0%{
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

@-o-keyframes rotateloading {
    0%{
        -webkit-transform: rotate(0);
        -o-transform: rotate(0);
        transform: rotate(0)
    }

    100% {
        -webkit-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

@keyframes rotateloading {
    0%{
        -webkit-transform: rotate(0);
        -o-transform: rotate(0);
        transform: rotate(0)
    }

    100% {
        -webkit-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

.min-width-24p{
  min-width: 24%;
}
.min-width-25p{
  min-width: 25%;
}
.min-width-30p{
  min-width: 30%;
}
.min-width-33p{
  min-width: 33%;
}


.width-14p{
  width: 14%;
}
.width-24p{
  width: 24%;
}
.width-25p{
  width: 25%;
}


.min-height-5vh{
  min-height: 5vh;
}
.min-height-15vh{
  min-height: 15vh;
}


.height-10vh{
  height: 10vh;
}


.font-size-1-5vw{
  font-size: 1.5vw !important;
}
.font-size-2vw{
  font-size: 2vw !important;
}
.font-size-3vw{
  font-size: 3vw !important;
}


.btn{
  overflow: hidden;
}


.hidden{
  display: none;
}

.no-padding{
  padding:0 !important;
}





#logo{
  position: absolute;
  width: 300px;
  z-index: 1;
  left: 2vw;
  top: 3vh;
  height: auto;
}
.hlavicka_vypln h1{
  color: #FFF;
}
.hlavicka_vypln h2{
  color: #000;
  clear: both;
}
.hlavicka_vypln{
  background-color: #2b83b5;
  opacity: 0.7;
}
.hlavicka{
  height: 40vh;
  overflow: hidden;
  background-image: url('https://francesca.cz/kostra/img/4.jpg');
  background-position: 50% 40%;
  background-size: cover;
  padding: 0;
}


.kalendar_vypsany_den_container{
  width: auto;
  background-color: #EEE;
  border-radius: 10px;
}

.kalendar_vypsany_den{
  /*background-color: #80FF00;*/
  font-weight: bold;
  margin:  0 auto;
  padding: 4px;
  color: #000;
  width: auto;
  display: block;    
}


.form_platba{
  display: inline-block;
  width: 25%;
  font-size: 130%;
  font-weight: bold;
}

.form_platba:hover,
.form_zbozi:hover, .form_zbozi_big:hover{
  background-color: #dfdfdf;
  cursor: pointer;
}

.zbozi_vyber{
  background-color: #2b83b5 !important;
}

.DP_skupina{
  border-left: 2px solid #2970a8;
  padding-left: 1%;
}

#repete{
  position: fixed;
  top: 3px;
  right: 3px;
  z-index: 1;
}

.sedy_podklad{
  background-color: #dee2e6;
  padding: 10px 10px;
  border-radius: 15px;
}

#nabidka_trid_nadpis h1,
#predmet_skolni_vylet h1,
#program_skolni_vylet h1{
  font-size: 130%;
  font-weight: bold;
  margin: 30px 0 20px 0;
}

#nabidka_programu_container{
  max-height: 700px;
  overflow: hidden;
  overflow-y: auto;
}

#predmet_skolni_vylet .container,
#program_skolni_vylet .container{
  margin-top: 60px;
}

#program_skolni_vylet .container{
  border-left: 1px #aaa solid;
  border-right: 1px #aaa solid;
}

.btn-outline-secondary{
  font-size: 130%;
  color: #FFF;
  background-color: #2970a8 !important;
  border: none !important;
  /*border-radius: 20%;*/ 
  min-width: 85%;
}
/*.btn-outline-secondary:hover{
  background-color: #72acdc !important;
}*/

#kalendar_terminu_all{
  margin-top: 15px;
}

#kalendar_terminu_all .btn-outline-secondary{
  min-width: max-content;
  margin-right: 20px;
}
#kalendar_terminu_all .btn-outline-secondary:nth-child(3){
  margin-right: 0;
  margin-left: 20px;
}

.kalendar_varovani{
  width: 100%;
  background-color: #72acdc;
  padding: 15px 5px;
  margin-bottom: 15px;
  border-radius: 15px;
  font-size: 125%;
}

#vybrany_program span,
#vybrany_predmet .btn-outline-secondary{
  min-width: 30%;
  margin-bottom: 4vh;
}

.program_nabidka{
    margin-top: 1vh;
}

.program_nabidka button{
  font-size: 1.5rem;
}

#programy_nabidka_kotva span{
  font-size: 80%;
}

/*button:focus{
  background-color: red;
}*/


#predmet_skolni_vylet button img,
#program_skolni_vylet button img{
  width: 30px;
  height: auto;
}

.posledni_sance{
  width: 1em;
  margin-right: 15px;
}

#nabidka_trid_container{
  flex-wrap: nowrap;
}

.dny_terminy,
#nabidka_trid_container .btn-outline-secondary,
#kalendar_terminu_all .btn-outline-secondary,
#predmet_skolni_vylet .btn-outline-secondary,
#program_skolni_vylet .btn-outline-secondary,
#termin_skolni_vylet .btn-outline-secondary{
  cursor: pointer;
  background: none !important;
  color: #000;
  border: none !important;
  border-radius: 30px;
}

#kalendar_terminu_all .vybrano{
    cursor: pointer;
    background: none !important;
    color: #000;
    border: none !important;
    border-radius: 15px;
}

#predmet_skolni_vylet .zamceno{
  opacity: .4;
}

#predmet_skolni_vylet .zamceno img{
  width: 5%;
  height: auto;
  vertical-align: baseline;
  margin-right: 10px;
}

#predmet_skolni_vylet .predmet_heslo{
  display: none;
  width: 70%;
  margin: 0 auto;  
  text-align: center;
  /*display: block;*/
}

#predmet_skolni_vylet .predmet_heslo input{
  display: inline-block;
  width: 50%;
  
}
#predmet_skolni_vylet .predmet_heslo button{
  margin-left: 5px;
}

/*Animace dnů v kalendáři*/
.dny_terminy{
/*  animation-name: aktualizace_dnu;
  animation-duration: 2s;*/
  text-decoration: underline;
  font-size: 95%;
}

/*@keyframes aktualizace_dnu {
  0% {color: #000;}
  50%  {color: #2970a8;}
  100% {color: #000;}
}*/

.dny_terminy:hover,
#nabidka_trid_container .btn-outline-secondary:hover,
#kalendar_terminu_all .btn-outline-secondary:hover,
#predmet_skolni_vylet .btn-outline-secondary:hover,
#program_skolni_vylet .btn-outline-secondary:hover,
#termin_skolni_vylet .btn-outline-secondary:hover{
  /*background-color: #72acdc !important;*/
  /*color: #FFF;*/
  transition: all 500ms ease-in-out;
  border: 0;
}
#predmet_skolni_vylet .vybrano,
#program_skolni_vylet .vybrano,
#nabidka_trid_container .vybrano,
#kalendar_terminu_all .vybrano{
  background-color: #2970a8 !important;
  color: #FFF;
}

#kalendar_terminu_all .table,
#termin_skolni_vylet .table{
  background: none;
}
#termin_skolni_vylet td,
#termin_skolni_vylet th,
#kalendar_terminu_all td,
#kalendar_terminu_all th{
  border: none;
  font-size: 110%;
}

#termin_skolni_vylet th,
#kalendar_terminu_all th{
  font-weight: bold;
}

#kalendar_terminu_all td{

}
.kalendar_vypsany_den_container:hover{
  background-color: #CCC;
}


#footer{
  background-color: #b0d1ec;
  padding: 4vh 0 4vh 0;
  font-size: 120%;
}

#footer .row{
  padding: 0;
  margin: 0;
}

#footer .socsite{
  margin-top: 5vh;
}

#footer ul{
  width: fit-content;
  margin: 0 auto;
}

#footer ul li{
  list-style-type: none;
  float: left;
  margin: 0 .5vw;
}

#footer table{
  margin: 0 auto;
}

#footer .h3{
  font-size: 100%;
}

/*#footer .h4{
  margin-top: 20px;
}*/



#www_ow{
  width: 100%;
  text-align: right;
  font-size: 85%;
  padding: 3.3vh 1vw 3.3vh 1vw;;
  background-color: #000;
}

#www_ow i{
  margin-right: 10px;
}


#www_ow .ow_text{
  color: #fff;
}

#www_ow .ow_text:hover{
  text-decoration: none;
  color: #007bff;
  transition: all 1s ease-in-out;
}
#www_ow .ow_logo{
  float: left;
}
#www_ow img{
  width: 100px;
  height: auto;
  margin-top: -25px;
  vertical-align: top;
}















@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .col{
    display: block;
    min-width: 9%;

  }
  .btn-group{
    width: 50%;
    float: left;
  }
}



@media(max-width: 800px){
  body{
    font-size: .8em
  }
  
  .program_nabidka button{
    font-size: .7rem;
  }
  
  h1{
    display: none;
  }

  .form_platba{
    white-space: nowrap;
    width: 70%;
    clear: both;
    margin-bottom: 5px;
  }
  
  #kalendar_terminu_all td{
      padding: 3px;
  }
  
  
  .text-middle{
    white-space: normal;
  }
  
}

@media(max-width: 500px){
  #kalendar_terminu_all {
    font-size: 0.4rem;
    padding: 0;
  }
}
