#header
{
    position: relative;
}

#sub-bg
{
    position: relative;

    width: 100%;
    height: 275px;
}
#sub-bg .sub-bg-tit
{
    position: relative;
    z-index: 20;

    display: table;

    height: 100%;
}


#sub-bg  .sub-tit-h2
{
    font-size: 3.0em;

    position: relative;
    z-index: 50;
    top: -25px;

    display: table-cell;

    text-align: center;
    vertical-align: middle;
    text-transform: uppercase;

    color: #fff;
}

#sub-bg  .sub-tit-h2 p
{
    font-size: .8rem;
    font-weight: 300;
}

#sub-bg.sub-bg-product
{
    /*background: url(../img/sub-bg-product.jpg) center center no-repeat;*/
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: cover;
            background-size: cover;
}

#sub-bg:before
{
    position: absolute;
    z-index: 10;

    width: 100%;
    height: 100%;

    content: '';

    opacity: .3;
    background-color: #444;
}

.sub-bg-menu
{
    position: absolute;
    z-index: 100;
    bottom: 0;

    display: table;
    overflow: hidden;

    width: 100%;
    height: 70px;

    background-color: #fff;
}
.sub-bg-menu li
{
    line-height: 70px;

    position: relative;

    display: table-cell;

    width: 1%;
    height: 65px;

    text-align: center;
}
.sub-bg-menu li a
{
    line-height: 25px;
    /* margin-top: 18px; */

    position: relative;
    top: 18px;

    display: block;

    width: 100%;
    /* float: left; */

    border-right: 1px solid rgb(200,200,200);
}
.sub-bg-menu li:last-of-type a
{
    border-right: none;
}
.sub-bg-menu li.on
{
    border-top: 5px solid #1069aa;
}

.sub-bg-menu li.on:after
{
    font-family: FontAwesome;
    font-size: 30px;

    position: absolute;
    z-index: 1;
    bottom: -20px;
    left: 0;
    /* content: ''; */

    display: inline-block;

    width: 100%;
    /* height: 20px; */

    content: '\f107';

    color: #0068b7;
}

.sub-bg-menu li.on a
{
    font-weight: 600;

    color: #2f2f2f;
}

.sub-container
{
    min-height: 30vmax;
    /*padding-bottom: 3vmax;*/
    padding-bottom: 6rem;
}

.sub-container hgroup
{
    margin-top: 30px;
    margin-bottom: 30px;

    text-align: center;
}
.sub-container hgroup h2
{
    font-size: 2.5rem;

    position: relative;

    margin-bottom: 15px;
    padding-bottom: 15px;

    text-transform: uppercase;

    color: #2f2f2f;
}
.sub-container hgroup h2:after
{
    position: absolute;
    bottom: 0;
    left: 50%;

    width: 70px;
    height: 2px;
    margin-left: -35px;

    content: '';

    background-color: #434343;
}

.sub-container hgroup h4
{
    font-size: 2.0em;
    font-weight: normal;
    line-height: 1.4em;

    position: relative;

    margin-bottom: 20px;
    padding-bottom: 20px;
}

.sub-container hgroup h4:after
{
    position: absolute;
    bottom: 0;
    left: 50%;

    width: 70px;
    height: 2px;
    margin-left: -35px;

    content: '';

    background-color: #434343;
}

.sub-container hgroup h4 span
{
    color: #ce1d1d;
}

.sub-tit
{
    position: relative;
    z-index: 1;

    display: table;
    overflow: hidden;

    width: 100%;
    height: 310px;
}
.sub-tit .sub-tit-img-wrap
{
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    overflow: hidden;
    width: 600px;
    height: 310px;
    /* display: table-cell;
    vertical-align: middle; */
}

