@charset "UTF-8";

/* ====================================================
   Variables
   ==================================================== */
:root {
	--title-f-size: 24px;
	--txt-f-size: 13px;
	--remark-f-size: 12px;
	--menu-f-size: 16px;
	--price-f-size: 13px;
	--smallcategory-f-size: 10px;
	--badge-f-size: 10px;
	--area-f-size: 10px;
	--tag-f-size:12px;
	--border-radius: 1em;
	--container-padding-x: 30px;
	--shadow-base: 0 2px 8px rgba(0, 0, 0, 0.04);
	--shadow-hover: 0 12px 24px rgba(0, 0, 0, 0.1);
	--transition-base: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);

	/* --- 共通利用するSVGマスクの変数 --- */
	--svg-mask-category: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='8' y1='6' x2='21' y2='6'/%3E%3Cline x1='8' y1='12' x2='21' y2='12'/%3E%3Cline x1='8' y1='18' x2='21' y2='18'/%3E%3Cline x1='3' y1='6' x2='3.01' y2='6'/%3E%3Cline x1='3' y1='12' x2='3.01' y2='12'/%3E%3Cline x1='3' y1='18' x2='3.01' y2='18'/%3E%3C/svg%3E");
	--svg-mask-area: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-20 -6 110 110'%3E%3Cpath d='M34.394,100h-1.561c-.879-.572-1.26-1.352-1.789-2.21L3.208,47.201C-9.092,19.693,18.352-8.788,46.292,2.557c18.9,7.674,25.604,29.2,16.492,47.115-8.251,16.222-18.258,31.902-26.6,48.118-.527.859-.913,1.638-1.789,2.21ZM31.623,16.95c-10.3,1.049-16.953,11.877-13.754,21.638,4.403,13.438,22.949,15.465,30.02,3.212,6.921-11.994-2.612-26.24-16.266-24.85Z'/%3E%3C/svg%3E");
	--svg-mask-more: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M10,.05C4.505.05.05,4.505.05,10s4.455,9.95,9.95,9.95,9.95-4.455,9.95-9.95S15.495.05,10,.05ZM13.687,15.691l-3.331-1.754c-.116-.058-.243-.089-.371-.089-.129,0-.257.032-.371.091l-3.326,1.765.634-3.715c.048-.267-.039-.535-.229-.715l-2.695-2.628,3.72-.535c.263-.036.492-.202.613-.444l1.663-3.372,1.665,3.374c.12.241.349.407.611.443l3.728.506-2.712,2.646c-.194.181-.284.458-.234.714l.634,3.714Z'/%3E%3C/svg%3E");
	--svg-mask-check: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 13 13'%3E%3Cpath d='M12.7971 11.7947L9.28524 8.29801C9.95702 7.42384 10.3628 6.33775 10.3628 5.15894C10.3628 2.31126 8.03479 0 5.18138 0C2.32796 0 0 2.31126 0 5.15894C0 8.00662 2.32796 10.3179 5.18138 10.3179C6.33871 10.3179 7.40957 9.93378 8.27424 9.29139L11.7928 12.7947C11.9325 12.9338 12.112 13 12.2916 13C12.4712 13 12.6575 12.9338 12.7905 12.7947C13.0698 12.5166 13.0698 12.0728 12.7905 11.7947H12.7971ZM5.18138 8.90729C3.10617 8.90729 1.41673 7.22517 1.41673 5.15894C1.41673 3.09272 3.10617 1.4106 5.18138 1.4106C7.25659 1.4106 8.94602 3.09272 8.94602 5.15894C8.94602 7.22517 7.25659 8.90729 5.18138 8.90729Z'/%3E%3C/svg%3E");
}

@media (width < 768px) {
	:root {
	--tag-f-size:13px;
	}
}

/* ====================================================
   Base
   ==================================================== */
tr,
th,
td,
div,
span,
a,
p {
	color: inherit;
}

@media (width < 768px) {
	#header-logo a {
		font-size: 0;
	}

	.wordMTWrap {
		margin: 0;
		line-height: 1.2;
	}

	.wordMTWrap p.wordMT {
		padding: 1em;
	}

	.wordMTWrap p.wordMT br {
		display: none;
	}

	input#spook_megamenu_keyword {
		font-size: 16px;
	}

	input#spook_megamenu_keyword::placeholder {
		transform-origin: left;
		scale: 0.75;
	}
}

/* ====================================================
   Layout
   ==================================================== */
.mainContentMT {
	width: 100%;
	margin: 0 auto;
}

