html {overflow: auto;}
html.wf-loading {
	opacity: 0;
	transition: all .3s ease;
}
html.wf-inactive,
html.wf-active {
	opacity: 1;
}
body {font-family:"YakuHanJPs",'Noto Sans JP', sans-serif, "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;font-size: 14px;color:#545454;background: #fff;line-height: 2;letter-spacing : 0.06em;}
.oswald {font-family: 'Oswald', sans-serif;}
.sp {display:none;}

/* transition */
.fadein.up { opacity: 0; transform:translateY(30px); transition: all .5s ease;  }
.fadein.scrollin.up { opacity: 1; transform:translateY(0); }
.fadein.left { opacity: 0; transform:translateX(-30px); transition: all .5s ease;  }
.fadein.scrollin.left { opacity: 1; transform:translateY(0); }
.fadein.right { opacity: 0; transform:translateX(30px); transition: all .3s ease;  }
.fadein.scrollin.right { opacity: 1; transform:translateY(0); }
.fadein.zoomout { opacity: 0; transform:scale(2, 2); transition: all .3s ease; transform-origin: center; }
.fadein.scrollin.zoomout { opacity: 1; transform:scale(1, 1); }
.fadein.delay02 { transition-delay:  .2s; }
.fadein.delay03 { transition-delay:  .3s; }
.fadein.delay04 { transition-delay:  .4s; }
.fadein.delay05 { transition-delay:  .5s; }
.fadein.delay06 { transition-delay:  .6s; }
.fadein.delay08 { transition-delay:  .8s; }
.fadein.delay10 { transition-delay: 1.0s; }
.fadein.delay15 { transition-delay: 1.5s; }
.fadein.speed02 { transition-duration:  .2s; }
.fadein.speed03 { transition-duration:  .3s; }
.fadein.speed04 { transition-duration:  .4s; }
.fadein.speed05 { transition-duration:  .5s; }
.fadein.speed06 { transition-duration:  .6s; }
.fadein.speed08 { transition-duration:  .8s; }
.fadein.speed10 { transition-duration: 1.0s; }
.fadein.speed15 { transition-duration: 1.5s; }

.fillin { transition: all .5s ease; opacity: 0; position: relative; overflow: hidden;}
em.fillin { font-style: normal; line-height: 1; }
.fillin.scrollin { opacity: 1; }
.fillin::after { content: ""; position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; background-color: #e83b18; transition: all .5s ease; transform: translateX(-100%); }
.fillin.scrollin::after { transform: translateX(101%) }
.fillin.red::after  { background-color: #a22024; }
.fillin.black::after  { background-color: #000000; }
.fillin.green::after  { background-color: #bbe276; }
.fillin.pink::after   { background-color: #fb808c; }
.fillin.purple::after { background-color: #bc7dc0; }
.fillin.blue::after   { background-color: #57adca; }
.fillin.brown::after  { background-color: #ad936c; }

/*パンくずリスト*/
.breadcrumbs {
    margin: 10px 0 0;
    font-size: 10px;
    color: #fff;
    position: absolute;
    right: 30px;
}
.breadcrumbs a{color: #fff}
.fbox {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
}
.fb-center {justify-content: center;}
.fb-between {justify-content: space-between;}


/*リンク*/
a {color:#2c2c2c;text-decoration: none; transition: opacity .3s ease 0s;}
a:hover {opacity: 0.7}
/*見出し*/
/* h1,h2,h3,h4,h5 {color:;} */
h1 {
    margin:0;
    font-size: 12px;
    font-weight: normal;
    line-height: 1;
    color: #fff
}
h2 {font-weight: normal;font-size: 36px;letter-spacing: 0.24em;margin-bottom: 30px;}
h3 {font-size: 25px;margin: 0px 0 30px;line-height: 1.8;letter-spacing: 0.06em;text-align: center;}
h4 {font-size: 16px ;}
h5 {font-weight: bold;}
p {margin-bottom: 30px;text-align: justify;}
.en {font-family: 'Cookie', cursive;}
.sfont {font-size: 10px}
.lfont {font-size: 18px}
.bold {font-weight: bold;}

.arrow{
    position: relative;
    display: inline-block;
    padding: 0 0 0 16px;
    color: #000;
    vertical-align: middle;
    text-decoration: none;
    font-size: 15px;
    top: -2px;
}
.arrow::before,
.arrow::after{
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
.right::before{
    left: 10px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.arrb {
    display: block;
    top: 2px;
    width: 30px;
    margin: 0 auto;
}
.bottom::before{
    left: 10px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}

/*リスト・テーブル*/
table {width: 100%}
td,th {
    font-weight: normal;
    padding:  22px 10px 22px;
    border-bottom: solid 1px #bfbfbf;
    border-top: solid 1px #bfbfbf;
    font-size: 14px;
    line-height: 1.5;
}
th {
    text-align: left;
    width: 25%;
    vertical-align: top;
    
}
td {width:75%;line-height: 2;}

dl{display:flex;flex-wrap: wrap;margin-bottom: 20px;}
dt {width: 36%;}
dd {width: 62%;margin-left: 0;}

/*カラム設定*/
.container {padding: 0;margin:0 auto;}
.con-l {max-width: 1100px;}
.con-m {max-width: 1060px;}
.con-s {max-width: 900px;}
.content-area {margin-top: 100px;}


/*ヘッダー*/
header {
    position: absolute;
    width: 100%;
    z-index: 100;
}
.logo-area {padding: 30px 0 0 30px;width: 35%}
.logo-area img {width:49px;}
.logo-area span {
    position: relative;
    top: 3px;
    left: 15px;
    display: inline-block;
    line-height: 1.8;
}

/*ナビメニュー*/
.nav-area {
    background: #a22024;
    height: 53px;
    position: absolute;
    right: 30px;
    top: 30px;
}
.sp-btn {display: none}
.navbar li {
    font-family: 'Oswald', sans-serif;
    font-size: 16px;
    letter-spacing: 0.1em;
    float: left;
}
.navbar li a{color:#fff;padding: 11px 25px 10px;display: block;}
.navbar li:last-child {padding: 3px;}
.navbar li:last-child a{color:#a22024;background: #fff;padding: 7px 25px 8px;}
.navbar li a:hover{opacity: 1}
/*サブメニュー*/
.sub-menu {
    width: 300px;
    background: #1e8cd7;
    display: none;
    position: absolute;
    z-index: -5;
    height: 100%;
    top: 0;
    left: 220px;
    text-align: left;
    padding: 45px 0 0;
}
.sub-menu-link {
    width: 49%;
    margin-right: 2%;
    font-size: 13px;
    line-height: 2;
}
.sub-menu-link img{width: 100%;}
.navbar li:hover::after{
    opacity: 1;
    transition: all 0.5s ease-in-out;
}
.navbar li:hover .sub-menu {
    display: block;
    animation: show 0.3s linear 0s;
    animation: slide 0.3s linear;
}
@keyframes show{
    from{
        opacity: 0;
    }
    to{
        opacity: 1;
    }
}

@keyframes slide {
    from {
        opacity: 0;
        transform: translateX(-220px);
    }
    to {
        opacity: 1;
        transform: translateX(0px);
    }
}

/*  メニューアクティブ時  */
nav.open {transform: translate(0);}
.on {display: block;}


/*フッター*/
footer {font-size: 12px;}
.footer-add {margin: 15px 0 0 50px;font-size: 13px;}
.footer-logo {
    width: 50%;
    text-align: center;
    padding: 70px 0 60px;
}
.footer-logo img{width:268px;}
.footer-link {
    width: 50%;
    background: url( ../images/footer-link-bg.jpg)no-repeat;
    background-size: cover;
    background-size: 100%;
    background-position: center;
}
.footer-link a{
    display: block;
    padding: 70px 0 60px;
    color:#fff;
}
.footer-link:hover {background-size: 110%;background-position: center;transition: all 1.3s ease;}
.btn {
    border: solid 1px #fff;
    padding: 5px;
    text-align: center;
    width: 300px;
    margin: 0 auto;
}
.footer-tx {margin-top: 5px;font-size: 10px;}
.copyright {
    padding: 10px 0;
    font-size: 10px;
    letter-spacing: 0.1em;
    text-align: center;
}
.arrow-top {
    position: fixed;
    bottom: 50px;
    right: 50px;
    z-index: 100;
    transition: all .6s ease-in .4s;
    transform: translateY(50px);
    opacity: 0;
}
.active {
    opacity: 1;
    transform: translateY(0);
}
.arrow-top img {width: 50px}


    
/*メインビジュアル*/
.main-v {
/*
    background: url(../images/main.jpg)no-repeat;
    background-size: cover;
    padding: 200px 0 0;
*/
    max-height: 890px;
    background-position: center;
    overflow: hidden;
}
.main-v video{width: 100%}
.v-area {
    position: absolute;
    top: 50px;
    right: 0;
    left: 0;
}
.main-v h2 {
    font-weight: bold;
    font-size: 60px;
    letter-spacing: 0.06em;
    margin-bottom: 0px;
    color: #fff;
    line-height: 1.2;
    text-shadow: 0 0 5px #000;
}
.main-v h2 span{
    font-size: 20px;
    display: block;
    line-height: 1.3;
    margin-bottom: 10px;
}
.main-tx {margin: 175px auto 0;max-width: 385px;}
.main-obj {
    max-width: 1007px;
    position: relative;
    top: -70px;
}
.main-obj img{width: 100%}

/*トップページ*/
h3.img-title {text-align: left;}
.message {margin-bottom: 100px;}
.mess-img {
    width: 65%;
    position: relative;
    left: 35%;
}
.slide-bg:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    height: 100%;
    width: 100%;
    background: #008475;
    -webkit-transition: 0.8s cubic-bezier(0.57, 0.15, 0.13, 0.97);
    transition: 0.8s cubic-bezier(0.57, 0.15, 0.13, 0.97);
}
.mess-img img{width: 100%}
.mess-title {width: 248px}
.mess-tx {
    width: 57%;
    margin-top: -180px;
    font-size: 16px;
    font-weight: bold;
    padding-left: 100px;
    position: relative;
}
.title {
    background: #a22024;
    text-align: center;
    color: #fff;
    font-size: 26px;
    font-weight: bold;
    height: 55px;
    padding: 3px 0 0;
    margin-bottom: 45px;
}
.title::after {
    content: "";
    position: relative;
    display: block;
    top: -8px;
    margin: 0 auto;
    width: 0;
    height: 0;
    border-left: 20px solid transparent;
    border-right: 20px solid transparent;
    border-top: 34px solid #a22024;
}
#about{margin-bottom: 70px}

.movie-area {margin-bottom: 100px;}
iframe {
    width: 48%;
    margin-top: 20px;
    height: 300px;
}
iframe:last-child {height: 296px}
.movie-link {margin: 40px 0 0;text-align: center;font-weight: bold;}

.about-area h3 {font-size: 30px;}
.about-title-tx {
    padding: 0 260px;
    margin-bottom: 50px;
    text-align: center;
}
.about-list {
    font-size: 16px;
    padding: 15px 20px;
    color: #a22024;
    font-weight: bold;
}
.about-content {
    width: 48.5%;
    margin-right: 3%;
    display: table;
    margin-bottom: 30px;
}
.about-content:nth-child(2n) {margin-right: 0;}
.about-img {width: 100%}
.about-img img{width: 100%}
.about-tx {
    width: 50%;
    padding-left: 3%;
    font-size: 12px;
    line-height: 1.5;
    display: table-cell;
    vertical-align: bottom;
}
.about-tx h4 {margin-bottom: 10px;letter-spacing: 0;}
.about-tx h4 span{font-size: 14px;}
.about-content:nth-child(3) .about-tx,.about-content:nth-child(4) .about-tx{padding-right: 3%;padding-left: 0}

.career-step {position: relative;margin: 50px 0}
.career-title {
    width: 142px;
    margin-right: 10px;
    position: relative;
    top: 10px;
}
.career-step h3{
    text-align: left;
    margin-bottom: -50px;
    font-size: 20px;
    color: #a22024;
}
.career-step-img {
    position: absolute;
    right: 0;
    top: 0;
}
.career-step-img img{width: 505px;height: auto;}
.career-img {
    width: 630px;
    border: solid 1px #ccc;
    padding: 40px 60px;
    margin-top: 80px;
}
.career-img img{
    width: 100%;
    margin: 0 auto 20px;
    display: block;
}
.career-img h4{
    color: #a22024;
    margin-bottom: 10px;
}
.cross-interview {margin: 100px 0 200px;}
.cross-pro-area {width: 45%;position: absolute;left: 0;}
.cross-pro-area img{width: 100%}
.cross-pro {
    background: #000;
    color: #fff;
    padding: 20px 60px 30px;
}
.cross-w {margin-left: auto;}
.cross-pro-list {
    width: 48%;
    margin-right: 4%;
}
.cross-pro-list:last-child {margin-right: 0;}
.cross-tx-area {
    width: 55%;
    margin-left: auto;
    position: relative
}
.cross-title {width: 213px}
.cross-tx h3 {font-size: 20px}
.cross-pro-list {
    width: 40%;
    margin-right: 20%;
    font-size: 12px;
    line-height: 1.5;
}
.cross-tx {
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    height: 620px;
    padding: 0 40px
}
.cross-pro-list h4{
    font-size: 15px;
    margin: 10px 0;
}
.cross-tx-title span{
    text-align: center;
    display: block;
    font-size: 16px;
    font-weight: bold;
    margin: 10px 0 20px;
}
.caption {
    text-align: center;
    font-style: italic;
    font-size: 16px;
    margin: 30px 0;
}
.cross-tx span{font-weight: bold;font-size: 15px;}
.cross-image {
    object-fit: cover;
    height: 600px;
    font-family: 'object-fit: cover;';
}
.interview-area {background: #ffced0;margin-top: 220px;}
.interview-title {width: 197px}
.interview-pro {
    background: #a22024;
    color: #fff;
    padding: 30px;
}
.interview-pro span{
    display: block;
    font-size: 15px;
    font-weight: bold;
}
.interview-tx h3 {
    font-size: 20px;
    color: #a22024;
    margin-top: -35px;
}
.interview-tx {
    padding: 0 0 49px 0;
    width: 60%;
}
.interview-tx h4{margin: 30px 0 15px;}
.interview-img {
    width: 40%;
    position: absolute;
    right: 0;
}
.interview-img img{
    object-fit: cover;
    height: 600px;
    width: 100%;
    font-family: 'object-fit: cover;';
}
.welfare-area {
    background: url(../images/welfare-bg.jpg)no-repeat;
    background-size: cover;
    margin: 50px 0;
    padding: 50px 0;
}
.welfare {
    width: 48%;
    margin-right: 4%;
}
.welfare:last-child {margin-right:0;}
.welfare h3{font-size: 15px}
.welfare h3 span{
    display: block;
    font-size: 34px;
    background: #000;
    color: #fff;
    width: 160px;
    margin: 0 auto;
    line-height: 1.3;
    font-weight: normal;
}
.welfare-list {
    display: table;
    border: solid 1px #000;
    padding: 15px;
    margin-bottom: 10px;
}
.welfare-title {
    width: 35%;
    display: table-cell;
    vertical-align: middle;
    color: #a22024;
    font-size: 14px;
    line-height: 1.3;
}
.welfare-list .tx {
    width: 75%;
    display: table-cell;
    font-size: 12px;
    padding-left: 20px;
}
.recruit-area {
    margin-bottom: 100px;background: url(../images/recruit-logo.png)no-repeat;
    background-position-x: 85%;
}
.recruit-title {width: 255px}
.recruit-area h3 {font-size: 20px}
.recruit-tx {
    font-size: 16px;
    padding: 0 100px;
    margin-bottom: 30px;
    text-align: center;
}


/*下層ページ*/
.main-v-page {
    background: #999 url(../images/main-page.jpg)no-repeat;
    background-size: cover;
    height: 300px;
    padding: 130px 0 0;
    background-position: center;
    color: #fff;
}
.main-v-page:before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 300px;
    background-color: rgba(0,0,0,.5);
    content: "";
}
.main-tx-page {
    margin: 0 auto;
    width: 385px;
    position: relative;
    z-index: 100;
}
.main-tx-page h2 {text-align: center;}
.content-area-page {
    background: #f5f5f5;
    padding: 100px 0;
}
.page {
    text-align: center;
    padding: 50px 100px;
    background: #fff;
}
.page h4 {text-align: left;}


/*contact*/
.contact-area {
    background: #f5f5f5;
    padding-bottom: 100px;
}
.mynavi {
    margin: 0 auto 50px;
    flex-direction: column;
    align-items: center;
}
.mynavi-tx {text-align: center;margin-bottom: 20px;}
.mynavi-img {display: flex; justify-content: space-around; max-width: 700px; width: 100%;
}
.mynavi-img img {width: 100%; height: auto;}

.mynavi-img a {
    width: calc(100% / 3 - 20px);
    max-width: 180px;
}
.contact-area .title {position: relative;top: -27px;}
.contact {
    background: #fff;
    padding: 50px 100px 10px;
    max-width: 900px;
    margin: 0 auto;
}
input[type="text"],input[type="email"],textarea {width: 100%;font-size: 16px;border: solid 1px #ccc;line-height: 1.5;}
.form-tx {text-align: center;margin-bottom: 50px;}
.f-title {
    border-bottom: solid 1px #000;
    width: 32%;
    padding: 35px 10px 30px;
}
.f-input {
    border-bottom: solid 1px #ccc;
    width: 68%;
    padding: 30px 10px 30px;
}
.doui {
    padding: 20px;
    width: 100%;
    margin: 20px auto;
    text-align: center;
}
.privacy-link {margin-top: 10px}
.privacy-link a{text-decoration: underline;}
.btn-area {text-align: center}
.send-btn {
    font-size: 18px;
    box-shadow: -1px 1px 5px #ccc;
    width: 250px;
    margin: 40px 20px 0;
    border-radius: 5px;
    padding: 15px;
    cursor: pointer;
    text-align: center;
    background:#a22024;
    transition: all 0.2s ease-out;
    display: inline-block;
}
.send-btn input{background: none;border: 0;color: #fff;}
.send-btn a:hover{opacity: 1}
.send-btn:hover {opacity: 0.7}
.hissu:after {
    content: "必須";
    background: #e5004f;
    color: #fff;
    float: right;
    font-size: 10px;
    padding: 2px 9px 3px;
    border-radius: 5px;
    margin-right: 20%;
}
.doui:before {
    content: "必須";
    background: #e5004f;
    color: #fff;
    font-size: 10px;
    padding: 2px 9px 3px;
    border-radius: 5px;
    margin-right: 1%;
    position: relative;
    top: -1px;
}
.ninni:after {
    content: "任意";
    background: #707070;
    color: #fff;
    float: right;
    font-size: 10px;
    padding: 2px 9px 3px;
    border-radius: 5px;
    margin-right: 20%;
}
#formWrap h4 {margin-bottom: 30px}
.error_messe {color:#ff0000;margin-bottom: 10px;}
.formTable td{text-align: left}

@media (min-width: 1920px) {
    .main-v {height: 990px;}
    .interview-img {
        width: 27%;
        right: 15%;
    }
    .cross-pro-area {
        width: 27%;
        left: 20%;
    }
}

@media (max-width: 1024px) {
    .pc {display: none}
    .sp {display: block}
    .con-l,.con-m,.con-s {padding: 0 30px;}

    /*ナビメニュー*/
    .sp-btn {
        width: 78px;
        height: 78px;
        cursor: pointer;
        z-index: 10100;
        text-align: center;
        padding-top: 26px;
        position: fixed;
        right: 20px;
        top:20px;
        background: #a22024;
    }
    nav {
        width: 100%;
        height: 100%;
        transition: all 0.2s;
        transform: translate(100%);
        position: fixed;
        top: 0;
        right: 0;
        z-index: 10080;
        background: rgba(255, 255, 255, 0.9);
        padding: 12vh 11vw 0
    }
    
    .navbar li {float: none;}    
    .navbar li a {padding: 10px 0 10px 20px;color:#a22024;}
    .sp-btn .btn_menu {
        display: inline-block;
        position: relative;
        z-index: 1001;
    }
    .hbmenu, .hbmenu span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
    }
    .hbmenu {
        position: relative;
        width: 19px;
        height: 14px;
        cursor: pointer;
    }
    .hbmenu span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #fff;
    }

    .hbmenu span:nth-of-type(1) {
        top: 3px;
    }

    .hbmenu span:nth-of-type(2) {
        top: 15px;
    }
    .hbmenu span:nth-of-type(3) {
        bottom: 4px;
    }
    .active .hbmenu span:nth-of-type(1) {
        background-color: #fff;
        top: -5px;
        animation: active-menu-bar04-01 .75s forwards;å
    }
    @keyframes active-menu-bar04-01 {
        0% {
            transform: translateY(0) rotate(0);
        }
        50% {
            transform: translateY(15px) rotate(0);
        }
        100% {
            transform: translateY(14px) rotate(45deg);
        }
    }
    .active .hbmenu span:nth-of-type(2) {
        background-color: #fff;
        opacity: 0;
        animation: none;
    }
    .active .hbmenu span:nth-of-type(3) {
        background-color: #fff;
        bottom: -5px;
        animation: active-menu-bar04-03 .75s forwards;
    }
    @keyframes active-menu-bar04-03 {
        0% {
            transform: translateY(0) rotate(0);
        }
        50% {
            transform: translateY(-7px) rotate(0);
        }
        100% {
            transform: translateY(-9px) rotate(-45deg);
        }
    }
    
    /*  メニューアクティブ時  */
    nav.open, .recruit-nav.open {transform: translate(0);}
    .on {animation: show 0.5s linear 0s;}
     
    @keyframes show{
        from{
            opacity: 0;
        }
        to{
            opacity: 1;
        }
    }
    /*トップページ*/
    .main-tx {margin: 100px auto 0;}
    .main-obj {max-width: 70vw;margin: 0 auto;}
    iframe {height: 26vw;}
    iframe:last-child {height: 24.9vw}
    
    .about-title-tx {padding: 0 19vw;}
    .mess-tx {padding-left: 5vw;}
    .career-step-img img {width: 48vw;height: 500px;object-fit: cover;font-family: 'object-fit: cover;'}
    .career-img {width: 50vw;padding: 40px 6vw;}
    .cross-pro {padding: 2vw 4vw;}
    .cross-w {width: 37vw;}
    .cross-pro-list {width: 42%;margin-right: 15%;}
    .interview-tx {width: 45vw;}
    .interview-img {width: 49vw;}
    .contact {padding: 50px 10vw 10px;}
    dt {width: 245px;}
    dd {width: 43vw;}
}



@media (max-width: 835px) {
    .logo-area {width: 40%;}
    .main-tx {margin: 8vw auto 0;}
    .about-title-tx {padding: 0 10vw;}
    .contact {padding: 30px 5vw 10px;}
    .recruit-tx {padding: 0 10vw;}
    .about-tx {line-height: 1.3;}
    .about-tx h4 {margin-bottom: 5px;font-size: 12px;}
    .about-tx h4 span {font-size: 12px;}
    .career-step-img img {width: 46vw;height: 470px;object-position: 0;}
    .career-step h3 {margin-bottom: -65px;}
    .career-title {margin-right: -59px;top: -11px;}
    .cross-pro-area {width: 100%;position: static;order: 2;margin-top: 30px;}
    .cross-tx-area {width: 100%;position: static;order: 1}
    .cross-image {height: 400px;}
    .cross-w {width: 67vw;margin: 0 auto;}
    .interview-tx {width: 100%;}
    .interview-img img {height: 400px;object-position: 0 10%;}
    .interview-img {width: 100%;position: relative;}
    .interview-area {padding-bottom: 30px;}
    .interview-pro {line-height: 1.5;}
    dd {width: 50vw;}
}

@media (max-width: 480px) {
    body {font-size: 14px;line-height: 1.5}
    .spbr {display: none}
    td {line-height: 1.5;}
    dl {background: #e8e8e8;padding: 10px;}
    dt {padding: 0 0 5px;}
    dd {width: 100%}
    .con-l, .con-m, .con-s {padding: 0 15px;}
    .arrow-top {bottom: 20px;right: 10px;}
    .logo-area {padding: 10px 10px 8px;width: 100%;}
    h1 {font-size: 2.5vw;}
    .logo-area img {width: 40px;}
    .logo-area span {top: 0px;left: 10px;text-shadow: 1px 1px 1px #626262;}
    .sp-btn {
        width: 50px;
        height: 50px;
        padding-top: 15px;
        right: 10px;
        top: 10px;
    }
    .main-v video {width: 150%;margin-left: -100px;}
    .main-tx {margin: 16vw 0 0 30px;}
    .main-v h2 {font-size: 33px;}
    .main-v h2 span {font-size: 13px;margin-bottom: 3px;}
    .main-obj {
        top: -6vw;
        width: 70%;
        margin: 0 auto;
    }
    .content-area {margin-top: 50px;}
    .message {margin-bottom: 50px;}
    .mess-tx {
        padding-left: 0;
        width: 100%;
        margin-top: -67px;
        font-size: 14px;
    }
    .mess-img img {width: 100%;}
    .mess-title {width: 173px;}
    .title {
        font-size: 22px;
        height: 40px;
        padding: 2px 0 0;
    }
    .title::after {
        top: 0;
        border-left: 15px solid transparent;
        border-right: 15px solid transparent;
        border-top: 22px solid #a22024;
    }
    h3 {font-size: 18px;line-height: 1.5;}
    #about {margin-bottom: 45px;}
    .about-area h3 {font-size: 6vw;}
    .about-title-tx {padding: 0;}
    .about-list {font-size: 15px;}
    .about-content {
        width: 100%;
        margin-right: 0;
        margin-bottom: 15px;
        display: flex;
    }
    .movie-area {margin-bottom: 50px;}
    iframe {
        width: 100%;
        height: 52.5vw;
        margin-top: 0px;
    }
    iframe:first-child {margin-bottom: 30px;margin-top: -20px;}
    iframe:last-child {height: 51.5vw}

    .about-img {width: 40%;}
    .about-tx {width: 60%;}
    .about-content:nth-child(3) .about-img,
    .about-content:nth-child(4) .about-img {order: 1;}
    .about-content:nth-child(3) .about-tx,
    .about-content:nth-child(4) .about-tx {order: 2;padding-right: 0;padding-left: 3%;}
    .about-img img {height: 100px;object-fit: cover;font-family: 'object-fit: cover;';}
    .career-title {
        margin-right: 5px;
        top: 0px;
        width: 100px;
    }
    .career-step h3 {font-size: 16px}
    .career-img {width: 100%;padding: 40px 6vw;}
    .career-step-img {position: relative;margin-top: 20px;}
    .career-step-img img {width: 100%;height: auto;}
    .cross-interview {margin: 50px 0 100px;}
    .cross-pro-area {
        width: 100%;
        position: absolute;
        order: 1;
        margin-top: 0px;
    }
    .cross-tx-area {
        width: 100%;
        position: relative;
        order: 2;
        margin-top: 570px;
    }
    .cross-title {width: 149px;}
    .cross-image {height: 300px;}
    .cross-tx {padding: 0 20px;height: 500px;}
    .caption {font-size: 14px;}
    .cross-w {width: 80vw;}
    .cross-pro-list {width: 45%;margin-right: 9%;line-height: 1.3;}
    .cross-pro-list h4 {line-height: 1.5;}
    .cross-pro {padding: 2vw 4vw 5vw;}
    .interview-area {margin-top: 120px;}
    .interview-title {width: 118px;}
    .interview-tx h3 {font-size: 18px;}
    .interview-tx {padding: 0 20px 49px;}
    .interview-inner {height: 500px;overflow-y: scroll;margin-top: 20px;-webkit-overflow-scrolling: touch;}
    .interview-pro {padding: 15px;}
    .interview-img img {height: 250px;}
    .welfare-area {margin:0;background-position-x: 85%;}
    .welfare h3 span {margin-bottom: 5px;font-size: 28px;}
    .welfare {width: 100%;margin-right: 0;margin-bottom: 30px;}
    .welfare:last-child {margin-bottom:0;}
    .welfare-list .tx {line-height: 1.5;}
    .welfare-title {width: 46%;}
    .recruit-area {margin-top: 50px;background-size: 50%;background-position-y: 30px;}
    .recruit-title {width: 178px;}
    .recruit-tx {
        padding: 0;
        font-size: 15px;
    }
    .contact-area .title {margin-bottom: 20px;}
    .mynavi-tx {width: 100%;margin-right:0;}
    .mynavi-img {
        width: 100%;
        text-align: center;
        margin: 20px 0 0;
    }
    .hissu:after {
        float: none;
        margin-right: 0;
        margin-left: 5px;
    }
    .ninni:after {
        float: none;
        margin-right: 0;
        margin-left: 5px;
    }

    .send-btn {width: 190px;padding: 10px;}
    
    .footer-logo {width: 100%;}
    .footer-logo img {width: 70%;}
    .footer-link {width: 100%;background-size: cover;}
    .footer-link:hover {background-size: cover;}
    .btn {width: 65%;}
    
    /*下層*/
    .main-v-page {height: 200px;padding: 85px 0 0;}
    .main-v-page:before {height: 200px}
    .content-area-page {padding: 30px 0;}
    .page {padding: 30px 20px;}
}