:root {
	--color-primary: #bfaf7c;
	--color-secondary: #ede9c5;
	--color-green: #50735d;
}

html {
	scroll-behavior: smooth;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	color: var(--color-primary);
	font-family: "Zen Old Mincho", serif;
	font-weight: 400;
	letter-spacing: 0.03em;
	line-height: 1.6;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

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

/* 背景レイヤー */
.bg-wrapper {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	visibility: visible;
	z-index: 1;
}
.bg-layer {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	opacity: 0;
	visibility: hidden;
}
.bg-layer.active {
	opacity: 1;
	visibility: visible;
}
.bg-layer-logo .logo-left {
	position: absolute;
	top: 37.76vw;
	/* left: 8.3vw; */
	left: 10vw;
	width: 7.47vw;
}
.bg-layer-logo .logo-right {
	position: absolute;
	top: 34.02vw;
	left: 74.07vw;
	width: 11.2vw;
}
@media (max-width: 768px) {
	.bg-layer-logo .logo-left {
		top: 17.65vw;
		left: 21.62vw;
		width: 15.15vw;
	}
	.bg-layer-logo .logo-right {
		top: 147.06vw;
		left: 52.06vw;
		width: 22.35vw;
	}
}

.bg-main {
	background-image: url("./img/bg/bg-main.jpg");
}
.bg-staff {
	background-image: url("./img/bg/bg-main.jpg");
}
.bg-movie {
	background-image: url("./img/bg/bg-main.jpg");
}
.bg-schedule {
	background-image: url("./img/bg/bg-main.jpg");
}

@media (max-width: 768px) {
	.bg-main {
		background-image: url("./img/bg/bg-main.jpg");
	}
	.bg-staff {
		background-image: url("./img/bg/bg-main.jpg");
	}
	.bg-movie {
		background-image: url("./img/bg/bg-main.jpg");
	}
	.bg-schedule {
		background-image: url("./img/bg/bg-main.jpg");
	}
}

/* ヘッダーレイヤー */
.header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	display: flex;
	justify-content: center;
	z-index: 10;
	pointer-events: none;
}
.fixed-header {
	position: absolute;
	opacity: 0;
	visibility: hidden;
	text-align: center;
	width: 100%;
	height: 100%;
}
.header .logo {
	position: absolute;
	top: -0.3vw;
	left: -0.2vw;
	width: 100%;
}
.header .logo-vertical {
	position: absolute;
	top: 0;
	left: 0;
	width: 5.4vw;
}
.header .logo-horizontal {
	position: absolute;
	top: -0.3vw;
	right: -0.2vw;
	width: 52.7vw;
}
.header .supported-by {
	position: absolute;
	width: 10vw;
}
.header .pattern-a .supported-by,
.header .pattern-c .supported-by {
	top: 14.11vw;
	left: 3vw;
}
.header .pattern-b .supported-by {
	top: 18.78vw;
	right: 3vw;
}
.header .catch {
	position: absolute;
	font-size: 2vw;
	font-weight: 900;
	letter-spacing: .25em;
	line-height: 1.85;
	text-align: start;
	writing-mode: vertical-rl;
	text-orientation: upright;
}
.header .pattern-a .catch,
.header .pattern-c .catch {
	top: 10.4vw;
	left: 19vw;
}
.header .pattern-b .catch {
	top: 7.47vw;
	left: 38vw;
}
.header .pattern-c .uniform-logo {
	position: absolute;
	top: 10.76vw;
	left: 78vw;
	width: 13.6vw;
}
@media (max-width: 768px) {
	.header .logo {
		top: 0;
		left: 0;
	}
	.header .logo-vertical {
		top: 0;
		left: 0;
		width: 10vw;
	}
	.header .logo-horizontal {
		top: 50vh;
		right: 0;
		width: 100%;
	}
	.header .supported-by {
		width: 15vw;
	}
	.header .pattern-a .supported-by,
	.header .pattern-c .supported-by {
		top: 46.47vw;
		left: 77.65vw;
	}
	.header .pattern-b .supported-by {
		top: 18.78vw;
		right: 3vw;
	}
	.header .catch {
		font-size: 5vw;
		letter-spacing: .25em;
		line-height: 1.85;
	}
	.header .pattern-a .catch,
	.header .pattern-c .catch {
		top: 52.65vw;
		/* left: 9.12vw; */
		left: 55vw;
	}
	.header .pattern-b .catch {
		top: 6.76vw;
		left: auto;
		right: 5.88vw;
	}
	.header .pattern-c .uniform-logo {
		top: 29.85vw;
		left: 63.24vw;
		width: 27.35vw;
	}
}

