@charset "UTF-8";

:root {
	--font-base: 'Inter', "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", serif;

	--color-black: #000;
	--color-brown01: #301D17;
	--color-orange01: #FF8C00;
	--color-orange02: #EA5504;
	--color-deep_blue01: #113258;

	--header-height: min(11.8vh, 11.8rem);
}

*, *::before, *::after {
	box-sizing: border-box;
}

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
}

html {
	font-size: clamp(6.2px, 0.73vw, 10px);
	overflow: auto; /* 20241216追加*/
	/* overflow: inherit !important; */
}

body {
	position: relative;
	width: 100%;
	height: auto;
	padding-top: var(--header-height);
	background: #fff;
	font-family: var(--font-base);
	color: var(--color-black);
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0;
	overflow-x: hidden;
	overflow-x: clip;
	-webkit-overflow-scrolling: touch;
}

h2 {
	font-size: 6rem;
	font-weight: 700;
	line-height: 1.3;
}

h3 {
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.44;
}

p {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 2;
}

ul, ol, li {
	list-style: none;
}

button {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

a, button {
	text-decoration: none;
	transition: opacity .25s ease, color .32s ease, background-color .32s ease;
	color: inherit;
}

a:hover, button:hover {
	opacity: 0.5;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

caption, th, td {
	text-align: left;
	font-weight: normal;
	vertical-align: middle;
}

strong {
	font-weight: 700;
}

.heading {
	position: relative;
	line-height: 1;
	z-index: 110;
}


/***   スクロールバー   ***/
::-webkit-scrollbar {
	width: 1.5rem;
}

::-webkit-scrollbar-track {
	background: #fff;
}

::-webkit-scrollbar-thumb {
	background: var(--color-deep_blue01);
}

@media screen and (max-width: 768px) {
	::-webkit-scrollbar {
		width: 1.1rem;
	}
}

/***   selection 調整   ***/
/*
::-moz-selection {
	background-color: transparent;
}

::selection {
	background-color: transparent;
}


/*****************

   common   

******************/
#body_inner {
	width: 100%;
	height: auto;
}

.contents_wrapper {
	position: relative;
	max-width: 144rem;
	width: 96%;
	padding: 0;
	margin-right: auto;
	margin-left: auto;
}


.attention_text {
	display: inline-block;
	font-size: 1.6rem;
	line-height: 1.7;
}

.color-red {
	color: var(--color-red01);
}



@media screen and (min-width:769px) {
	.sp_only {
		display: none !important;
	}
}

@media screen and (max-width:769px) {
	.pc_only {
		display: none !important;
	}

	:root {
		--header-height: 6.2rem;
	}

	html {
		font-size: 7px;
		font-size: clamp(7px, 2.5vw, 24px);
	}

	body {
		font-size: 1.5rem;
		line-height: 1.86;
	}

	#body_inner {
		width: 100%;
		min-width: 0px;
		top: -1px;
	}

	p {
		font-size: 1.32rem;
		line-height: 1.86;
	}

	img {
		width: 100%;
	}


	.contents_wrapper {
		width: 89.6%;
	}

	.attention_text {
		text-align: left;
		font-size: 1.18rem;
		line-height: 1.8;
	}
}



/*****************
   parts
******************/
/******   heading_block01   *****/
.heading_block01 {
	display: flex;
	align-content: center;
	justify-content: center;
	flex-direction: column;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin: 0 auto 6.29rem;
	row-gap: 2.5rem;
}

.heading_block01__icon {
	margin: 0 auto;
	width: 8.2rem;
}

.heading_block01__heading {
	width: 100%;
	max-width: 96rem;
}

@media screen and (min-width: 768px) {}

@media screen and (max-width: 768px) {
	.heading_block01 {
		margin-bottom: 3.1rem;
		row-gap: 1rem;
	}

	.heading_block01__icon {
		width: 6.2rem;
	}
}


/******   btn   *****/
.btn01 {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 44rem;
	border-radius: 10rem;
	color: #fff;
	padding: 1.5rem 0.55rem 1.6rem 1.6rem;
	margin: 3.2rem auto 0;
	-webkit-filter: drop-shadow(0 0.4rem 0.4rem rgba(0, 0, 0, 0.25));
	filter: drop-shadow(0 0.4rem 0.4rem rgba(0, 0, 0, 0.25));
	font-size: 2rem;
	transition: box-shadow 0.05s linear, background 0.1s ease, color 0.1s ease;
	cursor: pointer;
}

.btn01::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color-orange02);
	-webkit-mask-image: url(../../assets/img/design/btn01_bg_desing@2x.png);
	mask-image: url(../../assets/img/design/btn01_bg_desing@2x.png);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
	z-index: -1;
}

.btn01--more::before {
	background: var(--color-deep_blue01);
}

.btn01:hover {
	opacity: 1;
	-webkit-filter: brightness(1.3);
	filter: brightness(1.3);
}

.btn01 img {
	width: 80%;
	-o-object-fit: contain;
	object-fit: contain;
}

.btn_text_x {
	height: 3.7rem;
}

.btn_text_more {
	height: 4.5rem;
}

@media screen and (min-width:769.02px) {
	.btn01 {
		min-height: 8.7rem;
	}
}

@media screen and (max-width:769px) {
	.btn01 {
		min-height: 5.5rem;
		max-width: 28rem;
	}

	.btn_text_x {
		height: 2.5rem;
	}

	.btn_text_more {
		height: 3.2rem;
	}
}


/*****************

   header

******************/
#header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: var(--header-height);
	background: var(--color-deep_blue01);
	pointer-events: none;
	z-index: 9995;
}

.header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 89.6%;
	height: var(--header-height);
	margin-left: auto;
	margin-right: auto;
	pointer-events: all;
}

.header__logo {
	position: relative;
	width: 41.7rem;
	height: 100%;
	padding-top: 1.32%;
	padding-bottom: 0.62%;
}

.header__logo img {
	width: 100%;
	height: 100%;
	-o-object-fit: contain;
	object-fit: contain;
	-o-object-position: left;
	object-position: left;
}

.header__contents {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	-moz-column-gap: 3.1rem;
	column-gap: 3.1rem;
}


#header .hamburger_btn--open {
	--hamburger-size: min(8.2rem, 89%);
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--hamburger-size);
	height: var(--hamburger-size);
	background: transparent;
	z-index: 9992;
	cursor: pointer;
}

#header .hamburger_btn--open img {
	width: 100%;
	height: 100%;
	-o-object-fit: contain;
	object-fit: contain;
	-o-object-position: center;
	object-position: center;
}

#header .hamburger_btn--open:hover {
	transform: scale(1.11);
}


