@charset "UTF-8";

/* --------- FMT --------- */
.info_wrap,
.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;
}
img {
	display: block;
	width: 100%;
}
a:hover img {
	opacity: 1;
}
.content_wrap {
	color: #231816;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 16px;
	line-height: 1.5;
	font-weight: 400;
	margin-top: 66px;
	width: 100%;
	position: relative;
	z-index: 0;
	*,*::before,*::after {
		box-sizing: border-box;
	}
}
.content-inner {
	width: 92%;
	max-width: 500px;
	margin-inline: auto;
}
figure {
	margin: 0 auto;
    width: 100%;
}
:root {
	--font-saira: Saira,"Noto Sans JP",sans-serif;
	--font-barlow: Barlow,"Noto Sans JP",sans-serif;
}
.txt-link{
	color: #A3135E;
	text-decoration: underline;
	transition: .3s;
	&:active {
		opacity: .5;
	}
}
.red-txt {
	color: #A3135E;
}
.note-list__items {
	font-size: 12px;
	line-height: 1.67;
	letter-spacing: .05em;
}

/* ------ 汎用 ------ */

/* --- sec-ttl --- */
.sec-ttl {
	width: 92%;
	max-width: 520px;
	translate: 0 -15px;
	margin: 0 auto 9px;
}
/* --- sec-date --- */
.sec-date {
	background: #535B76;
	padding-block: 2px;
	max-width: 600px;
	margin: 0 auto 24px;
	color: #fff;
	font-weight: 600;
	line-height: 1.5625;
	letter-spacing: .025em;
	text-align: center;
}
/* --- sec-txt --- */
.sec-txt {
	color: #353E63;
	font-weight: 700;
	line-height: 1.875;
	text-align: center;
}
/* --- sec-step-box --- */
.sec-step-box {
	background: #fff;
	padding: 32px 16px 41px;
	margin: 0 14px 16px;
	position: relative;
	&::before,&::after {
		content: "";
		display: block;
		width: 100%;
		height: 16px;
		background: url(../img/bg_common.png) no-repeat center/cover;
		position: absolute;
		left: 0;
	}
	&::before {
		top: 0;
	}
	&::after {
		bottom: 0;
	}
}
.sec-step-box__ttl {
	margin-bottom: 12px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.43;
	text-align: center;
}
.sec-step-box__list {
	display: grid;
	gap: 8px;
}
.sec-step-box__list__items__inner {
	display: grid;
	grid-template-columns: 52px 1fr;
	gap: 8px;
	align-items: start;
}
.sec-step-box__list__ttl {
	background: #E7BB71;
	padding-top: 1px;
	border-radius: 10vh;
	font-size: 12px;
	font-weight: 600;
	font-family: var(--font-saira);
	line-height: 1.58;
	text-align: center;
}
.sec-step-box__list__dtl {
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
}
.sec-step-box__note-list {
	margin-top: 8px;
}
/* --- sec-info-box --- */
.sec-info-box {
	padding: 15px;
	border: 1px solid #353E63;
}
.sec-info-box__row:not(:last-child) {
	padding-bottom: 8px;
	border-bottom: 1px solid #535B76;
	margin-bottom: 10px;
}
.sec-info-box__ttl {
	width: fit-content;
	padding: 1px 8px 2px 9px;
	background: #535B76;
	color: #fff;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.4;
	margin-bottom: 8px;
}
.sec-info-box__dtl__txt {
	font-size: 15px;
	font-weight: 500;
	line-height: 1.33;
}
.sec-info-box__dtl__txt--note {
	font-size: 12px;
	font-weight: 500;
	line-height: 1.67;
}
/* --- splide --- */
.sec--stamp__splide__slide {
	padding-bottom: 60px;
	position: relative;
}
.splide__num {
	font-size: 18px;
	position: absolute;
	bottom: 13px;
	pointer-events: none;
	left: 50%;
	translate: -50%;
}
.splide__num__index,
.splide__num__total {
	margin-inline: 7px;
}
.splide__arrows {
	display: flex;
	justify-content: space-between;
	width: 190px;
	position: absolute;
	bottom: 0;
	left: 50%;
	translate: -50%;
}
.splide__arrow {
	display: block;
	border: 0;
	border-radius: 10px;
	background: #535B76;
	width: 48px;
	height: 48px;
	position: relative;
	transition: .3s;
	cursor: pointer;
	&::after {
		content: "";
		display: block;
		width: 6px;
		height: 9px;
		background: url(../img/ico_swiper-arrow.png) no-repeat center/cover;
		position: absolute;
		top: 50%;
		left: 50%;
		translate: -50% -50%;
	}
	&:active {
		opacity: .5;
	}
	svg {
		display: none;
	}
}
.splide__arrow--next {
	scale: -1 1;
}

