@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
/* mainVisual */
#main .mainVisual {
	position: relative;
	margin-left: 4rem;
}
#main .mainVisual::after {
	position: absolute;
	top: 0;
	left: -1px;
	width: 19.9rem;
	height: 19.9rem;
	background-color: #fff;
	content: "";
	z-index: 2;
	clip-path: polygon(0 0, 0% 100%, 100% 0);
}
#main .mainVisual .videoBox {
	position: relative;
	width: calc(100% - 26rem);
	aspect-ratio: 162/104;
	line-height: 0;
	pointer-events: none;
	height: 100dvh;
}
#main .mainVisual .videoBox video {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .mainVisual .photoBox {
	position: absolute;
	z-index: 2;
	top: 50%;
	transform: translateY(-45.8%);
	right: -36.5rem;
	width: 129.2rem;
	pointer-events: none;
}
#main .mainVisual .photoBox .image {
	position: relative;
	z-index: 2;
}
#main .mainVisual .photoBox img {
	width: 100%;
}
#main .mainVisual .photoBox .photoUl {
	position: absolute;
	width: 61%;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	z-index: 1;
}
#main .mainVisual .textBox {
	padding: 0 2rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: calc(50% - 73rem);
	z-index: 2;
	width: 80rem;
	color: #fff;
}
#main .mainVisual .textBox .title {
	margin-bottom: 2rem;
	font-size: 8.8rem;
	font-weight: 700;
	letter-spacing: 0.08em;	
	line-height: 1.6;
}
#main .mainVisual .textBox .title span {
	background: -webkit-linear-gradient(#fff,#fff) repeat-x left bottom  / 100% 0.2rem;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}
#main .mainVisual .textBox .text {
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	line-height: 2;
}
#main .mainVisual .scroll {
	position: absolute;
	z-index: 1;
	bottom: 0;
	right: calc(50% - 19.635vw);
	width: 7.4rem;
}
#main .mainVisual .scroll::after {
	position: absolute;
	bottom: 0;
	right: 50%;
	transform: translateX(59.3%);
	width: 35rem;
	height: 35rem;
	content: "";
	background-color: #fff;
	z-index: -1;
	clip-path: polygon(100% 0, 0% 100%, 100% 100%);
}
#main .mainVisual .scroll a {
	padding-bottom: 4rem;
	text-align: center;
	display: block;
	color: #2d4ba0;
	font-weight: 700;
	background: url(../img/common/icon01.png) no-repeat center bottom / 1.7rem;
}
#main .mainVisual .scroll a:hover {
	opacity: 0.7;
}
@media all and (min-width: 897px) and (max-width: 1900px) {
	#main .mainVisual .textBox {
		margin-top: 4rem;
		left: calc(50% - 61rem);
	}
	#main .mainVisual .textBox .title {
		font-size: 5vw
	}
	#main .mainVisual .photoBox {
		right: -22vw;
	}
	#main .mainVisual .scroll {
		right: calc(50% - 14.5vw);
	}
	#main .mainVisual .textBox .text {
		font-size: 1.2vw;
	}
}
@media all and (min-width: 897px) and (max-width: 1650px) {
	#main .mainVisual .photoBox {
		width: 115rem;
	}
}
@media all and (min-width: 1921px) {
	#main .mainVisual .scroll {
		right: 29vw;
	}
	#main .mainVisual .photoBox {
		width: 68vw;
	}
}
@media all and (min-width: 2070px) {
	#main .mainVisual .scroll {
		right: 34vw;
	}
}
@media all and (min-width: 2300px) {
	#main .mainVisual .scroll {
		right: 40vw;
	}
}
@media all and (min-width: 897px) and (max-width: 930px) {
	#main .mainVisual .photoBox {
		width: 117rem;
	}
	#main .mainVisual .videoBox {
		width: calc(100% - 32rem);
	}
}
@media all and (min-width: 897px) and (max-height: 1000px) {
	#main .mainVisual .photoBox {
		width: 140.87vh;
	}
	#main .mainVisual .scroll {
		right: 69vh;
	}
}
@media all and (min-width: 897px) and (max-width: 1480px) {
	#main .mainVisual .photoBox {
		width: 131vh;
	}
}
@media all and (min-width: 897px) and (max-width: 1080px) {
	#main .mainVisual .photoBox {
		width: 123vh;
	}
}
@media all and (min-width: 897px) {
	#main .mainVisual .li01 .videoBox video {
		width: 110%;
		object-position: right center;
	}
}
@media all and (max-width: 896px)  {
	#main .mainVisual {
		margin-left: 0;
	}
	#main .mainVisual::after {
		width: 7.3rem;
		height: 7.3rem;
	}
	#main .mainVisual::before {
		position: absolute;
		bottom: 0;
		right: 0;
		width: 19rem;
		height: 19rem;
		background-color: #fff;
		content: "";
		z-index: 2;
		clip-path: polygon(100% 0, 0% 100%, 100% 100%);
	}
	#main .mainVisual .videoBox {
		width: auto;
		aspect-ratio: inherit;
	}
	#main .mainVisual .photoBox {
		top: auto;
		transform: translateY(0);
		bottom: -7.7rem;
		right: -17.8rem;
		width: 46rem;
	}
	#main .mainVisual .photoBox .photoUl {
		width: 61.5%;
	}
	#main .mainVisual .textBox {
		top: 8rem;
		left: 50%;
		width: 100%;
		transform: translate(-50%,0);
		text-align: center;
	}
	#main .mainVisual .textBox .title {
		margin-bottom: 1rem;
		font-size: 3.9rem;
	}
	#main .mainVisual .textBox .text {
		font-size: 1.6rem;
		text-shadow: 4px 4px 8px rgba(0, 0, 0, 0.8);
	}
	#main .mainVisual .scroll {
		z-index: 10;
		bottom: 4rem;
		right: 16.3rem;
		width: 4.7rem;
	}
	#main .mainVisual .scroll::after {
		display: none;
	}
	#main .mainVisual .scroll a {
		padding-bottom: 1.9rem;
		color: #fff;
		font-size: 1.2rem;
		background-image: url(../img/common/icon01_sp.png);
		background-size: 1rem auto;
		background-position: left calc(50% - 0.2rem) bottom;
	}
}
/* message */
#main .message {
	padding-top: 18rem;
	position: relative;
	z-index: 3;
}
#main .message .headLine01 {
	margin-bottom: 6.6rem;
}
#main .message .bg {
	position: relative;
	z-index: 2;
}
#main .message .bg::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 27.3rem;
	content: "";
	background: linear-gradient(#fff 0%, #def2ff 100%);
	z-index: -1;
}
#main .message .bg .imgBox {
	align-items: flex-end;
}
#main .message .bg .imgBox .textBox {
	margin: 0 -0.7rem 8rem 0;
	flex: 1;
}
#main .message .bg .imgBox .textBox .h_title {
	margin: 0 -4rem 5rem 0;
	font-size: 4.8rem;
	font-weight: 700;
	color: #2d4ba0;
	line-height: 1.66;
}
#main .message .bg .imgBox .textBox .title {
	margin-bottom: 3.3rem;
	font-size: 4rem;
	font-weight: 700;
	color: #1dc8fd;
}
#main .message .bg .imgBox .textBox .comText {
	margin-bottom: 0;
	text-align: justify;
}
#main .message .bg .imgBox .photoBox {
	position: relative;
	margin-right: -2.8rem;
	width: 53rem;
	z-index: 1;
}
#main .message .bg .imgBox .photoBox::after {
	position: absolute;
	width: 94.5rem;
	height: 28.2rem;
	bottom: 0;
	right: -15.7rem;
	content: "";
	z-index: -1;
	background: url(../img/index/message_img01.png) no-repeat left bottom / 100%;
}
#main .message .bg .imgBox .photoBox .tag {
	padding: 2.4rem 0.5rem 1.8rem;
	position: absolute;
	bottom: 4rem;
	right: 2.7rem;
	z-index: 1;
	width: 26.8rem;
	color: #fff;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.04em;
	background-color: #2d4ba0;
	clip-path: polygon(14% 0, 100% 0, 100% 100%, 0 100%, 0% 35%);
}
#main .message .bg .imgBox .photoBox .tag span {
	margin-top: 0.3rem;
	display: block;
	font-size: 2.8rem;
}
#main .message .bg .imgBox .photoBox img {
	width: 100%;
}
#main .message .innerBox {
	padding: 8.3rem 0 12.5rem;
	overflow: hidden;
	position: relative;
	z-index: 1;
	background-color: #def2ff;
}
#main .message .innerBox .content {
	position: relative;
}
#main .message .innerBox .subBox {
	display: none;
}
#main .message .innerBox .lImage {
	width: 58.1rem;
	position: absolute;
	top: -29.3rem;
	right: -58rem;
	z-index: 1;
}
#main .message .innerBox .title {
	margin-bottom: 2.2rem;
	font-size: 4rem;
	font-weight: 700;
	color: #1dc8fd;
}
#main .message .innerBox .info {
	margin-bottom: 0;
	text-overflow:ellipsis;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
