#container {
    padding: 0;
    max-width: 100%
}

#index.home.top-page main#wrap:before {
    background-image: url(/img/index/top_003.jpg);
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: fixed;
    background-position: left center;
    background-size: cover
}

#wrap .cateConts > .inner {
    box-sizing: border-box;
    height: 100%
}

#wrap .cateConts .bg {
    padding: 1px;
    height: 100%;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative
}

#wrap .categoryTtl {
    position: relative;
    line-height: 1;
    text-align: center
}

#wrap .categoryTtl > span {
    display: block;
    position: relative;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
}

#wrap .categoryTtl .en {
    font-weight: 100
}

#wrap .categoryTtl .em {
    font-weight: 400
}

#wrap .box {
    box-sizing: border-box;
    padding: 1px;
    position: absolute;
    overflow: hidden
}

#wrap .box:before {
    content: "";
    display: block;
    /*padding-top: 100%;*/
    background-color: #FFF
}

#wrap .box .frame {
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

#wrap .box .frame > .txt {
    box-sizing: border-box;
    padding: 10px;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 0;
    line-height: 1;
    text-align: center;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    -ms-transform: translateY(-50%)
}

#wrap .box .frame > .txt > span {
    display: block
}

#wrap .box .frame > .txt .en {
    font-weight: 100
}

#wrap .box .frame > .txt .multi {
    margin-right: 5px;
    margin-left: 5px;
    display: inline-block
}

#wrap .box .frame > .txt .em {
    font-weight: 400;
    font-size: 0.9em
}

.recruit-page #wrap .box .frame > .txt .em {
    -webkit-transition: all .2s ease;
    -moz-transition: all .2s ease;
    -ms-transition: all .2s ease;
    -o-transition: all .2s ease;
    transition: all .2s ease
}

/*.recruit-page #wrap .box .frame:hover > .txt .em {
    text-shadow: 0px 0px 5px #FFFFFF
}*/

#wrap .box .frame .icon {
    display: block;
    position: relative
}

#wrap .box .frame .icon:before {
    box-sizing: border-box;
    border-style: solid;
    border-radius: 100%;
    position: absolute;
    top: 0;
    left: 50%;
    content: "";
    -webkit-transform: translateY(-50%) translateX(-50%);
    transform: translateY(-50%) translateX(-50%);
    -ms-transform: translateY(-50%) translateX(-50%)
}

/*breadcrumb*/

.bcl-contents {
    text-align: center;
    position: relative;
    overflow: hidden;
    left: 0;
    margin: 30px 0 25px
}

.bcl-contents li {
    display: inline-block;
    width: auto;
    font-size: 1.6rem;
    margin: 0 6px
}

.bcl-contents li:last-child {
    font-weight: bold
}

.bcl-contents li:after {
    display: inline-block;
    content: ">";
    padding-left: 12px
}

.bcl-contents li:last-child:after {
    display: none
}


.read-text {
    max-width: 610px;
    width: 100%;
    text-align: justify;
    margin: 0 auto 40px;
    font-size: 1.3rem
}


section.service-main {
    height: 380px;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
    margin-bottom: 120px
}

.sol-page section.service-main {
    background-image: url(/img/common/template/service-sol-top.png)
}

.sc-page section.service-main {
    background-image: url(/img/common/template/service-sc-top.png)
}

.ecw-page section.service-main {
    background-image: url(/img/common/template/service-ecw-top.png)
}

.ses-page section.service-main {
    background-image: url(/img/common/template/service-ses-top.png)
}


section.service-main > div {
    position: absolute;
    top: 50%;
    left: 50%;
    max-width: 1034px;
    width: 100%;
    color: #FFFFFF;
    text-align: center;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

section.service-main h1 {
    font-size: 3.8rem;
    letter-spacing: .04em;
    text-shadow: 0 0 8px rgba(0, 0, 0, .4);
    margin-bottom: 1em
}

section.service-main p {
    font-size: 1.6rem;
    text-shadow: 0 0 8px rgba(0, 0, 0, 1);
    line-height: 1.9em;
    letter-spacing: .06em
}

section.full-content {
    width: 100%
}

section.block-content {
    width: 100%;
    max-width: 1034px;
    margin: 0 auto 60px
}

.sol-page #service h3,
.sc-page #service h3,
.ecw-page #service h3,
.ses-page #service h3 {
    font-size: 1.6rem;
    text-align: center;
    line-height: 2.5;
    background: #CCCCCC;
    color: #FFFFFF;
    font-weight: normal
}

.sol-page #service h3 {
    background-color: rgba(0, 163, 226, 1)
}

.sc-page #service h3 {
    background-color: rgba(237, 137, 20, 1)
}

.ecw-page #service h3 {
    background-color: rgba(172, 207, 53, 1)
}

.ses-page #service h3 {
    background-color: rgba(29, 43, 100, 1)
}

#service .service-lists li {
    overflow: hidden;
    padding: 25px 20px;
    border-bottom: 1px solid #999999;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-align-items: center;
    -moz-align-items: center;
    -ms-align-items: center;
    align-items: center
}

#service .service-lists li:last-child {
    border-bottom: none
}

#service .service-lists li > div {
    width: 40%;
    font-size: 2rem;
    float: left
}

#service .service-lists li > p,
#service .service-lists li > div.content-box {
    width: calc(60% - 40px);
    font-size: 1.6rem;
    float: right;
    padding-left: 40px
}

#service p.box-text {
    background-color: rgba(245, 248, 249, 1);
    padding: 10px 20px;
    margin: 20px 0 0;
    font-size: 1.4rem
}

.ses-page #service p.box-text {
    width: 93%;
    margin-right: auto;
    margin-left: auto
}

#service p.box-text strong {
    margin-right: 10px;
    display: inline-block;
    vertical-align: middle;
    text-align: center;
    width: -webkit-calc(30% - 10px);
    width: -moz-calc(30% - 10px);
    width: -ms-calc(30% - 10px);
    width: -o-calc(30% - 10px);
    width: calc(30% - 10px)
}

.ses-page #service p.box-text strong {
    width: -webkit-calc(15% - 10px);
    width: -moz-calc(15% - 10px);
    width: -ms-calc(15% - 10px);
    width: -o-calc(15% - 10px);
    width: calc(15% - 10px)
}

#service p.box-text span {
    display: inline-block;
    width: 70%;
    vertical-align: middle
}

.ses-page #service p.box-text span {
    width: 85%
}

#service .service-lists .tcube-contents {
    position: relative;
    overflow: hidden;
    margin-top: 20px
}

#service .service-lists .tcube-contents > * {
    display: inline-block;
    vertical-align: middle
}

#service .service-lists .tcube-contents img {
    width: -webkit-calc(55% - 20px);
    width: -moz-calc(55% - 20px);
    width: -ms-calc(55% - 20px);
    width: -o-calc(55% - 20px);
    width: calc(55% - 20px);
    margin-right: 15px
}

#service .service-lists .tcube-contents a {
    width: 45%;
    background-color: rgba(172, 207, 53, 1);
    text-align: center;
    color: #FFFFFF;
    border-radius: 5px;
    padding: 0px 0 20px
}

#service .service-lists .tcube-contents a:hover {
    background-color: rgba(172, 207, 53, .6)
}

#service .service-lists .tcube-contents a:before {
    position: absolute;
    left: 50%;
    bottom: 7px;
    width: 1em;
    height: 1em;
    background-color: rgba(255, 255, 255, 1)
}

#service .service-lists .tcube-contents a:hover:before {
    background-color: rgba(255, 183, 0, .6)
}

#service .service-lists .tcube-contents a:after {
    display: block;
    left: 53%;
    bottom: 10px;
    top: unset;
    position: absolute;
    width: .5em;
    height: .5em;
    border-color: rgba(33, 33, 33, 1)
}

#service .service-lists .tcube-contents a:hover:after {
    border-color: rgba(255, 255, 255, .6)
}

p.xl-text {
    font-size: 2.2rem;
    text-align: center;
    margin: 40px
}

#service-page table.spHide {
    margin-bottom: 40px
}

#service-page table.spHide tr {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.full-content table th,
.full-content table td {
    width: 25%;
    vertical-align: top
}

.full-content table th.rowspan-content,
.full-content table td.rowspan-content {
    width: 50%
}

.full-content table h5 {
    width: 100%;
    text-align: center;
    font-size: 18px;
    background-color: #cccccc;
    line-height: 3;
    font-weight: normal;
    border: 3px solid #FFFFFF
}

.sol-page .full-content table h5.color-no1 {
    background-color: rgba(209, 242, 255, 1)
}

.sol-page .full-content table h5.color-no2 {
    background-color: rgba(151, 220, 247, 1)
}

.sol-page .full-content table h5.color-no3 {
    background-color: rgba(86, 187, 227, 1)
}

.sol-page .full-content table h5.color-no4 {
    background-color: rgba(0, 163, 226, 1)
}

.ses-page .full-content table h5.color-no1 {
    background-color: rgba(148, 161, 214, 1)
}

.ses-page .full-content table h5.color-no2 {
    background-color: rgba(84, 101, 171, 1)
}

.full-content table h5 {
    width: 100%;
    text-align: center;
    font-size: 1.8rem;
    background-color: #cccccc;
    line-height: 3;
    font-weight: normal;
    border: 3px solid #FFFFFF
}

.full-content table .list-style-1 {
    width: auto;
    max-width: 11.5em;
    font-size: 1.6rem;
    margin: 30px 0;
    list-style-type: disc;
    line-height: 1.7em;
    position: relative;
    left: 50%;
    float: left
}

.full-content table .list-style-1 li {
    position: relative;
    left: -50%
}

.full-content table tr:last-child td {
    border: 1px solid #999999;
    font-size: 1.6rem;
    background-color: #EFEFEF;
    padding: 20px 40px;
    margin: 20px;
    line-height: 1.7em;
    width: -webkit-calc(25% - 122px);
    width: -moz-calc(25% - 122px);
    width: -ms-calc(25% - 122px);
    width: -o-calc(25% - 122px);
    width: calc(25% - 122px)
}

.full-content table tr:last-child td.text-block.colspan-content {
    width: -webkit-calc(50% - 122px);
    width: -moz-calc(50% - 122px);
    width: -ms-calc(50% - 122px);
    width: -o-calc(50% - 122px);
    width: calc(50% - 122px)
}

.block-content > p.section-text {
    margin: 20px 0;
    font-size: 1.6rem
}

#footer .office {
    padding-right: 0
}

ul.link-col.col-3 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

ul.link-col.col-3 li {
    text-align: center;
    font-size: 1.6rem;
    font-weight: bold;
    background-color: #EFEFEF;
    margin-right: 20px;
    height: 150px;
    cursor: pointer;
    width: -webkit-calc(33.33333% - 13.333333px);
    width: -moz-calc(33.33333% - 13.333333px);
    width: -ms-calc(33.33333% - 13.333333px);
    width: -o-calc(33.33333% - 13.333333px);
    width: calc(33.33333% - 13.333333px)
}

ul.link-col.col-3 li:last-child {
    margin-right: 0
}

ul.link-col.col-3 li span {
    display: inline-block;
    line-height: 1.4
}

ul.link-col.col-3 li .arrow {
    display: block;
    padding: 0;
    letter-spacing: -.03em;
    height: 100%;
    top: 40%;
    -webkit-transform: translateY(-40%);
    -moz-transform: translateY(-40%);
    -ms-transform: translateY(-40%);
    -o-transform: translateY(-40%);
    transform: translateY(-40%)
}

ul.link-col.col-3 li .arrow span {
    position: absolute;
    top: 40%;
    -webkit-transform: translate(-50%, -40%);
    -moz-transform: translate(-50%, -40%);
    -ms-transform: translate(-50%, -40%);
    -o-transform: translate(-50%, -40%);
    transform: translate(-50%, -40%);
    width: 100%;
    left: 50%
}

ul.link-col.col-3 li .arrow.arrow-bk:before {
    position: absolute;
    left: 50%;
    bottom: 20px;
    width: 1.2em;
    height: 1.2em
}

ul.link-col.col-3 li .arrow.arrow-bk:after {
    display: block;
    left: 52%;
    bottom: 24px;
    top: unset;
    position: absolute
}


/*footer*/

section.partner_logo {
    position: relative;
    overflow: hidden;
    width: 67%;
    float: left;
    margin-right: 20px
}

section.facebook_widget {
    position: relative;
    overflow: hidden;
    width: -webkit-calc(33% - 20px);
    width: -moz-calc(33% - 20px);
    width: -ms-calc(33% - 20px);
    width: -o-calc(33% - 20px);
    width: calc(33% - 20px);
    float: right;
    max-width: 340px
}

#footer .location > * {
    width: -webkit-calc(33.3333% - 20px);
    width: -moz-calc(33.3333% - 20px);
    width: -ms-calc(33.3333% - 20px);
    width: -o-calc(33.3333% - 20px);
    width: calc(33.3333% - 20px);
    float: left;
    max-width: 500px;
    margin-right: 20px
}

#footer .location > section:last-child {
    margin-right: 0
}

section.partner_logo > ul.company-detail {
    margin: 0 10px 0 30px;
    max-width: 100%
}

section.partner_logo > ul.company-detail li {
    height: auto;
    margin: 0;
    display: block;
    float: none;
    text-align: left;
    font-size: 1.4rem
}

section.partner_logo > ul.company-detail li.name {
    font-size: 2rem
}



