@charset "UTF-8";

.main-slide {
   width: calc(100vw - 40px);
   height: calc(100vh - 150px);
   margin: 110px auto 0;
   border-radius: 5px;
   position: relative;
   overflow: hidden;
   z-index: 1;
}
.main-slide .slide-cc {
   position: absolute;
   bottom: 12%;
   left: 7%;
   z-index: 2;
}
.main-slide .slide-cc p {
   color: #FFF;
   font-size: min(9vw,9vh,90px);
   font-weight: 300;
   line-height: 1.2em;
   text-shadow: 0px 0px 20px rgba(28, 28, 28, 0.3);
}
.main-slide .slide-cc p span {
   font-weight: 500;
}
.swiper-container {
   width: 100%;
   height: 100%;
   position: relative;
}
.swiper-wrapper {
   width: 100%;
   height: 100%;
   position: relative;
}
.swiper-slide {
	width: 100vw;
	height: 100vh;
	position: relative;
}
.slide01 {
	background: url("../img/slide01.jpg") no-repeat 40% 10%;
	background-size: cover;
}
.slide02 {
	background: url("../img/slide02.jpg") no-repeat 50% 40%;
	background-size: cover;
}
.slide03 {
	background: url("../img/slide03.jpg") no-repeat 65% 25%;
	background-size: cover;
}


.np01 {
   font-size: 14px;
   font-weight: 300;
}
.career-top .np01 {
   line-height: 2em;
}
.career .content-box-normal {
   width: 90%;
   margin: 0 auto;
   max-width: 950px;
}
.career .content-box-full {
   width: 100%;
   margin: 0 auto;
}
.career-top h2 {
   font-size: 60px;
   font-weight: 100;
   color: #06456F;
   line-height: 1.4em;
   margin-bottom: 40px;
}
.career-top h2 span {
   display: block;
   color: #1C1C1C;
   font-size: 16px;
   font-weight: 500;
   line-height: 1em;
}
/* エントランス画像入り about us用 */
.top-block01 {
   width: 100%;
   padding: 120px 0 60px;
}
.top-block01 > div {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   position: relative;
}
.top-block01 .img-box {
   width: 50%;
}
.top-block01 .txt-wrap {
   width: 50%;
   box-sizing: border-box;
   padding: 0 6% 0 6%;
   position: relative;
   
}
.top-block01 .txt-wrap .txt-box {
   position: relative;
   top: 50%;
   transform: translateY(-50%);
   width: 100%;
   max-width: 500px;
}
/* エントランス画像入り about us用 end*/