.rootMT {
	width: min(100%, 940px);
	margin: 0 auto 10px;
}

.rootMT ul {
	padding: 0;
	margin: 0;
	position: relative;
	z-index: 0;
	overflow: initial;
	display: flex;
}

.layout-container {
	position: relative;
	box-sizing: border-box;
	width: 100%;
	margin: 0;
	padding: var(--container-padding-x) 0;
	color: var(--black-color);
}

.layout-container * {
	box-sizing: border-box;
	font-family: "Helvetica Neue", Helvetica, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", "Noto Sans CJK JP", Arial, "メイリオ", Meiryo, sans-serif;
	font-feature-settings: "palt";
	letter-spacing: 0.06em;
	text-autospace: normal;
	overflow-wrap: anywhere;
	word-break: normal;
	line-break: strict;
}

.layout-container .pc {
	display: block !important;
}

.layout-container .sp {
	display: none !important;
}

/* ====================================================
   Typography
   ==================================================== */
.layout-container .section-header__title {
	font-size: var(--title-f-size);
	font-weight: 700;
	line-height: 1.2;
	display: flex;
	align-items: center;
	gap: 0.25em;
	word-break: auto-phrase;
}

.layout-container .section-header__lead {
	width: 100%;
	font-size: var(--txt-f-size);
	font-weight: 400;
	line-height: 1.2;
	color: var(--gray-color02);
}

.layout-container .section-body__remark {
	font-size: var(--remark-f-size);
	font-weight: 400;
	line-height: 1.2;
	padding: 0 var(--container-padding-x);
}

/* ====================================================
   Components
   ==================================================== */

/* Loading Error */
#Loading-error {
	padding: 1em 0;
	text-align: center;
	margin: 1em 0 0;
}

#Loading-error .title {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.3;
}

#Loading-error .text {
	font-size: var(--remark-f-size);
	font-weight: 400;
	line-height: 1.3;
}

#Loading-error .reload-button {
	display: block;
	width: min(100%, 300px);
	border-radius: 3em;
	font-size: var(--txt-f-size);
	font-weight: 700;
	color: var(--blue-color);
	border: solid 2px var(--blue-color);
	background: #fff;
	padding: 1em;
	margin: 1em auto 0;
	cursor: pointer;
	transition: all ease .3s;
}

#Loading-error .reload-button:hover {
	background-color: var(--blue-color);
	color: #fff;
}

/* Section Header */
#section-header {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 1em;
	padding: 0 var(--container-padding-x) 1em;
	margin: 0 0 var(--container-padding-x);
	border-bottom: solid 1px var(--gray-color01);
}

#section-header .section-header__content {
	display: flex;
	gap: 0.25em;
	font-size: var(--title-f-size);
}

/* #section-header .section-header__content::before {
	content: "";
	width: 3.5px;
	align-self: stretch;
	background: var(--brand-color);
	display: block;
	border-radius: 3em;
	flex: none;
} */

#section-header .section-header__content .section-header__wrapper {
	display: flex;
	flex-direction: column;
	gap: 0.25em;
}

#section-header .page-function {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 2em;
}


#section-header .page-function .item-count {
	display: none;
	font-size: var(--txt-f-size);
	opacity: 0;
	transition: opacity 0.3s, display 0.3s allow-discrete;
}

#section-header .page-function .item-count:has(span.complete) {
	display: block;
	opacity: 1;

	@starting-style {
		opacity: 0;
	}
}

#section-header .page-function .item-count #item-count-number {
	font-size: 1.5em;
	font-weight: 700;
}

/* View Switch */
#section-header .view-switch {
	display: none;
}

#section-header .view-switch .view-switch__label {
	font-size: var(--remark-f-size);
	color: var(--black-color);
	line-height: 1;
}

#section-header .view-switch .view-switch__wrapper {
	display: flex;
	gap: 0.5em;
	background-color: var(--gray-color);
	border-radius: 0.75em;
	padding: 0.5em;
	box-shadow: rgba(0, 0, 0, 0.08) 0px 1px 3px inset;
}

#section-header .view-switch .view-switch__wrapper .view-switch__icon {
	border: none;
	border-radius: 0.5em;
	padding: 0.75em;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.4em;
	background: none;
}

#section-header .view-switch .view-switch__wrapper .view-switch__icon .view-switch__label {
	color: var(--gray-color01);
}

#section-header .view-switch .view-switch__wrapper .view-switch__icon svg {
	pointer-events: none;
	display: block;
	width: 2em;
	height: 2em;
	fill: var(--gray-color01);
}