#main .message .innerBox .info.omit {
	display: block;
	overflow: visible;
	text-overflow: clip;
	-webkit-line-clamp: unset;
}
#main .message .innerBox .outBox {
	margin: 11.8rem 0 12rem;
	padding-right: 2rem;
	width: calc(50% + 59rem);
}
#main .message .innerBox .outBox .photoBox {
	width: calc(50% + 13.5rem);
}
#main .message .innerBox .outBox .textBox {
	width: calc(50% - 19.5rem);
}
@media all and (min-width: 897px) and (max-width: 1900px) {
	#main .message .bg .imgBox .textBox .h_title {
		font-size: 4.5rem;
	}
	#main .message .bg .imgBox .photoBox {
		width: 30vw;
	}
	#main .message .bg .imgBox .photoBox::after {
		width: 76.5rem;
		right: -5.7rem;
	}
	#main .message .innerBox .lImage {
		right: -48rem;
	}
}
@media all and (max-width: 896px)  {
	#main .message {
		padding-top: 16.5rem;
		z-index: inherit;
	}
	#main .message .headLine01 {
		margin-bottom: 3.5rem;
	}
	#main .message .bg .imgBox {
		display: block;
	}
	#main .message .bg .imgBox .textBox {
		margin: 0 0 1.8rem;
	}
	#main .message .bg .imgBox .textBox .h_title {
		margin: 0 -4rem 7rem 0;
		font-size: 3.2rem;
		line-height: 1.75;
	}
	#main .message .bg .imgBox .textBox .title {
		margin-bottom: 1.4rem;
		font-size: 2.8rem;
	}
	#main .message .bg .imgBox .textBox .comText {
		margin-bottom: 0;
		text-align: left;
	}
	#main .message .bg .imgBox .photoBox {
		padding-left: 3.2rem;
		margin: 0 auto;
		width: 30.9rem;
		box-sizing: content-box;
	}
	#main .message .bg .imgBox .photoBox::after {
		left: -2.5rem;
		right: -2rem;
		width: 114%;
		height: 50rem;
		right: -0.5rem;
		z-index: 3;
		bottom: -0.5rem;
	}
	#main .message .bg .imgBox .photoBox .tag {
		padding: 1.5rem 0.5rem 1.5rem;
		bottom: 2rem;
		right: 0rem;
		z-index: 4;
		font-size: 1.2rem;
		width: 17.1rem;
	}
	#main .message .bg .imgBox .photoBox .tag span {
		margin-top: 0.2rem;
		font-size: 1.6rem;
	}
	#main .message .innerBox {
		padding: 8.3rem 0 10rem;
		z-index: auto;
	}
	#main .message .innerBox .title {
		margin-bottom: 1.5rem;
		font-size: 2.8rem;
	}
	#main .message .innerBox .info {
		-webkit-line-clamp: 6;
	}
	#main .message .innerBox .info.omit {
		-webkit-line-clamp: unset;
	}
	#main .message .innerBox .outBox {
		margin: 8.2rem 0 7.8rem;
		padding-right: 0;
		width: auto;
		display: block;
	}
	#main .message .innerBox .outBox .photoBox {
		margin-bottom: 8rem;
		width: auto;
	}
	#main .message .innerBox .outBox .photoBox img {
		width: 100%;
	}
	#main .message .innerBox .outBox .textBox {
		margin: 0 1.6rem;
		width: auto;
	}
}
/* flow */
#main .flow {
	padding-top: 14rem;
}
#main .flow .comText {
	margin-bottom: 1.8rem;
}
#main .flow .greyBox {
	padding: 4.2rem 11rem 3.8rem;
	background-color: #efefef;
	border-radius: 0.8rem;
}
#main .flow .greyBox .title {
	margin-bottom: 2.5rem;
	font-size: 3.2rem;
	font-weight: 700;
	color: #898989;
}
#main .flow .subImage {
	margin: 0 auto;
	position: relative;
	width: 10.5rem;
}
#main .flow .subImage span {
	width: 35rem;
	position: absolute;
	top: 50%;
	left: 121%;
	z-index: 1;
	transform: translateY(-50%);
	font-size: 2rem;
	font-weight: 700;
}
#main .flow .workBox {
	padding: 4rem 11rem 6.2rem;
	background-color: #edfbff;
	border-radius: 0.8rem;
}
#main .flow .workBox .h_title {
	margin-bottom: 3.2rem;
	text-align: center;
	font-size: 3.2rem;
	font-weight: 700;
	color: #2d4ba0;
}
#main .flow .workBox .workUl li {
	margin-bottom: 5.2rem;
	padding: 2rem 2rem 0.8rem;
	position: relative;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	background-color: #fff;
	border-radius: 2rem;
	align-items: flex-start;
}
#main .flow .workBox .workUl li:not(:last-child)::after {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	content: "";
	width: 10.5rem;
	height: 4.4rem;
	z-index: 1;
	background: url(../img/common/icon09.png) no-repeat center top / 100%;
}
#main .flow .workBox .workUl li:last-child {
	margin-bottom: 0;
}
#main .flow .workBox .workUl .photoBox {
	width: 20rem;
	border-radius: 0.8rem;
	overflow: hidden;
}
#main .flow .workBox .workUl .photoBox img {
	width: 100%;
}
#main .flow .workBox .workUl .textBox {
	margin-right: 6rem;
	flex: 1;
}
#main .flow .workBox .workUl h4 {
	padding: 1rem 0.5rem;
	text-align: center;
	color: #fff;
	font-size: 2.4rem;
	font-weight: 700;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	min-width: 32rem;
	border-radius: 0.3rem;
	background: linear-gradient(to right,#7ad1ec 0%, #2d4ba0 100%);
}
#main .flow .workBox .workUl .text {
	margin: 4.8rem 0 0 2rem;
	line-height: 1.8;
}
@media all and (max-width: 896px)  {
	#main .flow {
		padding-top: 13rem;
	}
	#main .flow .comText {
		margin-bottom: 4.3rem;
	}
	#main .flow .greyBox {
		padding: 3rem 1.3rem 3.8rem 1.9rem;
	}
	#main .flow .greyBox .title {
		margin-bottom: 2.5rem;
		font-size: 2rem;
		text-align: center;
	}
	#main .flow .greyBox .imgtext img {
		width: 100%;
	}
	#main .flow .subImage {
		width: 6.1rem;
	}
	#main .flow .subImage span {
		width: 10rem;
		left: 130%;
		font-size: 1.6rem;
		line-height: 1.25;
	}
	#main .flow .workBox {
		margin: 0 -1.6rem;
		padding: 4rem 2rem;
		border-radius: 0;
	}
	#main .flow .workBox .h_title {
		margin-bottom: 3.1rem;
		font-size: 2rem;
	}
	#main .flow .workBox .workUl li {
		margin-bottom: 3rem;
		padding: 2.3rem 2.8rem 2.2rem;
		display: block;
		border-radius: 0.8rem;
	}
	#main .flow .workBox .workUl li:not(:last-child)::after {
		width: 6.1rem;
		height: 3rem;
		background-image: url(../img/common/icon09_sp.png);
	}
	#main .flow .workBox .workUl li:last-child {
		margin-bottom: 0;
	}
	#main .flow .workBox .workUl .photoBox {
		margin-bottom: -1.7rem;
		width: auto;
	}
	#main .flow .workBox .workUl .textBox {
		margin-right: 0;
	}
	#main .flow .workBox .workUl h4 {
		margin-bottom: 1.4rem;
		padding: 1rem 0.5rem 0.8rem;
		font-size: 2rem;
		position: relative;
		min-width: fit-content;
	}
	#main .flow .workBox .workUl .text {
		margin: 0;
		line-height: 1.75;
	}
}
#main .different {
	margin-top: 12rem;
	padding: 7.8rem 0 8.6rem;
	position: relative;
	z-index: 2;
}
#main .different::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	content: "";
	background-color: #f5f5f5;
}
#main .different::after {
	position: absolute;
	bottom: -8.3rem;
	left: -35.9rem;
	z-index: -1;
	content: "";
	width: 205.3rem;
	height: 205.3rem;
	background: url(../img/common/img02.png) no-repeat left top / 100%;
}
#main .different .headLine02 {
	margin-bottom: 4rem;
}
#main .different .phoList {
	margin-top: -2rem;
}
#main .different .phoList li {
	margin: 2rem 2rem 0 0;
	width: 38rem;
}
#main .different .phoList li:nth-child(3n) {
	margin-right: 0;
}
#main .different .phoList li .photo {
	margin-bottom: 3.1rem;
}
#main .different .phoList li .photo img {
	width: 100%;
	border-radius: 0.8rem;
}
#main .different .phoList li p {
	margin: 0 1rem;
	line-height: 1.6;
}
#main .different .phoList li .title {
	margin-bottom: 1.7rem;
	text-align: center;
	color: #1b4387;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.5;
}
@media all and (min-width: 897px) and (max-width: 1900px) {
	#main .different::after {
		width: 117vw;
		height: 117vw;
	}
}
@media all and (max-width: 896px)  {
	#main .different {
		margin-top: 0;
		padding: 8.3rem 0 6rem;
	}
	#main .different::after {
		bottom: -10rem;
		right: -32rem;
		left: auto;
		width: 89.1rem;
		height: 89.1rem;
	}
	#main .different .headLine02 {
		margin-bottom: 6.2rem;
		font-size: 3.2rem;
		line-height: 1.3;
	}
	#main .different .phoList {
		margin-top: 0;
		display: block;
	}
	#main .different .phoList li {
		margin: 0 0 5.7rem;
		width: auto;
	}
	#main .different .phoList li:last-child {
		margin-bottom: 0;
	}
	#main .different .phoList li .photo {
		margin-bottom: 2rem;
	}
	#main .different .phoList li p {
		margin: 0;
		line-height: 2;
	}
	#main .different .phoList li .title {
		margin-bottom: 1.5rem;
		font-size: 2.4rem;
	}
}
/* place */
#main .place {
	padding: 11.9rem 0 12.8rem;
	background-color: #FFF;
}
#main .place .comText {
	margin-bottom: 6.7rem;
}
#main .place .map {
	position: relative;
}
#main .place .map .image01 {
	position: absolute;
	top: 0;
	left: 0;
	width: 56.3rem;
	pointer-events: none;
}
#main .place .map .image02 {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 51.8rem;
	pointer-events: none;
}
#main .place .map svg {
	padding: 1rem 3rem 4rem 0;
	display: block;
	margin: 0 auto;
	width: 100%;
	max-width: 93.4rem;
	box-sizing: content-box;
}
@media all and (max-width: 896px)  {
	#main .place {
		padding: 7.8rem 0 8rem;
	}
	#main .place .comText {
		margin-bottom: 3.7rem;
	}
	#main .place {
		margin: 0 auto;
	}
	#main .place img {
		width: 100%;
	}
}
/* interview */
#main .interview {
	padding: 13.7rem 0 10.7rem;
	position: relative;
	background: url("../img/index/interview_bg.png") no-repeat right top / 58.7rem;
}
#main .interview::before {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 42rem;
	z-index: -1;
	background: linear-gradient(#def2ff 0%, #FFF 100%);
	content: "";
}
#main .interview::after {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 42rem;
	background: linear-gradient(#fff 0%, #def2ff 100%);
	content: "";
}
#main .interview .phoList {
	margin: 0 -1rem;
	display: flex;
	flex-wrap: wrap;
}
#main .interview .phoList li {
	margin: 0 1rem;
	width: 38rem;
}
#main .interview .phoList a {
	position: relative;
	display: block;
}
#main .interview .phoList a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	content: "";
	z-index: 1;
	background-color: rgba(255, 255, 255, 0.4);
	transition: transform 0.4s cubic-bezier(0.2, 0.9, 0.4, 1.1);
	transform: scaleY(0);
	transform-origin: bottom;
}
#main .interview .phoList li .photo {
	margin-bottom: 2.6rem;
}
#main .interview .phoList li .title {
	margin-bottom: 2.5rem;
	padding: 0 1rem 1.4rem;
	color: #2d4ba0;
	line-height: 1.8;
	font-weight: 700;
	text-align: center;
	border-bottom: 0.2rem dotted #2d4ba0;
}
#main .interview .phoList li .name {
	margin-bottom: 1.4rem;
	font-weight: 700;
	line-height: 1.6;
}
#main .interview .phoList .textUl li {
	margin: 0 0 1.6rem;
	display: flex;
	flex: 1;
}
#main .interview .phoList .textUl li:last-child {
	margin-bottom: 0;
}
#main .interview .phoList .textUl li .tag {
	margin-right: 1.6rem;
	padding: 0rem 1.15rem 0.2rem;
	display: block;
	color: #FFF;
	background-color: #2d4ba0;	
}
@media all and (min-width: 897px) {
	#main .interview .phoList a:hover::after {
		transform: scaleY(1);
	}
}
@media all and (max-width: 896px)  {
	#main .interview {
		padding-bottom: 7.5rem;
		background-size: 18.7rem;
	}
	#main .interview::before {
		height: 16rem;
	}
	#main .interview::after {
		height: 16rem;
	}
	#main .interview .sliderBox {
		position: relative;
	}
	#main .interview .sliderBox .prev,
	#main .interview .sliderBox .next {
		width: 4.8rem;
		position: absolute;
		top: 50%;
		transform: translateY(-300%);
		z-index: 2;
	}
	#main .interview .sliderBox .prev {
		left: 0.8rem;
	}
	#main .interview .sliderBox .next {
		right: 0.8rem;
	}
	#main .interview .phoList {
		margin: 0 -1.6rem;
	}
	#main .interview .phoList li,
	#main .interview .phoList .slick-slide > div {
		margin-right: 3rem;
		width: 28rem;
	}
	#main .interview .phoList li .photo {
		margin-bottom: 2rem;
	}
	#main .interview .phoList li .title {
		margin-bottom: 1.5rem;
		padding: 0;
		font-size: 2rem;
		text-align: left;
		border-bottom: 0;
		line-height: 1.6;
	}
	#main .interview .phoList .textUl li .tag {
		margin-right: 1.1rem;
		padding: 0 0.8rem 0.2rem;
	}
}
#main .work {
    padding: 13.7rem 0 20.1rem;
    position: relative;
    background: #f5fbff;
}
#main .work .comText {
    margin-bottom: 7.7rem;
}
#main .work .inner p {
    margin-bottom: 7.7rem;
    line-height: 2.1;
}
#main .work .workList {
    margin: -8.5rem 0 8.2rem;
}
#main .work .workList li {
    margin-top: 8.5rem;
    width: 56rem;
}
#main .work .workList li p {
    margin-bottom: 1.9rem;
}
#main .work .workList li .photo img {
    border-radius: 1.6rem;
    width: 100%;
}
#main .work .inner:not(:last-child) {
    margin-bottom: 15.3rem;
}
#main .work .textArea .headLine04 {
    width: 31rem;
}
#main .work .textArea .textBox {
    margin-top: -0.3rem;
    width: calc(100% - 31.3rem);
}
#main .work .textArea .title {
    margin-bottom: -0.1rem;    
    color: #2d4ba0;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.5;
}
#main .work .textArea .textList {
    margin-bottom: 3.2rem;
}
#main .work .textArea .textList li {
    padding-left: 2.5rem;
    position: relative;
    line-height: 2.1;
}
#main .work .textArea .textList li::before {
    position: absolute;
    left: 0.6rem;
    top: 1.6rem;
    width: 1.2rem;
    height: 1.2rem;
    border-radius: 50%;
    background-color: #ffd800;
    content: "";
}
#main .work .textArea p {
    margin-bottom: 2.8rem;
}
#main .work .textArea p:last-child {
    margin-bottom: 0;
}
@media all and (max-width: 896px)  {
	#main .work {
        padding: 12.8rem 0 19.1rem;
    }
    #main .work .headLine01 {
        margin-bottom: 5.6rem;
    }
    #main .work .comText {
        margin-bottom: 6.2rem;
    }
    #main .work .inner p {
        line-height: 2;
    }
    #main .work .inner .text01 {
        margin: 0 2rem 0 1.6rem;
    }
    #main .work .inner .text02 {
        margin: 0 2rem 4rem 3.2rem;
    }
    #main .work .workList {
        margin: 0 0 3.8rem;
        display: block;
    }
    #main .work .workList li {
        margin: 0 0 3.7rem;
        width: auto;
    }
    #main .work .workList li:last-child {
        margin-bottom: 0;
    }
    #main .work .workList li p {
        margin: 0 1.6rem 0.9rem;
        line-height: 1.75;
    }
    #main .work .workList li .photo img {
        border-radius: 1.2rem;
    }
    #main .work .inner:not(:last-child) {
        margin-bottom: 12.2rem;
    }
    #main .work .textArea {
        display: block;
    }
    #main .work .textArea .headLine04 {
        margin-bottom: 2.9rem;
        width: auto;
    }
    #main .work .textArea .textBox {
        margin: 0 1.6rem 0;
        width: auto;
    }
    #main .work .textArea .title {
        margin-bottom: 0rem;    
        font-size: 2rem;
        line-height: 1.6;
    }
    #main .work .textArea .textList {
        margin-bottom: 3rem;
    }
    #main .work .textArea .textList li {
        padding-left: 2rem;
        line-height: 2;
    }
    #main .work .textArea .textList li::before {
        left: 0rem;
        top: 1.1rem;
    }
    #main .work .textArea p {
        margin-bottom: 3.1rem;
    }
}
/* information */
#main .information {
	padding-top: 27.5rem;
}
#main .information .headLine01 {
	margin-bottom: 7.9rem;
}
#main .information .tableBox {
	padding-bottom: 8.5rem;
	border-bottom: 1px dashed #707070;
}
#main .information  table {
	width: 100%;
}
#main .information  table th,
#main .information  table td {
	padding: 1.1rem 0 1.1rem 4rem;
	text-align: left;
	font-size: 2rem;
	font-weight: 400;
	line-height: 1.6;
	color: #5e5e5e;
	vertical-align: middle;
	word-break: break-all;
}
#main .information  table th {
	padding: 2.6rem 2rem 2.6rem 13rem;
	width: 30.35%;
	font-weight: 700;
	color: #fff;
	border: 0.1rem solid #fff;
	border-left-width: 0;
	border-right-width: 0;
	background-color: #2d4ba0;
}
#main .information  table td {
	margin-right: -1rem;
	border-bottom: 1px solid #707070;
}
#main .information  table td span {
	margin-right: -1rem;
	display: inline-block;
}
#main .information .textUl li {
	display: flex;
	flex-wrap: wrap;
}
#main .information .textUl .lText {
	width: 31.1rem;
}
#main .information .textUl .rText {
	flex: 1;
}
@media all and (max-width: 896px) {
	#main .information {
		padding-top: 12.8rem;
	}
	#main .information .headLine01 {
		margin-bottom: 6rem;
	}
	#main .information .headLine01 .en {
		line-height: 1.15;
	}
	#main .information  table th,
	#main .information  table td {
		padding: 0.9rem 1rem 0.5rem 2rem;
		font-size: 1.6rem;
		line-height: 1.5;
		height: 8.7rem;
	}
	#main .information  table th {
		padding: 0.5rem 0.5rem 0.5rem 1.4rem;
		width: 9.2rem;
	}
	#main .information  table td {
		margin-right: 0;
	}
	#main .information  table td span {
		margin-right: 0;
	}
	#main .information .textUl li {
		display: block;
	}
	#main .information .textUl .lText {
		width: auto;
		display: contents;
	}
	#main .information .textUl .rText {
		flex: none;
	}
}
/* qa */
#main .qa {
	padding: 9rem 0 17.5rem;
}
#main .qa .headLine01 {
	width: 19rem;
}
#main .qa .qaBox {
	width: calc(100% - 32rem);
}
#main .qa .qaBox dt {
	margin-bottom: 2rem;
	position: relative;
	font-size: 2rem;
	font-weight: 700;
	color: #2d4ba0;
}
#main .qa .qaBox dt::after {
	position: absolute;
	top: -0.5rem;
	left: -5.3rem;
	width: 4.2rem;
	height: 4.2rem;
	content: "";
	background: url(../img/common/q_img.png) no-repeat left top / 100%;
	z-index: 1;
}
#main .qa .qaBox dd {
	margin-bottom: 5.7rem;
	font-size: 2rem;
	line-height: 2.1;
}
#main .qa .qaBox dd:last-of-type {
	margin-bottom: 0;
}
@media all and (max-width: 896px) {
	#main .qa {
		padding: 13rem 0 13rem;
	}
	#main .qa .content {
		display: block;
	}
	#main .qa .headLine01 {
		margin-bottom: 4rem;
		width: auto;
	}
	#main .qa .qaBox {
		width: auto;
	}
	#main .qa .qaBox dt {
		padding-left: 5.5rem;
		margin-bottom: 1.5rem;
		font-size: 1.6rem;
		line-height: 2;
	}
	#main .qa .qaBox dt::after {
		top: -0.2rem;
		left: 0;
	}
	#main .qa .qaBox dd {
		margin: 0 0 4rem 5.5rem;
		font-size: 1.6rem;
		line-height: 1.75;
	}
}
/* entry */
#main .entry {
	padding-bottom: 16rem;
	position: relative;
}
#main .entry::after {
	position: absolute;
	top: -20rem;
	left: -17rem;
	width: 80.7rem;
	height: 80.7rem;
	content: "";
	z-index: -1;
	background: url(../img/common/img03.png) no-repeat left top / 100%;
}
#main .entry::before {
	position: absolute;
	top: -36.5rem;
	right: -23rem;
	width: 83.9rem;
	height: 83.9rem;
	content: "";
	z-index: -1;
	background: url(../img/common/img03.png) no-repeat left top / 100%;
}
#main .entry .bg {
	padding: 13.7rem 0 30.5rem;
	background-color: #f8f8f8;
}
#main .entry .bg .headLine01 {
	margin-bottom: 3.2rem;
}
#main .entry .bg .title {
	margin-bottom: 1.5rem;
	font-weight: 700;
	line-height: 2.1;
}
#main .entry .entryUl {
	margin: 0 -2rem 9.2rem 0;
	gap: 1rem 3.3rem;
}
#main .entry .entryUl li {
	padding: 1rem;
	position: relative;
	width: 21rem;
	height: 21rem;
	background: linear-gradient(135deg,#7ad1ec 10%, #2d4ba0 100%);
	border-radius: 0.8rem;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #fff;
	font-size: 3.2rem;
	font-weight: 700;
}
#main .entry .entryUl li:not(:last-child):after {
	position: absolute;
	top: 50%;
	left: 100%;
	content: "";
	z-index: 1;
	transform: translateY(-50%);
	width: 3.3rem;
	height: 5rem;
	background: url(../img/common/icon10.png) no-repeat left top / 100%;
}
#main .entry .entryBox {
	position: relative;
	padding: 8rem 12rem 9.8rem;
	background-color: #fff;
	border-radius: 2rem;
	overflow: hidden;
}
#main .entry .entryBox .textBox {
	width: calc(100% - 30rem);
}
#main .entry .entryBox .textBox .h_title {
	margin-bottom: 1.3rem;
	font-size: 2.8rem;
	color: #2d4ba0;
	font-weight: 700;
}
#main .entry .entryBox .textBox .text {
	font-weight: 700;
	line-height: 2.1;
}
#main .entry .entryBox .photoBox {
	width: 95.6rem;
	position: absolute;
	bottom: 0;
	right: 2rem;
	z-index: 1;
}
#main .entry .entryBox .photoBox img {
	width: 100%;
}
#main .formBox {
	margin-top: -23rem;
}
#main .formBox .headLine05 {
	margin-bottom: 5rem;
}
#main .formBox .tabPanel .tabUl {
	margin-bottom: 7.2rem;
	align-items: flex-end;
}
#main .formBox .tabPanel .tabUl li {
	position: relative;
	margin: 0.15rem;
	width: 36rem;
	min-height: 7.2rem;
}
#main .formBox .tabPanel .tabUl a {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1;
	min-height: 7.2rem;
	padding: 0.5rem;
	border-radius: 0.4rem 0.4rem 0 0;
	background-color: #e3e3e3;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #fff;
	font-size: 2rem;
	font-weight: 700;
	width: 100%;
}
#main .formBox .tabPanel .tabUl a .text span {
	font-size: 1.2rem;
	display: block;
}
#main .formBox .tabPanel .tabUl li.on a {
	min-height: 8.8rem;
	color: #fff;
	background-color: #2d4ba0;
}
#main .formBox .tabBox {
	display: none;
	padding: 0 12rem 0 10rem;
}
#main .formBox .tabBox.on {
	display: block;
}
#main .formBox .tabBox .title {
	margin-bottom: 1.5rem;
	font-size: 2rem;
	color: #2d4ba0;
	font-weight: 700;
}
#main .formBox .tabBox .text {
	margin-bottom: 8.8rem;
	font-size: 2rem;
	color: #5e5e5e;
	line-height: 1.6;
}
#main .formBox .tabBox01 .text {
	margin-bottom: 3.8rem;
}
#main .formBox table {
	margin-bottom: 3rem;
	width: 100%;
	border-collapse: collapse;
}
#main .formBox table th,
#main .formBox table td {
	width: 100%;
	display: block;
	font-size: 1.6rem;
	font-weight: 700;
	color: #5e5e5e;
	text-align: left;
	vertical-align: top;
	word-break: break-all;
}
#main .formBox table th {
	padding-bottom: 1.2rem;
}
#main .formBox table td  {
	padding-bottom: 1.8rem;
}
#main .formBox table input[type="text"],
#main .formBox table input[type="email"], 
#main .formBox table input[type="tel"],
#main .formBox table select, 
#main .formBox table textarea {
	padding: 1rem 1.9rem;
	width: 100%;
	display: block;
	height: 6.4rem;
	color: #5e5e5e;
	font-size: 2rem;
	font-weight: 400;
	border-radius: 0.4rem;
	border: 0;
	box-sizing: border-box;
	box-shadow: none;
	background-color: #f2f2f2;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
}
#main .mailForm input::placeholder,
#main .mailForm textarea::placeholder {
	color: #bababa;
	opacity: 1;
}
#main .mailForm .radioList {
	margin: 0.7rem 0 2.5rem;
}
#main .mailForm label {
	cursor: pointer;
}
#main .mailForm input[type="radio"] {
	display: none;
}
#main .mailForm input[type="radio"] + span {
	padding-left: 3rem;
	display: inline-block;
	font-size: 2rem;
	font-weight: 400;
	background: url(../img/common/radio_img01.png) no-repeat left center / 2.4rem;
}
#main .mailForm input[type="radio"]:checked + span {
	background-image: url(../img/common/radio_img02.png);
}
#main .mailForm table select {
	background: #f2f2f2 url(../img/common/icon08.png) no-repeat right 3.8rem center / 1.5rem;
}
#main .mailForm .agreeText {
	margin-bottom: 3.9rem;
	text-align: center;
}
#main .mailForm .agreeText a {
	text-decoration: underline;
}
#main .mailForm .agreeText a:hover {
	opacity: 0.7;
}
#main .mailForm input[type="checkbox"] {
	display: none;
}
#main .mailForm input[type="checkbox"] + span {
	padding-left: 3.3rem;
	display: inline-block;
	font-size: 2rem;
	font-weight: 400;
	background: url(../img/common/check_img01.png) no-repeat left center / 2.4rem;
}
#main .mailForm input[type="checkbox"]:checked + span {
	background-image: url(../img/common/check_img02.png);
}
#main .mailForm .submit li {
	margin: 0 1rem;
}
#main .mailForm table .info {
	color: #5e5e5e;
	font-weight: 400;
	font-size: 2rem;
}
#main .back a,
#main .mailForm .submit input {
    width: 32rem;
	min-height: 7.2rem;
    padding: 1.7rem 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
    text-align: center;
	justify-content: center;
	color: #fff;
    font-size: 2rem;
    font-weight: 700;
    background-color: #2d4ba0;
	border-radius: 0.5rem;
	box-shadow: none;
	box-sizing: border-box;
    border: 0.1rem solid #707070;
	cursor: pointer;
	appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
	transition: .3s;
}
#main .back a {
	margin: 0 auto;
}
#main .errorMsg {
	margin-bottom: 1rem;
	color: #ff0000;
}
#main .thanksBox {
	padding: 13rem 0;
}
#main .thanksBox .thanks {
	margin-bottom: 5rem;
}
#main .formBox .tabBox .telBox {
	margin-top: 5.5rem;
	width: 41.4rem;
}
#main .formBox .tabBox .telBox a {
	padding: 2.2rem 4.6rem 2.8rem;
	display: block;
	font-weight: 700;
	font-size: 2.8rem;
	color: #5e5e5e;
	border: 1px solid #2d4ba0;
}
#main .formBox .tabBox .telBox a span {
	font-size: 2rem;
}
#main .mailForm #confirmForm2 table .info {
	font-size: 1.6rem !important;
    font-weight: 700 !important;
}
@media all and (min-width: 897px) {
	#main .back a:hover,
	#main .mailForm .submit input:hover {
		opacity: 0.7;
	}
	#main .formBox .tabPanel .tabUl a:hover {
		color: #ffd800;
		background-color: #2d4ba0;
	}
	#main .thanksBox .thanks {
		text-align: center;
		line-height: 2;
	}
}
@media all and (max-width: 896px)  {
	#main .entry {
		padding-bottom: 16rem;
	}
	#main .entry::after {
		top: -8.5rem;
		left: -5rem;
		width: 22.5rem;
		height: 22.5rem;
	}
	#main .entry::before {
		top: -13rem;
		right: -8.3rem;
		width: 27rem;
		height: 27rem;
	}
	#main .entry .bg {
		padding: 12.7rem 0 30rem;
	}
	#main .entry .bg .headLine01 {
		margin-bottom: 3.9rem;
	}
	#main .entry .bg .title {
		margin-bottom: 5.5rem;
		line-height: 1.75;
	}
	#main .entry .entryUl {
		margin: 0 3.2rem 8.5rem;
		display: block;
	}
	#main .entry .entryUl li {
		margin-bottom: 3.9rem;
		padding: 1.9rem 1rem 1.5rem;
		width: auto;
		height: auto;
		font-size: 2rem;
		background: linear-gradient(to left,#7ad1ec 0%, #2d4ba0 100%);
	}
	#main .entry .entryUl li:last-child {
		margin-bottom: 0;
	}
	#main .entry .entryUl li:not(:last-child):after {
		top: 100%;
		left: 50%;
		transform: translateX(-50%);
		width: 5rem;
		height: 3.3rem;
		background-image: url(../img/common/icon10_sp.png);
	}
	#main .entry .entryBox {
		padding: 4.2rem 1.6rem 0;
	}
	#main .entry .entryBox .textBox {
		width: auto;
	}
	#main .entry .entryBox .textBox .h_title {
		margin-bottom: 1.7rem;
		font-size: 2.4rem;
		line-height: 1.33;
	}
	#main .entry .entryBox .textBox .text {
		line-height: 2;
	}
	#main .entry .entryBox .photoBox {
		margin-top: -2rem;
		width: 100%;
		position: static;
	}
	#main .formBox {
		margin: -20rem -1rem 0;
	}
	#main .formBox .tabPanel .tabUl {
		margin-bottom: 6rem;
		gap: 1px;
	}
	#main .formBox .tabPanel .tabUl li {
		margin: 0;
		min-height: 7.6rem !important;
		width: calc((100% - 0.3rem) / 3);
	}
	#main .formBox .tabPanel .tabUl a {
		min-height: 7.6rem !important;
		font-size: 1.6rem;
	}
	#main .formBox .tabPanel .tabUl a .text span {
		font-size: 1rem;
	}
	#main .formBox .tabBox {
		padding: 0 1rem;
	}
	#main .formBox .tabBox .title {
		margin-bottom: 1.5rem;
		font-size: 1.6rem;
	}
	#main .formBox .tabBox .text {
		margin-bottom: 3.8rem;
		font-size: 1.6rem;
		line-height: 1.75;
		font-weight: 700;
	}
	#main .formBox .tabBox02 .text {
		margin-bottom: 6.8rem;
	}
	#main .formBox table {
		margin-bottom: 8rem;
	}
	#main .formBox table th {
		padding-bottom: 1.2rem;
	}
	#main .formBox table td  {
		padding-bottom: 1.8rem;
	}
	#main .formBox table input[type="text"],
	#main .formBox table input[type="email"], 
	#main .formBox table input[type="tel"],
	#main .formBox table select, 
	#main .formBox table textarea {
		font-size: 1.8rem;
	}
	#main .formBox table select {
		background-position: right 1.5rem center;
	}
	#main .formBox .agreeText {
		margin: 0 1.5rem 4.1rem;
		text-align: left;
	}
	#main .mailForm input[type="checkbox"] + span {
		padding-left: 3.7rem;
		font-size: 1.6rem;
	}
	#main .mailForm .submit {
		margin: 0 auto;
		display: block;
		width: fit-content;
	}
	#main .mailForm .submit li {
		margin: 0 auto 1.5rem;
	}
	#main .mailForm .submit li:last-child {
		margin-bottom: 0;
	}
	#main .formBox .tabBox .telBox {
		margin-top: 4rem;
		width: auto;
	}
	#main .formBox .tabBox .telBox a {
		padding: 2.2rem 1rem 2.4rem;
		text-align: center;
	}
	#main .formBox .tabBox .telBox a span {
		display: inline-block;
		vertical-align: 0.2rem;
	}
}
/* popupBox */
.popupBox {
	padding: 20rem 0 16.3rem;
	position: relative;
	margin: 12.2rem auto;
	max-width: 120rem;
	box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
	background-color: #fff;
}
.popupBox .innerBox {
	padding: 0 2rem;
	margin: 0 auto 12rem;
	max-width: 92rem;
}
.popupBox .icon {
	position: fixed;
	z-index: 2;
	top: 16rem;
	right: calc(50% - 56rem);
	width: 8.2rem;
}
.popupBox .topBox {
	margin-bottom: 4rem;
	position: relative;
}
.popupBox .topBox .photo {
	position: relative;
}
.popupBox .topBox .photo::after {
	position: absolute;
	bottom: 0;
	right: 2rem;
	z-index: 1;
	width: 59.7rem;
	height: 17.8rem;
	content: "";
	background: url(../img/index/pop_img.png) no-repeat right bottom / 100%;
}
.popupBox .topBox .textBox {
	padding-right: 4.3rem;
	text-align: right;
	position: absolute;
	bottom: 1.4rem;
	left: 0;
	width: 100%;
	z-index: 2;
}
.popupBox .topBox .textBox .title {
	font-size: 2.8rem;
	font-weight: 700;
	color: #fff;
}
.popupBox .topBox .textBox .sub {
	padding-right: 1rem;
	color: #1b4387;
	font-weight: 700;
	font-size: 1.6rem;
}
.popupBox .topBox .textBox .sub span {
	margin-right: 1.8rem;
	display: inline-block;
	font-size: 2.4rem;
}
.popupBox .areaBox {
	margin-bottom: 11.3rem;
}
.popupBox .areaBox .lBox {
	text-align: center;
	color: #fff;
	font-size: 2.4rem;
	font-weight: 700;
	width: 16rem;
	min-height: 15rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #2d4ba0;
}
.popupBox .areaBox .rBox {
	padding: 0.8rem 0 1.6rem;
	flex: 1;
	margin-left: 4rem;
}
.popupBox .areaBox .rBox .dotUl {
	width: 50%;
}
.popupBox .areaBox .rBox .dotUl li {
	padding-left: 2.3rem;
	position: relative;
	line-height: 2.1;
}
.popupBox .areaBox .rBox .dotUl li::after {
	position: absolute;
	top: 1.4rem;
	left: 0;
	width: 1.5rem;
	height: 1.5rem;
	background-color: #2d4ba0;
	border-radius: 50%;
	content: "";
	z-index: 1;
}
.popupBox .info {
	margin-bottom: 5.3rem;
	line-height: 2.1;
}
.popupBox .innerBox .subBox {
	margin-bottom: 5.3rem;
}
.popupBox .innerBox > .photo {
	margin: 5.3rem 0 8rem;
}
.popupBox .innerBox > .photo img {
	width: 100%;
}
.popupBox .innerBox .h_title {
	margin: 7.2rem 0 3.3rem;
	font-weight: 700;
	font-size: 3.2rem;
	color: #2d4ba0;
	padding-left: 1em;
	text-indent: -1em;
}
.popupBox .text {
	line-height: 2.1;
}
.popupBox .text01 {
	margin-bottom: 4.3rem;
}
.popupBox .outBox {
	margin-top: 7.3rem;
}
.popupBox .outBox .lText {
	width: 18rem;
	color: #fff;
	font-weight: 700;
	font-size: 2.4rem;
	display: flex;
	align-items: center;
	text-align: center;
	justify-content: center;
	background-color: #2d4ba0;
}
.popupBox .outBox .rText {
	flex: 1;
	line-height: 2.1;
	padding: 4.1rem 6rem;
	background-color: rgba(45,75,160,0.1);
}
.popupBox .slide {
	overflow:hidden;
}
.popupBox .photoUl {
	display:flex;
}
.popupBox .photoUl li {
	width: 42rem;
}
body.popFix {
	overflow-y:auto;
}
.mfp-bg {
	background-color: #000 !important;
	opacity: 0.2 !important;
}
.mfp-wrap {
	overflow-y: auto;
}
.mfp-container {
	position: fixed;
	overflow: auto;
}
.popupBox .icon a {
	display: block;
}
.popupBox .icon a:hover {
	opacity: 0.7;
}
.popupBox01 .info {
	margin-bottom: 7.2rem;
}
@media all and (max-width: 896px) {
	.mfp-container {
		padding: 0 1.6rem;
	}
	.popupBox {
		padding: 0 0 11.7rem;
		margin: 2rem auto;
		max-width: 100%;
	}
	.popupBox .innerBox {
		padding: 0;
		margin-bottom: 4rem;
		max-width: 100%;
	}
	.popupBox .icon {
		top: 3.2rem;
        right: 2.4rem;
        width: 5.2rem;
	}
	.popupBox .topBox {
		margin-bottom: 2.6rem;
	}
	.popupBox .topBox .photo {
		margin-bottom: 4.3rem;
		aspect-ratio: 343/480;
	}
	.popupBox .topBox .photo img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.popupBox .topBox .photo::after {
		right: 1.5rem;
		width: 66%;
		height: 25rem;
	}
	.popupBox .topBox .textBox {
		margin: 0 2rem 2.5rem;
		padding: 0;
		text-align: center;
		width: auto;
		position: static;
	}
	.popupBox .topBox .textBox .title {
		margin-bottom: 1.3rem;
		padding-bottom: 4.3rem;
		font-size: 2rem;
		color: #1dc8fd;
		line-height: 1.6;
		border-bottom: 1px dashed #2d4ba0;
	}
	.popupBox .topBox .textBox .sub {
		padding-right: 0;
	}
	.popupBox .topBox .textBox .sub span {
		margin-right: 1.8rem;
		font-size: 2.8rem;
		letter-spacing: 0.04em;
	}
	.popupBox .areaBox {
		margin-bottom: 7.2rem;
		display: block;
	}
	.popupBox .areaBox .lBox {
		margin-bottom: 3.5rem;
		font-size: 1.8rem;
		width: auto;
		min-height: 7.2rem;
	}
	.popupBox .areaBox .rBox {
		display: block;
		padding: 0 1.6rem;
		margin-left: 0;
	}
	.popupBox .areaBox .rBox .dotUl {
		width: auto;
	}
	.popupBox .areaBox .rBox .dotUl li {
		padding-left: 2.3rem;
		line-height: 2;
	}
	.popupBox .areaBox .rBox .dotUl li::after {
		top: 0.9rem;
	}
	.popupBox .info {
		margin: 0 1.6rem 5.6rem;
		line-height: 2;
	}
	.popupBox .innerBox .subBox {
		margin: 0 1.6rem 8rem;
	}
	.popupBox .innerBox > .photo {
		margin: 7.5rem 0;
		aspect-ratio: 343/230;
	}
	.popupBox .innerBox > .photo01 {
		aspect-ratio: 343/210;
	}
	.popupBox .innerBox > .photo img {
		height: 100%;
		object-fit: cover;
	}
	.popupBox .innerBox .h_title {
		margin: 8rem 0 3.5rem;
		font-size: 2rem;
	}
	.popupBox .text {
		line-height: 2;
	}
	.popupBox .text01 {
		margin-bottom: 3rem;
	}
	.popupBox .outBox {
		margin: -1.5rem 1.6rem 0;
		display: block;
	}
	.popupBox .outBox .lText {
		width: auto;
		font-size: 2rem;
		min-height: 6.4rem;
	}
	.popupBox .outBox .rText {
		line-height: 2;
		padding: 2.7rem 2.2rem;
	}
	.popupBox .photoUl li {
		width: 22.5rem;
	}
	.popupBox01 .info {
		margin-bottom: 8rem;
	}
	.popupBox .slide {
		margin: 0 1.6rem;
	}
	.popupBox .pageTop {
		margin: 2.7rem auto 0;
		width: 7.8rem;
	}
}
.hover > path {
	transition: .3s;
	cursor: pointer;
}
.hover:hover > path {
	fill: #FFD800;
}
.hover1:hover > rect {
	fill: url("#pattern-12");
}
.hover .text {
	opacity: 0;
	transition: .3s;
	pointer-events: none;
}
.hover:hover .text {
	opacity: 1;
}
.hover2:hover .arrow {
	fill: url("#pattern");
}
.hideBox {
	display: none;
}