/* ヘッダー内要素のフェードイン用（初期は非表示） */
.fixed-header .logo,
.fixed-header .logo-vertical,
.fixed-header .logo-horizontal,
.fixed-header .supported-by,
.fixed-header .catch {
	opacity: 0;
}

/* フッター */
.footer {
	position: relative;
	z-index: 30;
}
.footer .footer-container,
.footer .footer-logo {
	/* opacity: 0; */
}
.footer .footer-container {
	position: fixed;
	bottom: 1.75vw;
	left: 2vw;
	display: grid;
	gap: 1vw;
}
.footer .menu {
	background: var(--color-green);
	padding: 0.4vw;
}
.footer .menu-container {
	border: 0.3vw solid var(--color-secondary);
	padding: 0.825vw 0.6vw;
	display: grid;
	gap: 1.625vw;
}
.footer .menu-title {
	cursor: pointer;
}
.footer .menu-title img {
	height: 1vw;
}
.footer .menu-list {
	/* display: none; */
}
.footer .menu.is-open .menu-list {
	display: block;
}
.footer .menu-list ul {
	display: grid;
	gap: 1vw;
}
.footer .menu-close {
	display: none;
	cursor: pointer;
}
.footer .menu.is-open .menu-close {
	display: block;
}
.footer .menu-list li {
	list-style: none;
}
.footer .menu-list li a {
	transition: opacity 0.3s ease;
	text-decoration: none;
}
.footer .menu-list li a:hover {
	opacity: 0.8;
}
.footer .menu-list img {
	height: 0.825vw;
}
.footer .copy {
	font-weight: 700;
	font-size: 0.71vw; /* 12px */
	line-height: 1.8;
}
.footer .footer-logo {
	position: fixed;
	bottom: 1.75vw;
	right: 2vw;
	width: 10vw;
}
@media (max-width: 768px) {
	.footer .footer-container {
		bottom: 4vw;
		left: 4vw;
		gap: 3vw;
	}
	.footer .menu {
		padding: 1vw;
	}
	.footer .menu-container {
		border: 0.75vw solid var(--color-secondary);
		padding: 2vw 1.5vw;
		display: grid;
		gap: 4vw;
	}
	.footer .menu-title img {
		height: 4.25vw;
	}
	.footer .menu-list {
		display: none;
	}
	.footer .menu-list ul {
		gap: 2.8vw;
	}
	.footer .menu-list img {
		height: 3vw;
	}
	.footer .menu-close {
		display: none;
		cursor: pointer;
	}
	.footer .copy {
		font-size: 2.5vw;
		list-style: 1.4;
	}
	.footer .footer-logo {
		bottom: 4vw;
		right: 4vw;
		width: 27.94vw;
	}
}

/* [Layer 3] コンテンツ */
.panel {
	width: 100%;
	height: 200vh;
	padding-top: 100vh;
	position: relative;
	z-index: 20;
	/* border-bottom: 1px solid #fff; */
}
.panel-top {
	height: 100vh;
	padding-top: 0;
	position: relative;
}
.panel-goods {
	height: 250vh;
}
.panel-event {
	z-index: 21;
}
.panel-event-item {
	height: auto;
	padding-top: 0;
	padding-bottom: 5vw;
}
@media (max-width: 768px) {
	.panel {
		height: auto;
		min-height: 100vh;
		padding-top: 50vh;
	}
	.panel-goods {
		height: auto;
	}
	.panel-event {
		padding-bottom: 0;
	}
	.panel-event-item {
		padding-top: 5vh;
	}
}


/* スクロール誘導の下向き矢印 */
.scroll-indicator {
	position: absolute;
	bottom: 2.5vw;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	justify-content: center;
	align-items: center;
	color: var(--color-gold);
	text-decoration: none;
	animation: scroll-bounce 2s ease-in-out infinite;
}
.scroll-indicator__arrow {
	width: 2vw;
	height: 2vw;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	margin-top: -0.5vw;
}
@keyframes scroll-bounce {
	0%, 100% { transform: translateX(-50%) translateY(0); }
	50% { transform: translateX(-50%) translateY(8px); }
}
@media (max-width: 768px) {
	.scroll-indicator {
		bottom: 20vw;
	}
	.scroll-indicator__arrow {
		width: 5vw;
		height: 5vw;
		border-width: 2px;
	}
}

.panel-container {
	position: relative;
	width: 100%;
	height: 100%;
}

