@charset "utf-8";

/* ===================================================
	Reset
====================================================== */
#customer_header *,
#customer_footer * {
	box-sizing: content-box;
}
#customer_header h1,
#customer_header h2,
#customer_header h3,
#customer_header h4,
#customer_header h5,
#customer_header h6,
#customer_footer h1,
#customer_footer h2,
#customer_footer h3,
#customer_footer h4,
#customer_footer h5,
#customer_footer h6 {
	margin: 0;
}
#customer_header ul,
#customer_header ol,
#customer_header li,
#customer_footer ul,
#customer_footer ol,
#customer_footer li {
	padding: 0;
	margin: 0;
	list-style-type: none;
}
#customer_header dl,
#customer_footer dl {
	padding: 0;
	margin: 0;
}
#customer_header p,
#customer_footer p {
	padding: 0;
	margin: 0;
}

/* ===================================================
	Custom CSS
	※ 予約番自体のコンテンツに影響するのを避けるため、
	　必ず #customer_header または #customer_footer からの継承で記述してください。
====================================================== */
/* color setting */
:root {
	--color-txt: rgba(0, 0, 0, 0.5);
	--color-bd: rgba(0, 0, 0, 0.15);
	--color-bg01: #f6f6f6;
	--color-bg01-hover: #eee;
	--color-bg02: #ebebeb;
	--color-bg02-hover: #ddd;
}

/* style */
#customer_header,
#customer_footer {
	font-family: "Yu Mincho", YuMincho, "Hiragino Mincho ProN", serif;
	font-size: 14px;
	font-weight: normal;
	line-height: 1.8;
	color: #000;
	background: #fff;
	-webkit-text-size-adjust: 100%;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizelegibility;
}
#customer_header header,
#customer_header nav,
#customer_footer footer,
#customer_header div,
#customer_footer div,
#customer_header p,
#customer_footer p,
#customer_header ul,
#customer_footer ul,
#customer_header li,
#customer_footer li,
#customer_header dl,
#customer_header dt,
#customer_header dd,
#customer_header span,
#customer_footer span,
#customer_header a,
#customer_footer a {
	box-sizing: border-box;
}
#customer_header a,
#customer_footer a {
	color: #000;
	text-decoration: none;
	outline: none;
	transition: opacity 0.5s;
}
#customer_header img,
#customer_footer img {
	max-width: 100%;
	height: auto;
}
#customer_header .br_pc,
#customer_footer .br_pc,
#customer_header .view_pc,
#customer_footer .view_pc {
	display: none;
}

@media screen and (orientation: landscape) {
	body {
		width: 100%;
	}
}
@media screen and (hover: hover) and (min-width: 769px) {
	#customer_header a:hover,
	#customer_footer a:hover {
		opacity: 0.6;
	}
}
@media screen and (min-width: 769px) {
	#customer_header,
	#customer_footer {
		min-width: 1200px;
		font-size: 16px;
	}
	#customer_header .br_sp,
	#customer_footer .br_sp,
	#customer_header .view_sp,
	#customer_footer .view_sp {
		display: none !important;
	}
	#customer_header .br_pc,
	#customer_footer .br_pc,
	#customer_header span.view_pc,
	#customer_footer span.view_pc {
		display: inline;
	}
	#customer_header .view_pc,
	#customer_footer .view_pc {
		display: block;
	}
}

/* Base Layout
------------------------------------------------------ */
/* ボタン色 */
#customer_header .cmn_btn_reserve,
#customer_footer .cmn_btn_reserve {
	color: #fff;
	background: #87546a;
	transition: background 0.5s;
}
#customer_header .cmn_btn_daytrip,
#customer_footer .cmn_btn_daytrip {
	color: #6e4d5b;
	background: #dcc8d1;
	transition: background 0.5s;
}

@media screen and (hover: hover) and (min-width: 769px) {
	#customer_header .cmn_btn_reserve:hover,
	#customer_footer .cmn_btn_reserve:hover {
		background: #683d50;
		opacity: 1;
	}
	#customer_header .cmn_btn_daytrip:hover,
	#customer_footer .cmn_btn_daytrip:hover {
		background: #c7afba;
		opacity: 1;
	}
}

