@charset "UTF-8";
/* CSS Document */
/*--------------------
01.共通
02.ヘッダー
03.
04.
--------------------*/

/*----------
01.共通
----------*/

@font-face {
font-family: 'A-OTF-UDShinMGoPro-Bold';
src:url('../font/A-OTF-UDShinMGoPro-Bold.woff2') format('woff2'),
url('../font/A-OTF-UDShinMGoPro-Bold.woff') format('woff'),
url('../font/A-OTF-UDShinMGoPro-Bold.otf')  format('opentype'); /* ttf - Safari, Android, iOS */
font-weight: normal;
font-style: normal;
}


body{
-webkit-font-smoothing: antialiased;
}

*{
box-sizing: border-box;
}

*:focus {
outline: none;
}

#wrapper{
width: 100%;
overflow: hidden;
font-family: 'Noto Sans JP', sans-serif;
font-size: 16px;
color: #333333;
}

.pc{
display: block;
}

.sp{
display: none;
}

.contents_in{
max-width: 1080px;
width: 96%;
margin: 0 auto;
}

a{
color: #333;
}

a:hover{
color:#333;
}

a:link{
color:#333;
}

img{
width: 100%;
height: auto;
display: block;
}

.title_ptn01 {
font-size: 28px;
line-height: 40px;
font-weight: 700;
position: relative;
text-align: center;
padding-bottom: 15px;
margin-bottom: 40px;
}

.title_ptn01::after {
position: absolute;
content: "";
background: #707070;
width: 40px;
height: 3px;
bottom: 0;
left: 50%;
transform: translateX(-50%);
}

.title_ptn02 {
font-size: 18px;
line-height: 26px;
font-weight: 700;
text-align: center;
border-bottom: solid #707070 1px;
width: fit-content;
margin: 0 auto 20px;
}


.title_ptn03 {
position: relative;
font-size: 32px;
line-height: 46px;
font-weight: 700;
text-align: center;
display: block;
text-transform: uppercase;
}

.title_ptn03 .min { 
font-size: 16px;
line-height: 24px;
font-weight: 500;
text-align: center;
display: block;
margin-top: 10px;
}

.title_ptn04 {
text-align: center;
font-size: 32px;
line-height: 46px;
font-weight: 700;
display: block;
margin-bottom: 35px;
}

.title_ptn04 .min {
font-size: 14px;
line-height: 20px;
font-weight: 500;
display: block;
margin-top: 10px;
}

.btn_ptn01 {
max-width: 300px;
margin: 0 auto;
}

.btn_ptn01 a{
display: block;
border: solid #707070 1px;
background: #FFFFFF;
font-size: 16px;
line-height: 20px;
font-weight: 500;
text-align: center;
padding: 18px 0;
transition: 0.2s;
}

.btn_ptn01 a:hover {
font-size: 18px;
}

.under_mv_area {
background: url("../../img/business/bridge/mv_bg.png")no-repeat center/cover;
height: 500px;
padding-top: 200px;
position: relative;
}

.under_mv_area::before {
position: absolute;
content: "";
background: rgba(66,133,162,0.5);
width: 100%;
height: 100%;
top: 0;
left: 0;
}

.under_mv_area .title_ptn03 {
color: #FFFFFF;
}

.first_area {
background: #FFFFFF;
border-radius: 40px;
max-width: 1080px;
margin: -100px auto 0;
position: relative;
padding:  40px 0 80px;
}

.first_area .icon {
position: absolute;
top: -116px;
right: 50px;
max-width: 134px;
}

.first_area .top_text {
font-size: 14px;
line-height: 24px;
text-align: center;
}

#recruit_area  {
/*position: relative;
padding-top: 176px;*/
}

#recruit_area .img_wrap {
position: relative;
/*position: absolute;
top: 0;
left: 0;*/
}

#recruit_area .img_wrap .train {
position: absolute;
top: 0;
right: -41.4%;
/*max-width: 526px;*/
width: 41.1%;
transition: right 4s linear;
}

#recruit_area .img_wrap .train.active {
right: 100%;
}

#recruit_area .img_wrap .bridge01 {
position: relative;
z-index: 1;
}

#recruit_area .cnt_wrap {
background: url("../img/recruit_bg.png")no-repeat center/cover;
padding: 55px 0 73px;
/*margin-top: -150px;*/
margin-top: -11.7%;
}

#recruit_area .cnt_wrap .title_ptn04 {
color: #FFFFFF;
}

#recruit_area .cnt_wrap .text {
font-size: 14px;
line-height: 21px;
color: #FFFFFF;
text-align: center;
margin-bottom: 40px;
}

.wp-pagenavi {
display: flex;
align-items: center;
justify-content: center;
}