/* logo-box */
.logo-box {
	position: relative;
	width: 20.33vw;
	height: 11.6vw;
	color: var(--color-secondary);
	background: url("./img/logo-box-bg-top.png") left top no-repeat, url("./img/logo-box-bg-btm.png") left bottom no-repeat;
	background-size: 100% auto;
	padding: 5.8vw 0;
}
.logo-box-green {
	background: url("./img/logo-box-green-bg-top.png") left top no-repeat, url("./img/logo-box-green-bg-btm.png") left bottom no-repeat;
	background-size: 100% auto;
}
.logo-box-wide {
	width: 30.5vw;
	background: url("./img/logo-box-wide-bg-top.png") left top no-repeat, url("./img/logo-box-wide-bg-btm.png") left bottom no-repeat;
	background-size: 100% auto;
}
.logo-box-green.logo-box-wide {
	width: 30.5vw;
	background: url("./img/logo-box-green-wide-bg-top.png") left top no-repeat, url("./img/logo-box-green-wide-bg-btm.png") left bottom no-repeat;
	background-size: 100% auto;
}
.logo-box.is-closed {
	cursor: pointer;
}
.panel-statement .logo-box {
	/* position: relative; */
	position: sticky;
	/* top: 10.58vw; */
	top: calc(50vh - 20.5vw);
	left: 60vw;
}
.panel-about .logo-box {
	/* position: relative; */
	position: sticky;
	/* top: 24.9vw; */
	top: calc(50vh - 24vw);
	left: 38.17vw;
}
.panel-uniform .logo-box {
	/* position: relative; */
	position: sticky;
	/* top: 19.09vw; */
	top: calc(50vh - 17.5vw);
	left: 20vw;
	width: 60vw;
	height: 33vw;
	background: url("./img/uniform-box-bg-top.png") left top no-repeat, url("./img/uniform-box-bg-btm.png") left bottom no-repeat;
	background-size: 100% auto;
}
.panel-goods .logo-box {
	/* position: relative; */
	position: sticky;
	/* top: 20.75vw; */
	top: 10vw;
	left: 12vw;
}
.panel-event .logo-box {
	/* position: relative; */
	position: sticky;
	top: 8.09vw;
	left: 47.3vw;
}
.panel-logo .logo-box {
	/* position: relative; */
	position: sticky;
	top: 24.48vw;
	left: 38.38vw;
}
.logo-box-bg-btm {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
}
.logo-box-bg {
	width: 100%;
	height: 100%;
	background: url("./img/logo-box-bg.png") left top repeat-y;
	background-size: 100% auto;
	padding: 0 1.66vw;
	display: grid;
	gap: 1.5vw;
	position: relative;
}
.logo-box-green .logo-box-bg {
	background: url("./img/logo-box-green-bg.png") left top repeat-y;
	background-size: 100% auto;
}
.logo-box-wide .logo-box-bg {
	width: 30.5vw;
	background: url("./img/logo-box-wide-bg.png") left top repeat-y;
	background-size: 100% auto;
}
.logo-box-green.logo-box-wide .logo-box-bg {
	width: 30.5vw;
	background: url("./img/logo-box-green-wide-bg.png") left top repeat-y;
	background-size: 100% auto;
}
.panel-uniform .logo-box-green.logo-box-wide .logo-box-bg {
	background: url("./img/uniform-box-bg.png") left top repeat-y;
	background-size: 100% auto;
	width: 100%;
}
.logo-box-title {
	position: absolute;
	left: 0;
	/* top: -0.5vw; */
	top: -4.1vw;
	width: 100%;
	/* height: 100%; */
	/* padding: 0 1.66vw; */
}
.panel-uniform .logo-box-title {
	width: 16.84vw;
	left: 1.8vw;
}
.logo-box-title img {
	width: 16.84vw;
	margin: 0 auto;
}
.logo-box-content {
	display: none;
	position: relative;
	padding-top: 5.5vw;
}
.panel-present .logo-box-content {
	display: block;
}
.panel-uniform .logo-box-content {
	display: grid;
	grid-template-columns: 28vw 1fr;
	column-gap: 1vw;
	padding-inline: 1vw;
}
.logo-box-text {
	position: relative;
	font-size: 0.95vw; /* 16px */
	line-height: 1.6;
}
.panel-statement .logo-box-text {
	text-align: center;
}
.panel-uniform .logo-box-text {
}
.logo-box-text p + p {
	margin-top: 0.75em;
}
.logo-box-text-small {
	font-size: 0.83vw; /* 14px */
	line-height: 1.4;
}
.logo-box-text a {
	color: inherit;
}
.logo-box-text a:hover {
	text-decoration: none;
}
.logo-box-link {
	display: block;
	width: 100%;
	color: var(--color-secondary);
	text-decoration: none;
	background: url("./img/icon-link.svg") right center no-repeat;
	background-size: 1.136vw;
	transition: opacity 0.3s ease;
	margin-top: 1.3vw;
}
.logo-box-link img {
	width: 13.03vw;
}
.logo-box-link:hover {
	opacity: 0.8;
}
.logo-box-footer {
	position: absolute;
	left: 0;
	bottom: 2.8vw;
	display: none;
	align-items: center;
	/* justify-content: space-between; */
	justify-content: flex-end;
	padding: 0 1.66vw;
	width: 100%
}
.logo-box-footer-close {
	position: relative;
	width: 1.5vw;
	height: 1.5vw;
	cursor: pointer;
	transition: opacity 0.3s ease;
}
.logo-box-footer-close::before,
.logo-box-footer-close::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 100%;
	height: 1px;
	background: currentColor;
}
.logo-box-footer-close::before {
	transform: translate(-50%, -50%) rotate(45deg);
}
.logo-box-footer-close::after {
	transform: translate(-50%, -50%) rotate(-45deg);
}
.logo-box-footer-close:hover {
	opacity: 0.8;
}
.logo-box-footer-copy {
	font-size: 0.71vw; /* 12px */
}
.logo-box-label {
	position: absolute;
	left: 4.2vw;
	right: 0;
	bottom: 0;
	width: 7.5vw;
	text-align: center;
	padding-bottom: 1.2vw;
	display: none;
}
.logo-box-wide .logo-box-label {
	left: 9.3vw;
}
.panel-present .logo-box-label {
	display: block;
}
.panel-uniform .logo-box-label {
	display: block;
	left: 4.2vw;
}
.logo-box-label img {
	height: 0.61vw;
	margin: 0 auto;
}
@media (max-width: 768px) {
	.logo-box {
		width: 60vw;
		height: auto;
		background: url("./img/logo-box-bg-top-sp.png") left top no-repeat, url("./img/logo-box-bg-btm-sp.png") left bottom no-repeat;
		background-size: 100% auto;
		padding: 8vw 0;
	}
	.logo-box-green {
		background: url("./img/logo-box-green-bg-top-sp.png") left top no-repeat, url("./img/logo-box-green-bg-btm-sp.png") left bottom no-repeat;
		background-size: 100% auto;
	}
	.logo-box-wide {
		width: 60vw;
		background: url("./img/logo-box-bg-top-sp.png") left top no-repeat, url("./img/logo-box-bg-btm-sp.png") left bottom no-repeat;
		background-size: 100% auto;
	}
	.logo-box-green.logo-box-wide {
		width: 60vw;
		background: url("./img/logo-box-green-bg-top-sp.png") left top no-repeat, url("./img/logo-box-green-bg-btm-sp.png") left bottom no-repeat;
		background-size: 100% auto;
	}
	.panel-statement .logo-box {
		position: relative;
		top: 10vw;
		left: 33vw;
		height: auto!important;
	}
	.panel-about .logo-box {
		position: relative;
		top: 10vw;
		left: 38.17vw;
		height: auto!important;
	}
	.panel-uniform .logo-box {
		position: relative;
		top: 10vw;
		left: 33vw;
		width: 60vw;
		height: 33vw;
		background: url("./img/logo-box-green-bg-top-sp.png") left top no-repeat, url("./img/logo-box-green-bg-btm-sp.png") left bottom no-repeat;
		background-size: 100% auto;
		height: auto!important;
	}
	.panel-goods .logo-box {
		position: relative;
		top: 10vw;
		left: 10vw;
		height: auto!important;
	}
	.panel-event .logo-box {
		position: relative;
		top: 10vw;
		left: 33vw;
		height: auto!important;
	}
	.panel-logo .logo-box {
		position: relative;
		top: 10vw;
		left: 38.38vw;
		height: auto!important;
	}
	.logo-box-bg-btm {
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
	}
	.logo-box-bg {
		width: 100%;
		height: 100%;
		background: url("./img/logo-box-bg-sp.png") left top repeat-y;
		background-size: 100% auto;
		padding: 0 4.5vw 9.5vw;
		display: grid;
		gap: 1.5vw;
		position: relative;
	}
	.logo-box-green .logo-box-bg {
		background: url("./img/logo-box-green-bg.png") left top repeat-y;
		background-size: 100% auto;
	}
	.logo-box-wide .logo-box-bg {
		width: 100%;
		background: url("./img/logo-box-bg-sp.png") left top repeat-y;
		background-size: 100% auto;
	}
	.logo-box-green.logo-box-wide .logo-box-bg {
		width: 100%;
		background: url("./img/logo-box-green-bg-sp.png") left top repeat-y;
		background-size: 100% auto;
	}
	.panel-uniform .logo-box-green.logo-box-wide .logo-box-bg {
		background: url("./img/logo-box-green-bg-sp.png") left top repeat-y;
		background-size: 100% auto;
		width: 100%;
	}
	.logo-box-title {
		position: absolute;
		left: 0;
		top: -4.1vw;
		width: 100%;
	}
	.panel-uniform .logo-box-title {
		width: inherit;
		left: inherit;
	}
	.logo-box-title img {
		width: 50vw;
		margin: 0 auto;
	}
	.logo-box-content {
		display: block;
		position: relative;
		padding-top: 24vw;
	}
	.panel-present .logo-box-content {
		display: block;
	}
	.panel-uniform .logo-box-content {
		display: block;
		padding-inline: 1vw;
	}
	.logo-box-text {
		font-size: 3vw;
		line-height: 1.5;
	}
	.panel-statement .logo-box-text {
		text-align: left;
	}
	.logo-box-text p + p {
		margin-top: 0.75em;
	}
	.logo-box-text-small {
		font-size: 2.5vw;
		line-height: 1.4;
	}
	.logo-box-link {
		display: block;
		width: 100%;
		background: url("./img/icon-link.svg") right center no-repeat;
		background-size: 3.5vw;
		margin-top: 4.5vw;
	}
	.logo-box-link img {
		width: 80%;
	}
	.logo-box-footer {
		left: 0;
		right: 0;
		bottom: 8.5vw;
		display: flex;
		justify-content: flex-end;
		padding: 0 4.5vw;
		width: 100%;
	}
	.logo-box-footer-close {
		display: none;
	}
	.logo-box-footer-copy {
		font-size: 2vw;
		line-height: 1.5;;
	}
	.logo-box-label {
		position: absolute;
		left: 12.5vw;
		right: 0;
		bottom: 0;
		width: 22vw;
		text-align: center;
		padding-bottom: 3.5vw;
		display: block
	}
	.logo-box-wide .logo-box-label {
		left: 12.5vw;
	}
	.panel-present .logo-box-label {
		display: block;
	}
	.panel-uniform .logo-box-label {
		display: block;
		left: 12.5vw;
	}
	.logo-box-label img {
		height: 2vw;
		margin: 0 auto;
	}
}

