@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap');

/* 共通
------------------------------------------ */
body {
	font-family: "Zen Kaku Gothic New", sans-serif !important;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

figure img {
  border-radius: 20px;
}

a {
  transition: 0.3s ease;
}

a:hover {
  opacity: 0.6;
}


.fw_m {
	font-weight: 500;
}

/* ダミータグを画像に追加 */
.dummy {
  position: relative;
  display: inline-block;
}

.dummy img {
  display: block;
  width: 100%;
  height: auto;
}

.dummy::after {
  content: "ダミー";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: red;
  font-size: 18px;
  font-weight: bold;
  background-color: #fff;
  padding: 5px 10px;
  border-radius: 5px;
  pointer-events: none;
}


/* 表示・非表示 */
.pc_only {
  display: block;
}

@media (max-width: 768px) {
  .pc_only {
    display: none;
  }
}

.sp_only {
  display: none;
}

@media (max-width: 768px) {
  .sp_only {
    display: block;
  }
}

html:lang(ja) .ja_only {
  display: block;
}

html:lang(ja) .ja_only.under_main-title {
  display: table;
}

html:lang(ja) .en_only {
  display: none;
}

html:lang(en) .en_only {
  display: block;
}

html:lang(en) .en_only.under_main-title {
  display: table;
}

html:lang(en) .ja_only {
  display: none;
}



/* ボタン */
.btn_typeA a {
  font-weight: 500;
}

.btn_typeA a::after {
  content: "";
  display: inline-block;
  width: 30px;
  height: 12px;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 12px;
}

.btn_typeA a:hover {
  opacity: 1;
  transition: 0.3s;
  border: 1px solid #433425;
  color: #fff;
  background-color: #433425;
}

.btn_typeA a:hover::after {
  background-image: url('/wp-content/uploads/2024/10/cmn_btn_arrow_white.svg');
}

.btn_typeA a::after {
  background-image: url('/wp-content/uploads/2024/10/cmn_btn_arrow.svg');
}

.btn_typeB a {
  border: 1px solid #433425;
}

.btn_typeB a::after {
  background-image: url('/wp-content/uploads/2024/10/cmn_btn_arrow_white.svg');
}

.btn_typeB a:hover {
  opacity: 1;
  transition: 0.3s;
  color: #433425;
  background-color: #fff !important;
}

.btn_typeB a:hover::after {
  background-image: url('/wp-content/uploads/2024/10/cmn_btn_arrow.svg');
}

.btn_typeB.reservation_page a {
  width: 400px;
  max-width: 100%;
  font-size: 22px;
}

@media (max-width: 768px) {
  .btn_typeB.reservation_page a {
    width: 100%;
  }
}


/* タイトル */
h2 {
  font-size: 28px;
}

@media (max-width: 768px) {
  h2 {
    font-size: 22px;
  }
}


h3 {
	font-size: 18px;
}


/* 整列 */
@media (max-width: 768px) {
	.sp_ta_c {
    text-align: center !important;
  }

  .sp_ta_l {
    text-align: left !important;
  }
}

/* 余白 */
@media (max-width: 768px) {
	.sp_mb_0 {
		margin-bottom: 0 !important;
	}
}




/* 共通パーツ
  ------------------------------------------ */

/* 装飾イラスト */
.top_line_illust::before {
  position: relative;
  content: "";
  display: inline-block;
  width: 100%;
  height: 31px;
  background-image: url('/wp-content/uploads/2024/10/grass-line.svg');
  background-position: center;
}

.top_line_illust_01 {
  position: absolute;
  bottom: 8px;
  left: 13%;
  margin-block-start: 0px !important;
}

.top_line_illust_02 {
  position: absolute;
  bottom: 8px;
  right: 13%;
  margin-block-start: 0px !important;
}

@media (max-width: 768px) {
  .top_line_illust_01 {
    left: 8%;
    width: 120px;
  }

  .top_line_illust_02 {
    right: 8%;
    width: 55px;
  }
}


/* ページトップボタン */
.page_top_btn {
  border-radius: 50%;
  transition: 0.3s ease;
}

@media (max-width: 768px) {
  .page_top_btn {
    bottom: 10%;
  }
}

.page_top_btn:hover {
  transition: 0.3s ease;
  transform: translateY(-5px);
  opacity: 0.8;
}


/* グーグルマップ */
.gglmap iframe {
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 6px;
  border: 1px solid #433425 !important;
}


/* 注意点 */
.caution {
  background-color: #fff;
  border-radius: 30px;
  padding: 30px 80px;
}

.caution h3 {
  margin-top: -46px !important;
  letter-spacing: 0.2em;
}

@media (max-width: 768px) {
  .caution {
    padding: 30px 34px;
  }
}



/* 共通レイアウト設定
  ------------------------------------------ */
	@media (max-width: 768px) {
		[data-unitone-layout~=container] {
			width: 100%;
			padding: 0;
		}
	}
	
	.unitone-section {
		margin-top: 0;
	}
	
	@media (max-width: 1023px) {
		.site-header {
			height: 83px;
			display: flex;
			align-items: center;
		}
	
		.site-header .header_btn_group .dropdown-button,
		.site-header .header_btn_group .reservation_btn {
			top: -18px;
			transition: none;
		}
	
		.wp-block-navigation__responsive-container .wp-block-navigation__responsive-container-content {
			display: none;
		}
	
		.wp-block-navigation__responsive-container-open:not(.always-shown) {
			display: block;
		}
	}
	


/* ハンバーガーメニュー
  ------------------------------------------ */
.logo_hamburger {
	display: none;
}

.site-header .wp-block-navigation__responsive-container {
  text-align: center;
}


@media (min-width: 1600px) {
  .site-header .wp-block-navigation__responsive-container .wp-block-navigation__container {
    gap: 48px !important;
  }
}

@media (max-width: 1599px) and (min-width: 1439px) {
  .site-header .wp-block-navigation__responsive-container .wp-block-navigation__container {
    gap: 38px !important;
  }
}

@media (max-width: 1485px) {
  .site-header .wp-block-navigation__responsive-container .wp-block-navigation__container {
    gap: 24px !important;
  }
}

.site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
  padding-top: 100px;
}

.site-header .wp-block-navigation .wp-block-navigation-item__label {
  color: #433425;
}

@media (max-width: 1023px) and (min-width: 769px) {
  .site-header .wp-block-navigation__responsive-container-close {
    left: 50%;
    top: 0;
    transform: translateX(-50%);
  }
}

@media (max-width: 1023px) {
	.site-header .wp-block-navigation-item{
		justify-content: center;
	}
  .site-header .logo_hamburger {
    display: block;
  }

  .site-header [data-unitone-layout~=gutters] {
    padding: 4px 0 !important;
  }

  .site-header .wp-block-navigation__responsive-container-close,
  .site-header .wp-block-navigation__responsive-container-open {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid #433425;
    background-color: transparent;
    transition: 0.3s;
  }

	.site-header .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-close,
	.site-header .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-open{
		position: absolute;
		top: 30px;
		left: 50%;
		transform: translateX(-50%);
		margin: 0;
	}

  .site-header .wp-block-navigation__responsive-container-close:hover,
  .site-header .wp-block-navigation__responsive-container-open:hover {
    background-color: #433425;
  }

  .site-header .wp-block-navigation__responsive-container-close:hover svg,
  .site-header .wp-block-navigation__responsive-container-open:hover svg {
    color: #fff;
  }
}




/* ヘッダー
  ------------------------------------------ */
html:lang(ja) .nav_en,
html:lang(ja) .en {
	display: none;
}

html:lang(en) .nav_ja,
html:lang(en) .ja {
	display: none;
}
	

	
@media (max-width: 1400px) and (min-width: 1079px) {
	html:lang(en) .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
		padding: 8px !important;
	}
}

@media (max-width: 1080px) and (min-width: 1023px) {
	html:lang(en) .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
		padding: 9.5px !important;
	}
}


