/* --------------------------------------------------------------------------------
reset
-------------------------------------------------------------------------------- */

*,
*::before,
*::after {
	box-sizing: border-box;
	font: inherit;
	border: none;
	margin: 0px;
	padding: 0px;
}
html {
	-webkit-text-size-adjust: none;
	-webkit-tap-highlight-color: transparent;
}
a {
	text-decoration: none;
	color: inherit;
}
ul,
ol {
	list-style: none;
}
table {
	border-collapse: collapse;
}
iframe,
img,
svg,
video {
	display: block;
}
img {
	max-width: 100%;
	height: auto;
}



/* --------------------------------------------------------------------------------
essential
-------------------------------------------------------------------------------- */

html {
	font-size: 16px;
}
body {
	text-align: justify;
	overflow-wrap: break-word;
	font-family: YakuHanMP, "Noto Serif JP", sans-serif;
	font-size: 1rem;
	font-weight: 600;
	font-feature-settings: "palt";
	line-height: 1.875rem;
	color: #000000;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
a.underline {
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.1em;
}
a.color {
	transition: 0.25s color ease;
}
a.color:hover {
	color: #808080;
}
h1 {
	font-size: 1.5rem;
	line-height: 2.25rem;
}
h2 {
	font-size: 1.375rem;
}
h3 {
	font-size: 1.25rem;
}
h4,
h5,
h6 {
	font-size: 1rem;
}
p.note {
	font-size: 0.8125rem;
	line-height: 1.25rem;
}
p:empty:before {
	content: none;
}
span.required {
	color: #ff0000;
}
*.indent {
	text-indent: -1em;
	padding-left: 1em;
}



/* --------------------------------------------------------------------------------
icon
-------------------------------------------------------------------------------- */

@font-face {
	font-family: "icon";
	src: url("../fonts/icon.woff") format("woff");
	font-weight: normal;
	font-style: normal;
}
i.icon {
	font-family: "icon";
	line-height: 1em;
}
i.icon-logo::before {
	content: "\e900";
}
i.icon-instagram::before {
	content: "\e901";
}



/* --------------------------------------------------------------------------------
misc
-------------------------------------------------------------------------------- */

br.small {
	display: none;
}
br.large {
	display: inline;
}
img.small {
	display: none;
}
img.large {
	display: block;
}
hr {
	height: 0px;
	border: none;
	border-bottom: 1px solid #cccccc;
	margin: 20px 0px;
}
iframe:where([src*="youtube.com"], .wp-embedded-content),
video {
	width: 100%;
}
iframe[src*="youtube.com"],
video {
	aspect-ratio: 16 / 9;
	height: auto;
}
mark {
	margin: 0px 5px;
	padding: 0px 5px;
	background-color: #f5f5f5;
	border-radius: 2.5px;
}



/* --------------------------------------------------------------------------------
page
-------------------------------------------------------------------------------- */

div#page {
	position: relative;
	overflow: hidden;
}
div#trigger {
	position: absolute;
	top: 50svh;
	pointer-events: none;
}
p.button-default,
p.button-default > * {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
p.button-default {
	text-align: center;
	line-height: 1.25rem;
}
p.button-default > *,
p.button-default > * > * {
	position: relative;
}
p.button-default > * {
	align-items: center;
	width: 240px;
	height: 50px;
	border: 1px solid #000000;
	border-radius: 25px;
	transition: 0.25s color ease, 0.25s background-color ease;
}
p.button-default > *:hover {
	color: #ffffff;
	background-color: #000000;
}
p.image {
	overflow: hidden;
}
p.image img {
	width: 100%;
}
p.image-zoom img {
	transition: 0.375s transform ease;
}
a:hover p.image-zoom img,
p.image-zoom a:hover img {
	transform: scale(1.0375);
}
*.scroll:where(.fade, .fade-slide, .fade-zoom, .fade-bounce),
*.scroll:where(.fade-each, .fade-each-slide, .fade-each-zoom, .fade-each-bounce) > * {
	opacity: 0;
	transition-duration: 1.25s;
}
*.scroll:where(.fade, .fade-slide, .fade-zoom, .fade-bounce).active,
*.scroll:where(.fade-each, .fade-each-slide, .fade-each-zoom, .fade-each-bounce).active > * {
	opacity: 1;
}
*.scroll.fade,
*.scroll.fade-each > * {
	transition-property: opacity;
	transition-timing-function: ease-in-out;
}
*.scroll.fade-slide,
*.scroll.fade-each-slide > * {
	transition-property: opacity, transform;
	transition-timing-function: ease-in-out, ease;
}
*.scroll.fade-slide-left,
*.scroll.fade-each-slide-left > * {
	transform: translate(40px, 0px);
}
*.scroll.fade-slide-right,
*.scroll.fade-each-slide-right > * {
	transform: translate(-40px, 0px);
}
*.scroll.fade-slide-up,
*.scroll.fade-each-slide-up > * {
	transform: translate(0px, 40px);
}
*.scroll.fade-slide-down,
*.scroll.fade-each-slide-down > * {
	transform: translate(0px, -40px);
}
*.scroll.fade-slide.active,
*.scroll.fade-each-slide.active > * {
	transform: translate(0px, 0px);
}
*.scroll:where(.fade-zoom, .fade-bounce),
*.scroll:where(.fade-each-zoom, .fade-each-bounce) > * {
	transition-property: opacity, transform;
}
*.scroll:where(.fade-zoom, .fade-bounce).active,
*.scroll:where(.fade-each-zoom, .fade-each-bounce).active > * {
	transform: scale(1);
}
*.scroll.fade-zoom,
*.scroll.fade-each-zoom > * {
	transition-timing-function: ease-in-out, ease;
	transform: scale(0.875);
}
*.scroll.fade-zoom.active,
*.scroll.fade-each-zoom.active > *,
*.scroll.fade-bounce.active,
*.scroll.fade-each-bounce.active > * {
	transform: scale(1);
}
*.scroll.fade-bounce,
*.scroll.fade-each-bounce > * {
	transition-timing-function: ease-in-out, linear(0, 0.016, 0.063 9.1%, 0.25, 0.563, 1, 0.813 45.5%, 0.766, 0.75, 0.766, 0.813 63.6%, 1 72.7%, 0.953, 0.938, 0.953, 1, 0.984, 1);
	transform: scale(0.75);
}
*.split-text {
	opacity: 0;
}
html.active *.split-text {
	opacity: 1;
}
*.split-text > * {
	display: inline-block;
}
*.delay-01 {
	transition-delay: calc(0.125s * 1);
}
*.delay-02 {
	transition-delay: calc(0.125s * 2);
}
*.delay-03 {
	transition-delay: calc(0.125s * 3);
}
*.delay-04 {
	transition-delay: calc(0.125s * 4);
}
*.delay-05 {
	transition-delay: calc(0.125s * 5);
}
*.delay-06 {
	transition-delay: calc(0.125s * 6);
}
*.delay-07 {
	transition-delay: calc(0.125s * 7);
}
*.delay-08 {
	transition-delay: calc(0.125s * 8);
}
*.delay-09 {
	transition-delay: calc(0.125s * 9);
}
*.delay-10 {
	transition-delay: calc(0.125s * 10);
}



/* --------------------------------------------------------------------------------
header
-------------------------------------------------------------------------------- */

header#header {
	position: relative;
	z-index: 100;
}
header#header :where(*#logo, p#button-instagram, nav#navi) {
	position: fixed;
	color: #ffffff;
}
div.header header#header :where(*#logo, p#button-instagram, nav#navi) {
	color: #000000;
}
header#header *#logo {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
	height: 100px;
	left: 0px;
	top: 0px;
	font-size: 2.75rem;
	font-weight: 400;
	padding-left: 70px;
	transition: 0.25s color ease, 0.25s background-color ease;
}
body.admin-bar header#header *#logo {
	top: 32px;
}
div.header header#header *#logo {
	background-color: #ffffff;
}
header#header :where(p#button-instagram, nav#navi) {
	top: 35px;
}
body.admin-bar header#header :where(p#button-instagram, nav#navi) {
	top: 67px;
}
header#header p#button-instagram {
	right: 80px;
	font-size: 1.75rem;
	font-weight: 400;
}
header#header div#menu p:where(.logo, .instagram, .button-default) {
	display: none;
}
header#header div#menu nav#navi {
	right: 150px;
}
header#header div#menu nav#navi ul {
	display: flex;
	flex-wrap: wrap;
}
header#header div#menu nav#navi ul li:not(:last-child) {
	margin-right: 40px;
}
header#header div#menu nav#navi ul li a:hover {
	color: #ffffff80;
}
div.header header#header div#menu nav#navi ul li a:hover {
	color: #808080;
}