#section-header .view-switch .view-switch__wrapper .view-switch__icon.is-active {
	background: #fff;
	box-shadow: rgba(0, 0, 0, 0.15) 0px 2px 6px;
}

#section-header .view-switch .view-switch__wrapper .view-switch__icon.is-active svg {
	fill: var(--brand-color);
}

#section-header .view-switch .view-switch__wrapper .view-switch__icon.is-active .view-switch__label {
	color: var(--brand-color);
}

/* ====================================================
   Section Body & Grid System
   ==================================================== */
#section-body {
	position: relative;
	min-height: 312px;

	--grid-columns: repeat(auto-fill, minmax(320px, 1fr));
	--grid-gap-row: 30px;
	--grid-gap-column: 30px;
	--grid-padding-x: 0px;
	--grid-item-min-w: auto;

	--card-padding: 1em;
	--card-gap: 0.75em;
	--card-badge-position: 1em;
	--card-img-aspect-ratio: 16 / 9;

	--price-val-scale: 1.8em;
	--price-val-word-break: normal;

	--skeleton-padding: 24px;
	--skel-meta-h: 12px;
	--skel-meta-mb: 16px;
	--skel-title-h: 18px;
	--skel-title-mb: 10px;
	--skel-title-short-h: 18px;
	--skel-title-short-mb: 24px;
	--skel-price-h: 14px;
	--skel-price-mb: 24px;
	--skel-tag-w: 90px;
	--skel-tag-h: 24px;
}

#section-body .skeleton-grid,
#section-body .card-grid {
	display: grid;
	grid-template-columns: var(--grid-columns);
	gap: var(--grid-gap-row) var(--grid-gap-column);
	list-style: none;
	padding: 0 var(--container-padding-x);
	margin: 0 0 1em 0;
	transition: opacity 0.5s ease-out;
}

#section-body .card-grid {
	display: none;
	opacity: 0;
}

#section-body .card-grid.fade-in {
	opacity: 1;
}

#section-body .skeleton-grid.fade-out {
	opacity: 0;
}

#section-body .skeleton-grid .skeleton-grid__item,
#section-body .card-grid .card-grid__item {
	height: 100%;
	min-width: var(--grid-item-min-w);
}

/* ====================================================
   Skeleton Animation
   ==================================================== */