.sub-tit .sub-tit-img-wrap img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.sub-tit figcaption
{
    position: absolute;
    z-index: 2;
    top: 0;
    right: 0;

    width: 50%;
    padding-left: 50px;
    height: 100%;

    background-color: #1069aa;
}
.sub-tit figcaption:before
{
    position: absolute;
    z-index: 10;
    left: -80px;

    display: block;

    content: '';

    border-top: 310px solid transparent;
    border-right: 80px solid #1069aa;
    border-bottom: 0 solid transparent;
    border-left: 0 solid transparent;
}
.sub-tit figcaption *
{
    color: #fff;
}
.sub-tit figcaption h3
{
    font-size: 1.5rem;

    position: relative;
    top: 70px;
    /*left: 80px;*/

    text-align: left;

    color: #52b3ff;
}
.sub-tit figcaption h1
{
    font-size: 4.0rem;
    font-weight: bolder;

    position: relative;
    top: 80px;
    /*left: 80px;*/

    text-align: left;
    text-transform: uppercase;
}
.sub-tit figcaption ul
{
    position: relative;
    top: 90px;
    /*left: 80px;*/
}
.sub-tit figcaption ul li
{
    float: left;

    padding-right: 1em;
}
.sub-tit figcaption.sub-bg-sub-soclio
{
    background-image: url(../img/product/sub-bg-sub-soclio.png);
    background-repeat: no-repeat;
    background-position: 90% 80%;
}

.sub-tit figcaption.sub-bg-sub-std
{
    background-image: url(../img/product/sub-bg-sub-std.png);
    background-repeat: no-repeat;
    background-position: 90% 80%;
}

.sub-tit figcaption.sub-bg-sub-sw
{
    background-image: url(../img/product/sub-bg-sub-sw.png);
    background-repeat: no-repeat;
    background-position: 90% 80%;
}

.sub-tit figcaption.sub-bg-sub-x50
{
    background-image: url(../img/product/sub-bg-sub-x50.png);
    background-repeat: no-repeat;
    background-position: 90% 80%;
}

.sub-tit figcaption.sub-bg-sub-x70
{
    background-image: url(../img/product/sub-bg-sub-x70.png);
    background-repeat: no-repeat;
    background-position: 90% 80%;
}

.title-h3
{
    font-size: 2.0rem;

    position: relative;

    text-indent: 40px;

    color: #383838;
}
.title-h3:before
{
    position: absolute;
    top: 50%;

    display: block;

    width: 25px;
    height: 5px;
    margin-top: -5px;

    content: '';
    -webkit-transform: skewY(20deg) rotateY(10deg);
        -ms-transform: skewY(20deg) rotateY(10deg);
         -o-transform: skewY(20deg) rotateY(10deg);
            transform: skewY(20deg) rotateY(10deg);

    background-color: #1069aa;
}

.sub-detail-dl
{
    display: table;
}

.sub-detail-dl dt
{
    /*display: table-cell;*/
    float: left;
    overflow: hidden;

    width: 350px;
    height: 100%;
    padding-right: 50px;

    text-align: center;
    /* color: darkslategray; */
    vertical-align: top;
    /*white-space: nowrap;*/
    /* text-align: right; */
    /*text-overflow: ellipsis;*/
}
.sub-detail-dl dt h3
{
    font-weight: normal;

    position: relative;
    /* text-indent: 10px; */

    padding-left: 20px;

    text-align: left;
}
.sub-detail-dl dt h3:before
{
    position: absolute;
    left: 0;

    display: inline-block;

    width: 10px;
    height: 10px;
    margin-bottom: 20px;

    content: '';

    background-color: #135384;
}

.sub-detail-dl dt i
{
    position: relative;

    display: inline-block;

    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
            box-sizing: border-box;
    width: 130px;
    height: 130px;
    padding: 40px;

    color: #7d7d86;
    border: 1px solid rgb(230,230,230);
    /*clear: both;*/
    border-radius: 50%;
    background: #fff;
}

