/*----------------------------------------





        クリエイターモードに記載





    ----------------------------------------*/

/*----------------------------------------
        reset
    ----------------------------------------*/
*,
::before,
::after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border-style: solid;
	border-width: 0;
	box-sizing: border-box;
}

* {
	font-size: inherit;
	line-height: inherit;
}

::before,
::after {
	text-decoration: inherit;
	vertical-align: inherit;
}

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
dialog,
figure,
footer,
header,
main,
menu,
nav,
section,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

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

span,
small,
strong,
em,
b,
i {
	color: inherit;
}

html {
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	text-size-adjust: 100%;
}

ul,
ol {
	list-style: none;
}

img {
	border: 0;
	vertical-align: top;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

caption,
th {
	text-align: left;
}

input,
select {
	vertical-align: middle;
	width: 100%;
}

input,
textarea {
	margin: 0;
	padding: 0;
}

address {
	font-style: normal;
}

q::before,
q::after {
	display: none;
}

/*----------------------------------------
        base
    ----------------------------------------*/
html {
	scroll-behavior: smooth;
	font-size: 0.6944444444vw;
}

@media (max-width: 767px) {
	html {
		font-size: 3.125vw;
		/*
          計算式：　10(px) / 320(px) * 100 = 3.125
          画面幅320pxの時に "font-size: 10px" 相当になる
        */
	}
}

@media (min-width: 768px) {
	html {
		font-size: 62.5%;
	}
}

body {
	overflow-x: hidden;
	overflow-y: auto;
	color: #343434;
	font-family: 'Noto Sans JP', 'sans-serif', ui-sans-serif, 'system-ui';
	line-height: 1.75;
	font-size: 1.6rem;
	font-weight: 300;
	background-color: #f1ece9;
}

.tenor-sans-regular {
	font-family: 'Tenor Sans', sans-serif;
	font-weight: 400;
	font-style: normal;
}

.text-me-one-regular {
	font-family: 'Text Me One', sans-serif;
	font-weight: 400;
	font-style: normal;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	line-height: 1rem;
}

a {
	color: inherit;
	text-decoration: underline;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

a:hover {
	opacity: 0.7;
}

img {
	width: 100%;
	height: auto;
}

button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: block;
	width: 100%;
	font-family: inherit;
	font-weight: inherit;
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
}

/*----------------------------------------
        header
    ----------------------------------------*/

.header-up {
	border-bottom: 1px solid #ffbd19;
	background: #f1ece9;
}

.hamburger-up span {
	background-color: #070c16 !important;
}

.BrandLogoNone {
	display: none;
}

.cart-svg-up path {
	stroke: #070c16 !important;
}

#header a.top-logo {
	display: block;
	padding: 5px;
}

#header {
	background-color: transparent;
	border-bottom: 1px solid transparent;
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	transition: 0.3s ease;
	width: 100%;
	z-index: 1000;
	justify-content: space-between;
	align-items: center;
	flex-shrink: 0;
	display: flex;
	/*border-bottom: 1px solid #FFBD19; */
	/* background: #F1ECE9;*/
}

#header #header-main {
	align-items: center;
	display: flex;
	justify-content: space-between;
	transition: 0.3s ease;
	width: 100%;
	height: 60px;
}

#header #header-main .hamburger-button {
	width: 60px;
	height: 60px;
	flex-shrink: 0;
	padding: 18px;
}

#header #header-main .hamburger-button .hamburger {
	height: 10px;
	position: relative;
	width: 19px;
}

#header #header-main .hamburger-button .hamburger span:first-child {
	translate: 0 -7px;
}

#header #header-main .hamburger-button .hamburger span:nth-child(2) {
	translate: 0 -50%;
}

#header #header-main .hamburger-button .hamburger span:nth-child(3) {
	translate: 0 7px;
}

#header #header-main .hamburger-button .hamburger span {
	background-color: #fff;
	display: block;
	height: 1px;
	left: 0;
	position: absolute;
	top: 50%;
	width: 100%;
}

.cp_offcm01 #cp_toggle01 {
	display: none;
	opacity: 0;
}

.cp_offcm01 #cp_toggle01 ~ label {
	display: block;
	cursor: pointer;
	-webkit-transition: 0.5s transform;
	transition: 0.5s transform;
	width: 45px;
	height: 45px;
}