.site-header {
	border-bottom: 1px solid #433425;
}

.site-header [data-unitone-layout~=gutters] {
	padding: 12px 0;
}

.site-header .header_logo {
	position: absolute;
}

.site-header .header_btn_group {
	position: static;
}

.site-header .header_btn .wp-block-button {
	border-left: 1px solid #433425;
}

.site-header .header_btn .wp-block-button span {
	position: relative;
	display: inline-block;
	margin-top: 5px;
}

.site-header .header_btn .wp-block-button span span {
	font-family: "Zen Kaku Gothic New", sans-serif;
}

@media (max-width: 1400px) and (min-width: 1024px) {
	.site-header .header_btn .wp-block-button span {
		margin-top: 10px;
	}
}

.site-header .wp-block-navigation__responsive-container-content ul {
	gap: 22px;
}

.site-header .wp-block-navigation__responsive-container-content ul li a {
	font-size: 14px;
}

@media (max-width: 1400px) and (min-width: 1079px) {
	.site-header .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
		max-width: 500px;
		padding-top: 8px;
		gap: 8px !important;
		justify-content: center;
	}
	
	.site-header .wp-block-navigation__responsive-container-content .wp-block-navigation__container li {
		padding: 0 10px;
	}
	
	.site-header .wp-block-navigation__responsive-container-content .wp-block-navigation__container li a {
		padding: 0 !important;
	}
}

@media (max-width: 1080px) and (min-width: 1023px) {
	.site-header .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
		max-width: 420px;
		padding-top: 7px;
		gap: 12px !important;
		justify-content: center;
	}
	
	.site-header .wp-block-navigation__responsive-container-content .wp-block-navigation__container li {
		padding: 0 5px;
	}
	
	.site-header .wp-block-navigation__responsive-container-content .wp-block-navigation__container li a {
		padding: 0 !important;
		font-size: 12px;
	}
}

.site-header .dropdown-button {
	padding: 33px 14px 18px 14px;
	height: 83px;
	position: absolute;
	top: 0;
	right: 189px;
	font-family: "Montserrat", sans-serif !important;
	font-weight: 600;
	font-size: 14px;
	background-color: #C6E0B4;
	border-left: 1px solid #433425;
}

@media (max-width: 1400px) and (min-width: 1024px) {
	.site-header .dropdown-button {
		top: -8px;
	}
}

@media (max-width: 1080px) {
	.site-header .dropdown-button {
		right: 165px !important;
	}
}

.site-header .dropdown-button::before {
	background-image: url(/wp-content/uploads/2024/10/header_btn_01.svg);
	width: 20px;
	height: 20px;
	top: 21px;
	content: '';
	display: inline-block;
	background-size: contain;
	background-repeat: no-repeat;
	vertical-align: middle;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}

@media (max-width: 1400px) and (min-width: 1024px) {
	.site-header .dropdown-button::before {
		top: 30px;
	}
}

.site-header .dropdown-button span {
	position: relative;
	display: inline-block;
	margin-top: 13px;
	font-size: 14px;
}

.site-header .dropdown-button span span {
	font-family: "Zen Kaku Gothic New", sans-serif;
}

@media (max-width: 1400px) and (min-width: 1024px) {
	.site-header .dropdown-button span {
		margin-top: 20px;
	}
}

@media (max-width: 1080px) {
	.site-header .dropdown-button span {
		font-size: 12px;
	}
}

@media (max-width: 1400px) and (min-width: 1024px) {
	.site-header .dropdown-button {
		height: 98px;
	}
}

.site-header #toggle {
	display: none;
}

.site-header .language_menu {
	visibility: hidden;
	opacity: 0;
}

.site-header label {
	cursor: pointer;
	transition: 0.3s ease;
}

.site-header label input:checked ~ .language_menu {
	visibility: visible;
	opacity: 1;
}

.site-header .language_menu {
	position: absolute;
	background-color: #fff;
	min-width: 160px;
	box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.2);
	border-radius: 5px;
	z-index: 100;
	top: 70px;
	right: -100px;
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.site-header .language_menu a {
	color: #433425;
	padding: 12px 16px;
	text-decoration: none;
	display: block;
	border-bottom: 1px solid #ddd;
	font-family: "Montserrat", "Zen Kaku Gothic New", sans-serif;
}

.site-header .language_menu a:hover {
	opacity: 0.7;
	transition: 0.3s;
}

.site-header .language_menu p:last-of-type a {
	border-bottom: none;
}

.site-header .reservation_btn {
	position: absolute;
	top: 0;
	right: 0;
	gap: 0;
	font-family: "Montserrat", sans-serif;
	font-weight: 600;
	font-size: 14px;
	margin-top: 0;
}

@media (max-width: 1400px) and (min-width: 1024px) {
	.site-header .reservation_btn {
		top: -8px;
	}
}

.site-header .reservation_btn a {
	padding: 33px 14px 18px 14px;
	height: 83px;
}

@media (max-width: 1400px) and (min-width: 1024px) {
	.site-header .reservation_btn a {
		height: 98px;
	}
}

.site-header .reservation_btn .wp-block-button span {
	font-size: 14px;
}

@media (max-width: 1080px) {
	.site-header .reservation_btn .wp-block-button span {
		font-size: 12px;
	}
}

.site-header .reservation_btn .wp-block-button a > span::before {
	content: '';
	display: inline-block;
	background-size: contain;
	background-repeat: no-repeat;
	vertical-align: middle;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
	background-image: url(/wp-content/uploads/2024/10/header_btn_02.svg);
	width: 17px;
	height: 19px;
	bottom: 28px;
}
	

html:lang(en) {
  .dropdown-button {
    right: 187px;
  }

  @media (max-width: 1400px) and (min-width: 1024px) {
    .dropdown-button {
      top: 0px;
    }
  }

  .reservation_btn {
    @media (max-width: 1400px) and (min-width: 1024px) {
      top: 0px;
    }
  }
}

.btn_group .wp-block-columns .wp-block-column:first-of-type .wp-block-buttons {
  justify-self: end;
}



