@charset "UTF-8";

/* product
---------------------------------*/
.user-review-rating {
	padding: 0.5em 1em;
	margin: 2em 0;
	background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px, #e9f4ff 3px, #e9f4ff 7px);
	background: repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px, #e9f4ff 3px, #e9f4ff 7px);
}

.user-review-rating p {
	margin: 0;
	padding: 0;
}

.rating {
	color: #FFD700 !important;
}

.user-review {
	width: 100%;
	margin: 1.5em 0;
	overflow: hidden;
}

.user-review .faceicon {
	float: left;
	margin-right: -90px;
	width: 80px;
}

.user-review .faceicon img {
	width: 100%;
	height: auto;
	border: solid 3px #d7ebfe;
	border-radius: 50%;
}

.user-review .chatting {
	width: 100%;
}

.says {
	display: inline-block;
	position: relative;
	margin: 5px 0 0 105px;
	padding: 17px 13px;
	border-radius: 12px;
	background: #d7ebfe;
}

.says:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: 18px;
	left: -24px;
	border: 12px solid transparent;
	border-right: 12px solid #d7ebfe;
}

.says p {
	margin: 0;
	padding: 0;
}

.point__box {
	position: relative;
	margin: 2em 0;
	padding: 0.5em 1em;
	border: solid 3px #4b3e2e;
	border-radius: 8px;
}

.point__box .point__box-title {
	position: absolute;
	display: inline-block;
	top: -13px;
	left: 10px;
	padding: 0 9px;
	line-height: 1;
	font-size: 19px;
	background: #FFF;
	color: #4b3e2e;
	font-weight: bold;
}

.point__box p {
	margin: 0;
	padding: 0;
}