.wp-pagenavi .page {
font-size: 20px;
line-height: 1;
font-weight: 500;
min-width: 40px;
height: 40px;
text-align: center;
color: #000000;
background: 0;
border: solid #000000 1px;
display: block;
padding-top: 8px;
margin: 0 10px;
}

.wp-pagenavi .page:hover {
background: #000000;
color: #FFFFFF;
}

.wp-pagenavi .current {
font-size: 20px;
line-height: 1;
font-weight: 500;
min-width: 40px;
height: 40px;
text-align: center;
color: #FFFFFF;
background: 0;
background: #000000;
display: block;
padding-top: 8px;
margin: 0 10px;
}

.wp-pagenavi .previouspostslink {
position: relative;
width: 14px;
height: 12px;
margin: 0 10px;
border: none;
}

.wp-pagenavi .previouspostslink::before {
position: absolute;
content: "";
background: url("../img/icon_arrow_prev.png")no-repeat center/contain;
width: 14px;
height: 12px;
top: 50%;
left: 50%;
transform: translateY(-50%)translateX(-50%);
}

.wp-pagenavi .nextpostslink {
position: relative;
width: 14px;
height: 12px;
margin: 0 10px;
border: none;
}

.wp-pagenavi .nextpostslink::before {
position: absolute;
content: "";
background: url("../img/icon_arrow_next.png")no-repeat center/contain;
width: 14px;
height: 12px;
top: 50%;
left: 50%;
transform: translateY(-50%)translateX(-50%);
}

/*----------
02.ヘッダー
----------*/
header {
position: fixed;
top: 20px;
left: 50%;
transform: translateX(-50%);
z-index: 10;
width: 100%;
}

header .header_wrap {
display: flex;
align-items: center;
justify-content: space-between;
background: #FFFFFF;
width: 100%;
border-radius: 100px;
}

header .header_wrap h1 {
max-width: 291px;
margin: 5px 0 0 30px;
}

header .header_wrap nav {
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
max-width: 715px;
}

header .header_wrap nav .nav_list {
display: flex;
align-items: center;
justify-content: space-between;
max-width: 550px;
width: 100%;

}

header .header_wrap nav .nav_list li {
padding: 0 20px;
position: relative;
}

header .header_wrap nav .nav_list li:first-child {
padding-left: 0;
}

header .header_wrap nav .nav_list li::after {
position: absolute;
content: "";
background: #000000;
width: 1px;
height: 14px;
top: 50%;
transform: translateY(-50%);
right: 0;
}

header .header_wrap nav .nav_list li:last-child::after {
display: none;
}

header .header_wrap nav .nav_list li a {
font-size: 14px;
line-height: 24px;
font-weight: 700;
display: block;
}

header .header_wrap nav .nav_list li a:hover {
opacity: 0.6;
}

header .header_wrap nav .contact_btn {
max-width: 139px;
width: 100%;
}

header .header_wrap nav .contact_btn a {
display: block;
background: #4285A2;
color: #FFFFFF;
text-align: center;
font-size: 16px;
font-weight: 700;
padding: 33px 0 32px;
border-radius: 0 100px 100px 0;
}

header .header_wrap nav .contact_btn a:hover {
background: rgba(66,133,162,0.8);
}

header .header_wrap .open_btn {
display: none;
}

/*----------
03.フッター
----------*/
footer {
background: #3D3D3D;
padding: 50px 0;
padding: 72px 0 55px;
}

footer .nav_list {
display: flex;
align-items: center;
justify-content: space-between;
max-width: 550px;
margin: 0 auto 38px;
}

footer .nav_list li {
padding: 0 18px;
position: relative;
}

footer .nav_list li:first-child {
padding-left: 0;
}

footer .nav_list li:last-child {
border-right: none;
padding-right: 0;
}

footer .nav_list li::after {
position: absolute;
content: "";
background: #FFFFFF;
width: 1px;
height: 14px;
top: 3px;
right: 0;
}

footer .nav_list li:last-child::after {
display: none;
}

footer .nav_list li a {
font-size: 12px;
line-height: 17px;
color: #FFFFFF;
}

footer .nav_list li a:hover {
opacity: 0.6;
}

footer .copyright {
color: #FFFFFF;
font-size: 12px;
line-height: 17px;
text-align: center;
}

