/* Y'S GEAR : /mc/chemical/css/select.css */

/*======================================================================*
 *  [ エフェクトのヘッダ ] 
 *======================================================================*/

.selectMain {
	position: relative;
	margin-bottom: 100px;
	padding-bottom: 10px;
	background: url(../img/main_select.jpg) center top / 100% auto no-repeat #000;
	/* background: #000; */
	clip-path: polygon(0 0, 100% 0, 100% 100%, 0 max(calc(100% - 49px), calc(100% - 5vw)));
	/* z-index: 101; */
}

.selectOutline {
	position: relative;
	min-height: 320px;
	padding: 4.5%;
}
.selectOutline p {
	margin-top: 10px;
	color: #fff;
	font-weight: bold;
	line-height: 1.8;
}
.selectOutline .img {
	position: absolute;
	right: 10px;
	bottom: max(-49px, -5vw);
	width: 35.7%;
	transform: translateY(10%);
	z-index: 2;
}

@media screen and (max-width: 980px) {
	.selectMain {
		margin-right: -20px;
		margin-left: -20px;
	}
} /* */

@media screen and (max-width: 568px) {
	.selectMain {
		margin: 0 -10px 50px;
		background-size: 180%;
		clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 15vw));
	}

	.selectOutline {
		min-height: auto;
	}
	.selectOutline .img {
		display: block;
		position: relative;
		right: auto;
		bottom: auto;
		margin: 0 auto -15vw;
		width: min(300px, 100%);
		transform: translateY(0);
	}
} /* */


/*======================================================================*
 *  [ やりたいコト：ナビ ] 
 *======================================================================*/

.effectNav {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0 4%;
	position: relative;
	padding: min(calc(49px + 5%), calc(5vw + 5%)) 3% min(calc(49px + 2.5%), calc(5vw + 2.5%));
	border-right: 10px solid #000;
	border-left: 10px solid #000;
	background: url(../effect/img/nav_bg.png) center bottom / cover no-repeat #0066B7;
	clip-path: polygon(0 0, 100% min(49px, 5vw), 100% 100%, 0 max(calc(100% - 49px), calc(100% - 5vw)));

}

/* [ ボタン ] */
.effectNav a {
	position: relative;
	width: min(266px, 30.66%);
	text-align: center;
}
.effectNav a:nth-child(3) ~ a {
	margin-top: -3%;
}
.effectNav a svg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.effectNav a svg .fuki {
	transition: all 0.3s ease;
}

/* [ ボタン：ホバー ] */
.effectNav a:hover,
.effectNav a:active {
	transform: translateY(-10px);
}
.effectNav a:hover img,
.effectNav a:active img {
	opacity: 1;
}
.effectNav a:hover svg .fuki {
	fill: #FFCC00;
}

@media screen and (max-width: 568px) {
	.effectNav {
		display: block;
		padding: 15vw 15px;
		clip-path: polygon(0 0, 100% 15vw, 100% 100%, 0 calc(100% - 15vw));
	}

	/* [ ボタン ] */
	.effectNav a {
		display: block;
		width: 55%;
		margin: 0 !important;
	}
	.effectNav a + a {
		margin-top: -13% !important;
	}
	.effectNav a:nth-child(even) {
		margin-left: auto !important;
	}
} /* */

/* .effectFloat {
	display: flex;
	flex-wrap: wrap;
	position: fixed;
	top: 0;
	left: 50%;
	width: min(980px, 100%);
	border: 3px solid #000;
	background: rgba(255,255,255,0.9);
	font-size: 1.8rem;
	font-weight: bold;
	transform: translate(-50%, -100%);
	transition: all 0.3s ease; 
	z-index: 100;
}
.effectFloat.is-show {
	transform: translate(-50%, 0);
}

.effectFloat a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 20%;
	height: 54px;
	color: #0066B7;
}
.effectFloat a:hover,
.effectFloat a:active {
	background: #0066B7;
	color: #fff !important;
} */

