@charset "utf-8";
:root {
	--c-primary: #fdf2b4;
	--c-secondary: #f4c017;
	--c-accent: #f86f19;
	--c-light: #f2f2f2;
	--c-l-gray: #d8d8d8;
	--c-m-gray: #999;
	--c-d-gray: #666;
	--c-bk: #1d1d1d;
	--c-white: #fff;
	--c-text: #5a4620;
	--c-bg: #fffbf2;
	--font-base: "Zen Old Mincho", serif;
	--font-en: "EB Garamond", serif;
}

*,
::before,
::after {
	box-sizing: border-box;
	border-width: 0;
	border-style: solid;
}
html {
	font-size: 15px;
	line-height: 1.6;
	tab-size: 4;
	color: var(--c-text);
	font-family: var(--font-base);
	font-feature-settings: normal;
	font-variation-settings: normal;
	letter-spacing: 0.05em;
	font-weight: var(--fw-medium);
	scroll-behavior: smooth;
	background-color: var(--c-bg);
}

body {
	margin: 0;
	line-height: inherit;
}

hr {
	height: 0;
	color: inherit;
	border-top-width: 1px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: inherit;
	font-weight: inherit;
}

a {
	color: inherit;
	text-decoration: inherit;
	user-select: none;
}
label {
	user-select: none;
}

b,
strong {
	font-weight: bolder;
}

small {
	font-size: 80%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

table {
	text-indent: 0;
	border-color: inherit;
	border-collapse: collapse;
}

button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	font-weight: inherit;
	line-height: inherit;
	color: inherit;
	margin: 0;
	padding: 0;
}

button,
select {
	text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
	background-color: transparent;
	background-image: none;
}

:-moz-focusring {
	outline: auto;
}

:-moz-ui-invalid {
	box-shadow: none;
}

th,
td {
	width: 41%;
	text-align: left;
	font-weight: inherit;
}
blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
	margin: 0;
}

fieldset {
	margin: 0;
	padding: 0;
}

legend {
	padding: 0;
}

ol,
ul,
menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

textarea {
	resize: vertical;
}

input::-moz-placeholder,
textarea::-moz-placeholder {
	opacity: 1;
	color: var(--c-dark);
}

input::placeholder,
textarea::placeholder {
	opacity: 1;
	color: var(--c-dark);
}

button,
[role="button"] {
	cursor: pointer;
}

:disabled {
	cursor: default;
}

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
	display: block;
	vertical-align: middle;
}

img,
video {
	max-width: 100%;
	height: auto;
}
[x-cloak] {
	display: none !important;
}
.not-scroll {
	touch-action: none;
	overflow: hidden;
}
.no-scroll-bar::-webkit-scrollbar {
	display: none;
}
::-webkit-scrollbar {
	width: 0px;
	height: 0px;
}

::-webkit-scrollbar-thumb {
	background-color: rgba(197, 197, 197, 0.55);
	border-radius: 5px;
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.3);
}

::-webkit-scrollbar-track {
	border-radius: 10px;
	box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.1);
}

.sp {
	display: none;
}
@media screen and (max-width: 768px) {
	.pc {
		display: none;
	}
	.sp {
		display: inline;
	}
}

/* ------------------------------------------------------------
common layout
---------------------------------------------------------------*/

main {
	width: 100%;
	overflow: hidden;
}
main > .c-sec {
	width: 100%;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	overflow: hidden;
}
main > .c-sec > * {
	width: 100%;
	height: 100%;
}
main > .c-sec > * > img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.mv {
	aspect-ratio: 1400 / 869;
}
.sec-1 {
	aspect-ratio: 1400 / 879;
}
.sec-2 {
	aspect-ratio: 1400 / 2359;
}
.sec-3 {
	aspect-ratio: 1400 / 1072;
}
.sec-4 {
	aspect-ratio: 1400 / 806;
}
.sec-5 {
	aspect-ratio: 1400 / 1146;
}
.sec-6 {
	aspect-ratio: 1400 / 1109;
}
.sec-7 {
	aspect-ratio: 1400 / 839;
}

footer {
	width: 100%;
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	background: var(--c-primary);
	font-family: var(--font-en);
	letter-spacing: 0.05em;
	font-weight: 400;
}

@media screen and (max-width: 768px) {
	main {
		max-width: 500px;
		margin-inline: auto;
	}
	.mv {
		aspect-ratio: 800 / 1599;
	}
	.sec-1 {
		aspect-ratio: 800 / 1946;
	}
	.sec-2 {
		aspect-ratio: 800 / 5751;
	}
	.sec-3 {
		aspect-ratio: 800 / 1754;
	}
	.sec-4 {
		aspect-ratio: 800 / 2181;
	}
	.sec-5 {
		aspect-ratio: 800 / 1834;
	}
	.sec-6 {
		aspect-ratio: 800 / 1277;
	}
	.sec-7 {
		aspect-ratio: 800 / 2155;
	}

	footer {
		font-size: 13px;
	}
}