@media (max-width: 768px) {
  .wp-block-site-logo img {
    width: 140px;
  }

  [data-unitone-layout~=center] {
    margin-right: initial;
  }

  .site-header {
    padding: 12px 18px;
    height: 65px;

    .header_btn_group {
      position: fixed;
      left: 0;
      bottom: 0;
      display: flex;
      z-index: 1000;
      width: 100%;
    }

    .dropdown-button {
      padding: 8px;
      height: 8vh;
      position: sticky;
      border-left: none;
      display: block;
      width: 50%;
      margin: 0px !important;
      text-align: center;
      display: flex;
      justify-content: center;
      align-items: center;
    }

    .dropdown-button:before {
      position: static;
      width: 18px;
      height: 18px;
    }

    .dropdown-button span {
      font-size: 12px;
      margin-top: 0;
    }

    .dropdown-button .language_menu {
      top: -138px;
      left: 50%;
      transform: translateX(-50%);
    }

    .dropdown-button .language_menu a {
      padding: 18px 16px;
    }

    .reservation_btn {
      position: static;
      margin: 0px !important;
      width: 50%;
      display: block;
      text-align: center;
    }

    .reservation_btn .wp-block-button {
      width: 100%;
      margin-top: 0;
      display: contents;
    }

    .reservation_btn .wp-block-button a {
      padding: 8px;
      height: 8vh;
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .reservation_btn .wp-block-button a > span {
      font-size: 12px;
      margin-top: 0;
    }

    .reservation_btn .wp-block-button a > span::before {
      position: static;
      transform: translate(0px);
      margin-right: 8px;
      vertical-align: sub;
      width: 15px;
      height: 17px;
    }

    label input:checked ~ .language_menu {
      width: fit-content;
    }
  }
}




/* フッター
  ------------------------------------------ */
.site-footer {
	.site-footer-breadcrumbs {
		display: block !important;
	}

	.wp-block-navigation {
		@media (max-width: 1330px) {
			display: block !important;
		}

		@media (max-width: 1080px) {
			.wp-block-navigation-item {
				font-size: 14px;
			}
		}

		@media (max-width: 1023px) {
			display: none !important;
		}
	}

	.footer_cta {
		padding: 60px 12px !important;
		margin-bottom: 180px;
		@media (max-width: 767px) {
			margin-bottom: 140px;
		}
	}

	.reservation_area {
		> .wp-block-group {
			@media (max-width: 767px) {
				padding-right: 24px;
				padding-left: 24px;
			}
		}
	}

	.wp-block-navigation {
		ul {
			li {
				font-weight: 600;
			}
		}
	}

	.footer_btn_area {
		width: 710px;
		max-width: 100%;
	}

	.footer_sns {
		display: table;
		margin: 0 auto;
	}

	.footer_sns img {
		border-radius: 0px;
	}

	.footer_sns a {
		svg {
			color: #fff;
			font-size: 18px;
			background-color: #433425;
			padding: 14px 12px;
			border-radius: 40px;
			margin-top: 0;
			margin-right: 15px;
		}

		&:last-of-type svg {
			margin-right: 0;
		}
	}

	.footer_line_illust {
		&::before {
			position: relative;
			content: "";
			display: inline-block;
			width: 100%;
			height: 31px;
			background-image: url('/wp-content/uploads/2024/10/grass-line.svg');
			background-position: center;
		}

		.footer_line_illust_01 {
			position: absolute;
			bottom: 13px;
			left: 13%;
			margin-block-start: 0px !important;

			@media (max-width: 768px) {
				width: 130px;
				left: 8%;
			}
		}

		.footer_line_illust_02 {
			position: absolute;
			bottom: 13px;
			right: 13%;
			margin-block-start: 0px !important;

			@media (max-width: 768px) {
				width: 95px;
				right: 8%;
			}
		}
	}

	.btn_typeA {
		@media (max-width: 767px) {
			justify-content: center;
			text-align: center;
		}
	}

	@media (max-width: 767px) {
		[data-unitone-layout~="-padding:3"] {
			padding-bottom: 100px;
		}
	}

	@media (max-width: 1330px) {
		nav {
			display: none;
		}
	}
}
	



/* キービジュアル
  ------------------------------------------ */
	.kv {
		margin-top: 0;
	}

	.kv.wp-block-cover {
		height: calc(100dvh - 83px);
		display: flex;
	}
	@media (max-width: 768px){
		.kv.wp-block-cover {
			height: calc(100dvh - 60px);
			display: flex;
		}
	}

	.kv.wp-block-cover.sp {
		display: none;
	}
	.kv.wp-block-cover.tb {
		display: none;
	}
	@media (max-width: 768px){
		.kv.wp-block-cover.tb {
			display: flex;
		}
		.kv.wp-block-cover.pc {
			display: none;
		}
	}
	@media (max-width: 430px) {
		.kv.wp-block-cover.tb {
			display: none;
		}
		.kv.wp-block-cover.sp {
			display: flex;
		}
	}
	

	.kv .wp-block-cover__image-background {
		object-position: center !important;
	}
	@media (max-width: 767px) {
		.kv.two-store .wp-block-cover__image-background {
			object-position: bottom !important;
		}
	}
	@media (max-width: 430px) {
		.kv .wp-block-cover__image-background {
			height: 100%;
		}
		.kv.two-store .wp-block-cover__image-background {
			object-position: left !important;
		}
	}
	
	.kv .kv_title {
		margin-top: -105px;
	}
	@media (max-width: 1300px){
		.kv .kv_title {
			margin-top: -130px;
		}
	}
	@media (max-width: 429px){
		.kv .kv_title {
			margin-top: -80px;
		}
	}
	

	.kv .kv_title h1{
		line-height: 1.5;
	}
	
	.kv .kv_title h1,
	.kv .kv_title p {
		letter-spacing: 0.1em;
	}
	
	.kv .wp-block-cover__inner-container {
		position: static;
	}
	
	.kv .kv_reservation-info {
		width: 370px;
		padding: 24px 36px 24px 38px;
		position: absolute !important;
		bottom: 0;
		right: 0;
		background-color: #fff;
		border-radius: 30px 0 0 0;
	}
	.wide-display{
		display: block;
	}
	@media (max-width: 1460px){
		.kv .kv_reservation-info {
			padding: 12px 0px 12px 36px;
			width: 760px;
		}
		.wide-display{
			display: none;
		}
		.post-name-home_english .kv .kv_reservation-info{
			padding: 0px 0px 12px 36px;
		}
	}
	@media (max-width: 785px){
		.kv .kv_reservation-info {
			padding: 12px 0px 12px 36px;
			width: 100%;
			border-radius: 0;
			text-align: center;
		}
		.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column.kv_info_text {
    	flex-basis: 87%!important;
		}
		.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column.kv_info_icon{
			flex-basis: 9% !important;
		}
	}
	
	
	
	.kv .kv_reservation-info p {
		letter-spacing: 0.05em;
	}
	
	.kv .kv_reservation-info p span {
		font-size: 24px;
		text-underline-offset: 8px;
		text-decoration: underline;
		text-decoration-thickness: 1px;
		margin: 0 10px;
	}
	
	.kv .kv_reservation-info:hover .circle-arrow {
		transform: translateX(5px);
	}
	
	.kv .circle-arrow {
		width: 40px;
		height: 40px;
		border: 1px solid #433425;
		border-radius: 50%;
		position: relative;
		transition: 0.3s ease;
	}
	
	.kv .circle-arrow::before {
		content: '';
		display: block;
		width: 24px;
		height: 7px;
		background-image: url('/wp-content/uploads/2024/10/arrow.svg');
		background-size: contain;
		background-repeat: no-repeat;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}

	
	@media (max-width: 767px) {
		.kv .kv_title .kv_logo {
			width: 100px !important;
		}
		.kv .wp-block-image img {
			width: 200px !important;
			border-radius: 0px !important;
		}
		.kv .kv_title h1,
		.kv .kv_title p {
			letter-spacing: 0.1em;
			text-shadow: 0 0 20px rgba(255, 255, 255, 1),
				0 0 40px rgba(255, 255, 255, 0.9),
				0 0 60px rgba(255, 255, 255, 0.8),
				0 0 80px rgba(255, 255, 255, 0.7),
				0 0 100px rgba(255, 255, 255, 0.6);
		}
	}

	.kv figure img{
		border-radius: 0;
	}
	
	.slide-in {
		transform: translateX(100%);
		animation: slide-in-animation 0.8s ease 0.5s forwards;
	}
	
	@keyframes slide-in-animation {
		from {
			transform: translateX(100%);
		}
	
		to {
			transform: translateX(0);
		}
	}



/* トップ
  ------------------------------------------ */

/* イントロ */
.top_intro {
  position: relative;
}

.top_intro h2 {
  line-height: 1.7;
}

.top_intro [data-unitone-layout~=gutters] {
  padding-bottom: 60px !important;
}

@media (max-width: 768px) {
  .top_intro .kv_reservation-info {
    background-color: #fff;
    padding: 18px 24px;
    border-radius: 30px;
    text-align: center;
  }

  .top_intro .kv_reservation-info p {
    letter-spacing: 0.05em;
  }

  .top_intro .kv_reservation-info p span {
    font-size: 24px;
    text-underline-offset: 8px;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    margin: 0 10px;
  }

  .top_intro .circle-arrow {
    width: 40px;
    height: 40px;
    display: inline-block;
    border: 1px solid #433425;
    border-radius: 50%;
    transform: translate(0px, 10px);
  }

  .top_intro .circle-arrow::before {
    width: 20px;
    height: 7px;
    content: '';
    display: block;
    background-image: url('/wp-content/uploads/2024/10/arrow.svg');
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}



/* cafe capyba でできること */
.top_usage {
  counter-reset: image-counter;
}

.top_usage .btn_typeA .wp-block-button {
  margin-top: -20px;
}

.top_usage .top_usage_contents figure {
  position: relative;
  display: inline-block;
  margin: 10px;
  overflow: hidden;
}

@media (max-width: 768px) {
  .top_usage .top_usage_contents figure {
    margin: 0;
    display: block;
  }
}

.top_usage .top_usage_contents figure::before {
  counter-increment: image-counter;
  content: counter(image-counter);
  position: absolute;
  top: 0;
  left: 0px;
  background-color: #EDEDEA;
  color: #433425;
  padding: 8px 20px;
  font-size: 18px;
  font-weight: bold;
  z-index: 1;
  border-radius: 5px 0px 5px 0;
  font-family: "Montserrat", sans-serif;
}



/* ご案内 */
.top_guidance {
  background-color: #E2E2D6;
}

.top_guidance [data-unitone-layout~=container] {
  margin-top: -232px;
}

.top_guidance [data-unitone-layout~=gutters] {
  margin-top: 120px;
}

.top_guidance .top_guidance_reservation {
  margin-right: calc(50% - 50vw);
  margin-left: 20px;
  gap: 120px;
}

@media (max-width: 768px) {
  .top_guidance .top_guidance_reservation {
    margin-right: 0;
    margin-left: 0;
    gap: 15px;
    padding: 0 24px;
  }

  .top_guidance .top_guidance_reservation h2 {
    margin-bottom: 10px !important;
  }
}

.top_guidance .top_guidance_capybara {
  margin-left: calc(50% - 50vw);
  margin-right: 20px;
  gap: 120px;
}

.top_guidance .top_guidance_capybara wp-block-column > figure {
  position: relative;
}

.top_guidance .top_guidance_capybara .top_guidance_capybara_illust {
  position: absolute;
  right: -60px;
  bottom: -70px;
}

@media (max-width: 768px) {
  .top_guidance .top_guidance_capybara {
    margin-right: 0;
    margin-left: 0;
    gap: 15px;
    padding: 0 24px;
  }

  .top_guidance .top_guidance_capybara h2 {
    margin-bottom: 10px !important;
  }

  .top_guidance .top_guidance_capybara img {
    border-top-left-radius: 20px !important;
    border-bottom-left-radius: 20px !important;
  }

  .top_guidance [data-unitone-layout~=gutters] {
    margin-top: 140px;
    padding-top: 120px;
  }

  .top_guidance .btn_typeA {
    justify-content: center;
  }

  .top_guidance .top_guidance_capybara .top_guidance_capybara_illust {
    position: absolute;
    right: -20px;
    bottom: -20px;
    width: 120px;
  }
}


/* お知らせ */
.top_news .wp-block-query h2 {
  font-size: 16px;
}

.top_news time {
  font-size: 16px;
  color: #7E7B78;
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
}

.top_news time a {
  text-decoration: none;
  color: #7E7B78;
}

.top_news .wp-block-post {
  border-bottom: 1px solid #7D7B78 !important;
}

.top_news .wp-block-post:first-of-type {
  border-top: 1px solid #7D7B78;
  padding-top: 28px !important;
}

@media (max-width: 768px) {
  .top_news [data-unitone-layout~=gutters] {
    padding-bottom: 85px;
  }

  .top_news [data-unitone-layout~=with-sidebar] {
    row-gap: 0px;
  }
}

.new-icon {
	background-color: #FDB769;
	color: #7E7B78;
	padding: 0px 10px;
	border-radius: 5px;
	margin-right: 5px;
}


/* ご利用料金・メニュー */
.top_menu .top_menu_item td:last-of-type {
  font-feature-settings: "tnum";
  font-size: 30px !important;
  font-weight: 600;
  font-family: "Montserrat", sans-serif;
  letter-spacing: -0.06em;
}

@media (max-width: 768px) {
  .top_menu .top_menu_item td:last-of-type {
    font-size: 22px !important;
  }
}

.top_menu .wp-block-table {
  position: relative;
}

.top_menu .wp-block-table tr {
  border-bottom: solid 6px #E2E2D6;
}

.top_menu .wp-block-table td {
  font-size: 18px;
  padding: 0 20px;
}

@media (max-width: 768px) {
  .top_menu .wp-block-table td {
    font-size: 16px;
    padding: 0 10px;
  }
}

.top_menu .wp-block-table tr:last-of-type {
  border-bottom: none;
}

.top_menu .tag {
  padding: 0px 12px;
  position: absolute;
  top: -28px;
  left: 0;
}

.top_menu ul li {
  list-style: none;
  margin-left: 0;
}

.top_menu ul li::before {
  content: "⚫︎";
  margin-right: 5px;
}

.top_menu .top_caution {
  padding: 30px 60px;
}

.top_menu .top_menu_capybara_illust {
  position: absolute;
  bottom: -126px;
  left: 0;
}

@media (max-width: 768px) {
  .top_menu [data-unitone-layout~=gutters] {
    padding-right: 24px;
    padding-left: 24px;
  }

  .top_menu .top_menu_item {
    margin-top: 50px;
  }

  .top_menu .wp-block-column figure {
    margin: 0 auto;
  }

  .top_menu .top_menu_capybara_illust {
    bottom: -100px;
    width: 120px;
  }
}

.insta img{
	border-radius: 20px
}

.insta [data-unitone-layout~=stack]{
	gap: 20px;
}




/* -------------------以下下層----------------------- */


/* 下層共通
  ------------------------------------------ */
.page-eyecatch {
	max-width: 100%;
}

.page-eyecatch img {
	height: auto;
	max-width: 100%;
	width: 100%;
	max-height: 500px;
	object-fit: cover;
}

@media (max-width: 768px) {
	.page-eyecatch img {
		height: 25vh;
	}
}
	

.under_main-title {
	margin-top: -64px;
	background-color: #EDEDEA;
	padding: 16px 50px;
	display: table;
	border-radius: 20px 20px 0 0;
}

@media (max-width: 768px) {
	.under_main-title {
		font-size: 22px !important;
		margin-top: -50px !important;
		background-color: #EDEDEA;
		padding: 10px 20px;
	}
}
	
.page-template-default:not(.home) main > .unitone-section>[data-unitone-layout~=gutters] {
	padding-top: 0 !important;
}

.page-template-default:not(.home) main header {
  display: none;
}

.page-template-default:not(.home) main [data-unitone-layout~=container] {
  padding-left: 0 !important;
  padding-right: 0 !important;
  width: 100%;
}

.page-template-default:not(.home) .site-contents > [data-unitone-layout~=gutters] {
  padding-top: 0;
}

.page-template-default:not(.home) .entry-content {
  padding-right: 0;
  padding-left: 0;
}

.page-template-default:not(.home) .is-layout-constrained > .alignfull {
  margin-right: 0 !important;
  margin-left: 0 !important;
  max-width: 100% !important;
}

.page-template-default:not(.home) .wrapper {
  padding: 0 48px;
  box-sizing: content-box;
}

@media (max-width: 768px) {
  .page-template-default:not(.home) .wrapper {
    padding: 0 24px !important;
  }

  .page-template-default:not(.home) .reservation_area [data-unitone-layout~=container] {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: auto;
  }
}




/* ご利用案内／店舗案内
  ------------------------------------------ */
.our-shop {
	counter-reset: image-counter;
}

.our-shop_intro [data-unitone-layout~=gutters] {
	padding-top: 40px;
}

@media (max-width: 768px) {
	.our-shop_intro [data-unitone-layout~=gutters] {
		padding-top: 20px;
		padding-bottom: 0;
	}
}

.our-shop_flow [data-unitone-layout~=gutters] {
	padding-top: 0px;
}

@media (max-width: 768px) {
	.our-shop_flow [data-unitone-layout~=gutters] {
		padding-bottom: 100px;
	}
}

.our-shop_flow_contents {
	border: 1px solid #433425;
	border-radius: 6px;
	padding: 60px 60px 60px 70px;
}

@media (max-width: 768px) {
	.our-shop_flow_contents {
		padding: 40px;
	}
}

.our-shop_flow_contents::before {
	counter-increment: image-counter;
	content: counter(image-counter);
	position: absolute;
	top: 0;
	left: 0px;
	background-color: #433425;
	color: #fff;
	padding: 8px 20px;
	font-size: 18px;
	font-weight: bold;
	z-index: 1;
	border-radius: 3px 0px 6px 0;
	font-family: "Montserrat", sans-serif;
}

.our-shop_note {
	position: relative;
}

.our-shop_note [data-unitone-layout~=container] {
	max-width: 960px;
	box-sizing: border-box;
	position: static !important;
}

.our-shop_note [data-unitone-layout~=stack] {
	position: static !important;
}

.our-shop_note ul li {
	list-style: none;
	margin-left: 0;
}

.our-shop_note ul li::before {
	content: "⚫︎";
	margin-right: 5px;
}

.our-shop_note_illust {
	position: absolute;
	top: -80px;
	left: 3vw;
}

@media (max-width: 768px) {
	.our-shop_note_illust {
		top: -70px;
		left: 0;
		width: 150px;
	}
}

.our-shop_info [data-unitone-layout~=stack__content] {
	border-bottom: 1px solid #433425;
}

.our-shop_info [data-unitone-layout~=stack__content]:first-of-type {
	border-top: 1px solid #433425;
}

.our-shop_access [data-unitone-layout~=gutters] {
	padding-top: 0px;
	padding-bottom: 40px;
}

@media (max-width: 768px) {
	.btn_group .wp-block-columns {
		justify-content: center;
	}

	.btn_group .wp-block-column:first-of-type {
		display: contents;
	}

	.btn_group .btn_typeB {
		justify-content: center;
	}

	[data-unitone-layout~=with-sidebar] {
		row-gap: 10px;
		display: block;
	}

	[data-unitone-layout~=with-sidebar__content] p {
		margin-bottom: 8px !important;
	}
}
	

/* ご予約について
  ------------------------------------------ */
.reservation_intro_message span {
	background: linear-gradient(transparent 70%, #FDB769 70%);
}

.reservation_caution {
	background-color: #fff;
	border: 20px solid #FDB769;
	padding: 40px 90px;
}

@media (max-width: 768px) {
	.reservation_caution {
		padding: 24px;
	}

	.reservation_caution .wp-block-image img {
		width: 90px;
		border-radius: 0;
	}
}

.reservation_caution_title {
	font-weight: 900;
	font-size: 22px;
}

.reservation_caution_title span {
	font-size: 36px;
}

@media (max-width: 768px) {
	.reservation_caution_title {
		font-size: 18px;
	}

	.reservation_caution_title span {
		font-size: 28px;
	}
}

.reservation_caution_title-text p {
	font-size: 18px;
	font-weight: bold;
	border-bottom: dashed 2px #C6C1BD;
	padding: 10px 0;
}

.reservation_caution_title-text p:first-of-type {
	border-top: dashed 2px #C6C1BD;
}

@media (max-width: 768px) {
	.reservation_caution_title-text p {
		font-size: 16px;
		text-align: left;
	}
}

.reservation_caution_list {
	list-style: none;
}

.reservation_caution_list li {
	margin-bottom: 20px;
	margin-left: 0;
}

.reservation_caution_list li::before {
	content: "";
	background-image: url(/wp-content/uploads/2024/11/reservation_caution_text_icon.svg);
	background-repeat: no-repeat;
	background-size: contain;
	display: inline-block;
	width: 57px;
	height: 27px;
	margin-right: 10px;
	vertical-align: middle;
}

@media (max-width: 768px) {
	.reservation_caution_list li::before {
		width: 32px;
	}
}

.reservation_caution_list li.indent {
	padding-left: 4.2em;
	text-indent: -4.2em;
}

@media (max-width: 768px) {
	.reservation_caution_list li.indent {
		padding-left: 2.6em;
		text-indent: -2.6em;
	}
}

.reservation_caution_list span {
	color: #FDB769;
	font-weight: 900;
	font-size: 18px;
}

.reservation_contents {
	position: relative;
	z-index: 1;
}

.reservation_contents::before {
	content: "";
	position: absolute;
	top: 10%;
	left: 62%;
	right: 0;
	bottom: 0;
	background-color: #E2E2D6;
	z-index: -1;
	height: 58%;
}

@media (max-width: 768px) {
	.reservation_contents::before {
		height: 24%;
		top: 58%;
		left: 0;
	}

	.reservation_contents [data-unitone-layout~=gutters] {
		margin-top: 60px;
	}
}

.reservation_img01 {
	position: relative;
}

.reservation_img01 .reservation_illust {
	position: absolute;
	bottom: -18px;
	left: -25px;
}

@media (max-width: 768px) {
	.reservation_img01 .reservation_illust {
		width: 130px;
	}
}
	
.post-name-reservation_english .reservation_area,
.post-name-reservation .reservation_area {
  display: none;
}

/* 吹き出しのコンテナ */
.speech-bubble {
  position: relative;
 
  border-radius: 8px;
  padding: 15px;
	max-width: 300px;
  margin-right: auto;
}

.speech-bubble.orange_bubble{
	background: #fdb769;
}

.speech-bubble.green_bubble{
	background: #C6E0B4;
}

.speech-bubble::after {
  content: '';
  position: absolute;
  bottom: -20px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-width: 10px;
}

.speech-bubble::before {
	content: '';
	position: absolute;
	bottom: -30px;
	left: 40px;
	transform: translateX(-50%);
	border-width: 18px;
	border-style: solid;
	z-index: 1;
}

.speech-bubble.orange_bubble::before{
	border-color: #fdb769 transparent transparent transparent;
}

.speech-bubble.green_bubble::before{
	border-color: #C6E0B4 transparent transparent transparent;
}


/* 会社概要
  ------------------------------------------ */
	.company .company_contents {
		position: relative;
		z-index: 1;
	}

	.company .company_contents:before {
		content: "";
		position: absolute;
		top: 10%;
		left: 62%;
		right: 0;
		bottom: 0;
		background-color: #E2E2D6;
		z-index: -1;
		height: 80%;
	}
	
	@media (max-width: 768px) {
		.company .company_contents:before {
			height: 25%;
			top: 75%;
			left: 0;
		}
	
		.company .company_contents [data-unitone-layout~=gutters] {
			padding-top: 20px;
		}
	}

	.company figure.company_table{
		display: block;
		width: 100%;
	}
	
	.company .company_table th,
	.company .company_table td {
		font-size: 14px;
		padding: 12px 14px;
	}
	
	@media (max-width: 768px) {
		.company .company_table td {
			padding: 10px 0;
			padding: 10px 12px 10px 0;
		}
	}
	
	.company .company_table.achievements td:first-of-type {
		width: 12%;
	}
	
	@media (max-width: 768px) {
		.company .company_table.achievements td:first-of-type {
			width: 25%;
		}
	}
	
	.company .company_table.sign td:first-of-type {
		width: 25%;
	}
	
	@media (max-width: 768px) {
		.company .company_table.sign td:first-of-type {
			width: 45%;
		}
	}
	
	.company .company_illust_01 {
		position: absolute;
		top: -77px;
		right: 0;
	}
	
	.company .company_illust_01 img {
		border-radius: 0;
	}
	
	@media (max-width: 768px) {
		.company .company_illust_01 {
			top: -36px;
			width: 160px;
		}
	}
	


/* カピバラさんの紹介
  ------------------------------------------ */
.capybaras #capybaras_intro [data-unitone-layout~=container] {
	box-sizing: content-box;
	margin-left: auto;
	margin-right: auto;
	max-width: 100%;
	padding-left: var(--unitone--gutters) !important;
	padding-right: var(--unitone--gutters) !important;
	width: min(100% - var(--unitone--gutters) * 2, var(--unitone--max-width));
}

.capybaras_intro_01 {
	margin-right: calc(50% - 50vw);
	margin-left: 20px;
	gap: 120px !important;
}

@media (max-width: 768px) {
	.capybaras_intro_01 {
		margin-right: 0;
		margin-left: 0;
		gap: 30px;
		padding-right: 24px;
		padding-left: 24px;
        gap: 30px !important;
	}
}

.capybaras_profile_01 ruby {
	font-size: 60px;
}

.capybaras_profile_01 rt {
	font-size: 0.26em;
	margin-bottom: 5px;
	font-weight: 500;
	margin-left: -8px;
}

.capybaras_profile_01 rt::before {
	content: " ";
	margin-right: 1.3em;
}

.capybaras_profile_01 rt::after {
	content: " ";
	margin-left: 0.5em;
}

.capybaras_profile_01 h3 {
	padding: 12px 5px;
	background-color: #FDB769;
	text-align: center;
	border-radius: 30px;
	line-height: 1.4;
}

@media (max-width: 768px) {
	.capybaras_profile_01 ruby {
		font-size: 40px;
	}

	.capybaras_profile_01 rt {
		font-size: 12px;
		margin-left: -10px;
	}
}

.capybaras_name_01::after {
	content: "";
	display: inline-block;
	width: 60px;
	height: 84px;
	margin-left: 20px;
	background-image: url(/wp-content/uploads/2024/10/footer_illust_02.svg);
	background-size: contain;
	vertical-align: bottom;
	background-repeat: no-repeat;
}

@media (max-width: 768px) {
	.capybaras_name_01::after {
		width: 50px;
		height: 64px;
	}

	.capybaras_name_01 {
		text-align: center;
	}
}

.capybaras_profile_02 h2 {
	font-size: 60px;
}

.capybaras_profile_02 h3 {
	padding: 12px 5px;
	background-color: #C6E0B4;
	text-align: center;
	border-radius: 30px;
	line-height: 1.4;
}

.capybaras_name_02::after {
	content: "";
	display: inline-block;
	width: 100px;
	height: 70px;
	margin-left: 20px;
	background-image: url(/wp-content/uploads/2024/12/footer_illust_01.svg);
	background-size: contain;
	vertical-align: bottom;
	background-repeat: no-repeat;
}

@media (max-width: 768px) {
	.capybaras_name_02::after {
		width: 70px;
		height: 54px;
	}

	.capybaras_name_02 {
		text-align: center;
	}

	.capybaras_profile_01,
	.capybaras_profile_02 {
		.wp-block-image {
			width: 70%;
			margin: 0 auto;
		}

		.wp-block-columns {
			gap: 10px;
		}

		h2 {
			&.capybaras_name_01,
			&.capybaras_name_02 {
				font-size: 40px;
			}
		}
	}
}

.capybaras .distinguish {
  background-color: #fff;
  border-radius: 20px;
  padding: 60px 40px;
}

.capybaras .distinguish h2 {
  margin-top: -85px;
}

.capybaras .distinguish .kohaku .name,
.capybaras .distinguish .pisuke .name {
  font-size: 22px;
  padding: 6px 30px;
  text-align: center;
  border-radius: 30px;
  display: table;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .capybaras .distinguish .kohaku .name,
  .capybaras .distinguish .pisuke .name {
    font-size: 18px;
    padding: 3px 24px;
  }
}

.capybaras .distinguish .kohaku .name {
  background-color: #FDB769;
}

.capybaras .distinguish .pisuke .name {
  background-color: #C6E0B4;
}


.capybaras .time-line::before {
  content: "";
  width: 2px;
  height: 93%;
  background-image: linear-gradient(to bottom, #433425 50%, transparent 0%);
  background-size: 2px 10px;
  position: absolute;
  top: 150px;
  left: 50%;
  transform: translateX(-50%);
}

@media (max-width: 768px) {
  .capybaras .time-line::before {
    display: none;
  }
}

.capybaras .time-line_item {
  gap: 140px !important;
}

@media (max-width: 768px) {
  .capybaras .time-line_item {
    gap: 10px !important;
    margin-bottom: 80px !important;
  }

  .capybaras .time-line_item:last-of-type {
    margin-bottom: 0 !important;
  }
}

.capybaras .time-line_item .capybaras_illust_01 {
  position: absolute;
  bottom: -20px;
  right: -80px;
}

@media (max-width: 768px) {
  .capybaras .time-line_item .capybaras_illust_01 {
    right: -10px;
    width: 100px;
  }
}

.capybaras .time-line_item .capybaras_illust_02 {
  position: absolute;
  bottom: -20px;
  left: -80px;
}

@media (max-width: 768px) {
  .capybaras .time-line_item .capybaras_illust_02 {
    bottom: -8px;
    left: -22px;
    width: 100px;
  }
}

.capybaras .time-line_item .capybaras_illust_03 {
  position: absolute;
  bottom: -20px;
  left: -80px;
}

@media (max-width: 768px) {
  .capybaras .time-line_item .capybaras_illust_03 {
    left: -20px;
    bottom: -3px;
    width: 130px;
  }
}

.capybaras .time-line_item::before {
  content: "";
  width: 150px;
  height: 150px;
  background: #FDB769;
  position: absolute;
  border-radius: 50%;
  top: 70px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
}

.capybaras .time-line_item::after {
  font-family: "Montserrat", sans-serif;
  font-size: 40px;
  color: #fff;
  font-weight: bold;
  position: absolute;
  top: 110px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 101;
}

@media (max-width: 768px) {
  .capybaras .time-line_item::before {
    width: 100px;
    height: 100px;
    top: -45px;
    left: 30px;
  }

  .capybaras .time-line_item::after {
    font-size: 28px;
    top: -18px;
    left: 30px;
  }
}

.capybaras .time-line_item:first-of-type::after {
  content: "8:30";
}

.capybaras .time-line_item:nth-of-type(2)::before {
  top: 80px;
}

.capybaras .time-line_item:nth-of-type(2)::after {
  top: 120px;
  content: "9:00";
}

@media (max-width: 768px) {
  .capybaras .time-line_item:nth-of-type(2)::before {
    top: -45px;
  }

  .capybaras .time-line_item:nth-of-type(2)::after {
    top: -18px;
  }
}

.capybaras .time-line_item:nth-of-type(3)::after {
  content: "9:20";
}

.capybaras .time-line_item:nth-of-type(4)::after {
  content: "11:00";
}

.capybaras .time-line_item:nth-of-type(5)::after {
  content: "13:00";
}

.capybaras .time-line_item:nth-of-type(6)::after {
  content: "14:00";
}

.capybaras .time-line_item:nth-of-type(7)::after {
  content: "15:30";
}

.capybaras .time-line_item:nth-of-type(8)::after {
  content: "16:30";
}

.capybaras .time-line_item:nth-of-type(9)::after {
  content: "18:00";
}

.capybaras .time-line_item:nth-of-type(10)::after {
  content: "18:30";
}

.capybaras .time-line_item:nth-of-type(11)::after {
  content: "19:00";
}

.capybaras .slide_gallery {
  display: flex;
  align-items: center;
  overflow: hidden;
  gap: 0 !important;
  padding: 0 !important;
  position: relative;
}

.capybaras .slide_gallery figure.wp-block-gallery {
  max-width: fit-content !important;
}

.capybaras .wp-block-gallery {
  flex-wrap: nowrap;
  gap: 20px !important;
}

.capybaras [data-unitone-layout~=stack]{
	gap: 20px;
}

.capybaras .wp-block-gallery .wp-block-image {
  width: 275px !important;
}

@media (max-width: 768px) {
  .capybaras .wp-block-gallery .wp-block-image {
    width: 155px !important;
  }
}

.capybaras .slide_gallery.first .wp-block-gallery {
  animation: loop-slide_toleft 45s infinite linear both;
  animation-fill-mode: forwards;
  margin-left: 20px;
}

.capybaras .slide_gallery.second .wp-block-gallery {
  animation: loop-slide_toright 45s infinite linear both;
  animation-fill-mode: forwards;
  margin-right: 20px;
}



@keyframes loop-slide_toleft {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-100%);
	}
}

@keyframes loop-slide_toright {
	from {
		transform: translateX(-100%);
	}
	to {
		transform: translateX(0);
	}
}

html:lang(en) {
	.capybaras_profile_01 {
		h2 {
			font-size: 60px;
		}
	}
}



/* オリジナルグッズ
  ------------------------------------------ */
.goods .fukidashi img {
	position: relative;
}

.goods .fukidashi p {
	font-size: 18px;
	position: absolute;
	top: 42%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.goods .unitone-section:first-of-type > [data-unitone-layout~=gutters] {
	padding-top: 40px;
	padding-bottom: 100px;
}

.goods .goods_contents {
	padding-bottom: 250px !important;
}

@media (max-width: 768px) {
	.goods .goods_contents {
		padding-bottom: 120px !important;
	}

	.goods .unitone-section > [data-unitone-layout~=gutters] {
		padding-bottom: 0px;
	}

	.goods .contents_section > [data-unitone-layout~=gutters]{
		padding-bottom: 0px !important;
	}

	.goods .goods_illust_01 {
		top: -80px;
		right: 40px;
		width: 160px;
	}

	.goods .goods_item_grid .wp-block-columns:last-of-type .wp-block-column:last-of-type {
		margin-bottom: 10%;
	}
}

.goods .goods_illust_01 {
	position: absolute;
	top: -90px;
	right: 120px;
}

.goods .goods_illust_02 {
	position: absolute;
	bottom: -40px;
	left: 50%;
	transform: translateX(-50%);
	width: clamp(400px, 70vw, 640px);
}
	

.pum-content {
  padding: 20px;
  display: flex;
  gap: 50px;
  flex-direction: row;
}

.pum-content .large-image-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.pum-content .large-image {
  width: 300px;
  margin-bottom: 15px;
}

.pum-content .large-image img {
  width: 100%;
  height: auto;
  border-radius: 10px;
}

.pum-content .thumbnails {
  display: flex;
  justify-content: space-between;
  width: 100%;
}

.pum-content .thumbnails img {
  width: 85px;
  cursor: pointer;
  transition: transform 0.3s ease;
  border-radius: 10px;
}

.pum-content .thumbnails img:hover {
  transform: scale(1.1);
}

.pum-content .info {
  flex: 1;
  text-align: left;
}

.pum-content .explanation_text {
  padding-bottom: 20px;
  border-bottom: 2px solid #433425;
}

.pum-content .explanation_text + p {
  padding-top: 20px;
}



/* 採用情報
  ------------------------------------------ */
.recruit {
	counter-reset: image-counter;
}

.recruit #recruit_intro [data-unitone-layout~=container] {
	box-sizing: content-box;
	margin-left: auto;
	margin-right: auto;
	max-width: 100%;
	padding-left: var(--unitone--gutters) !important;
	padding-right: var(--unitone--gutters) !important;
	width: min(100% - var(--unitone--gutters) * 2, var(--unitone--max-width));
}

@media (min-width: 768px) {
	.recruit .wp-block-columns {
			flex-wrap: nowrap !important;
	}
}

@media (min-width: 768px){
	.recruit #recruit_intro .recruit_intro_01 img{
		border-radius: 20px 0px 0px 20px;
	}
	.recruit #recruit_intro .recruit_intro_02 img{
		border-radius: 0px 20px 20px 0px;
	}
}