@media screen and (max-width: 768px) {
	/* .effectFloat {
		font-size: 1.6rem;
	} */
} /* */

@media screen and (max-width: 568px) {
	/* .effectFloat {
		font-size: 1.4rem;
	}
	.effectFloat a {
		width: 33.33%;
		height: 35px;
	} */
} /* */


/*======================================================================*
 *  [ やりたい場所：マップ ] 
 *======================================================================*/

.placeMap {
	padding: min(calc(49px + 4%), calc(5vw + 4%)) 3% min(49px, 5vw);
	border-right: 10px solid #000;
	border-left: 10px solid #000;
	background: url(../place/img/map_bg.png) center bottom / cover no-repeat #49BDF4;
	font-size: min(1.6rem, calc(1.63vw));
	font-family: "M PLUS 1p", sans-serif;
 	font-weight: 900;
  	font-style: normal;
	line-height: 1;
	clip-path: polygon(0 0, 100% min(49px, 5vw), 100% 100%, 0 100%);
}

/* [ インナー ] */
.placeMap .inner {
	position: relative;
	width: min(880px, 100%);
	margin: 0 auto;
	z-index: 2;
}

/* [ ボタン ] */
.placeMap a {
	display: flex;
	align-items: center;
	gap: 5px;
	position: absolute;
	width: fit-content;
	/* height: 40px; */
	padding: 5px;
	border: 3px solid #0066B7;
	border-radius: 25px;
	background: #0066B7;
	color: #fff;
	/* transform: translate(-50%, -50%); */
}
.placeMap a:nth-of-type(1) {
	top: 10%;
	left: 58%;
	transform: translate(-50%, calc(-100% + 10px));
}
.placeMap a:nth-of-type(2) {
	top: 14.2%;
	left: 40.5%;
	transform: translate(-75%, calc(-100% + 10px));
}
.placeMap a:nth-of-type(3) {
	top: 10%;
	right: 15.5%;
	transform: translate(50%, calc(-100% + 10px));
}
.placeMap a:nth-of-type(4) {
	top: 47.5%;
	right: 71.5%;
	transform: translate(10px, -50%);
}
.placeMap a:nth-of-type(5) {
	top: 14.2%;
	left: 17%;
	/* transform: translate(-50%, calc(-100% + 10px)); */
	transform: translate(-60%, calc(-100% + 10px));
}
.placeMap a:nth-of-type(6) {
	left: 0;
	bottom: 30%;
	transform: translate(0, 50%);
}
.placeMap a:nth-of-type(7) {
	left: 44%;
	bottom: 9.5%;
	transform: translate(-50%, 50%);
}
.placeMap a:nth-of-type(8) {
	right: 34.5%;
	bottom: 9.5%;
	transform: translate(75%, 50%);
}
.placeMap a b {
	flex: 1;
	transform: rotate(0.05deg);
}

/* [ ボタン：ホバー ] */
.placeMap a:hover, 
.placeMap a:active {
	border-color: #0066B7 !important;
	background: #FFCC00;
	color: #0066B7 !important;
}
.placeMap a:hover::after, 
.placeMap a:active::after {
	border-color: #0066B7;
}
.placeMap a:hover img, 
.placeMap a:active img {
	opacity: 1;
}