.hamburger_nav {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	max-width: 100%;
	max-height: 96vh;
	overflow: auto;
	padding: 19rem 0 11.7rem;
	margin-left: 0;
	margin-right: 0;
	background: var(--color-orange01);
	background-image: url(../img/design/hamburger_menu_bg.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: bottom;
	box-shadow: -1px 1px 1.7rem rgba(0, 0, 0, 0.17);
	transform: translateY(-25%);
	transition: transform 0.56s 0s ease, opacity 0.32s 0s ease;
	pointer-events: none;
	z-index: 9996;
	opacity: 0;
}

.active-hamburger .hamburger_nav {
	transform: translateX(0);
	opacity: 1;
	pointer-events: auto;
}


.hamburger_link_list {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	-moz-column-gap: 6.9rem;
	column-gap: 6.9rem;
	row-gap: 6.2rem;
	width: 92.8%;
	max-width: 170rem;
	margin: 0 auto 10rem;
}

.hamburger-active .hamburger_link_list {
	transition: opacity 0.62s 0.37s ease;
	opacity: 1;
}

.hamburger_link_list__item a {
	display: block;
	margin: 0;
	color: #fff;
	font-size: 1.8rem;
	line-height: 1.1;
	white-space: nowrap;
}


#header .hamburger_btn--close {
	--hamburger-size: 8.7rem;
	position: absolute;
	top: 3.9rem;
	right: 10rem;
	cursor: pointer;
	width: var(--hamburger-size);
	height: auto;
	background: transparent;
	z-index: 9992;
}

#header .hamburger_btn--close:hover {
	-webkit-filter: brightness(1.8);
	filter: brightness(1.8);
}

@media screen and (min-width:769px) {
	.hamburger_link_list__item a img {
		width: 100%;
		font-size: clamp(6.2px, 0.62vw, 10px);
	}

	.hamburger_link_list {
		justify-content: space-evenly;
	}

	.hamburger_link_list__item[data-link="news"] a img {
		width: 47em;
	}

	.hamburger_link_list__item[data-link="goods"] a img {
		width: 27.7em;
	}

	.hamburger_link_list__item[data-link="special_contents"] a img {
		width: 37em;
	}

	.hamburger_link_list__item[data-link="manga"] a img {
		width: 39.2em;
	}

	.hamburger_link_list__item[data-link="official_x"] a img {
		width: 24.4em;
	}

}

@media screen and (max-width:769px) {
	#header .hamburger_btn--open {
		--hamburger-size: 4rem;
	}

	.header__inner {
		width: 87%;
	}

	.header__logo {
		position: relative;
		width: 20rem;
	}


	.hamburger_nav {
		padding: 11rem 0 6.2rem;
		background-image: url(../img/design/hamburger_menu_bg-sp@2x.png);
	}

	.hamburger_link_list {
		flex-direction: column;
		row-gap: 3.2rem;
		margin-bottom: 5rem;
	}

	.hamburger_link_list__item a {
		width: 100%;
	}

	.hamburger_link_list__item[data-link="news"] a img {
		width: 28rem;
	}

	.hamburger_link_list__item[data-link="goods"] a img {
		width: 16.2rem;
	}

	.hamburger_link_list__item[data-link="special_contents"] a img {
		width: 32.8rem;
	}

	.hamburger_link_list__item[data-link="manga"] a img {
		width: 21.4rem;
	}

	.hamburger_link_list__item[data-link="official_x"] a img {
		width: 14rem;
	}

	#header .hamburger_btn--close {
		--hamburger-size: 5.5rem;
		top: 2rem;
		right: 2.8rem;
	}
}




/*****************

   footer

******************/
.footer {
	position: relative;
	width: 100%;
	height: auto;
	padding: 3.1rem 0 3.2rem;
	background: var(--color-deep_blue01);
	color: #fff;
	text-align: center;
	z-index: 5000;
}

.footer__logo_list {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	-moz-column-gap: 4rem;
	column-gap: 4rem;
	margin: 1rem 0 -4rem;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
}

.footer__text {
	margin-bottom: 0.2em;
	font-size: 1.8rem;
	font-weight: 500;
}

.footer .copyright {
	font-size: 1.8rem;
	line-height: 1.5;
}

@media screen and (max-width:1320px) {
	.footer__logo_list {
		margin: 1rem auto 2.8rem;
	}
}


@media screen and (max-width:769px) {
	.footer {
		padding-bottom: 6.2rem;
	}

	body.home .footer {
		padding-bottom: 13.2rem;
	}


	.footer__logo_list {
		width: 87%;
	}

	.footer__text {
		font-size: 1.25rem;
	}

	.footer .copyright {
		font-size: 1.25rem;
	}

}





/*******************

   animation  

********************/
/*****   swiper   *****/
.swiper {
	opacity: 0;
	transition: opacity 0.47s ease-in-out;
}

@media screen and (max-width: 768px) {
	.swiper {}
}

.swiper.swiper-initialized {
	opacity: 1;
}

/*****   アコーディオン   *****/
.js-acc_switch {
	position: relative;
	cursor: pointer;
}

.js-acc_block {
	display: none;
	will-change: height;
}

.js-acc_wrapper.active .js-acc_switch::after {
	transform: translateY(-45%) rotate(-540deg);
}

.js-acc_wrapper .acc_open_text,
.js-acc_wrapper.active .acc_close_text {
	display: block;
}

.js-acc_wrapper.active .acc_open_text,
.js-acc_wrapper .acc_close_text {
	display: none;
}

@media screen and (max-width:769px) {
	.acc_switch::after {
		right: 1.4rem;
	}

	.js-acc_switch::after {
		--size: 1.7rem;
	}
}




/***************

   main

****************/
.main_section {
	position: relative;
	background: #FFF;
}


/*****************

   .home-fv

******************/
.home-fv {
	position: relative;
	padding-top: 0.1px;
	text-align: center;
}

.home-fv__bg img {
	position: absolute;
	top: -20rem;
	left: 0;
	width: 100%;
	height: auto;
	min-height: 100%;
	z-index: -1;
	-o-object-fit: cover;
	object-fit: cover;
	opacity: 0.30;
}

.home-fv__wrapper {}

.home-fv__tit {
	margin: 3.9rem auto 0;
}

.home-fv__tit img {
	max-width: 81%;
}


.home-fv__logo {
	position: relative;
	margin-top: 13rem;
	margin-bottom: 6.2rem;
}

.home-fv__logo img {
	position: relative;
	transform: translateY(7.7%);
	width: min(86.2rem, 41.7vw);
}

.home-fv__logo::before {
	content: "";
	position: absolute;
	top: -10rem;
	left: 50%;
	transform: translateX(-50%);
	width: 106%;
	height: 47rem;
	background-repeat: repeat-x;
	background-size: contain;
	background-position: top;
}

.home-fv__character01 img {
	width: min(54vw, 101.4rem);
	margin-bottom: 7rem;
	pointer-events: none;
}

.home-fv__lead {
	display: block;
	width: 100%;
	/* padding: 3.4rem 1rem 4.7rem; */
	padding: 4.7rem 1rem 4.7rem;
	background: #224966;
}

.home-fv__lead img {
	width: min(54vw, 80rem);
}
p.home-fv__lead a:hover {
	opacity: 1;
}

/* .home-fv__lead img {
	width: min(55vw, 104rem);
} */


@media screen and (min-width: 768px) {
	.home-fv__logo::before {
		background-image: url(../img/design/home-fv__noren.png);
	}
}