/* 文字色 */
#customer_header .cmn_clr_gry,
#customer_footer .cmn_clr_gry {
	color: var(--color-txt);
}

/* 外部アイコン付きリンク */
#customer_header .cmn_link_external,
#customer_footer .cmn_link_external {
	display: inline-flex;
	gap: 0 5px;
	align-items: center;
}
#customer_header .cmn_link_external::after,
#customer_footer .cmn_link_external::after {
	width: 18px;
	height: 18px;
	content: "";
	background: url(../img/icon_site.svg) no-repeat center center;
	background-size: contain;
}

/* 矢印付きリンク */
#customer_header .cmn_link_arrow,
#customer_footer .cmn_link_arrow {
	display: inline-flex;
	gap: 0 5px;
	align-items: center;
}
#customer_header .cmn_link_arrow::before,
#customer_footer .cmn_link_arrow::before {
	width: 18px;
	height: 18px;
	content: "";
	background: url(../img/arrow_circle.svg) no-repeat center center;
	background-size: contain;
}

/* 灰色リンク */
#customer_header .cmn_link_txt_gry,
#customer_footer .cmn_link_txt_gry {
	color: var(--color-txt);
	transition: color 0.5s;
}

@media screen and (hover: hover) and (min-width: 769px) {
	#customer_header .cmn_link_txt_gry:hover,
	#customer_footer .cmn_link_txt_gry:hover {
		color: #000;
		opacity: 1;
	}
}

/* Header
------------------------------------------------------ */
#customer_header #g_header {
	display: flex;
	align-items: center;
	width: 100%;
	height: 56px;
	padding: 0 210px 0 0;
	border-bottom: 1px solid var(--color-bd);
}
#customer_header #g_header .h_logo {
	box-sizing: border-box;
	width: 115px;
	min-width: 0;
	max-width: 100%;
	padding: 0 0 0 15px;
	transition: opacity 0.5s;
}
#customer_header #g_header .fixed {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 10001;
	display: flex;
	width: 195px;
	height: 55px;
}
#customer_header #g_header .fixed :is(.lang, .btn_btm) {
	transition: opacity 0.5s;
}
#customer_header #g_header .btn_menu {
	position: relative;
	width: 55px;
	height: 100%;
	background: #fff;
}
#customer_header #g_header .btn_menu a {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	transition: background 0.5s, opacity 0.5s;
}
#customer_header #g_header .btn_menu span {
	width: 24px;
	height: 1px;
	background: #282828;
	transition: opacity 0.5s, transform 0.5s;
}
#customer_header #g_header .btn_menu span + span {
	margin: 5px 0 0;
}
#customer_header #g_header .btn_menu a[href="#close"] {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
#customer_header #g_header .btn_btm {
	display: flex;
	height: 100%;
}
#customer_header #g_header .btn_btm a {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 70px;
	min-height: 100%;
	font-size: 12px;
	line-height: 1.6;
}
#customer_header #g_header .btn_btm a .sub {
	margin: -2px;
	font-size: 10px;
	transform: scale(0.8);
}

/* .active */
#customer_header:has(#g_nav:target) #g_header .fixed {
	pointer-events: none;
}
#customer_header:has(#g_nav:target) #g_header .fixed :is(.lang, .btn_btm) {
	pointer-events: none;
	opacity: 0;
}
#customer_header:has(#g_nav:target) #g_header .fixed .btn_menu {
	pointer-events: auto;
	background: transparent;
}
#customer_header:has(#g_nav:target) #g_header .fixed .btn_menu span {
	margin: -1px 0 0;
	background: #282828;
}
#customer_header:has(#g_nav:target) #g_header .fixed .btn_menu span:first-of-type {
	transform: rotate(45deg);
}
#customer_header:has(#g_nav:target) #g_header .fixed .btn_menu span:nth-of-type(2) {
	opacity: 0;
}
#customer_header:has(#g_nav:target) #g_header .fixed .btn_menu span:last-of-type {
	transform: rotate(-45deg);
}
#customer_header:has(#g_nav:target) #g_header .btn_menu a[href="#close"] {
	pointer-events: auto;
}

