:root {
	--color-bg: #DEDBD9;
	--color-blue: #45496A;
	--color-pink: #E8CCC7;
}
* {
	-webkit-appearance: none;
	font-family: "heisei-maru-gothic-std", sans-serif;
	position: relative;
	z-index: 1;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	line-height: 1.6;
	font-weight: 400;
	font-style: normal;
}
body {
	font-size: 20px;
	background: #FFF;
}
img {
	width: 100%;
	vertical-align: bottom;
}



header {
	position: fixed;
	width: 90%;
	top: 20px;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 100;
}
header .header__logo {
	display: block;
	width: 50px;
	aspect-ratio: 1 / 1;
}
header .header__logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
}



.breadcrumb {
	display: -webkit-flex;
	display: flex;
	list-style: none;
	margin: auto auto 50px;
	max-width: 1000px;
	width: 100%;
	overflow: auto;
	padding-left: 5%;
}
.breadcrumb li {
	margin-right: 10px;
	padding-right: 10px;
	max-width: 100%;
	width: fit-content;
}
.breadcrumb li:after {
	content: '>';
	display: block;
	position: absolute;
	top: 5px;
	right: -5px;
	margin: auto;
	font-size: 0.7em;
	margin-left: 2px;
}
.breadcrumb li a {
	color: #7D8BAE;
}
.breadcrumb li a span {
	font-size: 0.7em;
	text-decoration: underline;
	white-space: nowrap
}
.breadcrumb li:last-child:after {
	display: none;
}
.breadcrumb li:last-child a {
	pointer-events: none;
	text-decoration: none;
	padding-right: 5%;
}
.breadcrumb li:last-child a span {
	text-decoration: none;
}


.font-vdl {
	font-family: "vdl-logomarupop-shadow", sans-serif;
	color: #BCB9B7;
}
.tx-bold {
	font-weight: bold;
	text-decoration: underline;
}

.btn {
	background: var(--color-blue);
	color: #FFF;
	display: block;
	text-align: center;
	font-weight: bold;
	font-size: 1em;
	border: 0;
	border-radius: 10px;
	padding: 8px 10px 5px;
	box-shadow: 0 5px 0 0 #7D8BAE;
	user-select: none;
	top: 0;
	transition: 0.3s;
	text-decoration: none;
	max-width: 300px;
	width: 100%;
	margin: 20px 0 20px 0;
}
.btn:active {
	top: 5px;
	box-shadow: 0 0px 0 0 #7D8BAE;
}


footer {
	background: #BCB9B7;
	border-radius: 50px 50px 0 0;
	padding: 50px;
	max-width: 500px;
	width: 100%;
	margin: auto;
}
footer .footer__logo {
	width: 100px;
	aspect-ratio: 1/1;
	display: block;
	margin: auto auto 50px;
}
footer .footer__linklist {
	list-style: none;
}
footer .footer__linklist li {
	margin-bottom: 20px;
}
footer .footer__linklist li a {
	color: #FFF;
	font-size: 0.8em;
	display: block;
	text-decoration: none;
}

footer .footer__snslist {
	display: flex;
	margin: 50px auto;
	list-style: none;
}
footer .footer__snslist li {
	margin-right: 20px;
}
footer .footer__snslist li a {}
footer .footer__snslist li a img {
	width: 30px;
	height: 30px;
	object-fit: contain;
	object-position: center;
}
footer .footer__copy {
	font-size: 10px;
	color: #FFF;
}



/*loading*/
#loading {
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 10000;
	width: 100%;
	min-height: 100lvh;
	height: 100vh;
	height: 100lvh;
	background: rgb(255 255 255 / 30%);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur( 8px );
	display: none;
}
#loading.active {
	display: flex;
	align-items: center;
	justify-content: center;
}
#loading .loading {
	width: fit-content;
}



