@charset "utf-8";

.gh {
	position: absolute;
}

.scroll-down .gh:not(.-show) {
	transform: translate3d(0, 0, 0);
}


@media screen and (min-width: 768px) {
	.PageHeader__ttl .ja {
		font-size: 3rem
	}
}

@media screen and (min-width: 1280px) {
	.PageHeader__ttl .ja {
		font-size: 3rem;
	}
}


/* --------------------------------------------------------- */


.PageHeader {
	margin-bottom: 20px;
	background-image: url(../img/dock/kv.webp);
}

.no-webp .PageHeader {
	background-image: url(../img/dock/kv.jpg);
}

.PageHeader__ttl-outer {
	padding: 15px 20px 0 20px;
}

@media screen and (min-width: 1280px) {
	.PageHeader {
		margin-bottom: 40px;
		height: 120px;
	}
}

.popular-contents-inner,
.gf__sitemap {
	display: none;
}


/* --------------------------------------------------------- */


.CalendarContainer {
	
}

.CalendarContainer.-start {
	
}

.CalendarContainer .CalendarBody {
	opacity: 0.2;
	pointer-events: none;
}

.CalendarContainer.-start .CalendarBody {
	opacity: 1;
	pointer-events: auto;
	transition-duration: 0.2s;
	transition-timing-function: ease-out;
	transition-property:  opacity;
}

.CalendarContainer .cal_day__data-sp {
	opacity: 0;
}

.CalendarContainer.-start.-show .cal_day__data-sp {
	opacity: 1;
	transition-duration: 0.5s;
	transition-timing-function: cubic-bezier(.22,.61,.36,1), cubic-bezier(.65,.05,.36,1);
	transition-property: transform, opacity;
}

.CalendarContainer .w-state {
	width: calc(100% - 40px);
	max-width: 1440px;
}

@media screen and (min-width: 768px) {
	.CalendarContainer .w-state {
		width: calc(100% - 100px);
	}
}

@media screen and (min-width: 1280px) {
	.CalendarContainer .w-state {
		width: calc(100% - 160px);
	}
}


/* --------------------------------------------------------- */


.Calendar {
	min-height: 400px;
	margin-top: 40px;
}

@media screen and (min-width: 768px) {
	.Calendar {
		width: calc(100% - 100px);
		margin-left: auto;
		margin-right: auto;
	}
}

@media screen and (min-width: 980px) {
	.Calendar {
		width: 100%;
		overflow: hidden;
	}
}

@media screen and (min-width: 1280px) {
	.Calendar {
		
	}
}


.CalendarBody {
	margin-top: 20px;
}



.CalendarBodyHeader {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	width: 100%;
	background-color: var(--color-bg);
	text-align: left;
	z-index: 2;
	box-shadow: 0 1px 0 rgba(133,87,74,0.2);
}

.CalendarBodyHeader__inner {
	position: relative;
	padding: 10px 0;
	box-sizing: border-box;
}

@media screen and (min-width: 768px) {
	.CalendarBodyHeader {
		
	}
	
	.CalendarBodyHeader__inner {
		
	}
}

@media screen and (min-width: 980px) {
	.CalendarBodyHeader {
		
	}
	
	.CalendarBodyHeader__inner {
		
	}
}

@media screen and (min-width: 1280px) {
	.CalendarBodyHeader {
		padding: 0;
	}
	
	.CalendarBodyHeader__inner {
		display: flex;
		align-items: center;
		justify-content: space-between;
	}
}

.CalendarTitle {
	position: absolute;
	left: 0;
	top: 9px;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	font-size: 1.6rem;
	font-feature-settings: "palt";
	font-family: var(--serif);
	
	transform: scaleX(0.9);
	transform-origin: left center;
	overflow: hidden;
	z-index: 1;
	opacity: 0;
}

.-start .CalendarTitle {
	opacity: 1;
}

.CalendarTitle__text {
	position: relative;
	opacity: 0;
	transform: translateY(100%);
}

.CalendarTitle__text:first-child {
	margin-left: 0;
}


.CalendarTitle__line {
	margin: 0;
}

.CalendarTitle__text.-hide {
	
}

.CalendarTitle__text.-show {
	transition: 0.75s cubic-bezier(.65,.05,.36,1);
	transition-property: transform, opacity;
	opacity: 1;
	transform: translateY(0%);
}

@media screen and (min-width: 768px) {
	.CalendarTitle {
		position: relative;
		top: 0;
		font-size: 2rem;
	}
}

@media screen and (min-width: 1280px) {
	.CalendarTitle {
		font-size: 2.6rem;
	}
}


/* --------------------------------------------------------- */



.CalendarFooter {
	margin-top: 20px;
}

.CalendarFooter > * {
	margin-top: 20px;
}

.CalendarFooter > *:first-child {
	margin-top: 0;
}

@media all and (min-width: 768px) {
	.CalendarFooter {
		
	}
}

@media all and (min-width: 1280px) {
	.CalendarFooter {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		margin-top: 40px;
	}
	
	.CalendarFooter > * {
		margin-top: 0;
	}
}

.CalendarNotes {
	font-size: 1.2rem;
}

