@charset “UTF-8”;
/* =============================================================================

CSS Information

 File name:	layout.css
 Style Info:	レイアウト設定

============================================================================= */

/* font-family: "Noto Sans JP", sans-serif; */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

/* font-family: 'Frank Ruhl Libre', serif; */
@import url('https://fonts.googleapis.com/css2?family=Frank+Ruhl+Libre&display=swap');

:root {
	--color-text      : #000;
	--color-body      : #FFF;
	--color-bg-base   : #f4f3ef;
	--color-bg-light  : #efeee8;
	--color-bg-or     : #efd9ce;

	--color-primary   : #d84a00;
	--color-secondary : #bb9222;

	--color-line      : #22ba4f;
	--color-fb        : #315096;
	
	--color-white     : #FFF;
	--color-gray-100  : #EEE;
	--color-gray-200  : #CCC;
	--color-gray-500  : #888;
	--color-gray-600  : #666;
	--color-gray-800  : #333;
	--color-black     : #000;
	
	--color-dred      : #C00;
	--color-burgundy  : #900;

	--layer_dark      : rgba(0,0,0,.9);
}

html {
	scroll-behavior: smooth;
}

body {
	overflow-x: hidden;
	position: relative;
	text-size-adjust: 100%;
	color: var(--color-text);
	font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
}

