@charset 'UTF-8';
/*----------------------------------------

	- pageKv
	- pageMain
	- summary
	- location
	+ route
		- routeTab
		- access
		- info
	- trafficInfo
	- sightseeingInfo
	- relatedPage_first

-----------------------------------------*/

/*----------------------------------------
	pageKv
-----------------------------------------*/
.pageKv {
	inline-size: min(80%, 1120px);
	margin-inline: auto;
}

.pageKv div {
	margin-inline-end: calc(50% - (50vw - 7.5px));
}

.pageKv h1 {
	position: relative;
	block-size: 100%;
	margin-inline-start: -3.09em;
	margin-inline-end: -3.15em;
	color: var(--color-white01);
	font-size: var(--font-size60);
	line-height: var(--line-height10);
	writing-mode: vertical-rl;
}

@media (width <=800px) {
	.pageKv {
		inline-size: 100%;
		margin-inline: 0;
	}

	.pageKv div {
		margin-inline-end: 0;
	}

	.pageKv h1 {
		position: relative;
		block-size: 96%;
		margin-inline-start: -2.5em;
		margin-inline-end: -3.75em;
		font-size: var(--font-size44);
	}
}

/*----------------------------------------
	pageMain
-----------------------------------------*/
.pageMain {
	z-index: 1;
	position: relative;
	overflow: hidden;
}

.pageMain .pageMainContainer {
	position: relative;
	inline-size: min(80%, 1120px);
	margin-inline: auto;
	padding-block: 24px 155px;
	padding-inline-start: 64px;
}

.pageMain .pageMainContainer::after {
	content: '';
	display: block;
	z-index: -1;
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: 0;
	block-size: 100%;
	inline-size: 100vw;
	border-end-start-radius: 64px;
	background: linear-gradient(160deg, var(--color-gradient-access01) 10%, var(--color-gradient-access02) 50%, var(--color-gradient-access03) 90%);
}

.pageMain .pageMainContainer .pageCategory {
	gap: 0 15px;
	margin-inline-end: 10px;
	font-size: var(--font-size50);
}

.pageMain .pageMainContainer .pageCategory>span:not(:first-of-type) {
	margin-block-start: 2px;
	margin-inline-end: 0;
	border-block-start-style: unset;
	border-block-start-width: unset;
}

.pageMain .pageMainContainer .pageCategory>span:not(:first-of-type) span {
	font-size: var(--font-size12);
}

@media (width <=800px) {
	.pageMain {
		overflow: unset;
	}

	.pageMain .pageMainContainer {
		inline-size: 100%;
		margin-inline: 0;
		padding-block: 26px 116px;
		padding-inline-start: 4%;
		overflow: hidden;
	}

	.pageMain .pageMainContainer::after {
		inline-size: 100%;
		background: linear-gradient(130deg, var(--color-gradient-access01) 10%, var(--color-gradient-access02) 50%, var(--color-gradient-access03) 90%);
	}

	.pageMain .pageMainContainer .pageCategory {
		gap: 0 10px;
		font-size: var(--font-size36);
	}

	.pageMain .pageMainContainer .pageCategory>span:not(:first-of-type) {
		margin-block-start: 0;
	}

	.pageMain .pageMainContainer .pageCategory span:not(:first-of-type) span {
		transform: unset;
	}
}

/*----------------------------------------
	summary
-----------------------------------------*/
.summary {
	inline-size: min(80%, 1120px);
	margin-block-start: 160px;
	margin-inline: auto;
}

@media (width <=800px) {
	.summary {
		inline-size: 84%;
		margin-block-start: 128px;
		margin-inline: auto;
	}
}

/*----------------------------------------
	location
-----------------------------------------*/
.location {
	display: grid;
	gap: 0 40px;
	grid-template-columns: minmax(calc(30.35% - 40px), 268px) minmax(69.64%, 780px);
	inline-size: min(80%, 1120px);
	margin-block-start: 80px;
	margin-inline: auto;
}

.location h2 {
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size36);
	line-height: var(--line-height15);
}

.location>div {
	margin-block-start: 12px;
	border-block: var(--border-width1) solid var(--color-black01);
}

.location>div dl {
	display: grid;
	grid-template-columns: max-content auto;
}

.location>div dl+dl {
	margin-block-start: 0;
	border-block-start: var(--border-width1) solid var(--color-opalgray01);
}

.location>div dl :is(dt, dd) {
	padding-block: 19px;
}

.location>div dl dt {
	min-inline-size: 217px;
	padding-inline-end: 16px;
	font-weight: var(--font-weight-medium);
	line-height: var(--line-height20);
}