@media only screen and (max-width:1024px){
/*----------
01.共通
----------*/
.title_ptn01 {
font-size: 24px;
line-height: 36px;
font-weight: 700;
position: relative;
text-align: center;
padding-bottom: 15px;
margin-bottom: 40px;
}

.title_ptn02 {
font-size: 17px;
line-height: 26px;
font-weight: 700;
text-align: center;
border-bottom: solid #707070 1px;
width: fit-content;
margin: 0 auto 20px;
}

.title_ptn03 {
position: relative;
font-size: 28px;
line-height: 40px;
font-weight: 700;
text-align: center;
display: block;
text-transform: uppercase;
}

.title_ptn03 .min { 
font-size: 15px;
line-height: 22px;
font-weight: 500;
text-align: center;
display: block;
margin-top: 10px;
}

.title_ptn04 {
text-align: center;
font-size: 28px;
line-height: 40px;
font-weight: 700;
display: block;
margin-bottom: 35px;
}

.title_ptn04 .min {
font-size: 14px;
line-height: 20px;
font-weight: 500;
display: block;
margin-top: 10px;
}

.under_mv_area {
background: url("../../img/business/bridge/mv_bg.png")no-repeat center/cover;
height: 440px;
padding-top: 175px;
position: relative;
}

.first_area .icon {
position: absolute;
top: -91px;
right: 50px;
max-width: 104.5px;
}

.first_area {
background: #FFFFFF;
border-radius: 40px;
max-width: 1080px;
margin: -80px auto 0;
position: relative;
padding: 40px 0 80px;
padding-top: 40px;
padding-right: 0px;
padding-bottom: 80px;
padding-left: 0px;
}

/*----------
02.ヘッダー
----------*/
header .header_wrap {
position: relative;
}

header .header_wrap h1 {
max-width: 253px;
margin: 5px 0 0 20px;
}

header .header_wrap nav {
display: none;
}

header .header_wrap nav.active {
display: block;
position: absolute;
top: 75px;
left: 0;
max-width: inherit;
width: 100%;
height: calc(100vh - 115px);
background: #FFFFFF;
border-radius: 40px;
margin: 0 auto;
padding: 60px 0 0;
}

header .header_wrap nav .nav_list {
display: block;
margin: 0 auto 30px;
}

header .header_wrap nav .nav_list li {
text-align: center;
margin: 0 auto 15px;
}

header .header_wrap nav .nav_list li {
padding: 0;
position: relative;
}

header .header_wrap nav .nav_list li:first-child {
padding-right: inherit;
}

header .header_wrap nav .nav_list li::after {
display: none;
}

header .header_wrap nav .nav_list li a {
display: inline-block;
}

header .header_wrap nav .contact_btn {
max-width: 200px;
width: 100%;
margin: 0 auto;
}

header .header_wrap nav .contact_btn a {
display: block;
background: #4285A2;
color: #FFFFFF;
text-align: center;
font-size: 16px;
font-weight: 700;
padding: 18px 0;
border-radius: 0;

}


header .header_wrap .open_btn {
display: block;
max-width: 100px;
width: 100%;
height: 65px;
position: relative;
background: #4285A2;
border-radius: 0 100px 100px 0;
}

header .header_wrap .open_btn .btn_in {
position: absolute;
width: 34px;
height: 24px;
top: 50%;
left: 32%;
transform: translateY(-50%);
}

header .header_wrap .open_btn .btn_in span {
position: absolute;
content: "";
background: #FFFFFF;
left: 0;
width: 100%;
height: 2px;
}

header .header_wrap .open_btn .btn_in span:nth-child(1) {
top: 0;
}

header .header_wrap .open_btn .btn_in span:nth-child(2) {
top: 50%;
transform: translateY(-50%);
}

header .header_wrap .open_btn .btn_in span:nth-child(3) {
bottom: 0;
}

header .header_wrap .open_btn.active .btn_in span:nth-child(1) {
top: 12px;
transform: rotate(-40deg);
}

header .header_wrap .open_btn.active .btn_in span:nth-child(2) {
display: none;
}

header .header_wrap .open_btn.active .btn_in span:nth-child(3) {
top: 12px;
transform: rotate(40deg);
bottom: inherit;
}

/*----------
03.フッター
----------*/


}

