@charset "UTF-8";
.product {
    max-width: 93%;
    width: 100%;
    margin: 0 auto;
    border-left: 1px solid #a0a0a0;
    border-right: 1px solid #a0a0a0;
}
@media screen and (max-width:768px) {
.product {
  max-width: 100%;
}
}
/*.product .mv-ttl {
  width: 100%;
  margin: 0 auto;
}

.product .mv-lead {
  width: 61.5%;
  margin: 8.3% auto 0;
}

.product .mv-txt {
  width: 61%;
  margin: 2.7% auto 0;
}*/
.product .mv {
    position: relative;
    z-index: 0;
}
.product .mv .mv_ttl {
    position: absolute;
    top: 50%;
    right: 5.5%;
    transform: translateY(-50%);
    font-size: calc(42.52 / 1800 * 100vw);
    font-weight: bold;
    line-height: 1.75;
    letter-spacing: .08em;
    color: #5a322a;
	/*text-shadow: 0 0 1px #5a322a;*/
}
.product .mv .mv_ttl .dec_en {
    letter-spacing: .28em;
    font-weight: bold;
}
@media screen and (max-width:768px) {
    .product .mv .mv_ttl {
        display: none;
        position: absolute;
        right: auto;
        width: 100%;
        text-align: center;
        left: 50%;
        transform: translate(-50%, -50%);
        font-size: calc(38 / 640 * 100vw);
        line-height: 1.6;
        letter-spacing: .1em;
        color: #fff;
    }
    .product .mv .mv_ttl .dec_en {
        letter-spacing: .3em;
    }
}
.product .mv_lead {
    width: calc(1030 / 1800 * 100vw);
    margin: calc(142 / 1800 * 100vw) auto calc(122 / 1800 * 100vw);
}
.product .mv_lead .lead_ttl {
    font-size: calc(35.52 / 1800 * 100vw);
    font-weight: bold;
    line-height: 1;
    letter-spacing: .08em;
    color: #5a322a;
    margin-bottom: calc(30 / 1800 * 100vw);
	/*text-shadow: 0 0 1px #5a322a;*/
}
.product .mv_lead .lead_ttl .dec01 {
    font-weight: bold;
    letter-spacing: .16em;
	margin-right: .3em;
}
.product .mv_lead p {
    font-size: calc(26 / 1800 * 100vw);
    font-weight: 500;
    color: #5a322a;
    line-height: 2.0;
    letter-spacing: 0;
    font-feature-settings: "palt";
    margin-bottom: calc(16 / 1800 * 100vw);
}
.mv_lead p.cap {
    font-size: calc(18 / 1800 * 100vw);
    letter-spacing: -.06em;
    margin-bottom: 0;
}
@media screen and (max-width:768px) {
    .product .mv_lead {
        margin: calc(133 / 640 * 100vw) auto calc(158 / 640 * 100vw);
        width: calc(550 / 640 * 100vw);
    }
    .product .mv_lead .lead_ttl {
        font-size: calc(35 / 640 * 100vw);
        font-weight: bold;
        text-align: center;
        line-height: 1.857;
        letter-spacing: .08em;
        color: #5a322a;
        margin-bottom: calc(48 / 640 * 100vw);
    }
	.product .mv_lead .lead_ttl .dec01 {
	margin-right: 0;
}

    .product .mv_lead p {
        width: 100%;
        font-size: calc(25 / 640 * 100vw);
        line-height: 2.260;
        letter-spacing: .00em;
        margin-bottom: calc(22 / 640 * 100vw);
    }
    .mv_lead p.cap {
        font-size: calc(18 / 640 * 100vw);
        letter-spacing: -.06em;
        line-height: 1.78;
        margin-bottom: 0;
    }
}
.product_content {
    width: calc(1400 / 1800 * 100vw);
    margin: 0 auto !important;
    display: flex;
    flex-flow: wrap;
    justify-content: space-between;
    gap: calc(72 / 1800 * 100vw) 0;
}
.product_content li {
    width: 22.64%;
}
.product_content li .no {
    font-size: calc(20 / 1800 * 100vw);
    font-weight: bold;
    letter-spacing: .1em;
    margin-bottom: calc(7 / 1800 * 100vw);
	/*text-shadow: 0 0 1px #313131;*/
}
.product_content li h4 {
    position: relative;
    z-index: 0;
    font-size: calc(17 / 1800 * 100vw);
    padding: 0 0 calc(4 / 1800 * 100vw) calc(13 / 1800 * 100vw);
    margin-top: calc(17 / 1800 * 100vw);
	letter-spacing: -.05em;
}
.product_content li h4::after {
    content: "";
    display: block;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    width: calc(6 / 1800 * 100vw);
    height: 100%;
    border: 1px solid #313131;
}
.product_content li h4 .dec01 {
    display: block;
    font-weight: bold;
    margin-top: .294em;
	/*text-shadow: 0 0 .5px #313131;*/
}
@media screen and (max-width: 768px) {
    .product_content {
        width: calc(590 / 640 * 100vw);
        gap: calc(53 / 640 * 100vw) 0;
    }
    .product_content li {
        width: 47.46%;
    }
    .product_content li .no {
        font-size: calc(20 / 640 * 100vw);
        margin-bottom: calc(5 / 640 * 100vw);
    }
    .product_content li figure {
        aspect-ratio: 283 / 244;
        border-radius: calc(8 / 640 * 100vw);
        overflow: hidden;
    }
    .product_content li figure img {
        object-fit: cover;
        height: 100%;
    }
    .product_content li h4 {
        position: relative;
        z-index: 0;
        font-size: calc(16 / 640 * 100vw);
        padding: 0 0 calc(4 / 640 * 100vw) calc(14 / 640 * 100vw);
        margin-top: calc(18 / 640 * 100vw);
    }
    .product_content li h4::after {
        content: "";
        display: block;
        position: absolute;
        z-index: 0;
        top: 0;
        left: 0;
        width: calc(6 / 640 * 100vw);
        height: 100%;
        border: 1px solid #313131;
    }
    .product_content li h4 .dec01 {
        display: block;
        font-weight: bold;
        margin-top: .45em;
    }
}