@charset "UTF-8";

:root {
	--color-white: #fff;
	--color-white-rgb: 255, 255, 255;
	--color-violet: #4d54c9;
	--color-violet-rgb: 77, 84, 201;
	--color-pale-navy: #3b7bc7;
	--color-pale-navy-rgb: 59, 123, 199;
	--color-pale-blue: #4e89c2;
	--color-pale-blue-rgb: 78, 137, 194;
	--color-royal-blue: #365fc9;
	--color-royal-blue-rgb: 54, 95, 201;
	--color-violet-blue: #3f50cf;
	--color-violet-blue-rgb: 63, 80, 207;
	--color-tiffany-blue: #25b3d7;
	--color-tiffany-blue-rgb: 37, 179, 215;
	--color-navy-white: #dfe3ef;
	--color-navy-white-rgb: 223, 227, 239;
	--color-blue-white: #f4f6fc;
	--color-blue-white-rgb: 244, 246, 252;
	--color-blue-grey-light: #bdc1cd;
	--color-blue-grey-light-rgb: 189, 193, 205;
	--color-blue-grey-dark: #333;
	--color-blue-grey-dark-rgb: 51, 51, 51;
	--color-yellow-green: #b8e26f;
	--color-yellow-green-rgb: 184, 226, 111;
	--color-cobalt-green: #4dd38b;
	--color-cobalt-green-rgb: 77, 211, 139;
	--color-peacock-green: #0ca18d;
	--color-peacock-green-rgb: 12, 161, 141;
	--color-emerald: #30c898;
	--color-emerald-rgb: 48, 200, 152;
	--color-grass: #18a711;
	--color-grass-rgb: 24, 167, 17;
	--color-mint: #0f9b60;
	--color-mint-rgb: 15, 155, 96;
	--color-mint-white: #e1efea;
	--color-mint-white-rgb: 225, 239, 234;
	--color-green-white: #f3fcf9;
	--color-green-white-rgb: 243, 252, 249;
	--color-green-grey-light: #bdcdc2;
	--color-green-grey-light-rgb: 189, 205, 194;
	--color-green-grey-dark: #4c5650;
	--color-green-grey-dark-rgb: 76, 86, 80;
	--color-lavender: #9b87e6;
	--color-lavender-rgb: 155, 135, 230;
	--color-cherry: #eb64b4;
	--color-cherry-rgb: 235, 100, 180;
	--color-peach: #f0e3ea;
	--color-peach-rgb: 240, 227, 234;
	--color-peach-white: #fff7fb;
	--color-peach-white-rgb: 255, 247, 251;
	--color-cherry-red: #d03767;
	--color-cherry-red-rgb: 208, 55, 103;
	--color-ruby: #b82054;
	--color-ruby-rgb: 184, 32, 84;
	--color-rose: #cc4874;
	--color-rose-rgb: 204, 72, 116;
	--color-raspberry: #c841a1;
	--color-raspberry-rgb: 200, 65, 161;
	--color-pink-grey-light: #cdbdc6;
	--color-pink-grey-light-rgb: 205, 189, 198;
	--color-pink-grey-dark: #555053;
	--color-pink-grey-dark-rgb: 85, 80, 83;
}

body:where([data-theme=aqua]) {
	--color-bg: var(--color-white);
	--color-bg-rgb: var(--color-white-rgb);
	--color-bg-light: var(--color-blue-white);
	--color-bg-light-rgb: var(--color-blue-white-rgb);
	--color-bg-accent: var(--color-pale-navy);
	--color-bg-accent-rgb: var(--color-pale-navy-rgb);
	--color-text: var(--color-blue-grey-dark);
	--color-text-rgb: var(--color-blue-grey-dark-rgb);
	--color-text-accent: var(--color-royal-blue);
	--color-text-accent-rgb: var(--color-royal-blue-rgb);
	--color-text-contrast: var(--color-white);
	--color-text-contrast-rgb: var(--color-white-rgb);
	--color-gradation-primary-start: var(--color-tiffany-blue);
	--color-gradation-primary-start-rgb: var(--color-tiffany-blue-rgb);
	--color-gradation-primary-end: var(--color-pale-navy);
	--color-gradation-primary-end-rgb: var(--color-pale-navy-rgb);
	--color-gradation-secondary-start: var(--color-violet);
	--color-gradation-secondary-start-rgb: var(--color-violet-rgb);
	--color-gradation-secondary-end: var(--color-pale-navy);
	--color-gradation-secondary-end-rgb: var(--color-pale-navy-rgb);
	--color-gradation-tertiary-start: var(--color-pale-blue);
	--color-gradation-tertiary-start-rgb: var(--color-pale-blue-rgb);
	--color-gradation-tertiary-end: var(--color-violet-blue);
	--color-gradation-tertiary-end-rgb: var(--color-violet-blue-rgb);
	--color-shadow-light-side: var(--color-white);
	--color-shadow-light-side-rgb: var(--color-white-rgb);
	--color-shadow-dark-side: var(--color-blue-grey-light);
	--color-shadow-dark-side-rgb: var(--color-blue-grey-light-rgb);
}