.recruit #recruit_intro .recruit_intro_01 {
	margin-right: calc(50% - 50vw);
	margin-left: 20px;
	gap: 120px;
}


@media (max-width: 768px) {
	.recruit #recruit_intro .recruit_intro_01 {
		margin-right: 0;
		margin-left: 0;
		gap: 30px;
	}
}

.recruit #recruit_intro .recruit_intro_02 {
	margin-left: calc(50% - 50vw);
	margin-right: 20px;
	gap: 120px;
}

@media (max-width: 768px) {
	.recruit #recruit_intro .recruit_intro_02 {
		margin-right: 0;
		margin-left: 0;
		gap: 30px;
		margin-bottom: 60px !important;
	}
}

.recruit [data-unitone-layout~=container],
.recruit [data-unitone-layout~=stack] {
	position: static;
}

.recruit .recruit_illust_05 {
	position: absolute;
	top: -200px;
	right: 15%;
}

@media (max-width: 768px) {
	.recruit .recruit_illust_05 {
		top: -90px;
		right: 8%;
		width: 100px;
	}
}

.recruit .job-description {
	border-radius: 10px;
	border: 1px solid #433425;
	background-color: #fff;
}

.recruit .job-description .unitone-flex__content {
	border-bottom: 1px solid #433425;
}

