@charset "UTF-8";

/*************
FMT
*************/
html {
  touch-action: manipulation;
}
/* body {
	overflow-x: hidden;
} */
.content_wrap {
	margin-top: 66px;
}
@media(min-width:751px){
	.content_wrap {
		margin-top: 90px;
	}
}
.content_wrap a:hover img {
	opacity: 1;
}
/*************
CONTENTS
*************/
.header_box {
	border-bottom: 1px solid #222222;
}

.main {
	--ff-default: "Noto Sans JP", sans-serif;
	--ff-en: "Oranienbaum", serif;

	--header-height: 66px;
  --base-width: 390;
	--vw: calc(100vw / var(--base-width));

	--black: #222222;
	--white: #FFFFFF;
	--white-bg: #FBF9F6;
	--brown: #AC795A;
	--brown-dark: #5F3930;
	--beige: #F6DAB5;
	--pink: #E95377;
	--pink-light: #FFDADB;
	--blue: #CDEEFF;
	--green: #BFF3CB;
	--purple: #E8D9FF;
	--gray: #CECECE;

	overflow-x: clip;
}

@media(min-width:751px) {
	.main {
		--header-height: 90px;
  	--base-width: 751;
	}
}

@media(min-width:1200px) {
	.page_wrapper {
  	--base-width: 1200;
	}
}

/*
page
*/
.page {
	font-family: var(--ff-default);
	font-weight: 400;
	letter-spacing: 0;
	box-sizing: border-box;
}

.page * {
	box-sizing: border-box;
}

.page_wrapper {
	/* display: grid;
	grid-template-columns: 1fr; */
}

.page_main {
	/* display: grid;
	grid-template-columns: 1fr; */
	min-width: 0;
	overflow-x: clip;
}

.page_content {
	width: 100%;
	background-color: var(--pink-light);
	min-width: 0;
}

.page_index {
	width: 100%;
	z-index: 1;
	min-width: 0;
	position: relative;
}

.page_index.pc.is-visible {
	opacity: 1;
	transform: translateY(0);
}
.page_index.pc {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 0.5s ease, transform 0.6s ease;
}

.page_index.sp {
	background-color: var(--white);
}

.page_mv {
	overflow: hidden;
	position: relative;
}

@media(min-width:751px) {
	/* .page_main {
		display: grid;
		grid-template-columns: 1fr 190px;
		background-color: var(--pink-light);
		position: relative;
	}

	.page_index {
		width: auto;
		position: relative;
		border-left: 1px solid var(--black);
		min-height: calc(100vh - var(--header-height));
	}

	.page_mv {
		height: auto;
		min-height: auto;
	} */

	.page_content {
		width: 100%;
		height: 100%;
		background-color: var(--pink-light);
		background-image: url(../img/bg-cross.svg);
		position: relative;
		z-index: 0;
	}
}
/*
@media(min-width:1200px) {
	.page_wrapper {
		grid-template-columns: 1fr 1fr;
	}
}

@media(min-width:1241px) {
	.page_wrapper {
		grid-template-columns: 1fr 1fr;
	}
} */




