@charset 'UTF-8'; /* CSS Document */
/*------------------------

トップページ

------------------------*/
/* mv */
.mv {
    width: calc(100% - 30px);
    height: calc(100vh - 33px);
    min-height: 600px;
    max-height: 62vw;
    margin: 10px auto;
    margin-bottom: 20px;
    transition: all ease 1.5s;
    background-attachment: fixed;
    background-position: center center;
    background-size: cover;
    opacity: 0;
    position: relative;
}

.mv.opacity {
    transition: all ease 1.5s;
    opacity: 1;
}

.mv .slick-track, .mv .slick-slide {
    width: 100% !important;
}

/* slider */
.slider, .slick-list, .slick-track, .slick-slide > div, .slide {
    height: 100%;
}

.slide {
    background-attachment: fixed;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
}

.mv .slide {
    transition: all ease 3s;
    transform: scale(1.3);
}

.mv .slide.scale {
    transition: all ease 3s;
    transform: scale(1);
}

/* slider */
.slider, .slick-list, .slick-track, .slick-slide > div, .slide {
    height: 100%;
}

.slide {
    background-attachment: fixed;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
}

.mv .slide {
    transition: all ease 3s;
    transform: scale(1.3);
}

.mv .slide.scale {
    transition: all ease 3s;
    transform: scale(1);
}

/* mainCopy */
.mainCopy {
    width: 100%;
    margin: auto;
    transition: all ease .5s;
    position: absolute;
    z-index: 1;
    top: 50%;
    bottom: 50%;
    left: 92px;
}

.mainCopy.fadeOut {
    opacity: 0;
    bottom: 40px;
}

.mainCopy .title {
    height: 80px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 4rem;
    font-weight: 500;
    line-height: 68px;
    letter-spacing: 16.7px;
    text-transform: uppercase;
    color: #ffffff;
    overflow: hidden;
}

.mainCopy .title span {
    margin-top: 12px;
    display: block;
    transition: all .6s ease;
    opacity: 0;
}

.mainCopy.fadeInUp .title span {
    margin-top: 0;
    display: block;
    transition: all .6s ease;
    opacity: 1;
    color: #000000;
}

.mainCopy .desc {
    width: 100%;
    margin-top: 41px;
    transition: all .6s ease;
    font-family: 'Helvetica Neue LT W01_55 Roman';
    font-size: 1.1rem;
    line-height: 29px;
    letter-spacing: .1px;
    opacity: 0;
    color: rgba(255, 255, 255, .7);
}

.mainCopy.fadeInUp .desc {
    margin-top: 24px;
    transition: all .6s ease;
    transition-delay: .3s;
    opacity: .8;
    color: #000000;
}

@media screen and (max-width: 320px) {
    .mainCopy .title {
        height: 44.3vw;
        font-size: 7.3vw;
        line-height: 1.675;
        letter-spacing: .39em;
    }
}

/* scrollNav */
.scrollNav {
    cursor: pointer;
    transition: all .6s ease;
    opacity: 0;
    position: absolute;
    bottom: 15px;
    left: 90px;
}

.scrollNav.fadeInUp {
    transition: all .6s ease;
    opacity: 1;
    bottom: 35px;
}

.scrollNav.fadeOut {
    transition: all .6s ease;
    opacity: 0;
    bottom: 62px;
}

.scrollNav .txt {
    margin-left: 0;
    padding-left: 0;
    font-size: 1.2rem;
    letter-spacing: .9px;
    color: #505155;
    position: relative;
}

.scrollNav .txt:after {
    width: 100%;
    height: 1px;
    content: '';
    transition: -webkit-transform .4s cubic-bezier(.08, .92, .35, 1);
    transition: transform .4s cubic-bezier(.08, .92, .35, 1);
    transition: transform .4s cubic-bezier(.08, .92, .35, 1), -webkit-transform .4s cubic-bezier(.08, .92, .35, 1);
    transform: scale(1, 1);
    transform-origin: left top;
    background: rgba(0, 0, 0, .3);
    position: absolute;
    bottom: -8px;
    left: 0;
}

.scrollNav .txt:hover::after {
    transform: scale(0, 1);
    transform-origin: right top;
}

/* latestInfo */
.latestInfo {
    width: 462px;
    height: 160px;
    transition: all .6s ease;
    border: 0 solid #000000;
    border-radius: 2px;
    background-color: rgba(255, 255, 255, 1);
    box-shadow: 0 0 6px 1px rgba(0, 0, 0, .1);
    opacity: 0;
    position: absolute;
    right: 22px;
    bottom: -10px;
}

.latestInfo.fadeInUp {
    transition: all .6s ease;
    opacity: 1;
    bottom: 20px;
}

.latestInfo.fadeOut {
    transition: all .6s ease;
    opacity: 0;
    bottom: 38px;
}

.latestInfo a {
    width: 100%;
    height: 100%;
    display: inline-block;
    transition: all ease .35s;
}

.latestInfo a:hover {
    transition: all ease .35s;
    color: #444444;
}

.latestInfo .inner {
    height: calc(100%);
    padding: 27px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    transition: all ease .35s;
}

.latestInfo .left {
    width: 60%;
    padding-left: 7px;
}

.latestInfo .left .subTitle {
    margin-top: 2px;
    margin-bottom: 18px;
    padding-bottom: 10px;
    padding-left: 1px;
    transition: all ease .35s;
    border-bottom: 1px solid #e1e1e1;
    font-size: 1.2rem;
    letter-spacing: .5px;
    text-transform: capitalize;
}

.latestInfo .left .title {
    margin-top: 10px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 23px;
    letter-spacing: -.1px;
}

.latestInfo .left .date {
    margin-top: 0;
    margin-left: 1px;
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: .7px;
    color: #8c8c8c;
}

.latestInfo .right {
    height: 100%;
    margin-left: auto;
}

.latestInfo .right .newsImg {
    width: 112px;
    height: 100%;
    background-color: #cccccc;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    box-shadow: 1.6px 1.4px 4px 0 rgba(162, 162, 162, .85);
}

/* section - Common */
.sectCommon h2.title {
    margin-left: 5px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 40px;
    font-weight: 500;
    letter-spacing: 3.7px;
    text-transform: uppercase;
}

.sectCommon h2.title span {
    margin-top: 8px;
    margin-left: -1px;
    display: block;
    font-family: '游ゴシック Medium', YuGothic, YuGothicM, 'Hiragino Kaku Gothic ProN', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, sans-serif;
    font-size: 1.35rem;
    letter-spacing: .06em;
    color: rgba(125, 125, 125, .9);
    position: relative;
}

/* section - News */
.latestNews {
    width: calc(100% - 12.5%);
    margin: 0 auto 6vw;
    padding-top: 6vw;
    position: relative;
}

a.latestBtn {
    width: 60px;
    height: 60px;
    display: none;
    transition: all ease .5s;
    border: 1px solid #e1e1e1;
    border-radius: 100%;
    box-shadow: 1.6px 1.4px 4px 0 rgba(162, 162, 162, .15);
    font-size: 2.8rem;
    line-height: 62px;
    text-align: center;
    color: #bfb653;
    position: absolute;
    top: 68px;
    right: 3px;
}

a.latestBtn:hover {
    transition: all ease .5s;
    right: -10px;
}

.latestList {
    margin-top: 40px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}

.latestList .left {
    width: 70%;
    padding-right: 40px;
    border-right: 1px solid rgb(238, 238, 238);
}

.latestList .left .latestMain {
    padding-bottom: 40px;
    position: sticky;
    position: -webkit-sticky;
    top: 153px;
}

.latestList .left .postImg {
    height: 42vw;
    /*background-color: #cccccc;*/
    position: relative;
    overflow: hidden;
}

.latestList .left .postImg > a {
    width: 100%;
    height: 100%;
    display: inline-block;
    transition: all ease .5s;
    transform: translate(-50%, -50%);
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    position: absolute;
    top: 50%;
    left: 50%;
}

.latestList .left .postImg:hover > a {
    width: 108%;
    height: 108%;
    display: inline-block;
    transition: all ease .5s;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
}

.latestList .left .postImg a:before {
    width: 100%;
    height: 100%;
    content: '';
    transition: all ease .5s;
    position: absolute;
    z-index: 1;
}

.latestList .left .postImg a:hover:before {
    transition: all ease .5s;
    background-color: rgba(0, 0, 0, .3);
}

.latestList .left .postCont {
    padding-top: 24px;
    text-align: left;
}

.latestList .left .postCont h3.title {
    width: 97%;
    margin-top: 13px;
    margin-left: 0;
    font-size: 2.05rem;
    font-weight: 500;
    line-height: 29px;
    letter-spacing: .03em;
}

.latestList .left .postCont .date {
    margin-top: 11px;
    margin-left: 1px;
    font-size: 1.2rem;
    font-weight: 400;
    letter-spacing: .4px;
    color: #a5a5a5;
}

.latestList .right {
    width: 30%;
}

.latestList .right .latestPost {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-wrap: wrap;
    justify-content: left;
    font-size: 0;
}

.latestList .right .latestPost li {
    width: 100%;
    padding-right: 40px;
    padding-bottom: 44px;
    padding-left: 40px;
    display: inline-block;
    border-right: 1px solid #eeeeee;
    vertical-align: top;
}

.latestList .right .postImg {
    height: 15vw;
    /*background-color: #cccccc;*/
    position: relative;
    overflow: hidden;
}

.latestList .right .postImg > a {
    width: 100%;
    height: 100%;
    display: inline-block;
    transition: all ease .5s;
    transform: translate(-50%, -50%);
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    position: absolute;
    top: 50%;
    left: 50%;
}

.latestList .right .postImg:hover > a {
    width: 115%;
    height: 115%;
    display: inline-block;
    transition: all ease .5s;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
}

.latestList .right .postImg a:before {
    width: 100%;
    height: 100%;
    content: '';
    transition: all ease .5s;
    position: absolute;
    z-index: 1;
}

.latestList .right .postImg a:hover:before {
    transition: all ease .5s;
    background-color: rgba(0, 0, 0, .3);
}

.latestList .postCont {
    padding-top: 26px;
}

.latestList .postCont h3.title {
    margin: 9px auto 0;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.65rem;
    font-weight: 500;
    line-height: 1.95;
    letter-spacing: .02em;
}

.latestList .postCont .date {
    margin-top: 3px;
    font-size: 1.1rem;
    font-weight: 400;
    letter-spacing: .4px;
    color: #a5a5a5;
}

.latestList .postCont .btn {
    margin-top: 15px;
    font-size: 12px;
    line-height: 1.3;
    letter-spacing: .06em;
}

/* section - Service */
.sectService {
    background-color: #161616;
    color: #ffffff;
    position: relative;
}

.sectService .navInner {
    padding-top: 80px;
    padding-bottom: 140px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    position: relative;
    z-index: 1;
}

.sectService .navInner .left {
    width: 42%;
    margin-left: 6%;
}

.sectService h2.title span:before {
    width: 200px;
    background-color: rgba(255, 255, 255, .4);
}