.recruit .job-description .unitone-flex__content:last-of-type,
.recruit .job-description .unitone-flex__content:nth-last-of-type(2) {
	border-bottom: none;
}

.recruit .job-description .unitone-flex__content:nth-last-of-type(2) {
	border-radius: 0 0 0 10px;
}

@media (max-width: 768px) {
	.recruit .job-description .unitone-flex__content {
		flex-basis: 100%;
		padding-top: 20px;
		padding-bottom: 48px;
	}

	.recruit .job-description .unitone-flex__content:nth-last-of-type(2) {
		border-bottom: 1px solid #433425;
		border-radius: 0;
	}
}

.recruit .job-description .job-description_head {
	border-right: 1px solid #433425;
	background-color: #F0EFEE;
	margin: 0;
	display: flex;
	flex-direction: column;
	justify-content: center !important;
}

.recruit .job-description .job-description_head:first-of-type {
	border-radius: 10px 0 0 0;
}

.recruit .job-description .job-description_head.radius_lower-left {
	border-radius: 0 0 0 10px;
	border-bottom: none;
}

@media (max-width: 768px) {
	.recruit .job-description .job-description_head {
		flex-basis: 100%;
		border-right: none;
		padding: 12px 24px;
	}

	.recruit .job-description .job-description_head:first-of-type {
		border-radius: 10px 10px 0 0;
	}
}