:root {
	--font-base: "Noto Sans JP", sans-serif;
	--font-serif: "Noto Serif JP", serif;
	--font-alisha: "alisha", sans-serif;
	--font-number: "Source Code Pro", monospace;
	--font-icon: "icomoon";
	--font-size-xxs: 1rem;
	--font-size-xs: 1.2rem;
	--font-size-sm: 1.4rem;
	--font-size-md: 1.6rem;
	--font-size-lg: 1.8rem;
	--font-size-xl: 2.4rem;
	--font-size-xxl: 3.0rem;
	--font-size-xxxl: 3.6rem;
	--font-size-xxxxl: 4.8rem;
	--font-weight-regular: 400;
	--font-weight-medium: 500;
	--font-weight-semibold: 600;
	--font-weight-bold: 700;
}

:root {
	--ease-in-sine: cubic-bezier(0.47, 0, 0.745, 0.715);
	--ease-out-sine: cubic-bezier(0.39, 0.575, 0.565, 1);
	--ease-in-out-sine: cubic-bezier(0.445, 0.05, 0.55, 0.95);
	--ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
	--ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
	--ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
	--ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
	--ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
	--ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
	--ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
	--ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1);
	--ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);
	--ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
	--ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1);
	--ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1);
	--ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
	--ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
	--ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
	--ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335);
	--ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1);
	--ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86);
	--ease-in-back: cubic-bezier(0.6, -0.28, 0.735, 0.045);
	--ease-out-back: cubic-bezier(0.175, 0.885, 0.32, 1.275);
	--ease-in-out-back: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

html {
	font-size: 62.5%;
	scroll-behavior: smooth;
}

body {
	--main-column-width: clamp(375px, 33%, 450px);
	--follow-bar-height: 67px;
	--shadow-size-sm: 2.5px;
	--shadow-size-md: 5px;
	--shadow-size-lg: 10px;
	--shadow-light-side-sm: calc(var(--shadow-size-sm) * -1) calc(var(--shadow-size-sm) * -1) calc(var(--shadow-size-sm) * 2) calc(var(--shadow-size-sm) * 0.5) rgba(var(--color-shadow-light-side-rgb), 0.85);
	--shadow-dark-side-sm: var(--shadow-size-sm) var(--shadow-size-sm) calc(var(--shadow-size-sm) * 2) calc(var(--shadow-size-sm) * 0.5) rgba(var(--color-shadow-dark-side-rgb), 0.95);
	--shadow-light-side-md: calc(var(--shadow-size-md) * -1) calc(var(--shadow-size-md) * -1) calc(var(--shadow-size-md) * 2) calc(var(--shadow-size-md) * 0.5) rgba(var(--color-shadow-light-side-rgb), 0.85);
	--shadow-dark-side-md: var(--shadow-size-md) var(--shadow-size-md) calc(var(--shadow-size-md) * 2) calc(var(--shadow-size-md) * 0.5) rgba(var(--color-shadow-dark-side-rgb), 0.95);
	--shadow-light-side-lg: calc(var(--shadow-size-lg) * -1) calc(var(--shadow-size-lg) * -1) calc(var(--shadow-size-lg) * 2) calc(var(--shadow-size-lg) * 0.5) rgba(var(--color-shadow-light-side-rgb), 0.85);
	--shadow-dark-side-lg: var(--shadow-size-lg) var(--shadow-size-lg) calc(var(--shadow-size-lg) * 2) calc(var(--shadow-size-lg) * 0.5) rgba(var(--color-shadow-dark-side-rgb), 1);
	--box-shadow-in-sm: inset var(--shadow-light-side-sm), inset var(--shadow-dark-side-sm);
	--box-shadow-in-md: inset var(--shadow-light-side-md), inset var(--shadow-dark-side-md);
	--box-shadow-in-lg: inset var(--shadow-light-side-lg), inset var(--shadow-dark-side-lg);
	--box-shadow-out-sm: var(--shadow-light-side-sm), var(--shadow-dark-side-sm);
	--box-shadow-out-md: var(--shadow-light-side-md), var(--shadow-dark-side-md);
	--box-shadow-out-lg: var(--shadow-light-side-lg), var(--shadow-dark-side-lg);
	--radius-sm: 12px;
	--radius-md: 16px;
	--radius-lg: 20px;
	font-family: var(--font-base);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-regular);
	line-height: 1.7;
	color: var(--color-text);
	background: var(--color-bg);
	letter-spacing: 0.05em;
}

@media (max-width: 1240px) {
	body {
		--main-column-width: clamp(375px, 50%, 450px);
	}
}

@media (max-width: 720px) {
	body {
		--main-column-width: 100%;
	}
}

.wow {
	animation-duration: 1.15s;
	animation-delay: 0.1s;
	animation-fill-mode: forwards;
}

.wow.fadeIn {
	opacity: 0;
}

.slick-slide {
	outline: none;
}

.simplebar-content-wrapper {
	outline: none;
}

.c-anchor {
	--header-height: 0px;
	--anchor-space: 0px;
	padding-top: calc(var(--header-height) + var(--anchor-space));
	margin-top: calc((var(--header-height) + var(--anchor-space)) * -1);
}

.c-button-primary {
	position: relative;
	z-index: 0;
	display: block;
	padding: 0.9em 1em 0.7em;
	overflow: hidden;
	font-size: var(--font-size-md);
	line-height: 1;
	color: var(--color-text-contrast);
	text-align: center;
}