.font-mincho,
.font-mincho * {
	font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

a {
	color: var(--color-text);
	text-decoration: underline;
}
a:link
a:active
a:visited {
	color: var(--color-text);
}
a:hover {
	opacity: .5;
	color: inherit;
	text-decoration: none;
}

a:hover img {
	opacity: 0.75;
	filter: alpha(opacity=70);
}

em {
	font-weight: bold;
}

strong {
	font-weight: bold;
}

.clearfix::after {
	content: '';
	display: block;
	clear: both;
	height: 0;
}

h1, h2, h3, h4, h5 {
	line-height: inherit;
}

p {
	margin-top: 0;
	margin-bottom: 1.5em;
}

.header p ,
.header_slim p ,
.footer_contact p ,
.footer p {
	margin: 0;
	padding: 0;
}

.vibtn {
	position: absolute;
	visibility: hidden;
}


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

 Future shop コマースクリエーター style [スタートアップテーマ(PC/タブレット)ベース]

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

.fs-preview-header {
	display: none;
}

.fs-l-header {
	padding-top: 0;
}

.fs-l-header--min {
	border-bottom: none;
}

.fs-l-footer {
	margin-top: 0;
	background: none;
	border-top: none;
}

.fs-c-breadcrumb {
	max-width: 1230px;
	margin: 0 auto;
	padding: 28px 15px;
	font-size: 1.4rem;
}
.fs-c-breadcrumb + .fs-c-breadcrumb {
	display: none;
}
.fs-c-breadcrumb .fs-c-breadcrumb__list {
	padding: 0;
}
.fs-c-breadcrumb .fs-c-breadcrumb__list a {
	text-decoration: none;
	color: var(--color-black);
}
.fs-c-breadcrumb .fs-c-breadcrumb__list a:hover, .fs-c-breadcrumb .fs-c-breadcrumb__list a:active {
	text-decoration: underline;
}

/* ログイン/ログアウト：非表示 */
.logout.my_false ,
.login.my_true ,
.member.my_true ,
.mypage.my_false {
	display: none;
}

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

 header

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

.fs-l-header {
	height: 114px;
}
.header {
	position: relative;
	z-index: 100;
}

.header-inner {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	padding: 10px 10px;
	background-color: var(--color-white);
	z-index: 2500;
}

/* logo */
.header .h-logo {
	width: 300px;
	max-width: 38%;
}
.header .h-logo h1 {
	margin: 0;
}
.header .h-logo a {
	display: block;
}
.header .h-logo img {
	display: block;
}

/* Amazon Pay & お問い合わせ
------------------------------------------------------------- */

.header .h-info {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: 100%;
	margin-bottom: 10px;
}

/* Amazon Pay */
.h-info .h-amazon-pay {
	margin-right: 25px;
}

/* h-contact */
.h-info .h-contact {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: center;
	font-size: 1.6rem;
	line-height: 1.2;
}
.h-info .h-contact .h-contact-box {
	margin-right: 16px;
	padding-right: 16px;
	border-right: 1px solid var(--color-black);
}
.h-info .h-contact .h-contact-box a {
	text-decoration: none;
}
.h-info .h-contact-tel {
	margin: 0 0 0 20px;
	padding: 0 0 0 27px;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.01em;
	color: var(--color-primary);
	background: url(../images/common/icon-tel-orange.svg) no-repeat 0 50%;
	background-size: 20px auto;
}


/* ユーティリティ
------------------------------------------------------------- */

.header .h-utility {
	display: flex;
	justify-content: flex-end;
}

/* ヘルプメニュー */
.unavi__wrap .unavi {
	padding: 0 11px 0 0;
}
.unavi {
	display: flex;
}
.unavi li {
	padding: 0 5px 0 0;
}
.unavi li a {
	position: relative;
	display: block;
	padding: 0 5px 0;
	text-decoration: none;
	font-size: min(1.4rem,3vw);
	background-repeat: no-repeat;
	white-space: nowrap;
}
.unavi li a::before {
	display: block;
	content: '';
	width: 1.8em;
	height: 1.65em;
	margin: 8px auto 8px;
	background: no-repeat center center;
	background-size: auto 100%;
}

/* 各ボタン画像 */
.unavi li.unavi__item--my a::before {
	background-image: url(../images/common/icon_mypage.svg);
}
.unavi li.unavi__item--register a::before {
	background-image: url(../images/common/icon_member.svg);
}
.unavi li.unavi__item--cart a::before {
	background-image: url(../images/common/icon_cart.svg);
	background-size: 95% auto;
	background-position: center bottom;
}
.unavi li.unavi__item--guide a::before {
	background-image: url(../images/common/icon_guide.svg);
}
.unavi li.unavi__item--contact a::before {
	background-image: url(../images/common/icon_contact.svg);
	background-size: 90% auto;
	background-position: center bottom;
}

/* カート数量 */
.unavi li.unavi__item--cart a .fs-client-cart-count {
	position: absolute;
	top: -2px;
	right: 4px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 15px;
	height: 15px;
	border-radius: 20px;
	font-size: 12px;
	color: var(--color-white);
	background: var(--color-primary);
	line-height: 1;
	z-index: 1;
}

/* 検索 */
.header .search {
	width: 210px;
	padding: 17px 0 0;
}
.header .search .search-box {
	display: flex;
	border-radius: 5px;
	border: solid 1px var(--color-gray-200);
	overflow: hidden;
}
.header .search .search-box input[type="text"] {
	width: 168px;
	padding: 6px 12px;
	border: none;
	font-size: 14px;
}
.header .search .search-box input[type="text"]::placeholder {
	color: var(--color-gray-200);
}
.header .search .search-box input[type="submit"] {
	display: block;
	width: 40px;
	margin: 0;
	padding: 0;
	border: none;
	text-indent: -9999px;
	text-align: left;
	background: var(--color-primary) url(../images/common/icon_search.svg) no-repeat 50% 50%;
	background-size: 18px auto;
}


/* menu
------------------------------------------------------------- */

.burger_btn_area {
	position: absolute;
	top: 10px;
	right: 10px;
	width: 50px;
	height: 50px;
}

/* ハンバーガーメニュー */
.burger_open_btn {
	position: absolute;
	top: 7px;
	right: 5px;
	display: block;
	width: 40px;
	height: 40px;
	z-index: 2600;
}
.burger_open_btn span {
	position: relative;
	display: block;
	width: 30px;
	height: 2px;
	margin: 19px auto 0;
	background-color: var(--color-text);
	transition: 0.4s;
}
.burger_open_btn span::before ,
.burger_open_btn span::after {
	position: absolute;
	content: '';
	left: 0;
	width: 30px;
	height: 2px;
	background-color: var(--color-text);
	transition: 0.4s;
}
.burger_open_btn span::before {
	top: -10px;
}
.burger_open_btn span::after {
	bottom: -10px;
}

/* ハンバーガーメニューを変形 */
input[type="checkbox"]#burger_btn:checked + .burger_open_btn span {
	background: transparent;
}
input[type="checkbox"]#burger_btn:checked + .burger_open_btn span::before {
	top: 25%;
	transform: rotate(45deg);
}
input[type="checkbox"]#burger_btn:checked + .burger_open_btn span::after {
	bottom: 25%;
	transform: rotate(-45deg);
}