/* uniform */
.uniform-images {
	display: grid;
	grid-template-columns: 11vw 11vw;
	justify-content: center;
	column-gap: 1vw;
}
@media (max-width: 768px) {
	.uniform-images {
		margin-top: 4vw;
		grid-template-columns: 1fr 1fr;
		column-gap: 2.5vw;
	}
}
/* movie */
.movie {
	/* opacity: 0; */
	/* position: relative; */
	position: sticky;
	top: calc(50vh - 13vw);
	left: 0;
	right: 0;
	width: 100%;
}
.movie-container {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 46.68vw;
	margin: 0 auto;
}
.movie-main {
	width: 46.68vw;
	height: 26.35vw;
	background: #000000;
	border: 0.25vw solid #bfaf7c;
	overflow: hidden;
}
.movie-main iframe {
	display: block;
	width: 100%;
	height: 100%;
}
.movie-logo {
	position: absolute;
	left: -6.94vw;
	bottom: -5.39vw;
	width: 11.93vw;
}
@media (max-width: 768px) {
	.movie {
		position: relative;
		top: calc(50vh - 20vw);
	}
	.movie-container {
		width: 80vw;
	}
	.movie-main {
		width: 100%;
		height: auto;
		aspect-ratio: 16 / 9;
		border: 0.8vw solid #bfaf7c;
	}
	.movie-logo {
		left: -5.12vw;
		bottom: -11.47vw;
		width: 23.97vw;
	}
}

