@font-face {
    font-family: 'webfont';
    font-display: swap;
    src: url('//at.alicdn.com/t/webfont_w6mqev3eqnj.eot'); /* IE9*/
    src: url('//at.alicdn.com/t/webfont_w6mqev3eqnj.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('//at.alicdn.com/t/webfont_w6mqev3eqnj.woff2') format('woff2'),
    url('//at.alicdn.com/t/webfont_w6mqev3eqnj.woff') format('woff'), /* chrome、firefox */ url('//at.alicdn.com/t/webfont_w6mqev3eqnj.ttf') format('truetype'), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/ url('//at.alicdn.com/t/webfont_w6mqev3eqnj.svg#after') format('svg'); /* iOS 4.1- */
}

@font-face {
    font-family: 'trmup';
    src: url('fonts/TrumpGothicEast_bold.otf');
    src: local('☺'), url('fonts/TrumpGothicEast_bold.woff') format('woff'), url('fonts/TrumpGothicEast_bold.ttf') format('truetype'), url('fonts/TrumpGothicEast_bold.svg') format('svg');
    font-weight: normal;
    font-style: normal;
}
section.common{
    width: 100%;
    padding: 5% 5% 5% 12rem;
}

body {
    margin: 0;
    padding: 0;
    border: none;

}
#header{
    border-right: 1px solid #ddd;
}
.flex-center li .item__txt {
    padding-left: 60px;
}

.flex-center li .item__txt p{
    line-height: 60px;
}
.flex-center li .item__txt span{
    font-size: 30px;
}
.flex-center li .item__txt .more-link{
    margin-top: 20px;
}
* {
    box-sizing: border-box;
}

img, div, p, blockquote, h1, h2, h3, h4, h5, h6, ul, ol, li, dl, dt, dd, form, fieldset, textarea, address, article, aside, dialog, figure, footer, header, hgroup, nav, section {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    text-decoration: none;
    list-style-type: none
}

article, aside, dialog, figure, footer, header, hgroup, nav, section {
    display: block
}

h1, h2, h3, h4, h5, h6 {
    font-weight: inherit
}

table {
    border: none;
    border-collapse: collapse;
    border-spacing: 0
}

th {
    text-align: left;
    vertical-align: top
}

caption {
    text-align: left
}

a, a:focus, a:hover, a:active {
    outline: none
}

input, input:focus, input:hover, input:active, textarea, textarea:focus, textarea:hover, textarea:active {
    outline: none
}

img {
    vertical-align: top
}

.clearfix {
    zoom: 1
}

.clearfix:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

html {
    overflow-y: scroll;
    font-size: 10px
}

@media only screen and (min-width: 1500px) {
    html {
        font-size: 13px
    }
}

@media only screen and (max-width: 768px) {
    html {
        overflow: visible;
        font-size: 20px
    }
}

@media only screen and (max-width: 639px) {
    html {
        font-size: 10px
    }
}

body {
    color: #000000;
    font-family: "Microsoft YaHei", sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.75;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

@media only screen and (max-width: 768px) {
    body {
        font-size: 14px;
        line-height: 1.86;
    }
}

::-moz-selection {
    background: #00a2e9;
    color: #ffffff
}

::selection {
    background: #00a2e9;
    color: #ffffff
}

a {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition-property: border-color, background-color, color, opacity, -webkit-transform;
    transition-property: border-color, background-color, color, opacity, -webkit-transform;
    transition-property: transform, border-color, background-color, color, opacity;
    transition-property: transform, border-color, background-color, color, opacity, -webkit-transform;
    position: relative;
    color: #00a2e9;
    text-decoration: none
}

html.notouch a:hover {
    text-decoration: underline
}

@media only screen and (max-width: 768px) {
    .sp-hidden {
        display: none
    }
}

#wrapper {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden;
    padding-left: 7rem
}

#wrapper img {
    max-width: 100%;
    height: auto
}

@media only screen and (max-width: 768px) {
    #wrapper {
        overflow: visible;
        padding-left: 0
    }
}

@-webkit-keyframes loading-logo {
    0% {
        opacity: 0
    }
    50% {
        opacity: 1
    }
    100% {
        opacity: 0
    }
}

@keyframes loading-logo {
    0% {
        opacity: 0
    }
    50% {
        opacity: 1
    }
    100% {
        opacity: 0
    }
}

.loading {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 20;
    width: 100%;
    height: 100%;
    background: #ffffff
}

.loading__progress {
    -webkit-transition: width .8s linear 0s;
    transition: width .8s linear 0s;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    width: 0;
    height: 0.3rem;
    background: #ffffff
}

.loading__inner {
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 1;
    width: 100%;
    margin-top: -2.7rem
}

.loading__descente {
    width: 2.4rem;
    margin: 0 auto 1.5rem
}

.loading__descente .logo {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    position: relative;
    width: 0;
    height: 2.7rem
}

.loading__descente .logo:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 2.4rem;
    height: 2.7rem;
    background: url(../images/logo_descente_white.svg) no-repeat center bottom;
    background-size: 100% auto
}

.loading__logo {
    width: 17.2rem;
    margin: 0 auto
}

.loading__logo .logo {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    position: relative;
    width: 17.2rem;
    height: 1.3rem;
    opacity: 0
}

.loading__logo .logo:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 17.2rem;
    height: 1.3rem;
    background: url(../images/logo_white.svg) no-repeat center center;
    background-size: contain
}

.loading__bg {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    background: #fff url(../images/loading.jpg) no-repeat center center;
    background-size: cover;
    opacity: 0
}

.loading.is-show .loading__descente .logo {
    -webkit-transition: width .2s cubic-bezier(0.075, 0.82, 0.165, 1) .4s;
    transition: width .2s cubic-bezier(0.075, 0.82, 0.165, 1) .4s;
    width: 2.4rem
}

.loading.is-show .loading__logo .logo {
    -webkit-transition: opacity 0s linear .8s;
    transition: opacity 0s linear .8s;
    -webkit-animation: loading-logo 0.1s linear .8s 6 normal;
    animation: loading-logo 0.1s linear .8s 6 normal;
    opacity: 1
}

.loading.is-show .loading__bg {
    -webkit-transition: opacity .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: opacity .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    opacity: 1
}

.loading.is-pause .loading__progress {
    -webkit-transition-duration: .4s;
    transition-duration: .4s;
    -webkit-transition-delay: 0s;
    transition-delay: 0s
}

.loading.is-pause .loading__logo .logo {
    -webkit-animation: none;
    animation: none;
    opacity: 1 !important
}

.content {
    -webkit-transition: opacity .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: opacity .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    position: relative;
    min-height: 100vh
}

html.is-contentHidden .content {
    opacity: 0
}

/*html.notouch .content__wrapper {*/
/*    overflow: hidden;*/
/*    position: fixed;*/
/*    top: 0;*/
/*    right: 0;*/
/*    left: 7rem;*/
/*    z-index: 1*/
/*}*/
html.notouch .content__wrapper {
    overflow: hidden;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 7rem;
    z-index: 1;
}
.content__body {
    position: relative
}

html.notouch .content__body {
    top: 0;
}

@media only screen and (max-width: 768px) {
    .content__wrapper {
        overflow: visible;
        position: static !important
    }

    .content__body {
        position: static
    }
}

@-webkit-keyframes scroll-circle {
    0% {
        -webkit-transform: scale(0.7);
        transform: scale(0.7);
        opacity: 0
    }
    33.33% {
        -webkit-transform: scale(1);
        transform: scale(1);
        opacity: 1
    }
    100% {
        -webkit-transform: scale(1.3);
        transform: scale(1.3);
        opacity: 0
    }
}

@keyframes scroll-circle {
    0% {
        -webkit-transform: scale(0.7);
        transform: scale(0.7);
        opacity: 0
    }
    33.33% {
        -webkit-transform: scale(1);
        transform: scale(1);
        opacity: 1
    }
    100% {
        -webkit-transform: scale(1.3);
        transform: scale(1.3);
        opacity: 0
    }
}

@-webkit-keyframes scroll-line_t {
    0% {
        -webkit-transform: translateY(-100%);
        transform: translateY(-100%)
    }
    15% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
    35% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
    50% {
        -webkit-transform: translateY(100%);
        transform: translateY(100%)
    }
    100% {
        -webkit-transform: translateY(100%);
        transform: translateY(100%)
    }
}

@keyframes scroll-line_t {
    0% {
        -webkit-transform: translateY(-100%);
        transform: translateY(-100%)
    }
    15% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
    35% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
    50% {
        -webkit-transform: translateY(100%);
        transform: translateY(100%)
    }
    100% {
        -webkit-transform: translateY(100%);
        transform: translateY(100%)
    }
}

@-webkit-keyframes scroll-line_b {
    0% {
        -webkit-transform: translateY(-100%);
        transform: translateY(-100%)
    }
    20% {
        -webkit-transform: translateY(-100%);
        transform: translateY(-100%)
    }
    35% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
    55% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
    70% {
        -webkit-transform: translateY(100%);
        transform: translateY(100%)
    }
    100% {
        -webkit-transform: translateY(100%);
        transform: translateY(100%)
    }
}

@keyframes scroll-line_b {
    0% {
        -webkit-transform: translateY(-100%);
        transform: translateY(-100%)
    }
    20% {
        -webkit-transform: translateY(-100%);
        transform: translateY(-100%)
    }
    35% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
    55% {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }
    70% {
        -webkit-transform: translateY(100%);
        transform: translateY(100%)
    }
    100% {
        -webkit-transform: translateY(100%);
        transform: translateY(100%)
    }
}

.scroll {
    position: fixed;
    right: 2.7rem;
    bottom: 0;
    z-index: 5;
    width: 7.8rem;
    height: 20rem
}

.scroll__icon {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    padding: 7.9rem 1.8rem
}

.scroll__icon:before {
    -webkit-animation: scroll-circle 1.2s linear 0s infinite normal;
    animation: scroll-circle 1.2s linear 0s infinite normal;
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 0;
    width: 6rem;
    height: 6rem;
    margin: -3rem 0 0 -3rem;
    border-radius: 3rem;
    background: rgba(0, 0, 0, 0.1)
}

.scroll__icon .icon {
    display: block
}

.scroll__icon .icon .txt {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    position: relative;
    z-index: 1;
    width: 4.2rem;
    height: 4.2rem;
    border-radius: 2.1rem;
    background: #f5f5f5
}

.scroll__icon .icon .txt:before {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    content: '';
    display: block;
    position: absolute;
    top: 1.8rem;
    left: 50%;
    margin-left: -0.5rem;
    border-top: #000000 solid 0.7rem;
    border-right: transparent solid 0.5rem;
    border-left: transparent solid 0.5rem
}

html.notouch .scroll__icon .icon:hover .txt {
    background: #00a2e9
}

html.notouch .scroll__icon .icon:hover .txt:before {
    border-top-color: #ffffff
}

.scroll__icon .line-t, .scroll__icon .line-b {
    overflow: hidden;
    display: block;
    position: absolute;
    left: 50%;
    width: 1px;
    height: 5.9rem;
    background: rgba(0, 0, 0, 0.1)
}