#footer .location > section.footer_map,
#footer .location > section.facebook_widget {
    margin: 20px auto;
    float: right;
    max-width: 360px;
    position: relative;
    overflow: hidden
}

#footer .location > section.footer_map > *,
#footer .location > section.facebook_widget > * {
    position: relative;
    top: 0;
    left: 50%;
    display: inline-block;
    display: block;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%)
}

section.partner_logo > ul {
    display: block;
    padding: 5px;
    width: auto;
    max-width: 200px;
    background: none;
    overflow: auto;
    margin-left: 200px;
    margin-top: 10px
}

section.partner_logo li {
    height: 120px;
    float: left;
    margin: 5px;
    width: auto
}

section.partner_logo > ul > li > a > img,
section.partner_logo > ul > li > img {
    width: 100%
}

section.partner_logo li > ul a > img,
section.partner_logo li > ul img {
    width: 100%;
    max-width: 100px
}

section.partner_logo li li {
    height: auto;
    float: none;
    margin: 0 0 5px
}

@media only screen and (min-width: 1025px) {
    .no_touch_device body {
        overflow-x: hidden
    }

    #wrap .cateConts > .inner {
        box-sizing: border-box;
        padding: 40px
    }

    #wrap .cateConts .bg {
        background-position: left top
    }

    #wrap .categoryTtl {
        /*top: 30px;
        left: 30px*/
    }

    #wrap .categoryTtl .en {
        margin-bottom: 15px;
        font-size: 4.2rem;
        line-height: 1em;
        text-align: center
    }

    #wrap .categoryTtl .ja {
        font-size: 2.2rem
    }

    #wrap .frame {
        -webkit-transition: all 500ms ease;
        transition: all 500ms ease
    }

    #wrap .frame:hover .icon:before {
        margin-top: -2px;
        width: 24px;
        height: 24px;
        border-width: 4px
    }

    #wrap .frame .box {
        padding: 2px
    }

    #wrap .frame > .txt {
        padding-right: 5px;
        padding-left: 5px
    }

    #wrap .frame > .txt .en {
        margin-bottom: 10px
    }

    #wrap .frame .icon {
        margin-top: 35px;
        padding-top: 15px;
        -webkit-transition: all 500ms ease;
        transition: all 500ms ease
    }

    #wrap .frame .icon:before {
        width: 16px;
        height: 16px;
        border-width: 6px;
        -webkit-transition: all 300ms ease;
        transition: all 300ms ease
    }

    .parallax_page #wrap .cateConts .bg {
        background-attachment: fixed
    }

    .parallax_page #wrap .cateConts .effectBox {
        opacity: 1;
        position: relative
    }

    .parallax_page #wrap .cateConts:not(#mainVisual) {
        background-color: #222
    }

    .parallax_page #wrap .cateConts:not(#mainVisual) > .inner {
        /*background-color: #222*/
        overflow: visible
    }

    #index.parallax_page #wrap #contact {
        background-color: #FFFFFF
    }

    .parallax_page #wrap #mission.cateConts {
        height: auto !important;
        background-color: #fff;
        background-position: left top;
        background-repeat: no-repeat;
        background-size: cover;
        background-attachment: fixed
    }

    .parallax_page #wrap #mission.cateConts > .inner {
        background-color: rgba(255, 255, 255, .5)
    }

    .parallax_page #wrap .cateConts.preview {
        z-index: 10
    }

    .parallax_page #wrap .textLoad {
        opacity: 0
    }

    .parallax_page #wrap .preview .textLoad {
        opacity: 1
    }

    .parallax_page #wrap .visited .textLoad {
        opacity: 1
    }

    .parallax_page #wrap .panelList {
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 5000
    }

    .parallax_page #wrap .panel {
        width: 20%;
        height: 33.33333333333%;
        background-color: #FFF;
        opacity: 1;
        position: absolute
    }

    .parallax_page #wrap .preview .panel {
        opacity: 0
    }

    .parallax_page #wrap .visited .panelList {
        display: none;
        z-index: -1000
    }

    .parallax_page .firstPanelList {
        width: 100%;
        height: 100%;
        position: fixed;
        top: 0;
        left: 0;
        z-index: 9999;
        content: ""
    }

    .parallax_page .firstPanelList .panel {
        width: 20%;
        height: 33.33333333333%;
        background-color: #FFF;
        opacity: 1;
        position: absolute
    }

    .parallax_page .firstPanelList.preview .panel {
        opacity: 0
    }

    .parallax_page .firstPanelList.visited {
        display: none;
        z-index: -10000
    }

    .touch_device .parallax_page #mainVisual {
        background-attachment: scroll
    }

    .touch_device .parallax_page #wrap .cateConts .bg {
        background-attachment: scroll
    }

    .touch_device .parallax_page .firstPanelList {
        display: none
    }

    .no-csstransitions.no_touch_device .parallax_page .textLoad {
        opacity: 1
    }

    .no-csstransitions.no_touch_device .parallax_page .panelList {
        display: none
    }

    .no-csstransitions.no_touch_device .parallax_page .panel {
        display: none;
        opacity: 0
    }

    .spLink {
        margin-right: 0;
        padding-right: 40px
    }

    .textFade0 {
        -webkit-transition: opacity 500ms ease 0ms;
        transition: opacity 500ms ease 0ms
    }

    .textFade1 {
        -webkit-transition: opacity 500ms ease 50ms;
        transition: opacity 500ms ease 50ms
    }

    .textFade2 {
        -webkit-transition: opacity 500ms ease 100ms;
        transition: opacity 500ms ease 100ms
    }

    .textFade3 {
        -webkit-transition: opacity 500ms ease 150ms;
        transition: opacity 500ms ease 150ms
    }

    .textFade4 {
        -webkit-transition: opacity 500ms ease 200ms;
        transition: opacity 500ms ease 200ms
    }

    .textFade5 {
        -webkit-transition: opacity 500ms ease 250ms;
        transition: opacity 500ms ease 250ms
    }

    .textFade6 {
        -webkit-transition: opacity 500ms ease 300ms;
        transition: opacity 500ms ease 300ms
    }

    .textFade7 {
        -webkit-transition: opacity 500ms ease 350ms;
        transition: opacity 500ms ease 350ms
    }

    .textFade8 {
        -webkit-transition: opacity 500ms ease 400ms;
        transition: opacity 500ms ease 400ms
    }

    .textFade9 {
        -webkit-transition: opacity 500ms ease 450ms;
        transition: opacity 500ms ease 450ms
    }

    .textFade10 {
        -webkit-transition: opacity 500ms ease 500ms;
        transition: opacity 500ms ease 500ms
    }

    .textFade11 {
        -webkit-transition: opacity 500ms ease 550ms;
        transition: opacity 500ms ease 550ms
    }

    .textFade12 {
        -webkit-transition: opacity 500ms ease 600ms;
        transition: opacity 500ms ease 600ms
    }

    .textFade13 {
        -webkit-transition: opacity 500ms ease 650ms;
        transition: opacity 500ms ease 650ms
    }

    .textFade14 {
        -webkit-transition: opacity 500ms ease 700ms;
        transition: opacity 500ms ease 700ms
    }

    .textFade15 {
        -webkit-transition: opacity 500ms ease 750ms;
        transition: opacity 500ms ease 750ms
    }

    .textFade16 {
        -webkit-transition: opacity 500ms ease 800ms;
        transition: opacity 500ms ease 800ms
    }

    .textFade17 {
        -webkit-transition: opacity 500ms ease 850ms;
        transition: opacity 500ms ease 850ms
    }

    .textFade18 {
        -webkit-transition: opacity 500ms ease 900ms;
        transition: opacity 500ms ease 900ms
    }

    .textFade19 {
        -webkit-transition: opacity 500ms ease 950ms;
        transition: opacity 500ms ease 950ms
    }

    .textFade20 {
        -webkit-transition: opacity 500ms ease 1000ms;
        transition: opacity 500ms ease 1000ms
    }

    .panel0 {
        top: 0;
        left: 0%;
        -webkit-transition: opacity 1000ms ease 0ms;
        transition: opacity 1000ms ease 0ms
    }

    .panel1 {
        top: 0;
        left: 20%;
        -webkit-transition: opacity 1000ms ease 50ms;
        transition: opacity 1000ms ease 50ms
    }

    .panel2 {
        top: 0;
        left: 40%;
        -webkit-transition: opacity 1000ms ease 100ms;
        transition: opacity 1000ms ease 100ms
    }

    .panel3 {
        top: 0;
        left: 60%;
        -webkit-transition: opacity 1000ms ease 150ms;
        transition: opacity 1000ms ease 150ms
    }

    .panel4 {
        top: 0;
        left: 80%;
        -webkit-transition: opacity 1000ms ease 200ms;
        transition: opacity 1000ms ease 200ms
    }

    .panel5 {
        top: 33.33333%;
        left: 0%;
        -webkit-transition: opacity 1000ms ease 250ms;
        transition: opacity 1000ms ease 250ms
    }

    .panel6 {
        top: 33.33333%;
        left: 20%;
        -webkit-transition: opacity 1000ms ease 300ms;
        transition: opacity 1000ms ease 300ms
    }

    .panel7 {
        top: 33.33333%;
        left: 40%;
        -webkit-transition: opacity 1000ms ease 350ms;
        transition: opacity 1000ms ease 350ms
    }

    .panel8 {
        top: 33.33333%;
        left: 60%;
        -webkit-transition: opacity 1000ms ease 400ms;
        transition: opacity 1000ms ease 400ms
    }

    .panel9 {
        top: 33.33333%;
        left: 80%;
        -webkit-transition: opacity 1000ms ease 450ms;
        transition: opacity 1000ms ease 450ms
    }

    .panel10 {
        top: 66.66667%;
        left: 0%;
        -webkit-transition: opacity 1000ms ease 500ms;
        transition: opacity 1000ms ease 500ms
    }

    .panel11 {
        top: 66.66667%;
        left: 20%;
        -webkit-transition: opacity 1000ms ease 550ms;
        transition: opacity 1000ms ease 550ms
    }

    .panel12 {
        top: 66.66667%;
        left: 40%;
        -webkit-transition: opacity 1000ms ease 600ms;
        transition: opacity 1000ms ease 600ms
    }

    .panel13 {
        top: 66.66667%;
        left: 60%;
        -webkit-transition: opacity 1000ms ease 650ms;
        transition: opacity 1000ms ease 650ms
    }

    .panel14 {
        top: 66.66667%;
        left: 80%;
        -webkit-transition: opacity 1000ms ease 700ms;
        transition: opacity 1000ms ease 700ms
    }

}

@media only screen and (max-width: 1360px) and (min-width: 1025px) {
    #footer .location > section.partner_logo {
        width: 400px
    }

    #footer .location > section.footer_map,
    #footer .location > section.facebook_widget {
        width: -webkit-calc(50% - 230px);
        width: -moz-calc(50% - 230px);
        width: -ms-calc(50% - 230px);
        width: -o-calc(50% - 230px);
        width: calc(50% - 230px);
        overflow: hidden;
        margin: 20px 10px;
    }
}


@media only screen and (min-width: 1025px) {
    #wrap .scene {
        height: 960px
    }

    #wrap .cateConts {
        padding-left: 248px
    }
}

@media only screen and (max-resolution: max-width: 1024px) and (min-width: 1025px) {
    #wrap .scene:not(#other) {
        height: 640px
    }

    #wrap .cateConts {
        padding-right: 80px
    }

    .parallax_page #wrap .scene {
        height: 640px
    }
}

@media only screen and (max-width: 1024px) {
    #index.home.top-page main#wrap:before {
        background-image: url(/img/index/top_003_sp.jpg);
        background-position: center bottom;
    }

    .sp-bk {
        display: none
    }

    .section-index main#wrap {
        padding-top: 60px;
    }

    #header {
        width: 100%;
        position: absolute;
        top: 0
    }

    #wrap .cateConts > .inner {
        padding: 20px
    }

    #wrap .cateConts .bg {
        background-position: left 25%
    }

    #wrap .categoryTtl {
        top: 20px;
        position: relative
    }

    #wrap .categoryTtl .en {
        margin-bottom: 10px;
        font-size: 3.2rem
    }

    #wrap .categoryTtl .ja {
        font-size: 1.4rem
    }

    #wrap .frame > .txt {
        padding-right: 5px;
        padding-left: 5px
    }

    #wrap .frame > .txt .en {
        margin-bottom: 7px;
        font-size: 1.6rem
    }

    #wrap .frame > .txt .ja {
        font-size: 0.8rem
    }

    #wrap .frame .icon {
        margin-top: 10px;
        padding-top: 7px
    }

    #wrap .frame .icon:before {
        width: 8px;
        height: 8px;
        border-width: 3px
    }

    #wrap .box:before {
        padding-top: 100%
    }

    section.block-content {
        margin-bottom: 40px
    }

    section.partner_logo > ul > li > a > img,
    section.partner_logo > ul > li > img {
        height: auto
    }
}

@media only screen and (orientation: landscape) and (max-width: 1024px) {
    #wrap .cateConts .bg {
        height: auto
    }
}

@media only screen and (orientation: portrait) and (max-width: 1024px) {
    #wrap .cateConts .bg {
        height: auto
    }
}