.CalendarNotes > * {
	margin: 0;
}

.note {
	line-height: 1.8;
	font-size: 1.1rem;
	font-feature-settings: "palt";
}

.note strong {
	color: var(--color-accent);
}


/* --------------------------------------------------------- */


.CalendarUI {
	
}

.msie .CalendarUI {
	width: 50%;
}

.CalendarUI .ui-accordion--item {
	width: 100%;
	border: none;
	text-align: right;
}

.CalendarUI .ui-accordion--trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-right: 0;
	margin-left: auto;
	background-color: var(--color-header-bg);
	color: #fff;
	border-radius: 5px;
	padding: 0 10px;
	
	min-width: 50px;
	min-height: 30px;
	box-sizing: border-box;
}

.CalendarUI .ui-accordion--lbl {
	margin-left: 0;
	margin-right: 0;
	font-size: 1.1rem;
	font-style: normal;
}

.CalendarUI .ui-accordion--icon {
	display: none;
	margin: 0;
}

.CalendarUI .uia--show .ui-accordion--lbl {
	display: none;
}

.CalendarUI .uia--show .ui-accordion--icon {
	display: block;
}

.CalendarUI .uia--show .ui-accordion--contents.-transitionend {
	overflow: visible;
}

.CalendarUI .ui-accordion--contents-inner {
	padding: 10px 0 15px;
}


@media screen and (min-width: 768px) {
	.CalendarUI {
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
	}
	
	.CalendarUI .ui-accordion--trigger {
		display: none;
	}
	
	.CalendarUI .ui-accordion--contents {
		height: auto !important;
		overflow: visible;
	}
	
	.CalendarUI .ui-accordion--contents {
		opacity: 1 !important;
	}
	
	.CalendarUI .ui-accordion--contents-inner {
		padding: 10px 0;
	}
}


.SelectForm {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}

.SelectForm > *:first-child {
	margin-top: 0;
}

.SelectForm__item {
	position: relative;
	display: flex;
	align-items: baseline;
	width: 100%;
	margin: 10px 0 0;
}

.SelectForm__item .popup {
	display: block;
	width: 100%;
	font-size: 1.3rem;
	text-overflow: ellipsis;
	font-feature-settings: "palt";
}

.SelectForm__item .popup__target {
	right: 0;
	left: 0;
	margin-right: 0;
	transform: translate(0, 0);
	min-width: 240px;
}