@media screen and (max-width: 768px) {
	.home-fv__bg img {
		top: 0;
	}

	.home-fv__tit {
		margin: 1.8rem auto 0;
	}

	.home-fv__tit img {
		max-width: 81%;
	}

	.home-fv__logo {
		margin-top: 4.17rem;
		margin-bottom: 3.2rem;
	}

	.home-fv__logo img {
		width: 26.2rem;
	}

	.home-fv__logo::before {
		top: -2.5rem;
		width: 48.7rem;
		height: auto;
		aspect-ratio: 487/139;
		background-image: url(../img/design/home-fv__noren-sp@2x.png);
	}

	.home-fv__character01 img {
		transform: translateX(1.1%);
		width: 37rem;
		margin-bottom: 2.28rem;
	}

	.home-fv__lead {
		display: block;
		width: 100%;
		padding: 2.5rem 3.2rem 2.8rem;
	}

	.home-fv__lead img {
		width: 100%;
	}

}



.section_group01 {
	position: relative;
}

.section_group01::before {
	content: "";
	position: absolute;
	top: -54rem;
	left: 0;
	width: 100%;
	height: calc(100% + 54rem);
	background: #FFF1DF;
	background-image: url(../../assets/img/design/bg_design02.png);
	background-repeat: repeat;
	z-index: -1;
}

@media screen and (max-width: 768px) {
	.section_group01::before {
		top: -28rem;
		height: calc(100% + 28rem);
	}
}


/*****************

   .news

******************/
.news__contents_block {}

.news__contents_block a {}

.news__date {
	color: var(--color-orange02);
	font-size: 2rem;
	font-weight: 500;
	text-align: right;
	line-height: 1.1;
}

.news__tit {
	color: var(--color-brown01);
	margin-bottom: 0.92em;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.25;
}

.news__text {
	color: var(--color-brown01);
	margin-bottom: 0.4em;
	font-size: 1.8rem;
	font-weight: 600;
	letter-spacing: 0.15em;
}


/***   single   ***/
.news_single {
	position: relative;
	padding: 10.6rem 0 13.9rem;
	background: #FFF1E3;
	background-image: url(../img/design/news__bg.png);
	background-repeat: repeat;
}

.news_single .contents_wrapper {
	max-width: 70rem;
}

.news_single__img_block {
	margin-bottom: 1.52805rem;
	width: 100%;
	background-image: url(../img/design/news__thumbnail_bg.png);
	background-repeat: no-repeat;
	background-size: 100% 100%;
}

.news_single__img_block img {
	width: 100%;
	height: auto;
	padding: 1.18%;
	border-radius: 0.5rem;
	-o-object-fit: contain;
	   object-fit: contain;
}


.news__contents_block h2,
.news__contents_block h3 {
	font-size: 2.2rem;
	margin-top: 1em;
	margin-bottom: 0.62em;
}

.news__contents_block p {
	margin-top: 1.25em;
	margin-bottom: 0.55em;
	color: var(--color-brown01);
	font-size: 1.8rem;
	font-weight: 600;
	letter-spacing: 0.055em;
	line-height: 1.73;
}

.news__contents_block>img {
	display: block;
	margin: 2.25rem 0 2.5rem;
}

.news__contents_block a:not(.btn01) {
	color: var(--color-orange02);
	transition: 0s;
	text-decoration: underline;
}

.news__contents_block a:not(.btn01):hover {
	opacity: 0.76;
	text-decoration: none;
	-webkit-filter: brightness(1.06);
	filter: brightness(1.06);
}

.news_single__return_btn {
	margin-top: 7.3rem;
}

.news_single .news__date {
	margin-bottom: 4rem;
}


/***   archive   ***/
.news_archive {
	position: relative;
	padding: 11rem 0 13.2rem;
	z-index: 1;
}

.news_archive .contents_wrapper {
	max-width: 134rem;
}

.news_archive .deco01 {
	position: absolute;
	top: -5.5rem;
	left: 0;
	transform: translateX(-155%);
	width: 11.8rem;
	z-index: -1;
	pointer-events: none;
}

.news_archive .deco02 {
	position: absolute;
	top: 66rem;
	right: 0;
	transform: translateX(62%);
	width: 62rem;
	opacity: 0.7;
	-webkit-filter: blur(1px);
	filter: blur(1px);
	z-index: -1;
	pointer-events: none;
}

.news_archive__heading {
	margin-bottom: 3.2rem;
}

.news_archive__heading .heading_block01__icon {
	width: 18rem;
}


.news_list_wrapper {
	position: relative;
	padding-top: 5.6rem;
}


.news_list_wrapper.js-more_contents {
	position: relative;
	max-height: 77.7rem;
	margin-bottom: 1rem;
	overflow: hidden;
}

.news_list_wrapper.js-more_contents.opening {
	max-height: 99999px;
}

.js-more_contents__switch_wrapper {
	display: none;
}
.news_list_wrapper.js-more_contents .js-more_contents__switch_wrapper {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	display: block;
}

.news_list_wrapper.js-more_contents.opening .js-more_contents__switch_wrapper {
	display: none;
}

.news_list_wrapper.js-more_contents .js-more_contents__switch_wrapper::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-55%);
	width: 102%;
	height: calc(100% + 17rem);
	background-image: linear-gradient(180deg, rgba(254, 240, 226, 0.00) 0, rgba(255, 241, 223, 1.00) 25%);
	background-position: center center;
	z-index: -1;
}

.news_list_wrapper.js-more_contents .js-more_contents__switch {
	margin: 2rem auto;
}



.news_list {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-wrap: wrap;
	width: 100%;
	-moz-column-gap: 2.8rem;
	column-gap: 2.8rem;
	row-gap: 5rem;
}

.news_list__item {
	position: relative;
	width: calc((100% - 2.8rem * 2) / 3 - 1px);
}

.news_list__item:first-of-type::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	background-image: url(../img/text/news__en_tit.svg);
	background-repeat: no-repeat;
	background-size: contain;
	width: 26rem;
	height: auto;
	aspect-ratio: 263/64;
	transform: translateY(-87.6%);
	z-index: -1;
}

.news_list__item a {
	transition: opacity 0.1s;
}

.news_list__item a:hover {
	opacity: 0.82;
}

.news_list__item_tit {
	margin-bottom: 0.5em;
	font-size: 2.5rem;
	letter-spacing: -0.02em;
}

.news_list__item_text {
	position: relative;
	max-height: 6.9em;
	line-height: 1.7;
	font-size: 1.66rem;
	letter-spacing: 0.07em;
	overflow: hidden;
}