/* メニュー：OPEN/CLOSE */
.burger_content {
	position:fixed;
	top: -100vh;
	left: 0;
	width: 100%;
	padding: 9vw 15px 15px;
	background: var(--layer_dark);
	color: var(--color-white);
	font-size: 1.6rem;
	transition: 0.1s ease-in-out;
	z-index: 2100;
}
#burger_btn:checked ~ .burger_content {
	overflow: scroll;
	overscroll-behavior-y: contain;
	-webkit-overflow-scrolling: touch;
	max-height: calc(100vh - 25vw);
	top: 25vw;
}

.burger_member {
	margin-bottom: 15px;
	text-align: center;
}
.bnavi a ,
.bnavi label {
	position: relative;
	display: block;
	height: auto;
	padding: 10px 0;
	color: inherit;
	text-decoration: none;
	line-height: 1.6;
}
.bnavi label::after {
	position: absolute;
	display: block;
	content: '';
	top: 1.5em;
	right: 0;
	width: 9px;
	height: 5px;
	background: no-repeat;
	background-image: url(../images/common/icon-arrow-wh.svg);
	background-size: 100% 100%;
	transition: 0.4s;
}
.bnavi--sub {
	margin-left: 1em;
}

/* OPEN/CLOSE */
.bnavi .bnavi--sub {
	position: relative;
	opacity: 0;
	display: none;
	height: 0;
	transition: 0.4s;
}
.bnavi .vibtn:checked ~ .bnavi--sub {
	display: block;
	height: auto;
	opacity: 1;
}
.bnavi .vibtn:checked + label::after {
	transform:rotate(180deg);
}


/* gnavi
------------------------------------------------------------- */

.navbar {
	position: relative;
	width: 100%;
	background: var(--color-black);
	z-index: 2400;
}
.gnavi__list {
	display: flex;
	justify-content: center;
}
.gnavi__item {
	position: relative;
}
.gnavi__item:not(:last-child)::after {
	position: absolute;
	content: '';
	top: 18px;
	right: 0;
	width: 1px;
	height: calc(100% - 36px);
	background-color: var(--color-white);
}
.gnavi__item a {
	position: relative;
	display: block;
	padding: 18px 1em;
	text-decoration: none;
	color: var(--color-gray-200);
	font-size: min(1.6rem,3.75vw);
}
.gnavi__item--open > a::after {
	display: inline-block;
	content: '';
	top: 1.5em;
	right: 0;
	width: 9px;
	height: 5px;
	margin-left: .25em;
	background: no-repeat;
	background-image: url(../images/common/icon-arrow-wh.svg);
	background-size: 100% 100%;
	vertical-align: middle;
	transition: 0.4s;
}

/* サブメニュー */
.gnavi .contents-open-close {
	display: none;
	position: absolute;
	top: 40px;
	left: -54px;
	z-index: 2;
	width: 170px;
	color: var(--color-black);
}
.gnavi .contents-open-close.gift {
	left: -200px;
	width: 480px;
}
.gnavi .contents-open-close .contents-open-close-wrapper {
	position: relative;
	padding-top: 20px;
}
.gnavi .contents-open-close .contents-open-close-box {
	position: relative;
	display: flex;
	gap: 10px;
	padding: 16px;
	background: rgba(255, 255, 255, .8);
}
.gnavi .contents-open-close .contents-open-close-box::before {
	position: absolute;
	display: block;
	content: '';
	top: -10px;
	left: calc(50% - 0px);
	width: 8px;
	height: 10px;
	background: rgba(255, 255, 255, .8);
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}
.gnavi .contents-open-close ul {
	flex: 1;
}
.gnavi .contents-open-close li:not(:last-child) {
	border-bottom: solid 1px var(--color-black);
}
.gnavi .contents-open-close li a {
	padding: 6px 0;
	color: var(--color-black);
}

/* サブメニューホバー時 */
.gnavi__item--open:hover > a::after {
	transform:rotate(180deg);
}
.gnavi__item--open:hover .contents-open-close {
	display: block;
}