.sub-detail-dl dd
{
    line-height: 2.0rem;
    /*margin-left: 190px;*/
    /*display: table-cell;*/

    float: right;

    width: 850px;

    /*color: gray;*/
    /*font-size: 1.3em;*/
}
.sub-detail-dl dd > p
{
    font-size: 1rem;
    font-weight: 300;
    line-height: 2.3em;

    position: relative;

    padding-left: 15px;
}
.sub-detail-dl dd > p:before
{
    line-height: 2.5em;

    position: absolute;
    top: 1.3rem;
    left: 0;

    display: inline-block;

    width: 3px;
    height: 3px;
    margin-right: 10px;
    padding: 0;

    content: '';
    transform: translateY(-50%);

    background-color: #1d72a7;
}

.sub-list-ul
{
    overflow: hidden;

    /*max-width: 1200px;*/
}

.sub-list-ul li
{
    float: left;
}
.sub-list-ul.sub-list-4-div li
{
    width: 25%;
}

.sub-list-ul.sub-list-3-div li
{
    width: 33.333333%;
}

.sub-list-ul.sub-list-2-div li
{
    width: 50%;
}


.sub-list-ul.sub-list-img li
{
    float: left;

    width: auto;
}

.sub-list-ul.sub-list-img li:first-of-type
{
    width: 35%;
}
.sub-list-ul.sub-list-img li:last-of-type
{
    width: 65%;
}

.sub-list-ul li .sub-list-div
{
    position: relative;
    /* margin: 0 1rem; */

    width: 95%;
    margin: 0 auto;
}

.sub-list-ul li .sub-list-div figure
{
    position: relative;
    z-index: 5;

    overflow: hidden;

    height: 205px;

    border: 1px solid rgb(200,200,200);
}

.sub-list-ul li .sub-list-div figure img
{
    position: relative;
    z-index: 5;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}
.sub-list-ul li .sub-list-div figure figcaption
{
    font-weight: 600;
    line-height: 35px;

    position: absolute;
    z-index: 10;
    bottom: 0;
    font-size: .8em;
    height: 35px;
    padding: 0 20px;

    color: #fff;
    background-color: #66b512;
}
.sub-list-ul li .sub-list-div figure figcaption:after
{
    position: absolute;
    top: 0;
    right: -20px;

    display: block;

    content: '';

    border-top: 40px solid transparent;
    border-right: 0 solid #66b512;
    border-bottom: 0 solid transparent;
    border-left: 20px solid #66b512;
}

.sub-list-ul li:nth-of-type(2) .sub-list-div figure figcaption
{
    background-color: #3094e2;
}

.sub-list-ul li:nth-of-type(2) .sub-list-div figure figcaption:after
{
    border-right: 0 solid #3094e2;
    border-left: 20px solid #3094e2;
}

.sub-list-ul li:nth-of-type(3) .sub-list-div figure figcaption
{
    background-color: #efab09;
}

.sub-list-ul li:nth-of-type(3) .sub-list-div figure figcaption:after
{
    border-right: 0 solid #efab09;
    border-left: 20px solid #efab09;
}

.sub-list-ul li:nth-of-type(4) .sub-list-div figure figcaption
{
    background-color: #a653d6;
}

.sub-list-ul li:nth-of-type(4) .sub-list-div figure figcaption:after
{
    border-right: 0 solid #a653d6;
    border-left: 20px solid #a653d6;
}

.sub-list-ul .sub-list-div-bg
{
    position: absolute;
    z-index: 1;
    top: 10px;
    right: -10px;

    display: block;

    width: 100%;
    height: 205px;

    background: url(../img/pattren_dot_gray.gif) 0 0 repeat;
}

.sub-list-ul li:not(:first-of-type)
{
    padding-left: 1rem;
}

.sub-list-ul li .sub-list-div > p
{
    font-size: .9rem;
    line-height: 1.7rem;

    position: relative;

    margin-top: 20px;

    /*text-align: justify;*/

    color: #5d5d5d;
}

.img-wrap
{
    position: relative;

    text-align: center;

    border: 1px solid rgb(200,200,200);
}

