@charset "UTF-8";

:root {
	--margin-fill: clamp(-85px, calc(-50vw + 524px - 24px), -24px);
}

.hero {
	display: flex;
	align-items: center;
	padding-top: 135px;
}

.hero_col {
}

.hero_col.-main {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 80px;
	width: 37.5%;
	padding-bottom: 90px;
}

.hero_col.-img {
	flex: 1;
	padding-top: 40px;
}

.hero_logo {
}

.hero_sub {
}

.hero_info {
	display: flex;
	justify-content: center;
	font-size: 12px;
	font-family: var(--ff-mont);
}

.hero_info > li {
}

.hero_info > li:not(:first-child)::before {
	content: "/";
	display: inline-block;
	padding: 0 0.5em;
}

.hero_main {
	margin-top: 12px;
}

body.-load .hero_main::after {
	opacity: 0;
}

.hero_main > img {
	width: 100%;
	height: auto;
	min-height: 540px;
	object-fit: cover;

	object-position: left;
}

.about {
	margin-top: 150px;
}

.about_row {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: flex-start;
}

.about_cnt {
	display: flex;
	gap: 75px;
}

.about_ttl {
	padding-top: 0.3em;
	font-weight: 500;
	font-size: 17px;
	font-family: var(--ff-mont);
	letter-spacing: 0.08em;
}

.about_text {
	line-height: 2.3125;
	word-break: auto-phrase;
}

.about_dog {
}

.about_dog > img:hover {
	animation: piko 0.5s ease-in-out infinite;
}

@keyframes piko {
	0%,
	100% {
		rotate: 0deg;
	}

	50% {
		rotate: 3deg;
	}
}

.about_img {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 100px;
	margin: 150px var(--margin-fill) 0;
}

.about_img_col {
}

.about_img_col.-main {
}

.about_img_col.-sub {
	display: flex;
	flex-direction: column;
	gap: 50px;
}

.about_img_illust {
}

.about_img_sub {
}

.price {
	margin-top: 150px;
}

.price_row {
	display: grid;
	grid-template-columns: 1fr 0.64fr;
	gap: 90px;
}

.price_col {
}

.price_col.-price {
}

.price_col.-option {
}

.price_ttl {
	font-weight: 500;
	font-size: 17px;
	font-family: var(--ff-mont);
	letter-spacing: 0.08em;
}

.price_tbl {
	width: 100%;
	margin-top: 65px;
	font-size: 15px;
}

.price_tbl thead tr > * {
	padding: 0 12px 15px;
	font-size: 15px;
	line-height: 1;
	font-family: var(--ff-mont);
}

.price_tbl tbody tr > * {
	padding: 14px 12px;
	border-top: 1px solid var(--color-border);
}

.price_tbl tbody tr.-spacer > * {
	padding-top: 24px;
	border-top: none;
}

.price_tbl tbody tr > th {
	word-break: auto-phrase;
}

.price_tbl tbody tr > td {
	font-size: 13px;
}

.price_tbl tbody tr > td span.-price {
	font-size: 15px;
	font-family: var(--ff-mont);
	letter-spacing: 0.08em;
	white-space: nowrap;
}

.price_list {
	margin-top: 50px;
}

.price_img {
	position: relative;
	margin-top: 120px;
	padding-bottom: 110px;
}

.price_img_main {
}

.price_img_sub {
	position: absolute;
	right: 0;
	bottom: 0;
}

.access {
	margin-top: 150px;
}

.access_row {
	display: flex;
	gap: 90px;
}

.access_col {
}

.access_col.-main {
	flex: 0.5423;
}

.access_col.-img {
	display: flex;
	flex: 1;
	flex-direction: row;
	justify-content: space-between;
	align-items: flex-end;
	gap: 65px;
}

.access_ttl {
	font-weight: 500;
	font-size: 17px;
	line-height: 1;
	font-family: var(--ff-mont);
	letter-spacing: 0.08em;
}

.access_info {
	display: grid;
	gap: 1em;
	margin-top: 50px;
	font-size: 14px;
}

.access_info > dl {
	display: flex;
}

.access_info > dl > dt {
	width: 11em;
}

.access_info > dl > dd {
	flex: 1;
}

.access_regist {
	margin-top: 45px;
	padding-top: 45px;
	border-top: 1px solid var(--color-border);
	font-size: 14px;
}

.access_regist_ttl {
}

.access_regist_info {
	display: grid;
	gap: 0.4em;
	margin-top: 18px;
	font-size: 12px;
}

.access_regist_info > dl {
	display: flex;
}

.access_regist_info > dl > dt {
}

.access_regist_info > dl > dt::after {
	content: "：";
}

.access_regist_info > dl > dd {
	flex: 1;
}

.access_img {
	flex: 0.6268;
}

.access_map {
	flex: 1;
	height: 100%;
}

.access_map > iframe {
	width: 100%;
	height: 100%;
}

.reserve {
	margin-top: 160px;
}

.reserve_row {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: flex-end;
	gap: 95px;
	margin-left: var(--margin-fill);
}