.sectService .navInner .left .title {
    margin-top: 6px;
    font-size: 40px;
    line-height: 66px;
    letter-spacing: 7.6px;
}

.sectService .navInner .left h2.title span {
    margin-top: 11px;
    font-size: 1.5rem;
    line-height: 23px;
    color: rgba(255, 255, 255, .8);
}

.sectService .navInner .right {
    width: 48.5%;
    padding-left: 1.5%;
}

.serviceSubTitle {
    margin-top: 12px;
    margin-bottom: 60px;
    margin-left: 91px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.25rem;
    font-weight: 400;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    position: relative;
}

.serviceSubTitle.inview.fadeInUp {
    opacity: .8 !important;
}

.serviceSubTitle:before {
    width: 68px;
    height: 1px;
    content: '';
    background-color: rgba(191, 182, 83, .8);
    position: absolute;
    top: 51%;
    left: -81px;
}

.sectService .navInner .right .serviceList {
    margin-top: 0;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 40px;
    font-variant: small-caps;
    letter-spacing: 2.7px;
}

.sectService .navInner .right .serviceList li span.jpn {
    height: 17px;
    margin-left: 27px;
    display: inline-block;
    transition: all ease .6s;
    font-family: '游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', sans-serif;
    font-size: 1.3rem;
    white-space: nowrap;
    letter-spacing: 0;
    opacity: 0;
    position: absolute;
    top: 21px;
    visibility: hidden;
    overflow: hidden;
}

.sectService .navInner .right .serviceList li span.jpn span {
    margin-top: 0;
    display: inline-block;
    transition: all ease .6s;
    opacity: 0;
}

.sectService .navInner .right .serviceList li.active span.jpn {
    transition: all ease .6s;
    opacity: .7;
    visibility: visible;
}

.sectService .navInner .right .serviceList li.active span.jpn span {
    margin-top: 0;
    transition: all ease .3s;
    transition-delay: 0s;
    opacity: 1;
    visibility: visible;
}

.sectService .navInner .right .serviceList li.inview {
    opacity: 0;
}

.sectService .navInner .right .serviceList li.inview.fadeInUp {
    transition: all ease .6s;
    opacity: .7;
    position: relative;
}

.sectService .navInner .right .serviceList li span.bar {
    height: 21px;
    display: inline-block;
    position: relative;
}

.sectService .navInner .right .serviceList li span.bar:before {
    width: 0;
    height: 1px;
    content: '';
    transition: all ease .3s;
    background-color: rgba(191, 182, 83, .8);
    opacity: 0;
    position: absolute;
    top: 48%;
    right: 9px;
}

.sectService .navInner .right .serviceList li.active span.bar:before {
    width: 95px;
    transition: all ease .6s;
    opacity: 1;
}

.sectService .navInner .right .serviceList li + li {
    margin-top: 31px;
}

.sectService .navInner .right .serviceList li.inview.fadeInUp.active {
    margin-left: 30px;
    transition: all ease .6s;
    opacity: 1;
}

.sectService .navInner .right .contTxt {
    width: 60%;
    height: 100%;
    transition: all ease .4s;
    background-color: #161616;
    opacity: 0;
    position: absolute;
    top: 0;
    right: 0;
    left: 40%;
    visibility: hidden;
}

.sectService .navInner .right .contTxt.active {
    width: 60%;
    transition: all ease .4s;
    opacity: 1;
    visibility: visible;
}

.sectService .navInner .right .contMain {
    width: 80%;
    margin: 0 auto;
    transition: all ease .4s;
    opacity: 0;
}

.sectService .navInner .right .contTxt.active .contMain {
    transition: all ease .4s;
    transition-delay: .5s;
    opacity: 1;
}

.sectService .navInner .right .contMain .number {
    margin-top: 80px;
    margin-left: 5px;
    display: inline-block;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.5rem;
    font-weight: 400;
    letter-spacing: 0;
    position: relative;
}

.sectService .navInner .right .contMain .number:before {
    width: 104%;
    height: 1px;
    content: '';
    background-color: rgba(191, 182, 83, .8);
    position: absolute;
    bottom: -6px;
    left: -7%;
}

.sectService .navInner .right .contMain .title {
    padding-top: 21px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 40px;
    font-weight: 500;
    font-variant: small-caps;
    letter-spacing: 2.9px;
}

.sectService .navInner .right .contMain .title span {
    margin-top: 5px;
    margin-left: 1px;
    display: block;
    font-size: 1.3rem;
    letter-spacing: .8px;
    opacity: .8;
    position: relative;
}

.sectService .navInner .right .contMain .desc {
    margin-top: 35px;
    margin-left: 38px;
    font-size: 1.35rem;
    line-height: 40px;
    letter-spacing: .3px;
    opacity: .9;
    position: relative;
}

.sectService .navInner .right .contMain .desc a {
    text-decoration: underline;
    color: #ffffff;
}

.sectService .navInner .right .contMain .desc:before {
    width: 1px;
    height: 91%;
    content: '';
    background-color: rgba(191, 182, 83, .8);
    position: absolute;
    top: 9px;
    left: -31px;
}

a.servBtn {
    width: 66px;
    height: 66px;
    margin-top: 37px;
    display: inline-block;
    transition: all ease .5s;
    border: 1px solid rgba(255, 255, 255, .3);
    font-family: '游明朝体', 'Yu Mincho', YuMincho, 'ヒラギノ明朝 Pro', 'Hiragino Mincho Pro', 'MS P明朝', 'MS PMincho', serif;
    font-size: 2.8rem;
    line-height: 68px;
    text-align: center;
    color: #bfb191;
}

a.servBtn:hover {
    margin-left: 10px;
    transition: all ease .5s;
    background-color: #ffffff;
}

.servClose {
    width: 36px;
    height: 36px;
    position: absolute;
    top: 45px;
    right: 37px;
}

.servClose span {
    width: 100%;
    height: 1px;
    background-color: #ffffff;
    position: absolute;
    top: 19px;
}

.servClose span:nth-child(1) {
    transform: rotate(45deg);
}

.servClose span:nth-child(2) {
    transform: rotate(-45deg);
}

.sectService .contInner {
    width: 100%;
    height: 100%;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
}

.sectService .contInner .left {
    width: 50%;
    height: 100%;
    position: relative;
}

.sectService .contInner .left .contImg {
    width: 100%;
    height: 100%;
    transition: all ease .6s;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    opacity: 0;
    position: absolute;
}

.sectService .contInner .left .contImg.active {
    transition: all ease .6s;
    opacity: .6;
}

.sectService .contInner .left .contImg.active2 {
    transition: all ease .6s;
    opacity: 1;
}

.sectService .contInner .left .contImg:before {
    width: 100%;
    height: 100%;
    content: '';
    transition: all ease .6s;
    background-color: #161616;
    position: absolute;
    right: 0;
}

.sectService .contInner .left .servServImg.inview2.active:before {
    width: 100%;
    transition: all ease .6s;
}

.sectService .contInner .left .servServImg.inview2.slideIn.active:before {
    width: 31%;
    transition: all ease .6s;
}

.sectService .contInner .left .servServImg {
    background-image: url('../img/top_service.jpg');
}

.sectService .contInner .left .servClickImg.active:before {
    width: 31%;
    transition: all ease .6s;
}

.sectService .contInner .left .servClickImg.active2:before {
    width: 19%;
    transition: all ease .6s;
}

.sectService .contInner .left .servIntimateImg {
    background-image: url('../img/top_service_intimate.jpg');
}

.sectService .contInner .left .servNailImg {
    background-image: url('../img/top_service_nail.jpg');
}

.sectService .contInner .left .servEyelashImg {
    background-image: url('../img/top_service_eyelash.jpg');
}

.sectService .contInner .right {
    width: 50%;
}

/* section - About us */
.sectCommon h2.aboutTitle {
    margin-left: 0;
    font-size: 40px;
    white-space: nowrap;
    letter-spacing: 3.1px;
}

.sectAbout {
    margin-bottom: 12vw;
    margin-left: 7%;
    padding-top: 6vw;
    border-top: 1px solid #eeeeee;
}

.sectAbout > .inner {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}

.sectAbout .left {
    width: 20%;
}

.sectAbout .right {
    width: 80%;
}

.aboutSlider {
    margin-top: 20px;
    cursor: -webkit-grab;
    cursor: grab;
    position: relative;
    z-index: 0;
}

.aboutSlider:before {
    width: 0;
    height: 89%;
    content: '';
    transition: all .7s cubic-bezier(.26, 0, .07, 1);
    background-color: #efefef;
    position: absolute;
    z-index: -1;
    top: 8vw;
    right: 0vw;
}

.aboutSlider .slick-list {
    overflow: hidden;
}

.aboutSlider.slideIn:before {
    width: 108%;
}

.aboutSlider .slick-slide {
    width: 24vw;
    transition: all ease .25s;
}

.aboutSlider .slick-slide:hover {
    transition: all ease .25s;
}

.slick-list {
    padding-top: 10px !important;
}

.aboutSlider .slick-slide + .slick-slide {
    margin-left: 65px;
}

.aboutSlider .listCont {
    background-color: #ffffff;
    box-shadow: 3px 3px 10px -3px rgba(0, 0, 0, .1);
}

.aboutSlider .slick-slide:hover .listCont {
    transition: all ease .5s;
}

.aboutSlider .listCont.fadeInUp {
    transition-delay: .7s;
}

.aboutSlider .listCont a {
    width: 100%;
    height: 100%;
    display: inline-block;
    cursor: -webkit-grab;
    cursor: grab;
}

.aboutSlider .slick-slide .image {
    overflow: hidden;
}

.aboutSlider .slick-slide .image .img {
    width: 100%;
    height: 14.6vw;
    transition: all ease .5s;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
}

.aboutSlider .slick-slide:hover .image .img {
    transition: all ease .5s;
    transform: scale(1.1);
}

.aboutSlider .slick-slide .image .historyImg {
    background-image: url('../img/top_about_history.jpg');
}

.aboutSlider .slick-slide .image .companyImg {
    background-image: url('../img/top_about_company.jpg');
}

.aboutSlider .slick-slide .cont {
	border:1px solid #EEE;
}

.aboutSlider .slick-slide .cont .inner {
    width: 75%;
    margin: 35px auto 44px;
}

.aboutSlider .slick-slide .number {
    margin-left: 3px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.25rem;
    font-weight: 400;
    letter-spacing: 1px;
    color: rgba(191, 182, 83, 1);
}

.aboutSlider .slick-slide .subTitle {
    margin-top: 9px;
    display: none;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.2rem;
    font-weight: 400;
    letter-spacing: .6px;
    color: #c6c6c6;
}

.aboutSlider .slick-slide .title {
    margin-top: 11px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.8rem;
    letter-spacing: 0;
}

.aboutSlider .slick-slide .desc {
    min-height: 5em;
    margin-top: 13px;
    font-size: 1.1rem;
    line-height: 24px;
    letter-spacing: .2px;
    color: #9d9d9d;
}