@media only screen and (min-width: 1025px) {
    #pager {
        position: fixed;
        bottom: 80px;
        left: 32px;
        z-index: 1500
    }

    #pager li {
        margin-top: 20px
    }

    #pager li:first-child {
        margin-top: 0
    }

    #pager a {
        width: 4px;
        height: 4px;
        border-width: 6px;
        border-style: solid;
        border-color: transparent;
        border-radius: 100%;
        display: block;
        position: relative;
        -webkit-transition: all 300ms ease;
        transition: all 300ms ease
    }

    #pager a:before {
        margin-top: -2px;
        margin-left: -2px;
        width: 4px;
        height: 4px;
        background-color: rgba(0, 0, 0, 0.25);
        border-radius: 100%;
        position: absolute;
        top: 50%;
        left: 50%;
        content: "";
        -webkit-transition: all 300ms ease;
        transition: all 300ms ease
    }

    #pager a:hover {
        border-color: rgba(0, 0, 0, 0.25)
    }

    #pager a:hover:before {
        background-color: rgba(255, 255, 255, 0.5)
    }

    #pager .current a {
        border-color: rgba(255, 255, 255, 0.25)
    }

    #pager .current a:before {
        background-color: rgba(255, 255, 255, 0.5)
    }
}

@media only screen and (max-width: 1024px) {
    #pager {
        display: none
    }
}

/*-----mainVisual---------------------------------------------------------------------*/

#mainVisual {
    position: relative;
    overflow: hidden
}

#mainVisual:after {
    /*background: url("/img/index/top.png") no-repeat center;*/
    /*    background: url("/img/index/top_001.jpg") no-repeat center;
    background-size: cover;*/
    display: block;
    content: "";
    min-width: 100vw;
    min-height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    /*    min-width: 150vw;
    min-height: 150vh;*/
    /*    animation-iteration-count:infinite;
    animation: Main-bg 300s ease-in alternate forwards;
    -webkit-animation: Main-bg 300s ease-in 0s forwards;
    -o-animation: Main-bg 300s ease-in 0s forwards;
    animation: Main-bg 300s ease-in 0s forwards;*/
}

#mainVisual > .inner {
    /*background-image: url(/img/index/top_003.jpg);*/
    background-size: cover;
    background-position: right bottom
}

/*#mainVisual.b2 > .inner { background-image: url("/img/index/top_002.jpg"); }
#mainVisual.b3 > .inner { background-image: url("/img/index/top_001.jpg"); }*/

/*@keyframes Main-bg {
    0%{
        -webkit-transform: rotate(0deg);
           -moz-transform: rotate(0deg);
            -ms-transform: rotate(0deg);
             -o-transform: rotate(0deg);
                transform: rotate(0deg);
    }
    100%{
        -webkit-transform: rotate(90deg);
           -moz-transform: rotate(90deg);
            -ms-transform: rotate(90deg);
             -o-transform: rotate(90deg);
                transform: rotate(90deg);
    }
}
@-moz-keyframes Main-bg {
    0%{
        -webkit-transform: rotate(0deg);
           -moz-transform: rotate(0deg);
            -ms-transform: rotate(0deg);
             -o-transform: rotate(0deg);
                transform: rotate(0deg);
    }
    100%{
        -webkit-transform: rotate(90deg);
           -moz-transform: rotate(90deg);
            -ms-transform: rotate(90deg);
             -o-transform: rotate(90deg);
                transform: rotate(90deg);
    }
}
@-webkit-keyframes Main-bg {
    0%{
        -webkit-transform: rotate(0deg);
           -moz-transform: rotate(0deg);
            -ms-transform: rotate(0deg);
             -o-transform: rotate(0deg);
                transform: rotate(0deg);
    }
    100%{
        -webkit-transform: rotate(90deg);
           -moz-transform: rotate(90deg);
            -ms-transform: rotate(90deg);
             -o-transform: rotate(90deg);
                transform: rotate(90deg);
    }
}
@-o-keyframes Main-bg {
    0%{
        -webkit-transform: rotate(0deg);
           -moz-transform: rotate(0deg);
            -ms-transform: rotate(0deg);
             -o-transform: rotate(0deg);
                transform: rotate(0deg);
    }
    100%{
        -webkit-transform: rotate(90deg);
           -moz-transform: rotate(90deg);
            -ms-transform: rotate(90deg);
             -o-transform: rotate(90deg);
                transform: rotate(90deg);
    }
}
@-ms-keyframes Main-bg {
    0%{
        -webkit-transform: rotate(0deg);
           -moz-transform: rotate(0deg);
            -ms-transform: rotate(0deg);
             -o-transform: rotate(0deg);
                transform: rotate(0deg);
    }
    100%{
        -webkit-transform: rotate(90deg);
           -moz-transform: rotate(90deg);
            -ms-transform: rotate(90deg);
             -o-transform: rotate(90deg);
                transform: rotate(90deg);
    }
}*/
/* #mainVisual > .inner:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 0;
    animation: Main-bg-w 8s ease-in alternate forwards;
    -webkit-animation: Main-bg-w 8s ease-in 0s forwards;
    -o-animation: Main-bg-w 8s ease-in 0s forwards;
    animation: Main-bg-w 8s ease-in 0s forwards
} */
@keyframes Main-bg-w {
    0% {
        background-color: rgba(255, 255, 255, 1)
    }

    70% {
        background-color: rgba(255, 255, 255, 1)
    }

    100% {
        background-color: rgba(255, 255, 255, 0)
    }
}

@-moz-keyframes Main-bg-w {
    0% {
        background-color: rgba(255, 255, 255, 1)
    }

    70% {
        background-color: rgba(255, 255, 255, 1)
    }

    100% {
        background-color: rgba(255, 255, 255, 0)
    }
}

@-webkit-keyframes Main-bg-w {
    0% {
        background-color: rgba(255, 255, 255, 1)
    }

    70% {
        background-color: rgba(255, 255, 255, 1)
    }

    100% {
        background-color: rgba(255, 255, 255, 0)
    }
}

@-o-keyframes Main-bg-w {
    0% {
        background-color: rgba(255, 255, 255, 1)
    }

    70% {
        background-color: rgba(255, 255, 255, 1)
    }

    100% {
        background-color: rgba(255, 255, 255, 0)
    }
}

@-ms-keyframes Main-bg-w {
    0% {
        background-color: rgba(255, 255, 255, 1)
    }

    70% {
        background-color: rgba(255, 255, 255, 1)
    }

    100% {
        background-color: rgba(255, 255, 255, 0)
    }
}

/*#mainVisual {
    background: url("/img/index/top.png") no-repeat center;
    background-size: cover;
    animation: Main-bg 8s ease-in alternate forwards;
    -webkit-animation: Main-bg 8s ease-in 0s forwards;
    -o-animation: Main-bg 8s ease-in 0s forwards;
    animation: Main-bg 8s ease-in 0s forwards
}

@keyframes Main-bg {
    0%{ background-color: rgba(255,255,255,0) }
    70%{ background-color: rgba(255,255,255,1); background-size: auto 400% }
    90%{ background-size: auto 120% }
    95%{ background-size: auto 200% }
    100%{ background-size: auto 100% }
}
@-moz-keyframes Main-bg {
    0%{ background-color: rgba(255,255,255,0) }
    70%{ background-color: rgba(255,255,255,1); background-size: auto 400% }
    90%{ background-size: auto 120% }
    95%{ background-size: auto 200% }
    100%{ background-size: auto 100% }
}
@-webkit-keyframes Main-bg {
    0%{ background-color: rgba(255,255,255,0) }
    70%{ background-color: rgba(255,255,255,1); background-size: auto 400% }
    90%{ background-size: auto 120% }
    95%{ background-size: auto 200% }
    100%{ background-size: auto 100% }
}
@-o-keyframes Main-bg {
    0%{ background-color: rgba(255,255,255,0) }
    70%{ background-color: rgba(255,255,255,1); background-size: auto 400% }
    90%{ background-size: auto 120% }
    95%{ background-size: auto 200% }
    100%{ background-size: auto 100% }
}
@-ms-keyframes Main-bg {
    0%{ background-color: rgba(255,255,255,0) }
    70%{ background-color: rgba(255,255,255,1); background-size: auto 400% }
    90%{ background-size: auto 120% }
    95%{ background-size: auto 200% }
    100%{ background-size: auto 100% }
}*/

#mainVisual > .inner {
    position: relative;
    z-index: 1
}

#mainVisual .philosophy {
    position: absolute;
    left: 50%;
    text-align: center;
    -webkit-transform: translateY(-50%) translateX(-50%);
    transform: translateY(-50%) translateX(-50%);
    -ms-transform: translateY(-50%) translateX(-50%)
}

#mainVisual .philosophy .catchcopy {
    line-height: 1
}

#mainVisual .mouse {
    opacity: 0.5;
    position: absolute;
    left: 50%
}

#mainVisual .mouse .wheel,
#mainVisual .mouse:after {
    box-sizing: border-box;
    position: absolute;
    content: ""
}

#mainVisual .mouse:after {
    width: 100%;
    height: 100%;
    border: 2px solid #333;
    border-radius: 15px;
    top: 0;
    left: 0
}

#mainVisual .mouse .wheel {
    background-color: #333;
    border-radius: 100%;
    left: 50%
}

#mainVisual .mouse .txt {
    position: absolute;
    left: 50%;
    color: #333;
    text-align: center
}

/*#mainVisual .arrow {
    position: absolute;
    left: 50%
}

#mainVisual .arrow:before,
#mainVisual .arrow:after {
    position: absolute;
    bottom: 0;
    content: ""
}

#mainVisual .arrow:before {
    background-color: #333;
    left: 50%
}

#mainVisual .arrow:after {
    box-sizing: border-box;
    border-top: none;
    border-right: none;
    border-bottom-style: solid;
    border-bottom-color: rgba(0, 0, 0, .9);
    border-left-style: solid;
    border-left-color: rgba(0, 0, 0, .9);
    left: 50%;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -ms-transform: rotate(-45deg)
}*/


/*main svg*/

.logoImg {
    width: 500px;
    margin: 0 auto
}

.logoImg svg {
    z-index: 2;
    animation: logo 5s ease-in alternate forwards;
    -webkit-animation: logo 5s ease-in 0s forwards;
    -o-animation: logo 5s ease-in 0s forwards;
    animation: logo 5s ease-in 0s forwards
}

@keyframes logo {
    0% {
        width: 500px;
    }

    85% {
        width: 500px;
    }

    100% {
        width: 350px;
    }
}

@-moz-keyframes logo {
    0% {
        width: 500px;
    }

    85% {
        width: 500px;
    }

    100% {
        width: 350px;
    }
}

@-webkit-keyframes logo {
    0% {
        width: 500px;
    }

    85% {
        width: 500px;
    }

    100% {
        width: 350px;
    }
}

@-o-keyframes logo {
    0% {
        width: 500px;
    }

    85% {
        width: 500px;
    }

    100% {
        width: 350px;
    }
}

@-ms-keyframes logo {
    0% {
        width: 500px;
    }

    85% {
        width: 500px;
    }

    100% {
        width: 350px;
    }
}

.path {
    stroke: rgba(0, 0, 0, 1);
    fill: rgba(0, 0, 0, 1);
    stroke-width: 2;
    stroke-dasharray: 940;
    stroke-dashoffset: 940;
    animation: DASH 4s ease-in alternate forwards;
    -webkit-animation: DASH 4s ease-in 0s forwards;
    -o-animation: DASH 4s ease-in 0s forwards;
    animation: DASH 4s ease-in 0s forwards;
    /*animation-iteration-count:infinite;*/
}