@media screen and (min-width: 769px) {
	#customer_header #g_header {
		gap: 0 25px;
		height: 121px;
		padding-right: 0;
	}
	#customer_header #g_header .h_logo {
		width: auto;
		padding-left: 47px;
		margin: 0 auto 0 0;
	}
	#customer_header #g_header .sns {
		display: flex;
		gap: 0 15px;
		align-items: center;
	}
	#customer_header #g_header .sns img[src*="icon_insta"] {
		width: 25px;
	}
	#customer_header #g_header .sns img[src*="icon_youtube"] {
		width: 30px;
	}
	#customer_header #g_header .lang {
		position: relative;
		z-index: 0;
		font-size: 12px;
	}
	#customer_header #g_header .lang dt {
		display: flex;
		gap: 0 5px;
		align-items: center;
		height: 25px;
		cursor: pointer;
	}
	#customer_header #g_header .lang dt::before {
		width: 15px;
		height: 15px;
		content: "";
		background: url(../img/icon_lang_gry.svg) no-repeat center center;
	}
	#customer_header #g_header .lang dt::after {
		width: 9px;
		height: 6px;
		content: "";
		background: url(../img/arrow_down_gry.svg) no-repeat center center;
	}
	#customer_header #g_header .lang dt.active::after {
		transform: rotate(180deg);
	}
	#customer_header #g_header .lang dd {
		position: absolute;
		top: 25px;
		display: none;
		width: 100%;
		padding: 15px;
		background: var(--color-bg01);
	}
	#customer_header #g_header .lang dd ul {
		display: flex;
		flex-direction: column;
		gap: 10px 0;
		width: 100%;
		text-align: center;
	}
	#customer_header #g_header .lang:hover dd {
		display: block;
	}
	#customer_header #g_header .fixed {
		position: static;
		z-index: 0;
		width: 450px;
		max-width: 43%;
		height: 120px;
	}
	#customer_header #g_header .btn_menu {
		flex-shrink: 0;
		width: 145px;
	}
	#customer_header #g_header .btn_menu span {
		width: 65px;
	}
	#customer_header #g_header .btn_menu span + span {
		margin-top: 8px;
	}
	#customer_header #g_header .btn_btm {
		width: calc(100% - 120px);
	}
	#customer_header #g_header .btn_btm li {
		width: 50%;
	}
	#customer_header #g_header .btn_btm a {
		width: 100%;
		font-size: 16px;
	}
	#customer_header #g_header .btn_btm a .sub {
		margin: 0;
		transform: scale(1);
	}
}

/* G-nav
------------------------------------------------------ */
#customer_header #g_nav {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 10000;
	width: 100%;
	height: 100dvh;
	overflow: auto;
	pointer-events: none;
	background: #fff;
	opacity: 0;
	transition: opacity 0.5s;
}
#customer_header #g_nav .btn_menu {
	display: none;
}
#customer_header #g_nav .inner {
	display: flex;
	flex-direction: column;
	min-height: 100dvh;
	padding: 0 7%;
}
#customer_header #g_nav .nav_main {
	display: flex;
	flex-direction: column;
	padding: 60px 0 clamp(40px, 7vw, 60px);
	margin: auto;
}
#customer_header #g_nav .nav_main .logo {
	align-self: center;
	width: 130px;
	margin: 0 0 clamp(30px, 6vw, 50px);
}
#customer_header #g_nav .nav_main .menu {
	display: flex;
	gap: 0 20px;
	margin: 0 0 30px;
	font-size: 14px;
}
#customer_header #g_nav .nav_main .menu ul {
	width: 100%;
	padding: 0 0 0 20px;
	border-left: 1px solid var(--color-bd);
}
#customer_header #g_nav .nav_main .menu li + li {
	margin: 15px 0 0;
}
#customer_header #g_nav .nav_main .btns {
	margin: 0 0 20px;
}
#customer_header #g_nav .nav_main .btns li + li {
	margin: 5px 0 0;
}
#customer_header #g_nav .nav_main .btns a {
	display: flex;
	gap: 0 15px;
	align-items: center;
	justify-content: center;
	min-height: 60px;
}
#customer_header #g_nav .nav_main .btns a .sub {
	font-size: 11px;
}
#customer_header #g_nav .nav_main .tel {
	margin: 0 0 10px;
	line-height: 1.6;
}
#customer_header #g_nav .nav_main .tel .tel-link {
	letter-spacing: 0.02em;
}
#customer_header #g_nav .nav_main .tel .num {
	font-size: 24px;
	line-height: 1.3;
}
#customer_header #g_nav .nav_main .tel .time {
	display: inline-block;
	font-size: 13px;
}
#customer_header #g_nav .nav_main .lang,
#customer_header #g_nav .nav_main .lang ul,
#customer_header #g_nav .nav_main .sns {
	display: flex;
	align-items: center;
}
#customer_header #g_nav .nav_main .lang {
	gap: 5px 6px;
	margin: 0 0 20px;
}
#customer_header #g_nav .nav_main .lang > img {
	align-self: flex-start;
	margin: 4px 0 0;
}
#customer_header #g_nav .nav_main .lang ul {
	flex-wrap: wrap;
	gap: 0 20px;
	font-size: 13px;
}
#customer_header #g_nav .nav_main .sns {
	gap: 0 17px;
	line-height: 1;
}
#customer_header #g_nav .nav_main .sns a {
	display: block;
}
#customer_header #g_nav .nav_sub {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 20px;
	padding: 0 0 calc(30px + env(safe-area-inset-bottom));
	font-size: 13px;
}