button.slick-arrow {
    width: 65px;
    height: 65px;
    transition: all ease .25s;
    border: 1px solid #e5e5e5;
    border-radius: 100%;
    outline: none;
    background: #ffffff;
    box-shadow: 1.6px 1.4px 4px 0 rgba(162, 162, 162, .15);
    color: transparent;
    position: absolute;
    bottom: -3.2vw;
    left: -18.4vw;
}

button.slick-next:hover {
    transition: all ease .25s;
    left: -18.7vw;
}

button.slick-prev {
    left: -13.4vw;
}

button.slick-prev:hover {
    transition: all ease .25s;
    left: -13.1vw;
}

button.slick-arrow:before {
    transform: translate(-50%, -50%);
    font-size: 2.9rem;
    color: #bfb653;
    position: absolute;
    top: 48%;
    left: 50%;
}

button.slick-prev:before {
    width: 8px;
    height: 8px;
    content: '';
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    border-top: 2px solid #bfb653;
    border-right: 2px solid #bfb653;
    top: 43%;
    left: 40%;
}

button.slick-next:before {
    width: 8px;
    height: 8px;
    content: '';
    -webkit-transform: rotate(-13deg);
    transform: rotate(-135deg);
    border-top: 2px solid #bfb653;
    border-right: 2px solid #bfb653;
    top: 43%;
    left: 45%;
}

/* section - Contact us */
.sectContact {
    margin-bottom: 80px;
    padding-top: 80px;
    border-top: 1px solid #eeeeee;
}

.ourPhilosophy + .sectContact {
    border-top: 0 solid #e5e5e5;
}

.sectContact > .inner {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    align-items: center;
}

.sectContact .left {
    margin-right: 100px;
}

.sectContact .right {
    display: flex;
    align-items: center;
}

.sectContact h2.title span {
    margin-top: 0;
    letter-spacing: 0;
}

.sectContact h2.title span:before {
    content: none;
}

.contactTitle {
    margin-top: -8px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 40px;
    font-weight: 500;
    white-space: nowrap;
    letter-spacing: 2.6px;
    text-transform: uppercase;
}

.contactTitle span {
    display: none;
}

a.contactBtn {
    width: 200px;
    height: 66px;
    margin: 0;
    margin-left: -5px;
    display: inline-block;
    transition: all ease .5s;
    border: 1px solid #e5e5e5;
    background: #ffffff;
    box-shadow: 1.6px 1.4px 4px 0 rgba(162, 162, 162, .15);
    font-family: '游明朝体', 'Yu Mincho', YuMincho, 'ヒラギノ明朝 Pro', 'Hiragino Mincho Pro', 'MS P明朝', 'MS PMincho', serif;
    font-size: 2.8rem;
    line-height: 68px;
    text-align: center;
    color: rgba(191, 182, 83, 1);
}

a.contactBtn:hover {
    margin-left: 10px;
    transition: all ease .5s;
}

@media screen and (max-width: 1100px) {
    .mainCopy {
        width: 50%;
        top: 162px;
        bottom: 180px;
        left: 60px;
    }

    .mainCopy .title {
        height: auto;
        font-size: 3.35rem;
        line-height: 58px;
        letter-spacing: 15.3px;
        overflow: visible;
    }

    .mainCopy.fadeInUp .desc {
        margin-top: 10px;
        font-size: 1.1rem;
        line-height: 27px;
    }

    .scrollNav {
        bottom: 30px;
        left: 56px;
    }

    .scrollNav.fadeInUp {
        bottom: 25px;
    }

    .scrollNav .txt {
        font-size: 1.25rem;
        letter-spacing: .6px;
    }

    .sectAbout {
        margin-bottom: 115px;
        margin-left: 7.3%;
        padding-top: 85px;
    }

    .sectAbout .left {
        width: 9%;
    }

    .sectAbout .right {
        width: 97%;
    }

    .aboutSlider {
        margin-top: 124px;
        margin-left: -15px;
    }

    .aboutSlider .slick-slide {
        width: 37vw;
    }

    .aboutSlider .slick-slide + .slick-slide {
        margin-left: 41px;
    }

    .aboutSlider .slick-slide .image .img {
        height: 22.2vw;
    }

    .aboutSlider .slick-slide .number {
        font-size: 1.05rem;
    }

    .aboutSlider .slick-slide .cont .inner {
        width: 75%;
        margin: 33px auto 50px;
    }

    .aboutSlider .slick-slide .title {
        margin-top: 7px;
        font-size: 1.9rem;
        letter-spacing: .2px;
    }

    .aboutSlider .slick-slide .desc {
        margin-top: 12px;
        font-size: .9rem;
        line-height: 2.4;
        letter-spacing: .05EM;
    }

    .aboutSlider:before {
        width: 0;
        height: 95%;
        top: 7vw;
        right: 0vw;
    }

    .aboutSlider.slideIn:before {
        width: 108%;
    }

    .aboutSelect .selectList .listCont.fadeInUp.scale:hover .image .img {
        transition: all ease .5s;
        transform: scale(1);
    }
}