.news_list__item_text::after {
	content: " ... 続きを読む";
	position: absolute;
	bottom: 0;
	right: 0;
	padding: 0.1em 0em 0.1em 2.8em;
	background: linear-gradient(90deg, rgba(254, 240, 226, 0.00) 0%, #FFF1DF 2em);
	color: var(--color-orange02);
	font-size: 1em;
	line-height: 1.7;
}

.news_list__item a:hover .news_list__item_text::after {
	text-decoration: underline;
}

.news_list__item_date {
	margin-bottom: 1.1rem;
}

.news_list__item_img_block {
	margin-bottom: 1.32rem;
	width: 100%;
	background-image: url(../img/design/news__thumbnail_bg.png);
	background-repeat: no-repeat;
	background-size: 100% 100%;
}

.news_list__item_img_block img {
	width: 100%;
	height: auto;
	padding: 1.32%;
	border-radius: 0.5rem;
	-o-object-fit: contain;
	object-fit: contain;
	border-radius: 0.9em;
}

.news_list__item a:hover .news_list__item_img_block {
	-webkit-filter: brightness(1.15);
	filter: brightness(1.15);
}


@media screen and (min-width: 768px) {}

@media screen and (max-width: 768px) {
	.news__date {
		font-size: 1.5rem;
	}

	.news__tit {
		margin-bottom: 0.87em;
		font-size: 2.0rem;
		letter-spacing: 0.01em;
	}


	/***   single   ***/
	.news_single {
		position: relative;
		padding: 4.4rem 0 5.5rem;
	}

	.news_single__img_block {
		margin-bottom: 1rem;
	}

	.news__contents_block h2,
	.news__contents_block h3 {
		font-size: 1.9rem;
	}

	.news__contents_block p {
		font-size: 1.6rem;
		letter-spacing: 0.02em;
		line-height: 1.82;
	}

	.news__contents_block>img {
		margin: 1.4rem 0 1.5rem;
	}

	.news_single__return_btn {
		margin-top: 5rem;
	}

	.news_single .news__date {
		margin-bottom: 1.8rem;
	}



	/***   archive   ***/
	.news_archive {
		padding: 4.4rem 0 4rem;
	}

	.news_archive .deco01 {
		position: absolute;
		top: -3.4rem;
		left: 0;
		transform: translateX(-5%);
		width: 4.7rem;
		pointer-events: none;
	}

	.news_archive .deco02 {
		top: 54rem;
		transform: translateX(32%);
		width: 28rem;
		opacity: 0.92;
	}

	.news_archive__heading {
		margin-bottom: 2.5rem;
	}

	.news_archive__heading .heading_block01__icon {
		width: 10.6rem;
	}

	.news_list_wrapper {
		padding-top: 0;
	}

	.news_list_wrapper.js-more_contents {
		max-height: 93.2rem;
	}

	.news_list__item:first-of-type::before {
		display: none;
	}

	.news_list {
		grid-template-columns: 1fr;
		row-gap: 1.4rem;
		width: 93.9%;
		margin-left: auto;
		margin-right: auto;
	}

	.news_list__item {
		width: 100%;
	}

	.news_list__item_img_block {
		margin-bottom: 0.87rem;
	}

	.news_list__item_date {
		margin-bottom: 0.54rem;
	}

	.news_list__item_tit {
		font-size: 1.6rem;
	}

	.news_list__item_text {
		display: none;
	}
}




/*****************

   .goods

******************/
.goods {
	position: relative;
	padding: 2rem 0 0;
	z-index: 10;
}

.goods .deco01 {
	position: absolute;
	top: -10rem;
	left: -38rem;
	z-index: -1;
	pointer-events: none;
}

.goods .deco02 {
	position: absolute;
	top: 70rem;
	left: -22rem;
	z-index: -1;
	pointer-events: none;
}

.goods .deco03 {
	position: absolute;
	top: 1rem;
	right: -31.8rem;
	z-index: -1;
	pointer-events: none;
}

.goods_sec__heading {
	margin-bottom: 3.2rem;
}

.goods .heading_block01__icon {
	width: 13.2rem;
}

.goods .en_tit {
	display: block;
	width: 41.7rem;
	margin-left: auto;
	margin-right: 8rem;
	transform: translateY(10%);
}


/* pickup */
/*
.goods__pickup_list_wrapper {
	position: relative;
	max-width: 130rem;
	margin: 0 auto;
}

.goods__pickup_list {
	display: flex;
	align-items: stretch;
	justify-content: center;
	-moz-column-gap: 1rem;
	column-gap: 1rem;
	row-gap: 3.2rem;
	width: 100%;
	margin: 0 auto 7rem;
}

.goods__pickup_list_item {
	position: relative;
	flex: 1;
	padding: 0;
	margin: 0;
}

.goods__pickup_list_item_box {
	position: relative;
	flex: 1;
	padding: 0;
	margin: 0;
	height: auto;
	border: 0.77rem solid #FFEABB;
	border-radius: 3.0rem;
	background: #fff;
	overflow: hidden;
}

.goods__pickup_list_item::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	background-image: url(../img/text/goods__item_label.svg);
	background-repeat: no-repeat;
	background-size: contain;
	width: 16rem;
	height: auto;
	aspect-ratio: 1/1;
	transform: translateX(-13%) translateY(-32%);
	z-index: 10;
}

.goods__pickup_list_item_img_block {
	text-align: center;
	background: #FFF8C3;
	padding: 0.5rem 2.5rem 0.76rem;
}

.goods__pickup_list_item_img_block img {
	width: 60rem;
	height: auto;
	aspect-ratio: 60/55;
	-o-object-fit: contain;
	object-fit: contain;
}

.goods__pickup_list_item_contents {
	padding: 2.8rem 2.9rem 3.2rem;
}

.goods__pickup_list_item_new {
	margin-bottom: 0.55rem;
	color: var(--color-orange02);
	font-size: 2.44rem;
	font-weight: 700;
	line-height: 1.1;
	text-align: left;
}

.goods__pickup_list_item_tit_block {
	display: flex;
	align-items: flex-end;
	-moz-column-gap: 0.82rem;
	column-gap: 0.82rem;
	line-height: 1;
	margin-bottom: 1.18rem;
}

.goods__pickup_list_item_tit {
	flex: 1;
	font-size: 2.28rem;
	font-weight: 700;
	line-height: 1.4;
}

.goods__pickup_list_item_tit_smaller {
	font-size: 0.87em;
}

.goods__pickup_list_item_price {
	font-size: 2.28rem;
	font-weight: 500;
	line-height: 1.38;
	letter-spacing: -0.02em;
}

.goods__pickup_list_item_text {
	font-size: 1.8rem;
	letter-spacing: 0.1em;
}

.goods__pickup_list_item_soon {
	color: #B5A695;
	font-size: 3.0rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: right;
}


/* list */
.goods__list_wrapper {
	position: relative;
	width: 100%;
	height: auto;
	padding: 8.7rem 0 6.2rem;
	background-image: url(../img/design/goods_list_bg.png);
	background-repeat: no-repeat;
	background-size: cover;
}

.goods__list_wrapper .illust01 {
	position: absolute;
	top: 0;
	left: 7rem;
	transform: translateY(-55%);
	width: 15rem;
	pointer-events: none;
}



.goods__list_tit {
	width: 32rem;
	margin: 0 auto 5.19rem;
}

.goods__list_item {
	background: #fff;
	height: auto;
	padding: 1.5rem 3.9rem 9.29rem;
	border-radius: 3.2rem;
	width: 44rem;
	margin: 0 3.2rem;
}

.goods__list_item_img_block {
	margin-top: -1rem;
	text-align: center;
}

.goods__list_item_img_block img {
	width: 30rem;
}

.goods__list_item_new {
	position: absolute;
	top: 1rem;
	left: 3.7rem;
	color: var(--color-orange02);
	font-size: 2.38rem;
	font-weight: 700;
	text-align: left;
}

.goods__list_item_tit {
	margin-bottom: 0.1em;
	font-size: 2.28rem;
	font-weight: 700;
	line-height: 1.32;
}

.goods__list_item_tit_smaller {
	font-size: 0.82em;
}

.goods__list_item_price {
	margin-bottom: 0.62rem;
	text-align: right;
	font-size: 2rem;
	font-weight: 500;
	line-height: 1.5;
}

.goods__list_item_text {
	margin-bottom: 2.5rem;
	color: var(--color-brown01);
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	line-height: 1.6;
}

.goods__list_item_soon {
	position: absolute;
	bottom: 3.9rem;
	left: 0;
	width: 100%;
	color: #B5A695;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.05em;
	text-align: center;
}

.goods__list_item_link {
	position: absolute;
	bottom: 3.47rem;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	-moz-column-gap: 0.62em;
	column-gap: 0.62em;
	width: calc(100% - 3.9rem * 2);
	padding: 1.6rem 1rem 1.7rem;
	background-image: url(../img/design/btn_border01@2x.png);
	background-repeat: no-repeat;
	background-size: 100% 100%;
	color: var(--color-orange02);
	font-size: 2.38rem;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: 0.05em;
	text-align: center;
	transition: 0s;
}

.goods__list_item_link::after {
	--size: 1.02em;
	content: "";
	position: relative;
	top: -0.025em;
	display: block;
	width: var(--size);
	height: auto;
	aspect-ratio: 1/1;
	background-image: url(../img/design/btn_arrow01.svg);
	background-repeat: no-repeat;
	background-size: contain;
	transition: transform 0.082805s linear;
}

.goods__list_item_link:hover {
	opacity: 0.62805;
	-webkit-filter: brightness(1.2805);
	        filter: brightness(1.2805);
}

.goods__list_item_link:hover::after {
	transform: translateX(0.55rem) scale(1.15);
}


.swiper_nav {
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin: 5.5rem auto 1rem;
	z-index: 100;
}

.swiper_nav .swiper-pagination {
	position: relative;
	z-index: 10;
}

.swiper_nav .swiper-pagination-bullet {
	--size: 2.5rem;
	width: var(--size);
	height: var(--size);
	margin: 0 1.38rem !important;
	background: #fff;
	opacity: 1;
}

.swiper_nav .swiper-pagination-bullet:hover {
	opacity: 0.55;
}

.swiper_nav .swiper-pagination-bullet-active {
	pointer-events: none;
	background: var(--color-orange02);
}

.swiper-button-next,
.swiper-button-prev {
	position: absolute;
	top: 50%;
	transform: translateY(-32%) translateX(-220%);
	background-image: url(../img/design/slider_arrow01.svg);
	background-repeat: no-repeat;
	background-size: contain;
	width: 4.4rem;
	height: auto;
	aspect-ratio: 41/45;
	-webkit-filter: drop-shadow(0 0.2rem 0.2rem rgba(0, 0, 0, 0.32));
	filter: drop-shadow(0 0.2rem 0.2rem rgba(0, 0, 0, 0.32));
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
	-webkit-filter: brightness(2);
	filter: brightness(2);
}

.swiper-button-next::after,
.swiper-button-prev::after {
	display: none;
}

.swiper-button-next {
	transform: translateY(-32%) rotateY(180deg) translateX(-220%);
}

.swiper-button-prev {}


@media screen and (min-width: 768px) {}

@media screen and (max-width: 768px) {
	.goods {}

	.goods__list_wrapper .illust01 {
		left: 2rem;
		transform: translateY(-45%);
		width: 8.7rem;
	}

	.goods__list_tit {
		width: 19.2rem;
		margin: 0 auto 3.47rem;
	}


	.goods .deco01 {
		top: -3.9rem;
		left: -10rem;
		width: 28rem;
	}

	.goods .deco02 {
		top: -3.4rem;
		left: auto;
		right: 0;
		width: 5rem;
	}

	.goods .deco03 {
		display: none;
	}


	.goods_sec__heading {
		margin-bottom: 1.1rem;
	}

	.goods .heading_block01__icon {
		width: 8.7rem;
	}

	.goods .en_tit {
		margin-right: 0;
		width: 22rem;
	}


	/* pickup */
	/*
	.goods__pickup_list {
		flex-direction: column;
		margin-bottom: 4rem;
	}

	.goods__pickup_list_item {}

	.goods__pickup_list_item_box {
		border: 0.55rem solid #FFEABB;
		border-radius: 1.8rem;
	}

	.goods__pickup_list_item::before {
		width: 11.1rem;
		transform: translateX(-6.2%) translateY(-28%);
	}

	.goods__pickup_list_item_img_block {
		padding: 0.15rem 2rem 0.2rem;
	}

	.goods__pickup_list_item_img_block img {
		width: 28rem;
	}

	.goods__pickup_list_item_contents {
		padding: 1.5rem 1.7rem 1.9rem;
	}

	.goods__pickup_list_item_new {
		margin-bottom: 0.47rem;
		font-size: 1.9rem;
	}

	.goods__pickup_list_item_tit_block {
		display: flex;
		align-items: stretch;
		flex-direction: column-reverse;
		margin-bottom: 1.18rem;
		margin-top: -2.76rem;
	}

	.goods__pickup_list_item_tit {
		font-size: 1.8rem;
		line-height: 1.32;
	}

	.goods__pickup_list_item_tit_smaller {
		font-size: 0.80em;
	}

	.goods__pickup_list_item_price {
		margin-bottom: 0.5rem;
		font-size: 1.8rem;
		text-align: right;
		letter-spacing: 0;
	}

	.goods__pickup_list_item_text {
		font-size: 1.38rem;
		letter-spacing: 0.04em;
	}

	.goods__pickup_list_item_soon {
		font-size: 2.0rem;
		letter-spacing: 0.028em;
		text-align: right;
	}



	/* list */
	.goods__list_item {
		width: 34.7rem;
		padding: 1.7rem 2.2rem 7.32805rem;
		margin: 0 4rem;
	}

	.goods__list_item_img_block img {
		width: 25rem;
	}

	.goods__list_item_tit {
		font-size: 1.9rem;
	}

	.goods__list_item_price {
		font-size: 1.5rem;
	}

	.goods__list_item_text {
		margin-bottom: 2rem;
		font-size: 1.5rem;
	}

	.goods__list_item_soon {
		bottom: 3.2rem;
		font-size: 2.2rem;
	}

	.goods__list_item_link {
		position: absolute;
		bottom: 3.02805rem;
		width: calc(100% - 2.2rem * 2);
		padding: 1rem 1rem 1.1rem;
		font-size: 1.76rem;
		font-weight: 700;
		line-height: 1.25;
		letter-spacing: 0.04em;
		text-align: center;
	}

	.goods__list_item_link::after {
		--size: 1.02em;
		top: -0.04em;
	}


	.swiper_nav {
		position: static;
		width: -webkit-fit-content;
		width: -moz-fit-content;
		width: fit-content;
		margin: 2.8rem auto 1rem;
		z-index: 100;
	}

	.swiper_nav .swiper-pagination-bullet {
		--size: 1.1rem;
		margin: 0 0.76rem !important;
	}

	.swiper-button-next,
	.swiper-button-prev {
		top: 37.6%;
		transform: translateY(-50%) translateX(-18%);
		background-image: url(../img/design/slider_arrow01.svg);
		width: 3.7rem;
	}

	.swiper-button-next::after,
	.swiper-button-prev::after {
		display: none;
	}

	.swiper-button-next {
		transform: translateY(-50%) rotateY(180deg) translateX(-18%);
	}
}


/*****************

   .link_sec01

******************/
.link_sec01 {
	position: relative;
	padding: 8.76rem 0 13.2805rem;
	background: transparent;
	z-index: 10;
}

.link_sec01::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url(../img/design/bg_design01.png);
	background-repeat: no-repeat;
	background-position: top;
	background-size: cover;
	transform: rotate(180deg);
	z-index: -1;
}

