/** FS **/
.logout.my-false { display: none; }
.login.my-true { display: none; }
.regist.my-true { display: none; }

.fs-preview-header { display: none; }
.fs-p-memberInfo__points {color: #3c3c3c;}
.fs-c-productPointDisplay {color: #3c3c3c;}
.fs-p-footerCopyright {color: #3c3c3c;}
.fs-p-banner--registration {background: #973136;}
.fs-c-documentColumn__heading {color: #3c3c3c;}
.fs-p-drawer__loginLogout__logout:hover {background: #973136;}
.fs-p-drawer__loginLogout__login:hover {background: #973136;}
.fs-p-sideMenu a:hover {background: #973136;color: #ffffff;}
.fs-c-sortItems__list__item.is-active {background: #973136;}
.fs-c-breadcrumb__list--subgroup {display:none;}
.fs-c-creditCardListItem.is-active {border-color: #973136;}
.fs-c-creditCardListItem__status__label {color: #973136;}
.fs-c-dropdown {overflow: visible; }
.fs-c-productOption__field {flex-direction: row;}
.fs-c-featuredProduct__title {margin: 20px 0px 10px 0px;}
.fs-c-subSection__title {border-bottom: 1px solid currentColor; color: #3c3c3c;}
.fs-l-main {padding: 0px;max-width: 100%;margin: 24px auto 0px auto;}
.fs-l-pageMain {max-width: 100%;margin: 24px 0px 0px 0px;}
.fs-l-footer {margin-top: 0px;}
.fs-pt-carousel__slide__caption {padding:4px;}
.fs-p-scrollingCartButton {bottom: 15%;}
.fs-l-account { margin:0px 25px;}
.fs-c-loginForm { padding:0px 10px;}
.fs-p-announcement{ padding:0px 10px;}
.fs-c-specTableContainer{ padding:0px 10px;}
.fs-c-inputInformation{ padding:0px 10px;}
.fs-body-my-orders .fs-c-history {margin: auto 2%;}
.fs-c-orderDetail {margin: auto 2%;}

.fs-c-mark--preorder {
background: #dc3545;
color: #ffffff;}

/** ショッピングカートページ　ボタン 1カラム化**/
@media screen and (min-width: 960px) {
.fs-body-cart .fs-l-cart__contentsArea {display: block;}
.fs-l-cart__mainColumn {max-width: 100%;padding: 0;}
}

/** ご注文手続きページ　ボタン 1カラム化 **/
@media screen and (min-width: 960px) {
  [class^="fs-body-checkout"] .fs-l-checkout {
    display: block;
  }
  [class^="fs-body-checkout"] .fs-l-checkout__mainColumn {
    max-width: 100%;
    padding: 0;
  }
}

/** 20yearscheck **/
/** チェックOFFなら非表示 */
.message{ 
  display: none;
}
/** チェックONなら表示 */
input:checked ~ .message{
  display: block;
}
 
/** チェックボックス横にラベル表示 
[type="checkbox"].toggle{
  position: relative;
width: 100%;
transform: scale(1.2);
}
[type="checkbox"].toggle:after{
  content: "20歳以上です：";
text-align: center;
  position: absolute;
  width: 100%;
  top: 50%;
  transform: translateY(-50%);
padding-right: 130px;
}*/


/** ボタン **/
.disp-box label {
    display: inline-block;
    color: #ffffff;                   /* ボタンの文字色 */
    background-color: #973136;        /* ボタンの背景色 */
    font-weight: bold;                /* 文字の太さ */
    padding: 0.5em 1em;               /* ボタン内側の余白 */
    border: solid 1px #000000; /* ボタンの影部分 */
    border-radius: 3px;               /* 角丸 */
    cursor: pointer;                  /* ボタンにカーソルを合わせた時に指アイコンを表示 */
width: 100%;
    text-align: center;
}
/** ボタンクリック時のボタンを押し込む動作 **/
.disp-box label:active {
    -webkit-transform: translateY(4px); /* Chrome、Safari用 */
    -moz-transform: translateY(4px);    /* Firefox用 */
    -ms-transform: translateY(4px);     /* IE用 */
    transform: translateY(4px);
    border-bottom: none;
}
/** チェックボックス **/
.disp-box input {
    display: none; /* 非表示 */
}
/** 表示・非表示を切り替えるテキスト（「クリックされました！」の部分） **/
.disp-box .text20 {
    overflow: hidden;
    opacity: 0;        /* 文字を非表示 */
    transition: 0.2s;  /* 文字が表示・非表示される時のスピード */
}
/** チェックボックスにチェックが入った時の、テキストの処理 **/
.disp-box input:checked ~ .text20 {
    height: auto;
    opacity: 1; /* 文字を表示 */
}


/** 次へボタン色調整 **/
.fs-c-button {background:#973136; border: 1px solid #973136;}
.fs-l-checkout　.fs-c-button{background: #8f9590; border: 1px solid #8f9590;}
#fs-addressList-container .fs-c-button--secondary {background:#973136; border: 1px solid #973136;}
.fs-c-button--addDestination {color:#ffffff; background:#973136; border: 1px solid #973136;}
.fs-c-button--next{background:#973136; border: 1px solid #973136;}

/** カートページ横幅調整 **/
.fs-l-cart {margin: 24px auto; padding: 8px; max-width: 1216px; flex-wrap: wrap; justify-content: space-between;}
.fs-l-checkout {margin: 24px auto; padding: 8px; max-width: 1216px; flex-wrap: wrap; justify-content: space-between;}
#fs-addressList-container {margin: 24px auto; padding: 8px; max-width: 1216px; flex-wrap: wrap; justify-content: space-between;}
.fs-c-checkout-deliveryInfo {margin: 24px auto; padding: 8px; max-width: 1216px; flex-wrap: wrap; justify-content: space-between;}
.fs-c-buttonContainer--back {margin: 24px auto; padding: 8px; max-width: 1216px; flex-wrap: wrap; justify-content: space-between;}
.fs-l-productLayout__item--2 {margin: 24px auto; padding: 8px; max-width: 1216px; flex-wrap: wrap; justify-content: space-between;}
.fs-l-footer {width: 100%;}


/** "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif; **/

body {
    /font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 16px;
    background-color: $white-color;
    margin-top: 85px;
    @media #{$breakpoint-xs} {
        margin-top: 80px;
    }}

/* ゆっくり遷移する */
html {scroll-behavior: smooth;
}

h1,h2,h3,h4,h5,h6 {
    /font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 16px;
    background-color: $white-color;
    margin-top: 85px;
    @media #{$breakpoint-xs} {
        margin-top: 80px;
    }}

.go {font-family:"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}

.carousel-control-next, .carousel-control-prev {width: 5%;}

/** 頭文字大きく **/
.big:first-letter {
    font-size: 3em;
    line-height: 1;
    float: left;
    margin: 0 .2em 0 0;
    padding: .1em 0;
}

/** pcランキング 色**/
.product_bubble_all
{
	background: #F06010;
}
.product_bubble_rough
{
	background: #64284B;
}
.product_bubble_blanc
{
	background: #005941;
}
.product_bubble_sparkling
{
	background: #004966;
}
.product_bubble_left_all::after
{
	border-color: #F06010 #F06010 transparent transparent;
}
.product_bubble_left_rough::after
{
	border-color: #64284B #64284B transparent transparent;
}
.product_bubble_left_blanc::after
{
	border-color: #005941 #005941 transparent transparent;
}
.product_bubble_left_sparkling::after
{
	border-color: #004966 #004966 transparent transparent;
}

/** 文字横に傍線 **/
.title-border {
display: flex;
align-items: center;
}
.title-border:before,
.title-border:after {
border-top: 1px solid;
content: "";
flex-grow: 1;
}
.title-border:before {
margin-right: 1rem;
}
.title-border:after {
margin-left: 1rem;
}

/** ブログimg　調整 **/
.imgsize {
  width: 100%;
  height: 300px;
  object-fit: cover;
}

/** logoマーク変更 **/
/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc { display: block !important; }
.sp { display: none !important; }
.pctext {text-align: center;}
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 991px) {
.pc { display: none !important; }
.sp { display: block !important; width:100%;}
.pctext {margin:10px 0px 20px 0px;padding:0% 2% 4% 2%;line-height:180%;text-align:left;}
}

/** 黒井追加 **/
p {color:#000000;}
.body {font-family: "hannari" , "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;}
.textarea {margin:10px 0px 20px 0px;padding:0% 2% 4% 2%;}
.ts {line-height:180%;}
.tc {color:#973136;}

/* 画像横縦並び均等*/
.layout_l{
float:left;
	width:49%;
	margin-bottom: 10px;
}
.layout_r{
float:right;
		width:49%;
	margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
.layout_l{
float:none;
width:100%!important;
}
.layout_r{
float:none;
width:100%!important;
}
.spimg-15{width:15%;
}}

/* 画像横縦並び2:8*/
.layout_ll{
float:left;
	width:19%;
	margin-bottom: 10px;
}
.layout_rr{
float:right;
		width:79%;
	margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
.layout_ll{
float:none;
width:100%!important;
}
.layout_rr{
float:none;
width:100%!important;
}}

/** テイスティングコメント欄 start**/	
table.type04 {
	width: 100%;
	border-collapse: separate;
	border-spacing: 1px;
	text-align: left;
	line-height: 1.5;
	border-top: 1px solid #ccc;
}
table.type04 th {
	width: 10%;
	padding: 10px;
	font-weight: bold;
	vertical-align: top;
	border-bottom: 1px solid #ccc;
}
table.type04 td {
	width: 90%;
	padding: 10px;
	vertical-align: top;
	border-bottom: 1px solid #ccc;
}
/** テイスティングコメント欄end**/	

/** gift box area start **/	
.boximgwidth {
	position:static;
	vertical-align:top;
	width:30%;}

.rightbox {
	vertical-align:top;
	padding:0 10px 0 10px;}

.giftboxtable {
	border-collapse: collapse;
	width:100%;}

/** midashi見出しstart **/
.midashi {
	position: relative;
	padding: .75em 1em .75em 2em;
	border: 1px solid #ccc;
	border-top: 3px solid #973136;
	background: -webkit-linear-gradient(top, #fff 0%, #f0f0f0 100%);
	background: linear-gradient(to bottom, #fff 0%, #f0f0f0 100%);
	box-shadow: 0 -1px 0 rgba(255, 255, 255, 1) inset;
	font-size: 120%;
}
.midashi::after {
	position: absolute;
	top: 0.7em;
	left: .6em;
	z-index: 2;
	content: '';
	width: 10px;
	height: 10px;
	border: 3px solid #973136;
	border-radius: 100%
}
/** midashi見出しend **/

/** midashi2見出しstart **/
.midashi2 {
	position: relative;
	padding: .25em 0 .5em .75em;
	border-left: 6px solid #ccc;font-size: 120%;
margin: 20px 0px 10px 0px;}

.midashi2::before {
	position: absolute;
	left: -6px;
	bottom: 0;
	content: '';
	width: 6px;
	height: 50%;
	background-color: #973136;
}
.midashi2::after {
	position: absolute;
	left: 0;
	bottom: 0;
	content: '';
	width: 100%;
	height: 0;
	border-bottom: 1px solid #ccc;
}
/** midashi2見出しend **/

/** midashi3見出しstart **/
.midashi3 {margin: 20px 0px 10px 0px;
padding: .25em 0 .5em .75em;
  border-left: 6px solid #ccc;
  border-bottom: 1px solid #ccc;font-size: 120%;}

.midashi4 {  padding-bottom: .5em; border-bottom: 1px solid #cccccc;font-size:24px;}

.midashi5 {padding-bottom: .5em;
  border-bottom: 3px double #cccccc;}
/** midashi3見出end **/

/** midashi66見出しstart **/
.midashi6 {
  position: relative;
  padding: 0.25em 1em;
  border-top: solid 2px black;
  border-bottom: solid 2px black;
}
.midashi6:before, .midashi6:after {
  content: '';
  position: absolute;
  top: -7px;
  width: 2px;
  height: -webkit-calc(100% + 14px);
  height: calc(100% + 14px);
  background-color: black;
}
.midashi6:before {
  left: 7px;
}
.midashi6:after {
  right: 7px;
}
/** midashi6見出しend **/

/** midashi7見出しstart **/
.midashi7 {
  position: relative;
  overflow: hidden;
  padding: 1.5rem 2rem 1.5rem 130px;
  word-break: break-all;
  border-top: 3px solid #000;
  border-radius: 12px 0 0 0;
}

.midashi7 span {
  font-size: 40px;
  font-size: 4rem;
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  padding: 3px 20px;
  color: #fff;
  border-radius: 10px 0 20px 10px;
  background: #000;
}
/** midashi7見出しend **/

/** 区切り線 start **/
.hr-text {
	line-height: 1em;
	position: relative;
	outline: 0;
	border: 0;
	color: black;
	text-align: center;
	height: 1.5em;
	opacity: .5;
}
.hr-text:before {
	content: '';
	background: -webkit-linear-gradient(left, transparent, #818078, transparent);
	background: linear-gradient(to right, transparent, #818078, transparent);
	position: absolute;
	left: 0;
	top: 50%;
	width: 100%;
	height: 1px;
}
.hr-text:after {
	content: attr(data-content);
	position: relative;
	display: inline-block;
	color: black;
	padding: 0 .5em;
	line-height: 1.5em;
	color: #818078;
	background-color: #fcfcfa;
}
/** 区切り線 end **/

/** 強調pop1 start **/
.pop1 {
text-align: center;
margin:15px 0px;
padding: 0.25em;
border-top: solid 2px #973136;
border-bottom: solid 2px #973136;
background: -webkit-linear-gradient(top, #fff 0%, #f0f0f0 100%);
background: linear-gradient(to bottom, #fff 0%, #f0f0f0 100%);
}
/** 強調pop1 end **/

.resizeimage img {
	width: 100%;}

/*=======================
   table ===========*/
/* クリアフィックス */
.item-list ul:after {
	content: "";
	clear: both;
	display: block;
}
/* 商品一覧のリストの設定 */
.item-list ul li {
	display: block;
	float: left;
	list-style-type: none;
	text-align: center;
	width: 50%;
}

 .hidari {
  float: left;
  margin: 0px 10px 10px 0px;
}

/** table ポイント段階 start **/
#memberrank {
	border: 1px solid #ccc;
    border-collapse: collapse;
    border-spacing: 0;
    margin: 20px auto;
    width: 100%;
}
#memberrank th {
	border: 1px solid #999;
	width:25%;
}
#memberrank td {
	text-align:center;
	border: 1px solid #999;
	width:25%;
}
.platinum {
	background-color:#ADEDF0;
}
.gold {
	background-color:#F9F2D6;
}
.silver {
	background-color:#E9E9E9;
}
.member {
	background-color:#FBE2E0;
}
.memberrank-smp {
	list-style:none;
	padding:0px 10px;
}
/** table ポイント段階 end **/

/** 下部カートに入れる用box start **/
.box22{
    padding: 0.5em 1em;
    margin: 1em 0;
    background: #ffffff;
    border-left: solid 6px #973136;
    box-shadow: 0px 2px 3px rgba(0, 0, 0, 0.33);
}
.box22 p {
    margin: 0; 
    padding: 0;
}
/** 下部カートに入れる用box end **/

/** 表形式 **/
.tb {
  width: 100%;
  border-collapse: collapse;
}

.tb tr{
  border-bottom: dotted 2px #dbdbdb;
}

.tb tr:last-child{
  border-bottom: none;
}

.tb th{
  position: relative;
  text-align: left;
  width: 30%;
  background-color: #dbdbdb;
  color: #3c3c3c;
  text-align: center;
  padding: 10px 0;
}

.tb th:after{
  display: block;
  content: "";
  width: 0px;
  height: 0px;
  position: absolute;
  top:calc(50% - 10px);
  right:-10px;
  border-left: 10px solid #dbdbdb;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
}

.tb td{
  text-align: left;
  width: 70%;
  text-align: center;
  background-color: #ffffff;
  padding: 10px 0;
}

/** 横並びリスト **/
*, *:before, *:after {
	box-sizing: border-box;
}
.col_4{
	width: 100%;
	display: flex;
	display: -ms-flexbox; /* IE10 */
	flex-wrap: wrap;
	-ms-flex-wrap: wrap; /* IE10 */
}
.col_4 > div{
	width: 25%;
	padding: 10px;
}
@media screen and (max-width: 960px) {
	.col_4 > div{
		width: 33.33333%;
	}
}
@media screen and (max-width: 480px) {
	.col_4 > div{
		width: 50%;
	}
}

/** メニューopen-close **/
/* 開いている状態 */
details[open] {
}
/* 閉じている状態 */
details:not([open]) {
}
.bg {background-color:#f5f5f5;}

/*タブ切り替え全体のスタイル*/
.cp_tab *, .cp_tab *:before, .cp_tab *:after {
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
.cp_tab {
	margin: 1em auto;
}
.cp_tab > input[type='radio'] {
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 0;
	outline: none;
	background: none;
	-webkit-appearance: none;
	        appearance: none;
	display: none;
}
.cp_tab .cp_tabpanel {
	display: none;
}
.cp_tab > input:first-child:checked ~ .cp_tabpanels > .cp_tabpanel:first-child,
.cp_tab > input:nth-child(3):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(2),
.cp_tab > input:nth-child(5):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(3),
.cp_tab > input:nth-child(7):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(4),
.cp_tab > input:nth-child(9):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(5),
.cp_tab > input:nth-child(11):checked ~ .cp_tabpanels > .cp_tabpanel:nth-child(6) {
	display: block;
}
.cp_tab > label {
	position: relative;
	display: inline-block;
	padding: 15px;
	cursor: pointer;
	border: 1px solid transparent;
	border-bottom: 0;
margin-bottom: .0rem;
}
.cp_tab > label:hover,
.cp_tab > input:focus + label {
	color: #973136;
}
.cp_tab > input:checked + label {
	margin-bottom: -1px;
	border-color: #cccccc;
	border-bottom: 1px solid #ffffff;/*背景色と同じ*/
	border-radius: 6px 6px 0 0;
}
.cp_tab .cp_tabpanel {
	padding: 0.5em 1em;
	border-top: 1px solid #cccccc;
}
@media (max-width: 480px) {
	.cp_tab {
		width: 100%;
		font-size: 0.8em;
	}
	.cp_tab label {
		padding: 0.5em;
	}
}

/* ここから下がボタンのCSS　*/
a.cp_btn {
	display: block;
	width: 100%;
	padding: 0.8em;
	text-align: center;
	text-decoration: none;
	color: #973136;;
	border: 2px solid #973136;;
	border-radius: 3px;
	transition: .4s;
}
a.cp_btn:hover {
	background: #973136;;
	color: #fff;
}

/* カートに入れるボタンのCSS　*/
button.cp_btn {
	display: block;
	padding: 0.3em;
	text-decoration: none;
	color: #973136;;
	border: 1px solid #973136;;
	border-radius: 3px;
	transition: .4s;
}
button.cp_btn:hover {
	background: #973136;;
	color: #fff;
}

/*戻るボタンstart*/
a.btn-radius-solid {
  border: 1px solid #ccc;
  background: #f1e767;
  background: -webkit-gradient(linear, left top, left bottom, from(#fdfbfb), to(#ebedee));
  background: -webkit-linear-gradient(top, #fdfbfb 0%, #ebedee 100%);
  background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
  -webkit-box-shadow: inset 1px 1px 1px #fff;
  box-shadow: inset 1px 1px 1px #fff;
}

a.btn-radius-solid:hover {
  background: -webkit-gradient(linear, left bottom, left top, from(#fdfbfb), to(#ebedee));
  background: -webkit-linear-gradient(bottom, #fdfbfb 0%, #ebedee 100%);
  background: linear-gradient(to top, #fdfbfb 0%, #ebedee 100%);
}
/*戻るボタンend*/

/* details　*/
details .cmp summary{
    color: transparent;
}
details .cmp summary span {
    color: #000000;
}
details .cmp {
  margin: 14px;
  padding: 10px;
  height: 10px;
  transition: 1s;
}
details[open] {
  height: auto;
  background: #ebebeb;
}

/* ワイナリー紹介 slider　*/
.fs-pt-carousel img {max-width: 25vw;}
@media screen and (max-width: 767px) {
.fs-pt-carousel img {max-width: 70vw;}
}
.abtext {position: relative;}

.abtext p {
  position: absolute;
  top: 65%;/*画像の左上に配置*/
  left: 0;
  margin: 0; /*余計な隙間を除く*/
  color: #ffffff;/*文字を白に*/
  background: rgba(0,0,0,0.5);/*背景色*/
  font-size: 15px;
  line-height: 1;/*行高は1に*/
  padding: 5px 10px;/*文字周りの余白*/
  }

.abtext img {
  width: 100%;
  }

/* 丹波ワインについて 画面幅いっぱい広げる　*/
.winery_h2 span {
    background-color: rgba(0,0,0,0.4);
    border: 1px solid #ffffff;
    border-radius: 10px;
    color: #ffffff;
    display: inline-block;
    padding: 15px;}
.winery_wrapper {
    background-image: url(https://tambawine.itembox.design/item/eco.jpg?t=20250212094933);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    padding: 100px 0;
    width: 100%;
    height: auto;}
.winery_h2 {
    text-align: center;
    margin: 0px;
    padding: 0px;
    border: 0px;
    font: inherit;
    font-size: 100%;
    vertical-align: baseline;}

/* 丹波ワインについて 囲みbox　*/
.box30 {
    margin: 2em 0;
    background: #f1f1f1;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.22);
}
.box30 .box-title {
    font-size: 1.2em;
    background: #973136;
    padding: 4px;
    text-align: center;
    color: #FFF;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.box30 p h4{
    padding: 15px 20px;
    margin: 0;
}

/* 美食とワイン 囲みbox　*/
.box40 {
    margin: 2em 0 0 0;
    background: #000000;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.22);
    color: #ffffff;
}
.box40 .box-title {
    font-size: 1.7em;
    padding: 4px;
    text-align: center;
    color: #ffffff;
    letter-spacing: 0.3em;
border-bottom: 1px solid #c0c0c0;
}
.box40 p{
    padding: 15px 20px;
    margin: 0;
    color: #ffffff;
}

/* ranking tab　*/
.f-8 {font-size:0.7em;}
a:hover, a:focus {
    font-size: 11px;}

/* 画像マウスオーバー処理　*/
figure img {
  opacity: 1;
  -webkit-transition: .3s ease-in-out;
  transition: .3s ease-in-out;
}
figure:hover img {
  opacity: .6;
}

/* 基本情報table風dl　*/
.t01 dt{ float: left;}
.t01 dd{ margin-left: 100px;}

/* 商品説明吹き出しcss　*/
.balloon-002 {
    display: flex;
    justify-content: center;
    position: relative;
    margin-top: 15px;
    padding: .8em 1.2em;
    border-radius: 5px;
    background-color: #f2f2f2;
    color: #333333;
}

.balloon-002::before {
    position: absolute;
    top: -15px;
    width: 30px;
    height: 15px;
    background-color: #f2f2f2;
    clip-path: polygon(50% 0, 0 100%, 100% 100%);
    content: '';
}

.fs-c-productListItem__productDescription {
    font-size: 0.8em;}

/* top slider　画像幅　*/
.carousel-cell {
  width: 80%; /* half-width */
}

/* top slide 画像の上テキスト　*/
.above_text{
    position: absolute;
    top:50%;
    left:50%;
    transform: translate(-50%,-50%);
    padding:0;
    margin:0;
    color: #ffffff;
}

/* top slide 画像の上テキスト2　*/
.above_text2 {
  position: relative;
  }

.above_text2 p {
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
  /*文字の装飾は省略*/
  }

/*　左上ランキング */
.rank2 li {
  counter-increment: rank;
  position: relative;
  overflow: hidden;
}

.rank2 li::before {
  content: "";
  background-color: #bf0000;
  display: block;
  width: 100%;
  height: 4rem;
  transform: rotate(-45deg);
  position: absolute;
  left: -50%;
  top: 0;
}

.rank2 li::after {
  content: counter(rank);
  color: white;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: initial;
  text-align: center;
  width: 1.5em;
  position: absolute;
  left: .3em;
  top: .3em;
}

@media screen and (min-width: 768px) {
  .rank2 li::after {
    font-size: 1.5rem;
  }
}