@charset "utf-8"; 
@font-face {
    font-family: "LibreBaskerville-Bold";
    src: url("../fonts/LibreBaskerville-Bold.ttf") format("truetype");
}
@font-face {
    font-family: "LibreBaskerville-Regular";
    src: url("../fonts/LibreBaskerville-Regular.ttf") format("truetype");
}

/*start 共通*/
html{
    font-size:calc(1000px / 62);
    min-height:0;
}
@media (max-width:1000px){
    html{
        font-size:calc(100vw / 62);
    }   
}

@media (max-width:768px){
    html{
        font-size:calc(100vw / 48);
    }
}

@media (max-width:480px){
    html{
        font-size:calc(100vw / 34);
    }
}


@media (min-width:481px){ .show-S{ display:none !important; } }
@media (min-width:769px){ .show-MS{ display:none !important; } }
@media (min-width:769px) and (max-width:480px){ .show-M{ display:none !important; } }
@media (max-width:480px){ .show-LM{ display:none !important; } }
@media (max-width:768px){ .show-L{ display:none !important; } }


* {
    box-sizing: border-box;
    font-family: sans-serif;
    -webkit-touch-callout:none;
    -webkit-tap-highlight-color:transparent;
}

body {
    color: #000000;
}

a {
    color: inherit;
    text-decoration: none;
}

body,p {
    margin: 0;
    font-size: 1rem;
}
section{
    background-color: #fff;
}

h1,h2,h3,h4,h5,h6 {
    font-weight: normal;
    margin:0;
    line-height: 1;
    font-size:inherit;
}

.image {
    display: inline-block;
    vertical-align: bottom;
    max-width: 100%;
}
.image a{
    display:block;
    vertical-align:bottom;
    width:100%;
}
.imageh{
    display: inline-block;
    vertical-align: bottom;
    height:100%;
}
.imageh a{
    height:100%;
}
.imageh img{
    height:100%;
}

.image img {
    width: 100%;
    display: block;
}

.image-base {
    position: relative;
    background-color: rgba(255,255,255,0.3);
}

.image-base img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.image-base a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
}

img {
    vertical-align: bottom;
}

ul {
    list-style: none;
    padding: 0;
    margin: 0;
}


[href^="tel:"] {
    color: inherit;
    font-size: inherit;
}

.flex-box {
    display: flex;
    flex-wrap: wrap;
}
.skn-bold{
    font-weight:bold;
}
.skn-red{
    color:#f00;
}

/*[href]{
    opacity:1;
    transition:opacity 0.3s ease;
}
[href]:hover{
    opacity:0.5;
}*/

[data-smooth]{
    cursor:pointer;
}
span{
    font-family:inherit;
}
.logo-image{
    position:absolute;
    left:3rem;
    top:1.5rem;
    width:9.5%;
    z-index: 100;
}
@media (max-width:768px){
    .logo-image{
        top: 0.5rem;
        left: 0.5rem;
        width:18%;
    }
}


.first-image{
    position:relative;
    width:100%;
    padding-top:calc((100% / 1920) * 1214);
}
@media (max-width:768px){
    .first-image{
        padding-top:calc((100% / 768) * 618);
    }   
}
.first-image > img{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
}

.inner-width{
    max-width:1000px;
    margin:0 auto;
    padding:0 1rem;
}

.h2_title h2{
    font-family: "LibreBaskerville-Bold",serif;
    font-weight:bold;
    font-size:3rem;
    text-align:center;
}
.h2_title h2 span + span{
    font-size:0.5em;
    display:block;
    margin-top:1.25rem;
    letter-spacing:0.2rem;
}

.title_img-image{
    height: 1.86rem;
}

.sub_title{
    margin-top:1.5rem;
    font-family: "LibreBaskerville-Bold",serif;
    letter-spacing:0.05rem;
    font-weight:bold;
    border-bottom:1px solid #ff0001;
    padding-left:1.5rem;
    /* text-align:center; */
}

.toggle_image-warp{
    position:relative;
}
.toggle-image{
    position:absolute;
    top:0;
    left:0;
    opacity:0;
    width:100%;
    transition:opacity 0.2s ease;
}
.parts-image:hover .toggle-image{
    opacity:1;
}

.parts-text{
    text-align:center;
    margin-top:0.25rem;
    font-family: "LibreBaskerville-Regular";
}
.price-row table{
    width:100%;
    border-collapse:collapse;
}
.price-row table tr td,
.price-row table tr th{
    padding:0.25rem 0;
    border-bottom:1px solid #888;
    font-family: "LibreBaskerville-Regular";
}
.price-row table tr th{
    border-top:1px solid #888;
    text-align:right;
    padding-right:2rem;
}
.price-row table tr td:last-child{
    padding-left:1rem;
    font-size: 0.8em;
}
.price-row table tr td.price{
    text-align:right;
}
[data-price-text]{
    font-size:0.8em;
    margin-left:0.1rem;
}


.model{
    background-color: #2e2e2e;
}
.model h3{
    color:#fff;
    font-size:1.5rem;
    text-align:center;
    padding-top: 5rem;
}

