@charset "utf-8";
@import url(./swiper.css);
@import url(./photoswipe.css);

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 100;
    src: url("../font/WorkSans-Thin.woff") format('woff'),
        url("../font/WorkSans-Thin.ttf") format('truetype');
}

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 200;
    src: url("../font/WorkSans-ExtraLight.woff") format('woff'),
        url("../font/WorkSans-ExtraLight.ttf") format('truetype');
}

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 300;
    src: url("../font/WorkSans-Light.woff") format('woff'),
        url("../font/WorkSans-Light.ttf") format('truetype');
}

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 400;
    src: url("../font/WorkSans-Regular.woff") format('woff'),
        url("../font/WorkSans-Regular.ttf") format('truetype');
}

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 500;
    src: url("../font/WorkSans-Medium.woff") format('woff'),
        url("../font/WorkSans-Medium.ttf") format('truetype');
}

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 600;
    src: url("../font/WorkSans-SemiBold.woff") format('woff'),
        url("../font/WorkSans-SemiBold.ttf") format('truetype');
}

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 700;
    src: url("../font/WorkSans-Bold.woff") format('woff'),
        url("../font/WorkSans-Bold.ttf") format('truetype');
}

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 800;
    src: url("../font/WorkSans-ExtraBold.woff") format('woff'),
        url("../font/WorkSans-ExtraBold.ttf") format('truetype');
}

@font-face {
    font-family: 'WorkSans';
    font-style: normal;
    font-weight: 900;
    src: url("../font/WorkSans-Black.woff") format('woff'),
        url("../font/WorkSans-Black.ttf") format('truetype');
}

@font-face {
    font-family: 'Geosans';
    src: url("../font/GeosansLight.woff") format('woff'),
        url("../font/GeosansLight.ttf") format('truetype');
}

.ffEn1 {
    font-family: 'WorkSans';
    font-weight: 200;
}

.ffEn2 {
    font-family: 'Geosans';
}


/* // base //
----------------------------------------------- */
body {
    color: #000;
    /*color:#444;*/
}

#Container {
    overflow: hidden;
    position: relative;
}

@media screen and (min-width: 1601px) {
    body {
        background-color: #f4f4f4 !important;
    }

    #Container {
        width: 1600px !important;
        margin: 0 auto;
        background-color: #FFF;
    }
}

a {
    color: #444;
    text-decoration: none;
}

a:hover {
    color: #777;
}

.widthFix {
    width: 1100px;
}

@media screen and (min-width: 741px) {
    .widthFixPC {
        width: 1100px;
    }
}

a.pageTop {
    font-size: 26px;
    width: 45px;
    height: 45px;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.65);
    -moz-border-radius: 0;
    -webkit-border-radius: 0;
    border-radius: 0;
}

html:not(.tbsp) a.pageTop:hover {
    background-color: #000;
}

a.btnA {
    background-color: #5B5C57;
    -ms-border-radius: 0px;
    -moz-border-radius: 0px;
    -webkit-border-radius: 0px;
    border-radius: 0px;
}

a.btnA i {
    color: #fff;
    font-size: 110%;
}

a.btnA:not(.white) {
    color: #fff;
}

a.btnA.black {
    background-color: #000;
}

a.btnA.red {
    background-color: #E61A19;
}

a.btnA.white,
a.btnA.white i {
    color: #5B5C57;
}

a.btnA.borderGray {
    border: 1px solid #5B5C57;
}

a.btnA.borderRed {
    border: 1px solid #E61A19;
}

a.btnA.radiusS {
    -ms-border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    border-radius: 20px;
    padding: 5px 25px;
    line-height: 1.0em;
    font-size: 13px;
    min-width: auto;
}

.fcRed {
    color: #E61A19 !important;
}





/* // ContentsWrap //
----------------------------------------------- */

#ContentsWrap {
    transition: 0.8s;
    transition-delay: 0.4s;
    opacity: 1;
    padding-bottom: 80px;
}

#ContentsWrap.default {
    opacity: 0;
}

/* // Header //
----------------------------------------------- */
#Header {
    margin-bottom: 0;
    background-color: #FFF;
}

.OLD #Header {
    margin-bottom: 0;
    ;
}

#Header>.inner {}

#Header .logo {
    vertical-align: middle;
}

#Header .logo img {
    height: 55px;
    width: auto;
}

#Header .logoEn {
    width: 220px;
    vertical-align: middle;
    margin-left: 25px;
    margin-top: -28px;
    -ms-transform: translateY(0px);
    -webkit-transform: translateY(0px);
    -moz-transform: translateY(0px);
    transform: translateY(0px);
    opacity: 0.66;
}

#Header .link {
    display: inline-block;
    vertical-align: middle;
    margin-left: 60px;
    margin-top: -28px;
    -ms-transform: translateY(0px);
    -webkit-transform: translateY(0px);
    -moz-transform: translateY(0px);
    transform: translateY(0px);
}

#Header .link li {
    line-height: 1;
    display: inline-block;
    margin-left: 10px;
}

#Header .link li a {
    font-weight: 500;
    display: block;
    background-color: #5B5C57;
    color: #FFF;
    padding: 4px 7px;
}

#Header .link li a:hover {
    background-color: #969691;
}

#Header .link li a i {
    font-size: 60%;
    vertical-align: middle;
}

#Header .logoGroup{
    display: block;
    position: absolute;
    top: 10px;
    right: -40px;
    width: 225px;
}
#Header .logoGroup img {
    width: 100%;
}

@media screen and (max-width: 740px) {
    #Header .logoGroup{
        display: none;
    }
}


/* //    |- HeaderContactBtn  */
#HeaderContactBtn {
    position: fixed;
    top: 0px;
    right: 0px;
    background-color: #000;
    width: 110px;
    height: 110px;
    overflow: hidden;
    z-index: 300;
    transition: 0.4s;
}

.tb #HeaderContactBtn {
    bottom: 0px;
    top: auto;
}

@media screen and (min-width: 1601px) {
    #HeaderContactBtn {
        right: 50%;
        -ms-transform: translateX(800px);
        -webkit-transform: translateX(800px);
        -moz-transform: translateX(800px);
        transform: translateX(800px);
    }
}


#HeaderContactBtn .wrap {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
}

#HeaderContactBtn .wrap .tx {
    position: absolute;
    display: block;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    line-height: 1;
    color: #FFF;
    white-space: nowrap;
    z-index: 10;
    transition: 0.4s;
    font-size: 100%;
}

#HeaderContactBtn .wrap .tx .en {
    display: block;
    font-weight: 700;
    text-align: center;
    font-size: 120%;
}

#HeaderContactBtn .wrap .tx .ja {
    display: block;
    text-align: center;
    opacity: 0.8;
    margin-top: 8px;
    font-weight: 200;
}

body:not(.print) #HeaderContactBtn.start {
    width: 100px;
    height: 61px;
}

#HeaderContactBtn.start .wrap .tx {
    font-size: 80%;
}

#HeaderContactBtn:before {
    content: " ";
    position: absolute;
    z-index: 10;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -ms-border-radius: 200px;
    -moz-border-radius: 200px;
    -webkit-border-radius: 200px;
    border-radius: 200px;
    display: block;
    width: 0;
    height: 0;
    background-color: #5B5C57;
    transition: 0.4s;
}

.pc #HeaderContactBtn:hover:before {
    width: 200%;
    height: 200%;
}


/* // #Header.fixed //
----------------------------------------------- */
body:not(.print) #Header.fixed {
    padding-bottom: 61px;
}

body:not(.print) #Header.fixed #GlobalNavi {
    position: fixed;
    left: 0;
    top: -1px;
    width: 100%;
    display: block;
    z-index: 200;
    transition: 0.4s;
}


/* // GlobalNavi //
----------------------------------------------- */
#GlobalNavi {
    border-top: 1px solid #ddd;
    border-bottom: 6px solid #5B5C57;
    background-color: #FFF;
}

#GlobalNavi .navi.parents {
    display: block;
    width: 100%;
    border-left: 1px solid #e3e3e3;
}

#GlobalNavi .navi.parents>li {
    display: block;
    float: left;
    width: 16.6%;
    border-right: 1px solid #e3e3e3;
    box-sizing: border-box;
    position: relative;
}

html.top #GlobalNavi .navi.parents>li {
    width: 20%;
}

#GlobalNavi .navi.parents>li a.parent {
    display: block;
    height: 54px;
    width: 100%;
    position: relative;
    overflow: hidden;
}

#GlobalNavi .navi.parents>li a.parent .tx {
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    line-height: 1;
    color: #000;
    z-index: 10;
    transition: 0.4s;
}

#GlobalNavi .navi.parents>li.on a.parent {
    background-color: #E61A19;
}

#GlobalNavi .navi.parents>li.on a.parent .tx {
    color: #fff;
}

#GlobalNavi .navi.parents>li.on a.parent .tx .ja {
    opacity: 1;
}

#GlobalNavi .navi.parents>li.on:after {}

#GlobalNavi .navi.parents>li a.parent .tx .en {
    display: block;
    font-weight: 700;
    text-align: center;
    font-size: 120%;
}

#GlobalNavi .navi.parents>li a.parent .tx .ja {
    display: block;
    text-align: center;
    opacity: 0.5;
    margin-top: 5px;
    font-weight: 500;
    font-size: 85%;
}

#GlobalNavi .navi.parents>li:after {
    content: " ";
    position: absolute;
    left: 50%;
    top: 100%;
    -ms-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    transform: translateX(-50%);
    height: 6px;
    width: 0%;
    background-color: #E61A19;
    transition: 0.3s;
}

.pc #GlobalNavi .navi.parents>li:not(.on):hover:after {
    width: 100%;
}

#GlobalNavi .navi.parents>li a.parent:before {
    content: " ";
    position: absolute;
    z-index: 10;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -ms-border-radius: 200px;
    -moz-border-radius: 200px;
    -webkit-border-radius: 200px;
    border-radius: 200px;
    display: block;
    width: 0;
    height: 0;
    background-color: #E61A19;
    transition: 0.3s;
}

.pc #GlobalNavi .navi.parents>li:not(.on):hover a.parent:before {
    width: 300px;
    height: 300px;
    transition: 0.5s;
}

.pc #GlobalNavi .navi.parents>li:not(.on):hover a.parent .tx {
    color: #FFF;
}

.pc #GlobalNavi .navi.parents>li:not(.on):hover a.parent .tx .ja {
    opacity: 1;
}

/* //    |- child  */

#GlobalNavi .navi.parents>li>.childWrap {
    z-index: 200;
    position: absolute;
    display: inline-block;
    top: 100%;
    left: 50%;
    -ms-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 270px;
    overflow: hidden;
    display: none;
    padding-top: 17px;
    padding-bottom: 40px;
}

.pc #GlobalNavi .navi.parents>li:hover>.childWrap {}

#GlobalNavi .navi.parents>li>.childWrap:before {
    width: 30px;
    height: 30px;
    position: absolute;
    top: 12px;
    left: 50%;
    -ms-transform: translateX(-50%) rotate(-45deg);
    -webkit-transform: translateX(-50%) rotate(-45deg);
    -moz-transform: translateX(-50%) rotate(-45deg);
    transform: translateX(-50%) rotate(-45deg);
    content: " ";
    background-color: #AAA;
}

#GlobalNavi .navi.parents>li>.childWrap a.child {
    display: block;
    line-height: 1;
    padding: 18px 5px;
    background-color: #8E8E8E;
    color: #FFF;
    text-align: center;
    position: relative;
    border-bottom: 1px solid #999;
    border-top: 1px solid #C6C6C6;
    overflow: hidden;
}

#GlobalNavi .navi.parents>li>.childWrap a.child.on {
    background-color: #5B5C57;
    border-top: 0;
    border-bottom: 0;
}

#GlobalNavi .navi.parents>li>.childWrap li:first-of-type a.child {
    border-top: 0;
}

#GlobalNavi .navi.parents>li>.childWrap li:last-of-type a.child {
    border-bottom: 0;
}

#GlobalNavi .navi.parents>li>.childWrap a.child:before {
    content: " ";
    position: absolute;
    z-index: 10;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -ms-border-radius: 200px;
    -moz-border-radius: 200px;
    -webkit-border-radius: 200px;
    border-radius: 200px;
    display: block;
    width: 0;
    height: 0;
    background-color: #5B5C57;
    transition: 0.3s;
}

.pc #GlobalNavi .navi.parents>li>.childWrap a.child:not(.on):hover:before {
    width: 300px;
    height: 300px;
    transition: 0.5s;
}

#GlobalNavi .navi.parents>li>.childWrap a.child .tx {
    z-index: 14;
    position: relative;
    display: block;
    text-align: center;
}

#GlobalNavi .navi.parents>li>.childWrap a.child i {
    position: absolute;
    top: 50%;
    right: 0;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

/* // BannerWrap //
----------------------------------------------- */
#BannerWrap {
    margin-bottom: 70px;
}

#BannerWrap img {
    max-width: 100%;
    margin: 0 auto;
    display: block;
}

@media screen and (min-width: 741px) {
    html.contact #BannerWrap {
        margin-top: 70px;
    }

    #BannerWrap .banner {
        display: flex;
        justify-content: center;
    }

    #BannerWrap .banner li {
        width: 48%;
    }

    #BannerWrap .banner li:nth-child(2) {
        margin-left: 4%;
    }
}

@media screen and (max-width: 740px) {
    #BannerWrap {
        margin-bottom: 50px;
    }

    #BannerWrap .banner li:nth-child(2) {
        margin-top: 30px;
    }
}

/* // Footer //
----------------------------------------------- */
#Footer {
    background-color: #EAEAEA;
}

/* //    |- upperBlock  */
#Footer .upperBlock {
    color: #555;
    padding-top: 45px;
    padding-bottom: 35px;
}

#Footer .upperBlock .logo img {
    width: 330px;
    position: absolute;
    left: 0px;
    bottom: -22px;
}

#Footer .upperBlock .menuWrap {
    width: 850px;
    color: #555;
}

#Footer .upperBlock .menuWrap .cellWrap {
    width: 100%;
}

#Footer .upperBlock .menuWrap .cellWrap .cell {
    width: 25%;
}

#Footer .upperBlock .menuWrap a {
    color: #333;
}

#Footer .upperBlock .menuWrap .menu li.parent {
    margin-bottom: 17px;
}

#Footer .upperBlock .menuWrap .menu li.parent em {
    font-weight: 500 !important;
    font-size: 108%;
}

#Footer .upperBlock .menuWrap .menu li {
    margin-bottom: 1px;
    line-height: 1.3;
    margin-bottom: 8px;
}

#Footer .upperBlock .menuWrap .menu li em {
    font-weight: 200 !important;
    font-size: 83%;
}

#Footer .upperBlock .menuWrap .menu li i {
    display: inline-block;
    margin-left: 4px;
}

#Footer .upperBlock .btnWrap {
    width: 350px;
}

#Footer .upperBlock .btnWrap .contact {
    margin-bottom: 28px;
}

#Footer .upperBlock .btnWrap .contact a {
    width: 100%;
    display: block;
    font-size: 170%;
    padding: 18px;
}

#Footer .upperBlock .btnWrap .access .htx {
    font-size: 150%;
    margin-bottom: 6px;
}

#Footer .upperBlock .btnWrap .access .btns li {
    margin-bottom: 22px;
}

#Footer .upperBlock .btnWrap .access .btns li .btn {
    background-color: #AAAAAA;
    width: 100%;
    display: block;
    margin-bottom: 3px;
}

#Footer .upperBlock .btnWrap .access .btns li .address {
    display: block;
    font-size: 83%;
    line-height: 1.4;
}

/* //    |- bottomBlock  */
#Footer .bottomBlock {
    background-color: #E61A19;
    color: #FFF;
    padding: 15px 0;
    line-height: 1;
}

#Footer .bottomBlock .menu li {
    display: inline-block;
    margin-right: 20px;
    font-size: 85%;
    ;
}

#Footer .bottomBlock .menu li a {
    color: #FFF;
}

#Footer .bottomBlock .copy {
    position: absolute;
    right: 0px;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: 80%;
    ;
}

/* // Breadcrumb //
----------------------------------------------- */
#Breadcrumb {
    position: relative;
    line-height: 1;
    z-index: 5;
}

#Breadcrumb .inner {
    position: absolute;
    top: 7px;
    left: 50%;
    margin-left: -550px;
}

#Breadcrumb ul {
    opacity: 0.7;
}

#Breadcrumb ul li {
    display: inline-block;
    font-size: 11px;
    margin-right: 25px;
    position: relative;
}

#Breadcrumb ul li:after {
    position: absolute;
    right: -19px;
    top: 50%;
    font-size: 85%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: '\e90e';
    font-family: iconfontA;
}

#Breadcrumb ul li:last-of-type:after {
    display: none;
}

#Breadcrumb.fcWhite a {
    color: #FFF;
}


/* // TEXT SETTING //
----------------------------------------------- */
/* //    |- PageTitleA  */
#PageTitleA {
    margin-bottom: 70px;
    position: relative;
    z-index: 3;
}

#PageTitleA .inner {
    width: 100%;
    height: 550px;
    position: relative;
    overflow: hidden;
}

#PageTitleA .image img {
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transfo rm: translate(-50%, -50%);
    width: 100%;
    z-index: 5;
}

#PageTitleA .txWrap {
    position: absolute;
    top: 47%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transfo rm: translate(-50%, -50%);
    width: 100%;
    z-index: 7;
    color: #FFF;
    line-height: 1;
}

#PageTitleA .en {
    text-align: center;
    font-weight: 100;
    margin-bottom: 17px;
    font-size: 170%;
    letter-spacing: 0.07em;
    opacity: 0.8;
}

#PageTitleA .ja {
    text-align: center;
    font-weight: 100;
    font-size: 250%;
    position: relative;
}

#PageTitleA .ja:before,
#PageTitleB .ja:before,
#PageTitleC .parentEn:before {
    position: absolute;
    left: 50%;
    bottom: -20px;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    content: ' ';
    width: 900px;
    height: 3px;
    background-color: #5D5F5B;
    display: block;
}

#PageTitleA .ja:after,
#PageTitleB .ja:after,
#PageTitleC .parentEn:after {
    position: absolute;
    left: 50%;
    bottom: -20px;
    -webkit-transform: translateX(-450px);
    -ms-transform: translateX(-450px);
    -webkit-transform: translateX(-450px);
    transform: translateX(-450px);
    content: ' ';
    width: 300px;
    height: 3px;
    background-color: #E10D20;
    display: block;
}

/* //    |- PageTitleB  */
#PageTitleB {
    margin-bottom: 50px;
    position: relative;
    z-index: 3;
}