.recruit .unitone-flex[data-unitone-layout~="-divider:bordered"] > :before {
	display: none;
}

.recruit .tab {
	display: flex;
	flex-wrap: wrap;
}

.recruit .tab > label {
	flex: 1 1;
	order: -1;
	min-width: 70px;
	padding: .7em 1em .5em;
	background-color: #EDEDEA;
	color: #433425;
	font-weight: 600;
	font-size: .9em;
	text-align: center;
	cursor: pointer;
	margin-block-start: auto;
	opacity: 0.8;
	border-radius: 30px;
}

.recruit .tab > label:hover {
	opacity: .6;
}

.recruit .tab input {
	display: none;
}

.recruit .tab label:has(:checked) {
	opacity: 1;
	background-color: #433425;
	color: #ffffff;
	transition: 0.3s;
}

.recruit .tab label:has(:checked).first ~ div.part-time {
	display: flex;
	width: 100%;
}

.recruit .tab label:has(:checked).second ~ div.full-time {
	display: flex;
	width: 100%;
}

.recruit .tab .not_recruiting {
	width: 100%;
	padding: 160px 0;
}

.recruit .recruit_flow_contents {
	border: 1px solid #433425;
	border-radius: 6px;
	padding: 60px 60px 60px 70px;
}

@media (max-width: 768px) {
	.recruit .recruit_flow_contents {
		padding: 40px;
	}

	.recruit .recruit_flow_contents h3 {
		text-align: center;
	}
}