.button-row{
    text-align:center;
}
.button-box{
    border:1px solid #fff;
    color:#fff;
    display:inline-flex;
    border-radius:1rem;
    margin: 1rem 0 3rem 0;
}
.button-box > a{
    padding:0.2rem 1rem;
    display:block;
    width:12rem;
    letter-spacing:0.1rem;
    cursor: pointer;
    color: #555;
}
.button-box > .front-btn{
    border-radius:1rem 0 0 1rem;
}
.button-box > .rear-btn{
    border-radius:0 1rem 1rem 0;
}

[data-active="1"] > div > a:first-child,
[data-active="2"] > div > a:last-child{
    background-color:#fff;
    color:#000;
}
[data-active="1"] + div > div > img:last-child,
[data-active="2"] + div > div > img:first-child{
    opacity:0;
}
[data-active="1"] + div > div > img:first-child,
[data-active="2"] + div > div > img:last-child{
    opacity:1;
}

.model-image img{
    transition:opacity 0.5s ease;
}


footer.background-show:before{
    background-image:url(../../img/footer.jpg) !important;
    background-position: center ;
  }






.space_5{
	height:8rem;
    width:100%;
    background-color: #fff;
}
.space_3{
	height:3rem;
    width:100%;
    background-color: #fff;
}
@media (max-width:480px){
    .space_3{
		height:2rem;
	}
}





#partsImage{
    /* background-color: #2e2e2e; */
}

.button2-row{
    text-align:center;
}
.button2-box{
    border:1px solid #2e2e2e;
    color:#2e2e2e;
    display:inline-flex;
    border-radius:1rem;
    margin: 5rem 0 3rem 0;
}
.button2-box > a{
    padding:0.2rem 1rem;
    display:block;
    width:12rem;
    letter-spacing:0.1rem;
    cursor: pointer;
}
.button2-box > .front-btn{
    border-radius:1rem 0 0 1rem;
}
.button2-box > .rear-btn{
    border-radius:0 1rem 1rem 0;
}

[data-active2="1"] > div > a:last-child,
[data-active2="2"] > div > a:first-child{
    background-color:#2e2e2e;
    color: #777;
}
[data-active2="1"] + div > div > img:last-child,
[data-active2="2"] + div > div > img:first-child{
    opacity:0;
}
[data-active2="1"] + div > div > img:last-child,
[data-active2="2"] + div > div > img:first-child{
    opacity:1;
}



[data-active3="1"] > div > a:first-child,
[data-active3="2"] > div > a:last-child{
    background-color:#fff;
    color:#000;
}

[data-active3="1"] > div > a:last-child,
[data-active3="2"] > div > a:first-child{
    background-color:#2e2e2e;
    /* color:#fff; */
}
[data-active3="1"] + div > div > img:last-child,
[data-active3="2"] + div > div > img:first-child{
    opacity:0;
}
[data-active3="1"] + div > div > img:last-child,
[data-active3="2"] + div > div > img:first-child{
    opacity:1;
}


#parts_detail h4{
    font-family:serif;
    font-weight:bold;
    font-size: 1.5rem;
}

#parts_detail h4 + p{
    font-family:serif;
    /* font-weight: bold; */
    letter-spacing:-0.1rem;
    margin-top:1.5rem;
}

.parts_detail-box{
    display:flex;
    align-items:center;
    padding:1rem;
    border:1px solid #000;
}
.parts_detail-box > .item_1{
     width: 42%;
     padding-right: 2rem;
     padding-left: 0.5rem;
}
.parts_detail-box > .item_2{
     width: 58%;
}
@media (max-width:768px){
     .parts_detail-box{
         flex-wrap:wrap;
     }
    .parts_detail-box > .item{
        width:calc((100% - 1rem) / 1);
    }
    .parts_detail-box > .item_1{
        padding:2rem 0;
    }
    .parts_detail-box > .item_2{
        margin-top:1rem;
    }
}

.parts_image-box{
    display:flex;
    flex-wrap:wrap;
    justify-content: space-between;
}
.parts_image-box > .item{
    width:calc((100% - 1rem) / 2);
}
.parts_image-box > .item:nth-child(n + 3){
    margin-top:1rem;
}


.tail-row{
    margin-top:2rem;
}
.tail-box{
    display:flex;
    flex-wrap:wrap;
    justify-content: space-between;
    background-color:#f2f2f2;
    padding:1rem;
    
}
.tail-box span,
.tail-box div{
    font-family: serif;
}
.tail-box .tail-name{
    margin-top:0.5rem;
    letter-spacing: 0.05rem;
}
.tail-box .small{
    font-size:0.7rem;
    margin-left:0.25rem;
    letter-spacing: 0.1rem;;
}
.tail-box > .item_1,
.tail-box > .item_2{
    width: calc(36% - 1rem);
}
.tail-box > .item_3{
    width: 28%;
}
@media (max-width:480px){
    .tail-box > .item{
        width:calc((100% - 0rem) / 1);
    }
    .tail-box > .item_1,
    .tail-box > .item_2{
        width: calc(50% - 0.5rem);
    }
    .tail-box > .item_3{
        margin-top:1rem;
    }
}