.link_sec01 .deco01 {
	position: absolute;
	top: 15rem;
	left: 0;
	width: 59rem;
	transform: translateX(-69%);
	pointer-events: none;
	z-index: -1;
}

.link_sec01 .deco02 {
	position: absolute;
	top: 7.3rem;
	right: 0;
	width: 51rem;
	transform: translateX(73%);
	pointer-events: none;
	z-index: -1;
}

.link_sec01 a {
	transition: 0s;
}

.link_sec01 a:hover {
	opacity: 0.96;
	-webkit-filter: brightness(1.1);
	        filter: brightness(1.1);
}

.link_sec01__heading {
	margin: 0 auto 2.805rem;
	text-align: center;
	line-height: 1.1;
}

.link_sec01__img_block {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	max-width: 92rem;
	margin: 0 auto 2.5rem;
}

.link_sec01__img_block img {
	-webkit-filter: drop-shadow(0.32805rem 0.44rem 0.73rem rgba(105, 76, 52, 0.62));
	        filter: drop-shadow(0.32805rem 0.44rem 0.73rem rgba(105, 76, 52, 0.62));
}

.link_sec01__img_block a:hover img {
	-webkit-filter: none;
	        filter: none;
}


.link_sec01__preparing_block {
	position: relative;
	transform: translateX(5%);
	width: 69rem;
	margin: 0 auto 2.5rem;
}