.cp_offcm01 {
	padding: 6px;
}

.cart-badge {
	margin-left: 3px;
	font-weight: bold;
	display: inline-block;
	width: 40px;
	height: 40px;
	padding: 4px 0 0 14px;
	color: #070c16;
	font-size: 20px;
	position: absolute;
	right: 38px;
	top: 8px;
}

@media screen and (max-width: 768px) {
	.cp_offcm01 .cp_menu_cart {
		right: -100vw;
		width: 70vw;
	}
}

@media screen and (min-width: 769px) {
	.cp_offcm01 .cp_menu_cart {
		right: -100vw;
		width: 100%;
	}
}

@media screen and (min-width: 769px) {
	.cp_offcm01 #cp_toggle01:checked ~ .cp_menu_cart {
		-webkit-transform: translateX(-100vw);
		transform: translateX(-100vw);
	}
}

@media screen and (max-width: 768px) {
	.cp_offcm01 #cp_toggle01:checked ~ .cp_menu_cart {
		-webkit-transform: translateX(-100vw);
		transform: translateX(-100vw);
	}
}

.cp_offcm01 .cp_menu_cart {
	position: fixed;
	top: 0;
	max-width: 500px;
	height: 100%;
	cursor: pointer;
	-webkit-transition: 0.5s transform;
	transition: 0.5s transform;
	background-color: rgba(255, 255, 255, 1);
	opacity: 0.95;
	overflow: hidden;
	z-index: 25;
}

.cp_offcm01 #cp_toggle01:checked ~ label {
	-webkit-transform: translateX(-500px);
	transform: translateX(-500px);
}

@media screen and (max-width: 768px) {
	.cp_offcm01 #cp_toggle01:checked ~ label {
		-webkit-transform: translateX(-70vw);
		transform: translateX(-70vw);
	}
}

.cp_offcm01 #cp_toggle01 ~ label:hover {
	transition: 0.3s ease-in-out;
}

#header #menu-wrapper {
	background-color: #f1ece9;
	height: 0;
	left: 0;
	overflow: scroll;
	position: absolute;
	top: calc(100% + 0px);
	transition: 0.5s ease-in-out;
	width: 100%;
}

#header.open #menu-wrapper {
	height: calc(100dvh - 70px);
}

#header #header-main .main-nav {
	display: none;
}

@media screen and (min-width: 1040px) and (max-width: 1512px) {
	#header #header-main .main-nav {
		margin-right: 10px;
	}
}

@media screen and (min-width: 1040px) {
	#header #header-main .main-nav {
		display: block;
		margin-left: auto;
		margin-right: 47px;
		transition: 0.3s ease;
	}
}

@media screen and (max-width: 768px) {
	.cart-object {
		width: 70vw;
	}
}

@media screen and (min-width: 768px) {
	.cart-object {
		width: 500px;
	}
}

#header #header-main .main-nav .navigation-item {
	font-size: 1rem;
}

.cp_offcm01 #cp_toggle01:checked ~ label svg {
	fill: #ffbd19;
}

p.head {
	font-weight: 600;
	font-family: 'Bricolage Grotesque', sans-serif, ui-sans-serif, system-ui;
	letter-spacing: 0.2em;
}

/*------------サイドナビ----------*/
/* hiddenの互換ケア */
[hidden] {
	display: none !important;
}

/* 親アイテム */
.side-category-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.side-category-item {
	border-bottom: 1px solid #eee;
}

/* 親ボタン */
.la-accordion {
	width: 100%;
	gap: 0.5rem;
	cursor: pointer;
	font: inherit;
}

.la-accordion .txt {
	flex: 1;
	text-align: left;
	font-weight: 400;
}

/* ← ここがポイント：テキストの直後に＋/－を直付け */
.la-accordion .txt::after {
	content: '＋';
	display: inline-block;
	width: 1em;
	/* 揺れ防止 */
	margin-left: 0.35em;
	line-height: 1;
	font-weight: 700;
	transform: translateY(-0.02em);
}

.la-accordion[aria-expanded='true'] .txt::after {
	content: '－';
}