.scroll__icon .line-t:after, .scroll__icon .line-b:after {
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #ffffff
}

.scroll__icon .line-t {
    top: 0
}

.scroll__icon .line-t:after {
    -webkit-animation: scroll-line_t 1.2s cubic-bezier(0.075, 0.82, 0.165, 1) 0s infinite normal;
    animation: scroll-line_t 1.2s cubic-bezier(0.075, 0.82, 0.165, 1) 0s infinite normal
}

.scroll__icon .line-b {
    bottom: 0
}

.scroll__icon .line-b:after {
    -webkit-animation: scroll-line_b 1.2s cubic-bezier(0.075, 0.82, 0.165, 1) 0s infinite normal;
    animation: scroll-line_b 1.2s cubic-bezier(0.075, 0.82, 0.165, 1) 0s infinite normal
}

.scroll__icon .pagetop {
    display: none;
    position: relative;
    z-index: 1;
    color: #000000;
    font-size: 1.2rem;
    line-height: 1;
    text-decoration: none
}

.scroll__icon .pagetop .txt {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    width: 4.2rem;
    height: 4.2rem;
    border: #d0d0d0 solid 1px;
    border-radius: 2.1rem;
    background: #ffffff
}

.scroll__icon .pagetop .txt:before {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    content: '';
    display: block;
    position: absolute;
    top: 1.6rem;
    left: 50%;
    margin-left: -0.5rem;
    border-right: transparent solid 0.5rem;
    border-bottom: #d0d0d0 solid 0.7rem;
    border-left: transparent solid 0.5rem
}

html.notouch .scroll__icon .pagetop:hover {
    text-decoration: none
}

html.notouch .scroll__icon .pagetop:hover .txt {
    background: #00a2e9;
    border-color: #00a2e9
}

html.notouch .scroll__icon .pagetop:hover .txt:before {
    border-bottom-color: #ffffff
}

.scroll__icon.is-white {
    z-index: 1
}

.scroll__icon.is-white:before {
    background: rgba(255, 255, 255, 0.1)
}

.scroll__icon.is-white .icon .txt {
    background: #ffffff
}

.scroll__icon.is-white .line-t, .scroll__icon.is-white .line-b {
    background: rgba(255, 255, 255, 0.1)
}

html.is-pagetop .scroll .scroll__icon:not(.is-white) {
    clip: auto !important
}

html.is-pagetop .scroll .scroll__icon:before {
    visibility: hidden
}

html.is-pagetop .scroll .scroll__icon .icon {
    display: none
}

html.is-pagetop .scroll .scroll__icon .pagetop {
    display: block
}

html.is-footer-show .scroll {
    position: absolute
}

@media only screen and (max-width: 768px) {
    .scroll {
        display: none
    }
}

@-webkit-keyframes cursor-visible {
    0% {
        visibility: hidden;
        width: 30px;
        height: 30px;
        opacity: 0
    }
    50% {
        visibility: visible;
        opacity: 1
    }
    100% {
        visibility: visible;
        width: 40px;
        height: 40px;
        opacity: 1
    }
}

@keyframes cursor-visible {
    0% {
        visibility: hidden;
        width: 30px;
        height: 30px;
        opacity: 0
    }
    50% {
        visibility: visible;
        opacity: 1
    }
    100% {
        visibility: visible;
        width: 40px;
        height: 40px;
        opacity: 1
    }
}

@-webkit-keyframes cursor-hidden {
    0% {
        visibility: visible;
        width: 40px;
        height: 40px;
        opacity: 1
    }
    50% {
        visibility: hidden;
        width: 30px;
        height: 30px;
        opacity: 0
    }
    100% {
        visibility: hidden;
        width: 30px;
        height: 30px;
        opacity: 0
    }
}

@keyframes cursor-hidden {
    0% {
        visibility: visible;
        width: 40px;
        height: 40px;
        opacity: 1
    }
    50% {
        visibility: hidden;
        width: 30px;
        height: 30px;
        opacity: 0
    }
    100% {
        visibility: hidden;
        width: 30px;
        height: 30px;
        opacity: 0
    }
}

.cursor {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-animation: cursor-hidden .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    animation: cursor-hidden .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition-property: top, left;
    transition-property: top, left;
    display: block;
    visibility: hidden;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 1;
    width: 30px;
    height: 30px;
    margin: -25px 0 0 -25px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.15);
    opacity: 0
}

.is-mousedown .cursor {
    background: #00a2e9
}

.cursor.is-visible {
    -webkit-animation: cursor-visible .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    animation: cursor-visible .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    visibility: visible;
    width: 40px;
    height: 40px;
    opacity: 1
}

.cursor-cross {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    display: none;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 20;
    width: 50px;
    height: 50px;
    margin: -40px 0 0 -40px;
    cursor: pointer
}

.cursor-cross:before {
    content: '';
    display: block;
    position: absolute;
    top: 25px;
    left: 0;
    width: 100%;
    height: 1px;
    background: #ffffff
}

.cursor-cross:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 24px;
    width: 1px;
    height: 100%;
    background: #ffffff
}

.cursor-cross.is-visible {
    display: block
}

.cursor-cross.is-close {
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg)
}

@media only screen and (max-width: 768px) {
    .cursor, .cursor-cross {
        display: none !important
    }
}

.m-links {
    font-family: 'webfont', sans-serif;
    font-size: 1.2rem;
    line-height: 1.2
}

.m-links dl dd {
    margin-top: 1rem
}

.m-links dl dd ul {
    zoom: 1
}

.m-links dl dd ul:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

.m-links dl dd ul li {
    float: left
}

.m-links dl dd ul li + li {
    margin-left: 1em
}

.m-links dl dd ul li a .txt {
    position: relative;
    z-index: 2
}

@media only screen and (max-width: 768px) {
    .m-links {
        font-size: 1.2rem
    }

    .m-links dl dt {
        font-size: 0.8rem
    }

    .m-links dl dd {
        margin-top: 0.5rem
    }
}

.m-logo {
    zoom: 1;
    line-height: 1
}

.m-logo:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

.m-logo li {
    float: left
}

.m-logo li + li {
    margin-left: 2rem
}

.m-logo li a {
    display: block
}

.m-logo li .logo {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    height: 2rem;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 100% auto
}

.m-logo li.descente .logo {
    width: 9.6rem;
    background-image: url(../images/descente.svg)
}

.m-logo li.allterrain .logo {
    width: 16.3rem;
    background-image: url(../images/allterrain.svg)
}

@media only screen and (max-width: 768px) {
    .m-logo li + li {
        margin-left: 1.5rem
    }

    .m-logo li .logo {
        height: 1.4rem
    }

    .m-logo li.descente .logo {
        width: 6.8rem
    }

    .m-logo li.allterrain .logo {
        width: 9.5rem
    }
}

.movie-modal {
    -webkit-transition: opacity .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: opacity .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 20;
    background: rgba(0, 0, 0, 0.6);
    opacity: 0
}

.movie-modal.is-visible {
    opacity: 1
}

.movie-modal__container {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    top: 50%;
    left: 50%;
    width: 80rem
}

.movie-modal__close {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    position: absolute;
    top: -8rem;
    right: -2rem;
    width: 8rem;
    height: 8rem
}

.movie-modal__close:before, .movie-modal__close:after {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 5.6rem;
    height: 1px;
    margin-left: -2.8rem;
    background: #ffffff
}

.movie-modal__close:before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg)
}

.movie-modal__close:after {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg)
}

.movie-modal__videoWrap {
    position: relative;
    padding-bottom: 56.25%;
    background: #ffffff
}

.movie-modal__video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

@media only screen and (max-width: 768px) {
    .movie-modal__container {
        width: 100%
    }
}

@-webkit-keyframes bg-change {
    0% {
        -webkit-filter: brightness(200%);
        filter: brightness(200%)
    }
    100% {
        -webkit-filter: brightness(100%);
        filter: brightness(100%)
    }
}

@keyframes bg-change {
    0% {
        -webkit-filter: brightness(200%);
        filter: brightness(200%)
    }
    100% {
        -webkit-filter: brightness(100%);
        filter: brightness(100%)
    }
}

@-webkit-keyframes share-overflow {
    0% {
        overflow: hidden
    }
    99.9% {
        overflow: hidden
    }
    100% {
        overflow: visible
    }
}

@keyframes share-overflow {
    0% {
        overflow: hidden
    }
    99.9% {
        overflow: hidden
    }
    100% {
        overflow: visible
    }
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    width: 7rem;
    height: 100%;
    background: #ffffff
}

.header__logo {
    position: relative;
    width: 7rem;
    z-index: 2;
    text-align: center;
    padding-top: 2rem;
}

.header__logo a {
    display: block
}

.header__logo img {
    width: 60px;
    z-index: 2;

}

.header__logo .logo:before, .header__logo .logo:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    width: 7rem;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain
}

.header__logo .logo:before {
    top: 2rem;
    height: 4rem;
    background-image: url(/upfile/logo.svg)
}

.header__logo .logo:after {
    top: 7rem;
    height: 6rem;
    background-image: url(../images/logo_v.svg)
}

body.page-top .header__logo .logo {
    height: 5.5rem
}

body.page-top .header__logo .logo:after {
    opacity: 0
}

html.is-scrolled body.page-top .header__logo .logo {
    height: 18.6rem
}

html.is-scrolled body.page-top .header__logo .logo:after {
    -webkit-transition: opacity 0.1s linear 0.2s;
    transition: opacity 0.1s linear 0.2s;
    -webkit-animation: loading-logo 0.1s linear 0s 3 normal;
    animation: loading-logo 0.1s linear 0s 3 normal;
    opacity: 1
}

.header__menu {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 7rem;
    height: 100%;
    z-index: 1
}

.header__menu .txt {
    display: none
}

.header__menu .open {
    display: block;
    position: absolute;
    top: 50%;
    left: 20px;
    z-index: 2;
    width: 35px;
    height: 35px;
    margin-top: -18px
}

.header__menu .open .line-1, .header__menu .open .line-2, .header__menu .open .line-3 {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    display: block;
    position: absolute;
    top: 0;
    width: 1px;
    height: 35px;
    background: #000000
}

.header__menu .open .line-1 {
    -webkit-transform: translateX(11px);
    transform: translateX(11px)
}

.header__menu .open .line-2 {
    -webkit-transform: translateX(17px);
    transform: translateX(17px)
}

.header__menu .open .line-3 {
    -webkit-transform: translateX(23px);
    transform: translateX(23px)
}

.header__menu .close {
    display: none;
    position: absolute;
    top: 50%;
    left: 20px;
    z-index: 2;
    width: 35px;
    height: 35px;
    margin-top: -18px
}

.header__menu .close .line-1, .header__menu .close .line-2 {
    display: block;
    position: absolute;
    top: 0;
    width: 1px;
    height: 48px;
    background: #000000
}