@media screen and (min-width: 768px) {}

@media screen and (max-width: 768px) {
	.link_sec01 {
		padding: 2.82805rem 0 5.5rem;
	}

	.link_sec01 .deco01 {
		top: 5.4rem;
		width: 15.5rem;
		transform: translateX(-50%);
	}

	.link_sec01 .deco02 {
		top: 19.2rem;
		width: 15rem;
		transform: translateX(38%);
	}

	.link_sec01__heading {
		width: 28.05rem;
		margin-bottom: 0.82805rem;
	}

	.link_sec01__preparing_block {
		max-width: 87%;
		transform: translateX(0);
	}
}


/*****************

   .special_contents

******************/
.special_contents {
	position: relative;
}

.special_contents .contents_wrapper {
	position: relative;
	padding: 11rem 0 17rem;
	max-width: 144rem;
}

.special_contents .deco01 {
	position: absolute;
	top: 80rem;
	left: -34.7rem;
	z-index: -1;
	pointer-events: none;
}

.special_contents .deco02 {
	position: absolute;
	top: 102rem;
	right: -35.4rem;
	z-index: -1;
	pointer-events: none;
}

.special_contents .en_tit {
	position: absolute;
	top: 1.1rem;
	left: 0;
	width: 73rem;
	z-index: 10;
}

.special_contents .heading_block01__icon {
	width: 18rem;
}

.special_contents__tit {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	max-width: 62rem;
	margin: 0 auto 1.7rem;
	line-height: 1.1;
}

.special_contents__text {
	margin-bottom: 6.2rem;
	text-align: center;
	font-size: 2.2rem;
	font-weight: 600;
}

.special_contents__text a {
	color: var(--color-orange01);
	text-decoration: underline;
	transition: 0s;
}

.special_contents__text a:hover {
	text-decoration: none;
}


.special_contents__introduction_lead {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	max-width: 62rem;
	margin: 0 25rem -7.6rem auto;
}

.special_contents__introduction_block {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	-moz-column-gap: 2rem;
	column-gap: 2rem;
	width: 100%;
	margin: 0 auto;
}

.special_contents__introduction_inner {}

.special_contents__introduction_img_block {
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin-bottom: 1rem;
}

.special_contents__introduction_img_block::before {
	content: "";
	position: absolute;
	background-image: url(../img/design/movie__light_deco.svg);
	background-repeat: no-repeat;
	background-size: contain;
	width: 62rem;
	height: auto;
	aspect-ratio: 374/455;
	z-index: -1;
}

.special_contents__introduction_inner:nth-of-type(1) .special_contents__introduction_img_block {
	left: 7rem;
	width: 62rem;
}

.special_contents__introduction_inner:nth-of-type(1) .special_contents__introduction_img_block::before {
	top: -39rem;
	left: -15rem;
	width: 69rem;
}

.special_contents__introduction_inner:nth-of-type(2) .special_contents__introduction_img_block {
	right: -11.8rem;
	width: 34rem;
}

.special_contents__introduction_inner:nth-of-type(2) .special_contents__introduction_img_block::before {
	top: -31.5rem;
	right: -22.8rem;
	width: 56rem;
	transform: rotateY(180deg);
}

.special_contents__introduction_contents {
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
	-moz-column-gap: 2.5rem;
	column-gap: 2.5rem;
}

.special_contents__introduction_inner:nth-of-type(2) .special_contents__introduction_contents {
	flex-direction: row-reverse;
}

.special_contents__introduction_name {
	max-width: min(20vw, 35rem);
	margin-bottom: 0.82rem;
	font-weight: 700;
}

.special_contents__introduction_text {
	font-size: min(1.5vw, 1.8rem);
	font-weight: 600;
}

.special_contents__introduction_inner:nth-of-type(2) .special_contents__introduction_text {
	text-align: right;
}


@media screen and (min-width: 768px) {}

@media screen and (max-width: 768px) {
	.special_contents .contents_wrapper {
		padding: 6.2rem 0 9.6rem;
	}

	.special_contents .deco01 {
		top: 73rem;
		left: -8.7rem;
		width: 22rem;
	}

	.special_contents .deco02 {
		top: 115rem;
		right: -15rem;
		width: 24.4rem;
	}

	.special_contents .heading_block01__icon {
		width: 8.7rem;
	}

	.special_contents__tit {
		width: 23.8rem;
		margin-bottom: 1.3rem;
	}

	.special_contents__text {
		margin-bottom: 3.0rem;
		font-size: 1.7rem;
		letter-spacing: 0.05em;
	}



	.special_contents__introduction_lead {
		width: 100%;
		max-width: 62rem;
		margin: 0 auto 4.7rem;
	}

	.special_contents__introduction_block {
		display: block;
	}

	.special_contents__introduction_inner:nth-of-type(1) {
		margin-bottom: 3.2rem;
	}

	.special_contents__introduction_img_block::before {
		content: "";
		position: absolute;
		background-image: url(../img/design/movie__light_deco.svg);
		background-repeat: no-repeat;
		background-size: contain;
		width: 37rem;
		height: auto;
		aspect-ratio: 374/455;
		z-index: -1;
	}

	.special_contents__introduction_inner:nth-of-type(1) .special_contents__introduction_img_block {
		left: 0.2rem;
		width: 35rem;
		margin-bottom: 4.4rem;
	}

	.special_contents__introduction_inner:nth-of-type(1) .special_contents__introduction_img_block::before {
		top: -19.2rem;
		left: -9.6rem;
		width: 37rem;
	}

	.special_contents__introduction_inner:nth-of-type(2) .special_contents__introduction_img_block {
		right: -11.8rem;
		width: 22.8rem;
		margin-bottom: 5.6rem;
	}

	.special_contents__introduction_inner:nth-of-type(2) .special_contents__introduction_img_block::before {
		top: -18.7rem;
		right: -11.8rem;
		width: 39rem;
		transform: rotateY(180deg);
	}

	.special_contents__introduction_contents {
		display: block;
	}

	.special_contents__introduction_name {
		max-width: 23.8rem;
	}

	.special_contents__introduction_text {
		font-size: 1.44rem;
	}

	.special_contents__introduction_inner:nth-of-type(2) .special_contents__introduction_name {
		margin-left: auto;
		margin-right: 0;
	}
}



