/*--------------------------------------*
 * foundation
 *--------------------------------------*/

*,
*:before,
*:after {
	box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
	border: 0;
	font: inherit;
	font-size: 100%;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

ol,
ul {
	list-style: none;
}

li,
dd {
	list-style-type: none;
}

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
	display: block;
}

html {
	font-size: 16px;
	height: 100%;
	line-height: 1;
	scroll-behavior: smooth;
	scroll-padding-top: 100px;
}

body {
	color: #222222;
	font-family: "Noto Sans JP", sans-serif !important;
	font-weight: 400;
	line-height: 1.7;
}

img,
video,
object {
	border: none;
	display: block;
	height: auto;
	width: 100%;
}

a {
	cursor: pointer;
	text-underline-offset: 3px;
}

a:hover {
	text-decoration: none;
	transition: all 0.3s;
}

a:hover img {
	opacity: 0.7;
	text-decoration: none;
	transition: all 0.3s;
}

/*===================================================================
# Header
===================================================================*/

.l-header {
  background-color: #040404;
  position: fixed;
  width: 100%;
  z-index: 1000;
}

.l-header__upper-contents {
  align-items: center;
  display: flex;
  height: 90px;
  justify-content: space-between;
  position: relative;
}

.l-header__drawer-icon {
  background-color: transparent;
  display: flex;
  flex-direction: column;
  height: 24px;
  justify-content: space-between;
  opacity: 1;
  transition: opacity 0.8s ease, visibility 0.8s ease;
  visibility: visible;
  width: 30px;
}

.l-header__drawer-bar {
  background-color: #fff;
  height: 3px;
  width: 100%;
}

.l-header__icon-x { /* バツアイコン */
  height: 26px;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 50%;
  transition: opacity 0.8s ease, visibility 0.8s ease;
  translate: 0 -50%;
  visibility: hidden;
  width: 26px;
}

.l-header__logo {
  height: auto;
  left: 50%;
  position: absolute;
  top: 50%;
  translate: -50% -50%;
  width: 200px;
}

.l-header__link-top { /* お買い物TOPへ */
  color: #fff; 
  letter-spacing: 2.24px;
  line-height: 27px;
  transition: opacity 0.3s ease;
}

.l-header__cart {
  height: 30px;
  margin-left: auto;
  margin-right: 0;
  width: 42px;
}

.l-header__lower-contents { /* SP時のみ表示 */
  align-items: center;
  background-color: #2f2e2e;
  display: none;
  gap: 20px;
  height: 33px;
  justify-content: center;
}

.l-header__lower-link-top {
  color: #fff;
  font-size: 14px;
}

.l-header__lower-link-top:hover {
  color: #fff;
  opacity: 0.7;
}

.l-header__lower-link-purchase {
	color: #fff;
	font-size: 12px;
	text-decoration: none;
}

.l-header__nav-container {
  background-color: rgba(4, 4, 4, 0.9);
  left: 50%;
  padding-bottom: 88px;
  padding-top: 85px;
  position: relative;
  transform: translateX(-50%);
}

.l-header__nav {
  display: flex;
  margin: 0 auto;
  max-width: 1000px;
  width: 100%;
}

.l-header__lists--1 {  /* 一番左のメニューブロック */
  max-width: 222px;
  padding-left: 30px;
  width: 100%;
}

.l-header__lists--2,
.l-header__lists--3,
.l-header__lists--4 {
  border-left: 1px solid rgba(255, 255, 255, 0.3);
  padding-left: 30px;
  width: 100%;
}

.l-header__lists--2 { /* 左から2番目のメニューブロック */
  max-width: 344px;
}

.l-header__lists--3 { /* 左から3番目のメニューブロック */
  max-width: 302px;
}

.l-header__lists--4 { /* 一番右のメニューブロック */
  max-width: 302px;
}

.l-header__list::after {
  border-right: solid 1px;
  border-top: solid 1px;
  color: #fff;
  content: "";
  display: none;
  height: 8px;
  position: absolute;
  right: 31px;
  top: 50%;
  transform: translateY(-50%);
  transform: rotate(45deg) translateY(-50%);
  width: 8px;
}

.l-header__listLink {
  color: #fff;
  font-size: 18px;
  letter-spacing: 1.8px;
  line-height: 50px;
  padding-left: 16px;
  position: relative;
}

.l-header__listLink:hover {
  color: #fff;
}

.l-header__listLink::before { /* 不等号のマーク */
  border-right: solid 1px;
  border-top: solid 1px;
  color: #fff;
  content: "";
  display: inline-block;
  height: 8px;
  left: -4px;
  position: absolute;
  top: 12px;
  transform: rotate(45deg) translateY(-50%);
  width: 8px;
}

/* メニューを開いたとき：ドロワーを非表示、バツを表示 */
.l-header__drawer-icon.js-hide {
  opacity: 0;
  visibility: hidden;
}

.l-header__icon-x.js-show {
  opacity: 1;
  visibility: visible;
}

/*===================================================================
# Footer
===================================================================*/

.l-footer {
  background-color: #eaebec;
}

.l-footer__contents {
  align-items: center;
  display: flex;
  height: 116px;
}

.l-footer__sns-items {
  display: flex;
  gap: 20px;
  margin-right: 43px;
  padding-left: 0;
}

.l-footer__sns-icon {
  height: 50px;
  width: 50px;
}

.l-footer__list-link {
  color: #222;
  font-size: 14px;
  letter-spacing: 1.4px;
  padding-left: 13px;
  position: relative;
}

.l-footer__copyright {
  font-size: 12px;
  letter-spacing: 1.2px;
  line-height: 3.75;
  margin-left: auto;
  margin-right: 0;
}

/*===================================================================
# Compornent
===================================================================*/

.c-inner {
  margin-inline: auto;
  max-width: 1040px;
  padding-inline: 20px;
}

.c-section__title {
	color: #fff;
	font-size: 48px;
	letter-spacing: 2.88px;
	line-height: 70px;
	padding-bottom: 14px;
	position: relative;
}

.c-section__title::after {
	background-color: #fff;
	bottom: 0;
	content: "";
	height: 2px;
	left: 0;
	position: absolute;
	width: 90px;
}

.c-section__title--wh {
	color: #222;
}

.c-link span {
  color: #222;
  display: inline-block;
  position: relative;
  text-decoration: underline;
}

.c-link span::before {
  border-right: 1px solid #222;
  border-top: 1px solid #222;
  content: "";
  display: inline-block;
  height: 10px;
  left: -19px;
  position: absolute;
  top: 9px;
  transform: rotate(45deg);
  width: 10px;
}

.c-link--wh span {
  color: #fff;
}

.c-link--wh span::before {
  border-right: 1px solid #fff;
  border-top: 1px solid #fff;
}

.c-link--pl {
  padding-left: 20px;
}

/*===================================================================
# 基本セット
===================================================================*/

.p-base-set__inner {
	margin-bottom: 40px; /* 元々95pxを修正 */
}

.p-base-set__inner.narrow {
	margin-left: auto;
	margin-right: auto;
	max-width: 860px;
}

.p-base-set__remove-mr { /* bootstrapにより意図しない余白が出た場合の処理 */
	overflow: hidden;
}

.p-base-set__hr { /* 区切り線 */
	background-color: #ccc;
	height: 1px;
}

.p-base-set__show-pc { /* PCサイズのみ表示 */
	display: block;
}

.p-base-set__show-sp { /* SPサイズのみ表示 */
	display: none;
}

.p-base-set__breadcrumb-wrap { /* パンくずリスト */
	margin-left: auto;
	margin-right: auto;
	max-width: 1000px;
	padding-top: 113px;
}

.p-base-set__breadcrumb {
	align-items: center;
	display: flex;
	gap: 12px;
  	margin-left: 0;
	padding-left: 0;
}

.p-base-set__breadcrumb a:hover {
  color: #222!important;
}

.p-base-set__breadcrumb-top,
.p-base-set__breadcrumb-current {
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.84px;
	line-height: 26px;
}

.p-base-set__breadcrumb-top {
	color: #222;
}

.p-base-set__breadcrumb-top:hover {
	color: #222;
}

.p-base-set__breadcrumb-2nd {  /* 第2階層 */
	color: #222;
	white-space: nowrap;
}

.p-base-set__breadcrumb-2nd:hover {
	color: #222;
}

.p-base-set__breadcrumb-2nd::before {
	color: #222;
	content: " > ";
	display: inline-block;
	padding-right: 5px;
	text-decoration: none;
}

.p-base-set__breadcrumb-current { /* 現在のページ */
	color: #999;
}

.p-base-set__breadcrumb-current::before {
	color: #222;
	content: " > ";
	padding-right: 5px;
}
.p-base-set__breadcrumb a{
	color: #222;
}

.p-base-set__h1 {
	font-size: 48px;
	letter-spacing: 2.88px;
	line-height: 70px;
	padding-bottom: 14px;
	position: relative;
}

.p-base-set__h1::after {
	background-color: #222;
	bottom: 0;
	content: "";
	height: 2px;
	left: 0;
	position: absolute;
	width: 90px;
}