@media screen and (max-width: 767px) {
	
.aboutSlider .slick-slide .image .companyImg {
    background-image: url('../img/top_about_company.jpg');
	background-position:-10px center;
}

    .mv {
        width: calc(100% - 20px);
        margin: 10px auto;
    }

    .slide {
        background-attachment: initial;
    }

    .slick-list {
        padding-top: 0 !important;
    }

    /* mainCopy */
    .under .mv .mainCopy {
        width: 100%;
        height: 58px;
        top: auto;
        bottom: 10px;
        left: 0;
    }

    .mainCopy.fadeOut {
        opacity: 0;
        top: 80px;
    }

    .mainCopy .title {
        font-size: 6.3vw;
        line-height: 1.8;
        letter-spacing: .4em;
    }

    .mainCopy .desc {
        width: 193px;
        margin-top: 28px;
        font-size: .9rem;
        line-height: 23px;
        letter-spacing: 0;
    }

    .mainCopy.fadeInUp .desc {
        width: 193px;
        margin-top: 32px;
        font-size: .9rem;
        line-height: 23px;
        letter-spacing: 0;
    }

    /* scrollNav */
    .scrollNav {
        display: block;
        bottom: 15px;
        left: 30px;
    }

    .scrollNav.fadeInUp {
        bottom: 25px;
    }

    .scrollNav.btnCursor.fadeInUp.fadeOut {
        bottom: 45px;
    }

    .scrollNav .txt {
        font-size: .9rem;
    }

    .scrollNav .txt:after {
        bottom: -5px;
    }

    /* latestInfo */
    .latestInfo {
        width: 347px;
        height: 130px;
        display: none;
    }

    .latestInfo .inner {
        width: 87%;
        height: calc(100% - 38px);
        margin: 0 auto;
        padding: 20px;
    }

    .latestInfo .left {
        padding-left: 0;
    }

    .latestInfo .left .subTitle {
        margin-top: 2px;
        margin-bottom: 9px;
        font-size: 1.05rem;
        letter-spacing: .4px;
    }

    .latestInfo .left .date {
        font-size: 1.05rem;
    }

    .latestInfo .left .title {
        height: 3em;
        margin-top: 6px;
        font-size: 1.15rem;
        line-height: 17px;
        overflow-y: hidden;
    }

    .latestInfo .right {
        margin-right: -1%;
    }

    .latestInfo .right .newsImg {
        width: 91px;
    }

    /* section - Common */
    .sectCommon h2.title {
        margin-left: 1px;
        font-size: 2.8rem;
        letter-spacing: .06em;
    }

    .sectAbout h2.title {
        font-size: 3rem;
        letter-spacing: .05em;
    }

    .sectCommon h2.title span {
        margin-top: 6px;
        margin-left: 0;
        font-size: 1rem;
        letter-spacing: .03em;
        color: rgba(125, 125, 125, .8);
    }

    .sectCommon h2.title span:before {
        width: 68px;
        top: -15px;
    }

    .sectService h2.title span:before {
        width: 70px;
        background-color: rgba(191, 177, 145, .4);
        top: -15px;
    }

    /* section - News */
    .latestNews {
        width: calc(100% - 47px);
        margin-bottom: 26px;
        padding-top: 46px;
    }

    .latestNews .postList {
        margin-top: 23px;
    }

    .latestList {
        margin-top: 37px;
    }

    .latestList {
        margin-top: 50px;
        flex-flow: column;
    }

    .latestList .left {
        width: 100%;
        margin-bottom: 40px;
        padding-right: 0;
        border-right: 0;
        border-bottom: 1px solid rgb(238, 238, 238);
    }

    .latestList .left .latestMain {
        padding-bottom: 40px;
        top: 118px;
    }

    .latestList .left .postImg {
        height: 45.7vw;
    }

    .latestList .left .postCont .date {
        margin-top: 4px;
        margin-left: 1px;
        font-size: 1.15rem;
        letter-spacing: .2px;
    }

    .latestList .left .postCont h3.title {
        margin-top: 9px;
        font-size: 1.3rem;
        line-height: 21px;
        letter-spacing: -.2px;
    }

    .latestList .left .postCont .cat {
        margin-top: 10px;
        margin-left: 1px;
        font-size: 1.1rem;
        letter-spacing: .4px;
    }

    .latestList .right {
        width: 100%;
        margin-left: initial;
    }

    .latestList .right .latestPost {
        justify-content: left;
    }

    .latestList .right .latestPost li {
        width: 50%;
        padding-right: 6.05%;
        padding-bottom: 0;
    }

    .latestList .right .latestPost li:nth-child(n + 3) {
        padding-top: 50px;
    }

    .latestList .right .latestPost li:nth-child(1) {
        padding-left: 0;
        display: block;
    }

    .latestList .right .latestPost li:nth-child(6) {
        padding-bottom: 31px;
    }

    .latestList .right .latestPost li:nth-child(7) {
        display: none;
    }

    .latestList .right .latestPost li + li {
        padding-left: 6.05%;
    }

    .latestList .right .latestPost li:nth-child(2) {
        padding-left: 6.05%;
    }

    .latestList .right .latestPost li + li:nth-child(2n + 3) {
        padding-right: 6.05%;
        border-right: 1px solid rgb(238, 238, 238);
    }

    .latestList .right .latestPost li + li:nth-child(2n + 4) {
        padding-left: 6.05%;
    }

    .latestList .right .latestPost li + li:nth-child(2n + 2) {
        padding-right: 0;
        border: none;
    }

    .latestList .right .latestPost li + li:nth-child(2n + 3) {
        padding-left: 0;
    }

    .latestList .right .latestPost li:nth-last-child(1) {
        padding-bottom: 30px;
    }

    .latestList .postCont {
        padding-top: 25px;
        text-align: left;
    }

    .latestList .right .postImg {
        height: 30.5vw;
    }

    .latestList .postCont {
        margin-top: 0;
    }

    .latestList .postCont .date {
        margin-left: 1px;
        font-size: .9rem;
        letter-spacing: .7px;
    }

    .latestList .postCont h3.title {
        width: 100%;
        margin: initial;
        margin-top: 8px;
        font-size: 1.4rem;
        line-height: 1.9;
        letter-spacing: .02em;
    }

    .latestList .postCont .cat {
        margin-top: 12px;
        font-size: .9rem;
        letter-spacing: .3px;
    }

    .latestList .postCont .cat:before {
        bottom: -4px;
    }

    a.latestBtn {
        display: none;
    }

    /* section - Service */
    .sectService {
        padding: 0 25px;
    }

    .sectService .navInner {
        padding-top: 58px;
        padding-bottom: 120px;
        display: block;
    }

    .sectService .navInner .left {
        width: calc(100% - 75px);
        margin: 0 auto;
        margin-left: initial;
    }

    .sectService .navInner .left .title {
        font-size: 2.9rem;
        line-height: 30px;
        letter-spacing: .07em;
    }

    .sectService .navInner .left .title br {
        display: none;
    }

    .sectService .navInner .left h2.title span {
        margin-top: 16px;
        margin-left: 1px;
        font-size: 1rem;
        color: rgba(255, 255, 255, .7);
        position: relative;
    }

    .sectService .navInner .left h2.title span:before {
        width: 190px;
        height: 1px;
        content: '';
        background-color: rgba(193, 183, 85, .3);
        position: absolute;
        top: -9px;
        left: 0;
    }

    .sectService .navInner .right {
        width: calc(100% - 72px);
        margin: 36px auto 0;
        padding-left: 10px;
    }

    .serviceSubTitle {
        display: none;
    }

    .sectService .navInner .right .serviceList {
        margin-left: -9px;
        font-size: 2.9rem;
        letter-spacing: 1.9px;
    }

    .sectService .navInner .right .serviceList li.inview.fadeInUp {
        opacity: .5;
    }

    .sectService .navInner .right .serviceList li.active span.jpn {
        opacity: 0;
        visibility: hidden;
    }

    .sectService .navInner .right .serviceList li.active span.bar:before {
        width: 0;
    }

    .sectService .navInner .right .serviceList li.inview.fadeInUp.active {
        margin-left: 0;
        transition: all ease .6s;
        opacity: 1;
    }

    .sectService .navInner .right .serviceList li + li {
        margin-top: 16px;
    }

    .sectService .navInner .right .contTxt {
        width: 100%;
        left: 0;
    }

    .sectService .navInner .right .contTxt.active {
        width: 100%;
        transition: all ease .4s;
        opacity: 1;
        left: 0;
        visibility: visible;
    }

    .sectService .navInner .right .contMain {
        width: calc(100% - 77px);
        margin: 0 auto;
        transition: all ease .4s;
        opacity: 0;
    }

    .sectService .navInner .right .contMain .number {
        margin-top: 47px;
        margin-left: 3px;
        font-size: 1.1rem;
        letter-spacing: 0;
    }

    .sectService .navInner .right .contMain .number:before {
        background-color: rgba(191, 177, 145, .4);
    }

    .sectService .navInner .right .contMain .title {
        margin-left: 0;
        padding-top: 17px;
        font-size: 3.7rem;
        letter-spacing: 1.6px;
    }

    .sectService .navInner .right .contMain .title span {
        margin-top: 1px;
        margin-left: 0;
        font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
        font-size: 1rem;
        letter-spacing: .8px;
        opacity: .7;
    }

    .sectService .navInner .right .contMain .desc {
        width: calc(100% - 33px);
        margin-top: 32px;
        margin-left: 27px;
        padding-top: 2px;
        padding-bottom: 1px;
        font-size: 1.2rem;
        line-height: 2.5;
        letter-spacing: .03em;
        opacity: .8;
    }

    .sectService .navInner .right .contMain .desc:before {
        left: -23px;
    }

    .servClose {
        width: 26px;
        height: 28px;
        position: absolute;
        top: 21px;
        right: 19px;
    }

    a.servBtn {
        width: 48px;
        height: 48px;
        margin-top: 23px;
        margin-left: -5px;
        border: 1px solid rgba(255, 255, 255, .4);
        font-size: 1.8rem;
        line-height: 51px;
    }

    .sectService .contInner {
        display: none;
    }

    /* section - About us */
    .sectAbout {
        margin-right: 25px;
        margin-bottom: 0;
        margin-left: 25px;
        padding-top: 50px;
        padding-bottom: 50px;
    }

    .sectAbout > .inner {
        flex-direction: column;
    }

    .sectAbout .left {
        width: 100%;
    }

    .sectAbout .right {
        width: 100%;
    }

    .aboutSlider {
        margin-top: 30px;
        margin-left: 0;
    }

    .aboutSlider .slick-slide {
        width: 63vw;
    }

    .aboutSlider.slideIn:before {
        width: calc(100% + 50px);
    }

    .aboutSlider .slick-slide:hover {
        margin-top: 0;
    }

    .aboutSlider:before {
        width: 0;
        height: 100%;
        top: 13.7vw;
        right: 0;
        left: -25px;
    }

    .aboutSlider .slick-slide + .slick-slide {
        margin-left: 0;
    }

    .aboutSlider .slick-slide .cont .inner {
        width: 75%;
        margin: 24px auto 36px;
    }

    .aboutSlider .slick-slide .image .img {
        height: 40.1vw;
    }

    .aboutSlider .slick-slide .number {
        display: block;
        font-size: 1rem;
        letter-spacing: .6px;
        color: rgba(173, 155, 113, 1);
    }

    .aboutSlider .slick-slide .title {
        margin-top: 5px;
        font-size: 1.5rem;
        letter-spacing: .5px;
    }

    .aboutSlider .slick-slide .subTitle {
        margin-top: 6px;
        margin-left: 1px;
        display: block;
        font-size: .9rem;
        letter-spacing: .4px;
        color: #b9b9b9;
    }

    .aboutSlider .slick-slide .desc {
        display: none;
    }

    .sectAbout .slick-track {
        width: calc(100vw - 25px) !important;
        display: flex;
        flex-wrap: wrap;
    }

    .sectAbout .slick-slide {
        width: 100%;
        margin-bottom: 20px;
    }

    /* section - Contact us */
    .sectContact .left {
        width: 100%;
        margin-right: 0;
    }

    .sectContact {
        margin-right: 30px;
        margin-bottom: 50px;
        margin-left: 30px;
        padding-top: 50px;
        padding-left: 0;
        border: none;
    }

    .sectContact h2.title span {
        margin-top: 0;
    }

    .contactTitle {
        margin-top: -5px;
        font-size: 2.9rem;
        letter-spacing: .04em;
    }

    a.contactBtn {
        width: 120px;
        height: 60px;
        margin-top: 0;
        margin-left: -2px;
        font-size: 1.8rem;
        line-height: 60px;
    }
}

/*------------------------

INFO

------------------------*/
.postList {
    margin-top: 40px;
    margin-bottom: 55px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    font-size: 0;
}

.postList li {
    width: calc(25% - 0px);
    margin-bottom: 0;
    padding: 30px;
    padding-bottom: 40px;
    border-right: 1px solid #eeeeee;
    border-bottom: 1px solid #eeeeee;
    vertical-align: top;
}

.postList li:nth-child(4n + 4) {
    border-right: 0;
}

.postList .postImg {
    height: 12.7vw;
    /*background-color: #cccccc;*/
    position: relative;
    overflow: hidden;
}

.postList .postImg > a {
    width: 100%;
    height: 100%;
    display: inline-block;
    transition: all ease .5s;
    transform: translate(-50%, -50%);
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    position: absolute;
    top: 50%;
    left: 50%;
}

.postList .postImg:hover > a {
    width: 110%;
    height: 110%;
    display: inline-block;
    transition: all ease .5s;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
}

.postList li:nth-child(1) .postImg:hover > a {
    width: 105%;
    height: 105%;
    display: inline-block;
    transition: all ease .5s;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
}

.postList .postImg a:before {
    width: 100%;
    height: 100%;
    content: '';
    transition: all ease .5s;
    position: absolute;
    z-index: 1;
}

.postList .postImg a:hover:before {
    transition: all ease .5s;
    background-color: rgba(0, 0, 0, .3);
}

.postList .postCont {
    width: 98%;
    margin: 0 auto;
    padding-top: 24px;
}

.postList .postCont h3.title {
    margin: 9px auto 0;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.65rem;
    font-weight: 500;
    line-height: 1.95;
    letter-spacing: .02em;
}

.postList .postCont .date {
    margin-top: 3px;
    font-size: 1.1rem;
    font-weight: 400;
    letter-spacing: .4px;
    color: #a5a5a5;
}

.postList .postCont .btn {
    margin-top: 15px;
    font-size: 12px;
    line-height: 1.3;
    letter-spacing: .06em;
}

.btn {
    margin-top: 0;
    margin-left: 35px;
    display: inline-block;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.5rem;
    font-weight: 400;
    letter-spacing: -.2px;
    position: relative;
}

.btn:before {
    content: '→';
    transition: all ease .25s;
    font-size: 2.5rem;
    color: #bfb653;
    position: absolute;
    top: -7px;
    left: -35px;
}

.btn:hover:before {
    transition: all ease .25s;
    left: -31px;
}

@media screen and (max-width: 1250px) {
    .btn {
        margin-left: 28px;
        font-size: 1.35rem;
        letter-spacing: -.2px;
    }

    .btn:before {
        content: '→';
        font-size: 2.1rem;
        top: -6px;
        left: -29px;
    }
}

.singleNews {
    width: calc(100% - 9%);
    margin: 80px auto 0;
}

.singleHead {
    width: 100%;
    margin-left: 8px;
    text-align: center;
    position: relative;
}

.singleHead .postTitle {
    width: 637px;
    margin: 7px auto;
    font-family: '游明朝体', 'Yu Mincho', YuMincho, 'ヒラギノ明朝 Pro', 'Hiragino Mincho Pro', 'MS P明朝', 'MS PMincho', serif;
    font-size: 3.25rem;
    font-weight: 500;
    line-height: 55px;
    text-align: center;
    letter-spacing: .03em;
}

.singleHead .postDate {
    margin-top: 10px;
    margin-left: -2px;
    display: inline-block;
    font-size: 1.35rem;
    font-weight: 400;
    text-align: center;
    letter-spacing: .5px;
    color: #b9b9b9;
    position: relative;
}

.singleHead .postDate:before {
    width: 100%;
    height: 0;
    content: '';
    background-color: #cccccc;
    position: absolute;
    bottom: -6px;
}

.singleCont {
    margin-top: 80px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}

.singleCont .left {
    width: 59%;
}

.singleCont .left .images {
    position: sticky;
    position: -webkit-sticky;
    top: 159px;
}

.singleCont .left .images .image {
    overflow: hidden;
}

.singleCont .left img {
    width: 100%;
    height: auto;
    transition: all ease 2.5s;
    transform: scale(1.1);
}

.singleCont .right {
    width: 31.8%;
    margin-left: 5.2%;
    position: sticky;
    position: -webkit-sticky;
    bottom: 30px;
}