/* 開いている親の見た目（任意） */
.la-accordion[aria-expanded='true'] {
	font-weight: 600;
	background-color: #ddd;
}

/* 子リンク */
.child-item {
	display: block;
	align-items: center;
	background-color: #eee;
	border: 1px solid #070c16;
	border-radius: 1.1rem;
	padding-inline: 0.9rem;
	text-decoration: none;
	padding: 0.5rem 0.8rem;
	font-size: 1rem;
	font-weight: 400;
	margin-top: 1rem;
}

.is-current {
	font-weight: 700;
	text-decoration: underline;
}

/*----------------------------------------
        footer
    ----------------------------------------*/

#footer {
	background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)),
		linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
	background-size: 14px 14px;
	background-repeat: repeat;
	background-position: center center;
	padding: 3rem 0 2rem 0;
	background-color: #fff;
	text-align: center;
	border-top: 1px solid #ffbd19;
}

.sns_menu {
	margin-bottom: 1rem;
}

.sns_menu a {
	text-decoration: none;
}

.menu-inner {
	text-align: left;
	font-size: 1rem;
	padding: 0 1rem;
	color: #070c16;
}

.navigation-item {
	align-items: center;
	background-color: #fff;
	border: 1px solid #070c16;
	border-radius: 1.1rem;
	padding-inline: 0.9rem;
	text-decoration: none;
	padding: 0.5rem 0.8rem;
	font-size: 1rem;
	font-weight: 400;
}

.main-nav .navigation-list li {
	margin-bottom: 1rem;
	margin-right: 1rem;
	line-height: 2rem;
}

.main-nav .navigation-list {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	margin-top: 2.2rem;
	margin-bottom: 3rem;
}

.menu-top {
	padding: 2.5rem 2rem;
	margin: 0 auto;
	width: 70%;
}

.menu-search-wrap {
	height: 3rem;
	line-height: 3rem;
	display: flex;
	justify-content: space-between;
	border-bottom: solid 1px #5d737e;
	width: 100%;
	margin: 2rem 0;
	border: 1px solid #070c16;
	border-radius: 1.5rem;
	background-color: #fff;
}

.menu-search-wrap input {
	width: 100%;
	height: 4rem;
	background: none;
	position: relative;
	z-index: 5;
	padding-bottom: 1rem;
	padding-left: 1rem;
}

.menu-search-wrap a {
	display: block;
	padding: 0 10px;
	z-index: 10;
}

.login-btn {
	width: 100%;
	height: 3rem;
	line-height: 3rem;
	background-color: #fff;
	display: inline-block;
	text-align: center;
	border: 1px solid #070c16;
	border-radius: 1.5rem;
	text-decoration: none;
}

.menu-login {
	width: 100%;
	margin: 2rem 0;
}

.menu-search-wrap svg {
	width: 25px;
	height: 25px;
	padding-top: 5px;
}

.copyright p {
	font-size: 0.7rem;
	position: relative;
	text-align: center;
	z-index: 2;
}

@media screen and (min-width: 1040px) {
	#footer .main-nav {
		max-width: 700px;
		margin: 0 auto;
	}
}

/*----------------------------------------
        fadein
    ----------------------------------------*/

/* フェードイン(初期値) */
.js-fadeUp {
	opacity: 0;
	/* 最初は非表示 */
	transform: translateY(30px);
	/* 下に30pxの位置から */
	transition: opacity 0.8s, transform 0.8s;
	/* 透過率と縦方向の移動を0.8秒 */
}

/* フェードイン(スクロールした後) */
.js-fadeUp.is-inview {
	opacity: 1;
	/* 表示領域に入ったら表示 */
	transform: translateY(0);
	/* 30px上に移動する */
	transition-delay: 0.2s;
	/* フェード開始を0.5秒遅らせる */
}

/*レビュースター*/
.reviewRateStar {
	position: relative;
	width: 22px;
	font-size: 22px;
	text-indent: 30px;
	white-space: nowrap;
	overflow: hidden;
}

.reviewRateStar::before {
	position: absolute;
	top: 0;
	left: 0;
	text-indent: 0;
}

.reviewRateStar.starOn::before {
	content: 'star';
}

.reviewRateStar.starOff::before {
	content: 'star_border';
}
.reviewRate {
	display: flex;
}