@keyframes DASH {
    0% {
        fill: rgba(0, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(0, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(0, 0, 0, 1);
    }
}

@-moz-keyframes DASH {
    0% {
        fill: rgba(0, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(0, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(0, 0, 0, 1);
    }
}

@-webkit-keyframes DASH {
    0% {
        fill: rgba(0, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(0, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(0, 0, 0, 1);
    }
}

@-o-keyframes DASH {
    0% {
        fill: rgba(0, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(0, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(0, 0, 0, 1);
    }
}

@-ms-keyframes DASH {
    0% {
        fill: rgba(0, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(0, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(0, 0, 0, 1);
    }
}

.st0.path {
    stroke: rgba(240, 0, 0, 1);
    fill: rgba(240, 0, 0, 1);
    stroke-width: 2;
    stroke-dasharray: 940;
    stroke-dashoffset: 940;
    animation: DASHr 4s ease-in alternate forwards;
    -webkit-animation: DASHr 4s ease-in 0s forwards;
    -o-animation: DASHr 4s ease-in 0s forwards;
    animation: DASHr 4s ease-in 0s forwards;
    /*animation-iteration-count:infinite;*/
}

@keyframes DASHr {

    0% {
        fill: rgba(240, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(240, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(240, 0, 0, 1);
    }
}

@-moz-keyframes DASHr {

    0% {
        fill: rgba(240, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(240, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(240, 0, 0, 1);
    }
}

@-webkit-keyframes DASHr {

    0% {
        fill: rgba(240, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(240, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(240, 0, 0, 1);
    }
}

@-o-keyframes DASHr {

    0% {
        fill: rgba(240, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(240, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(240, 0, 0, 1);
    }
}

@-ms-keyframes DASHr {

    0% {
        fill: rgba(240, 0, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(240, 0, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(240, 0, 0, 1);
    }
}

.st1.path {
    stroke: rgba(255, 183, 0, 1);
    fill: rgba(255, 183, 0, 1);
    stroke-width: 2;
    stroke-dasharray: 940;
    stroke-dashoffset: 940;
    animation: DASHy 4s ease-in alternate forwards;
    -webkit-animation: DASHy 4s ease-in 0s forwards;
    -o-animation: DASHy 4s ease-in 0s forwards;
    animation: DASHy 4s ease-in 0s forwards;
    /*animation-iteration-count:infinite;*/
}

@keyframes DASHy {

    0% {
        fill: rgba(255, 183, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(255, 183, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(255, 183, 0, 1);
    }
}

@-moz-keyframes DASHy {

    0% {
        fill: rgba(255, 183, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(255, 183, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(255, 183, 0, 1);
    }
}

@-webkit-keyframes DASHy {

    0% {
        fill: rgba(255, 183, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(255, 183, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(255, 183, 0, 1);
    }
}

@-o-keyframes DASHy {

    0% {
        fill: rgba(255, 183, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(255, 183, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(255, 183, 0, 1);
    }
}

@-ms-keyframes DASHy {

    0% {
        fill: rgba(255, 183, 0, 0);
    }

    50% {
        stroke-dashoffset: 940;
    }

    80% {
        stroke-dashoffset: 0;
        fill: rgba(255, 183, 0, 0);
    }

    100% {
        stroke-width: 0;
        fill: rgba(255, 183, 0, 1);
    }
}

#mainVisual .logo-text {
    font-size: 3rem;
    color: ;
    animation: maintext 7s ease-in alternate forwards;
    -webkit-animation: maintext 7s ease-in 0s forwards;
    -o-animation: maintext 7s ease-in 0s forwards;
    animation: maintext 7s ease-in 0s forwards;
    /*animation-iteration-count:infinite;*/
}

@keyframes maintext {
    0% {
        opacity: 0
    }

    80% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-moz-keyframes DASHy {
    0% {
        opacity: 0
    }

    80% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-webkit-keyframes DASHy {
    0% {
        opacity: 0
    }

    80% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-o-keyframes DASHy {
    0% {
        opacity: 0
    }

    80% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-ms-keyframes DASHy {
    0% {
        opacity: 0
    }

    80% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}


@media only screen and (min-width: 1025px) {
    #infinite {
        margin: 0 auto;
        width: 406px;
        position: absolute;
        top: 0;
        right: 0;
        left: 0
    }

    #infinite:after {
        display: block;
        clear: both;
        content: ""
    }

    #infinite .ring {
        background-color: rgba(0, 0, 0, 0.2);
        border-radius: 100%;
        overflow: hidden;
        float: left;
        line-height: 1
    }

    #infinite .ring + .ring {
        float: right
    }

    #infinite .ring svg {
        display: block
    }

    #mainVisual {
        background-attachment: fixed
    }

    #mainVisual .inner {
        overflow: visible
    }

    #mainVisual .philosophy {
        position: relative
    }

    #mainVisual .philosophy .catchcopy {
        margin-top: 40px;
        font-size: 4rem
    }

    #mainVisual .catch {
        display: none
    }

    #mainVisual .mouse {
        margin-left: -12px;
        width: 24px;
        height: 40px;
        bottom: 177px
    }

    #mainVisual .mouse .wheel {
        margin-left: -2px;
        width: 4px;
        height: 8px;
        top: 6px;
        -webkit-animation: wheel_move 1s infinite ease;
        animation: wheel_move 1s infinite ease
    }

    #mainVisual .mouse .txt {
        margin-left: -16px;
        width: 32px;
        top: -24px;
        font-size: 1.2rem
    }

    #mainVisual .arrow {
        width: 20px
    }

    /*    #mainVisual .arrow:before {
        margin-left: -1px;
        width: 2px;
        height: 36px
    }
    #mainVisual .arrow:after {
        margin-left: -6px;
        width: 11px;
        height: 11px
    }*/
    .csstransitions.no_touch_device #mainVisual .philosophy .catchImg {
        display: none
    }

    .csstransitions.no_touch_device #mainVisual .image {
        opacity: 0;
        -webkit-transition: opacity 750ms ease;
        transition: opacity 750ms ease
    }

    .csstransitions.no_touch_device #mainVisual .image.on {
        opacity: 1
    }

    .csstransitions.no_touch_device #mainVisual .catchcopy .textLoad {
        opacity: 0
    }

    .csstransitions.no_touch_device #mainVisual .catchcopy.on .textLoad {
        opacity: 1
    }

    .csstransitions.no_touch_device #mainVisual .catch {
        margin-right: auto;
        margin-left: auto;
        width: 406px;
        height: 180px;
        display: block;
        position: relative
    }

    .csstransitions.no_touch_device #mainVisual .ring {
        width: 180px;
        height: 180px;
        position: absolute;
        top: 0;
        -webkit-transition: all 500ms ease;
        transition: all 500ms ease
    }

    .csstransitions.no_touch_device #mainVisual .ring .img {
        opacity: 0
    }

    .csstransitions.no_touch_device #mainVisual .leftImg {
        left: -60px
    }

    .csstransitions.no_touch_device #mainVisual .leftImg.on {
        left: 0
    }

    .csstransitions.no_touch_device #mainVisual .leftImg .txtImg {
        -webkit-transition: all 500ms ease 1000ms;
        transition: all 500ms ease 1000ms
    }

    .csstransitions.no_touch_device #mainVisual .leftImg .img {
        margin-top: -20px;
        -webkit-transition: all 500ms ease;
        transition: all 500ms ease
    }

    .csstransitions.no_touch_device #mainVisual .leftImg .img.on {
        margin-top: 0;
        opacity: 1
    }

    .csstransitions.no_touch_device #mainVisual .rightImg {
        right: -80px
    }

    .csstransitions.no_touch_device #mainVisual .rightImg.midstream {
        right: -60px
    }

    .csstransitions.no_touch_device #mainVisual .rightImg.on {
        right: 0
    }

    .csstransitions.no_touch_device #mainVisual .rightImg .txtImg {
        -webkit-transition: all 500ms ease 1500ms;
        transition: all 500ms ease 1500ms
    }

    .csstransitions.no_touch_device #mainVisual .rightImg .img {
        margin-top: 20px;
        -webkit-transition: all 500ms ease 500ms;
        transition: all 500ms ease 500ms
    }

    .csstransitions.no_touch_device #mainVisual .rightImg .img.on {
        margin-top: 0;
        opacity: 1
    }

    .csstransitions.no_touch_device #mainVisual .rotate {
        -webkit-transform: rotateY(0deg);
        transform: rotateY(0deg);
        -webkit-transition: all 500ms ease;
        transition: all 500ms ease
    }

    .csstransitions.no_touch_device #mainVisual .rotate.on {
        -webkit-transform: rotateY(180deg);
        transform: rotateY(180deg)
    }

    .csstransitions.no_touch_device #mainVisual .cross {
        margin-top: -63px;
        margin-left: -63px;
        width: 126px;
        height: 126px;
        opacity: 0;
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
        -webkit-transition: all 500ms ease;
        transition: all 500ms ease
    }

    .csstransitions.no_touch_device #mainVisual .cross.on {
        -webkit-transform: rotate(720deg);
        transform: rotate(720deg);
        opacity: 1
    }

    .csstransitions.no_touch_device #mainVisual .txtImg {
        width: 100%;
        opacity: 0;
        position: absolute;
        top: 50%;
        left: 20px;
        text-align: center;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        -ms-transform: translateY(-50%)
    }

    .csstransitions.no_touch_device #mainVisual .txtImg.on {
        left: 0;
        opacity: 1
    }
}

@media only screen and (min-width: 1025px) {
    #mainVisual .philosophy {
        top: 45%
    }
}

@media only screen and (min-width: 1025px) and (max-height: 900px) {
    #mainVisual .philosophy {
        top: 35%
    }
}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {
    #mainVisual .philosophy {
        top: 40%
    }
}

@media only screen and (max-width: 1024px) {
    #mainVisual {
        height: -webkit-calc(100vh);
        /* - 60px*/
        height: -moz-calc(100vh);
        /* - 60px*/
        height: -ms-calc(100vh);
        /* - 60px*/
        height: -o-calc(100vh);
        /* - 60px*/
        height: calc(100vh)
    }

    /* - 60px*/
    #mainVisual .philosophy {
        top: 40%
    }

    #wrap #mainVisual.cateConts > .inner {
        height: -webkit-calc(100vh);
        /* - 60px*/
        height: -moz-calc(100vh);
        /* - 60px*/
        height: -ms-calc(100vh);
        /* - 60px*/
        height: -o-calc(100vh);
        /* - 60px*/
        height: calc(100vh)
            /* - 60px*/
    }

    #mainVisual > .inner {
        background-size: cover
    }

    #mainVisual.b2 > .inner {
        background-image: url("/img/index/top_002_sp.jpg");
    }

    #mainVisual.b3 > .inner {
        background-image: url("/img/index/top_001_sp.jpg");
    }

    #mainVisual .philosophy .catchImg {
        width: 203px
    }

    #mainVisual .philosophy .catchcopy {
        margin-top: 10px;
        margin-right: -20px;
        margin-left: -20px;
        font-size: 2rem
    }

    #mainVisual .catch {
        display: none
    }

    #mainVisual .logo-text {
        font-size: 2.6em;
        line-height: 1.4em;
        position: relative;
        bottom: 10vh
    }

    /*main svg*/

    .logoImg {
        width: 300px;
        margin: 0 auto;
    }

    .logoImg svg {
        animation: logo 8s ease-in alternate forwards;
        -webkit-animation: logo 8s ease-in 0s forwards;
        -o-animation: logo 8s ease-in 0s forwards;
        animation: logo 8s ease-in 0s forwards;
    }

    @keyframes logo {
        0% {
            width: 300px;
        }

        85% {
            width: 300px;
        }

        100% {
            width: 200px;
        }
    }

    @-moz-keyframes logo {
        0% {
            width: 300px;
        }

        85% {
            width: 300px;
        }

        100% {
            width: 200px;
        }
    }

    @-webkit-keyframes logo {
        0% {
            width: 300px;
        }

        85% {
            width: 300px;
        }

        100% {
            width: 200px;
        }
    }

    @-o-keyframes logo {
        0% {
            width: 300px;
        }

        85% {
            width: 300px;
        }

        100% {
            width: 200px;
        }
    }

    @-ms-keyframes logo {
        0% {
            width: 300px;
        }

        85% {
            width: 300px;
        }

        100% {
            width: 200px;
        }
    }
}



@-webkit-keyframes wheel_move {
    0% {
        -webkit-transform: translateY(0px);
        transform: translateY(0px)
    }

    50% {
        -webkit-transform: translateY(5px);
        transform: translateY(5px)
    }

    100% {
        -webkit-transform: translateY(0px);
        transform: translateY(0px)
    }
}

@keyframes wheel_move {
    0% {
        -webkit-transform: translateY(0px);
        transform: translateY(0px)
    }

    50% {
        -webkit-transform: translateY(5px);
        transform: translateY(5px)
    }

    100% {
        -webkit-transform: translateY(0px);
        transform: translateY(0px)
    }
}

/*-----news---------------------------------------------------------------------*/

#news {
    background-color: rgba(51, 51, 51, 0.8);
    box-sizing: border-box;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0
}

#news .frame {
    width: 100%;
    border-radius: 0;
    position: relative;
    overflow: hidden
}

#news .newsTicker {
    position: relative;
    overflow: hidden
}

#news .list {
    width: calc(25% - 20px);
    position: relative;
    top: 0;
    left: 0;
    line-height: 1;
    float: left;
    margin: 0 10px;
    opacity: 1;
    font-size: 1.6rem
}

#news .list:after {
    display: block;
    clear: both;
    content: ""
}

#news .list .date,
#news .list .txt {
    float: left;
    line-height: 1
}

#news .list .date {
    padding-right: 10px;
    width: 30%;
    min-width: 75px
}

#news .list img {
    width: 100%;
}

#news .list .ttl {
    font-weight: normal;
    color: #333;
    font-size: 1.6rem;
    display: block;
    height: 4.4em;
    overflow: hidden
}

#news .list .ttl time {
    display: block
}

#news .list.current {
    z-index: 10
}

#news .btnGroup {
    box-sizing: border-box;
    padding: 2px
}

#news .btnGroup:after {
    display: block;
    clear: both;
    content: ""
}

#news .switch {
    margin-right: 2px;
    height: 100%;
    float: left
}

#news .switch:after {
    display: block;
    clear: both;
    content: ""
}

#news .btn {
    height: 100%;
    position: relative;
    cursor: pointer
}

#news .btn:before {
    border: 2px solid #333;
    position: relative;
    top: 50%;
    left: 50%;
    content: "";
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -ms-transform: rotate(-45deg)
}

#news .btn.noClick {
    cursor: default
}

#news .btn.noClick:before {
    opacity: 0.3
}

#news .prev {
    float: left
}

#news .prev:before {
    border-right: none;
    border-bottom: none
}

#news .next {
    float: right
}

#news .next:before {
    border-top: none;
    border-left: none
}

#news .more {
    box-sizing: border-box;
    display: block;
    float: right;
    position: relative;
    color: #333;
    text-align: center
}

/*#news .more:before {
    box-sizing: border-box;
    border-radius: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    content: "";
    -webkit-transform: translateY(-50%) translateX(-50%);
    transform: translateY(-50%) translateX(-50%);
    -ms-transform: translateY(-50%) translateX(-50%)
}

#mainVisual #news .arrow:before {
    height: 20px;
    width: 20px;
    background-color: #FFFFFF;
    top: 40px;
}

#mainVisual #news .arrow:after {
    -webkit-transform: rotate(225deg);
    -moz-transform: rotate(225deg);
    -ms-transform: rotate(225deg);
    -o-transform: rotate(225deg);
    transform: rotate(225deg);
    border-radius: 30%;
    top: 34px;
    left: 49%
}*/