#PageTitleB .inner {
    width: 100%;
    height: 180px;
    position: relative;
    overflow: hidden;
    background-color: #EEE;
}

#PageTitleB.noImage .inner {
    background-color: #eee;
}

#PageTitleB .image img {
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transfo rm: translate(-50%, -50%);
    width: 100%;
    z-index: 5;
    opacity: 0.22;
    -webkit-filter: grayscale(100%);
    filter: grayscale(100%);
}

#PageTitleB .txWrap {
    position: absolute;
    top: 47%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transfo rm: translate(-50%, -50%);
    width: 100%;
    z-index: 7;
    color: #000;
    /*color:#333;*/
    line-height: 1;
}

#PageTitleB .en {
    text-align: center;
    font-weight: 300;
    margin-bottom: 17px;
    font-size: 170%;
    letter-spacing: 0.07em;
    opacity: 0.8;
}

#PageTitleB .ja {
    text-align: center;
    font-weight: 300;
    font-size: 250%;
    position: relative;
}


/* //    |- PageTitleC  */
#PageTitleC {
    margin-bottom: 70px;
    position: relative;
    z-index: 3;
}

#PageTitleC .inner {
    width: 100%;
    height: 450px;
    position: relative;
    overflow: hidden;
}

#PageTitleC.small .inner {
    height: 250px;
}

#PageTitleC .image img {
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transfo rm: translate(-50%, -50%);
    height: 100%;
    width: auto;
    z-index: 5;
}

#PageTitleC.small .image img {
    height: auto;
    width: 100%;
}

#PageTitleC .txWrap {
    position: absolute;
    top: 47%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transfo rm: translate(-50%, -50%);
    width: 100%;
    z-index: 7;
    color: #FFF;
    line-height: 1;
}

#PageTitleC .parentEn {
    text-align: center;
    font-weight: 100;
    padding-bottom: 14px;
    margin-bottom: 20px;
    font-size: 190%;
    letter-spacing: 0.07em;
    opacity: 1;
    position: relative;
}

#PageTitleC .parentEn:before {
    bottom: 0px;
    width: 500px;
}

#PageTitleC .parentEn:after {
    bottom: 0px;
    width: 166px;
    -webkit-transform: translateX(-250px);
    -ms-transform: translateX(-250px);
    -webkit-transform: translateX(-250px);
    transform: translateX(-250px);
}

#PageTitleC .titEn {
    text-align: center;
    font-weight: 200;
    margin-bottom: 14px;
    font-size: 340%;
    letter-spacing: 0.07em;
}

#PageTitleC .titJa {
    text-align: center;
    font-weight: 600;
    font-size: 190%;
}

/* //    |- titleTxA  */
.titleTxA {
    margin-bottom: 40px;
    line-height: 1.4;
}

.titleTxA .en {
    display: block;
    font-family: 'WorkSans';
    font-weight: 700;
    text-align: center;
    font-size: 260%;
    margin-bottom: 7px;
    color: #474747;
}

.titleTxA .ja {
    display: block;
    text-align: center;
    font-size: 130%;
    font-weight: 100;
}

.titleTxA .ja.main {
    font-size: 230%;
    font-weight: 200;
}

.titleTxA.line {
    text-align: center;
    overflow: hidden;
}

.titleTxA.line .tx {
    position: relative;
    z-index: 2;
    display: inline-block;
}

.titleTxA.line .tx:after,
.titleTxA.line .tx:before {
    content: " ";
    position: absolute;
    display: block;
    width: 1000px;
    height: 22px;
    background-color: #5B5C57;
    top: 50%;
}

.titleTxA.line.s .tx:after,
.titleTxA.line.s .tx:before {
    height: 14px;
}

.titleTxA.line .tx:after {
    left: 100%;
    -ms-transform: translate(40px, -50%);
    -webkit-transform: translate(40px, -50%);
    -moz-transform: translate(40px, -50%);
    transform: translate(40px, -50%);
}

.titleTxA.line .tx:before {
    right: 100%;
    -ms-transform: translate(-40px, -50%);
    -webkit-transform: translate(-40px, -50%);
    -moz-transform: translate(-40px, -50%);
    transform: translate(-40px, -50%);
}

.titleTxA.line.red .tx:after,
.titleTxA.line.red .tx:before {
    background-color: #E61A19;
}

.titleTxA.line.gray .tx:after,
.titleTxA.line.gray .tx:before {
    background-color: #5B5C57;
}


/* //    |- titleTxB  */
.titleTxB {
    margin-bottom: 30px;
    line-height: 1.4;
    text-align: center;
    font-size: 170%;
}

.titleTxB em {
    display: inline-block;
}

.titleTxB.line em {
    border-bottom: 3px solid #000;
    padding: 0 35px 15px;
    position: relative;
}

.titleTxB.line.red.gray em:before {
    position: absolute;
    bottom: -3px;
    left: 0px;
    width: 33.3%;
    height: 3px;
    display: block;
    content: " ";
    background-color: #E61A19;
}

.titleTxB.taLeft em {
    padding: 0 11px 15px;
}

.titleTxB.line.red em {
    border-color: #E61A19
}

.titleTxB.line.gray em {
    border-color: #5B5C57
}

.titleTxB.line.red.gray em {
    border-color: #5B5C57
}



/* //    |- titleTxC  */
.titleTxC {
    margin-bottom: 15px;
    padding-bottom: 11px;
    line-height: 1.45;
    text-align: center;
    font-size: 121%;
    border-bottom: 1px solid #D5D5D5;
}

.titleTxC em {
    display: inline-block;
}

.titleTxC.noline {
    margin-bottom: 13px;
    padding-bottom: 0;
    border-bottom: 0;
}


/* //    |- titleTxD  */
.titleTxD {
    margin-bottom: 35px;
    line-height: 1.4;
    text-align: center;
    overflow: hidden;
}

.titleTxD .tx {
    position: relative;
    z-index: 2;
    display: inline-block;
    font-size: 210%;
    font-weight: 100;
}

.titleTxD .tx:after,
.titleTxD .tx:before {
    content: " ";
    position: absolute;
    display: block;
    width: 1000px;
    height: 7px;
    background-color: #5B5C57;
    top: 50%;
}

.titleTxD.line3 .tx:after,
.titleTxD.line3 .tx:before {
    height: 3px;
}

.titleTxD.line1 .tx:after,
.titleTxD.line1 .tx:before {
    height: 1px;
}

.titleTxD .tx:after {
    left: 100%;
    -ms-transform: translate(40px, -50%);
    -webkit-transform: translate(40px, -50%);
    -moz-transform: translate(40px, -50%);
    transform: translate(40px, -50%);
}

.titleTxD .tx:before {
    right: 100%;
    -ms-transform: translate(-40px, -50%);
    -webkit-transform: translate(-40px, -50%);
    -moz-transform: translate(-40px, -50%);
    transform: translate(-40px, -50%);
}

.titleTxD.red .tx:after,
.titleTxD.red .tx:before {
    background-color: #E61A19;
}

.titleTxD.gray .tx:after,
.titleTxD.gray .tx:before {
    background-color: #5B5C57;
}


/* //    |- titleTxE  */
.titleTxE {
    margin-bottom: 40px;
    line-height: 1.3;
    text-align: center;
    overflow: hidden;
}

.titleTxE .en {
    display: block;
    text-align: center;
    font-weight: 200;
    font-size: 320%;
    color: #E61A19;
    margin-bottom: 10px;
}

.titleTxE .ja {
    display: block;
    text-align: center;
    font-weight: 400;
    font-size: 110%;
}

/* //    |- titleTxF  */
.titleTxF {
    margin-bottom: 50px;
    line-height: 1.3;
    text-align: center;
}

.titleTxF .tx {
    display: inline-block;
    text-align: center;
    padding: 0 50px 15px;
    font-size: 220%;
    min-width: 600px;
    position: relative;
    background-image: linear-gradient(to right, #E61A19 33.3%, #5B5C57 33.3%);
    background-position: center bottom;
    background-size: 100% 4px;
    background-repeat: no-repeat;
}


/* //    |- titleTxG  */
.titleTxG {
    display: block;
    position: relative;
    line-height: 1;
    text-align: center;
    margin-bottom: 35px;
}

.titleTxG:before {
    display: block;
    content: " ";
    background-color: #565753;
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0px;
    top: 50%;
    -ms-transform: translateY(1px);
    -webkit-transform: translateY(1px);
    -moz-transform: translateY(1px);
    transform: translateY(1px);
}

.titleTxG .tx {
    display: inline-block;
    background-color: #fff;
    padding: 0 32px;
    position: relative;
    z-index: 5;
}

.titleTxG .tx:before {
    display: block;
    content: " ";
    background-color: #E10D20;
    width: 90px;
    height: 3px;
    position: absolute;
    top: 50%;
    left: 0px;
    -ms-transform: translateX(-100%);
    -webkit-transform: translateX(-100%);
    -moz-transform: translateX(-100%);
    transform: translateX(-100%);
}

.titleTxG .tx:after {
    display: block;
    content: " ";
    background-color: #E10D20;
    width: 90px;
    height: 3px;
    position: absolute;
    top: 50%;
    right: 0px;
    -ms-transform: translateX(100%);
    -webkit-transform: translateX(100%);
    -moz-transform: translateX(100%);
    transform: translateX(100%);
}

.titleTxG .tx .ja {
    display: block;
    font-weight: 500;
    font-size: 160%;
    text-align: center;
    position: relative;
}

.titleTxG .tx .en {
    display: block;
    color: #E10D20;
    font-weight: 500;
    font-size: 94%;
    text-align: center;
    margin-top: 6px;
    position: relative;
    top: 4px;
}

/* //    |- hTx  */
.hTxA {
    margin-bottom: 20px;
    line-height: 1.55;
    text-align: center;
    font-size: 140%;
}

.hTxA.l {
    font-size: 150%;
}

.hTxA.s {
    font-size: 130%;
}


/* // PageMv //
----------------------------------------------- */
/* //    |- PageMvA  */
#PageMvA {
    margin-bottom: 100px;
}

#PageMvA .wrap {
    display: block;
    text-align: left;
    position: relative;
}

#PageMvA .image {}

#PageMvA .txBox {
    position: absolute;
    bottom: -40px;
    left: 50%;
    background-color: #E61A19;
    width: 50%;
    height: 320px;
    display: block;
}

#PageMvA .txBox:before {
    position: absolute;
    display: block;
    content: " ";
    left: 0px;
    top: 0px;
    width: 80px;
    height: 80px;
    background-color: #5B5C57;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

#PageMvA .txBox:after {
    position: absolute;
    display: block;
    content: " ";
    right: -70px;
    bottom: -70px;
    width: 140px;
    height: 140px;
    background-color: #fff;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}

#PageMvA .txBox .in {
    width: 100%;
    height: 100%;
    display: block;
    position: relative;
}

#PageMvA .txBox .txWrap {
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 100%;
    display: block;
    padding: 15px;
}

#PageMvA .txBox .txWrap p {
    color: #FFF;
    font-size: 260%;
    line-height: 1.3;
    font-weight: 100;
    text-align: center;
}


/* // section //
----------------------------------------------- */
/* //    |- sectionA  */
.sectionA {
    padding: 80px 0;
}

.sectionA.s {
    padding: 57px 0;
}

.sectionA.bg1 {
    background-color: #F4F4F4;
}

.sectionA.bg2 {
    background-color: #f0f0f0;
}

/* //    |- sectionB  */
.sectionB {
    margin-bottom: 80px;
}

.sectionB:last-of-type {
    margin-bottom: 30px;
}


/* // parallelSection //
----------------------------------------------- */
.parallelSection {
    display: table;
    width: 100%;
}

.parallelSection .block {
    display: table-cell;
    vertical-align: top;
}

.parallelSection.col2 .block {
    width: 50%;
}

.parallelSection.col2 .block:nth-of-type(odd) {
    padding-right: 30px;
}

.parallelSection.col2 .block:nth-of-type(even) {
    padding-left: 30px;
}

.parallelSection.col3 .block {
    width: 33.3%;
}

.parallelSection.col3 .block:nth-of-type(3n+1) {
    padding-right: 40px;
}

.parallelSection.col3 .block:nth-of-type(3n+2) {
    padding-right: 20px;
    padding-left: 20px;
}

.parallelSection.col3 .block:nth-of-type(3n) {
    padding-left: 40px;
}



/* // tabNavi //
----------------------------------------------- */
/* //    |- tabNaviA  */
.tabNaviA {
    max-width: 1200px;
    margin: 0 auto 40px;
}

.tabNaviA .btns {
    text-align: center;
}

.tabNaviA .btns li {
    display: inline-block;
    line-height: 1.4;
    margin: 0 5px 12px;
}

.tabNaviA .btns li a {
    display: block;
    border: 1px solid #9E9E9E;
    position: relative;
    color: #666;
    text-align: center;
    min-width: 227px;
    overflow: hidden;
}

.tabNaviA.s .btns li a {
    min-width: 180px;
}

.tabNaviA.red .btns li a {
    border: 0;
    color: #fff;
    background-color: #E61A19;
}

.tabNaviA .btns li a:after {
    content: " ";
    width: 0;
    height: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    background-color: rgba(0, 0, 0, 0.1);
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -ms-border-radius: 100%;
    -moz-border-radius: 100%;
    -webkit-border-radius: 100%;
    border-radius: 100%;
    transition: 0.4s;
}

.pc .tabNaviA .btns li a:hover:after {
    width: 400px;
    height: 400px;
}

.tabNaviA .btns li a i {
    position: absolute;
    top: 50%;
    right: 6px;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    z-index: 2;
}

.tabNaviA .btns li a .tx {
    position: relative;
    z-index: 2;
    display: block;
    padding: 14px 33px 14px 20px;
    text-align: center;
}

.tabNaviA.s .btns li a .tx {
    padding: 10px 23px 10px 10px;
}

.tabNaviA .btns.on1 li:nth-of-type(1) a,
.tabNaviA .btns.on2 li:nth-of-type(2) a,
.tabNaviA .btns.on3 li:nth-of-type(3) a,
.tabNaviA .btns.on4 li:nth-of-type(4) a,
.tabNaviA .btns.on5 li:nth-of-type(5) a,
.tabNaviA .btns.on6 li:nth-of-type(6) a,
.tabNaviA .btns.on7 li:nth-of-type(7) a,
.tabNaviA .btns.on8 li:nth-of-type(8) a,
.tabNaviA .btns.on9 li:nth-of-type(9) a,
.tabNaviA .btns.on10 li:nth-of-type(10) a,
.tabNaviA .btns li.on a,
.____ {
    color: #FFF;
    border-color: #5B5C57;
}

.tabNaviA .btns.on1 li:nth-of-type(1) a:after,
.tabNaviA .btns.on2 li:nth-of-type(2) a:after,
.tabNaviA .btns.on3 li:nth-of-type(3) a:after,
.tabNaviA .btns.on4 li:nth-of-type(4) a:after,
.tabNaviA .btns.on5 li:nth-of-type(5) a:after,
.tabNaviA .btns.on6 li:nth-of-type(6) a:after,
.tabNaviA .btns.on7 li:nth-of-type(7) a:after,
.tabNaviA .btns.on8 li:nth-of-type(8) a:after,
.tabNaviA .btns.on9 li:nth-of-type(9) a:after,
.tabNaviA .btns.on10 li:nth-of-type(10) a:after,
.tabNaviA .btns li.on a:after,
.____ {
    width: 400px;
    height: 400px;
    background-color: #5B5C57;
}

.tabNaviA .btns.on1 li:nth-of-type(1) a i,
.tabNaviA .btns.on2 li:nth-of-type(2) a i,
.tabNaviA .btns.on3 li:nth-of-type(3) a i,
.tabNaviA .btns.on4 li:nth-of-type(4) a i,
.tabNaviA .btns.on5 li:nth-of-type(5) a i,
.tabNaviA .btns.on6 li:nth-of-type(6) a i,
.tabNaviA .btns.on7 li:nth-of-type(7) a i,
.tabNaviA .btns.on8 li:nth-of-type(8) a i,
.tabNaviA .btns.on9 li:nth-of-type(9) a i,
.tabNaviA .btns.on10 li:nth-of-type(10) a i,
.tabNaviA .btns li.on a i,
.____ {
    display: none;
}

/* //    |- tabNaviB  */
.tabNaviB {
    max-width: 1200px;
    margin: 0 auto 30px;
}

.tabNaviB .btns {
    text-align: center;
}

.tabNaviB .btns li {
    display: inline-block;
    line-height: 1.3;
    margin: 0 7px 11px;
}

.tabNaviB .btns li a {
    display: block;
    border-bottom: 1px solid #7E7E7E;
    position: relative;
    color: #000;
    text-align: center;
    min-width: 130px;
}

.tabNaviB .btns li a .tx {
    position: relative;
    z-index: 2;
    display: block;
    padding: 11px 16px;
    text-align: center;
}

.tabNaviB .btns li a i {
    display: inline-block;
    vertical-align: middle;
    margin-left: 14px;
    position: relative;
    top: -2px;
    font-size: 80%;
    padding: 0;
}

.tabNaviB .btns li a:after {
    content: " ";
    width: 0%;
    height: 3px;
    position: absolute;
    bottom: 0;
    left: 50%;
    background-color: #494949;
    transform: translate(-50%, 2px);
    transition: 0.27s;
}

.pc .tabNaviB .btns li a:hover:after {
    width: 100%;
}

.tabNaviB .btns.on1 li:nth-of-type(1) a .tx em,
.tabNaviB .btns.on2 li:nth-of-type(2) a .tx em,
.tabNaviB .btns.on3 li:nth-of-type(3) a .tx em,
.tabNaviB .btns.on4 li:nth-of-type(4) a .tx em,
.tabNaviB .btns.on5 li:nth-of-type(5) a .tx em,
.tabNaviB .btns.on6 li:nth-of-type(6) a .tx em,
.tabNaviB .btns.on7 li:nth-of-type(7) a .tx em,
.tabNaviB .btns.on8 li:nth-of-type(8) a .tx em,
.tabNaviB .btns.on9 li:nth-of-type(9) a .tx em,
.tabNaviB .btns.on10 li:nth-of-type(10) a .tx em,
.tabNaviB .btns li.on a .tx em,
.____ {
    font-weight: 500;
}