/* --- modal --- */
.modal-wrapper {
	backdrop-filter: blur(15px);
	background: rgb(255 255 255/.7);
	position: fixed;
	inset: 0;
	z-index: 1000;
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
	user-select: none;
	transition: .3s;
	&.shown {
		visibility: visible;
		opacity: 1;
		pointer-events: auto;
		user-select: auto;
	}
}
.modal-bg {
	position: absolute;
	inset: 0;
	cursor: pointer;
}
.modal-content {
	width: 95%;
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
}
.modal-close-btn {
	width: 28px;
	height: 28px;
	position: absolute;
	top: -44px;
	right: 0;
	border: 0;
	background: 0;
	padding: 0;
	transition: .3s;
	cursor: pointer;
	&::before,&::after {
		content: "";
		display: block;
		width: 39px;
		height: 1px;
		background: #231816;
		position: absolute;
		top: 50%;
		left: 50%;
		translate: -50% -50%;
	}
	&::before {
		rotate: 45deg;
	}
	&::after {
		rotate: -45deg;
	}
	&:active {
		opacity: .5;
	}
}
/* --- CTA --- */
.cta-wrapper {
	max-width: 600px;
	margin-inline: auto;
}
.cta-btn {
	display: block;
	margin-bottom: 16px;
}
/* --- acc --- */
.acc__btn {
	display: block;
	width: fit-content;
	margin: 32px auto 0;
	padding: 3px 36px 5px 16px;
	background: #535B76;
	color: #fff;
	font-weight: 700;
	list-style: none;
	border-radius: 10vh;
	position: relative;
	cursor: pointer;
	transition: opacity .3s;
	&:active {
		opacity: .5;
	}
}
.acc__btn::-webkit-details-marker {
	display:none;
}
.acc__ico {
	display: block;
	width: 20px;
	height: 20px;
	position: absolute;
	top: 6px;
	right: 8px;
	background: #fff;
	border-radius: 50%;
	&::before,&::after {
		content: "";
		display: block;
		width: 10px;
		height: 2px;
		background: #535B76;
		position: absolute;
		top: 50%;
		left: 50%;
		translate: -50% -50%;
	}
	&::after {
		rotate: 90deg;
		transition: rotate .3s;
	}
}
.acc[open] .acc__ico::after {
	rotate: 0deg;
}
.acc__content {
	border: 1px solid #333333;
	border-radius: 8px;
	margin-top: 15px;
    transition: .6s ease-in-out;
	height: 0;
	overflow: hidden;
}
.acc__content__inner {
	padding: 16px 15px;
}

/* --- comingsoon,finish --- */
.comingsoon,.finish {
	position: relative;
	pointer-events: none;
	&::after {
		content: "Coming Soon";
		display: grid;
		place-content: center;
		background: rgb(255 255 255/.8);
		backdrop-filter: saturate(0);
		color: #535B76;
		font-size: 8vw;
		font-weight: 700;
		font-family: var(--font-saira);
		text-align: center;
		line-height: 1.2;
		position: absolute;
		inset: 0;
	}
}
.finish-txt {
	border: 2px solid #ff0000;
	background: #fff;
	padding-block: 8px;
	color: #ff0000;
	font-size: 18px;
	font-weight: 700;
	text-align: center;
	margin-block: 16px;
}
.finish::after {
	content: "終了しました";
	border: 2px solid #ff0000;
	color: #ff0000;
	font-size: 18px;
	width: 90%;
	height: 90%;
	left: 50%;
	top: 50%;
	translate: -50% -50%;
}