/* --------------------------------------------------------------------------------
cover
-------------------------------------------------------------------------------- */

div:where(#cover, #space-cover) {
	height: 100svh;
}
div#cover {
	position: fixed;
	width: 100%;
	left: 0px;
	top: 0px;
	z-index: 1;
}
body.admin-bar div:where(#cover, #space-cover) {
	height: calc(100svh - 32px);
}
body.admin-bar div#cover {
	top: 32px;
}
div#cover div.image,
div#cover div.text :where(div.navi, p.logo, p.button-scroll) {
	opacity: 0;
	transition: 1.25s opacity ease-in-out;
}
html.active div#cover div.image,
html.active div#cover div.text :where(div.navi, p.logo, p.button-scroll) {
	opacity: 1;
}
div#cover div:where(.image, .text),
div#cover div.image p.row {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0px;
	top: 0px;
}
html.active div#cover div.image::before {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0px;
	top: 0px;
	z-index: 5;
	background-color: #0000002d;
	content: "";
}
div.main div#cover div.image {
	visibility: hidden;
}
div#cover div.image p.row img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
div#cover div.text {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	z-index: 5;
	color: #ffffff;
}
div#cover div.text :where(div.navi, p.button-scroll) {
	position: absolute;
	transition-delay: 1.25s;
}
div#cover div.text div.navi {
	height: calc(1.625rem * 11);
	left: 80px;
	top: calc(50% - calc(calc(1.625rem * 11) * 0.5));
}
div#cover div.text div.navi ul li {
	position: relative;
	font-size: 0.8125rem;
	line-height: 1.625rem;
	cursor: pointer;
	padding-left: 20px;
}
div#cover div.text div.navi ul li::before {
	position: absolute;
	width: 10px;
	height: 10px;
	left: 0px;
	top: calc(50% - 5px);
	background-color: #ffffff;
	content: "";
	transition: 0.25s transform ease;
	clip-path: polygon(6.7% 25%, 50% 0%, 93.3% 25%, 93.3% 75%, 50% 100%, 6.7% 75%);
}
div#cover div.text div.navi ul li:hover::before,
div#cover div.text div.navi ul li.active::before {
	transform: scale(1.75);
}
div#cover div.text div.navi ul li span {
	display: block;
	opacity: 0;
	transition: 0.25s opacity ease;
}
div#cover div.text div.navi ul li:hover span,
div#cover div.text div.navi ul li.active span {
	opacity: 1;
}
div#cover div.text p.logo {
	width: 250px;
	transition-delay: 0.5s;
}
div#cover div.text p.logo svg {
	width: 100%;
}
div#cover div.text p.logo svg path {
	fill: #ffffff !important;
}
div#cover div.text p.button-scroll {
	width: 80px;
	left: calc(50% - 40px);
	bottom: 40px;
	text-align: center;
	font-size: 0.8125rem;
	font-weight: 400;
	line-height: 1.25rem;
}
div#cover div.text p.button-scroll a {
	display: block;
	position: relative;
	padding-bottom: 25px;
}
div#cover div.text p.button-scroll a:hover {
	color: #ffffff80;
}
div#cover div.text p.button-scroll a::before {
	position: absolute;
	width: 25px;
	height: 25px;
	left: calc(50% - 12.5px);
	bottom: 10px;
	border-right: 1px solid #ffffff;
	border-bottom: 1px solid #ffffff;
	content: "";
	transition: 0.25s border-color ease;
	transform: rotate(45deg);
	animation: button-scroll 3.75s linear infinite forwards;
}
div#cover div.text p.button-scroll a:hover::before {
	border-color: #ffffff80;
}
@keyframes button-scroll {
	0% { transform: translateY(0px) rotate(45deg); }
	50% { transform: translateY(10px) rotate(45deg); }
	100% { transform: translateY(0px) rotate(45deg); }
}