.p-base-set__h2 {
	font-size: 30px;
	font-weight: bold;
	letter-spacing: 3px;
	line-height: 36px;
}

.p-base-set__h3 {
	font-size: 24px;
	font-weight: bold;
	letter-spacing: 2.4px;
	line-height: 36px;
}

.p-base-set__h4 {
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 1.23px;
	line-height: 30px;
}

.p-base-set__h5-container { /* h5セクションの余白 */
	margin-bottom: 55px;
}

.p-base-set__h5 {
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 1.8px;
	line-height: 29px;
}

.p-base-set__p {
	letter-spacing: 2.24px;
	line-height: 27px;
}

.p-base-set__center {
	text-align: center;
}

.p-base-set__3column {
	margin-bottom: 55px;
	margin-top: 55px;
}

.p-base-set__3column-lower { /* グリッドのタイトル上の余白 */
	margin-top: 15px;
}

.p-base-set__gray-back { /* 背景がグレーのサンプル */
	margin-top: 55px;
}

.p-base-set__gray-container { /* グレー背景 */
	background-color: #eaebec;
	border-radius: 10px;
	margin-top: 27px;
	padding: 34px 41px 37px 41px;
}

.p-base-set__2column-1 {
	border: 1px solid #ccc;
	border-radius: 10px;
	box-sizing: border-box; /* 画像とテキストの横並び パターン1 */
	margin-top: 60px;
}

.p-base-set__2column-1-right {
	padding: 33px 42px 37px 47px;
}

.p-base-set__2column-1-img {
	border-radius: 8px 0 0 8px;
	height: 100%;
	width: 100%;
}

.p-base-set__2column-2 {  /* 画像とテキストの横並び パターン2 */
	border: 1px solid #ccc;
	border-radius: 10px;
	margin-bottom: 50px;
	margin-top: 60px;
	padding: 35px;
}

.p-base-set__2column-2-img {
	border-radius: 6px;
}

.p-base-set__2column-2-right {
	padding-left: 35px;
}

.p-base-set__a {
	color: #222;
	display: inline-block;
	letter-spacing: 1.6px;
	line-height: 32px;
}

.p-base-set__a:hover {
	color: #222;
}

.p-base-set__p--gray {
	color: #999;
	letter-spacing: 1.6px;
	line-height: 32px;
}

.p-base-set__product-contents { /* 商品詳細パーツ */
	display: flex;
	gap: 75px;
	margin-top: 50px;
}

.p-base-set__product-content--left {
	width: 52.1367521368%;
}

.p-base-set__product-content--right {
	width: 41.452991453%;
}

.p-base-set__p--bold { /* テキスト 太字 */
	font-weight: bold;
}

.p-base-set__product-a-wrap {
	margin-bottom: 30px;
	margin-top: 10px;
}

.p-base-set__a--product {
	line-height: 40px;
	padding-left: 16px;
	position: relative;
}

.p-base-set__a--product::before {
	border-right: solid 1px;
	border-top: solid 1px;
	color: #222;
	content: "";
	display: inline-block;
	height: 8px;
	left: -4px;
	position: absolute; /*  */
	top: calc(50% - 1px);
	transform: rotate(45deg) translateY(-50%);
	width: 8px;
}

.p-base-set__product-feature-wrap { /* 12%OFF 送料無料 */
	display: flex;
	gap: 25px;
	height: 46px;
	margin-bottom: 25px;
	margin-top: 25px;
}

.p-base-set__product-feature {
	border: 1px solid #ff0066;
	border-radius: 10px;
	color: #ff0066;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 1.6px;
	line-height: 46px;
	max-width: 230px;
	text-align: center;
	width: 100%;
}

.p-base-set__product-price {  /* 料金 */
	color: #ff0066;
	font-size: 30px;
	font-weight: bold;
	letter-spacing: 3px;
	line-height: 1;
	text-align: right;
}

.p-base-set__product-btn { /* カートに入れるボタン */
	background-color: #000;
	color: #fff;
	display: block;
	font-size: 20px;
	font-weight: bold;
	height: 71px;
	letter-spacing: 1.62px;
	line-height: 37px;
	margin-bottom: 21px;
	margin-top: 30px;
	width: 100%;
	text-decoration: none;
	text-align: center;
	padding: 17px;
}

.p-base-set__product-btn:hover {
	opacity: 0.7;
  color: #FFF;
}

.p-base-set__product-annotation-wrap { /* 注釈 */
	align-items: flex-end;
	display: flex;
	margin-bottom: 30px;
}

.p-base-set__product-line { 
	border: 1px solid #06c755;
	border-radius: 6px;
	color: #06c755;
	cursor: pointer;
	display: inline-block;
	font-size: 14px;
	font-weight: bold;
	height: 31px;
	letter-spacing: 1.12px;
	line-height: 31px;
	text-align: center;
	text-decoration: none;
	width: 100%;
}

.p-base-set__product-line:hover,
.p-base-set__product-line:active,
.p-base-set__product-line:focus {
	color: #06c755;
	opacity: 0.7;
	outline: 0;
	text-decoration: none;
}

/* 基本テーブル */

.p-base-set__inner table{
	border-collapse: separate;
	border-left: 1px solid #ccc;
	border-radius: 6px;
	border-spacing: 0;
	border-top: 1px solid #ccc;
	width: 100%;
}

.p-base-set__inner table tr:first-child th:first-child { /* 左上の角丸 */
	border-radius: 6px 0 0 0;
}

.p-base-set__inner table tr:first-child td:last-child {  /* 右上の角丸 */
	border-radius: 0 6px 0 0;
}

.p-base-set__inner table tr:last-child td:last-child { /* 右下の角丸 */
	border-radius: 0 0 6px 0;
}

.p-base-set__inner table tr:last-child th:first-child { /* 左下の角丸 */
	border-radius: 0 0 0 6px;
}

.p-base-set__inner table th {
	background-color: #eaebec;
	text-align: center;
	vertical-align: middle;
}

.p-base-set__inner table td {

}

.p-base-set__inner table th,
.p-base-set__inner table td {
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
	padding-bottom: 15px;
	padding-top: 15px;
	padding-left: 27px;
	padding-right: 27px;
  	word-break: break-word;
	letter-spacing: 1.6px;
	line-height: 27px;
}

.p-base-set__link-button {  /* リンクボタン */
	background-color: #222;
	color: #fff;
	display: block;
	font-size: 20px;
	height: 70px;
	letter-spacing: 3.12px;
	line-height: 70px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	text-decoration: none;
	width: 350px;
}

.p-base-set__link-button:hover {
	color: #fff;
	opacity: 0.7;
}

.p-base-set__ul-title {  /* 箇条書きの上の余白 */
	margin-top: 55px;
}

.p-base-set__ul { /* マークとテキストの間隔を調整 箇条書きul */
	padding-left: 22px;
}

.p-base-set__ul li {
	position: relative;
}

.p-base-set__ul li::after {
	border: 1px solid #222;
	border-radius: 50%;
	content: "";
	height: 4px;
	left: -16px;
	position: absolute;
	top: 51%;
	transform: translateY(-50%);
	width: 4px;
}

.p-base-set__li {
	letter-spacing: 1.6px;
	line-height: 27px;
}

.p-base-set__li--span {
	margin-right: 5px;
}

/*===================================================================
# コラム一覧
===================================================================*/

.p-article-list__container {
	display: flex;
	gap: 50px;
	margin: 0 auto;
	max-width: 1040px;
	padding-inline: 20px;
}

.p-article-list__main {
	max-width: 73.9316239316%;
	width: 100%;
}

.p-article-list__aside {
	margin-top: 28px;
	max-width: 21.7948717949%;
	width: 100%;
}

.p-article-list__contents {
	margin-bottom: 60px;
	padding-top: 40px;
}

.p-article-list__category {
	background-color: #bcd7e5;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 1.96px;
	line-height: 20px;
	text-align: center;
	display: inline-block;
	padding: 3px 10px 3px 10px;
	margin-right: 5px;
    margin-bottom: 0;
}

.p-article-list__contents-title {
	letter-spacing: 0.96px;
	line-height: 27px;
}

.p-article-list__date {
	font-size: 14px;
	letter-spacing: 28px;
	letter-spacing: 1.12px;
}

.p-column__link {
	color: #222;
	text-decoration: none;
}

.pagination {
	display: flex;
	gap: 10px;
	justify-content: center;
}

.page-numbers {
	border: 1px solid #222;
	color: #222;
	display: inline-block;
	height: 35px;
	line-height: 35px;
	text-align: center;
	text-decoration: none;
	width: 35px;
}
.page-numbers:hover {
	opacity: 0.7;
	color: #222;
}

.page-numbers.current {
	background-color: #222;
	color: #fff;
}

.page-numbers.prev,
.page-numbers.next {
	width: auto;
	padding: 0 10px;
}

.p-article-list__aside-title {
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 2.4px;
	line-height: 26px;
}

.p-article-list__aside-a {
	letter-spacing: 2.24px;
	line-height: 35px !important;
}