@keyframes skeleton-shimmer {
	0% {
		transform: translate(-100%, 0%);
	}

	60% {
		transform: translate(150%, 0%);
	}

	100% {
		transform: translate(150%, 0%);
	}
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card {
	background: #fff;
	border-radius: var(--border-radius);
	border: 1px solid var(--gray-color);
	overflow: hidden;
	height: 100%;
	display: flex;
	flex-direction: column;
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-anim {
	background-color: var(--gray-color);
	position: relative;
	overflow: hidden;
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-anim::before {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.5), transparent);
	animation: skeleton-shimmer 1.8s ease-in-out infinite;
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__image {
	width: 100%;
	aspect-ratio: var(--card-img-aspect-ratio);
	border-bottom: 1px solid rgba(0, 0, 0, 0.03);
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body {
	padding: var(--skeleton-padding);
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body .skeleton-card__meta {
	width: 30%;
	height: var(--skel-meta-h);
	margin-bottom: var(--skel-meta-mb);
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body .skeleton-card__title {
	width: 90%;
	height: var(--skel-title-h);
	margin-bottom: var(--skel-title-mb);
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body .skeleton-card__title-short {
	width: 60%;
	height: var(--skel-title-short-h);
	margin-bottom: var(--skel-title-short-mb);
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body .skeleton-card__price {
	width: 50%;
	height: var(--skel-price-h);
	margin-bottom: var(--skel-price-mb);
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body .skeleton-card__footer {
	margin-top: auto;
	display: flex;
	gap: 8px;
}

#section-body .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body .skeleton-card__footer .skeleton-card__tag {
	width: var(--skel-tag-w);
	height: var(--skel-tag-h);
	border-radius: 0.25em;
}

/* ====================================================
   Card Base & Hover
   ==================================================== */
#section-body .card-grid .card-grid__item .card-grid__wrapper {
	display: flex;
	flex-direction: column;
	height: 100%;
	background: var(--gray-color);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	position: relative;
	transition: var(--transition-base);
	border: 1px solid transparent;
	border-radius: var(--border-radius);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper:has(.expired):before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	background: #000;
	z-index: 10;
	opacity: .2;
	pointer-events: none;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper a {
	display: block;
	text-decoration: none;
	color: inherit;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper:has(a:hover) {
	background: #fff;
	border-color: var(--brand-color);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper:has(a:hover) .card__header .card__image {
	transform: scale(1.03);
}

@media (width > 768px) {
	#section-body .card-grid .card-grid__item .card-grid__wrapper:has(a:hover) {
		transform: translateY(-5px);
		box-shadow: var(--shadow-hover);
		z-index: 10;
	}
}

/* ====================================================
   Card Header
   ==================================================== */
#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header {
	position: relative;
	width: 100%;
	aspect-ratio: var(--card-img-aspect-ratio);
	padding: 8% 0;
	background-color: #fff;
	border-bottom: 1px solid rgba(0, 0, 0, 0.03);
	overflow: hidden;
	text-align: center;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header>a {
	height: 100%;
	aspect-ratio: 4/3;
	margin: 0 auto;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header .card__image {
	display: block;
	width: 100%;
	transition: transform 0.5s ease;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header .card__badges {
	position: absolute;
	top: var(--card-badge-position);
	left: var(--card-badge-position);
	width: calc(100% - (var(--card-badge-position) * 2));
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	gap: 0.4em;
	z-index: 5;
	pointer-events: none;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header .card__badge {
	display: flex;
	align-items: center;
	gap: 0.3em;
	color: #fff;
	padding: 0.5em 1em;
	font-size: var(--badge-f-size);
	width: fit-content;
	opacity: .9;
	font-weight: 700;
	border-radius: 0.5em;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header .card__badge--discount {
	background: var(--red-color);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header .card__badge--period {
	background: var(--blue-color);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header .card__badge--period::before {
	content: "";
	display: block;
	width: 1.2em;
	aspect-ratio: 1;
	background: url(../img/time.svg) center / contain no-repeat;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header .card__badge--period.expired {
	background: var(--black-color);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__header .card__badge--period.expired::before {
	display: none;
}

/* ====================================================
   Card Body
   ==================================================== */
#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body {
	flex-grow: 1;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body a {
	display: flex;
	flex-direction: column;
	gap: var(--card-gap);
	font-size: var(--menu-f-size);
	line-height: 1.2;
	padding: var(--card-padding);
	height: 100%;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5em 2em;
	font-size: var(--smallcategory-f-size);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__meta span {
	color: var(--gray-color02);
	font-size: var(--smallcategory-f-size);
	display: flex;
	gap: 0.3em;
	align-items: center;
	line-height: 1;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__meta span::before {
	content: "";
	display: block;
	flex-shrink: 0;
	width: 1.4em;
	height: 1.4em;
	background-color: var(--brand-color);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: contain;
	mask-size: contain;
	-webkit-mask-position: center;
	mask-position: center;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__meta .card__category::before {
	-webkit-mask-image: var(--svg-mask-category);
	mask-image: var(--svg-mask-category);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__meta .card__area::before {
	-webkit-mask-size: 85%;
	mask-size: 85%;
	-webkit-mask-image: var(--svg-mask-area);
	mask-image: var(--svg-mask-area);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__title {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	font-size: var(--menu-f-size);
	font-weight: 700;
	line-height: 1.2;
	padding: 0;
	margin: 0;
	background: none;
	overflow: hidden;
	min-height: 2lh;
	word-break: auto-phrase;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__price .card__price-detail {
	font-size: var(--price-f-size);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__price .card__price-detail strong {
	display: block;
	font-weight: 700;
	margin-top: 0.75em;
	padding-top: 0.75em;
	border-top: 1px solid var(--gray-color01);
	color: var(--black-color);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__price .card__price-detail strong .card__price-value {
	font-size: var(--price-val-scale);
	word-break: var(--price-val-word-break);
	color: var(--red-color);
	letter-spacing: -0.001em;
	margin: 0 0.05em;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__price .card__more {
	width: 100%;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin: 0.25em 0 0;
	color: var(--brand-color);
	font-weight: 700;
	font-size: var(--price-f-size);
	line-height: 1;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__price .card__more::before {
	content: "";
	display: block;
	width: 1.5em;
	aspect-ratio: 1;
	background-color: currentColor;
	border-radius: 50%;
	font-size: var(--badge-f-size);
	margin-right: 0.25em;
	flex-shrink: 0;
	-webkit-mask-image: var(--svg-mask-more);
	mask-image: var(--svg-mask-more);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: contain;
	mask-size: contain;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1em;
	margin-top: auto;
	font-size: var(--price-f-size);
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags {
	display: flex;
	gap: 0.25em;
	flex-wrap: wrap;
	align-items: stretch;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag {
	display: flex;
	gap: 0.3em;
	align-items: center;
	padding: 0.5em 0.75em 0.5em 0.5em;
	font-size: var(--badge-f-size);
	width: fit-content;
	border-radius: 0.5em;
	border: solid 1px;
	color: var(--blue-color);
	background: #fff;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag::before {
	content: "";
	display: block;
	width: 1.3em;
	aspect-ratio: 1;
}

/* Card Privilege Tags */
#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .type-02 {
	color: var(--orange-color);
	border-color: var(--orange-color);
	padding: 0.5em 0.75em;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag.type-01::before {
	background: url(../img/privilegetype/type01.svg) center / contain no-repeat;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag.type-02::before {
	content: none;
	display: none;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag.type-04::before {
	background: url(../img/privilegetype/type04.svg) center / contain no-repeat;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag.type-05::before {
	background: url(../img/privilegetype/type05.svg) center / contain no-repeat;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag.type-07::before {
	background: url(../img/privilegetype/type07.svg) center / contain no-repeat;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag.type-08::before {
	background: url(../img/privilegetype/type08.svg) center / contain no-repeat;
}

.card__privilegetype-tag.type-09::before {
	background: url(../img/privilegetype/type09.svg) center / contain no-repeat;
}

#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .cta-button {
	display: none;
	width: fit-content;
	font-size: var(--price-f-size);
	padding: 0.75em 1.25em;
	border-radius: 3em;
	color: #fff;
	background: var(--brand-color);
	flex: 0 1 auto;
	white-space: nowrap;
}

/* ====================================================
   #tag_recommend
   ==================================================== */

#tag_recommend #section-header {
	padding: 0 0 1em;
}

#fftop_recomDetail #tag_recommend #section-header {
	padding: 1em 0;
}

#tag_recommend #section-header .section-header__content {
	padding: 0 var(--container-padding-x);
}

#fftop_recomDetail #tag_recommend #section-header .section-header__content {
	padding: 0 10px;
}

#tag_recommend .tag-list-container {
	display: none;
	width: 100%;
	overflow-x: auto;
}

#tag_recommend .tag-list-container:has(li.tag-listItem) {
	display: block;
	opacity: 1;
	transition: opacity 0.5s ease;

	@starting-style {
		opacity: 0;
	}
}

#tag_recommend .tag-list-container #tag-list {
	width: auto;
	font-size: var(--txt-f-size);
	display: flex;
	gap: 1em;
}

#tag_recommend .tag-list-container #tag-list:has(li.tag-listItem) {
	margin: 0 0 1em;
}

#tag_recommend .tag-list-container #tag-list .tag-listItem:first-child {
	padding-left: var(--container-padding-x);
}

#tag_recommend .tag-list-container #tag-list .tag-listItem:last-child {
	padding-right: var(--container-padding-x);
}

@media (width < 768px) {
	#tag_recommend .tag-list-container #tag-list .tag-listItem:first-child {
		padding-left: 10px;
	}

	#tag_recommend .tag-list-container #tag-list .tag-listItem:last-child {
		padding-right: 10px;
	}
}

/* #tag_recommend .tag-list-container #tag-list .tag-listItem {
	order: 1;
}

#tag_recommend .tag-list-container #tag-list .tag-listItem:has(.is-active) {
	order: 0;
} */

#tag_recommend .tag-list-container #tag-list .tag-listItem .tag-link {
	display: flex;
	justify-content: center;
	gap: 0.25em;
	padding: 1em 1.5em 1em 1em;
	font-size: var(--tag-f-size);
	color: var(--black-color);
	background: var(--brand-thin-color);
	border-radius: 3em;
	line-height: 1;
	white-space: nowrap;
	transition: all ease .3s;
	text-decoration: none;
	border: none;
	cursor: pointer;
}

#tag_recommend .tag-list-container #tag-list .tag-listItem .tag-link.is-active {
	color: #fff;
	background: var(--brand-color);
}

#tag_recommend .tag-list-container #tag-list .tag-listItem .tag-link::before {
	display: block;
	content: "";
	background: var(--brand-color);
	-webkit-mask-image: var(--svg-mask-check);
	mask-image: var(--svg-mask-check);
	width: 1em;
	aspect-ratio: 1;
}

#tag_recommend .tag-list-container #tag-list .tag-listItem .tag-link.is-active::before {
	background: #fff;
}

@media (width > 767px) {
	#tag_recommend .tag-list-container #tag-list .tag-listItem .tag-link:hover {
		color: #fff;
		background: var(--brand-color);
	}

	#tag_recommend .tag-list-container #tag-list .tag-listItem .tag-link:hover::before {
		background: #fff;
	}
}

/* --- Scrollbar Customization --- */
@-moz-document url-prefix() {
	#tag_recommend .tag-list-container {
		scrollbar-width: thin;
		scrollbar-color: var(--gray-color02) var(--gray-color);
	}
}

#tag_recommend .tag-list-container::-webkit-scrollbar {
	width: 5px;
	height: 5px;
}

#tag_recommend .tag-list-container::-webkit-scrollbar-button {
	display: none;
}

#tag_recommend .tag-list-container::-webkit-scrollbar-thumb {
	background-color: var(--gray-color01);
	border-radius: 10px;
}

#tag_recommend .tag-list-container::-webkit-scrollbar-track {
	background-color: #fff;
	border-radius: 10px;
}

#tag_recommend #section-header .page-function {
	padding: 0 var(--container-padding-x);
}

@media (width < 768px) {
	#tag_recommend #section-header .page-function {
		padding: 0 10px;
	}

}


#tag_recommend #section-body .card-grid[data-target] {
	display: none;
	opacity: 0;
}

#tag_recommend #section-body .card-grid[data-target].is-active {
	display: grid;
	opacity: 1;
	transition: opacity 0.5s ease;

	@starting-style {
		opacity: 0;
	}
}

/* ====================================================
   Specific Layout
   ==================================================== */
#fftop_recomDetail section {
	padding: initial;
	margin: initial;
}

#fftop_recomDetail .layout-container {
	padding: 0;
}

#fftop_recomDetail .layout-container #section-header {
	padding: 1em 10px;
	margin: 0 0 1em;
	background: #fff;
	/* position: sticky;
	top:0;
	z-index: 11; */
}

#fftop_recomDetail .layout-container #section-header .section-header__content .section-header__title {
	padding: 0;
	margin: 0;
	background: none;
}

/* ====================================================
   Special Feature (#special_feature) - 統合追加部分
   ==================================================== */
#special_feature {
	position: relative;
	box-sizing: border-box;
	width: 100%;
	padding: var(--container-padding-x) 0;
	margin: 0 auto;
	color: var(--black-color);
}