.location>div dl dd {
	display: grid;
	gap: 0 20px;
	grid-template-columns: auto max-content;
}

.location>div dl dd>span:first-of-type {
	font-size: var(--font-size16);
}

.location>div dl dd .btn02 {
	max-inline-size: unset;
	min-inline-size: 200px;
}

@media (width <=1024px) {
	.location {
		gap: 16px 0;
		grid-template-columns: 1fr;
		grid-template-areas: unset;
	}
}

@media (width <=800px) {
	.location {
		gap: 32px 0;
		inline-size: 84%;
		margin-block-start: 65px;
		margin-inline: auto;
	}

	.location h2 {
		font-size: var(--font-size24);
	}

	.location>div {
		gap: 60px 15px;
		grid-template-columns: 1fr;
		margin-block-start: 0;
	}

	.location>div dl dt {
		min-inline-size: 116px;
		margin-block-start: 5px;
		line-height: var(--line-height15);
	}

	.location>div dl dd {
		gap: 21px 0;
		grid-template-columns: 1fr;
	}

	.location>div dl dd .btn02 {
		max-inline-size: 148px;
		min-inline-size: unset;
	}
}

/*----------------------------------------
	route
-----------------------------------------*/
.route {
	display: none;
	margin-block-start: 160px;
	scroll-margin-block-start: 162px;
	animation: route 0.3s ease-in-out;
}

.route.active {
	display: block;
}

@keyframes route {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

@media (width <=800px) {
	.route {
		margin-block-start: 128px;
		scroll-margin-block-start: 32px;
	}
}

/*----------------------------------------
	routeTab
-----------------------------------------*/
.routeTab {
	display: grid;
	grid-template-columns: repeat(3, minmax(21.42%, 240px));
	align-items: end;
	position: relative;
	inline-size: min(80%, 1120px);
	margin-inline: auto;
	padding-inline: 8px;
}

.routeTab h2 {
	display: grid;
	justify-content: center;
	align-items: center;
	min-block-size: 159px;
	padding-block-start: 68px;
	padding-block-end: 10px;
	border-block-start: 1px solid var(--color-black01);
	border-block-end: 1px solid var(--color-pearl01);
	border-inline: 1px solid var(--color-black01);
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size36);
	line-height: var(--line-height15);
	text-align: center;
}

.routeTab h2 span {
	display: block;
	font-size: var(--font-size20);
	line-height: var(--line-height125);
}

.routeTab p {
	display: grid;
	justify-content: center;
	align-items: center;
	min-block-size: 140px;
	padding-block-start: 57px;
	padding-block-end: 10px;
	border-block-start: 1px solid var(--color-black01);
	font-size: var(--font-size24);
	line-height: var(--line-height125);
	text-align: center;
	cursor: pointer;
}

@media (hover: hover) {
	.routeTab p:hover {
		border-color: var(--color-darkgray01);
		background-color: var(--color-darkgray01);
		color: var(--color-white01);
		transition: all 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	}
}

.routeTab p span {
	display: block;
	margin-block-start: -17px;
	font-size: var(--font-size18);
}

.routeTab :is(h2, p) {
	background-repeat: no-repeat;
	background-position: center top 23px;
	background-size: 40px 36px;
}

.routeTab .trainRoute {
	order: 1;
	background-image: url(/asset/img/access/ic_train.svg);
}

.routeTab .carRoute {
	order: 2;
	background-image: url(/asset/img/access/ic_car.svg);
}

.routeTab .planeRoute {
	order: 3;
	background-image: url(/asset/img/access/ic_plane.svg);
}

.route.train .routeTab p {
	border-inline-end: 1px solid var(--color-black01);
}

.route.car .routeTab p:last-of-type {
	border-inline-end: 1px solid var(--color-black01);
}

.route.car .routeTab p:first-of-type {
	border-inline-start: 1px solid var(--color-black01);
}

.route.plane .routeTab p {
	border-inline-start: 1px solid var(--color-black01);
}

@media (hover: hover) {
	.routeTab p.trainRoute:hover{
		background-image: url(/asset/img/access/ic_train_w.svg);
	}

	.routeTab p.carRoute:hover {
		background-image: url(/asset/img/access/ic_car_w.svg);
	}

	.routeTab p.planeRoute:hover {
		background-image: url(/asset/img/access/ic_plane_w.svg);
	}

	.route.train .routeTab p:hover {
		border-color: var(--color-darkgray01);
	}

	.route.car .routeTab p:hover:last-of-type {
		border-color: var(--color-darkgray01);
	}

	.route.car .routeTab p:hover:first-of-type {
		border-color: var(--color-darkgray01);
	}

	.route.plane .routeTab p:hover {
		border-color: var(--color-darkgray01);
	}
}