.c-button-primary::after {
	position: absolute;
	inset: 0;
	z-index: -2;
	content: "";
	background: #2497db;
}

.c-button-primary--square {
	aspect-ratio: 1/1;
	border-radius: var(--radius-md);
}

.c-list {
	--gradation-direction: to right;
	--gradation-color1: var(--color-gradation-secondary-start);
	--gradation-color2: var(--color-gradation-secondary-end);
	width: fit-content;
	line-height: 1.6;
}

.c-list--ordered {
	counter-reset: list;
}

.c-list__item {
	position: relative;
	padding-left: 1.7em;
}

.c-list__item:where(:nth-of-type(n + 2)) {
	margin-top: 0.25em;
}

.c-list__item::before {
	position: absolute;
	top: 0;
	left: 0;
	color: var(--gradation-color1);
}

:where(.c-list--dot > .c-list__item)::before {
	font-size: 1.25em;
	line-height: 1.35;
	content: "・";
}

:where(.c-list--ordered > .c-list__item) {
	counter-increment: list;
}

:where(.c-list--ordered > .c-list__item)::before {
	margin-left: 0.25em;
	line-height: 1.5;
	content: counter(list) ".";
}

:where(.c-list--check > .c-list__item)::before {
	font-family: var(--font-icon);
	font-size: 1.25em;
	line-height: 1.2;
	content: "\e919";
}

:where(.c-list--note > .c-list__item)::before {
	margin-left: 0.1em;
	font-size: 1.12em;
	line-height: 1.4;
	content: "※";
}

.c-list__text {
	display: block;
	color: transparent;
	background-image: linear-gradient(var(--gradation-direction), var(--gradation-color1), var(--gradation-color2));
	-webkit-background-clip: text;
	background-clip: text;
}

.c-heading-primary {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	margin-bottom: 20px;
}

.c-heading-primary--vertical {
	writing-mode: vertical-rl;
}

.c-heading-primary__text {
	--gradation-direction: to right;
	position: relative;
	line-height: 1;
}

.c-heading-primary__text--to-top {
	--gradation-direction: to top;
}

.c-heading-primary__text--to-left {
	--gradation-direction: to left;
}

.c-heading-primary__text--to-bottom {
	--gradation-direction: to bottom;
}

.c-heading-primary__text--en {
	z-index: 0;
	color: #2497db;
	font-size: 2.6rem;
	font-family: var(--font-alisha);
	line-height: 1;
}

.c-heading-primary__text--ja {
	position: relative;
	z-index: 1;
	display: inline-block;
	color: #1c3a5e;
	font-size: 2.6rem;
	font-weight: var(--font-weight-bold);
	line-height: 1.4;
	margin-top: 0.2em;
}

.c-history {
	max-width: 100%;
}

.c-history__year {
	padding-right: 1em;
	font-weight: var(--font-weight-medium);
	white-space: nowrap;
}

.c-image-card {
	overflow: hidden;
	background-color: var(--color-bg);
}

.c-image-card__image {
	width: 100%;
	height: auto;
}

.c-image-card__body {
	padding: 16px 22px 24px;
	background-color: rgba(var(--color-bg-light-rgb), 0.75);
}

.c-image-card__heading {
	margin-bottom: 0.2em;
	font-size: var(--font-size-lg);
	color: var(--color-text-accent);
	text-align: center;
}

.c-menu-list {
	--column-count: 2;
	display: grid;
	grid-template-columns: repeat(var(--column-count), 1fr);
	gap: calc(var(--shadow-size-md) * 4) calc(var(--shadow-size-md) * 3);
}

.c-menu-list__link {
	position: relative;
	display: flex;
	flex-wrap: nowrap;
	gap: 0.5em;
	align-items: center;
	min-height: 4.2em;
	padding: 0.65em;
	padding-right: 1em;
	background-color: var(--color-bg);
	border-radius: 10em;
	transition: all 0.35s;
}

.c-menu-list__link::before {
	position: absolute;
	inset: 0;
	z-index: 0;
	content: "";
	background-color: rgba(var(--color-bg-light-rgb), 0.5);
	border-radius: inherit;
}

.c-menu-list__icon {
	--icon-size: 1.35em;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--icon-size);
	height: var(--icon-size);
	font-size: 3.3rem;
	color: var(--color-text-contrast);
	background: linear-gradient(to right, var(--color-gradation-primary-start), var(--color-gradation-primary-end));
	border-radius: 50%;
}

.c-menu-list__text {
	position: relative;
	display: block;
	flex: 1;
	padding-left: 0.65em;
	margin-top: 0.2em;
	line-height: 1.3;
}

.c-menu-list__icon + .c-menu-list__text {
	padding-left: 0;
}

.c-paragraph {
	line-height: 1.85;
}

:where(.c-paragraph + .c-paragraph) {
	margin-top: 1em;
}

.c-step-list {
	--badge-width: 47px;
	--badge-y-gap: 10px;
	--badge-x-gap: 16px;
	--border: linear-gradient(to bottom, var(--color-gradation-secondary-start), var(--color-gradation-secondary-start));
	counter-reset: step-list;
	container-type: inline-size;
}

.c-step-list__item {
	position: relative;
	z-index: 1;
	counter-increment: step-list;
}

@container (width <=360px) {
	.c-step-list__item {
		--badge-width: 37px;
	}
}

