@charset "UTF-8";

/* ------------------------------------------------
                   Locations
--------------------------------------------------- */

/*---------- 共通 ----------*/

/* ページタイトル */
.sec-page-ttl {
	width: 100%;
	height: 300px;
	padding: 20px 0;
	position: relative;
}
.page-ttl-bg {
	width: 100%;
	height: 100%;
	background: url("../../img/locations/bg_ttl.jpg") center top -21.2222px no-repeat;
	background-size: cover;
	position: absolute;
	top: 0;
	left: 0;
}
.sec-page-ttl .cont-inn {
	height: 100%;
}
.page-ttl-wrap {
	width: 100%;
	max-width: 960px;
	text-align: left;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.page-ttl-en {
	margin-bottom: 10px;
	color: #fff;
	font-size: 1.7rem;
    font-weight: 500;
	line-height: 1.73;
	letter-spacing: 0.05em;
	font-family: "Roboto", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-variation-settings:
	"wdth" 100;
}
.page-ttl {
	color: #fff;
	font-size: 3.8rem;
    font-weight: 500;
	line-height: 1.05;
}
.page-sub-ttl {
	margin-top: 30px;
	color: #fff;
	font-size: 1.9rem;
	line-height: 2.05;
}

/* パンクズ */
.breadcrumbs, 
.breadcrumbs a {
	color: #fff;
}

/* セクションタイトル */
.sec-ttl-en {
	margin-bottom: 10px;
	color: var(--color-black);
	font-size: 1.7rem;
    font-weight: 500;
	line-height: 1.35;
	letter-spacing: 0.05em;
	font-family: "Roboto", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-variation-settings:
	"wdth" 100;
	opacity: 0.5;
}
.sec-ttl {
	color: var(--color-black);
	font-size: 2.3rem;
    font-weight: 500;
	line-height: 1.73;
}
.sec-lead-txt {
	margin-top: 30px;
	color: var(--color-black);
	font-size: 1.7rem;
    font-weight: 600;
	line-height: 1.85;
}

@media (max-width: 768px) {
	/* ページタイトル */
	.sec-page-ttl {
		width: 100%;
		height: 120vw;
		padding: 1.6vw 0 50.13vw;
		background: #fff;
		border-top: 1px solid var(--color-blue);
	}
	.page-ttl-bg {
		width: 100%;
		height: 50.13vw;
		background: url("../../img/locations/bg_ttl_sp.jpg") center top 0 no-repeat;
		background-size: 120%;
		position: absolute;
		top: auto;
		bottom: 0;
		left: 0;
	}
	.page-ttl-wrap {
		max-width: initial;
		text-align: center;
	}

	/* パンクズ */
	.breadcrumbs, 
	.breadcrumbs a {
		color: #000;
	}
	

	/* ページタイトル */
	.page-ttl-en {
		margin-bottom: 2.66vw;
		font-size: var(--fs-sp-14);
	}
	.page-ttl {
		color: #000;
		font-size: var(--fs-sp-32);
		text-shadow: none;
	}
	.page-sub-ttl {
		margin-top: 8vw;
		color: var(--color-black);
		font-size: var(--fs-sp-17);
		font-weight: 600;
		text-shadow: none;
	}


	/* セクションタイトル */
	.sec-ttl-en {
		margin-bottom: 1.33vw;
		font-size: var(--fs-sp-14);
	}
	.sec-ttl {
		font-size: var(--fs-sp-23);
	}
	.sec-lead-txt {
		margin-top: 8vw;
		font-size: var(--fs-sp-17);
	}

	
	
}



/*---------- ページ コピー ----------*/
.sec-page-copy {
	width: 100%;
	padding: 85px 0 50px;
	text-align: center;
}
.page-copy {
	color: var(--color-black);
	font-size: 1.9rem;
	line-height: 2;
}

@media (max-width: 768px) {
	.sec-page-copy {
		padding: 13.33vw 0;
		text-align: left;
	}
	.page-copy {
		color: var(--color-gray);
		font-size: var(--fs-sp-14);
	}
}



/*---------- エリア ----------*/
.sec-location {
	width: 100%;
	padding: 0 0 80px;
	background: #fff;
	text-align: center;
	position: relative;
	z-index: 2;
}


.btn-download {
	width: max-content;
	display: block;
	margin: 0 auto 80px;
	padding: 5px 10px;
	border: 1px solid var(--color-link);
	color: var(--color-link);
	font-weight: 700;
    transition: 0.3s ease-in-out;
}

@media (min-width: 769px) {

	.btn-download:hover {
		background: var(--color-link);
		color: #fff;
	}
	.btn-download:hover::after {
		content: none;
	}
}
@media (max-width: 768px) {
	.sec-location {
		width: 100%;
		padding: 0 0 18.66vw;
	}

	.btn-download {
		width: max-content;
		display: block;
		margin: 0 auto 21.33vw;
		padding: 1.33vw 2.66vw;
	}
    
}

.sec-location .cont-inn {
	max-width: 960px;
	justify-content: space-between;
}

/* エリア */
.location-area-wrap {
	width: 100%;
	margin: 0 auto;
	padding: 0;
	text-align: left;
}
.location-area-wrap.is-half {
	width: calc((100% - 40px) / 2);
	margin: 0;
	padding: 0;
	text-align: left;
}
.location-area-wrap:last-of-type {
	margin: 0 auto;
	padding: 50px 0 0;
	border-top: 1px dashed rgba(85, 85, 85, 0.2);
}

.location-area-ttl {
	width: 100%;
	margin-bottom: 50px;
	display: block;
	text-align: left;
	color: #009944;
	font-size: 2.3rem;
	font-weight: 500;
	line-height: 1;
	background: none;
	border: none;
	padding: 0;
}

/* リスト */
.area-list {
	width: 100%;
	margin-bottom: 50px;
	padding: 0 0 50px;
	align-items: flex-start;
}
.location-area-wrap.is-half .area-list {
	margin-bottom: 0;
}
.area-list.border-b {
	border-bottom: 1px solid rgba(85, 85, 85, 0.5);
}
.area-item {
	width: calc((100% - 40px) / 2);
	margin-right: 40px;
}
.location-area-wrap.is-half .area-item {
	width: 100%;
	margin-right: 0;
}
.area-item:nth-child(2n) {
	margin-right: 0;
}
.area-item:nth-child(n + 3) {
	margin-top: 80px;
}

.area-item-ttl {
	margin-bottom: 5px;
	font-size: 1.5rem;
	font-weight: 600;
	position: relative;
}
.area-item-ttl {
	color: var(--color-black);
}

.area-item-tag-wrap {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}

.area-item-txt, 
.area-item-address, 
.area-item-tel,
.area-item-fax {
	font-size: 1.5rem;
	font-weight: 400;
	line-height: 1.6;
}
.area-item-txt {
	margin-bottom: 10px;
}
.area-item-address {
	display: inline-block;
	position: relative;
}
.icon-map-pin {
	width: 17px;
	height: auto;
	position: absolute;
	bottom: 5px;
	right: -22px;
}
.area-item-add-txt{
	white-space: pre-wrap;
}

.area-item-img {
	margin-top: 40px;
}

.location-area-trigger {
	display: none;
}

.area-item .normal-link {
	display: inline-block;
	font-weight: 600;
	text-decoration: none;
	position: relative;
}

@media (min-width: 769px) {
	.location-area-ttl {
		pointer-events: none;
	}
	.area-list-wrap {
		display: block !important;
	}
	.area-list:not(.area-list-category) {
		display: flex !important;
	}
	

	.area-item {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
	}
	.area-item-ttl::after {
		content: '';
		width: 0;
		height: 1px;
		background: var(--color-sghblue);
		position: absolute;
		bottom: 0;
		left: 0;
		transition: 0.3s ease-in-out;
	}
	
	a:hover .area-item-ttl {
		color: var(--color-sghblue);
	}
	a:hover .area-item-ttl::after {
		width: 100%;
	}
	.area-item .normal-link::after {
		content: '';
		width: 0;
		height: 1px;
		background: var(--color-link);
		position: absolute;
		bottom: 0;
		left: 0;
		transition: 0.3s ease-in-out;
	}
	.area-item .normal-link:hover::after {
		width: 100%;
	}
}

@media (max-width: 768px) {

	/* エリア */
	.location-area-wrap, 
	.location-area-wrap.is-half {
		width: 100%;
		margin: 0 auto;
		padding: 0;
		text-align: left;
		border-bottom: none;
		border-top: 1px solid rgba(85, 85, 85, 0.5);
	}
	.location-area-wrap:last-of-type {
		margin: 0 auto;
		padding: 0;
		border-top: 1px solid rgba(85, 85, 85, 0.5);
	}
	
	.location-area-ttl {
		width: 100%;
		margin-bottom: 0;
		padding: 8vw 2vw;
		text-align: left;
		font-size: var(--fs-sp-16);
		color: var(--color-green);
		position: relative;
	}
	.location-area-ttl::after {
		content: '▼';
		display: block;
		color: var(--color-darkgray);
		font-size: 3.8vw;
		line-height: 1;
		position: absolute;
		top: calc(50% - 1.9vw);
		right: 0;
		transition: 0.3s ease-in-out;
	}
	.location-area-ttl.is-open::after {
		transform: rotate(-180deg);
	}

	.area-list-wrap {
		display: none;
	}
	.area-list-wrap.is-show {
		display: block !important;
	}

	/* リスト */
	.area-list {
		width: 100%;
		padding: 0 0 10.66vw;
	}
	
	.area-item {
		width: 100%;
		margin-right: 0;
	}
	.area-item + .area-item {
		margin-top: 13.33vw;
	}

	.area-item-ttl {
		margin-bottom: 1vw;
		padding-left: 5.33vw;
		font-size: var(--fs-sp-15);
	}
	.area-item-tag {
		margin-bottom: 1vw;
		padding: 1vw 2vw;
		font-size: var(--fs-sp-14);
	}
	
	.area-item-txt, 
	.area-item-address, 
	.area-item-tel,
	.area-item-fax {
		padding-left: 5.33vw;
		font-size: var(--fs-sp-15);
		line-height: 1.6;
	}
	.area-item-txt {
		margin-bottom: 2.66vw;
	}
	.icon-map-pin {
		width: 4.53vw;
		height: auto;
		position: absolute;
		bottom: 1.33vw;
		right: -5.86vw;
	}

	.area-item-img {
		margin-top: 10.66vw;
	}
	.area-item .normal-link {
		margin-left: 5.33vw;
	}

}


/*---------- ボタン ----------*/
.sec-btn-area {
	width: 100%;
	padding: 50px 0 80px;
	background: var(--color-lightgray);
	position: relative;
	z-index: 2;
}
.btn-wrap {
	width: 100%;
	align-items: center;
	justify-content: center;
}
.btn-link {
	width: 260px;
	height: 60px;
	padding-right: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 30px;
	background: #fff;
	font-weight: 500;
	position: relative;
}
.btn-link::before {
	content: '';
	width: 60px;
	height: 60px;
	background: var(--color-green);
	border-radius: 50%;
	position: absolute;
	top: calc(50% - 30px);
	right: 0;
	transition: 0.3s ease-in-out;
}
.btn-link::after {
	content: '';
	width: 60px;
	height: 60px;
	background: url("../../img/common/icon_arrow_w.svg") center center no-repeat;
	background-size: 22px;
	position: absolute;
	top: calc(50% - 30px);
	right: 0;
	transition: 0.3s ease-in-out;
}

.btn-link + .btn-link {
	margin-left: 200px;
}


.btn-back {
	width: 260px;
	height: 60px;
	padding-left: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 30px;
	background: #fff;
	font-weight: 500;
	position: relative;
}
.btn-back::before {
	content: '';
	width: 60px;
	height: 60px;
	background: var(--color-green);
	border-radius: 50%;
	position: absolute;
	top: calc(50% - 30px);
	left: 0;
	transition: 0.3s ease-in-out;
}
.btn-back::after {
	content: '';
	width: 60px;
	height: 60px;
	background: url("../../img/common/icon_arrow_back_w.svg") center center no-repeat;
	background-size: 22px;
	position: absolute;
	top: calc(50% - 30px);
	left: 0;
	transition: 0.3s ease-in-out;
}

@media (min-width: 769px) {
	.btn-link:hover::before {
		background: var(--color-darkblue);
	}
	
	.btn-back:hover::before {
		background: var(--color-darkblue);
	}
    
}


@media (max-width: 1100px) {
	.btn-link + .btn-link {
		margin-left: 15%;
	}
}


@media (max-width: 768px) {
	.sec-btn-area {
		width: 100%;
		padding: 13.33vw 0 21.33vw;
		background: var(--color-lightgray);
		position: relative;
		z-index: 2;
	}
	.btn-wrap {
		width: 100%;
		align-items: center;
		justify-content: center;
	}
	.btn-link {
		width: 80%;
		height: 15vw;
		padding-right: 3vw;
		border-radius: 8vw;
		font-size: 3.8vw;
	}
	.btn-link::before {
		content: '';
		width: 15vw;
		height: 15vw;
		position: absolute;
		top: calc(50% - 7.5vw);
		right: 0;
		transition: 0.3s ease-in-out;
	}
	.btn-link::after {
		content: '';
		width: 15vw;
		height: 15vw;
		background: url("../../img/common/icon_arrow_w.svg") center center no-repeat;
		background-size: 6vw;
		position: absolute;
		top: calc(50% - 7.5vw);
		right: 0;
		transition: 0.3s ease-in-out;
	}

	.btn-link + .btn-link {
		margin-left: 0;
		margin-top: 12vw;
	}

    
	.btn-back {
		width: 80%;
		height: 15vw;
		padding-left: 3vw;
		border-radius: 8vw;
		font-size: 3.8vw;
	}
	.btn-back::before {
		content: '';
		width: 15vw;
		height: 15vw;
		position: absolute;
		top: calc(50% - 7.5vw);
		left: 0;
		transition: 0.3s ease-in-out;
	}
	.btn-back::after {
		content: '';
		width: 15vw;
		height: 15vw;
		background: url("../../img/common/icon_arrow_back_w.svg") center center no-repeat;
		background-size: 6vw;
		position: absolute;
		top: calc(50% - 7.5vw);
		left: 0;
		transition: 0.3s ease-in-out;
	}
}