.recruit .recruit_flow_contents figure img {
	border-radius: 0;
}

.recruit .recruit_flow_contents::before {
	counter-increment: image-counter;
	content: counter(image-counter);
	position: absolute;
	top: 0;
	left: 0px;
	background-color: #433425;
	color: #fff;
	padding: 8px 20px;
	font-size: 18px;
	font-weight: bold;
	z-index: 1;
	border-radius: 3px 0px 6px 0;
	font-family: "Montserrat", sans-serif;
}
	


/* お知らせ
  ------------------------------------------ */
.blog .under_main-title,
.archive .under_main-title {
	margin: -64px auto;
}

.blog .blog_item,
.archive .blog_item {
	position: relative;
}

.blog .blog_item .taxonomy-category,
.archive .blog_item .taxonomy-category {
	position: absolute;
	top: 18px;
	left: 18px;
}

.blog .blog_item .taxonomy-category a,
.archive .blog_item .taxonomy-category a {
	color: #FDB769;
	background-color: #fff;
	border-radius: 6px;
	border: none;
	font-weight: bold;
}

.blog .blog_item .wp-block-post-date,
.archive .blog_item .wp-block-post-date {
	font-family: "Montserrat", sans-serif;
	font-weight: 500;
}

.blog .wp-block-query-pagination,
.archive .wp-block-query-pagination {
	font-family: "Montserrat", sans-serif;
}