#special_feature .pc {
	display: block !important;
}

#special_feature .sp {
	display: none !important;
}

#special_feature_contents {
	display: grid;
	grid-template-areas: "stack";
	width: 100%;
	position: relative;
	min-height: 265px;

	--grid-columns: repeat(auto-fill, minmax(min(270px, 100%), 1fr));
	--grid-gap-row: 30px;
	--grid-gap-column: 30px;
	--grid-padding-x: 0px;
	--grid-item-min-w: auto;

	--card-padding: 1em;
	--card-gap: 0.75em;
	--card-badge-position: 1em;
}


#special_feature_contents>.skeleton-grid,
#special_feature_contents>ul {
	grid-area: stack;
	width: 100%;
}

#special_feature .skeleton-grid {
	display: grid;
	gap: var(--grid-gap-row) var(--grid-gap-column);
	grid-template-columns: var(--grid-columns);
	padding: 0 var(--container-padding-x);
	margin: 0;
	opacity: 1;
	z-index: 2;
	pointer-events: all;
	transition: opacity 0.5s ease, visibility 0.5s ease allow-discrete;
	background: #fff;
}

#special_feature.is-loaded .skeleton-grid {
	opacity: 0;
	display: none;
	pointer-events: none;
}

#special_feature .skeleton-grid .skeleton-grid__item {
	height: 100%;
	min-width: auto;
}