.singleCont .right .article {
    margin-top: -8px;
    font-size: 1.45rem;
    line-height: 2.4;
    letter-spacing: .05em;
    position: sticky;
    position: -webkit-sticky;
    bottom: 30px;
}

.singleCont .right .article .copy {
    font-size: 24px;
    font-weight: 600;
}

.singleCont .label {
    margin-top: 0;
    margin-bottom: 10px;
    display: inline-block;
    font-size: 1.35rem;
    font-weight: 400;
    letter-spacing: .5px;
    color: #383533;
    position: relative;
}

.singleCont .label:before {
    width: 100%;
    height: 1px;
    content: '';
    transition: transform .3s;
    transform: scale(1, 1);
    transform-origin: left top;
    background-color: rgba(191, 182, 83, .8);
    position: absolute;
    bottom: -6px;
}

section.prevNext {
    width: calc(100% - 10.2%);
    margin: 115px auto 120px;
}

.prevNext .inner {
    display: flex;
}

.prevNext .navPost {
    width: calc(50% - 15px);
    font-size: 1.7rem;
    position: relative;
}

.prevNext .navPost a:before {
    width: 8px;
    height: 8px;
    content: '';
    border-top: 2px solid rgba(191, 182, 83, .8);
    border-right: 2px solid rgba(191, 182, 83, .8);
    position: absolute;
    z-index: 0;
    top: 50%;
}

.prevNext .navPost.nextPost {
    padding-left: 32px;
}

.prevNext .nextPost a:before {
    -webkit-transform: translateY(-41%) rotate(-135deg);
    transform: translateY(-41%) rotate(-135deg);
    left: -32px;
}

.prevNext .navPost.prevPost {
    padding-right: 32px;
    text-align: right;
}

.prevNext .prevPost a:before {
    -webkit-transform: translateY(-41%) rotate(45deg);
    transform: translateY(-41%) rotate(45deg);
    right: -32px;
}

.prevNext .navPost a {
    display: inline-block;
    position: relative;
}

.prevNext .navPost a::after {
    width: 100%;
    height: 1px;
    content: '';
    transition: -webkit-transform .4s cubic-bezier(.08, .92, .35, 1);
    transition: transform .4s cubic-bezier(.08, .92, .35, 1);
    transition: transform .4s cubic-bezier(.08, .92, .35, 1), -webkit-transform .4s cubic-bezier(.08, .92, .35, 1);
    transform: scale(0, 1);
    transform-origin: right top;
    background: rgba(191, 182, 83, .8);
    position: absolute;
    bottom: -6px;
    left: 0;
}

.prevNext .navPost a:hover::after {
    transform: scale(1, 1);
    transform-origin: left top;
}

.prevNext .toIndex {
    width: 30px;
    height: 27px;
    transition: all ease .35s;
}

.prevNext .toIndex:hover {
    transition: all ease .35s;
    opacity: .6;
}

.prevNext .toIndex a {
    width: 100%;
    height: 100%;
}

.prevNext .toIndex ul {
    width: 100%;
    height: 100%;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-wrap: wrap;
}

.prevNext .toIndex ul li {
    width: calc(33.333% - 2px);
    height: calc(33.333% - 2px);
    background-color: #000000;
}

.prevNext .toIndex ul li + li {
    margin-left: 3px;
}

.prevNext .toIndex ul li:nth-child(3n + 4) {
    margin-left: 0;
}

.prevNext .toIndex ul li:nth-child(n + 4) {
    margin-top: 3px;
}

@media screen and (max-width: 1100px) {
    .postList {
        margin-bottom: 43px;
    }

    .postList li {
    }

    .postList .postImg {
        height: 13.4vw;
    }

    .postList .postCont {
        width: 98%;
        padding-top: 21px;
    }

    .postList .postCont .date {
        font-size: .9rem;
    }

    .postList .postCont h3.title {
        margin-top: 8px;
        font-size: 1.1rem;
        line-height: 22px;
        letter-spacing: 0;
    }

    .postList .postCont .cat {
        margin-top: 14px;
        margin-left: 0;
        font-size: .9rem;
        letter-spacing: .4px;
    }

    .singleNews {
        width: calc(100% - 8.9%);
        margin: 8vh auto 0;
    }

    .singleHead .postTitle {
        width: 547px;
        margin: 7px auto;
        font-size: 2.4rem;
        line-height: 43px;
        letter-spacing: 0;
    }

    .singleHead .postDate {
        margin-top: 6px;
        font-size: 1.2rem;
        letter-spacing: .2px;
    }

    .singleCont {
        margin-top: 77px;
        margin-bottom: 37px;
        flex-direction: column;
    }

    .singleCont .left {
        width: 100%;
    }

    .singleCont .right {
        width: 100%;
        margin-top: 50px;
        margin-right: 0;
        margin-left: 0;
        align-self: initial;
        position: relative;
        bottom: 0;
    }

    .singleCont .cat {
        width: 91.4%;
        margin: 32px auto 0;
        margin-top: 22px;
        display: block;
        font-size: 1.3rem;
        letter-spacing: .2px;
    }

    .singleCont .cat a {
        display: inline-block;
        position: relative;
    }

    .postNav {
        top: 52.5%;
    }

    section.prevNext {
        width: calc(100% - 11.5%);
        margin: 91px auto 100px;
    }

    .prevNext .navPost {
        width: calc(50% - 15px);
        font-size: 1.6rem;
        position: relative;
    }

    .prevNext .navPost a:before {
        width: 8px;
        height: 8px;
        content: '';
        border-top: 2px solid #cdb99c;
        border-right: 2px solid #cdb99c;
        position: absolute;
        z-index: 0;
        top: 51%;
    }

    .prevNext .navPost.nextPost {
        padding-left: 26px;
    }

    .prevNext .nextPost a:before {
        left: -27px;
    }

    .prevNext .navPost.prevPost {
        padding-right: 26px;
    }

    .prevNext .navPost.prevPost a:before {
        right: -27px;
    }

    .prevNext .toIndex {
        width: 26px;
        height: 24px;
    }
}

@media screen and (max-width: 767px) {
    .postList {
        margin-top: 30px;
        margin-bottom: 30px;
    }

    .postList li {
        width: calc(50% - 0px);
        margin-bottom: 0;
        padding: 20px;
        padding-right: initial;
    }

    .postList li:nth-child(1) {
        width: 100%;
        padding: 0 10px 30px 10px;
        border-right: 0;
    }

    .postList li:nth-child(1) .inner {
        padding-right: 0;
        padding-left: 0;
    }

    .postList li:nth-child(1) .postImg {
        height: 60vw;
    }

    .postList li:nth-child(2n) {
        padding: 20px 20px 20px 10px;
        border-right: 1px solid #eeeeee;
    }

    .postList li:nth-child(2n + 3) {
        padding: 20px 10px 20px 20px;
        border-right: 0;
    }

    .postList .postCont {
        width: 98%;
        margin: 0 auto;
        padding-top: 16px;
    }

    .postList .postCont .date {
        margin-top: 6px;
        margin-left: 2px;
        font-size: .9rem;
        letter-spacing: .7px;
    }

    .postList .postCont h3.title {
        width: 100%;
        margin: initial;
        margin-top: 8px;
        font-size: 1.4rem;
        line-height: 1.9;
        letter-spacing: .02em;
    }

    .postList li:nth-child(1) .postCont h3.title {
        font-size: 1.7rem;
        line-height: 22px;
    }

    .postList .postCont .cat {
        margin-top: 12px;
        margin-left: 1px;
        font-size: .9rem;
        letter-spacing: .3px;
    }

    .postList li:nth-child(1) .postCont .cat {
        margin-top: 13px;
    }

    .postList .postImg {
        height: 26vw;
    }

    .pagenation {
        margin-bottom: 30px;
        margin-left: 3px;
        display: inline-block;
    }

    .pagenation ul li {
        width: 46px;
        height: 46px;
        font-size: 1.4rem;
        line-height: 48px;
    }

    .pagenation ul li + li {
        margin-left: 1px;
    }

    li.prev:before {
        width: 6px;
        height: 6px;
        left: 54%;
    }

    li.next:before {
        width: 6px;
        height: 6px;
        left: 46%;
    }

    .newsCont {
        margin-top: 30px;
    }

    .newsCont .underHead {
        width: calc(100% - 20px);
        padding-bottom: 17px;
    }

    .underNewsNav {
        margin-left: -16px;
    }

    .underNewsNav ul li {
        font-size: 1.2rem;
        line-height: 18px;
        letter-spacing: .9px;
    }

    .newsCont .underNewsNav ul li {
        font-size: 1.1rem;
        text-transform: uppercase;
    }

    .underNewsNav ul li + li:nth-child(2) {
        margin-left: 21px;
    }

    .underNewsNav ul li + li:nth-child(4) {
        margin-left: 25px;
    }

    .underNewsNav .arrowInner::after {
        top: 5px;
        right: -14px;
    }

    .underNewsNav ul li:after {
        bottom: -19px;
    }

    .underNav ul li:before {
        height: 11px;
        top: 6px;
        left: -9px;
    }

    .underNav ul li + li:nth-child(2):before {
        left: -9px;
    }

    .underNewsNav .arrowInner::after {
        width: 5px;
        height: 5px;
        top: 5px;
        right: -11px;
    }

    .underNewsNav select {
        font-size: 1.2rem;
        letter-spacing: .9px;
        text-transform: uppercase;
    }

    .newsCont > .inner {
        width: calc(100% - 27px);
        margin-top: 19px;
    }

    .singleNews {
        width: calc(100% - 30px);
        margin: 40px auto 0;
    }

    .singleHead {
        width: calc(100% - 13px);
        margin-left: 7.8%;
        text-align: left;
    }

    .singleHead .postTitle {
        width: 96%;
        margin: 7px 0 4px;
        font-size: 1.7rem;
        line-height: 1.65;
        text-align: left;
        letter-spacing: .01em;
    }

    .singleHead .postDate {
        margin-top: 0;
        margin-left: 0;
        font-size: 1rem;
        letter-spacing: .04em;
    }

    .singleCont {
        margin-top: 40px;
        margin-bottom: 57px;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        flex-direction: column;
        flex-wrap: wrap;
    }

    .singleCont .left {
        width: 100%;
        position: relative;
        bottom: initial;
    }

    .singleCont .left img {
        transform: scale(1);
    }

    .singleCont .right {
        width: 100%;
        margin-top: 20px;
        margin-left: initial;
        align-self: initial;
        position: relative;
        bottom: initial;
    }

    .singleCont .right .article {
        width: calc(100% - 34px);
        margin: 14px auto 0;
        margin-top: 9px;
        align-self: initial;
        font-size: 1.2rem;
        line-height: 30px;
        letter-spacing: .02em;
        position: relative;
        bottom: initial;
    }

    .singleCont .right .article:before {
        display: none;
    }

    .singleCont .right .article img.sign {
        width: 250px;
    }

    .singleCont .right .article .copy {
        font-size: 24px;
        font-weight: 600;
    }

    .singleCont .label {
        margin-top: 20px;
    }

    .singleCont .cat {
        margin-top: 20px;
        margin-bottom: 0;
        margin-left: 16px;
        font-size: 1.2rem;
        letter-spacing: .5px;
    }

    .postNav {
        width: calc(100% - 54px);
        margin: 67px auto 7px;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        position: relative;
        top: initial;
        right: initial;
    }

    .postNav.slideIn {
        right: initial;
    }

    .postNav.slideIn.active {
        right: initial;
    }

    .postBtn {
        width: 48px;
        height: 48px;
        font-size: 2.2rem;
        line-height: 42px;
    }

    .postBtn.next {
        order: 1;
    }

    .postBtn.shareBtn:nth-child(1) {
        order: 2;
    }

    .postBtn.shareBtn:nth-child(2) {
        order: 3;
    }

    .postBtn.next {
        margin-left: 2px;
        display: none;
        order: 4;
    }

    .postBtn.prev {
        display: none;
    }

    .postBtn.shareBtn {
        display: none;
    }

    .postBtn.share {
        line-height: 50px;
        opacity: 1;
        position: relative;
        bottom: initial;
        visibility: visible;
    }

    .postBtn + .postBtn {
        margin-top: 0;
        margin-left: 2px;
    }

    .postBtn.next:before {
        width: 6px;
        height: 6px;
        top: 42%;
        left: 38%;
    }

    .postBtn.prev:before {
        width: 6px;
        height: 6px;
        top: 42%;
        left: 44%;
    }

    .postBtn.next a:before {
        width: 6px;
        height: 6px;
        top: 42%;
        left: 38%;
    }

    .postBtn.prev a:before {
        width: 6px;
        height: 6px;
        top: 42%;
        left: 44%;
    }

    section.prevNext {
        width: calc(100% - 11.5%);
        margin: 23px auto 50px;
        padding-top: 26px;
        padding-bottom: 26px;
        border-top: 1px solid #eeeeee;
        border-bottom: 1px solid #eeeeee;
    }

    .prevNext .inner {
        align-items: center;
    }

    .prevNext .navPost {
        width: calc(50% - 15px);
        font-size: 1.1rem;
        line-height: 1.6;
        letter-spacing: .03em;
    }

    .prevNext .nextPost a {
        padding-right: 23px;
    }

    .prevNext .navPost.nextPost a:before {
        left: -21px;
    }

    .prevNext .prevPost a {
        padding-left: 23px;
    }

    .prevNext .navPost.prevPost a:before {
        right: -21px;
    }

    .prevNext .navPost a:after {
        content: initial;
    }

    .prevNext .toIndex {
        width: 26px;
        height: 20px;
    }
}