/* --- js-animate --- */
.js-animate[data-animate="fade-up"] {
	opacity: 0;
	translate: 0 40px;
	transition: opacity cubic-bezier(.2,.7,.25,1) 3s,
				translate cubic-bezier(.2,.7,.25,1) 1.5s;
}
.js-animate--active[data-animate="fade-up"] {
	opacity: 1;
	translate: 0;
}
.js-animate [data-animate="tapestry"] {
	clip-path: inset(0 0 100% 0);
	transition: clip-path cubic-bezier(.2,.7,.25,1) 1.5s;
}
.js-animate--active [data-animate="tapestry"] {
	clip-path: inset(0);
}


/* --------- mv --------- */
.mv__date {
	background: #353E63;
	padding-block: 4px;
	color: #FFF;
	font-size: 17px;
	font-weight: 600;
	font-family: var(--font-saira);
	line-height: 1.53;
	letter-spacing: .025em;
	text-align: center;
}

/* --------- sec--toc --------- */
.sec--toc {
	padding-block: 40px 48px;
	background: url(../img/bg_toc_sp.png) no-repeat center top/cover;
}
.sec--toc__ttl {
	width: fit-content;
	margin: 0 auto 16px;
	color: #354065;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.44;
	letter-spacing: .025em;
	&::before,&::after {
		content: "";
		display: inline-block;
		width: 18px;
		height: 1.5px;
		background: #354065;
		rotate: -110deg;
		vertical-align: 6px;
	}
	&::before {
		margin-left: 8px;
	}
	&::after {
		margin-right: 8px;
		rotate: 110deg;

	}
}
.sec--toc__list {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 8px 3px;
}
.sec--toc__list--top {
	margin-bottom: 16px;
}
.sec--toc__list__link {
	display: block;
	transition: .3s;
	&:active {
		opacity: .5;
	}
}
.sec--toc__list__items--2col {
	grid-area: 2/1/3/3;
}