/* エントランス画像なし about us用*/
.top-block01n {
   padding: 120px 0;
}
.top-block01n h2 {
   text-align: center;
}
.top-block01n ul {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.top-block01n ul li {
   width: 50%;
   position: relative;
   left: 25%;
}
.top-block01n ul li .scale-bg {
   position: relative;
   margin-bottom: 10px;
}
.top-block01n ul li .scale-bg p {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   text-align: center;
   z-index: 2;
   color: #FFF;
   font-weight: 100;
   font-size: 30px;
   line-height: 1.2em;
}
.top-block01n ul li .scale-bg p span {
   font-weight: 400;
   font-size: 18px;
   display: block;
}
/* エントランス画像なし about us用 end*/


.top-block02 {
   padding: 100px 0;
}
.top-block02 h2 {
   text-align: center;
}
.data-box {
   background: #F5F5F5;
   width: calc(100% - 40px);
   margin: 0 auto;
   padding: 80px 0;
   border-radius: 5px;
}
.data-box > ul {
   width: 90%;
   margin: 0 auto;
   max-width: 950px;
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   position: relative;
   z-index: 2;
}
.data-box > ul li {
   background: #FFF;
   position: relative;
   box-sizing: border-box;
   padding: 30px;
   margin-bottom: 4%;
}
.data-box > ul li:before {
   width: 100%;
   height: 100%;
   top: 10px;
   left: 10px;
   background: #EBEBEB;
   z-index: -1;
}

.data-box > ul li:nth-child(-n + 2) {
   width: 48%;
}   
.data-box > ul li:nth-child(3) {
   width: 100%;
   box-sizing: border-box;
}
.data-box > ul li:nth-child(n + 4) {
   width: 31.33%;
}
.data-box > ul .ttl {
   font-size: 17px;
   font-weight: 600;
   color: #06456F;
   white-space: nowrap;
   margin-bottom: 20px;
}
.data-box > ul li:nth-child(-n + 2) .figure {
   width: 80%;
   margin: 0 auto 30px;
}
.data-box > ul li:nth-child(n + 4) .figure {
   width: 100%;
   margin: 0 auto 30px;
}
.data-box > ul li:nth-child(3) .flex-wrap {
   width: 100%;
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.data-box > ul li:nth-child(3) .figure {
   order: 4;
   width: 30%;
}
.data-box > ul li:nth-child(3) .txt-wrap {
   width: 65%;
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.data-box > ul li:nth-child(3) .txt-wrap .txt-box {
   width: 30%;
   box-sizing: border-box;
   padding: 30px 0 0;
   order: -1;
}
.data-box > ul li:nth-child(3) .txt-wrap .txt-box2 {
   width: 30%;
   box-sizing: border-box;
   padding: 30px 0 0;
   order: 2;
}
.data-box > ul li:nth-child(3) .txt-wrap .txt-box3 {
   width: 30%;
   box-sizing: border-box;
   padding: 30px 0 0;
   order: 3;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-figure {
   width: 50%;
   padding: 20px 0 0;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box {
   width: 50%;
   padding: 20px 0 0;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box ul li {
   width: 100%;
   position: relative;
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   background: #F5F5F5;
   border-radius: 5px;
   box-sizing: border-box;
   padding: 5px 15px;
   margin-bottom: 10px;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box ul li .p01 {
   width: 70%;
   font-size: 15px;
   font-weight: 500;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box ul li .p02 {
   width: 30%;
   white-space: nowrap;
   color: #06456F;
   font-weight: 500;
   text-align: right;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box ul li .p02 span {
   font-family: 'Poppins', sans-serif;
   font-size: 26px;
   font-weight: 500;
}

/*  20221005 沢辺追加    */
.data-box > ul li:nth-child(3) .sub-data-box ul li .p03 {
   width: 100%;
   margin: 2% 0;
   font-size: 15px;
   font-weight: 500;
   text-align: center;
}
.data-box > ul li:nth-child(3) .sub-data-box ul li .p04 {
   font-family: 'Poppins', sans-serif;
   font-size: 26px;
   font-weight: 500;
   color: #06456F;
}
/*  20221005 沢辺追加    */

.data-box > ul li .number {
   font-size: 18px;
   font-weight: 600;
   color: #06456F;
   text-align: center;
}
.data-box > ul li .number span {
   font-family: 'Poppins', sans-serif;
   font-size: 60px;
   font-weight: 400;
   padding: 0 .04em;
}
.data-box > ul li .note {
   font-size: 13px;
   font-weight: 400;
   color: #06456F;
   text-align: center;
   line-height: 1.2em;
}

.data-box > ul li .number2 {
   font-size: 18px;
   font-weight: 600;
   color: #06456F;
   text-align: center;
}
.data-box > ul li .number2 span {
   font-family: 'Poppins', sans-serif;
   font-size: 60px;
   font-weight: 400;
   padding: 1em .04em;
}
.data-box > ul li .note2 {
   margin-top: -42px;
   margin-bottom: 20px;
   font-size: 12.5px;
   height: 35px;
   font-weight: 400;
   color: #06456F;
   text-align: center;
   line-height: 1.2em;
}


.top-block03 {
   padding: 60px 0;
}
.top-block03 h2 {
   text-align: center;
}
.top-block03 ul {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.top-block03 ul li {
   width: 48%;
   margin-bottom: 4%;
   position: relative;
}
.top-block03 ul li .scale-bg {
   position: relative;
   margin-bottom: 10px;
}
.top-block03 ul li .scale-bg p {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   text-align: center;
   z-index: 2;
   color: #FFF;
   font-weight: 100;
   font-size: 30px;
   line-height: 1.2em;
}
.top-block03 ul li .scale-bg p span {
   font-weight: 400;
   font-size: 18px;
   display: block;
}



.top-block04 {
   padding: 60px 0;
   position: relative;
}
.top-block04:before {
   background: #F5F5F5;
   width: calc(100% - 40px);
   border-radius: 5px;
   height: 60%;
   top: 40%;
   left: 20px;
}
.top-block04 h2 {
   text-align: center;
}
.top-block04 ul {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   margin-bottom: 30px;
}
.top-block04 ul li {
   width: 31.33%;
   margin-bottom: 4%;
   position: relative;
}
.top-block04 ul li:after {
   width: 100%;
   height: 40%;
   background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0,0,0,0.80) 100%);
   left: 0;
   bottom: 0;
   z-index: 0;
   border-radius: 0 5px 5px 0;
}
.top-block04 ul li .scale-bg p {
   position: absolute;
   bottom: 20px;
   left: 20px;
   z-index: 2;
   color: #FFF;
   font-weight: 100;
   font-size: 14px;
   line-height: 1.6em;
}
.top-block04 ul li .scale-bg p span {
   font-size: 24px;
   padding-right: 10px;
}



.top-block05 {
   width: 100%;
   padding: 80px 0 80px;
}
.top-block05 > div {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.top-block05 .img-box {
   width: 50%;
   order: 2;
}
.top-block05 .txt-wrap {
   order: 1;
   width: 50%;
   box-sizing: border-box;
   padding: 0 6% 0 3%;
   position: relative;
}
.top-block05 .txt-wrap .txt-box {
   position: relative;
   top: 50%;
   transform: translateY(-50%);
}
.top-block05 .button01 {
   margin: 40px 0 0 0;
   left: 0;
   transform: translateX(0);
}



.top-block06 {
   padding: 60px 0;
}
.top-block06 h2 {
   text-align: center;
}
.top-block06 ul {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.top-block06 ul li {
   width: 48%;
   margin-bottom: 4%;
   position: relative;
   left: 26%;
}
.top-block06 ul li .scale-bg {
   position: relative;
   margin-bottom: 10px;
}
.top-block06 ul li .scale-bg p {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   text-align: center;
   z-index: 2;
   color: #FFF;
   font-weight: 100;
   font-size: 30px;
   line-height: 1.2em;
}
.top-block06 ul li .scale-bg p span {
   font-weight: 400;
   font-size: 18px;
   display: block;
}




@media all and (max-width: 1023px) {
.main-slide {
   width: calc(100vw - 20px);
   height: calc(100vh - 140px);
   margin: 55px auto 0;
   border-radius: 5px;
   position: relative;
   overflow: hidden;
}
.main-slide .slide-cc {
   position: absolute;
   bottom: 7%;
   left: 7%;
   z-index: 2;
}


.np01 {
   font-size: 13px;
   font-weight: 300;
}
.career .content-box-normal {
   width: 90%;
   margin: 0 auto;
   max-width: 950px;
}
.career .content-box-full {
   width: 100%;
   margin: 0 auto;
}
.career-top h2 {
   text-align: center;
   font-size: min(8vw,40px);
   font-weight: 100;
   color: #06456F;
   line-height: 1.4em;
   margin-bottom: 20px;
}
.career-top h2 span {
   display: block;
   color: #1C1C1C;
   font-size: 16px;
   font-weight: 500;
   line-height: 1em;
}
.top-block01 {
   width: 100%;
   padding: 60px 0 30px;
}
.top-block01 > div {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.top-block01 .img-box {
   width: 90%;
   margin: 30px auto 0;
   order: 2;
}
.top-block01 .img-box img {
   border-radius: 5px;
}
.top-block01 .txt-wrap {
   width: 100%;
   box-sizing: border-box;
   padding: 0 5% 0 5%;
   position: relative;
   order: 1;
}
.top-block01 .txt-wrap .txt-box {
   position: relative;
   top: auto;
   transform: translateY(0);
   width: 100%;
   max-width: 100%;
}

.top-block02 {
   padding: 80px 0;
}
.top-block02 h2 {
   text-align: center;
}
.data-box {
   background: #F5F5F5;
   width: calc(100%);
   margin: 0 auto;
   padding: 20px 0;
   border-radius: 5px;
}
.data-box > ul {
   width: 80%;
   margin: 0 auto;
   max-width: 950px;
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   position: relative;
   z-index: 2;
}
.data-box > ul li {
   background: #FFF;
   position: relative;
   box-sizing: border-box;
   padding: 30px;
   margin-bottom: 4%;
}
.data-box > ul li:before {
   width: 100%;
   height: 100%;
   top: 10px;
   left: 10px;
   background: #EBEBEB;
   z-index: -1;
}

.data-box > ul li:nth-child(-n + 2) {
   width: 100%;
}   
.data-box > ul li:nth-child(3) {
   width: 100%;
   box-sizing: border-box;
}
.data-box > ul li:nth-child(n + 4) {
   width: 100%;
}
.data-box > ul .ttl {
   font-size: 15px;
   font-weight: 600;
   color: #06456F;
   white-space: nowrap;
   margin-bottom: 10px;
   text-align: center;
}
.data-box > ul li:nth-child(-n + 2) .figure {
   width: 80%;
   margin: 0 auto 30px;
}
.data-box > ul li:nth-child(n + 4) .figure {
   width: 80%;
   margin: 0 auto 30px;
}
.data-box > ul li:nth-child(3) .flex-wrap {
   width: 100%;
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.data-box > ul li:nth-child(3) .figure {
   order: 2;
   width: 100%;
}
.data-box > ul li:nth-child(3) .txt-wrap {
   width: 100%;
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.data-box > ul li:nth-child(3) .txt-wrap .txt-box {
   width: 100%;
   box-sizing: border-box;
   padding: 10px 0 0;
}

.data-box > ul li:nth-child(3) .txt-wrap .txt-box2 {
   width: 100%;
   box-sizing: border-box;
   padding: 30px 0 0;
   order: 2;
}
.data-box > ul li:nth-child(3) .txt-wrap .txt-box3 {
   width: 100%;
   box-sizing: border-box;
   padding: 30px 0 0;
   order: 3;
}


.data-box > ul li:nth-child(3) .txt-wrap .sub-figure {
   width: 100%;
   padding: 20px 0 20px;
   max-width: 400px;
   margin: 0 auto;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box {
   width: 80%;
   padding: 20px 0 0;
   margin-left: 10%;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box ul li {
   width: 100%;
   position: relative;
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   background: #F5F5F5;
   border-radius: 5px;
   box-sizing: border-box;
   padding: 5px 15px;
   margin-bottom: 10px;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box ul li .p01 {
   width: 70%;
   font-size: 13px;
   font-weight: 500;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box ul li .p02 {
   width: 30%;
   white-space: nowrap;
   color: #06456F;
   font-weight: 500;
   text-align: right;
}
.data-box > ul li:nth-child(3) .txt-wrap .sub-data-box ul li .p02 span {
   font-family: 'Poppins', sans-serif;
   font-size: 20px;
   font-weight: 500;
}

/*  20221005 沢辺追加    */
.data-box > ul li:nth-child(3) .sub-data-box ul li .p03 {
   width: 100%;
   padding: 0 5%;
   font-size: clamp(3px, 3vw, 20px);
   font-weight: 500;
   text-align: center;
}
.data-box > ul li:nth-child(3) .sub-data-box ul li .p04 {
   font-family: 'Poppins', sans-serif;
   font-size: clamp(6px, 5vw, 30px);;
   font-weight: 500;
   color: #06456F;
}
/*  20221005 沢辺追加    */

.data-box > ul li .number {
   font-size: 14px;
   font-weight: 600;
   color: #06456F;
   text-align: center;
}
.data-box > ul li .number span {
   font-family: 'Poppins', sans-serif;
   font-size: 36px;
   font-weight: 400;
   padding: 0 .04em;
}
.data-box > ul li .note {
   margin-bottom: 5px;
   font-size: 11px;
   font-weight: 400;
   color: #06456F;
   text-align: center;
}

.data-box > ul li .number2 {
   font-size: 14px;
   font-weight: 600;
   color: #06456F;
   text-align: center;
}
.data-box > ul li .number2 span {
   font-family: 'Poppins', sans-serif;
   font-size: 36px;
   font-weight: 400;
   padding: 1em .04em;
}
.data-box > ul li .note2 {
   margin-top: 5px;
   margin-bottom: 5px;
   font-size: 12.5px;
   font-weight: 400;
   color: #06456F;
   text-align: center;
   line-height: 1.2em;
}

.top-block03 {
   padding: 60px 0;
}
.top-block03 h2 {
   text-align: center;
}
.top-block03 ul {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.top-block03 ul li {
   width: 100%;
   margin-bottom: 30px;
   position: relative;
}
.top-block03 ul li .scale-bg {
   position: relative;
   margin-bottom: 10px;
}
.top-block03 ul li .scale-bg p {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   text-align: center;
   z-index: 2;
   color: #FFF;
   font-weight: 100;
   font-size: 20px;
   line-height: 1.2em;
}
.top-block03 ul li .scale-bg p span {
   font-weight: 300;
   font-size: 14px;
   display: block;
}



.top-block04 {
   padding: 60px 0;
   position: relative;
}
.top-block04:before {
   background: #F5F5F5;
   width: calc(100% - 40px);
   border-radius: 5px;
   height: 60%;
   top: 40%;
   left: 20px;
}
.top-block04 h2 {
   text-align: center;
}
.top-block04 ul {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   width: 90%;
   margin: 0 auto;
}
.top-block04 ul li {
   width: 100%;
   margin-bottom: 30px;
   position: relative;
   border-radius: 5px;
   overflow: hidden;
}
.top-block04 ul li:after {
   width: 100%;
   height: 40%;
   background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0,0,0,0.80) 100%);
   left: 0;
   bottom: 0;
   z-index: 0;
   border-radius: 0 5px 5px 0;
}
.top-block04 ul li .scale-bg p {
   position: absolute;
   bottom: 20px;
   left: 20px;
   z-index: 2;
   color: #FFF;
   font-weight: 100;
   font-size: 14px;
   line-height: 1.6em;
}
.top-block04 ul li .scale-bg p span {
   font-size: 24px;
   padding-right: 10px;
}



.top-block05 {
   width: 100%;
   padding: 80px 0 80px;
}
.top-block05 > div {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.top-block05 .img-box {
   width: 100%;
   order: 2;
}
.top-block05 .img-box img {
   height: 200px;
   object-fit: cover;
   border-radius: 5px;
}
.top-block05 .txt-wrap {
   order: 1;
   width: 100%;
   box-sizing: border-box;
   padding: 0 6% 0 3%;
   position: relative;
}
.top-block05 .txt-wrap .txt-box {
   position: relative;
   top: 50%;
   transform: translateY(-50%);
}
.top-block05 .button01 {
   margin: 30px auto 60px;
   left: 50%;
   transform: translateX(-50%);
}


.top-block06 {
   padding: 60px 0;
}
.top-block06 h2 {
   text-align: center;
}
.top-block06 ul {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
}
.top-block06 ul li {
   width: 100%;
   margin-bottom: 30px;
   position: relative;
   left: 0%;
}
.top-block06 ul li .scale-bg {
   position: relative;
   margin-bottom: 10px;
}
.top-block06 ul li .scale-bg p {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   text-align: center;
   z-index: 2;
   color: #FFF;
   font-weight: 100;
   font-size: 20px;
   line-height: 1.2em;
}
.top-block06 ul li .scale-bg p span {
   font-weight: 300;
   font-size: 14px;
   display: block;
}



/*  20221005 沢辺追加    */
.txt_b {
   color: #06456F;
}
/*  20221005 沢辺追加    */