.header__menu .close .line-1 {
    -webkit-transform: translate(17px, -7px) rotate(45deg);
    transform: translate(17px, -7px) rotate(45deg)
}

.header__menu .close .line-2 {
    -webkit-transform: translate(17px, -7px) rotate(-45deg);
    transform: translate(17px, -7px) rotate(-45deg)
}

@media only screen and (min-width: 1500px) {
    .header__menu .open {
        left: 25px;
        width: 44px;
        height: 44px;
        margin-top: -22px
    }

    .header__menu .open .line-1, .header__menu .open .line-2, .header__menu .open .line-3 {
        height: 44px
    }

    .header__menu .open .line-1 {
        -webkit-transform: translateX(14px);
        transform: translateX(14px)
    }

    .header__menu .open .line-2 {
        -webkit-transform: translateX(21px);
        transform: translateX(21px)
    }

    .header__menu .open .line-3 {
        -webkit-transform: translateX(28px);
        transform: translateX(28px)
    }

    .header__menu .close {
        left: 25px;
        width: 44px;
        height: 44px;
        margin-top: -22px
    }

    .header__menu .close .line-1, .header__menu .close .line-2 {
        height: 60px
    }

    .header__menu .close .line-1 {
        -webkit-transform: translate(21px, -8px) rotate(45deg);
        transform: translate(21px, -8px) rotate(45deg)
    }

    .header__menu .close .line-2 {
        -webkit-transform: translate(21px, -8px) rotate(-45deg);
        transform: translate(21px, -8px) rotate(-45deg)
    }
}

.header__share {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    width: 7rem;

}

.header__share .share-icon {
    display: block;
    overflow: hidden;
    text-align: center;
    width: 7rem;
    height: 7rem;
    font-size: 3rem;
    cursor: pointer;
    color: #999;
    font-weight: 100;
    text-decoration:none!important;
}

.header__share .share {
    -webkit-transition: height .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: height .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 7rem;
    height: 0;
    padding-bottom: 1rem;
    background: #ffffff
}

.header__share .share__list {
    position: absolute;
    left: 0;
    bottom: 1rem;
    height: 16.5rem
}

.header__share .share__list li a {
    display: block;
    width: 7rem;
    height: 5.5rem
}

.header__share .share__list li a .icon {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%
}

.header__share .share__list li a .icon:before, .header__share .share__list li a .icon:after {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 1.4rem;
    margin-top: -0.7rem;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: auto 1.4rem
}

.header__share .share__list li a .icon:after {
    opacity: 0
}

html.notouch .header__share .share__list li a:hover .icon:before {
    opacity: 0
}

html.notouch .header__share .share__list li a:hover .icon:after {
    opacity: 1
}

.header__share .share__list li.facebook a .icon:before {
    background-image: url(../images/facebook.svg)
}

.header__share .share__list li.facebook a .icon:after {
    background-image: url(../images/facebook_ov.svg)
}

.header__share .share__list li.instagram a .icon:before {
    background-image: url(../images/instagram.svg)
}

.header__share .share__list li.instagram a .icon:after {
    background-image: url(../images/instagram_ov.svg)
}

.header__share .share__list li.youtube a .icon:before {
    background-image: url(../images/youtube.svg)
}

.header__share .share__list li.youtube a .icon:after {
    background-image: url(../images/youtube_ov.svg)
}

.header__share.is-show .share {
    -webkit-animation: share-overflow .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    animation: share-overflow .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    overflow: visible;
    height: 17.5rem
}

.header__nav {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    background: #ffffff
}

.header__nav .h-nav__outer {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: table;
    position: relative;
    z-index: 1;
    width: 100vw;
    height: 100%;
    padding: 2rem 0 0 13.5rem
}

.header__nav .h-nav__outer:after {
    content: '';
    display: block;
    position: absolute;
    top: 6rem;
    right: 6.5rem;
    width: 18rem;
    height: 1.4rem;
    background: url(../images/logo.svg) no-repeat center center;
    background-size: contain
}

.header__nav .h-nav__inner {
    display: table-cell;
    vertical-align: middle
}

.header__nav .h-nav__list > li {
    width: 100%;
    padding: 1rem 0;
    line-height: 1
}

.header__nav .h-nav__list > li .label {
    color: #000000;
    font-family: "Helvetica Neue LT W01_65 Md", "Helvetica Bold", "Arial Bold", sans-serif;
    font-size: 5.4rem;
    vertical-align: top
}

.header__nav .h-nav__list > li .label .txt {
    position: relative;
    z-index: 2
}

html.notouch .header__nav .h-nav__list > li a.label:hover {
    color: #00a2e9;
    text-decoration: none
}

.header__nav .h-nav__list > li.has-children {
    display: table
}

.header__nav .h-nav__list > li.has-children .label {
    display: table-cell;
    width: 37rem;
    vertical-align: top
}

.header__nav .h-nav__list > li.has-children .children {
    display: table-cell;
    color: rgba(0, 0, 0, 0.3);
    line-height: 1.2;
    vertical-align: middle
}

.header__nav .h-nav__list > li.has-children .children__label {
    margin-bottom: 1rem;
    font-family: 'webfont', sans-serif;
    font-size: 1.2rem
}

.header__nav .h-nav__list > li.has-children .children__list {
    zoom: 1;
    font-family: 'webfont', sans-serif;
    font-size: 2.2rem
}

.header__nav .h-nav__list > li.has-children .children__list:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

.header__nav .h-nav__list > li.has-children .children__list li {
    float: left
}

.header__nav .h-nav__list > li.has-children .children__list li:after {
    content: '/';
    padding: 0 1rem
}

.header__nav .h-nav__list > li.has-children .children__list li:last-child:after {
    display: none
}

.header__nav .h-nav__list > li.has-children .children__list li a {
    -webkit-transition: all 0.1s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all 0.1s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    color: rgba(0, 0, 0, 0.3)
}

.header__nav .h-nav__list > li.has-children .children__list li a .txt {
    position: relative;
    z-index: 2
}

html.notouch .header__nav .h-nav__list > li.has-children .children__list li a:hover {
    -webkit-transition: all .8s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .8s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    color: #ffffff;
    text-decoration: none
}

.header__nav .h-nav__copyright {
    margin-top: 4rem;
    color: rgba(0, 0, 0, 0.3);
    font-family: 'webfont', sans-serif;
    font-size: 1rem;
    line-height: 1
}

.header__nav .h-nav__bg {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    width: 100vw;
    height: 100%
}

.header__nav .h-nav__bg .bg {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    opacity: 0
}

.header__nav .h-nav__bg .bg:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.24);
    opacity: 0
}

.header__nav .h-nav__bg .bg.is-current {
    z-index: 1;
    opacity: 1
}

.header__nav .h-nav__bg .bg.is-current:after {
    -webkit-transition: opacity .8s cubic-bezier(0.075, 0.82, 0.165, 1) 0.1s;
    transition: opacity .8s cubic-bezier(0.075, 0.82, 0.165, 1) 0.1s;
    opacity: 1
}

.header__nav .m-links {
    zoom: 1;
    margin-top: 4rem
}

.header__nav .m-links:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

.header__nav .m-links dl {
    float: left
}

.header__nav .m-links dl + dl {
    margin-left: 6rem
}

.header__nav .m-links dl dt {
    color: rgba(0, 0, 0, 0.3)
}

.header__nav .m-logo {
    margin-top: 4rem
}

html.is-nav-open .header {
    width: 100%
}

html.is-nav-open .header .header__menu .open {
    display: none
}

html.is-nav-open .header .header__menu .close {
    display: block
}

html.is-nav-open .header .header__share .share-icon {
    visibility: hidden
}

html.is-nav-open .header .header__share .share {
    -webkit-animation: share-overflow .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    animation: share-overflow .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    overflow: visible;
    height: 17.5rem;
    background: none
}

@media only screen and (max-width: 768px) {
    
    
    .header {
        overflow: hidden;
        width: 100%;
        height: 6.3rem;
        background: none
    }

    .header__logo {
        position: absolute;
        width: auto;
        padding: 0.5rem 0 0 0.5rem;
    }

    .header__logo .logo {
        width: 14rem;
        height: 6.3rem
    }

    .header__logo .logo:before {
        top: 0;
        left: 2rem;
        width: 1.6rem;
        height: 6.3rem
    }

    .header__logo .logo:after {
        top: 0;
        left: 4.5rem;
        width: 9rem;
        height: 6.3rem;
        background-image: url(../images/logo.svg)
    }

    body.page-top .header__logo .logo {
        width: 4rem;
        height: 6.3rem
    }

    body.page-top .header__logo .logo:before {
        background-image: url(../images/logo_descente_white.svg)
    }

    html.is-scrolled body.page-top .header__logo .logo {
        width: 14rem;
        height: 6.3rem
    }

    html.is-scrolled body.page-top .header__logo .logo:before {
        background-image: url(../images/logo_descente.svg)
    }

    .header__menu {
        right: 0;
        left: auto;
        width: 6.3rem;
        height: 6.3rem
    }

    .header__menu .open {
        display: block;
        position: absolute;
        top: 1.5rem;
        right: 1.5rem;
        left: auto;
        width: 3.3rem;
        height: 3.3rem;
        margin-top: 0
    }

    .header__menu .open .line-1, .header__menu .open .line-2, .header__menu .open .line-3 {
        top: 50%;
        width: 3.3rem;
        height: 1px
    }

    body.page-top .header__menu .open .line-1, body.page-top .header__menu .open .line-2, body.page-top .header__menu .open .line-3 {
        background: #ffffff
    }

    html.is-scrolled body.page-top .header__menu .open .line-1, html.is-scrolled body.page-top .header__menu .open .line-2, html.is-scrolled body.page-top .header__menu .open .line-3 {
        background: #000000
    }

    .header__menu .open .line-1 {
        -webkit-transform: translate(0, -0.4rem);
        transform: translate(0, -0.4rem)
    }

    .header__menu .open .line-2 {
        display: none
    }

    .header__menu .open .line-3 {
        -webkit-transform: translate(0, 0.3rem);
        transform: translate(0, 0.3rem)
    }

    .header__menu .close {
        top: 1.5rem;
        right: 1.5rem;
        left: auto;
        width: 3.3rem;
        height: 3.3rem;
        margin-top: 0
    }

    .header__menu .close .line-1, .header__menu .close .line-2 {
        top: 0;
        left: 50%;
        width: 1px;
        height: 3.5rem
    }

    .header__menu .close .line-1 {
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg)
    }

    .header__menu .close .line-2 {
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg)
    }

    .header__share {
        display: none
    }

    .header__nav {
        overflow: visible;
        position: relative;
        top: auto;
        left: auto;
        z-index: 0;
        width: auto;
        height: auto;
        padding: 12rem 1.5rem;
        background: none
    }

    .header__nav .h-nav__outer {
        display: block;
        width: auto;
        height: auto;
        padding: 0
    }

    .header__nav .h-nav__outer:after {
        display: none
    }

    .header__nav .h-nav__inner {
        display: block
    }

    .header__nav .h-nav__list {
        counter-reset: nav-number 0
    }

    .header__nav .h-nav__list > li {
        position: relative;
        width: auto;
        width: 100%;
        padding: 1.7rem 0 3.2rem;
        border-top: rgba(0, 0, 0, 0.1) solid 1px
    }

    .header__nav .h-nav__list > li:before {
        counter-increment: nav-number 1;
        content: "0" counter(nav-number);
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        width: 1.3rem;
        margin-top: -0.4rem;
        background: #ffffff;
        color: rgba(0, 0, 0, 0.5);
        font-family: "Helvetica Neue LT W01_65 Md", "Helvetica Bold", "Arial Bold", sans-serif;
        font-size: 0.8rem;
        line-height: 1
    }

    .header__nav .h-nav__list > li .label {
        display: inline-block;
        padding: 1.1rem 0;
        color: #000000;
        font-size: 1.8rem
    }

    html.notouch .header__nav .h-nav__list > li a.label:hover {
        color: #000000
    }

    .header__nav .h-nav__list > li.has-children .label {
        width: 13rem
    }

    .header__nav .h-nav__list > li.has-children .children {
        color: #000000;
        vertical-align: top
    }

    .header__nav .h-nav__list > li.has-children .children__label {
        margin-bottom: 1rem;
        padding-top: 1.5rem;
        font-size: 0.8rem
    }

    .header__nav .h-nav__list > li.has-children .children__list {
        font-size: 1.3rem
    }

    .header__nav .h-nav__list > li.has-children .children__list li:after {
        padding: 1rem;
        color: rgba(0, 0, 0, 0.3)
    }

    .header__nav .h-nav__list > li.has-children .children__list li a {
        display: inline-block;
        padding: 1rem 0
    }

    html.notouch .header__nav .h-nav__list > li.has-children .children__list li a:hover {
        color: rgba(0, 0, 0, 0.3)
    }

    .header__nav .h-nav__list > li.has-children .children__list.sp-vertical li {
        float: none
    }

    .header__nav .h-nav__copyright {
        display: none
    }

    .header__nav .h-nav__bg {
        display: none
    }

    .header__nav .m-links {
        margin-top: 2rem
    }

    .header__nav .m-links dl {
        float: none
    }

    .header__nav .m-links dl + dl {
        margin: 1.5rem 0 0
    }

    .header__nav .m-logo {
        margin-top: 3rem
    }

    html.is-nav-open .header {
        overflow: auto;
        height: 100%;
        background: #ffffff;
        -webkit-overflow-scrolling: touch
    }

    html.is-nav-open .header .header__logo .logo {
        width: 14rem !important
    }

    html.is-nav-open .header .header__logo .logo:before {
        background-image: url(../images/logo_descente.svg) !important
    }

    html.is-nav-open .header .header__logo .logo:after {
        -webkit-animation: none;
        animation: none;
        opacity: 1 !important
    }
}