/*------------------------

SERVICE

------------------------*/
.serviceCont {
    margin-bottom: 0;
}

.underCont .serviceList {
    width: calc(100% - 0%);
    margin-top: 40px;
    margin-right: auto;
    margin-bottom: 8vw;
    margin-left: auto;
}

.underCont .serviceList li {
    padding-top: 4vw;
    padding-bottom: 4vw;
    border-top: 1px solid #eeeeee;
}

.underCont .serviceList li:last-child {
    border-bottom: 1px solid #eeeeee;
}

.serviceList li > .inner {
    width: 100%;
    margin: 0 auto;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    align-items: center;
}

.serviceList li .postCont {
    width: 40.5%;
    margin-left: 5.5%;
}

.serviceList li .postCont .title {
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 5rem;
    font-weight: 300;
    letter-spacing: 2.3px;
}

.serviceList li .postCont .subTitle {
    margin-top: 4px;
    font-size: 1.3rem;
    letter-spacing: .05em;
    color: #787878;
}

.serviceList li .postCont .desc {
    width: 100%;
    margin-top: 36px;
    font-size: 1.3rem;
    line-height: 2.6;
    letter-spacing: .05em;
}

.serviceList li .postCont .detailBtn {
    width: 71%;
    margin-top: 37px;
    margin-left: -1%;
}

.serviceList li .detailBtn.tablet {
    display: none;
}

.serviceList li .postImg {
    width: 54%;
    height: 32vw;
    position: relative;
    overflow: hidden;
}

.serviceList li .postImg .img {
    width: 100%;
    height: 100%;
    display: inline-block;
    transition: all 1s cubic-bezier(.26, 0, .07, 1);
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
}

.serviceList li .postImg:hover .img {
    transition: all 1s cubic-bezier(.26, 0, .07, 1);
    transform: scale(1.1);
}

.serviceList li .postImg a {
    width: 100%;
    height: 100%;
}

.serviceList li .postImg a:hover {
    transition: all 1s cubic-bezier(.26, 0, .07, 1);
    transform: scale(1);
}

.serviceList li .postImg a:after {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    content: '';
    transition: all 1s cubic-bezier(.26, 0, .07, 1);
    border: 0 solid #ffffff;
    position: absolute;
    top: 0;
    right: 0;
}

.serviceList li .postImg a:hover:after {
    transition: all 1s cubic-bezier(.26, 0, .07, 1);
    border: 20px solid #ffffff;
}

.serviceList li .postImg:before {
    width: 100%;
    height: 100%;
    content: '';
    transition: all 1s cubic-bezier(.86, 0, .07, 1);
    background-color: #ffffff;
    position: absolute;
    top: 0;
    right: 0;
}

.serviceList li:nth-child(1) .postImg.slideLeft:before {
    width: 0;
    transition-delay: 1.9s;
}

.serviceList li .postImg.slideLeft:before {
    width: 0;
}

@media screen and (max-width: 767px) {
    .underCont .serviceList {
        width: calc(100% - 25px);
    }

    .underCont .serviceList li > .inner {
        width: 100%;
        flex-direction: column;
        flex-wrap: wrap;
    }

    .underCont .serviceList li {
        margin-top: 0;
        padding-top: 6vh;
        padding-bottom: 6vh;
    }

    .serviceList li .postCont {
        width: calc(100% - 49px);
        margin: 0 auto;
        padding-top: 4vh;
    }

    .serviceList li .postCont .title {
        font-size: 3rem;
        letter-spacing: 1.2px;
    }

    .serviceList li .postCont .subTitle {
        margin-top: 9px;
        font-size: 1rem;
        letter-spacing: .06em;
    }

    .serviceList li .postCont .detailBtn {
        width: 104%;
        margin-top: 25px;
        margin-bottom: 0;
        margin-left: -3%;
        display: block;
    }

    .serviceList li .postCont .desc {
        width: 100%;
        margin-top: 27px;
        font-size: 1.2rem;
        line-height: 2.4;
        letter-spacing: .05em;
    }

    .serviceList li .detailBtn.tablet {
        display: none;
    }

    .serviceList li .postCont .date {
        margin-top: 25px;
        margin-left: 24px;
        font-size: 1.1rem;
        letter-spacing: .9px;
    }

    .serviceList li .postCont .date:before {
        width: 29px;
        height: 1px;
        content: '';
        transform: rotate(-50deg);
        position: absolute;
        bottom: 13px;
        left: -27px;
    }

    .serviceList li .postCont .cat {
        margin-top: 15px;
        font-size: 1rem;
        letter-spacing: .3px;
    }

    .serviceList li .postCont .cat a {
        color: #828282;
    }

    .serviceList li .postCont .cat a + a:before {
        margin-right: 2px;
    }

    .serviceList li .postImg {
        width: 100%;
        height: 69vw;
        margin-left: 0;
    }
}

/*------------------------

INTIMATE

------------------------*/
.underBrandList {
    margin-top: 8vh;
    display: flex;
}

.underBrandList ul {
    width: 20%;
    padding-right: 20px;
    padding-left: 20px;
    border-left: 1px solid #bfb653;
}

.underBrandList ul li {
    margin: 10px;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.3rem;
    line-height: 1.618;
    letter-spacing: .05em;
    color: #8e8e8e;
}

.underBrand p {
    margin-top: 40px;
}

