
/*====================================================
//// id 　main
====================================================*/
#main .innerBox {
	width: 100%;
}
#main .itemBox {
	padding: 80px 0 50px;
	width: 100%;
}
#main .item-outer {
	margin: auto;
	width: 100%;
		max-width: 1200px;
	height: 100%;
}
#main .item-outer::before {
	background: url('../img/area-map/map.png') no-repeat center / contain;
	content: '';
	margin: auto;
	opacity: .5;
	position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	width: 95%;
		max-width: 700px;
	height: 70%;
		max-height: 700px;
}
#main .item {
	cursor: pointer;
	margin: auto;
	position: absolute;
	width: 36%;
		max-width: 250px;
}
#main .item img {
	margin: auto;
	transition: .3s ease-in-out;
}
#main .item .txt {
	margin: 0 1em;
	padding-right: 1.5em;
}
#main .item .txt::before {
	border: solid 1px;
	border-radius: 100%;
	content: '';
	margin: auto;
	position: absolute;
		top: .05em;
		right: 0;
	width: 1em;
	height: 1em;
}
#main .item .txt::after {
	border: solid;
	border-width: 1px 1px 0 0;
	content: '';
	margin: auto;
	position: absolute;
		top: .43em;
		right: .45em;
	transform: rotate(45deg);
	width: .3em;
	height: .3em;
}

#main .item-1 {
	top: 2%;
	right: 52%;
	width: 45%;
	max-width: 320px;
}
#main .item-1 .txt {
	transform: translateY(-2em);
}
#main .item-2 {
	top: 3%;
	left: 56%;
	text-align: right;
}
#main .item-3 {
	top: 25%;
	right: 65%;
	width: 33%;
}
#main .item-3 .txt {
	white-space: nowrap;
}
#main .item-4 {
	top: 34%;
	left: 56%;
	text-align: right;
	width: 42%;
		max-width: 320px;
}
#main .item-5 {
	top: 52%;
	right: 43%;
	text-align: right;
}
#main .item-5 .txt {
}
#main .item-6 {
	top: 70%;
	left: 58%;
	text-align: center;
	width: 40%;
		max-width: 300px;
}
#main .item-7 {
	bottom: 0;
	right: 53%;
	width: 40%;
		max-width: 300px;
}

/* ////////// mobile ////////// */
@media screen and (max-width: 769px) {
	#main .innerBox {
		/* min-height: calc(100vh - 180px); */
		min-height: 130vw;
		max-height: 1000px
	}
	#main .itemBox {
		height: 130vw;
		padding: 80px 0 60px;
	}
	#main .item .txt {
		letter-spacing: 0;
	}
	#main .item img {
	}
}

@media screen and (max-width:580px) {
	#main .innerBox {
		min-height: 170vw;
	}
	#main .itemBox {
		height: 170vw;
	}
	#main .item img {
		margin: auto;
		width: 94%;
	}
	#main .item .txt {
		font-size: 2.6vw;
	}
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	#main .itemBox {
		height: calc(100vh - 127px);
		height: calc(100dvh - 127px);
			max-height: 1100px;
			min-height: 980px;
	}
	#main .item:hover img {
		transform: scale(1.05);
	}
}

@media screen and (min-width:1080px) {
	#main .item-outer::before {
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:960px) {
}

@media screen and (min-width:1550px) {
}

/*====================================================
//// id 　leadCopy
====================================================*/

/* ////////// mobile ////////// */
@media screen and (max-width: 769px) {
	#leadCopy .itemBox {
		grid-gap: 0 5vw;
		grid-template-columns: 50px 1fr;
		padding-right: 2vw;
	}
	#leadCopy .headBox {
		grid-row: 1 / 3;
	}
	#leadCopy .headBox h2 {
		-ms-writing-mode: tb-rl;
		    writing-mode: vertical-rl;
		-webkit-text-orientation: upright;
		        text-orientation: upright;
		letter-spacing: .3em;
		margin-top: .2em;
	}
}

@media screen and (max-width:580px) {
	#leadCopy .itemBox {
		grid-template-columns: 14vw 1fr;
	}
	#leadCopy .headBox {
		grid-row: 1 / 2;
	}
	#leadCopy .headBox h2 {
		font-size: 7vw;
	}
	#leadCopy .linkBox {
		grid-column: 1 / 3;
	}
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	#leadCopy .headBox {
		margin-bottom: 40px;
		text-align: center;
	}
	#leadCopy .headBox h2 {
		font-size: 4.8rem;
		letter-spacing: .2em;
	}
	#leadCopy .txtBox {
		text-align: center;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:960px) {
	#leadCopy .headBox h2 {
		font-size: 4.0rem;
	}
}

@media screen and (min-width:1550px) {
}

