@charset "utf-8";
/* CSS Document */
html {
	scroll-snap-type: y proximity;
	scroll-padding-top: 100px;
	scroll-behavior: smooth;
}
.text_wrap{
	display: inline-block;
}
.under_visual {
	background: #def0ff;
	background-size: cover;
}
.visual_inner {
	max-width: 1240px;
	margin: auto;
	position: relative;
}

.under_visual h1{
	color: #28288e;
	filter: none;
	font-size: 280%;
}
.under_visual .btn_list{
	max-width: 160px;
	position: absolute;
	right:0;
	top: 40px;
}
.under_visual .btn_list li{
	margin-bottom: 10px;
}
.under_visual .btn_list li:last-child{
	margin-bottom: 0px;
}

/* ---上部消さない（採用ページ共通パーツ）---
========================== */
.tub_list li#tub4{
	background-color: #fff;
}

/* main_visual
========================== */
.block_area{
	background: url("../../../common/img/gn_bg.png") repeat-x top;
	padding: 80px 0 50px;
}
/* box_visual
========================== */
.box_visual{
	background: url(../img/main_bg01.png) no-repeat;
	background-size: cover;
	padding: 120px 0;
}




/* box_wrap
========================== */
.box_wrap{
	max-width: 1133px;
	margin: auto;
	padding: 40px 0 120px;
}
.intro_box .int_text {
	margin-top: 40px;
	font-size: 26px;
	font-weight: bold;
	text-align: center;
}
.intro_box .int_img {
	margin-top: 40px;
	text-align: center;
}
.exa_box {
	margin-top: 40px;
}
.exa_box.flex {
	display: flex;
	align-items: flex-end;
	gap: 17px;
}
.exa_title {
	color: #BB1E36;
	font-size: 24px;
	font-weight: bold;
}
.exa_text {
	margin-bottom: 20px;
}
.exa_imgbox {
	display: flex;
	gap: 17px;
}

/* モーダル */
.modal {
	display: none;
	position: fixed;
	z-index: 105;
	right: 0;
	top: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	background-color: rgba(0, 0, 0, 0.7);
	transition: all 1s ease-in-out;
  }
  .modal-content {
	background: #FFF;
	padding: 48px 95px 65px;
	box-sizing: border-box;
	max-width: 1124px;
	width: 90%;
	position: relative;
	top: 100px;
	left: 50%;
	z-index: 999;
	transform: translateX(-50%);
	animation: show 0.6s linear 0s;
	filter: drop-shadow(0px 2px 6px #777);
  }
  /* .modal-top {
	display: flex;
	width: 30px;
	height: 30px;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	border: 1px solid #000;
	position: fixed;
	right: 5px;
	top: 5px;
  } */
  /* .modal-close {
	color: #000;
	text-decoration: none;
	font-size: 2rem;
	line-height: 1;
	padding: 0 8px;
  } */
  .modal-close:hover, .modal-close:focus {
	text-decoration: none;
	cursor: pointer;
  }
  .mc_title {
	text-align: center;
	margin-bottom: 24px;
	font-size: 30px;
	letter-spacing: 0px;
  }
  .modal-container {
	text-align: center;
  }
	.pop_img_outer {
		position: relative;
	}
	.pop_img_outer a:hover img {
		opacity: 1;
	}
.pop_miniimg01 , .pop_miniimg02 , .pop_miniimg03 , .pop_miniimg04 , .pop_miniimg05 , .pop_miniimg06 {
	height: auto;
	position: absolute;
	display: flex;
	justify-content: flex-start;
}
.pop_miniimg01 {
	top: 17%;
	left: 2%;
}
.pop_miniimg02 {
	top: 15%;
	left: 29%;
}
.pop_miniimg03 {
	top: 13%;
	left: 56%;
}
.pop_miniimg04 {
	top: 50%;
	left: 2%;
}
.pop_miniimg05 {
	top: 52%;
	left: 29%;
}
.pop_miniimg06 {
	top: 54%;
	left: 56%;
}

/* 固有のスマホ対応記述
========================== */
/* 700pxより小さい場合 */
@media screen and ( max-width: 700px ){
.under_visual h1 {
	padding: 80px 0;
	}
.box.bottom{
	margin-bottom: 40px;
}
.box_visual {
	background-position: 80% !important;
    padding: 90px 0;
}

.visual_inner,.box{
	width: 90%;
	padding: 0 5%;
	display: block;
	}
.visual_inner{
    padding-bottom: 90px;
	}
.under_visual .btn_list li {
	width:100%;
	float: right;
	clear: both;
	text-align: right;
	}
.under_visual .btn_list{
	top: 140px;
	right: 15px;
	}
.under_visual .btn_list li img{
	width:80%;
	text-align: right;
	}
.box_visual .sub{
	min-width: auto;
	}

	
	
/* ---上部消さない（採用ページ第四階層共通パーツ）---
========================== */
.box_wrap {
	padding: 30px 5%;
}
.intro_box .int_text {
	font-size: 20px;
}
.int_img {
	margin-top: 20px;
}
.exa_title {
	font-size: 20px;
}
.exa_text {
	margin-bottom: 10px;
}
.exa_imgbox {
	margin-top: 10px;
	gap: 10px;
}

/* モーダル */
  .modal-content {
	padding: 30px 5%;
  }
  .mc_title {
	margin-bottom: 10px;
	font-size: 16px;
  }
.pop_miniimg01 , .pop_miniimg02 , .pop_miniimg03 , .pop_miniimg04 , .pop_miniimg05 , .pop_miniimg06 {
width: 20vw;
}
}
/* 375pxより小さい場合 */
@media screen and ( max-width: 375px ){

}
@media print {
.section_box {
	margin-bottom: 100px;
	}
.section_box.re .text_area {
	padding: 35px 35px 35px 35px;
	margin-left:0px;
	width: 100%;
	box-sizing: border-box;
	}
.section_box .text_area {
	width: 100%;
	padding: 35px 35px 35px 35px;
	box-sizing: border-box;
	}
.section_img{
	position: static;
	}
}