.c-step-list__header {
	position: relative;
	display: flex;
	flex-wrap: nowrap;
	gap: var(--badge-x-gap);
	align-items: center;
	padding: 12px 0;
}

.c-step-list__header::before {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: var(--badge-width);
	height: var(--badge-width);
	padding-top: 0.15em;
	font-size: calc(var(--badge-width) * 0.46);
	line-height: 1;
	color: var(--color-text-contrast);
	text-align: center;
	content: counter(step-list);
	background-image: linear-gradient(to right, var(--color-gradation-secondary-start), var(--color-gradation-secondary-end));
	border-radius: 50%;
}

.c-step-list__header::after {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: var(--badge-width);
	content: "";
	background-repeat: no-repeat;
	background-size: 1px calc(50% - (var(--badge-width) / 2 + var(--badge-y-gap)));
}

.c-step-list__item:first-of-type .c-step-list__header::after {
	background-image: var(--border);
	background-position: center bottom;
}

.c-step-list__item:last-of-type .c-step-list__header::after {
	background-image: var(--border);
	background-position: center top;
}

.c-step-list__item:not(:first-of-type, :last-of-type) .c-step-list__header::after {
	background-image: var(--border), var(--border);
	background-position: center top, center bottom;
}

.c-step-list__heading {
	position: relative;
	flex: 1;
	padding-top: 0.1em;
	font-size: var(--font-size-lg);
	line-height: 1.5;
	color: var(--color-text-accent);
}

.c-step-list__image {
	display: block;
	aspect-ratio: 1/0.65;
	margin-bottom: 24px;
	object-fit: cover;
}

.c-step-list__body {
	position: relative;
	padding-left: calc(var(--badge-width) + var(--badge-x-gap));
}

.c-step-list__item:not(:last-of-type) .c-step-list__body {
	padding-bottom: 16px;
}

.c-step-list__item:not(:last-of-type) .c-step-list__body::after {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	z-index: 0;
	width: var(--badge-width);
	content: "";
	background-image: var(--border);
	background-repeat: no-repeat;
	background-position: center;
	background-size: 1px 100%;
}