/* --------------------------------------------------------------------------------
main
-------------------------------------------------------------------------------- */

main,
main section,
main section div.inner-section {
	position: relative;
}
main {
	position: relative;
	z-index: 1;
}
main section header h2 {
	font-size: 2.25rem;
	line-height: 2.25rem;
	margin-bottom: 5px;
}
main section header p.sub {
	font-size: 1.125rem;
}
main ul.bullet li {
	position: relative;
	padding-left: 20px;
}
main ul.bullet li::before {
	position: absolute;
	width: 6px;
	height: 6px;
	left: 4px;
	top: 13px;
	background-color: #000000;
	content: "";
	border-radius: 50%;
}
main ol.decimal {
	padding-left: 20px;
}
main ol.decimal li {
	list-style-type: decimal;
}

/* home
-------------------------------------------------------------------------------- */

main section div.inner-section {
	position: relative;
	margin: 0px auto;
}
main section#commitment {
	color: #ffffff;
}
main section#commitment div.inner-section {
	padding-top: 25svh;
}
main section#commitment div.text {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	height: 125svh;
	min-height: 480px;
	opacity: 0;
}
main section#commitment div.text div.inner-text,
main section#commitment div.text div.description {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
}
main section#commitment div.text div.inner-text {
	position: relative;
}
main section#commitment div.text div#anchor-commitment {
	position: absolute;
	top: -160px;
}
main section#commitment div.text h2,
main section#commitment div.text div.description p.row {
	writing-mode: vertical-rl;
	white-space: pre;
}
main section#commitment div.text h2 {
	font-size: 2.25rem;
	margin-left: 60px;
}
main section#commitment div.text div.description p.row:not(:last-child) {
	margin-left: 20px;
}
main section#commitment div.text div.description-small {
	display: none;
}
main section:where(#news, #information) {
	background-color: #e6e6e6;
}
main section:where(#news, #information) div.inner-section {
	padding: 160px 0px;
}
main section#news div#trigger-header {
	position: absolute;
	top: -100px;
}
main section#news div.inner-section {
	width: calc(100% - 160px);
	max-width: 1000px;
	padding-left: 240px;
}
main section#news header {
	position: absolute;
	left: 0px;
	top: 155px;
}
main section#menu-alternate {
	background-color: #ffffff;
}
main section#menu-alternate div.block {
	position: relative;
	padding-left: 50%;
}
main section#menu-alternate div.block div.fix {
	position: absolute;
	width: 50%;
	height: 100%;
	left: 0px;
	top: 0px;
}
main section#menu-alternate div.block div.fix div.inner-fix {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0px;
	top: 0px;
	clip-path: inset(0px);
}
main section#menu-alternate div.block div.fix div.inner-fix p.image {
	position: fixed;
	width: 50%;
	height: 100svh;
	left: 0px;
	bottom: 0px;
}
main section#menu-alternate div.block div.fix div.inner-fix p.image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
main section#menu-alternate div.block div.text {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	max-width: 740px;
	min-height: 100svh;
	padding: 80px;
}
main section#menu-alternate div.block div.text div.inner-text {
	width: 100%;
}
main section#menu-alternate div.block div.text h2 {
	font-size: 1.625rem;
	line-height: 2.25rem;
	border-bottom: 1px solid #000000;
	margin-bottom: 40px;
	padding-bottom: 20px;
}
main section#menu-alternate div.block div.text div.segment {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	position: relative;
	line-height: 1.5rem;
	padding: 10px 0px;
}
main section#menu-alternate div.block div.text div.segment:not(:last-child) {
	margin-bottom: 20px;
}
main section#menu-alternate div.block div.text div.segment::before {
	position: absolute;
	width: 0px;
	height: 100%;
	left: 160px;
	top: 0px;
	border-right: 1px solid #000000;
	content: "";
}
main section#menu-alternate div.block div.text div.segment h3 {
	width: 160px;
	font-size: 1rem;
}
main section#menu-alternate div.block div.text div.segment h3 span {
	font-size: 0.8125rem;
}
main section#menu-alternate div.block div.text div.segment div.list {
	width: calc(100% - 200px);
}
main section#menu-alternate div.block div.text div.segment div.list div.row {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
main section#menu-alternate div.block div.text div.segment div.list div.row:not(:last-child) {
	margin-bottom: 10px;
}
main section#menu-alternate div.block div.text div.segment div.list div.row p.price {
	margin-left: auto;
}
main section#information div.inner-section {
	width: calc(100% - 160px);
	max-width: 1480px;
}
main section#information header {
	text-align: center;
	margin-bottom: 60px;
}
main section#information div.image-text,
main section#information div.image-text div.text {
	display: flex;
	flex-wrap: wrap;
}
main section#information div.image-text :where(p.image, div.text) {
	width: 50%;
}
main section#information div.image-text p.image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
main section#information div.image-text div.text {
	align-items: center;
	padding: 80px;
	background-color: #ffffff;
}
main section#information div.image-text div.text :where(h3, div.list) {
	margin-bottom: 40px;
}
main section#information div.image-text div.text h3 {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
main section#information div.image-text div.text h3 span {
	display: block;
}
main section#information div.image-text div.text h3 span.main {
	font-size: 1.375rem;
	margin-right: 20px;
}
main section#information div.image-text div.text h3 span.sub {
	font-size: 1.125rem;
}
main section#information div.image-text div.text div.list div.row {
	display: flex;
	flex-wrap: wrap;
	text-align: left;
}
main section#information div.image-text div.text div.list div.row p.label {
	width: 85px;
}
main section#information div.image-text div.text div.list div.row p.body {
	width: calc(100% - 85px);
}
main section#information div.image-text div.text div.list div.row p.body span {
	display: flex;
	flex-wrap: wrap;
}
main section#information div.image-text div.text div.list div.row p.body span i {
	display: block;
}
main section#information div.image-text div.text div.list div.row p.body span i:nth-child(1) {
	width: 70px;
}
main section#information div.image-text div.text div.list div.row p.body span i:nth-child(2) {
	width: calc(100% - 70px);
}