@media only screen and (min-width: 1025px) {
    #news {
        padding: 20px
    }

    #news .frame {
        display: block
    }

    #news .frame > .ttl,
    #news .frame > .inner {
        line-height: 1;
        display: block;
        position: relative
    }

    #news .frame > .ttl {
        width: 200px;
        font-size: 3rem;
        color: rgba(255, 255, 255, 1);
        position: absolute;
        top: 50%;
        left: 0;
        -webkit-transform: translateY(-50%);
        -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        -o-transform: translateY(-50%);
        transform: translateY(-50%);
        text-align: center;
        font-weight: normal
    }

    #news .frame > .inner {
        height: 100%;
        width: calc(100% - 200px);
        margin-left: 200px;
    }

    #news .newsTicker {
        width: 80%
    }

    #news .list .date {
        background-color: rgba(255, 255, 255, 1);
        position: relative;
        bottom: 0;
        left: 0;
        padding: 10px;
        width: calc(100% - 20px);
        color: #333;
        pointer-events: none;
        -webkit-transition: all .25s ease;
        -moz-transition: all .25s ease;
        -ms-transition: all .25s ease;
        -o-transition: all .25s ease;
        transition: all .25s ease
    }

    #news .list:hover .date {
        background-color: rgba(255, 183, 0, 1)
    }

    #news .list:hover .date h1 {
        color: #FFF
    }

    #news .list .txt p {
        padding-top: 2px;
        width: 100%;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis
    }

    #news .btnGroup {
        height: auto;
        width: 20%;
        padding: 0;
        position: absolute;
        top: 50%;
        right: 0
    }

    #news .switch {
        width: 74px;
        height: 100%
    }

    #news .btn {
        width: 36px;
        height: 100%;
        -webkit-transition: all 200ms ease;
        transition: all 200ms ease
    }

    #news .btn:before {
        margin-top: -7px;
        width: 14px;
        height: 14px
    }

    #news .btn:hover:not(.noClick) {
        background-color: #F6F6F6
    }

    #news .prev:before {
        margin-left: -5px
    }

    #news .next:before {
        margin-left: -9px
    }

    #news .more {
        width: 100%;
        border-radius: 0;
        font-size: 1.6rem;
        color: rgba(255, 255, 255, 1);
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -moz-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        -o-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%)
    }

    #news .more:hover {
        opacity: 0.6;
        text-decoration: none
    }

    #news .more:hover:before {
        width: 24px;
        height: 24px;
        border-width: 4px
    }
}

@media only screen and (min-width: 1025px) {
    #news .list .date {
        max-width: 100%
    }

    #news .list .txt {
        width: 100%
    }
}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {
    #news .list .txt {
        width: 30%
    }
}

@media only screen and (max-width: 1024px) {
    #news {
        padding: 10px
    }

    #news .frame {
        position: relative;
        color: rgba(255, 183, 0, 1)
    }

    #news .frame > .ttl,
    #news .frame > .inner {
        padding-right: 20px;
        padding-left: 20px
    }

    #news .frame > .ttl {
        padding: 0;
        margin-bottom: 15px;
        font-size: 2.2rem;
        color: rgba(255, 255, 255, 1);
    }

    #news .frame > .inner {
        padding: 0 0 0.5em
    }

    #news .frame > .inner > * {
        display: inline-block;
        float: left;
    }

    #news .frame > .inner > #ticker {
        width: 80%
    }

    #news .frame > .inner > .btnGroup {
        width: 20%;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
    }

    #news .list {
        display: none
    }

    #news .list:first-child {
        display: block;
        width: 100%;
        margin: 0 50px 0 0;
        position: relative;
        min-height: 4em;
        background-color: rgba(255, 255, 255, 1)
    }

    #news .list:first-child:hover {
        background-color: rgba(255, 183, 0, 1);
        color: #FFFFFF
    }

    #news .list .txt {
        line-height: 2;
        width: 70px;
        position: absolute;
        top: 0;
        left: 0
    }

    #news .list .date {
        margin-bottom: 10px;
        width: -webkit-calc(100% - 30px);
        width: -moz-calc(100% - 30px);
        width: -ms-calc(100% - 30px);
        width: -o-calc(100% - 30px);
        width: calc(100% - 30px);
        margin: 10px 15px;
        font-size: 0.5em
    }

    #news .switch {
        width: 47px;
        height: 38px
    }

    #news .btn {
        width: 18px;
        height: 100%
    }

    #news .btn:before {
        margin-top: -4px;
        width: 7px;
        height: 7px
    }

    #news .prev:before {
        margin-left: -3px
    }

    #news .next {
        margin-left: 10px
    }

    #news .next:before {
        margin-left: -4px
    }

    #news .more {
        margin-left: 10px;
        padding-bottom: 0;
        width: 100%;
        height: 100%;
        border-radius: 0;
        top: -0.5em;
        left: 0;
        color: rgba(255, 255, 255, 1)
    }

    #mainVisual #news .arrow:after {
        top: 63%;
        left: 50%
    }
}





@media only screen and (min-width: 1025px) {

    .top-page #wrap section .categoryTtl {
        margin-top: 40px;
        line-height: 2.7em;
    }

}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {}

@media only screen and (max-width: 1024px) {}


/*-----service---------------------------------------------------------------------*/


/*
    sunny #ed8914 rgba(237,137,20,1)
    sol   #00a3e2 rgba(0,163,226,1)
    ses   #a3ca0f rgba(29,43,100,1)
    ecweb #1d2b64 rgba(163,202,15,1)
*/

.hexagon-block {
    width: 1162px;
    height: 745px;
    -webkit-pointer-events: none;
    -moz-pointer-events: none;
    -ms-pointer-events: none;
    -o-pointer-events: none;
    pointer-events: none;
    bottom: 0;
    right: 0
}

.sunny-section {}

.sunny-section .hexagon {
    border-left: solid 3px rgba(237, 137, 20, 1);
    border-right: solid 3px rgba(237, 137, 20, 1)
}

.sunny-section .hexagon:before {
    border-top: solid 5px rgba(237, 137, 20, 1);
    border-right: solid 5px rgba(237, 137, 20, 1)
}

.sunny-section .hexagon:after {
    border-bottom: solid 5px rgba(237, 137, 20, 1);
    border-left: solid 5px rgba(237, 137, 20, 1)
}

.sunny-section .link-base .hexagon {
    color: #FFFFFF;
    background-color: rgba(237, 137, 20, 1)
}

.sol-section {}

.sol-section .hexagon {
    border-left: solid 3px rgba(0, 163, 226, 1);
    border-right: solid 3px rgba(0, 163, 226, 1)
}

.sol-section .hexagon:before {
    border-top: solid 5px rgba(0, 163, 226, 1);
    border-right: solid 5px rgba(0, 163, 226, 1)
}

.sol-section .hexagon:after {
    border-bottom: solid 5px rgba(0, 163, 226, 1);
    border-left: solid 5px rgba(0, 163, 226, 1)
}

.sol-section .link-base .hexagon {
    color: #FFFFFF;
    background-color: rgba(0, 163, 226, 1)
}

.ses-section {}

.ses-section .hexagon {
    border-left: solid 3px rgba(29, 43, 100, 1);
    border-right: solid 3px rgba(29, 43, 100, 1)
}

.ses-section .hexagon:before {
    border-top: solid 5px rgba(29, 43, 100, 1);
    border-right: solid 5px rgba(29, 43, 100, 1)
}

.ses-section .hexagon:after {
    border-bottom: solid 5px rgba(29, 43, 100, 1);
    border-left: solid 5px rgba(29, 43, 100, 1)
}

.ses-section .link-base .hexagon {
    color: #FFFFFF;
    background-color: rgba(29, 43, 100, 1)
}

.ecweb-section {}

.ecweb-section .hexagon {
    border-left: solid 3px rgba(163, 202, 15, 1);
    border-right: solid 3px rgba(163, 202, 15, 1)
}

.ecweb-section .hexagon:before {
    border-top: solid 5px rgba(163, 202, 15, 1);
    border-right: solid 5px rgba(163, 202, 15, 1)
}

.ecweb-section .hexagon:after {
    border-bottom: solid 5px rgba(163, 202, 15, 1);
    border-left: solid 5px rgba(163, 202, 15, 1)
}

.ecweb-section .link-base .hexagon {
    color: #FFFFFF;
    background-color: rgba(163, 202, 15, 1)
}

.sl-section {}

.sl-section .hexagon {
    border-left: solid 3px rgba(214, 89, 151, 1);
    border-right: solid 3px rgba(214, 89, 151, 1)
}

.sl-section .hexagon:before {
    border-top: solid 5px rgba(214, 89, 151, 1);
    border-right: solid 5px rgba(214, 89, 151, 1)
}

.sl-section .hexagon:after {
    border-bottom: solid 5px rgba(214, 89, 151, 1);
    border-left: solid 5px rgba(214, 89, 151, 1)
}

.sl-section .link-base .hexagon {
    color: #FFFFFF;
    background-color: rgba(214, 89, 151, 1)
}


.service-content-index {
    width: 100%;
    position: relative;
    top: 40px;
    margin-bottom: 40px;
    /*    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
         -o-transform: translateY(-50%);
            transform: translateY(-50%);*/
    overflow: hidden;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.service-content-index article {
    position: relative;
    width: -webkit-calc(25% - 30px);
    width: -moz-calc(25% - 30px);
    width: -ms-calc(25% - 30px);
    width: -o-calc(25% - 30px);
    width: calc(25% - 30px);
    margin-right: 10px;
    padding: 20px 10px 15px;
    -webkit-transition: all .25s ease;
    -moz-transition: all .25s ease;
    -ms-transition: all .25s ease;
    -o-transition: all .25s ease;
    transition: all .25s ease
}

.service-content-index article:last-child {
    margin: 0;
    padding:0;
    width: 25%;
}

.service-content-index article:last-child > div {
    position: relative;
    width: -webkit-calc(100% - 30px);
    width: -moz-calc(100% - 30px);
    width: -ms-calc(100% - 30px);
    width: -o-calc(100% - 30px);
    width: calc(100% - 30px);
    margin: 0 0 10px;
    padding: 20px 15px 15px;
    -webkit-transition: all .25s ease;
    -moz-transition: all .25s ease;
    -ms-transition: all .25s ease;
    -o-transition: all .25s ease;
    transition: all .25s ease;
    height: -webkit-calc(50% - 35px);
    height: -moz-calc(50% - 35px);
    height: -ms-calc(50% - 35px);
    height: -o-calc(50% - 35px);
    height: calc(50% - 35px)
}

.service-content-index article.sol-section {
    background-color: rgba(0, 163, 226, 1)
}

.service-content-index article.sunny-section {
    background-color: rgba(237, 137, 20, 1)
}

.service-content-index article.ecweb-section {
    background-color: rgba(163, 202, 15, 1)
}

.service-content-index .ses-section {
    background-color: rgba(29, 43, 100, 1)
}

.service-content-index .sl-section {
    background-color: rgba(232, 104, 162, 1)
}

.service-content-index article:hover a {
    color: #333
}

.service-content-index article.sol-section:hover {
    background-color: rgba(0, 163, 226, 0.9)
}

.service-content-index article.sunny-section:hover {
    background-color: rgba(237, 137, 20, 0.9)
}

.service-content-index article.ecweb-section:hover {
    background-color: rgba(163, 202, 15, 0.8)
}

.service-content-index .ses-section:hover {
    background-color: rgba(29, 43, 100, 0.8)
}

.service-content-index .sl-section:hover {
    background-color: rgba(232, 104, 162, 0.8)
}

.service-content-index article.sunny-section,
.service-content-index article.ecweb-section {
    padding-bottom: 76px
}

.service-content-index article h4 {
    font-size: 2.2rem;
    font-weight: normal;
    margin-bottom: 0.6em;
    min-height: 2em;
    color: #FFF
}

.service-content-index article p.service-caption {
    font-size: 1.6rem;
    line-height: 1.7em;
    min-height: 3.4em;
    text-align: justify-all;
    color: #FFF
}

.service-content-index article ul {
    position: relative;
    overflow: hidden;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.service-content-index article ul li {
    /*    width: -webkit-calc(50% - 2.5px);
    width: -moz-calc(50% - 2.5px);
    width: -ms-calc(50% - 2.5px);
    width: -o-calc(50% - 2.5px);
    width: calc(50% - 2.5px);
    float: left;
    position: relative;
    margin: 0 5px 5px 0;
    padding-top: -webkit-calc(36% - 2.5px);
    padding-top: -moz-calc(36% - 2.5px);
    padding-top: -ms-calc(36% - 2.5px);
    padding-top: -o-calc(36% - 2.5px);
    padding-top: calc(36% - 2.5px);
    overflow: hidden;
    border-radius: 5px;*/
}

.service-content-index article ul li:nth-child(even) {
    margin-right: 0
}

/*.service-content-index article ul li .bk-p { margin-right: 0 }*/

.service-content-index article ul li p {
    background: rgba(255, 255, 255, 0.2);
    padding: 100% 5px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: -webkit-calc(100% - 12px);
    width: -moz-calc(100% - 12px);
    width: -ms-calc(100% - 12px);
    width: -o-calc(100% - 12px);
    width: calc(100% - 12px);
    font-size: 1.6rem;
    line-height: 1.5em;
    text-align: center
}


.service-content-index article ul.banner-icon {
    margin-top: 10px;
    position: absolute;
    bottom: 10px;
    left: 10px;
    width: calc(100% - 20px)
}

.service-content-index article ul.banner-icon li {
    width: auto;
    display: inline-block;
    margin-right: 5px
}

.service-content-index article ul.banner-icon li img {
    max-height: 46px
}

.service-content-index article.sunny-section ul.banner-icon li img {
    max-height: 60px;
    width: 100%
}

/*type-1*/

.service-content-index article ul.type-1 li {
    width: 100%;
    float: none;
    padding: 0
}

.service-content-index article ul.type-1 li p {
    position: relative;
    top: 0;
    left: 0;
    transform: none;
    padding: 0;
    background: none;
    text-align: left
}

/*type-3*/

.service-content-index article ul.type-3 {
    margin-top: 5px
}

.service-content-index article ul.type-3 li {
    width: 100%;
    margin: 2px 0;
    padding-top: 0
}

.service-content-index article ul.type-3 li p {
    padding: 5px;
    text-align: left;
    position: relative;
    top: 0;
    left: 0;
    transform: none;
    font-size: 1.4rem;
    color: #FFF
}

#index.parallax_page main#wrap #service article p.arrow.ar-y {
    width: auto;
    display: inline-block;
    position: relative;
    font-size: 1.6rem;
    margin-top: 0.5em;
    color: #FFF
}

#index.parallax_page main#wrap #service article p.arrow.ar-y:after {
    top: 1rem
}