.routeTab::before {
	content: '';
	display: block;
	z-index: -1;
	position: absolute;
	inset-block-end: 0;
	block-size: 1px;
	inline-size: 100%;
	border-block-end: 1px solid var(--color-black01);
}

@media (width <=800px) {
	.routeTab {
		grid-template-columns: repeat(3, 1fr);
		inline-size: 100%;
		margin-inline: 0;
		padding-inline: 0;
	}

	.routeTab h2 {
		min-block-size: 86px;
		padding-block-start: 35px;
		padding-block-end: 7px;
		font-size: var(--font-size20);
	}

	.routeTab h2 span {
		margin-block-start: -2px;
		font-size: var(--font-size12);
	}

	.routeTab p {
		min-block-size: 79px;
		padding-block-start: 32px;
		padding-block-end: 10px;
		font-size: var(--font-size16);
	}

	.routeTab p span {
		margin-block-start: -3px;
		font-size: var(--font-size10);
	}

	.routeTab :is(h2, p) {
		background-position: center top 12px;
		background-size: 20px 18px;
	}

	.route.train .routeTab h2:first-of-type {
		border-inline-start: none;
	}

	.route.train .routeTab p:last-of-type {
		border-inline-end: none;
	}

	.route.car .routeTab p:first-of-type {
		border-inline-start: none;
	}

	.route.car .routeTab p:last-of-type {
		border-inline-end: none;
	}

	.route.plane .routeTab p:first-of-type {
		border-inline-start: none;
	}

	.route.plane .routeTab h2:last-of-type {
		border-inline-end: none;
	}
}

/*----------------------------------------
	access
-----------------------------------------*/
.access {
	display: grid;
	gap: 0 64px;
	grid-template-columns: minmax(calc(59.28% - 64px), 600px) minmax(40.71%, 456px);
	inline-size: min(80%, 1120px);
	margin-block-start: 80px;
	margin-inline: auto;
}

.access dl dd img {
	padding: 32px 20px;
}

.access dl span {
	padding-inline-start: 15px;
	font-size: var(--font-size18);
}

.access p .btn01 {
	max-inline-size: 366px;
	margin-block-start: 64px;
	margin-inline: auto;
}

.access p .btn01 span span {
	font-size: var(--font-size12);
}

@media (width <=1024px) {
	.access {
		gap: 64px;
		grid-template-columns: 1fr;
	}
}

@media (width <=800px) {
	.access {
		gap: 32px 0;
		inline-size: 100%;
		margin-block-start: 32px;
		margin-inline: 0;
	}

	.access dl span {
		font-size: var(--font-size14);
	}

	.access dl dd img {
		padding-inline: 5%;
	}

	.access p:has(.btn01) {
		inline-size: 80%;
		margin-inline: auto;
	}

	.route.car .access p:has(.btn01) {
		inline-size: 86.5%;
	}

	.access p .btn01 {
		max-inline-size: 320px;
	}

	.route.car .access p .btn01 {
		max-inline-size: 346px;
	}
}

/*----------------------------------------
	trafficInfo
-----------------------------------------*/
.trafficInfo {
	display: grid;
	gap: 0 40px;
	grid-template-columns: minmax(calc(30.35% - 40px), 268px) minmax(69.64%, 780px);
	inline-size: min(80%, 1120px);
	margin-block-start: 160px;
	margin-inline: auto;
}

.trafficInfo h2 {
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size36);
	line-height: var(--line-height15);
}

.trafficInfo>div {
	margin-block-start: 12px;
	border-block: var(--border-width1) solid var(--color-black01);
}

.trafficInfo>div dl {
	display: grid;
	grid-template-columns: max-content auto;
}

.trafficInfo>div dl+dl {
	margin-block-start: 0;
	border-block-start: var(--border-width1) solid var(--color-opalgray01);
}

.trafficInfo>div dl :is(dt, dd) {
	padding-block: 20px;
	line-height: var(--line-height15);
}

.trafficInfo>div dl dt {
	min-inline-size: 217px;
	font-weight: var(--font-weight-medium);
}

.trafficInfo>div dl dd a::after {
	content: '';
	display: inline-block;
	block-size: 14px;
	inline-size: 14px;
	margin-inline-start: 22px;
	background: url(/asset/img/common/ic_external01_m.svg) no-repeat center center;
	background-size: cover;
}

.trafficInfo>div dl dd ul li+li {
	margin-block-start: 17px;
}

.trafficInfo>div dl dd p {
	margin-block-start: 23px;
	font-size: var(--font-size14);
	line-height: var(--line-height20);
}

