 /* COMMON */
.contents { padding: 120px 0px 150px; }

.sub-visual-container{
    overflow: hidden; padding-top:70px; height: 340px; background-repeat: no-repeat; background-position: center; background-size: cover;
    -webkit-animation: visualFadeIn .4s ease-in-out .1s forwards; animation: visualFadeIn .4s ease-in-out .1s forwards; opacity: 0;
}
.sub-visual-wrapper {
    display: flex;
    align-items: center;
    height: 100%;
}
.sub-visual-wrapper .container{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.sub-visual-container .title {
    z-index: 2;
    position: relative;
    line-height: 1;
    font-size: 5.0rem;
    font-weight: 700;
    color: #fff;
    transition: all 0.3s ease;
}

.sub-visual-container .title small { display: block; margin-bottom: 15px; font-size: 14px; color: #bcc5df; font-weight: 300; letter-spacing: 0.2em; }
.sub-visual-container p{
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.6;
    color: #fff;
    text-align: right;
    text-shadow: 0 0 5px #333;
    transition: all 0.3s ease;
}

.sv, .sv1 { background-image: url('/child/img/sub/sv1.png'); }
.sv2 { background-image: url('/child/img/sub/sv2.png'); }
.sv3 { background-image: url('/child/img/sub/sv3.png'); }
.sv4 { background-image: url('/child/img/sub/sv4.png'); }
.sv5 { background-image: url('/child/img/sub/sv5.png'); }
@-webkit-keyframes visualFadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}
@keyframes visualFadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}
@media (max-width: 1200px){
}
@media (max-width: 1024px){
    .contents {padding:80px 0px 100px;}

    .sub-visual-container{height:200px; padding-top: 0;}
    .sub-visual-container .title { font-size: 3.4rem; }
    .sub-visual-container .title small { font-size: 1.3rem; }
    .sub-visual-container p {font-size: 1.6rem;}
}
@media (max-width: 768px){
    .contents {padding:60px 0px 80px;}

    .sub-visual-container{height:150px;}
    .sub-visual-wrapper .container{
        flex-direction: column;
        justify-content: flex-start;
        text-align: center;
    }
    .sub-visual-container .title { font-size: 2.4rem; }
    .sub-visual-container .title small { margin-bottom: 10px; font-size: 1.1rem; }
    .sub-visual-container p {font-size: 1.4rem; font-weight: 400; text-align: center; margin-top:10px;}
    .sub-visual-container p, .sub-visual-container p span{color: rgba(255, 255, 255, .8) !important;}
}