/*calender*/
#ui-datepicker-div.ui-datepicker {
	width: 90%;
}
#ui-datepicker-div.ui-widget.ui-widget-content {
	position: fixed !important;
	top: 0 !important;
	bottom: 0 !important;
	left: 0 !important;
	right: 0 !important;
	margin: auto;
	height: 430px;
	border: 0 !important;
	padding: 0;
	filter: drop-shadow(0 0 10px #bfbfbf);
	border-radius: 10px;
}
#ui-datepicker-div .ui-datepicker table {
	border-collapse: collapse !important;
	border-spacing: 0;
}
#ui-datepicker-div.ui-datepicker td {
	padding: 0;
}
#ui-datepicker-div.ui-datepicker td span,
#ui-datepicker-div.ui-datepicker td a {
	padding: 10px 5px;
	text-align: center;
}
#ui-datepicker-div .ui-datepicker-calendar .day-sunday > a,
#ui-datepicker-div .ui-datepicker-calendar .day-holiday > a {
	background: #ffc0c0;
}
#ui-datepicker-div .ui-datepicker-calendar .day-saturday > a {
	background: #c0d0ff;
}
#ui-datepicker-div .ui-state-default, .ui-widget-content .ui-state-default,
#ui-datepicker-div .ui-widget-header .ui-state-default,
#ui-datepicker-div .ui-button,
html .ui-button.ui-state-disabled:hover,
html .ui-button.ui-state-disabled:active {
	border: 0 !important;
}



.calendar {}
th.fc-day-sat {
  background-color: #F8FAFF;
}
th.fc-day-sun {
  background-color: #FFFBFB;
}
th.fc-day-sat .fc-col-header-cell-cushion {
  color: #59A0F0;
}
th.fc-day-sun .fc-col-header-cell-cushion{
  color: #DE5858;
}
td.fc-day-sat {
  background-color: rgb(172 212 255 / 10%);
}
td.fc-day-sun {
  background-color: rgb(255 185 185 / 10%);
}
.fc-col-header-cell-cushion {
  color: black;
}
.fc-daygrid-day-number {
  color: black;
}
td.fc-day-sat .fc-daygrid-day-number {
  color: #59A0F0;
}
td.fc-day-sun .fc-daygrid-day-number {
  color: #DE5858;
}
td.fc-timegrid-slot {
  height: 2.5em !important;
  border-bottom: 0 !important;
}


.block .fc .fc-toolbar-title {
	font-size: 14px;
}
.block .fc-timegrid-event .fc-event-time {
	display: none;
}
.block .fc .fc-non-business {
	background: rgb(255 255 255 / 0%);
}

.block .fc .fc-button .fc-icon {
	color: #FFF;
}


.block .fc .fc-button-primary {
	display: block;
	background: #7D8BAE;
	font-size: 0.7em;
}
.block .fc .fc-button-primary:disabled {
	display: none;
}

.fc .fc-button {
	font-size: 14px;
}
.fc .fc-toolbar-title {
	font-size: 3.2vw;
}
.fc .fc-col-header-cell-cushion {
	font-size: 10px;
	padding: 4px;
}
.fc .fc-timegrid-axis-cushion,
.fc .fc-timegrid-slot-label-cushion {
	font-size: 14px;
}

.block .fc-v-event {
	background: #E8CCC7;
	border: 0;
	box-shadow: 0 0 0 0 #FFF;
}
.block .fc-v-event .fc-event-title {
	margin: auto;
	left: 0;
	right: 0;
	padding: 5px 0;
	color: #FFF;
	font-size: 10px;
	text-align: center;
}



/**/
.wrap {
	padding: 100px 0;
}
.wrap article {
	max-width: 1000px;
	width: 90%;
	margin: auto;
}
.wrap h1 {
	text-align: center;
}

.block {
	margin: 20px auto 40px;
}
.label {
	display: block;
	margin: 10px auto;
}
.label-ttl {
	color: #45496A;
	font-size: 0.7em;
}
.input {
	display: block;
	border: 1px solid #F9ECEA;
	padding: 14px 10px 10px 10px;
	border-radius: 5px;
	font-size: 16px;
	width: 100%;
	resize: none;
}
textarea.input {
	height: 200px;
}
.col {
	display: flex;
	justify-content: space-between;
}
.input-col2 {
	width: calc(95% / 2);
}
.input-col3 {
	width: calc(95% / 3);
}
select.input {}
select.input option {
	padding: 10px;
}



/*料理*/
.cooking_detail {
	text-align: center;
	font-size: 0.6em;
	margin-top: 20px;
	color: #7D8BAE;
}
.cooklist {
	margin: 20px auto;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.cooklist li {
	width: calc(95% / 2);
	margin-bottom: 30px;
}
.cooklist li a {
	display: block;
	width: 100%;
	text-decoration: none;
}
.cooklist li img {
	aspect-ratio: 16 / 9;
	border-radius: 5px;
	background: #EFEFEF;
	object-fit: cover;
	object-position: center;
}
.cooklist li .coolist-name {
	color: #45496A;
	font-size: 0.8em;
	margin: 10px auto 5px;
}
.cooklist li .coolist-link {
	text-align: right;
	color: #B2B2B2;
	text-decoration: underline;
	font-size: 0.6em;
}