.reserve_col {
}

.reserve_col.-main {
}

.reserve_col.-img {
}

.reserve_ttl {
	font-weight: 500;
	font-size: 17px;
	line-height: 1;
	font-family: var(--ff-mont);
	letter-spacing: 0.08em;
}

.reserve_tel {
	margin-top: 60px;
}

.reserve_tel > a {
	display: inline-block;
	position: relative;
	padding: 5px 0 ;
	font-weight: 500;
	font-size: 21px;
	line-height: 1;
	font-family: var(--ff-mont);
	letter-spacing: 0.08em;
}

.reserve_tel > a::after {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background: var(--color-text);
	transform-origin: left;
	transition: transform 0.3s;
}

.reserve_tel > a:hover::after {
	transform: scaleX(0%);
	transform-origin: right;
}

.reserve_list {
	margin-top: 50px;
}

.reserve_img {
}

@media screen  and (min-width:1440px) {
	:root {
		--margin-fill: calc(-25vw + 262px - 24px);
	}

	.about_img_col {
	}

	.about_img_col.-main {
		flex: 1;
	}

	.about_img_col.-sub {
		flex: 0.47;
	}

	.about_img_col.-main > img,
	.about_img_sub > img {
		width: 100%;
	}

	.about_img_illust > img {
		min-width: 71.5%;
	}

	.reserve_col.-main {
		flex: 1;
	}

	.reserve_col.-img {
		flex: 0.7;
	}

	.reserve_img {
	}

	.reserve_img > img {
		width: 100%;
	}
}

@media screen and (min-width:768px) and (max-width:991.98px) {
	.hero {
		padding-top: 80px;
	}

	.hero_col {
	}

	.hero_col.-main {
	}

	.hero_col.-img {
	}

	.hero_logo {
		width: 110px;
	}

	.hero_sub {
		width: 140px;
	}

	.hero_info {
		font-size: 11px;
	}

	.hero_info > li {
	}

	.hero_info > li:not(:first-child)::before {
	}

	.hero_main {
	}

	body.-load .hero_main::after {
	}

	.hero_main > img {
		min-height: 360px;
	}

	.about {
		margin-top: 70px;
	}

	.about_row {
		justify-content: flex-start;
		align-items: flex-end;
		gap: 60px;
	}

	.about_cnt {
		flex-direction: column;
		gap: 35px;
	}

	.about_ttl {
	}

	.about_text {
		font-size: 14px;
	}

	.about_dog {
		width: 210px;
	}

	.about_img {
		gap: 60px;
		margin: 70px 0;
	}

	.about_img_col {
	}

	.about_img_col.-main {
	}

	.about_img_col.-sub {
	}

	.about_img_illust {
	}

	.about_img_sub {
	}

	.price {
		margin-top: 100px;
	}

	.price_row {
		gap: 60px;
	}

	.price_col {
	}

	.price_col.-price {
	}

	.price_col.-option {
	}

	.price_ttl {
	}

	.price_tbl {
		margin-top: 41px;
		font-size: 13px;
	}

	.price_tbl thead tr > * {
	}

	.price_tbl tbody tr > * {
	}

	.price_tbl tbody tr.-spacer > * {
	}

	.price_tbl tbody tr > th {
	}

	.price_tbl tbody tr > td {
	}

	.price_tbl tbody tr > td.-mobile-nowrap {
		white-space: nowrap;
	}

	.price_tbl tbody tr > td span.-price {
		font-size: 12px;
	}

	.price_list {
	}

	.price_img {
		padding-bottom: 90px;
	}

	.price_img_main {
	}

	.price_img_sub {
		width: 120px;
	}

	.access {
		margin-top: 20px;
	}

	.access_row {
		gap: 50px;
	}

	.access_col {
	}

	.access_col.-main {
		flex: 0.9;
	}

	.access_col.-img {
		justify-content: flex-end;
		gap: 30px;
	}

	.access_ttl {
	}

	.access_info {
	}

	.access_info > dl {
	}

	.access_info > dl > dt {
	}

	.access_info > dl > dd {
	}

	.access_regist {
	}

	.access_regist_ttl {
	}

	.access_regist_info {
	}

	.access_regist_info > dl {
	}

	.access_regist_info > dl > dt {
	}

	.access_regist_info > dl > dt::after {
	}

	.access_regist_info > dl > dd {
	}

	.access_img {
		width: 250px;
	}

	.access_map {
		/* aspect-ratio: 3/4; */
		height: auto;
	}

	.access_map > iframe {
		height: auto;
		aspect-ratio: 3 / 4;
	}

	.reserve {
		margin-top: 100px;
	}

	.reserve_row {
		gap: 60px;
	}

	.reserve_col {
	}

	.reserve_col.-main {
	}

	.reserve_col.-img {
	}

	.reserve_ttl {
	}

	.reserve_tel {
	}

	.reserve_tel > a {
	}

	.reserve_tel > a::after {
	}

	.reserve_tel > a:hover::after {
	}

	.reserve_list {
	}

	.reserve_img {
	}
}