.footer {
    position: absolute;
    z-index: 2;
    left: 0;
    bottom: 0;
    width: 100%;
}

.footer__inner {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    max-width: 133rem;
    margin-right: auto;
    margin-left: auto;
    padding-right: 6.5rem;
    padding-left: 6.5rem;
    zoom: 1
}

@media only screen and (max-width: 768px) {
    .footer__inner {
        padding-right: 1.5rem;
        padding-left: 1.5rem
    }
}

.footer__inner:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

.footer__info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

.footer__logo {
    display: block;
    overflow: hidden;
    font-size: 30px;
    font-family: webfont, sans-serif;
    width: 36.25%;

}

.footer__links {
    width: 63.75%
}

.footer__links .m-links dl + dl {
    margin-top: 4rem
}

.footer__links .m-logo {
    margin-top: 5rem
}

.footer__movie {
    width: 32.58%;
    font-family: 'webfont', sans-serif;
    font-size: 1.2rem;
    line-height: 1.2
}

.footer__movie dd {
    margin-top: 1rem
}

.footer__movie dd ul li + li {
    margin-top: 1rem
}

.footer__movie dd ul li a {
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    vertical-align: top
}

.footer__movie dd ul li a img {
    width: 7rem
}

.footer__movie dd ul li a .txt {
    -ms-flex-item-align: center;
    align-self: center;
    padding-left: 1.5rem
}

.footer__copyright {
    margin-top: 7.5rem;
    padding: 5.5rem 0;
    background: #00a2e9;
    color: #ffffff;
    font-family: 'webfont', sans-serif;
    font-size: 1.2rem;
    line-height: 1;
    text-align: center
}

.footer__copyright a {
    color: inherit;
}

@media only screen and (max-width: 768px) {
    .footer {
        position: relative;
        right: auto;
        bottom: auto;
        left: auto
    }

    .footer__inner {
        padding-top: 7.5rem;
        padding-bottom: 9rem;
        background: #000000;
        color: #ffffff
    }

    .footer__info {
        display: block
    }

    .footer__logo {
        float: none;
        font-size: 30px;
        margin-bottom: 3rem;

    }

    .footer__links {
        width: auto
    }

    .footer__links .m-links dl + dl {
        margin-top: 3rem
    }

    .footer__links .m-logo {
        margin-top: 3rem
    }

    .footer__copyright {
        margin-top: 0;
        padding: 2.6rem 0;
        font-size: 0.9rem
    }
}

@-webkit-keyframes bg-animation {
    0% {
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%)
    }
    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

@keyframes bg-animation {
    0% {
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%)
    }
    100% {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

body.page-top .header {
    -webkit-transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition: -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s, -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s
}

body.page-top .content {
    padding-bottom: 85rem
}

@media only screen and (max-width: 768px) {
    body.page-top .content {
        padding-bottom: 0
    }
}

body.page-top .ancNav {
    -webkit-transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition: -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s, -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transform: translate(0, 50%);
    transform: translate(0, 50%);
    position: fixed;
    right: 0;
    bottom: 50%;
    z-index: 5;
    font-size: 14px;
    line-height: 1;
    white-space: nowrap
}

body.page-top .ancNav__list {
    position: relative;
    z-index: 1;
    padding: 4rem 0;
    width: 7rem;
}

body.page-top .ancNav__list li a {
    display: block;
    position: relative;
    padding: 0.5rem 0;
    color: #ffffff;
    text-decoration: none
}

body.page-top .ancNav__list li a:before {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 0.2rem;
    z-index: 0;
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: #ffffff;
    opacity: 1
}

body.page-top .ancNav__list li a .txt {
    display: block;
    overflow: hidden;
    position: relative;
    z-index: 2;
    width: 0
}

html.is-scrolled body.page-top .ancNav__list li a {
    padding: 1.6rem 0
}

html.notouch body.page-top .ancNav__list li a:hover, body.page-top .ancNav__list li.is-current a {
    text-decoration: none
}

html.notouch body.page-top .ancNav__list li a:hover:before, body.page-top .ancNav__list li.is-current a:before {
    opacity: 0
}

html.notouch body.page-top .ancNav__list li a:hover .txt, body.page-top .ancNav__list li.is-current a .txt {
    width: 100%
}

body.page-top .ancNav__list.is-black {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2
}

body.page-top .ancNav__list.is-black li a {
    color: #000000
}

body.page-top .ancNav__list.is-black li a:before {
    background: #000000
}

html.is-footer-show body.page-top .ancNav {
    position: absolute;
    bottom: calc(24rem + 50vh)
}

@media only screen and (max-width: 768px) {
    body.page-top .ancNav {
        display: none
    }
}

body.page-top .section {
    overflow: hidden;
    position: relative;
    z-index: 1;
    padding: 5rem 0
}

body.page-top .section__inner {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    max-width: 133rem;
    margin-right: auto;
    margin-left: auto;
    padding-right: 6.5rem;
    padding-left: 6.5rem;
    zoom: 1;
    position: relative;
    z-index: 1
}

@media only screen and (max-width: 768px) {
    body.page-top .section__inner {
        padding-right: 1.5rem;
        padding-left: 1.5rem
    }
}

body.page-top .section__inner:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-top .section__head {
    position: absolute;
    top: 1rem;
    z-index: 0;
    left: auto;
    line-height: 1;
    white-space: nowrap
}

body.page-top .section__head .label {
    margin-bottom: 2rem;
    color: #cccccc;
    font-family: 'webfont', sans-serif;
    font-size: 1.2rem;
    opacity: 0
}

body.page-top .section__head .ttl {
    font-family: "Helvetica Neue LT W01_65 Md", "Helvetica Bold", "Arial Bold", sans-serif;
    font-size: 2.4rem;
    opacity: 0
}

body.page-top .section__body {
    position: relative;
    z-index: 1
}

body.page-top .section.head-left .section__head {
    left: 9.5rem
}

body.page-top .section.head-left .section__head .head {

}

body.page-top .section.head-left .section__body {
    margin-left: 20rem
}

body.page-top .section.head-right .section__head {
    right: 19.5rem
}

body.page-top .section.head-right .section__head .head {
}

body.page-top .section.head-right .section__body {
    margin-right: 20rem
}

body.page-top .section .slideup {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition-property: opacity, -webkit-transform;
    transition-property: opacity, -webkit-transform;
    transition-property: transform, opacity;
    transition-property: transform, opacity, -webkit-transform;
    -webkit-transform: translateY(5rem);
    transform: translateY(5rem);
    opacity: 0
}

body.page-top .section .shuffle-text {
    opacity: 0
}

body.page-top .section.is-show .slideup {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1
}

body.page-top .section.is-show .shuffle-text {
    opacity: 1
}

@media only screen and (max-width: 768px) {
    body.page-top .section {
        padding: 7.5rem 0;
        background: #ffffff
    }

    body.page-top .section__head {
        position: static;
        top: auto;
        height: auto !important;
        margin-bottom: 4rem;
        padding-top: 0
    }

    body.page-top .section__head .label {
        margin-bottom: 0.5rem;
        font-size: 0.9rem
    }

    body.page-top .section__head .ttl {
        font-size: 2rem
    }

    body.page-top .section.head-left .section__head {
        left: auto
    }

    body.page-top .section.head-left .section__head .head {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }

    body.page-top .section.head-left .section__body {
        margin-left: 0
    }

    body.page-top .section.head-right .section__head {
        right: auto
    }

    body.page-top .section.head-right .section__head .head {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }

    body.page-top .section.head-right .section__body {
        margin-right: 0
    }

    body.page-top .section .slideup {
        -webkit-transform: translateY(2rem);
        transform: translateY(2rem)
    }
}

@-webkit-keyframes mv-scroll {
    0% {
        -webkit-transform: scale(0.7);
        transform: scale(0.7);
        opacity: 0
    }
    33.33% {
        -webkit-transform: scale(1);
        transform: scale(1);
        opacity: 1
    }
    100% {
        -webkit-transform: scale(1.3);
        transform: scale(1.3);
        opacity: 0
    }
}

@keyframes mv-scroll {
    0% {
        -webkit-transform: scale(0.7);
        transform: scale(0.7);
        opacity: 0
    }
    33.33% {
        -webkit-transform: scale(1);
        transform: scale(1);
        opacity: 1
    }
    100% {
        -webkit-transform: scale(1.3);
        transform: scale(1.3);
        opacity: 0
    }
}

body.page-top .mainVisual {
    overflow: hidden;
    z-index: 0;
    height: 100vh;
    padding: 0
}

body.page-top .mainVisual:after {
    -webkit-transition: opacity .8s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: opacity .8s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 2;
    background: #ffffff;
    opacity: 0
}

body.page-top .mainVisual__logo {
    display: block;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    width: 100%;
    margin-top: -5rem;
    font-size: 10rem;
    color: #fff;
    text-align: center;
    opacity: 1
}

body.page-top .mainVisual__logo.is-show {
    opacity: 1
}

body.page-top .mainVisual__img {
    overflow: hidden;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 0
}

body.page-top .mainVisual__slider {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 0
}

body.page-top .mainVisual__slider .item {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    overflow: hidden;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 0;
    width: 100%;
    height: 100%
}

body.page-top .mainVisual__slider .item__imgWrap {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0
}

body.page-top .mainVisual__slider .item__imgWrap.is-zoomout {
    -webkit-transition: -webkit-transform 5.4s linear 0s;
    transition: -webkit-transform 5.4s linear 0s;
    transition: transform 5.4s linear 0s;
    transition: transform 5.4s linear 0s, -webkit-transform 5.4s linear 0s;
    -webkit-transform: scale(1);
    transform: scale(1)
}

body.page-top .mainVisual__slider .item__img {
    -webkit-transform: translateX(75%);
    transform: translateX(75%);
    display: block;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover
}

body.page-top .mainVisual__slider .item__img img {
    visibility: hidden;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    opacity: 0
}

body.page-top .mainVisual__slider .item.is-current {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    z-index: 1
}

body.page-top .mainVisual__slider .item.is-current .item__img {
    -webkit-transform: translateX(0);
    transform: translateX(0)
}

body.page-top .mainVisual__slider .item.is-next {
    -webkit-transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition: -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s, -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transform: translateX(0);
    transform: translateX(0);
    z-index: 2
}

body.page-top .mainVisual__slider .item.is-next .item__img {
    -webkit-transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition: -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s, -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transform: translateX(0);
    transform: translateX(0)
}

body.page-top .mainVisual__scroll {
    display: none
}

@media only screen and (max-width: 768px) {
    body.page-top .mainVisual__logo {
        position: fixed;
        left: 12%;
        width: 76%;
        height: 10rem;
        margin-top: -1.5rem;
        opacity: 1;
        font-size: 5rem;
    }

    body.page-top .mainVisual__video {
        visibility: hidden
    }

    body.page-top .mainVisual__img {
        visibility: visible
    }

    body.page-top .mainVisual__scroll {
        display: block;
        position: absolute;
        right: 0;
        left: 0;
        bottom: 0;
        z-index: 1;
        padding-bottom: 4rem;
        color: #ffffff;
        font-family: "Helvetica Neue LT W01_65 Md", "Helvetica Bold", "Arial Bold", sans-serif;
        font-size: 0.8rem;
        line-height: 1;
        text-align: center
    }

    body.page-top .mainVisual__scroll:before {
        -webkit-animation: mv-scroll 1.2s linear 0s infinite normal;
        animation: mv-scroll 1.2s linear 0s infinite normal;
        content: '';
        display: block;
        position: absolute;
        left: 50%;
        bottom: 1.8rem;
        width: 1.4rem;
        height: 1.4rem;
        margin-left: -0.7rem;
        border-radius: 0.7rem;
        background: rgba(255, 255, 255, 0.5)
    }

    body.page-top .mainVisual__scroll:after {
        content: '';
        display: block;
        position: absolute;
        left: 50%;
        bottom: 2rem;
        width: 1rem;
        height: 1rem;
        margin-left: -0.5rem;
        border-radius: 0.5rem;
        background: #ffffff
    }
}

body.page-top .about {
    overflow: visible;
    z-index: 2;
    height: 100vh;
    padding: 0;
    background: #f5f5f5
}

body.page-top .about:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 62.41%;
    z-index: 0;
    background-color: #00a2e9
}