@media only screen and (max-width:750px){

/*----------
01.共通
----------*/

.pc{
display: none;
}

.sp{
display: block;
}

.contents_in{
width: calc(100% - 20px - 20px);
}

.title_ptn01 {
font-size: 20px;
line-height: 30px;
font-weight: 700;
position: relative;
text-align: center;
padding-bottom: 10px;
margin-bottom: 30px;
}

.title_ptn01::after {
position: absolute;
content: "";
background: #707070;
width: 40px;
height: 2px;
bottom: 0;
left: 50%;
transform: translateX(-50%);
}

.title_ptn02 {
font-size: 16px;
line-height: 26px;
font-weight: 700;
text-align: center;
border-bottom: solid #707070 1px;
width: fit-content;
margin: 0 auto 20px;
}

.title_ptn03 { 
font-size: 24px;
line-height: 32px;
font-weight: 700;
text-align: center;
display: block;
text-transform: uppercase;
}

.title_ptn03 .min { 
font-size: 14px;
line-height: 20px;
font-weight: 500;
text-align: center;
display: block;
margin-top: 5px;
}

.title_ptn04 {
text-align: center;
font-size: 24px;
line-height: 32px;
font-weight: 700;
display: block;
margin-bottom: 30px;
}

.title_ptn04 .min {
font-size: 13px;
line-height: 20px;
font-weight: 500;
display: block;
margin-top: 5px;
}

.btn_ptn01 a{
display: block;
border: solid #707070 1px;
background: #FFFFFF;
font-size: 15px;
line-height: 20px;
font-weight: 500;
text-align: center;
padding: 17px 0;
}

.under_mv_area {
background: url("../../img/news/mv_bg.png")no-repeat center/cover;
height: 340px;
padding-top: 135px;
position: relative;
}

.first_area {
background: #FFFFFF;
border-radius: 30px;
max-width: 1080px;
margin: -60px auto 0;
position: relative;
padding:  30px 0 60px;
}

.first_area .icon {
position: absolute;
top: -70px;
right: 20px;
max-width: 81px;
}

#recruit_area .img_wrap .train {
position: absolute;
top: 0;
right: -56%;
/*max-width: 526px;*/
width: 56%;
transition: right 3s linear;
}
#recruit_area .cnt_wrap {
background: url("../img/recruit_bg.png")no-repeat center/cover;
padding: 55px 0 73px;
/*margin-top: -150px;*/
margin-top: -11.7%;
}

#recruit_area .cnt_wrap .text {
font-size: 14px;
line-height: 21px;
color: #FFFFFF;
text-align: center;
margin-bottom: 40px;
}

.wp-pagenavi .page {
font-size: 18px;
line-height: 1;
font-weight: 500;
min-width: 35px;
height: 35px;
text-align: center;
color: #000000;
background: 0;
border: solid #000000 1px;
display: block;
padding-top: 8px;
margin: 0 8px;
}

.wp-pagenavi .current {
font-size: 18px;
line-height: 1;
font-weight: 500;
min-width: 35px;
height: 35px;
text-align: center;
color: #FFFFFF;
background: 0;
background: #000000;
display: block;
padding-top: 8px;
margin: 0 8px;
}

.wp-pagenavi .previouspostslink {
position: relative;
width: 14px;
height: 12px;
margin: 0 8px;
}

.wp-pagenavi .nextpostslink {
position: relative;
width: 14px;
height: 12px;
margin: 0 8px;
}

/*----------
02.ヘッダー
----------*/
header {
top: 10px;
}


header .header_wrap h1 {
max-width: 181px;
margin: 2px 0 0 15px;
}

header .header_wrap nav.active {
display: block;
position: absolute;
top: 55px;
left: 0;
max-width: inherit;
width: 100%;
height: calc(100vh - 75px);
background: #FFFFFF;
border-radius: 30px;
margin: 0 auto;
padding: 60px 0 0;
}

header .header_wrap .open_btn {
display: block;
max-width: 80px;
width: 100%;
height: 45px;
position: relative;
background: #4285A2;
border-radius: 0 100px 100px 0;
}

header .header_wrap .open_btn .btn_in {
position: absolute;
width: 26px;
height: 18px;
top: 50%;
left: 32%;
transform: translateY(-50%);
}

header .header_wrap .open_btn .btn_in span {
position: absolute;
content: "";
background: #FFFFFF;
left: 0;
width: 100%;
height: 2px;
}

header .header_wrap .open_btn.active .btn_in span:nth-child(1) {
top: 9px;
transform: rotate(-40deg);
}

header .header_wrap .open_btn.active .btn_in span:nth-child(3) {
top: 9px;
transform: rotate(40deg);
bottom: inherit;
}

/*----------
03.フッター
----------*/
footer {
background: #3D3D3D;
padding: 57px 0 45px;
}

footer .nav_list {
display: flex;
align-items: center;
justify-content: center;
flex-wrap: wrap;
max-width: 335px;
margin: 0 auto 30px;
}

footer .nav_list li {
padding: 0 18px;
margin-bottom: 5px;
}

footer .nav_list li:first-child {
padding-left: 18px;
}

footer .nav_list li:last-child {
padding-right: 18px;
}

footer .nav_list li::after {
position: absolute;
content: "";
background: #FFFFFF;
width: 1px;
height: 14px;
top: 3px;
right: 0;
}

footer .nav_list li:nth-child(4)::after {
display: none;
}

footer .nav_list li a {
font-size: 12px;
line-height: 17px;
color: #FFFFFF;
}

footer .nav_list li a:hover {
opacity: 0.6;
}

footer .copyright {
color: #FFFFFF;
font-size: 12px;
line-height: 17px;
text-align: center;
}

}