@media only screen and (min-width: 1025px) {
    #index.parallax_page main#wrap #service {
        background-color: rgba(255, 255, 255, .5);
        background-attachment: fixed;
        background-size: cover;
        height: auto !important
    }

    #index.parallax_page main#wrap #service > .inner {
        background-color: rgba(255, 255, 255, .5);
        padding-bottom: 40px
    }

    #wrap #service .categoryTtl {
        top: 0;
        left: 50%;
        -webkit-transform: translateX(-50%);
        -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        -o-transform: translateX(-50%);
        transform: translateX(-50%)
    }
}

@media only screen and (max-width: 1024px) {

    #index.parallax_page main#wrap #service {
        background-image: url("/img/index/service.png");
        background-color: rgba(255, 255, 255, .5);
        background-attachment: scroll;
        background-size: auto 100vh
    }

    #index.parallax_page main#wrap #service > .inner {
        background-color: rgba(255, 255, 255, .5)
    }

    .service-content-index {
        position: relative;
        height: 100%;
        margin-top: 60px;
        transform: inherit;
        top: 0
    }

    #index.parallax_page main#wrap #service .service-content-index article {
        position: relative;
        top: 0;
        left: 0;
        margin-bottom: 20px;
    }

    #index.parallax_page main#wrap #service .service-content-index article:last-child {
        margin-bottom: 0;
        padding: 0;
        width:100%;
    }

    .service-content-index article:last-child > div {
        position: relative;
        width: 94%;
        margin: 0 0 10px;
        padding: 10px;
        -webkit-transition: all .25s ease;
        -moz-transition: all .25s ease;
        -ms-transition: all .25s ease;
        -o-transition: all .25s ease;
        transition: all .25s ease;
        height: -webkit-calc(50% - 10px);
        height: -moz-calc(50% - 10px);
        height: -ms-calc(50% - 10px);
        height: -o-calc(50% - 10px);
        height: calc(50% - 10px)
    }
}


/*-----mission---------------------------------------------------------------------*/

#index.parallax_page #wrap #mission.cateConts {
    overflow: hidden
}

#index.parallax_page #wrap #mission.cateConts > .inner {
    padding-left: 248px;
    padding-right: 0;
    padding-bottom: 120px
}

#mission .categoryTtl .en {
    color: #333
}


.transparence-block {
    position: relative;
    /*top: 100px;*/
    max-height: 360px;
    height: 100%;
    width: calc(100% + 2px);
    left: -1px;
    margin: 0
}

.home.top-page #mission .categoryList {
    padding: 0;
    margin: 40px 0 120px;
    width: 100%;
    max-width: 1120px;
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%)
}

.transparence-block .categoryList:before {
    content: "";
    width: calc(100% - 2px);
    height: calc(100% - 2px);
    border: 20000px solid #FFF;
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

/*.home.top-page #mission .categoryList:before {
    border: 100000em solid #AAAAAA;
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
       -moz-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
         -o-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: 1360px;
    height: 100%;
    z-index: 0
}*/

#wrap .box .frame > .txt > span:before,
#wrap .box .frame > .txt > span:after {
    margin: 0 auto;
    left: 49%
}

#mission .cs .frame,
#mission .value .frame,
#mission .philosophy .frame,
#mission .voice .frame {
    /*background-color: #fff;*/
    color: rgba(50, 50, 50, 1);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    background-color: rgba(255, 255, 255, 0.3);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#00000000, endColorstr=#00000000);
    opacity: 1;
    -webkit-transition: all .25s ease-in;
    -moz-transition: all .25s ease-in;
    -ms-transition: all .25s ease-in;
    -o-transition: all .25s ease-in;
    transition: all .25s ease-in
}

#mission .cs .frame:not(:target),
#mission .value .frame:not(:target),
#mission .philosophy .frame:not(:target),
#mission .voice .frame:not(:target) {
    filter: none;
}

.section-index #mission .philosophy .frame {
    background-color: rgba(255, 255, 255, 1)
}

.section-index #mission .cs .frame {
    background-color: rgba(255, 255, 255, 1)
}

.section-index #mission .value .frame {
    background-color: rgba(255, 255, 255, 1)
}

.section-index #mission .voice .frame {
    background-color: rgba(255, 255, 255, 1)
}

#mission .cs .icon,
#mission .value .icon,
#mission .philosophy .icon,
#mission .voice .icon {
    color: #0C3754
}

.top-page #wrap .box::before {
    background-color: rgba(0, 0, 0, 0) !important;
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#00000000, endColorstr=#00000000);
}

#mission .cs .icon:before,
#mission .value .icon:before,
#mission .philosophy .icon:before,
#mission .voice .icon:before {
    border-color: #0C3754
}

@media only screen and (min-width: 1025px) {
    #mission {}

    /*#mission .bg {
        background-image: url("/img/index/service.png")
    }*/
    #mission .categoryTtl {
        left: 40px
    }

    #wrap #mission.cateConts {
        padding-left: 0
    }

    #wrap #mission.cateConts > .inner {
        /*padding: 0;*/
        background-color: #fff;
        background-position: left top;
        background-repeat: no-repeat;
        background-size: cover;
        background-attachment: fixed;
        padding-left: 288px
    }

    /*#wrap #mission.cateConts>.inner:before {
        background: rgba(255,255,255,0.4);
        content: "";
        display: block;
        width: 100%;
        height: 100vh;
        position: absolute
    }*/
    #wrap #mission.cateConts > .inner .bg {
        background-image: none
    }

    #mission .box {
        float: left;
        position: relative;
        margin: 0;
        width: 25%;
        padding: 0;
        /*height: 33.33333333333%;*/
        -webkit-transition: all .5s linear;
        -moz-transition: all .5s linear;
        -ms-transition: all .5s linear;
        -o-transition: all .5s linear;
        transition: all .5s linear;
        border-left: 20px solid #FFF;
        border-right: 20px solid #FFF;
        border-top: 20px solid #FFF;
        border-bottom: 20px solid #FFF;
    }

    /*#mission .box:hover {
    }*/
    #mission .cs {
        /*        top: 0;
        right: 0*/
    }

    #mission .cs .frame:hover,
    #mission .value .frame:hover,
    #mission .philosophy .frame:hover,
    #mission .voice .frame:hover {
        background-color: rgba(240, 0, 0, .2);
        /*color: rgba(255,255,255,1)*/
    }

    #mission .cs .frame:hover .icon,
    #mission .value .frame:hover .icon,
    #mission .philosophy .frame:hover .icon,
    #mission .voice .frame:hover .icon {
        color: #fff
    }

    #mission .cs .frame:hover .icon:before,
    #mission .value .frame:hover .icon:before,
    #mission .philosophy .frame:hover .icon:before,
    #mission .voice .frame:hover .icon:before {
        border-color: #fff
    }

    #mission .value {
        /*        top: 33.33333333333%;
        right: 20%*/
    }

    #mission .philosophy {
        /*        top: 0;
        right: 40%*/
    }

    #mission .voice {
        /*        top: 66.66666666666%;
        right: 0;*/
        margin-right: 0
    }

    #wrap .box:before {
        padding-top: 100%
    }

}

@media only screen and (min-width: 1025px) {
    #mission .txt .en {
        font-size: 2.4rem
    }

    #mission .txt .ja {
        font-size: 1.6rem
    }
}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {
    #mission .txt .en {
        font-size: 2rem
    }

    #mission .txt .ja {
        font-size: 1.4rem
    }

    #mission .cs .txt .ja {
        font-size: 1.6rem
    }
}

@media only screen and (max-width: 1024px) {
    #container {
        background-color: rgba(255, 255, 255, 0)
    }

    #index.parallax_page main#wrap #service {
        background-position: 28% center;
        background-image: none;
        overflow: hidden
    }

    #mission {
        background-position: center center;
        background-size: cover;
    }

    #mission .categoryTtl {
        left: 20px
    }

    #index.parallax_page #wrap #mission.cateConts > .inner {
        padding-right: 20px;
        padding-left: 20px;
    }

    #index main#wrap {
        /*margin-top: 60px;*/
        margin-top: 0;
        padding-top: 0
    }

    #wrap .box {
        box-sizing: border-box;
        padding: 1px;
        position: relative;
        overflow: hidden;
        float: left;
    }

    .hexagon-block,
    .hexagon-lests {
        position: relative;
        width: 100%;
        height: auto;
        top: 0;
        left: 0;
    }

    #index.parallax_page main#wrap #service .hexagon-block,
    #index.parallax_page main#wrap #service article {
        width: -webkit-calc(100% - 20px);
        width: -moz-calc(100% - 20px);
        width: -ms-calc(100% - 20px);
        width: -o-calc(100% - 20px);
        width: calc(100% - 20px);
        height: auto;
        position: relative;
        top: 0;
        transform: none;
        margin: 0;
        padding: 10px 10px 65px;
        left: unset;
        right: unset;
    }

    #index.parallax_page main#wrap #service .service-content-index article.sunny-section {
        padding-bottom: 115px;
    }

    #index.parallax_page main#wrap #service .hexagon-block,
    #index.parallax_page main#wrap #service article {
        height: auto;
        width: -webkit-calc(100% - 20px);
        width: -moz-calc(100% - 20px);
        width: -ms-calc(100% - 20px);
        width: -o-calc(100% - 20px);
        width: calc(100% - 20px);
        left: 0;
        margin: 0;
        min-width: auto
    }

    #index.parallax_page main#wrap #service .hexagon-block.sunny-section {
        padding-top: 30px
    }

    #index.parallax_page main#wrap #service .hexagon-block {
        padding-top: 0
    }

    #index.parallax_page main#wrap #service article {
        position: absolute;
        top: 0;
        left: 0
    }

    #index.parallax_page main#wrap #service article p {
        max-width: 100%
    }

    #index.parallax_page main#wrap #service .hexagon-block {
        width: 245px;
        position: relative;
        margin: -90px auto 0;
        left: 0;
        transform: none;
        padding: 0
    }

    #index.parallax_page main#wrap #service .hexagon-block.sunny-section {
        margin-top: 0
    }

    #index.parallax_page main#wrap #service .hexagon-block article.hexagon-lests {
        top: 0px;
        left: 0;
        position: relative;
        width: 156px;
        margin: 10px 0 -90px;
        float: none;
        right: 0;
        padding: 20px 0
    }

    #index.parallax_page main#wrap #service .hexagon-block article.hexagon-lests .hexagon {
        width: -webkit-calc(100% - 6px);
        width: -moz-calc(100% - 6px);
        width: -ms-calc(100% - 6px);
        width: -o-calc(100% - 6px);
        width: calc(100% - 6px);
        height: auto;
        padding-top: 57.7%
    }

    #index.parallax_page main#wrap #service .hexagon-block article.hexagon-lests:nth-child(even) {
        left: 88px
    }

    #index.parallax_page main#wrap #service .hexagon-block article.hexagon-lests:last-child {
        margin-bottom: 0
    }

    #index.parallax_page main#wrap #service .hexagon-block.sol-section article.hexagon-lests:nth-child(even),
    #index.parallax_page main#wrap #service .hexagon-block.ecweb-section article.hexagon-lests:nth-child(even) {
        left: 0
    }

    #index.parallax_page main#wrap #service .hexagon-block.sol-section article.hexagon-lests:nth-child(odd),
    #index.parallax_page main#wrap #service .hexagon-block.ecweb-section article.hexagon-lests:nth-child(odd) {
        left: 88px
    }


    .bcl-contents li,
    .bcl-contents li > a {
        color: #333333
    }

    #mission .box {
        width: -webkit-calc(50% - 10px);
        width: -moz-calc(50% - 10px);
        width: -ms-calc(50% - 10px);
        width: -o-calc(50% - 10px);
        width: calc(50% - 10px);
        height: 25%;
        /*border: 15px solid rgba(255, 255, 255, 0.8);*/
        border: none;
        margin: 5px;
    }

    #mission .cs {
        top: 50%;
        right: 0
    }

    #mission .value {
        bottom: 0;
        right: 0
    }

    #mission .philosophy {
        top: 50%;
        left: 0
    }

    #mission .voice {
        bottom: 0;
        left: 0
    }

    #index #mission .box {
        width: 50%;
        height: 25%;
        border: 10px solid rgba(255, 255, 255, 1);
        margin: 0;
    }

    #index #mission .box .frame > .txt .en {
        font-size: 1.6rem
    }

    .section-index.parallax_page #wrap .cateConts .side-contents {
        background-color: rgba(255, 255, 255, 0.9);
        padding: 20px
    }

    .section-index.parallax_page #wrap .cateConts .side-contents h2 {
        font-size: 2.8rem;
        font-weight: lighter;
        margin-bottom: 20px;
        line-height: 1.4em;
        color: rgba(228, 167, 10, 1);
    }

    .section-index.parallax_page #wrap .cateConts .side-contents p {
        margin-bottom: 14px;
        font-size: 1.4rem;
        line-height: 1.7em;
    }

    #index.home.parallax_page #mission .transparence-block {
        max-height: 100%
    }

    .home.parallax_page #mission .categoryList {
        position: relative;
        top: 0;
        left: 0;
        transform: none;
        margin: 0;
    }

    #index.home.parallax_page #mission .categoryList {
        margin: 0 auto
    }
}