/*****************

   .movie

******************/
.movie {
	position: relative;
	padding: 7rem 0 15.5rem;
}

.movie .deco01 {
	position: absolute;
	top: 9.6rem;
	left: -29.2rem;
	width: 39rem;
	z-index: -1;
	pointer-events: none;
}

.movie .deco02 {
	position: absolute;
	bottom: 5.5rem;
	right: -32rem;
	width: 41.7rem;
	z-index: -1;
	pointer-events: none;
}

.movie__heading {
	position: relative;
	max-width: 82rem;
	margin-bottom: 3.9rem;
	z-index: 20;
}

.movie__block {
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin: 0 auto 4rem;
	z-index: 10;
}

.movie__block::before,
.movie__block::after {
	content: "";
	position: absolute;
	top: -22.8rem;
	background-image: url(../img/design/movie__light_deco.svg);
	background-repeat: no-repeat;
	background-size: contain;
	width: 38rem;
	height: auto;
	aspect-ratio: 374/455;
	z-index: -1;
}

.movie__block::before {
	left: 0;
	transform: translateX(-31%);
}

.movie__block::after {
	right: 0;
	transform: rotateY(180deg) translateX(-32%);
}

.movie__block .illust01 {
	position: absolute;
	bottom: 0;
	left: 0;
	transform: translateX(-89%) translateY(39%);
	max-width: 22rem;
	pointer-events: none;
}

.movie__block_box {
	position: relative;
	width: min(130rem, 70vw);
	max-width: 100%;
	height: auto;
	aspect-ratio: 1920/1100;
	margin: 0 auto;
	overflow: hidden;
	border-radius: 3.8rem;
	background: #426FB8;
	z-index: 10;
}

.movie__block_box::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url(../img/design/movie__box_border.png);
	background-repeat: no-repeat;
	background-size: 100% 100%;
	z-index: -1;
}

.movie__block_box img,
.movie__block_box video,
.movie__block_box iframe {
	--size: calc(100% - 1.5rem * 2);
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	width: var(--size);
	height: var(--size);
	border-radius: 2.52805rem;
	-o-object-fit: contain;
	object-fit: contain;
}

.movie__light_deco01 {}



@media screen and (min-width: 768px) {}

@media screen and (max-width: 768px) {
	.movie {
		padding: 2rem 0 2.8rem;
	}

	.movie .deco01 {
		position: absolute;
		top: -11rem;
		left: -4rem;
		width: 19rem;
		z-index: -1;
	}

	.movie .deco02 {
		display: none;
	}

	.movie__block .illust01 {
		display: none;
	}

	.movie__heading {
		width: 89%;
		margin-bottom: 2rem;
	}

	.movie__block {
		width: 100%;
	}

	.movie__block_box {
		width: 100%;
	}

	.movie__block_box {
		position: relative;
		width: 100%;
		aspect-ratio: 1920/1114;
		border-radius: 1.4rem;
	}

	.movie__block_box::before {}

	.movie__block_box img,
	.movie__block_box video,
	.movie__block_box iframe {
		--size: calc(100% - 0.69rem * 2);
		border-radius: 0.82rem;
	}

	.movie__block::before,
	.movie__block::after {
		top: -16.2rem;
		width: 19rem;
	}

	.movie__block::before {
		transform: rotateZ(12deg) translateX(-15%);
	}

	.movie__block::after {
		transform: rotateY(180deg) rotateZ(12deg) translateX(-18%);
	}

}



/*****************

   .manga

******************/
.manga {
	position: relative;
	background: #FFAD26;
	z-index: 10;
}

.manga .contents_wrapper {
	position: relative;
	max-width: 160rem;
	padding: 10rem 0 15rem;
}

.manga .deco_group {
	font-size: clamp(2px, 0.55vw, 10px);
}

.manga .deco01 {
	position: absolute;
	top: -7rem;
	left: 15em;
	width: 9.2rem;
	z-index: -1;
	pointer-events: none;
}

.manga .deco02 {
	position: absolute;
	top: 47rem;
	right: 18em;
	width: 6.2rem;
	z-index: -1;
	pointer-events: none;
}

.manga .deco03 {
	position: absolute;
	top: 77rem;
	left: 3.2em;
	width: 6.2rem;
	z-index: -1;
	pointer-events: none;
}

.manga .deco04 {
	position: absolute;
	bottom: 34em;
	right: 0;
	width: 9.6rem;
	z-index: -1;
	pointer-events: none;
}

.manga .deco05 {
	position: absolute;
	bottom: -5rem;
	left: -2.5em;
	width: 9.6rem;
	z-index: -1;
	pointer-events: none;
}

.manga .en_tit {
	position: absolute;
	top: 0;
	right: min(-1.5rem, -2vw);
	transform: translateY(-8.2%);
	width: 45rem;
}

.manga .heading_block01__icon {
	width: 19rem;
}

.manga__heading {
	margin-bottom: 4.7rem;
}

.manga__lead {
	width: 56.9rem;
	margin: 0 auto 5.4rem;
	text-align: center;
}

.manga__block {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	max-width: 100%;
	margin: 0 auto 7rem;
}

.manga__text {
	max-width: 92rem;
	margin: 2rem auto;
}

@media screen and (min-width: 768px) {}

@media screen and (max-width: 768px) {
	.manga .en_tit {
		position: absolute;
		right: auto;
		left: -2.32rem;
		width: 25.5rem;
	}

	.manga .contents_wrapper {
		padding: 6.2rem 0 5.4rem;
	}

	.manga .deco01 {
		top: -3.4rem;
		left: auto;
		right: 0;
		width: 4rem;
	}

	.manga .deco02 {
		display: none;
	}

	.manga .deco03 {
		top: auto;
		bottom: -2.5rem;
		left: 0;
		width: 3.8rem;
		height: 8.4rem;
		-o-object-fit: cover;
		object-fit: cover;
		-o-object-position: top;
		object-position: top;
	}

	.manga .deco04 {
		display: none;
	}

	.manga .deco05 {
		display: none;
	}



	.manga .heading_block01__icon {
		width: 8.2rem;
	}

	.manga__heading {
		margin-bottom: 3.2rem;
	}

	.manga__lead {
		width: 20.4rem;
		margin-bottom: 4.4rem;
	}

	.manga__block {
		margin-bottom: 3.2rem;
	}

	.manga__text {
		width: 87%;
	}
}


