@charset "utf-8";
/* CSS Document */

section.greeting {
	padding-bottom: 4vw;
}

section.feature::after {
	content: '';
	background: url("../images/common/back_dots.png");
	background-size: 200px 200px;
	display: inline-block;
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: -2;
}

.top_ttl {
	color: #B7002C;
}

.feature_ttl_wrap {
	background: #B7002C;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 30px 10px 6%;
}

.feature_ttl_wrap > * {
	display: flex;
	justify-content: center;
	width: 100%;
}

.feature_ttl_wrap > span {
	width: 130px;
}

.feature_ttl {
	color: #FFF;
	font-size: clamp(22px,4vw,40px);
	font-family: "fot-tsukuardgothic-std", sans-serif;
	font-weight: bold;
}

.sec_ttl_inner {
	margin-top: 20px;
}

.sec_ttl {
	color: #B7002C;
	line-height: 140%;
}

.sec_ttl > small {
	display: flex;
	justify-content: center;
	width: 100%;
	font-size: clamp(18px,2.4vw,24px);
}

.article_inner {
	padding: 40px 0px;
	width: 90%;
	margin: 0px auto;
}

.article_img {
	display: flex;
	justify-content: center;
}

.article_txt {
	font-size: clamp(15px,2vw,20px);
	font-family: "fot-tsukuardgothic-std", sans-serif;
	font-weight: bold;
	text-align: center;
	color: #242A39;
	margin: 0px auto;
	padding: 5vw 0px 5vw;
	line-height: 200%;
}


article.choose_03 .article_inner > p {
	padding: 0px 0px 5vw;
}


section.feature {
	padding: 100px 0px;
}

.feature article {
	width: 100%;
	margin-top: -4%;
} 

.feature article:nth-of-type(2) {
	padding-bottom: 10rem;
} 

.feature article.choose_01 .sec_ttl_icon::after {
	background: url("../images/common/back_dots.png");
	background-size: 200px 200px;
	background-attachment: fixed;
}

.feature article.choose_02 .sec_ttl_icon::after {
	background: #FCFFD2;
}

.feature article.choose_02::after {
	content: '';
    background: #FCFFD2;
    display: inline-block;
    width: 100%;
    height: 103%;
    bottom: -5%;
	left: 50%;
	transform: translateX(-50%);
    position: absolute;
    z-index: -1;
}

.feature article.choose_03 .sec_ttl_icon::after {
	background: #F8E5EA;
}

.feature article.choose_03::after {
	content: '';
    background: #F8E5EA;
    display: inline-block;
    width: 100%;
    height: 96%;
	top: 3%;
    bottom: 0px;
	left: 50%;
	transform: translateX(-50%);
    position: absolute;
    z-index: -1;
}

/*.series_wrap {
	max-width: 1500px;
	width: 90%;
	margin: 0px auto;
}
*/
.series-list {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap: 30px;
}

.series-list li {
	width: 100%;
}

.more_btn {
	margin-top: 4rem;
}

.choose_box {
	max-width: 1100px;
	width: 90%;
	margin: 4% auto 0px;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 30px;
}