.p-article-list__cta-aside {
	background-image: linear-gradient(to top, #090909, #1d1d1d, #252525, #000);
	margin-bottom: 60px;
}

.p-article-list__cta-aside-inner {
	padding-left: 21px;
	padding-right: 21px;
}

.p-article-list__cta-aside-text-main {
	height: auto;
	width: 100%;
}

.p-article-list__cta-aside-text-sub {
	height: auto;
	width: 100%;
}

.p-article-list__cta-side-img-product {
	height: auto;
	width: 100%;
}

.p-article-list__cta-side-btn-container {
	align-items: center;
	display: flex;
	height: 44px;
	justify-content: center;
	position: relative;
	width: 100%;
}

.p-article-list__cta-side-btn-background {
	background-color: rgba(255, 255, 255, 0.2);
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.p-article-list__cta-side-btn {
	background-color: transparent;
	color: rgba(255, 255, 255, 0.9);
	height: 100%;
	letter-spacing: 2.24px;
	line-height: 27px;
	position: relative;
	width: 100%;
}

.p-article-list__cta-side-btn:hover {
	opacity: 0.7;
}

.p-article-list__cta-aside-annotation {
	font-size: 10px;
	letter-spacing: -0.84px;
	line-height: 15px;
  	color: #fff;
	font-weight: 300;
}

.p-article-list__aside-hr {
	margin-bottom: 35px;
	margin-top: 60px;
}

.p-article-list__cta {
	background-image: linear-gradient(to top, #090909, #1d1d1d, #252525, #000);
	margin-top: 100px;
}

.p-article-list__content-left {
	padding-left: 70px;
}

.p-article-list__cta-text-main {
	height: auto;
	max-width: 318px;
}

.p-article-list__content-center {
	padding-left: 25px;
}

.p-article-list__text-sub {
	max-width: 506px;
}

.p-article-list__btn-container {
	align-items: center;
	display: flex;
	height: 60px;
	justify-content: center;
	position: relative;
	width: 350px;
}

.p-article-list__btn-background {
	background-color: rgba(255, 255, 255, 0.2);
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.p-article-list__btn {
	background-color: transparent;
	color: rgba(255, 255, 255, 0.9);
	letter-spacing: 2.24px;
	line-height: 27px;
	position: relative;
	width: 100%;
	text-align: center;
	text-decoration: none;
}

.p-article-list__btn:hover {
	opacity: 0.7;
	color: rgba(255, 255, 255, 0.9);
}

.p-article-list__img-product {
	height: auto;
	max-width: 182px;
}

/*===================================================================
# コラム記事
===================================================================*/

.p-article__container {
	display: flex;
	gap: 50px;
	margin: 0 auto;
	max-width: 1170px;
}

.p-article__main {
	max-width: 865px;
}

.p-article__aside {
	max-width: 255px;
}

.p-article__h1 {
	font-size: 30px;
	letter-spacing: 2.4px;
	line-height: 2.17;
	padding-bottom: 14px;
	position: relative;
}

.p-article__h1::after {
	background-color: #bcd7e5;
	bottom: 0;
	content: "";
	height: 3px;
	left: 0;
	position: absolute;
	width: 90px;
}

.p-article__contents h2 {
	background-color: #bcd7e5;
	font-size: 22px;
	font-weight: bold;
	letter-spacing: 1.92px;
	line-height: 1.5;
	padding: 9px 20px;
}

.p-article__contents h3 {
	font-size: 24px;
	font-weight: bold;
	letter-spacing: 2.4px;
	line-height: 36px;
	position: relative;
}

.p-article__contents h3::before {
	background-color: #bcd7e5;
	bottom: -8px;
	content: "";
	height: 3px;
	left: 0;
	position: absolute;
	width: 100%;
}

.p-article__contents h4 {
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 1.2px;
	line-height: 1.45;
	padding-inline-start: 22px;
	position: relative;
}

.p-article__contents h4::before {
	background-color: #bcd7e5;
	content: "";
	height: 12px;
	left: 0;
	position: absolute;
	top: 50%;
	translate: 0 -50%;
	width: 12px;
}

.p-article__category {
	background-color: #bcd7e5;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 1.12px;
	line-height: 20px;
	text-align: center;
	display: inline-block;
    padding: 3px 10px;
    margin-right: 5px;
}

.p-article__author {
	letter-spacing: 0.96px;
	line-height: 27px;
	margin-right: 10px;
	position: relative;
}

.p-article__author::before {
	background-color: rgba(204, 204, 204, 0.96);
	content: "";
	height: 18px;
	position: absolute;
	right: -10px;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
}

.p-article__author::after {
	background-color: rgba(204, 204, 204, 0.96);
	content: "";
	height: 18px;
	left: -10px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
}

.p-article__aside-hr {
	margin-bottom: 35px;
	margin-top: 54px;
}

.c-toc {
	border: solid 3px #bcd7e5;
	border-radius: 10px;
	margin-block-start: 35px;
	padding: 40px;
	transition: opacity 0.3s ease;
}

.c-toc a {
	color: #222;
	display: inline-block;
	position: relative;
	text-decoration: none;
}

.c-toc a::after {
	background: #bcd7e5;
	bottom: -2px;
	content: "";
	height: 1px;
	left: 0;
	position: absolute;
	transition: width 0.3s ease;
	width: 0;
}

.c-toc__title {
	margin-block-end: 40px;
	text-align: center;
}

.c-toc__title span {
	font-size: 22px;
	font-weight: bold;
	position: relative;
}

.c-toc__title span::after {
	background-color: #bcd7e5;
	bottom: -8px;
	content: "";
	height: 3px;
	left: 50%;
	position: absolute;
	translate: -50%;
	width: 120%;
}

.level-2 > .c-toc__link {
	font-size: 18px;
	font-stretch: normal;
	font-style: normal;
	font-weight: bold;
	letter-spacing: 1.2px;
	line-height: 1.45;
	margin-block-end: 3px;
	padding-inline-start: 12px;
	position: relative;
	text-align: justify;
}

.level-2 > .c-toc__link::before {
	background: url(https://file001.shop-pro.jp/PA01507/365/img/toc_arrow.svg) center center/contain no-repeat;
	content: "";
	height: 13px;
	left: 0;
	position: absolute;
	top: calc((1.45em - 13px) / 2);
	width: 7px;
}

.c-toc__item.level-2 {
	margin-block-end: 25px;
}

.c-toc__item.level-2:last-of-type {
	margin-block-end: 0;
}

.level-3 > .c-toc__link {
	font-size: 14px;
	font-stretch: normal;
	font-style: normal;
	font-weight: normal;
	letter-spacing: 1.96px;
	line-height: 2.36;
	margin-inline-start: 14px;
	padding-inline-start: 12px;
	position: relative;
	text-align: justify;
}

.level-3 > .c-toc__link::before {
	background: url(https://file001.shop-pro.jp/PA01507/365/img/toc_arrow.svg) center center/contain no-repeat;
	content: "";
	height: 13px;
	left: 0;
	position: absolute;
	top: calc((2.36em - 13px) / 2);
	width: 7px;
}

.p-fv__annotation {
	color: #fff;
	font-size: 14px;
	font-weight: 300;
	letter-spacing: 1.96px;
	line-height: 1.57;
}

.p-fv__annotation span {
	font-weight: 100;
}

/*===================================================================
# お問い合わせ
===================================================================*/

.p-contact__inner {
	margin: 0 auto 100px;
	max-width: 860px;
}

.p-contact__form-table {  /* テーブル */
	border: 1px solid #cccccc;
	border-collapse: separate;
	border-radius: 6px;
	border-spacing: 0;
	overflow: hidden; /* 内部のセルがはみ出さないようにする */
	width: 100%;
}

.p-contact__form-table tr th.p-contact__form-label {
	border-right: 1px solid #ccc;
}

.p-contact__form-table tr:not(:last-child) th.p-contact__form-label {
	border-bottom: 1px solid #ccc;
}

.p-contact__form-table tr:not(:last-child) td.p-contact__form-item {
	border-bottom: 1px solid #ccc;
}

.p-contact__form-label { /* ラベルの外枠 */
	background-color: #eaebec;
	font-weight: 500;
	letter-spacing: 2.6px;
	line-height: 53px;
	padding: 14px 0 14px 25px;
	vertical-align: middle;
	width: 29.6511627907%;
}

.p-contact__form-item { /* 入力欄の外枠 */
	padding: 25px;
	width: 70.3488372093%;
}

.p-contact__form-item--address, /* ラジオボタンの余白 */
.p-contact__form-item--buy {
	padding-bottom: 20px;
}

.p-contact__form-item--radio { /* ラジオボタンの余白 */
	padding-bottom: 10px;
	padding-top: 18px;
}

.p-contact__form-item--chk { /* チェックボックスの余白 */
	padding-bottom: 20px;
	padding-top: 18px;
}

.p-contact__form-input, /* インプットボックス */
.p-contact__form-textarea {
	border: 1px solid #ccc;
	border-radius: 2px;
	box-sizing: border-box;
	letter-spacing: 1.6px;
	line-height: 26px;
	padding-left: 13px;
}

.p-contact__form-input:focus, /* フォーカスが当たった時にアウトラインをつける */
.p-contact__form-textarea:focus {
	outline: 1px solid #222;
}

.p-contact__form-input { /* インプットボックス */
	height: 35px;
	width: 300px;
}

.p-contact__form-textarea {  /* テキストエリア */
	height: 140px;
	vertical-align: middle;
	width: 100%;
}

.p-contact__required,
.p-contact__required--sp {
	background: #f06;
	color: #fff;
	font-size: 12px;
	font-weight: 500;
	line-height: 20px;
	margin-bottom: 5px;
	padding: 0px 7px;
	vertical-align: middle;
}

.p-contact__required {
	display: inline-block;
	margin-left: 8px;
}

.p-contact__required--sp {
	display: none;
	margin-right: 8px;
}

.p-contact__form-group { /* インプットボックスの項目を1列にする */
	align-items: center;
	display: flex;
	margin-bottom: 10px;
}

.p-contact__form-input--w100 { /* 横幅が100pxのインプットボックス */
	width: 100px;
}

.p-contact__form-input--w400 { /* 横幅が400pxのインプットボックス */
	width: 400px;
}

.p-contact__form-input--w500 { /* 横幅が500pxのインプットボックス */
	width: 500px;
}

.p-contact__form-hyphen { /* ハイフン */
	color: #ccc;
	display: inline-block;
	margin: 0 5px;
}

.p-contact__form-hyphen--bk {
	color: #222;
	margin-right: 20px;
}

.p-contact__form-note { /* 注意書き */
	color: #999;
	font-size: 14px;
	letter-spacing: 1.4px;
	line-height: 26px;
	margin-top: -5px;
}

.p-contact__form-inside-label { /* インプットボックス内のラベル */
	font-weight: 500;
	letter-spacing: 1.6px;
	line-height: 26px;
	width: 100px;
}

.p-contact__form-inside-label--type2 {
	width: 100%;
}

.p-contact__zipcode-btn { /* 住所自動登録ボタン */
	background-color: #222;
	color: #fff;
	font-size: 14px;
	font-weight: 500;
	height: 35px;
	letter-spacing: 1.4px;
	line-height: 26px;
	margin-left: 15px;
	width: 160px;
}

.p-contact__zipcode-btn:hover {
	opacity: 0.7;
}

.p-contact__form-input--prefecture { /* 都道府県 */
	width: 100px;
	-webkit-appearance: none; /* Chrome, Safari, Opera, Edge */
	-moz-appearance: none; /* Firefox */
	appearance: none; /* デフォルトの矢印アイコンを非表示にする */
	background: none; /* 背景をクリア */
	cursor: pointer;
}

.p-contact__select-wrap {
	background-color: #fff;
	position: relative;
}

.p-contact__select-wrap::after {
	border-right: solid 1px;
	border-top: solid 1px;
	bottom: calc(50% + 2px);
	color: #222;
	content: "";
	display: inline-block;
	height: 12px;
	pointer-events: none; /* ポインターイベントを無効に */
	position: absolute;
	right: 15px;
	transform: rotate(135deg) translateY(-50%);
	width: 12px;
}

.p-contact__radio label {
	cursor: pointer;
	position: relative;
}

.p-contact__radio input[type=radio] + label::before { /* 疑似のラジオボタン */
	background-color: #fff;
	border: 1px solid #BCBCBC;
	border-radius: 50%;
	content: "";
	height: 17px;
	left: 0;
	position: absolute;
	top: 52%;
	transform: translateY(-50%);
	width: 17px;
}

.p-contact__radio input[type=radio]:focus + label:before {
	outline: 1px solid #222; /* フォーカスが当たった時にアウトラインをつける */
}

.p-contact__radio input[type=radio]:checked + label::after { /* 疑似のラジオボタン（チェック時） */
	background-color: #333;
	border-radius: 50%;
	content: "";
	height: 11px;
	left: 3px;
	position: absolute;
	top: 52%;
	transform: translateY(-50%);
	width: 11px;
}

.p-contact__default-chk { /* デフォルトのチェックボックスを非表示にする */
	opacity: 0;
	position: absolute;
}

.p-contact__default-chk + label { /* 各項目のラベル */
	cursor: pointer;
	padding-left: 26px; /* チェックボックスのスペースを確保 */
	position: relative;
}

.p-contact__default-chk + label:before { /* 疑似のチェックボックス */
	background-color: #fff;
	border: 1px solid #BCBCBC;
	border-radius: 5px;
	content: "";
	height: 17px;
	left: 0;
	position: absolute;
	top: 52%;
	transform: translateY(-50%);
	width: 17px;
}

.p-contact__default-chk:focus + label:before { /* フォーカスが当たった時にアウトラインをつける */
	outline: 1px solid #222;
}

.p-contact__default-chk + label:after { /* 疑似のチェックマーク */
	border-bottom: 2px solid #fff;
	border-right: 2px solid #fff;
	content: "";
	height: 10px;
	left: 6px;
	opacity: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	width: 5px;
}

.p-contact__default-chk:checked + label:after { /* チェックした時にマークを表示させる */
	opacity: 1;
}

.p-contact__default-chk:checked + label::before { /* チェックされたときの背景色を#222に変更 */
	background-color: #222;
}

.p-contact__privacy-wrap { /* プライバシーポリシー 外枠 */
	margin-bottom: 37px;
	margin-top: 34px;
	text-align: center;
}

.p-contact__privacy-link,
.p-contact__agreement-label { /* 同意する */
	color: #222;
	letter-spacing: 1.6px;
	line-height: 27px;
}

.p-contact__privacy-link {
	display: inline-block;
}

.p-contact__privacy-link:hover {
	color: #222;
}

.p-contact__privacy-chk { /* デフォルトのチェックボックスを非表示にする */
	opacity: 0;
	position: absolute;
}

.p-contact__privacy-chk + label { /* ラベル */
	cursor: pointer;
	padding-left: 27px; /* チェックボックスのスペースを確保 */
	position: relative;
}

.p-contact__privacy-chk + label:before { /* 疑似のチェックボックス */
	background-color: #fff;
	border: 1px solid #BCBCBC;
	border-radius: 5px;
	content: "";
	height: 17px;
	left: 2px;
	position: absolute;
	top: 54%;
	transform: translateY(-50%);
	width: 17px;
}

.p-contact__privacy-chk:focus + label:before { /* フォーカスが当たった時にアウトラインをつける */
	outline: 1px solid #222;
}

.p-contact__privacy-chk + label:after { /* 疑似のチェックマーク */
	border-bottom: 2px solid #fff;
	border-right: 2px solid #fff;
	content: "";
	height: 10px;
	left: 8px;
	opacity: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	width: 5px;
}

.p-contact__privacy-chk:checked + label:after { /* チェックした時にマークを表示させる */
	opacity: 1;
}

.p-contact__privacy-chk:checked + label::before { /* チェックされたときの背景色を#222に変更 */
	background-color: #222;
}

.p-contact__form-btn { /* 送信ボタン */
	background: #222;
	color: #FFF;
	display: block;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 1.62px;
	line-height: 37px;
	margin: 0 auto;
	padding: 17px 131px;
}

.p-contact__form-btn:hover {
	cursor: pointer;
	opacity: 0.7;
}

.p-contact__form-btn:focus { /* フォーカスが当たった時にアウトラインをつける */
	border: 3px solid #fff;
}

/*===================================================================
# ご購入前のよくある質問ページ
===================================================================*/

.p-qa-before__container {
	margin-bottom: 94px;
	margin-left: auto;
	margin-right: auto;
	max-width: 860px;
}

.p-qa-before__link-lists {  /* 内部リンク */
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-top: 60px;
}

.p-qa-before__link-list {
	border-left: 1px solid #ccc;
	box-sizing: border-box;
	height: 56px;
	max-width: 172px;
	text-align: center;
	width: 100%;
}

.p-qa-before__link-list:last-child {
	border-right: 1px solid #ccc;
}

.p-qa-before__link {
	align-items: center;
	color: #222;
	display: flex;
	height: 100%;
	justify-content: center;
	letter-spacing: 1.6px;
	line-height: 27px;
}

.p-qa-before__link:hover {
	color: #222;
}

.p-qa-before__section { /* 各セクション */
	margin-bottom: 74px;
	margin-top: 74px;
}

.p-qa-before__question,
.p-qa-before__answer {
	display: flex;
	gap: 17px;
}

.p-qa-before__question {
	align-items: center;
}

.p-qa-before__question-icon {
	font-weight: bold;
	letter-spacing: 2.5px;
	padding-bottom: 3px;
}

.p-qa-before__question-text {
	font-weight: bold;
}

.p-qa-before__answer-icon {
	letter-spacing: 4.5px;
}

/*===================================================================
# お知らせ
===================================================================*/
.p-notice {
  margin-bottom: 60px;
}
.p-notice__items {
  height: 224px;
  margin-inline: auto;
  max-width: 660px;
  overflow-y: scroll;
  padding-right: 32px;
}
.p-notice__item {
  margin-bottom: 24px;
}
.p-notice__item:last-of-type {
  margin-bottom: 0;
}

.p-notice__upper {
  align-items: center;
  display: flex;
  gap: 10px;
}

.p-notice p {
  letter-spacing: 1.6px;
  line-height: 2;
  text-align: justify;
}

.p-notice__label {
  align-items: center;
  background-color: #eaebec;
  display: flex;
  font-size: 14px;
  font-weight: 500;
  height: 19px;
  justify-content: center;
  letter-spacing: 0.56px;
  width: 60px;
}

.p-notice__date {
  color: #666;
}

.p-notice__link-wrap {
  margin-inline: auto;
  max-width: 660px;
}

/* イベントセクション スクロールバーのスタイル */
.p-notice ::-webkit-scrollbar {
  width: 4px; /* スクロールバーの幅 */
}

.p-notice ::-webkit-scrollbar-track {
  background: #ccc; /* トラックの背景色 */
}

.p-notice ::-webkit-scrollbar-thumb {
  background: #333; /* ハンドルの背景色 */
}

.p-notice ::-webkit-scrollbar-thumb:hover {
  background: #555; /* ホバー時のハンドルの背景色 */
  cursor: pointer;
}

/* お知らせ */
#news-preview.row .col .p-column__link:first-of-type {
  display: none;
}
#news-preview.row .col .p-column__link::nth-of-type(2) {
  margin-bottom: 0;
}
#news-preview.row .col .p-article-list__contents-text{
  margin-bottom: 0;
}  
#news-preview.row .col .p-article-list__date{
  margin-bottom: 10px;
}

/*===================================================================
# 商品リスト
===================================================================*/

.p-list__container {
	display: flex;
	gap: 50px;
	margin: 0 auto;
	max-width: 1040px;
	padding-inline: 20px;
}

.p-list__main {
	margin-bottom: 94px;
	width: 73.9316239316%;
}

.p-list__aside {
	margin-top: 62px;
	width: 21.7948717949%;
}

.p-list__aside-ul {
  padding-left:	0;
}

.p-list__text { /* タイトル下の説明文 */
	font-weight: bold;
	letter-spacing: 2.24px;
	line-height: 27px;
	margin-top: 53px;
}

.p-list__order { /* 並べ替えブロック */
	display: flex;
	gap: 25px;
	justify-content: flex-end;
	margin-top: 35px;
}

.p-list__arrows {
	align-items: center;
	display: flex;
}

.p-list__arrow-img {
	height: 20px;
	width: 13px;
}

.p-list__order-items { /* 並べ替えタイプ */
	align-items: center;
	display: flex;
	justify-content: space-between;
	max-width: 366px;
	width: 100%;
  	margin-bottom: 0;
}

.p-list__order-item {
	border-left: 1px solid #ccc;
	box-sizing: border-box;
	height: 30px;
	max-width: 122px;
	text-align: center;
	width: 100%;
}

.p-list__order-item:last-child {
	border-right: 1px solid #ccc;
}

.p-list__order-link {
	color: #222;
	letter-spacing: 1.28px;
	line-height: 27px;
}

.p-list__order-link:hover {
	color: #222;
}

.p-list__product-contents {
	margin-bottom: 55px;
	padding-top: 40px;
}

.p-list__product-a {
	color: #222;
	text-decoration: none;
}

.p-list__product-a:hover {
	color: #222;
	opacity: 0.7;
}

.p-list__product-feature-wrap { /* 割引 送料無料 */
	display: flex;
	gap: 9px;
}

.p-list__product-feature {
	border: 1px solid #ff0066;
	border-radius: 6px;
	color: #ff0066;
	font-size: 14px;
	font-weight: bold;
	height: 27px;
	letter-spacing: 1.12px;
	line-height: 27px;
	text-align: center;
	width: 50%;
}

.p-list__product-title { /* 商品名 */
	font-weight: bold;
	letter-spacing: 0.96px;
	line-height: 27px;
}

.p-list__product-volume {  /* 容量 */
	font-size: 14px;
	letter-spacing: 1.28px;
	line-height: 22px;
	text-align: right;
}

.p-list__product-price { /* 金額 */
	color: #f06;
	font-weight: bold;
	letter-spacing: 1.28px;
	line-height: 28px;
	text-align: right;
}

.p-list__product-text { /* 商品の説明文 */
	letter-spacing: 0.96px;
	line-height: 28px;
}

.p-list__group-link {
	color: #222;
	display: block;
	letter-spacing: 1.6px;
	line-height: 34px;
}

.p-list__group-link:hover {
	color: #222;
}

.p-list__group-link:nth-child(n+2) {  /* 2番目以降のリンク 余白 */
	margin-top: -7px;
}

.p-list__recent-check {  /* 最近チェックした商品 */
	margin-top: 55px;
}

.p-list__show-pc {
	display: block;
}

.p-list__show-sp {
	display: none;
}

.p-list__product-contents--chk { /* 最近チェックした商品 タイトル下の余白 */
	padding-top: 28px;
}

.p-list__aside-title {
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 2.4px;
	line-height: 26px;
}

.p-list__aside-a {
	letter-spacing: 2.24px;
	line-height: 35px;
}

.p-list__p--gray {
	color: #999999;
	font-weight: bold;
	letter-spacing: 2.24px;
	line-height: 35px;
}

/*===================================================================
# 商品詳細ページ
===================================================================*/

.p-products__inner {
	margin-bottom: 95px;
}

.p-products__thumb-image { /* サムネイル画像 */
	cursor: pointer;
	transition: opacity 0.3s ease;
}

.p-products__thumb-image:hover {
	opacity: 0.7;
}

.p-products__category-link { /* 商品名の上の商品種類 */
	color: #222;
	letter-spacing: 1.6px;
	line-height: 34px;
}

.p-products__category-link:hover {
	color: #222;
}

.p-products__size,
.p-products__aroma-level-p { /* 香りの強さ テキスト */
	letter-spacing: 2.24px;
	line-height: 27px;
}

.p-products__aroma-level,
.p-products__review-level { /* レビュー */
	align-items: center;
	display: flex;
}

.p-products__level-gauge,
.p-products__star-gauge { /* 星の数 */
	align-items: center;
	display: flex;
	gap: 2px;
}

.p-products__rectangle,
.p-products__star { /* 星の大きさ */
	height: 12px;
	width: 12px;
}

.p-products__review-link { /* レビュー リンク */
	color: #222;
	font-size: 14px;
	letter-spacing: 1.4px;
	line-height: 34px;
	margin-left: 10px;
}

.p-products__review-link:hover {
	color: #222;
}

.p-products__shipping {
	letter-spacing: 1.6px;
	line-height: 31px;
	text-align: right;
}

.p-products__number-wrap { /* 数量選択 */
	align-items: center;
	display: flex;
	gap: 3px;
}

.p-products__number { /* 数量 ラベル */
	font-size: 14px;
	letter-spacing: 1.12px;
	line-height: 27px;
}

.p-products__quantity-selector { /* ドロップダウンの幅を設定 */
	position: relative;
	width: 100px;
}

.p-products__quantity-dropdown,
.product_cart_select {
	border: 1px solid #999;
	border-radius: 6px;
	width: 100%;
	-webkit-appearance: none; /* デフォルトのスタイルを無効化 */
	-moz-appearance: none;
	appearance: none;
	background-color: #fff;
	background-image: url("https://file001.shop-pro.jp/PA01507/365/img/triangle.svg");
	background-position: right 10px center;
	background-repeat: no-repeat;
	background-size: 11px 11px;
}

.p-products__quantity-dropdown{
	padding: 0 15px 0 0;
	text-align: center;
}

.product_cart_select{
	padding: 0 15px 0 10px;
	text-align: left;
	height: 30px;
}
.p-product-option{
  margin-top: 20px;
}
.p-product-option-select__box{
  margin-bottom: 10px;
}

.p-products__quantity-dropdown:focus,
.product_cart_select:focus {
	border-color: #007bff; /* フォーカス時のボーダーカラーを設定 */
	outline: none; /* フォーカス時のアウトラインを無効化 */
}

.p-products__sold-out { /* 売り切れ */
	background-color: #999;
}

.p-products__container {
	max-width: 865px;
}

.p-products__about { /* 製品について */
	margin-top: 75px;
}

.p-products__about-text {
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 2px;
	line-height: 31px;
}

.p-products__blend-img { /* ブレンド */
	border-radius: 10px;
}

.p-products__blend-name {
	letter-spacing: 1.28px;
	line-height: 28px;
	text-align: center;
}

.p-products__effects {
	margin-bottom: 60px;
}

.p-products__effects-text {  /* 各効能・効果のテキスト */
	letter-spacing: 1.6px;
	line-height: 27px;
}

.p-products__sample-img {  /* 香りのサンプル 画像 */
	border-radius: 10px;
}

.p-products__review {
	margin-bottom: 59px;
	margin-top: 55px; /* レビュー */
}

.p-products__review-content:not(:last-child) {
	margin-bottom: 43px;
}

.p-products__review-name {
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 1.8px;
	line-height: 29px;
}

.p-products__review-info {
	align-items: center;
	display: flex;
	gap: 26px;
}

.p-products__review-info-left {  /* 年代・性別 */
	display: flex;
	gap: 17px;
}

.p-products__review-age,
.p-products__review-gender {
	letter-spacing: 1.6px;
	line-height: 27px;
}

.p-products__review-info-right {
	align-items: center;
	display: flex;
	gap: 15px;
}

.p-products__review-date {
	letter-spacing: 1.3px;
	line-height: 31px;
}

.p-products__review-date-line {
	background-color: #222;
	height: 16px;
	width: 1px;
}

.p-products__review-comment {
	letter-spacing: 1.6px;
	line-height: 27px;
}

.p-products__review-post {
	color: #222;
	letter-spacing: 1.6px;
	line-height: 27px;
}

.p-products__review-post:hover {
	color: #222;
}

.p-products__refill-margin { /* レフィルのマージン */
	margin-bottom: 75px;
	margin-top: 25px;
}

.p-products__refill-teikibin { /* 定期便のマージン */
	margin-bottom: 60px;
}

.p-products__refill-multi-set { /* 複数台セット */
	margin-bottom: 60px;
	margin-top: 60px;
}

.p-products__refill-contents { /* レフィル / 定期便 / 複数台セット 共通 */
	display: flex;
	gap: 51px;
	margin-top: 28px;
}

.p-products__refill-content-left {
	height: auto;
	max-width: 255px;
	width: 100%;
}

.p-products__refill-title {
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 1.8px;
	line-height: 29px;
	margin-top: -9px;
}

.p-products__refill-size {
	font-size: 14px;
	letter-spacing: 0.84px;
	line-height: 27px;
}

.p-products__refill-price {
	letter-spacing: 1.28px;
	line-height: 28px;
}

.p-products__refill-content-left--multi { /* 複数台セット */
	background-color: #eaebec;
	padding-top: 20px;
	position: relative;
}

.p-products__multi-badge { /* 商品名のバッジ */
	align-items: center;
	background-color: #222;
	border-radius: 50%;
	color: #fff;
	display: flex;
	font-size: 12px;
	height: 73px;
	justify-content: center;
	left: 5px;
	letter-spacing: 1.92px;
	line-height: 16px;
	opacity: 0.8;
	position: absolute;
	text-align: center;
	top: 5px;
	width: 73px;
}

.p-products__multi-img {
	max-height: 83px;
	max-width: 125px;
}

.p-products__multi-img--upper {
	margin-left: auto;
	margin-right: auto;
}

.p-products__multi-img-lower {
	display: flex;
	gap: 5px;
	justify-content: center;
	margin-top: 4px;
}

.p-products__multi-link-wrap a {
	display: block;
}

.p-products__multi-link-wrap :not(:first-child) {
	margin-top: 11px;
}

/*===================================================================
# campaign
===================================================================*/

.campaign {
	background-color: #fff;
	opacity: 0.96;
	position: fixed;
}

.campaign-inner {
	margin: 0 auto;
	max-width: 1174px;
	padding-bottom: 10px;
	padding-top: 10px;
}

.campaign-contents {
	align-items: center;
	display: flex;
	justify-content: center;
}

.campaign-content--1 { /* 左 画像ブロック */
}

.campaign-content--2 {
	display: flex; /* 中央 メッセージブロック */
	gap: 16px;
	margin-left: 10px;
	margin-right: 20px;
}

.campaign-img {
	display: block; /* 左 レモンとペンの画像 */
	width: 130px;
}

.campaign-img img {
	height: auto;
	width: 100%;
}

.campaign-text {
	display: block; /* 中央 メインメッセージ */
	height: auto;
	max-width: 454px;
	width: 100%;
}

.campaign-text img {
	height: auto;
	width: 100%;
}

.campaign-features {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.campaign-feature {
	align-items: center;
	border: solid 1px #f06;
	border-radius: 6px;
	color: #f06;
	display: flex;
	font-size: 14px;
	height: 28px;
	justify-content: center;
	letter-spacing: 1.12px;
	width: 285px;
    margin-bottom: 0;
}

.campaign-br--sp {
	display: none;
}

.campaign-link {
	align-items: center;
	background-color: #000;
	color: #fff;
	display: flex;
	font-size: 18px;
	height: 60px;
	justify-content: center;
	letter-spacing: 1.8px;
	transition: opacity 0.3s;
	width: 255px;
}

.campaign-link:hover {
	color: #fff;
	opacity: 0.7;
}

.campaign-br {
	display: none;
}

.campaign-icon-wrap {
	align-items: center;
	background-color: #fff;
	cursor: pointer;
	display: flex;
	height: 40px;
	justify-content: center;
	opacity: 0.96;
	position: absolute; /* バツアイコン 背景*/
	right: 24px;
	top: -40px;
	transition: opacity 0.3s;
	width: 40px;
}

.campaign-icon-wrap:hover {
	opacity: 0.7;
}

.campaign-icon {
	height: 26px;
	width: 26px; /* バツアイコン */
}

/* BootStrapのマージン打ち消し*/
.p-base-set__product-feature,
.p-products__number,
.p-products__review-age,
.p-products__review-gender,
.p-products__review-date,
.p-products__aroma-level-p,
.p-base-set__p
{
  margin-bottom: 0;
}



.p-list__product-a {
  color: #222;
  text-decoration: none;
}

.p-list__product-a:hover {
  color: #222;
  opacity: 0.7;
}

/* 特定商取引 */
.payment_img{
  width: auto;
  display: inline-block;
}

/*===================================================================
# Hover
===================================================================*/

@media (any-hover: hover) {

.l-header__link-top:hover {
  color: #fff;
  opacity: 0.7;
}

.l-footer__list-link:hover {
  color: #222;
}

.c-link span:hover {
  color: #222;
  text-decoration: none;
}

.c-link--wh span:hover {
  color: #fff;
}

.p-column__link:hover {
  color: #222;
  opacity: 0.7;
}
  
}

/*===================================================================
# Tablet
===================================================================*/

@media screen and (min-width: 768px) and (max-width: 1169px) {

.c-inner {
  margin-left: 30px;
  margin-right: 30px;
}

/* ヘッダー */
.l-header__lists--1 {
	max-width: 100px;
	padding-left: 10px;
}

.l-header__listLink {
	font-size: 16px;
}

/* フッター */
.l-footer__sns-container {
	padding-left: 0;
}

.l-footer__sns {
	gap: 10px;
}

/* インナー幅　共通 */
.c-inner {
	margin-left: 30px;
	margin-right: 30px;
}

/* TOPページ */
.p-fv__inner {
	margin-left: 30px;
	margin-right: 30px;
}

.p-fv__contents {
	margin-left: 0;
	margin-right: 0;
}

.p-fv__img-product {
	margin-top: 15px;
}

.p-feature__img--1st img {
	margin-left: auto;
}

.p-voice__inner {
	margin-left: 30px;
	margin-right: 30px;
}

.p-result__pickup-left {
	width: auto;
}

.p-result__pickup-left img {
	height: 100%;
	width: 254px;
	-o-object-fit: cover;
	object-fit: cover;
}

.p-result__pickup-right {
	width: auto;
}

.p-product__contents {
	gap: 0;
	justify-content: space-between;
}

.p-product__img--1 {
	width: 62.1621621622%;
}

.p-product__img--2 {
	width: 41.3513513514%;
}

.p-product__badge {
	z-index: 1;
}

.p-product__img--3 {
	margin-top: 155px;
}
  
/* パンくず */
.p-base-set__breadcrumb-wrap {
	margin-left: 20px;
	margin-right: 20px;
}

/* コラム一覧ページ */
.p-article__container {
	margin-left: 30px;
	margin-right: 30px;
}

/* カートリッジ一覧ページ */
.p-list__container {
	flex-direction: column;
	margin-bottom: 55px;
	margin-left: 30px;
	margin-right: 30px;
}

.p-list__main {
	margin-bottom: 0;
	width: 100%;
}

.p-list__aside {
	margin-top: 0;
	width: 100%;
}

.p-list__recent-check {
	margin-top: 37px;
}

.p-list__show-pc {
	display: none;
}

.p-list__show-sp {
	display: block;
}

/* お問い合わせページ */
.p-contact__inner {
	padding-left: 30px;
	padding-right: 30px;
}
  
/* 商品リスト */
.p-list__container {
	flex-direction: column;
	margin-bottom: 55px;
	margin-left: 30px;
	margin-right: 30px;
}
  
.p-list__main {
	margin-bottom: 0;
	width: 100%;
}
  
.p-list__aside {
	margin-top: 0;
	width: 100%;
}
  
.p-list__recent-check {
	margin-top: 37px;
}
  
.p-list__show-pc {
	display: none;
}
  
.p-list__show-sp {
	display: block;
}
  
.p-product__contents {
	gap: 0;
	justify-content: space-between;
}

.p-product__img--1 {
	width: 62.1621621622%;
}

.p-product__img--2 {
	width: 41.3513513514%;
}

.p-product__img--3 {
	margin-top: 155px;
}	

}

/* キャンペーン Tablet */
@media (min-width: 768px) and (max-width: 1173px) {

	.campaign-inner {
		max-width: 718px;
		padding-bottom: 9.125px;
		padding-top: 9.125px;
	}

	.campaign-content--2 {
		flex-direction: column; /* 中央 メッセージブロック */
		gap: 4.5px;
		margin-left: 14px;
		margin-right: 20px;
		max-width: 359px;
	}

	.campaign-img {
		width: 135px;
	}

	.campaign-text {
		width: 100%;
	}

	.campaign-features {
		flex-direction: row;
		gap: 5px;
	}

	.campaign-feature {
		font-size: 10px;
		height: 18px;
		letter-spacing: 0.2px;
		width: 100%;
	}

	.campaign-link {
		font-size: 14px;
		height: 40px;
		letter-spacing: 1.4px;
		width: 190px;
	}

	.campaign-icon-wrap {
		height: 30px;
		right: 0;
		top: -30px;
		width: 30px;
	}

	.campaign-icon {
		height: 20px;
		width: 20px;
	}
}


/*===================================================================
# SP
===================================================================*/
@media screen and (max-width: 767px) {

html {
	scroll-padding-top: 50px;
}

.l-header {
	position: static;
}

.l-header__upper-contents {
  height: 50px;
}

.l-header__logo {
  height: 29px;
  width: 158px;
}
  
.l-header__link-top {
  display: none;
}

.l-header__cart {
  height: auto;
  width: 36px;
}
  
.l-header__lower-contents {
  display: flex;
}

.l-header__nav-container {
  padding-bottom: 33px;
  padding-top: 0;
}

.l-header__nav {
  display: block;
}

.l-header__nav:last-child {
  border-bottom: 1px solid rgba(255, 255, 255, 0.3) !important;
}

.l-header__lists {
  margin-bottom: 0;
}

.l-header__lists--2,
.l-header__lists--3,
.l-header__lists--4 {
  border-left: none;
  padding-left: 0;
}

.l-header__lists--2 {
  max-width: none;
}

.l-header__lists--3 {
  max-width: none;
}

.l-header__lists--4 {
  max-width: none;
}

.l-header__list {
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  padding-left: 30px;
  position: relative;
}

.l-header__list::after {
  display: inline-block;
}

.l-header__listLink {
  display: block;
  line-height: 60px;
  text-decoration: none;
  width: 100%;
}

.l-header__listLink::before {
  display: none; /* spでは非表示 */
}

.l-footer c-inner {
  margin-left: auto!important;
  margin-right: auto!important;
  }
 
.l-footer {
  padding-block: 30px 10px;
}

.l-footer__contents {
  flex-direction: column;
  height: auto;
}

.l-footer ul {
  margin-bottom: 0;
  padding-left: 0;
}
  
.l-footer__sns-items {
  margin-right: 0;
}

.l-footer__copyright {
  margin-left: 0;
  margin-top: 8px;
}

.c-section__title {
	font-size: 30px;
	font-weight: 500;
	letter-spacing: 2.4px;
	line-height: 38px;
	padding-bottom: 9px;
	width: 100%;
}

.c-section__title::after {
	width: 50px;
}
  
  .p-base-set__inner {
	margin-bottom: 50px;
}

.p-base-set__show-pc {
	display: none;
}

.p-base-set__show-sp {
	display: block;
}

.p-base-set__breadcrumb-wrap {
	margin-left: 20px;
	margin-right: 20px;
	padding-top: 10px;
}

.p-base-set__breadcrumb-current {
	overflow-x: scroll;
	white-space: nowrap;
}

.p-base-set__h1 {
	font-size: 30px;
	font-weight: 500;
	letter-spacing: 2.4px;
	line-height: 38px;
	padding-bottom: 9px;
	width: 100%;
}

.p-base-set__h1::after {
	width: 50px;
}

.p-base-set__h2 {
	font-size: 26px;
	letter-spacing: 2.6px;
	line-height: 34px;
}

.p-base-set__h3 {
	font-size: 23px;
	letter-spacing: 2.76px;
	line-height: 32px;
}

.p-base-set__h5-container {
	margin-bottom: 35px;
}

.p-base-set__h5 {
	line-height: 27px;
}

.p-base-set__3column {
	margin-bottom: 35px;
	margin-top: 40px;
}

.p-base-set__gray-back {
	margin-top: 35px;
}

.p-base-set__gray-container {
	padding: 18px 13px;
}

.p-base-set__2column-1 {
	margin-top: 40px;
	overflow: hidden;
}

.p-base-set__2column-1-right {
	padding: 20px 30px;
}

.p-base-set__2column-1-img {
	border-radius: 9px 9px 0 0;
}

.p-base-set__2column-2 {
	margin-bottom: 40px;
	margin-top: 40px;
	padding: 20px;
}

.p-base-set__2column-2-right {
	padding-left: 10px;
	padding-right: 10px;
}

.p-base-set__product-contents {
	display: block;
	margin-bottom: 40px;
	margin-top: 40px;
}

.p-base-set__product-content--left {
	width: 100%;
}

.p-base-set__product-content--right {
	width: 100%;
}

.p-base-set__product-a-wrap {
	margin-bottom: 0;
}

.p-base-set__a--product {
	line-height: 27px;
}

.p-base-set__a--product::before {
	top: 13px;
}

.p-base-set__product-feature-wrap {
	gap: 20px;
	height: 32px;
	margin-bottom: 20px;
	margin-top: 10px;
}

.p-base-set__product-feature {
	border-radius: 6px;
	font-size: 16px;
	letter-spacing: 1.28px;
	line-height: 30px;
	max-width: 160px;
}

.p-base-set__product-price {
	font-size: 23px;
	letter-spacing: 2.3px;
}

.p-base-set__product-btn {
	font-size: 16px;
	margin-top: 20px;
}

.p-base-set_p-gray--product {
	letter-spacing: 1.2px !important;
}

.p-base-set__link-button {
	font-size: 16px;
	width: 100%;
}

.p-base-set__ul-title {
	margin-top: 40px;
}

.c-inner {
  margin-left: 0;
  margin-right: 0;
}

.p-fv__annotation {
  font-size: 12px;
  letter-spacing: 0.8px;
  text-align: right;
}

.p-event {
	margin-bottom: 40px;
	margin-top: 34px;
}

.p-event__h3 {
	font-size: 23px;
	letter-spacing: 1.84px;
	line-height: 32px;
}

.p-event__contents-container {
	margin-left: 0;
	margin-top: 25px;
}

.p-event__contents {
	margin-top: 14px;
	padding: 16px 16px 0 16px;
	border: 1px solid #DDD;
}

.p-event__contents .p-event__upper{
	display: block;
}
.p-event__contents .p-event__label{
  margin-bottom: 5px;
}

.p-history {
	padding-bottom: 36px;
	padding-top: 40px;
}

.p-history__logo-wrap {
	margin-bottom: 40px;
	margin-left: 20px;
	margin-right: 20px;
}

.p-history__section-title {
	letter-spacing: 1.84px !important;
}

.p-column {
	margin-bottom: 36px;
	margin-top: 30px;
}

.p-column__section-title {
	letter-spacing: 1.84px !important;
	margin-bottom: 12px;
}

.p-column__category {
	margin-top: 12px;
}

.p-column__text {
	margin-top: 6px;
}

.p-article-list__container {
	display: block;
}

.p-article-list__main {
	max-width: none;
	padding-top: 10px;
}

.p-article-list__aside {
	margin-top: 0;
	max-width: none;
}

.p-article-list__contents {
	margin-bottom: 26px;
	padding-top: 30px;
}

.p-article-list__aside-a::before {
	top: 50%;
}

.p-article-list__cta-aside-inner {
	padding-left: 20px;
	padding-right: 20px;
}

.p-article-list__cta-side-img-product {
	height: auto;
	margin-left: auto;
	margin-right: auto;
	width: 229px;
}

.p-article-list__cta-side-btn-container {
	height: 50px;
}

.p-article-list__cta-side-btn {
	font-size: 15px;
	font-weight: 300;
	letter-spacing: 1.8px;
}

.p-article-list__cta-aside-annotation {
	font-size: 11px;
	letter-spacing: 1.5px;
	line-height: 18px;
}

.p-article-list__cta {
	display: none;
}

.p-article__container {
	display: block;
	margin-left: 20px;
	margin-right: 20px;
}

.p-article__container {
	display: block;
}

.p-article__category {
	letter-spacing: 1.96px;
}

.p-article__h1::after {
	bottom: 4px;
	height: 2px;
	width: 50px;
}

.p-article__h1 {
	font-size: 24px;
	letter-spacing: 1.92px;
	line-height: 1.42;
}

.p-article__contents h2 {
	font-size: 20px;
	line-height: 1.6;
	letter-spacing: 1.6px;
}

.p-article__contents h3 {
	font-size: 18px;
	letter-spacing: 1.08px;
	line-height: 1.33;
}

.p-article__contents h4 {
	font-size: 16px;
	letter-spacing: 0.96px;
	line-height: 1.63;
}

.p-article__category {
	letter-spacing: 1.96px;
}

.p-article__author {
	font-size: 14px;
	letter-spacing: 0.84px;
}
  
.c-toc {
	padding: 25px 20px;
}

.level-2 > .c-toc__link {
	font-size: 18px;
	letter-spacing: 1.08px;
	line-height: 1.33;
	margin-block-end: 18px;
}

.c-toc__item.level-2 {
	margin-block-end: 30px;
}
  
.level-3 > .c-toc__link::before {
	top: calc((1.63em - 13px) / 2);
}

.level-3 > .c-toc__link {
	font-size: 16px;
	letter-spacing: 0.96px;
	line-height: 1.63;
}

.c-toc__item.level-3 {
	margin-block-end: 18px;
}

.p-contact__inner {
	margin-bottom: 60px;
	margin-left: 20px;
	margin-right: 20px;
	padding-top: 10px;
}

.p-contact__form-table {
	background-color: #eaebec;
	padding-top: 26px;
}

.p-contact__form-table tr {
	display: block;
	width: 100%;
}

.p-contact__form-table tr th.p-contact__form-label {
	border-right: none;
}

.p-contact__form-table tr:not(:last-child) th.p-contact__form-label {
	border-bottom: none;
}

.p-contact__form-table tr:not(:last-child) td.p-contact__form-item {
	border-bottom: none;
}

.p-contact__form-label {
	display: block;
	letter-spacing: 2.56px;
	line-height: 27px;
	padding-bottom: 0px;
	padding-left: 15px;
	padding-top: 0px;
	width: 100%;
}

.p-contact__form-item {
	padding: 4px 15px 26px 15px;
	width: 25%;
}

.p-contact__form-input {
	width: 100%;
}

.p-contact__form-input--zipcode {
	width: calc(100% - 162px);
}

.p-contact__form-textarea {
	height: 180px;
}

.p-contact__required {
	display: none;
}

.p-contact__required--sp {
	display: inline-block;
}

.p-contact__form-note {
	margin-top: -8px;
}

.p-contact__zipcode-btn {
	width: 152px;
}

.p-contact__form-input--prefecture {
	padding-left: 30px;
	width: 142px;
}

.p-contact__privacy-wrap {
	margin-bottom: 27px;
}

.p-contact__form-btn {
	font-size: 16px;
	height: 55px;
	letter-spacing: 1.28px;
	line-height: 55px;
	max-width: 350px;
	padding: 0;
	text-align: center;
	width: 100%;
}

.p-qa-before__container {
	margin-bottom: 56px;
}

.p-qa-before__link-lists {
	flex-wrap: wrap;
	margin-top: 32px;
}

.p-qa-before__link-list {
	border-left: none;
	max-width: none;
	min-height: 64px;
	width: 50%;
}

.p-qa-before__link-list:nth-child(2n+1) {
	border-right: 1px solid #ccc;
}

.p-qa-before__link-list:not(:last-child) {  /* 最後の要素を除くすべてに下の境界線を追加 */
	border-bottom: 1px solid #ccc;
}

.p-qa-before__link-list:nth-last-child(2):nth-child(odd) { /* 要素数が偶数の場合、最後の1つ前の要素には下の境界線をつけない */
	border-bottom: none;
}

.p-qa-before__link-list:last-child {
	border-right: none;
}

.p-qa-before__link-list:last-child:nth-last-child(1):nth-child(odd) {
	border-right: 1px solid #ccc;
}

.p-qa-before__section {
	margin-bottom: 44px;
	margin-top: 44px;
}
  
.p-list__container {
	display: block;
	margin-bottom: 55px;
	margin-left: 0;
	margin-right: 0;
}

.p-list__main {
	margin-bottom: 0;
	padding-top: 10px;
	width: 100%;
}

.p-list__aside {
	margin-top: 34px;
	width: 100%;
}

.p-list__text {
	margin-top: 25px;
}

.p-list__order {
	gap: 10px;
	margin-top: 31px;
}

.p-list__order-items {
	justify-content: flex-end;
	max-width: initial;
	width: auto;
}

.p-list__order-item {
	max-width: initial;
	width: auto;
}

.p-list__order-link {
	margin-left: 10px;
	margin-right: 10px;
}

.p-list__product-contents {
	margin-bottom: 32px;
	padding-top: 30px;
}

.p-list__product-feature {
	font-size: 13px;
	height: 25px;
	letter-spacing: 1.04px;
	line-height: 25px;
}

.p-list__product-volume {
	letter-spacing: 0.84px;
	line-height: 27px;
	-moz-text-align-last: left;
	text-align-last: left;
}

.p-list__product-price {
	-moz-text-align-last: left;
	text-align-last: left;
}

.p-list__recent-check {
	margin-top: 37px;
}

.p-list__show-pc {
	display: none;
}

.p-list__show-sp {
	display: block;
}
  
.p-products__inner {
	margin-bottom: 45px;
}

.p-products__size,
.p-products__aroma-level-p {
	font-size: 14px;
	letter-spacing: 1.12px;
	line-height: 34px;
}

.p-products__about {
	margin-top: 37px;
}

.p-products__about-text {
	font-size: 18px;
	letter-spacing: 1.44px;
	line-height: 27px;
}

.p-products__effects {
	margin-bottom: 45px;
}

.p-products__review-info {
	gap: 10px;
}

.p-products__review-info-left {
	gap: 8px;
}

.p-products__review-info-right {
	gap: 10px;
}

.p-products__refill-margin {
	margin-bottom: 55px;
}

.p-products__refill-teikibin {
	margin-bottom: 40px;
}

.p-products__refill-multi-set {
	margin-bottom: 40px;
	margin-top: 60px;
}

.p-products__refill-contents {
	gap: 25px;
}

.p-products__refill-contents-multi {
	display: block;
}

.p-products__refill-content-left--multi {
	margin-bottom: 25px;
	max-width: 335px;
}

.p-products__multi-img {
	height: auto;
	width: auto;
}

.p-product__contents {
	display: block;
	margin-top: 120px;
}

.p-product__content-left {
	width: 100%;
}

.p-product__img--1 {
	width: 51.9402985075%;
}

.p-product__img--2 {
	width: 37.9104477612%;
}

.p-product__badge {
	font-size: 12px;
	height: 90px;
	letter-spacing: 1.2px;
	line-height: 18px;
	width: 90px;
}

.p-product__badge--starter {
	top: -64px;
}

.p-product__badge--multi {
	top: -74px;
}

.p-product__content-right {
	margin-bottom: 40px;
	margin-top: 28px;
	width: 100%;
}

.p-product__name--1st {
	margin-top: 8px;
}

.p-product__name--2nd {
	margin-top: 7px;
}

.p-product__line {
	display: none;
}

.p-product__gray-text {
	margin-top: 4px;
}

.p-product__content-left--multi {
	margin-top: 114px;
	width: 100%;
}

.p-product__text {
	margin-top: 12px;
}

.p-product__name--3rd {
	font-size: 16px;
	letter-spacing: 2.24px;
	line-height: 26px;
}

.p-base-set__link-button.p-repeater__link-button {
	width: 100%;
}

.campaign-inner {
	max-width: 335px;
	padding-bottom: 6px;
	padding-top: 34px;
	position: relative;
}
	
.campaign-contents {
	align-items: start;
	gap: 9px;
	justify-content: space-between;
}
	
.campaign-content--2 {
	margin-left: 0;
	margin-right: 0;
}
	
.campaign-img {
	left: 0;
	position: absolute;
	top: 30px;
	width: 97.5px;
	height: 44px;
}
	
.campaign-text {
	left: 50%;
	position: absolute;
	top: 6px;
	translate: -50%;
	width: 335px;
	height: 19px;
}
	
.campaign-features {
	gap: 0;
	margin-top: 4px;
}
	
.campaign-feature {
	border: none;
	font-size: 12px;
	font-weight: 500;
	height: auto;
	letter-spacing: -0.7px;
	line-height: 16px;
	margin-left: 56px;
	text-align: center;
	width: auto;
}
	
.campaign-feature--right {
	display: none;
}
	
.campaign-br--sp {
	display: block;
}
	
.campaign-link {
	font-size: 12px;
	font-weight: 700;
	height: 40px;
	letter-spacing: 0.96px;
	line-height: 15px;
	text-align: center;
	width: 120px;
}
	
.campaign-br {
	display: block;
}
	
.campaign-icon-wrap {
	height: 30px;
	opacity: 0.96;
	right: 0;
	top: -30px;
	width: 30px;
}
  
}  /* sp ここまで*/


/* WordPressプラグイン MW WP Form */
.mw_wp_form .error{
  margin-top: 10px;
}
.mw_wp_form .inline-error .error{
  margin-top: 0;
  margin-left: 10px;
}