.p-product {
margin-bottom: 90px;
}
@media screen and (max-width: 767px) {
.p-product {
margin-bottom: 45px;
}
}
/* form */
.p-product select {
box-sizing: border-box;
padding: 5px;
height: 40px;
border: 1px solid #bfbfbf;
font-size: 16px;
}
.p-product input[type=text] {
box-sizing: border-box;
padding: 5px;
height: 40px;
border: 1px solid #bfbfbf;
font-size: 16px;
}
.p-product-img {
display: flex;
flex-wrap: wrap;
justify-content: center;
}
@media screen and (max-width: 1030px) {
.p-product-img {
display: block;
}
}
.p-product-img__main {
position: relative;
width: 660px;
text-align: center;
}
@media screen and (max-width: 1030px) {
.p-product-img__main {
margin-left: auto;
margin-right: auto;
width: 530px;
}
}
@media screen and (max-width: 767px) {
.p-product-img__main {
width: auto;
}
}
.p-product-img__main-item {
text-align: center;
}
.p-product-img__main-item img {
margin-left: auto;
margin-right: auto;
max-height: 660px;
}
@media screen and (max-width: 1030px) {
.p-product-img__main-item img {
max-height: 530px;
}
}
.p-product-img__thumb {
width: 340px;
}
@media screen and (max-width: 1030px) {
.p-product-img__thumb {
margin-left: auto;
margin-right: auto;
margin-top: 15px;
width: 530px;
}
}
@media screen and (max-width: 767px) {
.p-product-img__thumb {
width: auto;
}
}
.p-product-img__thumb * {
min-width: 0;
min-height: 0;
}
@media screen and (max-width: 1030px) {
.p-product-thumb-list {
margin-left: 0;
margin-right: 0;
flex-wrap: nowrap;
}
}
.p-product-thumb-list .slick-prev {
top: auto;
bottom: -56px;
left: auto;
right: 51px;
}
@media screen and (max-width: 1030px) {
.p-product-thumb-list .slick-prev {
top: 50%;
bottom: auto;
right: auto;
left: -10px;
}
}
.p-product-thumb-list .slick-next {
top: auto;
bottom: -56px;
left: auto;
right: 0px;
}
@media screen and (max-width: 1030px) {
.p-product-thumb-list .slick-next {
top: 50%;
bottom: auto;
right: -10px;
}
}
.p-product-thumb-list__item {
box-sizing: border-box;
position: relative;
margin-bottom: 20px;
padding-left: 20px;
width: 170px;
}
@media screen and (max-width: 1030px) {
.p-product-thumb-list__item {
margin-bottom: 0;
padding-left: 5px;
width: auto;
}
}
.p-product-thumb-list__item.is-current .p-product-thumb-list__img:before {
border-color: #cccccc;
}
.p-product-thumb-list__item.is-current .p-product-thumb-list__img img {
filter: blur(4px);
-ms-filter: blur(4px);
transform: scale(1.05, 1.05);
}
@media screen and (max-width: 767px) {
.p-product-thumb-list__item.is-current .p-product-thumb-list__img img {
transform: none;
}
}
.p-product-thumb-list__img {
overflow: hidden;
position: relative;
width: 150px;
height: 150px;
transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
@media screen and (max-width: 1030px) {
.p-product-thumb-list__img {
width: auto;
height: auto;
}
}
.p-product-thumb-list__img:hover {
opacity: 0.7;
cursor: pointer;
}
.p-product-thumb-list__img:before {
content: "";
position: absolute;
top: 0;
bottom: 0;
right: 0;
left: 0;
z-index: 10;
border: 2px solid transparent;
transition: all 0.1s ease;
}
@media screen and (max-width: 1030px) {
.p-product-thumb-list__img:before {
height: calc(100% - 4px);
}
}
.p-product-thumb-list__img img {
width: 100%;
transform: scale(1, 1);
transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
}
@media screen and (max-width: 1030px) {
.p-product-thumb-list__img img {
width: auto;
max-width: 100%;
}
}
@media screen and (max-width: 767px) {
.p-product-thumb-list__img img {
transform: none;
transition: none;
-webkit-backface-visibility: visible;
backface-visibility: visible;
}
}
/* 商品画像 slider */
.p-product-img__main .slick-track {
margin-left: 0;
margin-right: 0;
}
.p-product-img__main .slick-prev, .p-product-img__main .slick-next {
top: 50%;
width: 30px;
height: 30px;
transition: all 0.4s ease;
z-index: 1;
}
@media screen and (max-width: 767px) {
.p-product-img__main .slick-prev, .p-product-img__main .slick-next {
width: 45px;
height: 45px;
}
}
.p-product-img__main .slick-prev:before, .p-product-img__main .slick-next:before {
content: "";
position: absolute;
top: 7px;
left: 10px;
width: 15px;
height: 15px;
border-left: 1px solid #000000;
border-top: 1px solid #000000;
transition: all 0.4s ease;
z-index: 1;
}
@media screen and (max-width: 767px) {
.p-product-img__main .slick-prev:before, .p-product-img__main .slick-next:before {
top: 15px;
}
}
.p-product-img__main .slick-prev {
left: 15px;
}
@media screen and (max-width: 767px) {
.p-product-img__main .slick-prev {
left: 0px;
}
}
.p-product-img__main .slick-prev:before {
transform: rotate(-45deg);
}
@media screen and (max-width: 767px) {
.p-product-img__main .slick-prev:before {
left: 17px;
}
}
.p-product-img__main .slick-next {
right: 15px;
}
@media screen and (max-width: 767px) {
.p-product-img__main .slick-next {
right: 0px;
}
}
.p-product-img__main .slick-next:before {
left: 4px;
transform: rotate(135deg);
}
@media screen and (max-width: 767px) {
.p-product-img__main .slick-next:before {
left: 13px;
}
}
/***** 商品情報 *****/
.p-product-txt {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
margin-left: 100px;
margin-right: 100px;
}
@media screen and (max-width: 1030px) {
.p-product-txt {
margin-left: 0;
margin-right: 0;
}
}
@media screen and (max-width: 767px) {
.p-product-txt {
display: block;
}
}
.p-product-info {
box-sizing: border-box;
padding-top: 120px;
width: 330px;
}
@media screen and (max-width: 1030px) {
.p-product-info {
padding-top: 60px;
padding-right: 30px;
width: 50%;
}
}
@media screen and (max-width: 767px) {
.p-product-info {
padding-right: 0;
width: auto;
}
}
.p-product-info__ttl {
margin: 0;
line-height: 1.4;
font-size: 24px;
font-weight: normal;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
word-break: break-all;
}
@media screen and (max-width: 767px) {
.p-product-info__ttl {
font-size: 21px;
}
}
.p-product-info__ttl img {
vertical-align: middle;
}
.p-product-info__id {
margin: 0;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
}
@media screen and (max-width: 767px) {
.p-product-info__id {
margin-top: 5px;
font-size: 10px;
}
}
.p-product-price {
margin-top: 20px;
margin-bottom: 20px;
}
.p-product-price__sell {
font-size: 24px;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
}
.p-product-price__sell-off {
display: inline-block;
margin-left: 5px;
padding: 0px 8px;
border-radius: 3px;
font-size: 18px;
background: #cf1110;
color: #ffffff;
}
.p-product-price__normal {
font-size: 14px;
}
@media screen and (max-width: 767px) {
.p-product-price__normal {
font-size: 12px;
}
}
.p-product-price__list-price {
font-size: 14px;
}
@media screen and (max-width: 767px) {
.p-product-price__list-price {
font-size: 12px;
}
}
.p-product-action {
padding-top: 120px;
width: 400px;
}
@media screen and (max-width: 1030px) {
.p-product-action {
padding-top: 60px;
width: 50%;
}
}
@media screen and (max-width: 767px) {
.p-product-action {
width: auto;
}
}
/* オプション table */
.p-product-option-tbl {
margin-bottom: 30px;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
}
@media screen and (max-width: 767px) {
.p-product-option-tbl {
display: none;
}
}
.p-product-option-tbl table {
margin-bottom: 0;
border-top: 0;
border-left: 0;
border-right: 0;
width: 100%;
background: #f0ede8;
}
.p-product-option-tbl table div {
display: inline-block !important;
}
.p-product-option-tbl th, .p-product-option-tbl td {
padding: 12px 15px;
border-top: 1px solid #ffffff;
border-bottom: 1px solid #ffffff;
border-left: 0;
text-align: center;
}
.p-product-option-tbl label {
display: inline-block !important;
margin-left: 5px;
margin-bottom: 0;
}
.p-product-option-tbl input {
margin-top: 0;
}
.p-product-option-tbl {
overflow-x: scroll;
white-space: nowrap;
padding-bottom: 30px;
}
.p-product-option-tbl::-webkit-scrollbar {
height: 4px;
}
.p-product-option-tbl::-webkit-scrollbar-track {
background: #eeeeee;
}
.p-product-option-tbl::-webkit-scrollbar-thumb {
background: #bbbbbb;
border-radius: 2px;
}
/* オプション select */
.p-product-option-select {
margin-bottom: 30px;
}
.p-product-option-select__box {
margin-bottom: 15px;
}
.p-product-option-select__ttl {
margin-bottom: 5px;
font-size: 16px;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
color: #5a5a5a;
}
/* 名入れ */
.p-product-name {
margin-bottom: 30px;
}
.p-product-name__box {
margin-top: 15px;
}
.p-product-name__ttl {
margin-bottom: 5px;
font-size: 16px;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
color: #5a5a5a;
}
.p-product-name__body input {
width: 100%;
}
/* 数量 */
.p-product-form-stock {
display: flex;
flex-wrap: wrap;
align-items: center;
margin-bottom: 20px;
}
.p-product-form-stock__ttl {
margin-bottom: 5px;
font-size: 14px;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
color: #5a5a5a;
}
@media screen and (max-width: 767px) {
.p-product-form-stock__ttl {
font-size: 12px;
}
}
.p-product-form-stock__input {
display: flex;
align-items: center;
}
.p-product-form-stock__input input {
width: 60px;
}
.p-product-form-stock__unit {
margin-left: 10px;
}
.p-product-form-stock__stock {
margin-left: 25px;
}
/* ボタン */
.p-product-form-btn__cart {
margin-bottom: 10px;
}
.p-product-form-btn__favorite {
padding: 0;
border: 0;
background: transparent;
color: #d8d8d8;
cursor: pointer;
text-align: center;
transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.p-product-form-btn__favorite svg {
width: 21px;
height: 17px;
fill: currentColor;
}
.p-product-form__error-message {
color: #DB5656;
margin-top: 15px;
margin-bottom: 15px;
}
/* SNS */
.p-product-sns-list {
margin-top: 20px;
display: flex;
flex-wrap: wrap;
}
.p-product-sns-list__item {
margin-right: 20px;
}
/* link */
.p-product-link-list {
margin-top: 40px;
padding-top: 40px;
border-top: 1px solid #bfbfbf;
}
.p-product-link-list__item {
margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
.p-product-link-list__item {
margin-bottom: 20px;
}
}
/***** 商品詳細 *****/
.p-product__ttl {
position: relative;
margin-top: 240px;
margin-bottom: 45px;
padding-top: 25px;
line-height: 1.4;
font-size: 24px;
font-weight: bold;
font-family: "Playfair Display", serif;
color: #5a5a5a;
text-align: center;
}
@media screen and (max-width: 767px) {
.p-product__ttl {
margin-top: 120px;
margin-bottom: 30px;
padding-top: 15px;
line-height: 1.4;
font-size: 20px;
}
}
.p-product__ttl:before {
content: "";
position: absolute;
top: -85px;
left: 50%;
height: 85px;
width: 1px;
background: #5a5a5a;
}
@media screen and (max-width: 767px) {
.p-product__ttl:before {
top: -40px;
height: 40px;
}
}
.p-product-detail {
position: relative;
}
.p-product-explain {
margin-left: 100px;
margin-right: 100px;
margin-bottom: 120px;
}
@media screen and (max-width: 1030px) {
.p-product-explain {
margin-bottom: 60px;
margin-left: 0;
margin-right: 0;
width: auto;
}
}
.p-product-explain__body {
line-height: 2;
}
.p-product-other {
width: 530px;
order: -1;
}
@media screen and (max-width: 1030px) {
.p-product-other {
width: auto;
}
}
/* おすすめ商品 */
.p-product-recommend-list {
display: flex;
flex-wrap: wrap;
margin-left: -25px;
margin-right: -25px;
margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
.p-product-recommend-list {
margin-left: -5px;
margin-right: -5px;
margin-bottom: 60px;
}
}
.p-product-recommend-list__item {
box-sizing: border-box;
padding-left: 25px;
padding-right: 25px;
width: 33.3333%;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
word-break: break-all;
}
@media screen and (max-width: 767px) {
.p-product-recommend-list__item {
padding-left: 5px;
padding-right: 5px;
}
}
.p-product-recommend-list__img {
margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
.p-product-recommend-list__img {
margin-bottom: 5px;
}
}
.p-product-recommend-list__txt {
position: relative;
padding-bottom: 20px;
}

.p-product-recommend-list__ttl {
font-size: 16px;
}
@media screen and (max-width: 767px) {
.p-product-recommend-list__ttl {
font-size: 14px;
}
}
.p-product-recommend-list__price {
margin-top: 30px;
}
@media screen and (max-width: 767px) {
.p-product-recommend-list__price {
margin-top: 15px;
font-size: 12px;
}
}
.p-product-recommend-list__price.is-default {
margin-top: 0;
text-decoration: line-through;
}
.p-product-recommend-list__expl {
margin-top: 15px;
font-size: 12px;
color: #909090;
}
/* レビュー */
.p-product-review {
margin-left: 100px;
margin-right: 100px;
margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
.p-product-review {
margin-left: 0;
margin-right: 0;
margin-bottom: 30px;
}
}
.p-product-review__item {
box-sizing: border-box;
margin-bottom: 30px;
padding: 40px;
background: #ffffff;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
}
@media screen and (max-width: 767px) {
.p-product-review__item {
padding: 20px;
}
}
.p-product-review__heading {
margin-bottom: 15px;
}
.p-product-review__ttl {
margin-top: 10px;
margin-bottom: 10px;
line-height: 1.4;
font-size: 18px;
}
.p-product-review-info {
margin-top: 10px;
margin-bottom: 10px;
}
.p-product-review-info__item {
display: inline-block;
font-size: 12px;
}
@media screen and (max-width: 767px) {
.p-product-review-info__item {
display: block;
}
}
.p-product-review-info__item.is-type {
margin-right: 35px;
}
.p-product-review__img {
margin-top: 20px;
width: 80px;
text-align: center;
position: relative;
}
.p-product-review__img:before {
content: "";
position: absolute;
bottom: 0;
right: 0;
width: 18px;
height: 18px;
background: url(https://img.shop-pro.jp/tmpl_img/85/review-icon-zoom.png);
background-size: 18px 18px;
}
.p-product-review__body {
margin-top: 15px;
line-height: 2;
}
.p-product-review__rates {
display: flex;
flex-wrap: wrap;
}
.p-product-review__rate {
width: 18px;
height: 18px;
vertical-align: -0.3em;
fill: currentColor;
fill: #d8d8d8;
}
.p-product-review__rate.is-color {
fill: #ea872f;
}
/* レビュー 返信 */
.p-product-review-reply {
box-sizing: border-box;
margin-top: 30px;
padding: 15px 0;
border-top: 1px solid #eeeeee;
border-bottom: 1px solid #eeeeee;
}
.p-product-review-reply__ttl {
font-weight: bold;
}
.p-product-review-reply__body {
font-size: 12px;
}
.p-product-review-reply__date {
font-size: 12px;
}
.p-product-review__btn-wrap {
margin-top: 45px;
text-align: center;
}
@media screen and (max-width: 767px) {
.p-product-review__btn-wrap {
margin-top: 30px;
}
}
.p-product-review__btn {
display: inline-block;
padding: 25px;
min-width: 400px;
font-size: 20px;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
background: #b49579;
color: #ffffff;
text-align: center;
transition: all ease 0.2s;
}
@media screen and (max-width: 767px) {
.p-product-review__btn {
padding: 15px;
font-size: 16px;
min-width: 250px;
}
}
.p-product-review__btn:hover, .p-product-review__btn:focus {
background: rgba(180, 149, 121, 0.8);
color: #ffffff;
text-decoration: none;
}
.fix-cart-navi {
display: none;
position: fixed;
right: 30px;
bottom: 10px;
z-index: 100;
}
@media screen and (max-width: 767px) {
.fix-cart-navi {
right: 0;
left: 0;
bottom: 0;
}
}
.fix-cart-navi__link {
box-sizing: border-box;
display: inline-block;
padding: 15px;
width: 270px;
font-size: 18px;
font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, serif;
background: #121212;
color: #ffffff !important;
text-align: center;
text-decoration: none;
transition: all ease 0.2s;
}
@media screen and (max-width: 767px) {
.fix-cart-navi__link {
width: 100%;
}
}
.fix-cart-navi__link:hover {
text-decoration: none;
}
.fix-cart-navi__link .c-icon-cart {
margin-right: 10px;
}

/*  クイックカートイン CSS  */
.cart_in_modal,
.cart_in_error_modal {
position: fixed;
width: 100%;
height: 100%;
top: 0;
left: 0;
background-color: rgba(0, 0, 0, .7);
z-index: 20000;
display: flex;
overflow: auto;
}
@media screen and (min-width: 960px) {
.cart_in_modal,
.cart_in_error_modal {
align-items: center;
}
}
.cart_in_modal__bg {
background-color: rgba(0, 0, 0, .7);
position: fixed;
width: 100%;
height: 100%;
z-index: 20000;
}
.cart_in_modal__outline {
width: 90%;
margin: 20px 5%;
padding: 20px;
background-color: #fff;
border-radius: 5px;
box-shadow: 0 2px 5px rgba(0, 0, 0, .4);
box-sizing: border-box;
text-align: center;
position: absolute;
}
@media screen and (min-width: 960px) {
.cart_in_modal__outline {
width: 900px;
margin: auto;
padding: 20px 70px;
position: relative;
}
}
.cart_in_modal__heading {
font-size: 20px;
font-weight: bold;
margin: 20px 0;
line-height: 1.4;
}
@media screen and (min-width: 960px) {
.cart_in_modal__heading {
font-size: 26px;
margin: 30px 0;
line-height: 1.2;
}
}
.cart_in_error_modal__heading {
font-size: 20px;
font-weight: bold;
margin: 40px 0 20px;
line-height: 1.4;
}
@media screen and (min-width: 960px) {
.cart_in_error_modal__heading {
margin: 30px 0;
line-height: 1.2;
}
}
.cart_in_modal__detail {
display: flex;
padding: 20px;
border-top: 1px solid #ccc;
border-bottom: 1px solid #ccc;
align-items: center;
flex-direction: column;
}
@media screen and (min-width: 960px) {
.cart_in_modal__detail {
flex-direction: row;
}
}
.cart_in_modal__name {
font-size: 16px;
flex: 1;
line-height: 1.4;
text-align: left;
margin: 0;
}
@media screen and (min-width: 960px) {
.cart_in_modal__name {
font-size: 18px;
}
}
.cart_in_modal__image-wrap {
padding: 5px;
width: 170px;
height: 170px;
background: rgba(0, 0, 0, .1);
position: relative;
border: 5px solid transparent;
box-sizing: border-box;
}
@media screen and (min-width: 960px) {
.cart_in_modal__image-wrap {
margin: 0 30px 0 0;
flex-basis: 170px;
}
}
.cart_in_modal__image {
width: auto;
height: auto;
max-width: 100%;
max-height: 100%;
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
margin: auto;
}
.cart_in_modal__text-link {
color: #2169f3;
cursor: pointer;
position: relative;
display: inline-block;
margin: 20px 0 0;
padding: 0 0 0 20px;
line-height: 1.15;
}
.cart_in_modal__text-link::before {
content: "";
position: absolute;
top: 3px;
left: 3px;
width: 8px;
height: 8px;
border-top: 2px solid #2169f3;
border-right: 2px solid #2169f3;
-webkit-transform: rotate(225deg);
transform: rotate(225deg);
}
.cart_in_modal__button-wrap {
width: 100%;
margin: 30px auto;
font-size: 17px;
}
@media screen and (min-width: 960px) {
.cart_in_modal__button-wrap {
width: 350px;
}
}
.cart_in_modal__button {
font-size: 17px;
font-weight: bold;
line-height: 23px;
display: inline-block;
box-sizing: border-box;
cursor: pointer;
vertical-align: middle;
text-decoration: none;
color: #fff;
border: 0;
border-radius: 4px;
width: 100%;
height: 58px;
padding: 15px;
background: #2169f3;
box-shadow: 0 2px 0 #1a54c2;
outline: none;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}
.cart_in_modal__button:hover,
.cart_in_modal__button:focus {
height: 58px;
color: #e9f0fe;
background-color: #1e5fdb;
box-shadow: none;
transform: translate3d(0, 2px, 0);
}
.cart_in_modal__close-icon {
cursor: pointer;
}
.cart_in_modal__close-icon::before,
.cart_in_modal__close-icon::after {
content: "";
width: 35px;
height: 6px;
display: block;
position: absolute;
top: 30px;
right: 20px;
background: #eee;
border-radius: 4px;
}
.cart_in_modal__close-icon::before {
-webkit-transform: rotate(-45deg);
transform: rotate(-45deg);
}
.cart_in_modal__close-icon::after {
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
.spinner::before {
content: "";
box-sizing: border-box;
position: absolute;
top: 50%;
left: 50%;
height: 100px;
width: 100px;
margin-top: -50px;
margin-left: -50px;
border-radius: 50%;
border: 5px solid #eee;
border-top-color: #fd7f23;
animation: spinner 0.5s linear infinite;
}
@keyframes spinner {
to {
transform: rotate(360deg);
}
}
@media screen and (min-width: 960px) {
.sp-br {
display: none;
}
}