/* active */
#customer_header #g_nav:target {
	pointer-events: auto;
	opacity: 1;
}

@media screen and (min-width: 769px) {
	#customer_header #g_nav {
		width: clamp(700px, calc(50% + 150px), 935px);
	}
	#customer_header #g_nav .btn_menu {
		position: fixed;
		top: 0;
		right: 0;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 145px;
		height: 120px;
	}
	#customer_header #g_nav .btn_menu span {
		width: 65px;
		height: 1px;
		background: #282828;
		transform: rotate(45deg);
	}
	#customer_header #g_nav .btn_menu span + span {
		margin: -1px 0 0;
		transform: rotate(-45deg);
	}
	#customer_header #g_nav .inner {
		padding: 0;
	}
	#customer_header #g_nav .nav_main {
		width: 740px;
		max-width: 100%;
		padding: 60px 80px;
	}
	#customer_header #g_nav .nav_main .logo {
		width: auto;
	}
	#customer_header #g_nav .nav_main .menu {
		gap: 0 25px;
		font-size: 17px;
	}
	#customer_header #g_nav .nav_main .menu ul {
		padding-left: 25px;
	}
	#customer_header #g_nav .nav_main .menu li + li {
		margin-top: 25px;
	}
	#customer_header #g_nav .nav_main .btns {
		margin-bottom: 30px;
	}
	#customer_header #g_nav .nav_main .btns a {
		min-height: 70px;
	}
	#customer_header #g_nav .nav_main .lang ul {
		font-size: 14px;
	}
	#customer_header #g_nav .nav_main .sns img[src*="icon_insta"] {
		width: 25px;
	}
	#customer_header #g_nav .nav_main .sns img[src*="icon_youtube"] {
		width: 30px;
	}
	#customer_header #g_nav .nav_sub {
		width: 740px;
		max-width: 100%;
		padding: 0 40px 30px;
		font-size: 14px;
	}
}