/*====================================================
//// id 　modal
====================================================*/
.modal-container{
	background: rgba(0,0,0,.7);
	opacity: 0;
	position: fixed;
		top: 0;
		left: 0;
	transition: .3s;
	visibility: hidden;
	width: 100%;
	height: 100%;
	z-index: 1000;

	overflow-y: scroll;
	-ms-overflow-style: none;    /* IE, Edge 対応 */
	scrollbar-width: none;       /* Firefox 対応 */
}
.modal-container::-webkit-scrollbar {  /* Chrome, Safari 対応 */
	display:none;
}
.modal-container:before{
	background: rgba(0, 0, 0, .1);
	content: '';
	margin: auto;
	position: fixed;
		top: 0;
		left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
/*モーダル本体に「active」クラス付与した時のスタイル*/
.modal-container.active{
	opacity: 1;
	visibility: visible;
}
/*モーダル枠の指定*/
.modal-body{
	display: flex;
		align-items: center;
		justify-content: center;
	margin: auto;
	position: relative;
	vertical-align: middle;
	height: 100%;

}


/*モーダルを閉じるボタンの指定*/
.modal-close{
	background: #000;
	border-radius: 100%;
	cursor: pointer;
	display: flex;
		align-items: center;
		justify-content: center;
	position: absolute;
		top: -10px;
		right: -10px;
	width: 40px;
	height: 40px;
}
.modal-close::before ,
.modal-close::after {
	background: #fff;
	border-radius: 10px;
	content: '';
	margin: auto;
	position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	width: 40%;
	height: 8%;
}
.modal-close::before {
	transform: rotate(45deg);
}
.modal-close::after {
	transform: rotate(-45deg);
}
/*モーダル内のコンテンツの指定*/
.modal-content{
	background: #fff;
	text-align: left;
	padding: 30px;
}

/* ////////// mobile ////////// */
@media screen and (max-width: 769px) {
	.modal-close {
		position: fixed;
			top: auto;
			right: 20px;
			top: 15px;
	}
}

@media screen and (max-width:580px) {
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 769px) {
	header .menuBtn.event_none {
		transition: 0;
	}
}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:960px) {
}

@media screen and (min-width:1550px) {
}

/*====================================================
//// id modal item
====================================================*/
#modal .itemBox {
	width: 100%;
	max-height: 100%;
}
#modal .detail_item {
	color: #fff;
	margin: 0 !important;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	width: 100%;
		/* max-width: 1200px; */

}

#modal .detail_item.current {
	opacity: 1;
	pointer-events: auto;
	position: relative;
		top: 0;
	z-index: 10;
}

#modal .detail_item.layout-single {
	grid-template-columns: 1fr;
	margin-left: auto !important;
	margin-right: auto !important;
	max-width: 900px;
}

#modal .detail_item.layout-left .imgBox .coverImg,
#modal .detail_item.layout-right .imgBox .coverImg {
	/* margin: 0;
	width: 100%; */
}
#modal .detail_item .infoBox {
	border: solid;
	border-width: 1px 0;
}
#modal .detail_item .infoBox .info_item {
	grid-gap: 3px;
	grid-template-rows: auto 1fr;
	padding: .5em;
	position: relative;
}
#modal .detail_item .infoBox .info_item::after {
	border-left: solid 1px;
	content: '';
	margin: auto;
	position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
	width: 0;
	height: calc(100% - 16px);
}
#modal .detail_item .infoBox .info_item:last-child::after {
	display: none;
}
#modal .detail_item .infoBox .info_item dt {
	font-size: .7em;
}
#modal .detail_item .arrowBtn-small {
	font-size: 1em;
}
#modal .detail_item .txtBox .infoBox dd > div::-webkit-scrollbar ,
#modal .detail_item .txtBox .copyBox::-webkit-scrollbar {
 width: 5px;
}
#modal .detail_item .txtBox .infoBox dd > div::-webkit-scrollbar-track ,
#modal .detail_item .txtBox .copyBox::-webkit-scrollbar-track {
	 background-color: transparent;
}
#modal .detail_item .txtBox .infoBox dd > div::-webkit-scrollbar-thumb ,
#modal .detail_item .txtBox .copyBox::-webkit-scrollbar-thumb {
	 background-color: #fff;
	 background: linear-gradient(to right, transparent 50%, transparent 50%, #fff 50%, #fff 100%);
}

#modal .detail_item .linkBox {
	width: 100%;
	max-width: none;
}
#modal .detail_item .arrowBtn::before {
	border-bottom-color: #fff;
}
#modal .detail_item .arrowBtn::after {
	border-left-color: #fff;
}
/* ////////// mobile ////////// */
@media screen and (max-width: 960px) {
	#modal .detail_item {
		grid-gap: 15px 0;
		line-height: 1.7;
		margin: auto;
		width: 88%;
	}
	#modal .detail_item.layout-single .imgBox ,
	#modal .detail_item.layout-left .imgBox {
		margin: 0;
		width: 100%;
	}
	#modal .detail_item h2 {
		font-size: 2.4rem;
		margin-bottom: -.3em;
	}
	#modal .detail_item .txtBox {
		width: 100%;
	}
	#modal .detail_item .txtBox .infoBox dd {
		font-size: .9em;
	}
	#modal .detail_item .txtBox .infoBox dd > div {
		height: 2em;
		overflow-y: scroll;
	}
	#modal .detail_item .txtBox .copyBox {
		height: 4.2em;
		overflow-y: scroll;
	}

	#modal .detail_item .linkBox .linkBtn {
		width: auto;
	}
}

@media screen and (max-width:768px) {
	#modal .innerBox {
		padding: 30px 0 80px;
	}
}

@media screen and (max-width:580px) {
	#modal .detail_item .imgBox .coverImg {
		padding-top: 0;
		height: 80vw;
			max-height: 30vh;
	}
	#modal .detail_item h2 {
		font-size: 5.7vw;
	}
}

/* ////////// PC ////////// */
@media print, screen and (min-width: 960px) {
	#modal .detail_item .txtBox .infoBox {
		line-height: 1.8;
	}
	#modal .detail_item .txtBox .copyBox {
		max-height: 14.3em;
		overflow-y: scroll;
	}
	#modal .detail_item.layout-left .linkBox {
		grid-column: 1 / 3;
	}

}

/* ////////// tablet ////////// */
@media screen and (min-width:769px) and (max-width:960px) {
}

@media screen and (min-width:1550px) {
	#modal .detail_item .txtBox .copyBox {
		max-height: 22em;
	}
}
