@charset "UTF-8";
/* CSS Document */
/* 2020.06.29 */

*{margin: 0;padding: 0; outline: none; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; -webkit-appearance: none; box-sizing: border-box; /*font-feature-settings : "palt";*/}
html {font-size: 62.5%; width: 100%; height: 100%;}
body {font-family: 'Noto Sans JP', sans-serif; line-height: 2; background:#FFF; color:#1c1c1e; text-align: center; scrolling: yes; position: relative; -webkit-text-size-adjust: 100%; overflow-x: hidden; font-weight: 200;}
body.fixed {position: fixed; width: 100%; height: 100%;}

a{color: #1c1c1e; text-decoration: none; overflow: hidden; outline: none; cursor: pointer;}
a[href^="tel"]{color: #1c1c1e!important; text-decoration: none!important;}
a:hover{}
button, input, select, textarea{border: none; border-radius: 0; -webkit-appearance: none;}
button{ cursor: pointer;}

p{font-size: 1.5rem;}
li{font-size: 1.5rem;}
img{border: none; vertical-align: top;}
table{border-collapse: collapse;}
ul{list-style-type: none;}

strong{font-weight: 900;}
*.en{font-family: futura-pt, sans-serif; font-weight: 600; font-style: normal;}
*.hidden{transition: all 0.8s cubic-bezier(0.645, 0.045, 0.355, 1.000);}

/* ::::::::::::::::::::::::::::::::: COMMON ::::::::::::::::::::::::::::::::: */

div.bg{position: fixed; width: 100%; height: 100%; left: 0; top: 0; z-index: 1;}
div.bg ul{}
div.bg ul li{position: absolute; width: 100%; height: 100%; left: 0; top: 0; opacity: 0; transition: opacity 0.9s ease;}
div.bg ul li.on{opacity: 1;}
div.bg ul li.sld1{background: url(/img/img1_pc.jpg) no-repeat center bottom; background-size: cover;}
div.bg ul li.sld2{background: url(/img/img2_pc.jpg) no-repeat center bottom; background-size: cover;}
div.bg ul li.sld3{background: url(/img/img3_pc.jpg) no-repeat center bottom; background-size: cover;}
div.bg ul li.sld4{background: url(/img/img4_pc.jpg) no-repeat center bottom; background-size: cover;}

div.wrap{z-index: 2; position: relative; width: 100%; overflow: hidden;}

div.section{width: 100%;}
div.section div.inner{width: 80%; max-width: 1200px; margin: 0 auto; padding: 90px 0 110px;}
div.section h2{font-size: 3.2rem; line-height: 1.6; padding: 0 0 5px;}
div.section p.sub{font-style: italic; font-size: 2.1rem;}

div.section.seg1{background: #d4d9dc ; position: relative; height: 100vh; overflow: hidden;}
div.section.seg1::after{position: absolute; width: 100%; height: 40px; background: #FFF; left: 0; bottom: 0; content: "";}
div.section.seg1 video{position: absolute; left: 0; top: 0; opacity: 0; transition: opacity 2.5s ease;}
div.section.seg1 video.on{opacity: 1;}
div.section.seg1 h1{padding: 40px 0 0 50px; text-align: left; position: relative; z-index: 2;}
div.section.seg1 p.lead{width: 80%; height: 40%; position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto; text-indent: -9999px; overflow: hidden; background: url(/img/copy_pc.svg) no-repeat center center; background-size: contain; /*display: none;*/}
div.section.seg1 p.scroll{position: absolute; left: 0; right: 0; bottom: 20px; margin: 0 auto; width: 40px; height: 85px; z-index: 100;}
div.section.seg1 p.scroll a{color: #FFF; display: block; width: 100%; height: 85px; position: relative; font-size: 1.4rem; line-height: 1; font-style: italic;}
div.section.seg1 p.scroll a::before{content: ""; width: 3px; height: 60px; background: url(/img/bar_pc.svg) no-repeat center center; background-size: contain; position: absolute; left: 0; right: 0; bottom: 0; margin: 0 auto; opacity: 0.3;}
div.section.seg1 p.scroll a span{width: 3px; height: 60px; position: absolute; left: 0; right: 0; bottom: 0; margin: 0 auto; animation: scroll1 2s ease infinite; overflow: hidden;}
div.section.seg1 p.scroll a span::after{content: ""; width: 3px; height: 60px; background: url(/img/bar_pc.svg) no-repeat center center; background-size: contain; position: absolute; left: 0; top: 0; animation: scroll2 2s ease infinite;}
div.section.seg1 span.loadMark{width: 40px; height: 40px; border: 3px solid rgba(0,0,0,0); border-top-color: rgba(0,0,0,0.3); border-radius: 50%; animation: spinLoad 0.5s linear 0s infinite; position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto; content: "";}

@keyframes spinLoad {
    0% {transform: rotate(0deg);}
    100% {transform: rotate(360deg);}
}

@keyframes scroll1 {
    0% {height: 0px; bottom: 60px;}
    50% {height: 60px; bottom: 0;}
    100% {height: 0px; bottom: 0;}
}

@keyframes scroll2 {
    0% {top: 0;}
    50% {top: 0;}
    100% {top: -60px;}
}

div.section.seg2{background: #FFF; position: relative; z-index: 3;}
div.section.seg2 div.inner{padding-top: 70px; opacity: 0; transform: translateY(10px);}
div.section.seg2 div.inner.show{opacity: 1; transform: translateY(0);}
div.section.seg2 p{}
div.section.seg2 p.ja{font-size: 2.3rem; padding: 0 0 50px;}
div.section.seg2 p.en{font-size: 2.0rem;}

div.section.seg3{background: #1c1c1e;}
div.section.seg3 div.inner{display: flex; justify-content: space-between; text-align: left; align-items: center; opacity: 0; transform: translateY(10px);}
div.section.seg3 div.inner.show{opacity: 1; transform: translateY(0);}
div.section.seg3 div.left{width: 440px;}
div.section.seg3 div.right{width: calc(100% - 440px);}
div.section.seg3 h2,
div.section.seg3 p{color: #FFF;}
div.section.seg3 h2{font-size: 6.0rem; font-style: italic;}
div.section.seg3 h2 span{padding: 0 100px 10px 0; background: url(/img/equal_pc.svg) no-repeat right center; background-size: 32px 18px;}
div.section.seg3 p.ja{font-size: 1.7rem; line-height: 2.2; padding: 0 0 50px;}
div.section.seg3 p.en{font-size: 1.6rem;}

div.section.seg4{position: relative; min-height: 400px; max-height: 900px; height: 80vh;}

div.section.seg5{background: #eceeef;}
div.section.seg5 div.inner{display: flex; justify-content: space-between; text-align: left; opacity: 0; transform: translateY(10px);}
div.section.seg5 div.inner.show{opacity: 1; transform: translateY(0);}
div.section.seg5 div.left{width: 440px;}
div.section.seg5 div.right{width: calc(100% - 440px);}
div.section.seg5 p.lead{padding: 0 0 20px; font-size: 1.7rem;}
div.section.seg5 p.caption{padding: 0 0 45px;}
div.section.seg5 p.en{padding: 0 0 20px; font-size: 1.6rem;}
div.section.seg5 dl{font-size: 1.6rem; padding: 0 0 20px; display: flex; justify-content: flex-start; flex-wrap: wrap; align-items: baseline;}
div.section.seg5 dl dt{width: 45px;}
div.section.seg5 dl dd{width: calc(100% - 50px); font-style: italic;}
div.section.seg5 dl.large dt{width: 55px; font-size: 2.0rem;}
div.section.seg5 dl.large dd{width: calc(100% - 60px); font-size: 3.8rem; line-height: 1.3;}

div.section.seg6{background: #FFF;}
div.section.seg6 div.inner{opacity: 0; transform: translateY(10px);}
div.section.seg6 div.inner.show{opacity: 1; transform: translateY(0);}
div.section.seg6 p.sub{padding: 0 0 60px;}
div.section.seg6 ul{font-size: 2.7rem; line-height: 1.9;}

div.section.seg7{background: #1c1c1e;}
div.section.seg7 div.inner{opacity: 0; transform: translateY(10px);}
div.section.seg7 div.inner.show{opacity: 1; transform: translateY(0);}
div.section.seg7 p{color: #FFF;}
div.section.seg7 p.ja{font-size: 2.3rem; padding: 0 0 50px;}
div.section.seg7 p.en{font-size: 2.0rem;}

div.section.segNews{background: #eceeef;}
div.section.segNews#media{background: #eceeef;}
div.section.segNews div.inner{display: flex; justify-content: space-between; text-align: left; opacity: 0; transform: translateY(10px);}
div.section.segNews div.inner.show{opacity: 1; transform: translateY(0);}
div.section.segNews div.left{width: 440px;}
div.section.segNews div.right{width: calc(100% - 440px);}
div.section.segNews ul.newsArchiveList{}
div.section.segNews ul.newsArchiveList.old{display: none;}
div.section.segNews ul.newsArchiveList li{padding: 0 0  30px;}
div.section.segNews ul.newsArchiveList li h3{font-size: 1.6rem; padding: 0 0 5px;}
div.section.segNews ul.newsArchiveList li p.date{font-weight: 400;}
div.section.segNews ul.newsArchiveList li a{font-size: 1.4rem; text-decoration: underline;}
div.section.segNews p.btnArchive{padding: 15px 0 0;}
div.section.segNews p.btnArchive span{display: inline-block; line-height: 45px; background: #FFF; padding: 0 35px 0 55px; border-radius: 2px; cursor: pointer; position: relative; font-weight: bold;}
div.section.segNews p.btnArchive span::after{width: 5px; height: 5px; content: ""; position: absolute; transform-origin: center center; border-left: 2px solid #1c1c1e; border-top: 2px solid #1c1c1e; left: 27px; top: 17px; transform: rotate(-135deg);}
div.section.segNews p.btnArchive span.close{display: none;}
div.section.segNews p.btnArchive span.close::after{transform: rotate(45deg); top: 20px;}
div.section.segNews p.btnArchive.on span.open{display: none;}
div.section.segNews p.btnArchive.on span.close{display: inline-block;}

div.section.newsSingleTop{background: #eceeef;}
div.section.newsSingleTop p.siteTitle{padding: 40px 0 0 60px; text-align: left; position: relative; z-index: 2;}
div.section.newsSingleMain{background: #eceeef;}
div.section.newsSingleMain div.inner{text-align: left;}
div.section.newsSingleMain div.inner p.date{padding: 0 0 60px;}/* default {font-size: 2.0rem; line-height: 1.6; padding: 0 0 40px;} */
div.section.newsSingleMain div.inner h1{font-size: 3.6rem; line-height: 1.6; padding: 0 0 60px;}
div.section.newsSingleMain div.inner h2{font-size: 2.8rem; line-height: 1.6; padding: 0 0 20px;}/* default {font-size: 2.8rem; line-height: 1.6; padding: 0 0 35px;} */
div.section.newsSingleMain div.inner h3{font-size: 2.0rem; line-height: 1.6; padding: 0 0 20px;}/* default {font-size: 2.0rem; line-height: 1.6; padding: 0 0 35px;} */
div.section.newsSingleMain div.inner p.btnBack{padding: 0 0 30px;}/* default {font-size: 1.9rem; padding: 0 0 30px;} */
div.section.newsSingleMain div.inner p.btnBack a{line-height: 45px; background: #FFF; padding: 0 35px; border-radius: 2px; cursor: pointer; position: relative; display: inline-block; font-weight: bold;}/* default {line-height: 60px; background: #FFF; padding: 0 60px; border-radius: 2px; cursor: pointer; position: relative; display: inline-block;} */
div.section.newsSingleMain div.content{padding: 0 0 50px;}
div.section.newsSingleMain div.content p{padding: 0 0 50px;}/* default {padding: 0 0 40px;} */
div.section.newsSingleMain div.content p.small-space{padding: 0 0 30px;}/* default {} */
div.section.newsSingleMain div.content hr{padding: 0 0 40px; border: none; border-top: 1px solid #d4d9dc ;}
div.section.newsSingleMain div.content a{text-decoration: underline;}
div.section.newsSingleMain div.content a:hover{opacity: 0.7;}
div.section.newsSingleMain div.content ul{padding: 0 0 20px 20px; font-size: 1.5rem; list-style-type: circle;}/* default {padding: 0 0 40px 20px; font-size: 1.5rem; list-style-type: circle;} */
div.section.newsSingleMain div.content ul li{position: relative;}
div.section.newsSingleMain div.content table{margin: 0 0 40px; width: 100%;}
div.section.newsSingleMain div.content table th,
div.section.newsSingleMain div.content table td{text-align: left; vertical-align: top; border-bottom: 1px solid #d4d9dc ; padding: 15px 0;}
div.section.newsSingleMain div.content table th{padding-right: 15px;}
div.section.newsSingleMain div.content img{max-width: 100%; height: auto;}
div.section.newsSingleMain div.content div.youtube {position: relative; width: 100%; padding-top: 56.25%; margin: 0 0 40px;}
div.section.newsSingleMain div.content div.youtube iframe {position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important;}

/* FOOTER */
footer.mainFooter{background: #d4d9dc ; padding: 70px 7% 50px; text-align: left; z-index: 2; position: relative;}
footer.mainFooter div.inner{position: relative;}
footer.mainFooter h2{font-size: 2.2rem; padding: 0 0 30px;}
footer.mainFooter p{padding: 0 0 30px;}
footer.mainFooter p.en{font-weight: 500;}
footer.mainFooter p.copyright{color: #FFF; position: absolute; right: 0; bottom: 0;}
footer.mainFooter ul.snsList{position: absolute; right: 0; top: 10px; display: flex; justify-content: space-between; width: 76px;}


/* ::::::::::::::::::::::::::::::::: PC ::::::::::::::::::::::::::::::::: */
@media screen and (min-width: 1000px){
    .sp{display:none!important;}

    .hoverAlpha{transition: opacity 0.2s ease;}
    .hoverAlpha:hover{opacity: 0.8;}

}

/* ::::::::::::::::::::::::::::::::: SP ::::::::::::::::::::::::::::::::: */
@media screen and (max-width: 999px){
    .pc{display:none!important;}
    
    /* ::::::::::::::::::::::::::::::::: COMMON ::::::::::::::::::::::::::::::::: */

    div.bg{}
    div.bg ul{}
    div.bg ul li{}
    div.bg ul li.sld1{background-image: url(/img/img1_sp.jpg);}
    div.bg ul li.sld2{background-image: url(/img/img2_sp.jpg);}
    div.bg ul li.sld3{background-image: url(/img/img3_sp.jpg);}
    div.bg ul li.sld4{background-image: url(/img/img4_sp.jpg);}

    div.wrap{}
    
    div.section{}
    div.section div.inner{width: 85%; padding: 60px 0 60px;}
    div.section h2{font-size: 2.4rem; padding: 0;}
    div.section p.sub{font-size: 1.6rem; padding: 0 0 35px!important;}

    div.section.seg1{}
    div.section.seg1::after{height: 30px;}
    div.section.seg1 h1{padding: 20px 0 0 20px;}
    div.section.seg1 h1 img{width: 120px; height: 42px;}
    div.section.seg1 p.lead{width: 84%; height: 50%; position: absolute; background: url(/img/copy_sp.svg) no-repeat center center; background-size: contain;}
    div.section.seg1 p.scroll{bottom: 15px; width: 40px; height: 65px;}
    div.section.seg1 p.scroll a{height: 65px; font-size: 1.3rem;}
    /*div.section.seg1 p.scroll a::after{height: 45px; background: url(/img/bar_sp.svg) no-repeat center center; background-size: contain;}*/
    
    div.section.seg1 p.scroll a::before{height: 45px; background: url(/img/bar_sp.svg) no-repeat center center; background-size: contain; position: absolute;}
    div.section.seg1 p.scroll a span{height: 45px;}
    div.section.seg1 p.scroll a span::after{height: 45px; background: url(/img/bar_sp.svg) no-repeat center center; background-size: contain; position: absolute;}

    @keyframes scroll1 {
        0% {height: 0px; bottom: 45px;}
        50% {height: 45px; bottom: 0;}
        100% {height: 0px; bottom: 0;}
    }

    @keyframes scroll2 {
        0% {top: 0;}
        50% {top: 0;}
        100% {top: -45px;}
    }

    div.section.seg2{}
    div.section.seg2 div.inner{padding-top: 30px;}
    div.section.seg2 p{}
    div.section.seg2 p.ja{font-size: 1.6rem; padding: 0 0 25px;}
    div.section.seg2 p.en{font-size: 1.5rem;}

    div.section.seg3{}
    div.section.seg3 div.inner{display: block;}
    div.section.seg3 div.left{width: 100%;}
    div.section.seg3 div.right{width: 100%;}
    div.section.seg3 h2,
    div.section.seg3 p{}
    div.section.seg3 h2{font-size: 4.0rem; text-align: center; padding: 0 0 60px;}
    div.section.seg3 h2 span{padding: 0 0 40px 0; background: url(/img/equal_sp.svg) no-repeat center bottom; background-size: 14px 20px;}
    div.section.seg3 p.ja{font-size: 1.6rem; line-height: 2; padding: 0 0 25px;}
    div.section.seg3 p.en{font-size: 1.5rem;}

    div.section.seg4{min-height: 300px; max-height: 900px; height: 80vh;}

    div.section.seg5{}
    div.section.seg5 div.inner{display: block;}
    div.section.seg5 div.left{width: 100%; text-align: center;}
    div.section.seg5 div.right{width: 100%; margin: 0 0 -20px;}
    div.section.seg5 p.lead{padding: 0 0 20px; font-size: 1.5rem;}
    div.section.seg5 p.caption{padding: 0 0 40px; font-size: 1.4rem;}
    div.section.seg5 p.en{}
    div.section.seg5 dl{}
    div.section.seg5 dl dt{}
    div.section.seg5 dl dd{}
    div.section.seg5 dl.large{padding: 0 0 25px;}
    div.section.seg5 dl.large dt{width: 45px; font-size: 1.8rem;}
    div.section.seg5 dl.large dd{width: calc(100% - 50px); font-size: 3.4rem; line-height: 1.3;}

    div.section.seg6{}
    div.section.seg6 p.sub{}
    div.section.seg6 ul{font-size: 2.4rem; padding: 0 0 10px;}

    div.section.seg7{}
    div.section.seg7 p{}
    div.section.seg7 p.ja{font-size: 1.6rem; padding: 0 0 25px;}
    div.section.seg7 p.en{font-size: 1.5rem;}
    
    div.section.segNews{}
    div.section.segNews div.inner{display: block;}
    div.section.segNews div.left{width: 100%; text-align: center;}
    div.section.segNews div.right{width: 100%; margin: 0 0 15px;}
    div.section.segNews p.btnArchive{padding: 15px 0 0; text-align: center;}
    
    div.section.newsSingleTop{background: #eceeef;}
    div.section.newsSingleTop p.siteTitle{padding: 20px 0 0 20px;}
    div.section.newsSingleTop p.siteTitle img{width: 120px; height: 42px;}
    div.section.newsSingleMain{}
    div.section.newsSingleMain div.inner{}
    div.section.newsSingleMain div.inner p.date{padding: 0 0 35px;}
    div.section.newsSingleMain div.inner h1{font-size: 2.7rem; line-height: 1.7; padding: 0 0 50px;}
    div.section.newsSingleMain div.inner h2{font-size: 2.1rem; line-height: 1.7; padding: 0 0 15px;}/* default {font-size: 2.1rem; line-height: 1.7; padding: 0 0 30px;} */
    div.section.newsSingleMain div.inner h3{font-size: 1.8rem; line-height: 1.7; padding: 0 0 15px;}/* default {font-size: 1.8rem; line-height: 1.7; padding: 0 0 30px;} */
    div.section.newsSingleMain div.inner p.btnBack{padding: 0 0 20px;}
    div.section.newsSingleMain div.inner p.btnBack a{}
    div.section.newsSingleMain div.content{padding: 0 0 30px;}
    div.section.newsSingleMain div.content p{padding: 0 0 40px;}/* default {padding: 0 0 35px;} */
    div.section.newsSingleMain div.content p.small-space{padding: 0 0 25px;}/* default {} */
    div.section.newsSingleMain div.content hr{padding: 0 0 35px;}
    div.section.newsSingleMain div.content a{}
    div.section.newsSingleMain div.content a:hover{opacity: 1;}
    div.section.newsSingleMain div.content ul{padding: 0 0 25px 20px;}/* default {padding: 0 0 35px 20px;} */
    div.section.newsSingleMain div.content ul li{}
    div.section.newsSingleMain div.content table{margin: 0 0 35px;}
    div.section.newsSingleMain div.content table th,
    div.section.newsSingleMain div.content table td{padding: 12px 0;}
    div.section.newsSingleMain div.content table th{padding-right: 10px;}
    div.section.newsSingleMain div.content img{max-width: 100%; height: auto;}
    div.section.newsSingleMain div.content div.youtube {margin: 0 0 35px;}
    div.section.newsSingleMain div.content div.youtube iframe {}

    /* FOOTER */
    footer.mainFooter{padding: 60px 7.5% 20px;}
    footer.mainFooter div.inner{}
    footer.mainFooter h2{font-size: 1.9rem; padding: 0 0 30px;}
    footer.mainFooter p{padding: 0 0 25px; font-size: 1.4rem;}
    footer.mainFooter p.en{padding: 0 0 40px;}
    footer.mainFooter p.copyright{position: relative; right: inherit; bottom: inherit;}
    footer.mainFooter ul.snsList{position: relative; right: inherit; top: inherit; width: 64px; padding: 0 0 15px;}
    footer.mainFooter ul.snsList li img{width: 24px; height: 24px;}
}


/* ::::::::::::::::::::::::::::::::: DOWNLOAD COMPANY INFO ::::::::::::::::::::::::::::::::: */
    footer.mainFooter p.download a{color: #1c1c1e;}
    footer.mainFooter p.download a{font-size: 1.3rem; padding: 0 0 30px;}
    footer.mainFooter p.download a{line-height: 45px; padding: 0 55px 0 0px; border-radius: 2px; cursor: pointer; position: relative; display: inline-block; font-weight: bold;}
    footer.mainFooter span.download.icon {width: 14px; height: 4px; position: absolute; transform-origin: center center; color: #1c1c1e; border: solid 2px currentColor; border-top: none; margin-left: 5px; margin-top: 24px;}
    footer.mainFooter span.download.icon:before {width: 2px; height: 9px; content: ""; position: absolute; background-color: currentColor; left: 4px; top: -9px;}
    footer.mainFooter span.download.icon:after {width: 4px; height: 4px; content: ""; position: absolute; border-top: solid 2px currentColor; border-right: solid 2px currentColor; left: 2px; top: -5px; transform: rotate(135deg);}