@media screen and (max-width: 767px) {
    .underBrandList {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .underBrandList ul {
        width: 50%;
        margin-bottom: 40px;
    }

    .underBrand p {
        margin-top: 0;
    }
}

/*------------------------

NAIL

------------------------*/
@media only screen and (max-width: 767px) {
    .nailCont .underCont {
        margin-top: 8vh;
    }
}

.nailCont .info {
    margin-top: 4vh;
}

.nailCont .info .title {
    margin-top: 4vh;
}

.nailCont .info ul {
    margin-top: 10px;
    font-size: 1.2rem;
    text-align: left;
    letter-spacing: .1px;
    color: #666666;
}

/*------------------------

EYELASH

------------------------*/
.eyelashCont .menuBox_title {
    width: auto;
}

.eyelashCont .menuBoxInner dd {
    width: auto;
}

.eyelashCont .menuBox_time {
    margin-right: 10px;
}

.eyelashCont .menuBoxInner:nth-child(2) .menuBox_title {
    margin-top: 5px;
    font-family: '游ゴシック Medium', YuGothic, YuGothicM, 'Hiragino Kaku Gothic ProN', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, sans-serif;
    font-size: 1.2rem;
    letter-spacing: .1px;
    color: #666666;
}

.eyelashCont .menuBoxInner:nth-child(2) .menuBox_price {
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', HGS明朝E, メイリオ, Meiryo, serif;
    font-size: 1.2rem;
    letter-spacing: .1px;
    color: #666666;
}

.eyelashCont .info {
    margin-top: 4vh;
}

.eyelashCont .info .title {
    margin-top: 4vh;
}

.eyelashCont .info ul {
    margin-top: 10px;
    font-size: 1.2rem;
    text-align: left;
    letter-spacing: .1px;
    color: #666666;
}

@media screen and (max-width: 767px) {
    .eyelashCont .menuBox .menuBoxInner {
        padding-bottom: 5px;
        flex-direction: row;
        border-bottom: 1px dotted #c0b653;
    }

    .eyelashCont .menuBoxInner dd {
        padding-top: 0;
    }

    .eyelashCont .menuBoxInner:nth-child(2) dd {
        margin-top: 5px;
    }

    .eyelashCont .menuBoxInner:nth-of-type(2) {
        border-bottom: 0;
    }

    .eyelashCont .menuBox_title {
        padding-bottom: 0;
        border-bottom: 0;
    }

    .eyelashCont .menuBoxInner:nth-child(2) .menuBox_title {
        border-bottom: 0;
    }

    .eyelashCont .menuBox_price {
        margin-left: 0;
    }

    .eyelashCont .menuBoxInner:nth-child(2) .menuBox_price {
        margin-top: 0;
    }
}

/*------------------------

HISTORY

------------------------*/
.historyMain .mainCopy.fadeInUp .title span {
    color: #ffffff;
}

.historyMain .underDesc, .historyMain .underDesc02 {
    width: 100%;
    margin: 8vh auto;
}

.historyMain .underDesc > .inner, .historyMain .underDesc02 > .inner {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    align-items: flex-start;
}

.historyMain .underDesc .left {
    width: 64%;
    margin-right: 5.4%;
    opacity: 0;
    position: sticky;
    top: 80px;
    overflow: hidden;
    postion: -webkit-sticky;
}

.historyMain .underDesc02 .right {
    width: 64%;
    margin-top: 15px;
    margin-left: 5.4%;
    opacity: 0;
    position: sticky;
    top: 80px;
    overflow: hidden;
    postion: -webkit-sticky;
}

.historyMain .underDesc .left.animation, .historyMain .underDesc02 .right.animation {
    transition: all ease .5s;
    opacity: 1;
}

.historyMain .underDesc .left .image, .historyMain .underDesc02 .right .image {
    width: 100%;
    height: 40vw;
    transition: all 4s cubic-bezier(.18, .92, .35, 1);
    transform: scale(1.1);
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    position: relative;
}

.historyMain .underDesc .left .image.slideLeft, .historyMain .underDesc02 .right .image.slideLeft {
    transition-delay: 2s;
    transform: scale(1);
}

.historyMain .underDesc .left .image:before, .historyMain .underDesc02 .right .image:before {
    width: 0;
    height: 100%;
    content: '';
    background-color: #ffffff;
    position: absolute;
    top: 0;
    right: 0;
}

.historyMain .underDesc .left .image.slideLeft:before, .historyMain .underDesc02 .right .image.slideLeft:before {
    width: 0;
    transition: all 1s cubic-bezier(.86, 0, .07, 1);
    transition-delay: 1.9s;
}

.historyMain .underDesc .left .image {
    background-image: url(../img/history_img01.jpg);
}

.historyMain .underDesc02 .right .image {
    background-image: url(../img/history_img02.jpg);
}

.historyMain .underDesc .right, .historyMain .underDesc02 .left {
    width: 30%;
    margin-top: 15px;
    opacity: 0;
    top: 140px;
}

.historyMain .underDesc .right.animation, .historyMain .underDesc02 .left.animation {
    margin-top: 0;
    transition: all ease .5s;
    opacity: 1;
}

.historyMain .underDesc .right .title, .historyMain .underDesc02 .left .title {
    margin-top: 6px;
    margin-bottom: 30px;
    font-size: 2.8rem;
    font-weight: 500;
    line-height: 27px;
    letter-spacing: .7px;
}

.historyMain .underDesc .right .title span, .historyMain .underDesc02 .left .title span {
    margin-top: 14px;
    margin-left: 2px;
    display: block;
    font-family: 'Avenir LT W01_35 Light1475496';
    font-size: 1.35rem;
    letter-spacing: .2px;
    color: rgba(125, 125, 125, .6);
}

.historyMain .underDesc .right .desc, .historyMain .underDesc02 .left .desc {
    margin-top: 0;
    font-size: 1.45rem;
    line-height: 38px;
    letter-spacing: .3px;
    opacity: .8;
}

@media screen and (max-width: 1100px) {
    .historyMain .underDesc, .historyMain .underDesc02 {
        width: calc(100% - 30px);
        margin: 0 auto 0;
    }

    .historyMain .underDesc > .inner, .historyMain .underDesc02 > .inner {
        flex-wrap: wrap;
    }

    .historyMain .underDesc .left, .historyMain .underDesc02 .right {
        width: 100%;
        margin-right: initial;
        margin-left: 0;
        padding-top: 8vh;
        position: relative;
        top: 0;
    }

    .historyMain .underDesc .left .image, .historyMain .underDesc02 .right .image {
        height: calc(100vh - 321px);
    }

    .historyMain .underDesc .right, .historyMain .underDesc02 .left {
        width: 100%;
        width: calc(100% - 20.7% + 30px);
        margin: 0 auto 0;
        padding-top: 40px;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        flex-wrap: wrap;
        position: relative;
        top: 0;
    }

    .historyMain .underDesc .right .title, .historyMain .underDesc02 .left .title {
        width: 49%;
        margin-top: 4px;
        margin-bottom: 30px;
        font-size: 2.5rem;
        font-weight: 500;
        line-height: 24px;
        letter-spacing: .03em;
    }

    .historyMain .underDesc .right .title span, .historyMain .underDesc02 .left .title span {
        margin-top: 11px;
        margin-left: 2px;
        display: block;
        font-size: 1.15rem;
        letter-spacing: .2px;
        color: rgba(125, 125, 125, .6);
    }

    .historyMain .underDesc .right .desc, .historyMain .underDesc02 .left .desc {
        width: 100%;
        font-size: 1.45rem;
        line-height: 42px;
        letter-spacing: .025em;
    }
}

@media screen and (max-width: 767px) {
    .historyMain .underDesc, .historyMain .underDesc02 {
        width: calc(100% - 20px);
        margin: 0 auto 0;
    }

    .historyMain .underDesc > .inner, .historyMain .underDesc02 > .inner {
        flex-wrap: wrap;
        flex-flow: column;
    }

    .historyMain .underDesc .left, .historyMain .underDesc02 .right {
        width: 100%;
        margin-right: 0;
        padding-top: 0;
        position: relative;
        top: initial;
    }

    .historyMain .underDesc .left.animation, .historyMain .underDesc02 .right.animation {
        margin-top: 40px;
    }

    .historyMain .underDesc .left .image, .historyMain .underDesc02 .right .image {
        min-height: 150px;
        transform: scale(1);
    }

    .historyMain .underDesc .right, .historyMain .underDesc02 .left {
        width: calc(100% - 43px);
        margin: 19px auto 0;
        padding-top: 28px;
        position: relative;
        top: initial;
    }

    .historyMain .underDesc .right .title, .historyMain .underDesc02 .left .title {
        display: none;
    }

    .historyMain .underDesc .right .desc, .historyMain .underDesc02 .left .desc {
        width: 100%;
        margin-top: 0;
        margin-left: 0;
        padding-bottom: initial;
        font-size: 1.3rem;
        line-height: 30px;
        letter-spacing: .1px;
    }

    .historyMain .underDesc .right .desc:before, .historyMain .underDesc02 .left .desc:before {
        display: none;
    }
}

/*------------------------

COMPANY

------------------------*/
.companyMain .mainCopy.fadeInUp .title span {
    color: #ffffff;
}

.companyMain .underDesc, .companyMain .underDesc02, .companyMain .underDesc03, .companyMain .underDesc04, .companyMain .underDesc05 {
    width: 100%;
    margin: 8vh auto;
}

.companyMain .underDesc > .inner, .companyMain .underDesc02 > .inner, .companyMain .underDesc03 > .inner, .companyMain .underDesc04 > .inner, .companyMain .underDesc05 > .inner {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    align-items: center;
}

.companyMain .underDesc .left {
    width: 60%;
    margin-right: 5.4%;
    opacity: 0;
    position: sticky;
    top: 80px;
    overflow: hidden;
}

.companyMain .underDesc .right {
    width: 40%;
    margin-top: 15px;
    opacity: 0;
    top: 140px;
}

.companyMain .underDesc02 .left, .companyMain .underDesc04 .left {
    width: 45%;
    margin-top: 15px;
    opacity: 0;
    top: 140px;
}

.companyMain .underDesc02 .right, .companyMain .underDesc04 .right {
    width: 55%;
    margin-left: 5.4%;
    opacity: 0;
    position: sticky;
    top: 80px;
    overflow: hidden;
}

.companyMain .underDesc03 .left, .companyMain .underDesc05 .left {
    width: 55%;
    margin-right: 5.4%;
    opacity: 0;
    position: sticky;
    top: 80px;
    overflow: hidden;
}

.companyMain .underDesc03 .right, .companyMain .underDesc05 .right {
    width: 45%;
    margin-top: 15px;
    opacity: 0;
    top: 140px;
}

.companyMain .underDesc .left.animation, .companyMain .underDesc02 .right.animation, .companyMain .underDesc03 .left.animation, .companyMain .underDesc04 .right.animation, .companyMain .underDesc05 .left.animation {
    transition: all ease .5s;
    opacity: 1;
}

.companyMain .underDesc .left .image {
    width: 100%;
    height: 40vw;
    transition: all 4s cubic-bezier(.18, .92, .35, 1);
    transform: scale(1.1);
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    position: relative;
}

.companyMain .underDesc02 .right .image, .companyMain .underDesc03 .left .image, .companyMain .underDesc04 .right .image, .companyMain .underDesc05 .left .image {
    width: 100%;
    height: 27vw;
    transition: all 4s cubic-bezier(.18, .92, .35, 1);
    transform: scale(1.1);
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    position: relative;
}

.companyMain .underDesc .left .image.slideLeft, .companyMain .underDesc02 .right .image.slideLeft, .companyMain .underDesc03 .left .image.slideLeft, .companyMain .underDesc04 .right .image.slideLeft, .companyMain .underDesc05 .left .image.slideLeft {
    transition-delay: 2s;
    transform: scale(1);
}

.companyMain .underDesc .left .image:before, .companyMain .underDesc02 .right .image:before, .companyMain .underDesc03 .left .image:before, .companyMain .underDesc04 .right .image:before, .companyMain .underDesc05 .left .image:before {
    width: 0;
    height: 100%;
    content: '';
    background-color: #ffffff;
    position: absolute;
    top: 0;
    right: 0;
}

.companyMain .underDesc .left .image.slideLeft:before, .companyMain .underDesc02 .right .image.slideLeft:before, .companyMain .underDesc03 .left .image.slideLeft:before, .companyMain .underDesc04 .right .image.slideLeft:before, .companyMain .underDesc05 .left .image.slideLeft:before {
    width: 0;
    transition: all 1s cubic-bezier(.86, 0, .07, 1);
    transition-delay: 1.9s;
}

.companyMain .underDesc .left .image {
    background-image: url(../img/company_img01.jpg);
}

.companyMain .underDesc02 .right .image {
    background-image: url(../img/company_img02.jpg);
}

.companyMain .underDesc03 .left .image {
    background-image: url(../img/company_img03.jpg);
}

.companyMain .underDesc04 .right .image {
    background-image: url(../img/company_img04.jpg);
}

.companyMain .underDesc05 .left .image {
    background-image: url(../img/company_img05.jpg);
}

.companyMain .underDesc .right.animation, .companyMain .underDesc02 .left.animation, .companyMain .underDesc03 .right.animation, .companyMain .underDesc04 .left.animation, .companyMain .underDesc05 .right.animation {
    margin-top: 0;
    transition: all ease .5s;
    opacity: 1;
}

.companyMain .underDesc .right .desc, .companyMain .underDesc02 .left .desc, .companyMain .underDesc03 .right .desc, .companyMain .underDesc04 .left .desc, .companyMain .underDesc05 .right .desc {
    margin-top: 0;
    font-size: 1.45rem;
    line-height: 38px;
    letter-spacing: .3px;
    opacity: .8;
}

.underCompany dl {
    display: flex;
}

.underCompany dl dt {
    width: 120px;
    font-size: 14px;
    letter-spacing: .3px;
    position: relative;
}

.underCompany dl dt:after {
    content: '|';
    position: absolute;
    top: 0;
    right: 20px;
}

.underCompany dl dd {
    font-size: 14px;
    letter-spacing: .2px;
}

.underCompany dl + dl {
    margin-top: 20px;
}

.businessList li + li {
    margin-top: 10px;
}

.underHistory dl {
    display: flex;
}

.underHistory dl dt {
    width: 220px;
    font-size: 14px;
    letter-spacing: .3px;
    position: relative;
}

.underHistory dl dd {
    font-size: 14px;
    letter-spacing: .2px;
}

.underHistory dl + dl {
    margin-top: 20px;
}

.companyMain #page_top {
    width: 80px;
    height: 96px;
    animation: fwari 1.2s ease-in-out 0s infinite alternate;
    position: fixed;
    z-index: 1;
    right: 8vw;
    bottom: -80px;
}