#mission .bg {
    width: 100%;
    height: 100%;
    position: relative
}

#mission .categoryTtl {
    color: #333
}

#mission .frame {
    background-color: #660F27;
    color: #FFF
}

#mission .enclosure {
    box-sizing: border-box;
    padding: 2px;
    position: absolute;
    text-align: center
}

#mission .sentence {
    height: 100%;
    background-color: #FFF;
    display: block
}

#mission .writings {
    box-sizing: border-box;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    -ms-transform: translateY(-50%)
}

@media only screen and (min-width: 1025px) {
    #mission .bg {}

    #mission .categoryTtl {
        left: 50%;
        z-index: 1;
        -webkit-transform: translateX(-50%);
        -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        -o-transform: translateX(-50%);
        transform: translateX(-50%)
    }

    #mission .frame:hover {
        background-color: #FFF;
        color: #660F27
    }

    #mission .frame:hover .icon:before {
        border-color: #660F27
    }

    #mission .link,
    #mission .enclosure {
        height: 33.33333333333%
    }

    #mission .link {
        width: 20%;
        top: 33.33333333333%
    }

    #mission .enclosure {
        width: 40%;
        top: 66.66666666666%;
        left: 20%
    }

    #mission .writings {
        padding: 10px
    }
}

@media only screen and (min-width: 1025px) {
    #mission .txt .en {
        font-size: 2.4rem
    }

    #mission .txt .ja {
        font-size: 1.6rem
    }

    #mission .writings {
        font-size: 1.4rem
    }
}

@media only screen and (min-width: 1025px) and (max-height: 900px) {
    #mission .writings {
        font-size: 1.1rem
    }
}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {
    #mission .txt .en {
        font-size: 2rem
    }

    #mission .txt .ja {
        font-size: 1.6rem
    }

    #mission .writings {
        font-size: 1.1rem
    }
}

@media only screen and (max-width: 1024px) {
    #mission .categoryTtl {
        right: 0;
        left: 0;
        text-align: center;
        margin-bottom: 50px;
        z-index: 1
    }

    #mission .enclosure {
        padding-top: 1px;
        bottom: 0;
        left: 0
    }

    #mission .writings {
        padding: 5px;
        font-size: 0.7rem
    }

    #mission .voice {
        border: none
    }

    #mission .categoryList {
        width: 100%;
        height: 100%;
        position: relative;
        max-width: 500px;
        margin-left: auto;
        margin-right: auto
    }
}

@media only screen and (orientation: landscape) and (max-width: 1024px) {

    #mission .link,
    #mission .enclosure {
        height: 50%
    }

    #mission .link {
        width: 33.33333333333%;
        top: 0
    }

    #mission .enclosure {
        width: 66.66666666666%
    }
}

@media only screen and (orientation: portrait) and (max-width: 1024px) {

    #mission .link,
    #mission .enclosure {
        height: 25%
    }

    #mission .link {
        width: 50%;
        top: 50%
    }

    #mission .enclosure {
        width: 100%
    }
}



/*-----performance---------------------------------------------------------------------*/

#performance {
    position: relative;
    overflow: hidden;
    background: rgba(255, 255, 255, 1)
}

#performance .bg {
    width: 100%;
    height: 100%;
    position: relative
}

#performance .categoryTtl {
    color: #333
}

#performance .frame {
    background-color: #660F27;
    color: #FFF
}

#performance .enclosure {
    box-sizing: border-box;
    padding: 2px;
    position: absolute;
    text-align: center
}

#performance .sentence {
    height: 100%;
    background-color: #FFF;
    display: block
}

#performance .writings {
    box-sizing: border-box;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    -ms-transform: translateY(-50%)
}

#performance .link-banner {
    width: calc(100% - 80px);
    height: auto;
    margin: 40px 40px 60px;
    position: relative;
    overflow: auto;
    top: 0;
    left: 0;
    /*    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
         -o-transform: translateY(-50%);
            transform: translateY(-50%)*/
}

#performance .link-banner ul {
    overflow: hidden
}

#performance .link-banner li {
    /*max-width: 230px;*/
    width: calc(16.6666667% - 20px);
    float: left;
    margin: 10px
}

#performance .link-banner li a:hover {
    opacity: 0.4
}

#performance .link-banner li img {
    width: 100%
}

#performance .link-banner .more-link {
    text-align: center;
    font-size: 1.6rem;
    margin-top: 20px
}

#performance .link-banner .more-link a {
    color: #333
}

#performance .link-banner .more-link a:hover {
    color: #999999
}


@media only screen and (min-width: 1025px) {
    .parallax_page #wrap #performance.cateConts {
        height: auto !important;
        background-color: rgba(255, 183, 0, .9)
    }

    .parallax_page #wrap #performance.cateConts > .inner {
        background-color: initial
    }

    #performance .bg {
        background-color: #FFF
    }

    .top-page #wrap section#performance .categoryTtl {
        left: 50%;
        padding-top: 60px;
        -webkit-transform: translateX(-50%);
        -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        -o-transform: translateX(-50%);
        transform: translateX(-50%)
    }

    #performance .frame:hover {
        background-color: #FFF;
        color: #660F27
    }

    #performance .frame:hover .icon:before {
        border-color: #660F27
    }

    #performance .link,
    #performance .enclosure {
        height: 33.33333333333%
    }

    #performance .link {
        width: 20%;
        top: 33.33333333333%
    }

    #performance .enclosure {
        width: 40%;
        top: 66.66666666666%;
        left: 20%
    }

    #performance .writings {
        padding: 10px
    }
}

@media only screen and (min-width: 1025px) {
    #performance .txt .en {
        font-size: 2.4rem
    }

    #performance .txt .ja {
        font-size: 1.6rem
    }

    #performance .writings {
        font-size: 1.4rem
    }

    #footer .office {
        padding-top: 20px
    }
}

@media only screen and (min-width: 1025px) and (max-height: 900px) {
    #performance .writings {
        font-size: 1.1rem
    }
}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {
    #performance .txt .en {
        font-size: 2rem
    }

    #performance .txt .ja {
        font-size: 1.6rem
    }

    #performance .writings {
        font-size: 1.1rem
    }

    #performance .link-banner li {
        /*max-width: 230px;*/
        width: calc(25% - 20px);
        float: left;
        margin: 10px
    }
}

@media only screen and (max-width: 1024px) {

    #performance .categoryTtl {
        margin-bottom: 50px
    }

    #performance .enclosure {
        padding-top: 1px;
        bottom: 0;
        left: 0
    }

    #performance .writings {
        padding: 5px;
        font-size: 0.7rem
    }

    #performance .link-banner {
        position: relative;
        top: 0;
        left: 0;
        transform: none;
        width: 100%;
        margin: 0 auto;
        max-width: 500px;
    }

    #performance .link-banner li {
        width: -webkit-calc(50% - 20px);
        width: -moz-calc(50% - 20px);
        width: -ms-calc(50% - 20px);
        width: -o-calc(50% - 20px);
        width: calc(50% - 20px);
        float: left;
        margin: 10px;
    }
}

@media only screen and (orientation: landscape) and (max-width: 1024px) {

    #performance .link,
    #performance .enclosure {
        height: 50%
    }

    #performance .link {
        width: 33.33333333333%;
        top: 0
    }

    #performance .enclosure {
        width: 66.66666666666%
    }
}

@media only screen and (orientation: portrait) and (max-width: 1024px) {

    #performance .link,
    #performance .enclosure {
        height: 25%
    }

    #performance .link {
        width: 50%;
        top: 50%
    }

    #performance .enclosure {
        width: 100%
    }
}

/*-----other---------------------------------------------------------------------*/

.parallax_page #other {
    height: auto !important;
    background-color: rgba(255, 255, 255, 1)
}

.parallax_page #wrap #other.cateConts:not(#mainVisual) > .inner {
    padding: 0
}

#other .place {
    height: 100%;
    position: relative
}

#other .link {
    box-sizing: border-box;
    width: 100%
        /*margin-bottom: 20px*/
}

#other .cate {
    overflow: hidden
}

#other .cate .column {
    height: 100%;
    position: relative
}

#other .cate .ttl {
    box-sizing: border-box;
    width: 100%;
    background-repeat: repeat-x;
    background-position: center top;
    background-color: rgba(255, 183, 0, .8);
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 10;
    color: #FFF;
    line-height: 1
}

#other .cate .ttl > span {
    display: block
}

#other .cate .ttl .en {
    font-weight: 100
}

#other .cate .ttl .em {
    font-weight: 400
}

#other .cate .more {
    width: 100%;
    height: 100%;
    display: block;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    color: #FFF;
    background: #FFF
}

#other .cate .more:after {
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    z-index: 1
}

#other .cate .icon {
    display: block;
    position: absolute;
    z-index: 10
}

#other .cate .icon:before {
    box-sizing: border-box;
    border-radius: 100%;
    position: absolute;
    top: 0;
    left: 50%;
    content: ""
}

#other .about_text {
    /*overflow: hidden;*/
    position: relative;
    z-index: 0;
    /*    background-image: url(/img/index/seo.svg);*/
    background-size: 100%;
    background-position: center;
    padding: 40px;
    background-color: rgba(0, 0, 0, 0);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#00000000, endColorstr=#00000000)
}

#other .about_text:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    border: 20000px solid #222;
    width: -webkit-calc(100% - 80px);
    width: -moz-calc(100% - 80px);
    width: -ms-calc(100% - 80px);
    width: -o-calc(100% - 80px);
    width: calc(100% - 80px);
    height: -webkit-calc(100% - 80px);
    height: -moz-calc(100% - 80px);
    height: -ms-calc(100% - 80px);
    height: -o-calc(100% - 80px);
    height: calc(100% - 80px);
    display: block
}

#other .text-contents {
    background-color: rgba(240, 240, 240, 0.6);
    padding: 20px
}

#other .about_text h3 {
    font-size: 2.4rem;
    margin-bottom: 30px
}

#other .about_text p {
    font-size: 1.6rem;
    line-height: 1.7em
}


@media only screen and (min-width: 1025px) {
    #other {
        padding-bottom: 40px
    }

    #other .link {
        padding-bottom: 40px;
        display: table
    }

    #other .link > section {
        height: calc(100% - 20px);
        display: table-cell;
        vertical-align: top;
        padding-right: 20px;
    }

    #other .link > section:last-child {
        /*padding-right: 0;*/
    }

    #other .cate {
        cursor: pointer
    }

    #other .cate:hover .icon:before {
        margin-left: -12px;
        width: 24px;
        height: 24px;
        border: 4px solid #fff;
        top: -5px
    }

    #other .cate .ttl {
        padding-top: 25px;
        padding-bottom: 25px
    }

    #other .cate .ttl .en {
        margin-bottom: 0px
    }

    #other .cate .ttl .ja {
        font-size: 1.6rem
    }

    #other .cate .more:after {
        -webkit-transition: all 500ms ease;
        transition: all 500ms ease
    }

    #other .cate .icon {
        padding-top: 20px;
        bottom: 25px;
        right: 20px
    }

    #other .cate .icon:before {
        margin-left: -8px;
        width: 16px;
        height: 16px;
        border: 6px solid #fff;
        -webkit-transition: all 300ms ease;
        transition: all 300ms ease
    }

    .parallax_page #other {
        padding-bottom: 0
    }

    .parallax_page #other .place {
        overflow: hidden;
        border-radius: 0
    }

    .parallax_page #other .link {
        height: 320px;
        z-index: 1;
        padding: 40px 40px 0
    }

    .cssfilters.no_touch_device #other .cate:hover .more:after {
        /*-webkit-filter: blur(3px);
        filter: blur(3px);*/
        opacity: 0.2;
        -webkit-transform: translate(0)
    }
}

@media only screen and (min-width: 1025px) {
    #other .link {
        height: 320px
    }

    #other .cate .ttl {
        padding-right: 30px;
        padding-left: 30px
    }

    #other .cate .ttl .en {
        font-size: 2.4rem
    }

    #other .cate .ttl .ja {
        font-size: 1.6rem
    }
}

@media only screen and (min-width: 1025px) and (max-height: 900px) {
    #other .cate .ttl {
        padding-right: 30px;
        padding-left: 30px
    }

    #other .cate .ttl .en {
        font-size: 2rem
    }

    #other .cate .ttl .ja {
        font-size: 1.4rem
    }
}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {
    #other .link {
        height: 240px
    }

    #other .cate .ttl {
        padding-right: 30px;
        padding-left: 30px
    }

    #other .cate .ttl .en {
        font-size: 2rem
    }

    #other .cate .ttl .ja {
        font-size: 1.4rem
    }
}

