@charset "utf-8";
/*
====================================================
■ FUNCTION
====================================================
*/
/*
====================================================
■ ModBtn
====================================================
*/
/*
====================================================
■ MIXIN
====================================================
*/
/*
===== CLEARFIX ==========================================
*/
.clearfix:after {
  content: " ";
  display: block;
  clear: both;
}
/*
====================================================
■ EASING
====================================================
*/
/*
====================================================
■ DotNav
====================================================
*/
@media screen and (min-width: 1121px), print {
  #DotNav {
    position: fixed;
    right: 45px;
    top: calc(50% - 60px);
    z-index: 100;
    display: none;
    opacity: 0;
  }
  #DotNav .dot {
    width: 18px;
    height: 18px;
    cursor: pointer;
    -webkit-transition: -webkit-transform 150ms;
    transition: -webkit-transform 150ms;
    transition: transform 150ms;
    transition: transform 150ms, -webkit-transform 150ms;
    position: relative;
    margin-top: 21px;
  }
  #DotNav .dot:first-child {
    margin-top: 0;
  }
  #DotNav .dot:before,
  #DotNav .dot:after {
    content: "";
    -webkit-transition: opacity 100ms;
    transition: opacity 100ms;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    right: auto;
    bottom: auto;
    z-index: 1;
  }
  #DotNav .dot:before {
    background-image: url('../../img/common/nav/dot_black.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    width: 18px;
    height: 18px;
    display: block;
    text-indent: -9999px;
  }
  #DotNav .dot:after {
    background-image: url('../../img/common/nav/dot_yellow.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    width: 18px;
    height: 18px;
    display: block;
    text-indent: -9999px;
    opacity: 0;
  }
  #DotNav .dot.current:before {
    opacity: 0;
  }
  #DotNav .dot.current:after {
    opacity: 1;
  }
  #DotNav .dot:hover {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
}
@media screen and (min-width: 1921px), print {
  #DotNav {
    right: auto;
    left: calc(50% + 890px);
  }
}
@media screen and (max-width: 1120px) {
  #DotNav {
    display: none;
  }
}
/*
====================================================
■ TopKv
====================================================
*/
/*
----------------------------------------------------
PC
----------------------------------------------------
*/
@media screen and (min-width: 769px), print {
  #News {
    width: 100%;
    height: 60px;
    background-color: #FFF;
    position: relative;
    z-index: 10;
  }
  #News ul {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
  #News ul li {
    position: absolute;
    left: 0;
    top: 0;
    line-height: 60px;
    display: none;
    width: 100%;
    height: 100%;
  }
  #News ul li:after {
    content: " ";
    display: block;
    clear: both;
  }
  #News ul li:first-child {
    display: block;
  }
  #News ul li a {
    display: block;
    width: 100%;
    height: 100%;
  }
  #News ul li .date {
    display: block;
    float: left;
    padding-left: 42px;
    padding-right: 40px;
    overflow: hidden;
  }
  #News ul li .txt {
    float: left;
    display: block;
    height: 100%;
  }
  #News ul li a:hover {
    color: #999;
  }
}
/*
----------------------------------------------------
SP
----------------------------------------------------
*/
@media screen and (max-width: 768px) {
  #News {
    width: 100%;
    height: 10.66666667vw;
    background-color: #FFF;
    position: relative;
    z-index: 10;
  }
  #News ul {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
  #News ul li {
    position: absolute;
    left: 0;
    top: 0;
    line-height: 10.66666667vw;
    font-size: 2.66666667vw;
    display: none;
    width: 100%;
    height: 100%;
  }
  #News ul li:after {
    content: " ";
    display: block;
    clear: both;
  }
  #News ul li:first-child {
    display: block;
  }
  #News ul li .date {
    display: block;
    float: left;
    width: 22%;
    padding-left: 2.66666667vw;
  }
  #News ul li .txt {
    display: block;
    float: left;
    width: 75%;
    height: 100%;
    overflow: hidden;
  }
  #News ul li a:hover {
    color: #999;
  }
}
/*
====================================================
■ TopKv
====================================================
*/
/*
----------------------------------------------------
PC
----------------------------------------------------
*/
@media screen and (min-width: 769px), print {
  #TopKv {
    z-index: 10;
    width: 100%;
    height: calc(100vh - 80px);
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-line-pack: center;
        align-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #TopKv .box {
    width: 800px;
    text-align: center;
  }
  #TopKv h1 {
    background-image: url('../../img/top/kv/logo.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    width: 270px;
    height: 340px;
    display: block;
    text-indent: -9999px;
    margin: 0 auto;
    opacity: 0;
  }
  #TopKv .title_en {
    font-family: Georgia, Times, 'Times New Roman', serif;
    font-size: 14px;
    margin-top: 2vh;
  }
  #TopKv hr {
    border: none;
    width: 7px;
    height: 1px;
    background: #000;
    margin: 15px auto 4px;
  }
  #TopKv .nm {
    font-family: Georgia, Times, 'Times New Roman', serif;
    font-size: 14px;
  }
  #TopKv .sub {
    opacity: 0;
  }
  #TopKv .title_jp {
    font-size: 24px;
    line-height: 2;
    letter-spacing: 0.12rem;
    margin-top: 5vh;
    font-family: "Noto Sans Japanese";
    font-weight: 700;
    opacity: 0;
  }
  #TopKv .scroll {
    width: 64px;
    height: 52px;
    cursor: pointer;
    position: relative;
    margin: 40px auto 0;
    opacity: 0;
  }
  #TopKv .scroll .txt {
    font-family: Georgia, Times, 'Times New Roman', serif;
    font-weight: 700;
    font-size: 12px;
  }
  #TopKv .scroll .arrow2,
  #TopKv .scroll .arrow1 {
    background-image: url('../../img/top/kv/arrow.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    width: 16px;
    height: 13px;
    text-indent: -9999px;
    display: block;
    position: absolute;
    left: 23px;
    top: 26px;
    right: auto;
    bottom: auto;
    z-index: 1;
  }
  #TopKv .scroll .arrow2 {
    top: 35px;
  }
}
/*
----------------------------------------------------
SP
----------------------------------------------------
*/
@media screen and (min-width: 769px) and (max-height: 780px) {
  #TopKv h1 {
    width: 34.5vh;
    height: 43.44444444vh;
  }
}
@media screen and (min-width: 769px) and (max-height: 740px) {
  #TopKv hr {
    display: none;
  }
  #TopKv .nm {
    display: none;
  }
  #TopKv .title_jp {
    line-height: 1.7;
  }
}
@media screen and (max-width: 768px) {
  #TopKv {
    position: relative;
    z-index: 10;
    width: 100%;
    height: 100vh;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-line-pack: center;
        align-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #TopKv .box {
    text-align: center;
    padding-bottom: 5vh;
  }
  #TopKv h1 {
    background-image: url('../../img/top/kv/logo_sp.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    width: 38.4vw;
    height: 48.799872vw;
    display: block;
    text-indent: -9999px;
    margin: 0 auto;
    opacity: 0;
  }
  #TopKv .title_en {
    font-family: Georgia, Times, 'Times New Roman', serif;
    font-size: 2.66666667vw;
    margin-top: 2vh;
    opacity: 0;
  }
  #TopKv hr {
    border: none;
    width: 1.6vw;
    height: 1px;
    background: #000;
    margin: 2.66666667vw auto 0.53333333vw;
  }
  #TopKv .nm {
    font-family: Georgia, Times, 'Times New Roman', serif;
    font-size: 2.66666667vw;
    opacity: 0;
  }
  #TopKv .sub {
    opacity: 0;
  }
  #TopKv .title_jp {
    font-size: 4vw;
    line-height: 2;
    letter-spacing: 0.12rem;
    margin-top: 3vh;
    font-family: "Noto Sans Japanese";
    font-weight: 700;
    opacity: 0;
  }
  #TopKv .scroll {
    width: 16vw;
    height: 13.33333333vw;
    text-align: center;
    position: relative;
    margin: 5.86666667vw auto 0;
    opacity: 0;
  }
  #TopKv .scroll .txt {
    font-family: Georgia, Times, 'Times New Roman', serif;
    font-weight: 700;
    font-size: 2.66666667vw;
  }
  #TopKv .scroll .arrow2,
  #TopKv .scroll .arrow1 {
    background-image: url('../../img/top/kv/arrow_sp.png');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    width: 3.73333333vw;
    height: 2.66668267vw;
    text-indent: -9999px;
    display: block;
    position: absolute;
    left: 6vw;
    top: 6vw;
    right: auto;
    bottom: auto;
    z-index: 1;
  }
  #TopKv .scroll .arrow2 {
    top: 7.33333333vw;
  }
}
/* ipad */
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) {
  #TopKv .title_jp {
    margin-top: 3vh;
    line-height: 1.7;
  }
}
/*
====================================================
■ Mission
====================================================
*/
@media screen and (min-width: 769px), print {
  #Mission {
    position: relative;
    z-index: 10;
  }
  #Mission .ModContentsCenter {
    padding-bottom: 66px;
  }
  #Mission .box {
    width: 100%;
  }
  #Mission .box:after {
    content: " ";
    display: block;
    clear: both;
  }
  #Mission .box .left {
    position: relative;
    width: 50%;
    float: left;
  }
  #Mission .box .left .ph {
    background-image: url('../../img/top/mission/ph.jpg');
    background-repeat: no-repeat;
    background-position: center center;
    width: 640px;
    height: 426px;
    text-indent: -9999px;
    display: block;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 1;
  }
  #Mission .box .right {
    width: 50%;
    float: right;
    padding-left: 57px;
    position: relative;
  }
  #Mission .box .right h3 {
    font-family: "Noto Sans Japanese";
    font-weight: 700;
    font-size: 38px;
    line-height: 1.9;
    padding-top: 90px;
    letter-spacing: 0.2rem;
  }
  #Mission .box .right .txt {
    font-size: 16px;
    line-height: 2;
    font-weight: 700;
    padding-top: 38px;
  }
  #Mission .box .right .ModBtnMore {
    display: block;
    position: absolute;
    right: 0;
    bottom: 4px;
    left: auto;
    top: auto;
    z-index: 1;
  }
}
@media screen and (max-width: 768px) {
  #Mission {
    position: relative;
    z-index: 10;
  }
  #Mission .ModContentsCenter {
    padding-bottom: 66px;
  }
  #Mission .box {
    width: 100%;
  }
  #Mission .box:after {
    content: " ";
    display: block;
    clear: both;
  }
  #Mission .box .left {
    position: relative;
  }
  #Mission .box .left .ph {
    background-image: url('../../img/top/mission/ph_sp.jpg');
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    width: 60vw;
    height: 40.0002vw;
    display: block;
    text-indent: -9999px;
  }
  #Mission .box .right {
    position: relative;
  }
  #Mission .box .right h3 {
    font-family: "Noto Sans Japanese";
    font-weight: 700;
    font-size: 6.4vw;
    line-height: 1.9;
    padding-top: 10.4vw;
    letter-spacing: 0.15rem;
  }
  #Mission .box .right .txt {
    font-size: 3.73333333vw;
    line-height: 2;
    font-weight: 700;
    padding-top: 10.13333333vw;
  }
  #Mission .box .right .ModBtnMore {
    margin-top: 11.2vw;
  }
}
/*
====================================================
■ Report
====================================================
*/
@media screen and (min-width: 769px), print {
  #Report {
    position: relative;
    z-index: 10;
  }
  #Report .btnwrap {
    text-align: right;
    margin-top: 40px;
  }
}
@media screen and (max-width: 768px) {
  #Report {
    position: relative;
    z-index: 10;
  }
  #Report .btnwrap {
    text-align: right;
    margin-top: 10.66666667vw;
  }
}
/*
====================================================
■ Service
====================================================
*/
@media screen and (min-width: 769px), print {
  #Service {
    position: relative;
    z-index: 10;
  }
}
@media screen and (max-width: 768px) {
  #Service {
    position: relative;
    z-index: 10;
  }
}
/*
====================================================
■ Recruit
====================================================
*/
@media screen and (min-width: 769px), print {
  #Recruit {
    position: relative;
    z-index: 10;
    padding-bottom: 100px;
  }
}
@media screen and (max-width: 768px) {
  #Recruit {
    position: relative;
    z-index: 10;
  }
}