@media screen and (max-width: 568px) {
	.placeMap {
		padding: calc(15vw + 10px) 15px 15vw;
		background-size: 150% auto;
		clip-path: polygon(0 0, 100% 15vw, 100% 100%, 0 100%);
	}

	/* [ ボタン ] */
	.placeMap a {
		padding: 0;
	}
	.placeMap a:nth-of-type(1) {
		top: auto;
		bottom: 88%;
		left: 58.75%;
		transform: translate(-50%, 0);
	}
	.placeMap a:nth-of-type(2) {
		top: auto;
		bottom: 79%;
		left: 39.5%;
		transform: translate(-50%, 0);
	}
	.placeMap a:nth-of-type(3) {
		top: auto;
		bottom: 88%;
		right: 28%;
		transform: translate(50%, 0);
	}
	.placeMap a:nth-of-type(4) {
		top: 44%;
		right: 74%;
		transform: translate(0, -50%);
	}
	.placeMap a:nth-of-type(5) {
		top: auto;
		bottom: 79%;
		left: 12.5%;
		transform: translate(-50%, 0);
	}
	.placeMap a:nth-of-type(6) {
		right: 88%;
		left: auto;
		bottom: 27%;
		transform: translate(0, 50%);
	}
	.placeMap a:nth-of-type(7) {
		left: 40.5%;
		bottom: 11%;
		transform: translate(-50%, 100%);
	}
	.placeMap a:nth-of-type(8) {
		right: 46%;
		bottom: 11%;
		transform: translate(50%, 100%);
	}
	.placeMap a b {
		display: none;
	}
} /* */

/*======================================================================*
 *  [ やりたい場所：ナビ ] 
 *======================================================================*/

.placeNav {
	display: flex;
	flex-wrap: wrap;
	gap: 20px 15px;
	position: relative;
	margin-top: max(-49px, -5vw);
	padding: min(calc(49px + 2.5%), calc(5vw + 2.5%)) 3%;
	border-right: 10px solid #000;
	border-left: 10px solid #000;
	background: url(../place/img/nav_bg.png) center top / cover no-repeat #FFE577;
	font-family: "M PLUS 1p", sans-serif;
 	font-weight: 900;
  	font-style: normal;
	line-height: 1;
	clip-path: polygon(0 0, 100% min(49px, 5vw), 100% 100%, 0 max(calc(100% - 49px), calc(100% - 5vw)));
}

/* [ ボタン ] */
.placeNav a {
	display: flex;
	align-items: center;
	gap: 10px;
	width: calc(33.33% - 10px);
	height: 50px;
	padding: 0 10px;
	border: 3px solid #0066B7;
	border-radius: 25px;
	background: #0066B7;
	color: #fff;
}
.placeNav a::after {
	display: block;
	width: 10px;
	height: 10px;
	border-right: 3px solid #fff;
	border-bottom: 3px solid #fff;
	transform: translateY(-25%) rotate(45deg);
	content: "";
}
.placeNav a b {
	flex: 1;
	transform: rotate(0.05deg);
}

/* [ ボタン：ホバー ] */
.placeNav a:hover, 
.placeNav a:active {
	border-color: #0066B7 !important;
	background: #FFCC00;
	color: #0066B7 !important;
}
.placeNav a:hover::after, 
.placeNav a:active::after {
	border-color: #0066B7;
}
.placeNav a:hover img, 
.placeNav a:active img {
	opacity: 1;
}

@media screen and (max-width: 768px) {
	/* [ ボタン ] */
	.placeNav a {
		width: calc(50% - 7.5px);
	}
} /* */

@media screen and (max-width: 568px) {
	.placeNav {
		gap: 10px;
		margin-top: -15vw;
		padding: calc(15vw + 10px) 15px;
		font-size: 1.4rem;
		clip-path: polygon(0 0, 100% 15vw, 100% 100%, 0 calc(100% - 15vw));
	}

	/* [ ボタン ] */
	.placeNav a {
		gap: 5px;
		width: calc(50% - 5px);
		padding: 0 5px;
	}
} /* */


/*======================================================================*
 *  [ やりたい場所：ついてくるナビ ] 
 *======================================================================*/

.placeFloat {
	display: flex;
	flex-wrap: wrap;
	position: fixed;
	top: 0;
	left: 50%;
	width: min(980px, 100%);
	/* height: 60px; */
	border: 3px solid #000;
	background: rgba(255,255,255,0.9);
	/* font-size: 1.8rem; */
	line-height: 1.1;
	font-weight: bold;
	transform: translate(-50%, -100%);
	transition: all 0.3s ease; 
	z-index: 100;
}
.placeFloat.is-show {
	transform: translate(-50%, 0);
}

