/* Stylings for the calendar display. */

#calendar {
  background-color: #f8f1d1;
  border-spacing: 0px;
  margin: auto ;
  border: 8px ridge #cc0000;
  border-radius: 10px;
  box-shadow: 5px 4px 3px #888888;
  table-layout: fixed;
  width: 350px;
}

#calendar tr.header th {
  font-size: 30px;
  text-align: center;
  vertical-align: middle;
}

#calendar tr.days th {
  font-size: 20px;
  text-align: center;
}
#calendar tr.days th.sunday {
  color: #CC0033;
}
#calendar tr.footer td{
  border: none;
  height: 0px;
}
#calendar th{
  color: #000000;
  text-align: center;
}
#calendar td{
  color: #000000;
  text-align: center;
  font-size: 30px;
  font-weight: bold;
  }
#calendar a{
  color: #000000;
  }
#calendar td.target{
  border: 4px solid #990000;
  border-radius: 50%;
}
#calendar a.sunday {
  color: #CC0033;
  }  
#calendar tr.empty{
  visibility: hidden;
  display: none;
}

.grow 
{
padding: 10px;
-webkit-transition: all .2s ease-in-out;
-moz-transition: all .2s ease-in-out;
-ms-transition: all .2s ease-in-out;
-o-transition: all .2s ease-in-out;
transition: all .2s ease-in-out;
}

.grow:hover 
{
-webkit-transform: scale(1.5);
-moz-transform: scale(1.5);
-ms-transform: scale(1.5);
-o-transform: scale(1.5);
transform: scale(1.5);
}

.icon{
  width: 30px;
  height: 30px;
  margin: 0 auto;
  cursor: pointer;
}

.icon.reset
{
  width: 100px;
  height: 30px;
  background: transparent url('./images/calendar/sprite_reset.png') no-repeat top left;
  background-size: 200px 30px;
}

.icon.reset:hover { background-position: -100px 0px }

.icon.year_up
{
    background: transparent url('./images/calendar/sprite_double_right.jpg') no-repeat top left;
    background-size: 60px 30px;
}

.icon.year_up:hover { background-position: -30px 0px }

.icon.year_down
{
    background: transparent url('./images/calendar/sprite_double_left.jpg') no-repeat top left;
    background-size: 60px 30px;
}

.icon.year_down:hover { background-position: -30px 0px }

.icon.month_up
{
    background: transparent url('./images/calendar/sprite_right.jpg') no-repeat top left;
    background-size: 60px 30px;
}

.icon.month_up:hover { background-position: -30px 0px }

.icon.month_down
{
    background: transparent url('./images/calendar/sprite_left.jpg') no-repeat top left;
    background-size: 60px 30px;
}

.icon.month_down:hover { background-position: -30px 0px }

.icon.dot
{
    background: transparent url('./images/calendar/sprite_dot_on_brown.jpg') no-repeat top left;
    background-size: 60px 30px;
}

.icon.dot:hover { background-position: -30px 0px }

.tip
{
  cursor: pointer;
  position: relative;
}

.tip:hover ~ .tooltip
{
  visibility: visible;
  z-index: 100 !important;
}

.tooltip
{
  display: block;
  -moz-border-radius: 10px;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  -moz-box-shadow: inset 0px 0px 8px #000000;
  -webkit-box-shadow: inset 0px 0px 6px #000000;
  box-shadow: inset 0px 0px 8px #000000;
  border: 3px solid #CC0000;
  color: #006600;
  background-color: #fff8e1;
  font-size: 16px;
  font-family: arial, sans-serif;
  text-align: center;
  padding: 6px 10px 6px 10px;
  position: absolute;
  top: -50px;
  visibility: hidden;
}

.tooltip.year_down { left: 5px; }

.tooltip.month_down { left: -35px; }

.tooltip.reset { left: -38px; }

.tooltip.month_up { left: -37px; }

.tooltip.year_up { left: -65px; }

td { position: relative; }

.tipbox
{
  width: 230px;
  font-size: 22px;
  display: flex;
  align-items: center;
  justify-content: space-evenly;
}

.tooltip.tipbox { top: -55px; left: 50px; }