/* schedule */
.schedule {
	/* opacity: 0; */
	/* position: relative; */
	position: sticky;
	top: calc(50vh - 10vh);
	left: 0;
	right: 0;
	width: 100%;
	display: grid;
	row-gap: 4vw;
}
.schedule-team {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5.2vw;
}
.schedule-team-logo {
	width: 15.35vw;
	height: 15.35vw;
	position: relative;
}
.schedule-team-logo img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.schedule-team-logo a {
	transition: opacity 0.3s ease;
}
.schedule-team-logo a:hover {
	opacity: 0.9;
}
.schedule-team-vs {
	width: 6.22vw;
}
.schedule-date {
	overflow: hidden;
	width: 100%;
	white-space: nowrap;
	line-height: 1;
}
.schedule-date-track {
	display: flex;
	align-items: center;
	gap: 5vw;
	width: max-content;
	will-change: transform;
}
.schedule-date-item {
	width: 100%;
	font-size: 4.98vw;
	font-weight: 900;
	line-height: 1;
}
.schedule-date-item span {
	font-size: 2.7vw;
	line-height: 1;
	padding-left: 0.5vw;
}
@media (max-width: 768px) {
	.schedule {
		position: relative;
		top: 20vw;
		row-gap: 6vw;
		padding-top: 20vw;
	}
	.schedule-team {
		display: grid;
		align-items: center;
		justify-content: center;
		gap: 6vw;
	}
	.schedule-team-logo {
		width: 30.15vw;
		height: 30.15vw;
	}
	.schedule-team-vs {
		width: 13.09vw;
		margin: 0 auto;
	}
	.schedule-date-track {
		gap: 15vw;
	}
	.schedule-date-item {
		font-size: 12vw;
		letter-spacing: 0.01em;
	}
	.schedule-date-item span {
		font-size: 5vw;
		padding-left: 0.5vw;
	}
}