body.page-top .about__inner {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 100%
}

body.page-top .about__txt {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: table;
    position: absolute;
    top: 0;
    left: 13rem;
    z-index: 3;
    height: 100%;
    padding-top: 2rem;
    font-size: 1.4rem;
    line-height: 1.86;
    white-space: nowrap
}

body.page-top .about__txt .txt__inner {
    display: table-cell;
    vertical-align: middle
}

body.page-top .about__txt .txt__inner h3 {
    font-weight: bold;
    margin-top: 15px;
}

body.page-top .about__txt .ttl {
    margin-bottom: 3rem;
    font-family: 'webfont', sans-serif;
    font-size: 2.2rem;
    line-height: 1.2
}

body.page-top .about__img {
    position: absolute;
    right: 0;
    bottom: -10.1rem;
    z-index: 2;
    width: 50%
}

body.page-top .about__slider {
    overflow: hidden;
    position: relative;
    width: 100%;
    padding-bottom: 86%
}

body.page-top .about__slider .item {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    overflow: hidden;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 0;
    width: 100%;
    height: 100%
}

body.page-top .about__slider .item img {
    -webkit-transform: translateX(75%);
    transform: translateX(75%);
    width: 100%
}

body.page-top .about__slider .item.is-current {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    z-index: 1
}

body.page-top .about__slider .item.is-current img {
    -webkit-transform: translateX(0);
    transform: translateX(0)
}

body.page-top .about__slider .item.is-next {
    -webkit-transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition: -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s, -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transform: translateX(0);
    transform: translateX(0);
    z-index: 2
}

body.page-top .about__slider .item.is-next img {
    -webkit-transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition: -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s, -webkit-transform .6s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transform: translateX(0);
    transform: translateX(0)
}

body.page-top .about__bg {
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 1;
    width: 100%;
    height: 30rem;
    margin-top: -15rem
}

body.page-top .about__bg .bg {
    overflow: hidden;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    height: 30rem
}

body.page-top .about__bg .bg:before {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 100vw;
    width: 392.9rem;
    height: 30rem;
    background: url(../images/about_bg_2.svg) no-repeat center center;
    background-size: auto 30rem
}

body.page-top .about__bg .bg.bg-gray {
    right: 37.59%;
    background: #f5f5f5
}

body.page-top .about__bg .bg.bg-gray:before {
    background-image: url(../images/about_bg.svg)
}

body.page-top .about__bg.is-play .bg:before {
    -webkit-animation: bg-animation 196.45s linear infinite normal;
    animation: bg-animation 196.45s linear infinite normal
}

@media only screen and (max-width: 768px) {
    body.page-top .about {
        height: auto;
        padding: 7rem 3.5rem 7.5rem;
        background: #ffffff
    }

    body.page-top .about:before {
        display: none
    }

    body.page-top .about__inner {
        overflow: visible;
        position: relative;
        width: auto;
        height: auto
    }

    body.page-top .about__txt {
        display: block;
        position: relative;
        top: auto;
        left: auto;
        height: auto;
        padding-top: 0;
        font-size: 1.2rem;
        line-height: 1.67;
        white-space: normal
    }

    body.page-top .about__txt .txt__inner {
        zoom: 1;
        display: block;
        padding-left: 6rem
    }

    body.page-top .about__txt .txt__inner:after {
        content: '';
        display: block;
        clear: both;
        height: 0
    }

    body.page-top .about__txt .ttl {
        float: left;
        margin-bottom: 0;
        margin-left: -6rem;
        font-size: 1.5rem;
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl
    }

    body.page-top .about__img {
        position: relative;
        right: auto;
        bottom: auto;
        width: auto;
        margin-top: 6rem
    }

    body.page-top .about__bg {
        top: auto;
        bottom: calc((100vw - 7rem) * 0.4);
        right: -3.5rem;
        left: -3.5rem;
        width: auto;
        height: 19.4rem;
        margin-top: 0
    }

    body.page-top .about__bg .bg {
        display: none;
        height: 19.4rem;
        opacity: 0.5
    }

    body.page-top .about__bg .bg:before {
        width: 254.1rem;
        height: 19.4rem;
        background-size: auto 19.4rem
    }

    body.page-top .about__bg .bg.bg-gray {
        display: block;
        right: 0;
        background: none
    }

    body.page-top .about__bg .bg.bg-gray:before {
        background-image: url(../images/about_bg.svg)
    }

    body.page-top .about__bg.is-play .bg:before {
        -webkit-animation: bg-animation 127.05s linear infinite normal;
        animation: bg-animation 127.05s linear infinite normal
    }
}

body.page-top .features {
    position: relative;
    z-index: 1;
    margin-bottom: 9.9rem;
    padding: 0
}

body.page-top .feature {
    overflow: visible;
    margin-top: 10rem;
    padding: 0
}

body.page-top .feature__label {
    overflow: hidden;
    position: absolute;
    left: 0;
    z-index: 2;
    width: 6.5rem;
    font-family: 'webfont', sans-serif;
    font-size: 1.2rem;
    line-height: 1;
    white-space: nowrap
}

body.page-top .feature__label .label {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    height: 100vh
}

body.page-top .feature__label .txt {
    -webkit-transform-origin: center top;
    transform-origin: center top;
    -webkit-transform: translateX(-50%) rotate(90deg);
    transform: translateX(-50%) rotate(90deg);
    display: block;
    position: absolute;
    top: 50%;
    left: 100%;
    padding-right: 4.5rem;
    opacity: 1
}

body.page-top .feature__label .txt:after {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    right: 0;
    width: 3.6rem;
    height: 1px
}

body.page-top .feature__inner {
    overflow: hidden;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1;
    height: 100vh
}

body.page-top .feature__ttl {
    position: absolute;
    top: 0;
    left: 5%;
    z-index: 1;
    padding-left: 5rem
}

body.page-top .feature__ttl .logo {
    -webkit-transition: width .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: width .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    overflow: hidden;
    width: 0
}

body.page-top .feature__ttl .logo span {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    margin-bottom: 1rem;
    background-repeat: no-repeat;
    background-position: left center;
    background-size: auto 100%
}

body.page-top .feature__ttl .ttl {
    color: #ffffff;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.2
}

body.page-top .feature__txt {
    position: absolute;
    width: 40%;
    top: 40%;
    z-index: 1;
    font-size: 1.4rem;
    line-height: 1.86;
    background: rgba(255,255,255,.8);
    padding: 20px;
}

body.page-top .feature__txt .en {
    margin-top: 2rem;
    font-size: 1.3rem;
    line-height: 1.77;
    opacity: 0.8
}

body.page-top .feature__bg {
    overflow: hidden;
    position: absolute;
    top: 50%;
    z-index: 0;
    width: 37.59%
}

body.page-top .feature__bg:before {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    content: '';
    display: block;
    position: relative;
    left: 100%;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain
}

body.page-top .feature__img {
    zoom: 1;
    position: relative;
    z-index: 0;
    width: 62.41%
}