.tabNaviB .btns.on1 li:nth-of-type(1) a:after,
.tabNaviB .btns.on2 li:nth-of-type(2) a:after,
.tabNaviB .btns.on3 li:nth-of-type(3) a:after,
.tabNaviB .btns.on4 li:nth-of-type(4) a:after,
.tabNaviB .btns.on5 li:nth-of-type(5) a:after,
.tabNaviB .btns.on6 li:nth-of-type(6) a:after,
.tabNaviB .btns.on7 li:nth-of-type(7) a:after,
.tabNaviB .btns.on8 li:nth-of-type(8) a:after,
.tabNaviB .btns.on9 li:nth-of-type(9) a:after,
.tabNaviB .btns li.on a:after,
.____ {
    width: 100%;
}

.tabNaviB .btns.on1 li:nth-of-type(1) a i,
.tabNaviB .btns.on2 li:nth-of-type(2) a i,
.tabNaviB .btns.on3 li:nth-of-type(3) a i,
.tabNaviB .btns.on4 li:nth-of-type(4) a i,
.tabNaviB .btns.on5 li:nth-of-type(5) a i,
.tabNaviB .btns.on6 li:nth-of-type(6) a i,
.tabNaviB .btns.on7 li:nth-of-type(7) a i,
.tabNaviB .btns.on8 li:nth-of-type(8) a i,
.tabNaviB .btns.on9 li:nth-of-type(9) a i,
.tabNaviB .btns.on10 li:nth-of-type(10) a i,
.tabNaviB .btns li.on a i,
.____ {
    display: none;
}


.tabNaviB.year .btns li {
    margin-left: 5px;
    margin-right: 5px
}

.tabNaviB.year .btns li a {
    min-width: 100px
}

/* //    |- tabNaviC  */
.tabNaviC {
    margin: 0 auto 65px;
    background-color: #E61A19;
}

.tabNaviC ul {
    text-align: center;
}

.tabNaviC ul li {
    display: inline-block;
    margin-right: -2px;
}

.tabNaviC ul li a {
    display: block;
    color: #fff;
    line-height: 1.35;
    padding: 32px 32px;
    position: relative;
    min-width: 240px;
    text-align: center;
}

.tabNaviC ul li a:after {
    content: " ";
    display: block;
    width: 1px;
    height: 50px;
    background-color: #FFF;
    position: absolute;
    top: 50%;
    right: 0px;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    opacity: 0.4;
}

.tabNaviC ul li:first-of-type a:before {
    content: " ";
    display: block;
    width: 1px;
    height: 50px;
    background-color: #FFF;
    position: absolute;
    top: 50%;
    left: 0px;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    opacity: 0.4;
}

.tabNaviC ul li a i {
    padding-left: 20px;
    position: relative;
    transition: 0.3s;
    top: 0;
}

.tabNaviC ul li a:hover i {
    top: 3px;
}

.tabNaviC ul li a:hover {
    background-color: rgba(0, 0, 0, 0.1);
}

/* //    |- tabNaviD  */
.tabNaviD {}

.tabNaviD ul {
    text-align: center;
}

.tabNaviD ul li {
    display: inline-block;
    line-height: 1.3;
    margin: 0 8px;
    white-space: nowrap;
}

.tabNaviD ul li a {
    display: block;
}

.tabNaviD ul.col4 li a {
    width: 260px;
}

.tabNaviD ul.col3 li a {
    width: 300px;
}

.tabNaviD ul li a .image {
    display: block;
    width: 100%;
    height: 165px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    margin-bottom: 35px;
}

.tabNaviD ul li a .image:after {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    content: " ";
    transition: 0.3s;
}

.tabNaviD ul li a:hover .image:after {
    opacity: 0;
}

.tabNaviD ul li a .tx {
    display: block;
    text-align: center;
    font-size: 104%;
    font-weight: 400;
    position: relative;
}

.tabNaviD ul li a .tx:before {
    display: none;
    width: 100%;
    height: 1px;
    background-color: #E61A19;
    content: " ";
    position: absolute;
    top: -15px;
    left: 0px;
}

.tabNaviD ul li a .tx:after {
    display: none;
    position: absolute;
    left: 50%;
    top: -13px;
    font-size: 90%;
    line-height: 1;
    -ms-transform: translate(-50%, -100%);
    -webkit-transform: translate(-50%, -100%);
    -moz-transform: translate(-50%, -100%);
    transform: translate(-50%, -100%);
    content: '\e91b';
    font-family: iconfontA;
    color: #E61A19;
}


.tabNaviD ul.on1 li:nth-of-type(1) a .tx,
.tabNaviD ul.on2 li:nth-of-type(2) a .tx,
.tabNaviD ul.on3 li:nth-of-type(3) a .tx,
.tabNaviD ul.on4 li:nth-of-type(4) a .tx,
.tabNaviD ul.on5 li:nth-of-type(5) a .tx,
.tabNaviD ul.on6 li:nth-of-type(6) a .tx {
    color: #E61A19;
    font-weight: 500;
}

.tabNaviD ul.on1 li:nth-of-type(1) a .image:after,
.tabNaviD ul.on2 li:nth-of-type(2) a .image:after,
.tabNaviD ul.on3 li:nth-of-type(3) a .image:after,
.tabNaviD ul.on4 li:nth-of-type(4) a .image:after,
.tabNaviD ul.on5 li:nth-of-type(5) a .image:after,
.tabNaviD ul.on6 li:nth-of-type(6) a .image:after {
    opacity: 0;
}

.tabNaviD ul.on1 li:nth-of-type(1) a .tx:before,
.tabNaviD ul.on1 li:nth-of-type(1) a .tx:after,
.tabNaviD ul.on2 li:nth-of-type(2) a .tx:before,
.tabNaviD ul.on2 li:nth-of-type(2) a .tx:after,
.tabNaviD ul.on3 li:nth-of-type(3) a .tx:before,
.tabNaviD ul.on3 li:nth-of-type(3) a .tx:after,
.tabNaviD ul.on4 li:nth-of-type(4) a .tx:before,
.tabNaviD ul.on4 li:nth-of-type(4) a .tx:after,
.tabNaviD ul.on5 li:nth-of-type(5) a .tx:before,
.tabNaviD ul.on5 li:nth-of-type(5) a .tx:after,
.tabNaviD ul.on6 li:nth-of-type(6) a .tx:before,
.tabNaviD ul.on6 li:nth-of-type(6) a .tx:after {
    display: block;
}


/* // ServiceIndex //
----------------------------------------------- */
#ServiceIndex {}

#ServiceIndex .serviceItem {
    margin-bottom: 65px;
    position: relative;
}

@media screen and (min-width: 741px) {
    #ServiceIndex .serviceItem .widthFix {
        width: 1100px;
    }
}

#ServiceIndex .serviceItem .bg {
    height: 400px;
    width: 100%;
    position: absolute;
    left: 0px;
    top: 20px;
    overflow: hidden;
}

#ServiceIndex .serviceItem .bg img {
    height: 380px;
    width: 100%;
    position: absolute;
    left: 0px;
    top: 30px;
    overflow: hidden;
}

#ServiceIndex .serviceItem .mainBlock {
    text-align: right;
    position: relative;
    z-index: 10;
}

#ServiceIndex .serviceItem .box {
    display: inline-block;
    min-height: 420px;
    width: 500px;
    background-color: #E10D20;
    color: #FFF;
    position: relative;
    padding: 45px 40px;
    -moz-box-shadow: 10px 10px 0 #5B5C57;
    -webkit-box-shadow: 10px 10px 0 #5B5C57;
    box-shadow: 10px 10px 0 #5B5C57;
    z-index: 10;
}

html.top #ServiceIndex .serviceItem .box {
    width: 450px;
}

#ServiceIndex .serviceItem .box .name {
    line-height: 1.3;
    font-weight: 700;
    font-size: 220%;
    margin-bottom: 23px;
}

#ServiceIndex .serviceItem .box .company {
    line-height: 1.3;
    font-size: 92%;
    margin-top: -18px;
    margin-bottom: 23px;
}

#ServiceIndex .serviceItem .box .htx {
    line-height: 1.6;
    font-weight: 500;
    font-size: 140%;
    margin-bottom: 23px;
}

#ServiceIndex .serviceItem .box .description {
    line-height: 2;
    font-size: 90%;
    margin-bottom: 23px;
}

#ServiceIndex .serviceItem .box .btn {
    text-align: center;
}

#ServiceIndex .serviceItem .box .btn a {
    width: 100%;
    padding: 18px;
    position: relative;
    overflow: hidden;
}

#ServiceIndex .serviceItem .box .btn a:hover {
    opacity: 1;
}

.pc #ServiceIndex .serviceItem .box .btn a:before {
    content: " ";
    position: absolute;
    z-index: 10;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -ms-border-radius: 200px;
    -moz-border-radius: 200px;
    -webkit-border-radius: 200px;
    border-radius: 200px;
    display: block;
    width: 0;
    height: 0;
    background-color: #464743;
    transition: 0.4s;
    z-index: 3;
}

.pc #ServiceIndex .serviceItem .box .btn a:hover:before {
    width: 500px;
    height: 400px;
}

#ServiceIndex .serviceItem .box .btn a .tx {
    font-weight: 600;
    font-size: 110%;
    position: relative;
    z-index: 5;
}

#ServiceIndex .serviceItem .box .btn a i {
    z-index: 5;
}

#ServiceIndex .serviceItem .enName {
    line-height: 1;
    text-align: right;
    margin-top: 30px;
    position: relative;
    z-index: 8;
}

#ServiceIndex .serviceItem .enName .tx {
    font-weight: 700;
    font-size: 70px;
    color: #5B5C57;
}

#ServiceIndex .serviceItem .image {
    position: absolute;
    bottom: 10px;
    left: 0px;
    width: 750px;
    height: 480px;
    overflow: hidden;
    z-index: 5;
}

html.top #ServiceIndex .serviceItem .image {
    height: 430px;
}

#ServiceIndex .serviceItem .image .in {
    position: relative;
    width: 100%;
    height: 100%;
    display: block;
}

#ServiceIndex .serviceItem .image .in img {
    position: absolute;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 100%;
}

#ServiceIndex .serviceItem:nth-of-type(even) .mainBlock {
    text-align: left;
}

#ServiceIndex .serviceItem:nth-of-type(even) .enName {
    text-align: left;
}

#ServiceIndex .serviceItem:nth-of-type(even) .image {
    left: auto;
    right: 0;
    width: 750px;
}

/* //    |- appealPoint  */
#ServiceIndex .serviceItem .appealPoint {
    margin-top: 28px;
}

#ServiceIndex .serviceItem .appealPoint .title {
    display: block;
    position: relative;
    line-height: 1;
    text-align: center;
    margin-bottom: 15px;
}

#ServiceIndex .serviceItem .appealPoint .title:before {
    display: block;
    content: " ";
    background-color: #565753;
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0px;
    top: 50%;
    -ms-transform: translateY(1px);
    -webkit-transform: translateY(1px);
    -moz-transform: translateY(1px);
    transform: translateY(1px);
}

#ServiceIndex .serviceItem .appealPoint .title .tx {
    display: inline-block;
    background-color: #fff;
    padding: 0 32px;
    position: relative;
    z-index: 5;
}

#ServiceIndex .serviceItem .appealPoint .title .tx:before {
    display: block;
    content: " ";
    background-color: #E10D20;
    width: 90px;
    height: 3px;
    position: absolute;
    top: 50%;
    left: 0px;
    -ms-transform: translateX(-100%);
    -webkit-transform: translateX(-100%);
    -moz-transform: translateX(-100%);
    transform: translateX(-100%);
}

#ServiceIndex .serviceItem .appealPoint .title .tx:after {
    display: block;
    content: " ";
    background-color: #E10D20;
    width: 90px;
    height: 3px;
    position: absolute;
    top: 50%;
    right: 0px;
    -ms-transform: translateX(100%);
    -webkit-transform: translateX(100%);
    -moz-transform: translateX(100%);
    transform: translateX(100%);
}

#ServiceIndex .serviceItem .appealPoint .title .tx .ja {
    display: block;
    font-weight: 500;
    font-size: 120%;
    text-align: center;
    position: relative;
    top: 4px;
}

#ServiceIndex .serviceItem .appealPoint .title .tx .en {
    display: block;
    color: #E10D20;
    font-weight: 500;
    font-size: 94%;
    text-align: center;
    margin-top: 6px;
    position: relative;
    top: 4px;
}

#ServiceIndex .serviceItem .appealPoint .pointWrap {
    display: table;
    width: 100%;
    margin: 0 auto;
}

#ServiceIndex .serviceItem .appealPoint .pointWrap .point {
    display: table-cell;
    width: 25%;
    padding: 18px 26px 26px;
    border-right: 1px dotted #DDD;
}

#ServiceIndex .serviceItem .appealPoint .pointWrap .point .icon {
    padding-bottom: 10px;
}

#ServiceIndex .serviceItem .appealPoint .pointWrap.col3 {
    width: 80%;
}

#ServiceIndex .serviceItem .appealPoint .pointWrap.col3 .point {
    width: 33.3%;
    padding-right: 30px;
    padding-left: 30px;
}

#ServiceIndex .serviceItem .appealPoint .pointWrap .point:first-of-type {
    border-left: 1px dotted #DDD;
}

#ServiceIndex .serviceItem .appealPoint .pointWrap .point .tx p {
    font-size: 90%;
    font-weight: 500;
    text-align: center;
    line-height: 1.5;
}



/* // TopOtherService //
----------------------------------------------- */
#TopOtherService {
    background-color: #F3F3F3;
    padding: 45px;
}

#TopOtherService .title {
    text-align: center;
    margin-bottom: 26px;
    line-height: 1;
}

#TopOtherService .title .tx {
    color: #D1D1D0;
    font-weight: 700;
    font-size: 240%;
}

#TopOtherService .itemWrap {
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
}

#TopOtherService .itemWrap .item {
    width: calc(100% / 3 - 28px);
    margin: 0 13px;
    background-color: #FFF;
}

#TopOtherService .itemWrap .item>a {
    display: block;
    background-color: #FFF;
    color: #333;
    transition: 0.3s: position:relative;
}

#TopOtherService .itemWrap .item .image {
    display: block;
    width: 100%;
}

#TopOtherService .itemWrap .item .image img {
    width: 100%;
}

#TopOtherService .itemWrap .item .text {
    padding: 22px 22px 43px;
}

#TopOtherService .itemWrap .item .text .name {
    line-height: 1.3;
    font-weight: 500;
    font-size: 110%;
    margin-bottom: 16px;
}

#TopOtherService .itemWrap .item .text .name .company {
    display: block;
    font-size: 65%;
    margin-top: 4px;
}

#TopOtherService .itemWrap .item .text .description {
    line-height: 1.6;
    font-size: 88%;
    font-weight: 400;
    color: #999;
}

#TopOtherService .itemWrap .item a .text .linkIcon {
    position: absolute;
    bottom: 0px;
    right: 0;
    display: block;
    width: 44px;
    height: 44px;
    background-image: linear-gradient(to right, #E10D20 50%, #AA0311 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: 0.3s;
}

#TopOtherService .itemWrap .item a .text .linkIcon .in {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
}

#TopOtherService .itemWrap .item a .text .linkIcon .in i {
    color: #FFF;
    position: absolute;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

#TopOtherService .itemWrap .item a:hover .text .linkIcon {
    background-position: -100% 0;
    color: #fff;
}


/* // TopContentsMenu //
----------------------------------------------- */
#TopContentsMenu {
    margin-top: 75px;
}

#TopContentsMenu .cellWrap {
    margin-bottom: 24px;
    width: 100%;
}

#TopContentsMenu .cell {
    width: 50%;
}

#TopContentsMenu .cell a {
    display: block;
    width: 100%;
    height: 220px;
    position: relative;
}

#TopContentsMenu .cell:first-of-type {
    padding-right: 12px;
}

#TopContentsMenu .cell:last-of-type {
    padding-left: 12px;
}

#TopContentsMenu .cell .image {
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
    background-color: #000;
}

#TopContentsMenu .cell .image img {
    position: absolute;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 100%;
    -webkit-filter: grayscale(100%);
    filter: grayscale(100%);
    opacity: 0.6;
}

.pc #TopContentsMenu .cell a:hover .image img {
    -webkit-filter: grayscale(0%);
    filter: grayscale(0%);
    opacity: 0.8;
}

#TopContentsMenu .cell .title {
    display: block;
    position: absolute;
    left: 0px;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    color: #FFF;
    line-height: 1;
}

#TopContentsMenu .cell .title .tx {
    position: relative;
    padding-left: 75px;
}

#TopContentsMenu .cell .title .tx:after {
    content: " ";
    position: absolute;
    left: -8px;
    top: 52%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    height: 8px;
    width: 45px;
    background-color: #E10D20;
    transition: 0.3s;
}

#TopContentsMenu .cell .title .ja {
    font-weight: 600;
    font-size: 170%;
    padding-right: 40px;
    display: inline-block;
    vertical-align: middle;
}

#TopContentsMenu .cell .title .en {
    font-weight: 300;
    font-size: 100%;
    display: inline-block;
    vertical-align: middle;
}

/* // InfoIndex //
----------------------------------------------- */
#InfoIndex {
    margin-top: 70px;
}

#InfoIndex .title {
    line-height: 1;
    margin-bottom: 25px;
    position: relative;
}

#InfoIndex .title .tx {
    font-size: 210%;
    font-weight: 700;
}

#InfoIndex .title .btn {
    position: absolute;
    right: 0px;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
}

#InfoIndex .title .tx {
    font-size: 210%;
    font-weight: 700;
}

#InfoIndex .infoList {
    border-top: 1px dotted #CCC;
}

#InfoIndex .infoList li {
    border-bottom: 1px dotted #CCC;
    line-height: 1.3;
}

#InfoIndex .infoList li a {
    display: table;
    padding: 19px 0;
    width: 100%;
}

#InfoIndex .infoList li a.nolink {
    cursor: default;
}

#InfoIndex .infoList li a .date {
    display: table-cell;
    vertical-align: top;
    width: 10%;
    padding-left: 15px;
    font-weight: 300;
}

#InfoIndex .infoList li a .type {
    display: table-cell;
    vertical-align: top;
    width: 10%;
    padding-right: 20px;
}

@media screen and (min-width: 741px) {
    #InfoIndex .infoList li a .type {
        min-width: 120px;
    }
}

#InfoIndex .infoList li a .type .frame {
    display: block;
    color: #E10D20;
    border: 1px solid #E10D20;
    padding: 5px;
    text-align: center;
    font-size: 80%;
}

#InfoIndex .infoList li a .body {
    display: table-cell;
    vertical-align: top;
    width: 80%;
    padding-right: 30px;
    padding-left: 10px;
    font-size: 93%;
}

#InfoIndex .infoList li a .body em {}