.SelectForm__item .popup__trigger {
	display: block;
	width: 100%;
	box-sizing: border-box;
	font-size: 1.3rem;
	color: currentColor;
	padding: 5px 0;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.SelectForm .popup__current-tag {
	margin-top: 0;
	font-weight: bold;
}

.SelectForm .input-lbl {
	position: absolute;
	top: 0;
	width: 60px;
	height: 100%;
	padding: 0;
	font-size: 1.1rem;
	color: #777;
	z-index: 109;
	pointer-events: none;
}

.SelectForm .input-lbl::before {
	display: none;
}


@media screen and (min-width: 768px) {
	
	.SelectForm {
		flex-wrap: nowrap;
	}
	
	.SelectForm > *:first-child {
		margin-left: 0;
	}
	
	.SelectForm__item {
		flex: 1;
		margin: 0 0 0 15px;
		width: auto;
	}
	
	.SelectForm .input-lbl {
		
	}
	
	.SelectForm__item .popup {
		text-align: left;
	}
	
	.SelectForm__item .popup__trigger {
		padding-left: 60px;
	}
}

@media screen and (min-width: 1280px) {
	
	.SelectForm {
		width: 50%;
	}
	
	.SelectForm__item {
		max-width: 320px;
		position: relative;
	}
	
	.msie .SelectForm {
		width: 100%;
	}
}

/* --------------------------------------------------------- */


.-gallery.swiper-container {
	padding: 0;
	margin-top: 0;
	overflow: visible;
}

@media screen and (min-width: 768px) {
	.-gallery.swiper-container {
		max-width: 1440px;
		margin: 0 auto;
	}
}

@media screen and (min-width: 980px) {
	.-gallery.swiper-container {
		width: calc(100% - 100px);
	}
}

@media screen and (min-width: 1280px) {
	.-gallery.swiper-container {
		width: calc(100% - 160px);
	}
}


.-gallery .swiper-wrapper {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	transition-timing-function: cubic-bezier(.17,.84,.44,1);
}

@media screen and (min-width: 980px) {
	.-gallery .swiper-wrapper {
		
	}
}

.-gallery .swiper-slide {
	width: calc(100% - 40px);
	max-width: 1440px;
	margin: 0 auto 30px;
	/*! position: sticky; */
	/*! top: 50px; */
}


@media screen and (min-width: 768px) {
	.-gallery .swiper-slide {
		width: calc(50% - 20px);
		margin: 0 0 20px;
	}
	
	.-gallery .swiper-wrapper::before,
	.-gallery .swiper-wrapper::after {
		content: "";
		display: block;
		width: calc(50% - 20px);
		height: 0;
		order: 2;
	}
}

@media screen and (min-width: 1280px) {
	.-gallery .swiper-slide {
		width: calc(33.333% - 27px);
		margin: 0 0 40px;
	}
	
	.-gallery .swiper-wrapper::before,
	.-gallery .swiper-wrapper::after {
		width: calc(33.333% - 27px);
	}
	
	.-gallery .swiper-slide:last-child {
		margin-right: 0;
	}
}



/* --------------------------------------------------------- */



.Month {
	margin-top: 40px;
	box-sizing: border-box;
}



.MonthHeader {
	-webkit-user-select: none;
	        user-select: none;
	font-family: var(--serif);
	text-align: center;
}

.Month__year {
	margin: 0;
	font-weight: bold;
	line-height: 1;
}

.Month__month {
	margin: 0;
	font-weight: bold;
	font-size: 2.6rem;
	line-height: 1;
}

@media screen and (min-width: 980px) {
	.MonthHeader {
		display: flex;
		align-items: baseline;
		justify-content: center;
		text-align: left;
	}
	
	.Month__year {
		font-size: 2.0rem;
	}
	
	.Month__month {
		margin: 0 0 0 10px;
		font-size: 5.0rem;
	}
}

@media screen and (min-width: 1280px) {
	.MonthHeader {
		width: 50%;
		margin-right: auto;
		margin-left: auto;
	}
}


.MonthWeeks {
	-webkit-user-select: none;
	        user-select: none;
	display: flex;
	justify-content: space-between;
	flex-wrap: nowrap;
	list-style: none;
	margin: 15px 0 0;
	padding: 0;
	border-top: 1px solid rgba(0,0,0,0.2);
	/*! border-left: 1px solid rgba(0,0,0,0.2); */
	/*! background-color: #fff; */
}

.MonthWeeks__item {
	width: calc(100% / 7);
	/*! border-right: 1px solid rgba(0,0,0,0.2); */
	box-sizing: border-box;
	margin: 0;
	padding: 14px 10px;
	text-align: center;
	line-height: 1;
}

.msie .MonthWeeks__item {
	width: calc(100% / 7.5);
}

.MonthWeeks__item > * {
	margin-top: 5px;
}


.MonthWeeks__item > *:first-child {
	margin-top: 0;
}

.MonthWeeks__item .ja {
	display: block;
	
	font-size: 1.2rem;
}

.MonthWeeks__item .en {
	display: block;
	font-size: 0.9rem;
}
/*
@media screen and (min-width: 980px) {
	.MonthWeeks {
		margin-top: 30px;
	}
	
	.MonthWeeks__item {
		display: flex;
		align-items: baseline;
	}
	
	.MonthWeeks__item .en {
		margin-left: 10px;
	}
}
*/

/* ------------------------------ */


.cal_days {
	-webkit-user-select: none;
	        user-select: none;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	list-style: none;
	margin: 0;
	padding: 0;
	/*! border-left: 1px solid rgba(0,0,0,0.2); */
	border-bottom: 1px solid rgba(0,0,0,0.2);
	/*! background-color: #fff; */
}

.cal_days__cell {
	position: relative;
	width: calc(100% / 7);
	min-height: 70px;
	margin: 0;
	padding: 0;
	/*! border-right: 1px solid rgba(0,0,0,0.2); */
	border-top: 1px solid rgba(0,0,0,0.1);
	box-sizing: border-box;
}

.msie .cal_days__cell {
	width: 14.28571%;
}

/* 受付終了（過去の日付など） */
.cal_days__cell.-accepted {
	position: relative;
}

.cal_days__cell.-accepted:not(.-closed)::before {
	position: absolute;
	left: 0;
	top: 0;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 1.2rem;
	opacity: 0.5;
	content: "─";
}

/* 要確認（当日よりn日以内） */
.cal_days__cell.-after {
	
}


@media screen and (min-width: 980px) {
	.cal_days__cell {
		
	}
}

@media screen and (min-width: 1280px) {
	.cal_days__cell {
		
	}
}


.cal_days__cell:empty {
	background-color: rgba(0,0,0,0.02);
}

.cal_endblank {
	padding: 0;
	min-height: auto;
}


.cal_days__cell:nth-child(7n+1):nth-last-child(-n+7),
.cal_days__cell:nth-child(7n+1):nth-last-child(-n+7) ~ .cal_days__cell {
	border-top: none;
}






.cal_day {
	text-align: center;
}

.cal_day.-vacant {
	
}

.cal_day.-vacant > * {
	
}

.cal_day.-closed {
	
}

.cal_day.-closed > * {
	opacity: 0.4;
}



.cal_day__num {
	position: relative;
	padding: 10px 0;
	font-size: 1.5rem;
	font-weight: lighter;
	font-feature-settings: "palt";
	font-family: var(--serif);
	font-weight: 300;
	line-height: 1;
	pointer-events: none;
	z-index: 3;
	text-align: center;
}



.cal_day__data {
	display: none;
	content-visibility: hidden;
}

.cal_day__data > * {
	
}

.cal_day__data > *:first-child {
	
}

@media screen and (min-width: 980px) {
	
}

@media screen and (min-width: 1280px) {
	
}


/* ---------- */


.cal_day__data-sp {
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
}

.cal_day__data-sp .cal_day__btn {
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
}



@media screen and (min-width: 980px) {
	
}

@media screen and (min-width: 1280px) {
	.cal_days__cell {
		position: relative;
	}
}


/* ---------- */


.cal_day__btn {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	line-height: 1;
	z-index: 1;
	margin-top: 0;
	padding: 2em 5px 5px;
	box-sizing: border-box;
	font-family: var(--serif);
}



.cal_days__anchor {
	position: absolute;
	align-items: baseline;
	width: 100%;
	height: 100%;
	
	text-decoration: none;
	border-bottom: none;
	border-radius: 0;
	box-sizing: border-box;
	
	transition-duration: 0.5s;
	animation-timing-function: ease-out;
	transition-property: color, box-shadow, background-color;
	
	cursor: pointer;
}

.cal_days__anchor:hover {
	box-shadow: 5px 10px 10px rgba(133,87,74,0.2);
	z-index: 2;
	animation-timing-function: ease-in;
	transition-duration: 0.15s;
	color: #000;
	background-color: #fff;
}

.-show-modal .cal_days__anchor.-selected {
	background-color: #f4e4e4;
}

@media screen and (min-width: 1280px) {
	.cal_days__anchor {
		
	}
}



.cal_day__time {
	width: calc(100% - 25px);
	font-size: 1.15rem;
	text-align: right;
}

@media screen and (min-width: 1280px) {
	.cal_day__time {
		width: calc(100% - 40px);
	}
}



.cal_day__icon {
	width: 16px;
	height: 16px;
	text-align: center;
	background-size: 16px 16px;
	background-repeat: no-repeat;
	background-position: 0 center;
}

@media screen and (min-width: 1280px) {
	.cal_day__icon {
		width: 20px;
		height: 20px;
		background-size: 20px 20px;
	}
}


/* 要素数を減らすため、svg要素ではなく背景画像に変更 */

/* 〇 余裕あり */
.cal_day__btn.-available {
}

.cal_day__btn.-available .cal_day__icon,
.ModalCalendarDayDetail .cal_day__btn.-available .cal_day__icon {
	background-image: url(/assets/img/calendar/icon_circle.svg);
}


/* △ 残りわずか */
.cal_day__btn.-fewleft .cal_day__icon,
.ModalCalendarDayDetail .cal_day__btn.-fewleft .cal_day__icon {
	background-image: url(/assets/img/calendar/icon_triangle.svg);
}


/* × 空席無し */
.cal_day__btn.-unavailable {
	opacity: 0.5;
}

.cal_day__btn.-unavailable .cal_day__icon,
.ModalCalendarDayDetail .cal_day__btn.-unavailable .cal_day__icon {
	background-image: url(/assets/img/calendar/icon_close.svg);
}

.cal_day__btn.-unavailable .cal_days__anchor:hover {
	box-shadow: none;
}


/* 要確認（当日よりn日以内） */
.cal_day__btn.-after .cal_day__icon {
	background-image: url(/assets/img/calendar/icon_tel.svg);
}

.ModalCalendarDayDetail .cal_day__btn.-after .cal_day__icon {
	background-image: url(/assets/img/calendar/icon_tel.svg);
}

/* ─ 受付不可 */
.cal_day__btn.-disable {
	opacity: 0;
}

.cal_day__btn.-disable .cal_day__icon svg {
	
}

.cal_day__btn.-disable .cal_days__anchor:hover {
	box-shadow: none;
}

/* --------------------------------------------------------- */


.CalendarLabelDes {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	padding: 0;
	list-style: none;
	font-size: 1.0rem;
}

.CalendarLabelDes__item {
	display: flex;
	align-items: center;
	margin-left: 15px;
}

.CalendarLabelDes__item:first-child {
	margin-left: 0;
}

.CalendarLabelDes__item .icon {
	
}

.CalendarLabelDes__item .icon img {
	display: block;
	width: 16px;
	height: 16px;
	text-align: center;
	stroke-width: 1.3;
}

.CalendarLabelDes__item.-available img {
	color: #00bf9a;
	stroke-width: 3;
}

.CalendarLabelDes__item .lbl {
	margin-left: 5px;
	white-space: nowrap;
}

@media screen and (min-width: 980px) {
	.CalendarLabelDes {
		font-size: 1.2rem;
	}
}



/* --------------------------------------------------------- */



.CalendarModal {
	max-height: calc(100vh - 100px);
}

.CalendarModal .modal-scroll-container__outer {
	will-change: all;
	max-height: calc(100vh - 100px);
	will-change: all;
	perspective: 1;
}

.CalendarModal .modal-scroll-container {
	will-change: all;
	perspective: 1;
	overflow: hidden;
	will-change: transform;
}

.CalendarModal [data-modal-close] {
	position: relative;
	top: 0;
	right: 0;
	cursor: pointer;
	width: 100%;
	z-index: 5;
	display: block;
	max-width: 260px;
	margin-left: auto;
	margin-right: auto;
	padding: 15px 10px;
	border-radius: 3px;
	font-weight: bold;
}

[data-show-modal="selectTypes"].-show-modal [data-modal-overlay] {
	pointer-events: none;
}

.CalendarModal .modal-scroll-container__inner {
	border-radius: 3px;
}



.CalendarModal .w-state {
	width: calc(100% - 40px);
	max-width: 100%;
}

@media screen and (min-width: 768px) {
	.CalendarModal .w-state {
		width: calc(100% - 100px);
	}
	
	.CalendarModal .modal-scroll-container__inner {
		padding: 80px 0 60px;
	}
}

@media screen and (min-width: 1280px) {
	
	.CalendarModal {
		top: 0;
		bottom: 0;
	}
	
	.CalendarModal .w-state {
		width: calc(100% - 160px);
	}
}

@media screen and (max-height: 414px) and (max-width: 896px) and (orientation: landscape) {
	.CalendarModal .modal-scroll-container__outer {
		max-height: calc(100vh - 40px);
	}
}

.CalendarModalFieldset {
	border-top: 1px solid rgba(0,0,0,0.1);
	padding: 15px 0;
	display: flex;
}

.CalendarModalFieldset__lbl {
	display: flex;
	align-items: center;
	margin: 5px 20px 5px 0;
	font-size: 1.2rem;
	writing-mode: vertical-rl;
}

.CalendarModalFieldset__lbl .icon {
	margin: 0 0 10px;
	stroke-width: 1.3;
	display: none;
}

.CalendarModalFieldset__lbl .lbl {
	
}

.CalendarModalFieldset__body {
	
}


.CalendarModalFieldset__body > * {
	margin-top: 10px;
}

.CalendarModalFieldset__body > *:first-child {
	margin-top: 0;
}

.CalendarModalFieldset__ul {
	flex-direction: column;
	align-items: flex-start;
	gap: 10px 25px;
	list-style: none;
	padding: 0;
	font-feature-settings: "palt";
	line-height: 1.4;
}

.CalendarModalFieldset__ul .control-item {
	margin-top: 5px;
}

@media screen and (min-width: 768px) {
	
	.CalendarModalFieldset__lbl {
		margin-top: 0;
		writing-mode: horizontal-tb;
	}
	
	.CalendarModalFieldset__lbl .icon {
		display: block;
		margin: 0 20px 0 0;
	}
	
	.CalendarModalFieldset {
		display: flex;
		align-items: flex-start;
		padding: 30px 0;
	}
	
	.CalendarModalFieldset__lbl {
		width: 150px;
		margin-bottom: 0;
	}
	
	.CalendarModalFieldset__body {
		width: calc(100% - 150px);
	}
	
	.CalendarModal [data-modal-close] {
		padding: 20px 10px;
	}
}

@media screen and (min-width: 980px) {
	
	.CalendarModalFieldset__ul {
		flex-direction: row;
		align-items: center;
		padding-left: 0;
	}
	
	.CalendarModalFieldset__ul .control-item {
		display: flex;
		margin-top: 0;
	}
	
}


/* --------------------------------------------------------- */



.modal--toast {
	width: 100%;
	max-width: 100%;
	max-height: 100%;
}

.modal--toast .in-corner::before,
.modal--toast .in-corner::after {
	position: absolute;
	top: 0;
	display: block;
	width: 50px;
	height: 50px;
	content: "";
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	z-index: 1;
}

.modal--toast .in-corner::before {
	right: 0;
	background-image: var(--round-in-corner-LB-wt);
}

.modal--toast .in-corner::after {
	left: 0;
	background-image: var(--round-in-corner-RB-wt);
}

.modal--toast .modal-scroll-container__outer {
	position: absolute;
	top: auto;
	bottom: 0;
	height: auto;
	max-height: calc(100vh - 0px);
	border-radius: 15px 15px 0 0;
	transform: translateY(100%);
	transition: transform 0.36s cubic-bezier(.65,.05,.36,1);
	overflow: hidden;
	padding-top: 100px;
}

.modal--toast .modal-scroll-container__outer::before {
	position: absolute;
	left: 0;
	bottom: 0;
	height: calc(50% - 15px); /* border-raduis */
	width: 100%;
	background-color: var(--color-bg);
	content: "";
}

.modal--toast.-show .modal-scroll-container__outer {
	transform: translateY(0);
	pointer-events: none;
}

@media screen and (min-width: 768px) {
	.modal--toast .modal-scroll-container__outer {
		padding-top: 0;
	}
	.modal--toast .modal-scroll-container__outer::before {
		display: none;
	}
}

.modal--toast .modal-scroll-container {
	border-radius: 15px 15px 0 0;
}

.modal--toast.-show .modal-scroll-container {
	pointer-events: auto;
}

.modal--toast .modal-scroll-container__inner {
	position: relative;
	border-radius: 15px 15px 0 0;
	padding: 15px 0 50px;
	z-index: 1;
	background-color: var(--color-bg);
}

.modal--toast .modal-scroll-container__inner::before {
	position: absolute;
	top: 10px;
	left: 0;
	right: 0;
	margin: auto;
	display: block;
	width: 40px;
	height: 4px;
	border-radius: 5px;
	background-color: rgba(0,0,0,0.15);
	content: "";
}

.modal--toast .swiper-slide {
	width: 100%;
	height: auto! important;
	max-width: 100%;
	margin: 0;
}


@media screen and (max-height: 414px) and (max-width: 896px) and (orientation: landscape) {
	.modal--toast .modal-scroll-container__outer {
		max-height: calc(100vh - 20px);
		padding-top: 0;
	}
}


.ModalCalendarDayDetail {
	
}

@media screen and (min-width: 768px) {
	.ModalCalendarDayDetail {
		position: absolute;
		top: 0;
		left: 0;
		height: auto !important;
		bottom: auto;
		margin: 0;
		height: auto;
		max-width: 340px;
		overflow: visible !important;
		transition: opacity 0.12s cubic-bezier(0.22, 0.61, 0.36, 1);
		transition-property: opacity, transform;
		transform: translateY(-5px);
		
		--arrowleft: 0;
		--arrowtop: 0;
	}
	
	.ModalCalendarDayDetail::before {
		position: absolute;
		left: var(--arrowleft);
		top: auto;
		bottom: -10px;
		right: auto;
		margin: auto;
		content: "";
		display: block;
		width: 20px;
		height: 20px;
		z-index: 1;
		background-color: var(--color-bg);
		box-sizing: border-box;
		clip-path: polygon(50% 50%, 100% 50%, 50% 100%, 0 50%);
	}
	
	.ModalCalendarDayDetail.-arrow-posL::before {
		top: var(--arrowtop);
		bottom: auto;
		left: -10px;
		right: auto;
		transform: rotate(90deg);
	}
	
	.ModalCalendarDayDetail.-arrow-posR::before {
		top: var(--arrowtop);
		bottom: auto;
		right: -10px;
		left: auto;
		transform: rotate(-90deg);
	}
	
	.ModalCalendarDayDetail.-arrow-pos-hide::before {
		display: none;
	}
	
	.ModalCalendarDayDetail.-arrow-posLB::before {
		width: 30px;
		height: 30px;
		transform: rotate(45deg);
		clip-path: polygon(64.14% 2.86%, 83.50% 14.65%, 45% 90%, -4px 2.86%);
	}
	
	.msie .ModalCalendarDayDetail::before {
		display: none;
	}
	
	.ModalCalendarDayDetail.-show ~ [data-modal-overlay] {
		transition: opacity 0.1s ease-out;
		opacity: 0.25;
	}
	
	.ModalCalendarDayDetail .modal-scroll-container__outer {
		overflow: visible;
		border-radius: 10px;
		transform: translateY(10px);
		transition: transform 0.1s cubic-bezier(.22,.61,.36,1);
	}
	
	.ModalCalendarDayDetail.-show .modal-scroll-container__outer {
		transform: translateY(0);
	}
	
	.ModalCalendarDayDetail .modal-scroll-container {
		border-radius: 10px;
		overflow: visible;
	}
	
	.ModalCalendarDayDetail .modal-scroll-container__inner {
		padding: 0 0 20px;
		border-radius: 10px;
		box-shadow: 10px 10px 15px rgba(133,87,74,0.15);
	}
	
	.ModalCalendarDayDetail .w-state {
		width: calc(100% - 40px);
	}
	
	.ModalCalendarDayDetail .in-corner {
		display: none;
	}
}

/* max-width */
@media screen and (max-width: 767px) {
	/* タブレット以外はトーストで画面下部に表示 */
	
	.ModalCalendarDayDetail {
		top: auto !important;
		bottom: 0 !important;
		right: 0 !important;
		left: 0 !important;
	}
	
}


.ModalCalendarDayDetail__title {
	padding: 5px 20px 0;
	margin: 0;
	font-size: 1.4rem;
	font-weight: bold;
	font-feature-settings: "palt";
	font-family: var(--serif);
}

@media screen and (min-width: 768px) {
	.ModalCalendarDayDetail__title {
		background-color: var(--color-header-bg);
		color: #fff;
		border-radius: 8px 8px 0 0;
		padding: 10px 20px;
		text-align: left;
		border-bottom: none;
	}
}

.ModalCalendarDayDetail__date {
	margin-top: 20px;
}

.ModalCalendarDayDetail__date .cal_day__data {
	content-visibility: visible;
}

.ModalCalendarDayDetail__date .cal_day__btn {
	justify-content: flex-start;
	margin-top: 10px;
	padding: 10px 10px;
	border-radius: 5px;
	background-color: transparent;
}

.ModalCalendarDayDetail__date .cal_day__btn:first-child {
	margin-top: 0;
}

.ModalCalendarDayDetail__date .cal_day__btn:not(.-unavailable) {
	border-radius: 5px;
	background-color: #fff;
	box-shadow: 0px 1px 3px rgba(133,87,74,0.2);
}

.ModalCalendarDayDetail__date .cal_day__btn:not(.-unavailable)::after {
	position: absolute;
	right: 10px;
	content: "予約へ進む";
	display: block;
	width: 80px;
	padding: 0;
	box-sizing: border-box;
	font-family: var(--sansserif);
	font-size: 1.1rem;
	font-weight: bold;
	text-align: right;
}

.ModalCalendarDayDetail__date .cal_day__btn.-after::after {
	display: none;
}

@media screen and (min-width: 375px) {
	.ModalCalendarDayDetail__date .cal_day__btn {
		padding: 15px 10px;
	}
}

@media screen and (min-width: 768px) {
	
	.ModalCalendarDayDetail__date {
		margin-top: 15px;
	}
	
	.ModalCalendarDayDetail__date .cal_day__btn {
		
	}
	
	.ModalCalendarDayDetail__date .cal_day__btn,
	.ModalCalendarDayDetail__date .cal_day__btn:not(.-unavailable) {
		padding: 10px 15px;
		border: none;
	}
	
	.ModalCalendarDayDetail__date .cal_day__btn:first-child,
	.ModalCalendarDayDetail__date .cal_day__btn:not(.-unavailable):first-child {
		border: none;
	}
	
	.ModalCalendarDayDetail__date .cal_day__btn:not(.-unavailable) {
		transition-duration: 0.15s;
		animation-timing-function: cubic-bezier(0.78, 0.01, 0.32, 1.01);
		transition-property: color, box-shadow, background-color;
	}
	
	.ModalCalendarDayDetail__date .cal_day__btn.-unavailable > * {
		opacity: 0.5;
	}
	
	.ModalCalendarDayDetail__date .cal_day__btn:not(.-unavailable):hover {
		z-index: 2;
		box-shadow: 4px 4px 12px rgba(133,87,74,0.15);
		color: #000;
	}
}


.ModalCalendarDayDetail__date .cal_day__data {
	display: block;
}

/* smartphone */
@media screen and (max-height: 414px) and (max-width: 896px) and (orientation: landscape) {
	.ModalCalendarDayDetail__date .cal_day__data {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.ModalCalendarDayDetail__date .cal_day__btn:first-child {
		margin-top: 10px;
	}
	.ModalCalendarDayDetail .w-state {
		width: calc(100% - 40px);
	}
	
	.ModalCalendarDayDetail__date .cal_day__btn {
		width: calc(50% - 10px);
	}
}

.ModalCalendarDayDetail .w-state {
	width: calc(100% - 40px);
	max-width: 100%;
}


.ModalCalendarDayDetail__date .cal_days__anchor {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.ModalCalendarDayDetail__date a.cal_days__anchor {
	
}

.ModalCalendarDayDetail__date .cal_days__anchor:hover {
	background-color: transparent;
}

.ModalCalendarDayDetail__date .cal_day__time {
	text-align: left;
	width: 70px;
}

.ModalCalendarDayDetail__date .cal_day__icon {
	display: flex;
	align-items: center;
	width: calc(100% - 70px);
	text-align: left;
	padding-left: 25px;
	box-sizing: border-box;
}

.ModalCalendarDayDetail__date .cal_day__icon i {
	margin-right: 10px;
}

.ModalCalendarDayDetail__date .cal_day__icon svg {
	width: 24px;
	height: 24px;
}

.ModalCalendarDayDetail__date .cal_day__icon::after {
	font-size: 1.2rem;
}

.ModalCalendarDayDetail__date .-available .cal_day__icon::after {
	content: "受付中";
}

.ModalCalendarDayDetail__date .-fewleft .cal_day__icon::after {
	content: "残りわずか";
}

.ModalCalendarDayDetail__date .-unavailable .cal_day__icon::after {
	content: "空き無し";
}

.ModalCalendarDayDetail__date .-after .cal_day__icon::after {
	content: "お電話にてご確認ください";
}

.ModalCalendarDayDetail__date .-unavailable {
	opacity: 1;
}

.ModalCalendarDayDetail__date .-unavailable .cal_days__anchor::after {
	opacity: 0;
}

.ModalCalendarDayDetail__date .-disable {
	display: none;
}



@media screen and (min-width: 768px) {
	.ModalCalendarDayDetail__date .cal_day__icon {
		padding-left: 35px;
	}
	
	.ModalCalendarDayDetail__date .cal_days__anchor:hover {
		box-shadow: none;
	}
}



[data-modal-overlay] {
	transition: opacity 0.24s ease-out;
}

@media all and (min-width: 768px) {
	[data-modal].-show {
		overflow-y: hidden;
	}
}


/* --------------------------------------------------------- */
/* loading */

.CalendarContainer.-loading {
	
}

.CalendarContainer.-loading .cal_days {
	position: relative;
}

.CalendarContainer.-loading .cal_days::before {
	position: absolute;
	display: block;
	left: 0;
	top: 0;
	content: "";
	width: 100%;
	height: 100%;
	background-color: rgba(255,255,255,0.5);
}

.CalendarContainer.-loading .cal_days::after {
	position: absolute;
	display: block;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "Loading";
	font-family: var(--serif);
	width: 50px;
	height: 30px;
	border-radius: 5px;
	animation: loading-animation 0.1s infinite reverse ease-in-out;
	will-change: width;
}

@keyframes loading-animation {
	0% {
		opacity: 1;
	}
	50% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}


/* --------------------------------------------------------- */
/* View mode */


.viewmode {
	
	& .cal_day__btn .cal_days__anchor {
		pointer-events: none;
	}
	
	
	& .ModalCalendarDayDetail__date .cal_day__btn:not(.-unavailable) {
		z-index: 2;
		box-shadow: none;
		color: #000;
	}
	
	& .ModalCalendarDayDetail__date .cal_day__btn {
		margin-top: 0;
		
		&.-unavailable > * {
			opacity: 0.8;
		}
		
		&:not(.-unavailable) {
			box-shadow: none;
			background-color: transparent;
			
			&::after {
				display: none;
			}
		}
	}
}

.ModalCalendarDayDetail__to-reservation-info {
	display: none;
	
	& .btn {
		width: 100%;
		min-height: 50px;
		margin-top: 10px;
		font-weight: bold;
	}
	
	.viewmode & {
		display: block;
	}
}

.ModalReservationInfo {
	max-width: 1100px;
	max-height: calc(100vh - 40px);
	font-feature-settings: "palt";
	
	.flow-table__list {
		line-height: 1.5;
	}
	
	& .w-state--c {
		width: 100%;
	}
	
	& #reservation {
		margin-top: 30px;
	}
	
	& .tab__extra-text {
		margin-top: 0;
	}
	
	& .section-header + * {
		margin-top: 30px;
	}
	
	& .tab__extra-icon {
		display: none;
	}

	& .flow-table {
	    margin-top: 20px;
	}
	
	& .flow-table__row {
		
	}
	
	& .tab__btn {
		font-size: 1.4rem;
	}
	
	& .modal-selectedinfo {
		display: flex;
		flex-direction: column;
		gap: 10px;
		margin-top: 0;
		border-bottom: 1px solid currentColor;
		padding-bottom: 20px;
		
		& .modal-selectedinfo__date {
			font-weight: bold;
			white-space: nowrap;
		}
		
		& .cal_day__btn {
			padding: 0;
			border-radius: 0;
			font-family: inherit;
			/*gap: 5px;*/
		}
		
		& .modal-selectedinfo__list {
			display: flex;
			flex-direction: column;
			gap: 10px;
		}
		
		& .cal_day__icon::after {
			white-space: nowrap;
		}
		
		& .cal_day__time {
			/*width: auto;*/
		}
		
		& .cal_day__icon {
			padding-left: 25px;
		}
		
		& .-after .cal_day__icon::after {
			content: "お電話にて";
		}
	}
}

@media screen and (min-width: 1080px) {
	.ModalReservationInfo .flow-table__row {
		--cols: 3;
		
		& .flow-table__type {
			grid-row: 1;
			grid-column: 1 / 3;
		}
		
		& .flow-table__reservation {
			grid-row: 1;
			width: 100%;
		}
	}
}

@media screen and (min-width: 768px) {
	.ModalReservationInfo[data-modal] .w-state,
	.ModalReservationInfo[data-modal] .w-state--s {
		width: calc(100% - 60px);
	}
	
	.ModalReservationInfo {
		.tab__btn {
			font-size: 1.5rem;
		}
		
		& .modal-selectedinfo {
			flex-direction: row;
			align-items: flex-end;
			gap: 30px;
			padding-bottom: 30px;
			overflow-x: auto;
			
			& .modal-selectedinfo__date {
				font-weight: bold;
				white-space: nowrap;
				line-height: 1.5;
			}
			
			& .cal_day__btn {
				flex-direction: column;
				align-items: flex-start;
				padding: 0;
				border-left: 1px solid currentColor !important;
				border-radius: 0;
				padding-left: 1em;
				font-family: inherit;
				gap: 5px;
			}
			
			& .modal-selectedinfo__list {
				flex-direction: row;
				flex-grow: 1;
				gap: 20px;
			}
			
			& .cal_day__icon::after {
				white-space: nowrap;
			}
			
			& .cal_day__time {
				width: auto;
			}
			
			& .cal_day__icon {
				padding-left: 25px;
			}
			
			& .-after .cal_day__icon::after {
				content: "お電話にて";
			}
		}
	}
}

@media screen and (min-width: 1280px) {
	.ModalReservationInfo[data-modal] .w-state,
	.ModalReservationInfo[data-modal] .w-state--s {
		width: calc(100% - 100px);
	}
}

@media screen and (max-height: 414px) and (max-width: 896px) and (orientation: landscape) {
	.ModalReservationInfo[data-modal] {
		max-height: calc(100vh - 40px);
	}
}



/* --------------------------------------------------------- */

[data-modal] {
	&:not(.-show) {
		& .tab__panel[aria-hidden="false"] {
			pointer-events: none !important;
		}
	}
	& [data-modal-overlay] {
		z-index: -1;
	}

	.modal__close {
		border: none;
		padding: 0;
		
		& svg {
			stroke-width: 0.9;
		}
	}
}

[data-modal].-show .modal-scroll-container__outer {
	pointer-events: none;
}

.ModalReservationInfo[data-modal].-show .modal-scroll-container__outer {
	pointer-events: auto;
}