body.page-top .feature__img:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-top .feature__img .img {
    display: block;
    overflow: hidden;
    position: relative;
    float: left;
    width: 100%;
    padding-bottom: 150%;
    margin: -10rem 0
}

body.page-top .feature__img img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%
}

html.notouch body.page-top .feature__img img {
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%)
}

body.page-top .feature.img-left .feature__label {
    top: -10rem;
    bottom: -10rem;
    color: #ffffff
}

body.page-top .feature.img-left .feature__label .txt:after {
    background: #ffffff
}

body.page-top .feature.img-left .feature__txt {
    right: 10%;

}

body.page-top .feature.img-left .feature__bg {
    left: 62.41%
}

body.page-top .feature.img-right .feature__label {
    top: 0;
    bottom: 0;
    color: #000000
}

body.page-top .feature.img-right .feature__label .txt:after {
    background: #000000
}

body.page-top .feature.img-right .feature__ttl {
    left: 37.59%
}

body.page-top .feature.img-right .feature__txt {
    left: 13rem
}

body.page-top .feature.img-right .feature__img {
    margin-left: auto
}

body.page-top .feature.img-right .feature__bg {
    left: 0
}

body.page-top .feature.schematech {
    background: #82868c
}

body.page-top .feature.schematech .feature__ttl {
    padding-top: 4rem
}

body.page-top .feature.schematech .feature__ttl .logo span {
    width: 45.5rem;
    height: 6.1rem;
    background-image: url(../images/feature_schematech_logo.svg)
}

/*body.page-top .feature.schematech .feature__txt {*/
/*    color: #ffffff*/
/*}*/

body.page-top .feature.schematech .feature__bg {
    height: 44rem;
    margin-top: -22rem
}

body.page-top .feature.schematech .feature__bg:before {
    width: 332.9rem;
    background-image: url(../images/feature_schematech_bg.svg);
    display: none;
}

body.page-top .feature.schematech .feature__bg.is-play:before {
    -webkit-animation: bg-animation 166.45s linear infinite normal;
    animation: bg-animation 166.45s linear infinite normal
}

body.page-top .feature.schematech.is-show .feature__ttl .logo {
    width: 45.5rem
}

body.page-top .feature.performacut {
    background: #ffffff
}

body.page-top .feature.performacut .feature__ttl {
    padding-top: 3rem
}

body.page-top .feature.performacut .feature__ttl .logo span {
    width: 35rem;
    height: 5.7rem;
    background-image: url(../images/feature_performacut_logo.svg)
}

body.page-top .feature.performacut .feature__bg {
    height: 38.3rem;
    margin-top: -21.5rem
}

body.page-top .feature.performacut .feature__bg:before {
    width: 235.1rem;
    background-image: url(../images/feature_performacut_bg.svg);
    display: none;
}

body.page-top .feature.performacut .feature__bg.is-play:before {
    -webkit-animation: bg-animation 117.55s linear infinite normal;
    animation: bg-animation 117.55s linear infinite normal
}

body.page-top .feature.performacut .feature__img .img {
    margin-bottom: -10.1rem
}

body.page-top .feature.performacut.is-show .feature__ttl .logo {
    width: 35rem
}

body.page-top .feature.supersonic {
    background: #2f3133
}

body.page-top .feature.supersonic .feature__ttl {
    top: 0
}

body.page-top .feature.supersonic .feature__ttl .logo span {
    width: 41.3rem;
    height: 9.3rem;
    background-image: url(../images/feature_supersonic_logo.svg)
}

/*body.page-top .feature.supersonic .feature__txt {*/
/*    color: #ffffff*/
/*}*/

body.page-top .feature.supersonic .feature__bg {
    height: 66rem;
    margin-top: -40rem
}


body.page-top .feature.supersonic .feature__bg.is-play:before {
    -webkit-animation: bg-animation 145.65s linear infinite normal;
    animation: bg-animation 145.65s linear infinite normal
}

body.page-top .feature.supersonic.is-show .feature__ttl .logo {
    width: 41.3rem
}

@media only screen and (max-width: 768px) {
    body.page-top .features {
        z-index: 0;
        margin-bottom: 7.5rem
    }

    body.page-top .feature {
        margin-top: 0
    }

    body.page-top .feature:before {
        content: '';
        display: block;
        height: 150vw;
        margin-bottom: -100vw
    }

    body.page-top .feature__label {
        display: none
    }

    body.page-top .feature__inner {
        -webkit-box-orient: vertical;
        overflow: hidden;
        position: relative;
        position: -webkit-sticky;
        position: sticky;
        top: auto;
        bottom: 0;
        z-index: 2;
        height: 100vw;
       
        padding: 0 1.5rem 2rem;
        background: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.6)), to(rgba(0, 0, 0, 0)));
        background: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0));
        background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0))
    }

    body.page-top .feature__ttl {
        position: relative;
        top: auto;
        left: auto;
        margin-bottom: 1.5rem;
        padding-left: 0
    }

    body.page-top .feature__ttl .logo span {
        margin-bottom: 0.5rem
    }

    body.page-top .feature__ttl .ttl {
        font-size: 2rem
    }

    body.page-top .feature__txt {
        -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) .4s;
        transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) .4s;
        -webkit-transform: translateY(2rem);
        transform: translateY(2rem);
        position: relative;
        bottom: auto;
        top: 0;
        color: #ffffff;
        font-size: 1.2rem;
        line-height: 1.67;
        white-space: normal;
        opacity: 0
    }



    body.page-top .feature__bg {
        display: none
    }

    body.page-top .feature__img {
        position: relative;
        position: -webkit-sticky;
        position: sticky;
        bottom: 0;
        width: 100%;
        height: 0
    }

    body.page-top .feature__img .img {
        -webkit-transform: translateY(-100%);
        transform: translateY(-100%);
        float: none;
        height: 150vw;
        margin: 0 !important;
        padding-bottom: 0
    }

    body.page-top .feature__img img {
        position: static
    }

    html.notouch body.page-top .feature__img img {
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    body.page-top .feature.img-left .feature__txt {
        left: auto;
        margin-left: 0;
        width: 100%;
    }

    body.page-top .feature.img-right .feature__ttl {
        left: auto
    }

    body.page-top .feature.img-right .feature__txt {
        left: auto
    }

    body.page-top .feature.img-right .feature__img {
        margin-left: auto
    }

    body.page-top .feature.schematech {
        z-index: 2;
        background: none
    }

    body.page-top .feature.schematech .feature__ttl {
        padding-top: 0
    }

    body.page-top .feature.schematech .feature__ttl .logo span {
        width: 23rem;
        height: 3.1rem
    }

    body.page-top .feature.schematech.is-show .feature__ttl .logo {
        width: 23rem
    }

    body.page-top .feature.performacut {
        z-index: 1;
        background: none
    }

    body.page-top .feature.performacut .feature__ttl {
        padding-top: 0
    }

    body.page-top .feature.performacut .feature__ttl .logo span {
        width: 20.3rem;
        height: 3.3rem
    }

    body.page-top .feature.performacut.is-show .feature__ttl .logo {
        width: 20.3rem
    }

    body.page-top .feature.supersonic {
        z-index: 0;
        background: none
    }

    body.page-top .feature.supersonic .feature__ttl {
        top: 0
    }

    body.page-top .feature.supersonic .feature__ttl .logo span {
        width: 25rem;
        height: 5.7rem
    }

    body.page-top .feature.supersonic.is-show .feature__ttl .logo {
        width: 25rem
    }

    body.page-top .feature.is-show .feature__txt {
        -webkit-transform: translateY(0);
        transform: translateY(0);
        opacity: 1
    }
}

body.page-top .products:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 0;
    width: 37.59%;
    background: #f5f5f5
}

body.page-top .products__list {
    zoom: 1;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    max-width: 80rem;
    padding-left: 6rem
}

body.page-top .products__list:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-top .products__list .item {
    width: 50%;
    margin-top: 7rem;
    font-family: 'webfont', sans-serif
}

body.page-top .products__list .item:nth-child(odd) {
    float: left;
    margin-left: -6rem
}

body.page-top .products__list .item:nth-child(even) {
    float: right
}

body.page-top .products__list .item:first-child {
    margin-top: 0
}

body.page-top .products__list .item:nth-child(2) {
    margin-top: 10rem
}

body.page-top .products__list .item a {
    display: block;
    color: #000000
}

html.notouch body.page-top .products__list .item a:hover {
    text-decoration: none
}

body.page-top .products__list .item__img {
    position: relative;
    z-index: 0;
    padding-bottom: 100%;
    margin-bottom: 1.5rem;
    background: url(../images/product_bg.jpg) no-repeat center center;
    background-size: cover
}

body.page-top .products__list .item__img img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%
}

body.page-top .products__list .item__color {
    zoom: 1;
    position: absolute;
    bottom: 1rem;
    left: 1rem
}

body.page-top .products__list .item__color:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-top .products__list .item__color li {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    float: left;
    width: 1rem;
    height: 1rem;
    border-radius: 0.5rem
}

body.page-top .products__list .item__color li + li {
    margin-left: 0.5rem
}

body.page-top .products__list .item__color li.green {
    background: #b2db14
}

body.page-top .products__list .item__color li.black {
    background: #000000
}

body.page-top .products__list .item__color li.navy {
    background: #0e2554
}

body.page-top .products__list .item__color li.gray {
    background: #999999
}

body.page-top .products__list .item__color li.white-2019ss {
    background: #ede5cf
}

body.page-top .products__list .item__color li.red-2019ss {
    background: #d72432
}

body.page-top .products__list .item__color li.navy-2019ss {
    background: #2d2d38
}

body.page-top .products__list .item__color li.black-2019ss {
    background: #000000
}

body.page-top .products__list .item__color li.blue-2019fw {
    background: #7ad3d7
}

body.page-top .products__list .item__color li.white-2019fw {
    background: #f5f5f5
}

body.page-top .products__list .item__color li.black-2019fw {
    background: #000000
}

body.page-top .products__list .item__color li.navy-2019fw {
    background: #333145
}

body.page-top .products__list .item__color li.red-2020ss {
    background: #00a2e9
}

body.page-top .products__list .item__color li.white-2020ss {
    background: #f5f5f5
}

body.page-top .products__list .item__color li.black-2020ss {
    background: #000000
}

body.page-top .products__list .item__color li.navy-2020ss {
    background: #0e2554
}

body.page-top .products__list .item__code {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    /*color: #ffffff;*/
    font-size: 1.2rem;
    line-height: 1;
    display: none;
}

body.page-top .products__list .item__name {
    position: relative;
    z-index: 2;
    font-size: 1.8rem;
    line-height: 1.2
}

body.page-top .products__list .item__price {
    position: relative;
    z-index: 2;
    margin-top: 1rem;
    color: #00a2e9;
    font-size: 1.2rem;
    line-height: 1
}