@media only screen and (max-width: 767px) {
	.header {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
	}
	.header .h-info ,
	.unavi__item--register ,
	.unavi__item--guide ,
	.unavi__item--contact ,
	.header .search {
		display: none;
	}
	.h-utility {
		margin-right: 50px;
	}
	.gnavi {
		overflow-x: auto;
		width: 100%;
		-webkit-overflow-scrolling: touch;
	}
	.gnavi__list {
		justify-content: flex-start;
		min-width: 200vw;
	}
	.gnavi__item:not(:last-child)::after {
		top: 10px;
		height: calc(100% - 20px);
	}	
	.gnavi__item a {
		padding: 10px 1em;
	}
	.gnavi__item--open > a::after {
		content: none;
	}
	.gnavi__item:first-child a {
		padding-left: .5em;
	}
}
@media only screen and (min-width: 768px) {
	.burger_btn_area {
		display: none;
	}
	.fs-l-header {
		height: 196px;
	}
	.header-inner {
		padding: 15px 20px;
	}
	.navbar.fixed {
		position: fixed;
		top: 0;
		left: 0;
	}
}


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

メインコンテンツ : fs-l-main / fs-l-pageMain / side

※ fs で始まるクラスはショップ全体にかかわるので、変更するときは注意 ※
※ 変更する時はそのページの body のクラス名を調べてページだけ適応する ※

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

.fs-l-main {
	clear: both;
	display: block;
	max-width: 1230px;
	margin: 0 auto 40px;
	padding: 0;
	font-size: 1.4rem;
}
/* トップページ */
.fs-body-top .fs-l-main {
	margin-top: 0;
}

.fs-l-pageMain {
	width: 100%;
	max-width: none;
	padding: 0 15px;
}

@media only screen and (min-width: 768px) {
	.fs-l-main {
		font-size: 1.6rem;
	}
}
@media only screen and (min-width: 1231px) {
	.fs-l-main {
		max-width: 1240px;
	}
	.fs-l-pageMain {
		padding: 0 20px;
	}
}


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

 footer

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

.footer {
	padding: 45px 0 50px;
	background: var(--color-black);
	color: var(--color-white);
	font-size: 1.6rem;
	letter-spacing: -0.03em;
}
.footer .footer-outer {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 20px;
}
.footer a {
	color: inherit;
}
.footer a:hover {
	color: var(--color-gray-200);
}

.footer__head {
	position: relative;
	margin-bottom: 16px;
	font-size: 1.8rem;
	font-weight: 600;
}
.footer__head label {
	display: block;
}
.footer__head--sub {
	padding-bottom: 15px;
}


@media only screen and (max-width: 767px) {
	.footer__head label::after {
		position: absolute;
		display: block;
		content: '';
		top: .75em;
		right: 0;
		width: 18px;
		height: 10px;
		background: no-repeat;
		background-image: url(../images/common/icon-arrow-wh.svg);
		background-size: 100% 100%;
		transition: 0.4s;
	}
	.footer .fnavi__list ,
	.footer .f-info__box {
		position: relative;
		opacity: 0;
		display: none;
		height: 0;
		transition: 0.4s;
	}
	.footer .vibtn:checked ~ .fnavi__list ,
	.footer .vibtn:checked ~ .f-info__box {
		display: block;
		height: auto;
		opacity: 1;
		padding-bottom: 15px;
	}
	.footer .vibtn:checked + .footer__head label::after {
		transform:rotate(180deg);
	}
}
@media only screen and (min-width: 768px) {
	.fnavi {
		display: flex;
		gap: 10px;
	}
	.fnavi .fnavi__col {
		flex-grow: 12;
	}
	.fnavi .fnavi__col:nth-of-type(2) {
		flex-grow: 10;
	}
	.fnavi .fnavi__col:nth-of-type(3) {
		flex-grow: 13;
	}
	.fnavi__group {
		margin-bottom: 36px;
	}	
}
@media only screen and (min-width: 1023px) {
	.footer .footer-inner {
		display: flex;
		justify-content: space-between;
	}
	.fnavi {
		width: 64%;
	}
	.footer .f-info {
		width: 36%;
	}
}


/* fnavi
------------------------------------------------------------- */

/* list */
.fnavi__list li {
	margin-bottom: 12px;
}
.fnavi__list li {
	margin-bottom: 12px;
}
.fnavi__list a {
	display: block;
	text-decoration: none;
}
.fnavi__list--sub {
	padding-left: 1em;
}

/* list--guide */
.fnavi__list--guide li {
	display: flex;
	width: 100%;
}
.fnavi__list--guide li::before {
	display: block;
	content: '-';
	width: 5px;
	margin-right: 5px;
}
.fnavi__list--guide li a {
	display: block;
	flex: 1;
}