.pc #InfoIndex .infoList li a .body em.cf:after {
    transition: 0.7s;
    background-color: #CCC;
    bottom: -7px;
}

#InfoIndex .infoList li a .body .tx {
    position: relative;
}

#InfoIndex .infoList li a .body.pdf .tx {
    position: relative;
}

#InfoIndex .infoList li a .body.pdf .tx:after {
    position: absolute;
    left: 100%;
    top: 50%;
    font-size: 110%;
    -webkit-transform: translate(10px, -50%);
    -ms-transform: translate(10px, -50%);
    -webkit-transform: translate(10px, -50%);
    transform: translate(10px, -50%);
    content: '\e922';
    font-family: iconfontA;
    color: #BBB;
}

#InfoIndex .infoList li a .body.out .tx:after {
    position: absolute;
    left: 100%;
    top: 50%;
    font-size: 110%;
    -webkit-transform: translate(10px, -50%);
    -ms-transform: translate(10px, -50%);
    -webkit-transform: translate(10px, -50%);
    transform: translate(10px, -50%);
    content: '\e91f';
    font-family: iconfontA;
    color: #BBB;
}


/* // TOP waypoint Setting //
----------------------------------------------- */

#ServiceIndex .serviceItem .bg {
    display: none;
}

html.top #ServiceIndex .serviceItem .bg {
    display: block;
}

#ServiceIndex .serviceItem.show .bg {
    opacity: 1;
    transition-duration: 0.5s;
    transition-delay: 0.1s;
}

#ServiceIndex .serviceItem .box {
    position: relative;
    opacity: 0;
    top: 30px;
}

#ServiceIndex .serviceItem.show .box {
    opacity: 1;
    top: 0;
    transition-duration: 0.5s;
    transition-delay: 0.4s;
}

#ServiceIndex .serviceItem .image {
    opacity: 0;
    bottom: -10px;
}

#ServiceIndex .serviceItem.show .image {
    opacity: 1;
    bottom: 10px;
    transition-duration: 0.5s;
    transition-delay: 0.7s;
}

#ServiceIndex .serviceItem:nth-of-type(odd) .enName {
    position: relative;
    opacity: 0;
    left: -50px;
}

#ServiceIndex .serviceItem:nth-of-type(odd).show .enName {
    opacity: 1;
    left: 0;
    transition-duration: 0.6s;
    transition-delay: 0.8s;
}

#ServiceIndex .serviceItem:nth-of-type(even) .enName {
    position: relative;
    opacity: 0;
    right: -50px;
}

#ServiceIndex .serviceItem:nth-of-type(even).show .enName {
    opacity: 1;
    right: 0;
    transition-duration: 0.6s;
    transition-delay: 1s;
}

#ServiceIndex .serviceItem .appealPoint .title {
    position: relative;
    opacity: 0;
    top: 30px;
}

#ServiceIndex .serviceItem .appealPoint.show .title {
    opacity: 1;
    top: 0;
    transition-duration: 0.5s;
    transition-delay: 0.2s;
}


#ServiceIndex .serviceItem .appealPoint .pointWrap .point {
    position: relative;
    opacity: 0;
    top: 30px;
}

#ServiceIndex .serviceItem .appealPoint.show .pointWrap .point {
    opacity: 1;
    top: 0;
    transition-duration: 0.5s;
}

#ServiceIndex .serviceItem .appealPoint.show .pointWrap .point:nth-of-type(1) {
    transition-delay: 0.4s;
}

#ServiceIndex .serviceItem .appealPoint.show .pointWrap .point:nth-of-type(2) {
    transition-delay: 0.6s;
}

#ServiceIndex .serviceItem .appealPoint.show .pointWrap .point:nth-of-type(3) {
    transition-delay: 0.8s;
}

#ServiceIndex .serviceItem .appealPoint.show .pointWrap .point:nth-of-type(4) {
    transition-delay: 1s;
}

#TopOtherService .title {
    position: relative;
    opacity: 0;
    top: 30px;
}

#TopOtherService.show .title {
    opacity: 1;
    top: 0;
    transition-duration: 0.5s;
    transition-delay: 0.2s;
}

#TopOtherService .itemWrap .item {
    position: relative;
    opacity: 0;
    top: 30px;
}

#TopOtherService.show .item {
    opacity: 1;
    top: 0;
    transition-duration: 0.5s;
}

#TopOtherService.show .item:nth-of-type(1) {
    transition-delay: 0.4s;
}

#TopOtherService.show .item:nth-of-type(2) {
    transition-delay: 0.6s;
}

#TopOtherService.show .item:nth-of-type(3) {
    transition-delay: 0.8s;
}

#TopOtherService.show .item:nth-of-type(4) {
    transition-delay: 1s;
}

#TopContentsMenu .cellWrap {
    position: relative;
    opacity: 0;
    top: 30px;
}

#TopContentsMenu.show .cellWrap {
    opacity: 1;
    top: 0;
    transition-duration: 0.5s;
}

#TopContentsMenu.show .cellWrap:nth-of-type(1) {
    transition-delay: 0.4s;
}

#TopContentsMenu.show .cellWrap:nth-of-type(2) {
    transition-delay: 0.6s;
}

#TopContentsMenu.show .cellWrap:nth-of-type(3) {
    transition-delay: 0.8s;
}

#TopContentsMenu.show .cellWrap:nth-of-type(4) {
    transition-delay: 1s;
}

html.top #InfoIndex {
    position: relative;
    opacity: 0;
    top: 30px;
}

html.top #InfoIndex.show {
    opacity: 1;
    top: 0;
    transition-duration: 0.5s;
    transition-delay: 0.2s;
}


/* // ContentsIndex //
----------------------------------------------- */
#ContentsIndex {
    padding: 0 40px;
}

/* //    |- typeImage  */
#ContentsIndex .typeImage {
    margin-bottom: 60px;
}

#ContentsIndex .typeImage .item {}

#ContentsIndex .typeImage .item:nth-of-type(odd) {
    background-color: #F2F2F2;
}

#ContentsIndex .typeImage .item:nth-of-type(even) {
    background-color: #F8F8F8;
}

#ContentsIndex .typeImage .item .txWrap {
    width: 50%;
}

#ContentsIndex .typeImage .item .txWrap .inner {
    width: 430px;
    display: inline-block;
    padding: 70px 0;
    min-height: 400px;
}

#ContentsIndex .typeImage .item:nth-of-type(odd) .txWrap {
    float: right;
    text-align: right;
    padding-right: 40px;
}

#ContentsIndex .typeImage .item:nth-of-type(even) .txWrap {
    float: left;
    text-align: left;
    padding-left: 40px;
}

#ContentsIndex .typeImage .item .image {
    width: 50%;
    position: relative;
    overflow: hidden;
}

#ContentsIndex .typeImage .item .image img {
    width: 100%;
    position: absolute;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

#ContentsIndex .typeImage .item:nth-of-type(odd) .image {
    float: right;
}

#ContentsIndex .typeImage .item:nth-of-type(even) .image {
    float: left;
}

#ContentsIndex .typeImage .item .txWrap .title {
    line-height: 1.4;
    display: block;
    padding-bottom: 18px;
    margin-bottom: 20px;
    position: relative;
}

#ContentsIndex .typeImage .item .txWrap .title:after {
    content: " ";
    display: block;
    width: 130px;
    height: 3px;
    background-color: #E61A19;
    position: absolute;
    left: 0px;
    bottom: 0;
}

#ContentsIndex .typeImage .item .txWrap .title .en {
    display: block;
    font-weight: 100;
    font-size: 220%;
    color: #E61A19;
}

#ContentsIndex .typeImage .item .txWrap .title .ja {
    display: block;
    font-size: 100%;
    font-weight: 500;
    color: #E61A19;
}

#ContentsIndex .typeImage .item .txWrap .htx {
    display: block;
    font-size: 106%;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 10px;
}

#ContentsIndex .typeImage .item .txWrap .body {
    display: block;
    font-size: 94%;
    line-height: 1.7;
    margin-bottom: 7px;
}

#ContentsIndex .typeImage .item .txWrap .btn {
    margin-top: 20px;
    text-align: left;
}

#ContentsIndex .typeImage .item .txWrap .btn a {
    width: 100%;
}

/* //    |- typeIcon  */
#ContentsIndex .typeIcon .item {
    width: 33.3%;
    float: left;
    transition: 0.5s !important;
}

#ContentsIndex .typeIcon .item * {
    transition: 0.5s !important;
}

.pc #ContentsIndex .typeIcon .item:hover {
    color: #FFF;
    background-color: #E61A19 !important;
}

#ContentsIndex .typeIcon .item:nth-of-type(3n) {}

#ContentsIndex .typeIcon .item:nth-of-type(odd) {
    background-color: #F2F2F2;
}

#ContentsIndex .typeIcon .item:nth-of-type(even) {
    background-color: #F8F8F8;
}

#ContentsIndex .typeIcon .item .inner {
    padding: 35px 19%;
    position: relative;
}

#ContentsIndex .typeIcon .item .inner:before {
    position: absolute;
    right: 30px;
    top: 50%;
    font-size: 170%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: '\e90e';
    font-family: iconfontA;
    color: #fff;
    transition: 0.4s;
    opacity: 0;
}

#ContentsIndex .typeIcon .item .inner:hover:before {
    right: 10px;
    opacity: 1;
}

#ContentsIndex .typeIcon .item .icon {
    text-align: center;
    margin-bottom: 20px;
    height: 80px;
    width: 100%;
    position: relative;
}

#ContentsIndex .typeIcon .item .icon img {
    width: 80px;
    height: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

#ContentsIndex .typeIcon .item .icon img.white {
    opacity: 0;
    transition: 0.4s;
}

#ContentsIndex .typeIcon .item:hover .icon img.white {
    opacity: 1;
}

.pc #ContentsIndex .typeIcon .item:hover .icon img {}

#ContentsIndex .typeIcon .item .name {
    font-size: 110%;
    font-weight: 500;
    text-align: center;
    margin-bottom: 11px;
    color: #333;
}

#ContentsIndex .typeIcon .item .description {
    font-size: 92%;
    line-height: 1.7;
    color: #333;
}

#ContentsIndex .typeIcon .item:hover .name,
#ContentsIndex .typeIcon .item:hover .description {
    color: #FFF;
}



/* // RecruitTopIndex //
----------------------------------------------- */
#RecruitTopIndex {
    margin-top: 80px;
}

#RecruitTopIndex .title .ja {
    font-size: 200% !important;
    font-weight: 700 !important;
}

#RecruitTopIndex .btn a {
    padding-top: 16px;
    padding-bottom: 16px;
}


/* // RecruitContact //
----------------------------------------------- */
#RecruitContact {
    margin-top: 140px;
}

/* // RecruitListA //
----------------------------------------------- */
#RecruitListA .listWrap {}

#RecruitListA .listWrap .comment {
    text-align: center;
    font-weight: 500;
    font-size: 130%;
    line-height: 2.6;
    margin-bottom: 50px;
    display: none;
}

#RecruitListA .listItem:first-of-type {
    border-top: 1px solid #BEBEBE;
}

#RecruitListA .listItem {
    display: block;
    padding: 28px 25px;
    border-bottom: 1px solid #BEBEBE;
    color: #444;
    position: relative;
}

#RecruitListA .listItem:hover {
    background-color: #F9F9F9;
}

#RecruitListA .listItem:after {
    position: absolute;
    right: 30px;
    top: 50%;
    font-size: 110%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: '\e90e';
    font-family: iconfontA;
    transition: 0.3s;
    opacity: 0.5;
}

#RecruitListA .listItem:hover:after {
    right: 20px;
}

#RecruitListA .listItem .wrap {
    transition: 0.3s;
}

#RecruitListA .listItem:hover .wrap {
    transform: translateX(3px);
}

#RecruitListA .listItem .wrap {
    transition: 0.3s;
}

#RecruitListA .listItem .title {
    line-height: 1.5;
    font-weight: 400;
    font-size: 150%;
    margin-top: 10px;
}

/* // RecruitDetailA //
----------------------------------------------- */
#RecruitDetailA {}

#RecruitDetailA .btnBack {
    margin-bottom: 30px;
}

#RecruitDetailA .btnBack a {
    padding-top: 6px;
    padding-bottom: 6px;
    font-size: 80%;
    min-width: 160px;
}

#RecruitDetailA .title {
    line-height: 1.6;
    font-weight: 500;
    font-size: 170%;
}

#RecruitDetailA .infoListA {
    margin-top: 18px;
}

#RecruitDetailA .detailTable {
    margin-top: 40px;
}

#RecruitDetailA .detailTable th {
    font-size: 93%;
    line-height: 1.7;
}

#RecruitDetailA .detailTable td {
    font-size: 85%;
    line-height: 1.7;
}

#RecruitDetailA .detailTable td p {
    margin-bottom: 9px;
}

#RecruitDetailA .detailTable td .annotation {
    font-size: 0.84rem;
}

#RecruitDetailA .detailTable td p:last-of-type {
    margin-bottom: 0;
}

#RecruitDetailA .photoWrap {
    margin-top: 40px;
}

#RecruitDetailA .photoWrap ul {
    text-align: center;
}

#RecruitDetailA .photoWrap ul li {
    display: inline-block;
    width: 340px;
    margin-right: 20px;
}

#RecruitDetailA .photoWrap ul li .photo {
    display: block;
    width: 100%;
    height: 240px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

#RecruitDetailA .photoWrap ul li .tx1 {
    font-size: 90%;
    line-height: 1.5;
    display: block;
    margin-top: 7px;
}

#RecruitDetailA .btnEntry {
    margin-top: 40px;
    text-align: center;
}

#RecruitDetailA .btnEntry a {
    padding-top: 20px;
    padding-bottom: 20px;
    width: 450px;
    font-size: 110%;
    font-weight: 400;
}

#RecruitDetailA .photoWrap.one ul li {
    width: 500px;
    margin-right: 0;
}

#RecruitDetailA .photoWrap.one ul li .photo {
    height: 340px;
}


/* // infoListA //
----------------------------------------------- */
.infoListA {
    line-height: 1.4;
    font-size: 90%;
}

.infoListA li {
    display: inline-block;
    margin-right: 35px;
}

.infoListA li em {
    display: inline-block;
    position: relative;
    padding-right: 9px;
    margin-right: 9px;
    font-weight: 500;
}

.infoListA li em:after {
    content: " ";
    position: absolute;
    display: block;
    width: 1px;
    height: 10px;
    background-color: #666;
    right: 0px;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
}

.infoListA li .tx:after {
    content: "・";
}

.infoListA li .tx:last-of-type:after {
    content: "";
}


/* // refineSearchA //
----------------------------------------------- */
.refineSearchA {
    margin-bottom: 60px;
}

.refineSearchA .tit1 {
    line-height: 1.5;
    text-align: center;
    font-weight: 500;
    margin-bottom: 25px;
    font-size: 130%;
}

.refineSearchA .boxFrame1 {
    background-color: #F7F7F7;
    border: 1px solid #D7D7D7;
    padding: 25px 20px;
}

.refineSearchA .itemWrap1 {
    line-height: 1.6;
    font-size: 94%;
}

.refineSearchA .item {
    border-bottom: 1px dotted #C6C6C6;
    padding: 12px 12px 6px 12px;
    display: flex;
    display: -ms-flexbox;
}

.refineSearchA .item:first-of-type {
    border-top: 1px dotted #C6C6C6;
}

.refineSearchA .item .title {
    width: 15%;
    font-weight: 500;
    font-size: 110%;
}

.refineSearchA .item .select {
    width: 85%;
}

.refineSearchA .item .inputWrap li {
    display: inline-block;
    margin-right: 27px;
    margin-bottom: 6px
}

.refineSearchA .item .inputWrap label {
    font-weight: 400;
}

.refineSearchA .submit button {
    margin-top: 20px !important;
    background-color: #555;
    border-radius: 0px;
    position: relative;
}

.refineSearchA .submit button:hover {
    background-color: #444;
}

.refineSearchA .submit button .tx {
    font-size: 15px;
}

.refineSearchA .submit button i {
    position: absolute;
    top: 50%;
    right: 10px;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
}

.refineSearchA .reset {
    text-align: center;
    margin-top: 15px;
    font-size: 88%;
}

.refineSearchA .reset a {
    padding: 6px;
}

.refineSearchA .item .inputWrap li.allCheck a {
    line-height: 1;
    border-radius: 3px;
    color: #444;
    background-color: #E0E0E0;
    font-size: 80%;
    padding: 3px 7px 3px 22px;
    font-weight: 400;
    position: relative;
}

.refineSearchA .item .inputWrap li.allCheck a i {
    position: absolute;
    left: 0px;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
}




/* // TopMessage //
----------------------------------------------- */
#TopMessage {
    padding: 0 40px;
}

.tb #TopMessage {
    padding: 0 25px;
}

#TopMessage .intro {
    background-color: #F4F4F4;
    margin-bottom: 60px;
    position: relative;
    display: flex;
    display: -ms-flexbox;
    flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    align-items: center;
    -ms-align-items: center;
    justify-content: center;
    -ms-justify-content: center;
    height: 1100px;
    padding-left: 60px;
}

#TopMessage .intro .image {
    position: relative;
    overflow: hidden;
    width: 60%;
}

#TopMessage .intro .image img {
    width: 100%;
    max-width: 503px;
    /*
	height:auto;
	width:auto;
	position:absolute;
	top:50%;
	left:50%;
	-ms-transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	-moz-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
*/
}

.tb #TopMessage .intro .image img {
    width: 100%;
}

#TopMessage .intro .txWrap {
    width: 60%;
    color: #000;
}

.tb #TopMessage .intro .txWrap {
    /*
	width:42%;
	top:55px;
	left:40px;
	margin-left:-0;
*/
}

#TopMessage .intro .txWrap .htx {
    text-align: center;
    font-weight: 400;
    font-size: 185%;
    line-height: 1.6;
    padding-bottom: 40px;
    margin-bottom: 40px;
    position: relative;
}

.tb #TopMessage .intro .txWrap .htx br {
    display: none;
}

#TopMessage .intro .txWrap .htx:before {
    content: " ";
    position: absolute;
    bottom: 0px;
    left: 0px;
    display: block;
    width: 100%;
    height: 6px;
    background-color: #5B5C57;
}

#TopMessage .intro .txWrap .htx:after {
    content: " ";
    position: absolute;
    bottom: 0px;
    left: 0px;
    display: block;
    width: 33%;
    height: 6px;
    background-color: #E61A19;
}

#TopMessage .intro .txWrap .lead {
    font-size: 107%;
    line-height: 2.1;
    padding: 0 20px;
}