@media only screen and (max-width: 1024px) {
    #other .cate {
        height: 40vw
    }

    #other .cate .ttl {
        padding: 15px 10px
    }

    #other .cate .ttl .en {
        margin-bottom: 0;
        font-size: 1.8rem
    }

    #other .cate .ttl .ja {
        font-size: 1rem
    }

    #other .cate .icon {
        padding-top: 10px;
        bottom: 15px;
        right: 20px;
        font-size: 0.8rem
    }

    #other .cate .icon:before {
        margin-left: -4px;
        width: 8px;
        height: 8px;
        border: 3px solid #fff
    }

    #other .link {
        margin-bottom: 20px
    }

    #other .about_text {
        padding: 20px
    }

    #other .about_text:before {
        width: calc(100% - 40px);
        height: calc(100% - 40px);
    }
}

@media only screen and (max-width: 620px) {
    #other .cate {
        height: 60vw
    }
}

@media only screen and (orientation: landscape) and (max-width: 1024px) {
    #other .link {
        display: table
    }

    #other .link > section {
        box-sizing: border-box;
        width: 50%;
        display: table-cell
    }
}

/*-----recruit---------------------------------------------------------------------*/

#recruit {
    position: relative
}

#recruit .categoryTtl {
    z-index: 10;
    color: #FFF
}

#recruit .categoryList {
    box-sizing: border-box;
    width: 100%
}

.saiyo .more:after {
    background-image: url(/img/index/top-footer-service.jpg);
    /* opacity: 0.2; */
    cursor: pointer;
}

#other .cate.saiyo .ttl {
    cursor: pointer;
}

#other .cate.saiyo p.close-text {
    position: absolute;
    z-index: 6;
    top: 50%;
    left: 50%;
    color: #FFFFFF;
    font-size: 2rem;
    transform: translate(-50%, -50%);
    text-align: center;
    width: 100%;
    cursor: pointer;
}

.career .more:after {
    background-image: url("/img/index/career.jpg")
}

#aboutUs .column {
    position: relative
}

#aboutUs .more:after {
    background-image: url("/img/index/about_us.jpg")
}

@media only screen and (min-width: 1025px) {
    #recruit {
        padding-right: 15px;
        width: 67%
    }

    #recruit .categoryTtl {
        cursor: pointer
    }

    #recruit .categoryTtl .en {
        margin-bottom: 10px
    }

    #recruit .categoryList {
        height: 100%;
        display: table
    }

    #recruit .cate {
        width: 50%;
        display: table-cell;
        vertical-align: top
    }

    #recruit .saiyo {
        border-right: 1px solid #fff
    }

    #recruit .saiyo .more.on:after {
        /*-webkit-filter: blur(3px);
        filter: blur(3px)*/
        opacity: 0.2
    }

    #recruit .saiyo .more.on .icon:before {
        margin-left: -12px;
        width: 24px;
        height: 24px;
        border: 4px solid #fff;
        top: -5px
    }

    #recruit .career {
        border-left: 1px solid #fff
    }

    #aboutUs {
        width: 33%
    }
}

@media only screen and (min-width: 1025px) {
    #recruit .categoryTtl {
        top: 35px;
        left: 35px
    }

    #recruit .categoryTtl .en {
        font-size: 4.8rem
    }

    #recruit .categoryTtl .ja {
        font-size: 2.4rem
    }
}

@media only screen and (min-width: 1025px) and (max-height: 900px) {
    #recruit .categoryTtl .en {
        font-size: 3.2rem
    }

    #recruit .categoryTtl .ja {
        font-size: 1.6rem
    }
}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {
    #recruit .categoryTtl {
        top: 30px;
        left: 30px
    }

    #recruit .categoryTtl .en {
        font-size: 3.2rem
    }

    #recruit .categoryTtl .ja {
        font-size: 1.6rem
    }
}

@media only screen and (max-width: 1024px) {
    #recruit .categoryTtl {
        left: 20px
    }

    #recruit .categoryTtl .en {
        margin-bottom: 5px;
        font-size: 2.4rem
    }

    #recruit .categoryTtl .ja {
        font-size: 1.2rem
    }

    #recruit .cate .more:after {
        background-position: center 25%
    }

    #other section.cate.career,
    #aboutUs {
        margin-top: 20px
    }

    #aboutUs.cate .more:after {
        background-position: center 75%
    }
}

@media only screen and (orientation: landscape) and (max-width: 1024px) {
    #recruit {
        padding-right: 10px
    }

    #recruit .categoryList {
        display: table
    }

    #recruit .cate {
        width: 100%;
        display: table-cell;
        vertical-align: top
    }

    #recruit .saiyo {
        border-right: 1px solid #fff
    }

    #recruit .career {
        border-left: 1px solid #fff
    }

    #aboutUs {
        padding-left: 10px
    }
}

@media only screen and (orientation: portrait) and (max-width: 1024px) {
    #recruit .career {
        margin-top: 2px
    }
}


/*-----footer---------------------------------------------------------------------*/

@media only screen and (min-width: 1025px) {
    #footer {
        margin-top: 0;
        overflow: hidden;
        position: relative;
        height: 40%
    }

    #footer .inner .map {
        display: none
    }

    #footer .mapGroup {
        box-sizing: border-box;
        width: 100%;
        background-color: #B2B2B2
    }

    #footer .mapGroup .group {
        box-sizing: border-box;
        width: 67%;
        height: 100%;
        display: table
    }

    #footer .mapGroup .map {
        width: 50%;
        height: 100%;
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover;
        border-right: 1px solid rgba(255, 255, 255, 0.1);
        display: table-cell
    }

    #footer .mapGroup .gmap {
        height: 100%
    }

    #footer .mapGroup .more {
        width: 100%;
        height: 100%;
        display: block;
        position: absolute;
        top: 0;
        left: 0
    }

    #footer .mapGroup .more:after {
        width: 100%;
        height: 100%;
        opacity: 0;
        background-color: rgba(255, 255, 255, 0.25);
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1;
        content: "";
        -webkit-transition: all 500ms ease;
        transition: all 500ms ease
    }

    #footer .mapGroup .more:hover:after {
        opacity: 1
    }

    #footer .mapGroup .more:hover .icon:before {
        margin-left: -12px;
        width: 24px;
        height: 24px;
        border-width: 4px;
        top: -5px
    }

    #footer .mapGroup .square {
        height: 100%;
        position: relative
    }

    #footer .mapGroup .icon {
        padding-top: 20px;
        position: absolute;
        bottom: 60px;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        -ms-transform: translateX(-50%)
    }

    #footer .mapGroup .icon:before {
        box-sizing: border-box;
        margin-left: -8px;
        width: 16px;
        height: 16px;
        border: 6px solid #fff;
        border-radius: 100%;
        position: absolute;
        top: 0;
        left: 50%;
        content: "";
        -webkit-transition: all 300ms ease;
        transition: all 300ms ease
    }

    .parallax_page #footer {
        height: 40%;
        position: relative;
        bottom: 0;
        /*margin-top: 40px;*/
        padding-left: 248px
    }

    .parallax_page #footer .inner {
        height: 50%;
        padding-bottom: 80px
    }

    .parallax_page #footer .mapGroup {
        height: 45%
    }

    #footer .navi {
        text-align: center;
        position: relative;
        left: 0;
        top: 0
    }

    #index #footer .other {
        position: absolute;
        width: 100%;
        bottom: 60px;
        float: none;
        padding: 0;
        overflow: hidden
    }
}

@media only screen and (min-width: 801px) and (max-height: 750px) {
    .parallax_page #footer {
        height: 66%
    }

    .parallax_page #footer .inner {
        height: 100%
    }

    .parallax_page #footer .mapGroup {
        display: none
    }
}

@media only screen and (min-width: 1025px) {
    #footer {
        height: 40%
    }

    #footer .inner {
        height: 260px
    }

    #footer .mapGroup {
        height: 200px
    }

    #footer .mapGroup .group {
        padding-right: 30px
    }
}

@media only screen and (min-width: 1025px) and (max-height: 900px) {
    .parallax_page #footer {
        height: auto
    }

    .parallax_page #footer .inner {
        height: 100%
    }

    .parallax_page #footer .mapGroup {
        display: none
    }
}

@media only screen and (max-width: 1024px) and (min-width: 1025px) {
    #footer {
        height: auto
    }

    #footer .mapGroup {
        height: 240px
    }

    #footer .mapGroup .group {
        padding-right: 20px
    }
}

@media only screen and (max-width: 1024px) {
    #footer .office {
        background: #FFFFFF;
        padding-right: 20px
    }

    #footer .navi {
        background: #FFFFFF
    }

    #footer .address {
        border-bottom: none
    }

    #footer .address + .address {
        margin-top: 0
    }

    #footer .navi {
        /*padding-top: 5px*/
    }

    #footer .inner .map {
        margin-top: 20px;
        margin-right: -20px;
        margin-left: -20px;
        height: 160px;
        position: relative
    }

    #footer .inner .gmap {
        width: 100%;
        height: 160px
    }

    #footer .inner .more {
        width: 100%;
        height: 100%;
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        font-size: 0.8rem
    }

    #footer .inner .icon {
        padding-top: 10px;
        position: absolute;
        bottom: 20px;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        -ms-transform: translateX(-50%)
    }

    #footer .inner .icon:before {
        box-sizing: border-box;
        margin-left: -4px;
        width: 8px;
        height: 8px;
        border: 3px solid #fff;
        border-radius: 100%;
        position: absolute;
        top: 0;
        left: 50%;
        content: ""
    }

    #footer .mapGroup {
        display: none
    }

    #footer.small-footer #copyright {
        position: relative;
        line-height: 4
    }

    section.partner_logo {
        position: relative;
        overflow: hidden;
        width: 100%;
        float: none;
        margin-right: 0;
        margin-bottom: 20px
    }

    section.partner_logo > ul {
        display: block;
        padding: 5px;
        width: auto;
        max-width: 100%;
        background: ;
        overflow: auto;
        margin-left: 0;
        margin-top: 30px
    }

    section.facebook_widget {
        position: relative;
        overflow: hidden;
        width: 100%;
        float: none;
        left: 0
    }


    #footer .location > * {
        width: 100%;
        float: none;
        margin-right: 0;
    }

    #footer .location > section.footer_map,
    #footer .location > section.facebook_widget {
        margin: 20px auto;
        width: 50%;
        float: left
    }

    #footer .location > section.partner_logo {
        position: relative;
        overflow: hidden
    }

    #footer .location > section.partner_logo > ul:first-child {
        float: none;
        width: -webkit-calc(50% - 20px);
        width: -moz-calc(50% - 20px);
        width: -ms-calc(50% - 20px);
        width: -o-calc(50% - 20px);
        width: calc(50% - 20px)
    }

    section.partner_logo > ul.company-detail {
        float: none;
        width: -webkit-calc(100% - 10px);
        width: -moz-calc(100% - 10px);
        width: -ms-calc(100% - 10px);
        width: -o-calc(100% - 10px);
        width: calc(100% - 10px);
        margin: 20px 10px 0 0
    }
}

@media only screen and (max-width: 600px) {

    #footer .location > section.footer_map,
    #footer .location > section.facebook_widget {
        margin: 20px auto;
        width: 100%;
        float: none;
        overflow: hidden
    }
}

/*custom*/

.home.parallax_page #wrap #performance.cateConts {
    display: none;
    height: 0 !important;
}


p.important_info a {
    pointer-events: none;
    background: rgba(240, 0, 0, .9);
    padding: 15px 30px;
    color: #FFFFFF;
    font-size: 1.8rem;
    position: absolute;
    top: 20px;
    right: 20px;
    width: calc(100% - 100px);
    line-height: 1.7em;
    text-align: center;
    z-index: 1999;
}

p.important_info span {
    font-size: 2.4rem;
    display: block;
}

/* p.important_info a:hover { background: rgb(210, 0, 0); } */
p.important_info a:hover {
    background: rgba(255, 183, 0, .9);
    color: #FFFFFF;
}


.mv-banner {
    position: absolute;
    top: 20px;
    right: 20px;
    text-align: right;
    z-index: 1999;
    width: 30%;
}

.mv-banner img {
    width: 70%;
    margin-top: 10px;
}

.mv-banner li a:hover {
    opacity: 0.7;
}



@media screen and (max-width: 1024px) {
    .mv-banner {
        top: 600px;
        display: flex;
        width: calc(100% - 20px);
    }

    .mv-banner li {
        text-align: center;
        width: 100%;
    }
}



@media only screen and (max-width: 1280px) {
    p.important_info a {
        top: 20px;
    }
}

@media only screen and (max-width: 1024px) {
    p.important_info a {
        top: 60px;
        padding: 10px 10px;
        width: calc(100% - 20px);
        right: 0;
        line-height: 1.4;
    }

    .mv-banner {
        top: 600px;
        display: flex;
        width: calc(100% - 20px);
    }

    .mv-banner li {
        text-align: center;
        width: 100%;
    }
}


@media only screen and (max-width: 767px) {
    p.important_info a {
        font-size: 1.5rem;
        padding: 20px;
        width: calc(100% - 40px);
    }
}

@media only screen and (max-width: 320px) {
    p.important_info a {
        font-size: 1.5rem;
        padding: 10px 10px;
        width: calc(100% - 20px);
    }
}