/*****************

  .official_x

******************/
.official_x {
	position: relative;
	padding: 0;
	background: #3A88C1;
	z-index: 1;
}

.official_x .contents_wrapper {
	padding: 5rem 0 14rem;
}

.official_x .en_tit {
	position: absolute;
	top: -0.2rem;
	left: 0;
}

.official_x .deco01 {
	position: absolute;
	top: 2rem;
	left: 0;
	transform: translateX(-62%);
	width: 31rem;
	height: 100%;
	-o-object-fit: contain;
	object-fit: contain;
	z-index: -1;
	pointer-events: none;
}

.official_x .deco02 {
	position: absolute;
	top: 0;
	right: 0;
	transform: translateX(70%);
	width: 31rem;
	height: 100%;
	-o-object-fit: contain;
	object-fit: contain;
	z-index: -1;
	pointer-events: none;
}

.official_x__heading {}

.official_x__text {
	width: 88rem;
	max-width: 100%;
	margin: 0 auto 7.3rem;
}

.official_x__embed_wrapper {
	position: relative;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin: 0 auto;
	width: 50rem;
}

.twitter-timeline {
	width: 100%;
	max-width: 100%;
	min-height: 25rem;
	max-height: 62rem;
	overflow: auto;
	margin: 0 auto 5.5rem !important;
}


.official_x__character {
	position: relative;
	width: 100%;
	max-width: 80.0rem;
	margin: 5.6rem auto 1rem;
	height: auto;
	aspect-ratio: 80/27;
}

.official_x__character .character01 {
	position: absolute;
	top: 0;
	left: 0;
	max-width: 44rem;
	pointer-events: none;
}

.official_x__character .character02 {
	position: absolute;
	top: 0;
	right: 11rem;
	transform: translateY(30.4%);
	max-width: 22rem;
	pointer-events: none;
}

@media screen and (min-width: 768px) {}

@media screen and (max-width: 768px) {
	.official_x .contents_wrapper {
		padding-bottom: 22.8rem;
	}

	.official_x .en_tit {
		top: 0;
		left: auto;
		right: 0;
		width: 24.4rem;
	}

	.official_x .deco01 {
		top: 2.8rem;
		transform: translateX(-2%);
		width: 32rem;
		height: 56rem;
	}

	.official_x .deco02 {
		top: auto;
		bottom: 2.5rem;
		right: 0;
		transform: translateX(18%);
		width: 17rem;
		height: 59rem;
	}

	.official_x__text {
		margin-bottom: 3.4rem;
	}

	.official_x__embed_wrapper {
		width: 100%;
	}

	.twitter-timeline {
		width: 100%;
		max-height: 39.6rem;
		margin-bottom: 2.5rem !important;
	}

	.official_x__character {
		margin-top: 3.47rem;
		aspect-ratio: 80/4;
	}

	.official_x__character .character01 {
		width: 25rem;
		transform: translateX(-5%);
	}

	.official_x__character .character02 {
		right: 0;
		transform: translateY(62.9%) translateX(-8.7%);
		width: 10.2rem;
	}
}


/*****************

   .sns_share

******************/
.sns_share {
	position: relative;
	margin-top: -3.2rem;
	padding: 13rem 0 7.6rem;
	background-image: url(../img/design/bg_design01.png);
	background-repeat: no-repeat;
	background-position: top;
	background-size: cover;
	z-index: 5;
}

.sns_share .deco01 {
	position: absolute;
	top: 4rem;
	left: 0;
	width: 55.5rem;
	transform: translateX(-76%);
	pointer-events: none;
}

.sns_share .deco02 {
	position: absolute;
	top: 7rem;
	right: 0;
	width: 51.8rem;
	transform: translateX(73%);
	pointer-events: none;
}

.sns_share__heading {
	margin-bottom: 4rem;
	text-align: center;
}

.sns_share__heading img {
	max-width: 55rem;
}

.sns_share__list {
	display: flex;
	align-items: center;
	justify-content: center;
	-moz-column-gap: 5.5rem;
	column-gap: 5.5rem;
	margin: 0 auto 11.8rem;
}

.sns_share__list_item img {
	max-width: 25rem;
	-webkit-filter: drop-shadow(0.55rem 0.44rem 0.5rem rgba(140, 88, 50, 0.32));
	filter: drop-shadow(0.55rem 0.44rem 0.5rem rgba(140, 88, 50, 0.32));
}

.site_links {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
}

.site_links__item {
	padding: 0.4rem 0;
	font-size: 2.2rem;
}

.site_links__item:not(:last-of-type)::after {
	content: "|";
	font-size: 1.18em;
}

.site_links__item a {
	padding: 0.2em 0.82em 0.28em 1em;
	font-size: 1em;
	font-weight: 600;
	letter-spacing: 0.1em;
	line-height: 1.8;
}

.site_links__item a:hover {
	opacity: 0.4;
}

@media screen and (max-width:769px) {
	.sns_share {
		margin-top: -2rem;
		padding: 5.5rem 0 5.4rem;
	}

	.sns_share .deco01,
	.sns_share .deco02 {
		display: none;
	}

	.sns_share__heading {
		margin-bottom: 1rem;
	}

	.sns_share__heading img {
		width: 31rem;
	}

	.sns_share__list {
		width: 87%;
		-moz-column-gap: 1.5rem;
		column-gap: 1.5rem;
		margin-bottom: 5.5rem;
	}

	.site_links__item {
		font-size: 1.32rem;
	}

	.site_links__item a {
		padding-left: 0.82em;
		padding-right: 0.76em;
	}
}



/*****************

   .topへ戻るボタン

******************/
.return_top {
	position: static;
}

.js-return_top__switch {
	--adjust: 170vh;
	position: absolute;
	display: block;
	top: var(--adjust);
	left: 0;
	width: 100%;
	height: calc(100% - var(--adjust));
	z-index: -1;
}

.return_top__btn {
	position: fixed;
	bottom: 4rem;
	right: 5rem;
	z-index: 9992;
	transition: opacity 0.44s ease, transform 0.44s linear;
	will-change: transform, opacity;
	opacity: 0;
	transform: translateY(10%);
	pointer-events: none;
}

.return_top__btn.active {
	opacity: 1;
	transform: translateY(0);
	pointer-events: all;
}

.return_top__btn:hover {
	opacity: 1;
	-webkit-filter: brightness(1.18);
	filter: brightness(1.18);
}

.return_top__btn img {
	width: 18.2rem;
}

@media screen and (max-width:769px) {
	.return_top__btn {
		bottom: 2.5rem;
		right: 2rem;
	}

	.return_top__btn img {
		width: 8.7rem;
	}
}



/*========= 
追加20250404　archive ニュース過去一覧 
=========*/

div.archive_btn {
    text-align:center;
    /* position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%); */
	margin-top: 50px;
    width: 100%;
    display: block;
	padding-bottom: 10px;
}
div.archive_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-55%);
    width: 102%;
    height: calc(100% + 17rem);
    background-image: linear-gradient(180deg, rgba(254, 240, 226, 0.00) 0, rgba(255, 241, 223, 1.00) 25%);
    background-position: center center;
    z-index: -1;
}