#TopMessage .contents .htx1 {
    text-align: center;
    line-height: 1.3;
    font-size: 180%;
    margin-bottom: 40px;
}

#TopMessage .contents .htx1 em {
    display: inline-block;
    border-bottom: 1px solid #5B5C57;
    width: 75%;
    text-align: center;
    padding-bottom: 25px;
}

#TopMessage .contents p {
    line-height: 2.3;
}


/* // signature //
----------------------------------------------- */
.signature {
    margin-top: 40px;
}

.signature p {
    text-align: right;
    line-height: 1.6;
}

.signature p.logo {
    margin-bottom: 5px;
}

.signature p.logo img {
    width: 250px;
}



/* // SideLocalNavi //
----------------------------------------------- */
#SideLocalNavi {}

#SideLocalNavi>.in {
    position: fixed;
    top: 344px;
    left: 0;
    z-index: 80000;
    display: block;
    -ms-transform: translate(0, -50%);
    -webkit-transform: translate(0, -50%);
    -moz-transform: translate(0, -50%);
    transform: translate(0, -50%);
    overflow: hidden;
    height: 210px;
    width: 110px;
    transition-duration: 0s;
    transition-delay: 0.25s;
}


@media screen and (min-width: 1601px) {
    #SideLocalNavi>.in {
        left: 50%;
        -ms-transform: translate(-800px, -50%);
        -webkit-transform: translate(-800px, -50%);
        -moz-transform: translate(-800px, -50%);
        transform: translate(-800px, -50%);
    }
}

#SideLocalNavi:hover>.in {
    height: 440px;
    width: 1000px;
    transition-duration: 0s;
    transition-delay: 0s;
}

#SideLocalNavi>.in>.wrap {
    position: relative;
    top: 50%;
    left: 0px;
    width: 1px;
    height: 1px;
    display: block;
    margin-left: -120px;
    transition: 0.5s;
}

#SideLocalNavi.on>.in>.wrap {
    margin-left: -0;
}

/* //    |- menuBtn  */
#SideLocalNavi .menuBtnBox {
    position: absolute;
    top: 50%;
    left: -80px;
    width: 150px;
    height: 150px;
    background-color: #E61A19;
    -ms-transform: translateY(-50%) rotate(-45deg);
    -webkit-transform: translateY(-50%) rotate(-45deg);
    -moz-transform: translateY(-50%) rotate(-45deg);
    transform: translateY(-50%) rotate(-45deg);
    cursor: pointer;
    z-index: 2;
}

#SideLocalNavi .menuBtn {
    position: absolute;
    top: 50%;
    left: 12px;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    line-height: 1;
    cursor: pointer;
    z-index: 3;
}

#SideLocalNavi .menuBtn i {
    color: #FFF;
    font-size: 40px;
}

/* //    |- naviWrap  */
#SideLocalNavi .naviWrap {
    background-color: #F1F1F1;
    padding: 45px 45px 33px 130px;
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 1;
    -ms-transform: translate(-110%, -50%);
    -webkit-transform: translate(-110%, -50%);
    -moz-transform: translate(-110%, -50%);
    transform: translate(-110%, -50%);
    -moz-box-shadow: 0 0 7px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 0 7px rgba(0, 0, 0, 0.2);
    box-shadow: 0 0 7px rgba(0, 0, 0, 0.2);
    transition: 0.5s;
    opacity: 0;
}

#SideLocalNavi .naviWrap.on {
    opacity: 1;
}

/*  */
#SideLocalNavi.on:hover .naviWrap {
    -ms-transform: translate(-0%, -50%);
    -webkit-transform: translate(-0%, -50%);
    -moz-transform: translate(-0%, -50%);
    transform: translate(-0%, -50%);
}

#SideLocalNavi.on .naviWrap {}

#SideLocalNavi .naviWrap .inner {
    white-space: nowrap;
    text-align: left;
}

#SideLocalNavi .naviWrap a.item {
    display: inline-block;
    width: 160px;
    height: 160px;
    margin-right: 10px;
    margin-bottom: 12px;
    background-color: #fff;
    line-height: 1;
    vertical-align: top;
}

#SideLocalNavi .naviWrap a.item:hover {
    background-color: #E61A19;
    color: #FFF !important;
}


#SideLocalNavi .naviWrap a.item>.inner {}

#SideLocalNavi .naviWrap a.item .icon {
    display: block;
    width: 100%;
    height: 100px;
    position: relative;
}

#SideLocalNavi .naviWrap a.item .icon img {
    width: 70px;
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

#SideLocalNavi .naviWrap a.item:hover .icon img.red {
    opacity: 0;
}

#SideLocalNavi .naviWrap a.item .icon img.white {
    opacity: 0;
}

#SideLocalNavi .naviWrap a.item:hover .icon img.white {
    opacity: 1;
}

#SideLocalNavi .naviWrap a.item.on {
    background-color: #E61A19;
    color: #FFF;
}

#SideLocalNavi .naviWrap a.item.on .icon img.red {
    opacity: 0;
}

#SideLocalNavi .naviWrap a.item.on .icon img.white {
    opacity: 1;
}



#SideLocalNavi .naviWrap a.item .text {
    display: block;
    width: 100%;
    height: 60px;
    position: relative;
}

#SideLocalNavi .naviWrap a.item .name {
    text-align: center;
    font-weight: 400;
    line-height: 1.3;
    font-size: 88%;
    display: block;
    width: 95%;
    white-space: normal;
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}


#SideLocalNavi .naviWrap a.item.small {
    height: 60px;
}

#SideLocalNavi .naviWrap a.item.small .text {
    height: 60px !important;
}

#SideLocalNavi .naviWrap a.item.noicon .text {
    height: 160px;
}

#SideLocalNavi .naviWrap a.item .name.top {
    line-height: 1.5;
    font-size: 102%;
    font-weight: 500;
    color: #E61A19;
}

#SideLocalNavi .naviWrap a.item.on .name.top,
#SideLocalNavi .naviWrap a.item .name.top:hover {
    color: #fff;
}

#SideLocalNavi .naviWrap a.item .description {
    display: none;
}

/* //    |- title  */

#SideLocalNavi .titleWrap {
    position: fixed;
    top: 344px;
    left: 0;
    z-index: 80001;

}

@media screen and (min-width: 1601px) {
    #SideLocalNavi .titleWrap {
        left: 50%;
        -ms-transform: translate(-800px, 0);
        -webkit-transform: translate(-800px, 0);
        -moz-transform: translate(-800px, 0);
        transform: translate(-800px, 0);
    }
}

#SideLocalNavi .titleWrap>.inner {
    position: relative;
    display: block;
    margin-left: -120px;
    transition: 0.5s;
}

#SideLocalNavi.on .titleWrap>.inner {
    margin-left: -0;
}

#SideLocalNavi .title {
    display: inline-block;
    position: absolute;
    left: 48px;
    top: 50%;
    z-index: 2;
    line-height: 1;
    -ms-transform: translate(-100%, 17px) rotate(-90deg);
    -webkit-transform: translate(-100%, 17px) rotate(-90deg);
    -moz-transfo rm: translate(-100%, 17px) rotate(-90deg);
    transform: translate(-100%, 17px) rotate(-90deg);
    -ms-transform-origin: 100% 100%;
    -webkit-transform-origin: 100% 100%;
    -moz-transform-origin: 100% 100%;
    transform-origin: 100% 100%;
    color: #333;
    text-shadow: rgba(255, 255, 255, 0.6) 1px 1px 0px, rgba(255, 255, 255, 0.6) -1px 1px 0px, rgba(255, 255, 255, 0.6) 1px -1px 0px, rgba(255, 255, 255, 0.6) -1px -1px 0px;
}

#Services #SideLocalNavi .title {}

#SideLocalNavi .title span {
    display: block;
    text-align: right;
}

#SideLocalNavi .title .ja {
    font-size: 90%;
    white-space: nowrap;
}

#SideLocalNavi .title .en {
    font-size: 160%;
    font-weight: 600;
    margin-bottom: 3px;
    white-space: nowrap;
}




/* // CompanyPhilosophy //
----------------------------------------------- */
/* //    |- MainCopy  */
#CompanyPhilosophy #MainCopy {
    background: #f4f4f4;
    background: -moz-linear-gradient(top, #ffffff 0%, #f4f4f4 100%);
    background: -webkit-linear-gradient(top, #ffffff 0%, #f4f4f4 100%);
    background: linear-gradient(to bottom, #ffffff 0%, #f4f4f4 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#f4f4f4', GradientType=0);
    margin-bottom: 60px;
}

#CompanyPhilosophy #MainCopy .inner {
    position: relative;
    height: 440px;
}

#CompanyPhilosophy #MainCopy .tx {
    position: absolute;
    left: 0;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    line-height: 2.2;
    font-size: 180%;
    font-weight: 100;
}

#CompanyPhilosophy #MainCopy .image {
    position: absolute;
    width: 420px;
    bottom: 0px;
    right: 0px;
}

/* //    |- MainMassage  */
#CompanyPhilosophy #MainMassage {
    margin-bottom: 90px;
}

/* // CompanyHisotryImage //
----------------------------------------------- */
#CompanyHisotryImage {
    width: 1100px;
    margin: 0 auto;
}



/* // CompanyHisotry //
----------------------------------------------- */
#CompanyHisotry {
    width: 960px;
    margin: 0 auto;
    line-height: 1.7;
}

#CompanyHisotry>.inner {
    padding: 30px 0 30px 30px;
    border-left: #E8E8E8 solid 11px;
}

#CompanyHisotry .yearItem {
    position: relative;
    padding: 10px 20px;
    border: 1px solid #D3D3D3;
    display: table;
    width: 100%;
    margin-bottom: 6px;
}

#CompanyHisotry .yearItem:before {
    content: " ";
    display: block;
    width: 24px;
    height: 24px;
    position: absolute;
    left: -48px;
    top: 16px;
    background-color: #E61A19;
    -ms-border-radius: 100%;
    -moz-border-radius: 100%;
    -webkit-border-radius: 100%;
    border-radius: 100%;
}

#CompanyHisotry .yearItem .year {
    display: table-cell;
    font-weight: 700;
    font-size: 200%;
    vertical-align: top;
    line-height: 1.1;
    width: 19%;
}

#CompanyHisotry .yearItem .year .ja {
    display: inline-block;
    margin-left: 7px;
    font-weight: 500;
    font-size: 65%;
    vertical-align: middle;
}

#CompanyHisotry .yearItem .inner {
    display: table-cell;
    vertical-align: top;
    width: 81%;
}

#CompanyHisotry .yearItem .image1 {
    margin-top: -70px;
}

#CompanyHisotry .monthItem {
    display: table;
    width: 100%;
    padding: 5px 0;
    width: 100%;
}

#CompanyHisotry .monthItem .month {
    display: table-cell;
    font-weight: 600;
    font-size: 130%;
    line-height: 1.2;
    vertical-align: top;
    width: 9%;
}

#CompanyHisotry .monthItem .tx {
    display: table-cell;
    vertical-align: top;
    width: 91%;
    line-height: 1.5;
    font-size: 94%;
}

#CompanyHisotry .monthItem.photo .tx {
    width: 71%;
    padding-right: 10px;
}

#CompanyHisotry .monthItem.photo .image {
    display: table-cell;
    vertical-align: top;
    width: 20%;
}

#CompanyHisotry .monthItem.photo .image img {
    width: 100%;
}

/* // CompanyEnvironment //
----------------------------------------------- */
#CompanyEnvironment .bg {
    background: url(/_pack/img/company_environment_img_01.jpg) center center no-repeat;
    background-size: cover;
    padding: 70px;
}

#CompanyEnvironment .bg .inner {
    background-color: rgba(255, 255, 255, 0.85);
    padding: 60px;
}

#CompanyEnvironment .box {
    padding: 1px 5% 40px;
}

#CompanyEnvironment .box-bg {
    /*background-color: #F2F2F2;*/
    background: #fdebed;
    border: 1px dotted #ef7c86;
}

#CompanyEnvironment .box-bg .titleTxB+p {
    line-height: 2.5;
}

#CompanyEnvironment .titleTxB {
    text-align: left;
}

#CompanyEnvironment .titleTxB.line em {
    padding: 0 5px 15px;
}

#CompanyEnvironment .list {
    margin: 20px 0;
}

#CompanyEnvironment .list p {
    text-indent: -20px;
    margin-left: 20px;
}

#CompanyEnvironment .link {
    text-decoration: underline;
}

.box-wrap2 .image-wrap {
    margin-top: 30px;
}

@media screen and (min-width: 741px) {
    .box-wrap {
        display: flex;
    }

    .box-wrap.center {
        justify-content: center;
    }

    .box-wrap .txt-wrap {
        width: calc(100% - 300px);
    }

    .box-wrap .image-wrap {
        width: 300px;
        margin-top: -80px;
        margin-bottom: -20px;
    }

    .box-wrap2 {
        display: flex;
    }

    .box-wrap2 .txt-wrap {
        width: 50%;
        ;
    }

    .box-wrap2 .image-wrap {
        width: 50%;
        ;
        margin-top: 0;
    }

    .box-wrap2 .image-wrap img {
        width: 100%;
    }
}

/* // officeItem //
----------------------------------------------- */
.officeItem {
    border: 11px solid #F5F5F5;
    margin-bottom: 22px;
}

.officeItem .frame {
    border: 1px solid #DDD;
    padding: 15px 15px 8px;
    position: relative;
}

.officeItem .name {
    border-bottom: 1px solid #CCC;
    line-height: 1.3;
    font-size: 135%;
    font-weight: 700;
    padding: 0 4px 6px;
    margin-bottom: 12px;
}

.officeItem .name .tx {
    font-weight: 700;
}

.officeItem table.wrap {
    font-size: 85%;
    line-height: 1.4;
}

.officeItem table.wrap tr {}

.officeItem table.wrap>tbody>tr>th {
    padding-bottom: 8px;
    width: 8%;
    font-weight: 600;
    vertical-align: middle;
}

.officeItem table.wrap>tbody>tr>td {
    padding-bottom: 8px;
    width: 42%;
    vertical-align: middle;
}

.officeItem table.wrap>tbody>tr>th:nth-of-type(1) {}

.officeItem table.wrap>tbody>tr>td:nth-of-type(1) {
    padding-right: 15px;
}

.officeItem table.wrap>tbody>tr>th:nth-of-type(2) {
    padding-left: 10px;
    width: 10%;
}

.officeItem table.wrap>tbody>tr>td:nth-of-type(2) {
    width: 40%;
}

.officeItem table.wrap.addTel>tbody>tr>th:nth-of-type(1) {
    width: 5%;
}

.officeItem table.wrap.addTel>tbody>tr>td:nth-of-type(1) {
    width: 35%;
    padding-right: 25px;
}

.officeItem table.wrap.addTel>tbody>tr>th:nth-of-type(2) {
    width: 7%;
}

.officeItem table.wrap.addTel>tbody>tr>td:nth-of-type(2) {
    width: 53%;
}

.officeItem .mapBtn {
    position: absolute;
    right: 15px;
    top: 9px;
}

.officeItem .mapBtn .btn {
    padding-top: 4px !important;
    padding-bottom: 4px !important;
    width: 200px;
    color: #FFF !important;
    border: 0 !important;
    background-color: #818181;
}

.officeItem .mapBtn .btn i {
    color: #FFF !important;
}

.officeItem .mapBtn .btn .op {
    display: none;
}



/* // mapWrap //
----------------------------------------------- */
.mapWrap {
    padding-top: 20px;
    padding-bottom: 20px;
}

.mapWrap iframe {
    width: 100% !important;
    height: 400px !important;
    display: block;
}

.mapWrap .gMapBtn {
    margin-top: 20px;
    text-align: center;
}

.mapWrap .gMapBtn .btn {
    width: 270px;
}

/* // IrNewsList //
----------------------------------------------- */
#IrNewsList .tdNet {
    margin-bottom: 35px;
}

#IrNewsList .infolist.w900 {
    max-width: 900px;
    margin: auto;
}

#IrNewsList #InfoIndex .btn {
    display: block;
    text-align: right;
    margin: -10px 0 30px;
}

#Ir .tabNaviB.irnews .btns li:first-child {
    display: none;
}


/* // News //
----------------------------------------------- */
#NewsOLD .newsDetail {
    padding: 20px;
    display: block;
}

#NewsOLD .newsDetail p.date {
    text-align: right;
    margin-top: 20px;
    font-size: 92%;
}

#NewsOLD h1.pageTitle span.newsIcon {
    width: 100%;
    display: block;
    padding-left: 110px;
    background-position: left 2px;
    background-repeat: no-repeat;
}

.esg-summary {
    margin-top: 50px;
}

.esg-summary .ttl {
    text-align: center;
    font-size: 120%;
}

.esg-summary .ttl span::before,
.esg-summary .ttl span::after {
    display: inline-block;
    content: "";
    width: 40px;
    height: 2px;
    background: #000;
    margin: 0 10px 5px;
    vertical-align: middle;
}

.esg-summary img {
    display: block;
    margin: 20px auto 15px;
    max-width: 535px;
}

.esg-detail {
    margin: 50px auto 30px;
}

.esg-detail .box {
    padding: 0 0 40px;
}

.esg-detail .box img {
    display: block;
    margin: 0 auto 20px;
    max-width: 245px;
}

@media screen and (min-width: 741px) {
    #NewsOLD .newsDetail .box-wrap {
        display: flex;
    }

    #NewsOLD .newsDetail .box-wrap .box {
        width: calc((100% / 3) - 20px);
    }

    #NewsOLD .newsDetail .box-wrap .box:nth-child(2) {
        margin-left: 10px;
        margin-right: 10px;
    }

    #NewsOLD .newsDetail .box-wrap.wrap {
        flex-wrap: wrap;
        justify-content: space-between;
    }

    #NewsOLD .newsDetail .box-wrap .box2 {
        width: calc((100% - 10px) / 2);
    }

    #NewsOLD .newsDetail .box-wrap .box2:nth-child(2) {
        margin-left: 10px;
    }

    #NewsOLD .newsDetail .box-wrap img {
        max-width: 100%;
    }

    .esg-summary {
        margin-top: 100px;
    }

    .esg-summary p {
        text-align: center;
    }

    .esg-summary .ttl {
        font-size: 130%;
    }

    .esg-summary .ttl span::before,
    .esg-summary .ttl span::after {
        width: 80px;
        margin: 0 20px 5px;
    }

    .esg-summary img {
        margin: 40px auto 30px;
    }

    .esg-detail {
        display: flex;
        margin: 125px auto 70px;
    }

    .esg-detail .box {
        padding: 30px 0 20px;
        width: 342px;
    }

    .esg-detail .box:nth-child(2) {
        border-right: 1px solid #C0C0C0;
        border-left: 1px solid #C0C0C0;
        padding: 30px 35px 20px;
        margin: 0 35px;
        width: 376px;
    }

    .esg-detail .box img {
        margin: 0 auto 65px;
    }
}