.companyMain #page_top a {
    width: 80px;
    height: 96px;
    display: block;
    text-decoration: none;
    position: relative;
}

.companyMain #page_top a:hover {
    animation: slide-top .5s cubic-bezier(.250, .460, .450, .940) both;
}

@keyframes fwari {
    0% {
        transform: translate(0%, 0%);
    }

    100% {
        transform: translate(0%, -10px);
    }
}

@-webkit-keyframes fwari {
    0% {
        -webkit-transform: translate(0%, 0%);
    }

    100% {
        -webkit-transform: translate(0%, -10px);
    }
}

@-moz-keyframes fwari {
    0% {
        -moz-transform: translate(0%, 0%);
    }

    100% {
        -moz-transform: translate(0%, -10px);
    }
}

@-webkit-keyframes slide-top {
    0% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }

    100% {
        -webkit-transform: translateY(-20px);
        transform: translateY(-20px);
    }
}

@keyframes slide-top {
    0% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }

    100% {
        -webkit-transform: translateY(-20px);
        transform: translateY(-20px);
    }
}

@media screen and (max-width: 1100px) {
    .companyMain .underDesc, .companyMain .underDesc02, .companyMain .underDesc03, .companyMain .underDesc04, .companyMain .underDesc05 {
        width: calc(100% - 30px);
        margin: 0 auto 0;
    }

    .companyMain .underDesc > .inner, .companyMain .underDesc02 > .inner, .companyMain .underDesc03 > .inner, .companyMain .underDesc04 > .inner, .companyMain .underDesc05 > .inner {
        flex-wrap: wrap;
    }

    .companyMain .underDesc .left, .companyMain .underDesc02 .right, .companyMain .underDesc03 .left, .companyMain .underDesc04 .right, .companyMain .underDesc05 .left {
        width: 100%;
        margin-right: initial;
        margin-left: 0;
        padding-top: 8vh;
        position: relative;
        top: 0;
    }

    .companyMain .underDesc .left .image, .companyMain .underDesc02 .right .image, .companyMain .underDesc03 .left .image, .companyMain .underDesc04 .right .image, .companyMain .underDesc05 .left .image {
        height: calc(100vh - 321px);
    }

    .companyMain .underDesc .right, .companyMain .underDesc02 .left, .companyMain .underDesc03 .right, .companyMain .underDesc04 .left, .companyMain .underDesc05 .right {
        width: 100%;
        width: calc(100% - 20.7% + 30px);
        margin: 0 auto 0;
        padding-top: 40px;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        flex-wrap: wrap;
        position: relative;
        top: 0;
    }

    .companyMain .underDesc .right .desc, .companyMain .underDesc02 .left .desc, .companyMain .underDesc03 .right .desc, .companyMain .underDesc04 .left .desc, .companyMain .underDesc05 .right .desc {
        width: 100%;
        font-size: 1.45rem;
        line-height: 42px;
        letter-spacing: .025em;
    }
}

@media screen and (max-width: 767px) {
    .companyMain .underDesc, .companyMain .underDesc02, .companyMain .underDesc03, .companyMain .underDesc04, .companyMain .underDesc05 {
        width: calc(100% - 20px);
        margin: 0 auto 0;
    }

    .companyMain .underDesc > .inner, .companyMain .underDesc02 > .inner, .companyMain .underDesc03 > .inner, .companyMain .underDesc04 > .inner, .companyMain .underDesc05 > .inner {
        flex-wrap: wrap;
        flex-flow: column;
    }

    .companyMain .underDesc .left, .companyMain .underDesc02 .right, .companyMain .underDesc03 .left, .companyMain .underDesc04 .right, .companyMain .underDesc05 .left {
        width: 100%;
        margin-right: 0;
        padding-top: 0;
        position: relative;
        top: initial;
    }

    .companyMain .underDesc .left.animation, .companyMain .underDesc02 .right.animation, .companyMain .underDesc03 .left.animation, .companyMain .underDesc04 .right.animation, .companyMain .underDesc05 .left.animation {
        margin-top: 40px;
    }

    .companyMain .underDesc .left .image, .companyMain .underDesc02 .right .image, .companyMain .underDesc03 .left .image, .companyMain .underDesc04 .right .image, .companyMain .underDesc05 .left .image {
        min-height: 150px;
        transform: scale(1);
    }

    .companyMain .underDesc .right, .companyMain .underDesc02 .left, .companyMain .underDesc03 .right, .companyMain .underDesc04 .left, .companyMain .underDesc05 .right {
        width: 100%;
        margin: 19px auto 0;
        padding-top: 28px;
        position: relative;
        top: initial;
    }

    .companyMain .underDesc .right .desc, .companyMain .underDesc02 .left .desc, .companyMain .underDesc03 .right .desc, .companyMain .underDesc04 .left .desc, .companyMain .underDesc05 .right .desc {
        width: 100%;
        margin-top: 0;
        margin-left: 0;
        padding-bottom: initial;
        font-size: 1.3rem;
        line-height: 30px;
        letter-spacing: .1px;
    }

    .companyMain .underDesc .right .desc:before, .companyMain .underDesc02 .left .desc:before, .companyMain .underDesc03 .right .desc:before, .companyMain .underDesc04 .left .desc:before, .companyMain .underDesc05 .right .desc:before {
        display: none;
    }

    .underCompany dl {
        flex-direction: column;
    }

    .underCompany dl dt {
        width: 100%;
        font-weight: 600;
    }

    .underCompany dl dt:after {
        content: '';
    }

    .underCompany dl dd {
        margin-top: 5px;
    }

    .businessList li + li {
        margin-top: 0;
    }

    .underHistory dl {
        flex-direction: column;
    }

    .underHistory dl dt {
        width: 100%;
        font-weight: 600;
    }

    .underHistory dl dd {
        margin-top: 5px;
    }

    .companyMain #page_top {
        right: 10px;
    }

    .companyMain #page_top, .companyMain #page_top a:hover {
        animation: none;
    }
}

/*------------------------

CONTACT

------------------------*/
.contactMain .form {
    width: 800px;
    margin: auto;
    padding-top: 8vh;
}

.contactMain .formCont {
    display: flex;
    align-items: center;
}

.contactMain .formTitle {
    width: 20%;
    font-size: 1.3rem;
    letter-spacing: -0.1px;
    text-align: right;
}

.contactMain .formInput {
    width: 80%;
    padding-left: 40px;
}

.contactMain .formCont + .formCont {
    margin-top: 34px;
}

.contactMain .formCont input {
    font-size: 1.3rem;
    letter-spacing: 0.4px;
    width: calc(100% - 15px);
    line-height: 60px;
    padding-left: 15px;
    border: 1px solid #dcdcdc;
    background-color: #fdfdfd;
    outline: none;
    transition: all ease .35s;
    border-radius: 0;
    -webkit-appearance: none;
}

.contactMain .formCont textarea {
    font-size: 1.3rem;
    letter-spacing: 0.4px;
    width: calc(100% - 15px);
    height: calc(100% - 15px);
    padding-left: 15px;
    padding-top: 15px;
    padding-bottom: 15px;
    border: 1px solid #dcdcdc;
    background-color: #fdfdfd;
    outline: none;
    transition: all ease .35s;
    border-radius: 0;
    -webkit-appearance: none;
}

.contactMain .btnList input {
    font-size: 1.4rem;
    font-weight: 600;
    letter-spacing: 0px;
    color: #fff;
    width: 102%;
    margin-left: -1%;
    line-height: 60px;
    border: none;
    background-color: #161616;
    outline: none;
    border-radius: 0;
    border-radius: 32px;
}

.text_contact01 {
    padding: 20px 0 20px;
    text-align: center;
    line-height: 2;
}

.text_contact01 h2 {
    padding: 20px 0 10px;
    font-size: 115%;
    line-height: 0;
    font-weight: 600;
}

.text_contact01 input {
    margin: 0 5px 5px;
}

.text_contact02 {
    width: 800px;
    height: 200px;
    margin: 20px auto;
    padding: 20px;
    border: 1px solid #dcdcdc;
    overflow: auto;
    background: #fdfdfd;
}

.text_contact02 p {
    margin: 0 0 10px;
    text-align: left;
    font-size: 100%;
}

@media screen and (max-width: 1100px) {
    .contactMain .form {
        width: 100%;
        padding-top: 0;
    }

    .contactMain .formTitle {
        font-size: 1.15rem;
        letter-spacing: 0px;
        margin-bottom: 17px;
    }

    .contactMain .formCont + .formCont {
        margin-top: 36px;
    }

    .contactMain .formCont input {
        font-size: 1.3rem;
        letter-spacing: 0.4px;
        width: calc(100% - 15px);
        line-height: 55px;
        padding-left: 15px;
    }

    .contactMain .formCont textarea {
        height: 24em;
    }

    .contactMain .btnList {
        margin-top: 44px;
        width: 103%;
        margin-left: -1.5%;
    }

    .contactMain .btnList input {
        width: 100%;
        margin-left: 0%;
    }

    .text_contact01 {
        text-align: left;
        line-height: 1.618;
        padding: 0 0 20px;
    }

    .text_contact01 h2 {
        font-size: 108%;
        margin-top: 20px;
    }

    .text_contact02 {
        width: 100%;
        margin-top: 20px;
        padding: 15px;
    }

    .text_contact02 p {
        font-size: 93%;
    }
}

@media screen and (max-width: 767px) {
    .contactMain .form {
        padding-top: 8vh;
    }

    .contactMain .formCont {
        flex-direction: column;
    }

    .contactMain .formTitle {
        width: 100%;
        font-size: 1.1rem;
        letter-spacing: 0.2px;
        margin-bottom: 12px;
        text-align: left;
    }

    .contactMain .formInput {
        width: 100%;
        padding-left: 0;
    }

    .contactMain .formCont + .formCont {
        margin-top: 25px;
    }

    .contactMain .formCont input {
        font-size: 1.3rem;
        letter-spacing: 0.4px;
        width: 100%;
        line-height: 42px;
        padding-left: 15px;
    }

    .contactMain .formCont textarea {
        height: 15em;
        width: 100%;
    }

    .contactMain .btnList {
        margin-top: 33px;
    }

    .contactMain .btnList input {
        font-size: 1.2rem;
        letter-spacing: 0.4px;
        border-radius: 29px;
        line-height: 53px;
    }
}