/* present */
.present-box {
	/* position: relative; */
	position: sticky;
	top: calc(50vh - 12vw);
	left: 13.765vw;
	width: 72.47vw;
	padding-top: 3vw;
	background: url("./img/present-box-bg-top.png") left top no-repeat;
	background-size: 100% auto;
	color: var(--color-secondary);
}
.present-box-bg {
	padding: 1.5vw 2.5vw 4vw;
	background: url("./img/present-box-bg-btm.png") left bottom no-repeat;
	background-size: 100% auto;
}
.present-box-title {
	width: 16.84vw;
	top: 1.5vw;
	left: 1.5vw;
}
.present-box-content {
	display: grid;
	grid-template-columns: 18vw 1fr 18vw 1fr;
	column-gap: 2vw;
}
.present-box-text {
	padding-top: 7vw;
	font-size: 0.95vw;
}
.present-box-img {
	display: flex;
	align-items: center;
	justify-content: center;
}
.present-box-detail-title {
	width: 7.17vw;
	margin-bottom: 1.5vw;
}
.present-box-detail-list dt {
	padding-bottom: .5vw;
	font-size: 0.95vw;
}
.present-box-detail-list dd + dt {
	padding-top:  .5vw;
}
.present-box-detail-list dd {
	font-size: 0.71vw; /* 12px */
	line-height: 1.4;
}
.present-box-detail-list p {
	margin-bottom: .5vw;
}
.present-box-detail ul {
	list-style: none;
	text-indent: -1em;
	margin-left: 1em;
}
.present-box-detail-read-more {
	display: flex;
	align-items: self-end;
	min-height: 1.125vw;
	margin-top: 1vw;
	background: url("./img/icon-link.svg") right center no-repeat;
	background-size: auto 1.125vw;
	transition: opacity 0.3s ease;
}
.present-box-detail-read-more:hover {
	opacity: 0.8;
}
.present-box-detail-read-more img {
	width: 5.49vw;
}
.present-box-detail-img img {
	width: 80%;
	text-align: center;
}
@media (max-width: 768px) {
	.present-box {
		position: relative;
		top: 10vw;
		left: 33vw;
		width: 60vw;
		padding: 8vw 0 14vw;
		background: url("./img/logo-box-green-bg-top-sp.png") left top no-repeat, url("./img/logo-box-green-bg-btm-sp.png") left bottom no-repeat;
		background-size: 100% auto;
		color: var(--color-secondary);
	}
	.present-box-bg {
		padding: 1.5vw 4.5vw 4vw;
		background: url("./img/logo-box-green-bg-sp.png") left bottom repeat-y;
		background-size: 100% auto;
	}
	.present-box-title {
		width: 100%;
		top: 4vw;
		left: 0vw;
	}
	.present-box-content {
		display: grid;
		grid-template-columns: 1fr;
		row-gap: 5vw;
		padding-top: 24vw;
	}
	.present-box-text {
		padding-top: 0vw;
		font-size: 3vw;
	}
	.present-box-img {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 90%;
		margin: 0 auto;
	}
	.present-box-detail {
		padding: 4vw 0 2vw;
	}
	.present-box-detail-title {
		width: auto;
		margin-bottom: 4vw;
	}
	.present-box-detail-title img {
		height: 4vw;
	}
	.present-box-detail-list dt {
		padding-bottom: 1.25vw;
		font-size: 3vw;
	}
	.present-box-detail-list dd + dt {
		padding-top:  2.5vw;
	}
	.present-box-detail-list dd {
		font-size: 2.5vw;
		line-height: 1.6;
	}
	.present-box-detail-list p {
		margin-bottom: .5vw;
	}
	.present-box-detail ul {
		list-style: none;
		text-indent: -1em;
		margin-left: 1em;
	}
	.present-box-detail-read-more {
		display: flex;
		align-items: self-end;
		min-height: 3vw;
		margin-top: 3vw;
		background: url("./img/icon-link.svg") right center no-repeat;
		background-size: auto 3vw;
		transition: opacity 0.3s ease;
	}
	.present-box-detail-read-more img {
		width: auto;
		height: 2.5vw;
	}
	.present-box-detail-img img {
		width: 80%;
		text-align: center;
	}
}