/* [ ボタン ] */
.placeFloat a {
	display: flex;
	/* justify-content: center; */
	align-items: center;
	gap: 5px;
	width: 25%;
	height: 36px;
	padding: 0 10px;
	color: #0066B7;
}
.placeFloat b {
	flex-shrink: 0;
	width: 1.4em;
	height: 1.4em;
	border-radius: 50%;
	background: #0066B7;
	color: #fff;
	font-size: calc(1em - 0.2rem);
	line-height: 1.4;
	text-align: center;
}

/* [ ボタン：ホバー ] */
.placeFloat a:hover,
.placeFloat a:active {
	background: #0066B7;
	color: #fff !important;
}

@media screen and (max-width: 768px) {

} /* */

@media screen and (max-width: 568px) {
	.placeFloat {
		font-size: 1.2rem;
	}
	.placeFloat a {
		width: 50%;
		height: 30px;
		/* height: 35px; */
	}
} /* */



/*======================================================================*
 *  [  ] 
 *======================================================================*/

.selectCat {
	position: relative;
	padding: 0 30px 100px;
}
.selectCat::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #E5EFF8;
	clip-path: polygon(0 0, 100% min(49px, 5vw), 100% 100%, 0 max(calc(100% - 49px), calc(100% - 5vw)));
	content: "";
}
.selectCat > * {
	position: relative;
	z-index: 1;
}

.selectCat h2 {
	margin-bottom: 50px;
	text-align: center;
}
.selectCat h2:has(b) img {
	margin-top: 1%;
}
.selectCat h2 b {
	display: block;
	margin-top: 20px;
	font-size: 3rem;
	/* font-size: 4rem; */
}
.selectCat h2 + p {
	margin-bottom: 30px;
	color: #333;
	font-weight: bold;
	line-height: 1.8;
}
.selectCat h2 + img {
	display: block;
	width: 100%;
	margin-bottom: 50px;
}

/* [ サブタイトル ] */
.selectCat .sub {
	margin: 50px 0;
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
}

@media screen and (max-width: 980px) {
	.selectCat {
		margin-right: -20px;
		margin-left: -20px;
	}
} /* */

@media screen and (max-width: 568px) {
	.selectCat {
		margin: 0 -10px 50px !important;
		padding: 5vw 30px calc(15vw + 30px);
	}
	.selectCat::before {
		clip-path: polygon(0 0, 100% 15vw, 100% 100%, 0 calc(100% - 15vw));
	}

	.selectCat h2 {
		margin-bottom: 30px;
		text-align: center;
	}
	.selectCat h2:has(b) img {
		margin-top: 0;
		height: 24px;
	}
	.selectCat h2 b {
		display: block;
		margin-top: 20px;
		font-size: 1.8rem;
		font-size: 2.1rem;
	}
} /* */


/*======================================================================*
 *  [  ] 
 *======================================================================*/

.selectLineup {
	display: flex;
	flex-wrap: wrap;
	gap: 30px 20px;
}

.selectLineup section {
	position: relative;
	width: calc(50% - 10px);
	padding: 0 20px 66px 20px;
	border-radius: 20px;
	background: #fff;
}
.selectLineup section:has(.link div) {
	padding-bottom: 122px;
}

/* [ キャッチコピー ] */
.selectLineup .cach {
	display: flex;
	justify-content: center;
	align-items: center;
	width: calc(100% + 40px);
	height: 3em;
	margin: 0 -20px 20px;
	padding: 0 20px;
	border-radius: 20px 20px 0 0;
	background: #0066B7;
	color: #fff;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.2;
	text-align: center;
}

/* [ 画像 ] */
.selectLineup img {
	float: left;
	width: 41.5%;
	margin-bottom: 20px;
}