/* breadcrumb
------------------------------------------------------ */
#customer_footer #breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 86%;
	margin: clamp(30px, 11.5%, 80px) auto 20px;
}
#customer_footer #breadcrumb li {
	display: flex;
	align-items: center;
	max-width: 100%;
}
#customer_footer #breadcrumb li + li::before {
	margin: 0 10px;
	font-size: 14px;
	content: "＞";
}
#customer_footer #breadcrumb li a {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Footer
------------------------------------------------------ */
#customer_footer #g_footer {
	padding: clamp(60px, 8vw, 75px) 0 clamp(20px, 5vw, 35px);
	border-top: 1px solid var(--color-bd);
}
#customer_footer #g_footer .inner {
	display: flex;
	flex-direction: column;
	width: 550px;
	max-width: 86%;
	margin: 0 auto;
}
#customer_footer #g_footer .logo_col {
	text-align: center;
}
#customer_footer #g_footer .logo {
	display: inline-block;
	width: 150px;
	margin: 0 0 clamp(20px, 5vw, 30px);
}
#customer_footer #g_footer address {
	margin: 0 0 clamp(30px, 8vw, 40px);
	font-size: 15px;
	line-height: 1.8;
	text-align: center;
}
#customer_footer #g_footer address .contact {
	margin: 15px 0 0;
}
#customer_footer #g_footer address .contact .tel-link span {
	font-size: 26px;
	line-height: 1.6;
}
#customer_footer #g_footer address .contact img {
	vertical-align: baseline;
}
#customer_footer #g_footer .reserve_btns {
	margin: 0 0 30px;
}
#customer_footer #g_footer .reserve_btns li + li {
	margin: 5px 0 0;
}
#customer_footer #g_footer .reserve_btns a {
	display: flex;
	gap: 0 15px;
	align-items: center;
	justify-content: center;
	min-height: 70px;
}
#customer_footer #g_footer .reserve_btns a .sub {
	font-size: 11px;
}
#customer_footer #g_footer .reserve_links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 0;
	align-items: center;
	margin: 0 0 15px;
	font-size: 14px;
}
#customer_footer #g_footer .reserve_links li {
	padding: 0 15px 0 0;
	margin: 0 15px 0 0;
	line-height: 1;
	border-right: 1px solid var(--color-bd);
}
#customer_footer #g_footer .reserve_links li:first-of-type {
	padding-left: 0;
}
#customer_footer #g_footer .reserve_links li:last-of-type {
	padding-right: 0;
	margin-right: 0;
	border-right: none;
}
#customer_footer #g_footer .reserve_member {
	display: flex;
	gap: 0 20px;
	align-items: center;
	margin: 0 0 50px;
	font-size: 13px;
}
#customer_footer #g_footer .nav_main {
	column-count: 2;
	padding: clamp(30px, 8vw, 40px) 0;
	border-top: 1px solid var(--color-bd);
	border-bottom: 1px solid var(--color-bd);
}
#customer_footer #g_footer .nav_main li {
	display: inline-block;
	width: 100%;
	padding: 7px 0;
	break-inside: avoid;
}
#customer_footer #g_footer .nav_sub {
	display: flex;
	flex-wrap: wrap;
	gap: 5px 20px;
	align-items: center;
	padding: 20px 0 25px;
	font-size: 13px;
}
#customer_footer #g_footer #copyright {
	font-size: 11px;
	color: rgba(0, 0, 0, 0.4);
	text-align: center;
}

@media screen and (min-width: 769px) {
	#customer_footer #g_footer .inner {
		flex-direction: row;
		width: 86%;
		max-width: 1600px;
	}
	#customer_footer #g_footer .logo_col {
		width: 43%;
		border-right: 1px solid var(--color-bd);
	}
	#customer_footer #g_footer .logo_col > div {
		width: 550px;
		max-width: 100%;
		padding: 0 50px 0 0;
	}
	#customer_footer #g_footer .logo {
		width: auto;
	}
	#customer_footer #g_footer address {
		font-size: 17px;
	}
	#customer_footer #g_footer address .contact .tel-link span {
		font-size: 30px;
	}
	#customer_footer #g_footer .reserve_btns a {
		min-height: 90px;
	}
	#customer_footer #g_footer .reserve_links {
		font-size: 15px;
	}
	#customer_footer #g_footer .reserve_member {
		font-size: 14px;
	}
	#customer_footer #g_footer .nav_col {
		display: flex;
		flex-direction: column;
		justify-content: center;
		width: 57%;
	}
	#customer_footer #g_footer .nav_col > div {
		display: flex;
		align-items: flex-start;
		width: 770px;
		max-width: 100%;
		padding: 40px 0 0 50px;
		margin: 0 0 0 auto;
	}
	#customer_footer #g_footer .nav_main {
		padding: 0;
		border: none;
	}
	#customer_footer #g_footer .nav_sub {
		display: block;
		flex-shrink: 0;
		padding: 0;
		font-size: 14px;
	}
	#customer_footer #g_footer .nav_sub li {
		padding: 7px 0;
	}
	#customer_footer #g_footer #copyright {
		width: 770px;
		max-width: 100%;
		padding: 0 0 0 50px;
		margin: 60px 0 0 auto;
		text-align: right;
	}
}

/* ---------------------------------------------------
	更新履歴
------------------------------------------------------



------------------------------------------------------ */
