/* ページコンテナ 空白行*/
.p-container {width:100%;}
@media screen and (max-width: 959px) {
.p-container {display:none;}
}
/* ページコンテナ */
/* パンくずリストのボタン風デザイン */
.breadcrumb {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 1em;
    list-style: none;
    padding: 0;
}
.breadcrumb ul{
margin: 0;
unicode-bidi: isolate;
}

.breadcrumb li {
    display: inline-block;
}

.breadcrumb li a {
    display: inline-block;
    background-color: #fff; /* 背景色 */
    color: #7e7e7e; /* 文字色 */
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 5px;
    text-decoration: none;
    font-size: 12px;
    transition: background 0.3s ease;
}

.breadcrumb li a:hover {
    background-color: #ddd; /* ホバー時に少し濃く */
}

/*旧サイトと共通*/
/* item page */
.image_main { overflow:hidden; margin:35px 0 20px 0;}
.image_main img { width:738px; }
.item { width: 542px; margin:0 auto; }
.item_section { margin-bottom:15px; padding:15px 0 25px 0; border-bottom:1px dotted #999; overflow:hidden; }
.item_section:last-child { border-bottom:none; }

.item_section a { color:#666666;}
.item__name { font-size:1.8em; letter-spacing:0.13em; line-height:1.5; }
.item__price { color:#e50011; font-size:146%; }
.item__tax { font-size:78%; }
.item__entry { font-size:123.1%; letter-spacing:0.1em; line-height:1.5em; margin-bottom:25px; }
.item__entry a { text-decoration: none; }


/*センタリングタイトル*/
.item__center { font-size:1.8em; letter-spacing:0.13em; line-height:1.5em; text-align: center;}

.item_cart th, .item_cart td { padding:12px 0; vertical-align:middle; }
.item_cart th { width:78px; }
.product_num { width:40px; font-size:146%; padding:4px; margin-right:6px;  }
.item_cart .updown { vertical-align:middle; margin-left:10px; }
.item_cart input[type=select] { font-size:123.1%; }
.cart__inquiry { margin-top:20px; }
.cart__inquiry__li:after { content: "　"; background-image:url(https://file001.shop-pro.jp/PA01003/562/img/common/icon_tri_right.png); background-repeat:no-repeat; background-position:center; } 
.option_price { margin-top:15px; }
.option_price li:after,

.item_spec {  width: 100%; margin:20px 0; border-top:1px solid #ccc; }
.item_spec th, .item_spec td { padding:4px 18px; line-height:2.0; border-bottom:1px solid #ccc; }
.item_spec th { background:#f9f9f9; font-weight:bold; width:28%; }
.item_spec td { background:#ffffff; }

.item__photo img { width: 100%; }a

.item_recommend { margin:100px 0 30px 0; }
.item_recommend .item__entry { margin:20px 0; padding-bottom:20px; border-bottom:1px dotted #999; }
.recommend__each { float:left; width:162px; margin-right:29px; }
.recommend__each:nth-child(4n) { margin-right:0; }
.recommend__image img { width:100%; }
.recommend__text { margin:20px 0;  }
.item__box { padding:25px 25px 25px 25px ; overflow:hidden; margin-bottom:20px;  }
.item__box__photo { width:170px; float:left; margin:0 20px 20px 0; }
.item__box__photo img { width:170px; }
.item__box__entry { font-size:1.3em; font-weight:normal; margin-bottom:0.5em; }
.item__box p { font-size:1em; line-height:1.7; }

/*左寄せ画像*/
.item_photo_left img {  width:170px; float:left; margin:0 20px 20px 0; }

/* ------------------------------------------------
　色指定セット
--------------------------------------------------- */
.color_red { background:#cc3300; }
.color_ivory { background:#f7f6f5; }
.color_pink { background:#FFF6F9; }
.color_sky { background:#eff7ff; }
.color_green { background:#e9f3ee; }

/* ------------------------------------------------
  商品詳細の説明欄のスタイル定義はここに記述
  class名は .item_xxx 
--------------------------------------------------- */
.item_exsample { color:#ccc06a; font-size:1.1em; line-height:1.5; }
.item__entry02 { font-size:123.1%; letter-spacing:0.1em; margin:10px 0 10px 0; line-height: 1.2em}
.item__entry03 { font-size:123.1%; letter-spacing:0.1em; margin:10px 0 5px 0; line-height: 1.2em}
.item__bottomline { font-size:1em; line-height:1.7; border-bottom:1px dotted #999; }
.item__textb { font-size:1.5em;; font-weight:bold; line-height:1.7;  }

/*黄色マーカーライン*/
.item__marker {
   display: inline-block; 
   letter-spacing:0.15em; 
   margin:10px 0 10px 0; 
	font-size: 130.0%; 
	background-image: linear-gradient(rgba(0,0,0,0) 50%, rgb(255,255,153) 50%);
  }
  
/*上部ライン*/
.item__topline { padding:20px 0 10px 0; border-top:1px dotted #999; }
.item__topline02 {  padding:20px 0px 0px 0px; border-top:1px dotted #999; }

/* ------------------------------------------------
　角丸BOX　お客様の声
--------------------------------------------------- */
    #xsnazzy { background:transparent; margin:0; padding:0; }
    #xsnazzy .h, #xsnazzy p { margin:0; padding:10px 15px; line-height:2em; }
    #xsnazzy .h { font-size:1.2em; color:#60c8d8; padding-bottom:0; font-weight:bold; letter-spacing:0.1em;}
    #xsnazzy .xtop, #xsnazzy .xbottom {display:block; background:transparent; font-size:1px; }
    #xsnazzy b { display:block; overflow:hidden; }
    #xsnazzy .xb1, #xsnazzy .xb2, #xsnazzy .xb3 {height:1px; }
    #xsnazzy .xb2, #xsnazzy .xb3, #xsnazzy .xb4 {background:#f2f9fd; border-left:1px solid #c8ebf9; border-right:1px solid #c8ebf9; }
    #xsnazzy .xb1 { margin:0 5px; background:#c8ebf9; }
    #xsnazzy .xb2 { margin:0 3px; border-width:0 2px; }
    #xsnazzy .xb3 { margin:0 2px; }
    #xsnazzy .xb4 { height:2px; margin:0 1px; }
    #xsnazzy .xboxcontent { display:block; background:#f2f9fd; border:0 solid #c8ebf9; border-width:0 1px; }
    
/* ------------------------------------------------
　商品BOX　小
--------------------------------------------------- */
.item_sbox { float:left; width:30%; margin:auto; padding:10px; overflow:hidden; height:auto; }
.item_sphoto img { width:100%; }
.item_sname { font-size:116%; line-height:1.5; font-weight:bold; margin:10px 0 0 ; text-decoration: none;}
.item_sname2 { color:#999; font-size:90%; line-height:1.5; font-weight:bold; margin:5px 0 0 ; letter-spacing: 0.3em;}
.item_sname2 p {text-decoration: none;}
.item_sdescription { font-size:93%; line-height:1.6; margin-top:7px; text-decoration: none;} 
.item_sprice p {text-decoration: none;}

@media screen and (max-width: 600px) {
.item_sbox { float:left; width:45%; margin:auto; padding:10px; overflow:hidden; height:auto; }
.item_sphoto img { width:100%; }
}

/* ------------------------------------------------
　初めてセット用　石鹸一覧表
--------------------------------------------------- */
table.soaplist {
  border-collapse: collapse;
  border: solid 1px #ccc;
  font-size: 100%;
}

table.soaplist caption {
  margin-top: 1em;
  text-align: left;
  font-size: 100%; font-weight: bolder;
}

table.soaplist th,
table.soaplist td {
  border: solid 1px #ccc;
  padding: 6px 6px;
  vertical-align:middle
}

table.soaplist th {
  background:#f9f9f9;
  text-align: center;
  white-space: nowrap;
  color: #666;
}

table.soaplist td.name {
  text-align: left;
  width: 150px;
}

table.soaplist td.choice01 {
  text-align: center;
  white-space: nowrap;
  vertical-align:top
}

table.soaplist td.choice,{
  text-align: center;
  white-space: nowrap;
}

p.name { font-size: 115%; font-weight: bolder;}
p.copy { font-size: 80%;}
p.kaori { font-size: 80%;}
img.soap { width: 60px; height: 52px;}
img.choice { width: 20px; height:60px;}

/* color up 初めてセット用表  */
.kansou { color: #ff69b4; }
.binkan { color: #7b68ee; }
.sisei { color: #808000; }
.kongou { color: #ba55d3; }
.are { color: #82ae46; }
.nikibi { color: #556b2f; }
.keana { color: #d2691e; }
.akachan { color: #ee82ee; }
.mens { color: #191970; }
.hair { color: #b22222; }

/* ------------------------------------------------
　スタッフプロフィール
--------------------------------------------------- */
.item_profile img { width:50px; vertical-align: middle; margin:0 10px 0 0;}
.profile { font-size: 90%; }

/* ------------------------------------------------
　補足用テキスト（小）
--------------------------------------------------- */
.hosoku { font-size: 70%; }

/* ------------------------------------------------
　パスワード
--------------------------------------------------- */

.border_blue{width:220px; margin-bottom:10px; padding:10px 0; border:solid #1499b0; border-width:2px 0;}
.pass_box{width:220px; text-align:right; margin:10px 0 0 0;}
.pass_box input[type=text]{width:215px;}

/* ------------------------------------------------
　レビュー
--------------------------------------------------- */
.review{margin:10px auto;}
.reviewlist{margin:20px auto;}
.reviewlist_datas {overflow: hidden; zoom: 1; margin-bottom: 10px;}
.icon_star {float: left;width: 75px;overflow: hidden;}
.icon_star img {max-width: inherit;}
.review_poster li {float: left; margin-left: 10px;}
.review_poster li {list-style: none;}
.reviewlist {padding-bottom: 15px; margin-bottom: 15px; border-bottom: 1px dotted #ccc;}
.review_ttl,
.shopcomment_ttl {font-size: 14px; font-weight: bold; margin-bottom: 10px;}
.review_img {float: right; margin: 0 0 10px 10px}
.reviewlist_content {overflow: hidden; zoom: 1;}
.shopcomment {margin-top: 10px; margin-bottom: 10px; background: #eee; padding: 15px; border-radius: 6px;}

/* ------------------------------------------------
リンク用ボタン 01
--------------------------------------------------- */
a.button01 {
  color:#000;
  text-decoration:none;
  font-weight:bold;
  line-height:1.5; 
  padding:1rem;
  border:1px dotted #000;
  text-align:center;
  display:block;
  width:80%;
  margin:5% auto;
  background: #fff;
}

a.button01:hover {
  border:1px solid #fff;
  background: #f7f6f5;
}
/* ------------------------------------------------
Youtube　フレーム
--------------------------------------------------- */
.youtube {
	width: 100%;
	padding: 0;
	box-sizing: border-box;
}

.youtube .inner {
	padding-top: 56.25%;
	position: relative;
	height: 0;
	overflow: hidden;
}

.youtube .inner iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
/* ------------------------------------------------
カスタムオプション表示
--------------------------------------------------- */
#custom-options-radio{
  display: flex;
  align-items: center;
}

  /*旧サイトと共通ここまで*/
  /*追加*/
  .p-product-top-inner{
    background: #f5f8fa;
    border-radius: 10px;
    padding: 30px;
  }
  /*追加*/
  
  .p-product-heading__unit {
    margin: 0 20px 20px;
  }
  
  .p-product-heading__unit::after {
    display: block;
    clear: both;
    content: '';
  }
  
  .p-product-fav-item {
    margin-top: 10px;
  }
  
  .p-product-fav-item button {
    padding: 0;
    cursor: pointer;
    transition: .2s;
    color: #999;
    border: 0;
    outline: none;
    background: transparent;
  }
  
  .p-product-fav-item .is-added {
    color: #ff7373;
  }
  
  .p-product-fav-item svg {
    width: 20px;
    height: 20px;
    vertical-align: -.35em;
  
    fill: currentColor;
  }
  
  .p-large-image__image-wrap {
    max-width: 400px;
    border: 6px solid transparent;
  }
  
  .p-large-image__image-wrap {
    margin: 20px auto;
  }
  
  .p-thumbnail-list {
    box-sizing: border-box;
    margin: 20px -5px 10px;
    padding: 0;
    list-style-type: none;
    text-align: center;
  }
  
  .p-thumbnail-list__image-wrap {
    border: 2px solid transparent;
  }
  
  .p-thumbnail-list::after {
    display: block;
    clear: both;
    content: '';
  }
  
  .p-thumbnail-list__unit {
    float: left;
    box-sizing: border-box;
    width: 20%;
    margin-bottom: 10px;
    padding: 0 5px;
  }
  
  .p-thumbnail-list__image-wrap.is-current {
    border-color: #333;
    background: #333;
  }
  
  .p-view-product-images {
    text-align: right;
  }
  
  .p-view-product-images a {
    display: inline-block;
    padding: .5em 0;
    transition: opacity .2s;
    text-decoration: none;
  }
  
  .p-view-product-images a:hover {
    opacity: .66;
  }
  
  .p-view-product-images a:active {
    opacity: 1;
  }
  
  .p-short-description {
    line-height: 1.5;
    margin: 20px 0;
  }
  
  .p-cart-form {
    margin: 20px 0;
  }
  
  .p-cart-form::after {
    display: block;
    clear: both;
    content: '';
  }
  
  .p-cart-form__info {
    line-height: 1.5;
    margin-bottom: 40px;
    padding-bottom: 40px;
    text-align: center;
    border-bottom: 1px solid #eaeaea;
  }
  
  .p-cart-form__link-list {
    font-size: 12px;
    margin: 10px 0 0;
    padding: 0;
    list-style-type: none;
    text-align: right;
  }
  
  .p-cart-form__link-list a {
    display: inline-block;
    padding: .5em 0;
    transition: opacity .2s;
    text-decoration: none;
    color: #333;
  }
  
  .p-cart-form__link-list a:hover {
    opacity: .66;
  }
  
  .p-cart-form__link-list a:active {
    opacity: 1;
  }
  
  .p-cart-form__name {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.2;
    margin-bottom: .8em;
  }
  
  .p-cart-form__price {
    font-size: 18px;
    font-weight: bold;
  }
  
  .p-cart-form__regular-price {
    font-weight: bold;
    margin-top: .5em;
  }
  
  .p-cart-form__list-price {
    font-size: 12px;
    line-height: 2;
    opacity: .7;
  }
  
  .p-cart-form__point {
    font-size: 12px;
    margin-top: 10px;
  }
  
  .p-cart-form__point span {
    font-size: 18px;
    font-weight: bold;
  }
  
  .p-cart-form__stock {
    margin-top: 10px;
  }
  
  .p-cart-form__option-select select {
    box-sizing: border-box;
    width: 100%;
    border-color: #eaeaea;
  }
  
  .p-cart-form__option-select select:hover {
    border-color: #333;
  }
  
  .p-cart-form__password-input input {
    font-size: 16px;
    line-height: 40px;
    box-sizing: border-box;
    width: 100%;
    height: 40px;
    padding: 0 10px;
    transition: .2s;
    vertical-align: middle;
    border: 2px solid #eaeaea;
    border-radius: 4px;
  
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
  }
  
  .p-cart-form__password-input input:focus {
    border-color: #666;
    outline: none;
  }
  
  .p-cart-form__add-cart-num {
    font-family: 'Montserrat', sans-serif;
    display: inline-block;
    width: 100px;
    text-align: right;
  }
  
  .p-cart-form__add-num-wrap {
    position: relative;
    display: inline-block;
    width: 32px;
    height: 64px;
    vertical-align: -2em;
  }
  
  .p-cart-form__add-num {
    position: absolute;
    display: inline-block;
    padding: 5px;
    transition: opacity .2s;
    text-decoration: none;
    color: #333;
  }
  
  .p-cart-form__add-num:hover {
    opacity: .66;
  }
  
  .p-cart-form__add-num:active {
    opacity: 1;
  }
  
  .p-cart-form__add-num--up {
    top: 0;
  }
  
  .p-cart-form__add-num--down {
    bottom: 0;
  }
  
  .p-cart-form__add-num svg {
    width: 22px;
    height: 22px;
  
    fill: currentColor;
  }
  
  .p-cart-form__button-wrap {
    margin-top: 20px;
  }
  
  .p-cart-form__add-cart-button {
    font-family: 'Montserrat', sans-serif;
    width: 100%;
    padding: 15px;
    letter-spacing: 1px;
  }
  
  .p-cart-form__error-message {
    font-weight: bold;
    display: none;
    margin: 10px 0 0;
    text-align: center;
    color: #f00;
  }
  
  .p-view-option-info {
    display: block;
    margin-top: 20px;
    padding: .4em;
    text-align: center;
  }
  
  .p-price-table {
    line-height: 1.4;
    height: auto;
    margin-top: 10px;
    transition: .2s;
    text-align: left;
  }
  
  .p-price-table.is-hidden {
    overflow: hidden;
    height: 0;
    margin: 0;
    opacity: 0;
  }
  
  .p-price-table__heading-wrap {
    display: table;
    width: 100%;
  }
  
  .p-price-table__heading {
    font-size: 12px;
    display: table-cell;
    box-sizing: border-box;
    width: 50%;
    padding: .5em;
    background: #eaeaea;
  }
  
  .p-price-table__body {
    font-size: 12px;
    clear: both;
    margin: 0;
    padding: 0;
    border-bottom: 1px solid #eaeaea;
  }
  
  .p-price-table__body::after {
    display: block;
    clear: both;
    content: '';
  }
  
  .p-price-table__body dt {
    float: left;
    box-sizing: border-box;
    width: 50%;
    padding: .7em .5em;
    border-top: 1px solid #eaeaea;
  }
  
  .p-price-table__body dd {
    overflow: hidden;
    padding: 0;
    border-top: 1px solid #eaeaea;
  }
  
  .p-price-table__body span {
    display: block;
    text-align: right;
  }
  
  .p-price-table__body ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
  }
  
  .p-price-table__body li {
    padding: .7em .5em;
    border-bottom: 1px solid #eaeaea;
  }
  
  .p-price-table__body li:last-child {
    border-bottom: 0;
  }
  
  .p-price-table__name {
    font-weight: bold;
  }
  
  .p-option-table table {
    min-width: 100%;
    border-collapse: collapse;
    text-align: center;
    border: 1px solid #ccc;
  }
  
  .p-option-table br {
    display: none;
  }
  
  .p-option-table .cell_1,
  .p-option-table .cell_2 {
    padding: 10px 8px;
    text-align: center;
    white-space: nowrap;
    border: 1px solid #ddd;
  }
  
  .p-option-table [type='radio'] {
    position: relative;
    z-index: 0;
    width: 10px;
    height: 10px;
    margin: 5px;
    cursor: pointer;
  }
  
  .p-option-table [type='radio']::before {
    position: absolute;
    z-index: 1;
    top: -5px;
    left: -5px;
    display: block;
    width: 20px;
    height: 20px;
    content: '';
    border-radius: 20px;
    background: #eee;
  }
  
  .p-option-table [type='radio']::after {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    display: block;
    width: 10px;
    height: 10px;
    content: '';
    transition: .2s;
    border-radius: 10px;
    background: transparent;
  }
  
  .p-option-table [type='radio']:hover::after {
    background: rgba(0, 0, 0, .2);
  }
  
  .p-option-table [type='radio']:checked::after {
    background: #fd7f23;
  }
  
  .p-option-table .t_stock_num {
    font-size: 12px;
    display: block;
    margin-top: 12px;
    text-align: center;
  }
  
  .p-option-table .stock_zero {
    font-size: 12px;
  }
  
  .p-option-table .table_price {
    display: none;
  }
  
  .p-product-body__name {
    font-size: 26px;
    font-weight: bold;
    line-height: 1.4;
    text-align: center;
    letter-spacing: 0.1em;
  
  }
  
  .p-product-body__review-link {
    margin:10px 0px;
    text-align: center;
  }
  
  .p-product-body__review-link span {
    font-size: 18px;
  }
  
  .p-product-body__review-link a {
    transition: opacity .2s;
    text-decoration: none;
    color: #7e7e7e;
  }
  
  .p-product-body__review-link a:hover {
    opacity: .66;
  }
  
  .p-product-body__review-link a:active {
    opacity: 1;
  }
  
  .p-product-body__price {
    font-size: 1.8em;
    font-weight: bold;
    clear: both;
    text-align: center;
  }
  
  .p-product-body__price--discount {
    color: #f00;
  }
  
  .p-product-body__regular-price {
    margin-top: 10px;
    text-decoration: line-through;
  }
  
  .p-product-body__description {
    line-height: 1.8;
    clear: both;
    margin: 30px 0 0;
  }
  
  .p-product-body__images {
    margin-top: 30px;
    border-top: 1px solid #eaeaea;
  }
  
  .p-product-body__linkto-cart {
    font-size: 14px;
    font-weight: normal;
    line-height: 22px;
    display: inline-block;
    display: block;
    box-sizing: border-box;
    max-width: 300px;
    margin: 30px auto;
    padding: 15px;
    cursor: pointer;
    transition: .2s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    color: #fff;
    border: 0;
    border-radius: 4px;
    background: #0099BD;
  
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
  }
  
  .p-product-body__linkto-cart:hover,
  .p-product-body__linkto-cart:focus {
    outline: none;
    box-shadow: inset 0 -2px 0 rgba(0, 0, 0, .2);
    text-shadow: 0 -1px 0 rgba(0, 0, 0, .2);
  }
  
  .p-product-images {
    margin: 0 -10px 0 0;
    padding: 30px 0;
    list-style-type: none;
  }
  
  .p-product-images__image-wrap {
    border: 6px solid transparent;
  }
  
  .p-product-images::after {
    display: block;
    clear: both;
    content: '';
  }
  
  .p-product-images li {
    float: left;
    box-sizing: border-box;
    width: 33.33333%;
    margin-bottom: 15px;
    padding-right: 10px;
  }
  
  .p-product-images li:nth-child(3n + 1) {
    clear: left;
  }
  
  .p-product-footer-nav {
    font-size: 12px;
    margin: 0;
    padding: 0;
    padding-top: 20px;
    list-style-type: none;
    text-align: right;
    border-top: 1px solid #eaeaea;
  }
  
  .p-product-footer-nav li {
    margin-bottom: 10px;
  }
  
  .p-product-footer-nav a {
    transition: opacity .2s;
    text-decoration: none;
    color: #333;
  }
  
  .p-product-footer-nav a:hover {
    opacity: .66;
  }
  
  .p-product-footer-nav a:active {
    opacity: 1;
  }
  
  .p-product-footer-nav .c-icon {
    vertical-align: -.4em;
  }
  
  .p-review__unit {
    padding: 15px 20px;
    border-bottom: 1px solid #eaeaea;
  }
  
  .p-review__unit:last-child {
    border: 0;
  }
  
  .p-review__button {
    display: block;
    max-width: 300px;
    margin: 30px auto;
    padding: 15px;
    text-align: center;
  }
  
  .p-posted-review__image {
    display: block;
    max-width: 200px;
    margin: 0 auto 20px;
  }
  
  .p-posted-review__heading {
    overflow: hidden;
    margin: 0 20px 0 0;
  }
  
  .p-posted-review__title {
    font-weight: bold;
    display: block;
    margin: 15px 0;
  }
  
  .p-posted-review__info {
    margin: 15px 0;
    padding: 0;
  }
  
  .p-posted-review__info li {
    display: inline;
    margin-right: 10px;
  }
  
  .p-posted-review__body {
    line-height: 1.8;
    overflow: hidden;
  }
  
  .p-posted-review__star {
    width: 18px;
    height: 18px;
    vertical-align: -.3em;
  
    fill: currentColor;
    fill: #ddd;
  }
  
  .p-posted-review__star.is-color {
    fill: #ffdc00;
  }
  
@media screen and (min-width: 600px) {
/* パンくずリストのボタン風デザイン */
.breadcrumb {
    gap: 0.5em;
}
/* パンくずリストのボタン風デザイン ここまで*/

    .p-product-heading__unit {
      margin: 0 0 20px;
      padding: 0 20px;
      border: 1px solid #eaeaea;
    }
  
    .p-cart-form__password-input input {
      font-size: 14px;
    }
  
    .p-product-body__linkto-cart {
      padding: 12px 15px;
    }
  
    .p-product-footer-nav li {
      display: inline-block;
      margin-left: 10px;
    }
  
    .p-review__unit {
      padding: 30px 0;
    }
  
    .p-review__button {
      padding: 10px 15px;
    }
  
    .p-posted-review__image {
      float: left;
      height: auto;
      margin: 0 30px 0 0;
    }
  
    .p-posted-review__title {
      display: inline-block;
      margin: 0 0 0 20px;
    }
  }
  
  @media screen and (min-width: 600px) and (max-width: 959px) {


    .p-large-image {
      float: left;
      width: 50%;
      margin: 0;
    }
  
    .p-thumbnail-list {
      float: right;
      width: 45%;
    }
  
    .p-view-product-images {
      float: right;
      width: 45%;
    }
  
    .p-short-description {
      float: right;
      width: 45%;
    }
  
    .p-cart-form__info {
      float: left;
      width: 50%;
      margin: 0;
      padding: 0;
      text-align: left;
      border: 0;
    }
  
    .p-cart-form__option {
      float: right;
      width: 45%;
    }
  
    .p-cart-form__link-list {
      float: right;
      clear: right;
      width: 45%;
    }
  
    .p-product-body-inner {
      margin-top: 40px;
    }
  }
  
  @media screen and (min-width: 960px) {
    .p-product-wrap {
      overflow: hidden;
    }
  
    .p-product-heading {
      float: right;
      box-sizing: border-box;
      width: 400px;
    }
  
    .p-product-body {
      float: right;
      width: 100%;
      margin-right: -400px;
    }
  
    .p-product-body-inner {
      margin-right: 440px;
    }
  
    .p-large-image__image-wrap {
      border-width: 9px;
    }
  
    .p-thumbnail-list__image-wrap {
      border-width: 3px;
    }
  
    .p-view-product-images {
      display: none;
    }
  
    .p-product-body__linkto-cart {
      display: none;
    }
  
    .p-product-images__image-wrap {
      border-width: 9px;
    }
  
    .p-product-images li {
      width: 50%;
    }
  
    .p-product-images li:nth-child(3n + 1) {
      clear: none;
    }
  
    .p-product-images li:nth-child(2n + 1) {
      clear: left;
    }
  }
  
  @media screen and (max-width: 599px) {
    .p-short-description {
      display: none;
    }
  
    .p-product-body-inner {
      padding-top: 20px;
      border-top: 1px solid #eaeaea;
    }
  
    .p-product-body {
      padding: 0 20px;
    }

    .p-product-body__name {
      display: none;
    }
    .p-product-top-inner{
      padding: 8px;
      border-radius:8px;
    }

    .p-product-body__price {
      display: none;
    }
  
    .p-product-body__regular-price {
      display: none;
    }
  
  }
  
  /*  オプションごとのカートボタン CSS  */
  
  .cms-opt__unit-label {
    font-weight: bold;
    margin-bottom: .5em;
  }
  
  .cms-opt-button__opt-list {
    margin: 0;
  }
  
  .cms-opt-button__opt-body {
    padding-bottom: 20px;
    border-bottom: 1px solid #eaeaea;
    margin: 0 0 20px 0;
  }
  
  .cms-opt-button__opt-label {
    display: inline-block;
  }
  .cms-opt-button__opt-heading {
    background: #eee;
    font-weight: bold;
    box-sizing: border-box;
    width: 100%;
    padding: 10px;
    margin-bottom: 10px;
  }
  .cms-opt-button__opt-heading--hidden {
    visibility: hidden;
    height: 0;
    margin: 0;
    padding: 0;
  }
  
  .cms-opt-button__content {
    margin-bottom: 10px;
  }
  
  .cms-opt-button__content-name {
    min-width: 50%;
    display: inline-block;
    vertical-align: middle;
  }
  
  .cms-opt-button__content-price {
    font-size: 18px;
    min-width: 48%;
    display: inline-block;
    vertical-align: middle;
  }
 /*スマートフォンレイアウト*/ 
  @media screen and (min-width: 600px) {
    .cms-opt-button__content-price {
       font-size: 20px;
    }
  }
  
  .cms-opt-button__purchase-stock {
    display: inline-block;
    margin: 0;
    font-size: 13px;
    color: #777;
    min-width: 50%;
    word-break: break-all;
  }
  
  .cms-opt-button__purchase-number {
    display: inline-block;
  }
  
  .cms-opt-button__cart {
    margin-top: 10px;
  }
  
  .cms-opt-button__purchase-unit {
    word-break: break-all;
  }


  
  /*  クイックカートイン 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;
    }
  }