.marker-yellow {
	background: linear-gradient(transparent 75%, #fff799 75%);
	font-weight: bold;
}

/* ランキング箇所 */
.products__ranking {
	margin: 20px 0;
	background-color: #f1f0e0;
}

@media only screen and (max-width: 767px) {
	.products__ranking {
		padding: 30px 20px;
	}
}

.products__ranking--listBox {
	display: flex;
	display: -webkit-flex;
	display: -ms-flexbox;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-justify-content: space-between;
	flex-wrap: wrap;
}

.products__ranking--list {
	width: 240px;
	margin: 40px 10px;
	padding: 20px 10px;
	box-sizing: border-box;
	background: #fff;
}

@media only screen and (max-width: 767px) {
	.products__ranking--list {
		width: 100%;
	}
}

.products__ranking--list .icon {
	width: 120px;
	margin: -70px auto 10px;
}

@media only screen and (max-width: 767px) {
	.products__ranking--list .icon {
		width: 100px;
	}
}

.products__ranking--list .icon img {
	max-width: 100%;
}

.products__ranking--list .thmbnail {
	margin: 0 auto;
}

.products__ranking--list .thmbnail img {
	width: 100%;
}

@media only screen and (max-width: 767px) {
	.products__ranking--list .thmbnail {
		width: 100%;
		border: solid 3px #fff6f6;
		margin: 0 auto;
	}
}

.products__ranking--list dl {
	margin: 15px auto 10px;
}

.products__ranking--list dt {
	margin-bottom: 10px;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
}

.products__ranking--list dd {
	font-size: 13px;
	line-height: 22px;
}

.products__ranking .box-btn {
	margin-bottom: 0;
}

/* 埋込動画の高さをレスポンシブにする。 */
.movie-wrap {
	position: relative;
	padding-bottom: 56.25%;
	/*アスペクト比 16:9の場合の縦幅*/
	height: 0;
	overflow: hidden;
}

.movie-wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* ドットの罫線 */
.dot-line {
	background: linear-gradient(to right, rgba(75, 62, 46, 1), rgba(75, 62, 46, 1) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%) 0% 0%;
	background-size: 2px 1px;
	height: 1px;
}

/* オプションカード本体 */
.option__card {
	position: relative;
	box-shadow: 0 0 20px 0px gray;
	border-radius: 25px;
	background-color: #FFF;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: auto 40px;
}

/* カードのタイトル */
.option__title {
	color: #fff;
	font-size: 1.0em;
	font-weight: bold;
	background-color: #4b3e2e;
	padding: 0.5em;
	border-radius: 25px 25px 0 0;
	margin-bottom: 0px
}

.option__title h2 {
	text-align: center;
	margin: 0;
}

/* カードのタイトルの既存スタイルをリセット */
.option__title h2::after {
	display: none;
}

.option__summary {
	padding: 1em;
	font-size: 16px;
}

/* プロダクトカード本体 */
.product__card {
	position: relative;
	box-shadow: 0 0 20px 0px gray;
	border-radius: 25px;
	background-color: #FFF;
	margin-bottom: 40px;
}

/* カードのタイトル */
.product__title {
	color: #fff;
	font-size: 1.0em;
	font-weight: bold;
	background-color: #4b3e2e;
	padding: 0.5em;
	border-radius: 25px 25px 0 0;
	margin-bottom: 0px;
}

.product__title h2 {
	text-align: center;
	margin-bottom: 0;
}

/* カードのタイトルの既存スタイルをリセット */
.product__title h2::after {
	display: none;
}

.product__summary {
	padding: 1em;
	font-size: 16px;
}

/* 各情報セクションの枠 */
.summary-text {
	padding: 20px 10px;
	margin: 10px auto;
	background-color: #fff;
	width: 90%;
	display: flex;
}

.price {
	color: #d70a17;
	font-size: 20px;
	font-weight: 600;
	padding: 5px;
}

.price>span {
	font-size: 12px;
}

/* 価格ラベルの枠 */
.price-tag {
	color: #fff;
	background-color: #4b3e2e;
	padding: 10px;
	font-weight: 600;
	display: inline-block;
}

/* ラベルの表示割合 */
.label-section {
	width: 30%;
}

/* その他ラベル枠 */
.info-tag {
	border: solid 1px #4b3e2e;
	padding: 10px;
	display: inline-block;
	font-weight: 600;
}

/* 価格などの情報を記載する割合 */
.contents-section {
	width: 70%;
}

/* 所要時間テキストの余白を設定 */
.duration-text {
	margin: 1em 10px;
	text-align: right;
}

/* 情報テキストの余白を設定 */
.contents-text {
	margin: 1em 10px;
}

/* 背景色を黄緑に */
.bg-lightgreen {
	background-color: #f1f0e0;
}

/* カードの丸み */
.btm-rd {
	border-radius: 0 0 25px 25px;
}

/* 2カラム用 */
*,
*:before,
*:after {
	box-sizing: border-box;
}

.product__col_2 {
	width: 100%;
	display: flex;
	display: -ms-flexbox;
	/* IE10 */
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	/* IE10 */
}

.product__col_2>.summary-img {
	width: 50%;
	/* ★今回追記 */
	border-bottom-left-radius: 25px;
}

.product__col_2>.summary-contents {
	width: 50%;
}

.option__col_2 {
	width: 100%;
	display: flex;
	display: -ms-flexbox;
	/* IE10 */
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	/* IE10 */
}

.option__col_2>.option__card {
	width: 48%;
	padding: auto;
	margin-bottom: 40px;
}

/* オレンジグラデーションボタン */
.btn-gradient-radius {
	display: inline-block;
	padding: 0.8em 1.8em;
	border-radius: 25px;
	text-decoration: none;
	color: #FFF;
	font-weight: 600;
	font-size: 1.4em;
	background-image: linear-gradient(45deg, #ffa500 0%, #ff5514 100%);
	transition: .4s;
	border-bottom: solid 4px #895800;
	margin-top: 18px;
	margin-bottom: 18px;
}

/* ホバー時の挙動 */
.btn-gradient-radius:hover {
	background-image: linear-gradient(45deg, #FFC107 0%, #f76a35 100%);
}

.btn-gradient-radius:active {
	/*ボタンを押したとき*/
	-webkit-transform: translateY(4px);
	transform: translateY(4px);
	/*下に動く*/
	border-bottom: none;
	/*線を消す*/
}

/* ボタン中央配置 */
.btn-center {
	text-align: center;
}

/* 文字だけのリンク */
.txt-link {
	font-weight: 600;
	text-decoration: underline;
}

/* ＳＰスタイル　ここから */
@media screen and (max-width: 767px) {

	/* プロダクトカード */
	.product__col_2>.summary-img {
		width: 100%;
		border-bottom-left-radius: 0px;
	}

	.product__col_2>.summary-contents {
		width: 100%;
	}

	.product__col_2>.option-summary {
		width: 100%;
	}

	/* オプションカード */
	.option__col_2>.option__card {
		width: 100%;
	}
}

/* ＳＰスタイル　ここまで */

/* テーブルデザインの変更 */
.page-parts table {
	max-width: 100% !important;
}

.page-parts table th {
	background-color: initial;
}

.page-parts table tbody th {
	background: #f1f0e0 !important;
	color: #4b3e2e !important;
	padding: 18px 17px !important;
	font-weight: bold !important;
}

.page-parts table thead th {
	background: #4b3e2e !important;
	color: #fff !important;
	padding: 18px 17px !important;
	font-weight: bold !important;
}

.page-parts table thead td {
	background: #4b3e2e !important;
	color: #fff !important;
	padding: 18px 17px !important;
	font-weight: bold !important;
}

table.product-table {
	border-collapse: collapse;
	margin: 0 auto;
	padding: 0;
	width: 650px;
	table-layout: fixed;
}

table.product-table tr {
	background-color: #fff;
	padding: .35em;
	border-bottom: 2px solid #fff !important;
}

table.product-table th,
table.product-table td {
	padding: 1em 10px 1em 1em;
	border-right: 2px solid #fff !important;
	width: calc(100% / 3);
	width: -webkit-calc(100% / 3);
}

table.product-table th {
	font-size: .85em;
}

table.product-table thead tr {
	background-color: #fff;
	color: #fff;
}

table.product-table tbody th {
	background: #f1f0e0 !important;
	color: #fff;
}

.table-txt {
	text-align: right;
	font-size: .85em;
}

.table-price {
	text-align: right;
	color: #d70a17;
	font-weight: bold;
}

.table-price span {
	font-size: 12px;
}

.non {
	background: #4b3e2e;
}

/* ＳＰスタイル　ここから */
@media screen and (max-width: 767px) {

	.page-parts table tbody th {
		background: #4b3e2e !important;
		color: #f1f0e0 !important;
		padding: 18px 17px !important;
		font-weight: bold !important;
	}

	table.product-table {
		border: 0;
		width: 100%
	}

	table.product-table th {
		background-color: #4b3e2e;
		display: block;
		border-right: none;
	}

	table.product-table thead {
		border: none;
		clip: rect(0 0 0 0);
		height: 1px;
		margin: -1px;
		overflow: hidden;
		padding: 0;
		position: absolute;
		width: 1px;
	}

	table.product-table tr {
		display: block;
		margin-bottom: .625em;
	}

	table.product-table td {
		border-bottom: 1px solid #bbb !important;
		display: block;
		font-size: .8em;
		text-align: right;
		position: relative;
		padding: .625em .625em .625em 4em;
		border-right: none;
	}

	table.product-table td::before {
		content: attr(data-label);
		font-weight: bold;
		position: absolute;
		left: 10px;
		color: #4b3e2e;
	}

	table.product-table td:last-child {
		border-bottom: 0;
	}

	table.product-table tbody th {
		color: #fff;
	}
}

/* ＳＰスタイル　ここまで */
