@charset "UTF-8";
.contents-wrap {
	background: url("../images/top/pc_top_bk.png") repeat-y;
	background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	-ms-background-size: cover;
	background-position: top center;
	background-repeat: repeat-y;
}
.contents-wrap a:hover {
	opacity: 1;
}
.contents {
	margin: 0 auto;
	/* max-width: 1200px; */
	width: 100%;
	position: relative;
}
/* 画像の上に透明白を載せる */

a:hover .surface {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}
.surface {
	background: rgba(255, 255, 255, 0.5);
}
/* ヘッダー */

.top_bk {
	background-image: url("../images/top/pc_hero_top_bk.png");
	width: 100%;
	height: 0;
	padding-top: 75.64974%;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: relative;
}
.top_bk h1 {
	position: absolute;
	top: 23%;
	left: 55%;
	width: 35.9vw;
}
/* 共通 イベント　テキストパーツ */

.ky_cap {
	margin-bottom: 90px;
}
.ky_date .ky_week {
	display: flex;
	align-items: center;
	line-height: 1;
	font-size: 28px;
}
.ky_date .ky_week .span01 {
	font-size: 100%;
	padding-right: 5px;
}
.ky_date .ky_week .span02 {
	font-size: 65%;
	margin-bottom: 3px;
}
/* テキスト横線 */

.ky_date .ky_line-t {
	display: flex;
	align-items: baseline;
	line-height: 1;
	padding-right: 10px;
}
.ky_date .ky_line-t:before {
	border-top: 1px solid;
	content: "";
	flex-grow: 1;
	height: 1px;
	color: #b4b4b5;
}
.ky_date .ky_line-t:before {
	margin-right: 0.5rem;
}
/* 左より h2 タイトル */

.left-title {
	margin-left: 8%;
	margin-bottom: 20px;
}
.left-title span {
	display: block;
}
.left-title .photo-h2 img {
	width: 169px;
}
.left-title .cap-h2 {
	margin-top: 10px;
	font-size: 18px;
	font-weight: 600;
}
/* １段目 */

.first-ev dd h3 {
	font-weight: 600;
	font-size: 22px;
	margin-bottom: 25px;
}
.first-ev .ky_cap {
	margin-bottom: 75px;
	margin-top: 0;
}
.first-ev {
	margin-bottom: 75px;
	position: relative;
}
.first-ev-tb .number01 {
	text-align: right;
	font-size: 72px;
	color: #888888;
	margin-bottom: 10px;
}
.first-ev-tb dt h3 {
	font-size: 22px;
	font-weight: 600;
}
.first-ev .first-ev-pb {
	width: 58.3%;
	float: left;
	z-index: 1;
	position: relative;
}
.first-ev .first-ev-tb {
	background-color: #ffffff;
	width: 36%;
	padding: 20px 35px 25px 11%;
	position: absolute;
	bottom: 0;
	right: 0;
}
@media screen and (min-width: 768px) {
	/* PCのみ */
	/* １段目 */
	.first-ev-box {
		margin-top: -24%;
		-ms-transform: translateX(-50%);
	}
	.second-ev01-in li:nth-child(odd) a {
		display: flex;
		flex-direction: column-reverse;
	}
	.second-ev01-in li:nth-child(odd) .photo-b {
		margin-left: auto;
	}
}
/* カラム　3 */

.column03-b .item-list {
	width: 100%;
	justify-content: space-between;
	max-width: 1280px;
	margin: 0 auto;
}
.column03-b .item-list .item {
	margin-bottom: 40px;
	flex-direction: column;
	border: 1px solid #c8c9ca;
	position: relative;
	background-color: #eeeeef;
}
.column03-b .item p.auto {
	padding: 15px 20px 30px;
	font-size: 22px;
	font-weight: 600;
}
.column03-b .item p.auto span {
	font-size: 15px;
	display: block;
}
.column03-b .item {
	width: calc(100%/3 - 120px / 3);
}
.column03-b .item-list::after, .column03-b .item-list::before {
	display: block;
	content: "";
	width: calc(100%/3 - 120px / 3);
}
.column03-b .item-list::before {
	order: 1;
}
.column03-b .ky_date {
	margin-top: auto;
	padding: 0 20px 20px;
}
.column03-b .ky_date .ky_line-t {
	padding-right: 0;
}
/* イベントリスト */