/* news
-------------------------------------------------------------------------------- */

main div.list-news div.row {
	line-height: 1.5rem;
}
main div.list-news div.row a {
	display: flex;
	flex-wrap: wrap;
	border-bottom: 1px solid #000000;
	padding: 40px 20px;
}
main div.list-news div.row a[href="javascript:;"] {
	pointer-events: none;
	cursor: default;
}
main div.list-news div.row:first-child a {
	border-top: 1px solid #000000;
}
main div.list-news div.row p.created {
	width: 140px;
	font-weight: 400;
}
main div.list-news div.row h3 {
	width: calc(100% - 140px);
	font-size: 1rem;
}



/* --------------------------------------------------------------------------------
footer
-------------------------------------------------------------------------------- */

footer#footer,
footer#footer div.inner-footer {
	position: relative;
}
footer#footer {
	z-index: 1;
	color: #ffffff;
	background: url(../images/footer-image.jpg) no-repeat center;
	background-size: cover;
}
footer#footer::before {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0px;
	top: 0px;
	background-color: #0000002d;
	content: "";
}
footer#footer a:hover {
	color: #ffffff80;
}
footer#footer div.inner-footer {
	padding: 160px 0px 60px 0px;
}
footer#footer p.logo {
	width: 250px;
	margin: 0px auto;
}
footer#footer p.logo svg {
	width: 100%;
}
footer#footer p.logo svg path {
	fill: #ffffff !important;
}
footer#footer div.list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: calc(100% - 160px);
	max-width: 1480px;
	margin: -300px auto 80px auto;
}
footer#footer div.list div.row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: calc(50% - 205px);
	height: 300px;
	border-top: 1px solid #ffffff;
	border-bottom: 1px solid #ffffff;
}
footer#footer div.list div.row div.inner-row {
	width: 100%;
}
footer#footer div.list div.row-information :where(h3, p.address) {
	margin-bottom: 20px;
}
footer#footer div.list div.row-information h3 {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
footer#footer div.list div.row-information h3 span {
	display: block;
}
footer#footer div.list div.row-information h3 span.main {
	font-size: 1.375rem;
	margin-right: 20px;
}
footer#footer div.list div.row-information h3 span.sub {
	font-size: 1.125rem;
}
footer#footer div.list div.row-information p.instagram {
	font-size: 1.75rem;
	font-weight: 400;
}
footer#footer div.list div.row-contact p.button-default:not(:last-child) {
	margin-bottom: 20px;
}
footer#footer div.list div.row-contact p.button-default a {
	color: #ffffff;
	border-color: #ffffff;
}
footer#footer div.list div.row-contact p.button-default a:hover {
	color: #000000;
	background-color: #ffffff;
}
footer#footer p.copyright {
	text-align: center;
	font-size: 0.8125rem;
	font-weight: 400;
	line-height: 1.25rem;
}