@media only screen and (max-width: 768px) {
    body.page-top .products {
        padding-right: 2rem;
        padding-bottom: 5rem;
        padding-left: 2rem
    }

    body.page-top .products:before {
        right: 0;
        bottom: 12.5rem;
        left: auto;
        width: 36%
    }

    body.page-top .products__list {
        max-width: none;
        padding-left: 0
    }

    body.page-top .products__list .item {
        width: auto;
        margin-top: 3rem
    }

    body.page-top .products__list .item:nth-child(odd) {
        float: none;
        margin-left: 0
    }

    body.page-top .products__list .item:nth-child(even) {
        float: none
    }

    body.page-top .products__list .item:nth-child(2) {
        margin-top: 3rem
    }

    body.page-top .products__list .item a {
        zoom: 1;
        padding-left: 6.5rem
    }

    body.page-top .products__list .item a:after {
        content: '';
        display: block;
        clear: both;
        height: 0
    }

    body.page-top .products__list .item__img {
        float: left;
        width: 100%;
        margin-bottom: 0;
        margin-left: -6.5rem
    }

    body.page-top .products__list .item__color {
        bottom: 0.5rem;
        left: 0.5rem
    }

    body.page-top .products__list .item__color li {
        width: 0.8rem;
        height: 0.8rem;
        border-radius: 0.4rem
    }

    body.page-top .products__list .item__color li + li {
        margin-left: 0.4rem
    }

    body.page-top .products__list .item__code {
        right: 0.5rem;
        bottom: 0.5rem;
        font-size: 0.9rem
    }

    body.page-top .products__list .item__txt {


        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl
    }


    body.page-top .products__list .item__name {
        margin-left: 0.5rem;
        font-size: 1.2rem
    }

    body.page-top .products__list .item__price {
        margin-top: 0;
        font-size: 0.9rem
    }
}

body.page-top .contact {
    margin-top: -0.1rem
}

body.page-top .contact:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    width: 65%;
    height: 100%;
    background: #f5f5f5;
}

body.page-top .contact__list {
    zoom: 1;
    margin-right: 9.991rem
}

body.page-top .contact__list:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-top .contact__list .item {
    float: left;
    width: 100%;
    margin-top: 7rem
}

body.page-top .contact__list .item:nth-child(3n+1) {
    clear: left
}

body.page-top .contact__list .item:nth-child(-n+3) {
    margin-top: 0
}

body.page-top .contact__list .item__img {
    margin-bottom: 3.5rem
}

body.page-top .contact__list .item__img a {
    display: block;

}

body.page-top .contact__list .item__img img {

    width: 600px
}

body.page-top .contact__list .item__name {
    font-family: 'webfont', sans-serif;
    font-size: 1.4rem;
    line-height: 1.2
}

body.page-top .contact__list .item__addr {
    margin-top: 0.5rem;
    font-size: 1.2rem;
    line-height: 1.67
}

body.page-top .contact__list .item__addr a {
    color: #000000
}

body.page-top .contact__list .item__addr a .txt {
    position: relative;
    z-index: 2
}

body.page-top .contact__list .item__url {
    margin-top: 1.5rem;
    color: #00a2e9;
    font-family: 'webfont', sans-serif;
    font-size: 1.2rem;
    line-height: 1.2
}

body.page-top .contact__list .item__url a .txt {
    position: relative;
    z-index: 2
}

@media only screen and (max-width: 768px) {
    body.page-top .contact {
        margin-top: 0
    }

    body.page-top .contact:before {
        display: none
    }

    body.page-top .contact .section__head {
        text-align: center
    }

    body.page-top .contact__list {
        margin: 0 -1.5rem
    }

    body.page-top .contact__list .item {
        width: 50%;
        margin-top: 2.5rem
    }

    body.page-top .contact__list .item:nth-child(3n+1) {
        clear: none
    }

    body.page-top .contact__list .item:nth-child(-n+3) {
        margin-top: 2.5rem
    }

    body.page-top .contact__list .item:nth-child(odd) {
        clear: left
    }

    body.page-top .contact__list .item:nth-child(-n+2) {
        margin-top: 0
    }

    body.page-top .contact__list .item__img {
        margin-bottom: 1rem
    }

    body.page-top .contact__list .item__txt {
        padding: 0 1.5rem
    }

    body.page-top .contact__list .item__name {
        font-size: 1.1rem
    }

    body.page-top .contact__list .item__addr {
        margin-top: 0.5rem;
        font-size: 0.9rem;
        line-height: 1.45
    }

    body.page-top .contact__list .item__url {
        margin-top: 1rem;
        font-size: 0.9rem
    }
}

body.page-top .scroll {
    -webkit-transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    -webkit-transition: -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s, -webkit-transform .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s
}

html.is-footer-show body.page-top .scroll {
    bottom: 24rem
}

html.is-loading body.page-top .header {
    -webkit-transform: translateX(-7rem);
    transform: translateX(-7rem)
}

html.is-loading body.page-top .scroll {
    -webkit-transform: translateX(10.5rem);
    transform: translateX(10.5rem)
}

html.is-loading body.page-top .ancNav {
    -webkit-transform: translate(7rem, 50%);
    transform: translate(7rem, 50%)
}

html.is-loading body.page-top .mainVisual:after {
    -webkit-transition: none !important;
    transition: none !important;
    opacity: 1
}

@media only screen and (max-width: 768px) {
    html.is-loading body.page-top .header {
        -webkit-transform: translateX(0);
        transform: translateX(0)
    }
}

body.page-products .content {
    padding-bottom: 50rem
}

@media only screen and (max-width: 768px) {
    body.page-products .content {
        padding-bottom: 0
    }
}

body.page-products .productMain {
    overflow: hidden;
    position: relative;
    height: 100vh
}

body.page-products .productMain__outer {
    display: table;
    height: 100%;
    margin-left: 6.5rem
}

body.page-products .productMain__inner {
    display: table-cell;
    padding-top: 2rem;
    vertical-align: middle;
}

body.page-products .productMain__code {
    position: relative;
    z-index: 1;
    margin-bottom: 1rem;
    color: rgba(0, 0, 0, 0.3);
    font-family: 'webfont', sans-serif;
    font-size: 1.4rem;
    line-height: 1
}

body.page-products .productMain__ttl {
    position: relative;
    width: 100%;
    max-width: 600px;
    z-index: 1;
    margin-bottom: 1rem;
    font-family: webfont, sans-serif;
    font-size: 2.6rem;
    line-height: 1.2;
    text-shadow: 0 0 2px #fff;
}

body.page-products .productMain__spec {
    position: relative;
    z-index: 1;
    font-family: 'webfont', sans-serif;
    font-size: 1.1rem;
    line-height: 1.64
}

body.page-products .productMain__spec dt {
    margin-top: 2rem;
    color: rgba(0, 0, 0, 0.3)
}

body.page-products .productMain__spec dt:first-child {
    margin-top: 0
}

body.page-products .productMain__spec .spec__color {
    zoom: 1;
    margin-top: 1rem
}

body.page-products .productMain__spec .spec__color:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-products .productMain__spec .spec__color li {
    float: left
}

body.page-products .productMain__spec .spec__color li + li {
    margin-left: 1rem
}

body.page-products .productMain__spec .spec__color li a {
    display: block;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 1.1rem
}

body.page-products .productMain__spec .spec__color li a .txt {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 1.1rem
}

body.page-products .productMain__spec .spec__color li.green a .txt {
    background: #b2db14
}

body.page-products .productMain__spec .spec__color li.black a .txt {
    background: #000000
}

body.page-products .productMain__spec .spec__color li.navy a .txt {
    background: #0e2554
}

body.page-products .productMain__spec .spec__color li.gray a .txt {
    background: #999999
}

body.page-products .productMain__spec .spec__color li.white-2019ss a .txt {
    background: #ede5cf
}

body.page-products .productMain__spec .spec__color li.red-2019ss a .txt {
    background: #d72432
}

body.page-products .productMain__spec .spec__color li.navy-2019ss a .txt {
    background: #2d2d38
}

body.page-products .productMain__spec .spec__color li.black-2019ss a .txt {
    background: #000000
}

body.page-products .productMain__spec .spec__color li.blue-2019fw a .txt {
    background: #7ad3d7
}

body.page-products .productMain__spec .spec__color li.white-2019fw a .txt {
    background: #f5f5f5
}

body.page-products .productMain__spec .spec__color li.black-2019fw a .txt {
    background: #000000
}

body.page-products .productMain__spec .spec__color li.navy-2019fw a .txt {
    background: #333145
}

body.page-products .productMain__spec .spec__color li.red-2020ss a .txt {
    background: #00a2e9
}

body.page-products .productMain__spec .spec__color li.white-2020ss a .txt {
    background: #f5f5f5
}

body.page-products .productMain__spec .spec__color li.black-2020ss a .txt {
    background: #000000
}

body.page-products .productMain__spec .spec__color li.navy-2020ss a .txt {
    background: #0e2554
}

body.page-products .productMain__imgWrap {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 0
}

body.page-products .productMain__imgContainer {
    overflow: hidden;
    position: relative;
    width: 67.5vh;
    height: 100%;
    margin: 0 auto;
    cursor: pointer
}

body.page-products .productMain__imgContainer:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    width: 100%;
    height: 100%
}

body.page-products .productMain__imgContainer.is-zoom {
    width: 100%
}

body.page-products .productMain__imgContainer.is-zoom:before {
    opacity: 0
}

body.page-products .productMain__imgContainer.is-zoom .productMain__img {
    height: 0
}

body.page-products .productMain__imgContainer.is-zoom .productMain__img .img {
    visibility: visible;
    opacity: 1
}

body.page-products .productMain__imgContainer.is-zoom .productMain__img .thumb {
    visibility: hidden;
    opacity: 0
}

body.page-products .productMain__img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1
}

body.page-products .productMain__img .img, body.page-products .productMain__img .thumb {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover
}

body.page-products .productMain__img .img {
    visibility: hidden;
    opacity: 0
}

body.page-products .productMain__thumb {
    zoom: 1;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    right: 6.5rem;
    z-index: 2
}

body.page-products .productMain__thumb:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-products .productMain__thumb li {
    float: left;
    width: 5rem;
    margin: 1rem 0 0 1rem;
    background: #ffffff;
    text-align: center;
    cursor: pointer
}

body.page-products .productMain__thumb li a {
    display: block
}

body.page-products .productMain__thumb li:nth-child(4n+1) {
    clear: left;
    margin-left: 0
}

body.page-products .productMain__thumb li:nth-child(-n+4) {
    margin-top: 0
}

body.page-products .productMain__thumb li img {
    width: auto !important;
    height: 5rem !important
}

body.page-products .productMain__back {
    position: fixed;
    top: 2rem;
    right: 6rem;
    z-index: 6;
    padding: 1.7rem 2.5rem 1.7rem 0;
    color: #000000;
    font-family: "Helvetica Neue LT W01_65 Md", "Helvetica Bold", "Arial Bold", sans-serif;
    font-size: 1.2rem;
    line-height: 1
}