#special_feature .skeleton-grid .skeleton-grid__item .skeleton-card {
	background: #fff;
	border-radius: 0.5em;
	border: 1px solid var(--gray-color);
	overflow: hidden;
	height: 100%;
	display: flex;
	flex-direction: column;
}

#special_feature .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-anim {
	background-color: var(--gray-color);
	position: relative;
	overflow: hidden;
}

#special_feature .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-anim::before {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.5), transparent);
	animation: skeleton-shimmer 1.8s ease-in-out infinite;
}

#special_feature .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__image {
	width: 100%;
	aspect-ratio: 4 / 3;
	border-bottom: 1px solid rgba(0, 0, 0, 0.03);
}

#special_feature .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body {
	padding: 1em;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

#special_feature .skeleton-grid .skeleton-grid__item .skeleton-card .skeleton-card__body .skeleton-card__title {
	width: 50%;
	height: 12px;
}

#special_feature_contents ul {
	display: none;
	grid-template-columns: var(--grid-columns);
	gap: var(--grid-gap-row) var(--grid-gap-column);
	list-style: none;
	padding: 0 var(--container-padding-x);
	margin: 0;
	opacity: 0;
	z-index: 1;
	transition: all 0.5s ease;
}

#special_feature.is-loaded #special_feature_contents ul {
	display: grid;
	opacity: 1;

	@starting-style {
		opacity: 0;
	}
}

