@charset "UTF-8";
.content_ttl{
  padding: 30px 15px 10px;
  border-bottom: 1px solid #ccc;
  font-size: 18px;
  font-weight: bold;
}

.calendar{
  position: relative;
  margin: 20px 5px 0;
  padding: 20px 10px;
  border: 2px solid #c18a2d;
  box-shadow: 0 1px 0 #fff inset, 0 -1px 0 #fff inset, 1px 0 0 #fff inset, -1px 0 0 #fff inset, 0 2px 0 #c18a2d inset, 0 -2px 0 #c18a2d inset,  2px 0 0 #c18a2d inset, -2px 0 0 #c18a2d inset;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.calendar:before,
.calendar:after{
  position: absolute;
  top: 50%;
  width: 4px;
  height: 200px;
  margin-top: -100px;
	background: linear-gradient(to bottom, rgba(255,255,255,0) 0%,rgba(255,255,255,0) 1%,rgba(255,255,255,0.5) 25%,rgba(255,255,255,1) 50%,rgba(255,255,255,0.5) 75%,rgba(255,255,255,0) 100%);
  content: "";
}
.calendar:before{
  left: -2px;
}
.calendar:after{
  right: -2px;
}

.calendar_ttl{
  position: relative;
  transform: rotate(.03deg);
  margin-bottom: 20px;
  padding-top: 25px;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  white-space: nowrap;
}
.calendar_ttl .year{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  font-size: 12px;
  font-weight: normal;
}
.calendar_ttl:before{
  background: url(../images/event/calendar/calendar_ttl_l.png) no-repeat;
  margin: -2px 10px 0 0;
}
.calendar_ttl:after{
  background: url(../images/event/calendar/calendar_ttl_r.png) no-repeat;
  margin: -2px 0 0 10px;
}
.calendar_ttl:before,
.calendar_ttl:after{
  display: inline-block;
  width: 47px;
  height: 5px;
  background-size: 47px 5px;
  vertical-align: middle;
  content: "";
}
.calendar_table{
  width: 100%;
}
.calendar_table tbody{
  border-top: 1px solid #a8a8a8;
  border-left: 1px solid #a8a8a8;
}
.calendar_table tr>*:first-child{
  color: #ff0000;
}
.calendar_table tr>*:last-child{
  color: #008af2;
}
.calendar_table th,
.calendar_table td{
  width: 14%;
  text-align: center;
}
.calendar_table th{
  transform: rotate(.03deg);
  height: 20px;
  font-size: 12px;
  font-weight: normal;
}
.calendar_table td{
  padding: 0 2px 2px;
  border-right: 1px solid #a8a8a8;
  border-bottom: 1px solid #a8a8a8;
  background: rgb(247,247,247);
  background: linear-gradient(to bottom, rgba(247,247,247,1) 0%,rgba(255,255,255,1) 30%,rgba(255,255,255,1) 100%);
}
.calendar_table td span{
  display: block;
  transform: rotate(.03deg);
  padding: 5px 0;
  font-size: 12px;
}
.calendar_event{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-direction: column;
}
.calendar_event>*{
  display: inline-flex;
}
.calendar_event>*+*{
  margin-top: 2px;
}
.event_details {
	margin:15px;
}

.event_details:last-child {
	margin-bottom:45px;
}

.event_ttl-01,
.event_ttl-02 {
	margin:30px 0 20px;
	font-size:16px;
	font-weight:bold;
	text-align:center;
}

.event_ttl-02 {
	padding-top:20px;
	border-top:1px solid #ccc;
}

.event_details_p {
	margin:15px 0;
	font-size:12px;
	line-height:1.5;
}
.bold{
  font-weight: bold;
}
.red{
  color: #ff0000;
}
.orange{
  color: #ff6600;
}