.cal_wrapper {
	border: 1px solid #ccc;
	display: inline-block;
	vertical-align: top;
	width: 23.6%;
	margin: 0 0 1em 1.3%;
	padding: 10px 0px;
}
.cal_wrapper:first-child {
	margin-left: 0;
}
div.schedule_wrapper {
	padding: 10px 0px;
	border: solid 1px #CCC;
	border-radius: 5px;
	box-shadow: 0px 2px 0 2px #ccc;
}
.cal_wrapper:after {
	height: 1em;

}
div.schedule_wrapper h3 {
	padding: 0px 10px;
	font-weight: normal;
	margin: 0px;
	font-size: 12px;
	color: #666;
}
div.schedule_wrapper div.schedule_list {
	padding: 0px 10px;
	margin: 0px;
}
div.schedule_wrapper div.schedule_list ol {
	padding: 0px;
	margin: 5px auto;
	border-top: solid 1px #CCC;
}
div.schedule_wrapper div.schedule_list ol li {
	padding: 5px 10px 0px 0px;
	margin: 0px 0px 0px 30px;
	font-size: 12px;
	line-height: 1.5em;
}
div.schedule_wrapper div.schedule_list ol li:hover {
	text-decoration: underline;
}
div.cal_wrapper table.cal tr th p {
	/* float: left; */
	padding: 5px;
	margin: 0px;
	color: #666;
	font-size: 12px;
	font-weight: bold;
	text-align: center;
}
div.cal_wrapper table.cal tr th div.cal_ui {
	float: right;
}
div.cal_wrapper table.cal tr th div.cal_ui input {
	border: solid 1px #CCC;
	background-color: #FFF;
	font-size: 12px;
	margin: 0px 1px;
	padding: 1px 5px;
	border-radius: 3px;
}
div.cal_wrapper table.cal tr td {
	font-size: 12px;
	border-top: solid 1px #EEE;
}
div.cal_wrapper table.cal tr td {
	text-align: center;
	padding: 2px;
}
div.cal_wrapper table.cal tr.headline td {
	font-size: 10px;
	padding: 5px 0px;
	color: #666;
}
div.cal_wrapper table.cal tr.headline {
	background-color: #EEE;
}
div.cal_wrapper table.cal tr td div {
	position: relative;
	padding: 4px 6px;
	text-align: center;
	border-radius: 100%;
}
div.cal_wrapper table.cal tr td div span {
	display: none;
	position: absolute;
	top: 20px;
	left: 0px;
	width: 180px;
	border: solid 1px #EEE;
	background-color: #FFF;
	text-align: left;
	padding: 5px;
	z-index: 10;
	color: #000;
	font-weight: normal;
	line-height: 1.5em;
	box-shadow: 1px 1px 3px #666;
}

/* 以下、クラス指定するときのアレ */

div.cal_wrapper table.cal tr td div.Sat {
	color: #1DB2D1;
}
div.cal_wrapper table.cal tr td div.Sun {
	color: #FF8054;
}
div.cal_wrapper table.cal tr td div.Today {
	font-weight: bolder;
}
div.cal_wrapper table.cal tr td div.Deli {
	background-color: #EFE;
	font-weight: bold;
}
div.cal_wrapper table.cal tr td div.Holyday {
	color: #FF8054;
}
/* div.cal_wrapper table.cal tr td div.Birthday {
	font-weight: bolder;
	background-color: #EEF;
	color: #090;
	border-radius: 3px;
} */
div.cal_wrapper table.cal tr td div.Event {
	background: #d2ff4d;
}

div.cal_wrapper table.cal tr td div.backward {
	color: #999;
}
div.cal_wrapper table.cal tr td div.pointer {
	cursor: pointer;
}
div.cal_wrapper table.cal tr td div.pointer:hover {
	background: #eee;
}

/*----------------------------------------
タブレット・スマホ対応
----------------------------------------*/
@media screen and (min-width: 769px) {
  .schedule_wrapper,
	div.cal_wrapper table.cal tr th div.cal_ui {
		display: none;
	}
}
@media screen and (max-width: 768px) {
  #cal1,#cal2,#cal3 {
    display: none;
  }
  .cal_wrapper {
    width: 49%;
  }
  div.cal_wrapper table.cal {
  	width: 100%;
  }
  div.cal_wrapper table.cal tr td {
  	width: 14.2%;
  }
  .schedule_wrapper {
  	display: inline-block;
  	vertical-align: top;
  	margin-left: 2%;
  	width: 47%;
  }
  .fixHeight > div {
  	height: auto;
  }
}
@media screen and (max-width: 480px) {
  .cal_wrapper {
  	display: block;
    width: auto;
    margin-bottom: 1em;
  }
  .schedule_wrapper {
  	display: block;
  	width: auto;
  	margin-left: 0;
  }
}