@media screen and (max-width:767.98px) {
	.hero {
		flex-direction: column;
		gap: 50px;
		padding-top: 100px;
	}

	.hero_col {
	}

	.hero_col.-main {
		gap: 47px;
		width: 100%;
		padding-bottom: 0;
		text-align: center;
	}

	.hero_col.-img {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 15px;
		padding-top: 0;
	}

	.hero_logo {
		display: inline-block;
		max-width: 28%;
	}

	.hero_sub {
		max-width: 40%;
	}

	.hero_info {
		font-size: min(2.5vw,10px);
	}

	.hero_info > li {
	}

	.hero_info > li:not(:first-child)::before {
	}

	.hero_main {
		margin-top: 0;
	}

	.hero_main > img {
		min-height: auto;
	}

	.about {
		margin-top: 60px;
	}

	.about_row {
		flex-direction: column;
		align-items: flex-end;
		gap: 30px;
	}

	.about_cnt {
		flex-direction: column;
		gap: 20px;
	}

	.about_ttl {
		font-size: 16px;
	}

	.about_text {
		font-size: 13px;
	}

	.about_dog {
		max-width: 50%;
		text-align: right;
	}

	.about_img {
		flex-direction: column;
		gap: 24px;
		margin: 40px 0 0;
	}

	.about_img_col {
	}

	.about_img_col.-main {
	}

	.about_img_col.-sub {
		flex-direction: row-reverse;
		align-items: flex-end;
		gap: 20px;
	}

	.about_img_illust {
	}

	.about_img_sub {
	}

	.price {
		margin-top: 90px;
	}

	.price_row {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.price_col {
	}

	.price_col.-price {
	}

	.price_col.-option {
	}

	.price_ttl {
		font-size: 16px;
	}

	.price_tbl {
		margin-top: 20px;
		font-size: 12px;
	}

	.price_tbl thead tr > * {
		padding: 0 4px 15px;
		font-size: 13px;
		text-align: center;
	}

	.price_tbl tbody tr > * {
		padding: 12px 4px;
	}

	.price_tbl tbody tr.-spacer > * {
	}

	.price_tbl tbody tr > th {
		font-size: 13px;
	}

	.price_tbl tbody tr > td {
		font-size: 12px;
	}

	.price_tbl tbody tr > td.-mobile-nowrap {
		white-space: nowrap;
	}

	.price_tbl tbody tr > td span.-price {
		font-size: 12px;
	}

	.price_list {
		margin-top: 40px;
	}

	.price_img {
		margin-top: 50px;
		padding-bottom: 50px;
	}

	.price_img_main {
		padding-right: 50px;
		text-align: right;
	}

	.price_img_sub {
		max-width: 110px;
	}

	.access {
		margin-top: 40px;
	}

	.access_row {
		flex-direction: column;
		gap: 60px;
	}

	.access_col {
	}

	.access_col.-main {
	}

	.access_col.-img {
		gap: 24px;
	}

	.access_ttl {
		font-size: 16px;
	}

	.access_info {
	}

	.access_info > dl {
	}

	.access_info > dl > dt {
	}

	.access_info > dl > dd {
	}

	.access_regist {
		padding-top: 35px;
	}

	.access_regist_ttl {
		font-size: 14px;
	}

	.access_regist_info {
		margin-top: 15px;
	}

	.access_regist_info > dl {
	}

	.access_regist_info > dl > dt {
	}

	.access_regist_info > dl > dt::after {
	}

	.access_regist_info > dl > dd {
	}

	.access_img {
		max-width: 70%;
	}

	.access_map {
	}

	.access_map > iframe {
		height: auto;
		aspect-ratio: 3/4;
	}

	.reserve {
		margin-top: 90px;
	}

	.reserve_row {
		flex-direction: column;
		gap: 50px;
		margin-left: 0;
	}

	.reserve_col {
	}

	.reserve_col.-main {
	}

	.reserve_col.-img {
		width: 100%;
		text-align: center;
	}

	.reserve_ttl {
		font-size: 16px;
	}

	.reserve_tel {
		margin-top: 36px;
	}

	.reserve_tel > a {
		font-size: 20px;
	}

	.reserve_tel > a::after {
	}

	.reserve_tel > a:hover::after {
	}

	.reserve_list {
		margin-top: 40px;
		word-break: auto-phrase;
	}

	.reserve_img {
	}
}

body.-error {
	background: url("../img/space.jpg") center;
	color: #ffffff;
}

.error {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100vh;
}

.error_ttl {
	font-weight: bold;
	font-size: 50px;
	line-height: 1.5;
	font-family: var(--ff-mont);
}

.error_text {
	margin-top: 20px;
	font-weight: bold;
}

.error_dog {
	margin-top: 60px;
}

.error_dog a {
	display: inline-block;
}

.error_dog a:hover {
	animation: kuru linear 5s infinite;
}

.error_dog img {
	display: inline-block;
	animation: kuru linear 5s infinite;
}

@keyframes kuru {
	0% {
		rotate: 0deg;
	}

	100% {
		rotate: -360deg;
	}
}