/* // IrTopics //
----------------------------------------------- */
#IrTopics .innerWidth {
    width: 940px;
    margin: 0 auto;
}

/* //    |- TopicsIndex  */
#IrTopics #TopicsIndex .list li {
    float: left;
    width: 50%;
    padding: 0 20px;
    margin-bottom: 40px;
    display: block;
}

#IrTopics #TopicsIndex .list li a {
    width: 100%;
    height: 360px;
    overflow: hidden;
    display: block;
    position: relative;
}

#IrTopics #TopicsIndex .list li a .image {
    height: 100%;
    width: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: 0.3s;
}

#IrTopics #TopicsIndex .list li a:hover .image {
    height: 105%;
}

#IrTopics #TopicsIndex .list li a .title {
    color: #FFF;
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.7) 46%, rgba(0, 0, 0, 0.7) 100%);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.7) 46%, rgba(0, 0, 0, 0.7) 100%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.7) 46%, rgba(0, 0, 0, 0.7) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=0);
    display: block;
    position: absolute;
    left: 0px;
    bottom: 0px;
    width: 100%;
    padding: 45px 20px 13px 20px;
}

#IrTopics #TopicsIndex .list li a .title .inner {
    position: relative;
    padding-left: 50px;
}

#IrTopics #TopicsIndex .list li a .title p {
    font-size: 17px;
    line-height: 1.6;
    font-weight: 500;
    text-align: left;
    color: #FFF;
}

#IrTopics #TopicsIndex .list li a .title p:before {
    content: " ";
    position: absolute;
    left: 0px;
    top: 50%;
    width: 32px;
    height: 32px;
    background-color: #FFF;
    -ms-border-radius: 100%;
    -moz-border-radius: 100%;
    -webkit-border-radius: 100%;
    border-radius: 100%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    font-family: iconfontA;
    content: '\e91f';
    color: #000;
    text-align: center;
    display: block;
    padding-top: 7px;
    line-height: 1;
    box-sizing: border-box;
}

#IrTopics .topicsDetail {
    width: 800px;
    padding-bottom: 20px;
}

#IrTopics .swiperA.swiper-container {
    height: 270px;
    margin-top: 30px;
}

#IrTopics .swiperA.swiper-container.no,
#IrTopics .swiperA.swiper-container.no .swiper-wrapper {
    text-align: center;
    display: block;
}

#IrTopics .swiperA.swiper-container.no .swiper-pagination,
#IrTopics .swiperA.swiper-container.no .swiper-button-next,
#IrTopics .swiperA.swiper-container.no .swiper-button-prev,
.__ {
    display: none;
}

#IrTopics .swiperA.swiper-container.no .swiper-slide {
    display: inline-block;
    position: relative;
    float: none;
    margin: 0 10px;
}

#IrTopics .swiperA .swiper-slide {
    width: 360px;
    height: 270px;
}

#IrTopics .swiperA .swiper-slide .in {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    overflow: hidden;
}

#IrTopics .swiperA .swiper-slide .image {
    height: 100%;
    width: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: 0.3s;
}

#IrTopics .swiperA .swiper-slide .text {
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 46%, rgba(0, 0, 0, 0.55) 100%);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 46%, rgba(0, 0, 0, 0.55) 100%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 46%, rgba(0, 0, 0, 0.55) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=0);
    display: block;
    position: absolute;
    left: 0px;
    bottom: 0px;
    width: 100%;
    padding: 45px 20px 13px 20px;
    font-size: 13px;
    line-height: 1.5;
    text-align: left;
    color: #FFF;
}


/* // IrCG //
----------------------------------------------- */
#IrCG #Sec3 .item {
    margin-bottom: 30px;
}


/* // FaqWrap //
----------------------------------------------- */
#FaqWrap .faqItem {
    margin-bottom: 18px;
    font-size: 93%;
}

#FaqWrap .faqItem .que {
    display: block;
    background-color: #F3F3F3;
    line-height: 1.5;
    padding: 15px 15px 15px 40px;
    position: relative;
    transition: 0.25s;
}

#FaqWrap .faqItem a:hover .que {
    background-color: #E2E2E2;
}

#FaqWrap .faqItem .que:before {
    content: "Q";
    font-family: 'WorkSans';
    font-weight: 300;
    position: absolute;
    left: 12px;
    top: 9px;
    font-size: 22px;
    color: #257BBC;
}

#FaqWrap .faqItem .que:after {
    position: absolute;
    right: 10px;
    top: 50%;
    font-size: 100%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: '\e926';
    font-family: iconfontA;
    transition: 0.2s;
}

#FaqWrap .faqItem .open .que:after {
    content: '\e925';
}

#FaqWrap .faqItem .ans {
    line-height: 1.5;
    padding: 15px 15px 15px 40px;
    position: relative;
}

#FaqWrap .faqItem .ans:before {
    content: "A";
    font-family: 'WorkSans';
    font-weight: 300;
    position: absolute;
    left: 12px;
    top: 9px;
    font-size: 22px;
    color: #E61A19;
}

#FaqWrap .btnsAll {
    text-align: right;
    margin-bottom: 30px;
}

#FaqWrap .btnsAll .btn {
    display: inline-block;
}


/* // IrHighlight //
----------------------------------------------- */
#IrHighlight .section {
    margin-bottom: 70px;
}

#IrHighlight .section .titleTxB.s em {
    padding-left: 20px;
    padding-right: 20px;
}

#IrHighlight .section .pic {
    text-align: center;
}

#IrHighlight .section .pic img {
    width: 95%;
}


/* // IrResults //
----------------------------------------------- */
#IrResults .item {
    margin-bottom: 50px;
}

#IrResults .item ul.results {
    text-align: center;
}

#IrResults .item ul.results li {
    display: inline-block;
    line-height: 1;
    margin: 0 8px 18px;
    ;
    width: 198px;
    height: 198px;
}

#IrResults .item ul.results li a {
    display: block;
    width: 100%;
    height: 100%;
    border: 1px solid #E61A19;
    position: relative;
    color: #E61A19;
    position: relative;
    overflow: hidden;
}

.pc #IrResults .item ul.results li a:hover {
    color: #FFF;
}

#IrResults .item ul.results li a:before {
    content: " ";
    position: absolute;
    z-index: 10;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -ms-border-radius: 200px;
    -moz-border-radius: 200px;
    -webkit-border-radius: 200px;
    border-radius: 200px;
    display: block;
    width: 0;
    height: 0;
    background-color: #E61A19;
    transition: 0.4s;
    z-index: 1;
}

.pc #IrResults .item ul.results li a:hover:before {
    width: 200%;
    height: 200%;
}

#IrResults .item ul.results li a .wrap {
    position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 100%;
    padding: 0 10px;
    z-index: 2;
}

#IrResults .item ul.results li a .tx {
    display: block;
    text-align: center;
    margin-bottom: 15px;
    font-size: 112%;
    font-weight: 500;
    line-height: 1.4;
}

#IrResults .item ul.results li a .date {
    display: block;
    text-align: center;
    margin-bottom: 20px;
    font-family: 'WorkSans';
    font-size: 110%;
    font-weight: 300;
}

#IrResults .item ul.results li a .date.none {
    margin-bottom: 0px;
}

#IrResults .item ul.results li a .wrap:after {
    font-size: 200%;
    content: '\e922';
    font-family: iconfontA;
    display: block;
    text-align: center;
}

#IrResults .item ul.results.s {}

#IrResults .item ul.results.s li {
    height: auto;
    width: auto;
    vertical-align: top;
}

#IrResults .item ul.results.s li a {
    min-height: 30px;
    min-width: 180px;
    padding: 8px 10px;
}

#IrResults .item ul.results.s li a .wrap {
    position: relative;
    top: auto;
    left: auto;
    -ms-transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    transform: translate(0, 0);
    width: 100%;
    padding: 0;
    z-index: 2;
}

#IrResults .item ul.results.s li a .tx {
    margin-bottom: 3px;
    font-size: 95%;
    font-weight: 400;
    line-height: 1.28;
}

#IrResults .item ul.results.s li a .date {
    margin-bottom: 5px;
    font-size: 88%;
}

#IrResults .item ul.results.s li a .wrap:after {
    display: none;
}

/* // CareerChart //
----------------------------------------------- */
#CareerChart {
    margin-top: 50px;
    background: url(/_pack/img/human_career_img_02.jpg) center center no-repeat;
    background-size: cover;
    padding: 80px 0;
}

#CareerChart .image {
    padding-top: 30px;
}

/* // EngineeringCenter //
----------------------------------------------- */
#EngineeringCenter {}

#EngineeringCenter .swiper-container {
    height: 270px;
}

#EngineeringCenter .swiper-slide {
    width: 320px;
    height: 240px;
}

#EngineeringCenter .swiper-slide .in {
    display: block;
    position: relative;
    width: 320px;
    height: 240px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

#EngineeringCenter .swiperA .swiper-slide .in .tx {
    color: #FFF;
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 46%, rgba(0, 0, 0, 0.6) 100%);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 46%, rgba(0, 0, 0, 0.6) 100%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 46%, rgba(0, 0, 0, 0.6) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=0);
    display: block;
    position: absolute;
    left: 0px;
    bottom: 0px;
    width: 100%;
    padding: 32px 12px 10px 12px;
}

#EngineeringCenter .swiperA .swiper-slide .in .tx .inner {}

#EngineeringCenter .swiperA .swiper-slide .in .tx p {}

#EngineeringCenter .swiperA .swiper-slide .in .tx p.name {
    font-size: 92%;
    font-weight: 200;
    color: #FFF;
}

#EngineeringCenter .widthFix.noafter {
    position: relative;
}

#EngineeringCenter .widthFix.noafter::after {
    position: absolute;
    bottom: 0;
}

/* // HumanFukuri //
----------------------------------------------- */
#HumanFukuri .seiunkai {
    padding-left: 110px;
    background: url(/_pack/img/human_fukuri_img_02.png) left top no-repeat;
    background-size: auto 95px;
    min-height: 95px;
}

#HumanFukuri .facility .image {
    width: 280px;
    float: left;
}

#HumanFukuri .facility .tx {
    width: 100%;
    float: left;
    margin-left: -280px;
    padding-left: 320px;
}

#HumanFukuri .cultural .image {
    width: 200px;
    float: left;
}

#HumanFukuri .cultural .tx {
    width: 100%;
    float: left;
    margin-left: -200px;
    padding-left: 230px;
    font-size: 90%;
    line-height: 1.7;
}


/* // HumanStudy //
----------------------------------------------- */

#HumanStudy .mid_career_training .jobItem {}

#HumanStudy .mid_career_training .job {
    padding: 0 15px 8px;
    border-bottom: 1px solid #ddd;
    position: relative;
    font-size: 135%;
    font-weight: 500;
    margin-bottom: 20px;
}

#HumanStudy .mid_career_training .job:after {
    content: "　";
    position: absolute;
    display: block;
    width: 3px;
    height: 1.3em;
    left: 0;
    top: .1em;
    background-color: #DD0015;
    z-index: 1;
    transition: .5s;
}

#HumanStudy .mid_career_training .image {
    width: 300px;
    float: right;
    margin-bottom: 30px;
    margin-left: 30px;
}

#HumanStudy .mid_career_training .image.w2 {
    width: 600px;
}

#HumanStudy .mid_career_training .image img {
    width: 100%;
}

#HumanStudy .swiper-container {
    height: 270px;
}

#HumanStudy .swiper-slide {
    width: 320px;
    height: 240px;
}

#HumanStudy .swiper-slide .in {
    display: block;
    position: relative;
    width: 320px;
    height: 240px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

#HumanStudy .swiperA .swiper-slide .in .tx {
    color: #FFF;
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 46%, rgba(0, 0, 0, 0.6) 100%);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 46%, rgba(0, 0, 0, 0.6) 100%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 46%, rgba(0, 0, 0, 0.6) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=0);
    display: block;
    position: absolute;
    left: 0px;
    bottom: 0px;
    width: 100%;
    padding: 32px 12px 10px 12px;
}

#HumanStudy .swiperA .swiper-slide .in .tx p.name {
    font-size: 92%;
    font-weight: 200;
    color: #FFF;
}

/*
#HumanStudy .mid_career_training .tx {
	overflow:auto;
	zoom:1;
	display: block;
}
 */

/* // RecruitTop //
----------------------------------------------- */
#RecruitTop {}

/* // OtherPageA //
----------------------------------------------- */
#OtherPageA .item {
    margin-bottom: 50px;
}

/* // SNSAccount //
----------------------------------------------- */
#SNSAccount .accountItem {
    margin-bottom: 30px;
}

#SNSAccount .accountItem .image {
    float: left;
    width: 130px;
}

#SNSAccount .accountItem .contents {
    float: left;
    width: 100%;
    margin-left: -130px;
    padding-left: 150px;
}

/* // ContactPage //
----------------------------------------------- */
#ContactPage .tit1 {
    margin-bottom: 15px;
}

#ContactPage .tit1 em {
    padding: 0 17px 8px;
    border-width: 2px;
    width: 100%;
    font-size: 85%;
    font-weight: 400;
}

#ContactPage .tel {
    text-align: center;
    margin-bottom: 10px;
    font-family: 'WorkSans';
    font-weight: 300;
    font-size: 120%;
    line-height: 1.5;
}

#ContactPage .btn {
    text-align: center;
}

#ContactPage .btn a {
    font-size: 90%;
    width: 80%
}

#ContactPage .sectionA:last-child {
    padding-bottom: 0;
}

/* // Services //
----------------------------------------------- */
#Services .tabNavi {
    padding: 55px 0;
}

#Services .tabNavi.bottom {
    padding: 55px 0 0;
    border-top: 1px solid #CCC;
}

#Services .tabNavi.bottom.padding {
    padding-bottom: 80px;
}

#Services .item.A {}

#Services .item.A .image1 {
    text-align: center;
    margin-bottom: 32px;
}

#Services .item.A .htx1 {
    text-align: center;
    font-size: 150%;
    line-height: 1.6;
    margin-bottom: 27px;
}

#Services .item.A .body p {
    text-align: center;
}

#Services .item.A .body .pamphletListA .itemWrap .item .contents p.tit1 {
    text-align: left;
}

#Services .item.A .list1 {
    margin-top: 30px;
    border: 1px solid #E61A19;
    padding: 30px 30px 10px;
}

#Services .item.A .list1 ul {
    text-align: left;
    line-height: 1.3;
}

#Services .item.A .list1 ul.col2 li {
    margin-left: -2px;
    width: 49%;
}

#Services .item.A .list1 ul.col2 li:nth-of-type(odd) {
    padding-right: 15px;
}

#Services .item.A .list1 ul.col2 li:nth-of-type(even) {
    padding-left: 15px;
}

#Services .item.A .list1 ul li {
    display: inline-block;
    vertical-align: top;
    margin-left: 40px;
    margin-bottom: 20px;
}

#Services .item.A .list1 .htx2 {
    color: #E61A19;
    font-weight: 400;
    padding-left: 34px;
    position: relative;
}

#Services .item.A .list1 .tx1 {
    font-size: 86%;
    line-height: 1.5;
    margin-top: 10px;
    padding-left: 34px;
}

#Services .item.A .list1 .htx2:before {
    content: " ";
    display: block;
    width: 16px;
    height: 16px;
    background-color: #E61A19;
    left: 0px;
    top: 0px;
    position: absolute;
    -ms-box-shadow: 4px 4px 0 #5B5C57;
    -moz-box-shadow: 4px 4px 0 #5B5C57;
    -webkit-box-shadow: 4px 4px 0 #5B5C57;
    box-shadow: 4px 4px 0 #5B5C57;
}

/* // Mechatronics //
----------------------------------------------- */


/* //    |- TopLead  */
#Mechatronics #TopLead {
    text-align: center;
}

#Mechatronics #TopLead .list1 {
    text-align: center;
}

#Mechatronics #TopLead .list1 li {
    display: inline-block;
    margin: 0 20px;
    font-size: 94%;
    line-height: 1.5;
    text-align: center;
}

#Mechatronics #TopLead .list1 li .icon {
    display: block;
}

#Mechatronics #TopLead .list1 li .tx {
    display: block;
    text-align: center;
    font-weight: 400;
}

#Mechatronics #TopLead .mainImg {
    display: block;
    height: 420px;
    position: relative;
    margin-top: 40px;
}

#Mechatronics #TopLead .mainImg img {
    position: absolute;
    left: 50%;
    top: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

#Mechatronics #TopLead .list2 {
    margin-top: 16px;
    margin-bottom: 30px;
}

#Mechatronics #TopLead .list2 li {
    text-align: center;
    margin-bottom: 10px;
}

#Mechatronics #TopLead .list2 li .wrap {
    border-bottom: 1px solid #E10D20;
    display: inline-block;
    padding: 0 10px;
    font-weight: 400;
}

/* //    |- Strength  */
#Mechatronics #Strength .item {}

#Mechatronics #Strength .item>div {
    display: block;
    height: 350px;
    width: 50%;
    float: left;
    position: relative;
}

#Mechatronics #Strength .item:nth-of-type(even)>div {
    float: right;
}

#Mechatronics #Strength .item .contents {}

#Mechatronics #Strength .item .contents .inner {
    position: absolute;
    top: 50%;
    right: 0;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 90%;
}

#Mechatronics #Strength .item:nth-of-type(even) .contents .inner {
    right: auto;
    left: 0px;
}

#Mechatronics #Strength .item .contents .htx1 {
    font-size: 170%;
    line-height: 1.5;
    margin-bottom: 20px;
    color: #000;
}

/* //    |- FieldIndex  */

#Mechatronics #FieldIndex .itemWrap {}

#Mechatronics #FieldIndex .itemWrap .item {
    display: block;
    float: left;
    overflow: hidden;
    width: 50%;
    height: 370px;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    position: relative;
}

#Mechatronics #FieldIndex .itemWrap .item:before {
    display: block;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    content: " ";
    position: absolute;
    left: 0px;
    top: 0px;
}

#Mechatronics #FieldIndex .itemWrap .item .tx {
    display: block;
    width: 100%;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    z-index: 2;
}

#Mechatronics #FieldIndex .itemWrap .item .tx .name {
    text-align: center;
    color: #FFF;
    font-weight: 600;
    font-size: 180%;
    margin-bottom: 25px;
}