.c-table {
	--padding: var(--container-padding);
	--border-color: rgba(var(--color-text-accent-rgb), 0.35);
	--scroll-bar-height: 12px;
	max-width: 100%;
	padding: calc(var(--shadow-size-md) * 3) 0 calc(var(--shadow-size-md) * 3 + var(--scroll-bar-height));
	overflow: scroll;
	-webkit-mask-image: linear-gradient(to right, transparent, #000 var(--padding), #000 calc(100% - var(--padding)), transparent), linear-gradient(to top, #000 var(--scroll-bar-height), transparent var(--scroll-bar-height));
	mask-image: linear-gradient(to right, transparent, #000 var(--padding), #000 calc(100% - var(--padding)), transparent), linear-gradient(to top, #000 var(--scroll-bar-height), transparent var(--scroll-bar-height));
}

.c-table__inner {
	width: fit-content;
	padding: 0 var(--padding);
}

.c-table__content {
	position: relative;
	width: fit-content;
	min-width: 100%;
	padding: 1em;
	background-color: rgba(var(--color-bg-light-rgb), 0.5);
}

.c-table__content > table {
	min-width: 100%;
}

.c-table__content > table > thead > tr > th {
	padding: 1em;
}

.c-table__content > table > thead > tr > th > span {
	display: block;
	width: fit-content;
	min-width: 8.75em;
	min-height: 2.25em;
	padding: 0.35em 1.5em 0.2em;
	margin-right: auto;
	margin-left: auto;
	font-size: var(--font-size-md);
	color: var(--color-text-contrast);
	text-align: center;
	background-image: linear-gradient(to right, var(--color-gradation-secondary-start), var(--color-gradation-secondary-end));
}

.c-table__content > table > tbody > tr > th,
.c-table__content > table > tbody > tr > td {
	border-top: 1px solid var(--border-color);
}

.c-table__content > table > tbody > tr > th {
	min-width: 7em;
	padding: 1em;
	font-size: var(--font-size-md);
	color: var(--color-text-accent);
	white-space: nowrap;
	vertical-align: middle;
}

.c-table__content > table > tbody > tr > td {
	min-width: 16em;
	padding: 1em 1.75em;
}

.c-tel-link {
	display: flex;
	gap: 0.25em;
	align-items: flex-end;
	justify-content: center;
	width: fit-content;
	font-size: 3.1rem;
	line-height: 1;
	color: var(--color-text-accent);
	transition: opacity 0.2s;
}

.c-tel-link::before {
	margin-bottom: 0.12em;
	font-size: 0.72em;
	content: "Tel.";
}

.c-tel-link:hover {
	opacity: 0.8;
}

.c-term-list {
	--separator-color: rgba(var(--color-text-rgb), 0.35);
	display: grid;
	gap: 0;
}

.c-term-list__item {
	position: relative;
	display: flex;
	flex-wrap: nowrap;
	gap: 0.45em;
}

.c-term-list__item::after {
	flex-shrink: 0;
	order: 2;
	width: 1.15em;
	height: 1.5em;
	content: "";
	background-image: linear-gradient(to left, var(--separator-color), var(--separator-color) 100%);
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 100% 1px;
}

.c-term-list__term {
	flex-shrink: 0;
	order: 1;
	width: var(--term-width, 4em);
	color: var(--color-text-accent);
	text-align-last: justify;
}

.c-term-list__description {
	flex-shrink: 1;
	order: 3;
}

.c-text-link {
	text-decoration: underline;
	text-underline-offset: 0.15em;
	transition: opacity 0.2s;
}

.c-text-link:hover {
	opacity: 0.7;
}

.c-two-column {
	--wrapper-padding: var(--container-padding);
	display: grid;
	gap: 72px;
}

.c-two-column__item {
	--invisible-width: 8.5%;
	--negative-margin: calc((var(--invisible-width) + var(--wrapper-padding)) * -1);
	--image-width: 1.05fr;
	display: grid;
	gap: 6%;
}

.c-two-column__item:nth-child(odd) {
	grid-template-areas: "sub main";
	grid-template-columns: var(--image-width) 1fr;
	margin-left: var(--negative-margin);
}

.c-two-column__item:nth-child(even) {
	grid-template-areas: "main sub";
	grid-template-columns: 1fr var(--image-width);
	margin-right: var(--negative-margin);
}

.c-two-column__main {
	grid-area: main;
}

.c-two-column__sub {
	grid-area: sub;
}

.c-two-column__heading {
	position: relative;
	padding-bottom: 0.5em;
	margin-bottom: 1em;
	font-size: var(--font-size-md);
}

.c-two-column__heading::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	content: "";
	background-image: linear-gradient(to right, var(--color-gradation-primary-start), var(--color-gradation-primary-end));
}

:root {
	--container-padding: 19px;
	--container-padding-md: 38px;
}

@media (min-width: 450px) and (max-width: 720px) {
	:root {
		--container-padding: 8vw;
		--container-padding-md: 16vw;
	}
}

.l-container {
	padding-right: var(--container-padding);
	padding-left: var(--container-padding);
}

.l-container--md {
	padding-right: var(--container-padding-md);
	padding-left: var(--container-padding-md);
}

:root {
	--follow-z-index: 100;
}

.l-follow {
	--menu-button-width: min(25cqw, 110px);
	container-type: inline-size;
	position: fixed;
	bottom: 0;
	z-index: 1;
	width: var(--main-column-width);
}

@media (min-width: 1240.02px) {
	.l-follow {
		left: 50%;
		transform: translateX(-50%);
	}
}

@media (max-width: 1240px) {
	.l-follow {
		right: 0;
	}
}

.l-follow__list {
	position: relative;
	z-index: 2;
	display: flex;
	flex-wrap: nowrap;
	width: fit-content;
	max-width: 100%;
	margin-left: auto;
	overflow: hidden;
}

.l-follow__item {
	container-type: inline-size;
	flex: 1;
	width: 225px;
}

@media (max-width: 720px) {
	.l-follow__item {
		width: 50vw;
	}
}

.l-follow__button {
	color: var(--color-white);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 100%;
	height: var(--follow-bar-height);
	line-height: 1;
	white-space: nowrap;
}

.l-follow__box {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
}

.l-follow__button.is-tel {
	background: #15b593;
}

.l-follow__button.is-web {
	background: #ed9b49;
}

.l-follow__icon-tel {
	width: 16px;
}

.l-follow__icon-time {
	width: 27px;
}

.l-follow__text {
	font-size: 2.2rem;
}

.l-follow__button.is-tel .l-follow__text {
	font-family: "Times New Roman", var(--font-serif);
	font-weight: var(--font-weight-regular);
	letter-spacing: 0;
}

.l-follow__button.is-web .l-follow__text {
	font-family: var(--font-serif);
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.1em;
}

.l-follow__button small {
	font-size: 1rem;
}

.l-follow__menu {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 1;
	opacity: 0;
}

.l-follow__menu-button {
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 4;
	width: 60px;
	aspect-ratio: 1/1;
	overflow: hidden;
}

.l-footer {
	background: linear-gradient(to right, #e4feff 0%, #c4f5ff 100%);
}

.l-footer__main {
	padding-top: 40px;
}

.l-footer__to-top {
	display: block;
	width: fit-content;
	max-width: 288px;
	margin: auto;
}

.l-footer__logo {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.l-footer__side {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.l-footer__address {
	display: block;
	margin-top: 20px;
	font-size: 2rem;
}

.l-footer__schedule {
	margin-top: 30px;
}

.l-footer__banner {
	margin-top: 30px;
}

.l-footer__map {
	margin-top: 30px;
	height: 205px;
}

.l-footer__map > iframe {
	width: 100%;
	height: 100%;
}

.l-footer__sns-list {
	display: flex;
	gap: 0.75em;
	justify-content: center;
	margin-top: 30px;
	font-size: 3.4rem;
}

.l-footer__sns-link {
	--size: 1.7em;
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: var(--size);
	height: var(--size);
	padding: 0 !important;
	font-size: inherit !important;
	border-radius: 50%;
}

.l-footer__copyright {
	display: block;
	padding-top: 1em;
	padding-bottom: calc(var(--follow-bar-height) + 1em);
	color: var(--color-text-contrast);
	text-align: center;
	background-color: #1c3a5e;
}

.l-gallery {
	width: calc(50vw - 225px);
	height: 100%;
	margin: auto;
	overflow: hidden;
}

.l-gallery .slick-list,
.l-gallery .slick-track {
	width: 100%;
	height: 100%;
}

.l-gallery__item {
	width: 100%;
	height: 100%;
	position: relative;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}

.l-gallery__item:nth-child(1) {
	background-image: url(../images/common/gallery01.jpg);
}


.l-gallery__item:nth-child(2) {
	background-image: url(../images/common/gallery02.jpg);
}


.l-gallery__item:nth-child(3) {
	background-image: url(../images/common/gallery03.jpg);
}

.l-gallery__item:nth-child(4) {
	background-image: url(../images/common/gallery04.jpg);
}

.l-gallery__item:nth-child(5) {
	background-image: url(../images/common/gallery05.jpg);
}

.l-gallery__item::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.4);
}

:root {
	--header-height: 94px;
}

.l-header {
	width: 100%;
	height: 60px;
	display: flex;
	align-items: center;
	position: fixed;
	top: 0;
	z-index: 3;
	transition: ease 0.3s;
}

body.is-active .l-header {
	background: rgba(255, 255, 255, 0.8);
}

.l-header__inner {
	padding: 0 70px 0 10px;
}

.l-header__heading {
	position: absolute;
	top: 70px;
	left: 10px;
	right: 10px;
	font-size: var(--font-size-xxs);
	line-height: 1.4;
	z-index: 1;
    text-shadow: 0px 0px 2px #ffffff, 0px 0px 2px #ffffff, 0px 0px 2px #ffffff, 0px 0px 2px #ffffff, 0px 0px 2px #ffffff;
}

.l-header__to-top {
	display: block;
	max-width: 207px;
}

.l-header__logo {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.l-header__site {
	color: var(--color-white);
	font-size: 0.8rem;
	font-weight: var(--font-weight-medium);
	text-align: center;
	display: block;
	width: 135px;
    background: #2497db;
    margin: 0 13px 0 auto;
}

.l-info {
	position: sticky;
	top: 0;
	left: 0;
	height: 100vh;
}

.l-info .simplebar-content {
	height: 100%;
}

.l-info__inner {
	display: flex;
	flex-direction: column;
	gap: 20px;
	align-items: center;
	justify-content: center;
	max-width: 380px;
	min-height: 100%;
	padding: 24px 0;
	margin-right: auto;
	margin-left: auto;
	container-type: inline-size;
}

.l-info__to-top {
	display: block;
	width: 100%;
	margin: 0 auto;
}

.l-info__logo {
	display: block;
	height: 100%;
	object-fit: contain;
}

.l-info__site {
    color: var(--color-white);
    font-size: 1.6rem;
    font-weight: var(--font-weight-medium);
    text-align: center;
    display: block;
    background: #2497db;
    margin: 15px auto 0;
}

.l-info__address {
	font-size: var(--font-size-md);
	text-align: center;
}

.l-info__tel {
	font-size: 4.3rem;
	font-family: var(--font-serif);
	font-weight: var(--font-weight-bold);
	line-height: 1;
	white-space: nowrap;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
}

.l-info__tel i {
	display: flex;
	align-items: center;
}

.l-info__tel i img {
	width: 30px;
}

.l-info__grid {
	display: grid;
	gap: 20px;
	width: 100%;
}

.l-info__reservation {
	width: 100%;
}

.l-info__reservation .l-reservation__buttons {
	display: grid;
	gap: calc(var(--shadow-size-md) * 3);
	justify-content: unset;
}

.l-info__reservation .l-reservation__button {
	width: 100%;
	max-width: unset;
	aspect-ratio: initial;
	container-type: inline;
}

.l-info__reservation .l-reservation__button--tel.c-button-primary::after {
	background: #15b593;
}

.l-info__reservation .l-reservation__button--web.c-button-primary::after {
	background: #ed9b49;
}

.l-info__reservation .l-reservation__button-inner {
	display: grid;
	grid-template-areas: "icon heading body";
	grid-template-rows: auto;
	grid-template-columns: auto 1fr 1fr;
	gap: min(16px, 2.5cqw);
	align-items: center;
	height: unset;
	min-height: 4.5em;
	padding: 0.85em 0.35em 0.75em;
	font-size: min(var(--font-size-md), 5cqw);
	word-break: keep-all;
}

.l-info__reservation .l-reservation__icon-container {
	container-type: unset;
	grid-area: icon;
	height: fit-content;
	margin-left: 3.5cqw;
}

.l-info__reservation .l-reservation__icon--tel {
	width: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.l-info__reservation .l-reservation__icon--tel img {
	width: 20px;
}

.l-info__reservation .l-reservation__icon--time img {
	width: 30px;
}

.l-info__reservation .l-reservation__heading {
	display: flex;
	flex-direction: column;
	grid-area: heading;
	gap: 6px;
	font-size: min(2.2rem, 6.5cqw);
}

.l-info__reservation .l-reservation__heading__tel-number {
	display: block;
	font-size: min(1.65rem, 5cqw);
	font-family: "Times New Roman", var(--font-serif);
	font-weight: var(--font-weight-regular);
	letter-spacing: 0;
}

.l-info__reservation .l-reservation__heading--web {
	font-family: var(--font-serif);
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.1em;
}

.l-info__reservation .l-reservation__body {
	grid-area: body;
}

.l-info__reservation .l-reservation__text--sm {
	font-size: min(1.3rem, 4.25cqw);
}

.l-info__reservation .l-reservation__text--xs {
	font-size: min(1.1rem, 3cqw);
}

.l-info__schedule {
	width: 100%;
	background-color: var(--color-white);
}

.l-info__sns {
	display: flex;
	gap: 0.75em;
	justify-content: center;
	margin-top: 10px;
	font-size: 3.4rem;
}

.l-info__sns__item > a {
	--size: 1.7em;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--size);
	height: var(--size);
	padding: 0;
	font-size: inherit;
	border-radius: 50%;
}

.l-main {
	overflow: hidden;
}

.l-menu-button {
	position: fixed;
	top: 0;
	right: calc(50vw - 225px);
	width: 60px;
	aspect-ratio: 1/1;
	color: var(--color-text-contrast);
	background: #2497db;
}

@media (max-width: 1240px) {
	.l-menu-button {
		right: 0;
	}
}

.l-menu-button__inner {
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.l-menu-button__inner--close > * {
	opacity: 0;
}

.l-menu-button__icon--list {
	width: 30px;
}

.l-menu-button__icon--close {
	width: 27px;
}

.l-menu {
	--menu-bg-color: var(--color-bg-light);
	--fade-height: 42px;
	position: relative;
	width: 100%;
	height: 100vh;
	height: 100dvh;
}

.l-menu::before {
	position: absolute;
	inset: 0;
	z-index: -1;
	content: "";
	background: var(--color-white);
}

.l-menu .simplebar-content-wrapper {
	overscroll-behavior: contain;
}

.l-menu__inner {
	position: relative;
	display: grid;
	grid-template-rows: auto 1fr;
	height: 100%;
}

.l-menu__to-top {
	display: contents;
}

.l-menu__body {
	position: relative;
	overflow: hidden;
}

.l-menu__scroll-area {
	--padding-width: var(--container-padding);
	position: relative;
	height: 100%;
	padding-top: var(--fade-height);
	padding-bottom: calc(var(--menu-button-width) * 1.28);
	-webkit-mask-image: linear-gradient(to top, transparent, transparent var(--follow-bar-height), #000 calc(var(--follow-bar-height) + var(--fade-height)), #000 calc(100% - var(--fade-height)), transparent), linear-gradient(to left, #000 var(--padding-width), transparent var(--padding-width));
	mask-image: linear-gradient(to top, transparent, transparent var(--follow-bar-height), #000 calc(var(--follow-bar-height) + var(--fade-height)), #000 calc(100% - var(--fade-height)), transparent), linear-gradient(to left, #000 var(--padding-width), transparent var(--padding-width));
	-webkit-mask-repeat: no-repeat, no-repeat;
	mask-repeat: no-repeat, no-repeat;
	-webkit-mask-position: 0 0, 100% 0;
	mask-position: 0 0, 100% 0;
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
}

.l-menu__content {
	width: 100%;
	max-width: 380px;
	height: 100%;
	margin-right: auto;
	margin-left: auto;
}

.l-menu__nav {
	margin-top: 30px;
}

.l-menu__list {
	display: grid;
	gap: 1.2em;
	font-size: var(--font-size-lg);
}

.l-menu__link {
	position: relative;
	display: block;
	padding-bottom: 0.65em;
	line-height: 1.3;
}

.l-menu__link::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	content: "";
	background: #adadad;
}

.l-menu__text {
	display: inline-block;
	color: var(--color-text);
	background-image: linear-gradient(to right, var(--color-gradation-secondary-start), var(--color-gradation-secondary-end));
	-webkit-background-clip: text;
	background-clip: text;
}

.l-menu__submenu {
	--link-padding: 0.6em;
	--line-height: 1.35;
	display: grid;
	grid-template-columns: calc(50% - 1em) 1fr;
	gap: 0 0.5em;
	padding-left: 2px;
	margin-top: 1em;
	margin-bottom: 0.5em;
	font-size: var(--font-size-sm);
	line-height: var(--line-height);
}

.l-menu__submenu__item {
	display: flex;
	gap: 0.5em;
}

.l-menu__submenu__item::before {
	flex-shrink: 0;
	width: 0.5em;
	height: calc(1em * var(--line-height) + var(--link-padding) * 2);
	content: "";
	background-image: linear-gradient(to right, var(--color-gradation-secondary-start), var(--color-gradation-secondary-end));
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 100% 1.5px;
}

.l-menu__submenu__link {
	display: block;
	flex: 1;
	padding: var(--link-padding) 0;
}

.l-menu__submenu__text {
	display: inline-block;
	color: var(--color-text);
	background-image: linear-gradient(to right, var(--color-gradation-secondary-start), var(--color-gradation-secondary-end));
	-webkit-background-clip: text;
	background-clip: text;
	transition: all 0.2s;
}

.l-menu__submenu__link:hover .l-menu__submenu__text {
	color: transparent;
}

.l-menu__schedule {
	margin-top: 30px;
}

.l-menu__sns {
	display: flex;
	gap: 0.75em;
	justify-content: center;
	margin-top: 30px;
	font-size: 3.4rem;
}

.l-menu__sns__item > a {
	--size: 1.7em;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--size);
	height: var(--size);
	padding: 0;
	font-size: inherit;
	border-radius: 50%;
}

.l-mv__visual {
	display: block;
	height: 100%;
}

.l-mv__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
}

.l-nap__standard__list {
	--prefix: "・";
	--row-gap: 0;
	--padding: 1.3em;
}

.l-nap__standard__item {
	position: relative;
	padding-left: var(--padding);
}

.l-nap__standard__item::before {
	position: absolute;
	top: 0;
	left: 0;
	content: var(--prefix);
}

.l-nap__standard__link {
	display: block;
	width: fit-content;
	margin-top: 0.75em;
}

.l-reservation__buttons {
	--column-count: 2;
	--gap: var(--shadow-size-md) * 4;
	display: flex;
	flex-wrap: wrap;
	gap: calc(var(--gap));
	justify-content: center;
}

.l-reservation__button {
	width: calc((100% - var(--gap) * (var(--column-count) - 1)) / var(--column-count));
	max-width: 205px;
	padding: 0 !important;
	text-align: center;
	container-type: inline-size;
}

.l-reservation__button-inner {
	display: grid;
	grid-template-rows: auto 1fr auto;
	grid-template-columns: 1fr;
	gap: 3.5cqw;
	align-items: center;
	height: 100%;
	padding: 0.85em 0.5em 0.75em;
	font-size: 9.5cqw;
}

.l-reservation__heading {
	font-size: 1.275em;
}

.l-reservation__heading__tel-number {
	display: none;
}

.l-reservation__icon-container {
	display: flex;
	height: 100%;
	aspect-ratio: 1/1;
	margin: auto;
	container-type: inline-size;
}

.l-reservation__icon {
	display: block;
}

.l-reservation__body {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 4.5cqw;
	line-height: 1.3;
}

.l-reservation__text--sm {
	font-size: min(15px, 8cqw);
}

.l-reservation__text--xs {
	font-size: min(13px, 6.5cqw);
}

.l-schedule__table {
	width: 100%;
	border-collapse: collapse;
}

.l-schedule__table thead {
	border-bottom: 1px solid #adadad;
}

.l-schedule__table th,
.l-schedule__table td {
	font-weight: var(--font-weight-regular);
	padding: 0.2em 0.1em;
	border-bottom: 1px solid #adadad;
}

.l-schedule__table th:first-child,
.l-schedule__table td:first-child {
	white-space: nowrap;
}

.l-schedule__table th:not(:first-child),
.l-schedule__table td:not(:first-child) {
	width: 8.75%;
	text-align: center;
}

.l-schedule__note-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25em 1em;
	justify-content: flex-start;
	margin-top: 1em;
	line-height: 1.3;
}

.l-schedule__note {
	display: flex;
	flex-wrap: nowrap;
}

.l-schedule__note-name {
	font-weight: var(--font-weight-regular);
	white-space: nowrap;
}

.l-schedule__note-name::after {
	content: "：";
}

.l-top {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: calc(var(--follow-z-index) - 1);
	display: block;
	line-height: 1;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: #2497db;
}

@media (max-width: 1240px) {
	.l-top {
		right: 10px;
		bottom: calc(var(--follow-bar-height) + 10px);
	}
}

.l-top__inner {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 10px;
}

.l-top__icon {
	background: var(--color-white);
	height: calc(tan(60deg) * 10px / 2);
	width: 10px;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.l-top__text {
	color: var(--color-white);
	font-size: var(--font-size-xs);
	font-weight: var(--font-weight-bold);
}

.l-wrapper {
	position: relative;
	display: grid;
	grid-template-areas: "left center right";
	grid-template-columns: 1fr var(--main-column-width) 1fr;
	margin-right: auto;
	margin-left: auto;
}

@media (max-width: 1240px) {
	.l-wrapper {
		grid-template-areas: "left center";
		grid-template-columns: 1fr var(--main-column-width);
	}
}

@media (max-width: 720px) {
	.l-wrapper {
		grid-template-areas: "center";
		grid-template-columns: var(--main-column-width);
	}
}

.l-wrapper__left {
	position: sticky;
	top: 0;
	z-index: 0;
	grid-area: left;
	height: 100vh;
}

@media (max-width: 720px) {
	.l-wrapper__left {
		display: none;
	}
}

.l-wrapper__right {
	position: sticky;
	top: 0;
	z-index: 1;
	grid-area: right;
	height: 100vh;
}

@media (max-width: 1240px) {
	.l-wrapper__right {
		display: none;
	}
}

.l-wrapper__center {
	position: relative;
	z-index: 1;
	grid-area: center;
	min-height: 100vh;
}

.scroll-hint-shadow-wrap:has(.scroll-hint.is-left-scrollable)::before,
.scroll-hint-shadow-wrap.is-left-scrollable::before {
	display: none;
}

.scroll-hint-shadow-wrap:has(.scroll-hint.is-right-scrollable)::after,
.scroll-hint-shadow-wrap.is-right-scrollable::after {
	display: none;
}

#link01,
#link02,
#link03,
#link04,
#link05,
#link06,
#link07,
#link08,
#link09,
#link10,
#link11,
#link12,
#link13{
	margin-top: -60px;
	padding-top: 60px;
}