@media (width <=1024px) {
	.trafficInfo {
		gap: 16px 0;
		grid-template-columns: 1fr;
		grid-template-areas: unset;
	}

	.trafficInfo h2 br {
		display: none;
	}
}

@media (width <=800px) {
	.trafficInfo {
		gap: 32px 0;
		inline-size: 84%;
		margin-block-start: 128px;
		margin-inline: auto;
	}

	.trafficInfo h2 {
		font-size: var(--font-size24);
	}

	.trafficInfo>div {
		gap: 60px 15px;
		grid-template-columns: 1fr;
		margin-block-start: 0;
	}

	.trafficInfo>div dl dt {
		min-inline-size: 116px;
	}

	.trafficInfo>div dl dd a::after {
		block-size: 10px;
		inline-size: 10px;
		background-image: url(/asset/img/common/ic_external01_s.svg);
	}

	.trafficInfo>div dl dd p {
		margin-inline-start: -116px;
	}
}

/*----------------------------------------
	info
-----------------------------------------*/
.info {
	margin-block-start: 64px;
}

.info .infoTitle span {
	display: inline-block;
}

.info .infoTxt p+p {
	margin-block-start: 32px;
}

.info .infoTxt p+p a span {
	border-block-end: var(--border-width1) solid currentColor;
}

.info .infoTxt p+p a::after {
	content: '';
	display: inline-block;
	block-size: 14px;
	inline-size: 14px;
	margin-inline-start: 16px;
	background: url(/asset/img/common/ic_external01_m.svg) no-repeat center center;
	background-size: cover;
}

@media (width <=800px) {
	.info {
		margin-block-start: 32px;
	}

	.info .infoTxt p+p {
		margin-block-start: 16px;
	}

	.info .infoTxt p+p a::after {
		block-size: 10px;
		inline-size: 10px;
		margin-inline-start: 12px;
		background-image: url(/asset/img/common/ic_external01_s.svg);
	}
}

/*----------------------------------------
	sightseeingInfo
-----------------------------------------*/
.sightseeingInfo {
	inline-size: min(80%, 1120px);
	margin-block-start: 64px;
	margin-inline: auto;
}

.sightseeingInfo>div {
	display: grid;
	gap: 59px 60px;
	grid-template-columns: repeat(2, 1fr);
	inline-size: min(69.64%, 780px);
	margin-block-start: 12px;
	margin-inline-start: auto;
}

.sightseeingInfo>div a {
	display: block;
}

.sightseeingInfo>div a>span {
	display: grid;
	place-items: center;
	block-size: min(11.42vw, 160px);
	inline-size: 100%;
	background: var(--color-palegray01);
}

.sightseeingInfo>div a>span img {
	display: block;
	inline-size: min(69.44%, 250px);
}

.sightseeingInfo>div div dl dt {
	display: inline-block;
	position: relative;
	margin-block-start: 17px;
	padding-inline-end: 29px;
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size20);
	line-height: var(--line-height15);
}

.sightseeingInfo>div div dl dt::after {
	content: '';
	display: block;
	position: absolute;
	inset-block-start: 0.5em;
	inset-inline-end: 0;
	block-size: 10px;
	inline-size: 10px;
	background: url(/asset/img/common/ic_external01_s.svg) no-repeat center center;
	background-size: cover;
}

.sightseeingInfo>div div dl dd {
	font-size: var(--font-size16);
	line-height: var(--line-height2);
}

@media (width <=1024px) {
	.sightseeingInfo {
		gap: 16px 0;
		grid-template-columns: 1fr;
		grid-template-areas: unset;
	}

	.sightseeingInfo>div {
		inline-size: 100%;
	}

	.sightseeingInfo>div a>span {
		block-size: min(15.62vw, 160px);
	}
}

@media (width <=800px) {
	.sightseeingInfo {
		inline-size: 84%;
		margin-block-start: 0;
	}

	.sightseeingInfo>div {
		gap: 60px 15px;
		grid-template-columns: 1fr;
		margin-block-start: 32px;
	}

	.sightseeingInfo>div a>span {
		block-size: 37.5vw;
	}

	.sightseeingInfo>div a>span img {
		inline-size: 70%;
	}

	.sightseeingInfo>div div dl dt {
		margin-block-start: 16px;
		padding-inline-end: 21px;
		font-size: var(--font-size16);
	}

	.sightseeingInfo>div div dl dd {
		margin-block-start: 8px;
		font-size: var(--font-size14);
	}
}

/*----------------------------------------
	relatedPage_first
-----------------------------------------*/
.relatedPage_first {
	margin-block-start: 78px;
}

@media (width <=800px) {
	.relatedPage_first {
			margin-block-start: 79px;
		}
}