#Mechatronics #FieldIndex .itemWrap .item .tx .btn {
    text-align: center;
}

#Mechatronics #FieldIndex .itemWrap .item .tx .btn a.btnA {
    color: #FFF;
    background-color: transparent;
    border: 1px solid #fff;
    width: 300px;
    font-size: 114%;
    padding-top: 7px;
    padding-bottom: 7px;
}

/* //    |- manufacturing  */

#Mechatronics #DivFlow {
    background: url(../img/services_m_manufacturing_bg_01.jpg) no-repeat center;
    background-size: cover;
}




/* // Facility //
----------------------------------------------- */
/* //    |- imgTxt  */

#Facility .img.imgTxt {
    position: relative;
}

#Facility .img.imgTxt:before {
    content: "※イメージ";
    position: absolute;
    font-size: 11px;
    right: 5px;
    bottom: 5px;
    color: #fff;
    text-shadow: 0 0 15px rgba(0, 0, 0, .1);
    line-height: 1;
}


#Facility .item.A .list1 {
    padding: 15px 20px 15px;
}

#Facility .item.A .list1 ul li {
    margin-left: 20px;
    margin-bottom: 0;
}

#Facility .item.A .list1 ul li:first-child {
    margin-left: 0;
}

/* //    |- solutionList  */

#Facility .solutionList .item+.item {
    margin-top: 30px;
}

#Facility .solutionList .item .ttl {
    background: #e3e3e3;
    line-height: 1;
    padding: 18px 25px;
    border-left: 2px solid #cb0416;
    font-size: 113%;
    font-weight: 500;
    margin-bottom: 20px;
    position: relative;
}

#Facility .solutionList .item .ttl .icon {
    position: absolute;
    right: 5px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

#Facility .solutionList .item .inner {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: flex-start;
    align-items: flex-start;
}

#Facility .solutionList .item .inner .dlwrap {
    width: 810px;
}

#Facility .solutionList .item .inner .dlwrap dl {
    display: table;
    margin-bottom: 1px;
    line-height: 1.5;
    width: 100%;
    border-bottom: 1px solid #d7d7d7;
}

#Facility .solutionList .item .inner dt {
    background: #747474;
    padding: 10px;
    color: #fff;
    display: table-cell;
    width: 130px;
    vertical-align: middle;
}

#Facility .solutionList .item .inner .red dt {
    background: #cb0416;
}

#Facility .solutionList .item .inner dd {
    display: table-cell;
    padding: 10px 10px 10px 20px;
}

/* //    |- strengthList  */

#Facility .strengthList .item {
    display: table;
    width: 100%;
    padding: 35px 30px 35px 0;
    background-color: #FFF;
    border-bottom: 1px solid #E61A19;
}

#Facility .strengthList .item:first-of-type {
    border-top: 1px solid #E61A19;
    padding: 20px 30px 20px 0;
}

#Facility .strengthList .item>* {
    display: table-cell;
    vertical-align: middle;
}

#Facility .strengthList .item:nth-child(2n) {}

#Facility .strengthList .item .itemTtl {
    width: 215px;
    font-size: 200%;
    text-align: center;
    font-weight: 100;
    line-height: 1.2;
    color: #E61A19;
    font-weight: 300;
}

#Facility .strengthList .item li {
    position: relative;
}

#Facility .strengthList .item li+li {
    margin-top: 5px;
}

/* //    |- FieldIndex  */

#Facility #FieldIndex .crossA .item {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: stretch;
    align-items: stretch;
}

#Facility #FieldIndex .crossA .item:nth-child(2n) {
    -webkit-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

#Facility #FieldIndex .crossA .item>* {
    width: 50%;
}

#Facility #FieldIndex .crossA .item .img img {
    width: 100%;
}

#Facility #FieldIndex .crossA .item .wrap {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: column wrap;
    flex-flow: column wrap;
    -webkit-justify-content: center;
    justify-content: center;
    padding: 50px 0;
}

#Facility #FieldIndex .crossA .item .wrap * {
    text-align: center;
}

#Facility #FieldIndex .crossA .item .wrap .ttl {
    font-size: 226%;
    margin-bottom: 30px;
}

#Facility #FieldIndex .crossA .item .wrap .body {
    font-size: 126%;
    margin-bottom: 35px;
}

#Facility #FieldIndex .crossA .item .wrap .btn a {
    font-size: 200%;
    width: 70%;
    box-shadow: 6px 6px 0 #5B5C57;
}

/* //    |- Strength  */

#Facility #Strength .strengthList .item li:before {
    content: '\e945';
    font-family: IconfontA;
    display: inline-block;
    margin-right: 5px;
    font-size: 180%;
    position: absolute;
    left: 0;
    top: 0;
    color: #E61A19;
}

#Facility #Strength .groupTtl {
    font-size: 213%;
    font-weight: 100;
    line-height: 1.7;
    text-align: center;
}

#Facility #Strength .groupTtl img {
    width: 63px;
    margin-right: 10px;
    vertical-align: baseline;
}

#Facility #Strength .groupImg {
    text-align: center;
    position: relative;
}

#Facility #Strength .groupImg .obj {
    position: absolute;
    font-size: 93%;
    width: 380px;
}

#Facility #Strength .groupImg .obj.obj1 {
    left: -10px;
    top: 0;
}

#Facility #Strength .groupImg .obj.obj2 {
    right: -10px;
    top: 0;
}

#Facility #Strength .groupImg .obj.obj3 {
    left: -10px;
    bottom: 0;
}

#Facility #Strength .groupImg .obj.obj4 {
    right: -10px;
    bottom: 0;
}

#Facility #Strength .groupImg .obj .summery {
    font-weight: 400;
    line-height: 1.7;
    margin-bottom: 10px;
}

#Facility #Strength .groupImg .obj.obj1 .summery,
#Facility #Strength .groupImg .obj.obj1 .btn,
#Facility #Strength .groupImg .obj.obj3 .summery,
#Facility #Strength .groupImg .obj.obj3 .btn {
    text-align: right;
}

#Facility #Strength .groupImg .obj .btn a {
    padding: 8px 40px 8px 25px;
    background: transparent !important;
    opacity: .7;
}

#Facility #Strength .groupImg .obj .btn a:hover {
    background: #fff !important;
}

#Facility #Strength .groupImg .list {
    margin-bottom: 20px;
    line-height: 1.7;
}

#Facility #Strength .groupImg .list li {
    display: inline-block;
    padding-right: 20px;
}

#Facility #Strength .groupImg .list a {
    color: #E61A19;
    font-weight: 400;
    padding-left: 25px;
    position: relative;
    display: block;
    font-size: 80%;
}

#Facility #Strength .groupImg .list a:before {
    content: " ";
    display: block;
    width: 14px;
    height: 14px;
    background-color: #E61A19;
    left: 0px;
    top: 0px;
    position: absolute;
    -ms-box-shadow: 3px 3px 0 #5B5C57;
    -moz-box-shadow: 3px 3px 0 #5B5C57;
    -webkit-box-shadow: 3px 3px 0 #5B5C57;
    box-shadow: 3px 3px 0 #5B5C57;
}

#Facility #Strength .strengthList .item li,
#Facility #Strength .strengthList .item .btn {
    padding-left: 2.4em;
}


/* //    |- Results  */

#Facility #Results .titleTxD .tx {
    font-weight: 500;
    font-size: 160%;
}

#Facility #Results .item .columnwrap {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: stretch;
    align-items: stretch;
}

#Facility #Results .item .columnwrap .col {
    width: 23.6%;
    display: block;
    position: relative;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    transition: .2s;
}

#Facility #Results .item .columnwrap .col:hover {
    opacity: .7;
}

#Facility #Results .item .columnwrap .col:before {
    content: "　";
    display: block;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
}

#Facility #Results .item .columnwrap .col:after {
    content: "　";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0.7) 100%);
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0.7) 100%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0.7) 100%);
    z-index: 2;
    transition: .5s;
}

#Facility #Results .item .columnwrap .col p {
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 3;
    color: #fff;
    text-align: center;
    padding: 5px;
    width: 100%;
    line-height: 1.5;
}

#Facility #Results .item+.item {
    margin-top: 60px;
}

#Facility #Results .item .btn {
    text-align: center;
}

#Facility #Results .item .btn a {
    background: #9d9d9d;
    width: 360px;
}

#Facility #Results .item .tabNaviA .btns li a {
    min-width: 260px;
    font-size: 106%;
}

#Facility #Results .item .tabNaviA .btns li a span {
    text-align: left;
    font-weight: 500;
}

/* //    |- Intro  */

#Facility #Intro * {
    text-align: center;
}

#Facility #Intro .ttl {
    font-size: 161%;
    margin-bottom: 30px;
}

#Facility #Intro ul.range {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-around;
    justify-content: space-around;
    position: relative;
}

#Facility #Intro ul.range:before {
    content: "　";
    position: absolute;
    display: block;
    width: 100%;
    height: 1px;
    left: 0;
    top: 50%;
    background-color: #e10d20;
    z-index: 1;
}

#Facility #Intro ul.range li {
    z-index: 2;
}

#Facility #Intro .benefitsTtl {
    color: #e10d20;
    font-size: 213%;
    font-weight: 700;
}

#Facility #Intro .benefitsList {
    display: table;
    width: 100%;
}

#Facility #Intro .benefitsList li {
    width: calc(100% / 3);
    background-color: #e10d20;
    color: #fff;
    display: table-cell;
    font-size: 127%;
    line-height: 2;
    padding: 25px 0;
}

#Facility #Intro .benefitsList li:nth-child(2n) {
    background-color: #cb0416;
}

#Facility #Intro .benefitsList li i {
    font-size: 180%;
    -webkit-transform: translateY(5px);
    -ms-transform: translateY(5px);
    transform: translateY(5px);
    display: inline-block;
}

#Facility #Intro .strengthList .item .itemTtl {
    font-size: 180%;
    width: 280px;
}

#Facility #Intro .strengthList .item li {
    text-align: left;
    line-height: 1.7;
}

#Facility #Intro .strengthList .item li span {
    padding: 0 20px;
    border: 1px solid #fff;
    margin-right: 20px;
    display: inline-block;
    min-width: 100px;
}

#Facility #Intro .supportList .support {
    border-top: 2px solid #e3e3e3;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    padding: 35px 15px 35px 50px;
}

#Facility #Intro .supportList .support:nth-child(2n-1) {
    background: #f8f8f8;
}

#Facility #Intro .supportList .supportName {
    font-size: 186%;
    line-height: 1.4;
    padding-top: 15px;
    padding-bottom: 15px;
    border-bottom: 3px solid #e10d20;
    color: #e10d20;
    text-align: center;
    font-weight: 600;
}

#Facility #Intro .supportList .itemWrap {
    width: 830px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

#Facility #Intro .supportList .item {
    width: 245px;
    position: relative;
}

#Facility #Intro .supportList .item .name {
    text-align: center;
    border: 1px solid #000;
    font-size: 113%;
    font-weight: 500;
    margin-bottom: 10px;
}

#Facility #Intro .supportList .item:not(:last-child):before {
    content: "　";
    position: absolute;
    display: block;
    left: 100%;
    top: 50%;
    margin-left: 8px;
    margin-top: -13.5px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 13.5px 0 13.5px 12px;
    border-color: transparent transparent transparent rgba(0, 0, 0, .1);
}

#Facility #Intro .supportList .item li {
    font-size: 87%;
    text-align: left;
    color: #777;
}

#Facility .tabNaviFa {
    width: 830px;
    overflow: hidden;
    margin: 0 auto 60px;
}

#Facility .tabNaviFa a {
    width: 50%;
    border: 1px solid #e10d20;
    color: #e10d20;
    font-size: 147%;
    text-align: center;
    display: block;
    float: left;
    padding: 20px 0;
    transition: .2s;
}

#Facility .tabNaviFa.on1 a:first-child,
#Facility .tabNaviFa.on2 a:last-child {
    background: #e10d20;
    color: #fff;
}

#Facility .tabNaviFa.on1 a:last-child:hover,
#Facility .tabNaviFa.on2 a:first-child:hover {
    background: #f5f5f5;
}


/* //    |- Bui1  */

#Facility #Bui1 .item+.item {
    margin-top: 80px;
}

#Facility #Bui1 .ttl {
    font-size: 233%;
    text-align: center;
    margin-bottom: 50px;
}

#Facility #Bui1 .types {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

#Facility #Bui1 .type {
    width: 510px;
}

#Facility #Bui1 .type .inner {
    padding-left: 140px;
    position: relative;
}

#Facility #Bui1 .type .inner .icon {
    position: absolute;
    left: 10px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 95px;
}

#Facility #Bui1 .type .typeTtl {
    font-size: 213%;
    margin-bottom: 15px;
}

#Facility #Bui1 .targetList {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

#Facility #Bui1 .target {
    width: 530px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    margin-bottom: 35px;
}

#Facility #Bui1 .target .name {
    font-size: 167%;
    margin-bottom: 20px;
}

#Facility #Bui1 .target .contents {
    width: 365px;
    line-height: 1.7;
}

/* //    |- Bui2  */

#Facility #Bui2 .item+.item {
    margin-top: 80px;
}

#Facility #Bui2 .item.i1 .inner {
    padding-left: 350px;
    position: relative;
}

#Facility #Bui2 .item.i1 .inner>img {
    position: absolute;
    left: 0;
    top: 0;
}

#Facility #Bui2 .item.i1 .ttl {
    font-size: 133%;
    font-weight: 500;
    margin-bottom: 20px;
}

#Facility #Bui2 .item.i1 .txt {
    margin-bottom: 20px;
}

#Facility #Bui2 .item:not(.i1) .txt {
    text-align: center;
}

/* //    |- Rep1  */

#Facility #Rep1 .ranges {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: stretch;
    align-items: stretch;
}

#Facility #Rep1 .range {
    margin-bottom: 20px;
    width: 540px;
    background: #fff;
    box-shadow: 0 0 7px rgba(0, 0, 0, .03);
}

#Facility #Rep1 .range .txt {
    padding: 30px 20px;
}

#Facility #Rep1 .range .ttl {
    font-size: 167%;
    font-weight: 500;
    margin-bottom: 20px;
}

#Facility #Rep1 .range .list {
    margin-bottom: 20px;
    line-height: 1.7;
    overflow: hidden;
}

#Facility #Rep1 .range .list li {
    padding-right: 10px;
    padding-left: 20px;
    position: relative;
    font-size: 93%;
    width: 46%;
    float: left;
}

#Facility #Rep1 .range .list li:nth-child(2n-1) {
    width: 54%;
}

#Facility #Rep1 .range .list li:before {
    content: " ";
    display: block;
    width: 12px;
    height: 12px;
    background-color: #E61A19;
    left: 0px;
    top: 5px;
    position: absolute;
    -ms-box-shadow: 2px 2px 0 #5B5C57;
    -moz-box-shadow: 2px 2px 0 #5B5C57;
    -webkit-box-shadow: 2px 2px 0 #5B5C57;
    box-shadow: 2px 2px 0 #5B5C57;
}

#Facility #Rep1 .special {
    border: 11px solid #efdee0;
    background: #fff;
    padding: 30px;
    overflow: hidden;
}

#Facility #Rep1 .special img {
    float: left;
    margin-right: 30px;
}

/* //    |- Rep2  */
#Facility #Rep2 .item+.item {
    margin-top: 70px;
}

#Facility #Rep2 .item .ttl {
    font-size: 180%;
    font-weight: 600;
    text-align: center;
    margin-bottom: 40px;
}

#Facility #Rep2 .item .table {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin-bottom: 40px;
}

#Facility #Rep2 .item .table table {
    width: 540px;
}

#Facility #Rep2 .item .table th {
    background: #dcdcdc;
}

#Facility #Rep2 .item .table tr:not(:last-child) th {
    border-bottom-color: #fff;
}

#Facility #Rep2 .item .imgs {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: stretch;
    align-items: stretch;
}

#Facility #Rep2 .item .imgs p {
    position: relative;
}

#Facility #Rep2 .item .imgs p:not(:last-child)::after {
    content: '\e91d';
    font-family: IconFontA;
    position: absolute;
    left: calc(100% + 3px);
    top: 50%;
    line-height: 1;
    margin-top: -0.5em;
    font-size: 9px;
    color: #dedede;
}

/* //    |- Con1  */

#Facility .solTtl {
    text-align: center;
    margin-bottom: 20px;
}

#Facility .solTtl em {
    position: relative;
    color: #646464;
    font-size: 187%;
    font-weight: 400;
}

#Facility .solTtl em:before,
#Facility .solTtl em:after {
    content: "　";
    position: absolute;
    display: block;
    width: 60px;
    height: 1px;
    top: 50%;
    background-color: rgba(0, 0, 0, 0.1);
    z-index: 1;
    transition: .5s;
}

#Facility .solTtl em:before {
    right: 100%;
    margin-right: 20px;
}

#Facility .solTtl em:after {
    left: 100%;
    margin-left: 20px;
}

#Facility #Con1 .solTtl em {
    font-style: italic;
}

#Facility #Con1 .solTtl .num {
    color: #E61A19;
    font-size: 180%;
    font-style: italic;
    font-weight: 400;
}

#Facility .solblock {
    width: 900px;
    background: #fff;
    box-shadow: 0 0 7px rgba(0, 0, 0, .03);
    margin: 0 auto;
}

#Facility .solblock .problem {
    background: #646464;
    color: #fff;
}

#Facility .solblock .problem .checkEmpty {
    padding: 10px 55px;
    border-top: 1px solid #9e9e9e;
}

#Facility .solblock .problem .checkEmpty li {
    position: relative;
    padding-left: 35px;
}

#Facility .solblock .problem .checkEmpty li:before {
    content: " ";
    display: block;
    width: 12px;
    height: 12px;
    background-color: #fff;
    left: 0px;
    top: 5px;
    position: absolute;
    -ms-box-shadow: 2px 2px 0 #9e9e9e;
    -moz-box-shadow: 2px 2px 0 #9e9e9e;
    -webkit-box-shadow: 2px 2px 0 #9e9e9e;
    box-shadow: 2px 2px 0 #9e9e9e;
}

#Facility .solblock .info {
    background: #e8e8e8;
    color: #000;
    padding: 30px 0;
}

#Facility .solblock .infoTtl {
    text-align: center;
    font-size: 140%;
    font-weight: 400;
    margin-bottom: 15px;
}

#Facility .solblock .info .wrap {
    padding: 0 60px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

#Facility .solblock .info .wrap table {
    width: 48%;
}

#Facility .solblock .solution table {
    width: 90%;
    margin: 0 auto;
    padding: 10px 0;
}