#special_feature .special_feature_contents {
	position: relative;
}

#special_feature .special_feature_contents a {
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	text-decoration: none;
	transition: var(--transition-base);
	border: 1px solid transparent;
	border-radius: 0.5em;
	overflow: hidden;
	background: var(--gray-color);
}

#special_feature .special_feature_contents a:hover {
	background: #fff;
	border-color: var(--brand-color);
}

@media (width > 768px) {
	#special_feature .special_feature_contents a:hover {
		transform: translateY(-5px);
		box-shadow: var(--shadow-hover);
		z-index: 10;
	}
}

#special_feature .special_feature_contents a .bg_txt>img {
	transition: all ease .2s;
}

#special_feature .special_feature_contents a img {
	width: 100%;
	vertical-align: bottom;
}

#special_feature .special_feature_contents a>img {
	width: 100%;
	background: var(--black-color);
	display: block;
	position: relative;
	z-index: 0;
	transition: all ease .3s;
}

#special_feature .special_feature_contents a .bg_txt {
	position: relative;
}

#special_feature .special_feature_contents a .text_all {
	text-align: center;
	background: linear-gradient(to top, rgba(0, 0, 0, 50%) 0%, rgba(255, 255, 255, 0%) 70%);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

#special_feature .special_feature_contents a .text_all[data-empty="true"] {
	background: none !important;
	display: none;
}

#special_feature .special_feature_contents a .text_all .title {
	box-sizing: border-box;
	color: #fff;
	text-align: center;
	font-size: 16px;
	font-weight: 700;
	padding: 0 1em;
	line-height: 1.2;
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
	width: 100%;
}

#special_feature .special_feature_contents a .text_all .text {
	box-sizing: border-box;
	color: #fff;
	text-align: center;
	font-weight: 400;
	padding: 0 1.4em;
	margin: 0.5em 0 1.4em;
	line-height: 1.2;
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
	width: 100%;
	font-size: 12px;
}

#special_feature .special_feature_contents .inner_txt_all {
	flex: 0 1 auto;
	display: flex;
	gap: 1em;
	justify-content: space-between;
	align-items: center;
	padding: 1em;
}

#special_feature .special_feature_contents .inner_txt_all .text {
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	line-clamp: 2;
	-webkit-line-clamp: 2;
	min-height: calc(var(--txt-f-size) * 2 * 1.5);
	margin: 1em 0 0;
}

#special_feature .special_feature_contents .icn {
	font-size: var(--remark-f-size);
	line-height: 1;
	display: flex;
	gap: 0.5em;
	text-align: center;
	position: relative;
	align-items: center;
	box-sizing: border-box;
	margin: 0;
	order: 0;
}

#special_feature .special_feature_contents .icn img {
	display: block;
	position: relative;
	font-size: 1em;
	width: 1.2em;
	aspect-ratio: 1;
}

#special_feature .special_feature_contents .icn:nth-child(1)::before {
	content: "";
	width: 1.4em;
	aspect-ratio: 1;
	background-color: var(--brand-color);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: contain;
	mask-size: contain;
	-webkit-mask-position: center;
	mask-position: center;
	-webkit-mask-image: var(--svg-mask-category);
	mask-image: var(--svg-mask-category);
}

#special_feature .special_feature_contents .icn:nth-child(1) .icn_img {
	display: none;
}

#special_feature .special_feature_contents .icn_txt {
	padding: 0;
	font-size: var(--remark-f-size);
	line-height: 1;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	line-clamp: 1;
	-webkit-line-clamp: 1;
	overflow: hidden;
}

#special_feature .special_feature_contents .registered img {
	display: block;
}

#special_feature .special_feature_contents .registered figcaption {
	display: none;
}

#special_feature .icon-note {
	position: relative;
}

#special_feature .icon-note .icon {
	display: inline-block;
	font-size: var(--remark-f-size);
	width: 1.2em;
	aspect-ratio: 1;
	line-height: 1;
	vertical-align: middle;
}

#special_feature .icon-note .remark {
	display: inline;
}