.img-wrap > div
{
    position: relative;
    z-index: 2;

    height: 100%;
    padding: 2rem 0;

    background-color: #fff;
}
.img-wrap:after
{
    position: absolute;
    z-index: 1;
    right: -10px;
    bottom: -10px;

    display: block;
    display: block;

    width: 100%;
    height: 100%;

    content: '';

    background: url(../img/pattren_dot_gray.gif) 0 0 repeat;
}
/* 
.img-wrap-ul li
{
    float: left;
}

.img-wrap-ul li:not(:first-of-type)  {
    margin-left: 1rem;
}
.img-wrap-ul.img-wrap-ul-half li
{
    width: 50%;
}
 */



.processul li
{
    position: relative;

    display: table-cell;
    /* float: left; */

    width: 1%;

    text-align: center;
    vertical-align: top;
}

.processul_wrap
{
    display: inline-block;

    width: 90%;
    padding-top: 20px;
    padding-bottom: 20px;

    text-align: center;
    /* height: 300px; */

    border: 1px solid rgb(220,220,220);
    background-color: #fff;
}

.processul li:after
{
    font-family: FontAwesome;
    font-size: 16px;
    font-size: 2.5em;

    position: absolute;
    top: 45%;

    width: 10%;

    content: '\f105';
    text-align: center;

    color: #8c8c8c;
}

.processul li:last-of-type:after
{
    display: none;
}

.processul_wrap > figure
{
    position: relative;
    /*overflow: hidden;*/
    /*width: 230px;*/

    width: 100%;
    /*height: 170px;*/

    vertical-align: middle;
}

/* .processul_wrap > figure img
{
    position: absolute;
    top: 50%;
    left: 50%;

    -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
         -o-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
} */

.processul_wrap em
{
    font-size: 1rem;
    font-weight: bold;
    font-weight: normal;
    font-style: normal;

    position: relative;

    display: block;
    /*height: 60px;*/

    margin-top: 15px;

    color: #0095da;
}

/* .processul_wrap em:after
{
    position: absolute;
    bottom: 0;
    left: 50%;

    display: inline-block;

    width: 20px;
    margin-top: 20px;
    margin-bottom: 20px;
    margin-left: -10px;

    content: '';

    border-bottom: 2px solid #c9c9c9;
} */

.processul_wrap h4
{
    font-size: 1.1rem;
    font-weight: inherit;

    color: #292929;
}

.text-p
{
    font-size: 1.0em;
    font-weight: 500;
    line-height: 1.5rem;

    padding-left: 1rem;
}

.box_wrap
{
    position: relative;

    padding: 7px;

    background: url(../img/pattren_dot_gray.gif) 0 0 repeat;
}

.box_in
{
    /*font-size: 1.2rem;*/
    /*font-weight: 400;*/
    /*line-height: 2rem;*/
    padding: 30px;

    color: rgb(50,50,50);
    background-color: #fff;
}
.box_in li
{
    display: table-cell;

    vertical-align: middle;
}

.box_in li:first-of-type
{
    width: 30%;
}

.box_in li figure
{
    text-align: center;
}


.box_in .box_text
{
    font-size: 1.2rem;
    font-weight: normal;
    line-height: 2rem;

    position: relative;

    margin-left: 30px;
}
.box_in .box_text:after
{
    display: table;
    clear: both;

    height: 0;

    content: '';
}



.box_in:before
{
    position: absolute;
    top: 0;
    left: 0;

    width: 30px;
    height: 30px;

    content: '';

    border-top: 7px solid #0068b7;
    border-left: 7px solid #0068b7;
}

.box_in:after
{
    position: absolute;
    right: 0;
    bottom: 0;

    width: 30px;
    height: 30px;

    content: '';

    border-right: 7px solid #3ba3b2;
    border-bottom: 7px solid #3ba3b2;
}



.careerNote
{
    font-size: 1em;
    font-weight: 400;

    padding: 15px;
    font-weight: normal;

    text-align: center;

    color: #3a76a2;
    border: 2px solid #98cdd8;
    border-radius: .8rem;
    background-color: #d9edf7;
}