/* goods */
.goods-container {
	position: sticky;
	top: calc(50vh - 20vw);
	/* left: 30vw; */
	left: 34vw;
	/* width: 63.736vw; */
	width: 57.3vw;
	/* opacity: 0; */
	/* transform: translateY(100%); */
}
.goods-box {
	position: relative;
	padding: 4.5vw 3vw 3vw 6vw;
	background: url("./img/goods-bg-top.png") center top no-repeat, url("./img/goods-bg-btm.png") center bottom no-repeat;
	background-size: 100%;
	color: var(--color-secondary);
}
.goods-box-title {
	position: absolute;
	top: 1.2vw;
	right: 2.85vw;
	width: 9.67vw;
	text-align: center;
}
.goods-box-title img {
	height: 1.46vw;
	margin: 0 auto;
}
.goods-box-subtitle {
	position: absolute;
	top: 4.2vw;
	left: 1.2vw;
	font-size: 1.451vw;
	height: 12.015vw;
	line-height: 1;
	text-align: center;
	writing-mode: vertical-rl;
	padding-top: 1vw;
}
.goods-box-subtitle img {
	width: 1.46vw;
}
.goods-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.25vw;
	list-style: none;
	padding: 0;
	margin: 0;
	text-align: center;
}
.goods-list-item {
	display: grid;
  row-gap: 0.5vw;
}
.goods-list-item-images {
	display: flex;
	justify-content: center;
	gap: 1vw;
}
.goods-list-item-image {
	width: 100%;
}
.goods-list-item-image img {
	aspect-ratio: 1 / 1;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.goods-list-item-info {
	font-size: 0.83vw; /* 14px */
	letter-spacing: 0.01em;
	line-height: 1.3;
}
.goods-list-item-info span {
	font-size: 80%;
}
.goods-info {
	position: absolute;
	bottom: 1.5vw;
	right: 0;
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
	column-gap: 0.8vw;
	width: calc(100% - 2.3vw);
}
.goods-info-title {
	width: 3.4vw;
	text-align: center;
	font-size: 0.879vw;
	line-height: 1.5;
	padding-bottom: 1.2vw;
}
.goods-info-schedule {
	width: 43vw;
}
.goods-info-delivery {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	text-align: center;
	width: 5.201vw;
	height: 5.201vw;
	margin-left: 0.3vw;;
}
@keyframes goods-delivery-rotate {
	from { transform: rotate(0deg); }
	to { transform: rotate(360deg); }
}
.goods-info-delivery-animation {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	animation: goods-delivery-rotate 12s linear infinite;;
}
.goods-info-delivery-text {
	width: 2.344vw;
}
.logo-box-link-sp {
	display: none;
}
@media (max-width: 768px) {
	.goods-container {
		position: relative;
		top: 0;
		left: 33vw;
		width: 60vw;
		margin-top: 15vw;
	}
	.goods-box {
		padding: 10.5vw 4.5vw 25vw 9vw;
		background: url("./img/goods-bg-top-sp.png") center top no-repeat, url("./img/goods-bg-btm-sp.png") center bottom no-repeat;
		background-size: 100%;
	}
	.goods-box-title {
		position: absolute;
		top: 3.5vw;
		right: 6.5vw;
		width: 28vw;
		text-align: center;
	}
	.goods-box-title img {
		height: 3.5vw;
		margin: 0 auto;
	}
	.goods-box-subtitle {
		position: absolute;
		top: 17vw;
		left: 3vw;
		height: auto;
		line-height: 1;
		text-align: center;
		writing-mode: vertical-rl;
		padding-top: 1vw;
	}
	.goods-box-subtitle img {
		width: 3.5vw;
	}
	.goods-list {
		display: block;
	}
	.goods-list-item {
		display: grid;
		row-gap: 2vw;
		padding-bottom: 3vw;
	}
	.goods-list-item-images {
		display: flex;
		justify-content: center;
		gap: 2vw;
	}
	.goods-list-item-image {
		width: 100%;
	}
	.goods-list-item-image img {
		aspect-ratio: 1 / 1;
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.goods-list-item-info {
		font-size: 2.5vw;
		letter-spacing: 0.01em;
		line-height: 1.3;
	}
	.goods-list-item-info span {
		font-size: 80%;
	}
	.goods-info {
		position: absolute;
		bottom: 5vw;
		right: 0;
		display: block;
		padding: 0;
		width: 100%;
		/* background: orange; */
		padding: 0 5vw 0 17vw;
	}
	.goods-info-title {
		position: absolute;
		left: 8vw;
		bottom: 26.5vw;
		width: auto;
		text-align: center;
		font-size: 2.5vw;
		line-height: 1.4;
		padding-bottom: 1.2vw;
	}
	.goods-info-schedule {
		width: 100%;
	}
	.goods-info-wrap {
		display: grid;
		grid-template-columns: 1fr 1fr;
		align-items: center;
		justify-content: space-between;
		column-gap: 4vw;
		margin-top: 5vw;
	}
	.goods-info-delivery {
		display: flex;
		align-items: center;
		justify-content: center;
		position: relative;
		text-align: center;
		width: 100%;
		height: 100%;
		margin-left: 1vw;
	}
	@keyframes goods-delivery-rotate {
		from { transform: rotate(0deg); }
		to { transform: rotate(360deg); }
	}
	.goods-info-delivery-animation {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		animation: goods-delivery-rotate 12s linear infinite;;
	}
	.goods-info-delivery-text {
		width: 45%;
	}
	.logo-box-link-sp {
		display: block;
		width: 100%;
	}
}

/* event */
.event-cards {
	position: relative;
	top: 0;
	left: 21.23vw;
	/* width: 63.004vw; */
	width: 65vw;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
}
.event-card {
	position: relative;
	/* width: 19.77vw; */
	width: 23.28vw;
	padding-top: 3vw;
	background: url("./img/event-card-bg-top.png") left top no-repeat;
	background-size: 100% auto;
	color: var(--color-secondary);
}
.event-card-bg {
	display: grid;
	row-gap: .75vw;
	padding: 0.25vw 1.5vw 1.5vw;
	background: url("./img/event-card-bg-btm.png") left bottom no-repeat, url("./img/event-card-bg.png") left top repeat-y;
	background-size: 100% auto;
}
.event-card-label {
	position: absolute;
	left: 13.2vw;
	top: 1.1vw;
	width: 8.8vw;
	text-align: center;
}
.event-card-label img {
	height: 1.4vw;
	margin: 0 auto;
}
.event-card-title {
	font-size: 1.43vw; /* 24px */
	letter-spacing: 0.01em;
	line-height: 1.4;
}
.event-card-description {
	font-size: 0.95vw; /* 16px */
}
.event-card-image {
	border: 0.22vw solid var(--color-secondary);
}
.event-card-detail {
	font-size: 0.71vw; /* 12px */
}
.event-card-detail dl {
	display: flex;
}
.event-card-detail-row1 dt,
.event-card-detail-row2 dt {
	width: 3.8vw;
}
.event-card-detail-row1 dd,
.event-card-detail-row2 dd {
	width: calc(100% - 3.8vw);
}
.event-card-detail-row3 dt {
	width: 4.6vw;
}
.event-card-detail-row3 dd {
	width: calc(100% - 4.6vw);
}
.event-card-detail dl + dl {
	margin-top: 0.5em;
}
.event-card-image {
	margin: 0.25vw 0;
}
.event-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.event-card-note {
	font-size: 0.71vw; /* 12px */
}
@media (max-width: 768px) {
	.event-cards {
		left: 33vw;
		width: 60vw;
		display: block;
	}
	.event-card {
		width: 100%;
		margin-top: 4vw!important;
		padding-top: 10.5vw;
		background: url("./img/event-card-bg-top-sp.png") left top no-repeat;
		background-size: 100% auto;
	}
	.event-card-bg {
		row-gap: 2vw;
		padding: 0 5vw 5vw;
		background: url("./img/event-card-bg-btm-sp.png") left bottom no-repeat, url("./img/event-card-bg-sp.png") left top repeat-y;
		background-size: 100% auto;
	}
	.event-card-label {
		position: absolute;
		left: 34.5vw;
		top: 4vw;
		width: auto;
		text-align: center;
	}
	.event-card-label img {
		height: 3.5vw;
		margin: 0 auto;
	}
	.event-card-title {
		font-size: 4vw;
		letter-spacing: 0.01em;
		line-height: 1.3;
	}
	.event-card-description {
		font-size: 3vw;
	}
	.event-card-image {
		border: 0.75vw solid var(--color-secondary);
	}
	.event-card-detail {
		font-size: 2.5vw;
		margin-top: 1vw;
	}
	.event-card-detail dl {
		display: block;
	}
	.event-card-detail-row1 dt,
	.event-card-detail-row2 dt {
		width: 100%;
	}
	.event-card-detail-row1 dd,
	.event-card-detail-row2 dd {
		width: 100%;
	}
	.event-card-detail-row3 dt {
		width: 100%;
	}
	.event-card-detail-row3 dd {
		width: 100%;
	}
	.event-card-detail dl + dl {
		margin-top: 1em;
	}
	.event-card-image {
		margin: 1vw 0 0;
	}
	.event-card-image img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.event-card-note {
		font-size: 2.5vw;
	}
}