.second-ev01-in {
	margin-bottom: 100px;
}
.second-ev01-in li:nth-child(even) .second-ev-in dd {
	margin-top: 30px;
}
.second-ev-in dt {
	font-size: 60px;
	margin-top: 8px;
	width: 75px;
	line-height: 0;
	color: #888888;
}
.second-ev-in dd {
	flex: 1;
}
.second-ev-in dd h3 {
	font-weight: 600;
	font-size: 22px;
	margin-bottom: 25px;
}
.second-ev01-in li:nth-child(even) .second-ev-in dt {
	/* width: 75px; */
}
.second-ev01-in li:nth-child(even) .second-ev-in dd {
	padding-top: 30px;
}
.second-ev01-in li:nth-child(even) .text-b .second-ev-in {
	padding-top: 119px;
}
.second-ev01-in li {
	width: calc(50% - 45px / 2);
	margin-bottom: 70px;
}
.second-ev01-in li a {
	position: relative;
}
.second-ev01-in li .text-b {
	position: relative;
	background-color: #ffffff;
}
.second-ev01-in li .photo-b {
	z-index: 1;
	position: relative;
	/* margin-bottom: 100px; */
}
.second-ev01-in li:nth-child(odd) .text-b {
	padding: 35px 26px 80px 20px;
	width: 88%;
	float: left;
}
.second-ev01-in li:nth-child(odd) .photo-b {
	width: 84%;
	float: right;
	margin-top: -60px;
}
.second-ev01-in li:nth-child(even) {
	padding-top: 120px;
}
.second-ev01-in li:nth-child(even) .text-b {
	padding: 0 20px 16px 16px;
	width: 88%;
	float: left;
}
.second-ev01-in li:nth-child(even) .photo-b {
	width: 84%;
	float: right;
	margin-bottom: -155px;
	text-align: right;
	/* justify-content: flex-end; */
	/* position: relative; */
}
.second-ev01-in li:nth-child(odd) .second-ev-in dt {
	margin-top: 30px;
	/* width: 14%; */
}
.second-ev01-in .ky_cap {
	/* margin-top: 25px; */
	/* margin-bottom: 30px; */
	margin-top: 0;
}
@media screen and (max-width: 767px) {
	/* 全ての背景 */
	.sp_all_bk {
		background-image: url("../images/top/sp_hero_top_bk.png");
		width: 100%;
		background-size: cover;
		background-position: top center;
	}
	/* ヘッダー */
	.contents-wrap, .top_bk {
		background-image: none;
		padding-top: 0;
		background-size: inherit;
		background-repeat: inherit;
		background-position: inherit;
	}
	.contents-wrap {
		margin-top: -45px;
	}
	.top_bk {
		padding-top: 67%;
	}
	.top_bk h1 {
		/* height: 196px; */
		position: absolute;
		top: 30%;
		left: 40%;
		width: 54vw;
	}
	/* 共通 イベント　テキストパーツ */
	.ky_cap {
		margin-top: 10px;
		margin-bottom: 15px;
		font-size: 14px;
	}
	.ky_date .ky_week .span01 {
		font-size: 49%;
		padding-right: 5px;
	}
	.ky_date .ky_week .span02 {
		font-size: 43%;
		margin-bottom: 1px;
	}
	/* １段目 */
	.first-ev {
		margin-bottom: 35px;
		position: relative;
	}
	.first-ev .first-ev-pb {
		/* margin-left: 30px; */
		margin-top: 0;
		margin-bottom: -40px;
		width: 92%;
		float: right;
	}
	.first-ev .first-ev-t {
		margin-right: 25px;
		margin-top: -50px;
		padding-top: 50px;
		padding-left: 50px;
		width: auto;
		position: static;
		max-width: initial;
	}
	.first-ev .first-ev-p {
		margin-left: 50px;
		width: auto;
		float: initial;
	}
	.first-ev-tb dd {
		padding: 5px 15px 0 5px;
	}
	.first-ev .first-ev-tb {
		width: 88%;
		float: left;
		padding: 45px 0 20px 26px;
		position: relative;
	}
	.first-ev .ky_cap {
		margin-bottom: 15px;
	}
	.first-ev dd h3 {
		font-size: 16px;
		margin-bottom: 15px;
	}
	.left-title {
		text-align: center;
		margin-left: inherit;
		margin-bottom: 10px;
	}
	.left-title .photo-h2 img {
		width: 22%;
	}
	.left-title .cap-h2 {
		margin-top: 0;
		font-size: 12px;
	}
	/* 2段目以降 */
	.second-ev01-in li:nth-child(odd) .photo-b {
		margin-top: 0;
		margin-bottom: -40px;
		float: left;
		width: 92%;
	}
	.second-ev01-in li:nth-child(even) .photo-b {
		margin-top: 0;
		margin-bottom: -40px;
		width: 92%;
	}
	.second-ev01-in li:nth-child(even) {
		padding-top: 0;
	}
	.second-ev01-in li:nth-child(even) .text-b .second-ev-in {
		padding-top: 0;
	}
	.second-ev01-in li:nth-child(even) .second-ev-in dd {
		padding-top: 20px;
	}
	.second-ev01-in li:nth-child(odd) .text-b {
		padding: 45px 0 20px 21px;
		margin-left: auto;
		width: 90%;
		float: right;
	}
	.second-ev01-in li:nth-child(even) .text-b {
		padding: 0 0 16px 26px;
	}
	.second-ev01-in li:nth-child(odd) .text-b dd {
		padding-right: 33px;
		padding-top: 5px;
	}
	.second-ev01-in li:nth-child(even) .text-b dd {
		padding-right: 15px;
		padding-left: 5px;
	}
	.second-ev01-in {
		margin-bottom: 25px;
	}
	.second-ev01-in li {
		margin-bottom: 30px;
		width: 100%;
	}
	.second-ev01-in li .second-ev-tb {
		margin-top: -50px;
		padding-top: 50px;
		padding-bottom: 20px;
	}
	.second-ev01-in li:nth-child(even) .second-ev-tb {
		margin-right: 12px;
		padding-left: 25px;
		padding-right: 15px;
		background-color: lightblue;
	}
	.second-ev01-in li:nth-child(even) .second-ev-pb {
		margin-left: 30px;
	}
	.second-ev01-in li:nth-child(odd) .second-ev-tb {
		margin-left: 12px;
		padding-right: 25px;
		padding-left: 15px;
		background-color: lightblue;
	}
	.second-ev01-in li:nth-child(odd) .second-ev-pb {
		margin-right: 30px;
	}
	.second-ev-in dd h3 {
		font-size: 16px;
		margin-bottom: 15px;
	}
	/* カラム　3 */
	.column03-b {
		margin: 0 12px;
	}
	.column03-b .item-list .item {
		width: calc(50% - 20px / 2);
	}
	.column03-b .item-list::after {
		width: calc(50% - 20px / 2);
	}
	.column03-b .ky_date .ky_line-t {
		display: none;
	}
	.column03-b .item p.auto span {
		font-size: 10px;
		margin-bottom: 5px;
	}
	.column03-b .item p.auto {
		font-size: 12px;
		padding: 5px 10px 10px;
	}
	.column03-b .ky_date {
		padding: 0 10px 10px;
	}
}