/* [ 詳細 ] */
.selectLineup .detail {
	float: right;
	width: calc(58.5% - 20px);
	margin-bottom: 20px;
}
.selectLineup .detail h3 {
	margin-bottom: 20px;
	font-size: 1.6rem;
}
.selectLineup .detail h3 span {
	display: inline-block;
	font-size: calc(1em - 0.2rem);
}
.selectLineup .detail dl {
	display: flex;
	flex-wrap: wrap;
	font-size: 1.4rem;
}
.selectLineup .detail dt {
	width: 5em;
	color: #0066B7;
	font-weight: bold;
}
.selectLineup .detail dt.no {
	color: #FF0000;
}
.selectLineup .detail dd {
	width: calc(100% - 5em);
}
.selectLineup .detail dt:not(:nth-of-type(1)),
.selectLineup .detail dd:not(:nth-of-type(1)) {
	margin-top: 10px;
	padding-top: 10px;
	border-top: 1px solid #EDEDED;
}

/* [ テキスト ] */
.selectLineup .txt {
	clear: both;
	margin-bottom: 20px;
	font-size: 1.4rem;
}

/* [ リンク ] */
.selectLineup .link {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	position: absolute;
	right: 20px;
	bottom: 20px;
	left: 20px;
}
.selectLineup .link div {
	display: flex;
	flex-direction: column;
	gap: 10px;
	width: calc(50% - 10px);
}
.selectLineup .link a {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	width: calc(50% - 10px);
	height: 46px;
	padding: 0 10px;
	border: 2px solid;
	border-radius: 23px;
	font-weight: bold;
	line-height: 1;
	text-align: center;
}
.selectLineup .link div a {
	width: 100%;
}
.selectLineup .link a[href*="Detail"] {
	border-color: #333;
	color: #333;
}
.selectLineup .link a[href*="movie"] {
	border-color: #0066B7;
	color: #0066B7;
}
.selectLineup .link a::before {
	width: 18px;
	height: 14px;
	content: "";
}
.selectLineup .link a[href*="Detail"]::before {
	background: #333;
	mask: url(../img/icon_btn_arrow.svg) center center / contain no-repeat;
}
.selectLineup .link a[href*="movie"]::before {
	background: #0066B7;
	mask: url(../img/icon_btn_movie.svg) center center / contain no-repeat;
}
.selectLineup .link a:hover:before {
	background: #fff !important;
}
.selectLineup .link a[href*="Detail"]:hover,
.selectLineup .link a[href*="Detail"]:active {
	border-color: #333 !important;
	background: #333;
	color: #fff !important;
}
.selectLineup .link a[href*="movie"]:hover,
.selectLineup .link a[href*="movie"]:active {
	border-color: #0066B7 !important;
	background: #0066B7;
	color: #fff !important;
}
.selectLineup .link a b {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 2px 5px;
	flex-wrap: wrap;
	flex: 1;
	max-width: 8em;
}
.selectLineup .link a span {
	font-size: 1.2rem;
}

@media screen and (max-width: 768px) {
	.selectLineup {
		flex-direction: column;
		align-items: center;
	}

	.selectLineup section {
		width: min(450px, 100%);
	}
} /* */

@media screen and (max-width: 568px) {

	.selectLineup section {
		padding: 0 15px 15px !important;
	}

	/* [ キャッチコピー ] */
	.selectLineup .cach {
		width: calc(100% + 30px);
		height: auto;
		min-height: 3em;
		margin: 0 -15px 15px;
		padding: 10px 15px;
		font-size: 1.8rem;
	}

	/* [ 詳細 ] */
	.selectLineup .detail {
		width: calc(58.5% - 15px);
	}
	.selectLineup .detail dl {
		display: block;
	}
	.selectLineup .detail dt {
		width: 100%;
	}
	.selectLineup .detail dd {
		width: 100%;
		margin-top: 7px !important;
		padding-top: 0 !important;
		border-top: none !important;
	}

	/* [ リンク ] */
	.selectLineup .link {
		position: static;
		gap: 15px;
	}
	.selectLineup .link a {
		gap: 5px;
		width: calc(50% - 7.5px);
		/* height: 32px; */
		height: 36px;
		font-size: 1.4rem;
	}
} /* */