/* --------- sec--movie --------- */
.sec--movie {
	background: linear-gradient(to bottom,#FFFFFF,#D2E3E6);
	padding-bottom: 57px;
}
.sec--movie__txt {
	margin-bottom: 6px;
}
.sec--movie__img {
	position: relative;
	max-width: 500px;
	margin-inline: auto;
}
.sec--movie__img__bg {
	position: absolute;
	width: 105.87%;
	max-width: none;
	top: -3.14%;
	left: -10.67%;
	z-index: 0;
}
.sec--movie__img--front {
	width: 89.28%;
	margin-inline: auto;
	position: relative;
	z-index: 1;
}
.sec--moive__step-box {
	padding-bottom: 38px;
}

/* --------- sec--goods --------- */
.sec--goods {
	background: linear-gradient(to bottom,#FFFFFF,#D2E3E6);
	padding-bottom: 56px;
}
.sec--goods__txt {
	margin-bottom: 24px;
}
.sec--goods__img-ttl {
	width: fit-content;
	padding: 5px 11px 7px;
	border: 1px solid #535B76;
	margin: 0 auto 9px;
	color: #353E63;
	font-size: 18px;
	font-weight: 700;
}
.sec--goods__img-ttl__small-txt {
	font-size: 14px;
}
.sec--goods__img {
	margin-bottom: 8px;
	background: #fff;
	padding-block: 14px;
}
.sec--goods__img--front {
	width: 92%;
	margin-inline: auto;
}
.sec--goods__img--front {
	margin-bottom: -1px;
}
.sec--goods__img-note {
	font-size: 12px;
	text-align: right;
	margin-bottom: 23px;
}
.sec--goods__step-box {
	padding-bottom: 33px;
}
.sec--goods__info-box {
	margin-bottom: 8px;
}

/* --------- sec--stamp --------- */
.sec--stamp {
	background: linear-gradient(to bottom,#FFFFFF,#D2E3E6);
	padding-bottom: 57px;
}
.sec--stamp__col-mask {
	overflow: hidden;
}
.sec--stamp__col {
	max-width: 375px;
	position: relative;
	padding:  4.93% 14px 13px 0;
}
.sec--stamp__col__txt {
	width: 61.03%;
	margin-left: auto;
	background: #E1EFF2;
	padding: 12px 9px;
	border: 1px solid #CCE4EA;
	border-radius: 8px;
	color: #353E63;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.73;
	text-align: center;
	position: relative;
	z-index: 1;
}
.sec--stamp__col__img {
	width: 42.03%;
	position: absolute;
	bottom: 0;
	left: 2.32%;
	z-index: 2;
}
.sec--stamp__col__img--bg {
	width: 121.74%;
	max-width: none;
	position: absolute;
	top: 0;
	left: -19.13%;
	z-index: 0;
}
.sec--stamp__col__img--deco {
	width:  30.43%;
	position: absolute;
	bottom: 1.58%;
	right: -15.07%;
	z-index: 2;
}
.sec--stamp__acc {
	margin-bottom: 24px;
}
.sec--stamp__acc__btn {
	background: #D0A155;
	width: 100%;
	padding: 6px 0 7px;
	margin: 0;
	font-size: 14px;
	text-align: center;
	border-radius: 4px;
}
.sec--stamp__acc__btn__ico {
	width: 16px;
	height: 16px;
	position: relative;
	display: inline-block;
	top: 0;
	left: 0;
	margin-left: 8px;
	vertical-align: -2px;
	&::before,&::after {
		background: #D0A155;
		width: 8px;
		height: 2px;
		border-radius: 10vh;
	}
}
.sec--stamp__acc__content {
	border: 0;
	border-radius: 0;
}
.sec--stamp__acc__content__inner {
	padding: 0 14px;
}
.sec--stamp__acc__txt {
	width: fit-content;
	margin: 0 auto 27px;
	padding-inline: 37px 30px;
	color: #353E63;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
	position: relative;
	&::before,&::after {
		content: "";
		display: inline-block;
		width: 26px;
		height: 29px;
		background: url(../img/bg_stamp03.png) no-repeat center/cover;
		position: absolute;
		bottom: 0;
	}
	&::before {
		left: 0;
	}
	&::after {
		right: 0;
		scale: -1 1;
	}
}
.sec--stamp__acc__col {
	display: grid;
	grid-template-columns: 100%;
	gap: 17px 20px;
}
.sec--stamp__acc__map-wrapper {
	position: relative;
	margin-bottom: 9px;
}
.sec--stamp__acc__map-btn {
	display: grid;
	width: 11.36%;
	height: auto;
	aspect-ratio: 1/1;
	place-content: center;
	border: 3px solid #353E63;
	border-radius: 50%;
	background: #fff;
	color: #353E63;
	font-size: 22px;
	font-weight: 700;
	font-family: var(--font-barlow);
	line-height: 1;
	position: absolute;
	transition: .3s;
	cursor: pointer;
	&:hover,
	&.is-active {
		background: #353E63;
		color: #fff;
	}
}
.sec--stamp__acc__map-btn--01 {
	left: 32.81%;
	bottom: 16.82%;
}
.sec--stamp__acc__map-btn--02 {
	left: 18.3%;
	bottom: 7.48%;
}
.sec--stamp__acc__map-btn--03 {
	right: 16.4%;
	top: 23.36%;
}
.sec--stamp__acc__map-btn--04 {
	right: 11.04%;
	top: 3.12%;
}
.sec--stamp__acc__map-btn--05 {
	right: 41.32%;
	top: 6.85%;
}
.sec--stamp__acc__map-btn--06 {
	left: 10.41%;
	top: 26.48%;
}
.sec--stamp__splide__slide {
	height: auto;
}
.sec--stamp__splide__slide__inner {
	height: 100%;
	padding: 19px 14px;
	background: #fff;
	border: 1px solid #C6D9DD;
	border-radius: 16px;
}
.sec--stamp__splide__slide__img {
	margin-bottom: 16px;
}
.sec--stamp__splide__slide__img-ttl {
	color: #353E63;
	font-size: 18px;
	font-weight: 700;
	text-align: center;
	margin-bottom: 12px;
}
.sec--stamp__splide__slide__txt {
	font-size: 12px;
	font-weight: 500;
	line-height: 1.5;
	margin-bottom: 8px;
}
.sec--stamp__splide__slide__info {
	display: grid;
	gap: 8px;
}
.sec--stamp__splide__slide__info__row {
	display: flex;
}
.sec--stamp__splide__slide__info__ttl,
.sec--stamp__splide__slide__info__dtl {
	font-size: 12px;
	font-weight: 500;
	line-height: 1.5;
}
.sec--stamp__splide__slide__info__dtl {
	flex: 1;
}

/* --------- sec--photo --------- */
.sec--photo {
	background: linear-gradient(to bottom,#FFFFFF,#D2E3E6);
	padding-bottom: 56px;
}
.sec--photo__txt {
	margin-bottom: 32px;
}
.sec--photo__splide-container {
	padding-block: 26px 30px;
	margin-bottom: 24px;
}
.sec--photo__splide-container__deco {
	width: 68px;
	height: 68px;
	position: absolute;
}
.sec--photo__splide-container__deco--left-top {
	top: 0;
	left: 0;
}
.sec--photo__splide-container__deco--right-top {
	top: 0;
	right: 0;
	scale: -1 1;
}
.sec--photo__splide-container__deco--left-bottom {
	left: 0;
	bottom: 0;
	scale: 1 -1;
}
.sec--photo__splide-container__deco--right-bottom {
	right: 0;
	bottom: 0;
	scale: -1 -1;
}
.sec--photo__splide-container__ttl {
	width: fit-content;
	margin: 0 auto 18px;
	padding-inline: 14px 4px;
	background: linear-gradient(to top,#EBCD9A 14px,transparent 14px);
	color: #353E63;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.5;

}
.sec--photo__splide {
	margin: 0 14px 8px;
	padding-bottom: 64px;
}
.sec--photo__splide__slide__inner {
	scale: .719;
	transition: scale .2s;
}
.sec--photo__splide__slide.is-active .sec--photo__splide__slide__inner {
	scale: 1;
}
.sec--photo__splide-pagination {
	bottom: 68px;
}
.sec--photo__splide-button-wrapper {
	bottom: 55px;
}
.sec--photo__splide-container__note {
	text-align: center;
	font-size: 12px;
	line-height: 1.42;
}

/* --------- sec--original --------- */
.sec--original {
	background: url(../img/bg_original05_sp.png) no-repeat center/cover;
	padding-bottom: 55px;
}
.sec--original__date {
	background: #C6995B;
}
.sec--original__txt {
	color: #844F20;
	margin: 0;
	position: relative;
	z-index: 1;
}
.sec--original__note-list {
	margin-top: 8px;
	text-align: center;
}
.sec--original__img {
	position: relative;
	overflow: hidden;
}
.sec--original__img--01 {
	margin-block: -13.07% -10.67%;
	padding-block: 21.33% 16.27%;
}
.sec--original__img--02 {
	margin-top: -5.33%;
}
.sec--original__img__bg {
	width: 63.2%;
	position: absolute;
	z-index: 0;
}
.sec--original__img--top__bg--01 {
	top: 0;
	left: -22.67%;
}
.sec--original__img--top__bg--02 {
	bottom: 0;
	right: -19.47%;
}
.sec--original__img--bottom__bg--01 {
	bottom: 17.63%;
	left: -26.13%;
}
.sec--original__img__front {
	position: relative;
	z-index: 1;
}
.sec--original__img__front--01 {
	width: 85%;
	margin-inline: auto;
	transition: .3s;
	&:active {
		opacity: .5;
	}
}
.sec--original__img__front--02 {
	margin-bottom: -8.53%;
}
.sec--original__img__note {
	font-size: 12px;
	text-align: right;
	margin: 0 calc(4% + 14px) 16px;
}
.sec--original__info-box,
.sec--original__info-box__row {
	border-color: #956133;
}
.sec--original__info-box {
	margin-bottom: 24px;
}
.sec--original__info-box__ttl {
	background: #956133;
}
.sec--original__contact {
	background: #364868;
	padding-block: 8px 9px;
	color: #fff;
	text-align: center;
}
.sec--original__contact__txt {
	font-weight: 500;
	line-height: 1.4375;
	margin-bottom: 5px;
}
.sec--original__contact__txt--note {
	font-size: 12px;
	font-weight: 500;
}
.sec-info-box__dtl__btn-wrapper {
	margin-top: 16px;
	text-align: center
}
.sec-info-box__dtl__btn {
	display: block;
	background: #767676;
	color: #fff;
	font-size: 18px;
	font-weight: 500;
	padding: 16px;
	border-radius: 8px;
	margin-bottom: 8px;
	pointer-events: none;
	user-select: none;
}
.sec-info-box__dtl__btn-note {
	font-size: 12px;
}

/* ------ sec--partner ------ */
.sec--partner {
	padding-top: 36px;
}
.sec--partner__logo-col {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0 auto 24px;
    justify-content: center;
}
.partner_logo img {
	display: block;
}
.sec--partner_logo--nijisanji {
	max-width: 170px;
}
.sec--partner_logo--jrc {
    max-width: 34px;
	margin-right: 32px;
}
.sec--partner__message {
	color: #090909;
    font-weight: 700;
    font-size: 15px;
    line-height: 1.7;
	text-align: center;
}
.sec--partner__message__note {
	margin-top: 48px;
	color: #090909;
    font-size: 12px;
}

/* --------- btn-totop --------- */
.btn-totop {
	display: block;
    width: 88px;
    height: 88px;
    background: #535B76;
    border: 2px solid #fff;
    border-radius: 50%;
    box-shadow: 0 3px 10px rgb(0 0 0 / .16);
    position: fixed;
    right: 15px;
    bottom: 15px;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    text-align: center;
    padding-top: 31px;
    position: fixed;
	z-index: 1000;
    opacity: 0;
    pointer-events: none;
    transition: .3s;
	&::before {
	content: "";
        display: block;
        width: 12px;
        height: 12px;
        border-top: 2px solid #fff;
        border-left: 2px solid #fff;
        rotate: 45deg;
        position: absolute;
        top: 18px;
        left: 50%;
        translate: -50% 0;
	}
	&.shown {
		opacity: 1;
		pointer-events: auto;
	}
	&.shown:active {
		opacity: .7;
	}
}

/* --------- footer --------- */
/* ------ info_wrap ------ */
.info_wrap {
	margin: 0 auto;
	padding: 8px 40px 20px;
	position: relative;
	background-color: #FFF;
}
.oshitabi_btn {
	display: block;
	border: 4px solid #000;
	background: #FFF;
	max-width: 740px;
	margin: 32px auto 0;
	font-size: 18px;
	font-weight: 700;
	font-family: "Zen Kaku Gothic New", sans-serif;
	text-align: center;
	border-radius: 10px;
	padding: 10px 30px 10px 5px;
	position: relative;
	transition: all .3s;
	&::after {
		content: "";
		position: absolute;
		top: 50%;
		right: 30px;
		height: 12px;
		width: 12px;
		border-top: 3px solid #000;
		border-right: 3px solid #000;
		translate: 0 -50%;
		rotate: 45deg;
		transition: all .3s;
	}
	&:active {
		background: #364868;
		color: #FFF;
		border-color: #364868;
		&::after {
			border-color: #fff;
		}
	}
}
.credit {
	text-align: center;
	margin-top: 16px;
	font-size: 12px;
}
.footer_container {
	position: relative;
	z-index: 100;
	background-color: #FFF;
	padding-top: 1px;
}

/* --------- mediaquery --------- */
@media(min-width:751px){
	.sp {
		display: none;
	}
	.pc {
		display: block;
	}
	/* --------- FMT --------- */
	.content_wrap {
		margin-top: 90px;
	}
	.txt-link:hover {
		opacity: .5;
	}

	/* ------ 汎用 ------ */
	/* --- sec-ttl --- */
	.sec-ttl {
		translate: 0 -22px;
		margin-bottom: 2px;
	}
	/* --- sec-date --- */
	.sec-date {
		margin-bottom: 34px;
		font-size: 20px;
		line-height: 1.6;
	}
	/* --- sec-txt --- */
	.sec-txt {
		font-size: 18px;
		line-height: 1.89;
	}
	/* --- sec-step-box --- */
	.sec-step-box__ttl {
		margin-bottom: 16px;
		font-size: 16px;
	}
	.sec-step-box__list__items__inner {
		grid-template-columns: 72px 1fr;
	}
	.sec-step-box__list__ttl {
		font-size: 14px;
	}
	.sec-step-box__list__dtl {
		font-size: 16px;
	}
	/* --- sec-info-box --- */
	.sec-info-box__ttl {
		font-size: 16px;
	}
	.sec-info-box__dtl__txt {
		font-size: 16px;
		font-weight: 500;
		line-height: 1.33;
	}
	/* --- splide --- */
	.splide__arrow:hover {
		opacity: .5;
	}
	/* --- modal --- */
	.modal-close-btn:hover {
		opacity: .5;
	}
	.modal-content {
		max-width: 750px;
	}
	/* --- CTA --- */
	.qr-wrapper {
		display: grid;
		grid-template-columns: 1fr 100px;
		gap: 16px;
		background: url(../img/bg_cta_pc.png) no-repeat center/cover;
		border-radius: 8px;
		padding: 16px;
		margin-bottom: 16px;
	}
	.qr-ttl {
		background: #fff;
		border-radius: 4px;
		text-align: center;
		font-size: 18px;
		font-weight: 500;
		padding-block: 6px;
		margin-bottom: 6px;
	}
	.qr-txt {
		color: #fff;
		font-size: 15px;
		line-height: 1.5;
	}
	.qr-img {
		border-radius: 4px;
		overflow: hidden ;
	}
	/* --- acc --- */
	.acc__btn:hover {
		opacity: .5;
	}
	/* --- comingsoon,finish --- */
	.comingsoon::after {
		font-size: 18px;
	}
	.finish::after {
		white-space: pre;
		content: "終了\Aしました";
	}

	/* --------- mv --------- */
	.mv {
		background: url(../img/bg_mv_pc01.png) no-repeat left calc(50% + 11px) top calc(50% - 25px)/1485px auto,
					linear-gradient(to bottom,#FFFFFF,#CFE0E4);
		overflow: hidden;
	}
	.mv__inner {
		width: 85.29%;
		max-width: 1165px;
		margin-inline: auto;
		translate: -24px;
		position: relative;
	}
	.mv__date {
		width: 100%;
		margin-inline: auto;
	}
	.mv__deco {
		width: 756px;
		position: absolute;
		bottom: 29px;
		right: -168px;
	}

	/* --------- sec--toc --------- */
	.sec--toc {
		padding-block: 36px 57px;
		background: url(../img/bg_toc_pc.png) no-repeat center top/cover;
		.content-inner {
			max-width: none;
		}
	}
	.sec--toc__list {
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 0 13px;
	}
	.sec--toc__list--top {
		margin-bottom: 37px;
	}
	.sec--toc__list__items {
		width: 220px;
	}
	.sec--toc__list__link:hover {
		opacity: .5;
	}

	/* --------- sec--movie --------- */
	.sec--movie__txt {
		margin-bottom: 24px;
	}

	/* --------- sec--goods --------- */
	.sec--goods__img {
		margin: 0 -50px 12px;
		width: 600px;
		padding-block: 24px;
	}
	.sec--goods__img--front {
		width: 500px;
	}



	/* --------- sec--stamp --------- */
	.sec--stamp__col {
		padding-top: 40px;
	}
	.sec--stamp__acc__content {
		margin-inline: -100px;
	}
	.sec--stamp__acc__col {
		grid-template-columns: repeat(2,calc(50% - 10px));
	}

	/* --------- sec--original --------- */
	.sec--original {
		background: url(..//img/bg_original05_pc.png) no-repeat center top/cover;
	}
	.sec--original__note-list {
		margin-bottom: 31px;
	}
	.sec--original__txt--02 {
		margin-block: 20px;
	}
	.sec--original__img {
		overflow: visible;
		max-width: 500px;
		margin: 0 auto;
		padding: 0;
	}
	.sec--original__img--top__bg--01 {
		top: -80px;
		left: -112px;
	}
	.sec--original__img--top__bg--02 {
		bottom: -60px;
		right: -140px;
	}
	.sec--original__img--bottom__bg--01 {
		bottom: 84px;
		left: -130px;
	}
	.sec--original__img__front--01 {
		width: 100%;
		cursor: pointer;
		&:hover {
			opacity: .5;
		}
	}

	/* --------- btn-totop --------- */
	.btn-totop.shown:hover {
		opacity: .7;
	}

	/* --------- footer --------- */
	.info_wrap {
		margin: 0 auto;
		padding: 8px 20px 100px;
	}
	.oshitabi_btn {
		padding: 15px;
		font-size: 20px;
		&:hover {
			background: var(--primary-color);
			color: #FFF;
			border-color: var(--primary-color);
			&::after {
				border-color: #fff;
			}
		}
	}
}

@media(max-width:750px){
	.sp {
		display: block;
	}
	.pc {
		display: none;
	}
}