/* f-info
------------------------------------------------------------- */

.footer .f-info .footer__head {
	padding-bottom: 14px;
}
.footer .f-info .f-contact .footer__head--sub {
	padding-bottom: 5px;
}

.footer .f-info .f-contact {
	padding: 0 0 20px;
}
.footer .f-info .f-contact .f-contact-tel {
	min-height: 22px;
	padding: 0 0 10px 33px;
	letter-spacing: 0em;
	background: url(../images/common/icon-tel-white.svg) no-repeat 0 0;
	background-size: 24px auto;
}
.footer .f-info .f-contact .f-contact-contact {
	min-height: 22px;
	padding: 0 0 10px 33px;
	letter-spacing: 0em;
	background: url(../images/common/icon-contact-white.svg) no-repeat 0 9px;
	background-size: 20px auto;
}
.footer .f-info .f-contact .f-contact-contact a {
	padding: 0 0 5px;
	border-bottom: solid 1px var(--color-white);
	text-decoration: none;
	letter-spacing: -0.07em;
}

.footer .f-info .f-company {
	padding: 0 0 33px;
}
.footer .f-info .f-company .footer__head--sub {
	padding: 0 0 2px;
	font-weight: 700;
}
.footer .f-info .f-company .company-name {
	padding: 0 0 11px;
	letter-spacing: 0.02em;
}
.footer .f-info .f-company .address {
	padding: 0 0 13px;
}

.footer .f-info .tel-fax {
	letter-spacing: 0em;
}


/* 営業日カレンダー
------------------------------------------------------------- */

.footer .calendar .calendar-wrapper {
	display: flex;
	justify-content: space-between;
}
.footer .calendar .calendar-box {
	width: calc(50% - 5px);
}
/* 営業日カレンダー */
.footer .calendar table {
	width: 100%;
	line-height: 1;
	font-size: 14px;
	text-align: center;
	border: 1px solid var(--color-gray-200);
	border-collapse: collapse;
	color: var(--color-black);
	background: var(--color-gray-200);
}
/* 月名 */
.footer .calendar caption {
	padding: 6px 3px;
	text-align: center;
	font-size: 15px;
	color: var(--color-black);
	background: var(--color-gray-200);
}
.footer .calendar caption span {
}
/* 曜日 */
.footer .calendar th {
	padding: 5px 0;
	width: calc(100% / 7);
	border: 1px solid var(--color-gray-200);
	font-weight: 400;
	background: var(--color-white);
}
.footer .calendar th.sunday {
	color: #c66;
}
.footer .calendar th.saturday {
	color: #6699cc;
}
/* 日付の枠 */
.footer .calendar td {
	padding: 5px 0;
	width: calc(100% / 7);
	border: 1px solid var(--color-gray-200);
	background: var(--color-white);
}
.footer .calendar td.close {
	color: var(--color-white);
	background: #CCC;
}
.footer .calendar td.sunday {
	color: var(--color-white);
	background: #c66;
}
.footer .calendar td.saturday {
	color: var(--color-white);
	background: #6699cc;
}

/* カレンダーの色説明 */
.footer .calendar .txt-close {
	font-size: 14px;
}
.footer .calendar .txt-close .mark-close {
	color: #e2c600;
}
.footer .calendar .txt-close-note {
	font-size: 14px;
}


/* /////////////////////////////////////////////////////////////////////////////

 汎用CSS

///////////////////////////////////////////////////////////////////////////// */

.color--or {
	color: var(--color-primary);
}

.bold {
	font-weight: bold;
}
.center {
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

.left {
	text-align: left;
}

.right {
	text-align: right;
}

.mB10 {
	margin-bottom: 10px;
}
.mB20 {
	margin-bottom: 20px;
}
.mB30 {
	margin-bottom: 30px;
}
.mB40 {
	margin-bottom: 40px;
}

@media only screen and (max-width: 767px) {
	.sp_hide {
		display: none;
	}
	.sp_center {
		margin-left: auto;
		margin-right: auto;
		text-align: center;
	}
}
@media only screen and (min-width: 768px) {
	.pc_hide {
		display: none;
	}
	.pc_center {
		margin-left: auto;
		margin-right: auto;
		text-align: center;
	}
}