#Facility .solblock .solution th p {
    position: relative;
    font-weight: 400;
    padding-left: 35px
}

#Facility .solblock .solution th p:before {
    content: " ";
    display: block;
    width: 12px;
    height: 12px;
    background-color: #E61A19;
    left: 0px;
    top: 5px;
    position: absolute;
    -ms-box-shadow: 2px 2px 0 #5B5C57;
    -moz-box-shadow: 2px 2px 0 #5B5C57;
    -webkit-box-shadow: 2px 2px 0 #5B5C57;
    box-shadow: 2px 2px 0 #5B5C57;
}

#Facility .solblock .solution .imgs {
    padding: 30px 55px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

#Facility .solblock .solution .checkAll {
    padding: 0 55px 50px;
}

#Facility .solblock .solution .checkAll i {
    font-size: 180%;
    color: #E61A19;
    display: inline-block;
    -webkit-transform: translateY(3px);
    -ms-transform: translateY(3px);
    transform: translateY(3px);
}

#Facility .solblock .contents {
    padding: 15px 55px 20px;
    font-size: 133%;
    font-weight: 400;
    position: relative;
}

#Facility .solblock .contents .en {
    font-weight: 600;
    opacity: .34;
    display: block;
    position: relative;
}

#Facility .solblock .contents .en:before {
    content: "　";
    position: absolute;
    display: block;
    left: -1em;
    top: 12px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 3px 0 3px 5px;
    border-color: transparent transparent transparent #ffffff;
}

#Facility .solblock .problem .contents {
    background: url(../img/services_f_consulting_probrem_bg.png) no-repeat right bottom;
}

#Facility .solblock .solution .contents {
    border-bottom: 3px solid #E61A19;
    color: #E61A19;
}

#Facility .solblock .solution .contents .en:before {
    border-color: transparent transparent transparent #E61A19;
}

#Facility #Con1 .solblock .solution .contents:before {
    content: "　";
    position: absolute;
    display: block;
    left: 50%;
    top: 0;
    margin-left: -36px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 25px 36px 0 36px;
    border-color: #f9dcdd transparent transparent transparent;
}

#Facility #Con1 .item+.item {
    margin-top: 50px;
}

/* //    |- Con2  */

#Facility #Con2 .ttl {
    font-size: 161%;
    margin-bottom: 30px;
    text-align: center;
}

#Facility #Con2 .txt {
    text-align: center;
}

#Facility #Con2 .flowItem {
    position: relative;
    margin-bottom: 19px;
}

#Facility #Con2 .flowItem .flowTtl {
    width: 268px;
    height: 257px;
    padding-right: 40px;
    padding-top: 75px;
    text-align: center;
    color: #fff;
    font-weight: 500;
    font-size: 160%;
    line-height: 1.6;
    background: url(../img/services_f_consulting_flow_bg1.png) no-repeat left top;
    position: absolute;
    left: 0;
    top: -6px;
}

#Facility #Con2 .flowItem.flow3 .flowTtl {
    background: url(../img/services_f_consulting_flow_bg2.png) no-repeat left top;
}

#Facility #Con2 .flowItem .flowInner {
    background: #fdebed;
    border-top: 1px dotted #ef7c86;
    border-bottom: 1px dotted #ef7c86;
    padding: 20px 20px;
    margin-right: 0;
    margin-left: auto;
    width: 832px;
}

#Facility #Con2 .flowItem.flow1 .flowInner {
    height: 196px;
}

#Facility #Con2 .flowItem.flow2 .flowInner {
    height: 196px;
}

#Facility #Con2 .flowItem.flow3 .flowInner {
    height: 147px;
}

#Facility #Con2 .flowItem td {
    padding: 9px 0;
}

#Facility #Con2 .flowItem .num {
    font-size: 147%;
    color: #e10d20;
    font-weight: 600;
}

#Facility #Con2 .flowItem .num span {
    font-weight: 600;
}

#Facility #Con2 .flowItem .name {
    font-size: 147%;
    color: #e10d20;
}

#Facility #Con2 .flowItem li {
    position: relative;
    padding-left: 35px;
}

#Facility #Con2 .flowItem li:before {
    content: " ";
    display: block;
    width: 12px;
    height: 12px;
    background-color: #E61A19;
    left: 0px;
    top: 5px;
    position: absolute;
    -ms-box-shadow: 2px 2px 0 #5B5C57;
    -moz-box-shadow: 2px 2px 0 #5B5C57;
    -webkit-box-shadow: 2px 2px 0 #5B5C57;
    box-shadow: 2px 2px 0 #5B5C57;
}

/* //    |- Con3  */

#Facility #Con3 .solblock:first-of-type {
    margin-bottom: 70px;
    position: relative;
}

#Facility #Con3 .solblock.bl1:after {
    content: "　";
    position: absolute;
    display: block;
    left: 50%;
    top: 100%;
    margin-top: 25px;
    margin-left: -36px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 26px 36px 0 36px;
    border-color: #f3d6d7 transparent transparent transparent;
}

#Facility #Con3 .solblock.bl2 .contents {
    font-size: 160%;
}

#Facility #Con3 .solblock.bl2 .contents .en {
    font-size: 80%;
}

/* //    |- Results  */

#Facility #R_Hotel .ttl {
    text-align: center;
    font-size: 227%;
    margin-bottom: 40px;
}

#Facility #R_Hotel .mainArea {
    border: 1px solid #e10d20;
    padding: 1px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row nowrap;
    flex-flow: row nowrap;
    -webkit-align-items: center;
    align-items: center;
}

#Facility #R_Hotel .mainArea .txt {
    -webkit-flex-grow: 5;
    flex-grow: 5;
    padding: 0 100px;
}

#Facility #R_Hotel .mainArea .txt .name {
    font-size: 160%;
    margin-bottom: 20px;
}

#Facility #R_Hotel .mainArea .txt li {
    line-height: 1.7;
    margin-bottom: 6px;
}

#Facility #R_Hotel .mainArea .txt li span {
    padding: 0 20px;
    background: #e3e3e3;
    /* color: #fff; */
    margin-right: 20px;
    display: inline-block;
    min-width: 110px;
    text-align: center;
}

#Facility #R_Hotel .num {
    padding: 25px 30px;
    font-size: 120%;
    background: #f3f3f3;
    text-align: center;
    border: 1px solid #ddd;
}

#Facility #R_Hotel .num .numTtl {
    font-weight: 500;
    margin-right: 3em;
    display: inline-block;
}

#Facility #R_Hotel .num em {
    font-size: 180%;
    color: #dc0d1d;
    font-weight: 500;
}

#Facility .resultsWrap {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: flex-start;
    align-items: flex-start;
}

#Facility #R_Factory .resultsWrap,
#Facility #R_General .resultsWrap {
    -webkit-flex-flow: row-reverse wrap;
    flex-flow: row-reverse wrap;
}

#Facility .resultsWrap .txt {
    width: 500px;
}

#Facility .resultsWrap .ttl {
    font-size: 213%;
    margin-bottom: 40px;
}

#Facility .resultsWrap .detail li {
    position: relative;
    padding-left: 35px;
}

#Facility .resultsWrap .detail li:before {
    content: " ";
    display: block;
    width: 12px;
    height: 12px;
    background-color: #E61A19;
    left: 0px;
    top: 5px;
    position: absolute;
    -ms-box-shadow: 2px 2px 0 #5B5C57;
    -moz-box-shadow: 2px 2px 0 #5B5C57;
    -webkit-box-shadow: 2px 2px 0 #5B5C57;
    box-shadow: 2px 2px 0 #5B5C57;
}


/* // SiteMap //
----------------------------------------------- */
/* //    |- xxx  */
#SiteMap .tit {
    border-color: #333;
}

#SiteMap .tit a {
    color: #333;
    font-weight: 400;
    display: block;
}

#SiteMap .contentsList {
    padding-top: 5px;
}

#SiteMap .contentsList li {
    line-height: 1.4;
    margin-bottom: 10px;
}

#SiteMap .contentsList li a {
    color: #333;
    display: block;
    position: relative;
    padding: 7px 7px 7px 30px;
    background-color: #EEE;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.05) 50%);
    background-position: 0 0;
    background-size: 200% auto;
}

#SiteMap .contentsList li a:after {
    position: absolute;
    left: 10px;
    top: 50%;
    font-size: 70%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: '\e90e';
    font-family: iconfontA;
    transition: 0.2s;
}

#SiteMap .contentsList li a:hover {
    background-position: -100% 0;
}


/* // AdobeAcrobat //
----------------------------------------------- */
#AdobeAcrobat {
    margin-top: 70px;
    text-align: center;
}

#AdobeAcrobat .inner {
    display: inline-block;
    background-color: #EEE;
    padding: 15px;
}

#AdobeAcrobat .logo {
    display: inline-block;
    vertical-align: top;
}

#AdobeAcrobat .wrap1 {
    display: inline-block;
    margin-left: 15px;
}

#AdobeAcrobat .tx1 {
    line-height: 1;
    font-size: 92%;
    margin-bottom: 10px;
}



/* // IrLegalNotice //
----------------------------------------------- */
#IrLegalNotice .list1 li {
    margin-bottom: 15px;
    text-align: center;
}

#IrLegalNotice .list1 li .btn {
    width: 70%;
    text-align: left;
    display: inline-block;
    padding-left: 25px;
}

#IrLegalNotice .list1 li .btn .date {
    display: inline-block;
    width: 150px;
}

#IrLegalNotice .list1 li .btn .group {
    display: inline-block;
    line-height: 1;
    padding: 3px 6px;
    background-color: #FFF;
    color: #5B5C57;
    font-size: 10px;
    margin: 0 5px;
    font-weight: 400;
}

/* // pamphletListA //
----------------------------------------------- */
.pamphletListA {}

.pamphletListA .itemWrap {
    display: flex;
    display: -ms-flexbox;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
}

.pamphletListA .itemWrap.single {
    justify-content: center;
}

.pamphletListA .itemWrap .item {
    border: 13px solid #F5F5F5;
    width: calc(50% - 15px);
    margin-bottom: 30px;
}

.pamphletListA .itemWrap .item:nth-of-type(odd) {
    margin-right: 30px;
}

.pamphletListA .itemWrap .item .inner {
    display: flex;
    display: -ms-flexbox;
    height: 100%;
    border: 1px solid #DEDEDE;
    padding: 18px;
}

.pamphletListA .itemWrap .item .image {
    width: 110px;
}

.pamphletListA .itemWrap .item .image img {
    width: 100%;
}

.pamphletListA .itemWrap .item .contents {
    width: calc(100% - 110px);
    padding-left: 20px;
}

.pamphletListA .itemWrap .item .contents .tit1 {
    line-height: 1.4;
    font-size: 116%;
    font-weight: 400;
    margin-bottom: 14px;
}

.pamphletListA .itemWrap .item .contents .btns li {
    margin-bottom: 15px;
}

.pamphletListA .itemWrap .item .contents .btns li:last-of-type {
    margin-bottom: 5px;
}

.pamphletListA .itemWrap .item .contents .btns li .btn {
    min-width: 300px;
}




/* // OLD PAGE //
----------------------------------------------- */
/* //    |- xxx  */

.popup #Header .contact,
.popup #GlobalNavi,
.popup .print #Header .logoEn,
.popup #HeaderContactBtn,
.___ {
    display: none !important;
}

.popup .print #Header {
    padding-top: 10px;
    background-color: #FFF;
}

.popup .print #Header .widthFix {
    width: 100%;
}




/* // CompanyOfficer //
----------------------------------------------- */

#Officer .sectionA.s {
    padding: 70px 0 0;
}

#Officer .sectionB.s {
    padding: 90px 0 0;
    margin: 0px;
}

#Officer .widthFix {
    display: flex;
    position: relative;
}

#Officer .widthFix.reverse {
    flex-direction: row-reverse;
}

#Officer .widthFix .photo {
    display: inline-flex;
    flex-basis: 480px;
}

#Officer .widthFix .photo img {
    align-self: flex-start;
}

#Officer .widthFix .box {
    display: inline-flex;
    align-items: flex-start;
    justify-content: flex-end;
    align-items: center;
    margin-top: -20px;
}

#Officer .widthFix.reverse .box {
    margin-top: -30px;
    justify-content: flex-start;
}

#Officer .widthFix .box .txtArea {
    background: #fff;
    border: 1px solid #e5e5e5;
    flex-basis: 570px;
    padding: 30px 30px 40px 30px;
    font-size: 86%;
    text-align: left;
    box-sizing: border-box;
    width: 100%;
    position: relative;
    min-height: 420px;
}

#Officer .widthFix .box .txtArea p.txt {
    text-align: justify;
}

#Officer .widthFix .box .txtArea .ttl {
    position: relative;
    box-sizing: border-box;
    z-index: 5;
}

#Officer .widthFix .box .txtArea .ttl span {
    background: #fff;
    font-weight: bold;
    padding-right: 10px;
    font-size: 17px;
}

#Officer .widthFix .box .txtArea .ttl:after {
    content: "";
    width: 100%;
    left: 0px;
    position: absolute;
    display: inline-block;
    height: 4px;
    top: 12px;
    border-top: 6px solid #dcdcdc;
    z-index: -1;
}

#Officer .widthFix .nameBox {
    display: inline-block;
    width: 520px;
    background-color: #E10D20;
    color: #FFF;
    padding: 20px 20px 16px;
    -moz-box-shadow: 10px 10px 0 #5B5C57;
    -webkit-box-shadow: 10px 10px 0 #5B5C57;
    box-shadow: 10px 10px 0 #5B5C57;
    z-index: 10;
    position: absolute;
    left: 10%;
    bottom: -30px;
    box-sizing: border-box;
    min-height: 90px;
}

#Officer .widthFix.reverse .nameBox {
    left: 44%;
}

#Officer .widthFix .nameBox p {
    display: inline-block;
    text-align: left;
    width: 60%;
    font-weight: bold;
    font-size: 120%;
    line-height: 1.6em;
    vertical-align: middle;
}

#Officer .widthFix .nameBox p span {
    display: block;
    font-size: 80%;
    font-weight: 100;
    line-height: 1.3em;
}

#Officer .widthFix .nameBox p.name {
    text-align: right;
    font-size: 200%;
    width: 38%;
}


/* // CompanyOfficer //
----------------------------------------------- */

#Officer2 .sectionA.s {
    padding: 80px 0 0;
}

#Officer2 .sectionB.s {
    padding: 80px 0 0;
    margin: 0px;
}

#Officer2 .widthFix {
    display: flex;
    position: relative;
    justify-content: space-around;
}

#Officer2 .widthFix.reverse {
    flex-direction: row-reverse;
}

#Officer2 .widthFix .photo {
    display: inline-flex;
    flex-basis: 370px;
}

#Officer2 .widthFix .photo img {
    align-self: flex-start;
    width: 100%;
}

#Officer2 .widthFix .box {
    display: inline-flex;
    flex-basis: 700px;
    align-items: flex-start;
    justify-content: flex-end;
    align-items: center;
    margin-left: 25px;
}

#Officer2 .widthFix.reverse .box {
    margin-top: 0px;
    justify-content: flex-start;
    margin-left: 0px;
    margin-right: 25px;
}

#Officer2 .widthFix .box .txtArea {
    background: #fff;
    border: 1px solid #e5e5e5;
    padding: 30px 30px 10px 30px;
    font-size: 107%;
    line-height: 2.0;
    text-align: left;
    box-sizing: border-box;
    width: 100%;
    position: relative;
    min-height: 460px;
}

#Officer2 .widthFix .box .txtArea p.txt {
    text-align: justify;
}

#Officer2 .widthFix .box .txtArea .ttl {
    position: relative;
    box-sizing: border-box;
    z-index: 5;
}

#Officer2 .widthFix .box .txtArea .ttl span {
    background: #fff;
    font-weight: bold;
    padding-right: 10px;
    font-size: 17px;
}

#Officer2 .widthFix .box .txtArea .ttl:after {
    content: "";
    width: 100%;
    left: 0px;
    position: absolute;
    display: inline-block;
    height: 4px;
    top: 12px;
    border-top: 6px solid #dcdcdc;
    z-index: -1;
}

#Officer2 .widthFix .nameBox {
    display: inline-block;
    width: 340px;
    color: #000;
    padding: 0;
    /*
	-moz-box-shadow: 10px 10px 0 #5B5C57;
	-webkit-box-shadow: 10px 10px 0 #5B5C57;
	box-shadow: 10px 10px 0 #5B5C57;
	 */
    z-index: 10;
    position: absolute;
    left: 0px;
    top: 380px;
    box-sizing: border-box;
    min-height: 10px;
}

#Officer2 .widthFix .nameBox.executive {
    /*
    bottom:26px;
    min-height: 110px;
 */
}

#Officer2 .widthFix.reverse .nameBox {
    left: 100%;
    margin-left: -370px;
}

#Officer2 .widthFix .nameBox p {
    display: inline-block;
    text-align: left;
    width: 100%;
    font-weight: 500;
    font-size: 112%;
    line-height: 1.6em;
    vertical-align: middle;
}

#Officer2 .widthFix .nameBox p span {
    display: inline-block;
    margin-left: 12px;
    font-size: 90%;
    font-weight: 400;
    line-height: 1.3em;
}

#Officer2 .widthFix .nameBox p.name {
    text-align: left;
    font-size: 170%;
    width: 100%;
}

#Officer2 #Officer003 .widthFix .nameBox p span,
#Officer2 #Officer011 .widthFix .nameBox p span {
    display: block;
    margin-left: 0px;
    font-size: 80%;
}

/* health management */
.TxBold {
    font-weight: 700;
}

.tableCaption {
    text-align: right;
}

.helthTable {}

.helthTable tbody {
    width: 100%;
}

.helthTable th,
.helthTable td {
    padding: 5px 10px;
    vertical-align: middle;
}

.helthTable th {
    background: #E61A19;
    color: #fff;
    font-weight: 700;
    border: 1px solid #333;
}

.helthTable td {
    padding: 5px 10px;
    border: 1px solid #333;
}

.helthTable td:last-of-type {
    background: #fae5d6;
}

.tableCenter {
    text-align: center;
}

.tableNumber {
    text-align: right;
}

.spScrollNote {
    display: none;
}

@media screen and (max-width:740px) {
    .helthTable {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }

    .spScrollNote {
        display: block;
        text-align: right;
        margin-top: 0;
    }

    .spScrollNote:before {
        content: "";
        display: inline-block;
        background: url(../img/scroll_icon.svg) no-repeat;
        background-size: contain;
        vertical-align: middle;
        width: 23px;
        height: 15px;
        margin: 0 10px 0 0;
    }
}