.choose_box > div {
	width: 47%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.choose_box .sec_ttl_icon {
	align-items: center;
	width: 80px;
}

.choose_box .sec_ttl_icon::before {
	content: '';
	width: 200px;
	height: 200px;
	background: #FFF;
	position: absolute;
	border-radius: 100px;
	top: 0px;
}

.choose_box .sec_ttl {
	font-family: "fot-tsukuardgothic-std", sans-serif;
	font-weight: bold;
	text-align: center;
	margin-top: 20px;
}

.choose_box > div::before {
	content: '';
	display: inline-block;
	width: 200px;
	height: 200px;
	border-radius: 100px;
	border: 1px solid #242A39;
	top: -2px;
	position: absolute;
	z-index: -1;
}

.choose_box > div::after {
	content: '';
	background: #FFF;
	border: 1px solid #242A39;
	display: inline-block;
	border-radius: 30px;
	width: 100%;
	height: 94%;
	bottom: 0px;
	position: absolute;
	z-index: -1;
}

.choose_box_inner {
	padding: 30px 40px;
}

.choose_txt {
	font-size: clamp(16px,2vw,20px);
	font-family: "fot-tsukuardgothic-std", sans-serif;
	font-weight: bold;
	text-align: center;
	margin-top: 10px;
}


.kyudaimae_wrap {
	width: 100%;
	background: #FFF;
	z-index: 0;
}

.kyudaimae_wrap::after {
	content: '';
	background: #B7002C;
	display: inline-block;
	width: 100%;
	height: 40%;
	top: 0px;
	position: absolute;
	z-index: -1;
}

.kyudaimae_inner {
	max-width: 1500px;
	width: 90%;
	margin: 0px auto;
	padding: 50px 0px;
}

.kyudaimae_ttl {
	font-size: clamp(20px,4vw,40px);
	font-family: "fot-tsukuardgothic-std", sans-serif;
	font-weight: bold;
	text-align: center;
	color: #FFF;
	margin-bottom: 30px;
}

.kyudaimae_inner .article_txt {
	padding: 0px;
}

.about_tel {
	background: #F8E5EA;
	padding: 30px 15px;
}

section.about {
	padding: 20px 0px 10%;
}

section.access {
	padding: 20px 0px 10%;
}

.access_ttl {
	font-size: clamp(20px,3vw,30px);
	font-family: "fot-tsukuardgothic-std", sans-serif;
	font-weight: bold;
	text-align: center;
}

.access_map {
	height: 500px;
	border: 2px solid #242A39;
	margin: 10px 0px 30px;
}

.access_list {
	cursor: pointer;
	border: 2px solid #242A39;
}

.accordion {
	border-bottom: 2px solid #242A39;
	padding: 10px 20px;
	font-size: clamp(15px,1.8vw,18px);
	font-family: "fot-tsukuardgothic-std", sans-serif;
	font-weight: bold;
}

.accordion:last-of-type {
	border-bottom: 0px;
}

.accordion__title {
	width: 100%;
	padding-right: 40px;
}

.accordion__title,
.accordion__title > span {
	display: flex;
	align-items: center;
	width: 100%;
	line-height: 130%;
}

.accordion__title > span::before {
	content: '';
	background-repeat: no-repeat !important;
	background-size: contain !important;
	display: inline-block;
	width: 62px;
	height: 62px;
	left: 0px;
	position: relative;
	padding-right: 10px;
}

.accordion__title .case_car::before {
	background: url("../images/about/icon_access_car.svg");
}

.accordion__title .case_train::before {
	background: url("../images/about/icon_access_train.svg");
}

.accordion__title::after {
	content: '';
	background: url("../images/about/icon_open.svg");
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	width: 29px;
	height: 29px;
	right: 10px;
	position: absolute;
}

.accordion__title.show::after {
	content: '';
	background: url("../images/about/icon_close.svg");
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	width: 29px;
	height: 3px;
	right: 10px;
	position: absolute;
}

.accordion__content {
	display: none;
}

.accordion__content_inner {
	padding: 10px 0px 30px 70px;
	font-size: clamp(14px,1.6vw,16px);
	line-height: 130%;
}

.route_wrap {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 30px;
}

.route_wrap > div {
	width: 100%;
	background: #F7F7F1;
	padding: 2rem 6%;
}

.route_ttl_wrap {
	display: flex;
	flex-direction: column;
	margin-bottom: 10px;
}

.route_ttl {
	font-size: clamp(15px,1.8vw,18px);
	color: #042A39;
}

.route_ttl_wrap > small {
	font-size: clamp(13px,1.5vw,15px);
	color: #D50029;
	letter-spacing: 0px;
}

.route_img {
	width: 94%;
	margin: 0px auto 30px;
}

.train .route_img {
	margin: 3rem auto;
}

.train_ttl {
	margin-bottom: 10px;
	display: flex;
	flex-wrap: wrap;
	gap: 3px;
}

.train_ttl:nth-of-type(n+2) {
	margin-top: 30px;
}

.train_ttl > * {
	padding-left: 1.2rem;
	letter-spacing: 0px;
}

.train_ttl > span {
	font-size: clamp(15px,1.8vw,18px);
}

.train_ttl > small {
	font-size: clamp(13px,1.5vw,15px);
}

.train_ttl::before {
	content: '';
	background: url("../images/common/arrow_red_right.svg");
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	width: 0.7rem;
	height: 1rem;
	left: 0px;
	top: 3px;
	position: absolute;
}

.access_route {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.access_route li {
	display: flex;
	line-height: 140%;
	font-size: 15px;
	letter-spacing: 0px;
}

.access_route li:not(:last-child)::after {
	content: '';
	background: url("../images/common/arrow_red_bottom.svg");
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	width: 27px;
	height: 16px;
	bottom: -28px;
	left: 50%;
	transform: translateX(-50%);
	position: absolute;
}

.route_btn_wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 20px;
}

.route_btn {
	background: #F8E5EA;
	font-size: clamp(15px,1.8vw,18px);
	border-radius: 10px;
}

.route_btn a {
	display: flex;
	padding: 10px 20px;
}


@media screen and (max-width: 768px) {
	.feature_ttl_wrap {
		padding-bottom: 7%;
	}
	
	.feature_ttl_wrap > span {
		width: 80px;
	}
	
	.accordion__content_inner {
		padding: 20px 10px;
	}

	.route_wrap > div {
		text-align: center;
	}
	
	.access_route {
		place-items: center;
	}
	
	.train_ttl::before {
		top: 2px;
	}

	.route_wrap {
		grid-template-columns: repeat(1,1fr);
	}
	
	.route_img {
		width: 90%;
	}
}


@media screen and (max-width: 600px) {
	.feature_ttl_wrap {
		padding-bottom: 10%;
	}
	
	.feature_ttl_wrap > span {
		width: 60px;
	}
	
	.series-list {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
	}
	
	.feature article:nth-of-type(2) {
		padding-bottom: 20%;
	}

	.choose_box {
		margin-top: 10%;
	}
	
	.choose_box .sec_ttl_icon {
		width: 60px;
	}
	
	.choose_box > div::before {
		width: 110px;
		height: 110px;
	}
	
	.choose_box .sec_ttl_icon::before {
		width: 110px;
		height: 110px;
	}
	
	.choose_box > div {
		width: 100%;
	}
	
	.accordion {
		padding: 10px 15px;
	}
	
	.accordion__title > span::before {
		width: 50px;
		height: 50px;
		padding-right: 15px;
	}
	
	.accordion__title::after {
		width: 20px;
		height: 20px;
	}
	
	.accordion__title.show::after {
		width: 20px;
	}
}