body.page-products .productMain__back:after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
    width: 1.6rem;
    height: 100%;
    background: url(../images/arw_l.svg) no-repeat center center;
    background-size: 100% auto
}

body.page-products .productMain__back .txt {
    position: relative;
    z-index: 2
}

html.notouch body.page-products .productMain__back:hover {
    text-decoration: none
}

@media only screen and (min-width: 1400px) and (max-width: 1499px) {
    body.page-products .productMain__outer {
        margin-left: calc((100vw - 7rem - 120rem) / 2)
    }

    body.page-products .productMain__thumb {
        right: calc((100vw - 7rem - 120rem) / 2)
    }
}

@media only screen and (min-width: 1750px) {
    body.page-products .productMain__outer {
        margin-left: calc((100vw - 7rem - 120rem) / 2)
    }

    body.page-products .productMain__thumb {
        right: calc((100vw - 7rem - 120rem) / 2)
    }
}

@media only screen and (max-width: 768px) {
    body.page-products .productMain {
        height: auto;
        padding-top: 12rem
    }

    body.page-products .productMain__outer {
        display: block;
        height: auto;
        margin-left: 0
    }

    body.page-products .productMain__inner {
        display: block;
        padding-top: 0
    }

    body.page-products .productMain__code {
        margin: 0 2.5rem 1rem;
        font-size: 1.1rem
    }

    body.page-products .productMain__ttl {
        margin: 0 2.5rem 4rem;
        font-size: 2rem
    }

    body.page-products .productMain__spec {
        margin-top: 5rem;
        padding: 5rem 2.5rem;
        background: #f0f0f0;
        font-size: 1.2rem;
        line-height: 1.72
    }

    body.page-products .productMain__spec .spec__color {
        margin-top: 1rem
    }

    body.page-products .productMain__spec .spec__color li a {
        width: 2.6rem;
        height: 2.6rem;
        border-radius: 1.3rem
    }

    body.page-products .productMain__spec .spec__color li a .txt {
        width: 2.6rem;
        height: 2.6rem;
        border-radius: 1.3rem
    }

    body.page-products .productMain__imgWrap {
        position: relative
    }

    body.page-products .productMain__imgContainer {
        width: auto;
        height: 133.34vw;
        cursor: default
    }

    body.page-products .productMain__imgContainer:before {
        display: none
    }

    body.page-products .productMain__thumb {
        -webkit-transform: translateY(0);
        transform: translateY(0);
        position: relative;
        right: auto;
        width: 19.8rem;
        margin: 2rem auto 0
    }

    body.page-products .productMain__thumb li {
        width: 3.6rem;
        margin: 1.8rem 0 0 1.8rem
    }

    body.page-products .productMain__thumb li a {
        display: block
    }

    body.page-products .productMain__thumb li:nth-child(4n+1) {
        clear: left;
        margin-left: 0
    }

    body.page-products .productMain__thumb li:nth-child(-n+4) {
        margin-top: 0
    }

    body.page-products .productMain__thumb li img {
        width: auto !important;
        height: 3.6rem !important
    }

    body.page-products .productMain__back {
        display: none
    }
}

body.page-products .productDesc {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    max-width: 133rem;
    margin-right: auto;
    margin-left: auto;
    padding-right: 6.5rem;
    padding-left: 6.5rem;
    zoom: 1;
    margin-top: 11rem
}

@media only screen and (max-width: 768px) {
    body.page-products .productDesc {
        padding-right: 1.5rem;
        padding-left: 1.5rem
    }
}

body.page-products .productDesc:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-products .productDesc__block {
    zoom: 1;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

body.page-products .productDesc__block:after {
    content: '';
    display: block;
    clear: both;
    height: 0
}

body.page-products .productDesc__block dt {
    float: left;
    color: rgba(0, 0, 0, 0.3);
    font-family: 'webfont', sans-serif;
    font-size: 1.2rem;
    line-height: 1;
    white-space: nowrap;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl
}

body.page-products .productDesc__block dd {
    margin-left: 4.5rem
}

body.page-products .productDesc .main {
    float: left;
    width: 100%;
    margin-right: -43.5rem;
    padding-right: 43.5rem
}

body.page-products .productDesc .sub {
    float: right;
    width: 37rem
}

body.page-products .productDesc .sub dd {
    font-size: 1rem;
    line-height: 1.7
}

@media only screen and (max-width: 768px) {
    body.page-products .productDesc {
        margin: 5rem 1rem 0
    }

    body.page-products .productDesc__block dt {
        display: none
    }

    body.page-products .productDesc__block dd {
        margin-left: 0
    }

    body.page-products .productDesc .main {
        float: none;
        width: auto;
        margin-right: 0;
        padding-right: 0
    }

    body.page-products .productDesc .sub {
        float: none;
        width: auto;
        margin-top: 4rem
    }

    body.page-products .productDesc .sub dd {
        font-size: 0.9rem;
        line-height: 1.84
    }
}

body.page-products .productBack {
    display: block;
    z-index: 2;
    padding: 16.6rem 0 16.5rem;
    background: #f0f0f0;
    color: #000000;

    font-size: 2.2rem;
    line-height: 1;
    text-align: center
}

body.page-products .productBack:before {
    -webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1) 0s;
    content: '';
    display: block;
    position: relative;
    z-index: 2;
    width: 100%;
    height: 2.2rem;
    margin-bottom: 1.5rem;
    background: url(../images/arw_l.svg) no-repeat center center;
    background-size: auto 100%
}

body.page-products .productBack .txt {
    position: relative;
    z-index: 2
}

html.notouch body.page-products .productBack:hover {
    background: #00a2e9;
    color: #ffffff;
    text-decoration: none
}

html.notouch body.page-products .productBack:hover:before {
    background-image: url(../images/arw_l_white.svg)
}

@media only screen and (max-width: 768px) {
    body.page-products .productBack {
        margin-top: 5rem;
        position: static;
        padding: 7.6rem 0 7.5rem;
        font-size: 1.7rem
    }

    body.page-products .productBack:before {
        height: 1.7rem;
        margin-bottom: 1rem
    }
}

html.is-footer-show body.page-products .scroll {
    bottom: 39rem;
}

.pro-show {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 5%;
    overflow: hidden;
}

.pro-show .pro-title {
    font-size: 2.4rem;
    font-weight: bold;
    font-family: webfont, sans-serif;
    margin-bottom: 40px;
}

.do-content, .widget-detail-overview {
    display: none;
}

.pro-left {
    width: 50%;
    float: left;
    padding-right: 40px;
}

.pro-right {
    width: 50%;
    float: right;
}


.gallery-top .swiper-slide {
    border: 1px solid #ddd;
    box-sizing: border-box;
    cursor: pointer;
}

.gallery-thumbs {
    margin-top: 20px;
}

.gallery-thumbs .swiper-slide {
    opacity: 0.5;
    border: 1px solid #ddd;
    cursor: pointer;
}

.gallery-thumbs .swiper-slide.swiper-slide-thumb-active {
    opacity: 1;
    border-color: #00a2e9;
}


.flex-align-center {
    align-items: center;
}

.list-2 li {
    width: 48%;
}

.list-3 li {
    width: 31%;
}

.list-4 li {
    width: 23%;
}

.list-5 li {
    width: 18%;
}

.list-6 li {
    width: 15%;
}
#top-banner {
    position: relative;
    background: #fff url('/theme/default/images/about-bg.jpg') 0 0 no-repeat fixed;
    -webkit-background-size: cover;
    background-size: cover;
    color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
}

#top-banner:after {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, .5);
}

#top-banner .width, #about1 .width, #about2 .width, #about3 .width, #about4 .width {
    max-width: 1500px;
    width: 79%;

}
#top-banner .item1{
    float: left;
    width: 30%;
}
#top-banner .item2{
    float: right;
    width: 60%;
}
#top-banner h1 {
    font-size: 2.6rem;
    font-weight: 500;
    padding-bottom: 30px;
}
#top-banner p{
    font-size: 20px;
}
#top-banner h1:after {
    content: '';
    display: block;
    width: 40px;
    height: 3px;
    margin-top: 20px;
    background-color: #fff;

}

#top-banner li {
    flex: 1;
    text-align: center;
}

#top-banner li + li {
    border-left: 1px solid rgba(255, 255, 255, .3);
}

#top-banner li h2 {
    width: 100%;
    text-align: center;
    font-size: 100px;
    line-height: normal;
    font-family: trmup;
}

#top-banner li h2:after {
    content: '人';
    font-size: 20px;
    padding-left: 10px;
    font-weight: normal;
    font-family: webfont;
}
#top-banner li:nth-child(2) h2:after{
    content: '台';
}
#top-banner li:last-child h2:after{
    content: '亿元';
}
#top-banner li p.t1 {
    font-size: 16px;
}

#top-banner li p.t2 {
    font-size: 13px;
    color: #999;
}

#top-banner .content p {
    line-height: 2;
    font-size: 16px;
    text-align: justify;
    margin-bottom: 20px;
}

#about1 .video-wrapper {
    padding-left: 50px;
}

#about1 .video-wrapper .video {
    background-color: #000;
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;
}

#about1 .video-wrapper .video video {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    z-index: 1;
}
.text-hide{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;}
@media only screen and (max-width: 992px) {
    .flex-center li .item__txt p{
        font-size: 14px;
    }
    .flex-center li .item__txt span{
        font-size: 20px;
    }

    .list-4 li{
        width: 48%;
        margin-bottom: 20px;
    }
    .pro-show{
        padding: 5% 0;
    }
    section.common,#contact-1,#contact-2{
        padding: 7.3rem 3% 6%;
    }
    .pro-left,.pro-right{
        width:100%;
        padding-right: 0;
        display: block;
    }
    .header__nav .h-nav__list > li.has-children .label,.header__nav .h-nav__list > li.has-children .children{
        display: block;
    }
    #top-banner h1{
        line-height: 1;
        padding-bottom: 10px;
    }
    #top-banner .item1,#top-banner .item2{
        width: 100%;
        float: none;
        padding: 0;
    }
    #top-banner .item1{
        margin-bottom: 20px;
    }
    #top-banner .width, #about1 .width, #about2 .width, #about3 .width, #about4 .width{
        width: 100%;
        padding: 0 3%;
    }
    #top-banner li h2{
        font-size: 5rem;
    }
    #top-banner li h2:after {
        font-size: 16px;
        padding-left: 10px;
        font-family: "microsoft yahei";
    }
     #about1 .list-2 li,#about4 .list-2 li {
        width: 100%;
        margin-bottom: 10px;
    }
    #about1 .video-wrapper{
        padding-left: 0;
    }
    #about1 li .content-txt p{
        line-height: 1.6;
        margin-bottom: 15px;
    }
    .form-group,input[type="text"], textarea{
        margin-bottom: 5px;
    }
    .flex-center{
        display: block;
    }
    .flex-center li{
        width: 100%;
    }
    .flex-center li .item__txt{
        padding-left: 0;
    }
    body.page-top .feature.img-left .feature__txt{
        right: auto;
    }
    body.page-top .feature__txt{
        width: 100%;
    }

}