/* sub top */
.sub-top, .sub-top .container{
    min-height:70px;
}
.sub-top{
    border-bottom:1px solid #e1e1e1;
}
.sub-top .container{
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.sub-tab-container { z-index: 2; position: relative; }
.sub-tab-lists {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -30px;
}
.sub-tab-lists li {
    position: relative;
}
.sub-tab-lists li:first-child:before{display:none;}
.sub-tab-lists .link{
    display: flex; align-items: center; justify-content: center; position: relative;
    padding: 0 30px; height: 70px;
    line-height: 1.4; text-align: center;
    font-size: 1.6rem; color: #777;
    background-color: transparent;
    -webkit-transition: all ease-out .3s; transition: all ease-out .3s;
}
.sub-tab-lists .link span{
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}
.sub-tab-lists .link span::before{
    content: ''; position: absolute; bottom: 0; left: 0;
    width: 100%; height: 3px; background: transparent;
    -webkit-transition: all ease-out .3s; transition: all ease-out .3s;
    -webkit-transform-origin: bottom; transform-origin: bottom;
    -webkit-transform: scaleY(0); transform: scaleY(0);
}
.sub-tab-lists .link--on { font-weight: 600; color: #111;}
.sub-tab-lists .link--on span::before{
    background: #f47421;
    -webkit-transform: scaleY(1); transform: scaleY(1);
}
@media(min-width:1024px){
    .sub-tab-lists .link:hover{
        color:#f47421;
    }
}
@media (max-width:1024px){
    .sub-top, .sub-top .container{
        min-height:auto;
    }
    .sub-tab-lists{ margin:0 -15px; }
    .sub-tab-lists .link { height:50px; font-size: 1.4rem; }
    .sub-tab-lists .link {padding:0 15px;}
}
@media (max-width:768px){
}

/* breadcrumb */
.breadcrumb{
    margin-left: auto;
}
.breadcrumb ul{
    display: flex;
    align-items: center;
}
.breadcrumb ul li{
    font-size: 1.4rem;
    font-weight: 500;
    color:#777;
}
@media (max-width:1024px){
    .breadcrumb{display:none;}
}
@media (max-width:768px){
}
@media (max-width:576px){
}


.page-section{
    padding:60px 0;
}
.page-section--first{
    padding-top: 120px;
    margin-top:-120px;
}
.page-section--last{
    padding-bottom:150px;
    margin-bottom:-150px;
    position: relative;
    z-index: 1
}

.page-section--last2{
    padding-bottom: 70px;
}

.technique-img2{padding-bottom: 200px;}

@media (max-width:1024px){
    .page-section--first{
        padding-top: 80px;
        margin-top:-80px;
    }
    .page-section--last{
        padding-bottom:100px;
        margin-bottom:-100px;
    }

    .technique-img2{padding-bottom: 0;}
}
@media (max-width:992px){
}
@media (max-width:768px){
    .page-section{
        padding:40px 0;
    }
    .page-section--first{
        padding-top: 60px;
        margin-top:-60px;
    }
    .page-section--last{
        padding-bottom:80px;
        margin-bottom:-80px;
    }
}
@media (max-width:576px){
}

/* Greeting */
.greeting-img{
    margin-left: -380px;
}

.greeting-img-en{
    height: 100%;
}
.greeting-img-en img{
    height: 100%; position: relative; top: 30px;
}

@media (max-width:1200px){
    .greeting-img{
        margin-left:0;
    }
    .greeting-img-en img{top: 0}
}
@media (max-width:992px){
}
@media (max-width:768px){
}
@media (max-width:576px){
}

/* History */
.history-items{
    margin:-10px 0;
}
.history-item{
    display: flex;
    flex-wrap: wrap;
    padding:10px 0;
}
.history-item__left{
    width: 410px;
    padding-right: 26px;
}
.history-item__year-lg{
    font-size: 3.2rem;
    font-weight: 600;
    color: #f47421;
    padding-bottom: 4px;
    border-bottom: 1px solid #f47421;
}
.history-item__right{
    width: calc(100% - 410px);
    padding-top: 42px;
}
.history-item__con{
    position: relative;
    padding-top: 4px;
    padding-left: 100px;
}
.history-item__con + .history-item__con{
    margin-top: 15px;
}
.history-item__date{
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
}
.history-item__year{
    font-size: 2.2rem;
    font-weight: 600;
    padding-right: 15px;
}
.history-item__month{
    font-size: 1.6rem;
    font-weight: 600;
    color: #f47421;
}
@media (max-width:1024px){
    .history-item__left{
        width: 300px;
    }
    .history-item__right{
        width: calc(100% - 300px);
    }
}
@media (max-width:992px){
}
@media (max-width:768px){
    .history-items{
        margin: -15px 0;
    }
    .history-item{
        padding:15px 0;
    }
    .history-item__left, .history-item__right{
        width: 100%;
    }
    .history-item__year-lg{
        font-size: 2.2rem;
    }
    .history-item__right{
        padding-top: 10px;
    }
    .history-item__con + .history-item__con{
        margin-top: 5px;
    }
    .history-item__con{
        padding-left: 80px;
    }
    .history-item__year{
        font-size: 1.8rem;
        padding-right: 10px;
    }
    .history-item__month{
        font-size: 1.4rem;
    }
}
@media (max-width:576px){
}

/* Location*/
.location-map{
    position: relative;
    z-index: 1;
    width: 100%;
    padding-top: 100%;
    border-radius: 20px;
    margin-bottom: -470px;
    overflow: hidden;
}
.location-map iframe{
    position: absolute;
    top:0;
    left: 0;
}
@media (max-width:1024px){
}
@media (max-width:992px){
}
@media (max-width:768px){
    .location-map{
        margin:0 auto 10px;
    }
}
@media (max-width:576px){
}

/* Technique */
.technique-tit{
    padding-bottom: 20px;
    margin-right: 50px;
    border-bottom: 1px solid #f47421;
}
.technique-img{
    margin-top: -330px;
    margin-bottom: -400px;
}
@media (max-width:1024px){
    .technique-tit{
        margin-right: 0;
    }
    .technique-img{
        margin: 15px 0 0;
    }
    .technique-img img{
        width: 30%;
    }
}
@media (max-width:992px){
}
@media (max-width:768px){
    .technique-img img{
        width: 40%;
    }
}
@media (max-width:576px){
    .technique-img img{
        width: 60%;
    }
}

/* Brand */
#vue-app .brand-row{
    margin:-30px;
}
#vue-app .brand-row [class*="col-"]{
    display: flex;
    align-items: center;
    justify-content: center;
    padding:30px;
}
@media (max-width:1024px){
    #vue-app .brand-row{
        margin:-15px;
    }
    #vue-app .brand-row [class*="col-"]{
        padding:15px;
    }
}
@media (max-width:992px){
}
@media (max-width:768px){
    #vue-app .brand-row{
        margin:-12px;
    }
    #vue-app .brand-row [class*="col-"]{
        padding:12px;
    }
}
@media (max-width:576px){
}

.warranty-con{
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    padding-left: 25px;
}
.text-item{
    padding: 20px 0;
    border-bottom: 1px solid #e1e1e1;
}
@media (max-width:1024px){
}
@media (max-width:992px){
}
@media (max-width:768px){
    .warranty-con{
        padding-left: 0;
        margin-top:10px;
    }
    .text-item{
        padding: 15px 0;
    }
}
@media (max-width:576px){
}