.blog .wp-block-query-pagination .wp-block-query-pagination-numbers,
.archive .wp-block-query-pagination .wp-block-query-pagination-numbers {
	font-size: 18px;
	font-weight: 500;
	color: #433425;
}

.blog .wp-block-query-pagination .wp-block-query-pagination-numbers .current,
.archive .wp-block-query-pagination .wp-block-query-pagination-numbers .current {
	color: inherit;
	position: relative;
}

.blog .wp-block-query-pagination .wp-block-query-pagination-numbers .current::after,
.archive .wp-block-query-pagination .wp-block-query-pagination-numbers .current::after {
	content: "";
	position: absolute;
	bottom: 4px;
	display: block;
	width: 43%;
	height: 7px;
	background-color: #FDB769;
}

.blog .wp-block-query-pagination-next-arrow,
.blog .wp-block-query-pagination-previous-arrow,
.archive .wp-block-query-pagination-next-arrow,
.archive .wp-block-query-pagination-previous-arrow {
	font-size: 0;
}

.blog .wp-block-query-pagination-next,
.blog .wp-block-query-pagination-previous,
.archive .wp-block-query-pagination-next,
.archive .wp-block-query-pagination-previous {
	position: relative;
}

.blog .wp-block-query-pagination-next::after,
.blog .wp-block-query-pagination-previous::after,
.archive .wp-block-query-pagination-next::after,
.archive .wp-block-query-pagination-previous::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 60%;
	transform: translate(-50%, -50%);
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background-color: #FDB769;
	z-index: 1;
}

.blog .wp-block-query-pagination-next::before,
.blog .wp-block-query-pagination-previous::before,
.archive .wp-block-query-pagination-next::before,
.archive .wp-block-query-pagination-previous::before {
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	position: absolute;
	left: 50%;
	top: 60%;
	transform: translate(-50%, -50%);
	color: #ffffff;
	font-size: 1em;
	z-index: 2;
}

.blog .wp-block-query-pagination-next::before,
.archive .wp-block-query-pagination-next::before {
	content: "\f054";
}

.blog .wp-block-query-pagination-previous::before,
.archive .wp-block-query-pagination-previous::before {
	content: "\f053";
}

.blog .wp-block-post-title,
.archive .wp-block-post-title{
margin-top: -10px !important;
}

.blog [data-unitone-layout~=stack],
.archive [data-unitone-layout~=stack]{
	gap: 10px !important;
}

@media (max-width: 768px) {
	.blog .page-eyecatch img,
	.archive .page-eyecatch img {
		object-position: left;
	}
	
	.blog .wp-block-template-part,
	.archive .wp-block-template-part{
		padding-top: 12px;
	}
}


.single .movepost {
	justify-content: center;
	gap: 40px;
}

.single .movepost a {
	text-decoration: none;
	color: #433425;
}

.single .wp-block-post-date {
	font-family: "Montserrat", sans-serif;
}

.single .taxonomy-category a {
	text-decoration: none;
	background-color: #FDB769;
	color: #fff;
	padding: 3px 12px;
	border-radius: 20px;
	font-weight: 500;
}

.single .wp-block-post-navigation-link a {
	position: relative;
}

.single .wp-block-post-navigation-link a::after {
	content: "";
	position: absolute;
	top: 60%;
	transform: translate(-50%, -50%);
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background-color: #FDB769;
	z-index: 1;
}

.single .wp-block-post-navigation-link a::before {
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	position: absolute;
	top: 60%;
	transform: translate(-50%, -50%);
	color: #ffffff;
	font-size: 1em;
	z-index: 2;
}

.single .wp-block-post-navigation-link.post-navigation-link-next a::after {
	left: 180%;
}

.single .wp-block-post-navigation-link.post-navigation-link-next a::before {
	content: "\f054";
	left: 180%;
}

.single .wp-block-post-navigation-link.post-navigation-link-previous a::after {
	right: 75%;
}

.single .wp-block-post-navigation-link.post-navigation-link-previous a::before {
	content: "\f053";
	right: 160%;
}

@media (max-width: 768px) {
	.single h1 {
		font-size: 20px !important;
	}

	.single .post_title_section {
		padding: 0 24px;
	}

	.single [data-unitone-layout~="-padding:3"][data-unitone-layout~=gutters] {
		padding-top: 30px;
	}
}
	

html:lang(en) .single .post-navigation-link-previous a::before {
  content: "\f053";
  right: 120%;
}



/* お問い合わせ
  ------------------------------------------ */
.wpcf7-form input,
.wpcf7-form textarea {
	width: 100%;
}

.wpcf7-form input[type="checkbox"] {
	width: auto;
}

.wpcf7-form > p {
	margin-bottom: 20px;
}

.wpcf7-form .wpcf7-list-item {
	margin-left: 0;
}

.wpcf7-form .text-danger {
	color: #dc3232;
}

.wpcf7-form input[type="submit"] {
	color: #fff;
	background-color: #433425;
	border: none;
	cursor: pointer;
	font-weight: bold;
}

.wpcf7-form input[type="submit"]:hover {
	color: #433425;
	background-color: #fff;
	border: 1px solid #433425;
}






/*  -----------------202050929~追加分----------------- */

@media (max-width: 768px){
	.header_btn_group {
		position: fixed;
		left: 0;
		bottom: 0;
		display: flex;
		z-index: 1000;
		width: 100%;
		transform: translateY(100%);
		transition: transform 0.3s ease;
	}

	.header_btn_group.is-visible {
		transform: translateY(0);
	}
}


.post-name-our-shop .footer_cta,
.post-name-reservation .footer_cta,
.post-name-our-shop_english .footer_cta{
	display: none;
}

.border-bottom_none{
	border-bottom: none !important;
}


:root :where(.is-layout-constrained:not([data-unitone-layout~=text]))>:where(:not(:is(:last-child,h2,h3,h4,h5,h6))), [data-unitone-layout~=text]:where([data-unitone-layout~=-gap])>:where(:not(:is(:last-child,h2,h3,h4,h5,h6))) {
    margin-block-end: 0;
}

@media (min-width: 1400px){
	.site-header [data-unitone-layout~=gutters]{
		padding: 20.5px 0;
	}
}

.page-eyecatch{
	margin-block-end:0;
}

.pb_0 > [data-unitone-layout~=gutters]{
	padding-bottom: 0 !important;
}