/*
deco
*/
.deco {
	display: none;
	width: 100%;
	height: calc(100vh - var(--header-height));
	/* padding: 48px 50px;
	border-right: 1px solid var(--black); */
	background-color: white;
	border: 48px solid var(--white);
	position: relative;
	z-index: 0;
}
.deco::before {
	content: "";
	width: 100%;
	height: 100%;
	border-radius: 24px;
	background-color: var(--pink-light);
	background-image: url(../img/bg-cross.svg);
	position: absolute;
	top: 0;
	left: 0;
	z-index: -10;
}
.deco::after {
	content: "";
	width: 364px;
	height: 198px;
	background-image: url(../img/side-sakura_bottom.svg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: right bottom;
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 1;
}

.deco_inner {
	width: 100%;
	max-width: 1234px;
	height: 100%;
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.deco_inner::before {
	content: "";
	width: min(44.5%, 641px);
	height: 199px;
	background-image: url(../img/deco_sakura.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: left top;
	position: absolute;
	top: -48px;
	left: -48px;
	z-index: 10;
}
.deco_inner::after {
	content: "";
	width: min(44.5%, 641px);
	height: 199px;
	background-image: url(../img/deco_sakura-re.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: right top;
	position: absolute;
	top: -48px;
	right: -48px;
	z-index: 10;
}

.deco_img {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 42px calc(80 / 1440 * 100vw);
	position: relative;
	z-index: 2;
}
.deco_img img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	clip-path: inset(100% 0 0 0);
	animation: fadeInChara 0.6s cubic-bezier(.11,.57,.08,.97) forwards 1.2s;
}
.deco_img::before {
	/* content: ""; */
	width: calc(100% - (80 / 1440 * 100vw * 2));
	height: calc(100% - 84px);
	background-color: var(--white);
	mask-image: url(../img/side-main.png);
	mask-repeat: no-repeat;
	mask-size: contain;
	mask-position: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	clip-path: inset(100% 0 0 0);
	/* animation: fadeInChara 0.5s cubic-bezier(.11,.57,.08,.97) forwards 1.5s; */
	z-index: -1;
}
.deco_img::after {
	content: "";
	width: calc(100% - (80 / 1440 * 100vw * 2));
	height: calc(100% - 84px);
	background-image: linear-gradient(to top, var(--white) calc(100% / 3), #FFC0C0 calc(100% / 3), #FFC0C0 calc(100% / 3 * 2), var(--pink) calc(100% / 3 * 2));
	background-size: 100% 300%;
	background-position: 0 0;
	mask-image: url(../img/side-main.png);
	mask-repeat: no-repeat;
	mask-size: contain;
	mask-position: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	animation: fadeInCharaBg 0.5s linear forwards 0.5s;
	z-index: -2;
}

.deco_text {
	display: flex;
	align-items: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 0;
	pointer-events: none;
}
.deco_text span {
	font-family: var(--ff-en);
	font-size: 110px;
	color: #DDC695;
	line-height: 1.1;
	letter-spacing: 0;
	font-weight: 400;
	white-space: nowrap;
	padding: 0 8px;
	animation: scroll-left 10s infinite linear 0.5s both;
}

@keyframes scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

@keyframes fadeInChara {
	from {
		clip-path: inset(100% 0 0 0);
	}
	to {
		clip-path: inset(0 0 0 0);
	}
}

@keyframes fadeInCharaBg {
	0% {
		background-position: 0 0;
	}
	50% {
		background-position: 0 50%;
	}
	100% {
		background-position: 0 100%;
	}
}

.deco_bg {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: -2;
  will-change: transform;
  transform: translateZ(0);
}
.deco_bg path {
	will-change: transform, opacity;
}

@media(min-width:751px) {
	.deco {
		display: block;
	}

	.deco::after {
		content: unset;
	}

	.deco_inner {
		padding-right: 82px;
	}

	.deco_img {
		width: 42%;
		padding: 42px 0;
	}
	.deco_img::after {
		width: calc(100% - 0px);
	}
}

@media(min-width:751px) and (max-width:1024px){
	.deco {
		height: auto;
		min-height: calc(100vh - var(--header-height));
	}

	.deco_inner {
		height: 100%;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		row-gap: 32px;
		padding-inline: 20px;
		padding-block: 64px;
	}

	.deco_img {
		width: 80%;
		max-width: 640px;
		padding: 0;
	}

	.deco_img::after {
		height: 100%;
	}

	.deco_inner::before,
	.deco_inner::after {
		width: 56%;
		max-width: unset;
	}
}

/*
mv
*/
.mv {
	/* height: 100%;
	min-height: calc(100vh - var(--header-height)); */
	background-image: url(../img/bg-cross.svg);
	position: relative;
	z-index: 0;
}
/* .mv::before {
	content: "";
	width: 100%;
	height: 100%;
	background-image: linear-gradient(180deg, rgba(255, 218, 219, 0) 63.15%, #FFDADB 99.34%);
	opacity: 0.9;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
} */

.mv_deco {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

.mv_info {
	display: flex;
	flex-direction: column;
	align-items: center;
	row-gap: 12px;
	padding-top: calc(25 * var(--vw));
	padding-inline: 14px;
}

.mv_title {
	display: flex;
	max-width: 616px;
}

.mv_lead {
	display: flex;
	align-items: center;
	column-gap: 12px;
	padding-inline: 30px;
	width: 100%;
	max-width: 419px;
	font-size: 14px;
	line-height: 1;
	letter-spacing: 0.2em;
	white-space: nowrap;
	color: var(--pink);
}
.mv_lead::before, .mv_lead::after {
	content: "";
	width: 100%;
	height: 1px;
	background-color: var(--pink);
	flex-shrink: 1;
	border-radius: 1px;
}

.mv_date {
	display: flex;
	padding-inline: 30px;
	max-width: 464px;
}

.mv_main {
	display: flex;
	width: 100%;
	max-width: 528px;
	margin-inline: auto;
	margin-top: 20px;
	/* padding-inline: 8px; */
}

@media(min-width:751px){
	.mv {
		width: 58%;
		max-width: 648px;
		padding-inline: 16px;
		min-height: auto;
		background-image: unset;
		z-index: 1;
	}
	.mv_main {
		padding-inline: 16px;
	}

	.mv_info {
		padding: 0;
		margin-top: 12px;
	}

	.mv_lead {
		font-size: 16px;
		padding-inline: 18px;
	}

	.mv_date {
		padding-inline: 18px;
	}
}

@media(min-width:751px) and (max-width:1024px){
	.mv {
		width: 80%;
	}
}


/*
nav
*/
.nav {
	width: 100%;
	background-color: var(--white);
}

.nav_inner {
}

.nav_lead {
	padding-block: 6px 2px;
	font-family: var(--ff-en);
	font-size: 26px;
	line-height: 1.15;
	text-align: center;
	color: var(--pink);
}

.nav_list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.nav_item {
	border: 1px solid var(--gray);
	border-top: none;
}
.nav_item:nth-child(odd) {
	border-right: none;
}

.nav_frame {
	height: 70px;
	display: flex;
	align-items: center;
	column-gap: 7px;
	padding: 6px calc(8 * var(--vw));
}

.nav_number {
	flex-shrink: 0;
	display: flex;
	width: 39px;
}

.nav_body {
	display: flex;
	flex-direction: column;
	justify-content: center;
	row-gap: 5px;
}

.nav_sub {
	font-size: 10px;
	line-height: 1;
	color: var(--brown-dark);
}

.nav_title {
	display: flex;
	height: 15px;
	width: auto;
}
.nav_title.--larger {
	height: 47px;
}
.nav_title img {
	height: 100%;
	width: auto;
	object-fit: contain;
}


/*
sidebar
*/
.sidebar {
	width: 100%;
	margin-top: 50px;
	margin-bottom: 64px;
}

.sidebar_inner {
	max-width: 1000px;
	padding-inline: 10px;
	margin-inline: auto;
}

.sidebar_lead {
	font-family: var(--ff-en);
	font-size: 56px;
	line-height: 1.15;
	text-align: center;
	color: var(--pink);
}

.sidebar_list {
	margin-top: 8px;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	column-gap: 20px;
	row-gap: 15px;
}

.sidebar_item {
	background-color: var(--white);
	border: 1px solid var(--brown);
}

.sidebar_frame {
	height: 100px;
	display: flex;
	align-items: center;
	column-gap: 15px;
	padding: 18px 16px 18px 28px;
	background-color: var(--white);
	border: 5px solid var(--beige);
	transition: background-color 0.3s ease;
	position: relative;
}

.sidebar_frame::before,
.sidebar_frame::after {
	content: "";
	width: 21px;
	height: 100%;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

.sidebar_frame::before {
	background-image: url(../img/index-lead_deco.svg);
	left: 0;
}
.sidebar_frame::after {
	background-image: url(../img/index-lead_deco-re.svg);
	right: 0;
}

.sidebar_number {
	flex-shrink: 0;
	display: flex;
	width: 56px;
}

.sidebar_body {
	display: flex;
	flex-direction: column;
	justify-content: center;
	row-gap: 5px;
}

.sidebar_sub {
	font-size: 12px;
	line-height: 1.5;
	color: var(--brown-dark);
}

.sidebar_title {
	display: flex;
	height: 21px;
	width: auto;
}
.sidebar_title.--larger {
	height: 42px;
}
.sidebar_title img {
	height: 100%;
	width: auto;
	object-fit: contain;
}
.sidebar_text {
	padding-top: 8px;
	padding-inline: 7px;
	font-family: var(--ff-en);
	font-size: 26px;
	line-height: 1.15;
	color: var(--pink);
}

@media(min-width:751px) and (max-width:1024px){
	.sidebar_list {
		column-gap: 8px;
	}

	.sidebar_frame {
		column-gap: 5px;
		padding: 18px 16px 18px 22px;
	}

	.sidebar_title {
		height: 18px;
	}

	.sidebar_number {
		width: 40px;
	}

	.sidebar_sub {
		font-size: 10px;
	}
}


/*
fixedNav
*/
.fixedNav {
	opacity: 0;
	visibility: hidden;
	width: 100%;
	height: 67px;
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 100;
	transition: opacity 0.15s ease, visibility 0.15s ease;
}
.fixedNav.is-visible {
	opacity: 1;
	visibility: visible;
}

.fixedNav_list {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	background-color: var(--white);
	border-bottom: 1px solid var(--gray);
	height: 100%;
}

.fixedNav_item {
}
.fixedNav_item:not(:last-child) {
	border-right: 1px solid var(--gray);
}

.fixedNav_link {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
}

.fixedNav_text {
	font-family: var(--ff-en);
	font-size: 20px;
	line-height: 1;
	color: var(--pink);
}

.fixedNav_icon {
	display: block;
	height: 100%;
	max-height: 28px;
	width: auto;
}
.fixedNav_icon.--larger {
	max-height: 46px;
}
.fixedNav_icon img {
	height: 100%;
	width: auto;
	object-fit: contain;
}


/*
separator
*/
.separator {
	width: 100%;
	max-width: 514px;
	margin-inline: auto;
	padding: 20px;
}


/*
section
*/
.section {
	width: 100%;
	max-width: 560px;
	margin-inline: auto;
	padding-inline: 20px;
	padding-top: 20px;
	margin-top: -20px;
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 0.5s ease, transform 0.6s ease;
}
.section.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.section_inner {
	position: relative;
	border: 1px solid var(--brown);
}

.section_inner::before {
	content: "";
	width: calc(100% + 2px);
	height: 100%;
	aspect-ratio: 360 / 105;
	background-image: url(../img/section-frame_top.svg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: top center;
	position: absolute;
	top: 0;
	right: -1px;
	z-index: 0;
	pointer-events: none;
}
.section_inner::after {
	content: "";
	width: calc(100% + 2px);
	height: 100%;
	aspect-ratio: 360 / 105;
	background-image: url(../img/section-frame_bottom.svg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: bottom center;
	position: absolute;
	bottom: 0;
	left: -1px;
	z-index: 0;
	pointer-events: none;
}

.section_wrapper {
	background-color: var(--white-bg);
	border: 8px solid var(--beige);
	z-index: 0;
}

.section_wrapper::before {
	content: "";
	width: calc(100% - 14px);
	height: 100%;
	aspect-ratio: 346 / 78;
	background-image: url(../img/drama-frame_top.svg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: top left;
	position: absolute;
	top: -6px;
	left: -4px;
	z-index: 0;
	pointer-events: none;
}

.section_container {
	padding: 40px 0 105px;
	border: 1px solid var(--brown);
}

.section_heading {

}

.section_num {
	display: flex;
	width: 102px;
	margin-inline: auto;
	position: relative;
	z-index: 2;
}

.section_headingWrapper {
	position: relative;
	z-index: 0;
}
.section_headingWrapper::before {
	/* content: "";
	width: calc(100vw + 56px);
	max-width: 458px;
	height: 298px;
	background-image: url(../img/bg-sakura.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: left top;
	position: absolute;
	top: 0;
	left: -20px;
	z-index: -1;
	pointer-events: none; */
}

.section_headingBg {
	width: calc(100vw + 56px);
	max-width: 458px;
	height: 298px;
	position: absolute;
	top: 0;
	left: -20px;
	z-index: -1;
	pointer-events: none;
}

.section_sub {
	margin-top: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	column-gap: 7px;
	font-size: 14px;
	font-weight: bold;
	line-height: 1.4;
	letter-spacing: 0.1em;
	color: var(--brown-dark);
}
.section_sub::before, .section_sub::after {
	content: "";
	flex-shrink: 0;
	width: 12px;
	height: 12px;
	background-image: url(../img/shape-diamond-brown.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.section_title {
	margin-top: 16px;
}

.section_titleImg {
	display: flex;
	width: fit-content;
	max-width: 231px;
	margin-inline: auto;
}

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

.section_label {
	margin-top: 21px;
	font-family: var(--ff-en);
	font-size: 14px;
	line-height: 1;
	letter-spacing: 0.1em;
	text-align: center;
	color: var(--primary-color);
	text-transform: uppercase;
}

.section_lead {
	margin-top: 18px;
	display: flex;
	flex-direction: column;
	row-gap: 20px;
}

.section_leadText {
	font-size: 14px;
	line-height: 2;
	text-align: center;
	padding-inline: 15px;
	max-width: 460px;
	margin-inline: auto;
}

.section_imageWrapper {
	position: relative;
}

.section_imageMain {
	position: relative;
}

.section_image {
	display: flex;
	width: calc(100% + 6px);
	max-width: 702px;
	margin-left: -3px;
	margin-top: 18px;
	margin-bottom: 12px;
}

.section_imageInfo {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	row-gap: 3px;
	position: absolute;
	bottom: calc(25 * var(--vw));
	left: 50%;
	transform: translateX(-50%);
}

.section_imageName {
	width: fit-content;
	font-size: 14px;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 0;
	color: var(--white);
	text-align: center;
	padding: 10px 15px;
	background-color: var(--primary-color);
	border-radius: 50vh;
}

.section_imageNote {
	font-size: 12px;
	font-weight: bold;
	line-height: 1.6;
	letter-spacing: 0;
	text-align: center;
}

.section_imageCaution {
	width: fit-content;
	max-width: min(388px, 100%);
	margin-inline: auto;
	padding-inline: 15px;
	font-size: 12px;
	line-height: 1.6;
	letter-spacing: 0;
}

.section_imageCaution.--center {
	text-align: center;
}

.section_imagetext {
	margin-bottom: 8px;
	font-size: 16px;
	font-weight: bold;
	line-height: 1.6;
	letter-spacing: 0;
	text-align: center;
}
.section_imagetext.--brown {
	margin-bottom: 20px;
	color: var(--brown-dark);
}

@media(min-width:751px){
	.section_wrapper {
		border-width: 14px;
	}

	.section_container {
		padding: 52px 0 148px;
	}

	.section_num {
		width: 140px;
	}

	.section_sub {
		font-size: 18px;
		margin-top: 20px;
		column-gap: 10px;
	}

	.section_sub::before, .section_sub::after {
		width: 16px;
		height: 16px;
	}

	.section_titleImg {
		margin-top: 20px;
		padding-inline: 15px;
		width: 100%;
		max-width: 284px;
	}

	.section_label {
		margin-top: 25px;
		font-size: 16px;
	}

	.section_lead {
		margin-top: 25px;
		row-gap: 22px;
	}

	.section_leadText {
		font-size: 16px;
	}

	.section_image {
		width: calc(100% + 232px);
		max-width: 720px;
		margin-top: 52px;
		margin-left: -116px;
		margin-bottom: 20px;
	}

	.section_imageInfo {
		row-gap: 10px;
		bottom: min(80px, 12.3%);
	}

	.section_imageName {
		font-size: 16px;
	}

	.section_headingWrapper::before {
		/* width: calc(644 * var(--vw));
		max-width: 644px;
		height: 418px;
		top: -48px;
		left: -40px; */
	}

	.section_headingBg {
		width: calc(644 * var(--vw));
		max-width: 644px;
		height: 418px;
		top: -48px;
		left: -40px;
	}

	.section_imagetext {
		max-width: 364px;
		font-size: 16px;
		margin-inline: auto;
	}

	.section_imageCaution.--center {
		text-align: left;
	}
}



/*
howto
*/
.howto {
	margin-top: 48px;
}

.howto_inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	row-gap: 20px;
	max-width: 440px;
	margin-inline: auto;
	padding-inline: 20px;
}

.howto_ttl {
	width: fit-content;
	display: flex;
	padding: 6px 14px 8px;
	margin-inline: auto;
	background-color: var(--brown);
	position: relative;
}
.howto_ttl::before, .howto_ttl::after {
	content: "";
	width: 11px;
	height: 100%;
	background-image: url(../img/shape-ribbon-side.svg);
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center;
	position: absolute;
	top: 0;
}
.howto_ttl::before {
	left: -11px;
}
.howto_ttl::after {
	right: -11px;
	transform: rotate(180deg);
}

.howto_ttl span {
	font-size: 16px;
	line-height: 1;
	color: var(--white);
	padding-inline: 14px;
	position: relative;
}
.howto_ttl span::before,
.howto_ttl span::after {
	content: "";
	width: 7px;
	height: 7px;
	background-image: url(../img/shape-diamond.svg);
	background-size: cover;
	background-repeat: no-repeat;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
.howto_ttl span::before {
	left: 0;
}
.howto_ttl span::after {
	right: 0;
}

.howto_list {
	display: flex;
	flex-direction: column;
	row-gap: 8px;
}

.howto_item {
	display: flex;
	align-items: flex-start;
	column-gap: 10px;
}

.howto_num {
	width: 66px;
	flex-shrink: 0;
	font-family: var(--ff-en);
	font-size: 16px;
	line-height: 1;
	text-align: center;
	color: var(--white);
	padding: 5px 11px 3px;
	background-color: var(--brown);
	border-radius: 50vh;
}

.howto_body {
	margin-top: 2px;
	font-size: 14px;
	line-height: 1.4;
	letter-spacing: 0;
}

@media (min-width:751px){
	.howto_inner {
		row-gap: 25px;
		padding-inline: 30px;
	}
	.howto_ttl {
		padding: 7px 28px 9px;
	}
	.howto_ttl::before, .howto_ttl::after {
		content: "";
		width: 16px;
		height: 100%;
		background-size: 100% 100%;
	}
	.howto_ttl span {
		font-size: 18px;
		padding-inline: 20px;
	}
	.howto_ttl span::before,
	.howto_ttl span::after {
		width: 9px;
		height: 9px;
	}
	.howto_list {
		row-gap: 14px;
	}
	.howto_item {
		column-gap: 14px;
	}
	.howto_num {
		width: 70px;
		font-size: 16px;
		padding: 6px 2px 3px;
	}
	.howto_body {
		margin-top: 3px;
		font-size: 14px;
	}
}



/*
button
*/
.buttonCta {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 280px;
	height: 73px;
	margin-top: 40px;
	margin-bottom: 7px;
	margin-inline: auto;
	padding: 10px;
	background-image: url(../img/shape-button-bg.png);
	background-size: cover;
	position: relative;
	transition: background-image 0.3s ease;
}
.buttonCta::before {
	content: "";
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.05);
	position: absolute;
	top: 7px;
	left: 3px;
	pointer-events: none;
	transition: top 0.3s ease, left 0.3s ease;
}

.buttonCta.--disable {
}

.buttonCta_label {
	width: 100%;
	font-size: 16px;
	line-height: 1;
	letter-spacing: 0;
	text-align: center;
	color: var(--white);
	position: relative;
	transition: color 0.3s ease;
}
.buttonCta_label[lang="en"] {
	font-family: var(--ff-en);
	font-size: 22px;
}
.buttonCta_label::before, .buttonCta_label::after {
	content: "";
	width: 9px;
	height: 9px;
	background-image: url(../img/shape-square.svg);
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	transition: background-image 0.3s ease;
}
.buttonCta_label::before {
	left: 0;
}
.buttonCta_label::after {
	right: 0;
}

@media (min-width:751px){
	.buttonCta {
		margin-top: 45px;
		padding: 16px;
	}

	.buttonCta_label {
		font-size: 18px;
	}

	.buttonCta_label[lang="en"] {
		font-size: 26px;
	}
}



/*
note
*/
.note {
	max-width: 432px;
	margin-top: 32px;
	margin-inline: auto;
	padding-inline: 20px;
}

.note_list {
}

.note_item {
	font-size: 12px;
	line-height: 1.6;
}

.note_item::before {
	content: "※";
}

.note_item.--important {
	font-weight: bold;
}
.note_item.--important + .note_item:not(.--important) {
	margin-top: 12px;
}

@media (min-width:751px){
	.note {
		margin-top: 40px;
		padding-inline: 26px;
	}
}




/*
notice
*/
.notice {
	display: flex;
	flex-direction: column-reverse;
	row-gap: 25px;
	margin-top: 30px;
	padding-inline: 21px;
}

.notice_toggle {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 168px;
	margin-inline: auto;
	font-size: 14px;
	line-height: 1.5;
	text-align: center;
	color: var(--white);
	padding: 7px 3px;
	background-color: var(--brown-dark);
	border-radius: 50vh;
	position: relative;
	transition: background-color 0.3s ease;
}
.notice_toggle::before, .notice_toggle::after {
	content: "";
	width: 11px;
	height: 1px;
	background-color: var(--white);
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
.notice_toggle::before {
	right: 12px;
}
.notice_toggle::after {
	right: 12px;
	transform: translateY(-50%) rotate(90deg);
	transition: transform 0.15s ease;
}
.notice_toggle.is-open::after {
	transform: translateY(-50%) rotate(180deg);
}

.notice_frame {
	display: none;
	border: 1px solid #C8C8C8;
	background-color: var(--white);
	padding: 30px 20px;
}

.notice_container {
	display: flex;
	flex-direction: column;
	row-gap: 20px;
}

.notice_lead {
	font-size: 16px;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 0.2em;
	text-align: center;
}

.notice_list {
}

.notice_item {
	font-size: 12px;
	line-height: 1.7;
}
.notice_item::before {
	content: "※";
}

@media (min-width:751px){
	.notice {
		row-gap: 30px;
	}
	.notice_frame {
		padding: 40px 30px;
	}
	.notice_container {
		row-gap: 25px;
	}
	.notice_lead {
		font-size: 18px;
	}
}


/*
info
*/
.info {
	margin-top: 30px;
	padding-inline: 20px;
}

.info_inner {
	padding: 24px 28px 34px;
	border: 1px solid var(--brown);
	background-color: var(--white);
}

.info_title {
	display: flex;
	justify-content: center;
	align-items: center;
	column-gap: 10px;
	font-size: 16px;
	font-weight: bold;
	line-height: 1;
	white-space: nowrap;
	color: var(--brown);
}
.info_title::before, .info_title::after {
	content: "";
	width: 63px;
	height: 15px;
	background-image: url(../img/shape-diamond_group.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}
.info_title.goods_infoTitle::before, .info_title.goods_infoTitle::after {
	content: "";
	width: 79px;
	height: 15px;
	background-image: url(../img/shape-diamond_group-goods.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.info_container {
	margin-top: 32px;
	display: flex;
	flex-direction: column;
	row-gap: 28px;
}

.info_content {
}

.info_lead {
	display: flex;
	align-items: center;
	column-gap: 5px;
	font-size: 14px;
	font-weight: bold;
	line-height: 1;
	white-space: nowrap;
	color: var(--brown);
}
.info_lead::after {
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background-color: var(--brown);
}

.info_main {
	margin-top: 15px;
	font-size: 16px;
	line-height: 1.5;
}

.info_link {
	margin-top: 12px;
	display: flex;
	width: fit-content;
	font-size: 12px;
	line-height: 1.5;
	color: var(--white);
	padding: 2px 30px 4px 10px;
	background-color: var(--pink);
	border-radius: 50vh;
	position: relative;
	transition: background-color 0.3s ease;
}
.info_link::before {
	content: "";
	width: 12px;
	height: 9px;
	background-image: url(../img/icon-blank.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	position: absolute;
	top: 50%;
	right: 8px;
	transform: translateY(-50%);
}

.info_note {
	margin-top: 5px;
	font-size: 12px;
	line-height: 1.5;
}

.info_linkWrap {
	display: contents;
}

@media (min-width:751px){
	.info {
		margin-top: 45px;
		max-width: 432px;
		margin-inline: auto;
		padding-inline: 26px;
	}
	.info_title {
		font-size: 18px;
		column-gap: 14px;
	}
	.info_linkWrap {
		display: flex;
		align-items: center;
		flex-wrap: wrap;
		column-gap: 6px;
		row-gap: 6px;
		margin-top: 15px;
	}
	.info_link {
		margin-top: 0;
	}
	.info_note {
		margin-top: 0;
	}
	.info_title::before, .info_title::after {
		content: "";
		width: 95px;
		height: 15px;
		background-image: url(../img/shape-diamond_group-pc.svg);
		background-size: auto;
		background-position: center right;
	}
	.info_title::after {
		background-position: center left;
	}
	.info_title.goods_infoTitle::before, .info_title.goods_infoTitle::after {
		content: "";
		width: 109px;
		height: 15px;
		background-image: url(../img/shape-diamond_group-goods-pc.svg);
		background-size: auto;
		background-position: center right;
	}
	.info_title.goods_infoTitle::after {
		background-position: center left;
	}
}

.info + .note {
	margin-top: 15px;
}

@media (min-width:751px){
	.info + .note {
		margin-top: 20px;
	}
}


/*
spot
*/
.spot {
	margin-top: 40px;
}

.spot_inner {
	width: 100%;
	max-width: 432px;
	margin-inline: auto;
	padding-inline: 20px;
	overflow: hidden;
}

.spot_toggle {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 18px;
	font-weight: bold;
	line-height: 1;
	text-align: left;
	color: var(--brown);
	padding: 16px 20px 16px 12px;
	background-color: var(--white);
	border: 1px solid var(--brown);
	position: relative;
}
.spot_toggle::before {
	content: "";
	width: 34px;
	height: 34px;
	background-color: var(--beige);
	border: 1px solid var(--brown);
	border-radius: 50%;
	position: absolute;
	top: 50%;
	right: 22px;
	transform: translateY(-50%);
	transition: background-color 0.3s ease;
}

.spot_toggle > span {
	width: 100%;
	position: relative;
}
.spot_toggle > span::before,
.spot_toggle > span::after {
	content: "";
	width: 15px;
	height: 1px;
	background-color: var(--brown);
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	transform-origin: center;
	transition: transform 0.3s ease;
}
.spot_toggle > span::before {
	right: 12px;
}
.spot_toggle > span::after {
	right: 12px;
	transform: translateY(-50%) rotate(90deg);
	transition: transform 0.15s ease;
}
.spot_toggle.is-open > span::after {
	transform: translateY(-50%) rotate(180deg);
}

.spot_container {
	display: none;
}

.spot_container .note {
	padding: 0;
}

.spot_map {
	position: relative;
}

.spot_mapBg {
	display: flex;
}

.spot_mapIcon {
}

.spot_mapItem {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	display: flex;
	justify-content: center;
	align-items: center;
	width: calc(70 / 300 * 100%);
	height: calc(70 / 300 * 100%);
	position: absolute;
}
.spot_mapItem:nth-child(2) {
	top: calc(165 / 300 * 100%);
	left: calc(172 / 300 * 100%);
}
.spot_mapItem:nth-child(1) {
	top: calc(161 / 300 * 100%);
	left: calc(50 / 300 * 100%);
}
.spot_mapItem:nth-child(3) {
	top: calc(66 / 300 * 100%);
	left: calc(195 / 300 * 100%);
}
.spot_mapItem:nth-child(4) {
	top: calc(8 / 300 * 100%);
	left: calc(89 / 300 * 100%);
}

.spot_mapItem.is-active img.--active {
	opacity: 1;
}

.spot_mapItem img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	position: absolute;
	transition: opacity 0.2s ease;
}
.spot_mapItem img.--active {
	opacity: 0;
}

.spot_list {
	width: 100%;
	max-width: calc(270 * var(--vw));
	margin-top: 20px;
	margin-inline: auto;
}

.spot_slide {
}

.spot_slide.splide {
}

.spot_slide .splide__arrow {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 45px;
	height: 45px;
	background-color: var(--beige);
	border: 1px solid var(--brown);
	border-radius: 50%;
	position: absolute;
	top: 205px;
	transition: background-color 0.3s ease;
}
.spot_slide .splide__arrow--prev {
	left: -20px;
}
.spot_slide .splide__arrow--prev img {
	transform: rotate(180deg);
}
.spot_slide .splide__arrow--next {
	right: -20px;
}
.spot_slide .splide__arrow img {
	width: 17px;
}

.spot_slide .splide__track {
	overflow: visible;
}

.spot_slide .splide__list {
}

.spot_slide .splide__slide {
	min-width: 0;
}

.spot_image {
	display: flex;
	width: 100%;
	max-width: 200px;
	aspect-ratio: 1 / 1;
	margin-inline: auto;
}

.spot_wrap {
	height: calc(100% - 70px);
	margin-top: -130px;
	background-color: var(--white);
	box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
}

.spot_content {
	display: flex;
	flex-direction: column;
	row-gap: 13px;
	padding: 143px 20px 35px;
}

.spot_name {
	font-size: 22px;
	font-weight: bold;
	line-height: 1.3;
	text-align: center;
	color: var(--brown-dark);
}

.spot_lead {
	font-size: 14px;
	line-height: 1.5;
}

.spot_info {
	display: flex;
	flex-direction: column;
	row-gap: 8px;
}

.spot_infoItem {
	display: grid;
	grid-template-columns: 64px 1fr;
}
.spot_infoItem p {
	font-size: 12px;
	font-weight: bold;
	line-height: 1.7;
	text-align: left;
	white-space: normal;
	word-wrap: break-word;
	overflow-wrap: break-word;
}
.spot_infoItem p span {
	display: block;
	font-weight: 400;
}

.spot_note {
	font-size: 12px;
	line-height: 1.4;
}

@media(min-width:751px){
	.spot {
		margin-top: 40px;
	}
	.spot_inner {
		padding-inline: 12px;
	}

	.spot_toggle::before {
		width: 42px;
		height: 42px;
	}
	.spot_toggle > span::before,
	.spot_toggle > span::after {
		content: "";
		width: 18px;
	}
	.spot_toggle > span::before {
		right: 15px;
	}
	.spot_toggle > span::after {
		right: 15px;
	}

	.spot_mapItem {
		width: calc(90 / 408 * 100%);
		height: calc(90 / 430 * 100%);
	}
	.spot_mapItem:nth-child(2) {
		top: calc(239 / 430 * 100%);
		left: calc(246 / 408 * 100%);
	}
	.spot_mapItem:nth-child(1) {
		top: calc(228 / 430 * 100%);
		left: calc(69 / 408 * 100%);
	}
	.spot_mapItem:nth-child(3) {
		top: calc(99 / 430 * 100%);
		left: calc(277 / 408 * 100%);
	}
	.spot_mapItem:nth-child(4) {
		top: calc(12 / 430 * 100%);
		left: calc(129 / 408 * 100%);
	}

	.spot_list {
		width: calc(350 / 410 * 100%);
		max-width: calc(350 * var(--vw))
	}
	.spot_image {
		width: 80%;
		max-width: 230px;
	}
	.spot_wrap {
		margin-top: -160px;
	}
	.spot_content {
		padding: 176px 40px 35px;
	}
	.spot_infoItem p {
		font-size: 14px;
	}
	.spot_slide .splide__arrow {
		top: 250px;
	}
}



/*
modal
*/
.modal {
	margin-top: 40px;
	padding-inline: 20px;
}

.modal_open {
	padding: 0;
  border: none;
  outline: none;
  font: inherit;
  color: inherit;
  background: none;
	position: relative;
	/* cursor: pointer; */
	width: 100%;
	overflow: hidden;
	pointer-events: none;
}

.modal_thumb {
	display: flex;
	width: 100%;
	overflow: hidden;
}
.modal_thumb img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: transform 0.3s ease;
}

.modal_icon {
	width: 30px;
	position: absolute;
	left: 18px;
	bottom: 24px;
	z-index: 1;
}

.modal_container {
	opacity: 0;
	visibility: hidden;
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;;
	height: 100vh;
	background: rgba(255, 255, 255, 0.5);
	backdrop-filter: blur(15px);
	-webkit-backdrop-filter: blur(15px);
	z-index: 1000;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}
.modal_container.is-visible {
	opacity: 1;
	visibility: visible;
}
html:has(.modal_container.is-visible) {
	overflow: hidden;
}

.modal_content {
	height: calc(100vh - 80px - 56px);
	width: 100%;
	max-width: 370px;
	overflow-y: scroll;
	padding-block: 80px 56px;
	margin-inline: auto;
}

.modal_close {
	padding: 0;
  border: none;
  outline: none;
  font: inherit;
  color: inherit;
  background: none;
	width: 36px;
	cursor: pointer;
	position: fixed;
	top: 20px;
	right: 20px;
	z-index: 10;
}

.modal_image {
}

@media (min-width:751px){
	.modal {
		margin-top: 54px;
		max-width: 432px;
		margin-inline: auto;
		padding-inline: 26px;
	}
	.modal_icon {
		width: 40px;
	}
	.modal_container {
		backdrop-filter: blur(30px);
	}
	.modal_content {
		max-width: 680px;
		padding-top: 60px;
	}
	.modal_close {
		width: 42px;
		top: 30px;
		right: 30px;
	}
}




/*
drama
*/
.drama {
	--primary-color: #FB6085;
}

.drama_heading {
	position: relative;
	z-index: 1;
}

.drama_chara01 {
	width: 100%;
	max-width: 146.5px;
	position: absolute;
	top: 110px;
	left: -44px;
	z-index: 1;
}

.drama_chara02 {
	width: 100%;
	max-width: 144px;
	position: absolute;
	top: 128px;
	right: -40px;
	z-index: 1;
}

.drama_decoSakura {
	position: relative;
	z-index: 0;
}
.drama_decoSakura::before {
	/* content: "";
	width: calc(100vw + 56px);
	max-width: 458px;
	height: 298px;
	background-image: url(../img/bg-sakura.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: left top;
	position: absolute;
	top: -45px;
	left: -20px;
	z-index: -1;
	pointer-events: none; */
}
.drama_decoSakura .section_headingBg {
	width: calc(100vw + 56px);
	max-width: 458px;
	height: 298px;
	position: absolute;
	top: -45px;
	left: -20px;
	z-index: -1;
	pointer-events: none;
}

@media(min-width:751px){
	.section#drama {
		margin-top: unset;
	}

	.drama_chara01 {
		width: calc(210 / 458 * 100%);
		max-width: 210px;
		top: 220px;
		left: -105px;
	}

	.drama_chara02 {
		width: calc(230 / 458 * 100%);
		max-width: 230px;
		top: 232px;
		right: -130px;
	}

	.drama_decoSakura::before {
		display: none;
	}
	.drama_decoSakura .section_headingBg {
		display: none;
	}
}


/*
present
*/
.present {
	--primary-color: #417ADD;
}
.present::before {
	background-image: url(../img/present-frame_top.svg);
}

.present_heading .section_titleImg {
	max-width: 293px;
}

.present_info {
	bottom: calc(32 * var(--vw));
}

.present_imageWrapper {
	margin-top: 40px;
}

.present_chara01 {
	width: 151px;
	position: absolute;
	right: -29px;
	top: -102px;
	z-index: 1;
}

@media(min-width:560px){
	.present_chara01 {
		right: -20px;
		top: -68px;
	}
}

@media(min-width:751px){
	.present_info {
		bottom: min(75px, 11.5%);
	}
	.present_chara01 {
		width: calc(205.6 / 458 * 100%);
		max-width: 205.6px;
		right: -120px;
		top: -264px;
	}
	.present_heading .section_titleImg {
		max-width: 370px;
	}
}



/*
stamp-rally
*/
.stamp-rally {
	--primary-color: #63C288;
}
.stamp-rally::before {
	background-image: url(../img/stamp-rally-frame_top.svg);
}

.stamp-rally_imageWrapper {
	margin-top: 36px;
}

.stamp-rally_chara01 {
	width: 200px;
	position: absolute;
	left: -68px;
	top: -80px;
	z-index: 1;
}

.stamp-rally_heading .section_titleImg {
	max-width: 299px;
}

@media(min-width:560px){
	.stamp-rally_chara01 {
		left: -30px;
		top: -58px;
	}
}

@media (min-width:751px){
	.stamp-rally_chara01 {
		width: calc(274.4 / 458 * 100%);
		max-width: 274.4px;
		left: -168px;
		top: -172px;
	}
	.stamp-rally_heading .section_titleImg {
		max-width: 406px;
	}
}


/*
goods
*/
.goods {
	--primary-color: #9479D3;
}
.goods::before {
	background-image: url(../img/goods-frame_top.svg);
}

.goods_imageWrapper {
	margin-top: 36px;
}

.goods_chara01 {
	width: 186px;
	position: absolute;
	left: -78px;
	top: -208px;
	z-index: 1;
}

.goods_heading .section_titleImg {
	max-width: 180px;
}

.goods_info {
	margin-top: 25px;
}

.goods_infoLabel {
	font-size: 14px;
	line-height: 1.6;
	text-align: center;
}

.goods_infoLink {
	width: fit-content;
	margin-top: 6px;
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	column-gap: 8px;
}
.goods_infoLink::after {
	content: "";
	display: block;
	width: 12px;
	height: 9px;
	background-image: url(../img/icon-blank-black.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}
.goods_infoLink span {
	font-size: 14px;
	font-weight: bold;
	position: relative;
}
.goods_infoLink span::after {
	content: "";
	width: 100%;
	height: 1px;
	background-color: var(--black);
	position: absolute;
	bottom: 0;
	left: 0;
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.goods_buttonCta {
	margin-top: 16px;
}

.goods_infoNote {
	margin-top: 24px;
	font-size: 12px;
	line-height: 1.2;
	text-align: center;
}

@media (min-width:751px){
	.goods_chara01 {
		width: calc(288 / 458 * 100%);
		max-width: 288px;
		left: unset;
		right: -155px;
		top: -256px;
	}
	.goods_infoNote {
		margin-top: 12px;
	}
	.goods_heading .section_titleImg {
		max-width: 241px;
	}
}



/*
copyright
*/
.copyright {
	margin-top: 10px;
	padding-bottom: 50px;
	font-size: 12px;
	line-height: 1;
	color: var(--brown-dark);
}



/*
fuwafuwa
*/
.fuwafuwa {
	animation: float 3s ease-in-out infinite;
}

@keyframes float {
	0%, 100% {
		transform: translateY(-2%);
	}
	50% {
		transform: translateY(2%);
	}
}


/*************
footer
*************/
.oshitabi_btn--block {
	position: relative;
	padding: 24px 10px;
}

.oshitabi_btn {
	display: block;
	border: 4px solid #333;
	background-color: #FFF;
	max-width: 315px;
	margin: 0 auto;
	padding: 20px;
	text-align: center;
	font-size: 20px;
	font-weight: bold;
	border-radius: 20px;
	position: relative;
	transition: all .5s;
}

.oshitabi_btn::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 30px;
	height: 12px;
	width: 12px;
	border-top: 3px solid #333;
	border-right: 3px solid #333;
	transform: translateY(-50%) rotate(45deg);
}
@media(min-width:751px){

	.oshitabi_btn--block {
		border-top: 1px solid #000000;
		padding: 32px 10px;
	}

	a.oshitabi_btn:hover {
		opacity: 1;
	}

	.oshitabi_btn:hover {
		background-color: #333;
		color: #fff;
	}

	.oshitabi_btn:hover::after {
		border-top: 3px solid #fff;
		border-right: 3px solid #fff;
		transform: translateY(-50%) rotate(45deg);
	}
}


.footer_container {
	font-family: 'Noto Sans JP', "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Arial", "Verdana", "sans-serif";
	font-size: 16px;
	color: #000;
	line-height: 1.5;
	font-weight: 400;
	position: relative;
	z-index: 100;
	background-color: #FFF;
	padding-top: 1px;
}

/*************
メディアクエリ
*************/
@media(min-width:751px){
	.sp {
		display: none;
	}

	.buttonCta {
		width: 90%;
		max-width: 340px;
		height: 86px;
		margin-bottom: 10px;
		background-image: url(../img/shape-button-bg-pc.png);
		background-size: 100% 100%;
	}
	.buttonCta:not(.--disable):hover {
		background-image: url(../img/shape-button-bg-hover.png);
	}
	.buttonCta:not(.--disable):hover::before {
		top: 0;
		left: 0;
	}
	.buttonCta:not(.--disable):hover .buttonCta_label {
		color: var(--pink);
	}
	.buttonCta:not(.--disable):hover .buttonCta_label::before,
	.buttonCta:not(.--disable):hover .buttonCta_label::after {
		background-image: url(../img/shape-square-pink.svg);
	}
	.buttonCta::before {
		right: -5px;
		bottom: -10px;
	}
	.notice_toggle:hover {
		background-color: #4b2923;
	}
	.info_link:hover {
		background-color: var(--black);
	}
	.spot_toggle:hover::before {
		background-color: #f6e8d3;
	}
	.spot_mapItem:hover img.--active {
		opacity: 1;
	}
	.spot_slide .splide__arrow:hover {
		background-color: #f6e8d3;
	}
	.modal_open:hover .modal_thumb img {
		/* transform: scale(1.05); */
	}
	.goods_infoLink:hover span::after {
		transform: translateY(1px);
		opacity: 0;
	}
	.sidebar_frame:hover {
		background-color: rgba(255, 219, 220, 0.5);
	}
	.sidebar_frame[href="#present"]:hover {
		background-color: rgba(205, 238, 255, 0.5);
	}
	.sidebar_frame[href="#stamp-rally"]:hover {
		background-color: rgba(191, 243, 203, 0.5);
	}
	.sidebar_frame[href="#goods"]:hover {
		background-color: rgba(232, 217, 255, 0.5);
	}
}
@media(max-width:750px){
	.pc {
		display: none;
	}

}
	
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}
