div.booking-calendar {
    padding: 1px;
    background-color: #0076d0;
    color: #222;
    font-size: 1.2em;
    font-weight: normal;
    text-align: center;
}

div.booking-calendar table {
    table-layout: fixed;
    width: 100%;
}

div.booking-calendar table tr th {
    height: 1.5em;
    font-size: 0.4em;
    color: #fff;
}

div.booking-calendar table tr th.booking-calendar-nav-prev, div.booking-calendar table tr th.booking-calendar-nav-next {
    cursor: pointer;
    font-size: 1.5em;
    font-weight: bold;
    color: #ffc107;
}

div.booking-calendar table tr th select.booking-calendar-month {
    padding: 0.1em;
    font-size: 1.5em;
}

div.booking-calendar table tr th select.booking-calendar-year {
    padding: 0.1em;
    font-size: 1.5em;
}

div.booking-calendar table tr td {
    cursor: pointer;
    vertical-align: top;
    width: 14%;
}

.booking-calendar-Free {
    background-color: #aaffaa;
}

.booking-calendar-OneRoomLeft {
    background-color: #ffc107;
}

.booking-calendar-Full {
    background-color: #c40b95;
}

td.booking-calendar-selected {
    background: #0076d0;
    opacity : 0.2;
    filter: alpha(opacity=20); /* For IE8 and earlier */
}

div.booking-calendar div {
    float: left;
    width: 200px;
    margin-top: 20px;
    margin-left: 40px;
    padding: 5px;
    color: black;
    text-align: center;
    font-size: 1.3em;
}

select.booking-calendar-availabilities {
    width: 300px;
    height: 1.3em;
    font-size: 1.0em;    
}

div.legend {
    cursor: pointer;
    margin: 1em auto 0em auto;
    padding: 10px;
    color: #222;
    text-align: center;
}

/* Screens width specificities */

@media (min-width:576px) {

    div.booking-calendar table tr th {
        font-size: 0.6em;
    }
    
    div.legend {
        max-width: 15em;
    }
}

@media (min-width:768px) {

    div.booking-calendar table tr th {
        font-size: 0.6em;
    }
    
}

@media (min-width:992px) {   
   
    div.booking-calendar table tr th {
        font-size: 0.7em;
    }

    div.legend {
        margin: 0em auto 1em auto;
    }

}

@media (min-width:1200px) {    
    
    div.booking-calendar table tr th {
        font-size: 0.8em;
    }
    
}
