@charset "UTF-8";
.mainvisual {
  min-height: 420px;
  background: url("../img/h1-bg-sp.webp") no-repeat bottom center;
  background-size:cover;
}
.mainvisual img {
  width: 100%;
  max-width: 750px;
  height: auto;
}
.mainvisual p span {
  display: inline-block;
}
.mainvisual p {
  line-height: 1.6;
  padding: 15px 10%;
  text-align: center;
}
.innerBox {
	padding-bottom: 50px;
  background-color: #ceea75;
}
ul.month {
  width: 96%;
  margin: 0 auto 60px;
  padding: 20px 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  font-family: "Kosugi Maru", sans-serif;
  font-weight: 400;
  font-style: normal;
}
ul.month li {
  width: 21%;
  margin: 2%;
}
ul.month li a {
  font-size: 30px;
  color: #31b6a0;
  padding: 5px 0;
  background-color: #fff;
  border: 1px solid #31b6a0;
  border-radius: 10px;
  text-align: center;
}
ul.month li a span {
  font-size: 20px;
}
.dayList {
  padding-bottom: 80px;
  background: url("../img/dl-bg.webp") no-repeat center bottom;
  background-size: 100% auto;
}
.dayList .calendar {
  margin: 0 auto;
  width: calc(92% - 30px);
  padding: 15px;
  background-color: #fff;
}
.dayList h2 {
  margin-bottom: 15px;
  font-size: 30px;
  padding: 8px 0;
  font-family: "Kosugi Maru", sans-serif;
  font-weight: 400;
  font-style: normal;
  background-color: #ff9999;
  border-radius: 50px;
  color: #fff;
  text-align: center;
}
.dayList h2 span {
  font-size: 20px;
}
.calendar li + li {
  margin-top: 60px;
}
.calendar ul li h4 {
  font-family: "Kosugi Maru", sans-serif;
  font-weight: 400;
  font-style: normal;
  border-top: 1px solid #ff9999;
  border-bottom: 1px solid #ff9999;
  padding: 10px 0;
  font-size: 26px;
  text-align: center;
}
.calendar ul li h4 span {
  font-size: 16px;
}
.calendar ul li .photo {
  padding: 15px 0 0;
}
.calendar ul li .photo img {
  max-width: 100%;
  height: auto;
}
.calendar ul li h3 {
  font-size: 25px;
  font-family: "Kosugi Maru", sans-serif;
  font-weight: 400;
  font-style: normal;
  text-align: center;
  padding: 20px 0;
}
.calendar ul li p {
  line-height: 1.6;
}
.calendar p.message {
  padding: 50px 0;
  line-height: 1.6;
  text-align: center;
}
.sourceLink {
	width: 80px;
	margin: 15px 0 0 auto;
 	border-bottom: 1px dashed #808080;
	text-align: center;
}
.sourceLink a {
	padding: 5px;
}
.sourceLink a img {
	width: 25px;
	height: auto;
	vertical-align: middle;
	margin-right: 5px;
}
#source {
	margin: 0 auto;
  width: calc(92% - 30px);
  padding: 15px;
  background-color: #fff;
	border: 2px solid #31b6a0;
}
#source h5 {
	color: #31b6a0;
	text-align: center;
	border-bottom: 2px solid #31b6a0;
	font-size: 25px;
  font-family: "Kosugi Maru", sans-serif;
  font-weight: 400;
  font-style: normal;
  padding: 0 0 15px;
}
#source dl {
	padding: 30px 0;
}
#source dl + dl {
	border-top: 1px dashed #31b6a0;
}
#source dl dt {
	font-weight: bold;
}
#source dl dt img {
	width: 25px;
	height: auto;
	margin-right: 5px;
	vertical-align: middle;
}
#source dl dd {
	padding: 10px 0 0;
}
#source dl dd a {
	color: #00f;
	text-decoration: underline;
}
#source dl dd ul {
	list-style: disc;
	margin-left: 1.5em;
}
@media screen and (min-width: 768px) {
	body {
		min-width: 1000px;
	}
	.innerBox {
  padding-bottom: 80px;
}
  .mainvisual {
    min-height: 650px;
    background: url("../img/h1-bg.webp") no-repeat bottom center;
    background-size: cover;
    text-align: center;
  }
  .mainvisual p {
    font-size: 18px;
    width: 600px;
    margin: 0 auto;
    line-height: 1.6;
    padding: 30px 15%;
    text-align: center;
  }
  ul.month {
    width: 550px;
    margin: 0 auto 60px;
    padding: 20px 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    font-family: "Kosugi Maru", sans-serif;
    font-weight: 400;
    font-style: normal;
  }
  ul.month li {
    width: 80px;
    margin: 15px 0 0;
  }
  ul.month li a {
    font-size: 30px;
    color: #31b6a0;
    padding: 5px 0;
    background-color: #fff;
    border: 1px solid #31b6a0;
    border-radius: 10px;
    text-align: center;
  }
  ul.month li a span {
    font-size: 20px;
  }
  ul.month li a:hover {
    background-color: #31b6a0;
    color: #fff;
  }
  .dayList {
    padding-bottom: 80px;
    background: none;
  }
  .dayList .calendar {
    margin: 0 auto;
    width: 980px;
    padding: 15px;
    background-color: #fff;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
  }
  .dayList h2 {
    width: 100%;
    margin-bottom: 15px;
    font-size: 30px;
    padding: 8px 0;
    font-family: "Kosugi Maru", sans-serif;
    font-weight: 400;
    font-style: normal;
    background-color: #ff9999;
    border-radius: 50px;
    color: #fff;
    text-align: center;
  }
  .dayList h2 span {
    font-size: 20px;
  }
  .calendar ul {
    display: flex;
    flex-wrap: wrap;
    border-left: 1px solid #ff9999;
  }
  .calendar ul li {
    width: calc(50% - 2px);
    border-right: 1px solid #ff9999;
    border-bottom: 1px solid #ff9999;
		position: relative;
  }
  .calendar ul li + li {
    margin-top: 0;
  }
  .calendar ul li h4 {
    background-color: #ffeeee;
  }
  .calendar ul li:nth-child(n+3) h4 {
    border-top: none;
  }
  .calendar ul li .photo {
    padding: 15px 15px 0;
  }
  .calendar ul li p {
    line-height: 1.6;
    padding: 0 15px 60px;
  }
  .calendar p.message {
    width: 100%;
    line-height: 1.6;
    text-align: center;
  }
	#source {
	margin: 0 auto;
  width: 950px;
  padding: 15px 25px;
  background-color: #fff;
	border: 2px solid #31b6a0;
}
	#source h5 {
  padding: 10px 0 25px;
}
	.sourceLink {
		position: absolute;
		bottom: 20px;
		right: 20px;
	width: 100px;
 	border-bottom: 1px dashed #808080;
	text-align: center;
}
	.sourceLink a:hover {
		color: #31b6a0;
	}
}
#page-top a {
  z-index: 3;
}