#special_feature .title {
	font-size: var(--title-f-size);
	font-weight: 700;
	line-height: 1.2;
}

#special_feature .subtitle {
	font-size: var(--sbtitle-f-size);
	font-weight: 400;
	line-height: 1.2;
}

#special_feature .text {
	font-size: var(--txt-f-size);
	font-weight: 400;
	line-height: 1.5;
}

#special_feature .remark {
	font-size: var(--remark-f-size);
	font-weight: 400;
	line-height: 1.5;
}

/* ====================================================
   Media Queries (スマホ用上書き・変数による一元管理)
   ==================================================== */

@media (width < 1000px) {

	.layout-container,
	#section-body,
	#special_feature_contents {
		--container-padding-x: 20px;
		--grid-gap-row: 20px;
		--grid-gap-column: 20px;
	}
}

@media (width < 768px) {
	:root {
		--title-f-size: 17px;
	}

	.layout-container .sp,
	#special_feature .sp {
		display: block !important;
	}

	.layout-container .pc,
	#special_feature .pc {
		display: none !important;
	}

	.layout-container p {
		color: inherit;
	}

	#section-header .view-switch {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		gap: 0.5em;
	}

	#section-body,
	#special_feature_contents {
		min-height: 50vh;
	}

	#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body p {
		line-height: 1.2;
	}

	/* -----------------------------------------
       スマホ1カラム時の設定（詳細表示）
       ----------------------------------------- */
	#section-body {
		--grid-columns: 1fr;
		--grid-gap-row: 20px;
		--grid-gap-column: 0px;
		--grid-padding-x: 20px;
	}

	/* -----------------------------------------
       スマホ2カラム時の設定（一覧表示・はみ出し防止）
       一元管理された変数をここで上書きするだけで全要素に適用
       ----------------------------------------- */
	#section-body.is-2col {
		--grid-columns: repeat(2, 1fr);
		--grid-gap-row: 20px;
		--grid-gap-column: 10px;
		--grid-padding-x: 10px;
		--grid-item-min-w: 0;
		--border-radius: 0.5em;

		--menu-f-size: 13px;
		--price-f-size: 13px;
		--smallcategory-f-size: 9px;
		--badge-f-size: 9px;

		--card-padding: 0.75em;
		--card-gap: 0.5em;
		--card-badge-position: 0.5em;
		--card-img-aspect-ratio: 4 / 3;
		--price-val-scale: 1.4em;
		--price-val-word-break: break-all;

		--skeleton-padding: 0.75em;
		--skel-meta-h: 10px;
		--skel-meta-mb: 8px;
		--skel-title-h: 14px;
		--skel-title-mb: 6px;
		--skel-title-short-h: 14px;
		--skel-title-short-mb: 12px;
		--skel-price-h: 12px;
		--skel-price-mb: 12px;
		--skel-tag-w: 60px;
		--skel-tag-h: 20px;
	}

	#section-body .skeleton-grid,
	#section-body .card-grid {
		padding: 0 var(--grid-padding-x);
	}

	#section-body .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .cta-button {
		display: block;
	}

	#section-body.is-2col .card-grid .card-grid__item .card-grid__wrapper .card__header .card__badge--period::before,
	#section-body.is-2col .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag::before,
	#section-body.is-2col .card-grid__item .card-grid__wrapper .card__body .card__price .card__more,
	#section-body.is-2col .card-grid__item .card-grid__wrapper .card__body .card__footer .cta-button {
		display: none;
	}

	#section-body.is-2col .card-grid__item .card-grid__wrapper .card__body .card__title {
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	#section-body.is-2col .card-grid__item .card-grid__wrapper .card__body .card__price .card__price-detail {
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	#section-body.is-2col .card-grid__item .card-grid__wrapper .card__body .card__price .card__price-detail strong {
		display: inline;
		padding: 0;
		margin: 0;
		border: none;
		color: var(--red-color);
	}

	#section-body.is-2col .card-grid .card-grid__item .card-grid__wrapper .card__body .card__price .card__price-detail strong .card__price-value {
		font-size: inherit;
		letter-spacing: initial;
		margin: 0;
	}

	#section-body.is-2col .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags li:nth-child(n+3) {
		display: none;
	}

	#section-body.is-2col .card-grid .card-grid__item .card-grid__wrapper .card__body .card__footer .card__privilegetype-tags .card__privilegetype-tag {
		padding: 0.5em 0.75em;
	}

	.layout-container .section-body__remark {
		padding: 0 var(--grid-padding-x);
	}
}
